From c4fbdd98c4abcadfb642438ce691fb45dc70c0db Mon Sep 17 00:00:00 2001 From: Stefan Dirix Date: Tue, 15 Oct 2024 14:28:11 +0200 Subject: [PATCH] [lumino] lumino patch Adds the patch for Lumino which achieves the following: - Make sure listeners are registered on the correct document. This is necessary for secondary window support. - Make sure empty menus can be opened. This is required as Theia fills menus right before they are shown, so they seem to be empty. Contributed on behalf of STMicroelectronics --- .../cli/patches/@lumino+widgets+2.5.0.patch | 167 ++++++++++++++++++ 1 file changed, 167 insertions(+) create mode 100644 dev-packages/cli/patches/@lumino+widgets+2.5.0.patch diff --git a/dev-packages/cli/patches/@lumino+widgets+2.5.0.patch b/dev-packages/cli/patches/@lumino+widgets+2.5.0.patch new file mode 100644 index 0000000000000..bbfe28bfc3378 --- /dev/null +++ b/dev-packages/cli/patches/@lumino+widgets+2.5.0.patch @@ -0,0 +1,167 @@ +diff --git a/node_modules/@lumino/widgets/dist/index.es6.js b/node_modules/@lumino/widgets/dist/index.es6.js +index c6bd869..ec2c392 100644 +--- a/node_modules/@lumino/widgets/dist/index.es6.js ++++ b/node_modules/@lumino/widgets/dist/index.es6.js +@@ -6527,7 +6527,7 @@ class Menu extends Widget { + this.node.addEventListener('mouseenter', this); + this.node.addEventListener('mouseleave', this); + this.node.addEventListener('contextmenu', this); +- document.addEventListener('mousedown', this, true); ++ this.node.ownerDocument.addEventListener('mousedown', this, true); + } + /** + * A message handler invoked on an `'after-detach'` message. +@@ -6539,7 +6539,7 @@ class Menu extends Widget { + this.node.removeEventListener('mouseenter', this); + this.node.removeEventListener('mouseleave', this); + this.node.removeEventListener('contextmenu', this); +- document.removeEventListener('mousedown', this, true); ++ this.node.ownerDocument.removeEventListener('mousedown', this, true); + } + /** + * A message handler invoked on an `'activate-request'` message. +@@ -7305,7 +7305,7 @@ var Private$9; + style.opacity = '0'; + style.maxHeight = `${maxHeight}px`; + // Attach the menu to the document. +- Widget.attach(submenu, document.body); ++ Widget.attach(submenu, itemNode.ownerDocument.body); + // Measure the size of the menu. + let { width, height } = node.getBoundingClientRect(); + // Compute the box sizing for the menu. +@@ -13198,10 +13198,6 @@ class MenuBar extends Widget { + if (value < 0 || value >= this._menus.length) { + value = -1; + } +- // An empty menu cannot be active +- if (value > -1 && this._menus[value].items.length === 0) { +- value = -1; +- } + // Bail early if the index will not change. + if (this._activeIndex === value) { + return; +diff --git a/node_modules/@lumino/widgets/dist/index.es6.js.map b/node_modules/@lumino/widgets/dist/index.es6.js.map +index be4059b..2158c77 100644 +--- a/node_modules/@lumino/widgets/dist/index.es6.js.map ++++ b/node_modules/@lumino/widgets/dist/index.es6.js.map +@@ -1 +1 @@ +-{"version":3,"file":"index.es6.js","sources":["../src/boxengine.ts","../src/title.ts","../src/widget.ts","../src/layout.ts","../src/panellayout.ts","../src/utils.ts","../src/splitlayout.ts","../src/accordionlayout.ts","../src/panel.ts","../src/splitpanel.ts","../src/accordionpanel.ts","../src/boxlayout.ts","../src/boxpanel.ts","../src/commandpalette.ts","../src/menu.ts","../src/contextmenu.ts","../src/tabbar.ts","../src/docklayout.ts","../src/dockpanel.ts","../src/focustracker.ts","../src/gridlayout.ts","../src/menubar.ts","../src/scrollbar.ts","../src/singletonlayout.ts","../src/stackedlayout.ts","../src/stackedpanel.ts","../src/tabpanel.ts"],"sourcesContent":["// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\n\n/**\n * A sizer object for use with the box engine layout functions.\n *\n * #### Notes\n * A box sizer holds the geometry information for an object along an\n * arbitrary layout orientation.\n *\n * For best performance, this class should be treated as a raw data\n * struct. It should not typically be subclassed.\n */\nexport class BoxSizer {\n /**\n * The preferred size for the sizer.\n *\n * #### Notes\n * The sizer will be given this initial size subject to its size\n * bounds. The sizer will not deviate from this size unless such\n * deviation is required to fit into the available layout space.\n *\n * There is no limit to this value, but it will be clamped to the\n * bounds defined by {@link minSize} and {@link maxSize}.\n *\n * The default value is `0`.\n */\n sizeHint = 0;\n\n /**\n * The minimum size of the sizer.\n *\n * #### Notes\n * The sizer will never be sized less than this value, even if\n * it means the sizer will overflow the available layout space.\n *\n * It is assumed that this value lies in the range `[0, Infinity)`\n * and that it is `<=` to {@link maxSize}. Failure to adhere to this\n * constraint will yield undefined results.\n *\n * The default value is `0`.\n */\n minSize = 0;\n\n /**\n * The maximum size of the sizer.\n *\n * #### Notes\n * The sizer will never be sized greater than this value, even if\n * it means the sizer will underflow the available layout space.\n *\n * It is assumed that this value lies in the range `[0, Infinity]`\n * and that it is `>=` to {@link minSize}. Failure to adhere to this\n * constraint will yield undefined results.\n *\n * The default value is `Infinity`.\n */\n maxSize = Infinity;\n\n /**\n * The stretch factor for the sizer.\n *\n * #### Notes\n * This controls how much the sizer stretches relative to its sibling\n * sizers when layout space is distributed. A stretch factor of zero\n * is special and will cause the sizer to only be resized after all\n * other sizers with a stretch factor greater than zero have been\n * resized to their limits.\n *\n * It is assumed that this value is an integer that lies in the range\n * `[0, Infinity)`. Failure to adhere to this constraint will yield\n * undefined results.\n *\n * The default value is `1`.\n */\n stretch = 1;\n\n /**\n * The computed size of the sizer.\n *\n * #### Notes\n * This value is the output of a call to {@link BoxEngine.calc}. It represents\n * the computed size for the object along the layout orientation,\n * and will always lie in the range `[minSize, maxSize]`.\n *\n * This value is output only.\n *\n * Changing this value will have no effect.\n */\n size = 0;\n\n /**\n * An internal storage property for the layout algorithm.\n *\n * #### Notes\n * This value is used as temporary storage by the layout algorithm.\n *\n * Changing this value will have no effect.\n */\n done = false;\n}\n\n/**\n * The namespace for the box engine layout functions.\n */\nexport namespace BoxEngine {\n /**\n * Calculate the optimal layout sizes for a sequence of box sizers.\n *\n * This distributes the available layout space among the box sizers\n * according to the following algorithm:\n *\n * 1. Initialize the sizers's size to its size hint and compute the\n * sums for each of size hint, min size, and max size.\n *\n * 2. If the total size hint equals the available space, return.\n *\n * 3. If the available space is less than the total min size, set all\n * sizers to their min size and return.\n *\n * 4. If the available space is greater than the total max size, set\n * all sizers to their max size and return.\n *\n * 5. If the layout space is less than the total size hint, distribute\n * the negative delta as follows:\n *\n * a. Shrink each sizer with a stretch factor greater than zero by\n * an amount proportional to the negative space and the sum of\n * stretch factors. If the sizer reaches its min size, remove\n * it and its stretch factor from the computation.\n *\n * b. If after adjusting all stretch sizers there remains negative\n * space, distribute the space equally among the sizers with a\n * stretch factor of zero. If a sizer reaches its min size,\n * remove it from the computation.\n *\n * 6. If the layout space is greater than the total size hint,\n * distribute the positive delta as follows:\n *\n * a. Expand each sizer with a stretch factor greater than zero by\n * an amount proportional to the postive space and the sum of\n * stretch factors. If the sizer reaches its max size, remove\n * it and its stretch factor from the computation.\n *\n * b. If after adjusting all stretch sizers there remains positive\n * space, distribute the space equally among the sizers with a\n * stretch factor of zero. If a sizer reaches its max size,\n * remove it from the computation.\n *\n * 7. return\n *\n * @param sizers - The sizers for a particular layout line.\n *\n * @param space - The available layout space for the sizers.\n *\n * @returns The delta between the provided available space and the\n * actual consumed space. This value will be zero if the sizers\n * can be adjusted to fit, negative if the available space is too\n * small, and positive if the available space is too large.\n *\n * #### Notes\n * The {@link BoxSizer.size} of each sizer is updated with the computed size.\n *\n * This function can be called at any time to recompute the layout for\n * an existing sequence of sizers. The previously computed results will\n * have no effect on the new output. It is therefore not necessary to\n * create new sizer objects on each resize event.\n */\n export function calc(sizers: ArrayLike, space: number): number {\n // Bail early if there is nothing to do.\n let count = sizers.length;\n if (count === 0) {\n return space;\n }\n\n // Setup the size and stretch counters.\n let totalMin = 0;\n let totalMax = 0;\n let totalSize = 0;\n let totalStretch = 0;\n let stretchCount = 0;\n\n // Setup the sizers and compute the totals.\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n let min = sizer.minSize;\n let max = sizer.maxSize;\n let hint = sizer.sizeHint;\n sizer.done = false;\n sizer.size = Math.max(min, Math.min(hint, max));\n totalSize += sizer.size;\n totalMin += min;\n totalMax += max;\n if (sizer.stretch > 0) {\n totalStretch += sizer.stretch;\n stretchCount++;\n }\n }\n\n // If the space is equal to the total size, return early.\n if (space === totalSize) {\n return 0;\n }\n\n // If the space is less than the total min, minimize each sizer.\n if (space <= totalMin) {\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n sizer.size = sizer.minSize;\n }\n return space - totalMin;\n }\n\n // If the space is greater than the total max, maximize each sizer.\n if (space >= totalMax) {\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n sizer.size = sizer.maxSize;\n }\n return space - totalMax;\n }\n\n // The loops below perform sub-pixel precision sizing. A near zero\n // value is used for compares instead of zero to ensure that the\n // loop terminates when the subdivided space is reasonably small.\n let nearZero = 0.01;\n\n // A counter which is decremented each time a sizer is resized to\n // its limit. This ensures the loops terminate even if there is\n // space remaining to distribute.\n let notDoneCount = count;\n\n // Distribute negative delta space.\n if (space < totalSize) {\n // Shrink each stretchable sizer by an amount proportional to its\n // stretch factor. If a sizer reaches its min size it's marked as\n // done. The loop progresses in phases where each sizer is given\n // a chance to consume its fair share for the pass, regardless of\n // whether a sizer before it reached its limit. This continues\n // until the stretchable sizers or the free space is exhausted.\n let freeSpace = totalSize - space;\n while (stretchCount > 0 && freeSpace > nearZero) {\n let distSpace = freeSpace;\n let distStretch = totalStretch;\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n if (sizer.done || sizer.stretch === 0) {\n continue;\n }\n let amt = (sizer.stretch * distSpace) / distStretch;\n if (sizer.size - amt <= sizer.minSize) {\n freeSpace -= sizer.size - sizer.minSize;\n totalStretch -= sizer.stretch;\n sizer.size = sizer.minSize;\n sizer.done = true;\n notDoneCount--;\n stretchCount--;\n } else {\n freeSpace -= amt;\n sizer.size -= amt;\n }\n }\n }\n // Distribute any remaining space evenly among the non-stretchable\n // sizers. This progresses in phases in the same manner as above.\n while (notDoneCount > 0 && freeSpace > nearZero) {\n let amt = freeSpace / notDoneCount;\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n if (sizer.done) {\n continue;\n }\n if (sizer.size - amt <= sizer.minSize) {\n freeSpace -= sizer.size - sizer.minSize;\n sizer.size = sizer.minSize;\n sizer.done = true;\n notDoneCount--;\n } else {\n freeSpace -= amt;\n sizer.size -= amt;\n }\n }\n }\n }\n // Distribute positive delta space.\n else {\n // Expand each stretchable sizer by an amount proportional to its\n // stretch factor. If a sizer reaches its max size it's marked as\n // done. The loop progresses in phases where each sizer is given\n // a chance to consume its fair share for the pass, regardless of\n // whether a sizer before it reached its limit. This continues\n // until the stretchable sizers or the free space is exhausted.\n let freeSpace = space - totalSize;\n while (stretchCount > 0 && freeSpace > nearZero) {\n let distSpace = freeSpace;\n let distStretch = totalStretch;\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n if (sizer.done || sizer.stretch === 0) {\n continue;\n }\n let amt = (sizer.stretch * distSpace) / distStretch;\n if (sizer.size + amt >= sizer.maxSize) {\n freeSpace -= sizer.maxSize - sizer.size;\n totalStretch -= sizer.stretch;\n sizer.size = sizer.maxSize;\n sizer.done = true;\n notDoneCount--;\n stretchCount--;\n } else {\n freeSpace -= amt;\n sizer.size += amt;\n }\n }\n }\n // Distribute any remaining space evenly among the non-stretchable\n // sizers. This progresses in phases in the same manner as above.\n while (notDoneCount > 0 && freeSpace > nearZero) {\n let amt = freeSpace / notDoneCount;\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n if (sizer.done) {\n continue;\n }\n if (sizer.size + amt >= sizer.maxSize) {\n freeSpace -= sizer.maxSize - sizer.size;\n sizer.size = sizer.maxSize;\n sizer.done = true;\n notDoneCount--;\n } else {\n freeSpace -= amt;\n sizer.size += amt;\n }\n }\n }\n }\n\n // Indicate that the consumed space equals the available space.\n return 0;\n }\n\n /**\n * Adjust a sizer by a delta and update its neighbors accordingly.\n *\n * @param sizers - The sizers which should be adjusted.\n *\n * @param index - The index of the sizer to grow.\n *\n * @param delta - The amount to adjust the sizer, positive or negative.\n *\n * #### Notes\n * This will adjust the indicated sizer by the specified amount, along\n * with the sizes of the appropriate neighbors, subject to the limits\n * specified by each of the sizers.\n *\n * This is useful when implementing box layouts where the boundaries\n * between the sizers are interactively adjustable by the user.\n */\n export function adjust(\n sizers: ArrayLike,\n index: number,\n delta: number\n ): void {\n // Bail early when there is nothing to do.\n if (sizers.length === 0 || delta === 0) {\n return;\n }\n\n // Dispatch to the proper implementation.\n if (delta > 0) {\n growSizer(sizers, index, delta);\n } else {\n shrinkSizer(sizers, index, -delta);\n }\n }\n\n /**\n * Grow a sizer by a positive delta and adjust neighbors.\n */\n function growSizer(\n sizers: ArrayLike,\n index: number,\n delta: number\n ): void {\n // Compute how much the items to the left can expand.\n let growLimit = 0;\n for (let i = 0; i <= index; ++i) {\n let sizer = sizers[i];\n growLimit += sizer.maxSize - sizer.size;\n }\n\n // Compute how much the items to the right can shrink.\n let shrinkLimit = 0;\n for (let i = index + 1, n = sizers.length; i < n; ++i) {\n let sizer = sizers[i];\n shrinkLimit += sizer.size - sizer.minSize;\n }\n\n // Clamp the delta adjustment to the limits.\n delta = Math.min(delta, growLimit, shrinkLimit);\n\n // Grow the sizers to the left by the delta.\n let grow = delta;\n for (let i = index; i >= 0 && grow > 0; --i) {\n let sizer = sizers[i];\n let limit = sizer.maxSize - sizer.size;\n if (limit >= grow) {\n sizer.sizeHint = sizer.size + grow;\n grow = 0;\n } else {\n sizer.sizeHint = sizer.size + limit;\n grow -= limit;\n }\n }\n\n // Shrink the sizers to the right by the delta.\n let shrink = delta;\n for (let i = index + 1, n = sizers.length; i < n && shrink > 0; ++i) {\n let sizer = sizers[i];\n let limit = sizer.size - sizer.minSize;\n if (limit >= shrink) {\n sizer.sizeHint = sizer.size - shrink;\n shrink = 0;\n } else {\n sizer.sizeHint = sizer.size - limit;\n shrink -= limit;\n }\n }\n }\n\n /**\n * Shrink a sizer by a positive delta and adjust neighbors.\n */\n function shrinkSizer(\n sizers: ArrayLike,\n index: number,\n delta: number\n ): void {\n // Compute how much the items to the right can expand.\n let growLimit = 0;\n for (let i = index + 1, n = sizers.length; i < n; ++i) {\n let sizer = sizers[i];\n growLimit += sizer.maxSize - sizer.size;\n }\n\n // Compute how much the items to the left can shrink.\n let shrinkLimit = 0;\n for (let i = 0; i <= index; ++i) {\n let sizer = sizers[i];\n shrinkLimit += sizer.size - sizer.minSize;\n }\n\n // Clamp the delta adjustment to the limits.\n delta = Math.min(delta, growLimit, shrinkLimit);\n\n // Grow the sizers to the right by the delta.\n let grow = delta;\n for (let i = index + 1, n = sizers.length; i < n && grow > 0; ++i) {\n let sizer = sizers[i];\n let limit = sizer.maxSize - sizer.size;\n if (limit >= grow) {\n sizer.sizeHint = sizer.size + grow;\n grow = 0;\n } else {\n sizer.sizeHint = sizer.size + limit;\n grow -= limit;\n }\n }\n\n // Shrink the sizers to the left by the delta.\n let shrink = delta;\n for (let i = index; i >= 0 && shrink > 0; --i) {\n let sizer = sizers[i];\n let limit = sizer.size - sizer.minSize;\n if (limit >= shrink) {\n sizer.sizeHint = sizer.size - shrink;\n shrink = 0;\n } else {\n sizer.sizeHint = sizer.size - limit;\n shrink -= limit;\n }\n }\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { VirtualElement } from '@lumino/virtualdom';\n\n/**\n * An object which holds data related to an object's title.\n *\n * #### Notes\n * A title object is intended to hold the data necessary to display a\n * header for a particular object. A common example is the `TabPanel`,\n * which uses the widget title to populate the tab for a child widget.\n *\n * It is the responsibility of the owner to call the title disposal.\n */\nexport class Title implements IDisposable {\n /**\n * Construct a new title.\n *\n * @param options - The options for initializing the title.\n */\n constructor(options: Title.IOptions) {\n this.owner = options.owner;\n if (options.label !== undefined) {\n this._label = options.label;\n }\n if (options.mnemonic !== undefined) {\n this._mnemonic = options.mnemonic;\n }\n if (options.icon !== undefined) {\n this._icon = options.icon;\n }\n\n if (options.iconClass !== undefined) {\n this._iconClass = options.iconClass;\n }\n if (options.iconLabel !== undefined) {\n this._iconLabel = options.iconLabel;\n }\n if (options.caption !== undefined) {\n this._caption = options.caption;\n }\n if (options.className !== undefined) {\n this._className = options.className;\n }\n if (options.closable !== undefined) {\n this._closable = options.closable;\n }\n this._dataset = options.dataset || {};\n }\n\n /**\n * A signal emitted when the state of the title changes.\n */\n get changed(): ISignal {\n return this._changed;\n }\n\n /**\n * The object which owns the title.\n */\n readonly owner: T;\n\n /**\n * Get the label for the title.\n *\n * #### Notes\n * The default value is an empty string.\n */\n get label(): string {\n return this._label;\n }\n\n /**\n * Set the label for the title.\n */\n set label(value: string) {\n if (this._label === value) {\n return;\n }\n this._label = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the mnemonic index for the title.\n *\n * #### Notes\n * The default value is `-1`.\n */\n get mnemonic(): number {\n return this._mnemonic;\n }\n\n /**\n * Set the mnemonic index for the title.\n */\n set mnemonic(value: number) {\n if (this._mnemonic === value) {\n return;\n }\n this._mnemonic = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the icon renderer for the title.\n *\n * #### Notes\n * The default value is undefined.\n */\n get icon(): VirtualElement.IRenderer | undefined {\n return this._icon;\n }\n\n /**\n * Set the icon renderer for the title.\n *\n * #### Notes\n * A renderer is an object that supplies a render and unrender function.\n */\n set icon(value: VirtualElement.IRenderer | undefined) {\n if (this._icon === value) {\n return;\n }\n this._icon = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the icon class name for the title.\n *\n * #### Notes\n * The default value is an empty string.\n */\n get iconClass(): string {\n return this._iconClass;\n }\n\n /**\n * Set the icon class name for the title.\n *\n * #### Notes\n * Multiple class names can be separated with whitespace.\n */\n set iconClass(value: string) {\n if (this._iconClass === value) {\n return;\n }\n this._iconClass = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the icon label for the title.\n *\n * #### Notes\n * The default value is an empty string.\n */\n get iconLabel(): string {\n return this._iconLabel;\n }\n\n /**\n * Set the icon label for the title.\n *\n * #### Notes\n * Multiple class names can be separated with whitespace.\n */\n set iconLabel(value: string) {\n if (this._iconLabel === value) {\n return;\n }\n this._iconLabel = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the caption for the title.\n *\n * #### Notes\n * The default value is an empty string.\n */\n get caption(): string {\n return this._caption;\n }\n\n /**\n * Set the caption for the title.\n */\n set caption(value: string) {\n if (this._caption === value) {\n return;\n }\n this._caption = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the extra class name for the title.\n *\n * #### Notes\n * The default value is an empty string.\n */\n get className(): string {\n return this._className;\n }\n\n /**\n * Set the extra class name for the title.\n *\n * #### Notes\n * Multiple class names can be separated with whitespace.\n */\n set className(value: string) {\n if (this._className === value) {\n return;\n }\n this._className = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the closable state for the title.\n *\n * #### Notes\n * The default value is `false`.\n */\n get closable(): boolean {\n return this._closable;\n }\n\n /**\n * Set the closable state for the title.\n *\n * #### Notes\n * This controls the presence of a close icon when applicable.\n */\n set closable(value: boolean) {\n if (this._closable === value) {\n return;\n }\n this._closable = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the dataset for the title.\n *\n * #### Notes\n * The default value is an empty dataset.\n */\n get dataset(): Title.Dataset {\n return this._dataset;\n }\n\n /**\n * Set the dataset for the title.\n *\n * #### Notes\n * This controls the data attributes when applicable.\n */\n set dataset(value: Title.Dataset) {\n if (this._dataset === value) {\n return;\n }\n this._dataset = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Test whether the title has been disposed.\n */\n get isDisposed(): boolean {\n return this._isDisposed;\n }\n\n /**\n * Dispose of the resources held by the title.\n *\n * #### Notes\n * It is the responsibility of the owner to call the title disposal.\n */\n dispose(): void {\n if (this.isDisposed) {\n return;\n }\n this._isDisposed = true;\n\n Signal.clearData(this);\n }\n\n private _label = '';\n private _caption = '';\n private _mnemonic = -1;\n private _icon: VirtualElement.IRenderer | undefined = undefined;\n private _iconClass = '';\n private _iconLabel = '';\n private _className = '';\n private _closable = false;\n private _dataset: Title.Dataset;\n private _changed = new Signal(this);\n private _isDisposed = false;\n}\n\n/**\n * The namespace for the `Title` class statics.\n */\nexport namespace Title {\n /**\n * A type alias for a simple immutable string dataset.\n */\n export type Dataset = { readonly [key: string]: string };\n\n /**\n * An options object for initializing a title.\n */\n export interface IOptions {\n /**\n * The object which owns the title.\n */\n owner: T;\n\n /**\n * The label for the title.\n */\n label?: string;\n\n /**\n * The mnemonic index for the title.\n */\n mnemonic?: number;\n\n /**\n * The icon renderer for the title.\n */\n icon?: VirtualElement.IRenderer;\n\n /**\n * The icon class name for the title.\n */\n iconClass?: string;\n\n /**\n * The icon label for the title.\n */\n iconLabel?: string;\n\n /**\n * The caption for the title.\n */\n caption?: string;\n\n /**\n * The extra class name for the title.\n */\n className?: string;\n\n /**\n * The closable state for the title.\n */\n closable?: boolean;\n\n /**\n * The dataset for the title.\n */\n dataset?: Dataset;\n }\n}\n","/* eslint-disable @typescript-eslint/no-empty-function */\n// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { IObservableDisposable } from '@lumino/disposable';\n\nimport {\n ConflatableMessage,\n IMessageHandler,\n Message,\n MessageLoop\n} from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { Layout } from './layout';\n\nimport { Title } from './title';\n\n/**\n * The base class of the lumino widget hierarchy.\n *\n * #### Notes\n * This class will typically be subclassed in order to create a useful\n * widget. However, it can be used directly to host externally created\n * content.\n */\nexport class Widget implements IMessageHandler, IObservableDisposable {\n /**\n * Construct a new widget.\n *\n * @param options - The options for initializing the widget.\n */\n constructor(options: Widget.IOptions = {}) {\n this.node = Private.createNode(options);\n this.addClass('lm-Widget');\n }\n\n /**\n * Dispose of the widget and its descendant widgets.\n *\n * #### Notes\n * It is unsafe to use the widget after it has been disposed.\n *\n * All calls made to this method after the first are a no-op.\n */\n dispose(): void {\n // Do nothing if the widget is already disposed.\n if (this.isDisposed) {\n return;\n }\n\n // Set the disposed flag and emit the disposed signal.\n this.setFlag(Widget.Flag.IsDisposed);\n this._disposed.emit(undefined);\n\n // Remove or detach the widget if necessary.\n if (this.parent) {\n this.parent = null;\n } else if (this.isAttached) {\n Widget.detach(this);\n }\n\n // Dispose of the widget layout.\n if (this._layout) {\n this._layout.dispose();\n this._layout = null;\n }\n\n // Dispose the title\n this.title.dispose();\n\n // Clear the extra data associated with the widget.\n Signal.clearData(this);\n MessageLoop.clearData(this);\n AttachedProperty.clearData(this);\n }\n\n /**\n * A signal emitted when the widget is disposed.\n */\n get disposed(): ISignal {\n return this._disposed;\n }\n\n /**\n * Get the DOM node owned by the widget.\n */\n readonly node: HTMLElement;\n\n /**\n * Test whether the widget has been disposed.\n */\n get isDisposed(): boolean {\n return this.testFlag(Widget.Flag.IsDisposed);\n }\n\n /**\n * Test whether the widget's node is attached to the DOM.\n */\n get isAttached(): boolean {\n return this.testFlag(Widget.Flag.IsAttached);\n }\n\n /**\n * Test whether the widget is explicitly hidden.\n */\n get isHidden(): boolean {\n return this.testFlag(Widget.Flag.IsHidden);\n }\n\n /**\n * Test whether the widget is visible.\n *\n * #### Notes\n * A widget is visible when it is attached to the DOM, is not\n * explicitly hidden, and has no explicitly hidden ancestors.\n */\n get isVisible(): boolean {\n return this.testFlag(Widget.Flag.IsVisible);\n }\n\n /**\n * The title object for the widget.\n *\n * #### Notes\n * The title object is used by some container widgets when displaying\n * the widget alongside some title, such as a tab panel or side bar.\n *\n * Since not all widgets will use the title, it is created on demand.\n *\n * The `owner` property of the title is set to this widget.\n */\n get title(): Title {\n return Private.titleProperty.get(this);\n }\n\n /**\n * Get the id of the widget's DOM node.\n */\n get id(): string {\n return this.node.id;\n }\n\n /**\n * Set the id of the widget's DOM node.\n */\n set id(value: string) {\n this.node.id = value;\n }\n\n /**\n * The dataset for the widget's DOM node.\n */\n get dataset(): DOMStringMap {\n return this.node.dataset;\n }\n\n /**\n * Get the method for hiding the widget.\n */\n get hiddenMode(): Widget.HiddenMode {\n return this._hiddenMode;\n }\n\n /**\n * Set the method for hiding the widget.\n */\n set hiddenMode(value: Widget.HiddenMode) {\n if (this._hiddenMode === value) {\n return;\n }\n\n if (this.isHidden) {\n // Reset styles set by previous mode.\n this._toggleHidden(false);\n }\n\n if (value == Widget.HiddenMode.Scale) {\n this.node.style.willChange = 'transform';\n } else {\n this.node.style.willChange = 'auto';\n }\n\n this._hiddenMode = value;\n\n if (this.isHidden) {\n // Set styles for new mode.\n this._toggleHidden(true);\n }\n }\n\n /**\n * Get the parent of the widget.\n */\n get parent(): Widget | null {\n return this._parent;\n }\n\n /**\n * Set the parent of the widget.\n *\n * #### Notes\n * Children are typically added to a widget by using a layout, which\n * means user code will not normally set the parent widget directly.\n *\n * The widget will be automatically removed from its old parent.\n *\n * This is a no-op if there is no effective parent change.\n */\n set parent(value: Widget | null) {\n if (this._parent === value) {\n return;\n }\n if (value && this.contains(value)) {\n throw new Error('Invalid parent widget.');\n }\n if (this._parent && !this._parent.isDisposed) {\n let msg = new Widget.ChildMessage('child-removed', this);\n MessageLoop.sendMessage(this._parent, msg);\n }\n this._parent = value;\n if (this._parent && !this._parent.isDisposed) {\n let msg = new Widget.ChildMessage('child-added', this);\n MessageLoop.sendMessage(this._parent, msg);\n }\n if (!this.isDisposed) {\n MessageLoop.sendMessage(this, Widget.Msg.ParentChanged);\n }\n }\n\n /**\n * Get the layout for the widget.\n */\n get layout(): Layout | null {\n return this._layout;\n }\n\n /**\n * Set the layout for the widget.\n *\n * #### Notes\n * The layout is single-use only. It cannot be changed after the\n * first assignment.\n *\n * The layout is disposed automatically when the widget is disposed.\n */\n set layout(value: Layout | null) {\n if (this._layout === value) {\n return;\n }\n if (this.testFlag(Widget.Flag.DisallowLayout)) {\n throw new Error('Cannot set widget layout.');\n }\n if (this._layout) {\n throw new Error('Cannot change widget layout.');\n }\n if (value!.parent) {\n throw new Error('Cannot change layout parent.');\n }\n this._layout = value;\n value!.parent = this;\n }\n\n /**\n * Create an iterator over the widget's children.\n *\n * @returns A new iterator over the children of the widget.\n *\n * #### Notes\n * The widget must have a populated layout in order to have children.\n *\n * If a layout is not installed, the returned iterator will be empty.\n */\n *children(): IterableIterator {\n if (this._layout) {\n yield* this._layout;\n }\n }\n\n /**\n * Test whether a widget is a descendant of this widget.\n *\n * @param widget - The descendant widget of interest.\n *\n * @returns `true` if the widget is a descendant, `false` otherwise.\n */\n contains(widget: Widget): boolean {\n for (let value: Widget | null = widget; value; value = value._parent) {\n if (value === this) {\n return true;\n }\n }\n return false;\n }\n\n /**\n * Test whether the widget's DOM node has the given class name.\n *\n * @param name - The class name of interest.\n *\n * @returns `true` if the node has the class, `false` otherwise.\n */\n hasClass(name: string): boolean {\n return this.node.classList.contains(name);\n }\n\n /**\n * Add a class name to the widget's DOM node.\n *\n * @param name - The class name to add to the node.\n *\n * #### Notes\n * If the class name is already added to the node, this is a no-op.\n *\n * The class name must not contain whitespace.\n */\n addClass(name: string): void {\n this.node.classList.add(name);\n }\n\n /**\n * Remove a class name from the widget's DOM node.\n *\n * @param name - The class name to remove from the node.\n *\n * #### Notes\n * If the class name is not yet added to the node, this is a no-op.\n *\n * The class name must not contain whitespace.\n */\n removeClass(name: string): void {\n this.node.classList.remove(name);\n }\n\n /**\n * Toggle a class name on the widget's DOM node.\n *\n * @param name - The class name to toggle on the node.\n *\n * @param force - Whether to force add the class (`true`) or force\n * remove the class (`false`). If not provided, the presence of\n * the class will be toggled from its current state.\n *\n * @returns `true` if the class is now present, `false` otherwise.\n *\n * #### Notes\n * The class name must not contain whitespace.\n */\n toggleClass(name: string, force?: boolean): boolean {\n if (force === true) {\n this.node.classList.add(name);\n return true;\n }\n if (force === false) {\n this.node.classList.remove(name);\n return false;\n }\n return this.node.classList.toggle(name);\n }\n\n /**\n * Post an `'update-request'` message to the widget.\n *\n * #### Notes\n * This is a simple convenience method for posting the message.\n */\n update(): void {\n MessageLoop.postMessage(this, Widget.Msg.UpdateRequest);\n }\n\n /**\n * Post a `'fit-request'` message to the widget.\n *\n * #### Notes\n * This is a simple convenience method for posting the message.\n */\n fit(): void {\n MessageLoop.postMessage(this, Widget.Msg.FitRequest);\n }\n\n /**\n * Post an `'activate-request'` message to the widget.\n *\n * #### Notes\n * This is a simple convenience method for posting the message.\n */\n activate(): void {\n MessageLoop.postMessage(this, Widget.Msg.ActivateRequest);\n }\n\n /**\n * Send a `'close-request'` message to the widget.\n *\n * #### Notes\n * This is a simple convenience method for sending the message.\n */\n close(): void {\n MessageLoop.sendMessage(this, Widget.Msg.CloseRequest);\n }\n\n /**\n * Show the widget and make it visible to its parent widget.\n *\n * #### Notes\n * This causes the {@link isHidden} property to be `false`.\n *\n * If the widget is not explicitly hidden, this is a no-op.\n */\n show(): void {\n if (!this.testFlag(Widget.Flag.IsHidden)) {\n return;\n }\n if (this.isAttached && (!this.parent || this.parent.isVisible)) {\n MessageLoop.sendMessage(this, Widget.Msg.BeforeShow);\n }\n this.clearFlag(Widget.Flag.IsHidden);\n this._toggleHidden(false);\n\n if (this.isAttached && (!this.parent || this.parent.isVisible)) {\n MessageLoop.sendMessage(this, Widget.Msg.AfterShow);\n }\n if (this.parent) {\n let msg = new Widget.ChildMessage('child-shown', this);\n MessageLoop.sendMessage(this.parent, msg);\n }\n }\n\n /**\n * Hide the widget and make it hidden to its parent widget.\n *\n * #### Notes\n * This causes the {@link isHidden} property to be `true`.\n *\n * If the widget is explicitly hidden, this is a no-op.\n */\n hide(): void {\n if (this.testFlag(Widget.Flag.IsHidden)) {\n return;\n }\n if (this.isAttached && (!this.parent || this.parent.isVisible)) {\n MessageLoop.sendMessage(this, Widget.Msg.BeforeHide);\n }\n this.setFlag(Widget.Flag.IsHidden);\n this._toggleHidden(true);\n\n if (this.isAttached && (!this.parent || this.parent.isVisible)) {\n MessageLoop.sendMessage(this, Widget.Msg.AfterHide);\n }\n if (this.parent) {\n let msg = new Widget.ChildMessage('child-hidden', this);\n MessageLoop.sendMessage(this.parent, msg);\n }\n }\n\n /**\n * Show or hide the widget according to a boolean value.\n *\n * @param hidden - `true` to hide the widget, or `false` to show it.\n *\n * #### Notes\n * This is a convenience method for `hide()` and `show()`.\n */\n setHidden(hidden: boolean): void {\n if (hidden) {\n this.hide();\n } else {\n this.show();\n }\n }\n\n /**\n * Test whether the given widget flag is set.\n *\n * #### Notes\n * This will not typically be called directly by user code.\n */\n testFlag(flag: Widget.Flag): boolean {\n return (this._flags & flag) !== 0;\n }\n\n /**\n * Set the given widget flag.\n *\n * #### Notes\n * This will not typically be called directly by user code.\n */\n setFlag(flag: Widget.Flag): void {\n this._flags |= flag;\n }\n\n /**\n * Clear the given widget flag.\n *\n * #### Notes\n * This will not typically be called directly by user code.\n */\n clearFlag(flag: Widget.Flag): void {\n this._flags &= ~flag;\n }\n\n /**\n * Process a message sent to the widget.\n *\n * @param msg - The message sent to the widget.\n *\n * #### Notes\n * Subclasses may reimplement this method as needed.\n */\n processMessage(msg: Message): void {\n switch (msg.type) {\n case 'resize':\n this.notifyLayout(msg);\n this.onResize(msg as Widget.ResizeMessage);\n break;\n case 'update-request':\n this.notifyLayout(msg);\n this.onUpdateRequest(msg);\n break;\n case 'fit-request':\n this.notifyLayout(msg);\n this.onFitRequest(msg);\n break;\n case 'before-show':\n this.notifyLayout(msg);\n this.onBeforeShow(msg);\n break;\n case 'after-show':\n this.setFlag(Widget.Flag.IsVisible);\n this.notifyLayout(msg);\n this.onAfterShow(msg);\n break;\n case 'before-hide':\n this.notifyLayout(msg);\n this.onBeforeHide(msg);\n break;\n case 'after-hide':\n this.clearFlag(Widget.Flag.IsVisible);\n this.notifyLayout(msg);\n this.onAfterHide(msg);\n break;\n case 'before-attach':\n this.notifyLayout(msg);\n this.onBeforeAttach(msg);\n break;\n case 'after-attach':\n if (!this.isHidden && (!this.parent || this.parent.isVisible)) {\n this.setFlag(Widget.Flag.IsVisible);\n }\n this.setFlag(Widget.Flag.IsAttached);\n this.notifyLayout(msg);\n this.onAfterAttach(msg);\n break;\n case 'before-detach':\n this.notifyLayout(msg);\n this.onBeforeDetach(msg);\n break;\n case 'after-detach':\n this.clearFlag(Widget.Flag.IsVisible);\n this.clearFlag(Widget.Flag.IsAttached);\n this.notifyLayout(msg);\n this.onAfterDetach(msg);\n break;\n case 'activate-request':\n this.notifyLayout(msg);\n this.onActivateRequest(msg);\n break;\n case 'close-request':\n this.notifyLayout(msg);\n this.onCloseRequest(msg);\n break;\n case 'child-added':\n this.notifyLayout(msg);\n this.onChildAdded(msg as Widget.ChildMessage);\n break;\n case 'child-removed':\n this.notifyLayout(msg);\n this.onChildRemoved(msg as Widget.ChildMessage);\n break;\n default:\n this.notifyLayout(msg);\n break;\n }\n }\n\n /**\n * Invoke the message processing routine of the widget's layout.\n *\n * @param msg - The message to dispatch to the layout.\n *\n * #### Notes\n * This is a no-op if the widget does not have a layout.\n *\n * This will not typically be called directly by user code.\n */\n protected notifyLayout(msg: Message): void {\n if (this._layout) {\n this._layout.processParentMessage(msg);\n }\n }\n\n /**\n * A message handler invoked on a `'close-request'` message.\n *\n * #### Notes\n * The default implementation unparents or detaches the widget.\n */\n protected onCloseRequest(msg: Message): void {\n if (this.parent) {\n this.parent = null;\n } else if (this.isAttached) {\n Widget.detach(this);\n }\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onResize(msg: Widget.ResizeMessage): void {}\n\n /**\n * A message handler invoked on an `'update-request'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onUpdateRequest(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onFitRequest(msg: Message): void {}\n\n /**\n * A message handler invoked on an `'activate-request'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onActivateRequest(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'before-show'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onBeforeShow(msg: Message): void {}\n\n /**\n * A message handler invoked on an `'after-show'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onAfterShow(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'before-hide'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onBeforeHide(msg: Message): void {}\n\n /**\n * A message handler invoked on an `'after-hide'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onAfterHide(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onBeforeAttach(msg: Message): void {}\n\n /**\n * A message handler invoked on an `'after-attach'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onAfterAttach(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'before-detach'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onBeforeDetach(msg: Message): void {}\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onAfterDetach(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'child-added'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onChildAdded(msg: Widget.ChildMessage): void {}\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {}\n\n private _toggleHidden(hidden: boolean) {\n if (hidden) {\n switch (this._hiddenMode) {\n case Widget.HiddenMode.Display:\n this.addClass('lm-mod-hidden');\n break;\n case Widget.HiddenMode.Scale:\n this.node.style.transform = 'scale(0)';\n this.node.setAttribute('aria-hidden', 'true');\n break;\n case Widget.HiddenMode.ContentVisibility:\n // @ts-expect-error content-visibility unknown by DOM lib types\n this.node.style.contentVisibility = 'hidden';\n this.node.style.zIndex = '-1';\n break;\n }\n } else {\n switch (this._hiddenMode) {\n case Widget.HiddenMode.Display:\n this.removeClass('lm-mod-hidden');\n break;\n case Widget.HiddenMode.Scale:\n this.node.style.transform = '';\n this.node.removeAttribute('aria-hidden');\n break;\n case Widget.HiddenMode.ContentVisibility:\n // @ts-expect-error content-visibility unknown by DOM lib types\n this.node.style.contentVisibility = '';\n this.node.style.zIndex = '';\n break;\n }\n }\n }\n\n private _flags = 0;\n private _layout: Layout | null = null;\n private _parent: Widget | null = null;\n private _disposed = new Signal(this);\n private _hiddenMode: Widget.HiddenMode = Widget.HiddenMode.Display;\n}\n\n/**\n * The namespace for the `Widget` class statics.\n */\nexport namespace Widget {\n /**\n * An options object for initializing a widget.\n */\n export interface IOptions {\n /**\n * The optional node to use for the widget.\n *\n * If a node is provided, the widget will assume full ownership\n * and control of the node, as if it had created the node itself.\n *\n * The default is a new `
`.\n */\n node?: HTMLElement;\n\n /**\n * The optional element tag, used for constructing the widget's node.\n *\n * If a pre-constructed node is provided via the `node` arg, this\n * value is ignored.\n */\n tag?: keyof HTMLElementTagNameMap;\n }\n\n /**\n * The method for hiding the widget.\n *\n * The default is Display.\n *\n * Using `Scale` will often increase performance as most browsers will not\n * trigger style computation for the `transform` action. This should be used\n * sparingly and tested, since increasing the number of composition layers\n * may slow things down.\n *\n * To ensure the transformation does not trigger style recomputation, you\n * may need to set the widget CSS style `will-change: transform`. This\n * should be used only when needed as it may overwhelm the browser with a\n * high number of layers. See\n * https://developer.mozilla.org/en-US/docs/Web/CSS/will-change\n */\n export enum HiddenMode {\n /**\n * Set a `lm-mod-hidden` CSS class to hide the widget using `display:none`\n * CSS from the standard Lumino CSS.\n */\n Display = 0,\n\n /**\n * Hide the widget by setting the `transform` to `'scale(0)'`.\n */\n Scale,\n\n /**\n *Hide the widget by setting the `content-visibility` to `'hidden'`.\n */\n ContentVisibility\n }\n\n /**\n * An enum of widget bit flags.\n */\n export enum Flag {\n /**\n * The widget has been disposed.\n */\n IsDisposed = 0x1,\n\n /**\n * The widget is attached to the DOM.\n */\n IsAttached = 0x2,\n\n /**\n * The widget is hidden.\n */\n IsHidden = 0x4,\n\n /**\n * The widget is visible.\n */\n IsVisible = 0x8,\n\n /**\n * A layout cannot be set on the widget.\n */\n DisallowLayout = 0x10\n }\n\n /**\n * A collection of stateless messages related to widgets.\n */\n export namespace Msg {\n /**\n * A singleton `'before-show'` message.\n *\n * #### Notes\n * This message is sent to a widget before it becomes visible.\n *\n * This message is **not** sent when the widget is being attached.\n */\n export const BeforeShow = new Message('before-show');\n\n /**\n * A singleton `'after-show'` message.\n *\n * #### Notes\n * This message is sent to a widget after it becomes visible.\n *\n * This message is **not** sent when the widget is being attached.\n */\n export const AfterShow = new Message('after-show');\n\n /**\n * A singleton `'before-hide'` message.\n *\n * #### Notes\n * This message is sent to a widget before it becomes not-visible.\n *\n * This message is **not** sent when the widget is being detached.\n */\n export const BeforeHide = new Message('before-hide');\n\n /**\n * A singleton `'after-hide'` message.\n *\n * #### Notes\n * This message is sent to a widget after it becomes not-visible.\n *\n * This message is **not** sent when the widget is being detached.\n */\n export const AfterHide = new Message('after-hide');\n\n /**\n * A singleton `'before-attach'` message.\n *\n * #### Notes\n * This message is sent to a widget before it is attached.\n */\n export const BeforeAttach = new Message('before-attach');\n\n /**\n * A singleton `'after-attach'` message.\n *\n * #### Notes\n * This message is sent to a widget after it is attached.\n */\n export const AfterAttach = new Message('after-attach');\n\n /**\n * A singleton `'before-detach'` message.\n *\n * #### Notes\n * This message is sent to a widget before it is detached.\n */\n export const BeforeDetach = new Message('before-detach');\n\n /**\n * A singleton `'after-detach'` message.\n *\n * #### Notes\n * This message is sent to a widget after it is detached.\n */\n export const AfterDetach = new Message('after-detach');\n\n /**\n * A singleton `'parent-changed'` message.\n *\n * #### Notes\n * This message is sent to a widget when its parent has changed.\n */\n export const ParentChanged = new Message('parent-changed');\n\n /**\n * A singleton conflatable `'update-request'` message.\n *\n * #### Notes\n * This message can be dispatched to supporting widgets in order to\n * update their content based on the current widget state. Not all\n * widgets will respond to messages of this type.\n *\n * For widgets with a layout, this message will inform the layout to\n * update the position and size of its child widgets.\n */\n export const UpdateRequest = new ConflatableMessage('update-request');\n\n /**\n * A singleton conflatable `'fit-request'` message.\n *\n * #### Notes\n * For widgets with a layout, this message will inform the layout to\n * recalculate its size constraints to fit the space requirements of\n * its child widgets, and to update their position and size. Not all\n * layouts will respond to messages of this type.\n */\n export const FitRequest = new ConflatableMessage('fit-request');\n\n /**\n * A singleton conflatable `'activate-request'` message.\n *\n * #### Notes\n * This message should be dispatched to a widget when it should\n * perform the actions necessary to activate the widget, which\n * may include focusing its node or descendant node.\n */\n export const ActivateRequest = new ConflatableMessage('activate-request');\n\n /**\n * A singleton conflatable `'close-request'` message.\n *\n * #### Notes\n * This message should be dispatched to a widget when it should close\n * and remove itself from the widget hierarchy.\n */\n export const CloseRequest = new ConflatableMessage('close-request');\n }\n\n /**\n * A message class for child related messages.\n */\n export class ChildMessage extends Message {\n /**\n * Construct a new child message.\n *\n * @param type - The message type.\n *\n * @param child - The child widget for the message.\n */\n constructor(type: string, child: Widget) {\n super(type);\n this.child = child;\n }\n\n /**\n * The child widget for the message.\n */\n readonly child: Widget;\n }\n\n /**\n * A message class for `'resize'` messages.\n */\n export class ResizeMessage extends Message {\n /**\n * Construct a new resize message.\n *\n * @param width - The **offset width** of the widget, or `-1` if\n * the width is not known.\n *\n * @param height - The **offset height** of the widget, or `-1` if\n * the height is not known.\n */\n constructor(width: number, height: number) {\n super('resize');\n this.width = width;\n this.height = height;\n }\n\n /**\n * The offset width of the widget.\n *\n * #### Notes\n * This will be `-1` if the width is unknown.\n */\n readonly width: number;\n\n /**\n * The offset height of the widget.\n *\n * #### Notes\n * This will be `-1` if the height is unknown.\n */\n readonly height: number;\n }\n\n /**\n * The namespace for the `ResizeMessage` class statics.\n */\n export namespace ResizeMessage {\n /**\n * A singleton `'resize'` message with an unknown size.\n */\n export const UnknownSize = new ResizeMessage(-1, -1);\n }\n\n /**\n * Attach a widget to a host DOM node.\n *\n * @param widget - The widget of interest.\n *\n * @param host - The DOM node to use as the widget's host.\n *\n * @param ref - The child of `host` to use as the reference element.\n * If this is provided, the widget will be inserted before this\n * node in the host. The default is `null`, which will cause the\n * widget to be added as the last child of the host.\n *\n * #### Notes\n * This will throw an error if the widget is not a root widget, if\n * the widget is already attached, or if the host is not attached\n * to the DOM.\n */\n export function attach(\n widget: Widget,\n host: HTMLElement,\n ref: HTMLElement | null = null\n ): void {\n if (widget.parent) {\n throw new Error('Cannot attach a child widget.');\n }\n if (widget.isAttached || widget.node.isConnected) {\n throw new Error('Widget is already attached.');\n }\n if (!host.isConnected) {\n throw new Error('Host is not attached.');\n }\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n host.insertBefore(widget.node, ref);\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n\n /**\n * Detach the widget from its host DOM node.\n *\n * @param widget - The widget of interest.\n *\n * #### Notes\n * This will throw an error if the widget is not a root widget,\n * or if the widget is not attached to the DOM.\n */\n export function detach(widget: Widget): void {\n if (widget.parent) {\n throw new Error('Cannot detach a child widget.');\n }\n if (!widget.isAttached || !widget.node.isConnected) {\n throw new Error('Widget is not attached.');\n }\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n widget.node.parentNode!.removeChild(widget.node);\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * An attached property for the widget title object.\n */\n export const titleProperty = new AttachedProperty>({\n name: 'title',\n create: owner => new Title({ owner })\n });\n\n /**\n * Create a DOM node for the given widget options.\n */\n export function createNode(options: Widget.IOptions): HTMLElement {\n return options.node || document.createElement(options.tag || 'div');\n }\n}\n","/* eslint-disable @typescript-eslint/no-empty-function */\n// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { Signal } from '@lumino/signaling';\n\nimport { Widget } from './widget';\n\n/**\n * An abstract base class for creating lumino layouts.\n *\n * #### Notes\n * A layout is used to add widgets to a parent and to arrange those\n * widgets within the parent's DOM node.\n *\n * This class implements the base functionality which is required of\n * nearly all layouts. It must be subclassed in order to be useful.\n *\n * Notably, this class does not define a uniform interface for adding\n * widgets to the layout. A subclass should define that API in a way\n * which is meaningful for its intended use.\n */\nexport abstract class Layout implements Iterable, IDisposable {\n /**\n * Construct a new layout.\n *\n * @param options - The options for initializing the layout.\n */\n constructor(options: Layout.IOptions = {}) {\n this._fitPolicy = options.fitPolicy || 'set-min-size';\n }\n\n /**\n * Dispose of the resources held by the layout.\n *\n * #### Notes\n * This should be reimplemented to clear and dispose of the widgets.\n *\n * All reimplementations should call the superclass method.\n *\n * This method is called automatically when the parent is disposed.\n */\n dispose(): void {\n this._parent = null;\n this._disposed = true;\n Signal.clearData(this);\n AttachedProperty.clearData(this);\n }\n\n /**\n * Test whether the layout is disposed.\n */\n get isDisposed(): boolean {\n return this._disposed;\n }\n\n /**\n * Get the parent widget of the layout.\n */\n get parent(): Widget | null {\n return this._parent;\n }\n\n /**\n * Set the parent widget of the layout.\n *\n * #### Notes\n * This is set automatically when installing the layout on the parent\n * widget. The parent widget should not be set directly by user code.\n */\n set parent(value: Widget | null) {\n if (this._parent === value) {\n return;\n }\n if (this._parent) {\n throw new Error('Cannot change parent widget.');\n }\n if (value!.layout !== this) {\n throw new Error('Invalid parent widget.');\n }\n this._parent = value;\n this.init();\n }\n\n /**\n * Get the fit policy for the layout.\n *\n * #### Notes\n * The fit policy controls the computed size constraints which are\n * applied to the parent widget by the layout.\n *\n * Some layout implementations may ignore the fit policy.\n */\n get fitPolicy(): Layout.FitPolicy {\n return this._fitPolicy;\n }\n\n /**\n * Set the fit policy for the layout.\n *\n * #### Notes\n * The fit policy controls the computed size constraints which are\n * applied to the parent widget by the layout.\n *\n * Some layout implementations may ignore the fit policy.\n *\n * Changing the fit policy will clear the current size constraint\n * for the parent widget and then re-fit the parent.\n */\n set fitPolicy(value: Layout.FitPolicy) {\n // Bail if the policy does not change\n if (this._fitPolicy === value) {\n return;\n }\n\n // Update the internal policy.\n this._fitPolicy = value;\n\n // Clear the size constraints and schedule a fit of the parent.\n if (this._parent) {\n let style = this._parent.node.style;\n style.minWidth = '';\n style.minHeight = '';\n style.maxWidth = '';\n style.maxHeight = '';\n this._parent.fit();\n }\n }\n\n /**\n * Create an iterator over the widgets in the layout.\n *\n * @returns A new iterator over the widgets in the layout.\n *\n * #### Notes\n * This abstract method must be implemented by a subclass.\n */\n abstract [Symbol.iterator](): IterableIterator;\n\n /**\n * Remove a widget from the layout.\n *\n * @param widget - The widget to remove from the layout.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method should *not* modify the widget's `parent`.\n */\n abstract removeWidget(widget: Widget): void;\n\n /**\n * Process a message sent to the parent widget.\n *\n * @param msg - The message sent to the parent widget.\n *\n * #### Notes\n * This method is called by the parent widget to process a message.\n *\n * Subclasses may reimplement this method as needed.\n */\n processParentMessage(msg: Message): void {\n switch (msg.type) {\n case 'resize':\n this.onResize(msg as Widget.ResizeMessage);\n break;\n case 'update-request':\n this.onUpdateRequest(msg);\n break;\n case 'fit-request':\n this.onFitRequest(msg);\n break;\n case 'before-show':\n this.onBeforeShow(msg);\n break;\n case 'after-show':\n this.onAfterShow(msg);\n break;\n case 'before-hide':\n this.onBeforeHide(msg);\n break;\n case 'after-hide':\n this.onAfterHide(msg);\n break;\n case 'before-attach':\n this.onBeforeAttach(msg);\n break;\n case 'after-attach':\n this.onAfterAttach(msg);\n break;\n case 'before-detach':\n this.onBeforeDetach(msg);\n break;\n case 'after-detach':\n this.onAfterDetach(msg);\n break;\n case 'child-removed':\n this.onChildRemoved(msg as Widget.ChildMessage);\n break;\n case 'child-shown':\n this.onChildShown(msg as Widget.ChildMessage);\n break;\n case 'child-hidden':\n this.onChildHidden(msg as Widget.ChildMessage);\n break;\n }\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n *\n * #### Notes\n * This method is invoked immediately after the layout is installed\n * on the parent widget.\n *\n * The default implementation reparents all of the widgets to the\n * layout parent widget.\n *\n * Subclasses should reimplement this method and attach the child\n * widget nodes to the parent widget's node.\n */\n protected init(): void {\n for (const widget of this) {\n widget.parent = this.parent;\n }\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n *\n * #### Notes\n * The layout should ensure that its widgets are resized according\n * to the specified layout space, and that they are sent a `'resize'`\n * message if appropriate.\n *\n * The default implementation of this method sends an `UnknownSize`\n * resize message to all widgets.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, Widget.ResizeMessage.UnknownSize);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n *\n * #### Notes\n * The layout should ensure that its widgets are resized according\n * to the available layout space, and that they are sent a `'resize'`\n * message if appropriate.\n *\n * The default implementation of this method sends an `UnknownSize`\n * resize message to all widgets.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onUpdateRequest(msg: Message): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, Widget.ResizeMessage.UnknownSize);\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message\n * to all widgets. It assumes all widget nodes are attached to the\n * parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onBeforeAttach(msg: Message): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n\n /**\n * A message handler invoked on an `'after-attach'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message\n * to all widgets. It assumes all widget nodes are attached to the\n * parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onAfterAttach(msg: Message): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n\n /**\n * A message handler invoked on a `'before-detach'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message\n * to all widgets. It assumes all widget nodes are attached to the\n * parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onBeforeDetach(msg: Message): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message\n * to all widgets. It assumes all widget nodes are attached to the\n * parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onAfterDetach(msg: Message): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message to\n * all non-hidden widgets. It assumes all widget nodes are attached\n * to the parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onBeforeShow(msg: Message): void {\n for (const widget of this) {\n if (!widget.isHidden) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n }\n\n /**\n * A message handler invoked on an `'after-show'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message to\n * all non-hidden widgets. It assumes all widget nodes are attached\n * to the parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onAfterShow(msg: Message): void {\n for (const widget of this) {\n if (!widget.isHidden) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n }\n\n /**\n * A message handler invoked on a `'before-hide'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message to\n * all non-hidden widgets. It assumes all widget nodes are attached\n * to the parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onBeforeHide(msg: Message): void {\n for (const widget of this) {\n if (!widget.isHidden) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n }\n\n /**\n * A message handler invoked on an `'after-hide'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message to\n * all non-hidden widgets. It assumes all widget nodes are attached\n * to the parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onAfterHide(msg: Message): void {\n for (const widget of this) {\n if (!widget.isHidden) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n }\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n *\n * #### Notes\n * This will remove the child widget from the layout.\n *\n * Subclasses should **not** typically reimplement this method.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {\n this.removeWidget(msg.child);\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onFitRequest(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {}\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {}\n\n private _disposed = false;\n private _fitPolicy: Layout.FitPolicy;\n private _parent: Widget | null = null;\n}\n\n/**\n * The namespace for the `Layout` class statics.\n */\nexport namespace Layout {\n /**\n * A type alias for the layout fit policy.\n *\n * #### Notes\n * The fit policy controls the computed size constraints which are\n * applied to the parent widget by the layout.\n *\n * Some layout implementations may ignore the fit policy.\n */\n export type FitPolicy =\n | /**\n * No size constraint will be applied to the parent widget.\n */\n 'set-no-constraint'\n\n /**\n * The computed min size will be applied to the parent widget.\n */\n | 'set-min-size';\n\n /**\n * An options object for initializing a layout.\n */\n export interface IOptions {\n /**\n * The fit policy for the layout.\n *\n * The default is `'set-min-size'`.\n */\n fitPolicy?: FitPolicy;\n }\n\n /**\n * A type alias for the horizontal alignment of a widget.\n */\n export type HorizontalAlignment = 'left' | 'center' | 'right';\n\n /**\n * A type alias for the vertical alignment of a widget.\n */\n export type VerticalAlignment = 'top' | 'center' | 'bottom';\n\n /**\n * Get the horizontal alignment for a widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The horizontal alignment for the widget.\n *\n * #### Notes\n * If the layout width allocated to a widget is larger than its max\n * width, the horizontal alignment controls how the widget is placed\n * within the extra horizontal space.\n *\n * If the allocated width is less than the widget's max width, the\n * horizontal alignment has no effect.\n *\n * Some layout implementations may ignore horizontal alignment.\n */\n export function getHorizontalAlignment(widget: Widget): HorizontalAlignment {\n return Private.horizontalAlignmentProperty.get(widget);\n }\n\n /**\n * Set the horizontal alignment for a widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the horizontal alignment.\n *\n * #### Notes\n * If the layout width allocated to a widget is larger than its max\n * width, the horizontal alignment controls how the widget is placed\n * within the extra horizontal space.\n *\n * If the allocated width is less than the widget's max width, the\n * horizontal alignment has no effect.\n *\n * Some layout implementations may ignore horizontal alignment.\n *\n * Changing the horizontal alignment will post an `update-request`\n * message to widget's parent, provided the parent has a layout\n * installed.\n */\n export function setHorizontalAlignment(\n widget: Widget,\n value: HorizontalAlignment\n ): void {\n Private.horizontalAlignmentProperty.set(widget, value);\n }\n\n /**\n * Get the vertical alignment for a widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The vertical alignment for the widget.\n *\n * #### Notes\n * If the layout height allocated to a widget is larger than its max\n * height, the vertical alignment controls how the widget is placed\n * within the extra vertical space.\n *\n * If the allocated height is less than the widget's max height, the\n * vertical alignment has no effect.\n *\n * Some layout implementations may ignore vertical alignment.\n */\n export function getVerticalAlignment(widget: Widget): VerticalAlignment {\n return Private.verticalAlignmentProperty.get(widget);\n }\n\n /**\n * Set the vertical alignment for a widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the vertical alignment.\n *\n * #### Notes\n * If the layout height allocated to a widget is larger than its max\n * height, the vertical alignment controls how the widget is placed\n * within the extra vertical space.\n *\n * If the allocated height is less than the widget's max height, the\n * vertical alignment has no effect.\n *\n * Some layout implementations may ignore vertical alignment.\n *\n * Changing the horizontal alignment will post an `update-request`\n * message to widget's parent, provided the parent has a layout\n * installed.\n */\n export function setVerticalAlignment(\n widget: Widget,\n value: VerticalAlignment\n ): void {\n Private.verticalAlignmentProperty.set(widget, value);\n }\n}\n\n/**\n * An object which assists in the absolute layout of widgets.\n *\n * #### Notes\n * This class is useful when implementing a layout which arranges its\n * widgets using absolute positioning.\n *\n * This class is used by nearly all of the built-in lumino layouts.\n */\nexport class LayoutItem implements IDisposable {\n /**\n * Construct a new layout item.\n *\n * @param widget - The widget to be managed by the item.\n *\n * #### Notes\n * The widget will be set to absolute positioning.\n * The widget will use strict CSS containment.\n */\n constructor(widget: Widget) {\n this.widget = widget;\n this.widget.node.style.position = 'absolute';\n this.widget.node.style.contain = 'strict';\n }\n\n /**\n * Dispose of the the layout item.\n *\n * #### Notes\n * This will reset the positioning of the widget.\n */\n dispose(): void {\n // Do nothing if the item is already disposed.\n if (this._disposed) {\n return;\n }\n\n // Mark the item as disposed.\n this._disposed = true;\n\n // Reset the widget style.\n let style = this.widget.node.style;\n style.position = '';\n style.top = '';\n style.left = '';\n style.width = '';\n style.height = '';\n style.contain = '';\n }\n\n /**\n * The widget managed by the layout item.\n */\n readonly widget: Widget;\n\n /**\n * The computed minimum width of the widget.\n *\n * #### Notes\n * This value can be updated by calling the `fit` method.\n */\n get minWidth(): number {\n return this._minWidth;\n }\n\n /**\n * The computed minimum height of the widget.\n *\n * #### Notes\n * This value can be updated by calling the `fit` method.\n */\n get minHeight(): number {\n return this._minHeight;\n }\n\n /**\n * The computed maximum width of the widget.\n *\n * #### Notes\n * This value can be updated by calling the `fit` method.\n */\n get maxWidth(): number {\n return this._maxWidth;\n }\n\n /**\n * The computed maximum height of the widget.\n *\n * #### Notes\n * This value can be updated by calling the `fit` method.\n */\n get maxHeight(): number {\n return this._maxHeight;\n }\n\n /**\n * Whether the layout item is disposed.\n */\n get isDisposed(): boolean {\n return this._disposed;\n }\n\n /**\n * Whether the managed widget is hidden.\n */\n get isHidden(): boolean {\n return this.widget.isHidden;\n }\n\n /**\n * Whether the managed widget is visible.\n */\n get isVisible(): boolean {\n return this.widget.isVisible;\n }\n\n /**\n * Whether the managed widget is attached.\n */\n get isAttached(): boolean {\n return this.widget.isAttached;\n }\n\n /**\n * Update the computed size limits of the managed widget.\n */\n fit(): void {\n let limits = ElementExt.sizeLimits(this.widget.node);\n this._minWidth = limits.minWidth;\n this._minHeight = limits.minHeight;\n this._maxWidth = limits.maxWidth;\n this._maxHeight = limits.maxHeight;\n }\n\n /**\n * Update the position and size of the managed widget.\n *\n * @param left - The left edge position of the layout box.\n *\n * @param top - The top edge position of the layout box.\n *\n * @param width - The width of the layout box.\n *\n * @param height - The height of the layout box.\n */\n update(left: number, top: number, width: number, height: number): void {\n // Clamp the size to the computed size limits.\n let clampW = Math.max(this._minWidth, Math.min(width, this._maxWidth));\n let clampH = Math.max(this._minHeight, Math.min(height, this._maxHeight));\n\n // Adjust the left edge for the horizontal alignment, if needed.\n if (clampW < width) {\n switch (Layout.getHorizontalAlignment(this.widget)) {\n case 'left':\n break;\n case 'center':\n left += (width - clampW) / 2;\n break;\n case 'right':\n left += width - clampW;\n break;\n default:\n throw 'unreachable';\n }\n }\n\n // Adjust the top edge for the vertical alignment, if needed.\n if (clampH < height) {\n switch (Layout.getVerticalAlignment(this.widget)) {\n case 'top':\n break;\n case 'center':\n top += (height - clampH) / 2;\n break;\n case 'bottom':\n top += height - clampH;\n break;\n default:\n throw 'unreachable';\n }\n }\n\n // Set up the resize variables.\n let resized = false;\n let style = this.widget.node.style;\n\n // Update the top edge of the widget if needed.\n if (this._top !== top) {\n this._top = top;\n style.top = `${top}px`;\n }\n\n // Update the left edge of the widget if needed.\n if (this._left !== left) {\n this._left = left;\n style.left = `${left}px`;\n }\n\n // Update the width of the widget if needed.\n if (this._width !== clampW) {\n resized = true;\n this._width = clampW;\n style.width = `${clampW}px`;\n }\n\n // Update the height of the widget if needed.\n if (this._height !== clampH) {\n resized = true;\n this._height = clampH;\n style.height = `${clampH}px`;\n }\n\n // Send a resize message to the widget if needed.\n if (resized) {\n let msg = new Widget.ResizeMessage(clampW, clampH);\n MessageLoop.sendMessage(this.widget, msg);\n }\n }\n\n private _top = NaN;\n private _left = NaN;\n private _width = NaN;\n private _height = NaN;\n private _minWidth = 0;\n private _minHeight = 0;\n private _maxWidth = Infinity;\n private _maxHeight = Infinity;\n private _disposed = false;\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The attached property for a widget horizontal alignment.\n */\n export const horizontalAlignmentProperty = new AttachedProperty<\n Widget,\n Layout.HorizontalAlignment\n >({\n name: 'horizontalAlignment',\n create: () => 'center',\n changed: onAlignmentChanged\n });\n\n /**\n * The attached property for a widget vertical alignment.\n */\n export const verticalAlignmentProperty = new AttachedProperty<\n Widget,\n Layout.VerticalAlignment\n >({\n name: 'verticalAlignment',\n create: () => 'top',\n changed: onAlignmentChanged\n });\n\n /**\n * The change handler for the attached alignment properties.\n */\n function onAlignmentChanged(child: Widget): void {\n if (child.parent && child.parent.layout) {\n child.parent.update();\n }\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { MessageLoop } from '@lumino/messaging';\n\nimport { Layout } from './layout';\n\nimport { Widget } from './widget';\n\n/**\n * A concrete layout implementation suitable for many use cases.\n *\n * #### Notes\n * This class is suitable as a base class for implementing a variety of\n * layouts, but can also be used directly with standard CSS to layout a\n * collection of widgets.\n */\nexport class PanelLayout extends Layout {\n /**\n * Dispose of the resources held by the layout.\n *\n * #### Notes\n * This will clear and dispose all widgets in the layout.\n *\n * All reimplementations should call the superclass method.\n *\n * This method is called automatically when the parent is disposed.\n */\n dispose(): void {\n while (this._widgets.length > 0) {\n this._widgets.pop()!.dispose();\n }\n super.dispose();\n }\n\n /**\n * A read-only array of the widgets in the layout.\n */\n get widgets(): ReadonlyArray {\n return this._widgets;\n }\n\n /**\n * Create an iterator over the widgets in the layout.\n *\n * @returns A new iterator over the widgets in the layout.\n */\n *[Symbol.iterator](): IterableIterator {\n yield* this._widgets;\n }\n\n /**\n * Add a widget to the end of the layout.\n *\n * @param widget - The widget to add to the layout.\n *\n * #### Notes\n * If the widget is already contained in the layout, it will be moved.\n */\n addWidget(widget: Widget): void {\n this.insertWidget(this._widgets.length, widget);\n }\n\n /**\n * Insert a widget into the layout at the specified index.\n *\n * @param index - The index at which to insert the widget.\n *\n * @param widget - The widget to insert into the layout.\n *\n * #### Notes\n * The index will be clamped to the bounds of the widgets.\n *\n * If the widget is already added to the layout, it will be moved.\n *\n * #### Undefined Behavior\n * An `index` which is non-integral.\n */\n insertWidget(index: number, widget: Widget): void {\n // Remove the widget from its current parent. This is a no-op\n // if the widget's parent is already the layout parent widget.\n widget.parent = this.parent;\n\n // Look up the current index of the widget.\n let i = this._widgets.indexOf(widget);\n\n // Clamp the insert index to the array bounds.\n let j = Math.max(0, Math.min(index, this._widgets.length));\n\n // If the widget is not in the array, insert it.\n if (i === -1) {\n // Insert the widget into the array.\n ArrayExt.insert(this._widgets, j, widget);\n\n // If the layout is parented, attach the widget to the DOM.\n if (this.parent) {\n this.attachWidget(j, widget);\n }\n\n // There is nothing more to do.\n return;\n }\n\n // Otherwise, the widget exists in the array and should be moved.\n\n // Adjust the index if the location is at the end of the array.\n if (j === this._widgets.length) {\n j--;\n }\n\n // Bail if there is no effective move.\n if (i === j) {\n return;\n }\n\n // Move the widget to the new location.\n ArrayExt.move(this._widgets, i, j);\n\n // If the layout is parented, move the widget in the DOM.\n if (this.parent) {\n this.moveWidget(i, j, widget);\n }\n }\n\n /**\n * Remove a widget from the layout.\n *\n * @param widget - The widget to remove from the layout.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method does *not* modify the widget's `parent`.\n */\n removeWidget(widget: Widget): void {\n this.removeWidgetAt(this._widgets.indexOf(widget));\n }\n\n /**\n * Remove the widget at a given index from the layout.\n *\n * @param index - The index of the widget to remove.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method does *not* modify the widget's `parent`.\n *\n * #### Undefined Behavior\n * An `index` which is non-integral.\n */\n removeWidgetAt(index: number): void {\n // Remove the widget from the array.\n let widget = ArrayExt.removeAt(this._widgets, index);\n\n // If the layout is parented, detach the widget from the DOM.\n if (widget && this.parent) {\n this.detachWidget(index, widget);\n }\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n super.init();\n let index = 0;\n for (const widget of this) {\n this.attachWidget(index++, widget);\n }\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param index - The current index of the widget in the layout.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This method is called automatically by the panel layout at the\n * appropriate time. It should not be called directly by user code.\n *\n * The default implementation adds the widgets's node to the parent's\n * node at the proper location, and sends the appropriate attach\n * messages to the widget if the parent is attached to the DOM.\n *\n * Subclasses may reimplement this method to control how the widget's\n * node is added to the parent's node.\n */\n protected attachWidget(index: number, widget: Widget): void {\n // Look up the next sibling reference node.\n let ref = this.parent!.node.children[index];\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Insert the widget's node before the sibling.\n this.parent!.node.insertBefore(widget.node, ref);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n }\n\n /**\n * Move a widget in the parent's DOM node.\n *\n * @param fromIndex - The previous index of the widget in the layout.\n *\n * @param toIndex - The current index of the widget in the layout.\n *\n * @param widget - The widget to move in the parent.\n *\n * #### Notes\n * This method is called automatically by the panel layout at the\n * appropriate time. It should not be called directly by user code.\n *\n * The default implementation moves the widget's node to the proper\n * location in the parent's node and sends the appropriate attach and\n * detach messages to the widget if the parent is attached to the DOM.\n *\n * Subclasses may reimplement this method to control how the widget's\n * node is moved in the parent's node.\n */\n protected moveWidget(\n fromIndex: number,\n toIndex: number,\n widget: Widget\n ): void {\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` and message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Look up the next sibling reference node.\n let ref = this.parent!.node.children[toIndex];\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Insert the widget's node before the sibling.\n this.parent!.node.insertBefore(widget.node, ref);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param index - The previous index of the widget in the layout.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This method is called automatically by the panel layout at the\n * appropriate time. It should not be called directly by user code.\n *\n * The default implementation removes the widget's node from the\n * parent's node, and sends the appropriate detach messages to the\n * widget if the parent is attached to the DOM.\n *\n * Subclasses may reimplement this method to control how the widget's\n * node is removed from the parent's node.\n */\n protected detachWidget(index: number, widget: Widget): void {\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n }\n\n private _widgets: Widget[] = [];\n}\n","/*\n * Copyright (c) Jupyter Development Team.\n * Distributed under the terms of the Modified BSD License.\n */\n\nexport namespace Utils {\n /**\n * Clamp a dimension value to an integer >= 0.\n */\n export function clampDimension(value: number): number {\n return Math.max(0, Math.floor(value));\n }\n}\n\nexport default Utils;\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { BoxEngine, BoxSizer } from './boxengine';\n\nimport { LayoutItem } from './layout';\n\nimport { PanelLayout } from './panellayout';\n\nimport { Utils } from './utils';\n\nimport { Widget } from './widget';\n\n/**\n * A layout which arranges its widgets into resizable sections.\n */\nexport class SplitLayout extends PanelLayout {\n /**\n * Construct a new split layout.\n *\n * @param options - The options for initializing the layout.\n */\n constructor(options: SplitLayout.IOptions) {\n super();\n this.renderer = options.renderer;\n if (options.orientation !== undefined) {\n this._orientation = options.orientation;\n }\n if (options.alignment !== undefined) {\n this._alignment = options.alignment;\n }\n if (options.spacing !== undefined) {\n this._spacing = Utils.clampDimension(options.spacing);\n }\n }\n\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n // Dispose of the layout items.\n for (const item of this._items) {\n item.dispose();\n }\n\n // Clear the layout state.\n this._box = null;\n this._items.length = 0;\n this._sizers.length = 0;\n this._handles.length = 0;\n\n // Dispose of the rest of the layout.\n super.dispose();\n }\n\n /**\n * The renderer used by the split layout.\n */\n readonly renderer: SplitLayout.IRenderer;\n\n /**\n * Get the layout orientation for the split layout.\n */\n get orientation(): SplitLayout.Orientation {\n return this._orientation;\n }\n\n /**\n * Set the layout orientation for the split layout.\n */\n set orientation(value: SplitLayout.Orientation) {\n if (this._orientation === value) {\n return;\n }\n this._orientation = value;\n if (!this.parent) {\n return;\n }\n this.parent.dataset['orientation'] = value;\n this.parent.fit();\n }\n\n /**\n * Get the content alignment for the split layout.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire split layout.\n */\n get alignment(): SplitLayout.Alignment {\n return this._alignment;\n }\n\n /**\n * Set the content alignment for the split layout.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire split layout.\n */\n set alignment(value: SplitLayout.Alignment) {\n if (this._alignment === value) {\n return;\n }\n this._alignment = value;\n if (!this.parent) {\n return;\n }\n this.parent.dataset['alignment'] = value;\n this.parent.update();\n }\n\n /**\n * Get the inter-element spacing for the split layout.\n */\n get spacing(): number {\n return this._spacing;\n }\n\n /**\n * Set the inter-element spacing for the split layout.\n */\n set spacing(value: number) {\n value = Utils.clampDimension(value);\n if (this._spacing === value) {\n return;\n }\n this._spacing = value;\n if (!this.parent) {\n return;\n }\n this.parent.fit();\n }\n\n /**\n * A read-only array of the split handles in the layout.\n */\n get handles(): ReadonlyArray {\n return this._handles;\n }\n\n /**\n * Get the absolute sizes of the widgets in the layout.\n *\n * @returns A new array of the absolute sizes of the widgets.\n *\n * This method **does not** measure the DOM nodes.\n */\n absoluteSizes(): number[] {\n return this._sizers.map(sizer => sizer.size);\n }\n\n /**\n * Get the relative sizes of the widgets in the layout.\n *\n * @returns A new array of the relative sizes of the widgets.\n *\n * #### Notes\n * The returned sizes reflect the sizes of the widgets normalized\n * relative to their siblings.\n *\n * This method **does not** measure the DOM nodes.\n */\n relativeSizes(): number[] {\n return Private.normalize(this._sizers.map(sizer => sizer.size));\n }\n\n /**\n * Set the relative sizes for the widgets in the layout.\n *\n * @param sizes - The relative sizes for the widgets in the panel.\n * @param update - Update the layout after setting relative sizes.\n * Default is True.\n *\n * #### Notes\n * Extra values are ignored, too few will yield an undefined layout.\n *\n * The actual geometry of the DOM nodes is updated asynchronously.\n */\n setRelativeSizes(sizes: number[], update = true): void {\n // Copy the sizes and pad with zeros as needed.\n let n = this._sizers.length;\n let temp = sizes.slice(0, n);\n while (temp.length < n) {\n temp.push(0);\n }\n\n // Normalize the padded sizes.\n let normed = Private.normalize(temp);\n\n // Apply the normalized sizes to the sizers.\n for (let i = 0; i < n; ++i) {\n let sizer = this._sizers[i];\n sizer.sizeHint = normed[i];\n sizer.size = normed[i];\n }\n\n // Set the flag indicating the sizes are normalized.\n this._hasNormedSizes = true;\n\n // Trigger an update of the parent widget.\n if (update && this.parent) {\n this.parent.update();\n }\n }\n\n /**\n * Move the offset position of a split handle.\n *\n * @param index - The index of the handle of the interest.\n *\n * @param position - The desired offset position of the handle.\n *\n * #### Notes\n * The position is relative to the offset parent.\n *\n * This will move the handle as close as possible to the desired\n * position. The sibling widgets will be adjusted as necessary.\n */\n moveHandle(index: number, position: number): void {\n // Bail if the index is invalid or the handle is hidden.\n let handle = this._handles[index];\n if (!handle || handle.classList.contains('lm-mod-hidden')) {\n return;\n }\n\n // Compute the desired delta movement for the handle.\n let delta: number;\n if (this._orientation === 'horizontal') {\n delta = position - handle.offsetLeft;\n } else {\n delta = position - handle.offsetTop;\n }\n\n // Bail if there is no handle movement.\n if (delta === 0) {\n return;\n }\n\n // Prevent widget resizing unless needed.\n for (let sizer of this._sizers) {\n if (sizer.size > 0) {\n sizer.sizeHint = sizer.size;\n }\n }\n\n // Adjust the sizers to reflect the handle movement.\n BoxEngine.adjust(this._sizers, index, delta);\n\n // Update the layout of the widgets.\n if (this.parent) {\n this.parent.update();\n }\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n this.parent!.dataset['orientation'] = this.orientation;\n this.parent!.dataset['alignment'] = this.alignment;\n super.init();\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param index - The current index of the widget in the layout.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected attachWidget(index: number, widget: Widget): void {\n // Create the item, handle, and sizer for the new widget.\n let item = new LayoutItem(widget);\n let handle = Private.createHandle(this.renderer);\n let average = Private.averageSize(this._sizers);\n let sizer = Private.createSizer(average);\n\n // Insert the item, handle, and sizer into the internal arrays.\n ArrayExt.insert(this._items, index, item);\n ArrayExt.insert(this._sizers, index, sizer);\n ArrayExt.insert(this._handles, index, handle);\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget and handle nodes to the parent.\n this.parent!.node.appendChild(widget.node);\n this.parent!.node.appendChild(handle);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * Move a widget in the parent's DOM node.\n *\n * @param fromIndex - The previous index of the widget in the layout.\n *\n * @param toIndex - The current index of the widget in the layout.\n *\n * @param widget - The widget to move in the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected moveWidget(\n fromIndex: number,\n toIndex: number,\n widget: Widget\n ): void {\n // Move the item, sizer, and handle for the widget.\n ArrayExt.move(this._items, fromIndex, toIndex);\n ArrayExt.move(this._sizers, fromIndex, toIndex);\n ArrayExt.move(this._handles, fromIndex, toIndex);\n\n // Post a fit request to the parent to show/hide last handle.\n this.parent!.fit();\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param index - The previous index of the widget in the layout.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected detachWidget(index: number, widget: Widget): void {\n // Remove the item, handle, and sizer for the widget.\n let item = ArrayExt.removeAt(this._items, index);\n let handle = ArrayExt.removeAt(this._handles, index);\n ArrayExt.removeAt(this._sizers, index);\n\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget and handle nodes from the parent.\n this.parent!.node.removeChild(widget.node);\n this.parent!.node.removeChild(handle!);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Dispose of the layout item.\n item!.dispose();\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n */\n protected onBeforeShow(msg: Message): void {\n super.onBeforeShow(msg);\n this.parent!.update();\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n super.onBeforeAttach(msg);\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n if (this.parent!.isVisible) {\n this._update(msg.width, msg.height);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.parent!.isVisible) {\n this._update(-1, -1);\n }\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n */\n protected onFitRequest(msg: Message): void {\n if (this.parent!.isAttached) {\n this._fit();\n }\n }\n\n /**\n * Update the item position.\n *\n * @param i Item index\n * @param isHorizontal Whether the layout is horizontal or not\n * @param left Left position in pixels\n * @param top Top position in pixels\n * @param height Item height\n * @param width Item width\n * @param size Item size\n */\n protected updateItemPosition(\n i: number,\n isHorizontal: boolean,\n left: number,\n top: number,\n height: number,\n width: number,\n size: number\n ): void {\n const item = this._items[i];\n if (item.isHidden) {\n return;\n }\n\n // Fetch the style for the handle.\n let handleStyle = this._handles[i].style;\n\n // Update the widget and handle, and advance the relevant edge.\n if (isHorizontal) {\n left += this.widgetOffset;\n item.update(left, top, size, height);\n left += size;\n handleStyle.top = `${top}px`;\n handleStyle.left = `${left}px`;\n handleStyle.width = `${this._spacing}px`;\n handleStyle.height = `${height}px`;\n } else {\n top += this.widgetOffset;\n item.update(left, top, width, size);\n top += size;\n handleStyle.top = `${top}px`;\n handleStyle.left = `${left}px`;\n handleStyle.width = `${width}px`;\n handleStyle.height = `${this._spacing}px`;\n }\n }\n\n /**\n * Fit the layout to the total size required by the widgets.\n */\n private _fit(): void {\n // Update the handles and track the visible widget count.\n let nVisible = 0;\n let lastHandleIndex = -1;\n for (let i = 0, n = this._items.length; i < n; ++i) {\n if (this._items[i].isHidden) {\n this._handles[i].classList.add('lm-mod-hidden');\n } else {\n this._handles[i].classList.remove('lm-mod-hidden');\n lastHandleIndex = i;\n nVisible++;\n }\n }\n\n // Hide the handle for the last visible widget.\n if (lastHandleIndex !== -1) {\n this._handles[lastHandleIndex].classList.add('lm-mod-hidden');\n }\n\n // Update the fixed space for the visible items.\n this._fixed =\n this._spacing * Math.max(0, nVisible - 1) +\n this.widgetOffset * this._items.length;\n\n // Setup the computed minimum size.\n let horz = this._orientation === 'horizontal';\n let minW = horz ? this._fixed : 0;\n let minH = horz ? 0 : this._fixed;\n\n // Update the sizers and computed size limits.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item and corresponding box sizer.\n let item = this._items[i];\n let sizer = this._sizers[i];\n\n // Prevent resizing unless necessary.\n if (sizer.size > 0) {\n sizer.sizeHint = sizer.size;\n }\n\n // If the item is hidden, it should consume zero size.\n if (item.isHidden) {\n sizer.minSize = 0;\n sizer.maxSize = 0;\n continue;\n }\n\n // Update the size limits for the item.\n item.fit();\n\n // Update the stretch factor.\n sizer.stretch = SplitLayout.getStretch(item.widget);\n\n // Update the sizer limits and computed min size.\n if (horz) {\n sizer.minSize = item.minWidth;\n sizer.maxSize = item.maxWidth;\n minW += item.minWidth;\n minH = Math.max(minH, item.minHeight);\n } else {\n sizer.minSize = item.minHeight;\n sizer.maxSize = item.maxHeight;\n minH += item.minHeight;\n minW = Math.max(minW, item.minWidth);\n }\n }\n\n // Update the box sizing and add it to the computed min size.\n let box = (this._box = ElementExt.boxSizing(this.parent!.node));\n minW += box.horizontalSum;\n minH += box.verticalSum;\n\n // Update the parent's min size constraints.\n let style = this.parent!.node.style;\n style.minWidth = `${minW}px`;\n style.minHeight = `${minH}px`;\n\n // Set the dirty flag to ensure only a single update occurs.\n this._dirty = true;\n\n // Notify the ancestor that it should fit immediately. This may\n // cause a resize of the parent, fulfilling the required update.\n if (this.parent!.parent) {\n MessageLoop.sendMessage(this.parent!.parent!, Widget.Msg.FitRequest);\n }\n\n // If the dirty flag is still set, the parent was not resized.\n // Trigger the required update on the parent widget immediately.\n if (this._dirty) {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n }\n }\n\n /**\n * Update the layout position and size of the widgets.\n *\n * The parent offset dimensions should be `-1` if unknown.\n */\n private _update(offsetWidth: number, offsetHeight: number): void {\n // Clear the dirty flag to indicate the update occurred.\n this._dirty = false;\n\n // Compute the visible item count.\n let nVisible = 0;\n for (let i = 0, n = this._items.length; i < n; ++i) {\n nVisible += +!this._items[i].isHidden;\n }\n\n // Bail early if there are no visible items to layout.\n if (nVisible === 0 && this.widgetOffset === 0) {\n return;\n }\n\n // Measure the parent if the offset dimensions are unknown.\n if (offsetWidth < 0) {\n offsetWidth = this.parent!.node.offsetWidth;\n }\n if (offsetHeight < 0) {\n offsetHeight = this.parent!.node.offsetHeight;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent!.node);\n }\n\n // Compute the actual layout bounds adjusted for border and padding.\n let top = this._box.paddingTop;\n let left = this._box.paddingLeft;\n let width = offsetWidth - this._box.horizontalSum;\n let height = offsetHeight - this._box.verticalSum;\n\n // Set up the variables for justification and alignment offset.\n let extra = 0;\n let offset = 0;\n let horz = this._orientation === 'horizontal';\n\n if (nVisible > 0) {\n // Compute the adjusted layout space.\n let space: number;\n if (horz) {\n // left += this.widgetOffset;\n space = Math.max(0, width - this._fixed);\n } else {\n // top += this.widgetOffset;\n space = Math.max(0, height - this._fixed);\n }\n\n // Scale the size hints if they are normalized.\n if (this._hasNormedSizes) {\n for (let sizer of this._sizers) {\n sizer.sizeHint *= space;\n }\n this._hasNormedSizes = false;\n }\n\n // Distribute the layout space to the box sizers.\n let delta = BoxEngine.calc(this._sizers, space);\n\n // Account for alignment if there is extra layout space.\n if (delta > 0) {\n switch (this._alignment) {\n case 'start':\n break;\n case 'center':\n extra = 0;\n offset = delta / 2;\n break;\n case 'end':\n extra = 0;\n offset = delta;\n break;\n case 'justify':\n extra = delta / nVisible;\n offset = 0;\n break;\n default:\n throw 'unreachable';\n }\n }\n }\n\n // Layout the items using the computed box sizes.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item.\n const item = this._items[i];\n\n // Fetch the computed size for the widget.\n const size = item.isHidden ? 0 : this._sizers[i].size + extra;\n\n this.updateItemPosition(\n i,\n horz,\n horz ? left + offset : left,\n horz ? top : top + offset,\n height,\n width,\n size\n );\n\n const fullOffset =\n this.widgetOffset +\n (this._handles[i].classList.contains('lm-mod-hidden')\n ? 0\n : this._spacing);\n\n if (horz) {\n left += size + fullOffset;\n } else {\n top += size + fullOffset;\n }\n }\n }\n\n protected widgetOffset = 0;\n private _fixed = 0;\n private _spacing = 4;\n private _dirty = false;\n private _hasNormedSizes = false;\n private _sizers: BoxSizer[] = [];\n private _items: LayoutItem[] = [];\n private _handles: HTMLDivElement[] = [];\n private _box: ElementExt.IBoxSizing | null = null;\n private _alignment: SplitLayout.Alignment = 'start';\n private _orientation: SplitLayout.Orientation = 'horizontal';\n}\n\n/**\n * The namespace for the `SplitLayout` class statics.\n */\nexport namespace SplitLayout {\n /**\n * A type alias for a split layout orientation.\n */\n export type Orientation = 'horizontal' | 'vertical';\n\n /**\n * A type alias for a split layout alignment.\n */\n export type Alignment = 'start' | 'center' | 'end' | 'justify';\n\n /**\n * An options object for initializing a split layout.\n */\n export interface IOptions {\n /**\n * The renderer to use for the split layout.\n */\n renderer: IRenderer;\n\n /**\n * The orientation of the layout.\n *\n * The default is `'horizontal'`.\n */\n orientation?: Orientation;\n\n /**\n * The content alignment of the layout.\n *\n * The default is `'start'`.\n */\n alignment?: Alignment;\n\n /**\n * The spacing between items in the layout.\n *\n * The default is `4`.\n */\n spacing?: number;\n }\n\n /**\n * A renderer for use with a split layout.\n */\n export interface IRenderer {\n /**\n * Create a new handle for use with a split layout.\n *\n * @returns A new handle element.\n */\n createHandle(): HTMLDivElement;\n }\n\n /**\n * Get the split layout stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The split layout stretch factor for the widget.\n */\n export function getStretch(widget: Widget): number {\n return Private.stretchProperty.get(widget);\n }\n\n /**\n * Set the split layout stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the stretch factor.\n */\n export function setStretch(widget: Widget, value: number): void {\n Private.stretchProperty.set(widget, value);\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The property descriptor for a widget stretch factor.\n */\n export const stretchProperty = new AttachedProperty({\n name: 'stretch',\n create: () => 0,\n coerce: (owner, value) => Math.max(0, Math.floor(value)),\n changed: onChildSizingChanged\n });\n\n /**\n * Create a new box sizer with the given size hint.\n */\n export function createSizer(size: number): BoxSizer {\n let sizer = new BoxSizer();\n sizer.sizeHint = Math.floor(size);\n return sizer;\n }\n\n /**\n * Create a new split handle node using the given renderer.\n */\n export function createHandle(\n renderer: SplitLayout.IRenderer\n ): HTMLDivElement {\n let handle = renderer.createHandle();\n handle.style.position = 'absolute';\n // Do not use size containment to allow the handle to fill the available space\n handle.style.contain = 'style';\n return handle;\n }\n\n /**\n * Compute the average size of an array of box sizers.\n */\n export function averageSize(sizers: BoxSizer[]): number {\n return sizers.reduce((v, s) => v + s.size, 0) / sizers.length || 0;\n }\n\n /**\n * Normalize an array of values.\n */\n export function normalize(values: number[]): number[] {\n let n = values.length;\n if (n === 0) {\n return [];\n }\n let sum = values.reduce((a, b) => a + Math.abs(b), 0);\n return sum === 0 ? values.map(v => 1 / n) : values.map(v => v / sum);\n }\n\n /**\n * The change handler for the attached sizing properties.\n */\n function onChildSizingChanged(child: Widget): void {\n if (child.parent && child.parent.layout instanceof SplitLayout) {\n child.parent.fit();\n }\n }\n}\n","/*\n * Copyright (c) Jupyter Development Team.\n * Distributed under the terms of the Modified BSD License.\n */\n\nimport { ArrayExt } from '@lumino/algorithm';\nimport { UUID } from '@lumino/coreutils';\nimport { SplitLayout } from './splitlayout';\nimport { Title } from './title';\nimport Utils from './utils';\nimport { Widget } from './widget';\n\n/**\n * A layout which arranges its widgets into collapsible resizable sections.\n */\nexport class AccordionLayout extends SplitLayout {\n /**\n * Construct a new accordion layout.\n *\n * @param options - The options for initializing the layout.\n *\n * #### Notes\n * The default orientation will be vertical.\n *\n * Titles must be rotated for horizontal accordion panel using CSS: see accordionpanel.css\n */\n constructor(options: AccordionLayout.IOptions) {\n super({ ...options, orientation: options.orientation || 'vertical' });\n this.titleSpace = options.titleSpace || 22;\n }\n\n /**\n * The section title height or width depending on the orientation.\n */\n get titleSpace(): number {\n return this.widgetOffset;\n }\n set titleSpace(value: number) {\n value = Utils.clampDimension(value);\n if (this.widgetOffset === value) {\n return;\n }\n this.widgetOffset = value;\n if (!this.parent) {\n return;\n }\n this.parent.fit();\n }\n\n /**\n * A read-only array of the section titles in the panel.\n */\n get titles(): ReadonlyArray {\n return this._titles;\n }\n\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n if (this.isDisposed) {\n return;\n }\n\n // Clear the layout state.\n this._titles.length = 0;\n\n // Dispose of the rest of the layout.\n super.dispose();\n }\n\n /**\n * The renderer used by the accordion layout.\n */\n readonly renderer: AccordionLayout.IRenderer;\n\n public updateTitle(index: number, widget: Widget): void {\n const oldTitle = this._titles[index];\n const expanded = oldTitle.classList.contains('lm-mod-expanded');\n const newTitle = Private.createTitle(this.renderer, widget.title, expanded);\n this._titles[index] = newTitle;\n\n // Add the title node to the parent before the widget.\n this.parent!.node.replaceChild(newTitle, oldTitle);\n }\n\n /**\n * Insert a widget into the layout at the specified index.\n *\n * @param index - The index at which to insert the widget.\n *\n * @param widget - The widget to insert into the layout.\n *\n * #### Notes\n * The index will be clamped to the bounds of the widgets.\n *\n * If the widget is already added to the layout, it will be moved.\n *\n * #### Undefined Behavior\n * An `index` which is non-integral.\n */\n insertWidget(index: number, widget: Widget): void {\n if (!widget.id) {\n widget.id = `id-${UUID.uuid4()}`;\n }\n super.insertWidget(index, widget);\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param index - The current index of the widget in the layout.\n *\n * @param widget - The widget to attach to the parent.\n */\n protected attachWidget(index: number, widget: Widget): void {\n const title = Private.createTitle(this.renderer, widget.title);\n\n ArrayExt.insert(this._titles, index, title);\n\n // Add the title node to the parent before the widget.\n this.parent!.node.appendChild(title);\n\n widget.node.setAttribute('role', 'region');\n widget.node.setAttribute('aria-labelledby', title.id);\n\n super.attachWidget(index, widget);\n }\n\n /**\n * Move a widget in the parent's DOM node.\n *\n * @param fromIndex - The previous index of the widget in the layout.\n *\n * @param toIndex - The current index of the widget in the layout.\n *\n * @param widget - The widget to move in the parent.\n */\n protected moveWidget(\n fromIndex: number,\n toIndex: number,\n widget: Widget\n ): void {\n ArrayExt.move(this._titles, fromIndex, toIndex);\n super.moveWidget(fromIndex, toIndex, widget);\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param index - The previous index of the widget in the layout.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected detachWidget(index: number, widget: Widget): void {\n const title = ArrayExt.removeAt(this._titles, index);\n\n this.parent!.node.removeChild(title!);\n\n super.detachWidget(index, widget);\n }\n\n /**\n * Update the item position.\n *\n * @param i Item index\n * @param isHorizontal Whether the layout is horizontal or not\n * @param left Left position in pixels\n * @param top Top position in pixels\n * @param height Item height\n * @param width Item width\n * @param size Item size\n */\n protected updateItemPosition(\n i: number,\n isHorizontal: boolean,\n left: number,\n top: number,\n height: number,\n width: number,\n size: number\n ): void {\n const titleStyle = this._titles[i].style;\n\n // Titles must be rotated for horizontal accordion panel using CSS: see accordionpanel.css\n titleStyle.top = `${top}px`;\n titleStyle.left = `${left}px`;\n titleStyle.height = `${this.widgetOffset}px`;\n if (isHorizontal) {\n titleStyle.width = `${height}px`;\n } else {\n titleStyle.width = `${width}px`;\n }\n\n super.updateItemPosition(i, isHorizontal, left, top, height, width, size);\n }\n\n private _titles: HTMLElement[] = [];\n}\n\nexport namespace AccordionLayout {\n /**\n * A type alias for a accordion layout orientation.\n */\n export type Orientation = SplitLayout.Orientation;\n\n /**\n * A type alias for a accordion layout alignment.\n */\n export type Alignment = SplitLayout.Alignment;\n\n /**\n * An options object for initializing a accordion layout.\n */\n export interface IOptions extends SplitLayout.IOptions {\n /**\n * The renderer to use for the accordion layout.\n */\n renderer: IRenderer;\n\n /**\n * The section title height or width depending on the orientation.\n *\n * The default is `22`.\n */\n titleSpace?: number;\n }\n\n /**\n * A renderer for use with an accordion layout.\n */\n export interface IRenderer extends SplitLayout.IRenderer {\n /**\n * Common class name for all accordion titles.\n */\n readonly titleClassName: string;\n\n /**\n * Render the element for a section title.\n *\n * @param title - The data to use for rendering the section title.\n *\n * @returns A element representing the section title.\n */\n createSectionTitle(title: Title): HTMLElement;\n }\n}\n\nnamespace Private {\n /**\n * Create the title HTML element.\n *\n * @param renderer Accordion renderer\n * @param data Widget title\n * @returns Title HTML element\n */\n export function createTitle(\n renderer: AccordionLayout.IRenderer,\n data: Title,\n expanded: boolean = true\n ): HTMLElement {\n const title = renderer.createSectionTitle(data);\n title.style.position = 'absolute';\n title.style.contain = 'strict';\n title.setAttribute('aria-label', `${data.label} Section`);\n title.setAttribute('aria-expanded', expanded ? 'true' : 'false');\n title.setAttribute('aria-controls', data.owner.id);\n if (expanded) {\n title.classList.add('lm-mod-expanded');\n }\n return title;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { PanelLayout } from './panellayout';\n\nimport { Widget } from './widget';\n\n/**\n * A simple and convenient panel widget class.\n *\n * #### Notes\n * This class is suitable as a base class for implementing a variety of\n * convenience panel widgets, but can also be used directly with CSS to\n * arrange a collection of widgets.\n *\n * This class provides a convenience wrapper around a {@link PanelLayout}.\n */\nexport class Panel extends Widget {\n /**\n * Construct a new panel.\n *\n * @param options - The options for initializing the panel.\n */\n constructor(options: Panel.IOptions = {}) {\n super();\n this.addClass('lm-Panel');\n this.layout = Private.createLayout(options);\n }\n\n /**\n * A read-only array of the widgets in the panel.\n */\n get widgets(): ReadonlyArray {\n return (this.layout as PanelLayout).widgets;\n }\n\n /**\n * Add a widget to the end of the panel.\n *\n * @param widget - The widget to add to the panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n */\n addWidget(widget: Widget): void {\n (this.layout as PanelLayout).addWidget(widget);\n }\n\n /**\n * Insert a widget at the specified index.\n *\n * @param index - The index at which to insert the widget.\n *\n * @param widget - The widget to insert into to the panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n */\n insertWidget(index: number, widget: Widget): void {\n (this.layout as PanelLayout).insertWidget(index, widget);\n }\n}\n\n/**\n * The namespace for the `Panel` class statics.\n */\nexport namespace Panel {\n /**\n * An options object for creating a panel.\n */\n export interface IOptions {\n /**\n * The panel layout to use for the panel.\n *\n * The default is a new `PanelLayout`.\n */\n layout?: PanelLayout;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Create a panel layout for the given panel options.\n */\n export function createLayout(options: Panel.IOptions): PanelLayout {\n return options.layout || new PanelLayout();\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { IDisposable } from '@lumino/disposable';\n\nimport { Drag } from '@lumino/dragdrop';\n\nimport { Message } from '@lumino/messaging';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { Panel } from './panel';\n\nimport { SplitLayout } from './splitlayout';\n\nimport { Widget } from './widget';\n\n/**\n * A panel which arranges its widgets into resizable sections.\n *\n * #### Notes\n * This class provides a convenience wrapper around a {@link SplitLayout}.\n */\nexport class SplitPanel extends Panel {\n /**\n * Construct a new split panel.\n *\n * @param options - The options for initializing the split panel.\n */\n constructor(options: SplitPanel.IOptions = {}) {\n super({ layout: Private.createLayout(options) });\n this.addClass('lm-SplitPanel');\n }\n\n /**\n * Dispose of the resources held by the panel.\n */\n dispose(): void {\n this._releaseMouse();\n super.dispose();\n }\n\n /**\n * Get the layout orientation for the split panel.\n */\n get orientation(): SplitPanel.Orientation {\n return (this.layout as SplitLayout).orientation;\n }\n\n /**\n * Set the layout orientation for the split panel.\n */\n set orientation(value: SplitPanel.Orientation) {\n (this.layout as SplitLayout).orientation = value;\n }\n\n /**\n * Get the content alignment for the split panel.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire split panel.\n */\n get alignment(): SplitPanel.Alignment {\n return (this.layout as SplitLayout).alignment;\n }\n\n /**\n * Set the content alignment for the split panel.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire split panel.\n */\n set alignment(value: SplitPanel.Alignment) {\n (this.layout as SplitLayout).alignment = value;\n }\n\n /**\n * Get the inter-element spacing for the split panel.\n */\n get spacing(): number {\n return (this.layout as SplitLayout).spacing;\n }\n\n /**\n * Set the inter-element spacing for the split panel.\n */\n set spacing(value: number) {\n (this.layout as SplitLayout).spacing = value;\n }\n\n /**\n * The renderer used by the split panel.\n */\n get renderer(): SplitPanel.IRenderer {\n return (this.layout as SplitLayout).renderer;\n }\n\n /**\n * A signal emitted when a split handle has moved.\n */\n get handleMoved(): ISignal {\n return this._handleMoved;\n }\n\n /**\n * A read-only array of the split handles in the panel.\n */\n get handles(): ReadonlyArray {\n return (this.layout as SplitLayout).handles;\n }\n\n /**\n * Get the relative sizes of the widgets in the panel.\n *\n * @returns A new array of the relative sizes of the widgets.\n *\n * #### Notes\n * The returned sizes reflect the sizes of the widgets normalized\n * relative to their siblings.\n *\n * This method **does not** measure the DOM nodes.\n */\n relativeSizes(): number[] {\n return (this.layout as SplitLayout).relativeSizes();\n }\n\n /**\n * Set the relative sizes for the widgets in the panel.\n *\n * @param sizes - The relative sizes for the widgets in the panel.\n * @param update - Update the layout after setting relative sizes.\n * Default is True.\n *\n * #### Notes\n * Extra values are ignored, too few will yield an undefined layout.\n *\n * The actual geometry of the DOM nodes is updated asynchronously.\n */\n setRelativeSizes(sizes: number[], update = true): void {\n (this.layout as SplitLayout).setRelativeSizes(sizes, update);\n }\n\n /**\n * Handle the DOM events for the split panel.\n *\n * @param event - The DOM event sent to the panel.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the panel's DOM node. It should\n * not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'pointerdown':\n this._evtPointerDown(event as PointerEvent);\n break;\n case 'pointermove':\n this._evtPointerMove(event as PointerEvent);\n break;\n case 'pointerup':\n this._evtPointerUp(event as PointerEvent);\n break;\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('pointerdown', this);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('pointerdown', this);\n this._releaseMouse();\n }\n\n /**\n * A message handler invoked on a `'child-added'` message.\n */\n protected onChildAdded(msg: Widget.ChildMessage): void {\n msg.child.addClass('lm-SplitPanel-child');\n this._releaseMouse();\n }\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {\n msg.child.removeClass('lm-SplitPanel-child');\n this._releaseMouse();\n }\n\n /**\n * Handle the `'keydown'` event for the split panel.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // Stop input events during drag.\n if (this._pressData) {\n event.preventDefault();\n event.stopPropagation();\n }\n\n // Release the mouse if `Escape` is pressed.\n if (event.keyCode === 27) {\n this._releaseMouse();\n }\n }\n\n /**\n * Handle the `'pointerdown'` event for the split panel.\n */\n private _evtPointerDown(event: PointerEvent): void {\n // Do nothing if the primary button is not pressed.\n if (event.button !== 0) {\n return;\n }\n\n // Find the handle which contains the target, if any.\n let layout = this.layout as SplitLayout;\n let index = ArrayExt.findFirstIndex(layout.handles, handle => {\n return handle.contains(event.target as HTMLElement);\n });\n\n // Bail early if the mouse press was not on a handle.\n if (index === -1) {\n return;\n }\n\n // Stop the event when a split handle is pressed.\n event.preventDefault();\n event.stopPropagation();\n\n // Add the extra document listeners.\n document.addEventListener('pointerup', this, true);\n document.addEventListener('pointermove', this, true);\n document.addEventListener('keydown', this, true);\n document.addEventListener('contextmenu', this, true);\n\n // Compute the offset delta for the handle press.\n let delta: number;\n let handle = layout.handles[index];\n let rect = handle.getBoundingClientRect();\n if (layout.orientation === 'horizontal') {\n delta = event.clientX - rect.left;\n } else {\n delta = event.clientY - rect.top;\n }\n\n // Override the cursor and store the press data.\n let style = window.getComputedStyle(handle);\n let override = Drag.overrideCursor(style.cursor!);\n this._pressData = { index, delta, override };\n }\n\n /**\n * Handle the `'pointermove'` event for the split panel.\n */\n private _evtPointerMove(event: PointerEvent): void {\n // Stop the event when dragging a split handle.\n event.preventDefault();\n event.stopPropagation();\n\n // Compute the desired offset position for the handle.\n let pos: number;\n let layout = this.layout as SplitLayout;\n let rect = this.node.getBoundingClientRect();\n if (layout.orientation === 'horizontal') {\n pos = event.clientX - rect.left - this._pressData!.delta;\n } else {\n pos = event.clientY - rect.top - this._pressData!.delta;\n }\n\n // Move the handle as close to the desired position as possible.\n layout.moveHandle(this._pressData!.index, pos);\n }\n\n /**\n * Handle the `'pointerup'` event for the split panel.\n */\n private _evtPointerUp(event: PointerEvent): void {\n // Do nothing if the primary button is not released.\n if (event.button !== 0) {\n return;\n }\n\n // Stop the event when releasing a handle.\n event.preventDefault();\n event.stopPropagation();\n\n // Finalize the mouse release.\n this._releaseMouse();\n }\n\n /**\n * Release the mouse grab for the split panel.\n */\n private _releaseMouse(): void {\n // Bail early if no drag is in progress.\n if (!this._pressData) {\n return;\n }\n\n // Clear the override cursor.\n this._pressData.override.dispose();\n this._pressData = null;\n\n // Emit the handle moved signal.\n this._handleMoved.emit();\n\n // Remove the extra document listeners.\n document.removeEventListener('keydown', this, true);\n document.removeEventListener('pointerup', this, true);\n document.removeEventListener('pointermove', this, true);\n document.removeEventListener('contextmenu', this, true);\n }\n\n private _handleMoved = new Signal(this);\n private _pressData: Private.IPressData | null = null;\n}\n\n/**\n * The namespace for the `SplitPanel` class statics.\n */\nexport namespace SplitPanel {\n /**\n * A type alias for a split panel orientation.\n */\n export type Orientation = SplitLayout.Orientation;\n\n /**\n * A type alias for a split panel alignment.\n */\n export type Alignment = SplitLayout.Alignment;\n\n /**\n * A type alias for a split panel renderer.\n */\n export type IRenderer = SplitLayout.IRenderer;\n\n /**\n * An options object for initializing a split panel.\n */\n export interface IOptions {\n /**\n * The renderer to use for the split panel.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n\n /**\n * The layout orientation of the panel.\n *\n * The default is `'horizontal'`.\n */\n orientation?: Orientation;\n\n /**\n * The content alignment of the panel.\n *\n * The default is `'start'`.\n */\n alignment?: Alignment;\n\n /**\n * The spacing between items in the panel.\n *\n * The default is `4`.\n */\n spacing?: number;\n\n /**\n * The split layout to use for the split panel.\n *\n * If this is provided, the other options are ignored.\n *\n * The default is a new `SplitLayout`.\n */\n layout?: SplitLayout;\n }\n\n /**\n * The default implementation of `IRenderer`.\n */\n export class Renderer implements IRenderer {\n /**\n * Create a new handle for use with a split panel.\n *\n * @returns A new handle element for a split panel.\n */\n createHandle(): HTMLDivElement {\n let handle = document.createElement('div');\n handle.className = 'lm-SplitPanel-handle';\n return handle;\n }\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n\n /**\n * Get the split panel stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The split panel stretch factor for the widget.\n */\n export function getStretch(widget: Widget): number {\n return SplitLayout.getStretch(widget);\n }\n\n /**\n * Set the split panel stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the stretch factor.\n */\n export function setStretch(widget: Widget, value: number): void {\n SplitLayout.setStretch(widget, value);\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * An object which holds mouse press data.\n */\n export interface IPressData {\n /**\n * The index of the pressed handle.\n */\n index: number;\n\n /**\n * The offset of the press in handle coordinates.\n */\n delta: number;\n\n /**\n * The disposable which will clear the override cursor.\n */\n override: IDisposable;\n }\n\n /**\n * Create a split layout for the given panel options.\n */\n export function createLayout(options: SplitPanel.IOptions): SplitLayout {\n return (\n options.layout ||\n new SplitLayout({\n renderer: options.renderer || SplitPanel.defaultRenderer,\n orientation: options.orientation,\n alignment: options.alignment,\n spacing: options.spacing\n })\n );\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n\nimport { ArrayExt } from '@lumino/algorithm';\nimport { Message } from '@lumino/messaging';\nimport { ISignal, Signal } from '@lumino/signaling';\nimport { AccordionLayout } from './accordionlayout';\nimport { SplitLayout } from './splitlayout';\nimport { SplitPanel } from './splitpanel';\nimport { Title } from './title';\nimport { Widget } from './widget';\n\n/**\n * A panel which arranges its widgets into resizable sections separated by a title widget.\n *\n * #### Notes\n * This class provides a convenience wrapper around {@link AccordionLayout}.\n */\nexport class AccordionPanel extends SplitPanel {\n /**\n * Construct a new accordion panel.\n *\n * @param options - The options for initializing the accordion panel.\n */\n constructor(options: AccordionPanel.IOptions = {}) {\n super({ ...options, layout: Private.createLayout(options) });\n this.addClass('lm-AccordionPanel');\n }\n\n /**\n * The renderer used by the accordion panel.\n */\n get renderer(): AccordionPanel.IRenderer {\n return (this.layout as AccordionLayout).renderer;\n }\n\n /**\n * The section title space.\n *\n * This is the height if the panel is vertical and the width if it is\n * horizontal.\n */\n get titleSpace(): number {\n return (this.layout as AccordionLayout).titleSpace;\n }\n set titleSpace(value: number) {\n (this.layout as AccordionLayout).titleSpace = value;\n }\n\n /**\n * A read-only array of the section titles in the panel.\n */\n get titles(): ReadonlyArray {\n return (this.layout as AccordionLayout).titles;\n }\n\n /**\n * A signal emitted when a widget of the AccordionPanel is collapsed or expanded.\n */\n get expansionToggled(): ISignal {\n return this._expansionToggled;\n }\n\n /**\n * Add a widget to the end of the panel.\n *\n * @param widget - The widget to add to the panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n */\n addWidget(widget: Widget): void {\n super.addWidget(widget);\n widget.title.changed.connect(this._onTitleChanged, this);\n }\n\n /**\n * Collapse the widget at position `index`.\n *\n * #### Notes\n * If no widget is found for `index`, this will bail.\n *\n * @param index Widget index\n */\n collapse(index: number): void {\n const widget = (this.layout as AccordionLayout).widgets[index];\n\n if (widget && !widget.isHidden) {\n this._toggleExpansion(index);\n }\n }\n\n /**\n * Expand the widget at position `index`.\n *\n * #### Notes\n * If no widget is found for `index`, this will bail.\n *\n * @param index Widget index\n */\n expand(index: number): void {\n const widget = (this.layout as AccordionLayout).widgets[index];\n\n if (widget && widget.isHidden) {\n this._toggleExpansion(index);\n }\n }\n\n /**\n * Insert a widget at the specified index.\n *\n * @param index - The index at which to insert the widget.\n *\n * @param widget - The widget to insert into to the panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n */\n insertWidget(index: number, widget: Widget): void {\n super.insertWidget(index, widget);\n widget.title.changed.connect(this._onTitleChanged, this);\n }\n\n /**\n * Handle the DOM events for the accordion panel.\n *\n * @param event - The DOM event sent to the panel.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the panel's DOM node. It should\n * not be called directly by user code.\n */\n handleEvent(event: Event): void {\n super.handleEvent(event);\n switch (event.type) {\n case 'click':\n this._evtClick(event as MouseEvent);\n break;\n case 'keydown':\n this._eventKeyDown(event as KeyboardEvent);\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('click', this);\n this.node.addEventListener('keydown', this);\n super.onBeforeAttach(msg);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n super.onAfterDetach(msg);\n this.node.removeEventListener('click', this);\n this.node.removeEventListener('keydown', this);\n }\n\n /**\n * Handle the `changed` signal of a title object.\n */\n private _onTitleChanged(sender: Title): void {\n const index = ArrayExt.findFirstIndex(this.widgets, widget => {\n return widget.contains(sender.owner);\n });\n\n if (index >= 0) {\n (this.layout as AccordionLayout).updateTitle(index, sender.owner);\n this.update();\n }\n }\n\n /**\n * Compute the size of widgets in this panel on the title click event.\n * On closing, the size of the widget is cached and we will try to expand\n * the last opened widget.\n * On opening, we will use the cached size if it is available to restore the\n * widget.\n * In both cases, if we can not compute the size of widgets, we will let\n * `SplitLayout` decide.\n *\n * @param index - The index of widget to be opened of closed\n *\n * @returns Relative size of widgets in this panel, if this size can\n * not be computed, return `undefined`\n */\n private _computeWidgetSize(index: number): number[] | undefined {\n const layout = this.layout as AccordionLayout;\n\n const widget = layout.widgets[index];\n if (!widget) {\n return undefined;\n }\n const isHidden = widget.isHidden;\n const widgetSizes = layout.absoluteSizes();\n const delta = (isHidden ? -1 : 1) * this.spacing;\n const totalSize = widgetSizes.reduce(\n (prev: number, curr: number) => prev + curr\n );\n\n let newSize = [...widgetSizes];\n\n if (!isHidden) {\n // Hide the widget\n const currentSize = widgetSizes[index];\n\n this._widgetSizesCache.set(widget, currentSize);\n newSize[index] = 0;\n\n const widgetToCollapse = newSize.map(sz => sz > 0).lastIndexOf(true);\n if (widgetToCollapse === -1) {\n // All widget are closed, let the `SplitLayout` compute widget sizes.\n return undefined;\n }\n\n newSize[widgetToCollapse] =\n widgetSizes[widgetToCollapse] + currentSize + delta;\n } else {\n // Show the widget\n const previousSize = this._widgetSizesCache.get(widget);\n if (!previousSize) {\n // Previous size is unavailable, let the `SplitLayout` compute widget sizes.\n return undefined;\n }\n newSize[index] += previousSize;\n\n const widgetToCollapse = newSize\n .map(sz => sz - previousSize > 0)\n .lastIndexOf(true);\n if (widgetToCollapse === -1) {\n // Can not reduce the size of one widget, reduce all opened widgets\n // proportionally with its size.\n newSize.forEach((_, idx) => {\n if (idx !== index) {\n newSize[idx] -=\n (widgetSizes[idx] / totalSize) * (previousSize - delta);\n }\n });\n } else {\n newSize[widgetToCollapse] -= previousSize - delta;\n }\n }\n return newSize.map(sz => sz / (totalSize + delta));\n }\n /**\n * Handle the `'click'` event for the accordion panel\n */\n private _evtClick(event: MouseEvent): void {\n const target = event.target as HTMLElement | null;\n\n if (target) {\n const index = ArrayExt.findFirstIndex(this.titles, title => {\n return title.contains(target);\n });\n\n if (index >= 0) {\n event.preventDefault();\n event.stopPropagation();\n this._toggleExpansion(index);\n }\n }\n }\n\n /**\n * Handle the `'keydown'` event for the accordion panel.\n */\n private _eventKeyDown(event: KeyboardEvent): void {\n if (event.defaultPrevented) {\n return;\n }\n\n const target = event.target as HTMLElement | null;\n let handled = false;\n if (target) {\n const index = ArrayExt.findFirstIndex(this.titles, title => {\n return title.contains(target);\n });\n\n if (index >= 0) {\n const keyCode = event.keyCode.toString();\n\n // If Space or Enter is pressed on title, emulate click event\n if (event.key.match(/Space|Enter/) || keyCode.match(/13|32/)) {\n target.click();\n handled = true;\n } else if (\n this.orientation === 'horizontal'\n ? event.key.match(/ArrowLeft|ArrowRight/) || keyCode.match(/37|39/)\n : event.key.match(/ArrowUp|ArrowDown/) || keyCode.match(/38|40/)\n ) {\n // If Up or Down (for vertical) / Left or Right (for horizontal) is pressed on title, loop on titles\n const direction =\n event.key.match(/ArrowLeft|ArrowUp/) || keyCode.match(/37|38/)\n ? -1\n : 1;\n const length = this.titles.length;\n const newIndex = (index + length + direction) % length;\n\n this.titles[newIndex].focus();\n handled = true;\n } else if (event.key === 'End' || keyCode === '35') {\n // If End is pressed on title, focus on the last title\n this.titles[this.titles.length - 1].focus();\n handled = true;\n } else if (event.key === 'Home' || keyCode === '36') {\n // If Home is pressed on title, focus on the first title\n this.titles[0].focus();\n handled = true;\n }\n }\n\n if (handled) {\n event.preventDefault();\n }\n }\n }\n\n private _toggleExpansion(index: number) {\n const title = this.titles[index];\n const widget = (this.layout as AccordionLayout).widgets[index];\n\n const newSize = this._computeWidgetSize(index);\n if (newSize) {\n this.setRelativeSizes(newSize, false);\n }\n\n if (widget.isHidden) {\n title.classList.add('lm-mod-expanded');\n title.setAttribute('aria-expanded', 'true');\n widget.show();\n } else {\n title.classList.remove('lm-mod-expanded');\n title.setAttribute('aria-expanded', 'false');\n widget.hide();\n }\n\n // Emit the expansion state signal.\n this._expansionToggled.emit(index);\n }\n\n private _widgetSizesCache: WeakMap = new WeakMap();\n private _expansionToggled = new Signal(this);\n}\n\n/**\n * The namespace for the `AccordionPanel` class statics.\n */\nexport namespace AccordionPanel {\n /**\n * A type alias for a accordion panel orientation.\n */\n export type Orientation = SplitLayout.Orientation;\n\n /**\n * A type alias for a accordion panel alignment.\n */\n export type Alignment = SplitLayout.Alignment;\n\n /**\n * A type alias for a accordion panel renderer.\n */\n export type IRenderer = AccordionLayout.IRenderer;\n\n /**\n * An options object for initializing a accordion panel.\n */\n export interface IOptions extends Partial {\n /**\n * The accordion layout to use for the accordion panel.\n *\n * If this is provided, the other options are ignored.\n *\n * The default is a new `AccordionLayout`.\n */\n layout?: AccordionLayout;\n }\n\n /**\n * The default implementation of `IRenderer`.\n */\n export class Renderer extends SplitPanel.Renderer implements IRenderer {\n constructor() {\n super();\n this._uuid = ++Renderer._nInstance;\n }\n /**\n * A selector which matches any title node in the accordion.\n */\n readonly titleClassName = 'lm-AccordionPanel-title';\n\n /**\n * Render the collapse indicator for a section title.\n *\n * @param data - The data to use for rendering the section title.\n *\n * @returns A element representing the collapse indicator.\n */\n createCollapseIcon(data: Title): HTMLElement {\n return document.createElement('span');\n }\n\n /**\n * Render the element for a section title.\n *\n * @param data - The data to use for rendering the section title.\n *\n * @returns A element representing the section title.\n */\n createSectionTitle(data: Title): HTMLElement {\n const handle = document.createElement('h3');\n handle.setAttribute('tabindex', '0');\n handle.id = this.createTitleKey(data);\n handle.className = this.titleClassName;\n for (const aData in data.dataset) {\n handle.dataset[aData] = data.dataset[aData];\n }\n\n const collapser = handle.appendChild(this.createCollapseIcon(data));\n collapser.className = 'lm-AccordionPanel-titleCollapser';\n\n const label = handle.appendChild(document.createElement('span'));\n label.className = 'lm-AccordionPanel-titleLabel';\n label.textContent = data.label;\n label.title = data.caption || data.label;\n\n return handle;\n }\n\n /**\n * Create a unique render key for the title.\n *\n * @param data - The data to use for the title.\n *\n * @returns The unique render key for the title.\n *\n * #### Notes\n * This method caches the key against the section title the first time\n * the key is generated.\n */\n createTitleKey(data: Title): string {\n let key = this._titleKeys.get(data);\n if (key === undefined) {\n key = `title-key-${this._uuid}-${this._titleID++}`;\n this._titleKeys.set(data, key);\n }\n return key;\n }\n\n private static _nInstance = 0;\n private readonly _uuid: number;\n private _titleID = 0;\n private _titleKeys = new WeakMap, string>();\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n}\n\nnamespace Private {\n /**\n * Create an accordion layout for the given panel options.\n *\n * @param options Panel options\n * @returns Panel layout\n */\n export function createLayout(\n options: AccordionPanel.IOptions\n ): AccordionLayout {\n return (\n options.layout ||\n new AccordionLayout({\n renderer: options.renderer || AccordionPanel.defaultRenderer,\n orientation: options.orientation,\n alignment: options.alignment,\n spacing: options.spacing,\n titleSpace: options.titleSpace\n })\n );\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { BoxEngine, BoxSizer } from './boxengine';\n\nimport { LayoutItem } from './layout';\n\nimport { PanelLayout } from './panellayout';\n\nimport Utils from './utils';\n\nimport { Widget } from './widget';\n\n/**\n * A layout which arranges its widgets in a single row or column.\n */\nexport class BoxLayout extends PanelLayout {\n /**\n * Construct a new box layout.\n *\n * @param options - The options for initializing the layout.\n */\n constructor(options: BoxLayout.IOptions = {}) {\n super();\n if (options.direction !== undefined) {\n this._direction = options.direction;\n }\n if (options.alignment !== undefined) {\n this._alignment = options.alignment;\n }\n if (options.spacing !== undefined) {\n this._spacing = Utils.clampDimension(options.spacing);\n }\n }\n\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n // Dispose of the layout items.\n for (const item of this._items) {\n item.dispose();\n }\n\n // Clear the layout state.\n this._box = null;\n this._items.length = 0;\n this._sizers.length = 0;\n\n // Dispose of the rest of the layout.\n super.dispose();\n }\n\n /**\n * Get the layout direction for the box layout.\n */\n get direction(): BoxLayout.Direction {\n return this._direction;\n }\n\n /**\n * Set the layout direction for the box layout.\n */\n set direction(value: BoxLayout.Direction) {\n if (this._direction === value) {\n return;\n }\n this._direction = value;\n if (!this.parent) {\n return;\n }\n this.parent.dataset['direction'] = value;\n this.parent.fit();\n }\n\n /**\n * Get the content alignment for the box layout.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire box layout.\n */\n get alignment(): BoxLayout.Alignment {\n return this._alignment;\n }\n\n /**\n * Set the content alignment for the box layout.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire box layout.\n */\n set alignment(value: BoxLayout.Alignment) {\n if (this._alignment === value) {\n return;\n }\n this._alignment = value;\n if (!this.parent) {\n return;\n }\n this.parent.dataset['alignment'] = value;\n this.parent.update();\n }\n\n /**\n * Get the inter-element spacing for the box layout.\n */\n get spacing(): number {\n return this._spacing;\n }\n\n /**\n * Set the inter-element spacing for the box layout.\n */\n set spacing(value: number) {\n value = Utils.clampDimension(value);\n if (this._spacing === value) {\n return;\n }\n this._spacing = value;\n if (!this.parent) {\n return;\n }\n this.parent.fit();\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n this.parent!.dataset['direction'] = this.direction;\n this.parent!.dataset['alignment'] = this.alignment;\n super.init();\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param index - The current index of the widget in the layout.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected attachWidget(index: number, widget: Widget): void {\n // Create and add a new layout item for the widget.\n ArrayExt.insert(this._items, index, new LayoutItem(widget));\n\n // Create and add a new sizer for the widget.\n ArrayExt.insert(this._sizers, index, new BoxSizer());\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget's node to the parent.\n this.parent!.node.appendChild(widget.node);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * Move a widget in the parent's DOM node.\n *\n * @param fromIndex - The previous index of the widget in the layout.\n *\n * @param toIndex - The current index of the widget in the layout.\n *\n * @param widget - The widget to move in the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected moveWidget(\n fromIndex: number,\n toIndex: number,\n widget: Widget\n ): void {\n // Move the layout item for the widget.\n ArrayExt.move(this._items, fromIndex, toIndex);\n\n // Move the sizer for the widget.\n ArrayExt.move(this._sizers, fromIndex, toIndex);\n\n // Post an update request for the parent widget.\n this.parent!.update();\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param index - The previous index of the widget in the layout.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected detachWidget(index: number, widget: Widget): void {\n // Remove the layout item for the widget.\n let item = ArrayExt.removeAt(this._items, index);\n\n // Remove the sizer for the widget.\n ArrayExt.removeAt(this._sizers, index);\n\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Dispose of the layout item.\n item!.dispose();\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n */\n protected onBeforeShow(msg: Message): void {\n super.onBeforeShow(msg);\n this.parent!.update();\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n super.onBeforeAttach(msg);\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n if (this.parent!.isVisible) {\n this._update(msg.width, msg.height);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.parent!.isVisible) {\n this._update(-1, -1);\n }\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n */\n protected onFitRequest(msg: Message): void {\n if (this.parent!.isAttached) {\n this._fit();\n }\n }\n\n /**\n * Fit the layout to the total size required by the widgets.\n */\n private _fit(): void {\n // Compute the visible item count.\n let nVisible = 0;\n for (let i = 0, n = this._items.length; i < n; ++i) {\n nVisible += +!this._items[i].isHidden;\n }\n\n // Update the fixed space for the visible items.\n this._fixed = this._spacing * Math.max(0, nVisible - 1);\n\n // Setup the computed minimum size.\n let horz = Private.isHorizontal(this._direction);\n let minW = horz ? this._fixed : 0;\n let minH = horz ? 0 : this._fixed;\n\n // Update the sizers and computed minimum size.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item and corresponding box sizer.\n let item = this._items[i];\n let sizer = this._sizers[i];\n\n // If the item is hidden, it should consume zero size.\n if (item.isHidden) {\n sizer.minSize = 0;\n sizer.maxSize = 0;\n continue;\n }\n\n // Update the size limits for the item.\n item.fit();\n\n // Update the size basis and stretch factor.\n sizer.sizeHint = BoxLayout.getSizeBasis(item.widget);\n sizer.stretch = BoxLayout.getStretch(item.widget);\n\n // Update the sizer limits and computed min size.\n if (horz) {\n sizer.minSize = item.minWidth;\n sizer.maxSize = item.maxWidth;\n minW += item.minWidth;\n minH = Math.max(minH, item.minHeight);\n } else {\n sizer.minSize = item.minHeight;\n sizer.maxSize = item.maxHeight;\n minH += item.minHeight;\n minW = Math.max(minW, item.minWidth);\n }\n }\n\n // Update the box sizing and add it to the computed min size.\n let box = (this._box = ElementExt.boxSizing(this.parent!.node));\n minW += box.horizontalSum;\n minH += box.verticalSum;\n\n // Update the parent's min size constraints.\n let style = this.parent!.node.style;\n style.minWidth = `${minW}px`;\n style.minHeight = `${minH}px`;\n\n // Set the dirty flag to ensure only a single update occurs.\n this._dirty = true;\n\n // Notify the ancestor that it should fit immediately. This may\n // cause a resize of the parent, fulfilling the required update.\n if (this.parent!.parent) {\n MessageLoop.sendMessage(this.parent!.parent!, Widget.Msg.FitRequest);\n }\n\n // If the dirty flag is still set, the parent was not resized.\n // Trigger the required update on the parent widget immediately.\n if (this._dirty) {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n }\n }\n\n /**\n * Update the layout position and size of the widgets.\n *\n * The parent offset dimensions should be `-1` if unknown.\n */\n private _update(offsetWidth: number, offsetHeight: number): void {\n // Clear the dirty flag to indicate the update occurred.\n this._dirty = false;\n\n // Compute the visible item count.\n let nVisible = 0;\n for (let i = 0, n = this._items.length; i < n; ++i) {\n nVisible += +!this._items[i].isHidden;\n }\n\n // Bail early if there are no visible items to layout.\n if (nVisible === 0) {\n return;\n }\n\n // Measure the parent if the offset dimensions are unknown.\n if (offsetWidth < 0) {\n offsetWidth = this.parent!.node.offsetWidth;\n }\n if (offsetHeight < 0) {\n offsetHeight = this.parent!.node.offsetHeight;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent!.node);\n }\n\n // Compute the layout area adjusted for border and padding.\n let top = this._box.paddingTop;\n let left = this._box.paddingLeft;\n let width = offsetWidth - this._box.horizontalSum;\n let height = offsetHeight - this._box.verticalSum;\n\n // Distribute the layout space and adjust the start position.\n let delta: number;\n switch (this._direction) {\n case 'left-to-right':\n delta = BoxEngine.calc(this._sizers, Math.max(0, width - this._fixed));\n break;\n case 'top-to-bottom':\n delta = BoxEngine.calc(this._sizers, Math.max(0, height - this._fixed));\n break;\n case 'right-to-left':\n delta = BoxEngine.calc(this._sizers, Math.max(0, width - this._fixed));\n left += width;\n break;\n case 'bottom-to-top':\n delta = BoxEngine.calc(this._sizers, Math.max(0, height - this._fixed));\n top += height;\n break;\n default:\n throw 'unreachable';\n }\n\n // Setup the variables for justification and alignment offset.\n let extra = 0;\n let offset = 0;\n\n // Account for alignment if there is extra layout space.\n if (delta > 0) {\n switch (this._alignment) {\n case 'start':\n break;\n case 'center':\n extra = 0;\n offset = delta / 2;\n break;\n case 'end':\n extra = 0;\n offset = delta;\n break;\n case 'justify':\n extra = delta / nVisible;\n offset = 0;\n break;\n default:\n throw 'unreachable';\n }\n }\n\n // Layout the items using the computed box sizes.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item.\n let item = this._items[i];\n\n // Ignore hidden items.\n if (item.isHidden) {\n continue;\n }\n\n // Fetch the computed size for the widget.\n let size = this._sizers[i].size;\n\n // Update the widget geometry and advance the relevant edge.\n switch (this._direction) {\n case 'left-to-right':\n item.update(left + offset, top, size + extra, height);\n left += size + extra + this._spacing;\n break;\n case 'top-to-bottom':\n item.update(left, top + offset, width, size + extra);\n top += size + extra + this._spacing;\n break;\n case 'right-to-left':\n item.update(left - offset - size - extra, top, size + extra, height);\n left -= size + extra + this._spacing;\n break;\n case 'bottom-to-top':\n item.update(left, top - offset - size - extra, width, size + extra);\n top -= size + extra + this._spacing;\n break;\n default:\n throw 'unreachable';\n }\n }\n }\n\n private _fixed = 0;\n private _spacing = 4;\n private _dirty = false;\n private _sizers: BoxSizer[] = [];\n private _items: LayoutItem[] = [];\n private _box: ElementExt.IBoxSizing | null = null;\n private _alignment: BoxLayout.Alignment = 'start';\n private _direction: BoxLayout.Direction = 'top-to-bottom';\n}\n\n/**\n * The namespace for the `BoxLayout` class statics.\n */\nexport namespace BoxLayout {\n /**\n * A type alias for a box layout direction.\n */\n export type Direction =\n | 'left-to-right'\n | 'right-to-left'\n | 'top-to-bottom'\n | 'bottom-to-top';\n\n /**\n * A type alias for a box layout alignment.\n */\n export type Alignment = 'start' | 'center' | 'end' | 'justify';\n\n /**\n * An options object for initializing a box layout.\n */\n export interface IOptions {\n /**\n * The direction of the layout.\n *\n * The default is `'top-to-bottom'`.\n */\n direction?: Direction;\n\n /**\n * The content alignment of the layout.\n *\n * The default is `'start'`.\n */\n alignment?: Alignment;\n\n /**\n * The spacing between items in the layout.\n *\n * The default is `4`.\n */\n spacing?: number;\n }\n\n /**\n * Get the box layout stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The box layout stretch factor for the widget.\n */\n export function getStretch(widget: Widget): number {\n return Private.stretchProperty.get(widget);\n }\n\n /**\n * Set the box layout stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the stretch factor.\n */\n export function setStretch(widget: Widget, value: number): void {\n Private.stretchProperty.set(widget, value);\n }\n\n /**\n * Get the box layout size basis for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The box layout size basis for the widget.\n */\n export function getSizeBasis(widget: Widget): number {\n return Private.sizeBasisProperty.get(widget);\n }\n\n /**\n * Set the box layout size basis for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the size basis.\n */\n export function setSizeBasis(widget: Widget, value: number): void {\n Private.sizeBasisProperty.set(widget, value);\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The property descriptor for a widget stretch factor.\n */\n export const stretchProperty = new AttachedProperty({\n name: 'stretch',\n create: () => 0,\n coerce: (owner, value) => Math.max(0, Math.floor(value)),\n changed: onChildSizingChanged\n });\n\n /**\n * The property descriptor for a widget size basis.\n */\n export const sizeBasisProperty = new AttachedProperty({\n name: 'sizeBasis',\n create: () => 0,\n coerce: (owner, value) => Math.max(0, Math.floor(value)),\n changed: onChildSizingChanged\n });\n\n /**\n * Test whether a direction has horizontal orientation.\n */\n export function isHorizontal(dir: BoxLayout.Direction): boolean {\n return dir === 'left-to-right' || dir === 'right-to-left';\n }\n\n /**\n * Clamp a spacing value to an integer >= 0.\n */\n export function clampSpacing(value: number): number {\n return Math.max(0, Math.floor(value));\n }\n\n /**\n * The change handler for the attached sizing properties.\n */\n function onChildSizingChanged(child: Widget): void {\n if (child.parent && child.parent.layout instanceof BoxLayout) {\n child.parent.fit();\n }\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { BoxLayout } from './boxlayout';\n\nimport { Panel } from './panel';\n\nimport { Widget } from './widget';\n\n/**\n * A panel which arranges its widgets in a single row or column.\n *\n * #### Notes\n * This class provides a convenience wrapper around a {@link BoxLayout}.\n */\nexport class BoxPanel extends Panel {\n /**\n * Construct a new box panel.\n *\n * @param options - The options for initializing the box panel.\n */\n constructor(options: BoxPanel.IOptions = {}) {\n super({ layout: Private.createLayout(options) });\n this.addClass('lm-BoxPanel');\n }\n\n /**\n * Get the layout direction for the box panel.\n */\n get direction(): BoxPanel.Direction {\n return (this.layout as BoxLayout).direction;\n }\n\n /**\n * Set the layout direction for the box panel.\n */\n set direction(value: BoxPanel.Direction) {\n (this.layout as BoxLayout).direction = value;\n }\n\n /**\n * Get the content alignment for the box panel.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire box layout.\n */\n get alignment(): BoxPanel.Alignment {\n return (this.layout as BoxLayout).alignment;\n }\n\n /**\n * Set the content alignment for the box panel.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire box layout.\n */\n set alignment(value: BoxPanel.Alignment) {\n (this.layout as BoxLayout).alignment = value;\n }\n\n /**\n * Get the inter-element spacing for the box panel.\n */\n get spacing(): number {\n return (this.layout as BoxLayout).spacing;\n }\n\n /**\n * Set the inter-element spacing for the box panel.\n */\n set spacing(value: number) {\n (this.layout as BoxLayout).spacing = value;\n }\n\n /**\n * A message handler invoked on a `'child-added'` message.\n */\n protected onChildAdded(msg: Widget.ChildMessage): void {\n msg.child.addClass('lm-BoxPanel-child');\n }\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {\n msg.child.removeClass('lm-BoxPanel-child');\n }\n}\n\n/**\n * The namespace for the `BoxPanel` class statics.\n */\nexport namespace BoxPanel {\n /**\n * A type alias for a box panel direction.\n */\n export type Direction = BoxLayout.Direction;\n\n /**\n * A type alias for a box panel alignment.\n */\n export type Alignment = BoxLayout.Alignment;\n\n /**\n * An options object for initializing a box panel.\n */\n export interface IOptions {\n /**\n * The layout direction of the panel.\n *\n * The default is `'top-to-bottom'`.\n */\n direction?: Direction;\n\n /**\n * The content alignment of the panel.\n *\n * The default is `'start'`.\n */\n alignment?: Alignment;\n\n /**\n * The spacing between items in the panel.\n *\n * The default is `4`.\n */\n spacing?: number;\n\n /**\n * The box layout to use for the box panel.\n *\n * If this is provided, the other options are ignored.\n *\n * The default is a new `BoxLayout`.\n */\n layout?: BoxLayout;\n }\n\n /**\n * Get the box panel stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The box panel stretch factor for the widget.\n */\n export function getStretch(widget: Widget): number {\n return BoxLayout.getStretch(widget);\n }\n\n /**\n * Set the box panel stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the stretch factor.\n */\n export function setStretch(widget: Widget, value: number): void {\n BoxLayout.setStretch(widget, value);\n }\n\n /**\n * Get the box panel size basis for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The box panel size basis for the widget.\n */\n export function getSizeBasis(widget: Widget): number {\n return BoxLayout.getSizeBasis(widget);\n }\n\n /**\n * Set the box panel size basis for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the size basis.\n */\n export function setSizeBasis(widget: Widget, value: number): void {\n BoxLayout.setSizeBasis(widget, value);\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Create a box layout for the given panel options.\n */\n export function createLayout(options: BoxPanel.IOptions): BoxLayout {\n return options.layout || new BoxLayout(options);\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt, StringExt } from '@lumino/algorithm';\n\nimport { JSONExt, ReadonlyJSONObject } from '@lumino/coreutils';\n\nimport { CommandRegistry } from '@lumino/commands';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message } from '@lumino/messaging';\n\nimport {\n ElementDataset,\n h,\n VirtualDOM,\n VirtualElement\n} from '@lumino/virtualdom';\n\nimport { Widget } from './widget';\n\n/**\n * A widget which displays command items as a searchable palette.\n */\nexport class CommandPalette extends Widget {\n /**\n * Construct a new command palette.\n *\n * @param options - The options for initializing the palette.\n */\n constructor(options: CommandPalette.IOptions) {\n super({ node: Private.createNode() });\n this.addClass('lm-CommandPalette');\n this.setFlag(Widget.Flag.DisallowLayout);\n this.commands = options.commands;\n this.renderer = options.renderer || CommandPalette.defaultRenderer;\n this.commands.commandChanged.connect(this._onGenericChange, this);\n this.commands.keyBindingChanged.connect(this._onGenericChange, this);\n }\n\n /**\n * Dispose of the resources held by the widget.\n */\n dispose(): void {\n this._items.length = 0;\n this._results = null;\n super.dispose();\n }\n\n /**\n * The command registry used by the command palette.\n */\n readonly commands: CommandRegistry;\n\n /**\n * The renderer used by the command palette.\n */\n readonly renderer: CommandPalette.IRenderer;\n\n /**\n * The command palette search node.\n *\n * #### Notes\n * This is the node which contains the search-related elements.\n */\n get searchNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-CommandPalette-search'\n )[0] as HTMLDivElement;\n }\n\n /**\n * The command palette input node.\n *\n * #### Notes\n * This is the actual input node for the search area.\n */\n get inputNode(): HTMLInputElement {\n return this.node.getElementsByClassName(\n 'lm-CommandPalette-input'\n )[0] as HTMLInputElement;\n }\n\n /**\n * The command palette content node.\n *\n * #### Notes\n * This is the node which holds the command item nodes.\n *\n * Modifying this node directly can lead to undefined behavior.\n */\n get contentNode(): HTMLUListElement {\n return this.node.getElementsByClassName(\n 'lm-CommandPalette-content'\n )[0] as HTMLUListElement;\n }\n\n /**\n * A read-only array of the command items in the palette.\n */\n get items(): ReadonlyArray {\n return this._items;\n }\n\n /**\n * Add a command item to the command palette.\n *\n * @param options - The options for creating the command item.\n *\n * @returns The command item added to the palette.\n */\n addItem(options: CommandPalette.IItemOptions): CommandPalette.IItem {\n // Create a new command item for the options.\n let item = Private.createItem(this.commands, options);\n\n // Add the item to the array.\n this._items.push(item);\n\n // Refresh the search results.\n this.refresh();\n\n // Return the item added to the palette.\n return item;\n }\n\n /**\n * Adds command items to the command palette.\n *\n * @param items - An array of options for creating each command item.\n *\n * @returns The command items added to the palette.\n */\n addItems(items: CommandPalette.IItemOptions[]): CommandPalette.IItem[] {\n const newItems = items.map(item => Private.createItem(this.commands, item));\n newItems.forEach(item => this._items.push(item));\n this.refresh();\n return newItems;\n }\n\n /**\n * Remove an item from the command palette.\n *\n * @param item - The item to remove from the palette.\n *\n * #### Notes\n * This is a no-op if the item is not in the palette.\n */\n removeItem(item: CommandPalette.IItem): void {\n this.removeItemAt(this._items.indexOf(item));\n }\n\n /**\n * Remove the item at a given index from the command palette.\n *\n * @param index - The index of the item to remove.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n removeItemAt(index: number): void {\n // Remove the item from the array.\n let item = ArrayExt.removeAt(this._items, index);\n\n // Bail if the index is out of range.\n if (!item) {\n return;\n }\n\n // Refresh the search results.\n this.refresh();\n }\n\n /**\n * Remove all items from the command palette.\n */\n clearItems(): void {\n // Bail if there is nothing to remove.\n if (this._items.length === 0) {\n return;\n }\n\n // Clear the array of items.\n this._items.length = 0;\n\n // Refresh the search results.\n this.refresh();\n }\n\n /**\n * Clear the search results and schedule an update.\n *\n * #### Notes\n * This should be called whenever the search results of the palette\n * should be updated.\n *\n * This is typically called automatically by the palette as needed,\n * but can be called manually if the input text is programatically\n * changed.\n *\n * The rendered results are updated asynchronously.\n */\n refresh(): void {\n this._results = null;\n if (this.inputNode.value !== '') {\n let clear = this.node.getElementsByClassName(\n 'lm-close-icon'\n )[0] as HTMLInputElement;\n clear.style.display = 'inherit';\n } else {\n let clear = this.node.getElementsByClassName(\n 'lm-close-icon'\n )[0] as HTMLInputElement;\n clear.style.display = 'none';\n }\n this.update();\n }\n\n /**\n * Handle the DOM events for the command palette.\n *\n * @param event - The DOM event sent to the command palette.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the command palette's DOM node.\n * It should not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'click':\n this._evtClick(event as MouseEvent);\n break;\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'input':\n this.refresh();\n break;\n case 'focus':\n case 'blur':\n this._toggleFocused();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('click', this);\n this.node.addEventListener('keydown', this);\n this.node.addEventListener('input', this);\n this.node.addEventListener('focus', this, true);\n this.node.addEventListener('blur', this, true);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('click', this);\n this.node.removeEventListener('keydown', this);\n this.node.removeEventListener('input', this);\n this.node.removeEventListener('focus', this, true);\n this.node.removeEventListener('blur', this, true);\n }\n\n /**\n * A message handler invoked on an `'after-show'` message.\n */\n protected onAfterShow(msg: Message): void {\n this.update();\n super.onAfterShow(msg);\n }\n\n /**\n * A message handler invoked on an `'activate-request'` message.\n */\n protected onActivateRequest(msg: Message): void {\n if (this.isAttached) {\n let input = this.inputNode;\n input.focus();\n input.select();\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.isHidden) {\n return;\n }\n\n // Fetch the current query text and content node.\n let query = this.inputNode.value;\n let contentNode = this.contentNode;\n\n // Ensure the search results are generated.\n let results = this._results;\n if (!results) {\n // Generate and store the new search results.\n results = this._results = Private.search(this._items, query);\n\n // Reset the active index.\n this._activeIndex = query\n ? ArrayExt.findFirstIndex(results, Private.canActivate)\n : -1;\n }\n\n // If there is no query and no results, clear the content.\n if (!query && results.length === 0) {\n VirtualDOM.render(null, contentNode);\n return;\n }\n\n // If the is a query but no results, render the empty message.\n if (query && results.length === 0) {\n let content = this.renderer.renderEmptyMessage({ query });\n VirtualDOM.render(content, contentNode);\n return;\n }\n\n // Create the render content for the search results.\n let renderer = this.renderer;\n let activeIndex = this._activeIndex;\n let content = new Array(results.length);\n for (let i = 0, n = results.length; i < n; ++i) {\n let result = results[i];\n if (result.type === 'header') {\n let indices = result.indices;\n let category = result.category;\n content[i] = renderer.renderHeader({ category, indices });\n } else {\n let item = result.item;\n let indices = result.indices;\n let active = i === activeIndex;\n content[i] = renderer.renderItem({ item, indices, active });\n }\n }\n\n // Render the search result content.\n VirtualDOM.render(content, contentNode);\n\n // Adjust the scroll position as needed.\n if (activeIndex < 0 || activeIndex >= results.length) {\n contentNode.scrollTop = 0;\n } else {\n let element = contentNode.children[activeIndex];\n ElementExt.scrollIntoViewIfNeeded(contentNode, element);\n }\n }\n\n /**\n * Handle the `'click'` event for the command palette.\n */\n private _evtClick(event: MouseEvent): void {\n // Bail if the click is not the left button.\n if (event.button !== 0) {\n return;\n }\n\n // Clear input if the target is clear button\n if ((event.target as HTMLElement).classList.contains('lm-close-icon')) {\n this.inputNode.value = '';\n this.refresh();\n return;\n }\n\n // Find the index of the item which was clicked.\n let index = ArrayExt.findFirstIndex(this.contentNode.children, node => {\n return node.contains(event.target as HTMLElement);\n });\n\n // Bail if the click was not on an item.\n if (index === -1) {\n return;\n }\n\n // Kill the event when a content item is clicked.\n event.preventDefault();\n event.stopPropagation();\n\n // Execute the item if possible.\n this._execute(index);\n }\n\n /**\n * Handle the `'keydown'` event for the command palette.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n if (event.altKey || event.ctrlKey || event.metaKey || event.shiftKey) {\n return;\n }\n switch (event.keyCode) {\n case 13: // Enter\n event.preventDefault();\n event.stopPropagation();\n this._execute(this._activeIndex);\n break;\n case 38: // Up Arrow\n event.preventDefault();\n event.stopPropagation();\n this._activatePreviousItem();\n break;\n case 40: // Down Arrow\n event.preventDefault();\n event.stopPropagation();\n this._activateNextItem();\n break;\n }\n }\n\n /**\n * Activate the next enabled command item.\n */\n private _activateNextItem(): void {\n // Bail if there are no search results.\n if (!this._results || this._results.length === 0) {\n return;\n }\n\n // Find the next enabled item index.\n let ai = this._activeIndex;\n let n = this._results.length;\n let start = ai < n - 1 ? ai + 1 : 0;\n let stop = start === 0 ? n - 1 : start - 1;\n this._activeIndex = ArrayExt.findFirstIndex(\n this._results,\n Private.canActivate,\n start,\n stop\n );\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * Activate the previous enabled command item.\n */\n private _activatePreviousItem(): void {\n // Bail if there are no search results.\n if (!this._results || this._results.length === 0) {\n return;\n }\n\n // Find the previous enabled item index.\n let ai = this._activeIndex;\n let n = this._results.length;\n let start = ai <= 0 ? n - 1 : ai - 1;\n let stop = start === n - 1 ? 0 : start + 1;\n this._activeIndex = ArrayExt.findLastIndex(\n this._results,\n Private.canActivate,\n start,\n stop\n );\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * Execute the command item at the given index, if possible.\n */\n private _execute(index: number): void {\n // Bail if there are no search results.\n if (!this._results) {\n return;\n }\n\n // Bail if the index is out of range.\n let part = this._results[index];\n if (!part) {\n return;\n }\n\n // Update the search text if the item is a header.\n if (part.type === 'header') {\n let input = this.inputNode;\n input.value = `${part.category.toLowerCase()} `;\n input.focus();\n this.refresh();\n return;\n }\n\n // Bail if item is not enabled.\n if (!part.item.isEnabled) {\n return;\n }\n\n // Execute the item.\n this.commands.execute(part.item.command, part.item.args);\n\n // Clear the query text.\n this.inputNode.value = '';\n\n // Refresh the search results.\n this.refresh();\n }\n\n /**\n * Toggle the focused modifier based on the input node focus state.\n */\n private _toggleFocused(): void {\n let focused = document.activeElement === this.inputNode;\n this.toggleClass('lm-mod-focused', focused);\n }\n\n /**\n * A signal handler for generic command changes.\n */\n private _onGenericChange(): void {\n this.refresh();\n }\n\n private _activeIndex = -1;\n private _items: CommandPalette.IItem[] = [];\n private _results: Private.SearchResult[] | null = null;\n}\n\n/**\n * The namespace for the `CommandPalette` class statics.\n */\nexport namespace CommandPalette {\n /**\n * An options object for creating a command palette.\n */\n export interface IOptions {\n /**\n * The command registry for use with the command palette.\n */\n commands: CommandRegistry;\n\n /**\n * A custom renderer for use with the command palette.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n }\n\n /**\n * An options object for creating a command item.\n */\n export interface IItemOptions {\n /**\n * The category for the item.\n */\n category: string;\n\n /**\n * The command to execute when the item is triggered.\n */\n command: string;\n\n /**\n * The arguments for the command.\n *\n * The default value is an empty object.\n */\n args?: ReadonlyJSONObject;\n\n /**\n * The rank for the command item.\n *\n * The rank is used as a tie-breaker when ordering command items\n * for display. Items are sorted in the following order:\n * 1. Text match (lower is better)\n * 2. Category (locale order)\n * 3. Rank (lower is better)\n * 4. Label (locale order)\n *\n * The default rank is `Infinity`.\n */\n rank?: number;\n }\n\n /**\n * An object which represents an item in a command palette.\n *\n * #### Notes\n * Item objects are created automatically by a command palette.\n */\n export interface IItem {\n /**\n * The command to execute when the item is triggered.\n */\n readonly command: string;\n\n /**\n * The arguments for the command.\n */\n readonly args: ReadonlyJSONObject;\n\n /**\n * The category for the command item.\n */\n readonly category: string;\n\n /**\n * The rank for the command item.\n */\n readonly rank: number;\n\n /**\n * The display label for the command item.\n */\n readonly label: string;\n\n /**\n * The display caption for the command item.\n */\n readonly caption: string;\n\n /**\n * The icon renderer for the command item.\n */\n readonly icon: VirtualElement.IRenderer | undefined;\n\n /**\n * The icon class for the command item.\n */\n readonly iconClass: string;\n\n /**\n * The icon label for the command item.\n */\n readonly iconLabel: string;\n\n /**\n * The extra class name for the command item.\n */\n readonly className: string;\n\n /**\n * The dataset for the command item.\n */\n readonly dataset: CommandRegistry.Dataset;\n\n /**\n * Whether the command item is enabled.\n */\n readonly isEnabled: boolean;\n\n /**\n * Whether the command item is toggled.\n */\n readonly isToggled: boolean;\n\n /**\n * Whether the command item is toggleable.\n */\n readonly isToggleable: boolean;\n\n /**\n * Whether the command item is visible.\n */\n readonly isVisible: boolean;\n\n /**\n * The key binding for the command item.\n */\n readonly keyBinding: CommandRegistry.IKeyBinding | null;\n }\n\n /**\n * The render data for a command palette header.\n */\n export interface IHeaderRenderData {\n /**\n * The category of the header.\n */\n readonly category: string;\n\n /**\n * The indices of the matched characters in the category.\n */\n readonly indices: ReadonlyArray | null;\n }\n\n /**\n * The render data for a command palette item.\n */\n export interface IItemRenderData {\n /**\n * The command palette item to render.\n */\n readonly item: IItem;\n\n /**\n * The indices of the matched characters in the label.\n */\n readonly indices: ReadonlyArray | null;\n\n /**\n * Whether the item is the active item.\n */\n readonly active: boolean;\n }\n\n /**\n * The render data for a command palette empty message.\n */\n export interface IEmptyMessageRenderData {\n /**\n * The query which failed to match any commands.\n */\n query: string;\n }\n\n /**\n * A renderer for use with a command palette.\n */\n export interface IRenderer {\n /**\n * Render the virtual element for a command palette header.\n *\n * @param data - The data to use for rendering the header.\n *\n * @returns A virtual element representing the header.\n */\n renderHeader(data: IHeaderRenderData): VirtualElement;\n\n /**\n * Render the virtual element for a command palette item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n *\n * #### Notes\n * The command palette will not render invisible items.\n */\n renderItem(data: IItemRenderData): VirtualElement;\n\n /**\n * Render the empty results message for a command palette.\n *\n * @param data - The data to use for rendering the message.\n *\n * @returns A virtual element representing the message.\n */\n renderEmptyMessage(data: IEmptyMessageRenderData): VirtualElement;\n }\n\n /**\n * The default implementation of `IRenderer`.\n */\n export class Renderer implements IRenderer {\n /**\n * Render the virtual element for a command palette header.\n *\n * @param data - The data to use for rendering the header.\n *\n * @returns A virtual element representing the header.\n */\n renderHeader(data: IHeaderRenderData): VirtualElement {\n let content = this.formatHeader(data);\n return h.li({ className: 'lm-CommandPalette-header' }, content);\n }\n\n /**\n * Render the virtual element for a command palette item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n */\n renderItem(data: IItemRenderData): VirtualElement {\n let className = this.createItemClass(data);\n let dataset = this.createItemDataset(data);\n if (data.item.isToggleable) {\n return h.li(\n {\n className,\n dataset,\n role: 'menuitemcheckbox',\n 'aria-checked': `${data.item.isToggled}`\n },\n this.renderItemIcon(data),\n this.renderItemContent(data),\n this.renderItemShortcut(data)\n );\n }\n return h.li(\n {\n className,\n dataset,\n role: 'menuitem'\n },\n this.renderItemIcon(data),\n this.renderItemContent(data),\n this.renderItemShortcut(data)\n );\n }\n\n /**\n * Render the empty results message for a command palette.\n *\n * @param data - The data to use for rendering the message.\n *\n * @returns A virtual element representing the message.\n */\n renderEmptyMessage(data: IEmptyMessageRenderData): VirtualElement {\n let content = this.formatEmptyMessage(data);\n return h.li({ className: 'lm-CommandPalette-emptyMessage' }, content);\n }\n\n /**\n * Render the icon for a command palette item.\n *\n * @param data - The data to use for rendering the icon.\n *\n * @returns A virtual element representing the icon.\n */\n renderItemIcon(data: IItemRenderData): VirtualElement {\n let className = this.createIconClass(data);\n\n // If data.item.icon is undefined, it will be ignored.\n return h.div({ className }, data.item.icon!, data.item.iconLabel);\n }\n\n /**\n * Render the content for a command palette item.\n *\n * @param data - The data to use for rendering the content.\n *\n * @returns A virtual element representing the content.\n */\n renderItemContent(data: IItemRenderData): VirtualElement {\n return h.div(\n { className: 'lm-CommandPalette-itemContent' },\n this.renderItemLabel(data),\n this.renderItemCaption(data)\n );\n }\n\n /**\n * Render the label for a command palette item.\n *\n * @param data - The data to use for rendering the label.\n *\n * @returns A virtual element representing the label.\n */\n renderItemLabel(data: IItemRenderData): VirtualElement {\n let content = this.formatItemLabel(data);\n return h.div({ className: 'lm-CommandPalette-itemLabel' }, content);\n }\n\n /**\n * Render the caption for a command palette item.\n *\n * @param data - The data to use for rendering the caption.\n *\n * @returns A virtual element representing the caption.\n */\n renderItemCaption(data: IItemRenderData): VirtualElement {\n let content = this.formatItemCaption(data);\n return h.div({ className: 'lm-CommandPalette-itemCaption' }, content);\n }\n\n /**\n * Render the shortcut for a command palette item.\n *\n * @param data - The data to use for rendering the shortcut.\n *\n * @returns A virtual element representing the shortcut.\n */\n renderItemShortcut(data: IItemRenderData): VirtualElement {\n let content = this.formatItemShortcut(data);\n return h.div({ className: 'lm-CommandPalette-itemShortcut' }, content);\n }\n\n /**\n * Create the class name for the command palette item.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the command palette item.\n */\n createItemClass(data: IItemRenderData): string {\n // Set up the initial class name.\n let name = 'lm-CommandPalette-item';\n\n // Add the boolean state classes.\n if (!data.item.isEnabled) {\n name += ' lm-mod-disabled';\n }\n if (data.item.isToggled) {\n name += ' lm-mod-toggled';\n }\n if (data.active) {\n name += ' lm-mod-active';\n }\n\n // Add the extra class.\n let extra = data.item.className;\n if (extra) {\n name += ` ${extra}`;\n }\n\n // Return the complete class name.\n return name;\n }\n\n /**\n * Create the dataset for the command palette item.\n *\n * @param data - The data to use for creating the dataset.\n *\n * @returns The dataset for the command palette item.\n */\n createItemDataset(data: IItemRenderData): ElementDataset {\n return { ...data.item.dataset, command: data.item.command };\n }\n\n /**\n * Create the class name for the command item icon.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the item icon.\n */\n createIconClass(data: IItemRenderData): string {\n let name = 'lm-CommandPalette-itemIcon';\n let extra = data.item.iconClass;\n return extra ? `${name} ${extra}` : name;\n }\n\n /**\n * Create the render content for the header node.\n *\n * @param data - The data to use for the header content.\n *\n * @returns The content to add to the header node.\n */\n formatHeader(data: IHeaderRenderData): h.Child {\n if (!data.indices || data.indices.length === 0) {\n return data.category;\n }\n return StringExt.highlight(data.category, data.indices, h.mark);\n }\n\n /**\n * Create the render content for the empty message node.\n *\n * @param data - The data to use for the empty message content.\n *\n * @returns The content to add to the empty message node.\n */\n formatEmptyMessage(data: IEmptyMessageRenderData): h.Child {\n return `No commands found that match '${data.query}'`;\n }\n\n /**\n * Create the render content for the item shortcut node.\n *\n * @param data - The data to use for the shortcut content.\n *\n * @returns The content to add to the shortcut node.\n */\n formatItemShortcut(data: IItemRenderData): h.Child {\n let kb = data.item.keyBinding;\n return kb ? CommandRegistry.formatKeystroke(kb.keys) : null;\n }\n\n /**\n * Create the render content for the item label node.\n *\n * @param data - The data to use for the label content.\n *\n * @returns The content to add to the label node.\n */\n formatItemLabel(data: IItemRenderData): h.Child {\n if (!data.indices || data.indices.length === 0) {\n return data.item.label;\n }\n return StringExt.highlight(data.item.label, data.indices, h.mark);\n }\n\n /**\n * Create the render content for the item caption node.\n *\n * @param data - The data to use for the caption content.\n *\n * @returns The content to add to the caption node.\n */\n formatItemCaption(data: IItemRenderData): h.Child {\n return data.item.caption;\n }\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Create the DOM node for a command palette.\n */\n export function createNode(): HTMLDivElement {\n let node = document.createElement('div');\n let search = document.createElement('div');\n let wrapper = document.createElement('div');\n let input = document.createElement('input');\n let content = document.createElement('ul');\n let clear = document.createElement('button');\n search.className = 'lm-CommandPalette-search';\n wrapper.className = 'lm-CommandPalette-wrapper';\n input.className = 'lm-CommandPalette-input';\n clear.className = 'lm-close-icon';\n\n content.className = 'lm-CommandPalette-content';\n content.setAttribute('role', 'menu');\n input.spellcheck = false;\n wrapper.appendChild(input);\n wrapper.appendChild(clear);\n search.appendChild(wrapper);\n node.appendChild(search);\n node.appendChild(content);\n return node;\n }\n\n /**\n * Create a new command item from a command registry and options.\n */\n export function createItem(\n commands: CommandRegistry,\n options: CommandPalette.IItemOptions\n ): CommandPalette.IItem {\n return new CommandItem(commands, options);\n }\n\n /**\n * A search result object for a header label.\n */\n export interface IHeaderResult {\n /**\n * The discriminated type of the object.\n */\n readonly type: 'header';\n\n /**\n * The category for the header.\n */\n readonly category: string;\n\n /**\n * The indices of the matched category characters.\n */\n readonly indices: ReadonlyArray | null;\n }\n\n /**\n * A search result object for a command item.\n */\n export interface IItemResult {\n /**\n * The discriminated type of the object.\n */\n readonly type: 'item';\n\n /**\n * The command item which was matched.\n */\n readonly item: CommandPalette.IItem;\n\n /**\n * The indices of the matched label characters.\n */\n readonly indices: ReadonlyArray | null;\n }\n\n /**\n * A type alias for a search result item.\n */\n export type SearchResult = IHeaderResult | IItemResult;\n\n /**\n * Search an array of command items for fuzzy matches.\n */\n export function search(\n items: CommandPalette.IItem[],\n query: string\n ): SearchResult[] {\n // Fuzzy match the items for the query.\n let scores = matchItems(items, query);\n\n // Sort the items based on their score.\n scores.sort(scoreCmp);\n\n // Create the results for the search.\n return createResults(scores);\n }\n\n /**\n * Test whether a result item can be activated.\n */\n export function canActivate(result: SearchResult): boolean {\n return result.type === 'item' && result.item.isEnabled;\n }\n\n /**\n * Normalize a category for a command item.\n */\n function normalizeCategory(category: string): string {\n return category.trim().replace(/\\s+/g, ' ');\n }\n\n /**\n * Normalize the query text for a fuzzy search.\n */\n function normalizeQuery(text: string): string {\n return text.replace(/\\s+/g, '').toLowerCase();\n }\n\n /**\n * An enum of the supported match types.\n */\n const enum MatchType {\n Label,\n Category,\n Split,\n Default\n }\n\n /**\n * A text match score with associated command item.\n */\n interface IScore {\n /**\n * The numerical type for the text match.\n */\n matchType: MatchType;\n\n /**\n * The numerical score for the text match.\n */\n score: number;\n\n /**\n * The indices of the matched category characters.\n */\n categoryIndices: number[] | null;\n\n /**\n * The indices of the matched label characters.\n */\n labelIndices: number[] | null;\n\n /**\n * The command item associated with the match.\n */\n item: CommandPalette.IItem;\n }\n\n /**\n * Perform a fuzzy match on an array of command items.\n */\n function matchItems(items: CommandPalette.IItem[], query: string): IScore[] {\n // Normalize the query text to lower case with no whitespace.\n query = normalizeQuery(query);\n\n // Create the array to hold the scores.\n let scores: IScore[] = [];\n\n // Iterate over the items and match against the query.\n for (let i = 0, n = items.length; i < n; ++i) {\n // Ignore items which are not visible.\n let item = items[i];\n if (!item.isVisible) {\n continue;\n }\n\n // If the query is empty, all items are matched by default.\n if (!query) {\n scores.push({\n matchType: MatchType.Default,\n categoryIndices: null,\n labelIndices: null,\n score: 0,\n item\n });\n continue;\n }\n\n // Run the fuzzy search for the item and query.\n let score = fuzzySearch(item, query);\n\n // Ignore the item if it is not a match.\n if (!score) {\n continue;\n }\n\n // Penalize disabled items.\n // TODO - push disabled items all the way down in sort cmp?\n if (!item.isEnabled) {\n score.score += 1000;\n }\n\n // Add the score to the results.\n scores.push(score);\n }\n\n // Return the final array of scores.\n return scores;\n }\n\n /**\n * Perform a fuzzy search on a single command item.\n */\n function fuzzySearch(\n item: CommandPalette.IItem,\n query: string\n ): IScore | null {\n // Create the source text to be searched.\n let category = item.category.toLowerCase();\n let label = item.label.toLowerCase();\n let source = `${category} ${label}`;\n\n // Set up the match score and indices array.\n let score = Infinity;\n let indices: number[] | null = null;\n\n // The regex for search word boundaries\n let rgx = /\\b\\w/g;\n\n // Search the source by word boundary.\n // eslint-disable-next-line no-constant-condition\n while (true) {\n // Find the next word boundary in the source.\n let rgxMatch = rgx.exec(source);\n\n // Break if there is no more source context.\n if (!rgxMatch) {\n break;\n }\n\n // Run the string match on the relevant substring.\n let match = StringExt.matchSumOfDeltas(source, query, rgxMatch.index);\n\n // Break if there is no match.\n if (!match) {\n break;\n }\n\n // Update the match if the score is better.\n if (match.score <= score) {\n score = match.score;\n indices = match.indices;\n }\n }\n\n // Bail if there was no match.\n if (!indices || score === Infinity) {\n return null;\n }\n\n // Compute the pivot index between category and label text.\n let pivot = category.length + 1;\n\n // Find the slice index to separate matched indices.\n let j = ArrayExt.lowerBound(indices, pivot, (a, b) => a - b);\n\n // Extract the matched category and label indices.\n let categoryIndices = indices.slice(0, j);\n let labelIndices = indices.slice(j);\n\n // Adjust the label indices for the pivot offset.\n for (let i = 0, n = labelIndices.length; i < n; ++i) {\n labelIndices[i] -= pivot;\n }\n\n // Handle a pure label match.\n if (categoryIndices.length === 0) {\n return {\n matchType: MatchType.Label,\n categoryIndices: null,\n labelIndices,\n score,\n item\n };\n }\n\n // Handle a pure category match.\n if (labelIndices.length === 0) {\n return {\n matchType: MatchType.Category,\n categoryIndices,\n labelIndices: null,\n score,\n item\n };\n }\n\n // Handle a split match.\n return {\n matchType: MatchType.Split,\n categoryIndices,\n labelIndices,\n score,\n item\n };\n }\n\n /**\n * A sort comparison function for a match score.\n */\n function scoreCmp(a: IScore, b: IScore): number {\n // First compare based on the match type\n let m1 = a.matchType - b.matchType;\n if (m1 !== 0) {\n return m1;\n }\n\n // Otherwise, compare based on the match score.\n let d1 = a.score - b.score;\n if (d1 !== 0) {\n return d1;\n }\n\n // Find the match index based on the match type.\n let i1 = 0;\n let i2 = 0;\n switch (a.matchType) {\n case MatchType.Label:\n i1 = a.labelIndices![0];\n i2 = b.labelIndices![0];\n break;\n case MatchType.Category:\n case MatchType.Split:\n i1 = a.categoryIndices![0];\n i2 = b.categoryIndices![0];\n break;\n }\n\n // Compare based on the match index.\n if (i1 !== i2) {\n return i1 - i2;\n }\n\n // Otherwise, compare by category.\n let d2 = a.item.category.localeCompare(b.item.category);\n if (d2 !== 0) {\n return d2;\n }\n\n // Otherwise, compare by rank.\n let r1 = a.item.rank;\n let r2 = b.item.rank;\n if (r1 !== r2) {\n return r1 < r2 ? -1 : 1; // Infinity safe\n }\n\n // Finally, compare by label.\n return a.item.label.localeCompare(b.item.label);\n }\n\n /**\n * Create the results from an array of sorted scores.\n */\n function createResults(scores: IScore[]): SearchResult[] {\n // Set up the search results array.\n let results: SearchResult[] = [];\n\n // Iterate over each score in the array.\n for (let i = 0, n = scores.length; i < n; ++i) {\n // Extract the current item and indices.\n let { item, categoryIndices, labelIndices } = scores[i];\n\n // Extract the category for the current item.\n let category = item.category;\n\n // Is this the same category as the preceding result?\n if (i === 0 || category !== scores[i - 1].item.category) {\n // Add the header result for the category.\n results.push({ type: 'header', category, indices: categoryIndices });\n }\n\n // Create the item result for the score.\n results.push({ type: 'item', item, indices: labelIndices });\n }\n\n // Return the final results.\n return results;\n }\n\n /**\n * A concrete implementation of `CommandPalette.IItem`.\n */\n class CommandItem implements CommandPalette.IItem {\n /**\n * Construct a new command item.\n */\n constructor(\n commands: CommandRegistry,\n options: CommandPalette.IItemOptions\n ) {\n this._commands = commands;\n this.category = normalizeCategory(options.category);\n this.command = options.command;\n this.args = options.args || JSONExt.emptyObject;\n this.rank = options.rank !== undefined ? options.rank : Infinity;\n }\n\n /**\n * The category for the command item.\n */\n readonly category: string;\n\n /**\n * The command to execute when the item is triggered.\n */\n readonly command: string;\n\n /**\n * The arguments for the command.\n */\n readonly args: ReadonlyJSONObject;\n\n /**\n * The rank for the command item.\n */\n readonly rank: number;\n\n /**\n * The display label for the command item.\n */\n get label(): string {\n return this._commands.label(this.command, this.args);\n }\n\n /**\n * The icon renderer for the command item.\n */\n get icon(): VirtualElement.IRenderer | undefined {\n return this._commands.icon(this.command, this.args);\n }\n\n /**\n * The icon class for the command item.\n */\n get iconClass(): string {\n return this._commands.iconClass(this.command, this.args);\n }\n\n /**\n * The icon label for the command item.\n */\n get iconLabel(): string {\n return this._commands.iconLabel(this.command, this.args);\n }\n\n /**\n * The display caption for the command item.\n */\n get caption(): string {\n return this._commands.caption(this.command, this.args);\n }\n\n /**\n * The extra class name for the command item.\n */\n get className(): string {\n return this._commands.className(this.command, this.args);\n }\n\n /**\n * The dataset for the command item.\n */\n get dataset(): CommandRegistry.Dataset {\n return this._commands.dataset(this.command, this.args);\n }\n\n /**\n * Whether the command item is enabled.\n */\n get isEnabled(): boolean {\n return this._commands.isEnabled(this.command, this.args);\n }\n\n /**\n * Whether the command item is toggled.\n */\n get isToggled(): boolean {\n return this._commands.isToggled(this.command, this.args);\n }\n\n /**\n * Whether the command item is toggleable.\n */\n get isToggleable(): boolean {\n return this._commands.isToggleable(this.command, this.args);\n }\n\n /**\n * Whether the command item is visible.\n */\n get isVisible(): boolean {\n return this._commands.isVisible(this.command, this.args);\n }\n\n /**\n * The key binding for the command item.\n */\n get keyBinding(): CommandRegistry.IKeyBinding | null {\n let { command, args } = this;\n return (\n ArrayExt.findLastValue(this._commands.keyBindings, kb => {\n return kb.command === command && JSONExt.deepEqual(kb.args, args);\n }) || null\n );\n }\n\n private _commands: CommandRegistry;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { CommandRegistry } from '@lumino/commands';\n\nimport { JSONExt, ReadonlyJSONObject } from '@lumino/coreutils';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { getKeyboardLayout } from '@lumino/keyboard';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport {\n ARIAAttrNames,\n ElementARIAAttrs,\n ElementDataset,\n h,\n VirtualDOM,\n VirtualElement\n} from '@lumino/virtualdom';\n\nimport { Widget } from './widget';\n\ninterface IWindowData {\n pageXOffset: number;\n pageYOffset: number;\n clientWidth: number;\n clientHeight: number;\n}\n\n/**\n * A widget which displays items as a canonical menu.\n */\nexport class Menu extends Widget {\n /**\n * Construct a new menu.\n *\n * @param options - The options for initializing the menu.\n */\n constructor(options: Menu.IOptions) {\n super({ node: Private.createNode() });\n this.addClass('lm-Menu');\n this.setFlag(Widget.Flag.DisallowLayout);\n this.commands = options.commands;\n this.renderer = options.renderer || Menu.defaultRenderer;\n }\n\n /**\n * Dispose of the resources held by the menu.\n */\n dispose(): void {\n this.close();\n this._items.length = 0;\n super.dispose();\n }\n\n /**\n * A signal emitted just before the menu is closed.\n *\n * #### Notes\n * This signal is emitted when the menu receives a `'close-request'`\n * message, just before it removes itself from the DOM.\n *\n * This signal is not emitted if the menu is already detached from\n * the DOM when it receives the `'close-request'` message.\n */\n get aboutToClose(): ISignal {\n return this._aboutToClose;\n }\n\n /**\n * A signal emitted when a new menu is requested by the user.\n *\n * #### Notes\n * This signal is emitted whenever the user presses the right or left\n * arrow keys, and a submenu cannot be opened or closed in response.\n *\n * This signal is useful when implementing menu bars in order to open\n * the next or previous menu in response to a user key press.\n *\n * This signal is only emitted for the root menu in a hierarchy.\n */\n get menuRequested(): ISignal {\n return this._menuRequested;\n }\n\n /**\n * The command registry used by the menu.\n */\n readonly commands: CommandRegistry;\n\n /**\n * The renderer used by the menu.\n */\n readonly renderer: Menu.IRenderer;\n\n /**\n * The parent menu of the menu.\n *\n * #### Notes\n * This is `null` unless the menu is an open submenu.\n */\n get parentMenu(): Menu | null {\n return this._parentMenu;\n }\n\n /**\n * The child menu of the menu.\n *\n * #### Notes\n * This is `null` unless the menu has an open submenu.\n */\n get childMenu(): Menu | null {\n return this._childMenu;\n }\n\n /**\n * The root menu of the menu hierarchy.\n */\n get rootMenu(): Menu {\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n let menu: Menu = this;\n while (menu._parentMenu) {\n menu = menu._parentMenu;\n }\n return menu;\n }\n\n /**\n * The leaf menu of the menu hierarchy.\n */\n get leafMenu(): Menu {\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n let menu: Menu = this;\n while (menu._childMenu) {\n menu = menu._childMenu;\n }\n return menu;\n }\n\n /**\n * The menu content node.\n *\n * #### Notes\n * This is the node which holds the menu item nodes.\n *\n * Modifying this node directly can lead to undefined behavior.\n */\n get contentNode(): HTMLUListElement {\n return this.node.getElementsByClassName(\n 'lm-Menu-content'\n )[0] as HTMLUListElement;\n }\n\n /**\n * Get the currently active menu item.\n */\n get activeItem(): Menu.IItem | null {\n return this._items[this._activeIndex] || null;\n }\n\n /**\n * Set the currently active menu item.\n *\n * #### Notes\n * If the item cannot be activated, the item will be set to `null`.\n */\n set activeItem(value: Menu.IItem | null) {\n this.activeIndex = value ? this._items.indexOf(value) : -1;\n }\n\n /**\n * Get the index of the currently active menu item.\n *\n * #### Notes\n * This will be `-1` if no menu item is active.\n */\n get activeIndex(): number {\n return this._activeIndex;\n }\n\n /**\n * Set the index of the currently active menu item.\n *\n * #### Notes\n * If the item cannot be activated, the index will be set to `-1`.\n */\n set activeIndex(value: number) {\n // Adjust the value for an out of range index.\n if (value < 0 || value >= this._items.length) {\n value = -1;\n }\n\n // Ensure the item can be activated.\n if (value !== -1 && !Private.canActivate(this._items[value])) {\n value = -1;\n }\n\n // Bail if the index will not change.\n if (this._activeIndex === value) {\n return;\n }\n\n // Update the active index.\n this._activeIndex = value;\n\n // Make active element in focus\n if (\n this._activeIndex >= 0 &&\n this.contentNode.childNodes[this._activeIndex]\n ) {\n (this.contentNode.childNodes[this._activeIndex] as HTMLElement).focus();\n }\n\n // schedule an update of the items.\n this.update();\n }\n\n /**\n * A read-only array of the menu items in the menu.\n */\n get items(): ReadonlyArray {\n return this._items;\n }\n\n /**\n * Activate the next selectable item in the menu.\n *\n * #### Notes\n * If no item is selectable, the index will be set to `-1`.\n */\n activateNextItem(): void {\n let n = this._items.length;\n let ai = this._activeIndex;\n let start = ai < n - 1 ? ai + 1 : 0;\n let stop = start === 0 ? n - 1 : start - 1;\n this.activeIndex = ArrayExt.findFirstIndex(\n this._items,\n Private.canActivate,\n start,\n stop\n );\n }\n\n /**\n * Activate the previous selectable item in the menu.\n *\n * #### Notes\n * If no item is selectable, the index will be set to `-1`.\n */\n activatePreviousItem(): void {\n let n = this._items.length;\n let ai = this._activeIndex;\n let start = ai <= 0 ? n - 1 : ai - 1;\n let stop = start === n - 1 ? 0 : start + 1;\n this.activeIndex = ArrayExt.findLastIndex(\n this._items,\n Private.canActivate,\n start,\n stop\n );\n }\n\n /**\n * Trigger the active menu item.\n *\n * #### Notes\n * If the active item is a submenu, it will be opened and the first\n * item will be activated.\n *\n * If the active item is a command, the command will be executed.\n *\n * If the menu is not attached, this is a no-op.\n *\n * If there is no active item, this is a no-op.\n */\n triggerActiveItem(): void {\n // Bail if the menu is not attached.\n if (!this.isAttached) {\n return;\n }\n\n // Bail if there is no active item.\n let item = this.activeItem;\n if (!item) {\n return;\n }\n\n // Cancel the pending timers.\n this._cancelOpenTimer();\n this._cancelCloseTimer();\n\n // If the item is a submenu, open it.\n if (item.type === 'submenu') {\n this._openChildMenu(true);\n return;\n }\n\n // Close the root menu before executing the command.\n this.rootMenu.close();\n\n // Execute the command for the item.\n let { command, args } = item;\n if (this.commands.isEnabled(command, args)) {\n this.commands.execute(command, args);\n } else {\n console.log(`Command '${command}' is disabled.`);\n }\n }\n\n /**\n * Add a menu item to the end of the menu.\n *\n * @param options - The options for creating the menu item.\n *\n * @returns The menu item added to the menu.\n */\n addItem(options: Menu.IItemOptions): Menu.IItem {\n return this.insertItem(this._items.length, options);\n }\n\n /**\n * Insert a menu item into the menu at the specified index.\n *\n * @param index - The index at which to insert the item.\n *\n * @param options - The options for creating the menu item.\n *\n * @returns The menu item added to the menu.\n *\n * #### Notes\n * The index will be clamped to the bounds of the items.\n */\n insertItem(index: number, options: Menu.IItemOptions): Menu.IItem {\n // Close the menu if it's attached.\n if (this.isAttached) {\n this.close();\n }\n\n // Reset the active index.\n this.activeIndex = -1;\n\n // Clamp the insert index to the array bounds.\n let i = Math.max(0, Math.min(index, this._items.length));\n\n // Create the item for the options.\n let item = Private.createItem(this, options);\n\n // Insert the item into the array.\n ArrayExt.insert(this._items, i, item);\n\n // Schedule an update of the items.\n this.update();\n\n // Return the item added to the menu.\n return item;\n }\n\n /**\n * Remove an item from the menu.\n *\n * @param item - The item to remove from the menu.\n *\n * #### Notes\n * This is a no-op if the item is not in the menu.\n */\n removeItem(item: Menu.IItem): void {\n this.removeItemAt(this._items.indexOf(item));\n }\n\n /**\n * Remove the item at a given index from the menu.\n *\n * @param index - The index of the item to remove.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n removeItemAt(index: number): void {\n // Close the menu if it's attached.\n if (this.isAttached) {\n this.close();\n }\n\n // Reset the active index.\n this.activeIndex = -1;\n\n // Remove the item from the array.\n let item = ArrayExt.removeAt(this._items, index);\n\n // Bail if the index is out of range.\n if (!item) {\n return;\n }\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * Remove all menu items from the menu.\n */\n clearItems(): void {\n // Close the menu if it's attached.\n if (this.isAttached) {\n this.close();\n }\n\n // Reset the active index.\n this.activeIndex = -1;\n\n // Bail if there is nothing to remove.\n if (this._items.length === 0) {\n return;\n }\n\n // Clear the items.\n this._items.length = 0;\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * Open the menu at the specified location.\n *\n * @param x - The client X coordinate of the menu location.\n *\n * @param y - The client Y coordinate of the menu location.\n *\n * @param options - The additional options for opening the menu.\n *\n * #### Notes\n * The menu will be opened at the given location unless it will not\n * fully fit on the screen. If it will not fit, it will be adjusted\n * to fit naturally on the screen.\n *\n * The menu will be attached under the `host` element in the DOM\n * (or `document.body` if `host` is `null`) and before the `ref`\n * element (or as the last child of `host` if `ref` is `null`).\n * The menu may be displayed outside of the `host` element\n * following the rules of CSS absolute positioning.\n *\n * This is a no-op if the menu is already attached to the DOM.\n */\n open(x: number, y: number, options: Menu.IOpenOptions = {}): void {\n // Bail early if the menu is already attached.\n if (this.isAttached) {\n return;\n }\n\n // Extract the menu options.\n let forceX = options.forceX || false;\n let forceY = options.forceY || false;\n const host = options.host ?? null;\n const ref = options.ref ?? null;\n\n // Open the menu as a root menu.\n Private.openRootMenu(this, x, y, forceX, forceY, host, ref);\n\n // Activate the menu to accept keyboard input.\n this.activate();\n }\n\n /**\n * Handle the DOM events for the menu.\n *\n * @param event - The DOM event sent to the menu.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the menu's DOM nodes. It should\n * not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'mouseup':\n this._evtMouseUp(event as MouseEvent);\n break;\n case 'mousemove':\n this._evtMouseMove(event as MouseEvent);\n break;\n case 'mouseenter':\n this._evtMouseEnter(event as MouseEvent);\n break;\n case 'mouseleave':\n this._evtMouseLeave(event as MouseEvent);\n break;\n case 'mousedown':\n this._evtMouseDown(event as MouseEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('keydown', this);\n this.node.addEventListener('mouseup', this);\n this.node.addEventListener('mousemove', this);\n this.node.addEventListener('mouseenter', this);\n this.node.addEventListener('mouseleave', this);\n this.node.addEventListener('contextmenu', this);\n document.addEventListener('mousedown', this, true);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('keydown', this);\n this.node.removeEventListener('mouseup', this);\n this.node.removeEventListener('mousemove', this);\n this.node.removeEventListener('mouseenter', this);\n this.node.removeEventListener('mouseleave', this);\n this.node.removeEventListener('contextmenu', this);\n document.removeEventListener('mousedown', this, true);\n }\n\n /**\n * A message handler invoked on an `'activate-request'` message.\n */\n protected onActivateRequest(msg: Message): void {\n if (this.isAttached) {\n this.node.focus();\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n let items = this._items;\n let renderer = this.renderer;\n let activeIndex = this._activeIndex;\n let collapsedFlags = Private.computeCollapsed(items);\n let content = new Array(items.length);\n for (let i = 0, n = items.length; i < n; ++i) {\n let item = items[i];\n let active = i === activeIndex;\n let collapsed = collapsedFlags[i];\n content[i] = renderer.renderItem({\n item,\n active,\n collapsed,\n onfocus: () => {\n this.activeIndex = i;\n }\n });\n }\n VirtualDOM.render(content, this.contentNode);\n }\n\n /**\n * A message handler invoked on a `'close-request'` message.\n */\n protected onCloseRequest(msg: Message): void {\n // Cancel the pending timers.\n this._cancelOpenTimer();\n this._cancelCloseTimer();\n\n // Reset the active index.\n this.activeIndex = -1;\n\n // Close any open child menu.\n let childMenu = this._childMenu;\n if (childMenu) {\n this._childIndex = -1;\n this._childMenu = null;\n childMenu._parentMenu = null;\n childMenu.close();\n }\n\n // Remove this menu from its parent and activate the parent.\n let parentMenu = this._parentMenu;\n if (parentMenu) {\n this._parentMenu = null;\n parentMenu._childIndex = -1;\n parentMenu._childMenu = null;\n parentMenu.activate();\n }\n\n // Emit the `aboutToClose` signal if the menu is attached.\n if (this.isAttached) {\n this._aboutToClose.emit(undefined);\n }\n\n // Finish closing the menu.\n super.onCloseRequest(msg);\n }\n\n /**\n * Handle the `'keydown'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the menu node.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // A menu handles all keydown events.\n event.preventDefault();\n event.stopPropagation();\n\n // Fetch the key code for the event.\n let kc = event.keyCode;\n\n // Enter\n if (kc === 13) {\n this.triggerActiveItem();\n return;\n }\n\n // Escape\n if (kc === 27) {\n this.close();\n return;\n }\n\n // Left Arrow\n if (kc === 37) {\n if (this._parentMenu) {\n this.close();\n } else {\n this._menuRequested.emit('previous');\n }\n return;\n }\n\n // Up Arrow\n if (kc === 38) {\n this.activatePreviousItem();\n return;\n }\n\n // Right Arrow\n if (kc === 39) {\n let item = this.activeItem;\n if (item && item.type === 'submenu') {\n this.triggerActiveItem();\n } else {\n this.rootMenu._menuRequested.emit('next');\n }\n return;\n }\n\n // Down Arrow\n if (kc === 40) {\n this.activateNextItem();\n return;\n }\n\n // Get the pressed key character.\n let key = getKeyboardLayout().keyForKeydownEvent(event);\n\n // Bail if the key is not valid.\n if (!key) {\n return;\n }\n\n // Search for the next best matching mnemonic item.\n let start = this._activeIndex + 1;\n let result = Private.findMnemonic(this._items, key, start);\n\n // Handle the requested mnemonic based on the search results.\n // If exactly one mnemonic is matched, that item is triggered.\n // Otherwise, the next mnemonic is activated if available,\n // followed by the auto mnemonic if available.\n if (result.index !== -1 && !result.multiple) {\n this.activeIndex = result.index;\n this.triggerActiveItem();\n } else if (result.index !== -1) {\n this.activeIndex = result.index;\n } else if (result.auto !== -1) {\n this.activeIndex = result.auto;\n }\n }\n\n /**\n * Handle the `'mouseup'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the menu node.\n */\n private _evtMouseUp(event: MouseEvent): void {\n if (event.button !== 0) {\n return;\n }\n event.preventDefault();\n event.stopPropagation();\n this.triggerActiveItem();\n }\n\n /**\n * Handle the `'mousemove'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the menu node.\n */\n private _evtMouseMove(event: MouseEvent): void {\n // Hit test the item nodes for the item under the mouse.\n let index = ArrayExt.findFirstIndex(this.contentNode.children, node => {\n return ElementExt.hitTest(node, event.clientX, event.clientY);\n });\n\n // Bail early if the mouse is already over the active index.\n if (index === this._activeIndex) {\n return;\n }\n\n // Update and coerce the active index.\n this.activeIndex = index;\n index = this.activeIndex;\n\n // If the index is the current child index, cancel the timers.\n if (index === this._childIndex) {\n this._cancelOpenTimer();\n this._cancelCloseTimer();\n return;\n }\n\n // If a child menu is currently open, start the close timer.\n if (this._childIndex !== -1) {\n this._startCloseTimer();\n }\n\n // Cancel the open timer to give a full delay for opening.\n this._cancelOpenTimer();\n\n // Bail if the active item is not a valid submenu item.\n let item = this.activeItem;\n if (!item || item.type !== 'submenu' || !item.submenu) {\n return;\n }\n\n // Start the open timer to open the active item submenu.\n this._startOpenTimer();\n }\n\n /**\n * Handle the `'mouseenter'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the menu node.\n */\n private _evtMouseEnter(event: MouseEvent): void {\n // Synchronize the active ancestor items.\n for (let menu = this._parentMenu; menu; menu = menu._parentMenu) {\n menu._cancelOpenTimer();\n menu._cancelCloseTimer();\n menu.activeIndex = menu._childIndex;\n }\n }\n\n /**\n * Handle the `'mouseleave'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the menu node.\n */\n private _evtMouseLeave(event: MouseEvent): void {\n // Cancel any pending submenu opening.\n this._cancelOpenTimer();\n\n // If there is no open child menu, just reset the active index.\n if (!this._childMenu) {\n this.activeIndex = -1;\n return;\n }\n\n // If the mouse is over the child menu, cancel the close timer.\n let { clientX, clientY } = event;\n if (ElementExt.hitTest(this._childMenu.node, clientX, clientY)) {\n this._cancelCloseTimer();\n return;\n }\n\n // Otherwise, reset the active index and start the close timer.\n this.activeIndex = -1;\n this._startCloseTimer();\n }\n\n /**\n * Handle the `'mousedown'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the document node.\n */\n private _evtMouseDown(event: MouseEvent): void {\n // Bail if the menu is not a root menu.\n if (this._parentMenu) {\n return;\n }\n\n // The mouse button which is pressed is irrelevant. If the press\n // is not on a menu, the entire hierarchy is closed and the event\n // is allowed to propagate. This allows other code to act on the\n // event, such as focusing the clicked element.\n if (Private.hitTestMenus(this, event.clientX, event.clientY)) {\n event.preventDefault();\n event.stopPropagation();\n } else {\n this.close();\n }\n }\n\n /**\n * Open the child menu at the active index immediately.\n *\n * If a different child menu is already open, it will be closed,\n * even if the active item is not a valid submenu.\n */\n private _openChildMenu(activateFirst = false): void {\n // If the item is not a valid submenu, close the child menu.\n let item = this.activeItem;\n if (!item || item.type !== 'submenu' || !item.submenu) {\n this._closeChildMenu();\n return;\n }\n\n // Do nothing if the child menu will not change.\n let submenu = item.submenu;\n if (submenu === this._childMenu) {\n return;\n }\n\n // Prior to any DOM modifications save window data\n Menu.saveWindowData();\n\n // Ensure the current child menu is closed.\n this._closeChildMenu();\n\n // Update the private child state.\n this._childMenu = submenu;\n this._childIndex = this._activeIndex;\n\n // Set the parent menu reference for the child.\n submenu._parentMenu = this;\n\n // Ensure the menu is updated and lookup the item node.\n MessageLoop.sendMessage(this, Widget.Msg.UpdateRequest);\n let itemNode = this.contentNode.children[this._activeIndex];\n\n // Open the submenu at the active node.\n Private.openSubmenu(submenu, itemNode as HTMLElement);\n\n // Activate the first item if desired.\n if (activateFirst) {\n submenu.activeIndex = -1;\n submenu.activateNextItem();\n }\n\n // Activate the child menu.\n submenu.activate();\n }\n\n /**\n * Close the child menu immediately.\n *\n * This is a no-op if a child menu is not open.\n */\n private _closeChildMenu(): void {\n if (this._childMenu) {\n this._childMenu.close();\n }\n }\n\n /**\n * Start the open timer, unless it is already pending.\n */\n private _startOpenTimer(): void {\n if (this._openTimerID === 0) {\n this._openTimerID = window.setTimeout(() => {\n this._openTimerID = 0;\n this._openChildMenu();\n }, Private.TIMER_DELAY);\n }\n }\n\n /**\n * Start the close timer, unless it is already pending.\n */\n private _startCloseTimer(): void {\n if (this._closeTimerID === 0) {\n this._closeTimerID = window.setTimeout(() => {\n this._closeTimerID = 0;\n this._closeChildMenu();\n }, Private.TIMER_DELAY);\n }\n }\n\n /**\n * Cancel the open timer, if the timer is pending.\n */\n private _cancelOpenTimer(): void {\n if (this._openTimerID !== 0) {\n clearTimeout(this._openTimerID);\n this._openTimerID = 0;\n }\n }\n\n /**\n * Cancel the close timer, if the timer is pending.\n */\n private _cancelCloseTimer(): void {\n if (this._closeTimerID !== 0) {\n clearTimeout(this._closeTimerID);\n this._closeTimerID = 0;\n }\n }\n\n /**\n * Save window data used for menu positioning in transient cache.\n *\n * In order to avoid layout trashing it is recommended to invoke this\n * method immediately prior to opening the menu and any DOM modifications\n * (like closing previously visible menu, or adding a class to menu widget).\n *\n * The transient cache will be released upon `open()` call.\n */\n static saveWindowData(): void {\n Private.saveWindowData();\n }\n\n private _childIndex = -1;\n private _activeIndex = -1;\n private _openTimerID = 0;\n private _closeTimerID = 0;\n private _items: Menu.IItem[] = [];\n private _childMenu: Menu | null = null;\n private _parentMenu: Menu | null = null;\n private _aboutToClose = new Signal(this);\n private _menuRequested = new Signal(this);\n}\n\n/**\n * The namespace for the `Menu` class statics.\n */\nexport namespace Menu {\n /**\n * An options object for creating a menu.\n */\n export interface IOptions {\n /**\n * The command registry for use with the menu.\n */\n commands: CommandRegistry;\n\n /**\n * A custom renderer for use with the menu.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n }\n\n /**\n * An options object for the `open` method on a menu.\n */\n export interface IOpenOptions {\n /**\n * Whether to force the X position of the menu.\n *\n * Setting to `true` will disable the logic which repositions the\n * X coordinate of the menu if it will not fit entirely on screen.\n *\n * The default is `false`.\n */\n forceX?: boolean;\n\n /**\n * Whether to force the Y position of the menu.\n *\n * Setting to `true` will disable the logic which repositions the\n * Y coordinate of the menu if it will not fit entirely on screen.\n *\n * The default is `false`.\n */\n forceY?: boolean;\n\n /**\n * The DOM node to use as the menu's host.\n *\n * If not specified then uses `document.body`.\n */\n host?: HTMLElement;\n\n /**\n * The child of `host` to use as the reference element.\n * If this is provided, the menu will be inserted before this\n * node in the host. The default is `null`, which will cause the\n * menu to be added as the last child of the host.\n */\n ref?: HTMLElement;\n }\n\n /**\n * A type alias for a menu item type.\n */\n export type ItemType = 'command' | 'submenu' | 'separator';\n\n /**\n * An options object for creating a menu item.\n */\n export interface IItemOptions {\n /**\n * The type of the menu item.\n *\n * The default value is `'command'`.\n */\n type?: ItemType;\n\n /**\n * The command to execute when the item is triggered.\n *\n * The default value is an empty string.\n */\n command?: string;\n\n /**\n * The arguments for the command.\n *\n * The default value is an empty object.\n */\n args?: ReadonlyJSONObject;\n\n /**\n * The submenu for a `'submenu'` type item.\n *\n * The default value is `null`.\n */\n submenu?: Menu | null;\n }\n\n /**\n * An object which represents a menu item.\n *\n * #### Notes\n * Item objects are created automatically by a menu.\n */\n export interface IItem {\n /**\n * The type of the menu item.\n */\n readonly type: ItemType;\n\n /**\n * The command to execute when the item is triggered.\n */\n readonly command: string;\n\n /**\n * The arguments for the command.\n */\n readonly args: ReadonlyJSONObject;\n\n /**\n * The submenu for a `'submenu'` type item.\n */\n readonly submenu: Menu | null;\n\n /**\n * The display label for the menu item.\n */\n readonly label: string;\n\n /**\n * The mnemonic index for the menu item.\n */\n readonly mnemonic: number;\n\n /**\n * The icon renderer for the menu item.\n */\n readonly icon: VirtualElement.IRenderer | undefined;\n\n /**\n * The icon class for the menu item.\n */\n readonly iconClass: string;\n\n /**\n * The icon label for the menu item.\n */\n readonly iconLabel: string;\n\n /**\n * The display caption for the menu item.\n */\n readonly caption: string;\n\n /**\n * The extra class name for the menu item.\n */\n readonly className: string;\n\n /**\n * The dataset for the menu item.\n */\n readonly dataset: CommandRegistry.Dataset;\n\n /**\n * Whether the menu item is enabled.\n */\n readonly isEnabled: boolean;\n\n /**\n * Whether the menu item is toggled.\n */\n readonly isToggled: boolean;\n\n /**\n * Whether the menu item is visible.\n */\n readonly isVisible: boolean;\n\n /**\n * The key binding for the menu item.\n */\n readonly keyBinding: CommandRegistry.IKeyBinding | null;\n }\n\n /**\n * An object which holds the data to render a menu item.\n */\n export interface IRenderData {\n /**\n * The item to be rendered.\n */\n readonly item: IItem;\n\n /**\n * Whether the item is the active item.\n */\n readonly active: boolean;\n\n /**\n * Whether the item should be collapsed.\n */\n readonly collapsed: boolean;\n\n /**\n * Handler for when element is in focus.\n */\n readonly onfocus?: () => void;\n }\n\n /**\n * A renderer for use with a menu.\n */\n export interface IRenderer {\n /**\n * Render the virtual element for a menu item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n */\n renderItem(data: IRenderData): VirtualElement;\n }\n\n /**\n * The default implementation of `IRenderer`.\n *\n * #### Notes\n * Subclasses are free to reimplement rendering methods as needed.\n */\n export class Renderer implements IRenderer {\n /**\n * Render the virtual element for a menu item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n */\n renderItem(data: IRenderData): VirtualElement {\n let className = this.createItemClass(data);\n let dataset = this.createItemDataset(data);\n let aria = this.createItemARIA(data);\n return h.li(\n {\n className,\n dataset,\n tabindex: '0',\n onfocus: data.onfocus,\n ...aria\n },\n this.renderIcon(data),\n this.renderLabel(data),\n this.renderShortcut(data),\n this.renderSubmenu(data)\n );\n }\n\n /**\n * Render the icon element for a menu item.\n *\n * @param data - The data to use for rendering the icon.\n *\n * @returns A virtual element representing the item icon.\n */\n renderIcon(data: IRenderData): VirtualElement {\n let className = this.createIconClass(data);\n\n // If data.item.icon is undefined, it will be ignored.\n return h.div({ className }, data.item.icon!, data.item.iconLabel);\n }\n\n /**\n * Render the label element for a menu item.\n *\n * @param data - The data to use for rendering the label.\n *\n * @returns A virtual element representing the item label.\n */\n renderLabel(data: IRenderData): VirtualElement {\n let content = this.formatLabel(data);\n return h.div({ className: 'lm-Menu-itemLabel' }, content);\n }\n\n /**\n * Render the shortcut element for a menu item.\n *\n * @param data - The data to use for rendering the shortcut.\n *\n * @returns A virtual element representing the item shortcut.\n */\n renderShortcut(data: IRenderData): VirtualElement {\n let content = this.formatShortcut(data);\n return h.div({ className: 'lm-Menu-itemShortcut' }, content);\n }\n\n /**\n * Render the submenu icon element for a menu item.\n *\n * @param data - The data to use for rendering the submenu icon.\n *\n * @returns A virtual element representing the submenu icon.\n */\n renderSubmenu(data: IRenderData): VirtualElement {\n return h.div({ className: 'lm-Menu-itemSubmenuIcon' });\n }\n\n /**\n * Create the class name for the menu item.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the menu item.\n */\n createItemClass(data: IRenderData): string {\n // Setup the initial class name.\n let name = 'lm-Menu-item';\n\n // Add the boolean state classes.\n if (!data.item.isEnabled) {\n name += ' lm-mod-disabled';\n }\n if (data.item.isToggled) {\n name += ' lm-mod-toggled';\n }\n if (!data.item.isVisible) {\n name += ' lm-mod-hidden';\n }\n if (data.active) {\n name += ' lm-mod-active';\n }\n if (data.collapsed) {\n name += ' lm-mod-collapsed';\n }\n\n // Add the extra class.\n let extra = data.item.className;\n if (extra) {\n name += ` ${extra}`;\n }\n\n // Return the complete class name.\n return name;\n }\n\n /**\n * Create the dataset for the menu item.\n *\n * @param data - The data to use for creating the dataset.\n *\n * @returns The dataset for the menu item.\n */\n createItemDataset(data: IRenderData): ElementDataset {\n let result: ElementDataset;\n let { type, command, dataset } = data.item;\n if (type === 'command') {\n result = { ...dataset, type, command };\n } else {\n result = { ...dataset, type };\n }\n return result;\n }\n\n /**\n * Create the class name for the menu item icon.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the item icon.\n */\n createIconClass(data: IRenderData): string {\n let name = 'lm-Menu-itemIcon';\n let extra = data.item.iconClass;\n return extra ? `${name} ${extra}` : name;\n }\n\n /**\n * Create the aria attributes for menu item.\n *\n * @param data - The data to use for the aria attributes.\n *\n * @returns The aria attributes object for the item.\n */\n createItemARIA(data: IRenderData): ElementARIAAttrs {\n let aria: { [T in ARIAAttrNames]?: string } = {};\n switch (data.item.type) {\n case 'separator':\n aria.role = 'presentation';\n break;\n case 'submenu':\n aria['aria-haspopup'] = 'true';\n if (!data.item.isEnabled) {\n aria['aria-disabled'] = 'true';\n }\n break;\n default:\n if (!data.item.isEnabled) {\n aria['aria-disabled'] = 'true';\n }\n aria.role = 'menuitem';\n }\n return aria;\n }\n\n /**\n * Create the render content for the label node.\n *\n * @param data - The data to use for the label content.\n *\n * @returns The content to add to the label node.\n */\n formatLabel(data: IRenderData): h.Child {\n // Fetch the label text and mnemonic index.\n let { label, mnemonic } = data.item;\n\n // If the index is out of range, do not modify the label.\n if (mnemonic < 0 || mnemonic >= label.length) {\n return label;\n }\n\n // Split the label into parts.\n let prefix = label.slice(0, mnemonic);\n let suffix = label.slice(mnemonic + 1);\n let char = label[mnemonic];\n\n // Wrap the mnemonic character in a span.\n let span = h.span({ className: 'lm-Menu-itemMnemonic' }, char);\n\n // Return the content parts.\n return [prefix, span, suffix];\n }\n\n /**\n * Create the render content for the shortcut node.\n *\n * @param data - The data to use for the shortcut content.\n *\n * @returns The content to add to the shortcut node.\n */\n formatShortcut(data: IRenderData): h.Child {\n let kb = data.item.keyBinding;\n return kb ? CommandRegistry.formatKeystroke(kb.keys) : null;\n }\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The ms delay for opening and closing a submenu.\n */\n export const TIMER_DELAY = 300;\n\n /**\n * The horizontal pixel overlap for an open submenu.\n */\n export const SUBMENU_OVERLAP = 3;\n\n let transientWindowDataCache: IWindowData | null = null;\n let transientCacheCounter: number = 0;\n\n function getWindowData(): IWindowData {\n // if transient cache is in use, take one from it\n if (transientCacheCounter > 0) {\n transientCacheCounter--;\n return transientWindowDataCache!;\n }\n return _getWindowData();\n }\n\n /**\n * Store window data in transient cache.\n *\n * The transient cache will be released upon `getWindowData()` call.\n * If this function is called multiple times, the cache will be\n * retained until as many calls to `getWindowData()` were made.\n *\n * Note: should be called before any DOM modifications.\n */\n export function saveWindowData(): void {\n transientWindowDataCache = _getWindowData();\n transientCacheCounter++;\n }\n\n /**\n * Create the DOM node for a menu.\n */\n export function createNode(): HTMLDivElement {\n let node = document.createElement('div');\n let content = document.createElement('ul');\n content.className = 'lm-Menu-content';\n node.appendChild(content);\n content.setAttribute('role', 'menu');\n node.tabIndex = 0;\n return node;\n }\n\n /**\n * Test whether a menu item can be activated.\n */\n export function canActivate(item: Menu.IItem): boolean {\n return item.type !== 'separator' && item.isEnabled && item.isVisible;\n }\n\n /**\n * Create a new menu item for an owner menu.\n */\n export function createItem(\n owner: Menu,\n options: Menu.IItemOptions\n ): Menu.IItem {\n return new MenuItem(owner.commands, options);\n }\n\n /**\n * Hit test a menu hierarchy starting at the given root.\n */\n export function hitTestMenus(menu: Menu, x: number, y: number): boolean {\n for (let temp: Menu | null = menu; temp; temp = temp.childMenu) {\n if (ElementExt.hitTest(temp.node, x, y)) {\n return true;\n }\n }\n return false;\n }\n\n /**\n * Compute which extra separator items should be collapsed.\n */\n export function computeCollapsed(\n items: ReadonlyArray\n ): boolean[] {\n // Allocate the return array and fill it with `false`.\n let result = new Array(items.length);\n ArrayExt.fill(result, false);\n\n // Collapse the leading separators.\n let k1 = 0;\n let n = items.length;\n for (; k1 < n; ++k1) {\n let item = items[k1];\n if (!item.isVisible) {\n continue;\n }\n if (item.type !== 'separator') {\n break;\n }\n result[k1] = true;\n }\n\n // Hide the trailing separators.\n let k2 = n - 1;\n for (; k2 >= 0; --k2) {\n let item = items[k2];\n if (!item.isVisible) {\n continue;\n }\n if (item.type !== 'separator') {\n break;\n }\n result[k2] = true;\n }\n\n // Hide the remaining consecutive separators.\n let hide = false;\n while (++k1 < k2) {\n let item = items[k1];\n if (!item.isVisible) {\n continue;\n }\n if (item.type !== 'separator') {\n hide = false;\n } else if (hide) {\n result[k1] = true;\n } else {\n hide = true;\n }\n }\n\n // Return the resulting flags.\n return result;\n }\n\n function _getWindowData(): IWindowData {\n return {\n pageXOffset: window.pageXOffset,\n pageYOffset: window.pageYOffset,\n clientWidth: document.documentElement.clientWidth,\n clientHeight: document.documentElement.clientHeight\n };\n }\n\n /**\n * Open a menu as a root menu at the target location.\n */\n export function openRootMenu(\n menu: Menu,\n x: number,\n y: number,\n forceX: boolean,\n forceY: boolean,\n host: HTMLElement | null,\n ref: HTMLElement | null\n ): void {\n // Get the current position and size of the main viewport.\n const windowData = getWindowData();\n let px = windowData.pageXOffset;\n let py = windowData.pageYOffset;\n let cw = windowData.clientWidth;\n let ch = windowData.clientHeight;\n\n // Ensure the menu is updated before attaching and measuring.\n MessageLoop.sendMessage(menu, Widget.Msg.UpdateRequest);\n\n // Compute the maximum allowed height for the menu.\n let maxHeight = ch - (forceY ? y : 0);\n\n // Fetch common variables.\n let node = menu.node;\n let style = node.style;\n\n // Clear the menu geometry and prepare it for measuring.\n style.opacity = '0';\n style.maxHeight = `${maxHeight}px`;\n\n // Attach the menu to the document.\n Widget.attach(menu, host || document.body, ref);\n\n // Measure the size of the menu.\n let { width, height } = node.getBoundingClientRect();\n\n // Adjust the X position of the menu to fit on-screen.\n if (!forceX && x + width > px + cw) {\n x = px + cw - width;\n }\n\n // Adjust the Y position of the menu to fit on-screen.\n if (!forceY && y + height > py + ch) {\n if (y > py + ch) {\n y = py + ch - height;\n } else {\n y = y - height;\n }\n }\n\n // Update the position of the menu to the computed position.\n style.transform = `translate(${Math.max(0, x)}px, ${Math.max(0, y)}px`;\n\n // Finally, make the menu visible on the screen.\n style.opacity = '1';\n }\n\n /**\n * Open a menu as a submenu using an item node for positioning.\n */\n export function openSubmenu(submenu: Menu, itemNode: HTMLElement): void {\n // Get the current position and size of the main viewport.\n const windowData = getWindowData();\n let px = windowData.pageXOffset;\n let py = windowData.pageYOffset;\n let cw = windowData.clientWidth;\n let ch = windowData.clientHeight;\n\n // Ensure the menu is updated before opening.\n MessageLoop.sendMessage(submenu, Widget.Msg.UpdateRequest);\n\n // Compute the maximum allowed height for the menu.\n let maxHeight = ch;\n\n // Fetch common variables.\n let node = submenu.node;\n let style = node.style;\n\n // Clear the menu geometry and prepare it for measuring.\n style.opacity = '0';\n style.maxHeight = `${maxHeight}px`;\n\n // Attach the menu to the document.\n Widget.attach(submenu, document.body);\n\n // Measure the size of the menu.\n let { width, height } = node.getBoundingClientRect();\n\n // Compute the box sizing for the menu.\n let box = ElementExt.boxSizing(submenu.node);\n\n // Get the bounding rect for the target item node.\n let itemRect = itemNode.getBoundingClientRect();\n\n // Compute the target X position.\n let x = itemRect.right - SUBMENU_OVERLAP;\n\n // Adjust the X position to fit on the screen.\n if (x + width > px + cw) {\n x = itemRect.left + SUBMENU_OVERLAP - width;\n }\n\n // Compute the target Y position.\n let y = itemRect.top - box.borderTop - box.paddingTop;\n\n // Adjust the Y position to fit on the screen.\n if (y + height > py + ch) {\n y = itemRect.bottom + box.borderBottom + box.paddingBottom - height;\n }\n\n // Update the position of the menu to the computed position.\n style.transform = `translate(${Math.max(0, x)}px, ${Math.max(0, y)}px`;\n\n // Finally, make the menu visible on the screen.\n style.opacity = '1';\n }\n\n /**\n * The results of a mnemonic search.\n */\n export interface IMnemonicResult {\n /**\n * The index of the first matching mnemonic item, or `-1`.\n */\n index: number;\n\n /**\n * Whether multiple mnemonic items matched.\n */\n multiple: boolean;\n\n /**\n * The index of the first auto matched non-mnemonic item.\n */\n auto: number;\n }\n\n /**\n * Find the best matching mnemonic item.\n *\n * The search starts at the given index and wraps around.\n */\n export function findMnemonic(\n items: ReadonlyArray,\n key: string,\n start: number\n ): IMnemonicResult {\n // Setup the result variables.\n let index = -1;\n let auto = -1;\n let multiple = false;\n\n // Normalize the key to upper case.\n let upperKey = key.toUpperCase();\n\n // Search the items from the given start index.\n for (let i = 0, n = items.length; i < n; ++i) {\n // Compute the wrapped index.\n let k = (i + start) % n;\n\n // Lookup the item\n let item = items[k];\n\n // Ignore items which cannot be activated.\n if (!canActivate(item)) {\n continue;\n }\n\n // Ignore items with an empty label.\n let label = item.label;\n if (label.length === 0) {\n continue;\n }\n\n // Lookup the mnemonic index for the label.\n let mn = item.mnemonic;\n\n // Handle a valid mnemonic index.\n if (mn >= 0 && mn < label.length) {\n if (label[mn].toUpperCase() === upperKey) {\n if (index === -1) {\n index = k;\n } else {\n multiple = true;\n }\n }\n continue;\n }\n\n // Finally, handle the auto index if possible.\n if (auto === -1 && label[0].toUpperCase() === upperKey) {\n auto = k;\n }\n }\n\n // Return the search results.\n return { index, multiple, auto };\n }\n\n /**\n * A concrete implementation of `Menu.IItem`.\n */\n class MenuItem implements Menu.IItem {\n /**\n * Construct a new menu item.\n */\n constructor(commands: CommandRegistry, options: Menu.IItemOptions) {\n this._commands = commands;\n this.type = options.type || 'command';\n this.command = options.command || '';\n this.args = options.args || JSONExt.emptyObject;\n this.submenu = options.submenu || null;\n }\n\n /**\n * The type of the menu item.\n */\n readonly type: Menu.ItemType;\n\n /**\n * The command to execute when the item is triggered.\n */\n readonly command: string;\n\n /**\n * The arguments for the command.\n */\n readonly args: ReadonlyJSONObject;\n\n /**\n * The submenu for a `'submenu'` type item.\n */\n readonly submenu: Menu | null;\n\n /**\n * The display label for the menu item.\n */\n get label(): string {\n if (this.type === 'command') {\n return this._commands.label(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.label;\n }\n return '';\n }\n\n /**\n * The mnemonic index for the menu item.\n */\n get mnemonic(): number {\n if (this.type === 'command') {\n return this._commands.mnemonic(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.mnemonic;\n }\n return -1;\n }\n\n /**\n * The icon renderer for the menu item.\n */\n get icon(): VirtualElement.IRenderer | undefined {\n if (this.type === 'command') {\n return this._commands.icon(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.icon;\n }\n return undefined;\n }\n\n /**\n * The icon class for the menu item.\n */\n get iconClass(): string {\n if (this.type === 'command') {\n return this._commands.iconClass(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.iconClass;\n }\n return '';\n }\n\n /**\n * The icon label for the menu item.\n */\n get iconLabel(): string {\n if (this.type === 'command') {\n return this._commands.iconLabel(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.iconLabel;\n }\n return '';\n }\n\n /**\n * The display caption for the menu item.\n */\n get caption(): string {\n if (this.type === 'command') {\n return this._commands.caption(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.caption;\n }\n return '';\n }\n\n /**\n * The extra class name for the menu item.\n */\n get className(): string {\n if (this.type === 'command') {\n return this._commands.className(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.className;\n }\n return '';\n }\n\n /**\n * The dataset for the menu item.\n */\n get dataset(): CommandRegistry.Dataset {\n if (this.type === 'command') {\n return this._commands.dataset(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.dataset;\n }\n return {};\n }\n\n /**\n * Whether the menu item is enabled.\n */\n get isEnabled(): boolean {\n if (this.type === 'command') {\n return this._commands.isEnabled(this.command, this.args);\n }\n if (this.type === 'submenu') {\n return this.submenu !== null;\n }\n return true;\n }\n\n /**\n * Whether the menu item is toggled.\n */\n get isToggled(): boolean {\n if (this.type === 'command') {\n return this._commands.isToggled(this.command, this.args);\n }\n return false;\n }\n\n /**\n * Whether the menu item is visible.\n */\n get isVisible(): boolean {\n if (this.type === 'command') {\n return this._commands.isVisible(this.command, this.args);\n }\n if (this.type === 'submenu') {\n return this.submenu !== null;\n }\n return true;\n }\n\n /**\n * The key binding for the menu item.\n */\n get keyBinding(): CommandRegistry.IKeyBinding | null {\n if (this.type === 'command') {\n let { command, args } = this;\n return (\n ArrayExt.findLastValue(this._commands.keyBindings, kb => {\n return kb.command === command && JSONExt.deepEqual(kb.args, args);\n }) || null\n );\n }\n return null;\n }\n\n private _commands: CommandRegistry;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { CommandRegistry } from '@lumino/commands';\n\nimport { DisposableDelegate, IDisposable } from '@lumino/disposable';\n\nimport { Selector } from '@lumino/domutils';\n\nimport { Menu } from './menu';\n\n/**\n * An object which implements a universal context menu.\n *\n * #### Notes\n * The items shown in the context menu are determined by CSS selector\n * matching against the DOM hierarchy at the site of the mouse click.\n * This is similar in concept to how keyboard shortcuts are matched\n * in the command registry.\n */\nexport class ContextMenu {\n /**\n * Construct a new context menu.\n *\n * @param options - The options for initializing the menu.\n */\n constructor(options: ContextMenu.IOptions) {\n const { groupByTarget, sortBySelector, ...others } = options;\n this.menu = new Menu(others);\n this._groupByTarget = groupByTarget !== false;\n this._sortBySelector = sortBySelector !== false;\n }\n\n /**\n * The menu widget which displays the matched context items.\n */\n readonly menu: Menu;\n\n /**\n * Add an item to the context menu.\n *\n * @param options - The options for creating the item.\n *\n * @returns A disposable which will remove the item from the menu.\n */\n addItem(options: ContextMenu.IItemOptions): IDisposable {\n // Create an item from the given options.\n let item = Private.createItem(options, this._idTick++);\n\n // Add the item to the internal array.\n this._items.push(item);\n\n // Return a disposable which will remove the item.\n return new DisposableDelegate(() => {\n ArrayExt.removeFirstOf(this._items, item);\n });\n }\n\n /**\n * Open the context menu in response to a `'contextmenu'` event.\n *\n * @param event - The `'contextmenu'` event of interest.\n *\n * @returns `true` if the menu was opened, or `false` if no items\n * matched the event and the menu was not opened.\n *\n * #### Notes\n * This method will populate the context menu with items which match\n * the propagation path of the event, then open the menu at the mouse\n * position indicated by the event.\n */\n open(event: MouseEvent): boolean {\n // Prior to any DOM modifications update the window data.\n Menu.saveWindowData();\n\n // Clear the current contents of the context menu.\n this.menu.clearItems();\n\n // Bail early if there are no items to match.\n if (this._items.length === 0) {\n return false;\n }\n\n // Find the matching items for the event.\n let items = Private.matchItems(\n this._items,\n event,\n this._groupByTarget,\n this._sortBySelector\n );\n\n // Bail if there are no matching items.\n if (!items || items.length === 0) {\n return false;\n }\n\n // Add the filtered items to the menu.\n for (const item of items) {\n this.menu.addItem(item);\n }\n\n // Open the context menu at the current mouse position.\n this.menu.open(event.clientX, event.clientY);\n\n // Indicate success.\n return true;\n }\n\n private _groupByTarget: boolean = true;\n private _idTick = 0;\n private _items: Private.IItem[] = [];\n private _sortBySelector: boolean = true;\n}\n\n/**\n * The namespace for the `ContextMenu` class statics.\n */\nexport namespace ContextMenu {\n /**\n * An options object for initializing a context menu.\n */\n export interface IOptions {\n /**\n * The command registry to use with the context menu.\n */\n commands: CommandRegistry;\n\n /**\n * A custom renderer for use with the context menu.\n */\n renderer?: Menu.IRenderer;\n\n /**\n * Whether to sort by selector and rank or only rank.\n *\n * Default true.\n */\n sortBySelector?: boolean;\n\n /**\n * Whether to group items following the DOM hierarchy.\n *\n * Default true.\n *\n * #### Note\n * If true, when the mouse event occurs on element `span` within `div.top`,\n * the items matching `div.top` will be shown before the ones matching `body`.\n */\n groupByTarget?: boolean;\n }\n\n /**\n * An options object for creating a context menu item.\n */\n export interface IItemOptions extends Menu.IItemOptions {\n /**\n * The CSS selector for the context menu item.\n *\n * The context menu item will only be displayed in the context menu\n * when the selector matches a node on the propagation path of the\n * contextmenu event. This allows the menu item to be restricted to\n * user-defined contexts.\n *\n * The selector must not contain commas.\n */\n selector: string;\n\n /**\n * The rank for the item.\n *\n * The rank is used as a tie-breaker when ordering context menu\n * items for display. Items are sorted in the following order:\n * 1. Depth in the DOM tree (deeper is better)\n * 2. Selector specificity (higher is better)\n * 3. Rank (lower is better)\n * 4. Insertion order\n *\n * The default rank is `Infinity`.\n */\n rank?: number;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * A normalized item for a context menu.\n */\n export interface IItem extends Menu.IItemOptions {\n /**\n * The selector for the item.\n */\n selector: string;\n\n /**\n * The rank for the item.\n */\n rank: number;\n\n /**\n * The tie-breaking id for the item.\n */\n id: number;\n }\n\n /**\n * Create a normalized context menu item from an options object.\n */\n export function createItem(\n options: ContextMenu.IItemOptions,\n id: number\n ): IItem {\n let selector = validateSelector(options.selector);\n let rank = options.rank !== undefined ? options.rank : Infinity;\n return { ...options, selector, rank, id };\n }\n\n /**\n * Find the items which match a context menu event.\n *\n * The results are sorted by DOM level, specificity, and rank.\n */\n export function matchItems(\n items: IItem[],\n event: MouseEvent,\n groupByTarget: boolean,\n sortBySelector: boolean\n ): IItem[] | null {\n // Look up the target of the event.\n let target = event.target as Element | null;\n\n // Bail if there is no target.\n if (!target) {\n return null;\n }\n\n // Look up the current target of the event.\n let currentTarget = event.currentTarget as Element | null;\n\n // Bail if there is no current target.\n if (!currentTarget) {\n return null;\n }\n\n // There are some third party libraries that cause the `target` to\n // be detached from the DOM before lumino can process the event.\n // If that happens, search for a new target node by point. If that\n // node is still dangling, bail.\n if (!currentTarget.contains(target)) {\n target = document.elementFromPoint(event.clientX, event.clientY);\n if (!target || !currentTarget.contains(target)) {\n return null;\n }\n }\n\n // Set up the result array.\n let result: IItem[] = [];\n\n // Copy the items array to allow in-place modification.\n let availableItems: Array = items.slice();\n\n // Walk up the DOM hierarchy searching for matches.\n while (target !== null) {\n // Set up the match array for this DOM level.\n let matches: IItem[] = [];\n\n // Search the remaining items for matches.\n for (let i = 0, n = availableItems.length; i < n; ++i) {\n // Fetch the item.\n let item = availableItems[i];\n\n // Skip items which are already consumed.\n if (!item) {\n continue;\n }\n\n // Skip items which do not match the element.\n if (!Selector.matches(target, item.selector)) {\n continue;\n }\n\n // Add the matched item to the result for this DOM level.\n matches.push(item);\n\n // Mark the item as consumed.\n availableItems[i] = null;\n }\n\n // Sort the matches for this level and add them to the results.\n if (matches.length !== 0) {\n if (groupByTarget) {\n matches.sort(sortBySelector ? itemCmp : itemCmpRank);\n }\n result.push(...matches);\n }\n\n // Stop searching at the limits of the DOM range.\n if (target === currentTarget) {\n break;\n }\n\n // Step to the parent DOM level.\n target = target.parentElement;\n }\n\n if (!groupByTarget) {\n result.sort(sortBySelector ? itemCmp : itemCmpRank);\n }\n\n // Return the matched and sorted results.\n return result;\n }\n\n /**\n * Validate the selector for a menu item.\n *\n * This returns the validated selector, or throws if the selector is\n * invalid or contains commas.\n */\n function validateSelector(selector: string): string {\n if (selector.indexOf(',') !== -1) {\n throw new Error(`Selector cannot contain commas: ${selector}`);\n }\n if (!Selector.isValid(selector)) {\n throw new Error(`Invalid selector: ${selector}`);\n }\n return selector;\n }\n\n /**\n * A sort comparison function for a context menu item by ranks.\n */\n function itemCmpRank(a: IItem, b: IItem): number {\n // Sort based on rank.\n let r1 = a.rank;\n let r2 = b.rank;\n if (r1 !== r2) {\n return r1 < r2 ? -1 : 1; // Infinity-safe\n }\n\n // When all else fails, sort by item id.\n return a.id - b.id;\n }\n\n /**\n * A sort comparison function for a context menu item by selectors and ranks.\n */\n function itemCmp(a: IItem, b: IItem): number {\n // Sort first based on selector specificity.\n let s1 = Selector.calculateSpecificity(a.selector);\n let s2 = Selector.calculateSpecificity(b.selector);\n if (s1 !== s2) {\n return s2 - s1;\n }\n\n // If specificities are equal\n return itemCmpRank(a, b);\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Drag } from '@lumino/dragdrop';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport {\n ElementARIAAttrs,\n ElementBaseAttrs,\n ElementDataset,\n ElementInlineStyle,\n h,\n VirtualDOM,\n VirtualElement\n} from '@lumino/virtualdom';\n\nimport { Title } from './title';\n\nimport { Widget } from './widget';\n\nconst ARROW_KEYS = [\n 'ArrowLeft',\n 'ArrowUp',\n 'ArrowRight',\n 'ArrowDown',\n 'Home',\n 'End'\n];\n\n/**\n * A widget which displays titles as a single row or column of tabs.\n *\n * #### Notes\n * If CSS transforms are used to rotate nodes for vertically oriented\n * text, then tab dragging will not work correctly. The `tabsMovable`\n * property should be set to `false` when rotating nodes from CSS.\n */\nexport class TabBar extends Widget {\n /**\n * Construct a new tab bar.\n *\n * @param options - The options for initializing the tab bar.\n */\n constructor(options: TabBar.IOptions = {}) {\n super({ node: Private.createNode() });\n this.addClass('lm-TabBar');\n this.contentNode.setAttribute('role', 'tablist');\n this.setFlag(Widget.Flag.DisallowLayout);\n this._document = options.document || document;\n this.tabsMovable = options.tabsMovable || false;\n this.titlesEditable = options.titlesEditable || false;\n this.allowDeselect = options.allowDeselect || false;\n this.addButtonEnabled = options.addButtonEnabled || false;\n this.insertBehavior = options.insertBehavior || 'select-tab-if-needed';\n this.name = options.name || '';\n this.orientation = options.orientation || 'horizontal';\n this.removeBehavior = options.removeBehavior || 'select-tab-after';\n this.renderer = options.renderer || TabBar.defaultRenderer;\n }\n\n /**\n * Dispose of the resources held by the widget.\n */\n dispose(): void {\n this._releaseMouse();\n this._titles.length = 0;\n this._previousTitle = null;\n super.dispose();\n }\n\n /**\n * A signal emitted when the current tab is changed.\n *\n * #### Notes\n * This signal is emitted when the currently selected tab is changed\n * either through user or programmatic interaction.\n *\n * Notably, this signal is not emitted when the index of the current\n * tab changes due to tabs being inserted, removed, or moved. It is\n * only emitted when the actual current tab node is changed.\n */\n get currentChanged(): ISignal> {\n return this._currentChanged;\n }\n\n /**\n * A signal emitted when a tab is moved by the user.\n *\n * #### Notes\n * This signal is emitted when a tab is moved by user interaction.\n *\n * This signal is not emitted when a tab is moved programmatically.\n */\n get tabMoved(): ISignal> {\n return this._tabMoved;\n }\n\n /**\n * A signal emitted when a tab is clicked by the user.\n *\n * #### Notes\n * If the clicked tab is not the current tab, the clicked tab will be\n * made current and the `currentChanged` signal will be emitted first.\n *\n * This signal is emitted even if the clicked tab is the current tab.\n */\n get tabActivateRequested(): ISignal<\n this,\n TabBar.ITabActivateRequestedArgs\n > {\n return this._tabActivateRequested;\n }\n\n /**\n * A signal emitted when the tab bar add button is clicked.\n */\n get addRequested(): ISignal {\n return this._addRequested;\n }\n\n /**\n * A signal emitted when a tab close icon is clicked.\n *\n * #### Notes\n * This signal is not emitted unless the tab title is `closable`.\n */\n get tabCloseRequested(): ISignal> {\n return this._tabCloseRequested;\n }\n\n /**\n * A signal emitted when a tab is dragged beyond the detach threshold.\n *\n * #### Notes\n * This signal is emitted when the user drags a tab with the mouse,\n * and mouse is dragged beyond the detach threshold.\n *\n * The consumer of the signal should call `releaseMouse` and remove\n * the tab in order to complete the detach.\n *\n * This signal is only emitted once per drag cycle.\n */\n get tabDetachRequested(): ISignal> {\n return this._tabDetachRequested;\n }\n\n /**\n * The renderer used by the tab bar.\n */\n readonly renderer: TabBar.IRenderer;\n\n /**\n * The document to use with the tab bar.\n *\n * The default is the global `document` instance.\n */\n get document(): Document | ShadowRoot {\n return this._document;\n }\n\n /**\n * Whether the tabs are movable by the user.\n *\n * #### Notes\n * Tabs can always be moved programmatically.\n */\n tabsMovable: boolean;\n\n /**\n * Whether the titles can be user-edited.\n *\n */\n get titlesEditable(): boolean {\n return this._titlesEditable;\n }\n\n /**\n * Set whether titles can be user edited.\n *\n */\n set titlesEditable(value: boolean) {\n this._titlesEditable = value;\n }\n\n /**\n * Whether a tab can be deselected by the user.\n *\n * #### Notes\n * Tabs can be always be deselected programmatically.\n */\n allowDeselect: boolean;\n\n /**\n * The selection behavior when inserting a tab.\n */\n insertBehavior: TabBar.InsertBehavior;\n\n /**\n * The selection behavior when removing a tab.\n */\n removeBehavior: TabBar.RemoveBehavior;\n\n /**\n * Get the currently selected title.\n *\n * #### Notes\n * This will be `null` if no tab is selected.\n */\n get currentTitle(): Title | null {\n return this._titles[this._currentIndex] || null;\n }\n\n /**\n * Set the currently selected title.\n *\n * #### Notes\n * If the title does not exist, the title will be set to `null`.\n */\n set currentTitle(value: Title | null) {\n this.currentIndex = value ? this._titles.indexOf(value) : -1;\n }\n\n /**\n * Get the index of the currently selected tab.\n *\n * #### Notes\n * This will be `-1` if no tab is selected.\n */\n get currentIndex(): number {\n return this._currentIndex;\n }\n\n /**\n * Set the index of the currently selected tab.\n *\n * #### Notes\n * If the value is out of range, the index will be set to `-1`.\n */\n set currentIndex(value: number) {\n // Adjust for an out of range index.\n if (value < 0 || value >= this._titles.length) {\n value = -1;\n }\n\n // Bail early if the index will not change.\n if (this._currentIndex === value) {\n return;\n }\n\n // Look up the previous index and title.\n let pi = this._currentIndex;\n let pt = this._titles[pi] || null;\n\n // Look up the current index and title.\n let ci = value;\n let ct = this._titles[ci] || null;\n\n // Update the current index and previous title.\n this._currentIndex = ci;\n this._previousTitle = pt;\n\n // Schedule an update of the tabs.\n this.update();\n\n // Emit the current changed signal.\n this._currentChanged.emit({\n previousIndex: pi,\n previousTitle: pt,\n currentIndex: ci,\n currentTitle: ct\n });\n }\n\n /**\n * Get the name of the tab bar.\n */\n get name(): string {\n return this._name;\n }\n\n /**\n * Set the name of the tab bar.\n */\n set name(value: string) {\n this._name = value;\n if (value) {\n this.contentNode.setAttribute('aria-label', value);\n } else {\n this.contentNode.removeAttribute('aria-label');\n }\n }\n\n /**\n * Get the orientation of the tab bar.\n *\n * #### Notes\n * This controls whether the tabs are arranged in a row or column.\n */\n get orientation(): TabBar.Orientation {\n return this._orientation;\n }\n\n /**\n * Set the orientation of the tab bar.\n *\n * #### Notes\n * This controls whether the tabs are arranged in a row or column.\n */\n set orientation(value: TabBar.Orientation) {\n // Do nothing if the orientation does not change.\n if (this._orientation === value) {\n return;\n }\n\n // Release the mouse before making any changes.\n this._releaseMouse();\n\n // Toggle the orientation values.\n this._orientation = value;\n this.dataset['orientation'] = value;\n this.contentNode.setAttribute('aria-orientation', value);\n }\n\n /**\n * Whether the add button is enabled.\n */\n get addButtonEnabled(): boolean {\n return this._addButtonEnabled;\n }\n\n /**\n * Set whether the add button is enabled.\n */\n set addButtonEnabled(value: boolean) {\n // Do nothing if the value does not change.\n if (this._addButtonEnabled === value) {\n return;\n }\n\n this._addButtonEnabled = value;\n if (value) {\n this.addButtonNode.classList.remove('lm-mod-hidden');\n } else {\n this.addButtonNode.classList.add('lm-mod-hidden');\n }\n }\n\n /**\n * A read-only array of the titles in the tab bar.\n */\n get titles(): ReadonlyArray> {\n return this._titles;\n }\n\n /**\n * The tab bar content node.\n *\n * #### Notes\n * This is the node which holds the tab nodes.\n *\n * Modifying this node directly can lead to undefined behavior.\n */\n get contentNode(): HTMLUListElement {\n return this.node.getElementsByClassName(\n 'lm-TabBar-content'\n )[0] as HTMLUListElement;\n }\n\n /**\n * The tab bar add button node.\n *\n * #### Notes\n * This is the node which holds the add button.\n *\n * Modifying this node directly can lead to undefined behavior.\n */\n get addButtonNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-TabBar-addButton'\n )[0] as HTMLDivElement;\n }\n\n /**\n * Add a tab to the end of the tab bar.\n *\n * @param value - The title which holds the data for the tab,\n * or an options object to convert to a title.\n *\n * @returns The title object added to the tab bar.\n *\n * #### Notes\n * If the title is already added to the tab bar, it will be moved.\n */\n addTab(value: Title | Title.IOptions): Title {\n return this.insertTab(this._titles.length, value);\n }\n\n /**\n * Insert a tab into the tab bar at the specified index.\n *\n * @param index - The index at which to insert the tab.\n *\n * @param value - The title which holds the data for the tab,\n * or an options object to convert to a title.\n *\n * @returns The title object added to the tab bar.\n *\n * #### Notes\n * The index will be clamped to the bounds of the tabs.\n *\n * If the title is already added to the tab bar, it will be moved.\n */\n insertTab(index: number, value: Title | Title.IOptions): Title {\n // Release the mouse before making any changes.\n this._releaseMouse();\n\n // Coerce the value to a title.\n let title = Private.asTitle(value);\n\n // Look up the index of the title.\n let i = this._titles.indexOf(title);\n\n // Clamp the insert index to the array bounds.\n let j = Math.max(0, Math.min(index, this._titles.length));\n\n // If the title is not in the array, insert it.\n if (i === -1) {\n // Insert the title into the array.\n ArrayExt.insert(this._titles, j, title);\n\n // Connect to the title changed signal.\n title.changed.connect(this._onTitleChanged, this);\n\n // Schedule an update of the tabs.\n this.update();\n\n // Adjust the current index for the insert.\n this._adjustCurrentForInsert(j, title);\n\n // Return the title added to the tab bar.\n return title;\n }\n\n // Otherwise, the title exists in the array and should be moved.\n\n // Adjust the index if the location is at the end of the array.\n if (j === this._titles.length) {\n j--;\n }\n\n // Bail if there is no effective move.\n if (i === j) {\n return title;\n }\n\n // Move the title to the new location.\n ArrayExt.move(this._titles, i, j);\n\n // Schedule an update of the tabs.\n this.update();\n\n // Adjust the current index for the move.\n this._adjustCurrentForMove(i, j);\n\n // Return the title added to the tab bar.\n return title;\n }\n\n /**\n * Remove a tab from the tab bar.\n *\n * @param title - The title for the tab to remove.\n *\n * #### Notes\n * This is a no-op if the title is not in the tab bar.\n */\n removeTab(title: Title): void {\n this.removeTabAt(this._titles.indexOf(title));\n }\n\n /**\n * Remove the tab at a given index from the tab bar.\n *\n * @param index - The index of the tab to remove.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n removeTabAt(index: number): void {\n // Release the mouse before making any changes.\n this._releaseMouse();\n\n // Remove the title from the array.\n let title = ArrayExt.removeAt(this._titles, index);\n\n // Bail if the index is out of range.\n if (!title) {\n return;\n }\n\n // Disconnect from the title changed signal.\n title.changed.disconnect(this._onTitleChanged, this);\n\n // Clear the previous title if it's being removed.\n if (title === this._previousTitle) {\n this._previousTitle = null;\n }\n\n // Schedule an update of the tabs.\n this.update();\n\n // Adjust the current index for the remove.\n this._adjustCurrentForRemove(index, title);\n }\n\n /**\n * Remove all tabs from the tab bar.\n */\n clearTabs(): void {\n // Bail if there is nothing to remove.\n if (this._titles.length === 0) {\n return;\n }\n\n // Release the mouse before making any changes.\n this._releaseMouse();\n\n // Disconnect from the title changed signals.\n for (let title of this._titles) {\n title.changed.disconnect(this._onTitleChanged, this);\n }\n\n // Get the current index and title.\n let pi = this.currentIndex;\n let pt = this.currentTitle;\n\n // Reset the current index and previous title.\n this._currentIndex = -1;\n this._previousTitle = null;\n\n // Clear the title array.\n this._titles.length = 0;\n\n // Schedule an update of the tabs.\n this.update();\n\n // If no tab was selected, there's nothing else to do.\n if (pi === -1) {\n return;\n }\n\n // Emit the current changed signal.\n this._currentChanged.emit({\n previousIndex: pi,\n previousTitle: pt,\n currentIndex: -1,\n currentTitle: null\n });\n }\n\n /**\n * Release the mouse and restore the non-dragged tab positions.\n *\n * #### Notes\n * This will cause the tab bar to stop handling mouse events and to\n * restore the tabs to their non-dragged positions.\n */\n releaseMouse(): void {\n this._releaseMouse();\n }\n\n /**\n * Handle the DOM events for the tab bar.\n *\n * @param event - The DOM event sent to the tab bar.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the tab bar's DOM node.\n *\n * This should not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'pointerdown':\n this._evtPointerDown(event as PointerEvent);\n break;\n case 'pointermove':\n this._evtPointerMove(event as PointerEvent);\n break;\n case 'pointerup':\n this._evtPointerUp(event as PointerEvent);\n break;\n case 'dblclick':\n this._evtDblClick(event as MouseEvent);\n break;\n case 'keydown':\n event.eventPhase === Event.CAPTURING_PHASE\n ? this._evtKeyDownCapturing(event as KeyboardEvent)\n : this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('pointerdown', this);\n this.node.addEventListener('dblclick', this);\n this.node.addEventListener('keydown', this);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('pointerdown', this);\n this.node.removeEventListener('dblclick', this);\n this.node.removeEventListener('keydown', this);\n this._releaseMouse();\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n let titles = this._titles;\n let renderer = this.renderer;\n let currentTitle = this.currentTitle;\n let content = new Array(titles.length);\n // Keep the tabindex=\"0\" attribute to the tab which handled it before the update.\n // If the add button handles it, no need to do anything. If no element of the tab\n // bar handles it, set it on the current or the first tab to ensure one element\n // handles it after update.\n const tabHandlingTabindex =\n this._getCurrentTabindex() ??\n (this._currentIndex > -1 ? this._currentIndex : 0);\n\n for (let i = 0, n = titles.length; i < n; ++i) {\n let title = titles[i];\n let current = title === currentTitle;\n let zIndex = current ? n : n - i - 1;\n let tabIndex = tabHandlingTabindex === i ? 0 : -1;\n content[i] = renderer.renderTab({ title, current, zIndex, tabIndex });\n }\n VirtualDOM.render(content, this.contentNode);\n }\n\n /**\n * Get the index of the tab which handles tabindex=\"0\".\n * If the add button handles tabindex=\"0\", -1 is returned.\n * If none of the previous handles tabindex=\"0\", null is returned.\n */\n private _getCurrentTabindex(): number | null {\n let index = null;\n const elemTabindex = this.contentNode.querySelector('li[tabindex=\"0\"]');\n if (elemTabindex) {\n index = [...this.contentNode.children].indexOf(elemTabindex);\n } else if (\n this._addButtonEnabled &&\n this.addButtonNode.getAttribute('tabindex') === '0'\n ) {\n index = -1;\n }\n return index;\n }\n\n /**\n * Handle the `'dblclick'` event for the tab bar.\n */\n private _evtDblClick(event: MouseEvent): void {\n // Do nothing if titles are not editable\n if (!this.titlesEditable) {\n return;\n }\n\n let tabs = this.contentNode.children;\n\n // Find the index of the targeted tab.\n let index = ArrayExt.findFirstIndex(tabs, tab => {\n return ElementExt.hitTest(tab, event.clientX, event.clientY);\n });\n\n // Do nothing if the press is not on a tab.\n if (index === -1) {\n return;\n }\n\n let title = this.titles[index];\n let label = tabs[index].querySelector('.lm-TabBar-tabLabel') as HTMLElement;\n if (label && label.contains(event.target as HTMLElement)) {\n let value = title.label || '';\n\n // Clear the label element\n let oldValue = label.innerHTML;\n label.innerHTML = '';\n\n let input = document.createElement('input');\n input.classList.add('lm-TabBar-tabInput');\n input.value = value;\n label.appendChild(input);\n\n let onblur = () => {\n input.removeEventListener('blur', onblur);\n label.innerHTML = oldValue;\n this.node.addEventListener('keydown', this);\n };\n\n input.addEventListener('dblclick', (event: Event) =>\n event.stopPropagation()\n );\n input.addEventListener('blur', onblur);\n input.addEventListener('keydown', (event: KeyboardEvent) => {\n if (event.key === 'Enter') {\n if (input.value !== '') {\n title.label = title.caption = input.value;\n }\n onblur();\n } else if (event.key === 'Escape') {\n onblur();\n }\n });\n this.node.removeEventListener('keydown', this);\n input.select();\n input.focus();\n\n if (label.children.length > 0) {\n (label.children[0] as HTMLElement).focus();\n }\n }\n }\n\n /**\n * Handle the `'keydown'` event for the tab bar at capturing phase.\n */\n private _evtKeyDownCapturing(event: KeyboardEvent): void {\n if (event.eventPhase !== Event.CAPTURING_PHASE) {\n return;\n }\n\n // Stop all input events during drag.\n event.preventDefault();\n event.stopPropagation();\n\n // Release the mouse if `Escape` is pressed.\n if (event.key === 'Escape') {\n this._releaseMouse();\n }\n }\n\n /**\n * Handle the `'keydown'` event for the tab bar at target phase.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // Allow for navigation using tab key\n if (event.key === 'Tab' || event.eventPhase === Event.CAPTURING_PHASE) {\n return;\n }\n\n // Check if Enter or Spacebar key has been pressed and open that tab\n if (\n event.key === 'Enter' ||\n event.key === 'Spacebar' ||\n event.key === ' '\n ) {\n // Get focus element that is in focus by the tab key\n const focusedElement = document.activeElement;\n\n // Test first if the focus is on the add button node\n if (\n this.addButtonEnabled &&\n this.addButtonNode.contains(focusedElement)\n ) {\n event.preventDefault();\n event.stopPropagation();\n this._addRequested.emit();\n } else {\n const index = ArrayExt.findFirstIndex(this.contentNode.children, tab =>\n tab.contains(focusedElement)\n );\n if (index >= 0) {\n event.preventDefault();\n event.stopPropagation();\n this.currentIndex = index;\n }\n }\n // Handle the arrow keys to switch tabs.\n } else if (ARROW_KEYS.includes(event.key)) {\n // Create a list of all focusable elements in the tab bar.\n const focusable: Element[] = [...this.contentNode.children];\n if (this.addButtonEnabled) {\n focusable.push(this.addButtonNode);\n }\n // If the tab bar contains only one element, nothing to do.\n if (focusable.length <= 1) {\n return;\n }\n event.preventDefault();\n event.stopPropagation();\n\n // Get the current focused element.\n let focusedIndex = focusable.indexOf(document.activeElement as Element);\n if (focusedIndex === -1) {\n focusedIndex = this._currentIndex;\n }\n\n // Find the next element to focus on.\n let nextFocused: Element | null | undefined;\n if (\n (event.key === 'ArrowRight' && this._orientation === 'horizontal') ||\n (event.key === 'ArrowDown' && this._orientation === 'vertical')\n ) {\n nextFocused = focusable[focusedIndex + 1] ?? focusable[0];\n } else if (\n (event.key === 'ArrowLeft' && this._orientation === 'horizontal') ||\n (event.key === 'ArrowUp' && this._orientation === 'vertical')\n ) {\n nextFocused =\n focusable[focusedIndex - 1] ?? focusable[focusable.length - 1];\n } else if (event.key === 'Home') {\n nextFocused = focusable[0];\n } else if (event.key === 'End') {\n nextFocused = focusable[focusable.length - 1];\n }\n\n // Change the focused element and the tabindex value.\n if (nextFocused) {\n focusable[focusedIndex]?.setAttribute('tabindex', '-1');\n nextFocused?.setAttribute('tabindex', '0');\n (nextFocused as HTMLElement).focus();\n }\n }\n }\n\n /**\n * Handle the `'pointerdown'` event for the tab bar.\n */\n private _evtPointerDown(event: PointerEvent | MouseEvent): void {\n // Do nothing if it's not a left or middle mouse press.\n if (event.button !== 0 && event.button !== 1) {\n return;\n }\n\n // Do nothing if a drag is in progress.\n if (this._dragData) {\n return;\n }\n\n // Do nothing if a title editable input was clicked.\n if (\n (event.target as HTMLElement).classList.contains('lm-TabBar-tabInput')\n ) {\n return;\n }\n\n // Check if the add button was clicked.\n let addButtonClicked =\n this.addButtonEnabled &&\n this.addButtonNode.contains(event.target as HTMLElement);\n\n // Lookup the tab nodes.\n let tabs = this.contentNode.children;\n\n // Find the index of the pressed tab.\n let index = ArrayExt.findFirstIndex(tabs, tab => {\n return ElementExt.hitTest(tab, event.clientX, event.clientY);\n });\n\n // Do nothing if the press is not on a tab or the add button.\n if (index === -1 && !addButtonClicked) {\n return;\n }\n\n // Pressing on a tab stops the event propagation.\n event.preventDefault();\n event.stopPropagation();\n\n // Initialize the non-measured parts of the drag data.\n this._dragData = {\n tab: tabs[index] as HTMLElement,\n index: index,\n pressX: event.clientX,\n pressY: event.clientY,\n tabPos: -1,\n tabSize: -1,\n tabPressPos: -1,\n targetIndex: -1,\n tabLayout: null,\n contentRect: null,\n override: null,\n dragActive: false,\n dragAborted: false,\n detachRequested: false\n };\n\n // Add the document pointer up listener.\n this.document.addEventListener('pointerup', this, true);\n\n // Do nothing else if the middle button or add button is clicked.\n if (event.button === 1 || addButtonClicked) {\n return;\n }\n\n // Do nothing else if the close icon is clicked.\n let icon = tabs[index].querySelector(this.renderer.closeIconSelector);\n if (icon && icon.contains(event.target as HTMLElement)) {\n return;\n }\n\n // Add the extra listeners if the tabs are movable.\n if (this.tabsMovable) {\n this.document.addEventListener('pointermove', this, true);\n this.document.addEventListener('keydown', this, true);\n this.document.addEventListener('contextmenu', this, true);\n }\n\n // Update the current index as appropriate.\n if (this.allowDeselect && this.currentIndex === index) {\n this.currentIndex = -1;\n } else {\n this.currentIndex = index;\n }\n\n // Do nothing else if there is no current tab.\n if (this.currentIndex === -1) {\n return;\n }\n\n // Emit the tab activate request signal.\n this._tabActivateRequested.emit({\n index: this.currentIndex,\n title: this.currentTitle!\n });\n }\n\n /**\n * Handle the `'pointermove'` event for the tab bar.\n */\n private _evtPointerMove(event: PointerEvent | MouseEvent): void {\n // Do nothing if no drag is in progress.\n let data = this._dragData;\n if (!data) {\n return;\n }\n\n // Suppress the event during a drag.\n event.preventDefault();\n event.stopPropagation();\n\n // Lookup the tab nodes.\n let tabs = this.contentNode.children;\n\n // Bail early if the drag threshold has not been met.\n if (!data.dragActive && !Private.dragExceeded(data, event)) {\n return;\n }\n\n // Activate the drag if necessary.\n if (!data.dragActive) {\n // Fill in the rest of the drag data measurements.\n let tabRect = data.tab.getBoundingClientRect();\n if (this._orientation === 'horizontal') {\n data.tabPos = data.tab.offsetLeft;\n data.tabSize = tabRect.width;\n data.tabPressPos = data.pressX - tabRect.left;\n } else {\n data.tabPos = data.tab.offsetTop;\n data.tabSize = tabRect.height;\n data.tabPressPos = data.pressY - tabRect.top;\n }\n data.tabPressOffset = {\n x: data.pressX - tabRect.left,\n y: data.pressY - tabRect.top\n };\n data.tabLayout = Private.snapTabLayout(tabs, this._orientation);\n data.contentRect = this.contentNode.getBoundingClientRect();\n data.override = Drag.overrideCursor('default');\n\n // Add the dragging style classes.\n data.tab.classList.add('lm-mod-dragging');\n this.addClass('lm-mod-dragging');\n\n // Mark the drag as active.\n data.dragActive = true;\n }\n\n // Emit the detach requested signal if the threshold is exceeded.\n if (!data.detachRequested && Private.detachExceeded(data, event)) {\n // Only emit the signal once per drag cycle.\n data.detachRequested = true;\n\n // Setup the arguments for the signal.\n let index = data.index;\n let clientX = event.clientX;\n let clientY = event.clientY;\n let tab = tabs[index] as HTMLElement;\n let title = this._titles[index];\n\n // Emit the tab detach requested signal.\n this._tabDetachRequested.emit({\n index,\n title,\n tab,\n clientX,\n clientY,\n offset: data.tabPressOffset\n });\n\n // Bail if the signal handler aborted the drag.\n if (data.dragAborted) {\n return;\n }\n }\n\n // Update the positions of the tabs.\n Private.layoutTabs(tabs, data, event, this._orientation);\n }\n\n /**\n * Handle the `'pointerup'` event for the document.\n */\n private _evtPointerUp(event: PointerEvent | MouseEvent): void {\n // Do nothing if it's not a left or middle mouse release.\n if (event.button !== 0 && event.button !== 1) {\n return;\n }\n\n // Do nothing if no drag is in progress.\n const data = this._dragData;\n if (!data) {\n return;\n }\n\n // Stop the event propagation.\n event.preventDefault();\n event.stopPropagation();\n\n // Remove the extra mouse event listeners.\n this.document.removeEventListener('pointermove', this, true);\n this.document.removeEventListener('pointerup', this, true);\n this.document.removeEventListener('keydown', this, true);\n this.document.removeEventListener('contextmenu', this, true);\n\n // Handle a release when the drag is not active.\n if (!data.dragActive) {\n // Clear the drag data.\n this._dragData = null;\n\n // Handle clicking the add button.\n let addButtonClicked =\n this.addButtonEnabled &&\n this.addButtonNode.contains(event.target as HTMLElement);\n if (addButtonClicked) {\n this._addRequested.emit(undefined);\n return;\n }\n\n // Lookup the tab nodes.\n let tabs = this.contentNode.children;\n\n // Find the index of the released tab.\n let index = ArrayExt.findFirstIndex(tabs, tab => {\n return ElementExt.hitTest(tab, event.clientX, event.clientY);\n });\n\n // Do nothing if the release is not on the original pressed tab.\n if (index !== data.index) {\n return;\n }\n\n // Ignore the release if the title is not closable.\n let title = this._titles[index];\n if (!title.closable) {\n return;\n }\n\n // Emit the close requested signal if the middle button is released.\n if (event.button === 1) {\n this._tabCloseRequested.emit({ index, title });\n return;\n }\n\n // Emit the close requested signal if the close icon was released.\n let icon = tabs[index].querySelector(this.renderer.closeIconSelector);\n if (icon && icon.contains(event.target as HTMLElement)) {\n this._tabCloseRequested.emit({ index, title });\n return;\n }\n\n // Otherwise, there is nothing left to do.\n return;\n }\n\n // Do nothing if the left button is not released.\n if (event.button !== 0) {\n return;\n }\n\n // Position the tab at its final resting position.\n Private.finalizeTabPosition(data, this._orientation);\n\n // Remove the dragging class from the tab so it can be transitioned.\n data.tab.classList.remove('lm-mod-dragging');\n\n // Parse the transition duration for releasing the tab.\n let duration = Private.parseTransitionDuration(data.tab);\n\n // Complete the release on a timer to allow the tab to transition.\n setTimeout(() => {\n // Do nothing if the drag has been aborted.\n if (data.dragAborted) {\n return;\n }\n\n // Clear the drag data reference.\n this._dragData = null;\n\n // Reset the positions of the tabs.\n Private.resetTabPositions(this.contentNode.children, this._orientation);\n\n // Clear the cursor grab.\n data.override!.dispose();\n\n // Remove the remaining dragging style.\n this.removeClass('lm-mod-dragging');\n\n // If the tab was not moved, there is nothing else to do.\n let i = data.index;\n let j = data.targetIndex;\n if (j === -1 || i === j) {\n return;\n }\n\n // Move the title to the new locations.\n ArrayExt.move(this._titles, i, j);\n\n // Adjust the current index for the move.\n this._adjustCurrentForMove(i, j);\n\n // Emit the tab moved signal.\n this._tabMoved.emit({\n fromIndex: i,\n toIndex: j,\n title: this._titles[j]\n });\n\n // Update the tabs immediately to prevent flicker.\n MessageLoop.sendMessage(this, Widget.Msg.UpdateRequest);\n }, duration);\n }\n\n /**\n * Release the mouse and restore the non-dragged tab positions.\n */\n private _releaseMouse(): void {\n // Do nothing if no drag is in progress.\n let data = this._dragData;\n if (!data) {\n return;\n }\n\n // Clear the drag data reference.\n this._dragData = null;\n\n // Remove the extra document event listeners.\n this.document.removeEventListener('pointermove', this, true);\n this.document.removeEventListener('pointerup', this, true);\n this.document.removeEventListener('keydown', this, true);\n this.document.removeEventListener('contextmenu', this, true);\n\n // Indicate the drag has been aborted. This allows the mouse\n // event handlers to return early when the drag is canceled.\n data.dragAborted = true;\n\n // If the drag is not active, there's nothing more to do.\n if (!data.dragActive) {\n return;\n }\n\n // Reset the tabs to their non-dragged positions.\n Private.resetTabPositions(this.contentNode.children, this._orientation);\n\n // Clear the cursor override.\n data.override!.dispose();\n\n // Clear the dragging style classes.\n data.tab.classList.remove('lm-mod-dragging');\n this.removeClass('lm-mod-dragging');\n }\n\n /**\n * Adjust the current index for a tab insert operation.\n *\n * This method accounts for the tab bar's insertion behavior when\n * adjusting the current index and emitting the changed signal.\n */\n private _adjustCurrentForInsert(i: number, title: Title): void {\n // Lookup commonly used variables.\n let ct = this.currentTitle;\n let ci = this._currentIndex;\n let bh = this.insertBehavior;\n\n // TODO: do we need to do an update to update the aria-selected attribute?\n\n // Handle the behavior where the new tab is always selected,\n // or the behavior where the new tab is selected if needed.\n if (bh === 'select-tab' || (bh === 'select-tab-if-needed' && ci === -1)) {\n this._currentIndex = i;\n this._previousTitle = ct;\n this._currentChanged.emit({\n previousIndex: ci,\n previousTitle: ct,\n currentIndex: i,\n currentTitle: title\n });\n return;\n }\n\n // Otherwise, silently adjust the current index if needed.\n if (ci >= i) {\n this._currentIndex++;\n }\n }\n\n /**\n * Adjust the current index for a tab move operation.\n *\n * This method will not cause the actual current tab to change.\n * It silently adjusts the index to account for the given move.\n */\n private _adjustCurrentForMove(i: number, j: number): void {\n if (this._currentIndex === i) {\n this._currentIndex = j;\n } else if (this._currentIndex < i && this._currentIndex >= j) {\n this._currentIndex++;\n } else if (this._currentIndex > i && this._currentIndex <= j) {\n this._currentIndex--;\n }\n }\n\n /**\n * Adjust the current index for a tab remove operation.\n *\n * This method accounts for the tab bar's remove behavior when\n * adjusting the current index and emitting the changed signal.\n */\n private _adjustCurrentForRemove(i: number, title: Title): void {\n // Lookup commonly used variables.\n let ci = this._currentIndex;\n let bh = this.removeBehavior;\n\n // Silently adjust the index if the current tab is not removed.\n if (ci !== i) {\n if (ci > i) {\n this._currentIndex--;\n }\n return;\n }\n\n // TODO: do we need to do an update to adjust the aria-selected value?\n\n // No tab gets selected if the tab bar is empty.\n if (this._titles.length === 0) {\n this._currentIndex = -1;\n this._currentChanged.emit({\n previousIndex: i,\n previousTitle: title,\n currentIndex: -1,\n currentTitle: null\n });\n return;\n }\n\n // Handle behavior where the next sibling tab is selected.\n if (bh === 'select-tab-after') {\n this._currentIndex = Math.min(i, this._titles.length - 1);\n this._currentChanged.emit({\n previousIndex: i,\n previousTitle: title,\n currentIndex: this._currentIndex,\n currentTitle: this.currentTitle\n });\n return;\n }\n\n // Handle behavior where the previous sibling tab is selected.\n if (bh === 'select-tab-before') {\n this._currentIndex = Math.max(0, i - 1);\n this._currentChanged.emit({\n previousIndex: i,\n previousTitle: title,\n currentIndex: this._currentIndex,\n currentTitle: this.currentTitle\n });\n return;\n }\n\n // Handle behavior where the previous history tab is selected.\n if (bh === 'select-previous-tab') {\n if (this._previousTitle) {\n this._currentIndex = this._titles.indexOf(this._previousTitle);\n this._previousTitle = null;\n } else {\n this._currentIndex = Math.min(i, this._titles.length - 1);\n }\n this._currentChanged.emit({\n previousIndex: i,\n previousTitle: title,\n currentIndex: this._currentIndex,\n currentTitle: this.currentTitle\n });\n return;\n }\n\n // Otherwise, no tab gets selected.\n this._currentIndex = -1;\n this._currentChanged.emit({\n previousIndex: i,\n previousTitle: title,\n currentIndex: -1,\n currentTitle: null\n });\n }\n\n /**\n * Handle the `changed` signal of a title object.\n */\n private _onTitleChanged(sender: Title): void {\n this.update();\n }\n\n private _name: string;\n private _currentIndex = -1;\n private _titles: Title[] = [];\n private _orientation: TabBar.Orientation;\n private _document: Document | ShadowRoot;\n private _titlesEditable: boolean = false;\n private _previousTitle: Title | null = null;\n private _dragData: Private.IDragData | null = null;\n private _addButtonEnabled: boolean = false;\n private _tabMoved = new Signal>(this);\n private _currentChanged = new Signal>(\n this\n );\n private _addRequested = new Signal(this);\n private _tabCloseRequested = new Signal<\n this,\n TabBar.ITabCloseRequestedArgs\n >(this);\n private _tabDetachRequested = new Signal<\n this,\n TabBar.ITabDetachRequestedArgs\n >(this);\n private _tabActivateRequested = new Signal<\n this,\n TabBar.ITabActivateRequestedArgs\n >(this);\n}\n\n/**\n * The namespace for the `TabBar` class statics.\n */\nexport namespace TabBar {\n /**\n * A type alias for a tab bar orientation.\n */\n export type Orientation =\n | /**\n * The tabs are arranged in a single row, left-to-right.\n *\n * The tab text orientation is horizontal.\n */\n 'horizontal'\n\n /**\n * The tabs are arranged in a single column, top-to-bottom.\n *\n * The tab text orientation is horizontal.\n */\n | 'vertical';\n\n /**\n * A type alias for the selection behavior on tab insert.\n */\n export type InsertBehavior =\n | /**\n * The selected tab will not be changed.\n */\n 'none'\n\n /**\n * The inserted tab will be selected.\n */\n | 'select-tab'\n\n /**\n * The inserted tab will be selected if the current tab is null.\n */\n | 'select-tab-if-needed';\n\n /**\n * A type alias for the selection behavior on tab remove.\n */\n export type RemoveBehavior =\n | /**\n * No tab will be selected.\n */\n 'none'\n\n /**\n * The tab after the removed tab will be selected if possible.\n */\n | 'select-tab-after'\n\n /**\n * The tab before the removed tab will be selected if possible.\n */\n | 'select-tab-before'\n\n /**\n * The previously selected tab will be selected if possible.\n */\n | 'select-previous-tab';\n\n /**\n * An options object for creating a tab bar.\n */\n export interface IOptions {\n /**\n * The document to use with the tab bar.\n *\n * The default is the global `document` instance.\n */\n\n document?: Document | ShadowRoot;\n\n /**\n * Name of the tab bar.\n *\n * This is used for accessibility reasons. The default is the empty string.\n */\n name?: string;\n\n /**\n * The layout orientation of the tab bar.\n *\n * The default is `horizontal`.\n */\n orientation?: TabBar.Orientation;\n\n /**\n * Whether the tabs are movable by the user.\n *\n * The default is `false`.\n */\n tabsMovable?: boolean;\n\n /**\n * Whether a tab can be deselected by the user.\n *\n * The default is `false`.\n */\n allowDeselect?: boolean;\n\n /**\n * Whether the titles can be directly edited by the user.\n *\n * The default is `false`.\n */\n titlesEditable?: boolean;\n\n /**\n * Whether the add button is enabled.\n *\n * The default is `false`.\n */\n addButtonEnabled?: boolean;\n\n /**\n * The selection behavior when inserting a tab.\n *\n * The default is `'select-tab-if-needed'`.\n */\n insertBehavior?: TabBar.InsertBehavior;\n\n /**\n * The selection behavior when removing a tab.\n *\n * The default is `'select-tab-after'`.\n */\n removeBehavior?: TabBar.RemoveBehavior;\n\n /**\n * A renderer to use with the tab bar.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n }\n\n /**\n * The arguments object for the `currentChanged` signal.\n */\n export interface ICurrentChangedArgs {\n /**\n * The previously selected index.\n */\n readonly previousIndex: number;\n\n /**\n * The previously selected title.\n */\n readonly previousTitle: Title | null;\n\n /**\n * The currently selected index.\n */\n readonly currentIndex: number;\n\n /**\n * The currently selected title.\n */\n readonly currentTitle: Title | null;\n }\n\n /**\n * The arguments object for the `tabMoved` signal.\n */\n export interface ITabMovedArgs {\n /**\n * The previous index of the tab.\n */\n readonly fromIndex: number;\n\n /**\n * The current index of the tab.\n */\n readonly toIndex: number;\n\n /**\n * The title for the tab.\n */\n readonly title: Title;\n }\n\n /**\n * The arguments object for the `tabActivateRequested` signal.\n */\n export interface ITabActivateRequestedArgs {\n /**\n * The index of the tab to activate.\n */\n readonly index: number;\n\n /**\n * The title for the tab.\n */\n readonly title: Title;\n }\n\n /**\n * The arguments object for the `tabCloseRequested` signal.\n */\n export interface ITabCloseRequestedArgs {\n /**\n * The index of the tab to close.\n */\n readonly index: number;\n\n /**\n * The title for the tab.\n */\n readonly title: Title;\n }\n\n /**\n * The arguments object for the `tabDetachRequested` signal.\n */\n export interface ITabDetachRequestedArgs {\n /**\n * The index of the tab to detach.\n */\n readonly index: number;\n\n /**\n * The title for the tab.\n */\n readonly title: Title;\n\n /**\n * The node representing the tab.\n */\n readonly tab: HTMLElement;\n\n /**\n * The current client X position of the mouse.\n */\n readonly clientX: number;\n\n /**\n * The current client Y position of the mouse.\n */\n readonly clientY: number;\n\n /**\n * The mouse position in the tab coordinate.\n */\n readonly offset?: { x: number; y: number };\n }\n\n /**\n * An object which holds the data to render a tab.\n */\n export interface IRenderData {\n /**\n * The title associated with the tab.\n */\n readonly title: Title;\n\n /**\n * Whether the tab is the current tab.\n */\n readonly current: boolean;\n\n /**\n * The z-index for the tab.\n */\n readonly zIndex: number;\n\n /**\n * The tabindex value for the tab.\n */\n readonly tabIndex?: number;\n }\n\n /**\n * A renderer for use with a tab bar.\n */\n export interface IRenderer {\n /**\n * A selector which matches the close icon node in a tab.\n */\n readonly closeIconSelector: string;\n\n /**\n * Render the virtual element for a tab.\n *\n * @param data - The data to use for rendering the tab.\n *\n * @returns A virtual element representing the tab.\n */\n renderTab(data: IRenderData): VirtualElement;\n }\n\n /**\n * The default implementation of `IRenderer`.\n *\n * #### Notes\n * Subclasses are free to reimplement rendering methods as needed.\n */\n export class Renderer implements IRenderer {\n constructor() {\n this._uuid = ++Renderer._nInstance;\n }\n /**\n * A selector which matches the close icon node in a tab.\n */\n readonly closeIconSelector = '.lm-TabBar-tabCloseIcon';\n\n /**\n * Render the virtual element for a tab.\n *\n * @param data - The data to use for rendering the tab.\n *\n * @returns A virtual element representing the tab.\n */\n renderTab(data: IRenderData): VirtualElement {\n let title = data.title.caption;\n let key = this.createTabKey(data);\n let id = key;\n let style = this.createTabStyle(data);\n let className = this.createTabClass(data);\n let dataset = this.createTabDataset(data);\n let aria = this.createTabARIA(data);\n if (data.title.closable) {\n return h.li(\n { id, key, className, title, style, dataset, ...aria },\n this.renderIcon(data),\n this.renderLabel(data),\n this.renderCloseIcon(data)\n );\n } else {\n return h.li(\n { id, key, className, title, style, dataset, ...aria },\n this.renderIcon(data),\n this.renderLabel(data)\n );\n }\n }\n\n /**\n * Render the icon element for a tab.\n *\n * @param data - The data to use for rendering the tab.\n *\n * @returns A virtual element representing the tab icon.\n */\n renderIcon(data: IRenderData): VirtualElement {\n const { title } = data;\n let className = this.createIconClass(data);\n\n // If title.icon is undefined, it will be ignored.\n return h.div({ className }, title.icon!, title.iconLabel);\n }\n\n /**\n * Render the label element for a tab.\n *\n * @param data - The data to use for rendering the tab.\n *\n * @returns A virtual element representing the tab label.\n */\n renderLabel(data: IRenderData): VirtualElement {\n return h.div({ className: 'lm-TabBar-tabLabel' }, data.title.label);\n }\n\n /**\n * Render the close icon element for a tab.\n *\n * @param data - The data to use for rendering the tab.\n *\n * @returns A virtual element representing the tab close icon.\n */\n renderCloseIcon(data: IRenderData): VirtualElement {\n return h.div({ className: 'lm-TabBar-tabCloseIcon' });\n }\n\n /**\n * Create a unique render key for the tab.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The unique render key for the tab.\n *\n * #### Notes\n * This method caches the key against the tab title the first time\n * the key is generated. This enables efficient rendering of moved\n * tabs and avoids subtle hover style artifacts.\n */\n createTabKey(data: IRenderData): string {\n let key = this._tabKeys.get(data.title);\n if (key === undefined) {\n key = `tab-key-${this._uuid}-${this._tabID++}`;\n this._tabKeys.set(data.title, key);\n }\n return key;\n }\n\n /**\n * Create the inline style object for a tab.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The inline style data for the tab.\n */\n createTabStyle(data: IRenderData): ElementInlineStyle {\n return { zIndex: `${data.zIndex}` };\n }\n\n /**\n * Create the class name for the tab.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The full class name for the tab.\n */\n createTabClass(data: IRenderData): string {\n let name = 'lm-TabBar-tab';\n if (data.title.className) {\n name += ` ${data.title.className}`;\n }\n if (data.title.closable) {\n name += ' lm-mod-closable';\n }\n if (data.current) {\n name += ' lm-mod-current';\n }\n return name;\n }\n\n /**\n * Create the dataset for a tab.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The dataset for the tab.\n */\n createTabDataset(data: IRenderData): ElementDataset {\n return data.title.dataset;\n }\n\n /**\n * Create the ARIA attributes for a tab.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The ARIA attributes for the tab.\n */\n createTabARIA(data: IRenderData): ElementARIAAttrs | ElementBaseAttrs {\n return {\n role: 'tab',\n 'aria-selected': data.current.toString(),\n tabindex: `${data.tabIndex ?? '-1'}`\n };\n }\n\n /**\n * Create the class name for the tab icon.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The full class name for the tab icon.\n */\n createIconClass(data: IRenderData): string {\n let name = 'lm-TabBar-tabIcon';\n let extra = data.title.iconClass;\n return extra ? `${name} ${extra}` : name;\n }\n\n private static _nInstance = 0;\n private readonly _uuid: number;\n private _tabID = 0;\n private _tabKeys = new WeakMap, string>();\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n\n /**\n * A selector which matches the add button node in the tab bar.\n */\n export const addButtonSelector = '.lm-TabBar-addButton';\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The start drag distance threshold.\n */\n export const DRAG_THRESHOLD = 5;\n\n /**\n * The detach distance threshold.\n */\n export const DETACH_THRESHOLD = 20;\n\n /**\n * A struct which holds the drag data for a tab bar.\n */\n export interface IDragData {\n /**\n * The tab node being dragged.\n */\n tab: HTMLElement;\n\n /**\n * The index of the tab being dragged.\n */\n index: number;\n\n /**\n * The mouse press client X position.\n */\n pressX: number;\n\n /**\n * The mouse press client Y position.\n */\n pressY: number;\n\n /**\n * The offset left/top of the tab being dragged.\n *\n * This will be `-1` if the drag is not active.\n */\n tabPos: number;\n\n /**\n * The offset width/height of the tab being dragged.\n *\n * This will be `-1` if the drag is not active.\n */\n tabSize: number;\n\n /**\n * The original mouse X/Y position in tab coordinates.\n *\n * This will be `-1` if the drag is not active.\n */\n tabPressPos: number;\n\n /**\n * The original mouse position in tab coordinates.\n *\n * This is undefined if the drag is not active.\n */\n tabPressOffset?: { x: number; y: number };\n\n /**\n * The tab target index upon mouse release.\n *\n * This will be `-1` if the drag is not active.\n */\n targetIndex: number;\n\n /**\n * The array of tab layout objects snapped at drag start.\n *\n * This will be `null` if the drag is not active.\n */\n tabLayout: ITabLayout[] | null;\n\n /**\n * The bounding client rect of the tab bar content node.\n *\n * This will be `null` if the drag is not active.\n */\n contentRect: DOMRect | null;\n\n /**\n * The disposable to clean up the cursor override.\n *\n * This will be `null` if the drag is not active.\n */\n override: IDisposable | null;\n\n /**\n * Whether the drag is currently active.\n */\n dragActive: boolean;\n\n /**\n * Whether the drag has been aborted.\n */\n dragAborted: boolean;\n\n /**\n * Whether a detach request as been made.\n */\n detachRequested: boolean;\n }\n\n /**\n * An object which holds layout data for a tab.\n */\n export interface ITabLayout {\n /**\n * The left/top margin value for the tab.\n */\n margin: number;\n\n /**\n * The offset left/top position of the tab.\n */\n pos: number;\n\n /**\n * The offset width/height of the tab.\n */\n size: number;\n }\n\n /**\n * Create the DOM node for a tab bar.\n */\n export function createNode(): HTMLDivElement {\n let node = document.createElement('div');\n let content = document.createElement('ul');\n content.setAttribute('role', 'tablist');\n content.className = 'lm-TabBar-content';\n node.appendChild(content);\n\n let add = document.createElement('div');\n add.className = 'lm-TabBar-addButton lm-mod-hidden';\n add.setAttribute('tabindex', '-1');\n add.setAttribute('role', 'button');\n node.appendChild(add);\n return node;\n }\n\n /**\n * Coerce a title or options into a real title.\n */\n export function asTitle(value: Title | Title.IOptions): Title {\n return value instanceof Title ? value : new Title(value);\n }\n\n /**\n * Parse the transition duration for a tab node.\n */\n export function parseTransitionDuration(tab: HTMLElement): number {\n let style = window.getComputedStyle(tab);\n return 1000 * (parseFloat(style.transitionDuration!) || 0);\n }\n\n /**\n * Get a snapshot of the current tab layout values.\n */\n export function snapTabLayout(\n tabs: HTMLCollection,\n orientation: TabBar.Orientation\n ): ITabLayout[] {\n let layout = new Array(tabs.length);\n for (let i = 0, n = tabs.length; i < n; ++i) {\n let node = tabs[i] as HTMLElement;\n let style = window.getComputedStyle(node);\n if (orientation === 'horizontal') {\n layout[i] = {\n pos: node.offsetLeft,\n size: node.offsetWidth,\n margin: parseFloat(style.marginLeft!) || 0\n };\n } else {\n layout[i] = {\n pos: node.offsetTop,\n size: node.offsetHeight,\n margin: parseFloat(style.marginTop!) || 0\n };\n }\n }\n return layout;\n }\n\n /**\n * Test if the event exceeds the drag threshold.\n */\n export function dragExceeded(data: IDragData, event: MouseEvent): boolean {\n let dx = Math.abs(event.clientX - data.pressX);\n let dy = Math.abs(event.clientY - data.pressY);\n return dx >= DRAG_THRESHOLD || dy >= DRAG_THRESHOLD;\n }\n\n /**\n * Test if the event exceeds the drag detach threshold.\n */\n export function detachExceeded(data: IDragData, event: MouseEvent): boolean {\n let rect = data.contentRect!;\n return (\n event.clientX < rect.left - DETACH_THRESHOLD ||\n event.clientX >= rect.right + DETACH_THRESHOLD ||\n event.clientY < rect.top - DETACH_THRESHOLD ||\n event.clientY >= rect.bottom + DETACH_THRESHOLD\n );\n }\n\n /**\n * Update the relative tab positions and computed target index.\n */\n export function layoutTabs(\n tabs: HTMLCollection,\n data: IDragData,\n event: MouseEvent,\n orientation: TabBar.Orientation\n ): void {\n // Compute the orientation-sensitive values.\n let pressPos: number;\n let localPos: number;\n let clientPos: number;\n let clientSize: number;\n if (orientation === 'horizontal') {\n pressPos = data.pressX;\n localPos = event.clientX - data.contentRect!.left;\n clientPos = event.clientX;\n clientSize = data.contentRect!.width;\n } else {\n pressPos = data.pressY;\n localPos = event.clientY - data.contentRect!.top;\n clientPos = event.clientY;\n clientSize = data.contentRect!.height;\n }\n\n // Compute the target data.\n let targetIndex = data.index;\n let targetPos = localPos - data.tabPressPos;\n let targetEnd = targetPos + data.tabSize;\n\n // Update the relative tab positions.\n for (let i = 0, n = tabs.length; i < n; ++i) {\n let pxPos: string;\n let layout = data.tabLayout![i];\n let threshold = layout.pos + (layout.size >> 1);\n if (i < data.index && targetPos < threshold) {\n pxPos = `${data.tabSize + data.tabLayout![i + 1].margin}px`;\n targetIndex = Math.min(targetIndex, i);\n } else if (i > data.index && targetEnd > threshold) {\n pxPos = `${-data.tabSize - layout.margin}px`;\n targetIndex = Math.max(targetIndex, i);\n } else if (i === data.index) {\n let ideal = clientPos - pressPos;\n let limit = clientSize - (data.tabPos + data.tabSize);\n pxPos = `${Math.max(-data.tabPos, Math.min(ideal, limit))}px`;\n } else {\n pxPos = '';\n }\n if (orientation === 'horizontal') {\n (tabs[i] as HTMLElement).style.left = pxPos;\n } else {\n (tabs[i] as HTMLElement).style.top = pxPos;\n }\n }\n\n // Update the computed target index.\n data.targetIndex = targetIndex;\n }\n\n /**\n * Position the drag tab at its final resting relative position.\n */\n export function finalizeTabPosition(\n data: IDragData,\n orientation: TabBar.Orientation\n ): void {\n // Compute the orientation-sensitive client size.\n let clientSize: number;\n if (orientation === 'horizontal') {\n clientSize = data.contentRect!.width;\n } else {\n clientSize = data.contentRect!.height;\n }\n\n // Compute the ideal final tab position.\n let ideal: number;\n if (data.targetIndex === data.index) {\n ideal = 0;\n } else if (data.targetIndex > data.index) {\n let tgt = data.tabLayout![data.targetIndex];\n ideal = tgt.pos + tgt.size - data.tabSize - data.tabPos;\n } else {\n let tgt = data.tabLayout![data.targetIndex];\n ideal = tgt.pos - data.tabPos;\n }\n\n // Compute the tab position limit.\n let limit = clientSize - (data.tabPos + data.tabSize);\n let final = Math.max(-data.tabPos, Math.min(ideal, limit));\n\n // Set the final orientation-sensitive position.\n if (orientation === 'horizontal') {\n data.tab.style.left = `${final}px`;\n } else {\n data.tab.style.top = `${final}px`;\n }\n }\n\n /**\n * Reset the relative positions of the given tabs.\n */\n export function resetTabPositions(\n tabs: HTMLCollection,\n orientation: TabBar.Orientation\n ): void {\n for (const tab of tabs) {\n if (orientation === 'horizontal') {\n (tab as HTMLElement).style.left = '';\n } else {\n (tab as HTMLElement).style.top = '';\n }\n }\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt, empty } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { BoxEngine, BoxSizer } from './boxengine';\n\nimport { Layout, LayoutItem } from './layout';\n\nimport { TabBar } from './tabbar';\n\nimport Utils from './utils';\n\nimport { Widget } from './widget';\n\n/**\n * A layout which provides a flexible docking arrangement.\n *\n * #### Notes\n * The consumer of this layout is responsible for handling all signals\n * from the generated tab bars and managing the visibility of widgets\n * and tab bars as needed.\n */\nexport class DockLayout extends Layout {\n /**\n * Construct a new dock layout.\n *\n * @param options - The options for initializing the layout.\n */\n constructor(options: DockLayout.IOptions) {\n super();\n this.renderer = options.renderer;\n if (options.spacing !== undefined) {\n this._spacing = Utils.clampDimension(options.spacing);\n }\n this._document = options.document || document;\n this._hiddenMode =\n options.hiddenMode !== undefined\n ? options.hiddenMode\n : Widget.HiddenMode.Display;\n }\n\n /**\n * Dispose of the resources held by the layout.\n *\n * #### Notes\n * This will clear and dispose all widgets in the layout.\n */\n dispose(): void {\n // Get an iterator over the widgets in the layout.\n let widgets = this[Symbol.iterator]();\n\n // Dispose of the layout items.\n this._items.forEach(item => {\n item.dispose();\n });\n\n // Clear the layout state before disposing the widgets.\n this._box = null;\n this._root = null;\n this._items.clear();\n\n // Dispose of the widgets contained in the old layout root.\n for (const widget of widgets) {\n widget.dispose();\n }\n\n // Dispose of the base class.\n super.dispose();\n }\n\n /**\n * The renderer used by the dock layout.\n */\n readonly renderer: DockLayout.IRenderer;\n\n /**\n * The method for hiding child widgets.\n *\n * #### Notes\n * If there is only one child widget, `Display` hiding mode will be used\n * regardless of this setting.\n */\n get hiddenMode(): Widget.HiddenMode {\n return this._hiddenMode;\n }\n set hiddenMode(v: Widget.HiddenMode) {\n if (this._hiddenMode === v) {\n return;\n }\n this._hiddenMode = v;\n for (const bar of this.tabBars()) {\n if (bar.titles.length > 1) {\n for (const title of bar.titles) {\n title.owner.hiddenMode = this._hiddenMode;\n }\n }\n }\n }\n\n /**\n * Get the inter-element spacing for the dock layout.\n */\n get spacing(): number {\n return this._spacing;\n }\n\n /**\n * Set the inter-element spacing for the dock layout.\n */\n set spacing(value: number) {\n value = Utils.clampDimension(value);\n if (this._spacing === value) {\n return;\n }\n this._spacing = value;\n if (!this.parent) {\n return;\n }\n this.parent.fit();\n }\n\n /**\n * Whether the dock layout is empty.\n */\n get isEmpty(): boolean {\n return this._root === null;\n }\n\n /**\n * Create an iterator over all widgets in the layout.\n *\n * @returns A new iterator over the widgets in the layout.\n *\n * #### Notes\n * This iterator includes the generated tab bars.\n */\n [Symbol.iterator](): IterableIterator {\n return this._root ? this._root.iterAllWidgets() : empty();\n }\n\n /**\n * Create an iterator over the user widgets in the layout.\n *\n * @returns A new iterator over the user widgets in the layout.\n *\n * #### Notes\n * This iterator does not include the generated tab bars.\n */\n widgets(): IterableIterator {\n return this._root ? this._root.iterUserWidgets() : empty();\n }\n\n /**\n * Create an iterator over the selected widgets in the layout.\n *\n * @returns A new iterator over the selected user widgets.\n *\n * #### Notes\n * This iterator yields the widgets corresponding to the current tab\n * of each tab bar in the layout.\n */\n selectedWidgets(): IterableIterator {\n return this._root ? this._root.iterSelectedWidgets() : empty();\n }\n\n /**\n * Create an iterator over the tab bars in the layout.\n *\n * @returns A new iterator over the tab bars in the layout.\n *\n * #### Notes\n * This iterator does not include the user widgets.\n */\n tabBars(): IterableIterator> {\n return this._root ? this._root.iterTabBars() : empty();\n }\n\n /**\n * Create an iterator over the handles in the layout.\n *\n * @returns A new iterator over the handles in the layout.\n */\n handles(): IterableIterator {\n return this._root ? this._root.iterHandles() : empty();\n }\n\n /**\n * Move a handle to the given offset position.\n *\n * @param handle - The handle to move.\n *\n * @param offsetX - The desired offset X position of the handle.\n *\n * @param offsetY - The desired offset Y position of the handle.\n *\n * #### Notes\n * If the given handle is not contained in the layout, this is no-op.\n *\n * The handle will be moved as close as possible to the desired\n * position without violating any of the layout constraints.\n *\n * Only one of the coordinates is used depending on the orientation\n * of the handle. This method accepts both coordinates to make it\n * easy to invoke from a mouse move event without needing to know\n * the handle orientation.\n */\n moveHandle(handle: HTMLDivElement, offsetX: number, offsetY: number): void {\n // Bail early if there is no root or if the handle is hidden.\n let hidden = handle.classList.contains('lm-mod-hidden');\n if (!this._root || hidden) {\n return;\n }\n\n // Lookup the split node for the handle.\n let data = this._root.findSplitNode(handle);\n if (!data) {\n return;\n }\n\n // Compute the desired delta movement for the handle.\n let delta: number;\n if (data.node.orientation === 'horizontal') {\n delta = offsetX - handle.offsetLeft;\n } else {\n delta = offsetY - handle.offsetTop;\n }\n\n // Bail if there is no handle movement.\n if (delta === 0) {\n return;\n }\n\n // Prevent sibling resizing unless needed.\n data.node.holdSizes();\n\n // Adjust the sizers to reflect the handle movement.\n BoxEngine.adjust(data.node.sizers, data.index, delta);\n\n // Update the layout of the widgets.\n if (this.parent) {\n this.parent.update();\n }\n }\n\n /**\n * Save the current configuration of the dock layout.\n *\n * @returns A new config object for the current layout state.\n *\n * #### Notes\n * The return value can be provided to the `restoreLayout` method\n * in order to restore the layout to its current configuration.\n */\n saveLayout(): DockLayout.ILayoutConfig {\n // Bail early if there is no root.\n if (!this._root) {\n return { main: null };\n }\n\n // Hold the current sizes in the layout tree.\n this._root.holdAllSizes();\n\n // Return the layout config.\n return { main: this._root.createConfig() };\n }\n\n /**\n * Restore the layout to a previously saved configuration.\n *\n * @param config - The layout configuration to restore.\n *\n * #### Notes\n * Widgets which currently belong to the layout but which are not\n * contained in the config will be unparented.\n */\n restoreLayout(config: DockLayout.ILayoutConfig): void {\n // Create the widget set for validating the config.\n let widgetSet = new Set();\n\n // Normalize the main area config and collect the widgets.\n let mainConfig: DockLayout.AreaConfig | null;\n if (config.main) {\n mainConfig = Private.normalizeAreaConfig(config.main, widgetSet);\n } else {\n mainConfig = null;\n }\n\n // Create iterators over the old content.\n let oldWidgets = this.widgets();\n let oldTabBars = this.tabBars();\n let oldHandles = this.handles();\n\n // Clear the root before removing the old content.\n this._root = null;\n\n // Unparent the old widgets which are not in the new config.\n for (const widget of oldWidgets) {\n if (!widgetSet.has(widget)) {\n widget.parent = null;\n }\n }\n\n // Dispose of the old tab bars.\n for (const tabBar of oldTabBars) {\n tabBar.dispose();\n }\n\n // Remove the old handles.\n for (const handle of oldHandles) {\n if (handle.parentNode) {\n handle.parentNode.removeChild(handle);\n }\n }\n\n // Reparent the new widgets to the current parent.\n for (const widget of widgetSet) {\n widget.parent = this.parent;\n }\n\n // Create the root node for the new config.\n if (mainConfig) {\n this._root = Private.realizeAreaConfig(\n mainConfig,\n {\n // Ignoring optional `document` argument as we must reuse `this._document`\n createTabBar: (document?: Document | ShadowRoot) =>\n this._createTabBar(),\n createHandle: () => this._createHandle()\n },\n this._document\n );\n } else {\n this._root = null;\n }\n\n // If there is no parent, there is nothing more to do.\n if (!this.parent) {\n return;\n }\n\n // Attach the new widgets to the parent.\n widgetSet.forEach(widget => {\n this.attachWidget(widget);\n });\n\n // Post a fit request to the parent.\n this.parent.fit();\n }\n\n /**\n * Add a widget to the dock layout.\n *\n * @param widget - The widget to add to the dock layout.\n *\n * @param options - The additional options for adding the widget.\n *\n * #### Notes\n * The widget will be moved if it is already contained in the layout.\n *\n * An error will be thrown if the reference widget is invalid.\n */\n addWidget(widget: Widget, options: DockLayout.IAddOptions = {}): void {\n // Parse the options.\n let ref = options.ref || null;\n let mode = options.mode || 'tab-after';\n\n // Find the tab node which holds the reference widget.\n let refNode: Private.TabLayoutNode | null = null;\n if (this._root && ref) {\n refNode = this._root.findTabNode(ref);\n }\n\n // Throw an error if the reference widget is invalid.\n if (ref && !refNode) {\n throw new Error('Reference widget is not in the layout.');\n }\n\n // Reparent the widget to the current layout parent.\n widget.parent = this.parent;\n\n // Insert the widget according to the insert mode.\n switch (mode) {\n case 'tab-after':\n this._insertTab(widget, ref, refNode, true);\n break;\n case 'tab-before':\n this._insertTab(widget, ref, refNode, false);\n break;\n case 'split-top':\n this._insertSplit(widget, ref, refNode, 'vertical', false);\n break;\n case 'split-left':\n this._insertSplit(widget, ref, refNode, 'horizontal', false);\n break;\n case 'split-right':\n this._insertSplit(widget, ref, refNode, 'horizontal', true);\n break;\n case 'split-bottom':\n this._insertSplit(widget, ref, refNode, 'vertical', true);\n break;\n case 'merge-top':\n this._insertSplit(widget, ref, refNode, 'vertical', false, true);\n break;\n case 'merge-left':\n this._insertSplit(widget, ref, refNode, 'horizontal', false, true);\n break;\n case 'merge-right':\n this._insertSplit(widget, ref, refNode, 'horizontal', true, true);\n break;\n case 'merge-bottom':\n this._insertSplit(widget, ref, refNode, 'vertical', true, true);\n break;\n }\n\n // Do nothing else if there is no parent widget.\n if (!this.parent) {\n return;\n }\n\n // Ensure the widget is attached to the parent widget.\n this.attachWidget(widget);\n\n // Post a fit request for the parent widget.\n this.parent.fit();\n }\n\n /**\n * Remove a widget from the layout.\n *\n * @param widget - The widget to remove from the layout.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method does *not* modify the widget's `parent`.\n */\n removeWidget(widget: Widget): void {\n // Remove the widget from its current layout location.\n this._removeWidget(widget);\n\n // Do nothing else if there is no parent widget.\n if (!this.parent) {\n return;\n }\n\n // Detach the widget from the parent widget.\n this.detachWidget(widget);\n\n // Post a fit request for the parent widget.\n this.parent.fit();\n }\n\n /**\n * Find the tab area which contains the given client position.\n *\n * @param clientX - The client X position of interest.\n *\n * @param clientY - The client Y position of interest.\n *\n * @returns The geometry of the tab area at the given position, or\n * `null` if there is no tab area at the given position.\n */\n hitTestTabAreas(\n clientX: number,\n clientY: number\n ): DockLayout.ITabAreaGeometry | null {\n // Bail early if hit testing cannot produce valid results.\n if (!this._root || !this.parent || !this.parent.isVisible) {\n return null;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent.node);\n }\n\n // Convert from client to local coordinates.\n let rect = this.parent.node.getBoundingClientRect();\n let x = clientX - rect.left - this._box.borderLeft;\n let y = clientY - rect.top - this._box.borderTop;\n\n // Find the tab layout node at the local position.\n let tabNode = this._root.hitTestTabNodes(x, y);\n\n // Bail if a tab layout node was not found.\n if (!tabNode) {\n return null;\n }\n\n // Extract the data from the tab node.\n let { tabBar, top, left, width, height } = tabNode;\n\n // Compute the right and bottom edges of the tab area.\n let borderWidth = this._box.borderLeft + this._box.borderRight;\n let borderHeight = this._box.borderTop + this._box.borderBottom;\n let right = rect.width - borderWidth - (left + width);\n let bottom = rect.height - borderHeight - (top + height);\n\n // Return the hit test results.\n return { tabBar, x, y, top, left, right, bottom, width, height };\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n // Perform superclass initialization.\n super.init();\n\n // Attach each widget to the parent.\n for (const widget of this) {\n this.attachWidget(widget);\n }\n\n // Attach each handle to the parent.\n for (const handle of this.handles()) {\n this.parent!.node.appendChild(handle);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * Attach the widget to the layout parent widget.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This is a no-op if the widget is already attached.\n */\n protected attachWidget(widget: Widget): void {\n // Do nothing if the widget is already attached.\n if (this.parent!.node === widget.node.parentNode) {\n return;\n }\n\n // Create the layout item for the widget.\n this._items.set(widget, new LayoutItem(widget));\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget's node to the parent.\n this.parent!.node.appendChild(widget.node);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n }\n\n /**\n * Detach the widget from the layout parent widget.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This is a no-op if the widget is not attached.\n */\n protected detachWidget(widget: Widget): void {\n // Do nothing if the widget is not attached.\n if (this.parent!.node !== widget.node.parentNode) {\n return;\n }\n\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Delete the layout item for the widget.\n let item = this._items.get(widget);\n if (item) {\n this._items.delete(widget);\n item.dispose();\n }\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n */\n protected onBeforeShow(msg: Message): void {\n super.onBeforeShow(msg);\n this.parent!.update();\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n super.onBeforeAttach(msg);\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n if (this.parent!.isVisible) {\n this._update(msg.width, msg.height);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.parent!.isVisible) {\n this._update(-1, -1);\n }\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n */\n protected onFitRequest(msg: Message): void {\n if (this.parent!.isAttached) {\n this._fit();\n }\n }\n\n /**\n * Remove the specified widget from the layout structure.\n *\n * #### Notes\n * This is a no-op if the widget is not in the layout tree.\n *\n * This does not detach the widget from the parent node.\n */\n private _removeWidget(widget: Widget): void {\n // Bail early if there is no layout root.\n if (!this._root) {\n return;\n }\n\n // Find the tab node which contains the given widget.\n let tabNode = this._root.findTabNode(widget);\n\n // Bail early if the tab node is not found.\n if (!tabNode) {\n return;\n }\n\n Private.removeAria(widget);\n\n // If there are multiple tabs, just remove the widget's tab.\n if (tabNode.tabBar.titles.length > 1) {\n tabNode.tabBar.removeTab(widget.title);\n if (\n this._hiddenMode === Widget.HiddenMode.Scale &&\n tabNode.tabBar.titles.length == 1\n ) {\n const existingWidget = tabNode.tabBar.titles[0].owner;\n existingWidget.hiddenMode = Widget.HiddenMode.Display;\n }\n return;\n }\n\n // Otherwise, the tab node needs to be removed...\n\n // Dispose the tab bar.\n tabNode.tabBar.dispose();\n\n // Handle the case where the tab node is the root.\n if (this._root === tabNode) {\n this._root = null;\n return;\n }\n\n // Otherwise, remove the tab node from its parent...\n\n // Prevent widget resizing unless needed.\n this._root.holdAllSizes();\n\n // Clear the parent reference on the tab node.\n let splitNode = tabNode.parent!;\n tabNode.parent = null;\n\n // Remove the tab node from its parent split node.\n let i = ArrayExt.removeFirstOf(splitNode.children, tabNode);\n let handle = ArrayExt.removeAt(splitNode.handles, i)!;\n ArrayExt.removeAt(splitNode.sizers, i);\n\n // Remove the handle from its parent DOM node.\n if (handle.parentNode) {\n handle.parentNode.removeChild(handle);\n }\n\n // If there are multiple children, just update the handles.\n if (splitNode.children.length > 1) {\n splitNode.syncHandles();\n return;\n }\n\n // Otherwise, the split node also needs to be removed...\n\n // Clear the parent reference on the split node.\n let maybeParent = splitNode.parent;\n splitNode.parent = null;\n\n // Lookup the remaining child node and handle.\n let childNode = splitNode.children[0];\n let childHandle = splitNode.handles[0];\n\n // Clear the split node data.\n splitNode.children.length = 0;\n splitNode.handles.length = 0;\n splitNode.sizers.length = 0;\n\n // Remove the child handle from its parent node.\n if (childHandle.parentNode) {\n childHandle.parentNode.removeChild(childHandle);\n }\n\n // Handle the case where the split node is the root.\n if (this._root === splitNode) {\n childNode.parent = null;\n this._root = childNode;\n return;\n }\n\n // Otherwise, move the child node to the parent node...\n let parentNode = maybeParent!;\n\n // Lookup the index of the split node.\n let j = parentNode.children.indexOf(splitNode);\n\n // Handle the case where the child node is a tab node.\n if (childNode instanceof Private.TabLayoutNode) {\n childNode.parent = parentNode;\n parentNode.children[j] = childNode;\n return;\n }\n\n // Remove the split data from the parent.\n let splitHandle = ArrayExt.removeAt(parentNode.handles, j)!;\n ArrayExt.removeAt(parentNode.children, j);\n ArrayExt.removeAt(parentNode.sizers, j);\n\n // Remove the handle from its parent node.\n if (splitHandle.parentNode) {\n splitHandle.parentNode.removeChild(splitHandle);\n }\n\n // The child node and the split parent node will have the same\n // orientation. Merge the grand-children with the parent node.\n for (let i = 0, n = childNode.children.length; i < n; ++i) {\n let gChild = childNode.children[i];\n let gHandle = childNode.handles[i];\n let gSizer = childNode.sizers[i];\n ArrayExt.insert(parentNode.children, j + i, gChild);\n ArrayExt.insert(parentNode.handles, j + i, gHandle);\n ArrayExt.insert(parentNode.sizers, j + i, gSizer);\n gChild.parent = parentNode;\n }\n\n // Clear the child node.\n childNode.children.length = 0;\n childNode.handles.length = 0;\n childNode.sizers.length = 0;\n childNode.parent = null;\n\n // Sync the handles on the parent node.\n parentNode.syncHandles();\n }\n\n /**\n * Create the tab layout node to hold the widget.\n */\n private _createTabNode(widget: Widget): Private.TabLayoutNode {\n let tabNode = new Private.TabLayoutNode(this._createTabBar());\n tabNode.tabBar.addTab(widget.title);\n Private.addAria(widget, tabNode.tabBar);\n return tabNode;\n }\n\n /**\n * Insert a widget next to an existing tab.\n *\n * #### Notes\n * This does not attach the widget to the parent widget.\n */\n private _insertTab(\n widget: Widget,\n ref: Widget | null,\n refNode: Private.TabLayoutNode | null,\n after: boolean\n ): void {\n // Do nothing if the tab is inserted next to itself.\n if (widget === ref) {\n return;\n }\n\n // Create the root if it does not exist.\n if (!this._root) {\n let tabNode = new Private.TabLayoutNode(this._createTabBar());\n tabNode.tabBar.addTab(widget.title);\n this._root = tabNode;\n Private.addAria(widget, tabNode.tabBar);\n return;\n }\n\n // Use the first tab node as the ref node if needed.\n if (!refNode) {\n refNode = this._root.findFirstTabNode()!;\n }\n\n // If the widget is not contained in the ref node, ensure it is\n // removed from the layout and hidden before being added again.\n if (refNode.tabBar.titles.indexOf(widget.title) === -1) {\n this._removeWidget(widget);\n widget.hide();\n }\n\n // Lookup the target index for inserting the tab.\n let index: number;\n if (ref) {\n index = refNode.tabBar.titles.indexOf(ref.title);\n } else {\n index = refNode.tabBar.currentIndex;\n }\n\n // Using transform create an additional layer in the pixel pipeline\n // to limit the number of layer, it is set only if there is more than one widget.\n if (this._hiddenMode === Widget.HiddenMode.Scale) {\n if (refNode.tabBar.titles.length === 0) {\n // Singular tab should use display mode to limit number of layers.\n widget.hiddenMode = Widget.HiddenMode.Display;\n } else if (refNode.tabBar.titles.length == 1) {\n // If we are adding a second tab, switch the existing tab back to scale.\n const existingWidget = refNode.tabBar.titles[0].owner;\n existingWidget.hiddenMode = Widget.HiddenMode.Scale;\n } else {\n // For the third and subsequent tabs no special action is needed.\n widget.hiddenMode = Widget.HiddenMode.Scale;\n }\n } else {\n // For all other modes just propagate the current mode.\n widget.hiddenMode = this._hiddenMode;\n }\n\n // Insert the widget's tab relative to the target index.\n refNode.tabBar.insertTab(index + (after ? 1 : 0), widget.title);\n Private.addAria(widget, refNode.tabBar);\n }\n\n /**\n * Insert a widget as a new split area.\n *\n * #### Notes\n * This does not attach the widget to the parent widget.\n */\n private _insertSplit(\n widget: Widget,\n ref: Widget | null,\n refNode: Private.TabLayoutNode | null,\n orientation: Private.Orientation,\n after: boolean,\n merge: boolean = false\n ): void {\n // Do nothing if there is no effective split.\n if (widget === ref && refNode && refNode.tabBar.titles.length === 1) {\n return;\n }\n\n // Ensure the widget is removed from the current layout.\n this._removeWidget(widget);\n\n // Set the root if it does not exist.\n if (!this._root) {\n this._root = this._createTabNode(widget);\n return;\n }\n\n // If the ref node parent is null, split the root.\n if (!refNode || !refNode.parent) {\n // Ensure the root is split with the correct orientation.\n let root = this._splitRoot(orientation);\n\n // Determine the insert index for the new tab node.\n let i = after ? root.children.length : 0;\n\n // Normalize the split node.\n root.normalizeSizes();\n\n // Create the sizer for new tab node.\n let sizer = Private.createSizer(refNode ? 1 : Private.GOLDEN_RATIO);\n\n // Insert the tab node sized to the golden ratio.\n let tabNode = this._createTabNode(widget);\n ArrayExt.insert(root.children, i, tabNode);\n ArrayExt.insert(root.sizers, i, sizer);\n ArrayExt.insert(root.handles, i, this._createHandle());\n tabNode.parent = root;\n\n // Re-normalize the split node to maintain the ratios.\n root.normalizeSizes();\n\n // Finally, synchronize the visibility of the handles.\n root.syncHandles();\n return;\n }\n\n // Lookup the split node for the ref widget.\n let splitNode = refNode.parent;\n\n // If the split node already had the correct orientation,\n // the widget can be inserted into the split node directly.\n if (splitNode.orientation === orientation) {\n // Find the index of the ref node.\n let i = splitNode.children.indexOf(refNode);\n\n // Conditionally reuse a tab layout found in the wanted position.\n if (merge) {\n let j = i + (after ? 1 : -1);\n let sibling = splitNode.children[j];\n if (sibling instanceof Private.TabLayoutNode) {\n this._insertTab(widget, null, sibling, true);\n ++sibling.tabBar.currentIndex;\n return;\n }\n }\n\n // Normalize the split node.\n splitNode.normalizeSizes();\n\n // Consume half the space for the insert location.\n let s = (splitNode.sizers[i].sizeHint /= 2);\n\n // Insert the tab node sized to the other half.\n let j = i + (after ? 1 : 0);\n let tabNode = this._createTabNode(widget);\n ArrayExt.insert(splitNode.children, j, tabNode);\n ArrayExt.insert(splitNode.sizers, j, Private.createSizer(s));\n ArrayExt.insert(splitNode.handles, j, this._createHandle());\n tabNode.parent = splitNode;\n\n // Finally, synchronize the visibility of the handles.\n splitNode.syncHandles();\n return;\n }\n\n // Remove the ref node from the split node.\n let i = ArrayExt.removeFirstOf(splitNode.children, refNode);\n\n // Create a new normalized split node for the children.\n let childNode = new Private.SplitLayoutNode(orientation);\n childNode.normalized = true;\n\n // Add the ref node sized to half the space.\n childNode.children.push(refNode);\n childNode.sizers.push(Private.createSizer(0.5));\n childNode.handles.push(this._createHandle());\n refNode.parent = childNode;\n\n // Add the tab node sized to the other half.\n let j = after ? 1 : 0;\n let tabNode = this._createTabNode(widget);\n ArrayExt.insert(childNode.children, j, tabNode);\n ArrayExt.insert(childNode.sizers, j, Private.createSizer(0.5));\n ArrayExt.insert(childNode.handles, j, this._createHandle());\n tabNode.parent = childNode;\n\n // Synchronize the visibility of the handles.\n childNode.syncHandles();\n\n // Finally, add the new child node to the original split node.\n ArrayExt.insert(splitNode.children, i, childNode);\n childNode.parent = splitNode;\n }\n\n /**\n * Ensure the root is a split node with the given orientation.\n */\n private _splitRoot(\n orientation: Private.Orientation\n ): Private.SplitLayoutNode {\n // Bail early if the root already meets the requirements.\n let oldRoot = this._root;\n if (oldRoot instanceof Private.SplitLayoutNode) {\n if (oldRoot.orientation === orientation) {\n return oldRoot;\n }\n }\n\n // Create a new root node with the specified orientation.\n let newRoot = (this._root = new Private.SplitLayoutNode(orientation));\n\n // Add the old root to the new root.\n if (oldRoot) {\n newRoot.children.push(oldRoot);\n newRoot.sizers.push(Private.createSizer(0));\n newRoot.handles.push(this._createHandle());\n oldRoot.parent = newRoot;\n }\n\n // Return the new root as a convenience.\n return newRoot;\n }\n\n /**\n * Fit the layout to the total size required by the widgets.\n */\n private _fit(): void {\n // Set up the computed minimum size.\n let minW = 0;\n let minH = 0;\n\n // Update the size limits for the layout tree.\n if (this._root) {\n let limits = this._root.fit(this._spacing, this._items);\n minW = limits.minWidth;\n minH = limits.minHeight;\n }\n\n // Update the box sizing and add it to the computed min size.\n let box = (this._box = ElementExt.boxSizing(this.parent!.node));\n minW += box.horizontalSum;\n minH += box.verticalSum;\n\n // Update the parent's min size constraints.\n let style = this.parent!.node.style;\n style.minWidth = `${minW}px`;\n style.minHeight = `${minH}px`;\n\n // Set the dirty flag to ensure only a single update occurs.\n this._dirty = true;\n\n // Notify the ancestor that it should fit immediately. This may\n // cause a resize of the parent, fulfilling the required update.\n if (this.parent!.parent) {\n MessageLoop.sendMessage(this.parent!.parent!, Widget.Msg.FitRequest);\n }\n\n // If the dirty flag is still set, the parent was not resized.\n // Trigger the required update on the parent widget immediately.\n if (this._dirty) {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n }\n }\n\n /**\n * Update the layout position and size of the widgets.\n *\n * The parent offset dimensions should be `-1` if unknown.\n */\n private _update(offsetWidth: number, offsetHeight: number): void {\n // Clear the dirty flag to indicate the update occurred.\n this._dirty = false;\n\n // Bail early if there is no root layout node.\n if (!this._root) {\n return;\n }\n\n // Measure the parent if the offset dimensions are unknown.\n if (offsetWidth < 0) {\n offsetWidth = this.parent!.node.offsetWidth;\n }\n if (offsetHeight < 0) {\n offsetHeight = this.parent!.node.offsetHeight;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent!.node);\n }\n\n // Compute the actual layout bounds adjusted for border and padding.\n let x = this._box.paddingTop;\n let y = this._box.paddingLeft;\n let width = offsetWidth - this._box.horizontalSum;\n let height = offsetHeight - this._box.verticalSum;\n\n // Update the geometry of the layout tree.\n this._root.update(x, y, width, height, this._spacing, this._items);\n }\n\n /**\n * Create a new tab bar for use by the dock layout.\n *\n * #### Notes\n * The tab bar will be attached to the parent if it exists.\n */\n private _createTabBar(): TabBar {\n // Create the tab bar using the renderer.\n let tabBar = this.renderer.createTabBar(this._document);\n\n // Enforce necessary tab bar behavior.\n tabBar.orientation = 'horizontal';\n\n // Attach the tab bar to the parent if possible.\n if (this.parent) {\n this.attachWidget(tabBar);\n }\n\n // Return the initialized tab bar.\n return tabBar;\n }\n\n /**\n * Create a new handle for the dock layout.\n *\n * #### Notes\n * The handle will be attached to the parent if it exists.\n */\n private _createHandle(): HTMLDivElement {\n // Create the handle using the renderer.\n let handle = this.renderer.createHandle();\n\n // Initialize the handle layout behavior.\n let style = handle.style;\n style.position = 'absolute';\n style.contain = 'strict';\n style.top = '0';\n style.left = '0';\n style.width = '0';\n style.height = '0';\n\n // Attach the handle to the parent if it exists.\n if (this.parent) {\n this.parent.node.appendChild(handle);\n }\n\n // Return the initialized handle.\n return handle;\n }\n\n private _spacing = 4;\n private _dirty = false;\n private _root: Private.LayoutNode | null = null;\n private _box: ElementExt.IBoxSizing | null = null;\n private _document: Document | ShadowRoot;\n private _hiddenMode: Widget.HiddenMode;\n private _items: Private.ItemMap = new Map();\n}\n\n/**\n * The namespace for the `DockLayout` class statics.\n */\nexport namespace DockLayout {\n /**\n * An options object for creating a dock layout.\n */\n export interface IOptions {\n /**\n * The document to use with the dock panel.\n *\n * The default is the global `document` instance.\n */\n document?: Document | ShadowRoot;\n\n /**\n * The method for hiding widgets.\n *\n * The default is `Widget.HiddenMode.Display`.\n */\n hiddenMode?: Widget.HiddenMode;\n\n /**\n * The renderer to use for the dock layout.\n */\n renderer: IRenderer;\n\n /**\n * The spacing between items in the layout.\n *\n * The default is `4`.\n */\n spacing?: number;\n }\n\n /**\n * A renderer for use with a dock layout.\n */\n export interface IRenderer {\n /**\n * Create a new tab bar for use with a dock layout.\n *\n * @returns A new tab bar for a dock layout.\n */\n createTabBar(document?: Document | ShadowRoot): TabBar;\n\n /**\n * Create a new handle node for use with a dock layout.\n *\n * @returns A new handle node for a dock layout.\n */\n createHandle(): HTMLDivElement;\n }\n\n /**\n * A type alias for the supported insertion modes.\n *\n * An insert mode is used to specify how a widget should be added\n * to the dock layout relative to a reference widget.\n */\n export type InsertMode =\n | /**\n * The area to the top of the reference widget.\n *\n * The widget will be inserted just above the reference widget.\n *\n * If the reference widget is null or invalid, the widget will be\n * inserted at the top edge of the dock layout.\n */\n 'split-top'\n\n /**\n * The area to the left of the reference widget.\n *\n * The widget will be inserted just left of the reference widget.\n *\n * If the reference widget is null or invalid, the widget will be\n * inserted at the left edge of the dock layout.\n */\n | 'split-left'\n\n /**\n * The area to the right of the reference widget.\n *\n * The widget will be inserted just right of the reference widget.\n *\n * If the reference widget is null or invalid, the widget will be\n * inserted at the right edge of the dock layout.\n */\n | 'split-right'\n\n /**\n * The area to the bottom of the reference widget.\n *\n * The widget will be inserted just below the reference widget.\n *\n * If the reference widget is null or invalid, the widget will be\n * inserted at the bottom edge of the dock layout.\n */\n | 'split-bottom'\n\n /**\n * Like `split-top` but if a tab layout exists above the reference widget,\n * it behaves like `tab-after` with reference to that instead.\n */\n | 'merge-top'\n\n /**\n * Like `split-left` but if a tab layout exists left of the reference widget,\n * it behaves like `tab-after` with reference to that instead.\n */\n | 'merge-left'\n\n /**\n * Like `split-right` but if a tab layout exists right of the reference widget,\n * it behaves like `tab-after` with reference to that instead.\n */\n | 'merge-right'\n\n /**\n * Like `split-bottom` but if a tab layout exists below the reference widget,\n * it behaves like `tab-after` with reference to that instead.\n */\n | 'merge-bottom'\n\n /**\n * The tab position before the reference widget.\n *\n * The widget will be added as a tab before the reference widget.\n *\n * If the reference widget is null or invalid, a sensible default\n * will be used.\n */\n | 'tab-before'\n\n /**\n * The tab position after the reference widget.\n *\n * The widget will be added as a tab after the reference widget.\n *\n * If the reference widget is null or invalid, a sensible default\n * will be used.\n */\n | 'tab-after';\n\n /**\n * An options object for adding a widget to the dock layout.\n */\n export interface IAddOptions {\n /**\n * The insertion mode for adding the widget.\n *\n * The default is `'tab-after'`.\n */\n mode?: InsertMode;\n\n /**\n * The reference widget for the insert location.\n *\n * The default is `null`.\n */\n ref?: Widget | null;\n }\n\n /**\n * A layout config object for a tab area.\n */\n export interface ITabAreaConfig {\n /**\n * The discriminated type of the config object.\n */\n type: 'tab-area';\n\n /**\n * The widgets contained in the tab area.\n */\n widgets: Widget[];\n\n /**\n * The index of the selected tab.\n */\n currentIndex: number;\n }\n\n /**\n * A layout config object for a split area.\n */\n export interface ISplitAreaConfig {\n /**\n * The discriminated type of the config object.\n */\n type: 'split-area';\n\n /**\n * The orientation of the split area.\n */\n orientation: 'horizontal' | 'vertical';\n\n /**\n * The children in the split area.\n */\n children: AreaConfig[];\n\n /**\n * The relative sizes of the children.\n */\n sizes: number[];\n }\n\n /**\n * A type alias for a general area config.\n */\n export type AreaConfig = ITabAreaConfig | ISplitAreaConfig;\n\n /**\n * A dock layout configuration object.\n */\n export interface ILayoutConfig {\n /**\n * The layout config for the main dock area.\n */\n main: AreaConfig | null;\n }\n\n /**\n * An object which represents the geometry of a tab area.\n */\n export interface ITabAreaGeometry {\n /**\n * The tab bar for the tab area.\n */\n tabBar: TabBar;\n\n /**\n * The local X position of the hit test in the dock area.\n *\n * #### Notes\n * This is the distance from the left edge of the layout parent\n * widget, to the local X coordinate of the hit test query.\n */\n x: number;\n\n /**\n * The local Y position of the hit test in the dock area.\n *\n * #### Notes\n * This is the distance from the top edge of the layout parent\n * widget, to the local Y coordinate of the hit test query.\n */\n y: number;\n\n /**\n * The local coordinate of the top edge of the tab area.\n *\n * #### Notes\n * This is the distance from the top edge of the layout parent\n * widget, to the top edge of the tab area.\n */\n top: number;\n\n /**\n * The local coordinate of the left edge of the tab area.\n *\n * #### Notes\n * This is the distance from the left edge of the layout parent\n * widget, to the left edge of the tab area.\n */\n left: number;\n\n /**\n * The local coordinate of the right edge of the tab area.\n *\n * #### Notes\n * This is the distance from the right edge of the layout parent\n * widget, to the right edge of the tab area.\n */\n right: number;\n\n /**\n * The local coordinate of the bottom edge of the tab area.\n *\n * #### Notes\n * This is the distance from the bottom edge of the layout parent\n * widget, to the bottom edge of the tab area.\n */\n bottom: number;\n\n /**\n * The width of the tab area.\n *\n * #### Notes\n * This is total width allocated for the tab area.\n */\n width: number;\n\n /**\n * The height of the tab area.\n *\n * #### Notes\n * This is total height allocated for the tab area.\n */\n height: number;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * A fraction used for sizing root panels; ~= `1 / golden_ratio`.\n */\n export const GOLDEN_RATIO = 0.618;\n\n /**\n * A type alias for a dock layout node.\n */\n export type LayoutNode = TabLayoutNode | SplitLayoutNode;\n\n /**\n * A type alias for the orientation of a split layout node.\n */\n export type Orientation = 'horizontal' | 'vertical';\n\n /**\n * A type alias for a layout item map.\n */\n export type ItemMap = Map;\n\n /**\n * Create a box sizer with an initial size hint.\n */\n export function createSizer(hint: number): BoxSizer {\n let sizer = new BoxSizer();\n sizer.sizeHint = hint;\n sizer.size = hint;\n return sizer;\n }\n\n /**\n * Normalize an area config object and collect the visited widgets.\n */\n export function normalizeAreaConfig(\n config: DockLayout.AreaConfig,\n widgetSet: Set\n ): DockLayout.AreaConfig | null {\n let result: DockLayout.AreaConfig | null;\n if (config.type === 'tab-area') {\n result = normalizeTabAreaConfig(config, widgetSet);\n } else {\n result = normalizeSplitAreaConfig(config, widgetSet);\n }\n return result;\n }\n\n /**\n * Convert a normalized area config into a layout tree.\n */\n export function realizeAreaConfig(\n config: DockLayout.AreaConfig,\n renderer: DockLayout.IRenderer,\n document: Document | ShadowRoot\n ): LayoutNode {\n let node: LayoutNode;\n if (config.type === 'tab-area') {\n node = realizeTabAreaConfig(config, renderer, document);\n } else {\n node = realizeSplitAreaConfig(config, renderer, document);\n }\n return node;\n }\n\n /**\n * A layout node which holds the data for a tabbed area.\n */\n export class TabLayoutNode {\n /**\n * Construct a new tab layout node.\n *\n * @param tabBar - The tab bar to use for the layout node.\n */\n constructor(tabBar: TabBar) {\n let tabSizer = new BoxSizer();\n let widgetSizer = new BoxSizer();\n tabSizer.stretch = 0;\n widgetSizer.stretch = 1;\n this.tabBar = tabBar;\n this.sizers = [tabSizer, widgetSizer];\n }\n\n /**\n * The parent of the layout node.\n */\n parent: SplitLayoutNode | null = null;\n\n /**\n * The tab bar for the layout node.\n */\n readonly tabBar: TabBar;\n\n /**\n * The sizers for the layout node.\n */\n readonly sizers: [BoxSizer, BoxSizer];\n\n /**\n * The most recent value for the `top` edge of the layout box.\n */\n get top(): number {\n return this._top;\n }\n\n /**\n * The most recent value for the `left` edge of the layout box.\n */\n get left(): number {\n return this._left;\n }\n\n /**\n * The most recent value for the `width` of the layout box.\n */\n get width(): number {\n return this._width;\n }\n\n /**\n * The most recent value for the `height` of the layout box.\n */\n get height(): number {\n return this._height;\n }\n\n /**\n * Create an iterator for all widgets in the layout tree.\n */\n *iterAllWidgets(): IterableIterator {\n yield this.tabBar;\n yield* this.iterUserWidgets();\n }\n\n /**\n * Create an iterator for the user widgets in the layout tree.\n */\n *iterUserWidgets(): IterableIterator {\n for (const title of this.tabBar.titles) {\n yield title.owner;\n }\n }\n\n /**\n * Create an iterator for the selected widgets in the layout tree.\n */\n *iterSelectedWidgets(): IterableIterator {\n let title = this.tabBar.currentTitle;\n if (title) {\n yield title.owner;\n }\n }\n\n /**\n * Create an iterator for the tab bars in the layout tree.\n */\n *iterTabBars(): IterableIterator> {\n yield this.tabBar;\n }\n\n /**\n * Create an iterator for the handles in the layout tree.\n */\n // eslint-disable-next-line require-yield\n *iterHandles(): IterableIterator {\n return;\n }\n\n /**\n * Find the tab layout node which contains the given widget.\n */\n findTabNode(widget: Widget): TabLayoutNode | null {\n return this.tabBar.titles.indexOf(widget.title) !== -1 ? this : null;\n }\n\n /**\n * Find the split layout node which contains the given handle.\n */\n findSplitNode(\n handle: HTMLDivElement\n ): { index: number; node: SplitLayoutNode } | null {\n return null;\n }\n\n /**\n * Find the first tab layout node in a layout tree.\n */\n findFirstTabNode(): TabLayoutNode | null {\n return this;\n }\n\n /**\n * Find the tab layout node which contains the local point.\n */\n hitTestTabNodes(x: number, y: number): TabLayoutNode | null {\n if (x < this._left || x >= this._left + this._width) {\n return null;\n }\n if (y < this._top || y >= this._top + this._height) {\n return null;\n }\n return this;\n }\n\n /**\n * Create a configuration object for the layout tree.\n */\n createConfig(): DockLayout.ITabAreaConfig {\n let widgets = this.tabBar.titles.map(title => title.owner);\n let currentIndex = this.tabBar.currentIndex;\n return { type: 'tab-area', widgets, currentIndex };\n }\n\n /**\n * Recursively hold all of the sizes in the layout tree.\n *\n * This ignores the sizers of tab layout nodes.\n */\n holdAllSizes(): void {\n return;\n }\n\n /**\n * Fit the layout tree.\n */\n fit(spacing: number, items: ItemMap): ElementExt.ISizeLimits {\n // Set up the limit variables.\n let minWidth = 0;\n let minHeight = 0;\n let maxWidth = Infinity;\n let maxHeight = Infinity;\n\n // Lookup the tab bar layout item.\n let tabBarItem = items.get(this.tabBar);\n\n // Lookup the widget layout item.\n let current = this.tabBar.currentTitle;\n let widgetItem = current ? items.get(current.owner) : undefined;\n\n // Lookup the tab bar and widget sizers.\n let [tabBarSizer, widgetSizer] = this.sizers;\n\n // Update the tab bar limits.\n if (tabBarItem) {\n tabBarItem.fit();\n }\n\n // Update the widget limits.\n if (widgetItem) {\n widgetItem.fit();\n }\n\n // Update the results and sizer for the tab bar.\n if (tabBarItem && !tabBarItem.isHidden) {\n minWidth = Math.max(minWidth, tabBarItem.minWidth);\n minHeight += tabBarItem.minHeight;\n tabBarSizer.minSize = tabBarItem.minHeight;\n tabBarSizer.maxSize = tabBarItem.maxHeight;\n } else {\n tabBarSizer.minSize = 0;\n tabBarSizer.maxSize = 0;\n }\n\n // Update the results and sizer for the current widget.\n if (widgetItem && !widgetItem.isHidden) {\n minWidth = Math.max(minWidth, widgetItem.minWidth);\n minHeight += widgetItem.minHeight;\n widgetSizer.minSize = widgetItem.minHeight;\n widgetSizer.maxSize = Infinity;\n } else {\n widgetSizer.minSize = 0;\n widgetSizer.maxSize = Infinity;\n }\n\n // Return the computed size limits for the layout node.\n return { minWidth, minHeight, maxWidth, maxHeight };\n }\n\n /**\n * Update the layout tree.\n */\n update(\n left: number,\n top: number,\n width: number,\n height: number,\n spacing: number,\n items: ItemMap\n ): void {\n // Update the layout box values.\n this._top = top;\n this._left = left;\n this._width = width;\n this._height = height;\n\n // Lookup the tab bar layout item.\n let tabBarItem = items.get(this.tabBar);\n\n // Lookup the widget layout item.\n let current = this.tabBar.currentTitle;\n let widgetItem = current ? items.get(current.owner) : undefined;\n\n // Distribute the layout space to the sizers.\n BoxEngine.calc(this.sizers, height);\n\n // Update the tab bar item using the computed size.\n if (tabBarItem && !tabBarItem.isHidden) {\n let size = this.sizers[0].size;\n tabBarItem.update(left, top, width, size);\n top += size;\n }\n\n // Layout the widget using the computed size.\n if (widgetItem && !widgetItem.isHidden) {\n let size = this.sizers[1].size;\n widgetItem.update(left, top, width, size);\n }\n }\n\n private _top = 0;\n private _left = 0;\n private _width = 0;\n private _height = 0;\n }\n\n /**\n * A layout node which holds the data for a split area.\n */\n export class SplitLayoutNode {\n /**\n * Construct a new split layout node.\n *\n * @param orientation - The orientation of the node.\n */\n constructor(orientation: Orientation) {\n this.orientation = orientation;\n }\n\n /**\n * The parent of the layout node.\n */\n parent: SplitLayoutNode | null = null;\n\n /**\n * Whether the sizers have been normalized.\n */\n normalized = false;\n\n /**\n * The orientation of the node.\n */\n readonly orientation: Orientation;\n\n /**\n * The child nodes for the split node.\n */\n readonly children: LayoutNode[] = [];\n\n /**\n * The box sizers for the layout children.\n */\n readonly sizers: BoxSizer[] = [];\n\n /**\n * The handles for the layout children.\n */\n readonly handles: HTMLDivElement[] = [];\n\n /**\n * Create an iterator for all widgets in the layout tree.\n */\n *iterAllWidgets(): IterableIterator {\n for (const child of this.children) {\n yield* child.iterAllWidgets();\n }\n }\n\n /**\n * Create an iterator for the user widgets in the layout tree.\n */\n *iterUserWidgets(): IterableIterator {\n for (const child of this.children) {\n yield* child.iterUserWidgets();\n }\n }\n\n /**\n * Create an iterator for the selected widgets in the layout tree.\n */\n *iterSelectedWidgets(): IterableIterator {\n for (const child of this.children) {\n yield* child.iterSelectedWidgets();\n }\n }\n\n /**\n * Create an iterator for the tab bars in the layout tree.\n */\n *iterTabBars(): IterableIterator> {\n for (const child of this.children) {\n yield* child.iterTabBars();\n }\n }\n\n /**\n * Create an iterator for the handles in the layout tree.\n */\n *iterHandles(): IterableIterator {\n yield* this.handles;\n for (const child of this.children) {\n yield* child.iterHandles();\n }\n }\n\n /**\n * Find the tab layout node which contains the given widget.\n */\n findTabNode(widget: Widget): TabLayoutNode | null {\n for (let i = 0, n = this.children.length; i < n; ++i) {\n let result = this.children[i].findTabNode(widget);\n if (result) {\n return result;\n }\n }\n return null;\n }\n\n /**\n * Find the split layout node which contains the given handle.\n */\n findSplitNode(\n handle: HTMLDivElement\n ): { index: number; node: SplitLayoutNode } | null {\n let index = this.handles.indexOf(handle);\n if (index !== -1) {\n return { index, node: this };\n }\n for (let i = 0, n = this.children.length; i < n; ++i) {\n let result = this.children[i].findSplitNode(handle);\n if (result) {\n return result;\n }\n }\n return null;\n }\n\n /**\n * Find the first tab layout node in a layout tree.\n */\n findFirstTabNode(): TabLayoutNode | null {\n if (this.children.length === 0) {\n return null;\n }\n return this.children[0].findFirstTabNode();\n }\n\n /**\n * Find the tab layout node which contains the local point.\n */\n hitTestTabNodes(x: number, y: number): TabLayoutNode | null {\n for (let i = 0, n = this.children.length; i < n; ++i) {\n let result = this.children[i].hitTestTabNodes(x, y);\n if (result) {\n return result;\n }\n }\n return null;\n }\n\n /**\n * Create a configuration object for the layout tree.\n */\n createConfig(): DockLayout.ISplitAreaConfig {\n let orientation = this.orientation;\n let sizes = this.createNormalizedSizes();\n let children = this.children.map(child => child.createConfig());\n return { type: 'split-area', orientation, children, sizes };\n }\n\n /**\n * Sync the visibility and orientation of the handles.\n */\n syncHandles(): void {\n this.handles.forEach((handle, i) => {\n handle.setAttribute('data-orientation', this.orientation);\n if (i === this.handles.length - 1) {\n handle.classList.add('lm-mod-hidden');\n } else {\n handle.classList.remove('lm-mod-hidden');\n }\n });\n }\n\n /**\n * Hold the current sizes of the box sizers.\n *\n * This sets the size hint of each sizer to its current size.\n */\n holdSizes(): void {\n for (const sizer of this.sizers) {\n sizer.sizeHint = sizer.size;\n }\n }\n\n /**\n * Recursively hold all of the sizes in the layout tree.\n *\n * This ignores the sizers of tab layout nodes.\n */\n holdAllSizes(): void {\n for (const child of this.children) {\n child.holdAllSizes();\n }\n this.holdSizes();\n }\n\n /**\n * Normalize the sizes of the split layout node.\n */\n normalizeSizes(): void {\n // Bail early if the sizers are empty.\n let n = this.sizers.length;\n if (n === 0) {\n return;\n }\n\n // Hold the current sizes of the sizers.\n this.holdSizes();\n\n // Compute the sum of the sizes.\n let sum = this.sizers.reduce((v, sizer) => v + sizer.sizeHint, 0);\n\n // Normalize the sizes based on the sum.\n if (sum === 0) {\n for (const sizer of this.sizers) {\n sizer.size = sizer.sizeHint = 1 / n;\n }\n } else {\n for (const sizer of this.sizers) {\n sizer.size = sizer.sizeHint /= sum;\n }\n }\n\n // Mark the sizes as normalized.\n this.normalized = true;\n }\n\n /**\n * Snap the normalized sizes of the split layout node.\n */\n createNormalizedSizes(): number[] {\n // Bail early if the sizers are empty.\n let n = this.sizers.length;\n if (n === 0) {\n return [];\n }\n\n // Grab the current sizes of the sizers.\n let sizes = this.sizers.map(sizer => sizer.size);\n\n // Compute the sum of the sizes.\n let sum = sizes.reduce((v, size) => v + size, 0);\n\n // Normalize the sizes based on the sum.\n if (sum === 0) {\n for (let i = sizes.length - 1; i > -1; i--) {\n sizes[i] = 1 / n;\n }\n } else {\n for (let i = sizes.length - 1; i > -1; i--) {\n sizes[i] /= sum;\n }\n }\n\n // Return the normalized sizes.\n return sizes;\n }\n\n /**\n * Fit the layout tree.\n */\n fit(spacing: number, items: ItemMap): ElementExt.ISizeLimits {\n // Compute the required fixed space.\n let horizontal = this.orientation === 'horizontal';\n let fixed = Math.max(0, this.children.length - 1) * spacing;\n\n // Set up the limit variables.\n let minWidth = horizontal ? fixed : 0;\n let minHeight = horizontal ? 0 : fixed;\n let maxWidth = Infinity;\n let maxHeight = Infinity;\n\n // Fit the children and update the limits.\n for (let i = 0, n = this.children.length; i < n; ++i) {\n let limits = this.children[i].fit(spacing, items);\n if (horizontal) {\n minHeight = Math.max(minHeight, limits.minHeight);\n minWidth += limits.minWidth;\n this.sizers[i].minSize = limits.minWidth;\n } else {\n minWidth = Math.max(minWidth, limits.minWidth);\n minHeight += limits.minHeight;\n this.sizers[i].minSize = limits.minHeight;\n }\n }\n\n // Return the computed limits for the layout node.\n return { minWidth, minHeight, maxWidth, maxHeight };\n }\n\n /**\n * Update the layout tree.\n */\n update(\n left: number,\n top: number,\n width: number,\n height: number,\n spacing: number,\n items: ItemMap\n ): void {\n // Compute the available layout space.\n let horizontal = this.orientation === 'horizontal';\n let fixed = Math.max(0, this.children.length - 1) * spacing;\n let space = Math.max(0, (horizontal ? width : height) - fixed);\n\n // De-normalize the sizes if needed.\n if (this.normalized) {\n for (const sizer of this.sizers) {\n sizer.sizeHint *= space;\n }\n this.normalized = false;\n }\n\n // Distribute the layout space to the sizers.\n BoxEngine.calc(this.sizers, space);\n\n // Update the geometry of the child nodes and handles.\n for (let i = 0, n = this.children.length; i < n; ++i) {\n let child = this.children[i];\n let size = this.sizers[i].size;\n let handleStyle = this.handles[i].style;\n if (horizontal) {\n child.update(left, top, size, height, spacing, items);\n left += size;\n handleStyle.top = `${top}px`;\n handleStyle.left = `${left}px`;\n handleStyle.width = `${spacing}px`;\n handleStyle.height = `${height}px`;\n left += spacing;\n } else {\n child.update(left, top, width, size, spacing, items);\n top += size;\n handleStyle.top = `${top}px`;\n handleStyle.left = `${left}px`;\n handleStyle.width = `${width}px`;\n handleStyle.height = `${spacing}px`;\n top += spacing;\n }\n }\n }\n }\n\n export function addAria(widget: Widget, tabBar: TabBar): void {\n widget.node.setAttribute('role', 'tabpanel');\n let renderer = tabBar.renderer;\n if (renderer instanceof TabBar.Renderer) {\n let tabId = renderer.createTabKey({\n title: widget.title,\n current: false,\n zIndex: 0\n });\n widget.node.setAttribute('aria-labelledby', tabId);\n }\n }\n\n export function removeAria(widget: Widget): void {\n widget.node.removeAttribute('role');\n widget.node.removeAttribute('aria-labelledby');\n }\n\n /**\n * Normalize a tab area config and collect the visited widgets.\n */\n function normalizeTabAreaConfig(\n config: DockLayout.ITabAreaConfig,\n widgetSet: Set\n ): DockLayout.ITabAreaConfig | null {\n // Bail early if there is no content.\n if (config.widgets.length === 0) {\n return null;\n }\n\n // Setup the filtered widgets array.\n let widgets: Widget[] = [];\n\n // Filter the config for unique widgets.\n for (const widget of config.widgets) {\n if (!widgetSet.has(widget)) {\n widgetSet.add(widget);\n widgets.push(widget);\n }\n }\n\n // Bail if there are no effective widgets.\n if (widgets.length === 0) {\n return null;\n }\n\n // Normalize the current index.\n let index = config.currentIndex;\n if (index !== -1 && (index < 0 || index >= widgets.length)) {\n index = 0;\n }\n\n // Return a normalized config object.\n return { type: 'tab-area', widgets, currentIndex: index };\n }\n\n /**\n * Normalize a split area config and collect the visited widgets.\n */\n function normalizeSplitAreaConfig(\n config: DockLayout.ISplitAreaConfig,\n widgetSet: Set\n ): DockLayout.AreaConfig | null {\n // Set up the result variables.\n let orientation = config.orientation;\n let children: DockLayout.AreaConfig[] = [];\n let sizes: number[] = [];\n\n // Normalize the config children.\n for (let i = 0, n = config.children.length; i < n; ++i) {\n // Normalize the child config.\n let child = normalizeAreaConfig(config.children[i], widgetSet);\n\n // Ignore an empty child.\n if (!child) {\n continue;\n }\n\n // Add the child or hoist its content as appropriate.\n if (child.type === 'tab-area' || child.orientation !== orientation) {\n children.push(child);\n sizes.push(Math.abs(config.sizes[i] || 0));\n } else {\n children.push(...child.children);\n sizes.push(...child.sizes);\n }\n }\n\n // Bail if there are no effective children.\n if (children.length === 0) {\n return null;\n }\n\n // If there is only one effective child, return that child.\n if (children.length === 1) {\n return children[0];\n }\n\n // Return a normalized config object.\n return { type: 'split-area', orientation, children, sizes };\n }\n\n /**\n * Convert a normalized tab area config into a layout tree.\n */\n function realizeTabAreaConfig(\n config: DockLayout.ITabAreaConfig,\n renderer: DockLayout.IRenderer,\n document: Document | ShadowRoot\n ): TabLayoutNode {\n // Create the tab bar for the layout node.\n let tabBar = renderer.createTabBar(document);\n\n // Hide each widget and add it to the tab bar.\n for (const widget of config.widgets) {\n widget.hide();\n tabBar.addTab(widget.title);\n Private.addAria(widget, tabBar);\n }\n\n // Set the current index of the tab bar.\n tabBar.currentIndex = config.currentIndex;\n\n // Return the new tab layout node.\n return new TabLayoutNode(tabBar);\n }\n\n /**\n * Convert a normalized split area config into a layout tree.\n */\n function realizeSplitAreaConfig(\n config: DockLayout.ISplitAreaConfig,\n renderer: DockLayout.IRenderer,\n document: Document | ShadowRoot\n ): SplitLayoutNode {\n // Create the split layout node.\n let node = new SplitLayoutNode(config.orientation);\n\n // Add each child to the layout node.\n config.children.forEach((child, i) => {\n // Create the child data for the layout node.\n let childNode = realizeAreaConfig(child, renderer, document);\n let sizer = createSizer(config.sizes[i]);\n let handle = renderer.createHandle();\n\n // Add the child data to the layout node.\n node.children.push(childNode);\n node.handles.push(handle);\n node.sizers.push(sizer);\n\n // Update the parent for the child node.\n childNode.parent = node;\n });\n\n // Synchronize the handle state for the layout node.\n node.syncHandles();\n\n // Normalize the sizes for the layout node.\n node.normalizeSizes();\n\n // Return the new layout node.\n return node;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { find } from '@lumino/algorithm';\n\nimport { MimeData } from '@lumino/coreutils';\n\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ElementExt, Platform } from '@lumino/domutils';\n\nimport { Drag } from '@lumino/dragdrop';\n\nimport { ConflatableMessage, Message, MessageLoop } from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { DockLayout } from './docklayout';\n\nimport { TabBar } from './tabbar';\n\nimport { Widget } from './widget';\n\n/**\n * A widget which provides a flexible docking area for widgets.\n */\nexport class DockPanel extends Widget {\n /**\n * Construct a new dock panel.\n *\n * @param options - The options for initializing the panel.\n */\n constructor(options: DockPanel.IOptions = {}) {\n super();\n this.addClass('lm-DockPanel');\n this._document = options.document || document;\n this._mode = options.mode || 'multiple-document';\n this._renderer = options.renderer || DockPanel.defaultRenderer;\n this._edges = options.edges || Private.DEFAULT_EDGES;\n if (options.tabsMovable !== undefined) {\n this._tabsMovable = options.tabsMovable;\n }\n if (options.tabsConstrained !== undefined) {\n this._tabsConstrained = options.tabsConstrained;\n }\n if (options.addButtonEnabled !== undefined) {\n this._addButtonEnabled = options.addButtonEnabled;\n }\n\n // Toggle the CSS mode attribute.\n this.dataset['mode'] = this._mode;\n\n // Create the delegate renderer for the layout.\n let renderer: DockPanel.IRenderer = {\n createTabBar: () => this._createTabBar(),\n createHandle: () => this._createHandle()\n };\n\n // Set up the dock layout for the panel.\n this.layout = new DockLayout({\n document: this._document,\n renderer,\n spacing: options.spacing,\n hiddenMode: options.hiddenMode\n });\n\n // Set up the overlay drop indicator.\n this.overlay = options.overlay || new DockPanel.Overlay();\n this.node.appendChild(this.overlay.node);\n }\n\n /**\n * Dispose of the resources held by the panel.\n */\n dispose(): void {\n // Ensure the mouse is released.\n this._releaseMouse();\n\n // Hide the overlay.\n this.overlay.hide(0);\n\n // Cancel a drag if one is in progress.\n if (this._drag) {\n this._drag.dispose();\n }\n\n // Dispose of the base class.\n super.dispose();\n }\n\n /**\n * The method for hiding widgets.\n */\n get hiddenMode(): Widget.HiddenMode {\n return (this.layout as DockLayout).hiddenMode;\n }\n\n /**\n * Set the method for hiding widgets.\n */\n set hiddenMode(v: Widget.HiddenMode) {\n (this.layout as DockLayout).hiddenMode = v;\n }\n\n /**\n * A signal emitted when the layout configuration is modified.\n *\n * #### Notes\n * This signal is emitted whenever the current layout configuration\n * may have changed.\n *\n * This signal is emitted asynchronously in a collapsed fashion, so\n * that multiple synchronous modifications results in only a single\n * emit of the signal.\n */\n get layoutModified(): ISignal {\n return this._layoutModified;\n }\n\n /**\n * A signal emitted when the add button on a tab bar is clicked.\n *\n */\n get addRequested(): ISignal> {\n return this._addRequested;\n }\n\n /**\n * The overlay used by the dock panel.\n */\n readonly overlay: DockPanel.IOverlay;\n\n /**\n * The renderer used by the dock panel.\n */\n get renderer(): DockPanel.IRenderer {\n return (this.layout as DockLayout).renderer;\n }\n\n /**\n * Get the spacing between the widgets.\n */\n get spacing(): number {\n return (this.layout as DockLayout).spacing;\n }\n\n /**\n * Set the spacing between the widgets.\n */\n set spacing(value: number) {\n (this.layout as DockLayout).spacing = value;\n }\n\n /**\n * Get the mode for the dock panel.\n */\n get mode(): DockPanel.Mode {\n return this._mode;\n }\n\n /**\n * Set the mode for the dock panel.\n *\n * #### Notes\n * Changing the mode is a destructive operation with respect to the\n * panel's layout configuration. If layout state must be preserved,\n * save the current layout config before changing the mode.\n */\n set mode(value: DockPanel.Mode) {\n // Bail early if the mode does not change.\n if (this._mode === value) {\n return;\n }\n\n // Update the internal mode.\n this._mode = value;\n\n // Toggle the CSS mode attribute.\n this.dataset['mode'] = value;\n\n // Get the layout for the panel.\n let layout = this.layout as DockLayout;\n\n // Configure the layout for the specified mode.\n switch (value) {\n case 'multiple-document':\n for (const tabBar of layout.tabBars()) {\n tabBar.show();\n }\n break;\n case 'single-document':\n layout.restoreLayout(Private.createSingleDocumentConfig(this));\n break;\n default:\n throw 'unreachable';\n }\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Whether the tabs can be dragged / moved at runtime.\n */\n get tabsMovable(): boolean {\n return this._tabsMovable;\n }\n\n /**\n * Enable / Disable draggable / movable tabs.\n */\n set tabsMovable(value: boolean) {\n this._tabsMovable = value;\n for (const tabBar of this.tabBars()) {\n tabBar.tabsMovable = value;\n }\n }\n\n /**\n * Whether the tabs are constrained to their source dock panel\n */\n get tabsConstrained(): boolean {\n return this._tabsConstrained;\n }\n\n /**\n * Constrain/Allow tabs to be dragged outside of this dock panel\n */\n set tabsConstrained(value: boolean) {\n this._tabsConstrained = value;\n }\n\n /**\n * Whether the add buttons for each tab bar are enabled.\n */\n get addButtonEnabled(): boolean {\n return this._addButtonEnabled;\n }\n\n /**\n * Set whether the add buttons for each tab bar are enabled.\n */\n set addButtonEnabled(value: boolean) {\n this._addButtonEnabled = value;\n for (const tabBar of this.tabBars()) {\n tabBar.addButtonEnabled = value;\n }\n }\n\n /**\n * Whether the dock panel is empty.\n */\n get isEmpty(): boolean {\n return (this.layout as DockLayout).isEmpty;\n }\n\n /**\n * Create an iterator over the user widgets in the panel.\n *\n * @returns A new iterator over the user widgets in the panel.\n *\n * #### Notes\n * This iterator does not include the generated tab bars.\n */\n *widgets(): IterableIterator {\n yield* (this.layout as DockLayout).widgets();\n }\n\n /**\n * Create an iterator over the selected widgets in the panel.\n *\n * @returns A new iterator over the selected user widgets.\n *\n * #### Notes\n * This iterator yields the widgets corresponding to the current tab\n * of each tab bar in the panel.\n */\n *selectedWidgets(): IterableIterator {\n yield* (this.layout as DockLayout).selectedWidgets();\n }\n\n /**\n * Create an iterator over the tab bars in the panel.\n *\n * @returns A new iterator over the tab bars in the panel.\n *\n * #### Notes\n * This iterator does not include the user widgets.\n */\n *tabBars(): IterableIterator> {\n yield* (this.layout as DockLayout).tabBars();\n }\n\n /**\n * Create an iterator over the handles in the panel.\n *\n * @returns A new iterator over the handles in the panel.\n */\n *handles(): IterableIterator {\n yield* (this.layout as DockLayout).handles();\n }\n\n /**\n * Select a specific widget in the dock panel.\n *\n * @param widget - The widget of interest.\n *\n * #### Notes\n * This will make the widget the current widget in its tab area.\n */\n selectWidget(widget: Widget): void {\n // Find the tab bar which contains the widget.\n let tabBar = find(this.tabBars(), bar => {\n return bar.titles.indexOf(widget.title) !== -1;\n });\n\n // Throw an error if no tab bar is found.\n if (!tabBar) {\n throw new Error('Widget is not contained in the dock panel.');\n }\n\n // Ensure the widget is the current widget.\n tabBar.currentTitle = widget.title;\n }\n\n /**\n * Activate a specified widget in the dock panel.\n *\n * @param widget - The widget of interest.\n *\n * #### Notes\n * This will select and activate the given widget.\n */\n activateWidget(widget: Widget): void {\n this.selectWidget(widget);\n widget.activate();\n }\n\n /**\n * Save the current layout configuration of the dock panel.\n *\n * @returns A new config object for the current layout state.\n *\n * #### Notes\n * The return value can be provided to the `restoreLayout` method\n * in order to restore the layout to its current configuration.\n */\n saveLayout(): DockPanel.ILayoutConfig {\n return (this.layout as DockLayout).saveLayout();\n }\n\n /**\n * Restore the layout to a previously saved configuration.\n *\n * @param config - The layout configuration to restore.\n *\n * #### Notes\n * Widgets which currently belong to the layout but which are not\n * contained in the config will be unparented.\n *\n * The dock panel automatically reverts to `'multiple-document'`\n * mode when a layout config is restored.\n */\n restoreLayout(config: DockPanel.ILayoutConfig): void {\n // Reset the mode.\n this._mode = 'multiple-document';\n\n // Restore the layout.\n (this.layout as DockLayout).restoreLayout(config);\n\n // Flush the message loop on IE and Edge to prevent flicker.\n if (Platform.IS_EDGE || Platform.IS_IE) {\n MessageLoop.flush();\n }\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Add a widget to the dock panel.\n *\n * @param widget - The widget to add to the dock panel.\n *\n * @param options - The additional options for adding the widget.\n *\n * #### Notes\n * If the panel is in single document mode, the options are ignored\n * and the widget is always added as tab in the hidden tab bar.\n */\n addWidget(widget: Widget, options: DockPanel.IAddOptions = {}): void {\n // Add the widget to the layout.\n if (this._mode === 'single-document') {\n (this.layout as DockLayout).addWidget(widget);\n } else {\n (this.layout as DockLayout).addWidget(widget, options);\n }\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Process a message sent to the widget.\n *\n * @param msg - The message sent to the widget.\n */\n processMessage(msg: Message): void {\n if (msg.type === 'layout-modified') {\n this._layoutModified.emit(undefined);\n } else {\n super.processMessage(msg);\n }\n }\n\n /**\n * Handle the DOM events for the dock panel.\n *\n * @param event - The DOM event sent to the panel.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the panel's DOM node. It should\n * not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'lm-dragenter':\n this._evtDragEnter(event as Drag.Event);\n break;\n case 'lm-dragleave':\n this._evtDragLeave(event as Drag.Event);\n break;\n case 'lm-dragover':\n this._evtDragOver(event as Drag.Event);\n break;\n case 'lm-drop':\n this._evtDrop(event as Drag.Event);\n break;\n case 'pointerdown':\n this._evtPointerDown(event as PointerEvent);\n break;\n case 'pointermove':\n this._evtPointerMove(event as PointerEvent);\n break;\n case 'pointerup':\n this._evtPointerUp(event as PointerEvent);\n break;\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('lm-dragenter', this);\n this.node.addEventListener('lm-dragleave', this);\n this.node.addEventListener('lm-dragover', this);\n this.node.addEventListener('lm-drop', this);\n this.node.addEventListener('pointerdown', this);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('lm-dragenter', this);\n this.node.removeEventListener('lm-dragleave', this);\n this.node.removeEventListener('lm-dragover', this);\n this.node.removeEventListener('lm-drop', this);\n this.node.removeEventListener('pointerdown', this);\n this._releaseMouse();\n }\n\n /**\n * A message handler invoked on a `'child-added'` message.\n */\n protected onChildAdded(msg: Widget.ChildMessage): void {\n // Ignore the generated tab bars.\n if (Private.isGeneratedTabBarProperty.get(msg.child)) {\n return;\n }\n\n // Add the widget class to the child.\n msg.child.addClass('lm-DockPanel-widget');\n }\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {\n // Ignore the generated tab bars.\n if (Private.isGeneratedTabBarProperty.get(msg.child)) {\n return;\n }\n\n // Remove the widget class from the child.\n msg.child.removeClass('lm-DockPanel-widget');\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Handle the `'lm-dragenter'` event for the dock panel.\n */\n private _evtDragEnter(event: Drag.Event): void {\n // If the factory mime type is present, mark the event as\n // handled in order to get the rest of the drag events.\n if (event.mimeData.hasData('application/vnd.lumino.widget-factory')) {\n event.preventDefault();\n event.stopPropagation();\n }\n }\n\n /**\n * Handle the `'lm-dragleave'` event for the dock panel.\n */\n private _evtDragLeave(event: Drag.Event): void {\n // Mark the event as handled.\n event.preventDefault();\n\n if (this._tabsConstrained && event.source !== this) return;\n\n event.stopPropagation();\n\n // The new target might be a descendant, so we might still handle the drop.\n // Hide asynchronously so that if a lm-dragover event bubbles up to us, the\n // hide is cancelled by the lm-dragover handler's show overlay logic.\n this.overlay.hide(1);\n }\n\n /**\n * Handle the `'lm-dragover'` event for the dock panel.\n */\n private _evtDragOver(event: Drag.Event): void {\n // Mark the event as handled.\n event.preventDefault();\n\n // Show the drop indicator overlay and update the drop\n // action based on the drop target zone under the mouse.\n if (\n (this._tabsConstrained && event.source !== this) ||\n this._showOverlay(event.clientX, event.clientY) === 'invalid'\n ) {\n event.dropAction = 'none';\n } else {\n event.stopPropagation();\n event.dropAction = event.proposedAction;\n }\n }\n\n /**\n * Handle the `'lm-drop'` event for the dock panel.\n */\n private _evtDrop(event: Drag.Event): void {\n // Mark the event as handled.\n event.preventDefault();\n\n // Hide the drop indicator overlay.\n this.overlay.hide(0);\n\n // Bail if the proposed action is to do nothing.\n if (event.proposedAction === 'none') {\n event.dropAction = 'none';\n return;\n }\n\n // Find the drop target under the mouse.\n let { clientX, clientY } = event;\n let { zone, target } = Private.findDropTarget(\n this,\n clientX,\n clientY,\n this._edges\n );\n\n // Bail if the drop zone is invalid.\n if (\n (this._tabsConstrained && event.source !== this) ||\n zone === 'invalid'\n ) {\n event.dropAction = 'none';\n return;\n }\n\n // Bail if the factory mime type has invalid data.\n let mimeData = event.mimeData;\n let factory = mimeData.getData('application/vnd.lumino.widget-factory');\n if (typeof factory !== 'function') {\n event.dropAction = 'none';\n return;\n }\n\n // Bail if the factory does not produce a widget.\n let widget = factory();\n if (!(widget instanceof Widget)) {\n event.dropAction = 'none';\n return;\n }\n\n // Bail if the widget is an ancestor of the dock panel.\n if (widget.contains(this)) {\n event.dropAction = 'none';\n return;\n }\n\n // Find the reference widget for the drop target.\n let ref = target ? Private.getDropRef(target.tabBar) : null;\n\n // Add the widget according to the indicated drop zone.\n switch (zone) {\n case 'root-all':\n this.addWidget(widget);\n break;\n case 'root-top':\n this.addWidget(widget, { mode: 'split-top' });\n break;\n case 'root-left':\n this.addWidget(widget, { mode: 'split-left' });\n break;\n case 'root-right':\n this.addWidget(widget, { mode: 'split-right' });\n break;\n case 'root-bottom':\n this.addWidget(widget, { mode: 'split-bottom' });\n break;\n case 'widget-all':\n this.addWidget(widget, { mode: 'tab-after', ref });\n break;\n case 'widget-top':\n this.addWidget(widget, { mode: 'split-top', ref });\n break;\n case 'widget-left':\n this.addWidget(widget, { mode: 'split-left', ref });\n break;\n case 'widget-right':\n this.addWidget(widget, { mode: 'split-right', ref });\n break;\n case 'widget-bottom':\n this.addWidget(widget, { mode: 'split-bottom', ref });\n break;\n case 'widget-tab':\n this.addWidget(widget, { mode: 'tab-after', ref });\n break;\n default:\n throw 'unreachable';\n }\n\n // Accept the proposed drop action.\n event.dropAction = event.proposedAction;\n\n // Stop propagation if we have not bailed so far.\n event.stopPropagation();\n\n // Activate the dropped widget.\n this.activateWidget(widget);\n }\n\n /**\n * Handle the `'keydown'` event for the dock panel.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // Stop input events during drag.\n event.preventDefault();\n event.stopPropagation();\n\n // Release the mouse if `Escape` is pressed.\n if (event.keyCode === 27) {\n // Finalize the mouse release.\n this._releaseMouse();\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n }\n\n /**\n * Handle the `'pointerdown'` event for the dock panel.\n */\n private _evtPointerDown(event: PointerEvent): void {\n // Do nothing if the left mouse button is not pressed.\n if (event.button !== 0) {\n return;\n }\n\n // Find the handle which contains the mouse target, if any.\n let layout = this.layout as DockLayout;\n let target = event.target as HTMLElement;\n let handle = find(layout.handles(), handle => handle.contains(target));\n if (!handle) {\n return;\n }\n\n // Stop the event when a handle is pressed.\n event.preventDefault();\n event.stopPropagation();\n\n // Add the extra document listeners.\n this._document.addEventListener('keydown', this, true);\n this._document.addEventListener('pointerup', this, true);\n this._document.addEventListener('pointermove', this, true);\n this._document.addEventListener('contextmenu', this, true);\n\n // Compute the offset deltas for the handle press.\n let rect = handle.getBoundingClientRect();\n let deltaX = event.clientX - rect.left;\n let deltaY = event.clientY - rect.top;\n\n // Override the cursor and store the press data.\n let style = window.getComputedStyle(handle);\n let override = Drag.overrideCursor(style.cursor!, this._document);\n this._pressData = { handle, deltaX, deltaY, override };\n }\n\n /**\n * Handle the `'pointermove'` event for the dock panel.\n */\n private _evtPointerMove(event: PointerEvent): void {\n // Bail early if no drag is in progress.\n if (!this._pressData) {\n return;\n }\n\n // Stop the event when dragging a handle.\n event.preventDefault();\n event.stopPropagation();\n\n // Compute the desired offset position for the handle.\n let rect = this.node.getBoundingClientRect();\n let xPos = event.clientX - rect.left - this._pressData.deltaX;\n let yPos = event.clientY - rect.top - this._pressData.deltaY;\n\n // Set the handle as close to the desired position as possible.\n let layout = this.layout as DockLayout;\n layout.moveHandle(this._pressData.handle, xPos, yPos);\n }\n\n /**\n * Handle the `'pointerup'` event for the dock panel.\n */\n private _evtPointerUp(event: PointerEvent): void {\n // Do nothing if the left mouse button is not released.\n if (event.button !== 0) {\n return;\n }\n\n // Stop the event when releasing a handle.\n event.preventDefault();\n event.stopPropagation();\n\n // Finalize the mouse release.\n this._releaseMouse();\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Release the mouse grab for the dock panel.\n */\n private _releaseMouse(): void {\n // Bail early if no drag is in progress.\n if (!this._pressData) {\n return;\n }\n\n // Clear the override cursor.\n this._pressData.override.dispose();\n this._pressData = null;\n\n // Remove the extra document listeners.\n this._document.removeEventListener('keydown', this, true);\n this._document.removeEventListener('pointerup', this, true);\n this._document.removeEventListener('pointermove', this, true);\n this._document.removeEventListener('contextmenu', this, true);\n }\n\n /**\n * Show the overlay indicator at the given client position.\n *\n * Returns the drop zone at the specified client position.\n *\n * #### Notes\n * If the position is not over a valid zone, the overlay is hidden.\n */\n private _showOverlay(clientX: number, clientY: number): Private.DropZone {\n // Find the dock target for the given client position.\n let { zone, target } = Private.findDropTarget(\n this,\n clientX,\n clientY,\n this._edges\n );\n\n // If the drop zone is invalid, hide the overlay and bail.\n if (zone === 'invalid') {\n this.overlay.hide(100);\n return zone;\n }\n\n // Setup the variables needed to compute the overlay geometry.\n let top: number;\n let left: number;\n let right: number;\n let bottom: number;\n let box = ElementExt.boxSizing(this.node); // TODO cache this?\n let rect = this.node.getBoundingClientRect();\n\n // Compute the overlay geometry based on the dock zone.\n switch (zone) {\n case 'root-all':\n top = box.paddingTop;\n left = box.paddingLeft;\n right = box.paddingRight;\n bottom = box.paddingBottom;\n break;\n case 'root-top':\n top = box.paddingTop;\n left = box.paddingLeft;\n right = box.paddingRight;\n bottom = rect.height * Private.GOLDEN_RATIO;\n break;\n case 'root-left':\n top = box.paddingTop;\n left = box.paddingLeft;\n right = rect.width * Private.GOLDEN_RATIO;\n bottom = box.paddingBottom;\n break;\n case 'root-right':\n top = box.paddingTop;\n left = rect.width * Private.GOLDEN_RATIO;\n right = box.paddingRight;\n bottom = box.paddingBottom;\n break;\n case 'root-bottom':\n top = rect.height * Private.GOLDEN_RATIO;\n left = box.paddingLeft;\n right = box.paddingRight;\n bottom = box.paddingBottom;\n break;\n case 'widget-all':\n top = target!.top;\n left = target!.left;\n right = target!.right;\n bottom = target!.bottom;\n break;\n case 'widget-top':\n top = target!.top;\n left = target!.left;\n right = target!.right;\n bottom = target!.bottom + target!.height / 2;\n break;\n case 'widget-left':\n top = target!.top;\n left = target!.left;\n right = target!.right + target!.width / 2;\n bottom = target!.bottom;\n break;\n case 'widget-right':\n top = target!.top;\n left = target!.left + target!.width / 2;\n right = target!.right;\n bottom = target!.bottom;\n break;\n case 'widget-bottom':\n top = target!.top + target!.height / 2;\n left = target!.left;\n right = target!.right;\n bottom = target!.bottom;\n break;\n case 'widget-tab': {\n const tabHeight = target!.tabBar.node.getBoundingClientRect().height;\n top = target!.top;\n left = target!.left;\n right = target!.right;\n bottom = target!.bottom + target!.height - tabHeight;\n break;\n }\n default:\n throw 'unreachable';\n }\n\n // Show the overlay with the computed geometry.\n this.overlay.show({ top, left, right, bottom });\n\n // Finally, return the computed drop zone.\n return zone;\n }\n\n /**\n * Create a new tab bar for use by the panel.\n */\n private _createTabBar(): TabBar {\n // Create the tab bar.\n let tabBar = this._renderer.createTabBar(this._document);\n\n // Set the generated tab bar property for the tab bar.\n Private.isGeneratedTabBarProperty.set(tabBar, true);\n\n // Hide the tab bar when in single document mode.\n if (this._mode === 'single-document') {\n tabBar.hide();\n }\n\n // Enforce necessary tab bar behavior.\n // TODO do we really want to enforce *all* of these?\n tabBar.tabsMovable = this._tabsMovable;\n tabBar.allowDeselect = false;\n tabBar.addButtonEnabled = this._addButtonEnabled;\n tabBar.removeBehavior = 'select-previous-tab';\n tabBar.insertBehavior = 'select-tab-if-needed';\n\n // Connect the signal handlers for the tab bar.\n tabBar.tabMoved.connect(this._onTabMoved, this);\n tabBar.currentChanged.connect(this._onCurrentChanged, this);\n tabBar.tabCloseRequested.connect(this._onTabCloseRequested, this);\n tabBar.tabDetachRequested.connect(this._onTabDetachRequested, this);\n tabBar.tabActivateRequested.connect(this._onTabActivateRequested, this);\n tabBar.addRequested.connect(this._onTabAddRequested, this);\n\n // Return the initialized tab bar.\n return tabBar;\n }\n\n /**\n * Create a new handle for use by the panel.\n */\n private _createHandle(): HTMLDivElement {\n return this._renderer.createHandle();\n }\n\n /**\n * Handle the `tabMoved` signal from a tab bar.\n */\n private _onTabMoved(): void {\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Handle the `currentChanged` signal from a tab bar.\n */\n private _onCurrentChanged(\n sender: TabBar,\n args: TabBar.ICurrentChangedArgs\n ): void {\n // Extract the previous and current title from the args.\n let { previousTitle, currentTitle } = args;\n\n // Hide the previous widget.\n if (previousTitle) {\n previousTitle.owner.hide();\n }\n\n // Show the current widget.\n if (currentTitle) {\n currentTitle.owner.show();\n }\n\n // Flush the message loop on IE and Edge to prevent flicker.\n if (Platform.IS_EDGE || Platform.IS_IE) {\n MessageLoop.flush();\n }\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Handle the `addRequested` signal from a tab bar.\n */\n private _onTabAddRequested(sender: TabBar): void {\n this._addRequested.emit(sender);\n }\n\n /**\n * Handle the `tabActivateRequested` signal from a tab bar.\n */\n private _onTabActivateRequested(\n sender: TabBar,\n args: TabBar.ITabActivateRequestedArgs\n ): void {\n args.title.owner.activate();\n }\n\n /**\n * Handle the `tabCloseRequested` signal from a tab bar.\n */\n private _onTabCloseRequested(\n sender: TabBar,\n args: TabBar.ITabCloseRequestedArgs\n ): void {\n args.title.owner.close();\n }\n\n /**\n * Handle the `tabDetachRequested` signal from a tab bar.\n */\n private _onTabDetachRequested(\n sender: TabBar,\n args: TabBar.ITabDetachRequestedArgs\n ): void {\n // Do nothing if a drag is already in progress.\n if (this._drag) {\n return;\n }\n\n // Release the tab bar's hold on the mouse.\n sender.releaseMouse();\n\n // Extract the data from the args.\n let { title, tab, clientX, clientY, offset } = args;\n\n // Setup the mime data for the drag operation.\n let mimeData = new MimeData();\n let factory = () => title.owner;\n mimeData.setData('application/vnd.lumino.widget-factory', factory);\n\n // Create the drag image for the drag operation.\n let dragImage = tab.cloneNode(true) as HTMLElement;\n if (offset) {\n dragImage.style.top = `-${offset.y}px`;\n dragImage.style.left = `-${offset.x}px`;\n }\n\n // Create the drag object to manage the drag-drop operation.\n this._drag = new Drag({\n document: this._document,\n mimeData,\n dragImage,\n proposedAction: 'move',\n supportedActions: 'move',\n source: this\n });\n\n // Hide the tab node in the original tab.\n tab.classList.add('lm-mod-hidden');\n let cleanup = () => {\n this._drag = null;\n tab.classList.remove('lm-mod-hidden');\n };\n\n // Start the drag operation and cleanup when done.\n this._drag.start(clientX, clientY).then(cleanup);\n }\n\n private _edges: DockPanel.IEdges;\n private _document: Document | ShadowRoot;\n private _mode: DockPanel.Mode;\n private _drag: Drag | null = null;\n private _renderer: DockPanel.IRenderer;\n private _tabsMovable: boolean = true;\n private _tabsConstrained: boolean = false;\n private _addButtonEnabled: boolean = false;\n private _pressData: Private.IPressData | null = null;\n private _layoutModified = new Signal(this);\n\n private _addRequested = new Signal>(this);\n}\n\n/**\n * The namespace for the `DockPanel` class statics.\n */\nexport namespace DockPanel {\n /**\n * An options object for creating a dock panel.\n */\n export interface IOptions {\n /**\n * The document to use with the dock panel.\n *\n * The default is the global `document` instance.\n */\n\n document?: Document | ShadowRoot;\n /**\n * The overlay to use with the dock panel.\n *\n * The default is a new `Overlay` instance.\n */\n overlay?: IOverlay;\n\n /**\n * The renderer to use for the dock panel.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n\n /**\n * The spacing between the items in the panel.\n *\n * The default is `4`.\n */\n spacing?: number;\n\n /**\n * The mode for the dock panel.\n *\n * The default is `'multiple-document'`.\n */\n mode?: DockPanel.Mode;\n\n /**\n * The sizes of the edge drop zones, in pixels.\n * If not given, default values will be used.\n */\n edges?: IEdges;\n\n /**\n * The method for hiding widgets.\n *\n * The default is `Widget.HiddenMode.Display`.\n */\n hiddenMode?: Widget.HiddenMode;\n\n /**\n * Allow tabs to be draggable / movable by user.\n *\n * The default is `'true'`.\n */\n tabsMovable?: boolean;\n\n /**\n * Constrain tabs to this dock panel\n *\n * The default is `'false'`.\n */\n tabsConstrained?: boolean;\n\n /**\n * Enable add buttons in each of the dock panel's tab bars.\n *\n * The default is `'false'`.\n */\n addButtonEnabled?: boolean;\n }\n\n /**\n * The sizes of the edge drop zones, in pixels.\n */\n export interface IEdges {\n /**\n * The size of the top edge drop zone.\n */\n top: number;\n\n /**\n * The size of the right edge drop zone.\n */\n right: number;\n\n /**\n * The size of the bottom edge drop zone.\n */\n bottom: number;\n\n /**\n * The size of the left edge drop zone.\n */\n left: number;\n }\n\n /**\n * A type alias for the supported dock panel modes.\n */\n export type Mode =\n | /**\n * The single document mode.\n *\n * In this mode, only a single widget is visible at a time, and that\n * widget fills the available layout space. No tab bars are visible.\n */\n 'single-document'\n\n /**\n * The multiple document mode.\n *\n * In this mode, multiple documents are displayed in separate tab\n * areas, and those areas can be individually resized by the user.\n */\n | 'multiple-document';\n\n /**\n * A type alias for a layout configuration object.\n */\n export type ILayoutConfig = DockLayout.ILayoutConfig;\n\n /**\n * A type alias for the supported insertion modes.\n */\n export type InsertMode = DockLayout.InsertMode;\n\n /**\n * A type alias for the add widget options.\n */\n export type IAddOptions = DockLayout.IAddOptions;\n\n /**\n * An object which holds the geometry for overlay positioning.\n */\n export interface IOverlayGeometry {\n /**\n * The distance between the overlay and parent top edges.\n */\n top: number;\n\n /**\n * The distance between the overlay and parent left edges.\n */\n left: number;\n\n /**\n * The distance between the overlay and parent right edges.\n */\n right: number;\n\n /**\n * The distance between the overlay and parent bottom edges.\n */\n bottom: number;\n }\n\n /**\n * An object which manages the overlay node for a dock panel.\n */\n export interface IOverlay {\n /**\n * The DOM node for the overlay.\n */\n readonly node: HTMLDivElement;\n\n /**\n * Show the overlay using the given overlay geometry.\n *\n * @param geo - The desired geometry for the overlay.\n *\n * #### Notes\n * The given geometry values assume the node will use absolute\n * positioning.\n *\n * This is called on every mouse move event during a drag in order\n * to update the position of the overlay. It should be efficient.\n */\n show(geo: IOverlayGeometry): void;\n\n /**\n * Hide the overlay node.\n *\n * @param delay - The delay (in ms) before hiding the overlay.\n * A delay value <= 0 should hide the overlay immediately.\n *\n * #### Notes\n * This is called whenever the overlay node should been hidden.\n */\n hide(delay: number): void;\n }\n\n /**\n * A concrete implementation of `IOverlay`.\n *\n * This is the default overlay implementation for a dock panel.\n */\n export class Overlay implements IOverlay {\n /**\n * Construct a new overlay.\n */\n constructor() {\n this.node = document.createElement('div');\n this.node.classList.add('lm-DockPanel-overlay');\n this.node.classList.add('lm-mod-hidden');\n this.node.style.position = 'absolute';\n this.node.style.contain = 'strict';\n }\n\n /**\n * The DOM node for the overlay.\n */\n readonly node: HTMLDivElement;\n\n /**\n * Show the overlay using the given overlay geometry.\n *\n * @param geo - The desired geometry for the overlay.\n */\n show(geo: IOverlayGeometry): void {\n // Update the position of the overlay.\n let style = this.node.style;\n style.top = `${geo.top}px`;\n style.left = `${geo.left}px`;\n style.right = `${geo.right}px`;\n style.bottom = `${geo.bottom}px`;\n\n // Clear any pending hide timer.\n clearTimeout(this._timer);\n this._timer = -1;\n\n // If the overlay is already visible, we're done.\n if (!this._hidden) {\n return;\n }\n\n // Clear the hidden flag.\n this._hidden = false;\n\n // Finally, show the overlay.\n this.node.classList.remove('lm-mod-hidden');\n }\n\n /**\n * Hide the overlay node.\n *\n * @param delay - The delay (in ms) before hiding the overlay.\n * A delay value <= 0 will hide the overlay immediately.\n */\n hide(delay: number): void {\n // Do nothing if the overlay is already hidden.\n if (this._hidden) {\n return;\n }\n\n // Hide immediately if the delay is <= 0.\n if (delay <= 0) {\n clearTimeout(this._timer);\n this._timer = -1;\n this._hidden = true;\n this.node.classList.add('lm-mod-hidden');\n return;\n }\n\n // Do nothing if a hide is already pending.\n if (this._timer !== -1) {\n return;\n }\n\n // Otherwise setup the hide timer.\n this._timer = window.setTimeout(() => {\n this._timer = -1;\n this._hidden = true;\n this.node.classList.add('lm-mod-hidden');\n }, delay);\n }\n\n private _timer = -1;\n private _hidden = true;\n }\n\n /**\n * A type alias for a dock panel renderer;\n */\n export type IRenderer = DockLayout.IRenderer;\n\n /**\n * The default implementation of `IRenderer`.\n */\n export class Renderer implements IRenderer {\n /**\n * Create a new tab bar for use with a dock panel.\n *\n * @returns A new tab bar for a dock panel.\n */\n createTabBar(document?: Document | ShadowRoot): TabBar {\n let bar = new TabBar({ document });\n bar.addClass('lm-DockPanel-tabBar');\n return bar;\n }\n\n /**\n * Create a new handle node for use with a dock panel.\n *\n * @returns A new handle node for a dock panel.\n */\n createHandle(): HTMLDivElement {\n let handle = document.createElement('div');\n handle.className = 'lm-DockPanel-handle';\n return handle;\n }\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * A fraction used for sizing root panels; ~= `1 / golden_ratio`.\n */\n export const GOLDEN_RATIO = 0.618;\n\n /**\n * The default sizes for the edge drop zones, in pixels.\n */\n export const DEFAULT_EDGES = {\n /**\n * The size of the top edge dock zone for the root panel, in pixels.\n * This is different from the others to distinguish between the top\n * tab bar and the top root zone.\n */\n top: 12,\n\n /**\n * The size of the edge dock zone for the root panel, in pixels.\n */\n right: 40,\n\n /**\n * The size of the edge dock zone for the root panel, in pixels.\n */\n bottom: 40,\n\n /**\n * The size of the edge dock zone for the root panel, in pixels.\n */\n left: 40\n };\n\n /**\n * A singleton `'layout-modified'` conflatable message.\n */\n export const LayoutModified = new ConflatableMessage('layout-modified');\n\n /**\n * An object which holds mouse press data.\n */\n export interface IPressData {\n /**\n * The handle which was pressed.\n */\n handle: HTMLDivElement;\n\n /**\n * The X offset of the press in handle coordinates.\n */\n deltaX: number;\n\n /**\n * The Y offset of the press in handle coordinates.\n */\n deltaY: number;\n\n /**\n * The disposable which will clear the override cursor.\n */\n override: IDisposable;\n }\n\n /**\n * A type alias for a drop zone.\n */\n export type DropZone =\n | /**\n * An invalid drop zone.\n */\n 'invalid'\n\n /**\n * The entirety of the root dock area.\n */\n | 'root-all'\n\n /**\n * The top portion of the root dock area.\n */\n | 'root-top'\n\n /**\n * The left portion of the root dock area.\n */\n | 'root-left'\n\n /**\n * The right portion of the root dock area.\n */\n | 'root-right'\n\n /**\n * The bottom portion of the root dock area.\n */\n | 'root-bottom'\n\n /**\n * The entirety of a tabbed widget area.\n */\n | 'widget-all'\n\n /**\n * The top portion of tabbed widget area.\n */\n | 'widget-top'\n\n /**\n * The left portion of tabbed widget area.\n */\n | 'widget-left'\n\n /**\n * The right portion of tabbed widget area.\n */\n | 'widget-right'\n\n /**\n * The bottom portion of tabbed widget area.\n */\n | 'widget-bottom'\n\n /**\n * The the bar of a tabbed widget area.\n */\n | 'widget-tab';\n\n /**\n * An object which holds the drop target zone and widget.\n */\n export interface IDropTarget {\n /**\n * The semantic zone for the mouse position.\n */\n zone: DropZone;\n\n /**\n * The tab area geometry for the drop zone, or `null`.\n */\n target: DockLayout.ITabAreaGeometry | null;\n }\n\n /**\n * An attached property used to track generated tab bars.\n */\n export const isGeneratedTabBarProperty = new AttachedProperty<\n Widget,\n boolean\n >({\n name: 'isGeneratedTabBar',\n create: () => false\n });\n\n /**\n * Create a single document config for the widgets in a dock panel.\n */\n export function createSingleDocumentConfig(\n panel: DockPanel\n ): DockPanel.ILayoutConfig {\n // Return an empty config if the panel is empty.\n if (panel.isEmpty) {\n return { main: null };\n }\n\n // Get a flat array of the widgets in the panel.\n let widgets = Array.from(panel.widgets());\n\n // Get the first selected widget in the panel.\n let selected = panel.selectedWidgets().next().value;\n\n // Compute the current index for the new config.\n let currentIndex = selected ? widgets.indexOf(selected) : -1;\n\n // Return the single document config.\n return { main: { type: 'tab-area', widgets, currentIndex } };\n }\n\n /**\n * Find the drop target at the given client position.\n */\n export function findDropTarget(\n panel: DockPanel,\n clientX: number,\n clientY: number,\n edges: DockPanel.IEdges\n ): IDropTarget {\n // Bail if the mouse is not over the dock panel.\n if (!ElementExt.hitTest(panel.node, clientX, clientY)) {\n return { zone: 'invalid', target: null };\n }\n\n // Look up the layout for the panel.\n let layout = panel.layout as DockLayout;\n\n // If the layout is empty, indicate the entire root drop zone.\n if (layout.isEmpty) {\n return { zone: 'root-all', target: null };\n }\n\n // Test the edge zones when in multiple document mode.\n if (panel.mode === 'multiple-document') {\n // Get the client rect for the dock panel.\n let panelRect = panel.node.getBoundingClientRect();\n\n // Compute the distance to each edge of the panel.\n let pl = clientX - panelRect.left + 1;\n let pt = clientY - panelRect.top + 1;\n let pr = panelRect.right - clientX;\n let pb = panelRect.bottom - clientY;\n\n // Find the minimum distance to an edge.\n let pd = Math.min(pt, pr, pb, pl);\n\n // Return a root zone if the mouse is within an edge.\n switch (pd) {\n case pt:\n if (pt < edges.top) {\n return { zone: 'root-top', target: null };\n }\n break;\n case pr:\n if (pr < edges.right) {\n return { zone: 'root-right', target: null };\n }\n break;\n case pb:\n if (pb < edges.bottom) {\n return { zone: 'root-bottom', target: null };\n }\n break;\n case pl:\n if (pl < edges.left) {\n return { zone: 'root-left', target: null };\n }\n break;\n default:\n throw 'unreachable';\n }\n }\n\n // Hit test the dock layout at the given client position.\n let target = layout.hitTestTabAreas(clientX, clientY);\n\n // Bail if no target area was found.\n if (!target) {\n return { zone: 'invalid', target: null };\n }\n\n // Return the whole tab area when in single document mode.\n if (panel.mode === 'single-document') {\n return { zone: 'widget-all', target };\n }\n\n // Compute the distance to each edge of the tab area.\n let al = target.x - target.left + 1;\n let at = target.y - target.top + 1;\n let ar = target.left + target.width - target.x;\n let ab = target.top + target.height - target.y;\n\n const tabHeight = target.tabBar.node.getBoundingClientRect().height;\n if (at < tabHeight) {\n return { zone: 'widget-tab', target };\n }\n\n // Get the X and Y edge sizes for the area.\n let rx = Math.round(target.width / 3);\n let ry = Math.round(target.height / 3);\n\n // If the mouse is not within an edge, indicate the entire area.\n if (al > rx && ar > rx && at > ry && ab > ry) {\n return { zone: 'widget-all', target };\n }\n\n // Scale the distances by the slenderness ratio.\n al /= rx;\n at /= ry;\n ar /= rx;\n ab /= ry;\n\n // Find the minimum distance to the area edge.\n let ad = Math.min(al, at, ar, ab);\n\n // Find the widget zone for the area edge.\n let zone: DropZone;\n switch (ad) {\n case al:\n zone = 'widget-left';\n break;\n case at:\n zone = 'widget-top';\n break;\n case ar:\n zone = 'widget-right';\n break;\n case ab:\n zone = 'widget-bottom';\n break;\n default:\n throw 'unreachable';\n }\n\n // Return the final drop target.\n return { zone, target };\n }\n\n /**\n * Get the drop reference widget for a tab bar.\n */\n export function getDropRef(tabBar: TabBar): Widget | null {\n if (tabBar.titles.length === 0) {\n return null;\n }\n if (tabBar.currentTitle) {\n return tabBar.currentTitle.owner;\n }\n return tabBar.titles[tabBar.titles.length - 1].owner;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt, find, max } from '@lumino/algorithm';\n\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { Widget } from './widget';\n\n/**\n * A class which tracks focus among a set of widgets.\n *\n * This class is useful when code needs to keep track of the most\n * recently focused widget(s) among a set of related widgets.\n */\nexport class FocusTracker implements IDisposable {\n /**\n * Dispose of the resources held by the tracker.\n */\n dispose(): void {\n // Do nothing if the tracker is already disposed.\n if (this._counter < 0) {\n return;\n }\n\n // Mark the tracker as disposed.\n this._counter = -1;\n\n // Clear the connections for the tracker.\n Signal.clearData(this);\n\n // Remove all event listeners.\n for (const widget of this._widgets) {\n widget.node.removeEventListener('focus', this, true);\n widget.node.removeEventListener('blur', this, true);\n }\n\n // Clear the internal data structures.\n this._activeWidget = null;\n this._currentWidget = null;\n this._nodes.clear();\n this._numbers.clear();\n this._widgets.length = 0;\n }\n\n /**\n * A signal emitted when the current widget has changed.\n */\n get currentChanged(): ISignal> {\n return this._currentChanged;\n }\n\n /**\n * A signal emitted when the active widget has changed.\n */\n get activeChanged(): ISignal> {\n return this._activeChanged;\n }\n\n /**\n * A flag indicating whether the tracker is disposed.\n */\n get isDisposed(): boolean {\n return this._counter < 0;\n }\n\n /**\n * The current widget in the tracker.\n *\n * #### Notes\n * The current widget is the widget among the tracked widgets which\n * has the *descendant node* which has most recently been focused.\n *\n * The current widget will not be updated if the node loses focus. It\n * will only be updated when a different tracked widget gains focus.\n *\n * If the current widget is removed from the tracker, the previous\n * current widget will be restored.\n *\n * This behavior is intended to follow a user's conceptual model of\n * a semantically \"current\" widget, where the \"last thing of type X\"\n * to be interacted with is the \"current instance of X\", regardless\n * of whether that instance still has focus.\n */\n get currentWidget(): T | null {\n return this._currentWidget;\n }\n\n /**\n * The active widget in the tracker.\n *\n * #### Notes\n * The active widget is the widget among the tracked widgets which\n * has the *descendant node* which is currently focused.\n */\n get activeWidget(): T | null {\n return this._activeWidget;\n }\n\n /**\n * A read only array of the widgets being tracked.\n */\n get widgets(): ReadonlyArray {\n return this._widgets;\n }\n\n /**\n * Get the focus number for a particular widget in the tracker.\n *\n * @param widget - The widget of interest.\n *\n * @returns The focus number for the given widget, or `-1` if the\n * widget has not had focus since being added to the tracker, or\n * is not contained by the tracker.\n *\n * #### Notes\n * The focus number indicates the relative order in which the widgets\n * have gained focus. A widget with a larger number has gained focus\n * more recently than a widget with a smaller number.\n *\n * The `currentWidget` will always have the largest focus number.\n *\n * All widgets start with a focus number of `-1`, which indicates that\n * the widget has not been focused since being added to the tracker.\n */\n focusNumber(widget: T): number {\n let n = this._numbers.get(widget);\n return n === undefined ? -1 : n;\n }\n\n /**\n * Test whether the focus tracker contains a given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns `true` if the widget is tracked, `false` otherwise.\n */\n has(widget: T): boolean {\n return this._numbers.has(widget);\n }\n\n /**\n * Add a widget to the focus tracker.\n *\n * @param widget - The widget of interest.\n *\n * #### Notes\n * A widget will be automatically removed from the tracker if it\n * is disposed after being added.\n *\n * If the widget is already tracked, this is a no-op.\n */\n add(widget: T): void {\n // Do nothing if the widget is already tracked.\n if (this._numbers.has(widget)) {\n return;\n }\n\n // Test whether the widget has focus.\n let focused = widget.node.contains(document.activeElement);\n\n // Set up the initial focus number.\n let n = focused ? this._counter++ : -1;\n\n // Add the widget to the internal data structures.\n this._widgets.push(widget);\n this._numbers.set(widget, n);\n this._nodes.set(widget.node, widget);\n\n // Set up the event listeners. The capturing phase must be used\n // since the 'focus' and 'blur' events don't bubble and Firefox\n // doesn't support the 'focusin' or 'focusout' events.\n widget.node.addEventListener('focus', this, true);\n widget.node.addEventListener('blur', this, true);\n\n // Connect the disposed signal handler.\n widget.disposed.connect(this._onWidgetDisposed, this);\n\n // Set the current and active widgets if needed.\n if (focused) {\n this._setWidgets(widget, widget);\n }\n }\n\n /**\n * Remove a widget from the focus tracker.\n *\n * #### Notes\n * If the widget is the `currentWidget`, the previous current widget\n * will become the new `currentWidget`.\n *\n * A widget will be automatically removed from the tracker if it\n * is disposed after being added.\n *\n * If the widget is not tracked, this is a no-op.\n */\n remove(widget: T): void {\n // Bail early if the widget is not tracked.\n if (!this._numbers.has(widget)) {\n return;\n }\n\n // Disconnect the disposed signal handler.\n widget.disposed.disconnect(this._onWidgetDisposed, this);\n\n // Remove the event listeners.\n widget.node.removeEventListener('focus', this, true);\n widget.node.removeEventListener('blur', this, true);\n\n // Remove the widget from the internal data structures.\n ArrayExt.removeFirstOf(this._widgets, widget);\n this._nodes.delete(widget.node);\n this._numbers.delete(widget);\n\n // Bail early if the widget is not the current widget.\n if (this._currentWidget !== widget) {\n return;\n }\n\n // Filter the widgets for those which have had focus.\n let valid = this._widgets.filter(w => this._numbers.get(w) !== -1);\n\n // Get the valid widget with the max focus number.\n let previous =\n max(valid, (first, second) => {\n let a = this._numbers.get(first)!;\n let b = this._numbers.get(second)!;\n return a - b;\n }) || null;\n\n // Set the current and active widgets.\n this._setWidgets(previous, null);\n }\n\n /**\n * Handle the DOM events for the focus tracker.\n *\n * @param event - The DOM event sent to the panel.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the tracked nodes. It should\n * not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'focus':\n this._evtFocus(event as FocusEvent);\n break;\n case 'blur':\n this._evtBlur(event as FocusEvent);\n break;\n }\n }\n\n /**\n * Set the current and active widgets for the tracker.\n */\n private _setWidgets(current: T | null, active: T | null): void {\n // Swap the current widget.\n let oldCurrent = this._currentWidget;\n this._currentWidget = current;\n\n // Swap the active widget.\n let oldActive = this._activeWidget;\n this._activeWidget = active;\n\n // Emit the `currentChanged` signal if needed.\n if (oldCurrent !== current) {\n this._currentChanged.emit({ oldValue: oldCurrent, newValue: current });\n }\n\n // Emit the `activeChanged` signal if needed.\n if (oldActive !== active) {\n this._activeChanged.emit({ oldValue: oldActive, newValue: active });\n }\n }\n\n /**\n * Handle the `'focus'` event for a tracked widget.\n */\n private _evtFocus(event: FocusEvent): void {\n // Find the widget which gained focus, which is known to exist.\n let widget = this._nodes.get(event.currentTarget as HTMLElement)!;\n\n // Update the focus number if necessary.\n if (widget !== this._currentWidget) {\n this._numbers.set(widget, this._counter++);\n }\n\n // Set the current and active widgets.\n this._setWidgets(widget, widget);\n }\n\n /**\n * Handle the `'blur'` event for a tracked widget.\n */\n private _evtBlur(event: FocusEvent): void {\n // Find the widget which lost focus, which is known to exist.\n let widget = this._nodes.get(event.currentTarget as HTMLElement)!;\n\n // Get the node which being focused after this blur.\n let focusTarget = event.relatedTarget as HTMLElement;\n\n // If no other node is being focused, clear the active widget.\n if (!focusTarget) {\n this._setWidgets(this._currentWidget, null);\n return;\n }\n\n // Bail if the focus widget is not changing.\n if (widget.node.contains(focusTarget)) {\n return;\n }\n\n // If no tracked widget is being focused, clear the active widget.\n if (!find(this._widgets, w => w.node.contains(focusTarget))) {\n this._setWidgets(this._currentWidget, null);\n return;\n }\n }\n\n /**\n * Handle the `disposed` signal for a tracked widget.\n */\n private _onWidgetDisposed(sender: T): void {\n this.remove(sender);\n }\n\n private _counter = 0;\n private _widgets: T[] = [];\n private _activeWidget: T | null = null;\n private _currentWidget: T | null = null;\n private _numbers = new Map();\n private _nodes = new Map();\n private _activeChanged = new Signal>(this);\n private _currentChanged = new Signal>(\n this\n );\n}\n\n/**\n * The namespace for the `FocusTracker` class statics.\n */\nexport namespace FocusTracker {\n /**\n * An arguments object for the changed signals.\n */\n export interface IChangedArgs {\n /**\n * The old value for the widget.\n */\n oldValue: T | null;\n\n /**\n * The new value for the widget.\n */\n newValue: T | null;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { BoxEngine, BoxSizer } from './boxengine';\n\nimport { Layout, LayoutItem } from './layout';\n\nimport { Widget } from './widget';\n\n/**\n * A layout which arranges its widgets in a grid.\n */\nexport class GridLayout extends Layout {\n /**\n * Construct a new grid layout.\n *\n * @param options - The options for initializing the layout.\n */\n constructor(options: GridLayout.IOptions = {}) {\n super(options);\n if (options.rowCount !== undefined) {\n Private.reallocSizers(this._rowSizers, options.rowCount);\n }\n if (options.columnCount !== undefined) {\n Private.reallocSizers(this._columnSizers, options.columnCount);\n }\n if (options.rowSpacing !== undefined) {\n this._rowSpacing = Private.clampValue(options.rowSpacing);\n }\n if (options.columnSpacing !== undefined) {\n this._columnSpacing = Private.clampValue(options.columnSpacing);\n }\n }\n\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n // Dispose of the widgets and layout items.\n for (const item of this._items) {\n let widget = item.widget;\n item.dispose();\n widget.dispose();\n }\n\n // Clear the layout state.\n this._box = null;\n this._items.length = 0;\n this._rowStarts.length = 0;\n this._rowSizers.length = 0;\n this._columnStarts.length = 0;\n this._columnSizers.length = 0;\n\n // Dispose of the rest of the layout.\n super.dispose();\n }\n\n /**\n * Get the number of rows in the layout.\n */\n get rowCount(): number {\n return this._rowSizers.length;\n }\n\n /**\n * Set the number of rows in the layout.\n *\n * #### Notes\n * The minimum row count is `1`.\n */\n set rowCount(value: number) {\n // Do nothing if the row count does not change.\n if (value === this.rowCount) {\n return;\n }\n\n // Reallocate the row sizers.\n Private.reallocSizers(this._rowSizers, value);\n\n // Schedule a fit of the parent.\n if (this.parent) {\n this.parent.fit();\n }\n }\n\n /**\n * Get the number of columns in the layout.\n */\n get columnCount(): number {\n return this._columnSizers.length;\n }\n\n /**\n * Set the number of columns in the layout.\n *\n * #### Notes\n * The minimum column count is `1`.\n */\n set columnCount(value: number) {\n // Do nothing if the column count does not change.\n if (value === this.columnCount) {\n return;\n }\n\n // Reallocate the column sizers.\n Private.reallocSizers(this._columnSizers, value);\n\n // Schedule a fit of the parent.\n if (this.parent) {\n this.parent.fit();\n }\n }\n\n /**\n * Get the row spacing for the layout.\n */\n get rowSpacing(): number {\n return this._rowSpacing;\n }\n\n /**\n * Set the row spacing for the layout.\n */\n set rowSpacing(value: number) {\n // Clamp the spacing to the allowed range.\n value = Private.clampValue(value);\n\n // Bail if the spacing does not change\n if (this._rowSpacing === value) {\n return;\n }\n\n // Update the internal spacing.\n this._rowSpacing = value;\n\n // Schedule a fit of the parent.\n if (this.parent) {\n this.parent.fit();\n }\n }\n\n /**\n * Get the column spacing for the layout.\n */\n get columnSpacing(): number {\n return this._columnSpacing;\n }\n\n /**\n * Set the col spacing for the layout.\n */\n set columnSpacing(value: number) {\n // Clamp the spacing to the allowed range.\n value = Private.clampValue(value);\n\n // Bail if the spacing does not change\n if (this._columnSpacing === value) {\n return;\n }\n\n // Update the internal spacing.\n this._columnSpacing = value;\n\n // Schedule a fit of the parent.\n if (this.parent) {\n this.parent.fit();\n }\n }\n\n /**\n * Get the stretch factor for a specific row.\n *\n * @param index - The row index of interest.\n *\n * @returns The stretch factor for the row.\n *\n * #### Notes\n * This returns `-1` if the index is out of range.\n */\n rowStretch(index: number): number {\n let sizer = this._rowSizers[index];\n return sizer ? sizer.stretch : -1;\n }\n\n /**\n * Set the stretch factor for a specific row.\n *\n * @param index - The row index of interest.\n *\n * @param value - The stretch factor for the row.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n setRowStretch(index: number, value: number): void {\n // Look up the row sizer.\n let sizer = this._rowSizers[index];\n\n // Bail if the index is out of range.\n if (!sizer) {\n return;\n }\n\n // Clamp the value to the allowed range.\n value = Private.clampValue(value);\n\n // Bail if the stretch does not change.\n if (sizer.stretch === value) {\n return;\n }\n\n // Update the sizer stretch.\n sizer.stretch = value;\n\n // Schedule an update of the parent.\n if (this.parent) {\n this.parent.update();\n }\n }\n\n /**\n * Get the stretch factor for a specific column.\n *\n * @param index - The column index of interest.\n *\n * @returns The stretch factor for the column.\n *\n * #### Notes\n * This returns `-1` if the index is out of range.\n */\n columnStretch(index: number): number {\n let sizer = this._columnSizers[index];\n return sizer ? sizer.stretch : -1;\n }\n\n /**\n * Set the stretch factor for a specific column.\n *\n * @param index - The column index of interest.\n *\n * @param value - The stretch factor for the column.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n setColumnStretch(index: number, value: number): void {\n // Look up the column sizer.\n let sizer = this._columnSizers[index];\n\n // Bail if the index is out of range.\n if (!sizer) {\n return;\n }\n\n // Clamp the value to the allowed range.\n value = Private.clampValue(value);\n\n // Bail if the stretch does not change.\n if (sizer.stretch === value) {\n return;\n }\n\n // Update the sizer stretch.\n sizer.stretch = value;\n\n // Schedule an update of the parent.\n if (this.parent) {\n this.parent.update();\n }\n }\n\n /**\n * Create an iterator over the widgets in the layout.\n *\n * @returns A new iterator over the widgets in the layout.\n */\n *[Symbol.iterator](): IterableIterator {\n for (const item of this._items) {\n yield item.widget;\n }\n }\n\n /**\n * Add a widget to the grid layout.\n *\n * @param widget - The widget to add to the layout.\n *\n * #### Notes\n * If the widget is already contained in the layout, this is no-op.\n */\n addWidget(widget: Widget): void {\n // Look up the index for the widget.\n let i = ArrayExt.findFirstIndex(this._items, it => it.widget === widget);\n\n // Bail if the widget is already in the layout.\n if (i !== -1) {\n return;\n }\n\n // Add the widget to the layout.\n this._items.push(new LayoutItem(widget));\n\n // Attach the widget to the parent.\n if (this.parent) {\n this.attachWidget(widget);\n }\n }\n\n /**\n * Remove a widget from the grid layout.\n *\n * @param widget - The widget to remove from the layout.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method does *not* modify the widget's `parent`.\n */\n removeWidget(widget: Widget): void {\n // Look up the index for the widget.\n let i = ArrayExt.findFirstIndex(this._items, it => it.widget === widget);\n\n // Bail if the widget is not in the layout.\n if (i === -1) {\n return;\n }\n\n // Remove the widget from the layout.\n let item = ArrayExt.removeAt(this._items, i)!;\n\n // Detach the widget from the parent.\n if (this.parent) {\n this.detachWidget(widget);\n }\n\n // Dispose the layout item.\n item.dispose();\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n super.init();\n for (const widget of this) {\n this.attachWidget(widget);\n }\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param widget - The widget to attach to the parent.\n */\n protected attachWidget(widget: Widget): void {\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget's node to the parent.\n this.parent!.node.appendChild(widget.node);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param widget - The widget to detach from the parent.\n */\n protected detachWidget(widget: Widget): void {\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n */\n protected onBeforeShow(msg: Message): void {\n super.onBeforeShow(msg);\n this.parent!.update();\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n super.onBeforeAttach(msg);\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n if (this.parent!.isVisible) {\n this._update(msg.width, msg.height);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.parent!.isVisible) {\n this._update(-1, -1);\n }\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n */\n protected onFitRequest(msg: Message): void {\n if (this.parent!.isAttached) {\n this._fit();\n }\n }\n\n /**\n * Fit the layout to the total size required by the widgets.\n */\n private _fit(): void {\n // Reset the min sizes of the sizers.\n for (let i = 0, n = this.rowCount; i < n; ++i) {\n this._rowSizers[i].minSize = 0;\n }\n for (let i = 0, n = this.columnCount; i < n; ++i) {\n this._columnSizers[i].minSize = 0;\n }\n\n // Filter for the visible layout items.\n let items = this._items.filter(it => !it.isHidden);\n\n // Fit the layout items.\n for (let i = 0, n = items.length; i < n; ++i) {\n items[i].fit();\n }\n\n // Get the max row and column index.\n let maxRow = this.rowCount - 1;\n let maxCol = this.columnCount - 1;\n\n // Sort the items by row span.\n items.sort(Private.rowSpanCmp);\n\n // Update the min sizes of the row sizers.\n for (let i = 0, n = items.length; i < n; ++i) {\n // Fetch the item.\n let item = items[i];\n\n // Get the row bounds for the item.\n let config = GridLayout.getCellConfig(item.widget);\n let r1 = Math.min(config.row, maxRow);\n let r2 = Math.min(config.row + config.rowSpan - 1, maxRow);\n\n // Distribute the minimum height to the sizers as needed.\n Private.distributeMin(this._rowSizers, r1, r2, item.minHeight);\n }\n\n // Sort the items by column span.\n items.sort(Private.columnSpanCmp);\n\n // Update the min sizes of the column sizers.\n for (let i = 0, n = items.length; i < n; ++i) {\n // Fetch the item.\n let item = items[i];\n\n // Get the column bounds for the item.\n let config = GridLayout.getCellConfig(item.widget);\n let c1 = Math.min(config.column, maxCol);\n let c2 = Math.min(config.column + config.columnSpan - 1, maxCol);\n\n // Distribute the minimum width to the sizers as needed.\n Private.distributeMin(this._columnSizers, c1, c2, item.minWidth);\n }\n\n // If no size constraint is needed, just update the parent.\n if (this.fitPolicy === 'set-no-constraint') {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n return;\n }\n\n // Set up the computed min size.\n let minH = maxRow * this._rowSpacing;\n let minW = maxCol * this._columnSpacing;\n\n // Add the sizer minimums to the computed min size.\n for (let i = 0, n = this.rowCount; i < n; ++i) {\n minH += this._rowSizers[i].minSize;\n }\n for (let i = 0, n = this.columnCount; i < n; ++i) {\n minW += this._columnSizers[i].minSize;\n }\n\n // Update the box sizing and add it to the computed min size.\n let box = (this._box = ElementExt.boxSizing(this.parent!.node));\n minW += box.horizontalSum;\n minH += box.verticalSum;\n\n // Update the parent's min size constraints.\n let style = this.parent!.node.style;\n style.minWidth = `${minW}px`;\n style.minHeight = `${minH}px`;\n\n // Set the dirty flag to ensure only a single update occurs.\n this._dirty = true;\n\n // Notify the ancestor that it should fit immediately. This may\n // cause a resize of the parent, fulfilling the required update.\n if (this.parent!.parent) {\n MessageLoop.sendMessage(this.parent!.parent!, Widget.Msg.FitRequest);\n }\n\n // If the dirty flag is still set, the parent was not resized.\n // Trigger the required update on the parent widget immediately.\n if (this._dirty) {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n }\n }\n\n /**\n * Update the layout position and size of the widgets.\n *\n * The parent offset dimensions should be `-1` if unknown.\n */\n private _update(offsetWidth: number, offsetHeight: number): void {\n // Clear the dirty flag to indicate the update occurred.\n this._dirty = false;\n\n // Measure the parent if the offset dimensions are unknown.\n if (offsetWidth < 0) {\n offsetWidth = this.parent!.node.offsetWidth;\n }\n if (offsetHeight < 0) {\n offsetHeight = this.parent!.node.offsetHeight;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent!.node);\n }\n\n // Compute the layout area adjusted for border and padding.\n let top = this._box.paddingTop;\n let left = this._box.paddingLeft;\n let width = offsetWidth - this._box.horizontalSum;\n let height = offsetHeight - this._box.verticalSum;\n\n // Get the max row and column index.\n let maxRow = this.rowCount - 1;\n let maxCol = this.columnCount - 1;\n\n // Compute the total fixed row and column space.\n let fixedRowSpace = maxRow * this._rowSpacing;\n let fixedColSpace = maxCol * this._columnSpacing;\n\n // Distribute the available space to the box sizers.\n BoxEngine.calc(this._rowSizers, Math.max(0, height - fixedRowSpace));\n BoxEngine.calc(this._columnSizers, Math.max(0, width - fixedColSpace));\n\n // Update the row start positions.\n for (let i = 0, pos = top, n = this.rowCount; i < n; ++i) {\n this._rowStarts[i] = pos;\n pos += this._rowSizers[i].size + this._rowSpacing;\n }\n\n // Update the column start positions.\n for (let i = 0, pos = left, n = this.columnCount; i < n; ++i) {\n this._columnStarts[i] = pos;\n pos += this._columnSizers[i].size + this._columnSpacing;\n }\n\n // Update the geometry of the layout items.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item.\n let item = this._items[i];\n\n // Ignore hidden items.\n if (item.isHidden) {\n continue;\n }\n\n // Fetch the cell bounds for the widget.\n let config = GridLayout.getCellConfig(item.widget);\n let r1 = Math.min(config.row, maxRow);\n let c1 = Math.min(config.column, maxCol);\n let r2 = Math.min(config.row + config.rowSpan - 1, maxRow);\n let c2 = Math.min(config.column + config.columnSpan - 1, maxCol);\n\n // Compute the cell geometry.\n let x = this._columnStarts[c1];\n let y = this._rowStarts[r1];\n let w = this._columnStarts[c2] + this._columnSizers[c2].size - x;\n let h = this._rowStarts[r2] + this._rowSizers[r2].size - y;\n\n // Update the geometry of the layout item.\n item.update(x, y, w, h);\n }\n }\n\n private _dirty = false;\n private _rowSpacing = 4;\n private _columnSpacing = 4;\n private _items: LayoutItem[] = [];\n private _rowStarts: number[] = [];\n private _columnStarts: number[] = [];\n private _rowSizers: BoxSizer[] = [new BoxSizer()];\n private _columnSizers: BoxSizer[] = [new BoxSizer()];\n private _box: ElementExt.IBoxSizing | null = null;\n}\n\n/**\n * The namespace for the `GridLayout` class statics.\n */\nexport namespace GridLayout {\n /**\n * An options object for initializing a grid layout.\n */\n export interface IOptions extends Layout.IOptions {\n /**\n * The initial row count for the layout.\n *\n * The default is `1`.\n */\n rowCount?: number;\n\n /**\n * The initial column count for the layout.\n *\n * The default is `1`.\n */\n columnCount?: number;\n\n /**\n * The spacing between rows in the layout.\n *\n * The default is `4`.\n */\n rowSpacing?: number;\n\n /**\n * The spacing between columns in the layout.\n *\n * The default is `4`.\n */\n columnSpacing?: number;\n }\n\n /**\n * An object which holds the cell configuration for a widget.\n */\n export interface ICellConfig {\n /**\n * The row index for the widget.\n */\n readonly row: number;\n\n /**\n * The column index for the widget.\n */\n readonly column: number;\n\n /**\n * The row span for the widget.\n */\n readonly rowSpan: number;\n\n /**\n * The column span for the widget.\n */\n readonly columnSpan: number;\n }\n\n /**\n * Get the cell config for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The cell config for the widget.\n */\n export function getCellConfig(widget: Widget): ICellConfig {\n return Private.cellConfigProperty.get(widget);\n }\n\n /**\n * Set the cell config for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the cell config.\n */\n export function setCellConfig(\n widget: Widget,\n value: Partial\n ): void {\n Private.cellConfigProperty.set(widget, Private.normalizeConfig(value));\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The property descriptor for the widget cell config.\n */\n export const cellConfigProperty = new AttachedProperty<\n Widget,\n GridLayout.ICellConfig\n >({\n name: 'cellConfig',\n create: () => ({ row: 0, column: 0, rowSpan: 1, columnSpan: 1 }),\n changed: onChildCellConfigChanged\n });\n\n /**\n * Normalize a partial cell config object.\n */\n export function normalizeConfig(\n config: Partial\n ): GridLayout.ICellConfig {\n let row = Math.max(0, Math.floor(config.row || 0));\n let column = Math.max(0, Math.floor(config.column || 0));\n let rowSpan = Math.max(1, Math.floor(config.rowSpan || 0));\n let columnSpan = Math.max(1, Math.floor(config.columnSpan || 0));\n return { row, column, rowSpan, columnSpan };\n }\n\n /**\n * Clamp a value to an integer >= 0.\n */\n export function clampValue(value: number): number {\n return Math.max(0, Math.floor(value));\n }\n\n /**\n * A sort comparison function for row spans.\n */\n export function rowSpanCmp(a: LayoutItem, b: LayoutItem): number {\n let c1 = cellConfigProperty.get(a.widget);\n let c2 = cellConfigProperty.get(b.widget);\n return c1.rowSpan - c2.rowSpan;\n }\n\n /**\n * A sort comparison function for column spans.\n */\n export function columnSpanCmp(a: LayoutItem, b: LayoutItem): number {\n let c1 = cellConfigProperty.get(a.widget);\n let c2 = cellConfigProperty.get(b.widget);\n return c1.columnSpan - c2.columnSpan;\n }\n\n /**\n * Reallocate the box sizers for the given grid dimensions.\n */\n export function reallocSizers(sizers: BoxSizer[], count: number): void {\n // Coerce the count to the valid range.\n count = Math.max(1, Math.floor(count));\n\n // Add the missing sizers.\n while (sizers.length < count) {\n sizers.push(new BoxSizer());\n }\n\n // Remove the extra sizers.\n if (sizers.length > count) {\n sizers.length = count;\n }\n }\n\n /**\n * Distribute a min size constraint across a range of sizers.\n */\n export function distributeMin(\n sizers: BoxSizer[],\n i1: number,\n i2: number,\n minSize: number\n ): void {\n // Sanity check the indices.\n if (i2 < i1) {\n return;\n }\n\n // Handle the simple case of no cell span.\n if (i1 === i2) {\n let sizer = sizers[i1];\n sizer.minSize = Math.max(sizer.minSize, minSize);\n return;\n }\n\n // Compute the total current min size of the span.\n let totalMin = 0;\n for (let i = i1; i <= i2; ++i) {\n totalMin += sizers[i].minSize;\n }\n\n // Do nothing if the total is greater than the required.\n if (totalMin >= minSize) {\n return;\n }\n\n // Compute the portion of the space to allocate to each sizer.\n let portion = (minSize - totalMin) / (i2 - i1 + 1);\n\n // Add the portion to each sizer.\n for (let i = i1; i <= i2; ++i) {\n sizers[i].minSize += portion;\n }\n }\n\n /**\n * The change handler for the child cell config property.\n */\n function onChildCellConfigChanged(child: Widget): void {\n if (child.parent && child.parent.layout instanceof GridLayout) {\n child.parent.fit();\n }\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { getKeyboardLayout } from '@lumino/keyboard';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { CommandRegistry } from '@lumino/commands';\n\nimport {\n ElementARIAAttrs,\n ElementDataset,\n h,\n VirtualDOM,\n VirtualElement\n} from '@lumino/virtualdom';\n\nimport { Menu } from './menu';\n\nimport { Title } from './title';\n\nimport { Widget } from './widget';\n\n/**\n * A widget which displays menus as a canonical menu bar.\n */\nexport class MenuBar extends Widget {\n /**\n * Construct a new menu bar.\n *\n * @param options - The options for initializing the menu bar.\n */\n constructor(options: MenuBar.IOptions = {}) {\n super({ node: Private.createNode() });\n this.addClass('lm-MenuBar');\n this.setFlag(Widget.Flag.DisallowLayout);\n this.renderer = options.renderer || MenuBar.defaultRenderer;\n this._forceItemsPosition = options.forceItemsPosition || {\n forceX: true,\n forceY: true\n };\n this._overflowMenuOptions = options.overflowMenuOptions || {\n isVisible: true\n };\n }\n\n /**\n * Dispose of the resources held by the widget.\n */\n dispose(): void {\n this._closeChildMenu();\n this._menus.length = 0;\n super.dispose();\n }\n\n /**\n * The renderer used by the menu bar.\n */\n readonly renderer: MenuBar.IRenderer;\n\n /**\n * The child menu of the menu bar.\n *\n * #### Notes\n * This will be `null` if the menu bar does not have an open menu.\n */\n get childMenu(): Menu | null {\n return this._childMenu;\n }\n\n /**\n * The overflow index of the menu bar.\n */\n get overflowIndex(): number {\n return this._overflowIndex;\n }\n\n /**\n * The overflow menu of the menu bar.\n */\n get overflowMenu(): Menu | null {\n return this._overflowMenu;\n }\n\n /**\n * Get the menu bar content node.\n *\n * #### Notes\n * This is the node which holds the menu title nodes.\n *\n * Modifying this node directly can lead to undefined behavior.\n */\n get contentNode(): HTMLUListElement {\n return this.node.getElementsByClassName(\n 'lm-MenuBar-content'\n )[0] as HTMLUListElement;\n }\n\n /**\n * Get the currently active menu.\n */\n get activeMenu(): Menu | null {\n return this._menus[this._activeIndex] || null;\n }\n\n /**\n * Set the currently active menu.\n *\n * #### Notes\n * If the menu does not exist, the menu will be set to `null`.\n */\n set activeMenu(value: Menu | null) {\n this.activeIndex = value ? this._menus.indexOf(value) : -1;\n }\n\n /**\n * Get the index of the currently active menu.\n *\n * #### Notes\n * This will be `-1` if no menu is active.\n */\n get activeIndex(): number {\n return this._activeIndex;\n }\n\n /**\n * Set the index of the currently active menu.\n *\n * #### Notes\n * If the menu cannot be activated, the index will be set to `-1`.\n */\n set activeIndex(value: number) {\n // Adjust the value for an out of range index.\n if (value < 0 || value >= this._menus.length) {\n value = -1;\n }\n\n // An empty menu cannot be active\n if (value > -1 && this._menus[value].items.length === 0) {\n value = -1;\n }\n\n // Bail early if the index will not change.\n if (this._activeIndex === value) {\n return;\n }\n\n // Update the active index.\n this._activeIndex = value;\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * A read-only array of the menus in the menu bar.\n */\n get menus(): ReadonlyArray {\n return this._menus;\n }\n\n /**\n * Open the active menu and activate its first menu item.\n *\n * #### Notes\n * If there is no active menu, this is a no-op.\n */\n openActiveMenu(): void {\n // Bail early if there is no active item.\n if (this._activeIndex === -1) {\n return;\n }\n\n // Open the child menu.\n this._openChildMenu();\n\n // Activate the first item in the child menu.\n if (this._childMenu) {\n this._childMenu.activeIndex = -1;\n this._childMenu.activateNextItem();\n }\n }\n\n /**\n * Add a menu to the end of the menu bar.\n *\n * @param menu - The menu to add to the menu bar.\n *\n * #### Notes\n * If the menu is already added to the menu bar, it will be moved.\n */\n addMenu(menu: Menu, update: boolean = true): void {\n this.insertMenu(this._menus.length, menu, update);\n }\n\n /**\n * Insert a menu into the menu bar at the specified index.\n *\n * @param index - The index at which to insert the menu.\n *\n * @param menu - The menu to insert into the menu bar.\n *\n * #### Notes\n * The index will be clamped to the bounds of the menus.\n *\n * If the menu is already added to the menu bar, it will be moved.\n */\n insertMenu(index: number, menu: Menu, update: boolean = true): void {\n // Close the child menu before making changes.\n this._closeChildMenu();\n\n // Look up the index of the menu.\n let i = this._menus.indexOf(menu);\n\n // Clamp the insert index to the array bounds.\n let j = Math.max(0, Math.min(index, this._menus.length));\n\n // If the menu is not in the array, insert it.\n if (i === -1) {\n // Insert the menu into the array.\n ArrayExt.insert(this._menus, j, menu);\n\n // Add the styling class to the menu.\n menu.addClass('lm-MenuBar-menu');\n\n // Connect to the menu signals.\n menu.aboutToClose.connect(this._onMenuAboutToClose, this);\n menu.menuRequested.connect(this._onMenuMenuRequested, this);\n menu.title.changed.connect(this._onTitleChanged, this);\n\n // Schedule an update of the items.\n if (update) {\n this.update();\n }\n\n // There is nothing more to do.\n return;\n }\n\n // Otherwise, the menu exists in the array and should be moved.\n\n // Adjust the index if the location is at the end of the array.\n if (j === this._menus.length) {\n j--;\n }\n\n // Bail if there is no effective move.\n if (i === j) {\n return;\n }\n\n // Move the menu to the new locations.\n ArrayExt.move(this._menus, i, j);\n\n // Schedule an update of the items.\n if (update) {\n this.update();\n }\n }\n\n /**\n * Remove a menu from the menu bar.\n *\n * @param menu - The menu to remove from the menu bar.\n *\n * #### Notes\n * This is a no-op if the menu is not in the menu bar.\n */\n removeMenu(menu: Menu, update: boolean = true): void {\n this.removeMenuAt(this._menus.indexOf(menu), update);\n }\n\n /**\n * Remove the menu at a given index from the menu bar.\n *\n * @param index - The index of the menu to remove.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n removeMenuAt(index: number, update: boolean = true): void {\n // Close the child menu before making changes.\n this._closeChildMenu();\n\n // Remove the menu from the array.\n let menu = ArrayExt.removeAt(this._menus, index);\n\n // Bail if the index is out of range.\n if (!menu) {\n return;\n }\n\n // Disconnect from the menu signals.\n menu.aboutToClose.disconnect(this._onMenuAboutToClose, this);\n menu.menuRequested.disconnect(this._onMenuMenuRequested, this);\n menu.title.changed.disconnect(this._onTitleChanged, this);\n\n // Remove the styling class from the menu.\n menu.removeClass('lm-MenuBar-menu');\n\n // Schedule an update of the items.\n if (update) {\n this.update();\n }\n }\n\n /**\n * Remove all menus from the menu bar.\n */\n clearMenus(): void {\n // Bail if there is nothing to remove.\n if (this._menus.length === 0) {\n return;\n }\n\n // Close the child menu before making changes.\n this._closeChildMenu();\n\n // Disconnect from the menu signals and remove the styling class.\n for (let menu of this._menus) {\n menu.aboutToClose.disconnect(this._onMenuAboutToClose, this);\n menu.menuRequested.disconnect(this._onMenuMenuRequested, this);\n menu.title.changed.disconnect(this._onTitleChanged, this);\n menu.removeClass('lm-MenuBar-menu');\n }\n\n // Clear the menus array.\n this._menus.length = 0;\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * Handle the DOM events for the menu bar.\n *\n * @param event - The DOM event sent to the menu bar.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the menu bar's DOM nodes. It\n * should not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'mousedown':\n this._evtMouseDown(event as MouseEvent);\n break;\n case 'mousemove':\n this._evtMouseMove(event as MouseEvent);\n break;\n case 'focusout':\n this._evtFocusOut(event as FocusEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('keydown', this);\n this.node.addEventListener('mousedown', this);\n this.node.addEventListener('mousemove', this);\n this.node.addEventListener('focusout', this);\n this.node.addEventListener('contextmenu', this);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('keydown', this);\n this.node.removeEventListener('mousedown', this);\n this.node.removeEventListener('mousemove', this);\n this.node.removeEventListener('focusout', this);\n this.node.removeEventListener('contextmenu', this);\n this._closeChildMenu();\n }\n\n /**\n * A message handler invoked on an `'activate-request'` message.\n */\n protected onActivateRequest(msg: Message): void {\n if (this.isAttached) {\n this._focusItemAt(0);\n }\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n this.update();\n super.onResize(msg);\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n let menus = this._menus;\n let renderer = this.renderer;\n let activeIndex = this._activeIndex;\n let tabFocusIndex =\n this._tabFocusIndex >= 0 && this._tabFocusIndex < menus.length\n ? this._tabFocusIndex\n : 0;\n let length = this._overflowIndex > -1 ? this._overflowIndex : menus.length;\n let totalMenuSize = 0;\n let isVisible = false;\n\n // Check that the overflow menu doesn't count\n length = this._overflowMenu !== null ? length - 1 : length;\n let content = new Array(length);\n\n // Render visible menus\n for (let i = 0; i < length; ++i) {\n content[i] = renderer.renderItem({\n title: menus[i].title,\n active: i === activeIndex,\n tabbable: i === tabFocusIndex,\n disabled: menus[i].items.length === 0,\n onfocus: () => {\n this._tabFocusIndex = i;\n this.activeIndex = i;\n }\n });\n // Calculate size of current menu\n totalMenuSize += this._menuItemSizes[i];\n // Check if overflow menu is already rendered\n if (menus[i].title.label === this._overflowMenuOptions.title) {\n isVisible = true;\n length--;\n }\n }\n // Render overflow menu if needed and active\n if (this._overflowMenuOptions.isVisible) {\n if (this._overflowIndex > -1 && !isVisible) {\n // Create overflow menu\n if (this._overflowMenu === null) {\n const overflowMenuTitle = this._overflowMenuOptions.title ?? '...';\n this._overflowMenu = new Menu({ commands: new CommandRegistry() });\n this._overflowMenu.title.label = overflowMenuTitle;\n this._overflowMenu.title.mnemonic = 0;\n this.addMenu(this._overflowMenu, false);\n }\n // Move menus to overflow menu\n for (let i = menus.length - 2; i >= length; i--) {\n const submenu = this.menus[i];\n submenu.title.mnemonic = 0;\n this._overflowMenu.insertItem(0, {\n type: 'submenu',\n submenu: submenu\n });\n this.removeMenu(submenu, false);\n }\n content[length] = renderer.renderItem({\n title: this._overflowMenu.title,\n active: length === activeIndex && menus[length].items.length !== 0,\n tabbable: length === tabFocusIndex,\n disabled: menus[length].items.length === 0,\n onfocus: () => {\n this._tabFocusIndex = length;\n this.activeIndex = length;\n }\n });\n length++;\n } else if (this._overflowMenu !== null) {\n // Remove submenus from overflow menu\n let overflowMenuItems = this._overflowMenu.items;\n let screenSize = this.node.offsetWidth;\n let n = this._overflowMenu.items.length;\n for (let i = 0; i < n; ++i) {\n let index = menus.length - 1 - i;\n if (screenSize - totalMenuSize > this._menuItemSizes[index]) {\n let menu = overflowMenuItems[0].submenu as Menu;\n this._overflowMenu.removeItemAt(0);\n this.insertMenu(length, menu, false);\n content[length] = renderer.renderItem({\n title: menu.title,\n active: false,\n tabbable: length === tabFocusIndex,\n disabled: menus[length].items.length === 0,\n onfocus: () => {\n this._tabFocusIndex = length;\n this.activeIndex = length;\n }\n });\n length++;\n }\n }\n if (this._overflowMenu.items.length === 0) {\n this.removeMenu(this._overflowMenu, false);\n content.pop();\n this._overflowMenu = null;\n this._overflowIndex = -1;\n }\n }\n }\n VirtualDOM.render(content, this.contentNode);\n this._updateOverflowIndex();\n }\n\n /**\n * Calculate and update the current overflow index.\n */\n private _updateOverflowIndex(): void {\n if (!this._overflowMenuOptions.isVisible) {\n return;\n }\n\n // Get elements visible in the main menu bar\n const itemMenus = this.contentNode.childNodes;\n let screenSize = this.node.offsetWidth;\n let totalMenuSize = 0;\n let index = -1;\n let n = itemMenus.length;\n\n if (this._menuItemSizes.length == 0) {\n // Check if it is the first resize and get info about menu items sizes\n for (let i = 0; i < n; i++) {\n let item = itemMenus[i] as HTMLLIElement;\n // Add sizes to array\n totalMenuSize += item.offsetWidth;\n this._menuItemSizes.push(item.offsetWidth);\n if (totalMenuSize > screenSize && index === -1) {\n index = i;\n }\n }\n } else {\n // Calculate current menu size\n for (let i = 0; i < this._menuItemSizes.length; i++) {\n totalMenuSize += this._menuItemSizes[i];\n if (totalMenuSize > screenSize) {\n index = i;\n break;\n }\n }\n }\n this._overflowIndex = index;\n }\n\n /**\n * Handle the `'keydown'` event for the menu bar.\n *\n * #### Notes\n * All keys are trapped except the tab key that is ignored.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // Fetch the key code for the event.\n let kc = event.keyCode;\n\n // Reset the active index on tab, but do not trap the tab key.\n if (kc === 9) {\n this.activeIndex = -1;\n return;\n }\n\n // A menu bar handles all other keydown events.\n event.preventDefault();\n event.stopPropagation();\n\n // Enter, Space, Up Arrow, Down Arrow\n if (kc === 13 || kc === 32 || kc === 38 || kc === 40) {\n // The active index may have changed (for example, user hovers over an\n // item with the mouse), so be sure to use the focus index.\n this.activeIndex = this._tabFocusIndex;\n if (this.activeIndex !== this._tabFocusIndex) {\n // Bail if the setter refused to set activeIndex to tabFocusIndex\n // because it means that the item at tabFocusIndex cannot be opened (for\n // example, it has an empty menu)\n return;\n }\n this.openActiveMenu();\n return;\n }\n\n // Escape\n if (kc === 27) {\n this._closeChildMenu();\n this._focusItemAt(this.activeIndex);\n return;\n }\n\n // Left or Right Arrow\n if (kc === 37 || kc === 39) {\n let direction = kc === 37 ? -1 : 1;\n let start = this._tabFocusIndex + direction;\n let n = this._menus.length;\n for (let i = 0; i < n; i++) {\n let index = (n + start + direction * i) % n;\n if (this._menus[index].items.length) {\n this._focusItemAt(index);\n return;\n }\n }\n return;\n }\n\n // Get the pressed key character.\n let key = getKeyboardLayout().keyForKeydownEvent(event);\n\n // Bail if the key is not valid.\n if (!key) {\n return;\n }\n\n // Search for the next best matching mnemonic item.\n let start = this._activeIndex + 1;\n let result = Private.findMnemonic(this._menus, key, start);\n\n // Handle the requested mnemonic based on the search results.\n // If exactly one mnemonic is matched, that menu is opened.\n // Otherwise, the next mnemonic is activated if available,\n // followed by the auto mnemonic if available.\n if (result.index !== -1 && !result.multiple) {\n this.activeIndex = result.index;\n this.openActiveMenu();\n } else if (result.index !== -1) {\n this.activeIndex = result.index;\n this._focusItemAt(this.activeIndex);\n } else if (result.auto !== -1) {\n this.activeIndex = result.auto;\n this._focusItemAt(this.activeIndex);\n }\n }\n\n /**\n * Handle the `'mousedown'` event for the menu bar.\n */\n private _evtMouseDown(event: MouseEvent): void {\n // Bail if the mouse press was not on the menu bar. This can occur\n // when the document listener is installed for an active menu bar.\n if (!ElementExt.hitTest(this.node, event.clientX, event.clientY)) {\n return;\n }\n\n // Stop the propagation of the event. Immediate propagation is\n // also stopped so that an open menu does not handle the event.\n event.stopPropagation();\n event.stopImmediatePropagation();\n\n // Check if the mouse is over one of the menu items.\n let index = ArrayExt.findFirstIndex(this.contentNode.children, node => {\n return ElementExt.hitTest(node, event.clientX, event.clientY);\n });\n\n // If the press was not on an item, close the child menu.\n if (index === -1) {\n this._closeChildMenu();\n return;\n }\n\n // If the press was not the left mouse button, do nothing further.\n if (event.button !== 0) {\n return;\n }\n\n // Otherwise, toggle the open state of the child menu.\n if (this._childMenu) {\n this._closeChildMenu();\n this.activeIndex = index;\n } else {\n // If we don't call preventDefault() here, then the item in the menu\n // bar will take focus over the menu that is being opened.\n event.preventDefault();\n const position = this._positionForMenu(index);\n Menu.saveWindowData();\n // Begin DOM modifications.\n this.activeIndex = index;\n this._openChildMenu(position);\n }\n }\n\n /**\n * Handle the `'mousemove'` event for the menu bar.\n */\n private _evtMouseMove(event: MouseEvent): void {\n // Check if the mouse is over one of the menu items.\n let index = ArrayExt.findFirstIndex(this.contentNode.children, node => {\n return ElementExt.hitTest(node, event.clientX, event.clientY);\n });\n\n // Bail early if the active index will not change.\n if (index === this._activeIndex) {\n return;\n }\n\n // Bail early if a child menu is open and the mouse is not over\n // an item. This allows the child menu to be kept open when the\n // mouse is over the empty part of the menu bar.\n if (index === -1 && this._childMenu) {\n return;\n }\n\n // Get position for the new menu >before< updating active index.\n const position =\n index >= 0 && this._childMenu ? this._positionForMenu(index) : null;\n\n // Before any modification, update window data.\n Menu.saveWindowData();\n\n // Begin DOM modifications.\n\n // Update the active index to the hovered item.\n this.activeIndex = index;\n\n // Open the new menu if a menu is already open.\n if (position) {\n this._openChildMenu(position);\n }\n }\n\n /**\n * Find initial position for the menu based on menubar item position.\n *\n * NOTE: this should be called before updating active index to avoid\n * an additional layout and style invalidation as changing active\n * index modifies DOM.\n */\n private _positionForMenu(index: number): Private.IPosition {\n let itemNode = this.contentNode.children[index];\n let { left, bottom } = (itemNode as HTMLElement).getBoundingClientRect();\n return {\n top: bottom,\n left\n };\n }\n\n /**\n * Handle the `'focusout'` event for the menu bar.\n */\n private _evtFocusOut(event: FocusEvent): void {\n // Reset the active index if there is no open menu and the menubar is losing focus.\n if (!this._childMenu && !this.node.contains(event.relatedTarget as Node)) {\n this.activeIndex = -1;\n }\n }\n\n /**\n * Focus an item in the menu bar.\n *\n * #### Notes\n * Does not open the associated menu.\n */\n private _focusItemAt(index: number): void {\n const itemNode = this.contentNode.childNodes[index] as HTMLElement | void;\n if (itemNode) {\n itemNode.focus();\n }\n }\n\n /**\n * Open the child menu at the active index immediately.\n *\n * If a different child menu is already open, it will be closed,\n * even if there is no active menu.\n */\n private _openChildMenu(options: { left?: number; top?: number } = {}): void {\n // If there is no active menu, close the current menu.\n let newMenu = this.activeMenu;\n if (!newMenu) {\n this._closeChildMenu();\n return;\n }\n\n // Bail if there is no effective menu change.\n let oldMenu = this._childMenu;\n if (oldMenu === newMenu) {\n return;\n }\n\n // Swap the internal menu reference.\n this._childMenu = newMenu;\n\n // Close the current menu, or setup for the new menu.\n if (oldMenu) {\n oldMenu.close();\n } else {\n document.addEventListener('mousedown', this, true);\n }\n\n // Update the tab focus index and ensure the menu bar is updated.\n this._tabFocusIndex = this.activeIndex;\n MessageLoop.sendMessage(this, Widget.Msg.UpdateRequest);\n\n // Get the positioning data for the new menu.\n let { left, top } = options;\n if (typeof left === 'undefined' || typeof top === 'undefined') {\n ({ left, top } = this._positionForMenu(this._activeIndex));\n }\n // Begin DOM modifications\n\n if (!oldMenu) {\n // Continue setup for new menu\n this.addClass('lm-mod-active');\n }\n\n // Open the new menu at the computed location.\n if (newMenu.items.length > 0) {\n newMenu.open(left, top, this._forceItemsPosition);\n }\n }\n\n /**\n * Close the child menu immediately.\n *\n * This is a no-op if a child menu is not open.\n */\n private _closeChildMenu(): void {\n // Bail if no child menu is open.\n if (!this._childMenu) {\n return;\n }\n // Remove the active class from the menu bar.\n this.removeClass('lm-mod-active');\n\n // Remove the document listeners.\n document.removeEventListener('mousedown', this, true);\n\n // Clear the internal menu reference.\n let menu = this._childMenu;\n this._childMenu = null;\n\n // Close the menu.\n menu.close();\n\n // Reset the active index.\n this.activeIndex = -1;\n }\n\n /**\n * Handle the `aboutToClose` signal of a menu.\n */\n private _onMenuAboutToClose(sender: Menu): void {\n // Bail if the sender is not the child menu.\n if (sender !== this._childMenu) {\n return;\n }\n\n // Remove the active class from the menu bar.\n this.removeClass('lm-mod-active');\n\n // Remove the document listeners.\n document.removeEventListener('mousedown', this, true);\n\n // Clear the internal menu reference.\n this._childMenu = null;\n\n // Reset the active index.\n this.activeIndex = -1;\n }\n\n /**\n * Handle the `menuRequested` signal of a child menu.\n */\n private _onMenuMenuRequested(sender: Menu, args: 'next' | 'previous'): void {\n // Bail if the sender is not the child menu.\n if (sender !== this._childMenu) {\n return;\n }\n\n // Look up the active index and menu count.\n let i = this._activeIndex;\n let n = this._menus.length;\n\n // Active the next requested index.\n switch (args) {\n case 'next':\n this.activeIndex = i === n - 1 ? 0 : i + 1;\n break;\n case 'previous':\n this.activeIndex = i === 0 ? n - 1 : i - 1;\n break;\n }\n\n // Open the active menu.\n this.openActiveMenu();\n }\n\n /**\n * Handle the `changed` signal of a title object.\n */\n private _onTitleChanged(): void {\n this.update();\n }\n\n // Track the index of the item that is currently focused or hovered. -1 means nothing focused or hovered.\n private _activeIndex = -1;\n // Track which item can be focused using the TAB key. Unlike _activeIndex will\n // always point to a menuitem. Whenever you update this value, it's important\n // to follow it with an \"update-request\" message so that the `tabindex`\n // attribute on each menubar item gets properly updated.\n private _tabFocusIndex = 0;\n private _forceItemsPosition: Menu.IOpenOptions;\n private _overflowMenuOptions: IOverflowMenuOptions;\n private _menus: Menu[] = [];\n private _childMenu: Menu | null = null;\n private _overflowMenu: Menu | null = null;\n private _menuItemSizes: number[] = [];\n private _overflowIndex: number = -1;\n}\n\n/**\n * The namespace for the `MenuBar` class statics.\n */\nexport namespace MenuBar {\n /**\n * An options object for creating a menu bar.\n */\n export interface IOptions {\n /**\n * A custom renderer for creating menu bar content.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n /**\n * Whether to force the position of the menu. The MenuBar forces the\n * coordinates of its menus by default. With this option you can disable it.\n *\n * Setting to `false` will enable the logic which repositions the\n * coordinates of the menu if it will not fit entirely on screen.\n *\n * The default is `true`.\n */\n forceItemsPosition?: Menu.IOpenOptions;\n /**\n * Whether to add a overflow menu if there's overflow.\n *\n * Setting to `true` will enable the logic that creates an overflow menu\n * to show the menu items that don't fit entirely on the screen.\n *\n * The default is `true`.\n */\n overflowMenuOptions?: IOverflowMenuOptions;\n }\n\n /**\n * An object which holds the data to render a menu bar item.\n */\n export interface IRenderData {\n /**\n * The title to be rendered.\n */\n readonly title: Title;\n\n /**\n * Whether the item is the active item.\n */\n readonly active: boolean;\n\n /**\n * Whether the user can tab to the item.\n */\n readonly tabbable: boolean;\n\n /**\n * Whether the item is disabled.\n *\n * #### Notes\n * A disabled item cannot be active.\n * A disabled item cannot be focussed.\n */\n readonly disabled?: boolean;\n\n readonly onfocus?: (event: FocusEvent) => void;\n }\n\n /**\n * A renderer for use with a menu bar.\n */\n export interface IRenderer {\n /**\n * Render the virtual element for a menu bar item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n */\n renderItem(data: IRenderData): VirtualElement;\n }\n\n /**\n * The default implementation of `IRenderer`.\n *\n * #### Notes\n * Subclasses are free to reimplement rendering methods as needed.\n */\n export class Renderer implements IRenderer {\n /**\n * Render the virtual element for a menu bar item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n */\n renderItem(data: IRenderData): VirtualElement {\n let className = this.createItemClass(data);\n let dataset = this.createItemDataset(data);\n let aria = this.createItemARIA(data);\n return h.li(\n {\n className,\n dataset,\n ...(data.disabled ? {} : { tabindex: data.tabbable ? '0' : '-1' }),\n onfocus: data.onfocus,\n ...aria\n },\n this.renderIcon(data),\n this.renderLabel(data)\n );\n }\n\n /**\n * Render the icon element for a menu bar item.\n *\n * @param data - The data to use for rendering the icon.\n *\n * @returns A virtual element representing the item icon.\n */\n renderIcon(data: IRenderData): VirtualElement {\n let className = this.createIconClass(data);\n\n // If data.title.icon is undefined, it will be ignored.\n return h.div({ className }, data.title.icon!, data.title.iconLabel);\n }\n\n /**\n * Render the label element for a menu item.\n *\n * @param data - The data to use for rendering the label.\n *\n * @returns A virtual element representing the item label.\n */\n renderLabel(data: IRenderData): VirtualElement {\n let content = this.formatLabel(data);\n return h.div({ className: 'lm-MenuBar-itemLabel' }, content);\n }\n\n /**\n * Create the class name for the menu bar item.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the menu item.\n */\n createItemClass(data: IRenderData): string {\n let name = 'lm-MenuBar-item';\n if (data.title.className) {\n name += ` ${data.title.className}`;\n }\n if (data.active && !data.disabled) {\n name += ' lm-mod-active';\n }\n return name;\n }\n\n /**\n * Create the dataset for a menu bar item.\n *\n * @param data - The data to use for the item.\n *\n * @returns The dataset for the menu bar item.\n */\n createItemDataset(data: IRenderData): ElementDataset {\n return data.title.dataset;\n }\n\n /**\n * Create the aria attributes for menu bar item.\n *\n * @param data - The data to use for the aria attributes.\n *\n * @returns The aria attributes object for the item.\n */\n createItemARIA(data: IRenderData): ElementARIAAttrs {\n return {\n role: 'menuitem',\n 'aria-haspopup': 'true',\n 'aria-disabled': data.disabled ? 'true' : 'false'\n };\n }\n\n /**\n * Create the class name for the menu bar item icon.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the item icon.\n */\n createIconClass(data: IRenderData): string {\n let name = 'lm-MenuBar-itemIcon';\n let extra = data.title.iconClass;\n return extra ? `${name} ${extra}` : name;\n }\n\n /**\n * Create the render content for the label node.\n *\n * @param data - The data to use for the label content.\n *\n * @returns The content to add to the label node.\n */\n formatLabel(data: IRenderData): h.Child {\n // Fetch the label text and mnemonic index.\n let { label, mnemonic } = data.title;\n\n // If the index is out of range, do not modify the label.\n if (mnemonic < 0 || mnemonic >= label.length) {\n return label;\n }\n\n // Split the label into parts.\n let prefix = label.slice(0, mnemonic);\n let suffix = label.slice(mnemonic + 1);\n let char = label[mnemonic];\n\n // Wrap the mnemonic character in a span.\n let span = h.span({ className: 'lm-MenuBar-itemMnemonic' }, char);\n\n // Return the content parts.\n return [prefix, span, suffix];\n }\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n}\n\n/**\n * Options for overflow menu.\n */\nexport interface IOverflowMenuOptions {\n /**\n * Determines if a overflow menu appears when the menu items overflow.\n *\n * Defaults to `true`.\n */\n isVisible: boolean;\n /**\n * Determines the title of the overflow menu.\n *\n * Default: `...`.\n */\n title?: string;\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Create the DOM node for a menu bar.\n */\n export function createNode(): HTMLDivElement {\n let node = document.createElement('div');\n let content = document.createElement('ul');\n content.className = 'lm-MenuBar-content';\n node.appendChild(content);\n content.setAttribute('role', 'menubar');\n return node;\n }\n\n /**\n * Position for the menu relative to top-left screen corner.\n */\n export interface IPosition {\n /**\n * Pixels right from screen origin.\n */\n left: number;\n /**\n * Pixels down from screen origin.\n */\n top: number;\n }\n\n /**\n * The results of a mnemonic search.\n */\n export interface IMnemonicResult {\n /**\n * The index of the first matching mnemonic item, or `-1`.\n */\n index: number;\n\n /**\n * Whether multiple mnemonic items matched.\n */\n multiple: boolean;\n\n /**\n * The index of the first auto matched non-mnemonic item.\n */\n auto: number;\n }\n\n /**\n * Find the best matching mnemonic item.\n *\n * The search starts at the given index and wraps around.\n */\n export function findMnemonic(\n menus: ReadonlyArray,\n key: string,\n start: number\n ): IMnemonicResult {\n // Setup the result variables.\n let index = -1;\n let auto = -1;\n let multiple = false;\n\n // Normalize the key to upper case.\n let upperKey = key.toUpperCase();\n\n // Search the items from the given start index.\n for (let i = 0, n = menus.length; i < n; ++i) {\n // Compute the wrapped index.\n let k = (i + start) % n;\n\n // Look up the menu title.\n let title = menus[k].title;\n\n // Ignore titles with an empty label.\n if (title.label.length === 0) {\n continue;\n }\n\n // Look up the mnemonic index for the label.\n let mn = title.mnemonic;\n\n // Handle a valid mnemonic index.\n if (mn >= 0 && mn < title.label.length) {\n if (title.label[mn].toUpperCase() === upperKey) {\n if (index === -1) {\n index = k;\n } else {\n multiple = true;\n }\n }\n continue;\n }\n\n // Finally, handle the auto index if possible.\n if (auto === -1 && title.label[0].toUpperCase() === upperKey) {\n auto = k;\n }\n }\n\n // Return the search results.\n return { index, multiple, auto };\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Drag } from '@lumino/dragdrop';\n\nimport { Message } from '@lumino/messaging';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { Widget } from './widget';\n\n/**\n * A widget which implements a canonical scroll bar.\n */\nexport class ScrollBar extends Widget {\n /**\n * Construct a new scroll bar.\n *\n * @param options - The options for initializing the scroll bar.\n */\n constructor(options: ScrollBar.IOptions = {}) {\n super({ node: Private.createNode() });\n this.addClass('lm-ScrollBar');\n this.setFlag(Widget.Flag.DisallowLayout);\n\n // Set the orientation.\n this._orientation = options.orientation || 'vertical';\n this.dataset['orientation'] = this._orientation;\n\n // Parse the rest of the options.\n if (options.maximum !== undefined) {\n this._maximum = Math.max(0, options.maximum);\n }\n if (options.page !== undefined) {\n this._page = Math.max(0, options.page);\n }\n if (options.value !== undefined) {\n this._value = Math.max(0, Math.min(options.value, this._maximum));\n }\n }\n\n /**\n * A signal emitted when the user moves the scroll thumb.\n *\n * #### Notes\n * The payload is the current value of the scroll bar.\n */\n get thumbMoved(): ISignal {\n return this._thumbMoved;\n }\n\n /**\n * A signal emitted when the user clicks a step button.\n *\n * #### Notes\n * The payload is whether a decrease or increase is requested.\n */\n get stepRequested(): ISignal {\n return this._stepRequested;\n }\n\n /**\n * A signal emitted when the user clicks the scroll track.\n *\n * #### Notes\n * The payload is whether a decrease or increase is requested.\n */\n get pageRequested(): ISignal {\n return this._pageRequested;\n }\n\n /**\n * Get the orientation of the scroll bar.\n */\n get orientation(): ScrollBar.Orientation {\n return this._orientation;\n }\n\n /**\n * Set the orientation of the scroll bar.\n */\n set orientation(value: ScrollBar.Orientation) {\n // Do nothing if the orientation does not change.\n if (this._orientation === value) {\n return;\n }\n\n // Release the mouse before making changes.\n this._releaseMouse();\n\n // Update the internal orientation.\n this._orientation = value;\n this.dataset['orientation'] = value;\n\n // Schedule an update the scroll bar.\n this.update();\n }\n\n /**\n * Get the current value of the scroll bar.\n */\n get value(): number {\n return this._value;\n }\n\n /**\n * Set the current value of the scroll bar.\n *\n * #### Notes\n * The value will be clamped to the range `[0, maximum]`.\n */\n set value(value: number) {\n // Clamp the value to the allowable range.\n value = Math.max(0, Math.min(value, this._maximum));\n\n // Do nothing if the value does not change.\n if (this._value === value) {\n return;\n }\n\n // Update the internal value.\n this._value = value;\n\n // Schedule an update the scroll bar.\n this.update();\n }\n\n /**\n * Get the page size of the scroll bar.\n *\n * #### Notes\n * The page size is the amount of visible content in the scrolled\n * region, expressed in data units. It determines the size of the\n * scroll bar thumb.\n */\n get page(): number {\n return this._page;\n }\n\n /**\n * Set the page size of the scroll bar.\n *\n * #### Notes\n * The page size will be clamped to the range `[0, Infinity]`.\n */\n set page(value: number) {\n // Clamp the page size to the allowable range.\n value = Math.max(0, value);\n\n // Do nothing if the value does not change.\n if (this._page === value) {\n return;\n }\n\n // Update the internal page size.\n this._page = value;\n\n // Schedule an update the scroll bar.\n this.update();\n }\n\n /**\n * Get the maximum value of the scroll bar.\n */\n get maximum(): number {\n return this._maximum;\n }\n\n /**\n * Set the maximum value of the scroll bar.\n *\n * #### Notes\n * The max size will be clamped to the range `[0, Infinity]`.\n */\n set maximum(value: number) {\n // Clamp the value to the allowable range.\n value = Math.max(0, value);\n\n // Do nothing if the value does not change.\n if (this._maximum === value) {\n return;\n }\n\n // Update the internal values.\n this._maximum = value;\n\n // Clamp the current value to the new range.\n this._value = Math.min(this._value, value);\n\n // Schedule an update the scroll bar.\n this.update();\n }\n\n /**\n * The scroll bar decrement button node.\n *\n * #### Notes\n * Modifying this node directly can lead to undefined behavior.\n */\n get decrementNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-ScrollBar-button'\n )[0] as HTMLDivElement;\n }\n\n /**\n * The scroll bar increment button node.\n *\n * #### Notes\n * Modifying this node directly can lead to undefined behavior.\n */\n get incrementNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-ScrollBar-button'\n )[1] as HTMLDivElement;\n }\n\n /**\n * The scroll bar track node.\n *\n * #### Notes\n * Modifying this node directly can lead to undefined behavior.\n */\n get trackNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-ScrollBar-track'\n )[0] as HTMLDivElement;\n }\n\n /**\n * The scroll bar thumb node.\n *\n * #### Notes\n * Modifying this node directly can lead to undefined behavior.\n */\n get thumbNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-ScrollBar-thumb'\n )[0] as HTMLDivElement;\n }\n\n /**\n * Handle the DOM events for the scroll bar.\n *\n * @param event - The DOM event sent to the scroll bar.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the scroll bar's DOM node.\n *\n * This should not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'mousedown':\n this._evtMouseDown(event as MouseEvent);\n break;\n case 'mousemove':\n this._evtMouseMove(event as MouseEvent);\n break;\n case 'mouseup':\n this._evtMouseUp(event as MouseEvent);\n break;\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A method invoked on a 'before-attach' message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('mousedown', this);\n this.update();\n }\n\n /**\n * A method invoked on an 'after-detach' message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('mousedown', this);\n this._releaseMouse();\n }\n\n /**\n * A method invoked on an 'update-request' message.\n */\n protected onUpdateRequest(msg: Message): void {\n // Convert the value and page into percentages.\n let value = (this._value * 100) / this._maximum;\n let page = (this._page * 100) / (this._page + this._maximum);\n\n // Clamp the value and page to the relevant range.\n value = Math.max(0, Math.min(value, 100));\n page = Math.max(0, Math.min(page, 100));\n\n // Fetch the thumb style.\n let thumbStyle = this.thumbNode.style;\n\n // Update the thumb style for the current orientation.\n if (this._orientation === 'horizontal') {\n thumbStyle.top = '';\n thumbStyle.height = '';\n thumbStyle.left = `${value}%`;\n thumbStyle.width = `${page}%`;\n thumbStyle.transform = `translate(${-value}%, 0%)`;\n } else {\n thumbStyle.left = '';\n thumbStyle.width = '';\n thumbStyle.top = `${value}%`;\n thumbStyle.height = `${page}%`;\n thumbStyle.transform = `translate(0%, ${-value}%)`;\n }\n }\n\n /**\n * Handle the `'keydown'` event for the scroll bar.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // Stop all input events during drag.\n event.preventDefault();\n event.stopPropagation();\n\n // Ignore anything except the `Escape` key.\n if (event.keyCode !== 27) {\n return;\n }\n\n // Fetch the previous scroll value.\n let value = this._pressData ? this._pressData.value : -1;\n\n // Release the mouse.\n this._releaseMouse();\n\n // Restore the old scroll value if possible.\n if (value !== -1) {\n this._moveThumb(value);\n }\n }\n\n /**\n * Handle the `'mousedown'` event for the scroll bar.\n */\n private _evtMouseDown(event: MouseEvent): void {\n // Do nothing if it's not a left mouse press.\n if (event.button !== 0) {\n return;\n }\n\n // Send an activate request to the scroll bar. This can be\n // used by message hooks to activate something relevant.\n this.activate();\n\n // Do nothing if the mouse is already captured.\n if (this._pressData) {\n return;\n }\n\n // Find the pressed scroll bar part.\n let part = Private.findPart(this, event.target as HTMLElement);\n\n // Do nothing if the part is not of interest.\n if (!part) {\n return;\n }\n\n // Stop the event propagation.\n event.preventDefault();\n event.stopPropagation();\n\n // Override the mouse cursor.\n let override = Drag.overrideCursor('default');\n\n // Set up the press data.\n this._pressData = {\n part,\n override,\n delta: -1,\n value: -1,\n mouseX: event.clientX,\n mouseY: event.clientY\n };\n\n // Add the extra event listeners.\n document.addEventListener('mousemove', this, true);\n document.addEventListener('mouseup', this, true);\n document.addEventListener('keydown', this, true);\n document.addEventListener('contextmenu', this, true);\n\n // Handle a thumb press.\n if (part === 'thumb') {\n // Fetch the thumb node.\n let thumbNode = this.thumbNode;\n\n // Fetch the client rect for the thumb.\n let thumbRect = thumbNode.getBoundingClientRect();\n\n // Update the press data delta for the current orientation.\n if (this._orientation === 'horizontal') {\n this._pressData.delta = event.clientX - thumbRect.left;\n } else {\n this._pressData.delta = event.clientY - thumbRect.top;\n }\n\n // Add the active class to the thumb node.\n thumbNode.classList.add('lm-mod-active');\n\n // Store the current value in the press data.\n this._pressData.value = this._value;\n\n // Finished.\n return;\n }\n\n // Handle a track press.\n if (part === 'track') {\n // Fetch the client rect for the thumb.\n let thumbRect = this.thumbNode.getBoundingClientRect();\n\n // Determine the direction for the page request.\n let dir: 'decrement' | 'increment';\n if (this._orientation === 'horizontal') {\n dir = event.clientX < thumbRect.left ? 'decrement' : 'increment';\n } else {\n dir = event.clientY < thumbRect.top ? 'decrement' : 'increment';\n }\n\n // Start the repeat timer.\n this._repeatTimer = window.setTimeout(this._onRepeat, 350);\n\n // Emit the page requested signal.\n this._pageRequested.emit(dir);\n\n // Finished.\n return;\n }\n\n // Handle a decrement button press.\n if (part === 'decrement') {\n // Add the active class to the decrement node.\n this.decrementNode.classList.add('lm-mod-active');\n\n // Start the repeat timer.\n this._repeatTimer = window.setTimeout(this._onRepeat, 350);\n\n // Emit the step requested signal.\n this._stepRequested.emit('decrement');\n\n // Finished.\n return;\n }\n\n // Handle an increment button press.\n if (part === 'increment') {\n // Add the active class to the increment node.\n this.incrementNode.classList.add('lm-mod-active');\n\n // Start the repeat timer.\n this._repeatTimer = window.setTimeout(this._onRepeat, 350);\n\n // Emit the step requested signal.\n this._stepRequested.emit('increment');\n\n // Finished.\n return;\n }\n }\n\n /**\n * Handle the `'mousemove'` event for the scroll bar.\n */\n private _evtMouseMove(event: MouseEvent): void {\n // Do nothing if no drag is in progress.\n if (!this._pressData) {\n return;\n }\n\n // Stop the event propagation.\n event.preventDefault();\n event.stopPropagation();\n\n // Update the mouse position.\n this._pressData.mouseX = event.clientX;\n this._pressData.mouseY = event.clientY;\n\n // Bail if the thumb is not being dragged.\n if (this._pressData.part !== 'thumb') {\n return;\n }\n\n // Get the client rect for the thumb and track.\n let thumbRect = this.thumbNode.getBoundingClientRect();\n let trackRect = this.trackNode.getBoundingClientRect();\n\n // Fetch the scroll geometry based on the orientation.\n let trackPos: number;\n let trackSpan: number;\n if (this._orientation === 'horizontal') {\n trackPos = event.clientX - trackRect.left - this._pressData.delta;\n trackSpan = trackRect.width - thumbRect.width;\n } else {\n trackPos = event.clientY - trackRect.top - this._pressData.delta;\n trackSpan = trackRect.height - thumbRect.height;\n }\n\n // Compute the desired value from the scroll geometry.\n let value = trackSpan === 0 ? 0 : (trackPos * this._maximum) / trackSpan;\n\n // Move the thumb to the computed value.\n this._moveThumb(value);\n }\n\n /**\n * Handle the `'mouseup'` event for the scroll bar.\n */\n private _evtMouseUp(event: MouseEvent): void {\n // Do nothing if it's not a left mouse release.\n if (event.button !== 0) {\n return;\n }\n\n // Stop the event propagation.\n event.preventDefault();\n event.stopPropagation();\n\n // Release the mouse.\n this._releaseMouse();\n }\n\n /**\n * Release the mouse and restore the node states.\n */\n private _releaseMouse(): void {\n // Bail if there is no press data.\n if (!this._pressData) {\n return;\n }\n\n // Clear the repeat timer.\n clearTimeout(this._repeatTimer);\n this._repeatTimer = -1;\n\n // Clear the press data.\n this._pressData.override.dispose();\n this._pressData = null;\n\n // Remove the extra event listeners.\n document.removeEventListener('mousemove', this, true);\n document.removeEventListener('mouseup', this, true);\n document.removeEventListener('keydown', this, true);\n document.removeEventListener('contextmenu', this, true);\n\n // Remove the active classes from the nodes.\n this.thumbNode.classList.remove('lm-mod-active');\n this.decrementNode.classList.remove('lm-mod-active');\n this.incrementNode.classList.remove('lm-mod-active');\n }\n\n /**\n * Move the thumb to the specified position.\n */\n private _moveThumb(value: number): void {\n // Clamp the value to the allowed range.\n value = Math.max(0, Math.min(value, this._maximum));\n\n // Bail if the value does not change.\n if (this._value === value) {\n return;\n }\n\n // Update the internal value.\n this._value = value;\n\n // Schedule an update of the scroll bar.\n this.update();\n\n // Emit the thumb moved signal.\n this._thumbMoved.emit(value);\n }\n\n /**\n * A timeout callback for repeating the mouse press.\n */\n private _onRepeat = () => {\n // Clear the repeat timer id.\n this._repeatTimer = -1;\n\n // Bail if the mouse has been released.\n if (!this._pressData) {\n return;\n }\n\n // Look up the part that was pressed.\n let part = this._pressData.part;\n\n // Bail if the thumb was pressed.\n if (part === 'thumb') {\n return;\n }\n\n // Schedule the timer for another repeat.\n this._repeatTimer = window.setTimeout(this._onRepeat, 20);\n\n // Get the current mouse position.\n let mouseX = this._pressData.mouseX;\n let mouseY = this._pressData.mouseY;\n\n // Handle a decrement button repeat.\n if (part === 'decrement') {\n // Bail if the mouse is not over the button.\n if (!ElementExt.hitTest(this.decrementNode, mouseX, mouseY)) {\n return;\n }\n\n // Emit the step requested signal.\n this._stepRequested.emit('decrement');\n\n // Finished.\n return;\n }\n\n // Handle an increment button repeat.\n if (part === 'increment') {\n // Bail if the mouse is not over the button.\n if (!ElementExt.hitTest(this.incrementNode, mouseX, mouseY)) {\n return;\n }\n\n // Emit the step requested signal.\n this._stepRequested.emit('increment');\n\n // Finished.\n return;\n }\n\n // Handle a track repeat.\n if (part === 'track') {\n // Bail if the mouse is not over the track.\n if (!ElementExt.hitTest(this.trackNode, mouseX, mouseY)) {\n return;\n }\n\n // Fetch the thumb node.\n let thumbNode = this.thumbNode;\n\n // Bail if the mouse is over the thumb.\n if (ElementExt.hitTest(thumbNode, mouseX, mouseY)) {\n return;\n }\n\n // Fetch the client rect for the thumb.\n let thumbRect = thumbNode.getBoundingClientRect();\n\n // Determine the direction for the page request.\n let dir: 'decrement' | 'increment';\n if (this._orientation === 'horizontal') {\n dir = mouseX < thumbRect.left ? 'decrement' : 'increment';\n } else {\n dir = mouseY < thumbRect.top ? 'decrement' : 'increment';\n }\n\n // Emit the page requested signal.\n this._pageRequested.emit(dir);\n\n // Finished.\n return;\n }\n };\n\n private _value = 0;\n private _page = 10;\n private _maximum = 100;\n private _repeatTimer = -1;\n private _orientation: ScrollBar.Orientation;\n private _pressData: Private.IPressData | null = null;\n private _thumbMoved = new Signal(this);\n private _stepRequested = new Signal(this);\n private _pageRequested = new Signal(this);\n}\n\n/**\n * The namespace for the `ScrollBar` class statics.\n */\nexport namespace ScrollBar {\n /**\n * A type alias for a scroll bar orientation.\n */\n export type Orientation = 'horizontal' | 'vertical';\n\n /**\n * An options object for creating a scroll bar.\n */\n export interface IOptions {\n /**\n * The orientation of the scroll bar.\n *\n * The default is `'vertical'`.\n */\n orientation?: Orientation;\n\n /**\n * The value for the scroll bar.\n *\n * The default is `0`.\n */\n value?: number;\n\n /**\n * The page size for the scroll bar.\n *\n * The default is `10`.\n */\n page?: number;\n\n /**\n * The maximum value for the scroll bar.\n *\n * The default is `100`.\n */\n maximum?: number;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * A type alias for the parts of a scroll bar.\n */\n export type ScrollBarPart = 'thumb' | 'track' | 'decrement' | 'increment';\n\n /**\n * An object which holds mouse press data.\n */\n export interface IPressData {\n /**\n * The scroll bar part which was pressed.\n */\n part: ScrollBarPart;\n\n /**\n * The offset of the press in thumb coordinates, or -1.\n */\n delta: number;\n\n /**\n * The scroll value at the time the thumb was pressed, or -1.\n */\n value: number;\n\n /**\n * The disposable which will clear the override cursor.\n */\n override: IDisposable;\n\n /**\n * The current X position of the mouse.\n */\n mouseX: number;\n\n /**\n * The current Y position of the mouse.\n */\n mouseY: number;\n }\n\n /**\n * Create the DOM node for a scroll bar.\n */\n export function createNode(): HTMLElement {\n let node = document.createElement('div');\n let decrement = document.createElement('div');\n let increment = document.createElement('div');\n let track = document.createElement('div');\n let thumb = document.createElement('div');\n decrement.className = 'lm-ScrollBar-button';\n increment.className = 'lm-ScrollBar-button';\n decrement.dataset['action'] = 'decrement';\n increment.dataset['action'] = 'increment';\n track.className = 'lm-ScrollBar-track';\n thumb.className = 'lm-ScrollBar-thumb';\n track.appendChild(thumb);\n node.appendChild(decrement);\n node.appendChild(track);\n node.appendChild(increment);\n return node;\n }\n\n /**\n * Find the scroll bar part which contains the given target.\n */\n export function findPart(\n scrollBar: ScrollBar,\n target: HTMLElement\n ): ScrollBarPart | null {\n // Test the thumb.\n if (scrollBar.thumbNode.contains(target)) {\n return 'thumb';\n }\n\n // Test the track.\n if (scrollBar.trackNode.contains(target)) {\n return 'track';\n }\n\n // Test the decrement button.\n if (scrollBar.decrementNode.contains(target)) {\n return 'decrement';\n }\n\n // Test the increment button.\n if (scrollBar.incrementNode.contains(target)) {\n return 'increment';\n }\n\n // Indicate no match.\n return null;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { MessageLoop } from '@lumino/messaging';\n\nimport { Layout } from './layout';\n\nimport { Widget } from './widget';\n\n/**\n * A concrete layout implementation which holds a single widget.\n *\n * #### Notes\n * This class is useful for creating simple container widgets which\n * hold a single child. The child should be positioned with CSS.\n */\nexport class SingletonLayout extends Layout {\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n if (this._widget) {\n let widget = this._widget;\n this._widget = null;\n widget.dispose();\n }\n super.dispose();\n }\n\n /**\n * Get the child widget for the layout.\n */\n get widget(): Widget | null {\n return this._widget;\n }\n\n /**\n * Set the child widget for the layout.\n *\n * #### Notes\n * Setting the child widget will cause the old child widget to be\n * automatically disposed. If that is not desired, set the parent\n * of the old child to `null` before assigning a new child.\n */\n set widget(widget: Widget | null) {\n // Remove the widget from its current parent. This is a no-op\n // if the widget's parent is already the layout parent widget.\n if (widget) {\n widget.parent = this.parent;\n }\n\n // Bail early if the widget does not change.\n if (this._widget === widget) {\n return;\n }\n\n // Dispose of the old child widget.\n if (this._widget) {\n this._widget.dispose();\n }\n\n // Update the internal widget.\n this._widget = widget;\n\n // Attach the new child widget if needed.\n if (this.parent && widget) {\n this.attachWidget(widget);\n }\n }\n\n /**\n * Create an iterator over the widgets in the layout.\n *\n * @returns A new iterator over the widgets in the layout.\n */\n *[Symbol.iterator](): IterableIterator {\n if (this._widget) {\n yield this._widget;\n }\n }\n\n /**\n * Remove a widget from the layout.\n *\n * @param widget - The widget to remove from the layout.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method does *not* modify the widget's `parent`.\n */\n removeWidget(widget: Widget): void {\n // Bail early if the widget does not exist in the layout.\n if (this._widget !== widget) {\n return;\n }\n\n // Clear the internal widget.\n this._widget = null;\n\n // If the layout is parented, detach the widget from the DOM.\n if (this.parent) {\n this.detachWidget(widget);\n }\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n super.init();\n for (const widget of this) {\n this.attachWidget(widget);\n }\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This method is called automatically by the single layout at the\n * appropriate time. It should not be called directly by user code.\n *\n * The default implementation adds the widgets's node to the parent's\n * node at the proper location, and sends the appropriate attach\n * messages to the widget if the parent is attached to the DOM.\n *\n * Subclasses may reimplement this method to control how the widget's\n * node is added to the parent's node.\n */\n protected attachWidget(widget: Widget): void {\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget's node to the parent.\n this.parent!.node.appendChild(widget.node);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This method is called automatically by the single layout at the\n * appropriate time. It should not be called directly by user code.\n *\n * The default implementation removes the widget's node from the\n * parent's node, and sends the appropriate detach messages to the\n * widget if the parent is attached to the DOM.\n *\n * Subclasses may reimplement this method to control how the widget's\n * node is removed from the parent's node.\n */\n protected detachWidget(widget: Widget): void {\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n }\n\n private _widget: Widget | null = null;\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { Layout, LayoutItem } from './layout';\n\nimport { PanelLayout } from './panellayout';\n\nimport { Widget } from './widget';\n\n/**\n * A layout where visible widgets are stacked atop one another.\n *\n * #### Notes\n * The Z-order of the visible widgets follows their layout order.\n */\nexport class StackedLayout extends PanelLayout {\n constructor(options: StackedLayout.IOptions = {}) {\n super(options);\n this._hiddenMode =\n options.hiddenMode !== undefined\n ? options.hiddenMode\n : Widget.HiddenMode.Display;\n }\n\n /**\n * The method for hiding widgets.\n *\n * #### Notes\n * If there is only one child widget, `Display` hiding mode will be used\n * regardless of this setting.\n */\n get hiddenMode(): Widget.HiddenMode {\n return this._hiddenMode;\n }\n\n /**\n * Set the method for hiding widgets.\n *\n * #### Notes\n * If there is only one child widget, `Display` hiding mode will be used\n * regardless of this setting.\n */\n set hiddenMode(v: Widget.HiddenMode) {\n if (this._hiddenMode === v) {\n return;\n }\n this._hiddenMode = v;\n if (this.widgets.length > 1) {\n this.widgets.forEach(w => {\n w.hiddenMode = this._hiddenMode;\n });\n }\n }\n\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n // Dispose of the layout items.\n for (const item of this._items) {\n item.dispose();\n }\n\n // Clear the layout state.\n this._box = null;\n this._items.length = 0;\n\n // Dispose of the rest of the layout.\n super.dispose();\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param index - The current index of the widget in the layout.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected attachWidget(index: number, widget: Widget): void {\n // Using transform create an additional layer in the pixel pipeline\n // to limit the number of layer, it is set only if there is more than one widget.\n if (\n this._hiddenMode === Widget.HiddenMode.Scale &&\n this._items.length > 0\n ) {\n if (this._items.length === 1) {\n this.widgets[0].hiddenMode = Widget.HiddenMode.Scale;\n }\n widget.hiddenMode = Widget.HiddenMode.Scale;\n } else {\n widget.hiddenMode = Widget.HiddenMode.Display;\n }\n\n // Create and add a new layout item for the widget.\n ArrayExt.insert(this._items, index, new LayoutItem(widget));\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget's node to the parent.\n this.parent!.node.appendChild(widget.node);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * Move a widget in the parent's DOM node.\n *\n * @param fromIndex - The previous index of the widget in the layout.\n *\n * @param toIndex - The current index of the widget in the layout.\n *\n * @param widget - The widget to move in the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected moveWidget(\n fromIndex: number,\n toIndex: number,\n widget: Widget\n ): void {\n // Move the layout item for the widget.\n ArrayExt.move(this._items, fromIndex, toIndex);\n\n // Post an update request for the parent widget.\n this.parent!.update();\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param index - The previous index of the widget in the layout.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected detachWidget(index: number, widget: Widget): void {\n // Remove the layout item for the widget.\n let item = ArrayExt.removeAt(this._items, index);\n\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Reset the z-index for the widget.\n item!.widget.node.style.zIndex = '';\n\n // Reset the hidden mode for the widget.\n if (this._hiddenMode === Widget.HiddenMode.Scale) {\n widget.hiddenMode = Widget.HiddenMode.Display;\n\n // Reset the hidden mode for the first widget if necessary.\n if (this._items.length === 1) {\n this._items[0].widget.hiddenMode = Widget.HiddenMode.Display;\n }\n }\n\n // Dispose of the layout item.\n item!.dispose();\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n */\n protected onBeforeShow(msg: Message): void {\n super.onBeforeShow(msg);\n this.parent!.update();\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n super.onBeforeAttach(msg);\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n if (this.parent!.isVisible) {\n this._update(msg.width, msg.height);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.parent!.isVisible) {\n this._update(-1, -1);\n }\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n */\n protected onFitRequest(msg: Message): void {\n if (this.parent!.isAttached) {\n this._fit();\n }\n }\n\n /**\n * Fit the layout to the total size required by the widgets.\n */\n private _fit(): void {\n // Set up the computed minimum size.\n let minW = 0;\n let minH = 0;\n\n // Update the computed minimum size.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item.\n let item = this._items[i];\n\n // Ignore hidden items.\n if (item.isHidden) {\n continue;\n }\n\n // Update the size limits for the item.\n item.fit();\n\n // Update the computed minimum size.\n minW = Math.max(minW, item.minWidth);\n minH = Math.max(minH, item.minHeight);\n }\n\n // Update the box sizing and add it to the computed min size.\n let box = (this._box = ElementExt.boxSizing(this.parent!.node));\n minW += box.horizontalSum;\n minH += box.verticalSum;\n\n // Update the parent's min size constraints.\n let style = this.parent!.node.style;\n style.minWidth = `${minW}px`;\n style.minHeight = `${minH}px`;\n\n // Set the dirty flag to ensure only a single update occurs.\n this._dirty = true;\n\n // Notify the ancestor that it should fit immediately. This may\n // cause a resize of the parent, fulfilling the required update.\n if (this.parent!.parent) {\n MessageLoop.sendMessage(this.parent!.parent!, Widget.Msg.FitRequest);\n }\n\n // If the dirty flag is still set, the parent was not resized.\n // Trigger the required update on the parent widget immediately.\n if (this._dirty) {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n }\n }\n\n /**\n * Update the layout position and size of the widgets.\n *\n * The parent offset dimensions should be `-1` if unknown.\n */\n private _update(offsetWidth: number, offsetHeight: number): void {\n // Clear the dirty flag to indicate the update occurred.\n this._dirty = false;\n\n // Compute the visible item count.\n let nVisible = 0;\n for (let i = 0, n = this._items.length; i < n; ++i) {\n nVisible += +!this._items[i].isHidden;\n }\n\n // Bail early if there are no visible items to layout.\n if (nVisible === 0) {\n return;\n }\n\n // Measure the parent if the offset dimensions are unknown.\n if (offsetWidth < 0) {\n offsetWidth = this.parent!.node.offsetWidth;\n }\n if (offsetHeight < 0) {\n offsetHeight = this.parent!.node.offsetHeight;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent!.node);\n }\n\n // Compute the actual layout bounds adjusted for border and padding.\n let top = this._box.paddingTop;\n let left = this._box.paddingLeft;\n let width = offsetWidth - this._box.horizontalSum;\n let height = offsetHeight - this._box.verticalSum;\n\n // Update the widget stacking order and layout geometry.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item.\n let item = this._items[i];\n\n // Ignore hidden items.\n if (item.isHidden) {\n continue;\n }\n\n // Set the z-index for the widget.\n item.widget.node.style.zIndex = `${i}`;\n\n // Update the item geometry.\n item.update(left, top, width, height);\n }\n }\n\n private _dirty = false;\n private _items: LayoutItem[] = [];\n private _box: ElementExt.IBoxSizing | null = null;\n private _hiddenMode: Widget.HiddenMode;\n}\n\n/**\n * The namespace for the `StackedLayout` class statics.\n */\nexport namespace StackedLayout {\n /**\n * An options object for initializing a stacked layout.\n */\n export interface IOptions extends Layout.IOptions {\n /**\n * The method for hiding widgets.\n *\n * The default is `Widget.HiddenMode.Display`.\n */\n hiddenMode?: Widget.HiddenMode;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { Panel } from './panel';\n\nimport { StackedLayout } from './stackedlayout';\n\nimport { Widget } from './widget';\n\n/**\n * A panel where visible widgets are stacked atop one another.\n *\n * #### Notes\n * This class provides a convenience wrapper around a {@link StackedLayout}.\n */\nexport class StackedPanel extends Panel {\n /**\n * Construct a new stacked panel.\n *\n * @param options - The options for initializing the panel.\n */\n constructor(options: StackedPanel.IOptions = {}) {\n super({ layout: Private.createLayout(options) });\n this.addClass('lm-StackedPanel');\n }\n\n /**\n * The method for hiding widgets.\n *\n * #### Notes\n * If there is only one child widget, `Display` hiding mode will be used\n * regardless of this setting.\n */\n get hiddenMode(): Widget.HiddenMode {\n return (this.layout as StackedLayout).hiddenMode;\n }\n\n /**\n * Set the method for hiding widgets.\n *\n * #### Notes\n * If there is only one child widget, `Display` hiding mode will be used\n * regardless of this setting.\n */\n set hiddenMode(v: Widget.HiddenMode) {\n (this.layout as StackedLayout).hiddenMode = v;\n }\n\n /**\n * A signal emitted when a widget is removed from a stacked panel.\n */\n get widgetRemoved(): ISignal {\n return this._widgetRemoved;\n }\n\n /**\n * A message handler invoked on a `'child-added'` message.\n */\n protected onChildAdded(msg: Widget.ChildMessage): void {\n msg.child.addClass('lm-StackedPanel-child');\n }\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {\n msg.child.removeClass('lm-StackedPanel-child');\n this._widgetRemoved.emit(msg.child);\n }\n\n private _widgetRemoved = new Signal(this);\n}\n\n/**\n * The namespace for the `StackedPanel` class statics.\n */\nexport namespace StackedPanel {\n /**\n * An options object for creating a stacked panel.\n */\n export interface IOptions {\n /**\n * The stacked layout to use for the stacked panel.\n *\n * The default is a new `StackedLayout`.\n */\n layout?: StackedLayout;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Create a stacked layout for the given panel options.\n */\n export function createLayout(options: StackedPanel.IOptions): StackedLayout {\n return options.layout || new StackedLayout();\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { Platform } from '@lumino/domutils';\n\nimport { MessageLoop } from '@lumino/messaging';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { BoxLayout } from './boxlayout';\n\nimport { StackedPanel } from './stackedpanel';\n\nimport { TabBar } from './tabbar';\n\nimport { Widget } from './widget';\n\n/**\n * A widget which combines a `TabBar` and a `StackedPanel`.\n *\n * #### Notes\n * This is a simple panel which handles the common case of a tab bar\n * placed next to a content area. The selected tab controls the widget\n * which is shown in the content area.\n *\n * For use cases which require more control than is provided by this\n * panel, the `TabBar` widget may be used independently.\n */\nexport class TabPanel extends Widget {\n /**\n * Construct a new tab panel.\n *\n * @param options - The options for initializing the tab panel.\n */\n constructor(options: TabPanel.IOptions = {}) {\n super();\n this.addClass('lm-TabPanel');\n\n // Create the tab bar and stacked panel.\n this.tabBar = new TabBar(options);\n this.tabBar.addClass('lm-TabPanel-tabBar');\n this.stackedPanel = new StackedPanel();\n this.stackedPanel.addClass('lm-TabPanel-stackedPanel');\n\n // Connect the tab bar signal handlers.\n this.tabBar.tabMoved.connect(this._onTabMoved, this);\n this.tabBar.currentChanged.connect(this._onCurrentChanged, this);\n this.tabBar.tabCloseRequested.connect(this._onTabCloseRequested, this);\n this.tabBar.tabActivateRequested.connect(\n this._onTabActivateRequested,\n this\n );\n this.tabBar.addRequested.connect(this._onTabAddRequested, this);\n\n // Connect the stacked panel signal handlers.\n this.stackedPanel.widgetRemoved.connect(this._onWidgetRemoved, this);\n\n // Get the data related to the placement.\n this._tabPlacement = options.tabPlacement || 'top';\n let direction = Private.directionFromPlacement(this._tabPlacement);\n let orientation = Private.orientationFromPlacement(this._tabPlacement);\n\n // Configure the tab bar for the placement.\n this.tabBar.orientation = orientation;\n this.tabBar.dataset['placement'] = this._tabPlacement;\n\n // Create the box layout.\n let layout = new BoxLayout({ direction, spacing: 0 });\n\n // Set the stretch factors for the child widgets.\n BoxLayout.setStretch(this.tabBar, 0);\n BoxLayout.setStretch(this.stackedPanel, 1);\n\n // Add the child widgets to the layout.\n layout.addWidget(this.tabBar);\n layout.addWidget(this.stackedPanel);\n\n // Install the layout on the tab panel.\n this.layout = layout;\n }\n\n /**\n * A signal emitted when the current tab is changed.\n *\n * #### Notes\n * This signal is emitted when the currently selected tab is changed\n * either through user or programmatic interaction.\n *\n * Notably, this signal is not emitted when the index of the current\n * tab changes due to tabs being inserted, removed, or moved. It is\n * only emitted when the actual current tab node is changed.\n */\n get currentChanged(): ISignal {\n return this._currentChanged;\n }\n\n /**\n * Get the index of the currently selected tab.\n *\n * #### Notes\n * This will be `-1` if no tab is selected.\n */\n get currentIndex(): number {\n return this.tabBar.currentIndex;\n }\n\n /**\n * Set the index of the currently selected tab.\n *\n * #### Notes\n * If the index is out of range, it will be set to `-1`.\n */\n set currentIndex(value: number) {\n this.tabBar.currentIndex = value;\n }\n\n /**\n * Get the currently selected widget.\n *\n * #### Notes\n * This will be `null` if there is no selected tab.\n */\n get currentWidget(): Widget | null {\n let title = this.tabBar.currentTitle;\n return title ? title.owner : null;\n }\n\n /**\n * Set the currently selected widget.\n *\n * #### Notes\n * If the widget is not in the panel, it will be set to `null`.\n */\n set currentWidget(value: Widget | null) {\n this.tabBar.currentTitle = value ? value.title : null;\n }\n\n /**\n * Get the whether the tabs are movable by the user.\n *\n * #### Notes\n * Tabs can always be moved programmatically.\n */\n get tabsMovable(): boolean {\n return this.tabBar.tabsMovable;\n }\n\n /**\n * Set the whether the tabs are movable by the user.\n *\n * #### Notes\n * Tabs can always be moved programmatically.\n */\n set tabsMovable(value: boolean) {\n this.tabBar.tabsMovable = value;\n }\n\n /**\n * Get the whether the add button is enabled.\n *\n */\n get addButtonEnabled(): boolean {\n return this.tabBar.addButtonEnabled;\n }\n\n /**\n * Set the whether the add button is enabled.\n *\n */\n set addButtonEnabled(value: boolean) {\n this.tabBar.addButtonEnabled = value;\n }\n\n /**\n * Get the tab placement for the tab panel.\n *\n * #### Notes\n * This controls the position of the tab bar relative to the content.\n */\n get tabPlacement(): TabPanel.TabPlacement {\n return this._tabPlacement;\n }\n\n /**\n * Set the tab placement for the tab panel.\n *\n * #### Notes\n * This controls the position of the tab bar relative to the content.\n */\n set tabPlacement(value: TabPanel.TabPlacement) {\n // Bail if the placement does not change.\n if (this._tabPlacement === value) {\n return;\n }\n\n // Update the internal value.\n this._tabPlacement = value;\n\n // Get the values related to the placement.\n let direction = Private.directionFromPlacement(value);\n let orientation = Private.orientationFromPlacement(value);\n\n // Configure the tab bar for the placement.\n this.tabBar.orientation = orientation;\n this.tabBar.dataset['placement'] = value;\n\n // Update the layout direction.\n (this.layout as BoxLayout).direction = direction;\n }\n\n /**\n * A signal emitted when the add button on a tab bar is clicked.\n *\n */\n get addRequested(): ISignal> {\n return this._addRequested;\n }\n\n /**\n * The tab bar used by the tab panel.\n *\n * #### Notes\n * Modifying the tab bar directly can lead to undefined behavior.\n */\n readonly tabBar: TabBar;\n\n /**\n * The stacked panel used by the tab panel.\n *\n * #### Notes\n * Modifying the panel directly can lead to undefined behavior.\n */\n readonly stackedPanel: StackedPanel;\n\n /**\n * A read-only array of the widgets in the panel.\n */\n get widgets(): ReadonlyArray {\n return this.stackedPanel.widgets;\n }\n\n /**\n * Add a widget to the end of the tab panel.\n *\n * @param widget - The widget to add to the tab panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n *\n * The widget's `title` is used to populate the tab.\n */\n addWidget(widget: Widget): void {\n this.insertWidget(this.widgets.length, widget);\n }\n\n /**\n * Insert a widget into the tab panel at a specified index.\n *\n * @param index - The index at which to insert the widget.\n *\n * @param widget - The widget to insert into to the tab panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n *\n * The widget's `title` is used to populate the tab.\n */\n insertWidget(index: number, widget: Widget): void {\n if (widget !== this.currentWidget) {\n widget.hide();\n }\n this.stackedPanel.insertWidget(index, widget);\n this.tabBar.insertTab(index, widget.title);\n\n widget.node.setAttribute('role', 'tabpanel');\n\n let renderer = this.tabBar.renderer;\n if (renderer instanceof TabBar.Renderer) {\n let tabId = renderer.createTabKey({\n title: widget.title,\n current: false,\n zIndex: 0\n });\n widget.node.setAttribute('aria-labelledby', tabId);\n }\n }\n\n /**\n * Handle the `currentChanged` signal from the tab bar.\n */\n private _onCurrentChanged(\n sender: TabBar,\n args: TabBar.ICurrentChangedArgs\n ): void {\n // Extract the previous and current title from the args.\n let { previousIndex, previousTitle, currentIndex, currentTitle } = args;\n\n // Extract the widgets from the titles.\n let previousWidget = previousTitle ? previousTitle.owner : null;\n let currentWidget = currentTitle ? currentTitle.owner : null;\n\n // Hide the previous widget.\n if (previousWidget) {\n previousWidget.hide();\n }\n\n // Show the current widget.\n if (currentWidget) {\n currentWidget.show();\n }\n\n // Emit the `currentChanged` signal for the tab panel.\n this._currentChanged.emit({\n previousIndex,\n previousWidget,\n currentIndex,\n currentWidget\n });\n\n // Flush the message loop on IE and Edge to prevent flicker.\n if (Platform.IS_EDGE || Platform.IS_IE) {\n MessageLoop.flush();\n }\n }\n\n /**\n * Handle the `tabAddRequested` signal from the tab bar.\n */\n private _onTabAddRequested(sender: TabBar, args: void): void {\n this._addRequested.emit(sender);\n }\n\n /**\n * Handle the `tabActivateRequested` signal from the tab bar.\n */\n private _onTabActivateRequested(\n sender: TabBar,\n args: TabBar.ITabActivateRequestedArgs\n ): void {\n args.title.owner.activate();\n }\n\n /**\n * Handle the `tabCloseRequested` signal from the tab bar.\n */\n private _onTabCloseRequested(\n sender: TabBar,\n args: TabBar.ITabCloseRequestedArgs\n ): void {\n args.title.owner.close();\n }\n\n /**\n * Handle the `tabMoved` signal from the tab bar.\n */\n private _onTabMoved(\n sender: TabBar,\n args: TabBar.ITabMovedArgs\n ): void {\n this.stackedPanel.insertWidget(args.toIndex, args.title.owner);\n }\n\n /**\n * Handle the `widgetRemoved` signal from the stacked panel.\n */\n private _onWidgetRemoved(sender: StackedPanel, widget: Widget): void {\n widget.node.removeAttribute('role');\n widget.node.removeAttribute('aria-labelledby');\n this.tabBar.removeTab(widget.title);\n }\n\n private _tabPlacement: TabPanel.TabPlacement;\n private _currentChanged = new Signal(\n this\n );\n\n private _addRequested = new Signal>(this);\n}\n\n/**\n * The namespace for the `TabPanel` class statics.\n */\nexport namespace TabPanel {\n /**\n * A type alias for tab placement in a tab bar.\n */\n export type TabPlacement =\n | /**\n * The tabs are placed as a row above the content.\n */\n 'top'\n\n /**\n * The tabs are placed as a column to the left of the content.\n */\n | 'left'\n\n /**\n * The tabs are placed as a column to the right of the content.\n */\n | 'right'\n\n /**\n * The tabs are placed as a row below the content.\n */\n | 'bottom';\n\n /**\n * An options object for initializing a tab panel.\n */\n export interface IOptions {\n /**\n * The document to use with the tab panel.\n *\n * The default is the global `document` instance.\n */\n document?: Document | ShadowRoot;\n\n /**\n * Whether the tabs are movable by the user.\n *\n * The default is `false`.\n */\n tabsMovable?: boolean;\n\n /**\n * Whether the button to add new tabs is enabled.\n *\n * The default is `false`.\n */\n addButtonEnabled?: boolean;\n\n /**\n * The placement of the tab bar relative to the content.\n *\n * The default is `'top'`.\n */\n tabPlacement?: TabPlacement;\n\n /**\n * The renderer for the panel's tab bar.\n *\n * The default is a shared renderer instance.\n */\n renderer?: TabBar.IRenderer;\n }\n\n /**\n * The arguments object for the `currentChanged` signal.\n */\n export interface ICurrentChangedArgs {\n /**\n * The previously selected index.\n */\n previousIndex: number;\n\n /**\n * The previously selected widget.\n */\n previousWidget: Widget | null;\n\n /**\n * The currently selected index.\n */\n currentIndex: number;\n\n /**\n * The currently selected widget.\n */\n currentWidget: Widget | null;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Convert a tab placement to tab bar orientation.\n */\n export function orientationFromPlacement(\n plc: TabPanel.TabPlacement\n ): TabBar.Orientation {\n return placementToOrientationMap[plc];\n }\n\n /**\n * Convert a tab placement to a box layout direction.\n */\n export function directionFromPlacement(\n plc: TabPanel.TabPlacement\n ): BoxLayout.Direction {\n return placementToDirectionMap[plc];\n }\n\n /**\n * A mapping of tab placement to tab bar orientation.\n */\n const placementToOrientationMap: { [key: string]: TabBar.Orientation } = {\n top: 'horizontal',\n left: 'vertical',\n right: 'vertical',\n bottom: 'horizontal'\n };\n\n /**\n * A mapping of tab placement to box layout direction.\n */\n const placementToDirectionMap: { [key: string]: BoxLayout.Direction } = {\n top: 'top-to-bottom',\n left: 'left-to-right',\n right: 'right-to-left',\n bottom: 'bottom-to-top'\n };\n}\n"],"names":["Private","Utils"],"mappings":"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"} +\ No newline at end of file ++{"version":3,"file":"index.es6.js","sources":["../src/boxengine.ts","../src/title.ts","../src/widget.ts","../src/layout.ts","../src/panellayout.ts","../src/utils.ts","../src/splitlayout.ts","../src/accordionlayout.ts","../src/panel.ts","../src/splitpanel.ts","../src/accordionpanel.ts","../src/boxlayout.ts","../src/boxpanel.ts","../src/commandpalette.ts","../src/menu.ts","../src/contextmenu.ts","../src/tabbar.ts","../src/docklayout.ts","../src/dockpanel.ts","../src/focustracker.ts","../src/gridlayout.ts","../src/menubar.ts","../src/scrollbar.ts","../src/singletonlayout.ts","../src/stackedlayout.ts","../src/stackedpanel.ts","../src/tabpanel.ts"],"sourcesContent":["// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\n\n/**\n * A sizer object for use with the box engine layout functions.\n *\n * #### Notes\n * A box sizer holds the geometry information for an object along an\n * arbitrary layout orientation.\n *\n * For best performance, this class should be treated as a raw data\n * struct. It should not typically be subclassed.\n */\nexport class BoxSizer {\n /**\n * The preferred size for the sizer.\n *\n * #### Notes\n * The sizer will be given this initial size subject to its size\n * bounds. The sizer will not deviate from this size unless such\n * deviation is required to fit into the available layout space.\n *\n * There is no limit to this value, but it will be clamped to the\n * bounds defined by {@link minSize} and {@link maxSize}.\n *\n * The default value is `0`.\n */\n sizeHint = 0;\n\n /**\n * The minimum size of the sizer.\n *\n * #### Notes\n * The sizer will never be sized less than this value, even if\n * it means the sizer will overflow the available layout space.\n *\n * It is assumed that this value lies in the range `[0, Infinity)`\n * and that it is `<=` to {@link maxSize}. Failure to adhere to this\n * constraint will yield undefined results.\n *\n * The default value is `0`.\n */\n minSize = 0;\n\n /**\n * The maximum size of the sizer.\n *\n * #### Notes\n * The sizer will never be sized greater than this value, even if\n * it means the sizer will underflow the available layout space.\n *\n * It is assumed that this value lies in the range `[0, Infinity]`\n * and that it is `>=` to {@link minSize}. Failure to adhere to this\n * constraint will yield undefined results.\n *\n * The default value is `Infinity`.\n */\n maxSize = Infinity;\n\n /**\n * The stretch factor for the sizer.\n *\n * #### Notes\n * This controls how much the sizer stretches relative to its sibling\n * sizers when layout space is distributed. A stretch factor of zero\n * is special and will cause the sizer to only be resized after all\n * other sizers with a stretch factor greater than zero have been\n * resized to their limits.\n *\n * It is assumed that this value is an integer that lies in the range\n * `[0, Infinity)`. Failure to adhere to this constraint will yield\n * undefined results.\n *\n * The default value is `1`.\n */\n stretch = 1;\n\n /**\n * The computed size of the sizer.\n *\n * #### Notes\n * This value is the output of a call to {@link BoxEngine.calc}. It represents\n * the computed size for the object along the layout orientation,\n * and will always lie in the range `[minSize, maxSize]`.\n *\n * This value is output only.\n *\n * Changing this value will have no effect.\n */\n size = 0;\n\n /**\n * An internal storage property for the layout algorithm.\n *\n * #### Notes\n * This value is used as temporary storage by the layout algorithm.\n *\n * Changing this value will have no effect.\n */\n done = false;\n}\n\n/**\n * The namespace for the box engine layout functions.\n */\nexport namespace BoxEngine {\n /**\n * Calculate the optimal layout sizes for a sequence of box sizers.\n *\n * This distributes the available layout space among the box sizers\n * according to the following algorithm:\n *\n * 1. Initialize the sizers's size to its size hint and compute the\n * sums for each of size hint, min size, and max size.\n *\n * 2. If the total size hint equals the available space, return.\n *\n * 3. If the available space is less than the total min size, set all\n * sizers to their min size and return.\n *\n * 4. If the available space is greater than the total max size, set\n * all sizers to their max size and return.\n *\n * 5. If the layout space is less than the total size hint, distribute\n * the negative delta as follows:\n *\n * a. Shrink each sizer with a stretch factor greater than zero by\n * an amount proportional to the negative space and the sum of\n * stretch factors. If the sizer reaches its min size, remove\n * it and its stretch factor from the computation.\n *\n * b. If after adjusting all stretch sizers there remains negative\n * space, distribute the space equally among the sizers with a\n * stretch factor of zero. If a sizer reaches its min size,\n * remove it from the computation.\n *\n * 6. If the layout space is greater than the total size hint,\n * distribute the positive delta as follows:\n *\n * a. Expand each sizer with a stretch factor greater than zero by\n * an amount proportional to the postive space and the sum of\n * stretch factors. If the sizer reaches its max size, remove\n * it and its stretch factor from the computation.\n *\n * b. If after adjusting all stretch sizers there remains positive\n * space, distribute the space equally among the sizers with a\n * stretch factor of zero. If a sizer reaches its max size,\n * remove it from the computation.\n *\n * 7. return\n *\n * @param sizers - The sizers for a particular layout line.\n *\n * @param space - The available layout space for the sizers.\n *\n * @returns The delta between the provided available space and the\n * actual consumed space. This value will be zero if the sizers\n * can be adjusted to fit, negative if the available space is too\n * small, and positive if the available space is too large.\n *\n * #### Notes\n * The {@link BoxSizer.size} of each sizer is updated with the computed size.\n *\n * This function can be called at any time to recompute the layout for\n * an existing sequence of sizers. The previously computed results will\n * have no effect on the new output. It is therefore not necessary to\n * create new sizer objects on each resize event.\n */\n export function calc(sizers: ArrayLike, space: number): number {\n // Bail early if there is nothing to do.\n let count = sizers.length;\n if (count === 0) {\n return space;\n }\n\n // Setup the size and stretch counters.\n let totalMin = 0;\n let totalMax = 0;\n let totalSize = 0;\n let totalStretch = 0;\n let stretchCount = 0;\n\n // Setup the sizers and compute the totals.\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n let min = sizer.minSize;\n let max = sizer.maxSize;\n let hint = sizer.sizeHint;\n sizer.done = false;\n sizer.size = Math.max(min, Math.min(hint, max));\n totalSize += sizer.size;\n totalMin += min;\n totalMax += max;\n if (sizer.stretch > 0) {\n totalStretch += sizer.stretch;\n stretchCount++;\n }\n }\n\n // If the space is equal to the total size, return early.\n if (space === totalSize) {\n return 0;\n }\n\n // If the space is less than the total min, minimize each sizer.\n if (space <= totalMin) {\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n sizer.size = sizer.minSize;\n }\n return space - totalMin;\n }\n\n // If the space is greater than the total max, maximize each sizer.\n if (space >= totalMax) {\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n sizer.size = sizer.maxSize;\n }\n return space - totalMax;\n }\n\n // The loops below perform sub-pixel precision sizing. A near zero\n // value is used for compares instead of zero to ensure that the\n // loop terminates when the subdivided space is reasonably small.\n let nearZero = 0.01;\n\n // A counter which is decremented each time a sizer is resized to\n // its limit. This ensures the loops terminate even if there is\n // space remaining to distribute.\n let notDoneCount = count;\n\n // Distribute negative delta space.\n if (space < totalSize) {\n // Shrink each stretchable sizer by an amount proportional to its\n // stretch factor. If a sizer reaches its min size it's marked as\n // done. The loop progresses in phases where each sizer is given\n // a chance to consume its fair share for the pass, regardless of\n // whether a sizer before it reached its limit. This continues\n // until the stretchable sizers or the free space is exhausted.\n let freeSpace = totalSize - space;\n while (stretchCount > 0 && freeSpace > nearZero) {\n let distSpace = freeSpace;\n let distStretch = totalStretch;\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n if (sizer.done || sizer.stretch === 0) {\n continue;\n }\n let amt = (sizer.stretch * distSpace) / distStretch;\n if (sizer.size - amt <= sizer.minSize) {\n freeSpace -= sizer.size - sizer.minSize;\n totalStretch -= sizer.stretch;\n sizer.size = sizer.minSize;\n sizer.done = true;\n notDoneCount--;\n stretchCount--;\n } else {\n freeSpace -= amt;\n sizer.size -= amt;\n }\n }\n }\n // Distribute any remaining space evenly among the non-stretchable\n // sizers. This progresses in phases in the same manner as above.\n while (notDoneCount > 0 && freeSpace > nearZero) {\n let amt = freeSpace / notDoneCount;\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n if (sizer.done) {\n continue;\n }\n if (sizer.size - amt <= sizer.minSize) {\n freeSpace -= sizer.size - sizer.minSize;\n sizer.size = sizer.minSize;\n sizer.done = true;\n notDoneCount--;\n } else {\n freeSpace -= amt;\n sizer.size -= amt;\n }\n }\n }\n }\n // Distribute positive delta space.\n else {\n // Expand each stretchable sizer by an amount proportional to its\n // stretch factor. If a sizer reaches its max size it's marked as\n // done. The loop progresses in phases where each sizer is given\n // a chance to consume its fair share for the pass, regardless of\n // whether a sizer before it reached its limit. This continues\n // until the stretchable sizers or the free space is exhausted.\n let freeSpace = space - totalSize;\n while (stretchCount > 0 && freeSpace > nearZero) {\n let distSpace = freeSpace;\n let distStretch = totalStretch;\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n if (sizer.done || sizer.stretch === 0) {\n continue;\n }\n let amt = (sizer.stretch * distSpace) / distStretch;\n if (sizer.size + amt >= sizer.maxSize) {\n freeSpace -= sizer.maxSize - sizer.size;\n totalStretch -= sizer.stretch;\n sizer.size = sizer.maxSize;\n sizer.done = true;\n notDoneCount--;\n stretchCount--;\n } else {\n freeSpace -= amt;\n sizer.size += amt;\n }\n }\n }\n // Distribute any remaining space evenly among the non-stretchable\n // sizers. This progresses in phases in the same manner as above.\n while (notDoneCount > 0 && freeSpace > nearZero) {\n let amt = freeSpace / notDoneCount;\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n if (sizer.done) {\n continue;\n }\n if (sizer.size + amt >= sizer.maxSize) {\n freeSpace -= sizer.maxSize - sizer.size;\n sizer.size = sizer.maxSize;\n sizer.done = true;\n notDoneCount--;\n } else {\n freeSpace -= amt;\n sizer.size += amt;\n }\n }\n }\n }\n\n // Indicate that the consumed space equals the available space.\n return 0;\n }\n\n /**\n * Adjust a sizer by a delta and update its neighbors accordingly.\n *\n * @param sizers - The sizers which should be adjusted.\n *\n * @param index - The index of the sizer to grow.\n *\n * @param delta - The amount to adjust the sizer, positive or negative.\n *\n * #### Notes\n * This will adjust the indicated sizer by the specified amount, along\n * with the sizes of the appropriate neighbors, subject to the limits\n * specified by each of the sizers.\n *\n * This is useful when implementing box layouts where the boundaries\n * between the sizers are interactively adjustable by the user.\n */\n export function adjust(\n sizers: ArrayLike,\n index: number,\n delta: number\n ): void {\n // Bail early when there is nothing to do.\n if (sizers.length === 0 || delta === 0) {\n return;\n }\n\n // Dispatch to the proper implementation.\n if (delta > 0) {\n growSizer(sizers, index, delta);\n } else {\n shrinkSizer(sizers, index, -delta);\n }\n }\n\n /**\n * Grow a sizer by a positive delta and adjust neighbors.\n */\n function growSizer(\n sizers: ArrayLike,\n index: number,\n delta: number\n ): void {\n // Compute how much the items to the left can expand.\n let growLimit = 0;\n for (let i = 0; i <= index; ++i) {\n let sizer = sizers[i];\n growLimit += sizer.maxSize - sizer.size;\n }\n\n // Compute how much the items to the right can shrink.\n let shrinkLimit = 0;\n for (let i = index + 1, n = sizers.length; i < n; ++i) {\n let sizer = sizers[i];\n shrinkLimit += sizer.size - sizer.minSize;\n }\n\n // Clamp the delta adjustment to the limits.\n delta = Math.min(delta, growLimit, shrinkLimit);\n\n // Grow the sizers to the left by the delta.\n let grow = delta;\n for (let i = index; i >= 0 && grow > 0; --i) {\n let sizer = sizers[i];\n let limit = sizer.maxSize - sizer.size;\n if (limit >= grow) {\n sizer.sizeHint = sizer.size + grow;\n grow = 0;\n } else {\n sizer.sizeHint = sizer.size + limit;\n grow -= limit;\n }\n }\n\n // Shrink the sizers to the right by the delta.\n let shrink = delta;\n for (let i = index + 1, n = sizers.length; i < n && shrink > 0; ++i) {\n let sizer = sizers[i];\n let limit = sizer.size - sizer.minSize;\n if (limit >= shrink) {\n sizer.sizeHint = sizer.size - shrink;\n shrink = 0;\n } else {\n sizer.sizeHint = sizer.size - limit;\n shrink -= limit;\n }\n }\n }\n\n /**\n * Shrink a sizer by a positive delta and adjust neighbors.\n */\n function shrinkSizer(\n sizers: ArrayLike,\n index: number,\n delta: number\n ): void {\n // Compute how much the items to the right can expand.\n let growLimit = 0;\n for (let i = index + 1, n = sizers.length; i < n; ++i) {\n let sizer = sizers[i];\n growLimit += sizer.maxSize - sizer.size;\n }\n\n // Compute how much the items to the left can shrink.\n let shrinkLimit = 0;\n for (let i = 0; i <= index; ++i) {\n let sizer = sizers[i];\n shrinkLimit += sizer.size - sizer.minSize;\n }\n\n // Clamp the delta adjustment to the limits.\n delta = Math.min(delta, growLimit, shrinkLimit);\n\n // Grow the sizers to the right by the delta.\n let grow = delta;\n for (let i = index + 1, n = sizers.length; i < n && grow > 0; ++i) {\n let sizer = sizers[i];\n let limit = sizer.maxSize - sizer.size;\n if (limit >= grow) {\n sizer.sizeHint = sizer.size + grow;\n grow = 0;\n } else {\n sizer.sizeHint = sizer.size + limit;\n grow -= limit;\n }\n }\n\n // Shrink the sizers to the left by the delta.\n let shrink = delta;\n for (let i = index; i >= 0 && shrink > 0; --i) {\n let sizer = sizers[i];\n let limit = sizer.size - sizer.minSize;\n if (limit >= shrink) {\n sizer.sizeHint = sizer.size - shrink;\n shrink = 0;\n } else {\n sizer.sizeHint = sizer.size - limit;\n shrink -= limit;\n }\n }\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { VirtualElement } from '@lumino/virtualdom';\n\n/**\n * An object which holds data related to an object's title.\n *\n * #### Notes\n * A title object is intended to hold the data necessary to display a\n * header for a particular object. A common example is the `TabPanel`,\n * which uses the widget title to populate the tab for a child widget.\n *\n * It is the responsibility of the owner to call the title disposal.\n */\nexport class Title implements IDisposable {\n /**\n * Construct a new title.\n *\n * @param options - The options for initializing the title.\n */\n constructor(options: Title.IOptions) {\n this.owner = options.owner;\n if (options.label !== undefined) {\n this._label = options.label;\n }\n if (options.mnemonic !== undefined) {\n this._mnemonic = options.mnemonic;\n }\n if (options.icon !== undefined) {\n this._icon = options.icon;\n }\n\n if (options.iconClass !== undefined) {\n this._iconClass = options.iconClass;\n }\n if (options.iconLabel !== undefined) {\n this._iconLabel = options.iconLabel;\n }\n if (options.caption !== undefined) {\n this._caption = options.caption;\n }\n if (options.className !== undefined) {\n this._className = options.className;\n }\n if (options.closable !== undefined) {\n this._closable = options.closable;\n }\n this._dataset = options.dataset || {};\n }\n\n /**\n * A signal emitted when the state of the title changes.\n */\n get changed(): ISignal {\n return this._changed;\n }\n\n /**\n * The object which owns the title.\n */\n readonly owner: T;\n\n /**\n * Get the label for the title.\n *\n * #### Notes\n * The default value is an empty string.\n */\n get label(): string {\n return this._label;\n }\n\n /**\n * Set the label for the title.\n */\n set label(value: string) {\n if (this._label === value) {\n return;\n }\n this._label = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the mnemonic index for the title.\n *\n * #### Notes\n * The default value is `-1`.\n */\n get mnemonic(): number {\n return this._mnemonic;\n }\n\n /**\n * Set the mnemonic index for the title.\n */\n set mnemonic(value: number) {\n if (this._mnemonic === value) {\n return;\n }\n this._mnemonic = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the icon renderer for the title.\n *\n * #### Notes\n * The default value is undefined.\n */\n get icon(): VirtualElement.IRenderer | undefined {\n return this._icon;\n }\n\n /**\n * Set the icon renderer for the title.\n *\n * #### Notes\n * A renderer is an object that supplies a render and unrender function.\n */\n set icon(value: VirtualElement.IRenderer | undefined) {\n if (this._icon === value) {\n return;\n }\n this._icon = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the icon class name for the title.\n *\n * #### Notes\n * The default value is an empty string.\n */\n get iconClass(): string {\n return this._iconClass;\n }\n\n /**\n * Set the icon class name for the title.\n *\n * #### Notes\n * Multiple class names can be separated with whitespace.\n */\n set iconClass(value: string) {\n if (this._iconClass === value) {\n return;\n }\n this._iconClass = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the icon label for the title.\n *\n * #### Notes\n * The default value is an empty string.\n */\n get iconLabel(): string {\n return this._iconLabel;\n }\n\n /**\n * Set the icon label for the title.\n *\n * #### Notes\n * Multiple class names can be separated with whitespace.\n */\n set iconLabel(value: string) {\n if (this._iconLabel === value) {\n return;\n }\n this._iconLabel = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the caption for the title.\n *\n * #### Notes\n * The default value is an empty string.\n */\n get caption(): string {\n return this._caption;\n }\n\n /**\n * Set the caption for the title.\n */\n set caption(value: string) {\n if (this._caption === value) {\n return;\n }\n this._caption = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the extra class name for the title.\n *\n * #### Notes\n * The default value is an empty string.\n */\n get className(): string {\n return this._className;\n }\n\n /**\n * Set the extra class name for the title.\n *\n * #### Notes\n * Multiple class names can be separated with whitespace.\n */\n set className(value: string) {\n if (this._className === value) {\n return;\n }\n this._className = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the closable state for the title.\n *\n * #### Notes\n * The default value is `false`.\n */\n get closable(): boolean {\n return this._closable;\n }\n\n /**\n * Set the closable state for the title.\n *\n * #### Notes\n * This controls the presence of a close icon when applicable.\n */\n set closable(value: boolean) {\n if (this._closable === value) {\n return;\n }\n this._closable = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the dataset for the title.\n *\n * #### Notes\n * The default value is an empty dataset.\n */\n get dataset(): Title.Dataset {\n return this._dataset;\n }\n\n /**\n * Set the dataset for the title.\n *\n * #### Notes\n * This controls the data attributes when applicable.\n */\n set dataset(value: Title.Dataset) {\n if (this._dataset === value) {\n return;\n }\n this._dataset = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Test whether the title has been disposed.\n */\n get isDisposed(): boolean {\n return this._isDisposed;\n }\n\n /**\n * Dispose of the resources held by the title.\n *\n * #### Notes\n * It is the responsibility of the owner to call the title disposal.\n */\n dispose(): void {\n if (this.isDisposed) {\n return;\n }\n this._isDisposed = true;\n\n Signal.clearData(this);\n }\n\n private _label = '';\n private _caption = '';\n private _mnemonic = -1;\n private _icon: VirtualElement.IRenderer | undefined = undefined;\n private _iconClass = '';\n private _iconLabel = '';\n private _className = '';\n private _closable = false;\n private _dataset: Title.Dataset;\n private _changed = new Signal(this);\n private _isDisposed = false;\n}\n\n/**\n * The namespace for the `Title` class statics.\n */\nexport namespace Title {\n /**\n * A type alias for a simple immutable string dataset.\n */\n export type Dataset = { readonly [key: string]: string };\n\n /**\n * An options object for initializing a title.\n */\n export interface IOptions {\n /**\n * The object which owns the title.\n */\n owner: T;\n\n /**\n * The label for the title.\n */\n label?: string;\n\n /**\n * The mnemonic index for the title.\n */\n mnemonic?: number;\n\n /**\n * The icon renderer for the title.\n */\n icon?: VirtualElement.IRenderer;\n\n /**\n * The icon class name for the title.\n */\n iconClass?: string;\n\n /**\n * The icon label for the title.\n */\n iconLabel?: string;\n\n /**\n * The caption for the title.\n */\n caption?: string;\n\n /**\n * The extra class name for the title.\n */\n className?: string;\n\n /**\n * The closable state for the title.\n */\n closable?: boolean;\n\n /**\n * The dataset for the title.\n */\n dataset?: Dataset;\n }\n}\n","/* eslint-disable @typescript-eslint/no-empty-function */\n// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { IObservableDisposable } from '@lumino/disposable';\n\nimport {\n ConflatableMessage,\n IMessageHandler,\n Message,\n MessageLoop\n} from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { Layout } from './layout';\n\nimport { Title } from './title';\n\n/**\n * The base class of the lumino widget hierarchy.\n *\n * #### Notes\n * This class will typically be subclassed in order to create a useful\n * widget. However, it can be used directly to host externally created\n * content.\n */\nexport class Widget implements IMessageHandler, IObservableDisposable {\n /**\n * Construct a new widget.\n *\n * @param options - The options for initializing the widget.\n */\n constructor(options: Widget.IOptions = {}) {\n this.node = Private.createNode(options);\n this.addClass('lm-Widget');\n }\n\n /**\n * Dispose of the widget and its descendant widgets.\n *\n * #### Notes\n * It is unsafe to use the widget after it has been disposed.\n *\n * All calls made to this method after the first are a no-op.\n */\n dispose(): void {\n // Do nothing if the widget is already disposed.\n if (this.isDisposed) {\n return;\n }\n\n // Set the disposed flag and emit the disposed signal.\n this.setFlag(Widget.Flag.IsDisposed);\n this._disposed.emit(undefined);\n\n // Remove or detach the widget if necessary.\n if (this.parent) {\n this.parent = null;\n } else if (this.isAttached) {\n Widget.detach(this);\n }\n\n // Dispose of the widget layout.\n if (this._layout) {\n this._layout.dispose();\n this._layout = null;\n }\n\n // Dispose the title\n this.title.dispose();\n\n // Clear the extra data associated with the widget.\n Signal.clearData(this);\n MessageLoop.clearData(this);\n AttachedProperty.clearData(this);\n }\n\n /**\n * A signal emitted when the widget is disposed.\n */\n get disposed(): ISignal {\n return this._disposed;\n }\n\n /**\n * Get the DOM node owned by the widget.\n */\n readonly node: HTMLElement;\n\n /**\n * Test whether the widget has been disposed.\n */\n get isDisposed(): boolean {\n return this.testFlag(Widget.Flag.IsDisposed);\n }\n\n /**\n * Test whether the widget's node is attached to the DOM.\n */\n get isAttached(): boolean {\n return this.testFlag(Widget.Flag.IsAttached);\n }\n\n /**\n * Test whether the widget is explicitly hidden.\n */\n get isHidden(): boolean {\n return this.testFlag(Widget.Flag.IsHidden);\n }\n\n /**\n * Test whether the widget is visible.\n *\n * #### Notes\n * A widget is visible when it is attached to the DOM, is not\n * explicitly hidden, and has no explicitly hidden ancestors.\n */\n get isVisible(): boolean {\n return this.testFlag(Widget.Flag.IsVisible);\n }\n\n /**\n * The title object for the widget.\n *\n * #### Notes\n * The title object is used by some container widgets when displaying\n * the widget alongside some title, such as a tab panel or side bar.\n *\n * Since not all widgets will use the title, it is created on demand.\n *\n * The `owner` property of the title is set to this widget.\n */\n get title(): Title {\n return Private.titleProperty.get(this);\n }\n\n /**\n * Get the id of the widget's DOM node.\n */\n get id(): string {\n return this.node.id;\n }\n\n /**\n * Set the id of the widget's DOM node.\n */\n set id(value: string) {\n this.node.id = value;\n }\n\n /**\n * The dataset for the widget's DOM node.\n */\n get dataset(): DOMStringMap {\n return this.node.dataset;\n }\n\n /**\n * Get the method for hiding the widget.\n */\n get hiddenMode(): Widget.HiddenMode {\n return this._hiddenMode;\n }\n\n /**\n * Set the method for hiding the widget.\n */\n set hiddenMode(value: Widget.HiddenMode) {\n if (this._hiddenMode === value) {\n return;\n }\n\n if (this.isHidden) {\n // Reset styles set by previous mode.\n this._toggleHidden(false);\n }\n\n if (value == Widget.HiddenMode.Scale) {\n this.node.style.willChange = 'transform';\n } else {\n this.node.style.willChange = 'auto';\n }\n\n this._hiddenMode = value;\n\n if (this.isHidden) {\n // Set styles for new mode.\n this._toggleHidden(true);\n }\n }\n\n /**\n * Get the parent of the widget.\n */\n get parent(): Widget | null {\n return this._parent;\n }\n\n /**\n * Set the parent of the widget.\n *\n * #### Notes\n * Children are typically added to a widget by using a layout, which\n * means user code will not normally set the parent widget directly.\n *\n * The widget will be automatically removed from its old parent.\n *\n * This is a no-op if there is no effective parent change.\n */\n set parent(value: Widget | null) {\n if (this._parent === value) {\n return;\n }\n if (value && this.contains(value)) {\n throw new Error('Invalid parent widget.');\n }\n if (this._parent && !this._parent.isDisposed) {\n let msg = new Widget.ChildMessage('child-removed', this);\n MessageLoop.sendMessage(this._parent, msg);\n }\n this._parent = value;\n if (this._parent && !this._parent.isDisposed) {\n let msg = new Widget.ChildMessage('child-added', this);\n MessageLoop.sendMessage(this._parent, msg);\n }\n if (!this.isDisposed) {\n MessageLoop.sendMessage(this, Widget.Msg.ParentChanged);\n }\n }\n\n /**\n * Get the layout for the widget.\n */\n get layout(): Layout | null {\n return this._layout;\n }\n\n /**\n * Set the layout for the widget.\n *\n * #### Notes\n * The layout is single-use only. It cannot be changed after the\n * first assignment.\n *\n * The layout is disposed automatically when the widget is disposed.\n */\n set layout(value: Layout | null) {\n if (this._layout === value) {\n return;\n }\n if (this.testFlag(Widget.Flag.DisallowLayout)) {\n throw new Error('Cannot set widget layout.');\n }\n if (this._layout) {\n throw new Error('Cannot change widget layout.');\n }\n if (value!.parent) {\n throw new Error('Cannot change layout parent.');\n }\n this._layout = value;\n value!.parent = this;\n }\n\n /**\n * Create an iterator over the widget's children.\n *\n * @returns A new iterator over the children of the widget.\n *\n * #### Notes\n * The widget must have a populated layout in order to have children.\n *\n * If a layout is not installed, the returned iterator will be empty.\n */\n *children(): IterableIterator {\n if (this._layout) {\n yield* this._layout;\n }\n }\n\n /**\n * Test whether a widget is a descendant of this widget.\n *\n * @param widget - The descendant widget of interest.\n *\n * @returns `true` if the widget is a descendant, `false` otherwise.\n */\n contains(widget: Widget): boolean {\n for (let value: Widget | null = widget; value; value = value._parent) {\n if (value === this) {\n return true;\n }\n }\n return false;\n }\n\n /**\n * Test whether the widget's DOM node has the given class name.\n *\n * @param name - The class name of interest.\n *\n * @returns `true` if the node has the class, `false` otherwise.\n */\n hasClass(name: string): boolean {\n return this.node.classList.contains(name);\n }\n\n /**\n * Add a class name to the widget's DOM node.\n *\n * @param name - The class name to add to the node.\n *\n * #### Notes\n * If the class name is already added to the node, this is a no-op.\n *\n * The class name must not contain whitespace.\n */\n addClass(name: string): void {\n this.node.classList.add(name);\n }\n\n /**\n * Remove a class name from the widget's DOM node.\n *\n * @param name - The class name to remove from the node.\n *\n * #### Notes\n * If the class name is not yet added to the node, this is a no-op.\n *\n * The class name must not contain whitespace.\n */\n removeClass(name: string): void {\n this.node.classList.remove(name);\n }\n\n /**\n * Toggle a class name on the widget's DOM node.\n *\n * @param name - The class name to toggle on the node.\n *\n * @param force - Whether to force add the class (`true`) or force\n * remove the class (`false`). If not provided, the presence of\n * the class will be toggled from its current state.\n *\n * @returns `true` if the class is now present, `false` otherwise.\n *\n * #### Notes\n * The class name must not contain whitespace.\n */\n toggleClass(name: string, force?: boolean): boolean {\n if (force === true) {\n this.node.classList.add(name);\n return true;\n }\n if (force === false) {\n this.node.classList.remove(name);\n return false;\n }\n return this.node.classList.toggle(name);\n }\n\n /**\n * Post an `'update-request'` message to the widget.\n *\n * #### Notes\n * This is a simple convenience method for posting the message.\n */\n update(): void {\n MessageLoop.postMessage(this, Widget.Msg.UpdateRequest);\n }\n\n /**\n * Post a `'fit-request'` message to the widget.\n *\n * #### Notes\n * This is a simple convenience method for posting the message.\n */\n fit(): void {\n MessageLoop.postMessage(this, Widget.Msg.FitRequest);\n }\n\n /**\n * Post an `'activate-request'` message to the widget.\n *\n * #### Notes\n * This is a simple convenience method for posting the message.\n */\n activate(): void {\n MessageLoop.postMessage(this, Widget.Msg.ActivateRequest);\n }\n\n /**\n * Send a `'close-request'` message to the widget.\n *\n * #### Notes\n * This is a simple convenience method for sending the message.\n */\n close(): void {\n MessageLoop.sendMessage(this, Widget.Msg.CloseRequest);\n }\n\n /**\n * Show the widget and make it visible to its parent widget.\n *\n * #### Notes\n * This causes the {@link isHidden} property to be `false`.\n *\n * If the widget is not explicitly hidden, this is a no-op.\n */\n show(): void {\n if (!this.testFlag(Widget.Flag.IsHidden)) {\n return;\n }\n if (this.isAttached && (!this.parent || this.parent.isVisible)) {\n MessageLoop.sendMessage(this, Widget.Msg.BeforeShow);\n }\n this.clearFlag(Widget.Flag.IsHidden);\n this._toggleHidden(false);\n\n if (this.isAttached && (!this.parent || this.parent.isVisible)) {\n MessageLoop.sendMessage(this, Widget.Msg.AfterShow);\n }\n if (this.parent) {\n let msg = new Widget.ChildMessage('child-shown', this);\n MessageLoop.sendMessage(this.parent, msg);\n }\n }\n\n /**\n * Hide the widget and make it hidden to its parent widget.\n *\n * #### Notes\n * This causes the {@link isHidden} property to be `true`.\n *\n * If the widget is explicitly hidden, this is a no-op.\n */\n hide(): void {\n if (this.testFlag(Widget.Flag.IsHidden)) {\n return;\n }\n if (this.isAttached && (!this.parent || this.parent.isVisible)) {\n MessageLoop.sendMessage(this, Widget.Msg.BeforeHide);\n }\n this.setFlag(Widget.Flag.IsHidden);\n this._toggleHidden(true);\n\n if (this.isAttached && (!this.parent || this.parent.isVisible)) {\n MessageLoop.sendMessage(this, Widget.Msg.AfterHide);\n }\n if (this.parent) {\n let msg = new Widget.ChildMessage('child-hidden', this);\n MessageLoop.sendMessage(this.parent, msg);\n }\n }\n\n /**\n * Show or hide the widget according to a boolean value.\n *\n * @param hidden - `true` to hide the widget, or `false` to show it.\n *\n * #### Notes\n * This is a convenience method for `hide()` and `show()`.\n */\n setHidden(hidden: boolean): void {\n if (hidden) {\n this.hide();\n } else {\n this.show();\n }\n }\n\n /**\n * Test whether the given widget flag is set.\n *\n * #### Notes\n * This will not typically be called directly by user code.\n */\n testFlag(flag: Widget.Flag): boolean {\n return (this._flags & flag) !== 0;\n }\n\n /**\n * Set the given widget flag.\n *\n * #### Notes\n * This will not typically be called directly by user code.\n */\n setFlag(flag: Widget.Flag): void {\n this._flags |= flag;\n }\n\n /**\n * Clear the given widget flag.\n *\n * #### Notes\n * This will not typically be called directly by user code.\n */\n clearFlag(flag: Widget.Flag): void {\n this._flags &= ~flag;\n }\n\n /**\n * Process a message sent to the widget.\n *\n * @param msg - The message sent to the widget.\n *\n * #### Notes\n * Subclasses may reimplement this method as needed.\n */\n processMessage(msg: Message): void {\n switch (msg.type) {\n case 'resize':\n this.notifyLayout(msg);\n this.onResize(msg as Widget.ResizeMessage);\n break;\n case 'update-request':\n this.notifyLayout(msg);\n this.onUpdateRequest(msg);\n break;\n case 'fit-request':\n this.notifyLayout(msg);\n this.onFitRequest(msg);\n break;\n case 'before-show':\n this.notifyLayout(msg);\n this.onBeforeShow(msg);\n break;\n case 'after-show':\n this.setFlag(Widget.Flag.IsVisible);\n this.notifyLayout(msg);\n this.onAfterShow(msg);\n break;\n case 'before-hide':\n this.notifyLayout(msg);\n this.onBeforeHide(msg);\n break;\n case 'after-hide':\n this.clearFlag(Widget.Flag.IsVisible);\n this.notifyLayout(msg);\n this.onAfterHide(msg);\n break;\n case 'before-attach':\n this.notifyLayout(msg);\n this.onBeforeAttach(msg);\n break;\n case 'after-attach':\n if (!this.isHidden && (!this.parent || this.parent.isVisible)) {\n this.setFlag(Widget.Flag.IsVisible);\n }\n this.setFlag(Widget.Flag.IsAttached);\n this.notifyLayout(msg);\n this.onAfterAttach(msg);\n break;\n case 'before-detach':\n this.notifyLayout(msg);\n this.onBeforeDetach(msg);\n break;\n case 'after-detach':\n this.clearFlag(Widget.Flag.IsVisible);\n this.clearFlag(Widget.Flag.IsAttached);\n this.notifyLayout(msg);\n this.onAfterDetach(msg);\n break;\n case 'activate-request':\n this.notifyLayout(msg);\n this.onActivateRequest(msg);\n break;\n case 'close-request':\n this.notifyLayout(msg);\n this.onCloseRequest(msg);\n break;\n case 'child-added':\n this.notifyLayout(msg);\n this.onChildAdded(msg as Widget.ChildMessage);\n break;\n case 'child-removed':\n this.notifyLayout(msg);\n this.onChildRemoved(msg as Widget.ChildMessage);\n break;\n default:\n this.notifyLayout(msg);\n break;\n }\n }\n\n /**\n * Invoke the message processing routine of the widget's layout.\n *\n * @param msg - The message to dispatch to the layout.\n *\n * #### Notes\n * This is a no-op if the widget does not have a layout.\n *\n * This will not typically be called directly by user code.\n */\n protected notifyLayout(msg: Message): void {\n if (this._layout) {\n this._layout.processParentMessage(msg);\n }\n }\n\n /**\n * A message handler invoked on a `'close-request'` message.\n *\n * #### Notes\n * The default implementation unparents or detaches the widget.\n */\n protected onCloseRequest(msg: Message): void {\n if (this.parent) {\n this.parent = null;\n } else if (this.isAttached) {\n Widget.detach(this);\n }\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onResize(msg: Widget.ResizeMessage): void {}\n\n /**\n * A message handler invoked on an `'update-request'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onUpdateRequest(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onFitRequest(msg: Message): void {}\n\n /**\n * A message handler invoked on an `'activate-request'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onActivateRequest(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'before-show'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onBeforeShow(msg: Message): void {}\n\n /**\n * A message handler invoked on an `'after-show'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onAfterShow(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'before-hide'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onBeforeHide(msg: Message): void {}\n\n /**\n * A message handler invoked on an `'after-hide'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onAfterHide(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onBeforeAttach(msg: Message): void {}\n\n /**\n * A message handler invoked on an `'after-attach'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onAfterAttach(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'before-detach'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onBeforeDetach(msg: Message): void {}\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onAfterDetach(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'child-added'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onChildAdded(msg: Widget.ChildMessage): void {}\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {}\n\n private _toggleHidden(hidden: boolean) {\n if (hidden) {\n switch (this._hiddenMode) {\n case Widget.HiddenMode.Display:\n this.addClass('lm-mod-hidden');\n break;\n case Widget.HiddenMode.Scale:\n this.node.style.transform = 'scale(0)';\n this.node.setAttribute('aria-hidden', 'true');\n break;\n case Widget.HiddenMode.ContentVisibility:\n // @ts-expect-error content-visibility unknown by DOM lib types\n this.node.style.contentVisibility = 'hidden';\n this.node.style.zIndex = '-1';\n break;\n }\n } else {\n switch (this._hiddenMode) {\n case Widget.HiddenMode.Display:\n this.removeClass('lm-mod-hidden');\n break;\n case Widget.HiddenMode.Scale:\n this.node.style.transform = '';\n this.node.removeAttribute('aria-hidden');\n break;\n case Widget.HiddenMode.ContentVisibility:\n // @ts-expect-error content-visibility unknown by DOM lib types\n this.node.style.contentVisibility = '';\n this.node.style.zIndex = '';\n break;\n }\n }\n }\n\n private _flags = 0;\n private _layout: Layout | null = null;\n private _parent: Widget | null = null;\n private _disposed = new Signal(this);\n private _hiddenMode: Widget.HiddenMode = Widget.HiddenMode.Display;\n}\n\n/**\n * The namespace for the `Widget` class statics.\n */\nexport namespace Widget {\n /**\n * An options object for initializing a widget.\n */\n export interface IOptions {\n /**\n * The optional node to use for the widget.\n *\n * If a node is provided, the widget will assume full ownership\n * and control of the node, as if it had created the node itself.\n *\n * The default is a new `
`.\n */\n node?: HTMLElement;\n\n /**\n * The optional element tag, used for constructing the widget's node.\n *\n * If a pre-constructed node is provided via the `node` arg, this\n * value is ignored.\n */\n tag?: keyof HTMLElementTagNameMap;\n }\n\n /**\n * The method for hiding the widget.\n *\n * The default is Display.\n *\n * Using `Scale` will often increase performance as most browsers will not\n * trigger style computation for the `transform` action. This should be used\n * sparingly and tested, since increasing the number of composition layers\n * may slow things down.\n *\n * To ensure the transformation does not trigger style recomputation, you\n * may need to set the widget CSS style `will-change: transform`. This\n * should be used only when needed as it may overwhelm the browser with a\n * high number of layers. See\n * https://developer.mozilla.org/en-US/docs/Web/CSS/will-change\n */\n export enum HiddenMode {\n /**\n * Set a `lm-mod-hidden` CSS class to hide the widget using `display:none`\n * CSS from the standard Lumino CSS.\n */\n Display = 0,\n\n /**\n * Hide the widget by setting the `transform` to `'scale(0)'`.\n */\n Scale,\n\n /**\n *Hide the widget by setting the `content-visibility` to `'hidden'`.\n */\n ContentVisibility\n }\n\n /**\n * An enum of widget bit flags.\n */\n export enum Flag {\n /**\n * The widget has been disposed.\n */\n IsDisposed = 0x1,\n\n /**\n * The widget is attached to the DOM.\n */\n IsAttached = 0x2,\n\n /**\n * The widget is hidden.\n */\n IsHidden = 0x4,\n\n /**\n * The widget is visible.\n */\n IsVisible = 0x8,\n\n /**\n * A layout cannot be set on the widget.\n */\n DisallowLayout = 0x10\n }\n\n /**\n * A collection of stateless messages related to widgets.\n */\n export namespace Msg {\n /**\n * A singleton `'before-show'` message.\n *\n * #### Notes\n * This message is sent to a widget before it becomes visible.\n *\n * This message is **not** sent when the widget is being attached.\n */\n export const BeforeShow = new Message('before-show');\n\n /**\n * A singleton `'after-show'` message.\n *\n * #### Notes\n * This message is sent to a widget after it becomes visible.\n *\n * This message is **not** sent when the widget is being attached.\n */\n export const AfterShow = new Message('after-show');\n\n /**\n * A singleton `'before-hide'` message.\n *\n * #### Notes\n * This message is sent to a widget before it becomes not-visible.\n *\n * This message is **not** sent when the widget is being detached.\n */\n export const BeforeHide = new Message('before-hide');\n\n /**\n * A singleton `'after-hide'` message.\n *\n * #### Notes\n * This message is sent to a widget after it becomes not-visible.\n *\n * This message is **not** sent when the widget is being detached.\n */\n export const AfterHide = new Message('after-hide');\n\n /**\n * A singleton `'before-attach'` message.\n *\n * #### Notes\n * This message is sent to a widget before it is attached.\n */\n export const BeforeAttach = new Message('before-attach');\n\n /**\n * A singleton `'after-attach'` message.\n *\n * #### Notes\n * This message is sent to a widget after it is attached.\n */\n export const AfterAttach = new Message('after-attach');\n\n /**\n * A singleton `'before-detach'` message.\n *\n * #### Notes\n * This message is sent to a widget before it is detached.\n */\n export const BeforeDetach = new Message('before-detach');\n\n /**\n * A singleton `'after-detach'` message.\n *\n * #### Notes\n * This message is sent to a widget after it is detached.\n */\n export const AfterDetach = new Message('after-detach');\n\n /**\n * A singleton `'parent-changed'` message.\n *\n * #### Notes\n * This message is sent to a widget when its parent has changed.\n */\n export const ParentChanged = new Message('parent-changed');\n\n /**\n * A singleton conflatable `'update-request'` message.\n *\n * #### Notes\n * This message can be dispatched to supporting widgets in order to\n * update their content based on the current widget state. Not all\n * widgets will respond to messages of this type.\n *\n * For widgets with a layout, this message will inform the layout to\n * update the position and size of its child widgets.\n */\n export const UpdateRequest = new ConflatableMessage('update-request');\n\n /**\n * A singleton conflatable `'fit-request'` message.\n *\n * #### Notes\n * For widgets with a layout, this message will inform the layout to\n * recalculate its size constraints to fit the space requirements of\n * its child widgets, and to update their position and size. Not all\n * layouts will respond to messages of this type.\n */\n export const FitRequest = new ConflatableMessage('fit-request');\n\n /**\n * A singleton conflatable `'activate-request'` message.\n *\n * #### Notes\n * This message should be dispatched to a widget when it should\n * perform the actions necessary to activate the widget, which\n * may include focusing its node or descendant node.\n */\n export const ActivateRequest = new ConflatableMessage('activate-request');\n\n /**\n * A singleton conflatable `'close-request'` message.\n *\n * #### Notes\n * This message should be dispatched to a widget when it should close\n * and remove itself from the widget hierarchy.\n */\n export const CloseRequest = new ConflatableMessage('close-request');\n }\n\n /**\n * A message class for child related messages.\n */\n export class ChildMessage extends Message {\n /**\n * Construct a new child message.\n *\n * @param type - The message type.\n *\n * @param child - The child widget for the message.\n */\n constructor(type: string, child: Widget) {\n super(type);\n this.child = child;\n }\n\n /**\n * The child widget for the message.\n */\n readonly child: Widget;\n }\n\n /**\n * A message class for `'resize'` messages.\n */\n export class ResizeMessage extends Message {\n /**\n * Construct a new resize message.\n *\n * @param width - The **offset width** of the widget, or `-1` if\n * the width is not known.\n *\n * @param height - The **offset height** of the widget, or `-1` if\n * the height is not known.\n */\n constructor(width: number, height: number) {\n super('resize');\n this.width = width;\n this.height = height;\n }\n\n /**\n * The offset width of the widget.\n *\n * #### Notes\n * This will be `-1` if the width is unknown.\n */\n readonly width: number;\n\n /**\n * The offset height of the widget.\n *\n * #### Notes\n * This will be `-1` if the height is unknown.\n */\n readonly height: number;\n }\n\n /**\n * The namespace for the `ResizeMessage` class statics.\n */\n export namespace ResizeMessage {\n /**\n * A singleton `'resize'` message with an unknown size.\n */\n export const UnknownSize = new ResizeMessage(-1, -1);\n }\n\n /**\n * Attach a widget to a host DOM node.\n *\n * @param widget - The widget of interest.\n *\n * @param host - The DOM node to use as the widget's host.\n *\n * @param ref - The child of `host` to use as the reference element.\n * If this is provided, the widget will be inserted before this\n * node in the host. The default is `null`, which will cause the\n * widget to be added as the last child of the host.\n *\n * #### Notes\n * This will throw an error if the widget is not a root widget, if\n * the widget is already attached, or if the host is not attached\n * to the DOM.\n */\n export function attach(\n widget: Widget,\n host: HTMLElement,\n ref: HTMLElement | null = null\n ): void {\n if (widget.parent) {\n throw new Error('Cannot attach a child widget.');\n }\n if (widget.isAttached || widget.node.isConnected) {\n throw new Error('Widget is already attached.');\n }\n if (!host.isConnected) {\n throw new Error('Host is not attached.');\n }\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n host.insertBefore(widget.node, ref);\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n\n /**\n * Detach the widget from its host DOM node.\n *\n * @param widget - The widget of interest.\n *\n * #### Notes\n * This will throw an error if the widget is not a root widget,\n * or if the widget is not attached to the DOM.\n */\n export function detach(widget: Widget): void {\n if (widget.parent) {\n throw new Error('Cannot detach a child widget.');\n }\n if (!widget.isAttached || !widget.node.isConnected) {\n throw new Error('Widget is not attached.');\n }\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n widget.node.parentNode!.removeChild(widget.node);\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * An attached property for the widget title object.\n */\n export const titleProperty = new AttachedProperty>({\n name: 'title',\n create: owner => new Title({ owner })\n });\n\n /**\n * Create a DOM node for the given widget options.\n */\n export function createNode(options: Widget.IOptions): HTMLElement {\n return options.node || document.createElement(options.tag || 'div');\n }\n}\n","/* eslint-disable @typescript-eslint/no-empty-function */\n// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { Signal } from '@lumino/signaling';\n\nimport { Widget } from './widget';\n\n/**\n * An abstract base class for creating lumino layouts.\n *\n * #### Notes\n * A layout is used to add widgets to a parent and to arrange those\n * widgets within the parent's DOM node.\n *\n * This class implements the base functionality which is required of\n * nearly all layouts. It must be subclassed in order to be useful.\n *\n * Notably, this class does not define a uniform interface for adding\n * widgets to the layout. A subclass should define that API in a way\n * which is meaningful for its intended use.\n */\nexport abstract class Layout implements Iterable, IDisposable {\n /**\n * Construct a new layout.\n *\n * @param options - The options for initializing the layout.\n */\n constructor(options: Layout.IOptions = {}) {\n this._fitPolicy = options.fitPolicy || 'set-min-size';\n }\n\n /**\n * Dispose of the resources held by the layout.\n *\n * #### Notes\n * This should be reimplemented to clear and dispose of the widgets.\n *\n * All reimplementations should call the superclass method.\n *\n * This method is called automatically when the parent is disposed.\n */\n dispose(): void {\n this._parent = null;\n this._disposed = true;\n Signal.clearData(this);\n AttachedProperty.clearData(this);\n }\n\n /**\n * Test whether the layout is disposed.\n */\n get isDisposed(): boolean {\n return this._disposed;\n }\n\n /**\n * Get the parent widget of the layout.\n */\n get parent(): Widget | null {\n return this._parent;\n }\n\n /**\n * Set the parent widget of the layout.\n *\n * #### Notes\n * This is set automatically when installing the layout on the parent\n * widget. The parent widget should not be set directly by user code.\n */\n set parent(value: Widget | null) {\n if (this._parent === value) {\n return;\n }\n if (this._parent) {\n throw new Error('Cannot change parent widget.');\n }\n if (value!.layout !== this) {\n throw new Error('Invalid parent widget.');\n }\n this._parent = value;\n this.init();\n }\n\n /**\n * Get the fit policy for the layout.\n *\n * #### Notes\n * The fit policy controls the computed size constraints which are\n * applied to the parent widget by the layout.\n *\n * Some layout implementations may ignore the fit policy.\n */\n get fitPolicy(): Layout.FitPolicy {\n return this._fitPolicy;\n }\n\n /**\n * Set the fit policy for the layout.\n *\n * #### Notes\n * The fit policy controls the computed size constraints which are\n * applied to the parent widget by the layout.\n *\n * Some layout implementations may ignore the fit policy.\n *\n * Changing the fit policy will clear the current size constraint\n * for the parent widget and then re-fit the parent.\n */\n set fitPolicy(value: Layout.FitPolicy) {\n // Bail if the policy does not change\n if (this._fitPolicy === value) {\n return;\n }\n\n // Update the internal policy.\n this._fitPolicy = value;\n\n // Clear the size constraints and schedule a fit of the parent.\n if (this._parent) {\n let style = this._parent.node.style;\n style.minWidth = '';\n style.minHeight = '';\n style.maxWidth = '';\n style.maxHeight = '';\n this._parent.fit();\n }\n }\n\n /**\n * Create an iterator over the widgets in the layout.\n *\n * @returns A new iterator over the widgets in the layout.\n *\n * #### Notes\n * This abstract method must be implemented by a subclass.\n */\n abstract [Symbol.iterator](): IterableIterator;\n\n /**\n * Remove a widget from the layout.\n *\n * @param widget - The widget to remove from the layout.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method should *not* modify the widget's `parent`.\n */\n abstract removeWidget(widget: Widget): void;\n\n /**\n * Process a message sent to the parent widget.\n *\n * @param msg - The message sent to the parent widget.\n *\n * #### Notes\n * This method is called by the parent widget to process a message.\n *\n * Subclasses may reimplement this method as needed.\n */\n processParentMessage(msg: Message): void {\n switch (msg.type) {\n case 'resize':\n this.onResize(msg as Widget.ResizeMessage);\n break;\n case 'update-request':\n this.onUpdateRequest(msg);\n break;\n case 'fit-request':\n this.onFitRequest(msg);\n break;\n case 'before-show':\n this.onBeforeShow(msg);\n break;\n case 'after-show':\n this.onAfterShow(msg);\n break;\n case 'before-hide':\n this.onBeforeHide(msg);\n break;\n case 'after-hide':\n this.onAfterHide(msg);\n break;\n case 'before-attach':\n this.onBeforeAttach(msg);\n break;\n case 'after-attach':\n this.onAfterAttach(msg);\n break;\n case 'before-detach':\n this.onBeforeDetach(msg);\n break;\n case 'after-detach':\n this.onAfterDetach(msg);\n break;\n case 'child-removed':\n this.onChildRemoved(msg as Widget.ChildMessage);\n break;\n case 'child-shown':\n this.onChildShown(msg as Widget.ChildMessage);\n break;\n case 'child-hidden':\n this.onChildHidden(msg as Widget.ChildMessage);\n break;\n }\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n *\n * #### Notes\n * This method is invoked immediately after the layout is installed\n * on the parent widget.\n *\n * The default implementation reparents all of the widgets to the\n * layout parent widget.\n *\n * Subclasses should reimplement this method and attach the child\n * widget nodes to the parent widget's node.\n */\n protected init(): void {\n for (const widget of this) {\n widget.parent = this.parent;\n }\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n *\n * #### Notes\n * The layout should ensure that its widgets are resized according\n * to the specified layout space, and that they are sent a `'resize'`\n * message if appropriate.\n *\n * The default implementation of this method sends an `UnknownSize`\n * resize message to all widgets.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, Widget.ResizeMessage.UnknownSize);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n *\n * #### Notes\n * The layout should ensure that its widgets are resized according\n * to the available layout space, and that they are sent a `'resize'`\n * message if appropriate.\n *\n * The default implementation of this method sends an `UnknownSize`\n * resize message to all widgets.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onUpdateRequest(msg: Message): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, Widget.ResizeMessage.UnknownSize);\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message\n * to all widgets. It assumes all widget nodes are attached to the\n * parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onBeforeAttach(msg: Message): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n\n /**\n * A message handler invoked on an `'after-attach'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message\n * to all widgets. It assumes all widget nodes are attached to the\n * parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onAfterAttach(msg: Message): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n\n /**\n * A message handler invoked on a `'before-detach'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message\n * to all widgets. It assumes all widget nodes are attached to the\n * parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onBeforeDetach(msg: Message): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message\n * to all widgets. It assumes all widget nodes are attached to the\n * parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onAfterDetach(msg: Message): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message to\n * all non-hidden widgets. It assumes all widget nodes are attached\n * to the parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onBeforeShow(msg: Message): void {\n for (const widget of this) {\n if (!widget.isHidden) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n }\n\n /**\n * A message handler invoked on an `'after-show'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message to\n * all non-hidden widgets. It assumes all widget nodes are attached\n * to the parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onAfterShow(msg: Message): void {\n for (const widget of this) {\n if (!widget.isHidden) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n }\n\n /**\n * A message handler invoked on a `'before-hide'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message to\n * all non-hidden widgets. It assumes all widget nodes are attached\n * to the parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onBeforeHide(msg: Message): void {\n for (const widget of this) {\n if (!widget.isHidden) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n }\n\n /**\n * A message handler invoked on an `'after-hide'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message to\n * all non-hidden widgets. It assumes all widget nodes are attached\n * to the parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onAfterHide(msg: Message): void {\n for (const widget of this) {\n if (!widget.isHidden) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n }\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n *\n * #### Notes\n * This will remove the child widget from the layout.\n *\n * Subclasses should **not** typically reimplement this method.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {\n this.removeWidget(msg.child);\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onFitRequest(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {}\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {}\n\n private _disposed = false;\n private _fitPolicy: Layout.FitPolicy;\n private _parent: Widget | null = null;\n}\n\n/**\n * The namespace for the `Layout` class statics.\n */\nexport namespace Layout {\n /**\n * A type alias for the layout fit policy.\n *\n * #### Notes\n * The fit policy controls the computed size constraints which are\n * applied to the parent widget by the layout.\n *\n * Some layout implementations may ignore the fit policy.\n */\n export type FitPolicy =\n | /**\n * No size constraint will be applied to the parent widget.\n */\n 'set-no-constraint'\n\n /**\n * The computed min size will be applied to the parent widget.\n */\n | 'set-min-size';\n\n /**\n * An options object for initializing a layout.\n */\n export interface IOptions {\n /**\n * The fit policy for the layout.\n *\n * The default is `'set-min-size'`.\n */\n fitPolicy?: FitPolicy;\n }\n\n /**\n * A type alias for the horizontal alignment of a widget.\n */\n export type HorizontalAlignment = 'left' | 'center' | 'right';\n\n /**\n * A type alias for the vertical alignment of a widget.\n */\n export type VerticalAlignment = 'top' | 'center' | 'bottom';\n\n /**\n * Get the horizontal alignment for a widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The horizontal alignment for the widget.\n *\n * #### Notes\n * If the layout width allocated to a widget is larger than its max\n * width, the horizontal alignment controls how the widget is placed\n * within the extra horizontal space.\n *\n * If the allocated width is less than the widget's max width, the\n * horizontal alignment has no effect.\n *\n * Some layout implementations may ignore horizontal alignment.\n */\n export function getHorizontalAlignment(widget: Widget): HorizontalAlignment {\n return Private.horizontalAlignmentProperty.get(widget);\n }\n\n /**\n * Set the horizontal alignment for a widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the horizontal alignment.\n *\n * #### Notes\n * If the layout width allocated to a widget is larger than its max\n * width, the horizontal alignment controls how the widget is placed\n * within the extra horizontal space.\n *\n * If the allocated width is less than the widget's max width, the\n * horizontal alignment has no effect.\n *\n * Some layout implementations may ignore horizontal alignment.\n *\n * Changing the horizontal alignment will post an `update-request`\n * message to widget's parent, provided the parent has a layout\n * installed.\n */\n export function setHorizontalAlignment(\n widget: Widget,\n value: HorizontalAlignment\n ): void {\n Private.horizontalAlignmentProperty.set(widget, value);\n }\n\n /**\n * Get the vertical alignment for a widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The vertical alignment for the widget.\n *\n * #### Notes\n * If the layout height allocated to a widget is larger than its max\n * height, the vertical alignment controls how the widget is placed\n * within the extra vertical space.\n *\n * If the allocated height is less than the widget's max height, the\n * vertical alignment has no effect.\n *\n * Some layout implementations may ignore vertical alignment.\n */\n export function getVerticalAlignment(widget: Widget): VerticalAlignment {\n return Private.verticalAlignmentProperty.get(widget);\n }\n\n /**\n * Set the vertical alignment for a widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the vertical alignment.\n *\n * #### Notes\n * If the layout height allocated to a widget is larger than its max\n * height, the vertical alignment controls how the widget is placed\n * within the extra vertical space.\n *\n * If the allocated height is less than the widget's max height, the\n * vertical alignment has no effect.\n *\n * Some layout implementations may ignore vertical alignment.\n *\n * Changing the horizontal alignment will post an `update-request`\n * message to widget's parent, provided the parent has a layout\n * installed.\n */\n export function setVerticalAlignment(\n widget: Widget,\n value: VerticalAlignment\n ): void {\n Private.verticalAlignmentProperty.set(widget, value);\n }\n}\n\n/**\n * An object which assists in the absolute layout of widgets.\n *\n * #### Notes\n * This class is useful when implementing a layout which arranges its\n * widgets using absolute positioning.\n *\n * This class is used by nearly all of the built-in lumino layouts.\n */\nexport class LayoutItem implements IDisposable {\n /**\n * Construct a new layout item.\n *\n * @param widget - The widget to be managed by the item.\n *\n * #### Notes\n * The widget will be set to absolute positioning.\n * The widget will use strict CSS containment.\n */\n constructor(widget: Widget) {\n this.widget = widget;\n this.widget.node.style.position = 'absolute';\n this.widget.node.style.contain = 'strict';\n }\n\n /**\n * Dispose of the the layout item.\n *\n * #### Notes\n * This will reset the positioning of the widget.\n */\n dispose(): void {\n // Do nothing if the item is already disposed.\n if (this._disposed) {\n return;\n }\n\n // Mark the item as disposed.\n this._disposed = true;\n\n // Reset the widget style.\n let style = this.widget.node.style;\n style.position = '';\n style.top = '';\n style.left = '';\n style.width = '';\n style.height = '';\n style.contain = '';\n }\n\n /**\n * The widget managed by the layout item.\n */\n readonly widget: Widget;\n\n /**\n * The computed minimum width of the widget.\n *\n * #### Notes\n * This value can be updated by calling the `fit` method.\n */\n get minWidth(): number {\n return this._minWidth;\n }\n\n /**\n * The computed minimum height of the widget.\n *\n * #### Notes\n * This value can be updated by calling the `fit` method.\n */\n get minHeight(): number {\n return this._minHeight;\n }\n\n /**\n * The computed maximum width of the widget.\n *\n * #### Notes\n * This value can be updated by calling the `fit` method.\n */\n get maxWidth(): number {\n return this._maxWidth;\n }\n\n /**\n * The computed maximum height of the widget.\n *\n * #### Notes\n * This value can be updated by calling the `fit` method.\n */\n get maxHeight(): number {\n return this._maxHeight;\n }\n\n /**\n * Whether the layout item is disposed.\n */\n get isDisposed(): boolean {\n return this._disposed;\n }\n\n /**\n * Whether the managed widget is hidden.\n */\n get isHidden(): boolean {\n return this.widget.isHidden;\n }\n\n /**\n * Whether the managed widget is visible.\n */\n get isVisible(): boolean {\n return this.widget.isVisible;\n }\n\n /**\n * Whether the managed widget is attached.\n */\n get isAttached(): boolean {\n return this.widget.isAttached;\n }\n\n /**\n * Update the computed size limits of the managed widget.\n */\n fit(): void {\n let limits = ElementExt.sizeLimits(this.widget.node);\n this._minWidth = limits.minWidth;\n this._minHeight = limits.minHeight;\n this._maxWidth = limits.maxWidth;\n this._maxHeight = limits.maxHeight;\n }\n\n /**\n * Update the position and size of the managed widget.\n *\n * @param left - The left edge position of the layout box.\n *\n * @param top - The top edge position of the layout box.\n *\n * @param width - The width of the layout box.\n *\n * @param height - The height of the layout box.\n */\n update(left: number, top: number, width: number, height: number): void {\n // Clamp the size to the computed size limits.\n let clampW = Math.max(this._minWidth, Math.min(width, this._maxWidth));\n let clampH = Math.max(this._minHeight, Math.min(height, this._maxHeight));\n\n // Adjust the left edge for the horizontal alignment, if needed.\n if (clampW < width) {\n switch (Layout.getHorizontalAlignment(this.widget)) {\n case 'left':\n break;\n case 'center':\n left += (width - clampW) / 2;\n break;\n case 'right':\n left += width - clampW;\n break;\n default:\n throw 'unreachable';\n }\n }\n\n // Adjust the top edge for the vertical alignment, if needed.\n if (clampH < height) {\n switch (Layout.getVerticalAlignment(this.widget)) {\n case 'top':\n break;\n case 'center':\n top += (height - clampH) / 2;\n break;\n case 'bottom':\n top += height - clampH;\n break;\n default:\n throw 'unreachable';\n }\n }\n\n // Set up the resize variables.\n let resized = false;\n let style = this.widget.node.style;\n\n // Update the top edge of the widget if needed.\n if (this._top !== top) {\n this._top = top;\n style.top = `${top}px`;\n }\n\n // Update the left edge of the widget if needed.\n if (this._left !== left) {\n this._left = left;\n style.left = `${left}px`;\n }\n\n // Update the width of the widget if needed.\n if (this._width !== clampW) {\n resized = true;\n this._width = clampW;\n style.width = `${clampW}px`;\n }\n\n // Update the height of the widget if needed.\n if (this._height !== clampH) {\n resized = true;\n this._height = clampH;\n style.height = `${clampH}px`;\n }\n\n // Send a resize message to the widget if needed.\n if (resized) {\n let msg = new Widget.ResizeMessage(clampW, clampH);\n MessageLoop.sendMessage(this.widget, msg);\n }\n }\n\n private _top = NaN;\n private _left = NaN;\n private _width = NaN;\n private _height = NaN;\n private _minWidth = 0;\n private _minHeight = 0;\n private _maxWidth = Infinity;\n private _maxHeight = Infinity;\n private _disposed = false;\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The attached property for a widget horizontal alignment.\n */\n export const horizontalAlignmentProperty = new AttachedProperty<\n Widget,\n Layout.HorizontalAlignment\n >({\n name: 'horizontalAlignment',\n create: () => 'center',\n changed: onAlignmentChanged\n });\n\n /**\n * The attached property for a widget vertical alignment.\n */\n export const verticalAlignmentProperty = new AttachedProperty<\n Widget,\n Layout.VerticalAlignment\n >({\n name: 'verticalAlignment',\n create: () => 'top',\n changed: onAlignmentChanged\n });\n\n /**\n * The change handler for the attached alignment properties.\n */\n function onAlignmentChanged(child: Widget): void {\n if (child.parent && child.parent.layout) {\n child.parent.update();\n }\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { MessageLoop } from '@lumino/messaging';\n\nimport { Layout } from './layout';\n\nimport { Widget } from './widget';\n\n/**\n * A concrete layout implementation suitable for many use cases.\n *\n * #### Notes\n * This class is suitable as a base class for implementing a variety of\n * layouts, but can also be used directly with standard CSS to layout a\n * collection of widgets.\n */\nexport class PanelLayout extends Layout {\n /**\n * Dispose of the resources held by the layout.\n *\n * #### Notes\n * This will clear and dispose all widgets in the layout.\n *\n * All reimplementations should call the superclass method.\n *\n * This method is called automatically when the parent is disposed.\n */\n dispose(): void {\n while (this._widgets.length > 0) {\n this._widgets.pop()!.dispose();\n }\n super.dispose();\n }\n\n /**\n * A read-only array of the widgets in the layout.\n */\n get widgets(): ReadonlyArray {\n return this._widgets;\n }\n\n /**\n * Create an iterator over the widgets in the layout.\n *\n * @returns A new iterator over the widgets in the layout.\n */\n *[Symbol.iterator](): IterableIterator {\n yield* this._widgets;\n }\n\n /**\n * Add a widget to the end of the layout.\n *\n * @param widget - The widget to add to the layout.\n *\n * #### Notes\n * If the widget is already contained in the layout, it will be moved.\n */\n addWidget(widget: Widget): void {\n this.insertWidget(this._widgets.length, widget);\n }\n\n /**\n * Insert a widget into the layout at the specified index.\n *\n * @param index - The index at which to insert the widget.\n *\n * @param widget - The widget to insert into the layout.\n *\n * #### Notes\n * The index will be clamped to the bounds of the widgets.\n *\n * If the widget is already added to the layout, it will be moved.\n *\n * #### Undefined Behavior\n * An `index` which is non-integral.\n */\n insertWidget(index: number, widget: Widget): void {\n // Remove the widget from its current parent. This is a no-op\n // if the widget's parent is already the layout parent widget.\n widget.parent = this.parent;\n\n // Look up the current index of the widget.\n let i = this._widgets.indexOf(widget);\n\n // Clamp the insert index to the array bounds.\n let j = Math.max(0, Math.min(index, this._widgets.length));\n\n // If the widget is not in the array, insert it.\n if (i === -1) {\n // Insert the widget into the array.\n ArrayExt.insert(this._widgets, j, widget);\n\n // If the layout is parented, attach the widget to the DOM.\n if (this.parent) {\n this.attachWidget(j, widget);\n }\n\n // There is nothing more to do.\n return;\n }\n\n // Otherwise, the widget exists in the array and should be moved.\n\n // Adjust the index if the location is at the end of the array.\n if (j === this._widgets.length) {\n j--;\n }\n\n // Bail if there is no effective move.\n if (i === j) {\n return;\n }\n\n // Move the widget to the new location.\n ArrayExt.move(this._widgets, i, j);\n\n // If the layout is parented, move the widget in the DOM.\n if (this.parent) {\n this.moveWidget(i, j, widget);\n }\n }\n\n /**\n * Remove a widget from the layout.\n *\n * @param widget - The widget to remove from the layout.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method does *not* modify the widget's `parent`.\n */\n removeWidget(widget: Widget): void {\n this.removeWidgetAt(this._widgets.indexOf(widget));\n }\n\n /**\n * Remove the widget at a given index from the layout.\n *\n * @param index - The index of the widget to remove.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method does *not* modify the widget's `parent`.\n *\n * #### Undefined Behavior\n * An `index` which is non-integral.\n */\n removeWidgetAt(index: number): void {\n // Remove the widget from the array.\n let widget = ArrayExt.removeAt(this._widgets, index);\n\n // If the layout is parented, detach the widget from the DOM.\n if (widget && this.parent) {\n this.detachWidget(index, widget);\n }\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n super.init();\n let index = 0;\n for (const widget of this) {\n this.attachWidget(index++, widget);\n }\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param index - The current index of the widget in the layout.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This method is called automatically by the panel layout at the\n * appropriate time. It should not be called directly by user code.\n *\n * The default implementation adds the widgets's node to the parent's\n * node at the proper location, and sends the appropriate attach\n * messages to the widget if the parent is attached to the DOM.\n *\n * Subclasses may reimplement this method to control how the widget's\n * node is added to the parent's node.\n */\n protected attachWidget(index: number, widget: Widget): void {\n // Look up the next sibling reference node.\n let ref = this.parent!.node.children[index];\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Insert the widget's node before the sibling.\n this.parent!.node.insertBefore(widget.node, ref);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n }\n\n /**\n * Move a widget in the parent's DOM node.\n *\n * @param fromIndex - The previous index of the widget in the layout.\n *\n * @param toIndex - The current index of the widget in the layout.\n *\n * @param widget - The widget to move in the parent.\n *\n * #### Notes\n * This method is called automatically by the panel layout at the\n * appropriate time. It should not be called directly by user code.\n *\n * The default implementation moves the widget's node to the proper\n * location in the parent's node and sends the appropriate attach and\n * detach messages to the widget if the parent is attached to the DOM.\n *\n * Subclasses may reimplement this method to control how the widget's\n * node is moved in the parent's node.\n */\n protected moveWidget(\n fromIndex: number,\n toIndex: number,\n widget: Widget\n ): void {\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` and message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Look up the next sibling reference node.\n let ref = this.parent!.node.children[toIndex];\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Insert the widget's node before the sibling.\n this.parent!.node.insertBefore(widget.node, ref);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param index - The previous index of the widget in the layout.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This method is called automatically by the panel layout at the\n * appropriate time. It should not be called directly by user code.\n *\n * The default implementation removes the widget's node from the\n * parent's node, and sends the appropriate detach messages to the\n * widget if the parent is attached to the DOM.\n *\n * Subclasses may reimplement this method to control how the widget's\n * node is removed from the parent's node.\n */\n protected detachWidget(index: number, widget: Widget): void {\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n }\n\n private _widgets: Widget[] = [];\n}\n","/*\n * Copyright (c) Jupyter Development Team.\n * Distributed under the terms of the Modified BSD License.\n */\n\nexport namespace Utils {\n /**\n * Clamp a dimension value to an integer >= 0.\n */\n export function clampDimension(value: number): number {\n return Math.max(0, Math.floor(value));\n }\n}\n\nexport default Utils;\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { BoxEngine, BoxSizer } from './boxengine';\n\nimport { LayoutItem } from './layout';\n\nimport { PanelLayout } from './panellayout';\n\nimport { Utils } from './utils';\n\nimport { Widget } from './widget';\n\n/**\n * A layout which arranges its widgets into resizable sections.\n */\nexport class SplitLayout extends PanelLayout {\n /**\n * Construct a new split layout.\n *\n * @param options - The options for initializing the layout.\n */\n constructor(options: SplitLayout.IOptions) {\n super();\n this.renderer = options.renderer;\n if (options.orientation !== undefined) {\n this._orientation = options.orientation;\n }\n if (options.alignment !== undefined) {\n this._alignment = options.alignment;\n }\n if (options.spacing !== undefined) {\n this._spacing = Utils.clampDimension(options.spacing);\n }\n }\n\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n // Dispose of the layout items.\n for (const item of this._items) {\n item.dispose();\n }\n\n // Clear the layout state.\n this._box = null;\n this._items.length = 0;\n this._sizers.length = 0;\n this._handles.length = 0;\n\n // Dispose of the rest of the layout.\n super.dispose();\n }\n\n /**\n * The renderer used by the split layout.\n */\n readonly renderer: SplitLayout.IRenderer;\n\n /**\n * Get the layout orientation for the split layout.\n */\n get orientation(): SplitLayout.Orientation {\n return this._orientation;\n }\n\n /**\n * Set the layout orientation for the split layout.\n */\n set orientation(value: SplitLayout.Orientation) {\n if (this._orientation === value) {\n return;\n }\n this._orientation = value;\n if (!this.parent) {\n return;\n }\n this.parent.dataset['orientation'] = value;\n this.parent.fit();\n }\n\n /**\n * Get the content alignment for the split layout.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire split layout.\n */\n get alignment(): SplitLayout.Alignment {\n return this._alignment;\n }\n\n /**\n * Set the content alignment for the split layout.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire split layout.\n */\n set alignment(value: SplitLayout.Alignment) {\n if (this._alignment === value) {\n return;\n }\n this._alignment = value;\n if (!this.parent) {\n return;\n }\n this.parent.dataset['alignment'] = value;\n this.parent.update();\n }\n\n /**\n * Get the inter-element spacing for the split layout.\n */\n get spacing(): number {\n return this._spacing;\n }\n\n /**\n * Set the inter-element spacing for the split layout.\n */\n set spacing(value: number) {\n value = Utils.clampDimension(value);\n if (this._spacing === value) {\n return;\n }\n this._spacing = value;\n if (!this.parent) {\n return;\n }\n this.parent.fit();\n }\n\n /**\n * A read-only array of the split handles in the layout.\n */\n get handles(): ReadonlyArray {\n return this._handles;\n }\n\n /**\n * Get the absolute sizes of the widgets in the layout.\n *\n * @returns A new array of the absolute sizes of the widgets.\n *\n * This method **does not** measure the DOM nodes.\n */\n absoluteSizes(): number[] {\n return this._sizers.map(sizer => sizer.size);\n }\n\n /**\n * Get the relative sizes of the widgets in the layout.\n *\n * @returns A new array of the relative sizes of the widgets.\n *\n * #### Notes\n * The returned sizes reflect the sizes of the widgets normalized\n * relative to their siblings.\n *\n * This method **does not** measure the DOM nodes.\n */\n relativeSizes(): number[] {\n return Private.normalize(this._sizers.map(sizer => sizer.size));\n }\n\n /**\n * Set the relative sizes for the widgets in the layout.\n *\n * @param sizes - The relative sizes for the widgets in the panel.\n * @param update - Update the layout after setting relative sizes.\n * Default is True.\n *\n * #### Notes\n * Extra values are ignored, too few will yield an undefined layout.\n *\n * The actual geometry of the DOM nodes is updated asynchronously.\n */\n setRelativeSizes(sizes: number[], update = true): void {\n // Copy the sizes and pad with zeros as needed.\n let n = this._sizers.length;\n let temp = sizes.slice(0, n);\n while (temp.length < n) {\n temp.push(0);\n }\n\n // Normalize the padded sizes.\n let normed = Private.normalize(temp);\n\n // Apply the normalized sizes to the sizers.\n for (let i = 0; i < n; ++i) {\n let sizer = this._sizers[i];\n sizer.sizeHint = normed[i];\n sizer.size = normed[i];\n }\n\n // Set the flag indicating the sizes are normalized.\n this._hasNormedSizes = true;\n\n // Trigger an update of the parent widget.\n if (update && this.parent) {\n this.parent.update();\n }\n }\n\n /**\n * Move the offset position of a split handle.\n *\n * @param index - The index of the handle of the interest.\n *\n * @param position - The desired offset position of the handle.\n *\n * #### Notes\n * The position is relative to the offset parent.\n *\n * This will move the handle as close as possible to the desired\n * position. The sibling widgets will be adjusted as necessary.\n */\n moveHandle(index: number, position: number): void {\n // Bail if the index is invalid or the handle is hidden.\n let handle = this._handles[index];\n if (!handle || handle.classList.contains('lm-mod-hidden')) {\n return;\n }\n\n // Compute the desired delta movement for the handle.\n let delta: number;\n if (this._orientation === 'horizontal') {\n delta = position - handle.offsetLeft;\n } else {\n delta = position - handle.offsetTop;\n }\n\n // Bail if there is no handle movement.\n if (delta === 0) {\n return;\n }\n\n // Prevent widget resizing unless needed.\n for (let sizer of this._sizers) {\n if (sizer.size > 0) {\n sizer.sizeHint = sizer.size;\n }\n }\n\n // Adjust the sizers to reflect the handle movement.\n BoxEngine.adjust(this._sizers, index, delta);\n\n // Update the layout of the widgets.\n if (this.parent) {\n this.parent.update();\n }\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n this.parent!.dataset['orientation'] = this.orientation;\n this.parent!.dataset['alignment'] = this.alignment;\n super.init();\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param index - The current index of the widget in the layout.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected attachWidget(index: number, widget: Widget): void {\n // Create the item, handle, and sizer for the new widget.\n let item = new LayoutItem(widget);\n let handle = Private.createHandle(this.renderer);\n let average = Private.averageSize(this._sizers);\n let sizer = Private.createSizer(average);\n\n // Insert the item, handle, and sizer into the internal arrays.\n ArrayExt.insert(this._items, index, item);\n ArrayExt.insert(this._sizers, index, sizer);\n ArrayExt.insert(this._handles, index, handle);\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget and handle nodes to the parent.\n this.parent!.node.appendChild(widget.node);\n this.parent!.node.appendChild(handle);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * Move a widget in the parent's DOM node.\n *\n * @param fromIndex - The previous index of the widget in the layout.\n *\n * @param toIndex - The current index of the widget in the layout.\n *\n * @param widget - The widget to move in the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected moveWidget(\n fromIndex: number,\n toIndex: number,\n widget: Widget\n ): void {\n // Move the item, sizer, and handle for the widget.\n ArrayExt.move(this._items, fromIndex, toIndex);\n ArrayExt.move(this._sizers, fromIndex, toIndex);\n ArrayExt.move(this._handles, fromIndex, toIndex);\n\n // Post a fit request to the parent to show/hide last handle.\n this.parent!.fit();\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param index - The previous index of the widget in the layout.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected detachWidget(index: number, widget: Widget): void {\n // Remove the item, handle, and sizer for the widget.\n let item = ArrayExt.removeAt(this._items, index);\n let handle = ArrayExt.removeAt(this._handles, index);\n ArrayExt.removeAt(this._sizers, index);\n\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget and handle nodes from the parent.\n this.parent!.node.removeChild(widget.node);\n this.parent!.node.removeChild(handle!);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Dispose of the layout item.\n item!.dispose();\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n */\n protected onBeforeShow(msg: Message): void {\n super.onBeforeShow(msg);\n this.parent!.update();\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n super.onBeforeAttach(msg);\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n if (this.parent!.isVisible) {\n this._update(msg.width, msg.height);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.parent!.isVisible) {\n this._update(-1, -1);\n }\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n */\n protected onFitRequest(msg: Message): void {\n if (this.parent!.isAttached) {\n this._fit();\n }\n }\n\n /**\n * Update the item position.\n *\n * @param i Item index\n * @param isHorizontal Whether the layout is horizontal or not\n * @param left Left position in pixels\n * @param top Top position in pixels\n * @param height Item height\n * @param width Item width\n * @param size Item size\n */\n protected updateItemPosition(\n i: number,\n isHorizontal: boolean,\n left: number,\n top: number,\n height: number,\n width: number,\n size: number\n ): void {\n const item = this._items[i];\n if (item.isHidden) {\n return;\n }\n\n // Fetch the style for the handle.\n let handleStyle = this._handles[i].style;\n\n // Update the widget and handle, and advance the relevant edge.\n if (isHorizontal) {\n left += this.widgetOffset;\n item.update(left, top, size, height);\n left += size;\n handleStyle.top = `${top}px`;\n handleStyle.left = `${left}px`;\n handleStyle.width = `${this._spacing}px`;\n handleStyle.height = `${height}px`;\n } else {\n top += this.widgetOffset;\n item.update(left, top, width, size);\n top += size;\n handleStyle.top = `${top}px`;\n handleStyle.left = `${left}px`;\n handleStyle.width = `${width}px`;\n handleStyle.height = `${this._spacing}px`;\n }\n }\n\n /**\n * Fit the layout to the total size required by the widgets.\n */\n private _fit(): void {\n // Update the handles and track the visible widget count.\n let nVisible = 0;\n let lastHandleIndex = -1;\n for (let i = 0, n = this._items.length; i < n; ++i) {\n if (this._items[i].isHidden) {\n this._handles[i].classList.add('lm-mod-hidden');\n } else {\n this._handles[i].classList.remove('lm-mod-hidden');\n lastHandleIndex = i;\n nVisible++;\n }\n }\n\n // Hide the handle for the last visible widget.\n if (lastHandleIndex !== -1) {\n this._handles[lastHandleIndex].classList.add('lm-mod-hidden');\n }\n\n // Update the fixed space for the visible items.\n this._fixed =\n this._spacing * Math.max(0, nVisible - 1) +\n this.widgetOffset * this._items.length;\n\n // Setup the computed minimum size.\n let horz = this._orientation === 'horizontal';\n let minW = horz ? this._fixed : 0;\n let minH = horz ? 0 : this._fixed;\n\n // Update the sizers and computed size limits.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item and corresponding box sizer.\n let item = this._items[i];\n let sizer = this._sizers[i];\n\n // Prevent resizing unless necessary.\n if (sizer.size > 0) {\n sizer.sizeHint = sizer.size;\n }\n\n // If the item is hidden, it should consume zero size.\n if (item.isHidden) {\n sizer.minSize = 0;\n sizer.maxSize = 0;\n continue;\n }\n\n // Update the size limits for the item.\n item.fit();\n\n // Update the stretch factor.\n sizer.stretch = SplitLayout.getStretch(item.widget);\n\n // Update the sizer limits and computed min size.\n if (horz) {\n sizer.minSize = item.minWidth;\n sizer.maxSize = item.maxWidth;\n minW += item.minWidth;\n minH = Math.max(minH, item.minHeight);\n } else {\n sizer.minSize = item.minHeight;\n sizer.maxSize = item.maxHeight;\n minH += item.minHeight;\n minW = Math.max(minW, item.minWidth);\n }\n }\n\n // Update the box sizing and add it to the computed min size.\n let box = (this._box = ElementExt.boxSizing(this.parent!.node));\n minW += box.horizontalSum;\n minH += box.verticalSum;\n\n // Update the parent's min size constraints.\n let style = this.parent!.node.style;\n style.minWidth = `${minW}px`;\n style.minHeight = `${minH}px`;\n\n // Set the dirty flag to ensure only a single update occurs.\n this._dirty = true;\n\n // Notify the ancestor that it should fit immediately. This may\n // cause a resize of the parent, fulfilling the required update.\n if (this.parent!.parent) {\n MessageLoop.sendMessage(this.parent!.parent!, Widget.Msg.FitRequest);\n }\n\n // If the dirty flag is still set, the parent was not resized.\n // Trigger the required update on the parent widget immediately.\n if (this._dirty) {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n }\n }\n\n /**\n * Update the layout position and size of the widgets.\n *\n * The parent offset dimensions should be `-1` if unknown.\n */\n private _update(offsetWidth: number, offsetHeight: number): void {\n // Clear the dirty flag to indicate the update occurred.\n this._dirty = false;\n\n // Compute the visible item count.\n let nVisible = 0;\n for (let i = 0, n = this._items.length; i < n; ++i) {\n nVisible += +!this._items[i].isHidden;\n }\n\n // Bail early if there are no visible items to layout.\n if (nVisible === 0 && this.widgetOffset === 0) {\n return;\n }\n\n // Measure the parent if the offset dimensions are unknown.\n if (offsetWidth < 0) {\n offsetWidth = this.parent!.node.offsetWidth;\n }\n if (offsetHeight < 0) {\n offsetHeight = this.parent!.node.offsetHeight;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent!.node);\n }\n\n // Compute the actual layout bounds adjusted for border and padding.\n let top = this._box.paddingTop;\n let left = this._box.paddingLeft;\n let width = offsetWidth - this._box.horizontalSum;\n let height = offsetHeight - this._box.verticalSum;\n\n // Set up the variables for justification and alignment offset.\n let extra = 0;\n let offset = 0;\n let horz = this._orientation === 'horizontal';\n\n if (nVisible > 0) {\n // Compute the adjusted layout space.\n let space: number;\n if (horz) {\n // left += this.widgetOffset;\n space = Math.max(0, width - this._fixed);\n } else {\n // top += this.widgetOffset;\n space = Math.max(0, height - this._fixed);\n }\n\n // Scale the size hints if they are normalized.\n if (this._hasNormedSizes) {\n for (let sizer of this._sizers) {\n sizer.sizeHint *= space;\n }\n this._hasNormedSizes = false;\n }\n\n // Distribute the layout space to the box sizers.\n let delta = BoxEngine.calc(this._sizers, space);\n\n // Account for alignment if there is extra layout space.\n if (delta > 0) {\n switch (this._alignment) {\n case 'start':\n break;\n case 'center':\n extra = 0;\n offset = delta / 2;\n break;\n case 'end':\n extra = 0;\n offset = delta;\n break;\n case 'justify':\n extra = delta / nVisible;\n offset = 0;\n break;\n default:\n throw 'unreachable';\n }\n }\n }\n\n // Layout the items using the computed box sizes.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item.\n const item = this._items[i];\n\n // Fetch the computed size for the widget.\n const size = item.isHidden ? 0 : this._sizers[i].size + extra;\n\n this.updateItemPosition(\n i,\n horz,\n horz ? left + offset : left,\n horz ? top : top + offset,\n height,\n width,\n size\n );\n\n const fullOffset =\n this.widgetOffset +\n (this._handles[i].classList.contains('lm-mod-hidden')\n ? 0\n : this._spacing);\n\n if (horz) {\n left += size + fullOffset;\n } else {\n top += size + fullOffset;\n }\n }\n }\n\n protected widgetOffset = 0;\n private _fixed = 0;\n private _spacing = 4;\n private _dirty = false;\n private _hasNormedSizes = false;\n private _sizers: BoxSizer[] = [];\n private _items: LayoutItem[] = [];\n private _handles: HTMLDivElement[] = [];\n private _box: ElementExt.IBoxSizing | null = null;\n private _alignment: SplitLayout.Alignment = 'start';\n private _orientation: SplitLayout.Orientation = 'horizontal';\n}\n\n/**\n * The namespace for the `SplitLayout` class statics.\n */\nexport namespace SplitLayout {\n /**\n * A type alias for a split layout orientation.\n */\n export type Orientation = 'horizontal' | 'vertical';\n\n /**\n * A type alias for a split layout alignment.\n */\n export type Alignment = 'start' | 'center' | 'end' | 'justify';\n\n /**\n * An options object for initializing a split layout.\n */\n export interface IOptions {\n /**\n * The renderer to use for the split layout.\n */\n renderer: IRenderer;\n\n /**\n * The orientation of the layout.\n *\n * The default is `'horizontal'`.\n */\n orientation?: Orientation;\n\n /**\n * The content alignment of the layout.\n *\n * The default is `'start'`.\n */\n alignment?: Alignment;\n\n /**\n * The spacing between items in the layout.\n *\n * The default is `4`.\n */\n spacing?: number;\n }\n\n /**\n * A renderer for use with a split layout.\n */\n export interface IRenderer {\n /**\n * Create a new handle for use with a split layout.\n *\n * @returns A new handle element.\n */\n createHandle(): HTMLDivElement;\n }\n\n /**\n * Get the split layout stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The split layout stretch factor for the widget.\n */\n export function getStretch(widget: Widget): number {\n return Private.stretchProperty.get(widget);\n }\n\n /**\n * Set the split layout stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the stretch factor.\n */\n export function setStretch(widget: Widget, value: number): void {\n Private.stretchProperty.set(widget, value);\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The property descriptor for a widget stretch factor.\n */\n export const stretchProperty = new AttachedProperty({\n name: 'stretch',\n create: () => 0,\n coerce: (owner, value) => Math.max(0, Math.floor(value)),\n changed: onChildSizingChanged\n });\n\n /**\n * Create a new box sizer with the given size hint.\n */\n export function createSizer(size: number): BoxSizer {\n let sizer = new BoxSizer();\n sizer.sizeHint = Math.floor(size);\n return sizer;\n }\n\n /**\n * Create a new split handle node using the given renderer.\n */\n export function createHandle(\n renderer: SplitLayout.IRenderer\n ): HTMLDivElement {\n let handle = renderer.createHandle();\n handle.style.position = 'absolute';\n // Do not use size containment to allow the handle to fill the available space\n handle.style.contain = 'style';\n return handle;\n }\n\n /**\n * Compute the average size of an array of box sizers.\n */\n export function averageSize(sizers: BoxSizer[]): number {\n return sizers.reduce((v, s) => v + s.size, 0) / sizers.length || 0;\n }\n\n /**\n * Normalize an array of values.\n */\n export function normalize(values: number[]): number[] {\n let n = values.length;\n if (n === 0) {\n return [];\n }\n let sum = values.reduce((a, b) => a + Math.abs(b), 0);\n return sum === 0 ? values.map(v => 1 / n) : values.map(v => v / sum);\n }\n\n /**\n * The change handler for the attached sizing properties.\n */\n function onChildSizingChanged(child: Widget): void {\n if (child.parent && child.parent.layout instanceof SplitLayout) {\n child.parent.fit();\n }\n }\n}\n","/*\n * Copyright (c) Jupyter Development Team.\n * Distributed under the terms of the Modified BSD License.\n */\n\nimport { ArrayExt } from '@lumino/algorithm';\nimport { UUID } from '@lumino/coreutils';\nimport { SplitLayout } from './splitlayout';\nimport { Title } from './title';\nimport Utils from './utils';\nimport { Widget } from './widget';\n\n/**\n * A layout which arranges its widgets into collapsible resizable sections.\n */\nexport class AccordionLayout extends SplitLayout {\n /**\n * Construct a new accordion layout.\n *\n * @param options - The options for initializing the layout.\n *\n * #### Notes\n * The default orientation will be vertical.\n *\n * Titles must be rotated for horizontal accordion panel using CSS: see accordionpanel.css\n */\n constructor(options: AccordionLayout.IOptions) {\n super({ ...options, orientation: options.orientation || 'vertical' });\n this.titleSpace = options.titleSpace || 22;\n }\n\n /**\n * The section title height or width depending on the orientation.\n */\n get titleSpace(): number {\n return this.widgetOffset;\n }\n set titleSpace(value: number) {\n value = Utils.clampDimension(value);\n if (this.widgetOffset === value) {\n return;\n }\n this.widgetOffset = value;\n if (!this.parent) {\n return;\n }\n this.parent.fit();\n }\n\n /**\n * A read-only array of the section titles in the panel.\n */\n get titles(): ReadonlyArray {\n return this._titles;\n }\n\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n if (this.isDisposed) {\n return;\n }\n\n // Clear the layout state.\n this._titles.length = 0;\n\n // Dispose of the rest of the layout.\n super.dispose();\n }\n\n /**\n * The renderer used by the accordion layout.\n */\n readonly renderer: AccordionLayout.IRenderer;\n\n public updateTitle(index: number, widget: Widget): void {\n const oldTitle = this._titles[index];\n const expanded = oldTitle.classList.contains('lm-mod-expanded');\n const newTitle = Private.createTitle(this.renderer, widget.title, expanded);\n this._titles[index] = newTitle;\n\n // Add the title node to the parent before the widget.\n this.parent!.node.replaceChild(newTitle, oldTitle);\n }\n\n /**\n * Insert a widget into the layout at the specified index.\n *\n * @param index - The index at which to insert the widget.\n *\n * @param widget - The widget to insert into the layout.\n *\n * #### Notes\n * The index will be clamped to the bounds of the widgets.\n *\n * If the widget is already added to the layout, it will be moved.\n *\n * #### Undefined Behavior\n * An `index` which is non-integral.\n */\n insertWidget(index: number, widget: Widget): void {\n if (!widget.id) {\n widget.id = `id-${UUID.uuid4()}`;\n }\n super.insertWidget(index, widget);\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param index - The current index of the widget in the layout.\n *\n * @param widget - The widget to attach to the parent.\n */\n protected attachWidget(index: number, widget: Widget): void {\n const title = Private.createTitle(this.renderer, widget.title);\n\n ArrayExt.insert(this._titles, index, title);\n\n // Add the title node to the parent before the widget.\n this.parent!.node.appendChild(title);\n\n widget.node.setAttribute('role', 'region');\n widget.node.setAttribute('aria-labelledby', title.id);\n\n super.attachWidget(index, widget);\n }\n\n /**\n * Move a widget in the parent's DOM node.\n *\n * @param fromIndex - The previous index of the widget in the layout.\n *\n * @param toIndex - The current index of the widget in the layout.\n *\n * @param widget - The widget to move in the parent.\n */\n protected moveWidget(\n fromIndex: number,\n toIndex: number,\n widget: Widget\n ): void {\n ArrayExt.move(this._titles, fromIndex, toIndex);\n super.moveWidget(fromIndex, toIndex, widget);\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param index - The previous index of the widget in the layout.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected detachWidget(index: number, widget: Widget): void {\n const title = ArrayExt.removeAt(this._titles, index);\n\n this.parent!.node.removeChild(title!);\n\n super.detachWidget(index, widget);\n }\n\n /**\n * Update the item position.\n *\n * @param i Item index\n * @param isHorizontal Whether the layout is horizontal or not\n * @param left Left position in pixels\n * @param top Top position in pixels\n * @param height Item height\n * @param width Item width\n * @param size Item size\n */\n protected updateItemPosition(\n i: number,\n isHorizontal: boolean,\n left: number,\n top: number,\n height: number,\n width: number,\n size: number\n ): void {\n const titleStyle = this._titles[i].style;\n\n // Titles must be rotated for horizontal accordion panel using CSS: see accordionpanel.css\n titleStyle.top = `${top}px`;\n titleStyle.left = `${left}px`;\n titleStyle.height = `${this.widgetOffset}px`;\n if (isHorizontal) {\n titleStyle.width = `${height}px`;\n } else {\n titleStyle.width = `${width}px`;\n }\n\n super.updateItemPosition(i, isHorizontal, left, top, height, width, size);\n }\n\n private _titles: HTMLElement[] = [];\n}\n\nexport namespace AccordionLayout {\n /**\n * A type alias for a accordion layout orientation.\n */\n export type Orientation = SplitLayout.Orientation;\n\n /**\n * A type alias for a accordion layout alignment.\n */\n export type Alignment = SplitLayout.Alignment;\n\n /**\n * An options object for initializing a accordion layout.\n */\n export interface IOptions extends SplitLayout.IOptions {\n /**\n * The renderer to use for the accordion layout.\n */\n renderer: IRenderer;\n\n /**\n * The section title height or width depending on the orientation.\n *\n * The default is `22`.\n */\n titleSpace?: number;\n }\n\n /**\n * A renderer for use with an accordion layout.\n */\n export interface IRenderer extends SplitLayout.IRenderer {\n /**\n * Common class name for all accordion titles.\n */\n readonly titleClassName: string;\n\n /**\n * Render the element for a section title.\n *\n * @param title - The data to use for rendering the section title.\n *\n * @returns A element representing the section title.\n */\n createSectionTitle(title: Title): HTMLElement;\n }\n}\n\nnamespace Private {\n /**\n * Create the title HTML element.\n *\n * @param renderer Accordion renderer\n * @param data Widget title\n * @returns Title HTML element\n */\n export function createTitle(\n renderer: AccordionLayout.IRenderer,\n data: Title,\n expanded: boolean = true\n ): HTMLElement {\n const title = renderer.createSectionTitle(data);\n title.style.position = 'absolute';\n title.style.contain = 'strict';\n title.setAttribute('aria-label', `${data.label} Section`);\n title.setAttribute('aria-expanded', expanded ? 'true' : 'false');\n title.setAttribute('aria-controls', data.owner.id);\n if (expanded) {\n title.classList.add('lm-mod-expanded');\n }\n return title;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { PanelLayout } from './panellayout';\n\nimport { Widget } from './widget';\n\n/**\n * A simple and convenient panel widget class.\n *\n * #### Notes\n * This class is suitable as a base class for implementing a variety of\n * convenience panel widgets, but can also be used directly with CSS to\n * arrange a collection of widgets.\n *\n * This class provides a convenience wrapper around a {@link PanelLayout}.\n */\nexport class Panel extends Widget {\n /**\n * Construct a new panel.\n *\n * @param options - The options for initializing the panel.\n */\n constructor(options: Panel.IOptions = {}) {\n super();\n this.addClass('lm-Panel');\n this.layout = Private.createLayout(options);\n }\n\n /**\n * A read-only array of the widgets in the panel.\n */\n get widgets(): ReadonlyArray {\n return (this.layout as PanelLayout).widgets;\n }\n\n /**\n * Add a widget to the end of the panel.\n *\n * @param widget - The widget to add to the panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n */\n addWidget(widget: Widget): void {\n (this.layout as PanelLayout).addWidget(widget);\n }\n\n /**\n * Insert a widget at the specified index.\n *\n * @param index - The index at which to insert the widget.\n *\n * @param widget - The widget to insert into to the panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n */\n insertWidget(index: number, widget: Widget): void {\n (this.layout as PanelLayout).insertWidget(index, widget);\n }\n}\n\n/**\n * The namespace for the `Panel` class statics.\n */\nexport namespace Panel {\n /**\n * An options object for creating a panel.\n */\n export interface IOptions {\n /**\n * The panel layout to use for the panel.\n *\n * The default is a new `PanelLayout`.\n */\n layout?: PanelLayout;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Create a panel layout for the given panel options.\n */\n export function createLayout(options: Panel.IOptions): PanelLayout {\n return options.layout || new PanelLayout();\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { IDisposable } from '@lumino/disposable';\n\nimport { Drag } from '@lumino/dragdrop';\n\nimport { Message } from '@lumino/messaging';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { Panel } from './panel';\n\nimport { SplitLayout } from './splitlayout';\n\nimport { Widget } from './widget';\n\n/**\n * A panel which arranges its widgets into resizable sections.\n *\n * #### Notes\n * This class provides a convenience wrapper around a {@link SplitLayout}.\n */\nexport class SplitPanel extends Panel {\n /**\n * Construct a new split panel.\n *\n * @param options - The options for initializing the split panel.\n */\n constructor(options: SplitPanel.IOptions = {}) {\n super({ layout: Private.createLayout(options) });\n this.addClass('lm-SplitPanel');\n }\n\n /**\n * Dispose of the resources held by the panel.\n */\n dispose(): void {\n this._releaseMouse();\n super.dispose();\n }\n\n /**\n * Get the layout orientation for the split panel.\n */\n get orientation(): SplitPanel.Orientation {\n return (this.layout as SplitLayout).orientation;\n }\n\n /**\n * Set the layout orientation for the split panel.\n */\n set orientation(value: SplitPanel.Orientation) {\n (this.layout as SplitLayout).orientation = value;\n }\n\n /**\n * Get the content alignment for the split panel.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire split panel.\n */\n get alignment(): SplitPanel.Alignment {\n return (this.layout as SplitLayout).alignment;\n }\n\n /**\n * Set the content alignment for the split panel.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire split panel.\n */\n set alignment(value: SplitPanel.Alignment) {\n (this.layout as SplitLayout).alignment = value;\n }\n\n /**\n * Get the inter-element spacing for the split panel.\n */\n get spacing(): number {\n return (this.layout as SplitLayout).spacing;\n }\n\n /**\n * Set the inter-element spacing for the split panel.\n */\n set spacing(value: number) {\n (this.layout as SplitLayout).spacing = value;\n }\n\n /**\n * The renderer used by the split panel.\n */\n get renderer(): SplitPanel.IRenderer {\n return (this.layout as SplitLayout).renderer;\n }\n\n /**\n * A signal emitted when a split handle has moved.\n */\n get handleMoved(): ISignal {\n return this._handleMoved;\n }\n\n /**\n * A read-only array of the split handles in the panel.\n */\n get handles(): ReadonlyArray {\n return (this.layout as SplitLayout).handles;\n }\n\n /**\n * Get the relative sizes of the widgets in the panel.\n *\n * @returns A new array of the relative sizes of the widgets.\n *\n * #### Notes\n * The returned sizes reflect the sizes of the widgets normalized\n * relative to their siblings.\n *\n * This method **does not** measure the DOM nodes.\n */\n relativeSizes(): number[] {\n return (this.layout as SplitLayout).relativeSizes();\n }\n\n /**\n * Set the relative sizes for the widgets in the panel.\n *\n * @param sizes - The relative sizes for the widgets in the panel.\n * @param update - Update the layout after setting relative sizes.\n * Default is True.\n *\n * #### Notes\n * Extra values are ignored, too few will yield an undefined layout.\n *\n * The actual geometry of the DOM nodes is updated asynchronously.\n */\n setRelativeSizes(sizes: number[], update = true): void {\n (this.layout as SplitLayout).setRelativeSizes(sizes, update);\n }\n\n /**\n * Handle the DOM events for the split panel.\n *\n * @param event - The DOM event sent to the panel.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the panel's DOM node. It should\n * not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'pointerdown':\n this._evtPointerDown(event as PointerEvent);\n break;\n case 'pointermove':\n this._evtPointerMove(event as PointerEvent);\n break;\n case 'pointerup':\n this._evtPointerUp(event as PointerEvent);\n break;\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('pointerdown', this);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('pointerdown', this);\n this._releaseMouse();\n }\n\n /**\n * A message handler invoked on a `'child-added'` message.\n */\n protected onChildAdded(msg: Widget.ChildMessage): void {\n msg.child.addClass('lm-SplitPanel-child');\n this._releaseMouse();\n }\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {\n msg.child.removeClass('lm-SplitPanel-child');\n this._releaseMouse();\n }\n\n /**\n * Handle the `'keydown'` event for the split panel.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // Stop input events during drag.\n if (this._pressData) {\n event.preventDefault();\n event.stopPropagation();\n }\n\n // Release the mouse if `Escape` is pressed.\n if (event.keyCode === 27) {\n this._releaseMouse();\n }\n }\n\n /**\n * Handle the `'pointerdown'` event for the split panel.\n */\n private _evtPointerDown(event: PointerEvent): void {\n // Do nothing if the primary button is not pressed.\n if (event.button !== 0) {\n return;\n }\n\n // Find the handle which contains the target, if any.\n let layout = this.layout as SplitLayout;\n let index = ArrayExt.findFirstIndex(layout.handles, handle => {\n return handle.contains(event.target as HTMLElement);\n });\n\n // Bail early if the mouse press was not on a handle.\n if (index === -1) {\n return;\n }\n\n // Stop the event when a split handle is pressed.\n event.preventDefault();\n event.stopPropagation();\n\n // Add the extra document listeners.\n document.addEventListener('pointerup', this, true);\n document.addEventListener('pointermove', this, true);\n document.addEventListener('keydown', this, true);\n document.addEventListener('contextmenu', this, true);\n\n // Compute the offset delta for the handle press.\n let delta: number;\n let handle = layout.handles[index];\n let rect = handle.getBoundingClientRect();\n if (layout.orientation === 'horizontal') {\n delta = event.clientX - rect.left;\n } else {\n delta = event.clientY - rect.top;\n }\n\n // Override the cursor and store the press data.\n let style = window.getComputedStyle(handle);\n let override = Drag.overrideCursor(style.cursor!);\n this._pressData = { index, delta, override };\n }\n\n /**\n * Handle the `'pointermove'` event for the split panel.\n */\n private _evtPointerMove(event: PointerEvent): void {\n // Stop the event when dragging a split handle.\n event.preventDefault();\n event.stopPropagation();\n\n // Compute the desired offset position for the handle.\n let pos: number;\n let layout = this.layout as SplitLayout;\n let rect = this.node.getBoundingClientRect();\n if (layout.orientation === 'horizontal') {\n pos = event.clientX - rect.left - this._pressData!.delta;\n } else {\n pos = event.clientY - rect.top - this._pressData!.delta;\n }\n\n // Move the handle as close to the desired position as possible.\n layout.moveHandle(this._pressData!.index, pos);\n }\n\n /**\n * Handle the `'pointerup'` event for the split panel.\n */\n private _evtPointerUp(event: PointerEvent): void {\n // Do nothing if the primary button is not released.\n if (event.button !== 0) {\n return;\n }\n\n // Stop the event when releasing a handle.\n event.preventDefault();\n event.stopPropagation();\n\n // Finalize the mouse release.\n this._releaseMouse();\n }\n\n /**\n * Release the mouse grab for the split panel.\n */\n private _releaseMouse(): void {\n // Bail early if no drag is in progress.\n if (!this._pressData) {\n return;\n }\n\n // Clear the override cursor.\n this._pressData.override.dispose();\n this._pressData = null;\n\n // Emit the handle moved signal.\n this._handleMoved.emit();\n\n // Remove the extra document listeners.\n document.removeEventListener('keydown', this, true);\n document.removeEventListener('pointerup', this, true);\n document.removeEventListener('pointermove', this, true);\n document.removeEventListener('contextmenu', this, true);\n }\n\n private _handleMoved = new Signal(this);\n private _pressData: Private.IPressData | null = null;\n}\n\n/**\n * The namespace for the `SplitPanel` class statics.\n */\nexport namespace SplitPanel {\n /**\n * A type alias for a split panel orientation.\n */\n export type Orientation = SplitLayout.Orientation;\n\n /**\n * A type alias for a split panel alignment.\n */\n export type Alignment = SplitLayout.Alignment;\n\n /**\n * A type alias for a split panel renderer.\n */\n export type IRenderer = SplitLayout.IRenderer;\n\n /**\n * An options object for initializing a split panel.\n */\n export interface IOptions {\n /**\n * The renderer to use for the split panel.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n\n /**\n * The layout orientation of the panel.\n *\n * The default is `'horizontal'`.\n */\n orientation?: Orientation;\n\n /**\n * The content alignment of the panel.\n *\n * The default is `'start'`.\n */\n alignment?: Alignment;\n\n /**\n * The spacing between items in the panel.\n *\n * The default is `4`.\n */\n spacing?: number;\n\n /**\n * The split layout to use for the split panel.\n *\n * If this is provided, the other options are ignored.\n *\n * The default is a new `SplitLayout`.\n */\n layout?: SplitLayout;\n }\n\n /**\n * The default implementation of `IRenderer`.\n */\n export class Renderer implements IRenderer {\n /**\n * Create a new handle for use with a split panel.\n *\n * @returns A new handle element for a split panel.\n */\n createHandle(): HTMLDivElement {\n let handle = document.createElement('div');\n handle.className = 'lm-SplitPanel-handle';\n return handle;\n }\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n\n /**\n * Get the split panel stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The split panel stretch factor for the widget.\n */\n export function getStretch(widget: Widget): number {\n return SplitLayout.getStretch(widget);\n }\n\n /**\n * Set the split panel stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the stretch factor.\n */\n export function setStretch(widget: Widget, value: number): void {\n SplitLayout.setStretch(widget, value);\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * An object which holds mouse press data.\n */\n export interface IPressData {\n /**\n * The index of the pressed handle.\n */\n index: number;\n\n /**\n * The offset of the press in handle coordinates.\n */\n delta: number;\n\n /**\n * The disposable which will clear the override cursor.\n */\n override: IDisposable;\n }\n\n /**\n * Create a split layout for the given panel options.\n */\n export function createLayout(options: SplitPanel.IOptions): SplitLayout {\n return (\n options.layout ||\n new SplitLayout({\n renderer: options.renderer || SplitPanel.defaultRenderer,\n orientation: options.orientation,\n alignment: options.alignment,\n spacing: options.spacing\n })\n );\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n\nimport { ArrayExt } from '@lumino/algorithm';\nimport { Message } from '@lumino/messaging';\nimport { ISignal, Signal } from '@lumino/signaling';\nimport { AccordionLayout } from './accordionlayout';\nimport { SplitLayout } from './splitlayout';\nimport { SplitPanel } from './splitpanel';\nimport { Title } from './title';\nimport { Widget } from './widget';\n\n/**\n * A panel which arranges its widgets into resizable sections separated by a title widget.\n *\n * #### Notes\n * This class provides a convenience wrapper around {@link AccordionLayout}.\n */\nexport class AccordionPanel extends SplitPanel {\n /**\n * Construct a new accordion panel.\n *\n * @param options - The options for initializing the accordion panel.\n */\n constructor(options: AccordionPanel.IOptions = {}) {\n super({ ...options, layout: Private.createLayout(options) });\n this.addClass('lm-AccordionPanel');\n }\n\n /**\n * The renderer used by the accordion panel.\n */\n get renderer(): AccordionPanel.IRenderer {\n return (this.layout as AccordionLayout).renderer;\n }\n\n /**\n * The section title space.\n *\n * This is the height if the panel is vertical and the width if it is\n * horizontal.\n */\n get titleSpace(): number {\n return (this.layout as AccordionLayout).titleSpace;\n }\n set titleSpace(value: number) {\n (this.layout as AccordionLayout).titleSpace = value;\n }\n\n /**\n * A read-only array of the section titles in the panel.\n */\n get titles(): ReadonlyArray {\n return (this.layout as AccordionLayout).titles;\n }\n\n /**\n * A signal emitted when a widget of the AccordionPanel is collapsed or expanded.\n */\n get expansionToggled(): ISignal {\n return this._expansionToggled;\n }\n\n /**\n * Add a widget to the end of the panel.\n *\n * @param widget - The widget to add to the panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n */\n addWidget(widget: Widget): void {\n super.addWidget(widget);\n widget.title.changed.connect(this._onTitleChanged, this);\n }\n\n /**\n * Collapse the widget at position `index`.\n *\n * #### Notes\n * If no widget is found for `index`, this will bail.\n *\n * @param index Widget index\n */\n collapse(index: number): void {\n const widget = (this.layout as AccordionLayout).widgets[index];\n\n if (widget && !widget.isHidden) {\n this._toggleExpansion(index);\n }\n }\n\n /**\n * Expand the widget at position `index`.\n *\n * #### Notes\n * If no widget is found for `index`, this will bail.\n *\n * @param index Widget index\n */\n expand(index: number): void {\n const widget = (this.layout as AccordionLayout).widgets[index];\n\n if (widget && widget.isHidden) {\n this._toggleExpansion(index);\n }\n }\n\n /**\n * Insert a widget at the specified index.\n *\n * @param index - The index at which to insert the widget.\n *\n * @param widget - The widget to insert into to the panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n */\n insertWidget(index: number, widget: Widget): void {\n super.insertWidget(index, widget);\n widget.title.changed.connect(this._onTitleChanged, this);\n }\n\n /**\n * Handle the DOM events for the accordion panel.\n *\n * @param event - The DOM event sent to the panel.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the panel's DOM node. It should\n * not be called directly by user code.\n */\n handleEvent(event: Event): void {\n super.handleEvent(event);\n switch (event.type) {\n case 'click':\n this._evtClick(event as MouseEvent);\n break;\n case 'keydown':\n this._eventKeyDown(event as KeyboardEvent);\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('click', this);\n this.node.addEventListener('keydown', this);\n super.onBeforeAttach(msg);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n super.onAfterDetach(msg);\n this.node.removeEventListener('click', this);\n this.node.removeEventListener('keydown', this);\n }\n\n /**\n * Handle the `changed` signal of a title object.\n */\n private _onTitleChanged(sender: Title): void {\n const index = ArrayExt.findFirstIndex(this.widgets, widget => {\n return widget.contains(sender.owner);\n });\n\n if (index >= 0) {\n (this.layout as AccordionLayout).updateTitle(index, sender.owner);\n this.update();\n }\n }\n\n /**\n * Compute the size of widgets in this panel on the title click event.\n * On closing, the size of the widget is cached and we will try to expand\n * the last opened widget.\n * On opening, we will use the cached size if it is available to restore the\n * widget.\n * In both cases, if we can not compute the size of widgets, we will let\n * `SplitLayout` decide.\n *\n * @param index - The index of widget to be opened of closed\n *\n * @returns Relative size of widgets in this panel, if this size can\n * not be computed, return `undefined`\n */\n private _computeWidgetSize(index: number): number[] | undefined {\n const layout = this.layout as AccordionLayout;\n\n const widget = layout.widgets[index];\n if (!widget) {\n return undefined;\n }\n const isHidden = widget.isHidden;\n const widgetSizes = layout.absoluteSizes();\n const delta = (isHidden ? -1 : 1) * this.spacing;\n const totalSize = widgetSizes.reduce(\n (prev: number, curr: number) => prev + curr\n );\n\n let newSize = [...widgetSizes];\n\n if (!isHidden) {\n // Hide the widget\n const currentSize = widgetSizes[index];\n\n this._widgetSizesCache.set(widget, currentSize);\n newSize[index] = 0;\n\n const widgetToCollapse = newSize.map(sz => sz > 0).lastIndexOf(true);\n if (widgetToCollapse === -1) {\n // All widget are closed, let the `SplitLayout` compute widget sizes.\n return undefined;\n }\n\n newSize[widgetToCollapse] =\n widgetSizes[widgetToCollapse] + currentSize + delta;\n } else {\n // Show the widget\n const previousSize = this._widgetSizesCache.get(widget);\n if (!previousSize) {\n // Previous size is unavailable, let the `SplitLayout` compute widget sizes.\n return undefined;\n }\n newSize[index] += previousSize;\n\n const widgetToCollapse = newSize\n .map(sz => sz - previousSize > 0)\n .lastIndexOf(true);\n if (widgetToCollapse === -1) {\n // Can not reduce the size of one widget, reduce all opened widgets\n // proportionally with its size.\n newSize.forEach((_, idx) => {\n if (idx !== index) {\n newSize[idx] -=\n (widgetSizes[idx] / totalSize) * (previousSize - delta);\n }\n });\n } else {\n newSize[widgetToCollapse] -= previousSize - delta;\n }\n }\n return newSize.map(sz => sz / (totalSize + delta));\n }\n /**\n * Handle the `'click'` event for the accordion panel\n */\n private _evtClick(event: MouseEvent): void {\n const target = event.target as HTMLElement | null;\n\n if (target) {\n const index = ArrayExt.findFirstIndex(this.titles, title => {\n return title.contains(target);\n });\n\n if (index >= 0) {\n event.preventDefault();\n event.stopPropagation();\n this._toggleExpansion(index);\n }\n }\n }\n\n /**\n * Handle the `'keydown'` event for the accordion panel.\n */\n private _eventKeyDown(event: KeyboardEvent): void {\n if (event.defaultPrevented) {\n return;\n }\n\n const target = event.target as HTMLElement | null;\n let handled = false;\n if (target) {\n const index = ArrayExt.findFirstIndex(this.titles, title => {\n return title.contains(target);\n });\n\n if (index >= 0) {\n const keyCode = event.keyCode.toString();\n\n // If Space or Enter is pressed on title, emulate click event\n if (event.key.match(/Space|Enter/) || keyCode.match(/13|32/)) {\n target.click();\n handled = true;\n } else if (\n this.orientation === 'horizontal'\n ? event.key.match(/ArrowLeft|ArrowRight/) || keyCode.match(/37|39/)\n : event.key.match(/ArrowUp|ArrowDown/) || keyCode.match(/38|40/)\n ) {\n // If Up or Down (for vertical) / Left or Right (for horizontal) is pressed on title, loop on titles\n const direction =\n event.key.match(/ArrowLeft|ArrowUp/) || keyCode.match(/37|38/)\n ? -1\n : 1;\n const length = this.titles.length;\n const newIndex = (index + length + direction) % length;\n\n this.titles[newIndex].focus();\n handled = true;\n } else if (event.key === 'End' || keyCode === '35') {\n // If End is pressed on title, focus on the last title\n this.titles[this.titles.length - 1].focus();\n handled = true;\n } else if (event.key === 'Home' || keyCode === '36') {\n // If Home is pressed on title, focus on the first title\n this.titles[0].focus();\n handled = true;\n }\n }\n\n if (handled) {\n event.preventDefault();\n }\n }\n }\n\n private _toggleExpansion(index: number) {\n const title = this.titles[index];\n const widget = (this.layout as AccordionLayout).widgets[index];\n\n const newSize = this._computeWidgetSize(index);\n if (newSize) {\n this.setRelativeSizes(newSize, false);\n }\n\n if (widget.isHidden) {\n title.classList.add('lm-mod-expanded');\n title.setAttribute('aria-expanded', 'true');\n widget.show();\n } else {\n title.classList.remove('lm-mod-expanded');\n title.setAttribute('aria-expanded', 'false');\n widget.hide();\n }\n\n // Emit the expansion state signal.\n this._expansionToggled.emit(index);\n }\n\n private _widgetSizesCache: WeakMap = new WeakMap();\n private _expansionToggled = new Signal(this);\n}\n\n/**\n * The namespace for the `AccordionPanel` class statics.\n */\nexport namespace AccordionPanel {\n /**\n * A type alias for a accordion panel orientation.\n */\n export type Orientation = SplitLayout.Orientation;\n\n /**\n * A type alias for a accordion panel alignment.\n */\n export type Alignment = SplitLayout.Alignment;\n\n /**\n * A type alias for a accordion panel renderer.\n */\n export type IRenderer = AccordionLayout.IRenderer;\n\n /**\n * An options object for initializing a accordion panel.\n */\n export interface IOptions extends Partial {\n /**\n * The accordion layout to use for the accordion panel.\n *\n * If this is provided, the other options are ignored.\n *\n * The default is a new `AccordionLayout`.\n */\n layout?: AccordionLayout;\n }\n\n /**\n * The default implementation of `IRenderer`.\n */\n export class Renderer extends SplitPanel.Renderer implements IRenderer {\n constructor() {\n super();\n this._uuid = ++Renderer._nInstance;\n }\n /**\n * A selector which matches any title node in the accordion.\n */\n readonly titleClassName = 'lm-AccordionPanel-title';\n\n /**\n * Render the collapse indicator for a section title.\n *\n * @param data - The data to use for rendering the section title.\n *\n * @returns A element representing the collapse indicator.\n */\n createCollapseIcon(data: Title): HTMLElement {\n return document.createElement('span');\n }\n\n /**\n * Render the element for a section title.\n *\n * @param data - The data to use for rendering the section title.\n *\n * @returns A element representing the section title.\n */\n createSectionTitle(data: Title): HTMLElement {\n const handle = document.createElement('h3');\n handle.setAttribute('tabindex', '0');\n handle.id = this.createTitleKey(data);\n handle.className = this.titleClassName;\n for (const aData in data.dataset) {\n handle.dataset[aData] = data.dataset[aData];\n }\n\n const collapser = handle.appendChild(this.createCollapseIcon(data));\n collapser.className = 'lm-AccordionPanel-titleCollapser';\n\n const label = handle.appendChild(document.createElement('span'));\n label.className = 'lm-AccordionPanel-titleLabel';\n label.textContent = data.label;\n label.title = data.caption || data.label;\n\n return handle;\n }\n\n /**\n * Create a unique render key for the title.\n *\n * @param data - The data to use for the title.\n *\n * @returns The unique render key for the title.\n *\n * #### Notes\n * This method caches the key against the section title the first time\n * the key is generated.\n */\n createTitleKey(data: Title): string {\n let key = this._titleKeys.get(data);\n if (key === undefined) {\n key = `title-key-${this._uuid}-${this._titleID++}`;\n this._titleKeys.set(data, key);\n }\n return key;\n }\n\n private static _nInstance = 0;\n private readonly _uuid: number;\n private _titleID = 0;\n private _titleKeys = new WeakMap, string>();\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n}\n\nnamespace Private {\n /**\n * Create an accordion layout for the given panel options.\n *\n * @param options Panel options\n * @returns Panel layout\n */\n export function createLayout(\n options: AccordionPanel.IOptions\n ): AccordionLayout {\n return (\n options.layout ||\n new AccordionLayout({\n renderer: options.renderer || AccordionPanel.defaultRenderer,\n orientation: options.orientation,\n alignment: options.alignment,\n spacing: options.spacing,\n titleSpace: options.titleSpace\n })\n );\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { BoxEngine, BoxSizer } from './boxengine';\n\nimport { LayoutItem } from './layout';\n\nimport { PanelLayout } from './panellayout';\n\nimport Utils from './utils';\n\nimport { Widget } from './widget';\n\n/**\n * A layout which arranges its widgets in a single row or column.\n */\nexport class BoxLayout extends PanelLayout {\n /**\n * Construct a new box layout.\n *\n * @param options - The options for initializing the layout.\n */\n constructor(options: BoxLayout.IOptions = {}) {\n super();\n if (options.direction !== undefined) {\n this._direction = options.direction;\n }\n if (options.alignment !== undefined) {\n this._alignment = options.alignment;\n }\n if (options.spacing !== undefined) {\n this._spacing = Utils.clampDimension(options.spacing);\n }\n }\n\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n // Dispose of the layout items.\n for (const item of this._items) {\n item.dispose();\n }\n\n // Clear the layout state.\n this._box = null;\n this._items.length = 0;\n this._sizers.length = 0;\n\n // Dispose of the rest of the layout.\n super.dispose();\n }\n\n /**\n * Get the layout direction for the box layout.\n */\n get direction(): BoxLayout.Direction {\n return this._direction;\n }\n\n /**\n * Set the layout direction for the box layout.\n */\n set direction(value: BoxLayout.Direction) {\n if (this._direction === value) {\n return;\n }\n this._direction = value;\n if (!this.parent) {\n return;\n }\n this.parent.dataset['direction'] = value;\n this.parent.fit();\n }\n\n /**\n * Get the content alignment for the box layout.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire box layout.\n */\n get alignment(): BoxLayout.Alignment {\n return this._alignment;\n }\n\n /**\n * Set the content alignment for the box layout.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire box layout.\n */\n set alignment(value: BoxLayout.Alignment) {\n if (this._alignment === value) {\n return;\n }\n this._alignment = value;\n if (!this.parent) {\n return;\n }\n this.parent.dataset['alignment'] = value;\n this.parent.update();\n }\n\n /**\n * Get the inter-element spacing for the box layout.\n */\n get spacing(): number {\n return this._spacing;\n }\n\n /**\n * Set the inter-element spacing for the box layout.\n */\n set spacing(value: number) {\n value = Utils.clampDimension(value);\n if (this._spacing === value) {\n return;\n }\n this._spacing = value;\n if (!this.parent) {\n return;\n }\n this.parent.fit();\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n this.parent!.dataset['direction'] = this.direction;\n this.parent!.dataset['alignment'] = this.alignment;\n super.init();\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param index - The current index of the widget in the layout.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected attachWidget(index: number, widget: Widget): void {\n // Create and add a new layout item for the widget.\n ArrayExt.insert(this._items, index, new LayoutItem(widget));\n\n // Create and add a new sizer for the widget.\n ArrayExt.insert(this._sizers, index, new BoxSizer());\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget's node to the parent.\n this.parent!.node.appendChild(widget.node);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * Move a widget in the parent's DOM node.\n *\n * @param fromIndex - The previous index of the widget in the layout.\n *\n * @param toIndex - The current index of the widget in the layout.\n *\n * @param widget - The widget to move in the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected moveWidget(\n fromIndex: number,\n toIndex: number,\n widget: Widget\n ): void {\n // Move the layout item for the widget.\n ArrayExt.move(this._items, fromIndex, toIndex);\n\n // Move the sizer for the widget.\n ArrayExt.move(this._sizers, fromIndex, toIndex);\n\n // Post an update request for the parent widget.\n this.parent!.update();\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param index - The previous index of the widget in the layout.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected detachWidget(index: number, widget: Widget): void {\n // Remove the layout item for the widget.\n let item = ArrayExt.removeAt(this._items, index);\n\n // Remove the sizer for the widget.\n ArrayExt.removeAt(this._sizers, index);\n\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Dispose of the layout item.\n item!.dispose();\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n */\n protected onBeforeShow(msg: Message): void {\n super.onBeforeShow(msg);\n this.parent!.update();\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n super.onBeforeAttach(msg);\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n if (this.parent!.isVisible) {\n this._update(msg.width, msg.height);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.parent!.isVisible) {\n this._update(-1, -1);\n }\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n */\n protected onFitRequest(msg: Message): void {\n if (this.parent!.isAttached) {\n this._fit();\n }\n }\n\n /**\n * Fit the layout to the total size required by the widgets.\n */\n private _fit(): void {\n // Compute the visible item count.\n let nVisible = 0;\n for (let i = 0, n = this._items.length; i < n; ++i) {\n nVisible += +!this._items[i].isHidden;\n }\n\n // Update the fixed space for the visible items.\n this._fixed = this._spacing * Math.max(0, nVisible - 1);\n\n // Setup the computed minimum size.\n let horz = Private.isHorizontal(this._direction);\n let minW = horz ? this._fixed : 0;\n let minH = horz ? 0 : this._fixed;\n\n // Update the sizers and computed minimum size.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item and corresponding box sizer.\n let item = this._items[i];\n let sizer = this._sizers[i];\n\n // If the item is hidden, it should consume zero size.\n if (item.isHidden) {\n sizer.minSize = 0;\n sizer.maxSize = 0;\n continue;\n }\n\n // Update the size limits for the item.\n item.fit();\n\n // Update the size basis and stretch factor.\n sizer.sizeHint = BoxLayout.getSizeBasis(item.widget);\n sizer.stretch = BoxLayout.getStretch(item.widget);\n\n // Update the sizer limits and computed min size.\n if (horz) {\n sizer.minSize = item.minWidth;\n sizer.maxSize = item.maxWidth;\n minW += item.minWidth;\n minH = Math.max(minH, item.minHeight);\n } else {\n sizer.minSize = item.minHeight;\n sizer.maxSize = item.maxHeight;\n minH += item.minHeight;\n minW = Math.max(minW, item.minWidth);\n }\n }\n\n // Update the box sizing and add it to the computed min size.\n let box = (this._box = ElementExt.boxSizing(this.parent!.node));\n minW += box.horizontalSum;\n minH += box.verticalSum;\n\n // Update the parent's min size constraints.\n let style = this.parent!.node.style;\n style.minWidth = `${minW}px`;\n style.minHeight = `${minH}px`;\n\n // Set the dirty flag to ensure only a single update occurs.\n this._dirty = true;\n\n // Notify the ancestor that it should fit immediately. This may\n // cause a resize of the parent, fulfilling the required update.\n if (this.parent!.parent) {\n MessageLoop.sendMessage(this.parent!.parent!, Widget.Msg.FitRequest);\n }\n\n // If the dirty flag is still set, the parent was not resized.\n // Trigger the required update on the parent widget immediately.\n if (this._dirty) {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n }\n }\n\n /**\n * Update the layout position and size of the widgets.\n *\n * The parent offset dimensions should be `-1` if unknown.\n */\n private _update(offsetWidth: number, offsetHeight: number): void {\n // Clear the dirty flag to indicate the update occurred.\n this._dirty = false;\n\n // Compute the visible item count.\n let nVisible = 0;\n for (let i = 0, n = this._items.length; i < n; ++i) {\n nVisible += +!this._items[i].isHidden;\n }\n\n // Bail early if there are no visible items to layout.\n if (nVisible === 0) {\n return;\n }\n\n // Measure the parent if the offset dimensions are unknown.\n if (offsetWidth < 0) {\n offsetWidth = this.parent!.node.offsetWidth;\n }\n if (offsetHeight < 0) {\n offsetHeight = this.parent!.node.offsetHeight;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent!.node);\n }\n\n // Compute the layout area adjusted for border and padding.\n let top = this._box.paddingTop;\n let left = this._box.paddingLeft;\n let width = offsetWidth - this._box.horizontalSum;\n let height = offsetHeight - this._box.verticalSum;\n\n // Distribute the layout space and adjust the start position.\n let delta: number;\n switch (this._direction) {\n case 'left-to-right':\n delta = BoxEngine.calc(this._sizers, Math.max(0, width - this._fixed));\n break;\n case 'top-to-bottom':\n delta = BoxEngine.calc(this._sizers, Math.max(0, height - this._fixed));\n break;\n case 'right-to-left':\n delta = BoxEngine.calc(this._sizers, Math.max(0, width - this._fixed));\n left += width;\n break;\n case 'bottom-to-top':\n delta = BoxEngine.calc(this._sizers, Math.max(0, height - this._fixed));\n top += height;\n break;\n default:\n throw 'unreachable';\n }\n\n // Setup the variables for justification and alignment offset.\n let extra = 0;\n let offset = 0;\n\n // Account for alignment if there is extra layout space.\n if (delta > 0) {\n switch (this._alignment) {\n case 'start':\n break;\n case 'center':\n extra = 0;\n offset = delta / 2;\n break;\n case 'end':\n extra = 0;\n offset = delta;\n break;\n case 'justify':\n extra = delta / nVisible;\n offset = 0;\n break;\n default:\n throw 'unreachable';\n }\n }\n\n // Layout the items using the computed box sizes.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item.\n let item = this._items[i];\n\n // Ignore hidden items.\n if (item.isHidden) {\n continue;\n }\n\n // Fetch the computed size for the widget.\n let size = this._sizers[i].size;\n\n // Update the widget geometry and advance the relevant edge.\n switch (this._direction) {\n case 'left-to-right':\n item.update(left + offset, top, size + extra, height);\n left += size + extra + this._spacing;\n break;\n case 'top-to-bottom':\n item.update(left, top + offset, width, size + extra);\n top += size + extra + this._spacing;\n break;\n case 'right-to-left':\n item.update(left - offset - size - extra, top, size + extra, height);\n left -= size + extra + this._spacing;\n break;\n case 'bottom-to-top':\n item.update(left, top - offset - size - extra, width, size + extra);\n top -= size + extra + this._spacing;\n break;\n default:\n throw 'unreachable';\n }\n }\n }\n\n private _fixed = 0;\n private _spacing = 4;\n private _dirty = false;\n private _sizers: BoxSizer[] = [];\n private _items: LayoutItem[] = [];\n private _box: ElementExt.IBoxSizing | null = null;\n private _alignment: BoxLayout.Alignment = 'start';\n private _direction: BoxLayout.Direction = 'top-to-bottom';\n}\n\n/**\n * The namespace for the `BoxLayout` class statics.\n */\nexport namespace BoxLayout {\n /**\n * A type alias for a box layout direction.\n */\n export type Direction =\n | 'left-to-right'\n | 'right-to-left'\n | 'top-to-bottom'\n | 'bottom-to-top';\n\n /**\n * A type alias for a box layout alignment.\n */\n export type Alignment = 'start' | 'center' | 'end' | 'justify';\n\n /**\n * An options object for initializing a box layout.\n */\n export interface IOptions {\n /**\n * The direction of the layout.\n *\n * The default is `'top-to-bottom'`.\n */\n direction?: Direction;\n\n /**\n * The content alignment of the layout.\n *\n * The default is `'start'`.\n */\n alignment?: Alignment;\n\n /**\n * The spacing between items in the layout.\n *\n * The default is `4`.\n */\n spacing?: number;\n }\n\n /**\n * Get the box layout stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The box layout stretch factor for the widget.\n */\n export function getStretch(widget: Widget): number {\n return Private.stretchProperty.get(widget);\n }\n\n /**\n * Set the box layout stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the stretch factor.\n */\n export function setStretch(widget: Widget, value: number): void {\n Private.stretchProperty.set(widget, value);\n }\n\n /**\n * Get the box layout size basis for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The box layout size basis for the widget.\n */\n export function getSizeBasis(widget: Widget): number {\n return Private.sizeBasisProperty.get(widget);\n }\n\n /**\n * Set the box layout size basis for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the size basis.\n */\n export function setSizeBasis(widget: Widget, value: number): void {\n Private.sizeBasisProperty.set(widget, value);\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The property descriptor for a widget stretch factor.\n */\n export const stretchProperty = new AttachedProperty({\n name: 'stretch',\n create: () => 0,\n coerce: (owner, value) => Math.max(0, Math.floor(value)),\n changed: onChildSizingChanged\n });\n\n /**\n * The property descriptor for a widget size basis.\n */\n export const sizeBasisProperty = new AttachedProperty({\n name: 'sizeBasis',\n create: () => 0,\n coerce: (owner, value) => Math.max(0, Math.floor(value)),\n changed: onChildSizingChanged\n });\n\n /**\n * Test whether a direction has horizontal orientation.\n */\n export function isHorizontal(dir: BoxLayout.Direction): boolean {\n return dir === 'left-to-right' || dir === 'right-to-left';\n }\n\n /**\n * Clamp a spacing value to an integer >= 0.\n */\n export function clampSpacing(value: number): number {\n return Math.max(0, Math.floor(value));\n }\n\n /**\n * The change handler for the attached sizing properties.\n */\n function onChildSizingChanged(child: Widget): void {\n if (child.parent && child.parent.layout instanceof BoxLayout) {\n child.parent.fit();\n }\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { BoxLayout } from './boxlayout';\n\nimport { Panel } from './panel';\n\nimport { Widget } from './widget';\n\n/**\n * A panel which arranges its widgets in a single row or column.\n *\n * #### Notes\n * This class provides a convenience wrapper around a {@link BoxLayout}.\n */\nexport class BoxPanel extends Panel {\n /**\n * Construct a new box panel.\n *\n * @param options - The options for initializing the box panel.\n */\n constructor(options: BoxPanel.IOptions = {}) {\n super({ layout: Private.createLayout(options) });\n this.addClass('lm-BoxPanel');\n }\n\n /**\n * Get the layout direction for the box panel.\n */\n get direction(): BoxPanel.Direction {\n return (this.layout as BoxLayout).direction;\n }\n\n /**\n * Set the layout direction for the box panel.\n */\n set direction(value: BoxPanel.Direction) {\n (this.layout as BoxLayout).direction = value;\n }\n\n /**\n * Get the content alignment for the box panel.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire box layout.\n */\n get alignment(): BoxPanel.Alignment {\n return (this.layout as BoxLayout).alignment;\n }\n\n /**\n * Set the content alignment for the box panel.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire box layout.\n */\n set alignment(value: BoxPanel.Alignment) {\n (this.layout as BoxLayout).alignment = value;\n }\n\n /**\n * Get the inter-element spacing for the box panel.\n */\n get spacing(): number {\n return (this.layout as BoxLayout).spacing;\n }\n\n /**\n * Set the inter-element spacing for the box panel.\n */\n set spacing(value: number) {\n (this.layout as BoxLayout).spacing = value;\n }\n\n /**\n * A message handler invoked on a `'child-added'` message.\n */\n protected onChildAdded(msg: Widget.ChildMessage): void {\n msg.child.addClass('lm-BoxPanel-child');\n }\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {\n msg.child.removeClass('lm-BoxPanel-child');\n }\n}\n\n/**\n * The namespace for the `BoxPanel` class statics.\n */\nexport namespace BoxPanel {\n /**\n * A type alias for a box panel direction.\n */\n export type Direction = BoxLayout.Direction;\n\n /**\n * A type alias for a box panel alignment.\n */\n export type Alignment = BoxLayout.Alignment;\n\n /**\n * An options object for initializing a box panel.\n */\n export interface IOptions {\n /**\n * The layout direction of the panel.\n *\n * The default is `'top-to-bottom'`.\n */\n direction?: Direction;\n\n /**\n * The content alignment of the panel.\n *\n * The default is `'start'`.\n */\n alignment?: Alignment;\n\n /**\n * The spacing between items in the panel.\n *\n * The default is `4`.\n */\n spacing?: number;\n\n /**\n * The box layout to use for the box panel.\n *\n * If this is provided, the other options are ignored.\n *\n * The default is a new `BoxLayout`.\n */\n layout?: BoxLayout;\n }\n\n /**\n * Get the box panel stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The box panel stretch factor for the widget.\n */\n export function getStretch(widget: Widget): number {\n return BoxLayout.getStretch(widget);\n }\n\n /**\n * Set the box panel stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the stretch factor.\n */\n export function setStretch(widget: Widget, value: number): void {\n BoxLayout.setStretch(widget, value);\n }\n\n /**\n * Get the box panel size basis for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The box panel size basis for the widget.\n */\n export function getSizeBasis(widget: Widget): number {\n return BoxLayout.getSizeBasis(widget);\n }\n\n /**\n * Set the box panel size basis for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the size basis.\n */\n export function setSizeBasis(widget: Widget, value: number): void {\n BoxLayout.setSizeBasis(widget, value);\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Create a box layout for the given panel options.\n */\n export function createLayout(options: BoxPanel.IOptions): BoxLayout {\n return options.layout || new BoxLayout(options);\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt, StringExt } from '@lumino/algorithm';\n\nimport { JSONExt, ReadonlyJSONObject } from '@lumino/coreutils';\n\nimport { CommandRegistry } from '@lumino/commands';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message } from '@lumino/messaging';\n\nimport {\n ElementDataset,\n h,\n VirtualDOM,\n VirtualElement\n} from '@lumino/virtualdom';\n\nimport { Widget } from './widget';\n\n/**\n * A widget which displays command items as a searchable palette.\n */\nexport class CommandPalette extends Widget {\n /**\n * Construct a new command palette.\n *\n * @param options - The options for initializing the palette.\n */\n constructor(options: CommandPalette.IOptions) {\n super({ node: Private.createNode() });\n this.addClass('lm-CommandPalette');\n this.setFlag(Widget.Flag.DisallowLayout);\n this.commands = options.commands;\n this.renderer = options.renderer || CommandPalette.defaultRenderer;\n this.commands.commandChanged.connect(this._onGenericChange, this);\n this.commands.keyBindingChanged.connect(this._onGenericChange, this);\n }\n\n /**\n * Dispose of the resources held by the widget.\n */\n dispose(): void {\n this._items.length = 0;\n this._results = null;\n super.dispose();\n }\n\n /**\n * The command registry used by the command palette.\n */\n readonly commands: CommandRegistry;\n\n /**\n * The renderer used by the command palette.\n */\n readonly renderer: CommandPalette.IRenderer;\n\n /**\n * The command palette search node.\n *\n * #### Notes\n * This is the node which contains the search-related elements.\n */\n get searchNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-CommandPalette-search'\n )[0] as HTMLDivElement;\n }\n\n /**\n * The command palette input node.\n *\n * #### Notes\n * This is the actual input node for the search area.\n */\n get inputNode(): HTMLInputElement {\n return this.node.getElementsByClassName(\n 'lm-CommandPalette-input'\n )[0] as HTMLInputElement;\n }\n\n /**\n * The command palette content node.\n *\n * #### Notes\n * This is the node which holds the command item nodes.\n *\n * Modifying this node directly can lead to undefined behavior.\n */\n get contentNode(): HTMLUListElement {\n return this.node.getElementsByClassName(\n 'lm-CommandPalette-content'\n )[0] as HTMLUListElement;\n }\n\n /**\n * A read-only array of the command items in the palette.\n */\n get items(): ReadonlyArray {\n return this._items;\n }\n\n /**\n * Add a command item to the command palette.\n *\n * @param options - The options for creating the command item.\n *\n * @returns The command item added to the palette.\n */\n addItem(options: CommandPalette.IItemOptions): CommandPalette.IItem {\n // Create a new command item for the options.\n let item = Private.createItem(this.commands, options);\n\n // Add the item to the array.\n this._items.push(item);\n\n // Refresh the search results.\n this.refresh();\n\n // Return the item added to the palette.\n return item;\n }\n\n /**\n * Adds command items to the command palette.\n *\n * @param items - An array of options for creating each command item.\n *\n * @returns The command items added to the palette.\n */\n addItems(items: CommandPalette.IItemOptions[]): CommandPalette.IItem[] {\n const newItems = items.map(item => Private.createItem(this.commands, item));\n newItems.forEach(item => this._items.push(item));\n this.refresh();\n return newItems;\n }\n\n /**\n * Remove an item from the command palette.\n *\n * @param item - The item to remove from the palette.\n *\n * #### Notes\n * This is a no-op if the item is not in the palette.\n */\n removeItem(item: CommandPalette.IItem): void {\n this.removeItemAt(this._items.indexOf(item));\n }\n\n /**\n * Remove the item at a given index from the command palette.\n *\n * @param index - The index of the item to remove.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n removeItemAt(index: number): void {\n // Remove the item from the array.\n let item = ArrayExt.removeAt(this._items, index);\n\n // Bail if the index is out of range.\n if (!item) {\n return;\n }\n\n // Refresh the search results.\n this.refresh();\n }\n\n /**\n * Remove all items from the command palette.\n */\n clearItems(): void {\n // Bail if there is nothing to remove.\n if (this._items.length === 0) {\n return;\n }\n\n // Clear the array of items.\n this._items.length = 0;\n\n // Refresh the search results.\n this.refresh();\n }\n\n /**\n * Clear the search results and schedule an update.\n *\n * #### Notes\n * This should be called whenever the search results of the palette\n * should be updated.\n *\n * This is typically called automatically by the palette as needed,\n * but can be called manually if the input text is programatically\n * changed.\n *\n * The rendered results are updated asynchronously.\n */\n refresh(): void {\n this._results = null;\n if (this.inputNode.value !== '') {\n let clear = this.node.getElementsByClassName(\n 'lm-close-icon'\n )[0] as HTMLInputElement;\n clear.style.display = 'inherit';\n } else {\n let clear = this.node.getElementsByClassName(\n 'lm-close-icon'\n )[0] as HTMLInputElement;\n clear.style.display = 'none';\n }\n this.update();\n }\n\n /**\n * Handle the DOM events for the command palette.\n *\n * @param event - The DOM event sent to the command palette.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the command palette's DOM node.\n * It should not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'click':\n this._evtClick(event as MouseEvent);\n break;\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'input':\n this.refresh();\n break;\n case 'focus':\n case 'blur':\n this._toggleFocused();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('click', this);\n this.node.addEventListener('keydown', this);\n this.node.addEventListener('input', this);\n this.node.addEventListener('focus', this, true);\n this.node.addEventListener('blur', this, true);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('click', this);\n this.node.removeEventListener('keydown', this);\n this.node.removeEventListener('input', this);\n this.node.removeEventListener('focus', this, true);\n this.node.removeEventListener('blur', this, true);\n }\n\n /**\n * A message handler invoked on an `'after-show'` message.\n */\n protected onAfterShow(msg: Message): void {\n this.update();\n super.onAfterShow(msg);\n }\n\n /**\n * A message handler invoked on an `'activate-request'` message.\n */\n protected onActivateRequest(msg: Message): void {\n if (this.isAttached) {\n let input = this.inputNode;\n input.focus();\n input.select();\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.isHidden) {\n return;\n }\n\n // Fetch the current query text and content node.\n let query = this.inputNode.value;\n let contentNode = this.contentNode;\n\n // Ensure the search results are generated.\n let results = this._results;\n if (!results) {\n // Generate and store the new search results.\n results = this._results = Private.search(this._items, query);\n\n // Reset the active index.\n this._activeIndex = query\n ? ArrayExt.findFirstIndex(results, Private.canActivate)\n : -1;\n }\n\n // If there is no query and no results, clear the content.\n if (!query && results.length === 0) {\n VirtualDOM.render(null, contentNode);\n return;\n }\n\n // If the is a query but no results, render the empty message.\n if (query && results.length === 0) {\n let content = this.renderer.renderEmptyMessage({ query });\n VirtualDOM.render(content, contentNode);\n return;\n }\n\n // Create the render content for the search results.\n let renderer = this.renderer;\n let activeIndex = this._activeIndex;\n let content = new Array(results.length);\n for (let i = 0, n = results.length; i < n; ++i) {\n let result = results[i];\n if (result.type === 'header') {\n let indices = result.indices;\n let category = result.category;\n content[i] = renderer.renderHeader({ category, indices });\n } else {\n let item = result.item;\n let indices = result.indices;\n let active = i === activeIndex;\n content[i] = renderer.renderItem({ item, indices, active });\n }\n }\n\n // Render the search result content.\n VirtualDOM.render(content, contentNode);\n\n // Adjust the scroll position as needed.\n if (activeIndex < 0 || activeIndex >= results.length) {\n contentNode.scrollTop = 0;\n } else {\n let element = contentNode.children[activeIndex];\n ElementExt.scrollIntoViewIfNeeded(contentNode, element);\n }\n }\n\n /**\n * Handle the `'click'` event for the command palette.\n */\n private _evtClick(event: MouseEvent): void {\n // Bail if the click is not the left button.\n if (event.button !== 0) {\n return;\n }\n\n // Clear input if the target is clear button\n if ((event.target as HTMLElement).classList.contains('lm-close-icon')) {\n this.inputNode.value = '';\n this.refresh();\n return;\n }\n\n // Find the index of the item which was clicked.\n let index = ArrayExt.findFirstIndex(this.contentNode.children, node => {\n return node.contains(event.target as HTMLElement);\n });\n\n // Bail if the click was not on an item.\n if (index === -1) {\n return;\n }\n\n // Kill the event when a content item is clicked.\n event.preventDefault();\n event.stopPropagation();\n\n // Execute the item if possible.\n this._execute(index);\n }\n\n /**\n * Handle the `'keydown'` event for the command palette.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n if (event.altKey || event.ctrlKey || event.metaKey || event.shiftKey) {\n return;\n }\n switch (event.keyCode) {\n case 13: // Enter\n event.preventDefault();\n event.stopPropagation();\n this._execute(this._activeIndex);\n break;\n case 38: // Up Arrow\n event.preventDefault();\n event.stopPropagation();\n this._activatePreviousItem();\n break;\n case 40: // Down Arrow\n event.preventDefault();\n event.stopPropagation();\n this._activateNextItem();\n break;\n }\n }\n\n /**\n * Activate the next enabled command item.\n */\n private _activateNextItem(): void {\n // Bail if there are no search results.\n if (!this._results || this._results.length === 0) {\n return;\n }\n\n // Find the next enabled item index.\n let ai = this._activeIndex;\n let n = this._results.length;\n let start = ai < n - 1 ? ai + 1 : 0;\n let stop = start === 0 ? n - 1 : start - 1;\n this._activeIndex = ArrayExt.findFirstIndex(\n this._results,\n Private.canActivate,\n start,\n stop\n );\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * Activate the previous enabled command item.\n */\n private _activatePreviousItem(): void {\n // Bail if there are no search results.\n if (!this._results || this._results.length === 0) {\n return;\n }\n\n // Find the previous enabled item index.\n let ai = this._activeIndex;\n let n = this._results.length;\n let start = ai <= 0 ? n - 1 : ai - 1;\n let stop = start === n - 1 ? 0 : start + 1;\n this._activeIndex = ArrayExt.findLastIndex(\n this._results,\n Private.canActivate,\n start,\n stop\n );\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * Execute the command item at the given index, if possible.\n */\n private _execute(index: number): void {\n // Bail if there are no search results.\n if (!this._results) {\n return;\n }\n\n // Bail if the index is out of range.\n let part = this._results[index];\n if (!part) {\n return;\n }\n\n // Update the search text if the item is a header.\n if (part.type === 'header') {\n let input = this.inputNode;\n input.value = `${part.category.toLowerCase()} `;\n input.focus();\n this.refresh();\n return;\n }\n\n // Bail if item is not enabled.\n if (!part.item.isEnabled) {\n return;\n }\n\n // Execute the item.\n this.commands.execute(part.item.command, part.item.args);\n\n // Clear the query text.\n this.inputNode.value = '';\n\n // Refresh the search results.\n this.refresh();\n }\n\n /**\n * Toggle the focused modifier based on the input node focus state.\n */\n private _toggleFocused(): void {\n let focused = document.activeElement === this.inputNode;\n this.toggleClass('lm-mod-focused', focused);\n }\n\n /**\n * A signal handler for generic command changes.\n */\n private _onGenericChange(): void {\n this.refresh();\n }\n\n private _activeIndex = -1;\n private _items: CommandPalette.IItem[] = [];\n private _results: Private.SearchResult[] | null = null;\n}\n\n/**\n * The namespace for the `CommandPalette` class statics.\n */\nexport namespace CommandPalette {\n /**\n * An options object for creating a command palette.\n */\n export interface IOptions {\n /**\n * The command registry for use with the command palette.\n */\n commands: CommandRegistry;\n\n /**\n * A custom renderer for use with the command palette.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n }\n\n /**\n * An options object for creating a command item.\n */\n export interface IItemOptions {\n /**\n * The category for the item.\n */\n category: string;\n\n /**\n * The command to execute when the item is triggered.\n */\n command: string;\n\n /**\n * The arguments for the command.\n *\n * The default value is an empty object.\n */\n args?: ReadonlyJSONObject;\n\n /**\n * The rank for the command item.\n *\n * The rank is used as a tie-breaker when ordering command items\n * for display. Items are sorted in the following order:\n * 1. Text match (lower is better)\n * 2. Category (locale order)\n * 3. Rank (lower is better)\n * 4. Label (locale order)\n *\n * The default rank is `Infinity`.\n */\n rank?: number;\n }\n\n /**\n * An object which represents an item in a command palette.\n *\n * #### Notes\n * Item objects are created automatically by a command palette.\n */\n export interface IItem {\n /**\n * The command to execute when the item is triggered.\n */\n readonly command: string;\n\n /**\n * The arguments for the command.\n */\n readonly args: ReadonlyJSONObject;\n\n /**\n * The category for the command item.\n */\n readonly category: string;\n\n /**\n * The rank for the command item.\n */\n readonly rank: number;\n\n /**\n * The display label for the command item.\n */\n readonly label: string;\n\n /**\n * The display caption for the command item.\n */\n readonly caption: string;\n\n /**\n * The icon renderer for the command item.\n */\n readonly icon: VirtualElement.IRenderer | undefined;\n\n /**\n * The icon class for the command item.\n */\n readonly iconClass: string;\n\n /**\n * The icon label for the command item.\n */\n readonly iconLabel: string;\n\n /**\n * The extra class name for the command item.\n */\n readonly className: string;\n\n /**\n * The dataset for the command item.\n */\n readonly dataset: CommandRegistry.Dataset;\n\n /**\n * Whether the command item is enabled.\n */\n readonly isEnabled: boolean;\n\n /**\n * Whether the command item is toggled.\n */\n readonly isToggled: boolean;\n\n /**\n * Whether the command item is toggleable.\n */\n readonly isToggleable: boolean;\n\n /**\n * Whether the command item is visible.\n */\n readonly isVisible: boolean;\n\n /**\n * The key binding for the command item.\n */\n readonly keyBinding: CommandRegistry.IKeyBinding | null;\n }\n\n /**\n * The render data for a command palette header.\n */\n export interface IHeaderRenderData {\n /**\n * The category of the header.\n */\n readonly category: string;\n\n /**\n * The indices of the matched characters in the category.\n */\n readonly indices: ReadonlyArray | null;\n }\n\n /**\n * The render data for a command palette item.\n */\n export interface IItemRenderData {\n /**\n * The command palette item to render.\n */\n readonly item: IItem;\n\n /**\n * The indices of the matched characters in the label.\n */\n readonly indices: ReadonlyArray | null;\n\n /**\n * Whether the item is the active item.\n */\n readonly active: boolean;\n }\n\n /**\n * The render data for a command palette empty message.\n */\n export interface IEmptyMessageRenderData {\n /**\n * The query which failed to match any commands.\n */\n query: string;\n }\n\n /**\n * A renderer for use with a command palette.\n */\n export interface IRenderer {\n /**\n * Render the virtual element for a command palette header.\n *\n * @param data - The data to use for rendering the header.\n *\n * @returns A virtual element representing the header.\n */\n renderHeader(data: IHeaderRenderData): VirtualElement;\n\n /**\n * Render the virtual element for a command palette item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n *\n * #### Notes\n * The command palette will not render invisible items.\n */\n renderItem(data: IItemRenderData): VirtualElement;\n\n /**\n * Render the empty results message for a command palette.\n *\n * @param data - The data to use for rendering the message.\n *\n * @returns A virtual element representing the message.\n */\n renderEmptyMessage(data: IEmptyMessageRenderData): VirtualElement;\n }\n\n /**\n * The default implementation of `IRenderer`.\n */\n export class Renderer implements IRenderer {\n /**\n * Render the virtual element for a command palette header.\n *\n * @param data - The data to use for rendering the header.\n *\n * @returns A virtual element representing the header.\n */\n renderHeader(data: IHeaderRenderData): VirtualElement {\n let content = this.formatHeader(data);\n return h.li({ className: 'lm-CommandPalette-header' }, content);\n }\n\n /**\n * Render the virtual element for a command palette item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n */\n renderItem(data: IItemRenderData): VirtualElement {\n let className = this.createItemClass(data);\n let dataset = this.createItemDataset(data);\n if (data.item.isToggleable) {\n return h.li(\n {\n className,\n dataset,\n role: 'menuitemcheckbox',\n 'aria-checked': `${data.item.isToggled}`\n },\n this.renderItemIcon(data),\n this.renderItemContent(data),\n this.renderItemShortcut(data)\n );\n }\n return h.li(\n {\n className,\n dataset,\n role: 'menuitem'\n },\n this.renderItemIcon(data),\n this.renderItemContent(data),\n this.renderItemShortcut(data)\n );\n }\n\n /**\n * Render the empty results message for a command palette.\n *\n * @param data - The data to use for rendering the message.\n *\n * @returns A virtual element representing the message.\n */\n renderEmptyMessage(data: IEmptyMessageRenderData): VirtualElement {\n let content = this.formatEmptyMessage(data);\n return h.li({ className: 'lm-CommandPalette-emptyMessage' }, content);\n }\n\n /**\n * Render the icon for a command palette item.\n *\n * @param data - The data to use for rendering the icon.\n *\n * @returns A virtual element representing the icon.\n */\n renderItemIcon(data: IItemRenderData): VirtualElement {\n let className = this.createIconClass(data);\n\n // If data.item.icon is undefined, it will be ignored.\n return h.div({ className }, data.item.icon!, data.item.iconLabel);\n }\n\n /**\n * Render the content for a command palette item.\n *\n * @param data - The data to use for rendering the content.\n *\n * @returns A virtual element representing the content.\n */\n renderItemContent(data: IItemRenderData): VirtualElement {\n return h.div(\n { className: 'lm-CommandPalette-itemContent' },\n this.renderItemLabel(data),\n this.renderItemCaption(data)\n );\n }\n\n /**\n * Render the label for a command palette item.\n *\n * @param data - The data to use for rendering the label.\n *\n * @returns A virtual element representing the label.\n */\n renderItemLabel(data: IItemRenderData): VirtualElement {\n let content = this.formatItemLabel(data);\n return h.div({ className: 'lm-CommandPalette-itemLabel' }, content);\n }\n\n /**\n * Render the caption for a command palette item.\n *\n * @param data - The data to use for rendering the caption.\n *\n * @returns A virtual element representing the caption.\n */\n renderItemCaption(data: IItemRenderData): VirtualElement {\n let content = this.formatItemCaption(data);\n return h.div({ className: 'lm-CommandPalette-itemCaption' }, content);\n }\n\n /**\n * Render the shortcut for a command palette item.\n *\n * @param data - The data to use for rendering the shortcut.\n *\n * @returns A virtual element representing the shortcut.\n */\n renderItemShortcut(data: IItemRenderData): VirtualElement {\n let content = this.formatItemShortcut(data);\n return h.div({ className: 'lm-CommandPalette-itemShortcut' }, content);\n }\n\n /**\n * Create the class name for the command palette item.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the command palette item.\n */\n createItemClass(data: IItemRenderData): string {\n // Set up the initial class name.\n let name = 'lm-CommandPalette-item';\n\n // Add the boolean state classes.\n if (!data.item.isEnabled) {\n name += ' lm-mod-disabled';\n }\n if (data.item.isToggled) {\n name += ' lm-mod-toggled';\n }\n if (data.active) {\n name += ' lm-mod-active';\n }\n\n // Add the extra class.\n let extra = data.item.className;\n if (extra) {\n name += ` ${extra}`;\n }\n\n // Return the complete class name.\n return name;\n }\n\n /**\n * Create the dataset for the command palette item.\n *\n * @param data - The data to use for creating the dataset.\n *\n * @returns The dataset for the command palette item.\n */\n createItemDataset(data: IItemRenderData): ElementDataset {\n return { ...data.item.dataset, command: data.item.command };\n }\n\n /**\n * Create the class name for the command item icon.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the item icon.\n */\n createIconClass(data: IItemRenderData): string {\n let name = 'lm-CommandPalette-itemIcon';\n let extra = data.item.iconClass;\n return extra ? `${name} ${extra}` : name;\n }\n\n /**\n * Create the render content for the header node.\n *\n * @param data - The data to use for the header content.\n *\n * @returns The content to add to the header node.\n */\n formatHeader(data: IHeaderRenderData): h.Child {\n if (!data.indices || data.indices.length === 0) {\n return data.category;\n }\n return StringExt.highlight(data.category, data.indices, h.mark);\n }\n\n /**\n * Create the render content for the empty message node.\n *\n * @param data - The data to use for the empty message content.\n *\n * @returns The content to add to the empty message node.\n */\n formatEmptyMessage(data: IEmptyMessageRenderData): h.Child {\n return `No commands found that match '${data.query}'`;\n }\n\n /**\n * Create the render content for the item shortcut node.\n *\n * @param data - The data to use for the shortcut content.\n *\n * @returns The content to add to the shortcut node.\n */\n formatItemShortcut(data: IItemRenderData): h.Child {\n let kb = data.item.keyBinding;\n return kb ? CommandRegistry.formatKeystroke(kb.keys) : null;\n }\n\n /**\n * Create the render content for the item label node.\n *\n * @param data - The data to use for the label content.\n *\n * @returns The content to add to the label node.\n */\n formatItemLabel(data: IItemRenderData): h.Child {\n if (!data.indices || data.indices.length === 0) {\n return data.item.label;\n }\n return StringExt.highlight(data.item.label, data.indices, h.mark);\n }\n\n /**\n * Create the render content for the item caption node.\n *\n * @param data - The data to use for the caption content.\n *\n * @returns The content to add to the caption node.\n */\n formatItemCaption(data: IItemRenderData): h.Child {\n return data.item.caption;\n }\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Create the DOM node for a command palette.\n */\n export function createNode(): HTMLDivElement {\n let node = document.createElement('div');\n let search = document.createElement('div');\n let wrapper = document.createElement('div');\n let input = document.createElement('input');\n let content = document.createElement('ul');\n let clear = document.createElement('button');\n search.className = 'lm-CommandPalette-search';\n wrapper.className = 'lm-CommandPalette-wrapper';\n input.className = 'lm-CommandPalette-input';\n clear.className = 'lm-close-icon';\n\n content.className = 'lm-CommandPalette-content';\n content.setAttribute('role', 'menu');\n input.spellcheck = false;\n wrapper.appendChild(input);\n wrapper.appendChild(clear);\n search.appendChild(wrapper);\n node.appendChild(search);\n node.appendChild(content);\n return node;\n }\n\n /**\n * Create a new command item from a command registry and options.\n */\n export function createItem(\n commands: CommandRegistry,\n options: CommandPalette.IItemOptions\n ): CommandPalette.IItem {\n return new CommandItem(commands, options);\n }\n\n /**\n * A search result object for a header label.\n */\n export interface IHeaderResult {\n /**\n * The discriminated type of the object.\n */\n readonly type: 'header';\n\n /**\n * The category for the header.\n */\n readonly category: string;\n\n /**\n * The indices of the matched category characters.\n */\n readonly indices: ReadonlyArray | null;\n }\n\n /**\n * A search result object for a command item.\n */\n export interface IItemResult {\n /**\n * The discriminated type of the object.\n */\n readonly type: 'item';\n\n /**\n * The command item which was matched.\n */\n readonly item: CommandPalette.IItem;\n\n /**\n * The indices of the matched label characters.\n */\n readonly indices: ReadonlyArray | null;\n }\n\n /**\n * A type alias for a search result item.\n */\n export type SearchResult = IHeaderResult | IItemResult;\n\n /**\n * Search an array of command items for fuzzy matches.\n */\n export function search(\n items: CommandPalette.IItem[],\n query: string\n ): SearchResult[] {\n // Fuzzy match the items for the query.\n let scores = matchItems(items, query);\n\n // Sort the items based on their score.\n scores.sort(scoreCmp);\n\n // Create the results for the search.\n return createResults(scores);\n }\n\n /**\n * Test whether a result item can be activated.\n */\n export function canActivate(result: SearchResult): boolean {\n return result.type === 'item' && result.item.isEnabled;\n }\n\n /**\n * Normalize a category for a command item.\n */\n function normalizeCategory(category: string): string {\n return category.trim().replace(/\\s+/g, ' ');\n }\n\n /**\n * Normalize the query text for a fuzzy search.\n */\n function normalizeQuery(text: string): string {\n return text.replace(/\\s+/g, '').toLowerCase();\n }\n\n /**\n * An enum of the supported match types.\n */\n const enum MatchType {\n Label,\n Category,\n Split,\n Default\n }\n\n /**\n * A text match score with associated command item.\n */\n interface IScore {\n /**\n * The numerical type for the text match.\n */\n matchType: MatchType;\n\n /**\n * The numerical score for the text match.\n */\n score: number;\n\n /**\n * The indices of the matched category characters.\n */\n categoryIndices: number[] | null;\n\n /**\n * The indices of the matched label characters.\n */\n labelIndices: number[] | null;\n\n /**\n * The command item associated with the match.\n */\n item: CommandPalette.IItem;\n }\n\n /**\n * Perform a fuzzy match on an array of command items.\n */\n function matchItems(items: CommandPalette.IItem[], query: string): IScore[] {\n // Normalize the query text to lower case with no whitespace.\n query = normalizeQuery(query);\n\n // Create the array to hold the scores.\n let scores: IScore[] = [];\n\n // Iterate over the items and match against the query.\n for (let i = 0, n = items.length; i < n; ++i) {\n // Ignore items which are not visible.\n let item = items[i];\n if (!item.isVisible) {\n continue;\n }\n\n // If the query is empty, all items are matched by default.\n if (!query) {\n scores.push({\n matchType: MatchType.Default,\n categoryIndices: null,\n labelIndices: null,\n score: 0,\n item\n });\n continue;\n }\n\n // Run the fuzzy search for the item and query.\n let score = fuzzySearch(item, query);\n\n // Ignore the item if it is not a match.\n if (!score) {\n continue;\n }\n\n // Penalize disabled items.\n // TODO - push disabled items all the way down in sort cmp?\n if (!item.isEnabled) {\n score.score += 1000;\n }\n\n // Add the score to the results.\n scores.push(score);\n }\n\n // Return the final array of scores.\n return scores;\n }\n\n /**\n * Perform a fuzzy search on a single command item.\n */\n function fuzzySearch(\n item: CommandPalette.IItem,\n query: string\n ): IScore | null {\n // Create the source text to be searched.\n let category = item.category.toLowerCase();\n let label = item.label.toLowerCase();\n let source = `${category} ${label}`;\n\n // Set up the match score and indices array.\n let score = Infinity;\n let indices: number[] | null = null;\n\n // The regex for search word boundaries\n let rgx = /\\b\\w/g;\n\n // Search the source by word boundary.\n // eslint-disable-next-line no-constant-condition\n while (true) {\n // Find the next word boundary in the source.\n let rgxMatch = rgx.exec(source);\n\n // Break if there is no more source context.\n if (!rgxMatch) {\n break;\n }\n\n // Run the string match on the relevant substring.\n let match = StringExt.matchSumOfDeltas(source, query, rgxMatch.index);\n\n // Break if there is no match.\n if (!match) {\n break;\n }\n\n // Update the match if the score is better.\n if (match.score <= score) {\n score = match.score;\n indices = match.indices;\n }\n }\n\n // Bail if there was no match.\n if (!indices || score === Infinity) {\n return null;\n }\n\n // Compute the pivot index between category and label text.\n let pivot = category.length + 1;\n\n // Find the slice index to separate matched indices.\n let j = ArrayExt.lowerBound(indices, pivot, (a, b) => a - b);\n\n // Extract the matched category and label indices.\n let categoryIndices = indices.slice(0, j);\n let labelIndices = indices.slice(j);\n\n // Adjust the label indices for the pivot offset.\n for (let i = 0, n = labelIndices.length; i < n; ++i) {\n labelIndices[i] -= pivot;\n }\n\n // Handle a pure label match.\n if (categoryIndices.length === 0) {\n return {\n matchType: MatchType.Label,\n categoryIndices: null,\n labelIndices,\n score,\n item\n };\n }\n\n // Handle a pure category match.\n if (labelIndices.length === 0) {\n return {\n matchType: MatchType.Category,\n categoryIndices,\n labelIndices: null,\n score,\n item\n };\n }\n\n // Handle a split match.\n return {\n matchType: MatchType.Split,\n categoryIndices,\n labelIndices,\n score,\n item\n };\n }\n\n /**\n * A sort comparison function for a match score.\n */\n function scoreCmp(a: IScore, b: IScore): number {\n // First compare based on the match type\n let m1 = a.matchType - b.matchType;\n if (m1 !== 0) {\n return m1;\n }\n\n // Otherwise, compare based on the match score.\n let d1 = a.score - b.score;\n if (d1 !== 0) {\n return d1;\n }\n\n // Find the match index based on the match type.\n let i1 = 0;\n let i2 = 0;\n switch (a.matchType) {\n case MatchType.Label:\n i1 = a.labelIndices![0];\n i2 = b.labelIndices![0];\n break;\n case MatchType.Category:\n case MatchType.Split:\n i1 = a.categoryIndices![0];\n i2 = b.categoryIndices![0];\n break;\n }\n\n // Compare based on the match index.\n if (i1 !== i2) {\n return i1 - i2;\n }\n\n // Otherwise, compare by category.\n let d2 = a.item.category.localeCompare(b.item.category);\n if (d2 !== 0) {\n return d2;\n }\n\n // Otherwise, compare by rank.\n let r1 = a.item.rank;\n let r2 = b.item.rank;\n if (r1 !== r2) {\n return r1 < r2 ? -1 : 1; // Infinity safe\n }\n\n // Finally, compare by label.\n return a.item.label.localeCompare(b.item.label);\n }\n\n /**\n * Create the results from an array of sorted scores.\n */\n function createResults(scores: IScore[]): SearchResult[] {\n // Set up the search results array.\n let results: SearchResult[] = [];\n\n // Iterate over each score in the array.\n for (let i = 0, n = scores.length; i < n; ++i) {\n // Extract the current item and indices.\n let { item, categoryIndices, labelIndices } = scores[i];\n\n // Extract the category for the current item.\n let category = item.category;\n\n // Is this the same category as the preceding result?\n if (i === 0 || category !== scores[i - 1].item.category) {\n // Add the header result for the category.\n results.push({ type: 'header', category, indices: categoryIndices });\n }\n\n // Create the item result for the score.\n results.push({ type: 'item', item, indices: labelIndices });\n }\n\n // Return the final results.\n return results;\n }\n\n /**\n * A concrete implementation of `CommandPalette.IItem`.\n */\n class CommandItem implements CommandPalette.IItem {\n /**\n * Construct a new command item.\n */\n constructor(\n commands: CommandRegistry,\n options: CommandPalette.IItemOptions\n ) {\n this._commands = commands;\n this.category = normalizeCategory(options.category);\n this.command = options.command;\n this.args = options.args || JSONExt.emptyObject;\n this.rank = options.rank !== undefined ? options.rank : Infinity;\n }\n\n /**\n * The category for the command item.\n */\n readonly category: string;\n\n /**\n * The command to execute when the item is triggered.\n */\n readonly command: string;\n\n /**\n * The arguments for the command.\n */\n readonly args: ReadonlyJSONObject;\n\n /**\n * The rank for the command item.\n */\n readonly rank: number;\n\n /**\n * The display label for the command item.\n */\n get label(): string {\n return this._commands.label(this.command, this.args);\n }\n\n /**\n * The icon renderer for the command item.\n */\n get icon(): VirtualElement.IRenderer | undefined {\n return this._commands.icon(this.command, this.args);\n }\n\n /**\n * The icon class for the command item.\n */\n get iconClass(): string {\n return this._commands.iconClass(this.command, this.args);\n }\n\n /**\n * The icon label for the command item.\n */\n get iconLabel(): string {\n return this._commands.iconLabel(this.command, this.args);\n }\n\n /**\n * The display caption for the command item.\n */\n get caption(): string {\n return this._commands.caption(this.command, this.args);\n }\n\n /**\n * The extra class name for the command item.\n */\n get className(): string {\n return this._commands.className(this.command, this.args);\n }\n\n /**\n * The dataset for the command item.\n */\n get dataset(): CommandRegistry.Dataset {\n return this._commands.dataset(this.command, this.args);\n }\n\n /**\n * Whether the command item is enabled.\n */\n get isEnabled(): boolean {\n return this._commands.isEnabled(this.command, this.args);\n }\n\n /**\n * Whether the command item is toggled.\n */\n get isToggled(): boolean {\n return this._commands.isToggled(this.command, this.args);\n }\n\n /**\n * Whether the command item is toggleable.\n */\n get isToggleable(): boolean {\n return this._commands.isToggleable(this.command, this.args);\n }\n\n /**\n * Whether the command item is visible.\n */\n get isVisible(): boolean {\n return this._commands.isVisible(this.command, this.args);\n }\n\n /**\n * The key binding for the command item.\n */\n get keyBinding(): CommandRegistry.IKeyBinding | null {\n let { command, args } = this;\n return (\n ArrayExt.findLastValue(this._commands.keyBindings, kb => {\n return kb.command === command && JSONExt.deepEqual(kb.args, args);\n }) || null\n );\n }\n\n private _commands: CommandRegistry;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { CommandRegistry } from '@lumino/commands';\n\nimport { JSONExt, ReadonlyJSONObject } from '@lumino/coreutils';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { getKeyboardLayout } from '@lumino/keyboard';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport {\n ARIAAttrNames,\n ElementARIAAttrs,\n ElementDataset,\n h,\n VirtualDOM,\n VirtualElement\n} from '@lumino/virtualdom';\n\nimport { Widget } from './widget';\n\ninterface IWindowData {\n pageXOffset: number;\n pageYOffset: number;\n clientWidth: number;\n clientHeight: number;\n}\n\n/**\n * A widget which displays items as a canonical menu.\n */\nexport class Menu extends Widget {\n /**\n * Construct a new menu.\n *\n * @param options - The options for initializing the menu.\n */\n constructor(options: Menu.IOptions) {\n super({ node: Private.createNode() });\n this.addClass('lm-Menu');\n this.setFlag(Widget.Flag.DisallowLayout);\n this.commands = options.commands;\n this.renderer = options.renderer || Menu.defaultRenderer;\n }\n\n /**\n * Dispose of the resources held by the menu.\n */\n dispose(): void {\n this.close();\n this._items.length = 0;\n super.dispose();\n }\n\n /**\n * A signal emitted just before the menu is closed.\n *\n * #### Notes\n * This signal is emitted when the menu receives a `'close-request'`\n * message, just before it removes itself from the DOM.\n *\n * This signal is not emitted if the menu is already detached from\n * the DOM when it receives the `'close-request'` message.\n */\n get aboutToClose(): ISignal {\n return this._aboutToClose;\n }\n\n /**\n * A signal emitted when a new menu is requested by the user.\n *\n * #### Notes\n * This signal is emitted whenever the user presses the right or left\n * arrow keys, and a submenu cannot be opened or closed in response.\n *\n * This signal is useful when implementing menu bars in order to open\n * the next or previous menu in response to a user key press.\n *\n * This signal is only emitted for the root menu in a hierarchy.\n */\n get menuRequested(): ISignal {\n return this._menuRequested;\n }\n\n /**\n * The command registry used by the menu.\n */\n readonly commands: CommandRegistry;\n\n /**\n * The renderer used by the menu.\n */\n readonly renderer: Menu.IRenderer;\n\n /**\n * The parent menu of the menu.\n *\n * #### Notes\n * This is `null` unless the menu is an open submenu.\n */\n get parentMenu(): Menu | null {\n return this._parentMenu;\n }\n\n /**\n * The child menu of the menu.\n *\n * #### Notes\n * This is `null` unless the menu has an open submenu.\n */\n get childMenu(): Menu | null {\n return this._childMenu;\n }\n\n /**\n * The root menu of the menu hierarchy.\n */\n get rootMenu(): Menu {\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n let menu: Menu = this;\n while (menu._parentMenu) {\n menu = menu._parentMenu;\n }\n return menu;\n }\n\n /**\n * The leaf menu of the menu hierarchy.\n */\n get leafMenu(): Menu {\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n let menu: Menu = this;\n while (menu._childMenu) {\n menu = menu._childMenu;\n }\n return menu;\n }\n\n /**\n * The menu content node.\n *\n * #### Notes\n * This is the node which holds the menu item nodes.\n *\n * Modifying this node directly can lead to undefined behavior.\n */\n get contentNode(): HTMLUListElement {\n return this.node.getElementsByClassName(\n 'lm-Menu-content'\n )[0] as HTMLUListElement;\n }\n\n /**\n * Get the currently active menu item.\n */\n get activeItem(): Menu.IItem | null {\n return this._items[this._activeIndex] || null;\n }\n\n /**\n * Set the currently active menu item.\n *\n * #### Notes\n * If the item cannot be activated, the item will be set to `null`.\n */\n set activeItem(value: Menu.IItem | null) {\n this.activeIndex = value ? this._items.indexOf(value) : -1;\n }\n\n /**\n * Get the index of the currently active menu item.\n *\n * #### Notes\n * This will be `-1` if no menu item is active.\n */\n get activeIndex(): number {\n return this._activeIndex;\n }\n\n /**\n * Set the index of the currently active menu item.\n *\n * #### Notes\n * If the item cannot be activated, the index will be set to `-1`.\n */\n set activeIndex(value: number) {\n // Adjust the value for an out of range index.\n if (value < 0 || value >= this._items.length) {\n value = -1;\n }\n\n // Ensure the item can be activated.\n if (value !== -1 && !Private.canActivate(this._items[value])) {\n value = -1;\n }\n\n // Bail if the index will not change.\n if (this._activeIndex === value) {\n return;\n }\n\n // Update the active index.\n this._activeIndex = value;\n\n // Make active element in focus\n if (\n this._activeIndex >= 0 &&\n this.contentNode.childNodes[this._activeIndex]\n ) {\n (this.contentNode.childNodes[this._activeIndex] as HTMLElement).focus();\n }\n\n // schedule an update of the items.\n this.update();\n }\n\n /**\n * A read-only array of the menu items in the menu.\n */\n get items(): ReadonlyArray {\n return this._items;\n }\n\n /**\n * Activate the next selectable item in the menu.\n *\n * #### Notes\n * If no item is selectable, the index will be set to `-1`.\n */\n activateNextItem(): void {\n let n = this._items.length;\n let ai = this._activeIndex;\n let start = ai < n - 1 ? ai + 1 : 0;\n let stop = start === 0 ? n - 1 : start - 1;\n this.activeIndex = ArrayExt.findFirstIndex(\n this._items,\n Private.canActivate,\n start,\n stop\n );\n }\n\n /**\n * Activate the previous selectable item in the menu.\n *\n * #### Notes\n * If no item is selectable, the index will be set to `-1`.\n */\n activatePreviousItem(): void {\n let n = this._items.length;\n let ai = this._activeIndex;\n let start = ai <= 0 ? n - 1 : ai - 1;\n let stop = start === n - 1 ? 0 : start + 1;\n this.activeIndex = ArrayExt.findLastIndex(\n this._items,\n Private.canActivate,\n start,\n stop\n );\n }\n\n /**\n * Trigger the active menu item.\n *\n * #### Notes\n * If the active item is a submenu, it will be opened and the first\n * item will be activated.\n *\n * If the active item is a command, the command will be executed.\n *\n * If the menu is not attached, this is a no-op.\n *\n * If there is no active item, this is a no-op.\n */\n triggerActiveItem(): void {\n // Bail if the menu is not attached.\n if (!this.isAttached) {\n return;\n }\n\n // Bail if there is no active item.\n let item = this.activeItem;\n if (!item) {\n return;\n }\n\n // Cancel the pending timers.\n this._cancelOpenTimer();\n this._cancelCloseTimer();\n\n // If the item is a submenu, open it.\n if (item.type === 'submenu') {\n this._openChildMenu(true);\n return;\n }\n\n // Close the root menu before executing the command.\n this.rootMenu.close();\n\n // Execute the command for the item.\n let { command, args } = item;\n if (this.commands.isEnabled(command, args)) {\n this.commands.execute(command, args);\n } else {\n console.log(`Command '${command}' is disabled.`);\n }\n }\n\n /**\n * Add a menu item to the end of the menu.\n *\n * @param options - The options for creating the menu item.\n *\n * @returns The menu item added to the menu.\n */\n addItem(options: Menu.IItemOptions): Menu.IItem {\n return this.insertItem(this._items.length, options);\n }\n\n /**\n * Insert a menu item into the menu at the specified index.\n *\n * @param index - The index at which to insert the item.\n *\n * @param options - The options for creating the menu item.\n *\n * @returns The menu item added to the menu.\n *\n * #### Notes\n * The index will be clamped to the bounds of the items.\n */\n insertItem(index: number, options: Menu.IItemOptions): Menu.IItem {\n // Close the menu if it's attached.\n if (this.isAttached) {\n this.close();\n }\n\n // Reset the active index.\n this.activeIndex = -1;\n\n // Clamp the insert index to the array bounds.\n let i = Math.max(0, Math.min(index, this._items.length));\n\n // Create the item for the options.\n let item = Private.createItem(this, options);\n\n // Insert the item into the array.\n ArrayExt.insert(this._items, i, item);\n\n // Schedule an update of the items.\n this.update();\n\n // Return the item added to the menu.\n return item;\n }\n\n /**\n * Remove an item from the menu.\n *\n * @param item - The item to remove from the menu.\n *\n * #### Notes\n * This is a no-op if the item is not in the menu.\n */\n removeItem(item: Menu.IItem): void {\n this.removeItemAt(this._items.indexOf(item));\n }\n\n /**\n * Remove the item at a given index from the menu.\n *\n * @param index - The index of the item to remove.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n removeItemAt(index: number): void {\n // Close the menu if it's attached.\n if (this.isAttached) {\n this.close();\n }\n\n // Reset the active index.\n this.activeIndex = -1;\n\n // Remove the item from the array.\n let item = ArrayExt.removeAt(this._items, index);\n\n // Bail if the index is out of range.\n if (!item) {\n return;\n }\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * Remove all menu items from the menu.\n */\n clearItems(): void {\n // Close the menu if it's attached.\n if (this.isAttached) {\n this.close();\n }\n\n // Reset the active index.\n this.activeIndex = -1;\n\n // Bail if there is nothing to remove.\n if (this._items.length === 0) {\n return;\n }\n\n // Clear the items.\n this._items.length = 0;\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * Open the menu at the specified location.\n *\n * @param x - The client X coordinate of the menu location.\n *\n * @param y - The client Y coordinate of the menu location.\n *\n * @param options - The additional options for opening the menu.\n *\n * #### Notes\n * The menu will be opened at the given location unless it will not\n * fully fit on the screen. If it will not fit, it will be adjusted\n * to fit naturally on the screen.\n *\n * The menu will be attached under the `host` element in the DOM\n * (or `document.body` if `host` is `null`) and before the `ref`\n * element (or as the last child of `host` if `ref` is `null`).\n * The menu may be displayed outside of the `host` element\n * following the rules of CSS absolute positioning.\n *\n * This is a no-op if the menu is already attached to the DOM.\n */\n open(x: number, y: number, options: Menu.IOpenOptions = {}): void {\n // Bail early if the menu is already attached.\n if (this.isAttached) {\n return;\n }\n\n // Extract the menu options.\n let forceX = options.forceX || false;\n let forceY = options.forceY || false;\n const host = options.host ?? null;\n const ref = options.ref ?? null;\n\n // Open the menu as a root menu.\n Private.openRootMenu(this, x, y, forceX, forceY, host, ref);\n\n // Activate the menu to accept keyboard input.\n this.activate();\n }\n\n /**\n * Handle the DOM events for the menu.\n *\n * @param event - The DOM event sent to the menu.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the menu's DOM nodes. It should\n * not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'mouseup':\n this._evtMouseUp(event as MouseEvent);\n break;\n case 'mousemove':\n this._evtMouseMove(event as MouseEvent);\n break;\n case 'mouseenter':\n this._evtMouseEnter(event as MouseEvent);\n break;\n case 'mouseleave':\n this._evtMouseLeave(event as MouseEvent);\n break;\n case 'mousedown':\n this._evtMouseDown(event as MouseEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('keydown', this);\n this.node.addEventListener('mouseup', this);\n this.node.addEventListener('mousemove', this);\n this.node.addEventListener('mouseenter', this);\n this.node.addEventListener('mouseleave', this);\n this.node.addEventListener('contextmenu', this);\n this.node.ownerDocument.addEventListener('mousedown', this, true);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('keydown', this);\n this.node.removeEventListener('mouseup', this);\n this.node.removeEventListener('mousemove', this);\n this.node.removeEventListener('mouseenter', this);\n this.node.removeEventListener('mouseleave', this);\n this.node.removeEventListener('contextmenu', this);\n this.node.ownerDocument.removeEventListener('mousedown', this, true);\n }\n\n /**\n * A message handler invoked on an `'activate-request'` message.\n */\n protected onActivateRequest(msg: Message): void {\n if (this.isAttached) {\n this.node.focus();\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n let items = this._items;\n let renderer = this.renderer;\n let activeIndex = this._activeIndex;\n let collapsedFlags = Private.computeCollapsed(items);\n let content = new Array(items.length);\n for (let i = 0, n = items.length; i < n; ++i) {\n let item = items[i];\n let active = i === activeIndex;\n let collapsed = collapsedFlags[i];\n content[i] = renderer.renderItem({\n item,\n active,\n collapsed,\n onfocus: () => {\n this.activeIndex = i;\n }\n });\n }\n VirtualDOM.render(content, this.contentNode);\n }\n\n /**\n * A message handler invoked on a `'close-request'` message.\n */\n protected onCloseRequest(msg: Message): void {\n // Cancel the pending timers.\n this._cancelOpenTimer();\n this._cancelCloseTimer();\n\n // Reset the active index.\n this.activeIndex = -1;\n\n // Close any open child menu.\n let childMenu = this._childMenu;\n if (childMenu) {\n this._childIndex = -1;\n this._childMenu = null;\n childMenu._parentMenu = null;\n childMenu.close();\n }\n\n // Remove this menu from its parent and activate the parent.\n let parentMenu = this._parentMenu;\n if (parentMenu) {\n this._parentMenu = null;\n parentMenu._childIndex = -1;\n parentMenu._childMenu = null;\n parentMenu.activate();\n }\n\n // Emit the `aboutToClose` signal if the menu is attached.\n if (this.isAttached) {\n this._aboutToClose.emit(undefined);\n }\n\n // Finish closing the menu.\n super.onCloseRequest(msg);\n }\n\n /**\n * Handle the `'keydown'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the menu node.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // A menu handles all keydown events.\n event.preventDefault();\n event.stopPropagation();\n\n // Fetch the key code for the event.\n let kc = event.keyCode;\n\n // Enter\n if (kc === 13) {\n this.triggerActiveItem();\n return;\n }\n\n // Escape\n if (kc === 27) {\n this.close();\n return;\n }\n\n // Left Arrow\n if (kc === 37) {\n if (this._parentMenu) {\n this.close();\n } else {\n this._menuRequested.emit('previous');\n }\n return;\n }\n\n // Up Arrow\n if (kc === 38) {\n this.activatePreviousItem();\n return;\n }\n\n // Right Arrow\n if (kc === 39) {\n let item = this.activeItem;\n if (item && item.type === 'submenu') {\n this.triggerActiveItem();\n } else {\n this.rootMenu._menuRequested.emit('next');\n }\n return;\n }\n\n // Down Arrow\n if (kc === 40) {\n this.activateNextItem();\n return;\n }\n\n // Get the pressed key character.\n let key = getKeyboardLayout().keyForKeydownEvent(event);\n\n // Bail if the key is not valid.\n if (!key) {\n return;\n }\n\n // Search for the next best matching mnemonic item.\n let start = this._activeIndex + 1;\n let result = Private.findMnemonic(this._items, key, start);\n\n // Handle the requested mnemonic based on the search results.\n // If exactly one mnemonic is matched, that item is triggered.\n // Otherwise, the next mnemonic is activated if available,\n // followed by the auto mnemonic if available.\n if (result.index !== -1 && !result.multiple) {\n this.activeIndex = result.index;\n this.triggerActiveItem();\n } else if (result.index !== -1) {\n this.activeIndex = result.index;\n } else if (result.auto !== -1) {\n this.activeIndex = result.auto;\n }\n }\n\n /**\n * Handle the `'mouseup'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the menu node.\n */\n private _evtMouseUp(event: MouseEvent): void {\n if (event.button !== 0) {\n return;\n }\n event.preventDefault();\n event.stopPropagation();\n this.triggerActiveItem();\n }\n\n /**\n * Handle the `'mousemove'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the menu node.\n */\n private _evtMouseMove(event: MouseEvent): void {\n // Hit test the item nodes for the item under the mouse.\n let index = ArrayExt.findFirstIndex(this.contentNode.children, node => {\n return ElementExt.hitTest(node, event.clientX, event.clientY);\n });\n\n // Bail early if the mouse is already over the active index.\n if (index === this._activeIndex) {\n return;\n }\n\n // Update and coerce the active index.\n this.activeIndex = index;\n index = this.activeIndex;\n\n // If the index is the current child index, cancel the timers.\n if (index === this._childIndex) {\n this._cancelOpenTimer();\n this._cancelCloseTimer();\n return;\n }\n\n // If a child menu is currently open, start the close timer.\n if (this._childIndex !== -1) {\n this._startCloseTimer();\n }\n\n // Cancel the open timer to give a full delay for opening.\n this._cancelOpenTimer();\n\n // Bail if the active item is not a valid submenu item.\n let item = this.activeItem;\n if (!item || item.type !== 'submenu' || !item.submenu) {\n return;\n }\n\n // Start the open timer to open the active item submenu.\n this._startOpenTimer();\n }\n\n /**\n * Handle the `'mouseenter'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the menu node.\n */\n private _evtMouseEnter(event: MouseEvent): void {\n // Synchronize the active ancestor items.\n for (let menu = this._parentMenu; menu; menu = menu._parentMenu) {\n menu._cancelOpenTimer();\n menu._cancelCloseTimer();\n menu.activeIndex = menu._childIndex;\n }\n }\n\n /**\n * Handle the `'mouseleave'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the menu node.\n */\n private _evtMouseLeave(event: MouseEvent): void {\n // Cancel any pending submenu opening.\n this._cancelOpenTimer();\n\n // If there is no open child menu, just reset the active index.\n if (!this._childMenu) {\n this.activeIndex = -1;\n return;\n }\n\n // If the mouse is over the child menu, cancel the close timer.\n let { clientX, clientY } = event;\n if (ElementExt.hitTest(this._childMenu.node, clientX, clientY)) {\n this._cancelCloseTimer();\n return;\n }\n\n // Otherwise, reset the active index and start the close timer.\n this.activeIndex = -1;\n this._startCloseTimer();\n }\n\n /**\n * Handle the `'mousedown'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the document node.\n */\n private _evtMouseDown(event: MouseEvent): void {\n // Bail if the menu is not a root menu.\n if (this._parentMenu) {\n return;\n }\n\n // The mouse button which is pressed is irrelevant. If the press\n // is not on a menu, the entire hierarchy is closed and the event\n // is allowed to propagate. This allows other code to act on the\n // event, such as focusing the clicked element.\n if (Private.hitTestMenus(this, event.clientX, event.clientY)) {\n event.preventDefault();\n event.stopPropagation();\n } else {\n this.close();\n }\n }\n\n /**\n * Open the child menu at the active index immediately.\n *\n * If a different child menu is already open, it will be closed,\n * even if the active item is not a valid submenu.\n */\n private _openChildMenu(activateFirst = false): void {\n // If the item is not a valid submenu, close the child menu.\n let item = this.activeItem;\n if (!item || item.type !== 'submenu' || !item.submenu) {\n this._closeChildMenu();\n return;\n }\n\n // Do nothing if the child menu will not change.\n let submenu = item.submenu;\n if (submenu === this._childMenu) {\n return;\n }\n\n // Prior to any DOM modifications save window data\n Menu.saveWindowData();\n\n // Ensure the current child menu is closed.\n this._closeChildMenu();\n\n // Update the private child state.\n this._childMenu = submenu;\n this._childIndex = this._activeIndex;\n\n // Set the parent menu reference for the child.\n submenu._parentMenu = this;\n\n // Ensure the menu is updated and lookup the item node.\n MessageLoop.sendMessage(this, Widget.Msg.UpdateRequest);\n let itemNode = this.contentNode.children[this._activeIndex];\n\n // Open the submenu at the active node.\n Private.openSubmenu(submenu, itemNode as HTMLElement);\n\n // Activate the first item if desired.\n if (activateFirst) {\n submenu.activeIndex = -1;\n submenu.activateNextItem();\n }\n\n // Activate the child menu.\n submenu.activate();\n }\n\n /**\n * Close the child menu immediately.\n *\n * This is a no-op if a child menu is not open.\n */\n private _closeChildMenu(): void {\n if (this._childMenu) {\n this._childMenu.close();\n }\n }\n\n /**\n * Start the open timer, unless it is already pending.\n */\n private _startOpenTimer(): void {\n if (this._openTimerID === 0) {\n this._openTimerID = window.setTimeout(() => {\n this._openTimerID = 0;\n this._openChildMenu();\n }, Private.TIMER_DELAY);\n }\n }\n\n /**\n * Start the close timer, unless it is already pending.\n */\n private _startCloseTimer(): void {\n if (this._closeTimerID === 0) {\n this._closeTimerID = window.setTimeout(() => {\n this._closeTimerID = 0;\n this._closeChildMenu();\n }, Private.TIMER_DELAY);\n }\n }\n\n /**\n * Cancel the open timer, if the timer is pending.\n */\n private _cancelOpenTimer(): void {\n if (this._openTimerID !== 0) {\n clearTimeout(this._openTimerID);\n this._openTimerID = 0;\n }\n }\n\n /**\n * Cancel the close timer, if the timer is pending.\n */\n private _cancelCloseTimer(): void {\n if (this._closeTimerID !== 0) {\n clearTimeout(this._closeTimerID);\n this._closeTimerID = 0;\n }\n }\n\n /**\n * Save window data used for menu positioning in transient cache.\n *\n * In order to avoid layout trashing it is recommended to invoke this\n * method immediately prior to opening the menu and any DOM modifications\n * (like closing previously visible menu, or adding a class to menu widget).\n *\n * The transient cache will be released upon `open()` call.\n */\n static saveWindowData(): void {\n Private.saveWindowData();\n }\n\n private _childIndex = -1;\n private _activeIndex = -1;\n private _openTimerID = 0;\n private _closeTimerID = 0;\n private _items: Menu.IItem[] = [];\n private _childMenu: Menu | null = null;\n private _parentMenu: Menu | null = null;\n private _aboutToClose = new Signal(this);\n private _menuRequested = new Signal(this);\n}\n\n/**\n * The namespace for the `Menu` class statics.\n */\nexport namespace Menu {\n /**\n * An options object for creating a menu.\n */\n export interface IOptions {\n /**\n * The command registry for use with the menu.\n */\n commands: CommandRegistry;\n\n /**\n * A custom renderer for use with the menu.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n }\n\n /**\n * An options object for the `open` method on a menu.\n */\n export interface IOpenOptions {\n /**\n * Whether to force the X position of the menu.\n *\n * Setting to `true` will disable the logic which repositions the\n * X coordinate of the menu if it will not fit entirely on screen.\n *\n * The default is `false`.\n */\n forceX?: boolean;\n\n /**\n * Whether to force the Y position of the menu.\n *\n * Setting to `true` will disable the logic which repositions the\n * Y coordinate of the menu if it will not fit entirely on screen.\n *\n * The default is `false`.\n */\n forceY?: boolean;\n\n /**\n * The DOM node to use as the menu's host.\n *\n * If not specified then uses `document.body`.\n */\n host?: HTMLElement;\n\n /**\n * The child of `host` to use as the reference element.\n * If this is provided, the menu will be inserted before this\n * node in the host. The default is `null`, which will cause the\n * menu to be added as the last child of the host.\n */\n ref?: HTMLElement;\n }\n\n /**\n * A type alias for a menu item type.\n */\n export type ItemType = 'command' | 'submenu' | 'separator';\n\n /**\n * An options object for creating a menu item.\n */\n export interface IItemOptions {\n /**\n * The type of the menu item.\n *\n * The default value is `'command'`.\n */\n type?: ItemType;\n\n /**\n * The command to execute when the item is triggered.\n *\n * The default value is an empty string.\n */\n command?: string;\n\n /**\n * The arguments for the command.\n *\n * The default value is an empty object.\n */\n args?: ReadonlyJSONObject;\n\n /**\n * The submenu for a `'submenu'` type item.\n *\n * The default value is `null`.\n */\n submenu?: Menu | null;\n }\n\n /**\n * An object which represents a menu item.\n *\n * #### Notes\n * Item objects are created automatically by a menu.\n */\n export interface IItem {\n /**\n * The type of the menu item.\n */\n readonly type: ItemType;\n\n /**\n * The command to execute when the item is triggered.\n */\n readonly command: string;\n\n /**\n * The arguments for the command.\n */\n readonly args: ReadonlyJSONObject;\n\n /**\n * The submenu for a `'submenu'` type item.\n */\n readonly submenu: Menu | null;\n\n /**\n * The display label for the menu item.\n */\n readonly label: string;\n\n /**\n * The mnemonic index for the menu item.\n */\n readonly mnemonic: number;\n\n /**\n * The icon renderer for the menu item.\n */\n readonly icon: VirtualElement.IRenderer | undefined;\n\n /**\n * The icon class for the menu item.\n */\n readonly iconClass: string;\n\n /**\n * The icon label for the menu item.\n */\n readonly iconLabel: string;\n\n /**\n * The display caption for the menu item.\n */\n readonly caption: string;\n\n /**\n * The extra class name for the menu item.\n */\n readonly className: string;\n\n /**\n * The dataset for the menu item.\n */\n readonly dataset: CommandRegistry.Dataset;\n\n /**\n * Whether the menu item is enabled.\n */\n readonly isEnabled: boolean;\n\n /**\n * Whether the menu item is toggled.\n */\n readonly isToggled: boolean;\n\n /**\n * Whether the menu item is visible.\n */\n readonly isVisible: boolean;\n\n /**\n * The key binding for the menu item.\n */\n readonly keyBinding: CommandRegistry.IKeyBinding | null;\n }\n\n /**\n * An object which holds the data to render a menu item.\n */\n export interface IRenderData {\n /**\n * The item to be rendered.\n */\n readonly item: IItem;\n\n /**\n * Whether the item is the active item.\n */\n readonly active: boolean;\n\n /**\n * Whether the item should be collapsed.\n */\n readonly collapsed: boolean;\n\n /**\n * Handler for when element is in focus.\n */\n readonly onfocus?: () => void;\n }\n\n /**\n * A renderer for use with a menu.\n */\n export interface IRenderer {\n /**\n * Render the virtual element for a menu item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n */\n renderItem(data: IRenderData): VirtualElement;\n }\n\n /**\n * The default implementation of `IRenderer`.\n *\n * #### Notes\n * Subclasses are free to reimplement rendering methods as needed.\n */\n export class Renderer implements IRenderer {\n /**\n * Render the virtual element for a menu item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n */\n renderItem(data: IRenderData): VirtualElement {\n let className = this.createItemClass(data);\n let dataset = this.createItemDataset(data);\n let aria = this.createItemARIA(data);\n return h.li(\n {\n className,\n dataset,\n tabindex: '0',\n onfocus: data.onfocus,\n ...aria\n },\n this.renderIcon(data),\n this.renderLabel(data),\n this.renderShortcut(data),\n this.renderSubmenu(data)\n );\n }\n\n /**\n * Render the icon element for a menu item.\n *\n * @param data - The data to use for rendering the icon.\n *\n * @returns A virtual element representing the item icon.\n */\n renderIcon(data: IRenderData): VirtualElement {\n let className = this.createIconClass(data);\n\n // If data.item.icon is undefined, it will be ignored.\n return h.div({ className }, data.item.icon!, data.item.iconLabel);\n }\n\n /**\n * Render the label element for a menu item.\n *\n * @param data - The data to use for rendering the label.\n *\n * @returns A virtual element representing the item label.\n */\n renderLabel(data: IRenderData): VirtualElement {\n let content = this.formatLabel(data);\n return h.div({ className: 'lm-Menu-itemLabel' }, content);\n }\n\n /**\n * Render the shortcut element for a menu item.\n *\n * @param data - The data to use for rendering the shortcut.\n *\n * @returns A virtual element representing the item shortcut.\n */\n renderShortcut(data: IRenderData): VirtualElement {\n let content = this.formatShortcut(data);\n return h.div({ className: 'lm-Menu-itemShortcut' }, content);\n }\n\n /**\n * Render the submenu icon element for a menu item.\n *\n * @param data - The data to use for rendering the submenu icon.\n *\n * @returns A virtual element representing the submenu icon.\n */\n renderSubmenu(data: IRenderData): VirtualElement {\n return h.div({ className: 'lm-Menu-itemSubmenuIcon' });\n }\n\n /**\n * Create the class name for the menu item.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the menu item.\n */\n createItemClass(data: IRenderData): string {\n // Setup the initial class name.\n let name = 'lm-Menu-item';\n\n // Add the boolean state classes.\n if (!data.item.isEnabled) {\n name += ' lm-mod-disabled';\n }\n if (data.item.isToggled) {\n name += ' lm-mod-toggled';\n }\n if (!data.item.isVisible) {\n name += ' lm-mod-hidden';\n }\n if (data.active) {\n name += ' lm-mod-active';\n }\n if (data.collapsed) {\n name += ' lm-mod-collapsed';\n }\n\n // Add the extra class.\n let extra = data.item.className;\n if (extra) {\n name += ` ${extra}`;\n }\n\n // Return the complete class name.\n return name;\n }\n\n /**\n * Create the dataset for the menu item.\n *\n * @param data - The data to use for creating the dataset.\n *\n * @returns The dataset for the menu item.\n */\n createItemDataset(data: IRenderData): ElementDataset {\n let result: ElementDataset;\n let { type, command, dataset } = data.item;\n if (type === 'command') {\n result = { ...dataset, type, command };\n } else {\n result = { ...dataset, type };\n }\n return result;\n }\n\n /**\n * Create the class name for the menu item icon.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the item icon.\n */\n createIconClass(data: IRenderData): string {\n let name = 'lm-Menu-itemIcon';\n let extra = data.item.iconClass;\n return extra ? `${name} ${extra}` : name;\n }\n\n /**\n * Create the aria attributes for menu item.\n *\n * @param data - The data to use for the aria attributes.\n *\n * @returns The aria attributes object for the item.\n */\n createItemARIA(data: IRenderData): ElementARIAAttrs {\n let aria: { [T in ARIAAttrNames]?: string } = {};\n switch (data.item.type) {\n case 'separator':\n aria.role = 'presentation';\n break;\n case 'submenu':\n aria['aria-haspopup'] = 'true';\n if (!data.item.isEnabled) {\n aria['aria-disabled'] = 'true';\n }\n break;\n default:\n if (!data.item.isEnabled) {\n aria['aria-disabled'] = 'true';\n }\n aria.role = 'menuitem';\n }\n return aria;\n }\n\n /**\n * Create the render content for the label node.\n *\n * @param data - The data to use for the label content.\n *\n * @returns The content to add to the label node.\n */\n formatLabel(data: IRenderData): h.Child {\n // Fetch the label text and mnemonic index.\n let { label, mnemonic } = data.item;\n\n // If the index is out of range, do not modify the label.\n if (mnemonic < 0 || mnemonic >= label.length) {\n return label;\n }\n\n // Split the label into parts.\n let prefix = label.slice(0, mnemonic);\n let suffix = label.slice(mnemonic + 1);\n let char = label[mnemonic];\n\n // Wrap the mnemonic character in a span.\n let span = h.span({ className: 'lm-Menu-itemMnemonic' }, char);\n\n // Return the content parts.\n return [prefix, span, suffix];\n }\n\n /**\n * Create the render content for the shortcut node.\n *\n * @param data - The data to use for the shortcut content.\n *\n * @returns The content to add to the shortcut node.\n */\n formatShortcut(data: IRenderData): h.Child {\n let kb = data.item.keyBinding;\n return kb ? CommandRegistry.formatKeystroke(kb.keys) : null;\n }\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The ms delay for opening and closing a submenu.\n */\n export const TIMER_DELAY = 300;\n\n /**\n * The horizontal pixel overlap for an open submenu.\n */\n export const SUBMENU_OVERLAP = 3;\n\n let transientWindowDataCache: IWindowData | null = null;\n let transientCacheCounter: number = 0;\n\n function getWindowData(): IWindowData {\n // if transient cache is in use, take one from it\n if (transientCacheCounter > 0) {\n transientCacheCounter--;\n return transientWindowDataCache!;\n }\n return _getWindowData();\n }\n\n /**\n * Store window data in transient cache.\n *\n * The transient cache will be released upon `getWindowData()` call.\n * If this function is called multiple times, the cache will be\n * retained until as many calls to `getWindowData()` were made.\n *\n * Note: should be called before any DOM modifications.\n */\n export function saveWindowData(): void {\n transientWindowDataCache = _getWindowData();\n transientCacheCounter++;\n }\n\n /**\n * Create the DOM node for a menu.\n */\n export function createNode(): HTMLDivElement {\n let node = document.createElement('div');\n let content = document.createElement('ul');\n content.className = 'lm-Menu-content';\n node.appendChild(content);\n content.setAttribute('role', 'menu');\n node.tabIndex = 0;\n return node;\n }\n\n /**\n * Test whether a menu item can be activated.\n */\n export function canActivate(item: Menu.IItem): boolean {\n return item.type !== 'separator' && item.isEnabled && item.isVisible;\n }\n\n /**\n * Create a new menu item for an owner menu.\n */\n export function createItem(\n owner: Menu,\n options: Menu.IItemOptions\n ): Menu.IItem {\n return new MenuItem(owner.commands, options);\n }\n\n /**\n * Hit test a menu hierarchy starting at the given root.\n */\n export function hitTestMenus(menu: Menu, x: number, y: number): boolean {\n for (let temp: Menu | null = menu; temp; temp = temp.childMenu) {\n if (ElementExt.hitTest(temp.node, x, y)) {\n return true;\n }\n }\n return false;\n }\n\n /**\n * Compute which extra separator items should be collapsed.\n */\n export function computeCollapsed(\n items: ReadonlyArray\n ): boolean[] {\n // Allocate the return array and fill it with `false`.\n let result = new Array(items.length);\n ArrayExt.fill(result, false);\n\n // Collapse the leading separators.\n let k1 = 0;\n let n = items.length;\n for (; k1 < n; ++k1) {\n let item = items[k1];\n if (!item.isVisible) {\n continue;\n }\n if (item.type !== 'separator') {\n break;\n }\n result[k1] = true;\n }\n\n // Hide the trailing separators.\n let k2 = n - 1;\n for (; k2 >= 0; --k2) {\n let item = items[k2];\n if (!item.isVisible) {\n continue;\n }\n if (item.type !== 'separator') {\n break;\n }\n result[k2] = true;\n }\n\n // Hide the remaining consecutive separators.\n let hide = false;\n while (++k1 < k2) {\n let item = items[k1];\n if (!item.isVisible) {\n continue;\n }\n if (item.type !== 'separator') {\n hide = false;\n } else if (hide) {\n result[k1] = true;\n } else {\n hide = true;\n }\n }\n\n // Return the resulting flags.\n return result;\n }\n\n function _getWindowData(): IWindowData {\n return {\n pageXOffset: window.pageXOffset,\n pageYOffset: window.pageYOffset,\n clientWidth: document.documentElement.clientWidth,\n clientHeight: document.documentElement.clientHeight\n };\n }\n\n /**\n * Open a menu as a root menu at the target location.\n */\n export function openRootMenu(\n menu: Menu,\n x: number,\n y: number,\n forceX: boolean,\n forceY: boolean,\n host: HTMLElement | null,\n ref: HTMLElement | null\n ): void {\n // Get the current position and size of the main viewport.\n const windowData = getWindowData();\n let px = windowData.pageXOffset;\n let py = windowData.pageYOffset;\n let cw = windowData.clientWidth;\n let ch = windowData.clientHeight;\n\n // Ensure the menu is updated before attaching and measuring.\n MessageLoop.sendMessage(menu, Widget.Msg.UpdateRequest);\n\n // Compute the maximum allowed height for the menu.\n let maxHeight = ch - (forceY ? y : 0);\n\n // Fetch common variables.\n let node = menu.node;\n let style = node.style;\n\n // Clear the menu geometry and prepare it for measuring.\n style.opacity = '0';\n style.maxHeight = `${maxHeight}px`;\n\n // Attach the menu to the document.\n Widget.attach(menu, host || document.body, ref);\n\n // Measure the size of the menu.\n let { width, height } = node.getBoundingClientRect();\n\n // Adjust the X position of the menu to fit on-screen.\n if (!forceX && x + width > px + cw) {\n x = px + cw - width;\n }\n\n // Adjust the Y position of the menu to fit on-screen.\n if (!forceY && y + height > py + ch) {\n if (y > py + ch) {\n y = py + ch - height;\n } else {\n y = y - height;\n }\n }\n\n // Update the position of the menu to the computed position.\n style.transform = `translate(${Math.max(0, x)}px, ${Math.max(0, y)}px`;\n\n // Finally, make the menu visible on the screen.\n style.opacity = '1';\n }\n\n /**\n * Open a menu as a submenu using an item node for positioning.\n */\n export function openSubmenu(submenu: Menu, itemNode: HTMLElement): void {\n // Get the current position and size of the main viewport.\n const windowData = getWindowData();\n let px = windowData.pageXOffset;\n let py = windowData.pageYOffset;\n let cw = windowData.clientWidth;\n let ch = windowData.clientHeight;\n\n // Ensure the menu is updated before opening.\n MessageLoop.sendMessage(submenu, Widget.Msg.UpdateRequest);\n\n // Compute the maximum allowed height for the menu.\n let maxHeight = ch;\n\n // Fetch common variables.\n let node = submenu.node;\n let style = node.style;\n\n // Clear the menu geometry and prepare it for measuring.\n style.opacity = '0';\n style.maxHeight = `${maxHeight}px`;\n\n // Attach the menu to the document.\n Widget.attach(submenu, itemNode.ownerDocument.body);\n\n // Measure the size of the menu.\n let { width, height } = node.getBoundingClientRect();\n\n // Compute the box sizing for the menu.\n let box = ElementExt.boxSizing(submenu.node);\n\n // Get the bounding rect for the target item node.\n let itemRect = itemNode.getBoundingClientRect();\n\n // Compute the target X position.\n let x = itemRect.right - SUBMENU_OVERLAP;\n\n // Adjust the X position to fit on the screen.\n if (x + width > px + cw) {\n x = itemRect.left + SUBMENU_OVERLAP - width;\n }\n\n // Compute the target Y position.\n let y = itemRect.top - box.borderTop - box.paddingTop;\n\n // Adjust the Y position to fit on the screen.\n if (y + height > py + ch) {\n y = itemRect.bottom + box.borderBottom + box.paddingBottom - height;\n }\n\n // Update the position of the menu to the computed position.\n style.transform = `translate(${Math.max(0, x)}px, ${Math.max(0, y)}px`;\n\n // Finally, make the menu visible on the screen.\n style.opacity = '1';\n }\n\n /**\n * The results of a mnemonic search.\n */\n export interface IMnemonicResult {\n /**\n * The index of the first matching mnemonic item, or `-1`.\n */\n index: number;\n\n /**\n * Whether multiple mnemonic items matched.\n */\n multiple: boolean;\n\n /**\n * The index of the first auto matched non-mnemonic item.\n */\n auto: number;\n }\n\n /**\n * Find the best matching mnemonic item.\n *\n * The search starts at the given index and wraps around.\n */\n export function findMnemonic(\n items: ReadonlyArray,\n key: string,\n start: number\n ): IMnemonicResult {\n // Setup the result variables.\n let index = -1;\n let auto = -1;\n let multiple = false;\n\n // Normalize the key to upper case.\n let upperKey = key.toUpperCase();\n\n // Search the items from the given start index.\n for (let i = 0, n = items.length; i < n; ++i) {\n // Compute the wrapped index.\n let k = (i + start) % n;\n\n // Lookup the item\n let item = items[k];\n\n // Ignore items which cannot be activated.\n if (!canActivate(item)) {\n continue;\n }\n\n // Ignore items with an empty label.\n let label = item.label;\n if (label.length === 0) {\n continue;\n }\n\n // Lookup the mnemonic index for the label.\n let mn = item.mnemonic;\n\n // Handle a valid mnemonic index.\n if (mn >= 0 && mn < label.length) {\n if (label[mn].toUpperCase() === upperKey) {\n if (index === -1) {\n index = k;\n } else {\n multiple = true;\n }\n }\n continue;\n }\n\n // Finally, handle the auto index if possible.\n if (auto === -1 && label[0].toUpperCase() === upperKey) {\n auto = k;\n }\n }\n\n // Return the search results.\n return { index, multiple, auto };\n }\n\n /**\n * A concrete implementation of `Menu.IItem`.\n */\n class MenuItem implements Menu.IItem {\n /**\n * Construct a new menu item.\n */\n constructor(commands: CommandRegistry, options: Menu.IItemOptions) {\n this._commands = commands;\n this.type = options.type || 'command';\n this.command = options.command || '';\n this.args = options.args || JSONExt.emptyObject;\n this.submenu = options.submenu || null;\n }\n\n /**\n * The type of the menu item.\n */\n readonly type: Menu.ItemType;\n\n /**\n * The command to execute when the item is triggered.\n */\n readonly command: string;\n\n /**\n * The arguments for the command.\n */\n readonly args: ReadonlyJSONObject;\n\n /**\n * The submenu for a `'submenu'` type item.\n */\n readonly submenu: Menu | null;\n\n /**\n * The display label for the menu item.\n */\n get label(): string {\n if (this.type === 'command') {\n return this._commands.label(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.label;\n }\n return '';\n }\n\n /**\n * The mnemonic index for the menu item.\n */\n get mnemonic(): number {\n if (this.type === 'command') {\n return this._commands.mnemonic(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.mnemonic;\n }\n return -1;\n }\n\n /**\n * The icon renderer for the menu item.\n */\n get icon(): VirtualElement.IRenderer | undefined {\n if (this.type === 'command') {\n return this._commands.icon(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.icon;\n }\n return undefined;\n }\n\n /**\n * The icon class for the menu item.\n */\n get iconClass(): string {\n if (this.type === 'command') {\n return this._commands.iconClass(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.iconClass;\n }\n return '';\n }\n\n /**\n * The icon label for the menu item.\n */\n get iconLabel(): string {\n if (this.type === 'command') {\n return this._commands.iconLabel(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.iconLabel;\n }\n return '';\n }\n\n /**\n * The display caption for the menu item.\n */\n get caption(): string {\n if (this.type === 'command') {\n return this._commands.caption(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.caption;\n }\n return '';\n }\n\n /**\n * The extra class name for the menu item.\n */\n get className(): string {\n if (this.type === 'command') {\n return this._commands.className(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.className;\n }\n return '';\n }\n\n /**\n * The dataset for the menu item.\n */\n get dataset(): CommandRegistry.Dataset {\n if (this.type === 'command') {\n return this._commands.dataset(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.dataset;\n }\n return {};\n }\n\n /**\n * Whether the menu item is enabled.\n */\n get isEnabled(): boolean {\n if (this.type === 'command') {\n return this._commands.isEnabled(this.command, this.args);\n }\n if (this.type === 'submenu') {\n return this.submenu !== null;\n }\n return true;\n }\n\n /**\n * Whether the menu item is toggled.\n */\n get isToggled(): boolean {\n if (this.type === 'command') {\n return this._commands.isToggled(this.command, this.args);\n }\n return false;\n }\n\n /**\n * Whether the menu item is visible.\n */\n get isVisible(): boolean {\n if (this.type === 'command') {\n return this._commands.isVisible(this.command, this.args);\n }\n if (this.type === 'submenu') {\n return this.submenu !== null;\n }\n return true;\n }\n\n /**\n * The key binding for the menu item.\n */\n get keyBinding(): CommandRegistry.IKeyBinding | null {\n if (this.type === 'command') {\n let { command, args } = this;\n return (\n ArrayExt.findLastValue(this._commands.keyBindings, kb => {\n return kb.command === command && JSONExt.deepEqual(kb.args, args);\n }) || null\n );\n }\n return null;\n }\n\n private _commands: CommandRegistry;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { CommandRegistry } from '@lumino/commands';\n\nimport { DisposableDelegate, IDisposable } from '@lumino/disposable';\n\nimport { Selector } from '@lumino/domutils';\n\nimport { Menu } from './menu';\n\n/**\n * An object which implements a universal context menu.\n *\n * #### Notes\n * The items shown in the context menu are determined by CSS selector\n * matching against the DOM hierarchy at the site of the mouse click.\n * This is similar in concept to how keyboard shortcuts are matched\n * in the command registry.\n */\nexport class ContextMenu {\n /**\n * Construct a new context menu.\n *\n * @param options - The options for initializing the menu.\n */\n constructor(options: ContextMenu.IOptions) {\n const { groupByTarget, sortBySelector, ...others } = options;\n this.menu = new Menu(others);\n this._groupByTarget = groupByTarget !== false;\n this._sortBySelector = sortBySelector !== false;\n }\n\n /**\n * The menu widget which displays the matched context items.\n */\n readonly menu: Menu;\n\n /**\n * Add an item to the context menu.\n *\n * @param options - The options for creating the item.\n *\n * @returns A disposable which will remove the item from the menu.\n */\n addItem(options: ContextMenu.IItemOptions): IDisposable {\n // Create an item from the given options.\n let item = Private.createItem(options, this._idTick++);\n\n // Add the item to the internal array.\n this._items.push(item);\n\n // Return a disposable which will remove the item.\n return new DisposableDelegate(() => {\n ArrayExt.removeFirstOf(this._items, item);\n });\n }\n\n /**\n * Open the context menu in response to a `'contextmenu'` event.\n *\n * @param event - The `'contextmenu'` event of interest.\n *\n * @returns `true` if the menu was opened, or `false` if no items\n * matched the event and the menu was not opened.\n *\n * #### Notes\n * This method will populate the context menu with items which match\n * the propagation path of the event, then open the menu at the mouse\n * position indicated by the event.\n */\n open(event: MouseEvent): boolean {\n // Prior to any DOM modifications update the window data.\n Menu.saveWindowData();\n\n // Clear the current contents of the context menu.\n this.menu.clearItems();\n\n // Bail early if there are no items to match.\n if (this._items.length === 0) {\n return false;\n }\n\n // Find the matching items for the event.\n let items = Private.matchItems(\n this._items,\n event,\n this._groupByTarget,\n this._sortBySelector\n );\n\n // Bail if there are no matching items.\n if (!items || items.length === 0) {\n return false;\n }\n\n // Add the filtered items to the menu.\n for (const item of items) {\n this.menu.addItem(item);\n }\n\n // Open the context menu at the current mouse position.\n this.menu.open(event.clientX, event.clientY);\n\n // Indicate success.\n return true;\n }\n\n private _groupByTarget: boolean = true;\n private _idTick = 0;\n private _items: Private.IItem[] = [];\n private _sortBySelector: boolean = true;\n}\n\n/**\n * The namespace for the `ContextMenu` class statics.\n */\nexport namespace ContextMenu {\n /**\n * An options object for initializing a context menu.\n */\n export interface IOptions {\n /**\n * The command registry to use with the context menu.\n */\n commands: CommandRegistry;\n\n /**\n * A custom renderer for use with the context menu.\n */\n renderer?: Menu.IRenderer;\n\n /**\n * Whether to sort by selector and rank or only rank.\n *\n * Default true.\n */\n sortBySelector?: boolean;\n\n /**\n * Whether to group items following the DOM hierarchy.\n *\n * Default true.\n *\n * #### Note\n * If true, when the mouse event occurs on element `span` within `div.top`,\n * the items matching `div.top` will be shown before the ones matching `body`.\n */\n groupByTarget?: boolean;\n }\n\n /**\n * An options object for creating a context menu item.\n */\n export interface IItemOptions extends Menu.IItemOptions {\n /**\n * The CSS selector for the context menu item.\n *\n * The context menu item will only be displayed in the context menu\n * when the selector matches a node on the propagation path of the\n * contextmenu event. This allows the menu item to be restricted to\n * user-defined contexts.\n *\n * The selector must not contain commas.\n */\n selector: string;\n\n /**\n * The rank for the item.\n *\n * The rank is used as a tie-breaker when ordering context menu\n * items for display. Items are sorted in the following order:\n * 1. Depth in the DOM tree (deeper is better)\n * 2. Selector specificity (higher is better)\n * 3. Rank (lower is better)\n * 4. Insertion order\n *\n * The default rank is `Infinity`.\n */\n rank?: number;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * A normalized item for a context menu.\n */\n export interface IItem extends Menu.IItemOptions {\n /**\n * The selector for the item.\n */\n selector: string;\n\n /**\n * The rank for the item.\n */\n rank: number;\n\n /**\n * The tie-breaking id for the item.\n */\n id: number;\n }\n\n /**\n * Create a normalized context menu item from an options object.\n */\n export function createItem(\n options: ContextMenu.IItemOptions,\n id: number\n ): IItem {\n let selector = validateSelector(options.selector);\n let rank = options.rank !== undefined ? options.rank : Infinity;\n return { ...options, selector, rank, id };\n }\n\n /**\n * Find the items which match a context menu event.\n *\n * The results are sorted by DOM level, specificity, and rank.\n */\n export function matchItems(\n items: IItem[],\n event: MouseEvent,\n groupByTarget: boolean,\n sortBySelector: boolean\n ): IItem[] | null {\n // Look up the target of the event.\n let target = event.target as Element | null;\n\n // Bail if there is no target.\n if (!target) {\n return null;\n }\n\n // Look up the current target of the event.\n let currentTarget = event.currentTarget as Element | null;\n\n // Bail if there is no current target.\n if (!currentTarget) {\n return null;\n }\n\n // There are some third party libraries that cause the `target` to\n // be detached from the DOM before lumino can process the event.\n // If that happens, search for a new target node by point. If that\n // node is still dangling, bail.\n if (!currentTarget.contains(target)) {\n target = document.elementFromPoint(event.clientX, event.clientY);\n if (!target || !currentTarget.contains(target)) {\n return null;\n }\n }\n\n // Set up the result array.\n let result: IItem[] = [];\n\n // Copy the items array to allow in-place modification.\n let availableItems: Array = items.slice();\n\n // Walk up the DOM hierarchy searching for matches.\n while (target !== null) {\n // Set up the match array for this DOM level.\n let matches: IItem[] = [];\n\n // Search the remaining items for matches.\n for (let i = 0, n = availableItems.length; i < n; ++i) {\n // Fetch the item.\n let item = availableItems[i];\n\n // Skip items which are already consumed.\n if (!item) {\n continue;\n }\n\n // Skip items which do not match the element.\n if (!Selector.matches(target, item.selector)) {\n continue;\n }\n\n // Add the matched item to the result for this DOM level.\n matches.push(item);\n\n // Mark the item as consumed.\n availableItems[i] = null;\n }\n\n // Sort the matches for this level and add them to the results.\n if (matches.length !== 0) {\n if (groupByTarget) {\n matches.sort(sortBySelector ? itemCmp : itemCmpRank);\n }\n result.push(...matches);\n }\n\n // Stop searching at the limits of the DOM range.\n if (target === currentTarget) {\n break;\n }\n\n // Step to the parent DOM level.\n target = target.parentElement;\n }\n\n if (!groupByTarget) {\n result.sort(sortBySelector ? itemCmp : itemCmpRank);\n }\n\n // Return the matched and sorted results.\n return result;\n }\n\n /**\n * Validate the selector for a menu item.\n *\n * This returns the validated selector, or throws if the selector is\n * invalid or contains commas.\n */\n function validateSelector(selector: string): string {\n if (selector.indexOf(',') !== -1) {\n throw new Error(`Selector cannot contain commas: ${selector}`);\n }\n if (!Selector.isValid(selector)) {\n throw new Error(`Invalid selector: ${selector}`);\n }\n return selector;\n }\n\n /**\n * A sort comparison function for a context menu item by ranks.\n */\n function itemCmpRank(a: IItem, b: IItem): number {\n // Sort based on rank.\n let r1 = a.rank;\n let r2 = b.rank;\n if (r1 !== r2) {\n return r1 < r2 ? -1 : 1; // Infinity-safe\n }\n\n // When all else fails, sort by item id.\n return a.id - b.id;\n }\n\n /**\n * A sort comparison function for a context menu item by selectors and ranks.\n */\n function itemCmp(a: IItem, b: IItem): number {\n // Sort first based on selector specificity.\n let s1 = Selector.calculateSpecificity(a.selector);\n let s2 = Selector.calculateSpecificity(b.selector);\n if (s1 !== s2) {\n return s2 - s1;\n }\n\n // If specificities are equal\n return itemCmpRank(a, b);\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Drag } from '@lumino/dragdrop';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport {\n ElementARIAAttrs,\n ElementBaseAttrs,\n ElementDataset,\n ElementInlineStyle,\n h,\n VirtualDOM,\n VirtualElement\n} from '@lumino/virtualdom';\n\nimport { Title } from './title';\n\nimport { Widget } from './widget';\n\nconst ARROW_KEYS = [\n 'ArrowLeft',\n 'ArrowUp',\n 'ArrowRight',\n 'ArrowDown',\n 'Home',\n 'End'\n];\n\n/**\n * A widget which displays titles as a single row or column of tabs.\n *\n * #### Notes\n * If CSS transforms are used to rotate nodes for vertically oriented\n * text, then tab dragging will not work correctly. The `tabsMovable`\n * property should be set to `false` when rotating nodes from CSS.\n */\nexport class TabBar extends Widget {\n /**\n * Construct a new tab bar.\n *\n * @param options - The options for initializing the tab bar.\n */\n constructor(options: TabBar.IOptions = {}) {\n super({ node: Private.createNode() });\n this.addClass('lm-TabBar');\n this.contentNode.setAttribute('role', 'tablist');\n this.setFlag(Widget.Flag.DisallowLayout);\n this._document = options.document || document;\n this.tabsMovable = options.tabsMovable || false;\n this.titlesEditable = options.titlesEditable || false;\n this.allowDeselect = options.allowDeselect || false;\n this.addButtonEnabled = options.addButtonEnabled || false;\n this.insertBehavior = options.insertBehavior || 'select-tab-if-needed';\n this.name = options.name || '';\n this.orientation = options.orientation || 'horizontal';\n this.removeBehavior = options.removeBehavior || 'select-tab-after';\n this.renderer = options.renderer || TabBar.defaultRenderer;\n }\n\n /**\n * Dispose of the resources held by the widget.\n */\n dispose(): void {\n this._releaseMouse();\n this._titles.length = 0;\n this._previousTitle = null;\n super.dispose();\n }\n\n /**\n * A signal emitted when the current tab is changed.\n *\n * #### Notes\n * This signal is emitted when the currently selected tab is changed\n * either through user or programmatic interaction.\n *\n * Notably, this signal is not emitted when the index of the current\n * tab changes due to tabs being inserted, removed, or moved. It is\n * only emitted when the actual current tab node is changed.\n */\n get currentChanged(): ISignal> {\n return this._currentChanged;\n }\n\n /**\n * A signal emitted when a tab is moved by the user.\n *\n * #### Notes\n * This signal is emitted when a tab is moved by user interaction.\n *\n * This signal is not emitted when a tab is moved programmatically.\n */\n get tabMoved(): ISignal> {\n return this._tabMoved;\n }\n\n /**\n * A signal emitted when a tab is clicked by the user.\n *\n * #### Notes\n * If the clicked tab is not the current tab, the clicked tab will be\n * made current and the `currentChanged` signal will be emitted first.\n *\n * This signal is emitted even if the clicked tab is the current tab.\n */\n get tabActivateRequested(): ISignal<\n this,\n TabBar.ITabActivateRequestedArgs\n > {\n return this._tabActivateRequested;\n }\n\n /**\n * A signal emitted when the tab bar add button is clicked.\n */\n get addRequested(): ISignal {\n return this._addRequested;\n }\n\n /**\n * A signal emitted when a tab close icon is clicked.\n *\n * #### Notes\n * This signal is not emitted unless the tab title is `closable`.\n */\n get tabCloseRequested(): ISignal> {\n return this._tabCloseRequested;\n }\n\n /**\n * A signal emitted when a tab is dragged beyond the detach threshold.\n *\n * #### Notes\n * This signal is emitted when the user drags a tab with the mouse,\n * and mouse is dragged beyond the detach threshold.\n *\n * The consumer of the signal should call `releaseMouse` and remove\n * the tab in order to complete the detach.\n *\n * This signal is only emitted once per drag cycle.\n */\n get tabDetachRequested(): ISignal> {\n return this._tabDetachRequested;\n }\n\n /**\n * The renderer used by the tab bar.\n */\n readonly renderer: TabBar.IRenderer;\n\n /**\n * The document to use with the tab bar.\n *\n * The default is the global `document` instance.\n */\n get document(): Document | ShadowRoot {\n return this._document;\n }\n\n /**\n * Whether the tabs are movable by the user.\n *\n * #### Notes\n * Tabs can always be moved programmatically.\n */\n tabsMovable: boolean;\n\n /**\n * Whether the titles can be user-edited.\n *\n */\n get titlesEditable(): boolean {\n return this._titlesEditable;\n }\n\n /**\n * Set whether titles can be user edited.\n *\n */\n set titlesEditable(value: boolean) {\n this._titlesEditable = value;\n }\n\n /**\n * Whether a tab can be deselected by the user.\n *\n * #### Notes\n * Tabs can be always be deselected programmatically.\n */\n allowDeselect: boolean;\n\n /**\n * The selection behavior when inserting a tab.\n */\n insertBehavior: TabBar.InsertBehavior;\n\n /**\n * The selection behavior when removing a tab.\n */\n removeBehavior: TabBar.RemoveBehavior;\n\n /**\n * Get the currently selected title.\n *\n * #### Notes\n * This will be `null` if no tab is selected.\n */\n get currentTitle(): Title | null {\n return this._titles[this._currentIndex] || null;\n }\n\n /**\n * Set the currently selected title.\n *\n * #### Notes\n * If the title does not exist, the title will be set to `null`.\n */\n set currentTitle(value: Title | null) {\n this.currentIndex = value ? this._titles.indexOf(value) : -1;\n }\n\n /**\n * Get the index of the currently selected tab.\n *\n * #### Notes\n * This will be `-1` if no tab is selected.\n */\n get currentIndex(): number {\n return this._currentIndex;\n }\n\n /**\n * Set the index of the currently selected tab.\n *\n * #### Notes\n * If the value is out of range, the index will be set to `-1`.\n */\n set currentIndex(value: number) {\n // Adjust for an out of range index.\n if (value < 0 || value >= this._titles.length) {\n value = -1;\n }\n\n // Bail early if the index will not change.\n if (this._currentIndex === value) {\n return;\n }\n\n // Look up the previous index and title.\n let pi = this._currentIndex;\n let pt = this._titles[pi] || null;\n\n // Look up the current index and title.\n let ci = value;\n let ct = this._titles[ci] || null;\n\n // Update the current index and previous title.\n this._currentIndex = ci;\n this._previousTitle = pt;\n\n // Schedule an update of the tabs.\n this.update();\n\n // Emit the current changed signal.\n this._currentChanged.emit({\n previousIndex: pi,\n previousTitle: pt,\n currentIndex: ci,\n currentTitle: ct\n });\n }\n\n /**\n * Get the name of the tab bar.\n */\n get name(): string {\n return this._name;\n }\n\n /**\n * Set the name of the tab bar.\n */\n set name(value: string) {\n this._name = value;\n if (value) {\n this.contentNode.setAttribute('aria-label', value);\n } else {\n this.contentNode.removeAttribute('aria-label');\n }\n }\n\n /**\n * Get the orientation of the tab bar.\n *\n * #### Notes\n * This controls whether the tabs are arranged in a row or column.\n */\n get orientation(): TabBar.Orientation {\n return this._orientation;\n }\n\n /**\n * Set the orientation of the tab bar.\n *\n * #### Notes\n * This controls whether the tabs are arranged in a row or column.\n */\n set orientation(value: TabBar.Orientation) {\n // Do nothing if the orientation does not change.\n if (this._orientation === value) {\n return;\n }\n\n // Release the mouse before making any changes.\n this._releaseMouse();\n\n // Toggle the orientation values.\n this._orientation = value;\n this.dataset['orientation'] = value;\n this.contentNode.setAttribute('aria-orientation', value);\n }\n\n /**\n * Whether the add button is enabled.\n */\n get addButtonEnabled(): boolean {\n return this._addButtonEnabled;\n }\n\n /**\n * Set whether the add button is enabled.\n */\n set addButtonEnabled(value: boolean) {\n // Do nothing if the value does not change.\n if (this._addButtonEnabled === value) {\n return;\n }\n\n this._addButtonEnabled = value;\n if (value) {\n this.addButtonNode.classList.remove('lm-mod-hidden');\n } else {\n this.addButtonNode.classList.add('lm-mod-hidden');\n }\n }\n\n /**\n * A read-only array of the titles in the tab bar.\n */\n get titles(): ReadonlyArray> {\n return this._titles;\n }\n\n /**\n * The tab bar content node.\n *\n * #### Notes\n * This is the node which holds the tab nodes.\n *\n * Modifying this node directly can lead to undefined behavior.\n */\n get contentNode(): HTMLUListElement {\n return this.node.getElementsByClassName(\n 'lm-TabBar-content'\n )[0] as HTMLUListElement;\n }\n\n /**\n * The tab bar add button node.\n *\n * #### Notes\n * This is the node which holds the add button.\n *\n * Modifying this node directly can lead to undefined behavior.\n */\n get addButtonNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-TabBar-addButton'\n )[0] as HTMLDivElement;\n }\n\n /**\n * Add a tab to the end of the tab bar.\n *\n * @param value - The title which holds the data for the tab,\n * or an options object to convert to a title.\n *\n * @returns The title object added to the tab bar.\n *\n * #### Notes\n * If the title is already added to the tab bar, it will be moved.\n */\n addTab(value: Title | Title.IOptions): Title {\n return this.insertTab(this._titles.length, value);\n }\n\n /**\n * Insert a tab into the tab bar at the specified index.\n *\n * @param index - The index at which to insert the tab.\n *\n * @param value - The title which holds the data for the tab,\n * or an options object to convert to a title.\n *\n * @returns The title object added to the tab bar.\n *\n * #### Notes\n * The index will be clamped to the bounds of the tabs.\n *\n * If the title is already added to the tab bar, it will be moved.\n */\n insertTab(index: number, value: Title | Title.IOptions): Title {\n // Release the mouse before making any changes.\n this._releaseMouse();\n\n // Coerce the value to a title.\n let title = Private.asTitle(value);\n\n // Look up the index of the title.\n let i = this._titles.indexOf(title);\n\n // Clamp the insert index to the array bounds.\n let j = Math.max(0, Math.min(index, this._titles.length));\n\n // If the title is not in the array, insert it.\n if (i === -1) {\n // Insert the title into the array.\n ArrayExt.insert(this._titles, j, title);\n\n // Connect to the title changed signal.\n title.changed.connect(this._onTitleChanged, this);\n\n // Schedule an update of the tabs.\n this.update();\n\n // Adjust the current index for the insert.\n this._adjustCurrentForInsert(j, title);\n\n // Return the title added to the tab bar.\n return title;\n }\n\n // Otherwise, the title exists in the array and should be moved.\n\n // Adjust the index if the location is at the end of the array.\n if (j === this._titles.length) {\n j--;\n }\n\n // Bail if there is no effective move.\n if (i === j) {\n return title;\n }\n\n // Move the title to the new location.\n ArrayExt.move(this._titles, i, j);\n\n // Schedule an update of the tabs.\n this.update();\n\n // Adjust the current index for the move.\n this._adjustCurrentForMove(i, j);\n\n // Return the title added to the tab bar.\n return title;\n }\n\n /**\n * Remove a tab from the tab bar.\n *\n * @param title - The title for the tab to remove.\n *\n * #### Notes\n * This is a no-op if the title is not in the tab bar.\n */\n removeTab(title: Title): void {\n this.removeTabAt(this._titles.indexOf(title));\n }\n\n /**\n * Remove the tab at a given index from the tab bar.\n *\n * @param index - The index of the tab to remove.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n removeTabAt(index: number): void {\n // Release the mouse before making any changes.\n this._releaseMouse();\n\n // Remove the title from the array.\n let title = ArrayExt.removeAt(this._titles, index);\n\n // Bail if the index is out of range.\n if (!title) {\n return;\n }\n\n // Disconnect from the title changed signal.\n title.changed.disconnect(this._onTitleChanged, this);\n\n // Clear the previous title if it's being removed.\n if (title === this._previousTitle) {\n this._previousTitle = null;\n }\n\n // Schedule an update of the tabs.\n this.update();\n\n // Adjust the current index for the remove.\n this._adjustCurrentForRemove(index, title);\n }\n\n /**\n * Remove all tabs from the tab bar.\n */\n clearTabs(): void {\n // Bail if there is nothing to remove.\n if (this._titles.length === 0) {\n return;\n }\n\n // Release the mouse before making any changes.\n this._releaseMouse();\n\n // Disconnect from the title changed signals.\n for (let title of this._titles) {\n title.changed.disconnect(this._onTitleChanged, this);\n }\n\n // Get the current index and title.\n let pi = this.currentIndex;\n let pt = this.currentTitle;\n\n // Reset the current index and previous title.\n this._currentIndex = -1;\n this._previousTitle = null;\n\n // Clear the title array.\n this._titles.length = 0;\n\n // Schedule an update of the tabs.\n this.update();\n\n // If no tab was selected, there's nothing else to do.\n if (pi === -1) {\n return;\n }\n\n // Emit the current changed signal.\n this._currentChanged.emit({\n previousIndex: pi,\n previousTitle: pt,\n currentIndex: -1,\n currentTitle: null\n });\n }\n\n /**\n * Release the mouse and restore the non-dragged tab positions.\n *\n * #### Notes\n * This will cause the tab bar to stop handling mouse events and to\n * restore the tabs to their non-dragged positions.\n */\n releaseMouse(): void {\n this._releaseMouse();\n }\n\n /**\n * Handle the DOM events for the tab bar.\n *\n * @param event - The DOM event sent to the tab bar.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the tab bar's DOM node.\n *\n * This should not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'pointerdown':\n this._evtPointerDown(event as PointerEvent);\n break;\n case 'pointermove':\n this._evtPointerMove(event as PointerEvent);\n break;\n case 'pointerup':\n this._evtPointerUp(event as PointerEvent);\n break;\n case 'dblclick':\n this._evtDblClick(event as MouseEvent);\n break;\n case 'keydown':\n event.eventPhase === Event.CAPTURING_PHASE\n ? this._evtKeyDownCapturing(event as KeyboardEvent)\n : this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('pointerdown', this);\n this.node.addEventListener('dblclick', this);\n this.node.addEventListener('keydown', this);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('pointerdown', this);\n this.node.removeEventListener('dblclick', this);\n this.node.removeEventListener('keydown', this);\n this._releaseMouse();\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n let titles = this._titles;\n let renderer = this.renderer;\n let currentTitle = this.currentTitle;\n let content = new Array(titles.length);\n // Keep the tabindex=\"0\" attribute to the tab which handled it before the update.\n // If the add button handles it, no need to do anything. If no element of the tab\n // bar handles it, set it on the current or the first tab to ensure one element\n // handles it after update.\n const tabHandlingTabindex =\n this._getCurrentTabindex() ??\n (this._currentIndex > -1 ? this._currentIndex : 0);\n\n for (let i = 0, n = titles.length; i < n; ++i) {\n let title = titles[i];\n let current = title === currentTitle;\n let zIndex = current ? n : n - i - 1;\n let tabIndex = tabHandlingTabindex === i ? 0 : -1;\n content[i] = renderer.renderTab({ title, current, zIndex, tabIndex });\n }\n VirtualDOM.render(content, this.contentNode);\n }\n\n /**\n * Get the index of the tab which handles tabindex=\"0\".\n * If the add button handles tabindex=\"0\", -1 is returned.\n * If none of the previous handles tabindex=\"0\", null is returned.\n */\n private _getCurrentTabindex(): number | null {\n let index = null;\n const elemTabindex = this.contentNode.querySelector('li[tabindex=\"0\"]');\n if (elemTabindex) {\n index = [...this.contentNode.children].indexOf(elemTabindex);\n } else if (\n this._addButtonEnabled &&\n this.addButtonNode.getAttribute('tabindex') === '0'\n ) {\n index = -1;\n }\n return index;\n }\n\n /**\n * Handle the `'dblclick'` event for the tab bar.\n */\n private _evtDblClick(event: MouseEvent): void {\n // Do nothing if titles are not editable\n if (!this.titlesEditable) {\n return;\n }\n\n let tabs = this.contentNode.children;\n\n // Find the index of the targeted tab.\n let index = ArrayExt.findFirstIndex(tabs, tab => {\n return ElementExt.hitTest(tab, event.clientX, event.clientY);\n });\n\n // Do nothing if the press is not on a tab.\n if (index === -1) {\n return;\n }\n\n let title = this.titles[index];\n let label = tabs[index].querySelector('.lm-TabBar-tabLabel') as HTMLElement;\n if (label && label.contains(event.target as HTMLElement)) {\n let value = title.label || '';\n\n // Clear the label element\n let oldValue = label.innerHTML;\n label.innerHTML = '';\n\n let input = document.createElement('input');\n input.classList.add('lm-TabBar-tabInput');\n input.value = value;\n label.appendChild(input);\n\n let onblur = () => {\n input.removeEventListener('blur', onblur);\n label.innerHTML = oldValue;\n this.node.addEventListener('keydown', this);\n };\n\n input.addEventListener('dblclick', (event: Event) =>\n event.stopPropagation()\n );\n input.addEventListener('blur', onblur);\n input.addEventListener('keydown', (event: KeyboardEvent) => {\n if (event.key === 'Enter') {\n if (input.value !== '') {\n title.label = title.caption = input.value;\n }\n onblur();\n } else if (event.key === 'Escape') {\n onblur();\n }\n });\n this.node.removeEventListener('keydown', this);\n input.select();\n input.focus();\n\n if (label.children.length > 0) {\n (label.children[0] as HTMLElement).focus();\n }\n }\n }\n\n /**\n * Handle the `'keydown'` event for the tab bar at capturing phase.\n */\n private _evtKeyDownCapturing(event: KeyboardEvent): void {\n if (event.eventPhase !== Event.CAPTURING_PHASE) {\n return;\n }\n\n // Stop all input events during drag.\n event.preventDefault();\n event.stopPropagation();\n\n // Release the mouse if `Escape` is pressed.\n if (event.key === 'Escape') {\n this._releaseMouse();\n }\n }\n\n /**\n * Handle the `'keydown'` event for the tab bar at target phase.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // Allow for navigation using tab key\n if (event.key === 'Tab' || event.eventPhase === Event.CAPTURING_PHASE) {\n return;\n }\n\n // Check if Enter or Spacebar key has been pressed and open that tab\n if (\n event.key === 'Enter' ||\n event.key === 'Spacebar' ||\n event.key === ' '\n ) {\n // Get focus element that is in focus by the tab key\n const focusedElement = document.activeElement;\n\n // Test first if the focus is on the add button node\n if (\n this.addButtonEnabled &&\n this.addButtonNode.contains(focusedElement)\n ) {\n event.preventDefault();\n event.stopPropagation();\n this._addRequested.emit();\n } else {\n const index = ArrayExt.findFirstIndex(this.contentNode.children, tab =>\n tab.contains(focusedElement)\n );\n if (index >= 0) {\n event.preventDefault();\n event.stopPropagation();\n this.currentIndex = index;\n }\n }\n // Handle the arrow keys to switch tabs.\n } else if (ARROW_KEYS.includes(event.key)) {\n // Create a list of all focusable elements in the tab bar.\n const focusable: Element[] = [...this.contentNode.children];\n if (this.addButtonEnabled) {\n focusable.push(this.addButtonNode);\n }\n // If the tab bar contains only one element, nothing to do.\n if (focusable.length <= 1) {\n return;\n }\n event.preventDefault();\n event.stopPropagation();\n\n // Get the current focused element.\n let focusedIndex = focusable.indexOf(document.activeElement as Element);\n if (focusedIndex === -1) {\n focusedIndex = this._currentIndex;\n }\n\n // Find the next element to focus on.\n let nextFocused: Element | null | undefined;\n if (\n (event.key === 'ArrowRight' && this._orientation === 'horizontal') ||\n (event.key === 'ArrowDown' && this._orientation === 'vertical')\n ) {\n nextFocused = focusable[focusedIndex + 1] ?? focusable[0];\n } else if (\n (event.key === 'ArrowLeft' && this._orientation === 'horizontal') ||\n (event.key === 'ArrowUp' && this._orientation === 'vertical')\n ) {\n nextFocused =\n focusable[focusedIndex - 1] ?? focusable[focusable.length - 1];\n } else if (event.key === 'Home') {\n nextFocused = focusable[0];\n } else if (event.key === 'End') {\n nextFocused = focusable[focusable.length - 1];\n }\n\n // Change the focused element and the tabindex value.\n if (nextFocused) {\n focusable[focusedIndex]?.setAttribute('tabindex', '-1');\n nextFocused?.setAttribute('tabindex', '0');\n (nextFocused as HTMLElement).focus();\n }\n }\n }\n\n /**\n * Handle the `'pointerdown'` event for the tab bar.\n */\n private _evtPointerDown(event: PointerEvent | MouseEvent): void {\n // Do nothing if it's not a left or middle mouse press.\n if (event.button !== 0 && event.button !== 1) {\n return;\n }\n\n // Do nothing if a drag is in progress.\n if (this._dragData) {\n return;\n }\n\n // Do nothing if a title editable input was clicked.\n if (\n (event.target as HTMLElement).classList.contains('lm-TabBar-tabInput')\n ) {\n return;\n }\n\n // Check if the add button was clicked.\n let addButtonClicked =\n this.addButtonEnabled &&\n this.addButtonNode.contains(event.target as HTMLElement);\n\n // Lookup the tab nodes.\n let tabs = this.contentNode.children;\n\n // Find the index of the pressed tab.\n let index = ArrayExt.findFirstIndex(tabs, tab => {\n return ElementExt.hitTest(tab, event.clientX, event.clientY);\n });\n\n // Do nothing if the press is not on a tab or the add button.\n if (index === -1 && !addButtonClicked) {\n return;\n }\n\n // Pressing on a tab stops the event propagation.\n event.preventDefault();\n event.stopPropagation();\n\n // Initialize the non-measured parts of the drag data.\n this._dragData = {\n tab: tabs[index] as HTMLElement,\n index: index,\n pressX: event.clientX,\n pressY: event.clientY,\n tabPos: -1,\n tabSize: -1,\n tabPressPos: -1,\n targetIndex: -1,\n tabLayout: null,\n contentRect: null,\n override: null,\n dragActive: false,\n dragAborted: false,\n detachRequested: false\n };\n\n // Add the document pointer up listener.\n this.document.addEventListener('pointerup', this, true);\n\n // Do nothing else if the middle button or add button is clicked.\n if (event.button === 1 || addButtonClicked) {\n return;\n }\n\n // Do nothing else if the close icon is clicked.\n let icon = tabs[index].querySelector(this.renderer.closeIconSelector);\n if (icon && icon.contains(event.target as HTMLElement)) {\n return;\n }\n\n // Add the extra listeners if the tabs are movable.\n if (this.tabsMovable) {\n this.document.addEventListener('pointermove', this, true);\n this.document.addEventListener('keydown', this, true);\n this.document.addEventListener('contextmenu', this, true);\n }\n\n // Update the current index as appropriate.\n if (this.allowDeselect && this.currentIndex === index) {\n this.currentIndex = -1;\n } else {\n this.currentIndex = index;\n }\n\n // Do nothing else if there is no current tab.\n if (this.currentIndex === -1) {\n return;\n }\n\n // Emit the tab activate request signal.\n this._tabActivateRequested.emit({\n index: this.currentIndex,\n title: this.currentTitle!\n });\n }\n\n /**\n * Handle the `'pointermove'` event for the tab bar.\n */\n private _evtPointerMove(event: PointerEvent | MouseEvent): void {\n // Do nothing if no drag is in progress.\n let data = this._dragData;\n if (!data) {\n return;\n }\n\n // Suppress the event during a drag.\n event.preventDefault();\n event.stopPropagation();\n\n // Lookup the tab nodes.\n let tabs = this.contentNode.children;\n\n // Bail early if the drag threshold has not been met.\n if (!data.dragActive && !Private.dragExceeded(data, event)) {\n return;\n }\n\n // Activate the drag if necessary.\n if (!data.dragActive) {\n // Fill in the rest of the drag data measurements.\n let tabRect = data.tab.getBoundingClientRect();\n if (this._orientation === 'horizontal') {\n data.tabPos = data.tab.offsetLeft;\n data.tabSize = tabRect.width;\n data.tabPressPos = data.pressX - tabRect.left;\n } else {\n data.tabPos = data.tab.offsetTop;\n data.tabSize = tabRect.height;\n data.tabPressPos = data.pressY - tabRect.top;\n }\n data.tabPressOffset = {\n x: data.pressX - tabRect.left,\n y: data.pressY - tabRect.top\n };\n data.tabLayout = Private.snapTabLayout(tabs, this._orientation);\n data.contentRect = this.contentNode.getBoundingClientRect();\n data.override = Drag.overrideCursor('default');\n\n // Add the dragging style classes.\n data.tab.classList.add('lm-mod-dragging');\n this.addClass('lm-mod-dragging');\n\n // Mark the drag as active.\n data.dragActive = true;\n }\n\n // Emit the detach requested signal if the threshold is exceeded.\n if (!data.detachRequested && Private.detachExceeded(data, event)) {\n // Only emit the signal once per drag cycle.\n data.detachRequested = true;\n\n // Setup the arguments for the signal.\n let index = data.index;\n let clientX = event.clientX;\n let clientY = event.clientY;\n let tab = tabs[index] as HTMLElement;\n let title = this._titles[index];\n\n // Emit the tab detach requested signal.\n this._tabDetachRequested.emit({\n index,\n title,\n tab,\n clientX,\n clientY,\n offset: data.tabPressOffset\n });\n\n // Bail if the signal handler aborted the drag.\n if (data.dragAborted) {\n return;\n }\n }\n\n // Update the positions of the tabs.\n Private.layoutTabs(tabs, data, event, this._orientation);\n }\n\n /**\n * Handle the `'pointerup'` event for the document.\n */\n private _evtPointerUp(event: PointerEvent | MouseEvent): void {\n // Do nothing if it's not a left or middle mouse release.\n if (event.button !== 0 && event.button !== 1) {\n return;\n }\n\n // Do nothing if no drag is in progress.\n const data = this._dragData;\n if (!data) {\n return;\n }\n\n // Stop the event propagation.\n event.preventDefault();\n event.stopPropagation();\n\n // Remove the extra mouse event listeners.\n this.document.removeEventListener('pointermove', this, true);\n this.document.removeEventListener('pointerup', this, true);\n this.document.removeEventListener('keydown', this, true);\n this.document.removeEventListener('contextmenu', this, true);\n\n // Handle a release when the drag is not active.\n if (!data.dragActive) {\n // Clear the drag data.\n this._dragData = null;\n\n // Handle clicking the add button.\n let addButtonClicked =\n this.addButtonEnabled &&\n this.addButtonNode.contains(event.target as HTMLElement);\n if (addButtonClicked) {\n this._addRequested.emit(undefined);\n return;\n }\n\n // Lookup the tab nodes.\n let tabs = this.contentNode.children;\n\n // Find the index of the released tab.\n let index = ArrayExt.findFirstIndex(tabs, tab => {\n return ElementExt.hitTest(tab, event.clientX, event.clientY);\n });\n\n // Do nothing if the release is not on the original pressed tab.\n if (index !== data.index) {\n return;\n }\n\n // Ignore the release if the title is not closable.\n let title = this._titles[index];\n if (!title.closable) {\n return;\n }\n\n // Emit the close requested signal if the middle button is released.\n if (event.button === 1) {\n this._tabCloseRequested.emit({ index, title });\n return;\n }\n\n // Emit the close requested signal if the close icon was released.\n let icon = tabs[index].querySelector(this.renderer.closeIconSelector);\n if (icon && icon.contains(event.target as HTMLElement)) {\n this._tabCloseRequested.emit({ index, title });\n return;\n }\n\n // Otherwise, there is nothing left to do.\n return;\n }\n\n // Do nothing if the left button is not released.\n if (event.button !== 0) {\n return;\n }\n\n // Position the tab at its final resting position.\n Private.finalizeTabPosition(data, this._orientation);\n\n // Remove the dragging class from the tab so it can be transitioned.\n data.tab.classList.remove('lm-mod-dragging');\n\n // Parse the transition duration for releasing the tab.\n let duration = Private.parseTransitionDuration(data.tab);\n\n // Complete the release on a timer to allow the tab to transition.\n setTimeout(() => {\n // Do nothing if the drag has been aborted.\n if (data.dragAborted) {\n return;\n }\n\n // Clear the drag data reference.\n this._dragData = null;\n\n // Reset the positions of the tabs.\n Private.resetTabPositions(this.contentNode.children, this._orientation);\n\n // Clear the cursor grab.\n data.override!.dispose();\n\n // Remove the remaining dragging style.\n this.removeClass('lm-mod-dragging');\n\n // If the tab was not moved, there is nothing else to do.\n let i = data.index;\n let j = data.targetIndex;\n if (j === -1 || i === j) {\n return;\n }\n\n // Move the title to the new locations.\n ArrayExt.move(this._titles, i, j);\n\n // Adjust the current index for the move.\n this._adjustCurrentForMove(i, j);\n\n // Emit the tab moved signal.\n this._tabMoved.emit({\n fromIndex: i,\n toIndex: j,\n title: this._titles[j]\n });\n\n // Update the tabs immediately to prevent flicker.\n MessageLoop.sendMessage(this, Widget.Msg.UpdateRequest);\n }, duration);\n }\n\n /**\n * Release the mouse and restore the non-dragged tab positions.\n */\n private _releaseMouse(): void {\n // Do nothing if no drag is in progress.\n let data = this._dragData;\n if (!data) {\n return;\n }\n\n // Clear the drag data reference.\n this._dragData = null;\n\n // Remove the extra document event listeners.\n this.document.removeEventListener('pointermove', this, true);\n this.document.removeEventListener('pointerup', this, true);\n this.document.removeEventListener('keydown', this, true);\n this.document.removeEventListener('contextmenu', this, true);\n\n // Indicate the drag has been aborted. This allows the mouse\n // event handlers to return early when the drag is canceled.\n data.dragAborted = true;\n\n // If the drag is not active, there's nothing more to do.\n if (!data.dragActive) {\n return;\n }\n\n // Reset the tabs to their non-dragged positions.\n Private.resetTabPositions(this.contentNode.children, this._orientation);\n\n // Clear the cursor override.\n data.override!.dispose();\n\n // Clear the dragging style classes.\n data.tab.classList.remove('lm-mod-dragging');\n this.removeClass('lm-mod-dragging');\n }\n\n /**\n * Adjust the current index for a tab insert operation.\n *\n * This method accounts for the tab bar's insertion behavior when\n * adjusting the current index and emitting the changed signal.\n */\n private _adjustCurrentForInsert(i: number, title: Title): void {\n // Lookup commonly used variables.\n let ct = this.currentTitle;\n let ci = this._currentIndex;\n let bh = this.insertBehavior;\n\n // TODO: do we need to do an update to update the aria-selected attribute?\n\n // Handle the behavior where the new tab is always selected,\n // or the behavior where the new tab is selected if needed.\n if (bh === 'select-tab' || (bh === 'select-tab-if-needed' && ci === -1)) {\n this._currentIndex = i;\n this._previousTitle = ct;\n this._currentChanged.emit({\n previousIndex: ci,\n previousTitle: ct,\n currentIndex: i,\n currentTitle: title\n });\n return;\n }\n\n // Otherwise, silently adjust the current index if needed.\n if (ci >= i) {\n this._currentIndex++;\n }\n }\n\n /**\n * Adjust the current index for a tab move operation.\n *\n * This method will not cause the actual current tab to change.\n * It silently adjusts the index to account for the given move.\n */\n private _adjustCurrentForMove(i: number, j: number): void {\n if (this._currentIndex === i) {\n this._currentIndex = j;\n } else if (this._currentIndex < i && this._currentIndex >= j) {\n this._currentIndex++;\n } else if (this._currentIndex > i && this._currentIndex <= j) {\n this._currentIndex--;\n }\n }\n\n /**\n * Adjust the current index for a tab remove operation.\n *\n * This method accounts for the tab bar's remove behavior when\n * adjusting the current index and emitting the changed signal.\n */\n private _adjustCurrentForRemove(i: number, title: Title): void {\n // Lookup commonly used variables.\n let ci = this._currentIndex;\n let bh = this.removeBehavior;\n\n // Silently adjust the index if the current tab is not removed.\n if (ci !== i) {\n if (ci > i) {\n this._currentIndex--;\n }\n return;\n }\n\n // TODO: do we need to do an update to adjust the aria-selected value?\n\n // No tab gets selected if the tab bar is empty.\n if (this._titles.length === 0) {\n this._currentIndex = -1;\n this._currentChanged.emit({\n previousIndex: i,\n previousTitle: title,\n currentIndex: -1,\n currentTitle: null\n });\n return;\n }\n\n // Handle behavior where the next sibling tab is selected.\n if (bh === 'select-tab-after') {\n this._currentIndex = Math.min(i, this._titles.length - 1);\n this._currentChanged.emit({\n previousIndex: i,\n previousTitle: title,\n currentIndex: this._currentIndex,\n currentTitle: this.currentTitle\n });\n return;\n }\n\n // Handle behavior where the previous sibling tab is selected.\n if (bh === 'select-tab-before') {\n this._currentIndex = Math.max(0, i - 1);\n this._currentChanged.emit({\n previousIndex: i,\n previousTitle: title,\n currentIndex: this._currentIndex,\n currentTitle: this.currentTitle\n });\n return;\n }\n\n // Handle behavior where the previous history tab is selected.\n if (bh === 'select-previous-tab') {\n if (this._previousTitle) {\n this._currentIndex = this._titles.indexOf(this._previousTitle);\n this._previousTitle = null;\n } else {\n this._currentIndex = Math.min(i, this._titles.length - 1);\n }\n this._currentChanged.emit({\n previousIndex: i,\n previousTitle: title,\n currentIndex: this._currentIndex,\n currentTitle: this.currentTitle\n });\n return;\n }\n\n // Otherwise, no tab gets selected.\n this._currentIndex = -1;\n this._currentChanged.emit({\n previousIndex: i,\n previousTitle: title,\n currentIndex: -1,\n currentTitle: null\n });\n }\n\n /**\n * Handle the `changed` signal of a title object.\n */\n private _onTitleChanged(sender: Title): void {\n this.update();\n }\n\n private _name: string;\n private _currentIndex = -1;\n private _titles: Title[] = [];\n private _orientation: TabBar.Orientation;\n private _document: Document | ShadowRoot;\n private _titlesEditable: boolean = false;\n private _previousTitle: Title | null = null;\n private _dragData: Private.IDragData | null = null;\n private _addButtonEnabled: boolean = false;\n private _tabMoved = new Signal>(this);\n private _currentChanged = new Signal>(\n this\n );\n private _addRequested = new Signal(this);\n private _tabCloseRequested = new Signal<\n this,\n TabBar.ITabCloseRequestedArgs\n >(this);\n private _tabDetachRequested = new Signal<\n this,\n TabBar.ITabDetachRequestedArgs\n >(this);\n private _tabActivateRequested = new Signal<\n this,\n TabBar.ITabActivateRequestedArgs\n >(this);\n}\n\n/**\n * The namespace for the `TabBar` class statics.\n */\nexport namespace TabBar {\n /**\n * A type alias for a tab bar orientation.\n */\n export type Orientation =\n | /**\n * The tabs are arranged in a single row, left-to-right.\n *\n * The tab text orientation is horizontal.\n */\n 'horizontal'\n\n /**\n * The tabs are arranged in a single column, top-to-bottom.\n *\n * The tab text orientation is horizontal.\n */\n | 'vertical';\n\n /**\n * A type alias for the selection behavior on tab insert.\n */\n export type InsertBehavior =\n | /**\n * The selected tab will not be changed.\n */\n 'none'\n\n /**\n * The inserted tab will be selected.\n */\n | 'select-tab'\n\n /**\n * The inserted tab will be selected if the current tab is null.\n */\n | 'select-tab-if-needed';\n\n /**\n * A type alias for the selection behavior on tab remove.\n */\n export type RemoveBehavior =\n | /**\n * No tab will be selected.\n */\n 'none'\n\n /**\n * The tab after the removed tab will be selected if possible.\n */\n | 'select-tab-after'\n\n /**\n * The tab before the removed tab will be selected if possible.\n */\n | 'select-tab-before'\n\n /**\n * The previously selected tab will be selected if possible.\n */\n | 'select-previous-tab';\n\n /**\n * An options object for creating a tab bar.\n */\n export interface IOptions {\n /**\n * The document to use with the tab bar.\n *\n * The default is the global `document` instance.\n */\n\n document?: Document | ShadowRoot;\n\n /**\n * Name of the tab bar.\n *\n * This is used for accessibility reasons. The default is the empty string.\n */\n name?: string;\n\n /**\n * The layout orientation of the tab bar.\n *\n * The default is `horizontal`.\n */\n orientation?: TabBar.Orientation;\n\n /**\n * Whether the tabs are movable by the user.\n *\n * The default is `false`.\n */\n tabsMovable?: boolean;\n\n /**\n * Whether a tab can be deselected by the user.\n *\n * The default is `false`.\n */\n allowDeselect?: boolean;\n\n /**\n * Whether the titles can be directly edited by the user.\n *\n * The default is `false`.\n */\n titlesEditable?: boolean;\n\n /**\n * Whether the add button is enabled.\n *\n * The default is `false`.\n */\n addButtonEnabled?: boolean;\n\n /**\n * The selection behavior when inserting a tab.\n *\n * The default is `'select-tab-if-needed'`.\n */\n insertBehavior?: TabBar.InsertBehavior;\n\n /**\n * The selection behavior when removing a tab.\n *\n * The default is `'select-tab-after'`.\n */\n removeBehavior?: TabBar.RemoveBehavior;\n\n /**\n * A renderer to use with the tab bar.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n }\n\n /**\n * The arguments object for the `currentChanged` signal.\n */\n export interface ICurrentChangedArgs {\n /**\n * The previously selected index.\n */\n readonly previousIndex: number;\n\n /**\n * The previously selected title.\n */\n readonly previousTitle: Title | null;\n\n /**\n * The currently selected index.\n */\n readonly currentIndex: number;\n\n /**\n * The currently selected title.\n */\n readonly currentTitle: Title | null;\n }\n\n /**\n * The arguments object for the `tabMoved` signal.\n */\n export interface ITabMovedArgs {\n /**\n * The previous index of the tab.\n */\n readonly fromIndex: number;\n\n /**\n * The current index of the tab.\n */\n readonly toIndex: number;\n\n /**\n * The title for the tab.\n */\n readonly title: Title;\n }\n\n /**\n * The arguments object for the `tabActivateRequested` signal.\n */\n export interface ITabActivateRequestedArgs {\n /**\n * The index of the tab to activate.\n */\n readonly index: number;\n\n /**\n * The title for the tab.\n */\n readonly title: Title;\n }\n\n /**\n * The arguments object for the `tabCloseRequested` signal.\n */\n export interface ITabCloseRequestedArgs {\n /**\n * The index of the tab to close.\n */\n readonly index: number;\n\n /**\n * The title for the tab.\n */\n readonly title: Title;\n }\n\n /**\n * The arguments object for the `tabDetachRequested` signal.\n */\n export interface ITabDetachRequestedArgs {\n /**\n * The index of the tab to detach.\n */\n readonly index: number;\n\n /**\n * The title for the tab.\n */\n readonly title: Title;\n\n /**\n * The node representing the tab.\n */\n readonly tab: HTMLElement;\n\n /**\n * The current client X position of the mouse.\n */\n readonly clientX: number;\n\n /**\n * The current client Y position of the mouse.\n */\n readonly clientY: number;\n\n /**\n * The mouse position in the tab coordinate.\n */\n readonly offset?: { x: number; y: number };\n }\n\n /**\n * An object which holds the data to render a tab.\n */\n export interface IRenderData {\n /**\n * The title associated with the tab.\n */\n readonly title: Title;\n\n /**\n * Whether the tab is the current tab.\n */\n readonly current: boolean;\n\n /**\n * The z-index for the tab.\n */\n readonly zIndex: number;\n\n /**\n * The tabindex value for the tab.\n */\n readonly tabIndex?: number;\n }\n\n /**\n * A renderer for use with a tab bar.\n */\n export interface IRenderer {\n /**\n * A selector which matches the close icon node in a tab.\n */\n readonly closeIconSelector: string;\n\n /**\n * Render the virtual element for a tab.\n *\n * @param data - The data to use for rendering the tab.\n *\n * @returns A virtual element representing the tab.\n */\n renderTab(data: IRenderData): VirtualElement;\n }\n\n /**\n * The default implementation of `IRenderer`.\n *\n * #### Notes\n * Subclasses are free to reimplement rendering methods as needed.\n */\n export class Renderer implements IRenderer {\n constructor() {\n this._uuid = ++Renderer._nInstance;\n }\n /**\n * A selector which matches the close icon node in a tab.\n */\n readonly closeIconSelector = '.lm-TabBar-tabCloseIcon';\n\n /**\n * Render the virtual element for a tab.\n *\n * @param data - The data to use for rendering the tab.\n *\n * @returns A virtual element representing the tab.\n */\n renderTab(data: IRenderData): VirtualElement {\n let title = data.title.caption;\n let key = this.createTabKey(data);\n let id = key;\n let style = this.createTabStyle(data);\n let className = this.createTabClass(data);\n let dataset = this.createTabDataset(data);\n let aria = this.createTabARIA(data);\n if (data.title.closable) {\n return h.li(\n { id, key, className, title, style, dataset, ...aria },\n this.renderIcon(data),\n this.renderLabel(data),\n this.renderCloseIcon(data)\n );\n } else {\n return h.li(\n { id, key, className, title, style, dataset, ...aria },\n this.renderIcon(data),\n this.renderLabel(data)\n );\n }\n }\n\n /**\n * Render the icon element for a tab.\n *\n * @param data - The data to use for rendering the tab.\n *\n * @returns A virtual element representing the tab icon.\n */\n renderIcon(data: IRenderData): VirtualElement {\n const { title } = data;\n let className = this.createIconClass(data);\n\n // If title.icon is undefined, it will be ignored.\n return h.div({ className }, title.icon!, title.iconLabel);\n }\n\n /**\n * Render the label element for a tab.\n *\n * @param data - The data to use for rendering the tab.\n *\n * @returns A virtual element representing the tab label.\n */\n renderLabel(data: IRenderData): VirtualElement {\n return h.div({ className: 'lm-TabBar-tabLabel' }, data.title.label);\n }\n\n /**\n * Render the close icon element for a tab.\n *\n * @param data - The data to use for rendering the tab.\n *\n * @returns A virtual element representing the tab close icon.\n */\n renderCloseIcon(data: IRenderData): VirtualElement {\n return h.div({ className: 'lm-TabBar-tabCloseIcon' });\n }\n\n /**\n * Create a unique render key for the tab.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The unique render key for the tab.\n *\n * #### Notes\n * This method caches the key against the tab title the first time\n * the key is generated. This enables efficient rendering of moved\n * tabs and avoids subtle hover style artifacts.\n */\n createTabKey(data: IRenderData): string {\n let key = this._tabKeys.get(data.title);\n if (key === undefined) {\n key = `tab-key-${this._uuid}-${this._tabID++}`;\n this._tabKeys.set(data.title, key);\n }\n return key;\n }\n\n /**\n * Create the inline style object for a tab.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The inline style data for the tab.\n */\n createTabStyle(data: IRenderData): ElementInlineStyle {\n return { zIndex: `${data.zIndex}` };\n }\n\n /**\n * Create the class name for the tab.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The full class name for the tab.\n */\n createTabClass(data: IRenderData): string {\n let name = 'lm-TabBar-tab';\n if (data.title.className) {\n name += ` ${data.title.className}`;\n }\n if (data.title.closable) {\n name += ' lm-mod-closable';\n }\n if (data.current) {\n name += ' lm-mod-current';\n }\n return name;\n }\n\n /**\n * Create the dataset for a tab.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The dataset for the tab.\n */\n createTabDataset(data: IRenderData): ElementDataset {\n return data.title.dataset;\n }\n\n /**\n * Create the ARIA attributes for a tab.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The ARIA attributes for the tab.\n */\n createTabARIA(data: IRenderData): ElementARIAAttrs | ElementBaseAttrs {\n return {\n role: 'tab',\n 'aria-selected': data.current.toString(),\n tabindex: `${data.tabIndex ?? '-1'}`\n };\n }\n\n /**\n * Create the class name for the tab icon.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The full class name for the tab icon.\n */\n createIconClass(data: IRenderData): string {\n let name = 'lm-TabBar-tabIcon';\n let extra = data.title.iconClass;\n return extra ? `${name} ${extra}` : name;\n }\n\n private static _nInstance = 0;\n private readonly _uuid: number;\n private _tabID = 0;\n private _tabKeys = new WeakMap, string>();\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n\n /**\n * A selector which matches the add button node in the tab bar.\n */\n export const addButtonSelector = '.lm-TabBar-addButton';\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The start drag distance threshold.\n */\n export const DRAG_THRESHOLD = 5;\n\n /**\n * The detach distance threshold.\n */\n export const DETACH_THRESHOLD = 20;\n\n /**\n * A struct which holds the drag data for a tab bar.\n */\n export interface IDragData {\n /**\n * The tab node being dragged.\n */\n tab: HTMLElement;\n\n /**\n * The index of the tab being dragged.\n */\n index: number;\n\n /**\n * The mouse press client X position.\n */\n pressX: number;\n\n /**\n * The mouse press client Y position.\n */\n pressY: number;\n\n /**\n * The offset left/top of the tab being dragged.\n *\n * This will be `-1` if the drag is not active.\n */\n tabPos: number;\n\n /**\n * The offset width/height of the tab being dragged.\n *\n * This will be `-1` if the drag is not active.\n */\n tabSize: number;\n\n /**\n * The original mouse X/Y position in tab coordinates.\n *\n * This will be `-1` if the drag is not active.\n */\n tabPressPos: number;\n\n /**\n * The original mouse position in tab coordinates.\n *\n * This is undefined if the drag is not active.\n */\n tabPressOffset?: { x: number; y: number };\n\n /**\n * The tab target index upon mouse release.\n *\n * This will be `-1` if the drag is not active.\n */\n targetIndex: number;\n\n /**\n * The array of tab layout objects snapped at drag start.\n *\n * This will be `null` if the drag is not active.\n */\n tabLayout: ITabLayout[] | null;\n\n /**\n * The bounding client rect of the tab bar content node.\n *\n * This will be `null` if the drag is not active.\n */\n contentRect: DOMRect | null;\n\n /**\n * The disposable to clean up the cursor override.\n *\n * This will be `null` if the drag is not active.\n */\n override: IDisposable | null;\n\n /**\n * Whether the drag is currently active.\n */\n dragActive: boolean;\n\n /**\n * Whether the drag has been aborted.\n */\n dragAborted: boolean;\n\n /**\n * Whether a detach request as been made.\n */\n detachRequested: boolean;\n }\n\n /**\n * An object which holds layout data for a tab.\n */\n export interface ITabLayout {\n /**\n * The left/top margin value for the tab.\n */\n margin: number;\n\n /**\n * The offset left/top position of the tab.\n */\n pos: number;\n\n /**\n * The offset width/height of the tab.\n */\n size: number;\n }\n\n /**\n * Create the DOM node for a tab bar.\n */\n export function createNode(): HTMLDivElement {\n let node = document.createElement('div');\n let content = document.createElement('ul');\n content.setAttribute('role', 'tablist');\n content.className = 'lm-TabBar-content';\n node.appendChild(content);\n\n let add = document.createElement('div');\n add.className = 'lm-TabBar-addButton lm-mod-hidden';\n add.setAttribute('tabindex', '-1');\n add.setAttribute('role', 'button');\n node.appendChild(add);\n return node;\n }\n\n /**\n * Coerce a title or options into a real title.\n */\n export function asTitle(value: Title | Title.IOptions): Title {\n return value instanceof Title ? value : new Title(value);\n }\n\n /**\n * Parse the transition duration for a tab node.\n */\n export function parseTransitionDuration(tab: HTMLElement): number {\n let style = window.getComputedStyle(tab);\n return 1000 * (parseFloat(style.transitionDuration!) || 0);\n }\n\n /**\n * Get a snapshot of the current tab layout values.\n */\n export function snapTabLayout(\n tabs: HTMLCollection,\n orientation: TabBar.Orientation\n ): ITabLayout[] {\n let layout = new Array(tabs.length);\n for (let i = 0, n = tabs.length; i < n; ++i) {\n let node = tabs[i] as HTMLElement;\n let style = window.getComputedStyle(node);\n if (orientation === 'horizontal') {\n layout[i] = {\n pos: node.offsetLeft,\n size: node.offsetWidth,\n margin: parseFloat(style.marginLeft!) || 0\n };\n } else {\n layout[i] = {\n pos: node.offsetTop,\n size: node.offsetHeight,\n margin: parseFloat(style.marginTop!) || 0\n };\n }\n }\n return layout;\n }\n\n /**\n * Test if the event exceeds the drag threshold.\n */\n export function dragExceeded(data: IDragData, event: MouseEvent): boolean {\n let dx = Math.abs(event.clientX - data.pressX);\n let dy = Math.abs(event.clientY - data.pressY);\n return dx >= DRAG_THRESHOLD || dy >= DRAG_THRESHOLD;\n }\n\n /**\n * Test if the event exceeds the drag detach threshold.\n */\n export function detachExceeded(data: IDragData, event: MouseEvent): boolean {\n let rect = data.contentRect!;\n return (\n event.clientX < rect.left - DETACH_THRESHOLD ||\n event.clientX >= rect.right + DETACH_THRESHOLD ||\n event.clientY < rect.top - DETACH_THRESHOLD ||\n event.clientY >= rect.bottom + DETACH_THRESHOLD\n );\n }\n\n /**\n * Update the relative tab positions and computed target index.\n */\n export function layoutTabs(\n tabs: HTMLCollection,\n data: IDragData,\n event: MouseEvent,\n orientation: TabBar.Orientation\n ): void {\n // Compute the orientation-sensitive values.\n let pressPos: number;\n let localPos: number;\n let clientPos: number;\n let clientSize: number;\n if (orientation === 'horizontal') {\n pressPos = data.pressX;\n localPos = event.clientX - data.contentRect!.left;\n clientPos = event.clientX;\n clientSize = data.contentRect!.width;\n } else {\n pressPos = data.pressY;\n localPos = event.clientY - data.contentRect!.top;\n clientPos = event.clientY;\n clientSize = data.contentRect!.height;\n }\n\n // Compute the target data.\n let targetIndex = data.index;\n let targetPos = localPos - data.tabPressPos;\n let targetEnd = targetPos + data.tabSize;\n\n // Update the relative tab positions.\n for (let i = 0, n = tabs.length; i < n; ++i) {\n let pxPos: string;\n let layout = data.tabLayout![i];\n let threshold = layout.pos + (layout.size >> 1);\n if (i < data.index && targetPos < threshold) {\n pxPos = `${data.tabSize + data.tabLayout![i + 1].margin}px`;\n targetIndex = Math.min(targetIndex, i);\n } else if (i > data.index && targetEnd > threshold) {\n pxPos = `${-data.tabSize - layout.margin}px`;\n targetIndex = Math.max(targetIndex, i);\n } else if (i === data.index) {\n let ideal = clientPos - pressPos;\n let limit = clientSize - (data.tabPos + data.tabSize);\n pxPos = `${Math.max(-data.tabPos, Math.min(ideal, limit))}px`;\n } else {\n pxPos = '';\n }\n if (orientation === 'horizontal') {\n (tabs[i] as HTMLElement).style.left = pxPos;\n } else {\n (tabs[i] as HTMLElement).style.top = pxPos;\n }\n }\n\n // Update the computed target index.\n data.targetIndex = targetIndex;\n }\n\n /**\n * Position the drag tab at its final resting relative position.\n */\n export function finalizeTabPosition(\n data: IDragData,\n orientation: TabBar.Orientation\n ): void {\n // Compute the orientation-sensitive client size.\n let clientSize: number;\n if (orientation === 'horizontal') {\n clientSize = data.contentRect!.width;\n } else {\n clientSize = data.contentRect!.height;\n }\n\n // Compute the ideal final tab position.\n let ideal: number;\n if (data.targetIndex === data.index) {\n ideal = 0;\n } else if (data.targetIndex > data.index) {\n let tgt = data.tabLayout![data.targetIndex];\n ideal = tgt.pos + tgt.size - data.tabSize - data.tabPos;\n } else {\n let tgt = data.tabLayout![data.targetIndex];\n ideal = tgt.pos - data.tabPos;\n }\n\n // Compute the tab position limit.\n let limit = clientSize - (data.tabPos + data.tabSize);\n let final = Math.max(-data.tabPos, Math.min(ideal, limit));\n\n // Set the final orientation-sensitive position.\n if (orientation === 'horizontal') {\n data.tab.style.left = `${final}px`;\n } else {\n data.tab.style.top = `${final}px`;\n }\n }\n\n /**\n * Reset the relative positions of the given tabs.\n */\n export function resetTabPositions(\n tabs: HTMLCollection,\n orientation: TabBar.Orientation\n ): void {\n for (const tab of tabs) {\n if (orientation === 'horizontal') {\n (tab as HTMLElement).style.left = '';\n } else {\n (tab as HTMLElement).style.top = '';\n }\n }\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt, empty } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { BoxEngine, BoxSizer } from './boxengine';\n\nimport { Layout, LayoutItem } from './layout';\n\nimport { TabBar } from './tabbar';\n\nimport Utils from './utils';\n\nimport { Widget } from './widget';\n\n/**\n * A layout which provides a flexible docking arrangement.\n *\n * #### Notes\n * The consumer of this layout is responsible for handling all signals\n * from the generated tab bars and managing the visibility of widgets\n * and tab bars as needed.\n */\nexport class DockLayout extends Layout {\n /**\n * Construct a new dock layout.\n *\n * @param options - The options for initializing the layout.\n */\n constructor(options: DockLayout.IOptions) {\n super();\n this.renderer = options.renderer;\n if (options.spacing !== undefined) {\n this._spacing = Utils.clampDimension(options.spacing);\n }\n this._document = options.document || document;\n this._hiddenMode =\n options.hiddenMode !== undefined\n ? options.hiddenMode\n : Widget.HiddenMode.Display;\n }\n\n /**\n * Dispose of the resources held by the layout.\n *\n * #### Notes\n * This will clear and dispose all widgets in the layout.\n */\n dispose(): void {\n // Get an iterator over the widgets in the layout.\n let widgets = this[Symbol.iterator]();\n\n // Dispose of the layout items.\n this._items.forEach(item => {\n item.dispose();\n });\n\n // Clear the layout state before disposing the widgets.\n this._box = null;\n this._root = null;\n this._items.clear();\n\n // Dispose of the widgets contained in the old layout root.\n for (const widget of widgets) {\n widget.dispose();\n }\n\n // Dispose of the base class.\n super.dispose();\n }\n\n /**\n * The renderer used by the dock layout.\n */\n readonly renderer: DockLayout.IRenderer;\n\n /**\n * The method for hiding child widgets.\n *\n * #### Notes\n * If there is only one child widget, `Display` hiding mode will be used\n * regardless of this setting.\n */\n get hiddenMode(): Widget.HiddenMode {\n return this._hiddenMode;\n }\n set hiddenMode(v: Widget.HiddenMode) {\n if (this._hiddenMode === v) {\n return;\n }\n this._hiddenMode = v;\n for (const bar of this.tabBars()) {\n if (bar.titles.length > 1) {\n for (const title of bar.titles) {\n title.owner.hiddenMode = this._hiddenMode;\n }\n }\n }\n }\n\n /**\n * Get the inter-element spacing for the dock layout.\n */\n get spacing(): number {\n return this._spacing;\n }\n\n /**\n * Set the inter-element spacing for the dock layout.\n */\n set spacing(value: number) {\n value = Utils.clampDimension(value);\n if (this._spacing === value) {\n return;\n }\n this._spacing = value;\n if (!this.parent) {\n return;\n }\n this.parent.fit();\n }\n\n /**\n * Whether the dock layout is empty.\n */\n get isEmpty(): boolean {\n return this._root === null;\n }\n\n /**\n * Create an iterator over all widgets in the layout.\n *\n * @returns A new iterator over the widgets in the layout.\n *\n * #### Notes\n * This iterator includes the generated tab bars.\n */\n [Symbol.iterator](): IterableIterator {\n return this._root ? this._root.iterAllWidgets() : empty();\n }\n\n /**\n * Create an iterator over the user widgets in the layout.\n *\n * @returns A new iterator over the user widgets in the layout.\n *\n * #### Notes\n * This iterator does not include the generated tab bars.\n */\n widgets(): IterableIterator {\n return this._root ? this._root.iterUserWidgets() : empty();\n }\n\n /**\n * Create an iterator over the selected widgets in the layout.\n *\n * @returns A new iterator over the selected user widgets.\n *\n * #### Notes\n * This iterator yields the widgets corresponding to the current tab\n * of each tab bar in the layout.\n */\n selectedWidgets(): IterableIterator {\n return this._root ? this._root.iterSelectedWidgets() : empty();\n }\n\n /**\n * Create an iterator over the tab bars in the layout.\n *\n * @returns A new iterator over the tab bars in the layout.\n *\n * #### Notes\n * This iterator does not include the user widgets.\n */\n tabBars(): IterableIterator> {\n return this._root ? this._root.iterTabBars() : empty();\n }\n\n /**\n * Create an iterator over the handles in the layout.\n *\n * @returns A new iterator over the handles in the layout.\n */\n handles(): IterableIterator {\n return this._root ? this._root.iterHandles() : empty();\n }\n\n /**\n * Move a handle to the given offset position.\n *\n * @param handle - The handle to move.\n *\n * @param offsetX - The desired offset X position of the handle.\n *\n * @param offsetY - The desired offset Y position of the handle.\n *\n * #### Notes\n * If the given handle is not contained in the layout, this is no-op.\n *\n * The handle will be moved as close as possible to the desired\n * position without violating any of the layout constraints.\n *\n * Only one of the coordinates is used depending on the orientation\n * of the handle. This method accepts both coordinates to make it\n * easy to invoke from a mouse move event without needing to know\n * the handle orientation.\n */\n moveHandle(handle: HTMLDivElement, offsetX: number, offsetY: number): void {\n // Bail early if there is no root or if the handle is hidden.\n let hidden = handle.classList.contains('lm-mod-hidden');\n if (!this._root || hidden) {\n return;\n }\n\n // Lookup the split node for the handle.\n let data = this._root.findSplitNode(handle);\n if (!data) {\n return;\n }\n\n // Compute the desired delta movement for the handle.\n let delta: number;\n if (data.node.orientation === 'horizontal') {\n delta = offsetX - handle.offsetLeft;\n } else {\n delta = offsetY - handle.offsetTop;\n }\n\n // Bail if there is no handle movement.\n if (delta === 0) {\n return;\n }\n\n // Prevent sibling resizing unless needed.\n data.node.holdSizes();\n\n // Adjust the sizers to reflect the handle movement.\n BoxEngine.adjust(data.node.sizers, data.index, delta);\n\n // Update the layout of the widgets.\n if (this.parent) {\n this.parent.update();\n }\n }\n\n /**\n * Save the current configuration of the dock layout.\n *\n * @returns A new config object for the current layout state.\n *\n * #### Notes\n * The return value can be provided to the `restoreLayout` method\n * in order to restore the layout to its current configuration.\n */\n saveLayout(): DockLayout.ILayoutConfig {\n // Bail early if there is no root.\n if (!this._root) {\n return { main: null };\n }\n\n // Hold the current sizes in the layout tree.\n this._root.holdAllSizes();\n\n // Return the layout config.\n return { main: this._root.createConfig() };\n }\n\n /**\n * Restore the layout to a previously saved configuration.\n *\n * @param config - The layout configuration to restore.\n *\n * #### Notes\n * Widgets which currently belong to the layout but which are not\n * contained in the config will be unparented.\n */\n restoreLayout(config: DockLayout.ILayoutConfig): void {\n // Create the widget set for validating the config.\n let widgetSet = new Set();\n\n // Normalize the main area config and collect the widgets.\n let mainConfig: DockLayout.AreaConfig | null;\n if (config.main) {\n mainConfig = Private.normalizeAreaConfig(config.main, widgetSet);\n } else {\n mainConfig = null;\n }\n\n // Create iterators over the old content.\n let oldWidgets = this.widgets();\n let oldTabBars = this.tabBars();\n let oldHandles = this.handles();\n\n // Clear the root before removing the old content.\n this._root = null;\n\n // Unparent the old widgets which are not in the new config.\n for (const widget of oldWidgets) {\n if (!widgetSet.has(widget)) {\n widget.parent = null;\n }\n }\n\n // Dispose of the old tab bars.\n for (const tabBar of oldTabBars) {\n tabBar.dispose();\n }\n\n // Remove the old handles.\n for (const handle of oldHandles) {\n if (handle.parentNode) {\n handle.parentNode.removeChild(handle);\n }\n }\n\n // Reparent the new widgets to the current parent.\n for (const widget of widgetSet) {\n widget.parent = this.parent;\n }\n\n // Create the root node for the new config.\n if (mainConfig) {\n this._root = Private.realizeAreaConfig(\n mainConfig,\n {\n // Ignoring optional `document` argument as we must reuse `this._document`\n createTabBar: (document?: Document | ShadowRoot) =>\n this._createTabBar(),\n createHandle: () => this._createHandle()\n },\n this._document\n );\n } else {\n this._root = null;\n }\n\n // If there is no parent, there is nothing more to do.\n if (!this.parent) {\n return;\n }\n\n // Attach the new widgets to the parent.\n widgetSet.forEach(widget => {\n this.attachWidget(widget);\n });\n\n // Post a fit request to the parent.\n this.parent.fit();\n }\n\n /**\n * Add a widget to the dock layout.\n *\n * @param widget - The widget to add to the dock layout.\n *\n * @param options - The additional options for adding the widget.\n *\n * #### Notes\n * The widget will be moved if it is already contained in the layout.\n *\n * An error will be thrown if the reference widget is invalid.\n */\n addWidget(widget: Widget, options: DockLayout.IAddOptions = {}): void {\n // Parse the options.\n let ref = options.ref || null;\n let mode = options.mode || 'tab-after';\n\n // Find the tab node which holds the reference widget.\n let refNode: Private.TabLayoutNode | null = null;\n if (this._root && ref) {\n refNode = this._root.findTabNode(ref);\n }\n\n // Throw an error if the reference widget is invalid.\n if (ref && !refNode) {\n throw new Error('Reference widget is not in the layout.');\n }\n\n // Reparent the widget to the current layout parent.\n widget.parent = this.parent;\n\n // Insert the widget according to the insert mode.\n switch (mode) {\n case 'tab-after':\n this._insertTab(widget, ref, refNode, true);\n break;\n case 'tab-before':\n this._insertTab(widget, ref, refNode, false);\n break;\n case 'split-top':\n this._insertSplit(widget, ref, refNode, 'vertical', false);\n break;\n case 'split-left':\n this._insertSplit(widget, ref, refNode, 'horizontal', false);\n break;\n case 'split-right':\n this._insertSplit(widget, ref, refNode, 'horizontal', true);\n break;\n case 'split-bottom':\n this._insertSplit(widget, ref, refNode, 'vertical', true);\n break;\n case 'merge-top':\n this._insertSplit(widget, ref, refNode, 'vertical', false, true);\n break;\n case 'merge-left':\n this._insertSplit(widget, ref, refNode, 'horizontal', false, true);\n break;\n case 'merge-right':\n this._insertSplit(widget, ref, refNode, 'horizontal', true, true);\n break;\n case 'merge-bottom':\n this._insertSplit(widget, ref, refNode, 'vertical', true, true);\n break;\n }\n\n // Do nothing else if there is no parent widget.\n if (!this.parent) {\n return;\n }\n\n // Ensure the widget is attached to the parent widget.\n this.attachWidget(widget);\n\n // Post a fit request for the parent widget.\n this.parent.fit();\n }\n\n /**\n * Remove a widget from the layout.\n *\n * @param widget - The widget to remove from the layout.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method does *not* modify the widget's `parent`.\n */\n removeWidget(widget: Widget): void {\n // Remove the widget from its current layout location.\n this._removeWidget(widget);\n\n // Do nothing else if there is no parent widget.\n if (!this.parent) {\n return;\n }\n\n // Detach the widget from the parent widget.\n this.detachWidget(widget);\n\n // Post a fit request for the parent widget.\n this.parent.fit();\n }\n\n /**\n * Find the tab area which contains the given client position.\n *\n * @param clientX - The client X position of interest.\n *\n * @param clientY - The client Y position of interest.\n *\n * @returns The geometry of the tab area at the given position, or\n * `null` if there is no tab area at the given position.\n */\n hitTestTabAreas(\n clientX: number,\n clientY: number\n ): DockLayout.ITabAreaGeometry | null {\n // Bail early if hit testing cannot produce valid results.\n if (!this._root || !this.parent || !this.parent.isVisible) {\n return null;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent.node);\n }\n\n // Convert from client to local coordinates.\n let rect = this.parent.node.getBoundingClientRect();\n let x = clientX - rect.left - this._box.borderLeft;\n let y = clientY - rect.top - this._box.borderTop;\n\n // Find the tab layout node at the local position.\n let tabNode = this._root.hitTestTabNodes(x, y);\n\n // Bail if a tab layout node was not found.\n if (!tabNode) {\n return null;\n }\n\n // Extract the data from the tab node.\n let { tabBar, top, left, width, height } = tabNode;\n\n // Compute the right and bottom edges of the tab area.\n let borderWidth = this._box.borderLeft + this._box.borderRight;\n let borderHeight = this._box.borderTop + this._box.borderBottom;\n let right = rect.width - borderWidth - (left + width);\n let bottom = rect.height - borderHeight - (top + height);\n\n // Return the hit test results.\n return { tabBar, x, y, top, left, right, bottom, width, height };\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n // Perform superclass initialization.\n super.init();\n\n // Attach each widget to the parent.\n for (const widget of this) {\n this.attachWidget(widget);\n }\n\n // Attach each handle to the parent.\n for (const handle of this.handles()) {\n this.parent!.node.appendChild(handle);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * Attach the widget to the layout parent widget.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This is a no-op if the widget is already attached.\n */\n protected attachWidget(widget: Widget): void {\n // Do nothing if the widget is already attached.\n if (this.parent!.node === widget.node.parentNode) {\n return;\n }\n\n // Create the layout item for the widget.\n this._items.set(widget, new LayoutItem(widget));\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget's node to the parent.\n this.parent!.node.appendChild(widget.node);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n }\n\n /**\n * Detach the widget from the layout parent widget.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This is a no-op if the widget is not attached.\n */\n protected detachWidget(widget: Widget): void {\n // Do nothing if the widget is not attached.\n if (this.parent!.node !== widget.node.parentNode) {\n return;\n }\n\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Delete the layout item for the widget.\n let item = this._items.get(widget);\n if (item) {\n this._items.delete(widget);\n item.dispose();\n }\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n */\n protected onBeforeShow(msg: Message): void {\n super.onBeforeShow(msg);\n this.parent!.update();\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n super.onBeforeAttach(msg);\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n if (this.parent!.isVisible) {\n this._update(msg.width, msg.height);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.parent!.isVisible) {\n this._update(-1, -1);\n }\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n */\n protected onFitRequest(msg: Message): void {\n if (this.parent!.isAttached) {\n this._fit();\n }\n }\n\n /**\n * Remove the specified widget from the layout structure.\n *\n * #### Notes\n * This is a no-op if the widget is not in the layout tree.\n *\n * This does not detach the widget from the parent node.\n */\n private _removeWidget(widget: Widget): void {\n // Bail early if there is no layout root.\n if (!this._root) {\n return;\n }\n\n // Find the tab node which contains the given widget.\n let tabNode = this._root.findTabNode(widget);\n\n // Bail early if the tab node is not found.\n if (!tabNode) {\n return;\n }\n\n Private.removeAria(widget);\n\n // If there are multiple tabs, just remove the widget's tab.\n if (tabNode.tabBar.titles.length > 1) {\n tabNode.tabBar.removeTab(widget.title);\n if (\n this._hiddenMode === Widget.HiddenMode.Scale &&\n tabNode.tabBar.titles.length == 1\n ) {\n const existingWidget = tabNode.tabBar.titles[0].owner;\n existingWidget.hiddenMode = Widget.HiddenMode.Display;\n }\n return;\n }\n\n // Otherwise, the tab node needs to be removed...\n\n // Dispose the tab bar.\n tabNode.tabBar.dispose();\n\n // Handle the case where the tab node is the root.\n if (this._root === tabNode) {\n this._root = null;\n return;\n }\n\n // Otherwise, remove the tab node from its parent...\n\n // Prevent widget resizing unless needed.\n this._root.holdAllSizes();\n\n // Clear the parent reference on the tab node.\n let splitNode = tabNode.parent!;\n tabNode.parent = null;\n\n // Remove the tab node from its parent split node.\n let i = ArrayExt.removeFirstOf(splitNode.children, tabNode);\n let handle = ArrayExt.removeAt(splitNode.handles, i)!;\n ArrayExt.removeAt(splitNode.sizers, i);\n\n // Remove the handle from its parent DOM node.\n if (handle.parentNode) {\n handle.parentNode.removeChild(handle);\n }\n\n // If there are multiple children, just update the handles.\n if (splitNode.children.length > 1) {\n splitNode.syncHandles();\n return;\n }\n\n // Otherwise, the split node also needs to be removed...\n\n // Clear the parent reference on the split node.\n let maybeParent = splitNode.parent;\n splitNode.parent = null;\n\n // Lookup the remaining child node and handle.\n let childNode = splitNode.children[0];\n let childHandle = splitNode.handles[0];\n\n // Clear the split node data.\n splitNode.children.length = 0;\n splitNode.handles.length = 0;\n splitNode.sizers.length = 0;\n\n // Remove the child handle from its parent node.\n if (childHandle.parentNode) {\n childHandle.parentNode.removeChild(childHandle);\n }\n\n // Handle the case where the split node is the root.\n if (this._root === splitNode) {\n childNode.parent = null;\n this._root = childNode;\n return;\n }\n\n // Otherwise, move the child node to the parent node...\n let parentNode = maybeParent!;\n\n // Lookup the index of the split node.\n let j = parentNode.children.indexOf(splitNode);\n\n // Handle the case where the child node is a tab node.\n if (childNode instanceof Private.TabLayoutNode) {\n childNode.parent = parentNode;\n parentNode.children[j] = childNode;\n return;\n }\n\n // Remove the split data from the parent.\n let splitHandle = ArrayExt.removeAt(parentNode.handles, j)!;\n ArrayExt.removeAt(parentNode.children, j);\n ArrayExt.removeAt(parentNode.sizers, j);\n\n // Remove the handle from its parent node.\n if (splitHandle.parentNode) {\n splitHandle.parentNode.removeChild(splitHandle);\n }\n\n // The child node and the split parent node will have the same\n // orientation. Merge the grand-children with the parent node.\n for (let i = 0, n = childNode.children.length; i < n; ++i) {\n let gChild = childNode.children[i];\n let gHandle = childNode.handles[i];\n let gSizer = childNode.sizers[i];\n ArrayExt.insert(parentNode.children, j + i, gChild);\n ArrayExt.insert(parentNode.handles, j + i, gHandle);\n ArrayExt.insert(parentNode.sizers, j + i, gSizer);\n gChild.parent = parentNode;\n }\n\n // Clear the child node.\n childNode.children.length = 0;\n childNode.handles.length = 0;\n childNode.sizers.length = 0;\n childNode.parent = null;\n\n // Sync the handles on the parent node.\n parentNode.syncHandles();\n }\n\n /**\n * Create the tab layout node to hold the widget.\n */\n private _createTabNode(widget: Widget): Private.TabLayoutNode {\n let tabNode = new Private.TabLayoutNode(this._createTabBar());\n tabNode.tabBar.addTab(widget.title);\n Private.addAria(widget, tabNode.tabBar);\n return tabNode;\n }\n\n /**\n * Insert a widget next to an existing tab.\n *\n * #### Notes\n * This does not attach the widget to the parent widget.\n */\n private _insertTab(\n widget: Widget,\n ref: Widget | null,\n refNode: Private.TabLayoutNode | null,\n after: boolean\n ): void {\n // Do nothing if the tab is inserted next to itself.\n if (widget === ref) {\n return;\n }\n\n // Create the root if it does not exist.\n if (!this._root) {\n let tabNode = new Private.TabLayoutNode(this._createTabBar());\n tabNode.tabBar.addTab(widget.title);\n this._root = tabNode;\n Private.addAria(widget, tabNode.tabBar);\n return;\n }\n\n // Use the first tab node as the ref node if needed.\n if (!refNode) {\n refNode = this._root.findFirstTabNode()!;\n }\n\n // If the widget is not contained in the ref node, ensure it is\n // removed from the layout and hidden before being added again.\n if (refNode.tabBar.titles.indexOf(widget.title) === -1) {\n this._removeWidget(widget);\n widget.hide();\n }\n\n // Lookup the target index for inserting the tab.\n let index: number;\n if (ref) {\n index = refNode.tabBar.titles.indexOf(ref.title);\n } else {\n index = refNode.tabBar.currentIndex;\n }\n\n // Using transform create an additional layer in the pixel pipeline\n // to limit the number of layer, it is set only if there is more than one widget.\n if (this._hiddenMode === Widget.HiddenMode.Scale) {\n if (refNode.tabBar.titles.length === 0) {\n // Singular tab should use display mode to limit number of layers.\n widget.hiddenMode = Widget.HiddenMode.Display;\n } else if (refNode.tabBar.titles.length == 1) {\n // If we are adding a second tab, switch the existing tab back to scale.\n const existingWidget = refNode.tabBar.titles[0].owner;\n existingWidget.hiddenMode = Widget.HiddenMode.Scale;\n } else {\n // For the third and subsequent tabs no special action is needed.\n widget.hiddenMode = Widget.HiddenMode.Scale;\n }\n } else {\n // For all other modes just propagate the current mode.\n widget.hiddenMode = this._hiddenMode;\n }\n\n // Insert the widget's tab relative to the target index.\n refNode.tabBar.insertTab(index + (after ? 1 : 0), widget.title);\n Private.addAria(widget, refNode.tabBar);\n }\n\n /**\n * Insert a widget as a new split area.\n *\n * #### Notes\n * This does not attach the widget to the parent widget.\n */\n private _insertSplit(\n widget: Widget,\n ref: Widget | null,\n refNode: Private.TabLayoutNode | null,\n orientation: Private.Orientation,\n after: boolean,\n merge: boolean = false\n ): void {\n // Do nothing if there is no effective split.\n if (widget === ref && refNode && refNode.tabBar.titles.length === 1) {\n return;\n }\n\n // Ensure the widget is removed from the current layout.\n this._removeWidget(widget);\n\n // Set the root if it does not exist.\n if (!this._root) {\n this._root = this._createTabNode(widget);\n return;\n }\n\n // If the ref node parent is null, split the root.\n if (!refNode || !refNode.parent) {\n // Ensure the root is split with the correct orientation.\n let root = this._splitRoot(orientation);\n\n // Determine the insert index for the new tab node.\n let i = after ? root.children.length : 0;\n\n // Normalize the split node.\n root.normalizeSizes();\n\n // Create the sizer for new tab node.\n let sizer = Private.createSizer(refNode ? 1 : Private.GOLDEN_RATIO);\n\n // Insert the tab node sized to the golden ratio.\n let tabNode = this._createTabNode(widget);\n ArrayExt.insert(root.children, i, tabNode);\n ArrayExt.insert(root.sizers, i, sizer);\n ArrayExt.insert(root.handles, i, this._createHandle());\n tabNode.parent = root;\n\n // Re-normalize the split node to maintain the ratios.\n root.normalizeSizes();\n\n // Finally, synchronize the visibility of the handles.\n root.syncHandles();\n return;\n }\n\n // Lookup the split node for the ref widget.\n let splitNode = refNode.parent;\n\n // If the split node already had the correct orientation,\n // the widget can be inserted into the split node directly.\n if (splitNode.orientation === orientation) {\n // Find the index of the ref node.\n let i = splitNode.children.indexOf(refNode);\n\n // Conditionally reuse a tab layout found in the wanted position.\n if (merge) {\n let j = i + (after ? 1 : -1);\n let sibling = splitNode.children[j];\n if (sibling instanceof Private.TabLayoutNode) {\n this._insertTab(widget, null, sibling, true);\n ++sibling.tabBar.currentIndex;\n return;\n }\n }\n\n // Normalize the split node.\n splitNode.normalizeSizes();\n\n // Consume half the space for the insert location.\n let s = (splitNode.sizers[i].sizeHint /= 2);\n\n // Insert the tab node sized to the other half.\n let j = i + (after ? 1 : 0);\n let tabNode = this._createTabNode(widget);\n ArrayExt.insert(splitNode.children, j, tabNode);\n ArrayExt.insert(splitNode.sizers, j, Private.createSizer(s));\n ArrayExt.insert(splitNode.handles, j, this._createHandle());\n tabNode.parent = splitNode;\n\n // Finally, synchronize the visibility of the handles.\n splitNode.syncHandles();\n return;\n }\n\n // Remove the ref node from the split node.\n let i = ArrayExt.removeFirstOf(splitNode.children, refNode);\n\n // Create a new normalized split node for the children.\n let childNode = new Private.SplitLayoutNode(orientation);\n childNode.normalized = true;\n\n // Add the ref node sized to half the space.\n childNode.children.push(refNode);\n childNode.sizers.push(Private.createSizer(0.5));\n childNode.handles.push(this._createHandle());\n refNode.parent = childNode;\n\n // Add the tab node sized to the other half.\n let j = after ? 1 : 0;\n let tabNode = this._createTabNode(widget);\n ArrayExt.insert(childNode.children, j, tabNode);\n ArrayExt.insert(childNode.sizers, j, Private.createSizer(0.5));\n ArrayExt.insert(childNode.handles, j, this._createHandle());\n tabNode.parent = childNode;\n\n // Synchronize the visibility of the handles.\n childNode.syncHandles();\n\n // Finally, add the new child node to the original split node.\n ArrayExt.insert(splitNode.children, i, childNode);\n childNode.parent = splitNode;\n }\n\n /**\n * Ensure the root is a split node with the given orientation.\n */\n private _splitRoot(\n orientation: Private.Orientation\n ): Private.SplitLayoutNode {\n // Bail early if the root already meets the requirements.\n let oldRoot = this._root;\n if (oldRoot instanceof Private.SplitLayoutNode) {\n if (oldRoot.orientation === orientation) {\n return oldRoot;\n }\n }\n\n // Create a new root node with the specified orientation.\n let newRoot = (this._root = new Private.SplitLayoutNode(orientation));\n\n // Add the old root to the new root.\n if (oldRoot) {\n newRoot.children.push(oldRoot);\n newRoot.sizers.push(Private.createSizer(0));\n newRoot.handles.push(this._createHandle());\n oldRoot.parent = newRoot;\n }\n\n // Return the new root as a convenience.\n return newRoot;\n }\n\n /**\n * Fit the layout to the total size required by the widgets.\n */\n private _fit(): void {\n // Set up the computed minimum size.\n let minW = 0;\n let minH = 0;\n\n // Update the size limits for the layout tree.\n if (this._root) {\n let limits = this._root.fit(this._spacing, this._items);\n minW = limits.minWidth;\n minH = limits.minHeight;\n }\n\n // Update the box sizing and add it to the computed min size.\n let box = (this._box = ElementExt.boxSizing(this.parent!.node));\n minW += box.horizontalSum;\n minH += box.verticalSum;\n\n // Update the parent's min size constraints.\n let style = this.parent!.node.style;\n style.minWidth = `${minW}px`;\n style.minHeight = `${minH}px`;\n\n // Set the dirty flag to ensure only a single update occurs.\n this._dirty = true;\n\n // Notify the ancestor that it should fit immediately. This may\n // cause a resize of the parent, fulfilling the required update.\n if (this.parent!.parent) {\n MessageLoop.sendMessage(this.parent!.parent!, Widget.Msg.FitRequest);\n }\n\n // If the dirty flag is still set, the parent was not resized.\n // Trigger the required update on the parent widget immediately.\n if (this._dirty) {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n }\n }\n\n /**\n * Update the layout position and size of the widgets.\n *\n * The parent offset dimensions should be `-1` if unknown.\n */\n private _update(offsetWidth: number, offsetHeight: number): void {\n // Clear the dirty flag to indicate the update occurred.\n this._dirty = false;\n\n // Bail early if there is no root layout node.\n if (!this._root) {\n return;\n }\n\n // Measure the parent if the offset dimensions are unknown.\n if (offsetWidth < 0) {\n offsetWidth = this.parent!.node.offsetWidth;\n }\n if (offsetHeight < 0) {\n offsetHeight = this.parent!.node.offsetHeight;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent!.node);\n }\n\n // Compute the actual layout bounds adjusted for border and padding.\n let x = this._box.paddingTop;\n let y = this._box.paddingLeft;\n let width = offsetWidth - this._box.horizontalSum;\n let height = offsetHeight - this._box.verticalSum;\n\n // Update the geometry of the layout tree.\n this._root.update(x, y, width, height, this._spacing, this._items);\n }\n\n /**\n * Create a new tab bar for use by the dock layout.\n *\n * #### Notes\n * The tab bar will be attached to the parent if it exists.\n */\n private _createTabBar(): TabBar {\n // Create the tab bar using the renderer.\n let tabBar = this.renderer.createTabBar(this._document);\n\n // Enforce necessary tab bar behavior.\n tabBar.orientation = 'horizontal';\n\n // Attach the tab bar to the parent if possible.\n if (this.parent) {\n this.attachWidget(tabBar);\n }\n\n // Return the initialized tab bar.\n return tabBar;\n }\n\n /**\n * Create a new handle for the dock layout.\n *\n * #### Notes\n * The handle will be attached to the parent if it exists.\n */\n private _createHandle(): HTMLDivElement {\n // Create the handle using the renderer.\n let handle = this.renderer.createHandle();\n\n // Initialize the handle layout behavior.\n let style = handle.style;\n style.position = 'absolute';\n style.contain = 'strict';\n style.top = '0';\n style.left = '0';\n style.width = '0';\n style.height = '0';\n\n // Attach the handle to the parent if it exists.\n if (this.parent) {\n this.parent.node.appendChild(handle);\n }\n\n // Return the initialized handle.\n return handle;\n }\n\n private _spacing = 4;\n private _dirty = false;\n private _root: Private.LayoutNode | null = null;\n private _box: ElementExt.IBoxSizing | null = null;\n private _document: Document | ShadowRoot;\n private _hiddenMode: Widget.HiddenMode;\n private _items: Private.ItemMap = new Map();\n}\n\n/**\n * The namespace for the `DockLayout` class statics.\n */\nexport namespace DockLayout {\n /**\n * An options object for creating a dock layout.\n */\n export interface IOptions {\n /**\n * The document to use with the dock panel.\n *\n * The default is the global `document` instance.\n */\n document?: Document | ShadowRoot;\n\n /**\n * The method for hiding widgets.\n *\n * The default is `Widget.HiddenMode.Display`.\n */\n hiddenMode?: Widget.HiddenMode;\n\n /**\n * The renderer to use for the dock layout.\n */\n renderer: IRenderer;\n\n /**\n * The spacing between items in the layout.\n *\n * The default is `4`.\n */\n spacing?: number;\n }\n\n /**\n * A renderer for use with a dock layout.\n */\n export interface IRenderer {\n /**\n * Create a new tab bar for use with a dock layout.\n *\n * @returns A new tab bar for a dock layout.\n */\n createTabBar(document?: Document | ShadowRoot): TabBar;\n\n /**\n * Create a new handle node for use with a dock layout.\n *\n * @returns A new handle node for a dock layout.\n */\n createHandle(): HTMLDivElement;\n }\n\n /**\n * A type alias for the supported insertion modes.\n *\n * An insert mode is used to specify how a widget should be added\n * to the dock layout relative to a reference widget.\n */\n export type InsertMode =\n | /**\n * The area to the top of the reference widget.\n *\n * The widget will be inserted just above the reference widget.\n *\n * If the reference widget is null or invalid, the widget will be\n * inserted at the top edge of the dock layout.\n */\n 'split-top'\n\n /**\n * The area to the left of the reference widget.\n *\n * The widget will be inserted just left of the reference widget.\n *\n * If the reference widget is null or invalid, the widget will be\n * inserted at the left edge of the dock layout.\n */\n | 'split-left'\n\n /**\n * The area to the right of the reference widget.\n *\n * The widget will be inserted just right of the reference widget.\n *\n * If the reference widget is null or invalid, the widget will be\n * inserted at the right edge of the dock layout.\n */\n | 'split-right'\n\n /**\n * The area to the bottom of the reference widget.\n *\n * The widget will be inserted just below the reference widget.\n *\n * If the reference widget is null or invalid, the widget will be\n * inserted at the bottom edge of the dock layout.\n */\n | 'split-bottom'\n\n /**\n * Like `split-top` but if a tab layout exists above the reference widget,\n * it behaves like `tab-after` with reference to that instead.\n */\n | 'merge-top'\n\n /**\n * Like `split-left` but if a tab layout exists left of the reference widget,\n * it behaves like `tab-after` with reference to that instead.\n */\n | 'merge-left'\n\n /**\n * Like `split-right` but if a tab layout exists right of the reference widget,\n * it behaves like `tab-after` with reference to that instead.\n */\n | 'merge-right'\n\n /**\n * Like `split-bottom` but if a tab layout exists below the reference widget,\n * it behaves like `tab-after` with reference to that instead.\n */\n | 'merge-bottom'\n\n /**\n * The tab position before the reference widget.\n *\n * The widget will be added as a tab before the reference widget.\n *\n * If the reference widget is null or invalid, a sensible default\n * will be used.\n */\n | 'tab-before'\n\n /**\n * The tab position after the reference widget.\n *\n * The widget will be added as a tab after the reference widget.\n *\n * If the reference widget is null or invalid, a sensible default\n * will be used.\n */\n | 'tab-after';\n\n /**\n * An options object for adding a widget to the dock layout.\n */\n export interface IAddOptions {\n /**\n * The insertion mode for adding the widget.\n *\n * The default is `'tab-after'`.\n */\n mode?: InsertMode;\n\n /**\n * The reference widget for the insert location.\n *\n * The default is `null`.\n */\n ref?: Widget | null;\n }\n\n /**\n * A layout config object for a tab area.\n */\n export interface ITabAreaConfig {\n /**\n * The discriminated type of the config object.\n */\n type: 'tab-area';\n\n /**\n * The widgets contained in the tab area.\n */\n widgets: Widget[];\n\n /**\n * The index of the selected tab.\n */\n currentIndex: number;\n }\n\n /**\n * A layout config object for a split area.\n */\n export interface ISplitAreaConfig {\n /**\n * The discriminated type of the config object.\n */\n type: 'split-area';\n\n /**\n * The orientation of the split area.\n */\n orientation: 'horizontal' | 'vertical';\n\n /**\n * The children in the split area.\n */\n children: AreaConfig[];\n\n /**\n * The relative sizes of the children.\n */\n sizes: number[];\n }\n\n /**\n * A type alias for a general area config.\n */\n export type AreaConfig = ITabAreaConfig | ISplitAreaConfig;\n\n /**\n * A dock layout configuration object.\n */\n export interface ILayoutConfig {\n /**\n * The layout config for the main dock area.\n */\n main: AreaConfig | null;\n }\n\n /**\n * An object which represents the geometry of a tab area.\n */\n export interface ITabAreaGeometry {\n /**\n * The tab bar for the tab area.\n */\n tabBar: TabBar;\n\n /**\n * The local X position of the hit test in the dock area.\n *\n * #### Notes\n * This is the distance from the left edge of the layout parent\n * widget, to the local X coordinate of the hit test query.\n */\n x: number;\n\n /**\n * The local Y position of the hit test in the dock area.\n *\n * #### Notes\n * This is the distance from the top edge of the layout parent\n * widget, to the local Y coordinate of the hit test query.\n */\n y: number;\n\n /**\n * The local coordinate of the top edge of the tab area.\n *\n * #### Notes\n * This is the distance from the top edge of the layout parent\n * widget, to the top edge of the tab area.\n */\n top: number;\n\n /**\n * The local coordinate of the left edge of the tab area.\n *\n * #### Notes\n * This is the distance from the left edge of the layout parent\n * widget, to the left edge of the tab area.\n */\n left: number;\n\n /**\n * The local coordinate of the right edge of the tab area.\n *\n * #### Notes\n * This is the distance from the right edge of the layout parent\n * widget, to the right edge of the tab area.\n */\n right: number;\n\n /**\n * The local coordinate of the bottom edge of the tab area.\n *\n * #### Notes\n * This is the distance from the bottom edge of the layout parent\n * widget, to the bottom edge of the tab area.\n */\n bottom: number;\n\n /**\n * The width of the tab area.\n *\n * #### Notes\n * This is total width allocated for the tab area.\n */\n width: number;\n\n /**\n * The height of the tab area.\n *\n * #### Notes\n * This is total height allocated for the tab area.\n */\n height: number;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * A fraction used for sizing root panels; ~= `1 / golden_ratio`.\n */\n export const GOLDEN_RATIO = 0.618;\n\n /**\n * A type alias for a dock layout node.\n */\n export type LayoutNode = TabLayoutNode | SplitLayoutNode;\n\n /**\n * A type alias for the orientation of a split layout node.\n */\n export type Orientation = 'horizontal' | 'vertical';\n\n /**\n * A type alias for a layout item map.\n */\n export type ItemMap = Map;\n\n /**\n * Create a box sizer with an initial size hint.\n */\n export function createSizer(hint: number): BoxSizer {\n let sizer = new BoxSizer();\n sizer.sizeHint = hint;\n sizer.size = hint;\n return sizer;\n }\n\n /**\n * Normalize an area config object and collect the visited widgets.\n */\n export function normalizeAreaConfig(\n config: DockLayout.AreaConfig,\n widgetSet: Set\n ): DockLayout.AreaConfig | null {\n let result: DockLayout.AreaConfig | null;\n if (config.type === 'tab-area') {\n result = normalizeTabAreaConfig(config, widgetSet);\n } else {\n result = normalizeSplitAreaConfig(config, widgetSet);\n }\n return result;\n }\n\n /**\n * Convert a normalized area config into a layout tree.\n */\n export function realizeAreaConfig(\n config: DockLayout.AreaConfig,\n renderer: DockLayout.IRenderer,\n document: Document | ShadowRoot\n ): LayoutNode {\n let node: LayoutNode;\n if (config.type === 'tab-area') {\n node = realizeTabAreaConfig(config, renderer, document);\n } else {\n node = realizeSplitAreaConfig(config, renderer, document);\n }\n return node;\n }\n\n /**\n * A layout node which holds the data for a tabbed area.\n */\n export class TabLayoutNode {\n /**\n * Construct a new tab layout node.\n *\n * @param tabBar - The tab bar to use for the layout node.\n */\n constructor(tabBar: TabBar) {\n let tabSizer = new BoxSizer();\n let widgetSizer = new BoxSizer();\n tabSizer.stretch = 0;\n widgetSizer.stretch = 1;\n this.tabBar = tabBar;\n this.sizers = [tabSizer, widgetSizer];\n }\n\n /**\n * The parent of the layout node.\n */\n parent: SplitLayoutNode | null = null;\n\n /**\n * The tab bar for the layout node.\n */\n readonly tabBar: TabBar;\n\n /**\n * The sizers for the layout node.\n */\n readonly sizers: [BoxSizer, BoxSizer];\n\n /**\n * The most recent value for the `top` edge of the layout box.\n */\n get top(): number {\n return this._top;\n }\n\n /**\n * The most recent value for the `left` edge of the layout box.\n */\n get left(): number {\n return this._left;\n }\n\n /**\n * The most recent value for the `width` of the layout box.\n */\n get width(): number {\n return this._width;\n }\n\n /**\n * The most recent value for the `height` of the layout box.\n */\n get height(): number {\n return this._height;\n }\n\n /**\n * Create an iterator for all widgets in the layout tree.\n */\n *iterAllWidgets(): IterableIterator {\n yield this.tabBar;\n yield* this.iterUserWidgets();\n }\n\n /**\n * Create an iterator for the user widgets in the layout tree.\n */\n *iterUserWidgets(): IterableIterator {\n for (const title of this.tabBar.titles) {\n yield title.owner;\n }\n }\n\n /**\n * Create an iterator for the selected widgets in the layout tree.\n */\n *iterSelectedWidgets(): IterableIterator {\n let title = this.tabBar.currentTitle;\n if (title) {\n yield title.owner;\n }\n }\n\n /**\n * Create an iterator for the tab bars in the layout tree.\n */\n *iterTabBars(): IterableIterator> {\n yield this.tabBar;\n }\n\n /**\n * Create an iterator for the handles in the layout tree.\n */\n // eslint-disable-next-line require-yield\n *iterHandles(): IterableIterator {\n return;\n }\n\n /**\n * Find the tab layout node which contains the given widget.\n */\n findTabNode(widget: Widget): TabLayoutNode | null {\n return this.tabBar.titles.indexOf(widget.title) !== -1 ? this : null;\n }\n\n /**\n * Find the split layout node which contains the given handle.\n */\n findSplitNode(\n handle: HTMLDivElement\n ): { index: number; node: SplitLayoutNode } | null {\n return null;\n }\n\n /**\n * Find the first tab layout node in a layout tree.\n */\n findFirstTabNode(): TabLayoutNode | null {\n return this;\n }\n\n /**\n * Find the tab layout node which contains the local point.\n */\n hitTestTabNodes(x: number, y: number): TabLayoutNode | null {\n if (x < this._left || x >= this._left + this._width) {\n return null;\n }\n if (y < this._top || y >= this._top + this._height) {\n return null;\n }\n return this;\n }\n\n /**\n * Create a configuration object for the layout tree.\n */\n createConfig(): DockLayout.ITabAreaConfig {\n let widgets = this.tabBar.titles.map(title => title.owner);\n let currentIndex = this.tabBar.currentIndex;\n return { type: 'tab-area', widgets, currentIndex };\n }\n\n /**\n * Recursively hold all of the sizes in the layout tree.\n *\n * This ignores the sizers of tab layout nodes.\n */\n holdAllSizes(): void {\n return;\n }\n\n /**\n * Fit the layout tree.\n */\n fit(spacing: number, items: ItemMap): ElementExt.ISizeLimits {\n // Set up the limit variables.\n let minWidth = 0;\n let minHeight = 0;\n let maxWidth = Infinity;\n let maxHeight = Infinity;\n\n // Lookup the tab bar layout item.\n let tabBarItem = items.get(this.tabBar);\n\n // Lookup the widget layout item.\n let current = this.tabBar.currentTitle;\n let widgetItem = current ? items.get(current.owner) : undefined;\n\n // Lookup the tab bar and widget sizers.\n let [tabBarSizer, widgetSizer] = this.sizers;\n\n // Update the tab bar limits.\n if (tabBarItem) {\n tabBarItem.fit();\n }\n\n // Update the widget limits.\n if (widgetItem) {\n widgetItem.fit();\n }\n\n // Update the results and sizer for the tab bar.\n if (tabBarItem && !tabBarItem.isHidden) {\n minWidth = Math.max(minWidth, tabBarItem.minWidth);\n minHeight += tabBarItem.minHeight;\n tabBarSizer.minSize = tabBarItem.minHeight;\n tabBarSizer.maxSize = tabBarItem.maxHeight;\n } else {\n tabBarSizer.minSize = 0;\n tabBarSizer.maxSize = 0;\n }\n\n // Update the results and sizer for the current widget.\n if (widgetItem && !widgetItem.isHidden) {\n minWidth = Math.max(minWidth, widgetItem.minWidth);\n minHeight += widgetItem.minHeight;\n widgetSizer.minSize = widgetItem.minHeight;\n widgetSizer.maxSize = Infinity;\n } else {\n widgetSizer.minSize = 0;\n widgetSizer.maxSize = Infinity;\n }\n\n // Return the computed size limits for the layout node.\n return { minWidth, minHeight, maxWidth, maxHeight };\n }\n\n /**\n * Update the layout tree.\n */\n update(\n left: number,\n top: number,\n width: number,\n height: number,\n spacing: number,\n items: ItemMap\n ): void {\n // Update the layout box values.\n this._top = top;\n this._left = left;\n this._width = width;\n this._height = height;\n\n // Lookup the tab bar layout item.\n let tabBarItem = items.get(this.tabBar);\n\n // Lookup the widget layout item.\n let current = this.tabBar.currentTitle;\n let widgetItem = current ? items.get(current.owner) : undefined;\n\n // Distribute the layout space to the sizers.\n BoxEngine.calc(this.sizers, height);\n\n // Update the tab bar item using the computed size.\n if (tabBarItem && !tabBarItem.isHidden) {\n let size = this.sizers[0].size;\n tabBarItem.update(left, top, width, size);\n top += size;\n }\n\n // Layout the widget using the computed size.\n if (widgetItem && !widgetItem.isHidden) {\n let size = this.sizers[1].size;\n widgetItem.update(left, top, width, size);\n }\n }\n\n private _top = 0;\n private _left = 0;\n private _width = 0;\n private _height = 0;\n }\n\n /**\n * A layout node which holds the data for a split area.\n */\n export class SplitLayoutNode {\n /**\n * Construct a new split layout node.\n *\n * @param orientation - The orientation of the node.\n */\n constructor(orientation: Orientation) {\n this.orientation = orientation;\n }\n\n /**\n * The parent of the layout node.\n */\n parent: SplitLayoutNode | null = null;\n\n /**\n * Whether the sizers have been normalized.\n */\n normalized = false;\n\n /**\n * The orientation of the node.\n */\n readonly orientation: Orientation;\n\n /**\n * The child nodes for the split node.\n */\n readonly children: LayoutNode[] = [];\n\n /**\n * The box sizers for the layout children.\n */\n readonly sizers: BoxSizer[] = [];\n\n /**\n * The handles for the layout children.\n */\n readonly handles: HTMLDivElement[] = [];\n\n /**\n * Create an iterator for all widgets in the layout tree.\n */\n *iterAllWidgets(): IterableIterator {\n for (const child of this.children) {\n yield* child.iterAllWidgets();\n }\n }\n\n /**\n * Create an iterator for the user widgets in the layout tree.\n */\n *iterUserWidgets(): IterableIterator {\n for (const child of this.children) {\n yield* child.iterUserWidgets();\n }\n }\n\n /**\n * Create an iterator for the selected widgets in the layout tree.\n */\n *iterSelectedWidgets(): IterableIterator {\n for (const child of this.children) {\n yield* child.iterSelectedWidgets();\n }\n }\n\n /**\n * Create an iterator for the tab bars in the layout tree.\n */\n *iterTabBars(): IterableIterator> {\n for (const child of this.children) {\n yield* child.iterTabBars();\n }\n }\n\n /**\n * Create an iterator for the handles in the layout tree.\n */\n *iterHandles(): IterableIterator {\n yield* this.handles;\n for (const child of this.children) {\n yield* child.iterHandles();\n }\n }\n\n /**\n * Find the tab layout node which contains the given widget.\n */\n findTabNode(widget: Widget): TabLayoutNode | null {\n for (let i = 0, n = this.children.length; i < n; ++i) {\n let result = this.children[i].findTabNode(widget);\n if (result) {\n return result;\n }\n }\n return null;\n }\n\n /**\n * Find the split layout node which contains the given handle.\n */\n findSplitNode(\n handle: HTMLDivElement\n ): { index: number; node: SplitLayoutNode } | null {\n let index = this.handles.indexOf(handle);\n if (index !== -1) {\n return { index, node: this };\n }\n for (let i = 0, n = this.children.length; i < n; ++i) {\n let result = this.children[i].findSplitNode(handle);\n if (result) {\n return result;\n }\n }\n return null;\n }\n\n /**\n * Find the first tab layout node in a layout tree.\n */\n findFirstTabNode(): TabLayoutNode | null {\n if (this.children.length === 0) {\n return null;\n }\n return this.children[0].findFirstTabNode();\n }\n\n /**\n * Find the tab layout node which contains the local point.\n */\n hitTestTabNodes(x: number, y: number): TabLayoutNode | null {\n for (let i = 0, n = this.children.length; i < n; ++i) {\n let result = this.children[i].hitTestTabNodes(x, y);\n if (result) {\n return result;\n }\n }\n return null;\n }\n\n /**\n * Create a configuration object for the layout tree.\n */\n createConfig(): DockLayout.ISplitAreaConfig {\n let orientation = this.orientation;\n let sizes = this.createNormalizedSizes();\n let children = this.children.map(child => child.createConfig());\n return { type: 'split-area', orientation, children, sizes };\n }\n\n /**\n * Sync the visibility and orientation of the handles.\n */\n syncHandles(): void {\n this.handles.forEach((handle, i) => {\n handle.setAttribute('data-orientation', this.orientation);\n if (i === this.handles.length - 1) {\n handle.classList.add('lm-mod-hidden');\n } else {\n handle.classList.remove('lm-mod-hidden');\n }\n });\n }\n\n /**\n * Hold the current sizes of the box sizers.\n *\n * This sets the size hint of each sizer to its current size.\n */\n holdSizes(): void {\n for (const sizer of this.sizers) {\n sizer.sizeHint = sizer.size;\n }\n }\n\n /**\n * Recursively hold all of the sizes in the layout tree.\n *\n * This ignores the sizers of tab layout nodes.\n */\n holdAllSizes(): void {\n for (const child of this.children) {\n child.holdAllSizes();\n }\n this.holdSizes();\n }\n\n /**\n * Normalize the sizes of the split layout node.\n */\n normalizeSizes(): void {\n // Bail early if the sizers are empty.\n let n = this.sizers.length;\n if (n === 0) {\n return;\n }\n\n // Hold the current sizes of the sizers.\n this.holdSizes();\n\n // Compute the sum of the sizes.\n let sum = this.sizers.reduce((v, sizer) => v + sizer.sizeHint, 0);\n\n // Normalize the sizes based on the sum.\n if (sum === 0) {\n for (const sizer of this.sizers) {\n sizer.size = sizer.sizeHint = 1 / n;\n }\n } else {\n for (const sizer of this.sizers) {\n sizer.size = sizer.sizeHint /= sum;\n }\n }\n\n // Mark the sizes as normalized.\n this.normalized = true;\n }\n\n /**\n * Snap the normalized sizes of the split layout node.\n */\n createNormalizedSizes(): number[] {\n // Bail early if the sizers are empty.\n let n = this.sizers.length;\n if (n === 0) {\n return [];\n }\n\n // Grab the current sizes of the sizers.\n let sizes = this.sizers.map(sizer => sizer.size);\n\n // Compute the sum of the sizes.\n let sum = sizes.reduce((v, size) => v + size, 0);\n\n // Normalize the sizes based on the sum.\n if (sum === 0) {\n for (let i = sizes.length - 1; i > -1; i--) {\n sizes[i] = 1 / n;\n }\n } else {\n for (let i = sizes.length - 1; i > -1; i--) {\n sizes[i] /= sum;\n }\n }\n\n // Return the normalized sizes.\n return sizes;\n }\n\n /**\n * Fit the layout tree.\n */\n fit(spacing: number, items: ItemMap): ElementExt.ISizeLimits {\n // Compute the required fixed space.\n let horizontal = this.orientation === 'horizontal';\n let fixed = Math.max(0, this.children.length - 1) * spacing;\n\n // Set up the limit variables.\n let minWidth = horizontal ? fixed : 0;\n let minHeight = horizontal ? 0 : fixed;\n let maxWidth = Infinity;\n let maxHeight = Infinity;\n\n // Fit the children and update the limits.\n for (let i = 0, n = this.children.length; i < n; ++i) {\n let limits = this.children[i].fit(spacing, items);\n if (horizontal) {\n minHeight = Math.max(minHeight, limits.minHeight);\n minWidth += limits.minWidth;\n this.sizers[i].minSize = limits.minWidth;\n } else {\n minWidth = Math.max(minWidth, limits.minWidth);\n minHeight += limits.minHeight;\n this.sizers[i].minSize = limits.minHeight;\n }\n }\n\n // Return the computed limits for the layout node.\n return { minWidth, minHeight, maxWidth, maxHeight };\n }\n\n /**\n * Update the layout tree.\n */\n update(\n left: number,\n top: number,\n width: number,\n height: number,\n spacing: number,\n items: ItemMap\n ): void {\n // Compute the available layout space.\n let horizontal = this.orientation === 'horizontal';\n let fixed = Math.max(0, this.children.length - 1) * spacing;\n let space = Math.max(0, (horizontal ? width : height) - fixed);\n\n // De-normalize the sizes if needed.\n if (this.normalized) {\n for (const sizer of this.sizers) {\n sizer.sizeHint *= space;\n }\n this.normalized = false;\n }\n\n // Distribute the layout space to the sizers.\n BoxEngine.calc(this.sizers, space);\n\n // Update the geometry of the child nodes and handles.\n for (let i = 0, n = this.children.length; i < n; ++i) {\n let child = this.children[i];\n let size = this.sizers[i].size;\n let handleStyle = this.handles[i].style;\n if (horizontal) {\n child.update(left, top, size, height, spacing, items);\n left += size;\n handleStyle.top = `${top}px`;\n handleStyle.left = `${left}px`;\n handleStyle.width = `${spacing}px`;\n handleStyle.height = `${height}px`;\n left += spacing;\n } else {\n child.update(left, top, width, size, spacing, items);\n top += size;\n handleStyle.top = `${top}px`;\n handleStyle.left = `${left}px`;\n handleStyle.width = `${width}px`;\n handleStyle.height = `${spacing}px`;\n top += spacing;\n }\n }\n }\n }\n\n export function addAria(widget: Widget, tabBar: TabBar): void {\n widget.node.setAttribute('role', 'tabpanel');\n let renderer = tabBar.renderer;\n if (renderer instanceof TabBar.Renderer) {\n let tabId = renderer.createTabKey({\n title: widget.title,\n current: false,\n zIndex: 0\n });\n widget.node.setAttribute('aria-labelledby', tabId);\n }\n }\n\n export function removeAria(widget: Widget): void {\n widget.node.removeAttribute('role');\n widget.node.removeAttribute('aria-labelledby');\n }\n\n /**\n * Normalize a tab area config and collect the visited widgets.\n */\n function normalizeTabAreaConfig(\n config: DockLayout.ITabAreaConfig,\n widgetSet: Set\n ): DockLayout.ITabAreaConfig | null {\n // Bail early if there is no content.\n if (config.widgets.length === 0) {\n return null;\n }\n\n // Setup the filtered widgets array.\n let widgets: Widget[] = [];\n\n // Filter the config for unique widgets.\n for (const widget of config.widgets) {\n if (!widgetSet.has(widget)) {\n widgetSet.add(widget);\n widgets.push(widget);\n }\n }\n\n // Bail if there are no effective widgets.\n if (widgets.length === 0) {\n return null;\n }\n\n // Normalize the current index.\n let index = config.currentIndex;\n if (index !== -1 && (index < 0 || index >= widgets.length)) {\n index = 0;\n }\n\n // Return a normalized config object.\n return { type: 'tab-area', widgets, currentIndex: index };\n }\n\n /**\n * Normalize a split area config and collect the visited widgets.\n */\n function normalizeSplitAreaConfig(\n config: DockLayout.ISplitAreaConfig,\n widgetSet: Set\n ): DockLayout.AreaConfig | null {\n // Set up the result variables.\n let orientation = config.orientation;\n let children: DockLayout.AreaConfig[] = [];\n let sizes: number[] = [];\n\n // Normalize the config children.\n for (let i = 0, n = config.children.length; i < n; ++i) {\n // Normalize the child config.\n let child = normalizeAreaConfig(config.children[i], widgetSet);\n\n // Ignore an empty child.\n if (!child) {\n continue;\n }\n\n // Add the child or hoist its content as appropriate.\n if (child.type === 'tab-area' || child.orientation !== orientation) {\n children.push(child);\n sizes.push(Math.abs(config.sizes[i] || 0));\n } else {\n children.push(...child.children);\n sizes.push(...child.sizes);\n }\n }\n\n // Bail if there are no effective children.\n if (children.length === 0) {\n return null;\n }\n\n // If there is only one effective child, return that child.\n if (children.length === 1) {\n return children[0];\n }\n\n // Return a normalized config object.\n return { type: 'split-area', orientation, children, sizes };\n }\n\n /**\n * Convert a normalized tab area config into a layout tree.\n */\n function realizeTabAreaConfig(\n config: DockLayout.ITabAreaConfig,\n renderer: DockLayout.IRenderer,\n document: Document | ShadowRoot\n ): TabLayoutNode {\n // Create the tab bar for the layout node.\n let tabBar = renderer.createTabBar(document);\n\n // Hide each widget and add it to the tab bar.\n for (const widget of config.widgets) {\n widget.hide();\n tabBar.addTab(widget.title);\n Private.addAria(widget, tabBar);\n }\n\n // Set the current index of the tab bar.\n tabBar.currentIndex = config.currentIndex;\n\n // Return the new tab layout node.\n return new TabLayoutNode(tabBar);\n }\n\n /**\n * Convert a normalized split area config into a layout tree.\n */\n function realizeSplitAreaConfig(\n config: DockLayout.ISplitAreaConfig,\n renderer: DockLayout.IRenderer,\n document: Document | ShadowRoot\n ): SplitLayoutNode {\n // Create the split layout node.\n let node = new SplitLayoutNode(config.orientation);\n\n // Add each child to the layout node.\n config.children.forEach((child, i) => {\n // Create the child data for the layout node.\n let childNode = realizeAreaConfig(child, renderer, document);\n let sizer = createSizer(config.sizes[i]);\n let handle = renderer.createHandle();\n\n // Add the child data to the layout node.\n node.children.push(childNode);\n node.handles.push(handle);\n node.sizers.push(sizer);\n\n // Update the parent for the child node.\n childNode.parent = node;\n });\n\n // Synchronize the handle state for the layout node.\n node.syncHandles();\n\n // Normalize the sizes for the layout node.\n node.normalizeSizes();\n\n // Return the new layout node.\n return node;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { find } from '@lumino/algorithm';\n\nimport { MimeData } from '@lumino/coreutils';\n\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ElementExt, Platform } from '@lumino/domutils';\n\nimport { Drag } from '@lumino/dragdrop';\n\nimport { ConflatableMessage, Message, MessageLoop } from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { DockLayout } from './docklayout';\n\nimport { TabBar } from './tabbar';\n\nimport { Widget } from './widget';\n\n/**\n * A widget which provides a flexible docking area for widgets.\n */\nexport class DockPanel extends Widget {\n /**\n * Construct a new dock panel.\n *\n * @param options - The options for initializing the panel.\n */\n constructor(options: DockPanel.IOptions = {}) {\n super();\n this.addClass('lm-DockPanel');\n this._document = options.document || document;\n this._mode = options.mode || 'multiple-document';\n this._renderer = options.renderer || DockPanel.defaultRenderer;\n this._edges = options.edges || Private.DEFAULT_EDGES;\n if (options.tabsMovable !== undefined) {\n this._tabsMovable = options.tabsMovable;\n }\n if (options.tabsConstrained !== undefined) {\n this._tabsConstrained = options.tabsConstrained;\n }\n if (options.addButtonEnabled !== undefined) {\n this._addButtonEnabled = options.addButtonEnabled;\n }\n\n // Toggle the CSS mode attribute.\n this.dataset['mode'] = this._mode;\n\n // Create the delegate renderer for the layout.\n let renderer: DockPanel.IRenderer = {\n createTabBar: () => this._createTabBar(),\n createHandle: () => this._createHandle()\n };\n\n // Set up the dock layout for the panel.\n this.layout = new DockLayout({\n document: this._document,\n renderer,\n spacing: options.spacing,\n hiddenMode: options.hiddenMode\n });\n\n // Set up the overlay drop indicator.\n this.overlay = options.overlay || new DockPanel.Overlay();\n this.node.appendChild(this.overlay.node);\n }\n\n /**\n * Dispose of the resources held by the panel.\n */\n dispose(): void {\n // Ensure the mouse is released.\n this._releaseMouse();\n\n // Hide the overlay.\n this.overlay.hide(0);\n\n // Cancel a drag if one is in progress.\n if (this._drag) {\n this._drag.dispose();\n }\n\n // Dispose of the base class.\n super.dispose();\n }\n\n /**\n * The method for hiding widgets.\n */\n get hiddenMode(): Widget.HiddenMode {\n return (this.layout as DockLayout).hiddenMode;\n }\n\n /**\n * Set the method for hiding widgets.\n */\n set hiddenMode(v: Widget.HiddenMode) {\n (this.layout as DockLayout).hiddenMode = v;\n }\n\n /**\n * A signal emitted when the layout configuration is modified.\n *\n * #### Notes\n * This signal is emitted whenever the current layout configuration\n * may have changed.\n *\n * This signal is emitted asynchronously in a collapsed fashion, so\n * that multiple synchronous modifications results in only a single\n * emit of the signal.\n */\n get layoutModified(): ISignal {\n return this._layoutModified;\n }\n\n /**\n * A signal emitted when the add button on a tab bar is clicked.\n *\n */\n get addRequested(): ISignal> {\n return this._addRequested;\n }\n\n /**\n * The overlay used by the dock panel.\n */\n readonly overlay: DockPanel.IOverlay;\n\n /**\n * The renderer used by the dock panel.\n */\n get renderer(): DockPanel.IRenderer {\n return (this.layout as DockLayout).renderer;\n }\n\n /**\n * Get the spacing between the widgets.\n */\n get spacing(): number {\n return (this.layout as DockLayout).spacing;\n }\n\n /**\n * Set the spacing between the widgets.\n */\n set spacing(value: number) {\n (this.layout as DockLayout).spacing = value;\n }\n\n /**\n * Get the mode for the dock panel.\n */\n get mode(): DockPanel.Mode {\n return this._mode;\n }\n\n /**\n * Set the mode for the dock panel.\n *\n * #### Notes\n * Changing the mode is a destructive operation with respect to the\n * panel's layout configuration. If layout state must be preserved,\n * save the current layout config before changing the mode.\n */\n set mode(value: DockPanel.Mode) {\n // Bail early if the mode does not change.\n if (this._mode === value) {\n return;\n }\n\n // Update the internal mode.\n this._mode = value;\n\n // Toggle the CSS mode attribute.\n this.dataset['mode'] = value;\n\n // Get the layout for the panel.\n let layout = this.layout as DockLayout;\n\n // Configure the layout for the specified mode.\n switch (value) {\n case 'multiple-document':\n for (const tabBar of layout.tabBars()) {\n tabBar.show();\n }\n break;\n case 'single-document':\n layout.restoreLayout(Private.createSingleDocumentConfig(this));\n break;\n default:\n throw 'unreachable';\n }\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Whether the tabs can be dragged / moved at runtime.\n */\n get tabsMovable(): boolean {\n return this._tabsMovable;\n }\n\n /**\n * Enable / Disable draggable / movable tabs.\n */\n set tabsMovable(value: boolean) {\n this._tabsMovable = value;\n for (const tabBar of this.tabBars()) {\n tabBar.tabsMovable = value;\n }\n }\n\n /**\n * Whether the tabs are constrained to their source dock panel\n */\n get tabsConstrained(): boolean {\n return this._tabsConstrained;\n }\n\n /**\n * Constrain/Allow tabs to be dragged outside of this dock panel\n */\n set tabsConstrained(value: boolean) {\n this._tabsConstrained = value;\n }\n\n /**\n * Whether the add buttons for each tab bar are enabled.\n */\n get addButtonEnabled(): boolean {\n return this._addButtonEnabled;\n }\n\n /**\n * Set whether the add buttons for each tab bar are enabled.\n */\n set addButtonEnabled(value: boolean) {\n this._addButtonEnabled = value;\n for (const tabBar of this.tabBars()) {\n tabBar.addButtonEnabled = value;\n }\n }\n\n /**\n * Whether the dock panel is empty.\n */\n get isEmpty(): boolean {\n return (this.layout as DockLayout).isEmpty;\n }\n\n /**\n * Create an iterator over the user widgets in the panel.\n *\n * @returns A new iterator over the user widgets in the panel.\n *\n * #### Notes\n * This iterator does not include the generated tab bars.\n */\n *widgets(): IterableIterator {\n yield* (this.layout as DockLayout).widgets();\n }\n\n /**\n * Create an iterator over the selected widgets in the panel.\n *\n * @returns A new iterator over the selected user widgets.\n *\n * #### Notes\n * This iterator yields the widgets corresponding to the current tab\n * of each tab bar in the panel.\n */\n *selectedWidgets(): IterableIterator {\n yield* (this.layout as DockLayout).selectedWidgets();\n }\n\n /**\n * Create an iterator over the tab bars in the panel.\n *\n * @returns A new iterator over the tab bars in the panel.\n *\n * #### Notes\n * This iterator does not include the user widgets.\n */\n *tabBars(): IterableIterator> {\n yield* (this.layout as DockLayout).tabBars();\n }\n\n /**\n * Create an iterator over the handles in the panel.\n *\n * @returns A new iterator over the handles in the panel.\n */\n *handles(): IterableIterator {\n yield* (this.layout as DockLayout).handles();\n }\n\n /**\n * Select a specific widget in the dock panel.\n *\n * @param widget - The widget of interest.\n *\n * #### Notes\n * This will make the widget the current widget in its tab area.\n */\n selectWidget(widget: Widget): void {\n // Find the tab bar which contains the widget.\n let tabBar = find(this.tabBars(), bar => {\n return bar.titles.indexOf(widget.title) !== -1;\n });\n\n // Throw an error if no tab bar is found.\n if (!tabBar) {\n throw new Error('Widget is not contained in the dock panel.');\n }\n\n // Ensure the widget is the current widget.\n tabBar.currentTitle = widget.title;\n }\n\n /**\n * Activate a specified widget in the dock panel.\n *\n * @param widget - The widget of interest.\n *\n * #### Notes\n * This will select and activate the given widget.\n */\n activateWidget(widget: Widget): void {\n this.selectWidget(widget);\n widget.activate();\n }\n\n /**\n * Save the current layout configuration of the dock panel.\n *\n * @returns A new config object for the current layout state.\n *\n * #### Notes\n * The return value can be provided to the `restoreLayout` method\n * in order to restore the layout to its current configuration.\n */\n saveLayout(): DockPanel.ILayoutConfig {\n return (this.layout as DockLayout).saveLayout();\n }\n\n /**\n * Restore the layout to a previously saved configuration.\n *\n * @param config - The layout configuration to restore.\n *\n * #### Notes\n * Widgets which currently belong to the layout but which are not\n * contained in the config will be unparented.\n *\n * The dock panel automatically reverts to `'multiple-document'`\n * mode when a layout config is restored.\n */\n restoreLayout(config: DockPanel.ILayoutConfig): void {\n // Reset the mode.\n this._mode = 'multiple-document';\n\n // Restore the layout.\n (this.layout as DockLayout).restoreLayout(config);\n\n // Flush the message loop on IE and Edge to prevent flicker.\n if (Platform.IS_EDGE || Platform.IS_IE) {\n MessageLoop.flush();\n }\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Add a widget to the dock panel.\n *\n * @param widget - The widget to add to the dock panel.\n *\n * @param options - The additional options for adding the widget.\n *\n * #### Notes\n * If the panel is in single document mode, the options are ignored\n * and the widget is always added as tab in the hidden tab bar.\n */\n addWidget(widget: Widget, options: DockPanel.IAddOptions = {}): void {\n // Add the widget to the layout.\n if (this._mode === 'single-document') {\n (this.layout as DockLayout).addWidget(widget);\n } else {\n (this.layout as DockLayout).addWidget(widget, options);\n }\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Process a message sent to the widget.\n *\n * @param msg - The message sent to the widget.\n */\n processMessage(msg: Message): void {\n if (msg.type === 'layout-modified') {\n this._layoutModified.emit(undefined);\n } else {\n super.processMessage(msg);\n }\n }\n\n /**\n * Handle the DOM events for the dock panel.\n *\n * @param event - The DOM event sent to the panel.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the panel's DOM node. It should\n * not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'lm-dragenter':\n this._evtDragEnter(event as Drag.Event);\n break;\n case 'lm-dragleave':\n this._evtDragLeave(event as Drag.Event);\n break;\n case 'lm-dragover':\n this._evtDragOver(event as Drag.Event);\n break;\n case 'lm-drop':\n this._evtDrop(event as Drag.Event);\n break;\n case 'pointerdown':\n this._evtPointerDown(event as PointerEvent);\n break;\n case 'pointermove':\n this._evtPointerMove(event as PointerEvent);\n break;\n case 'pointerup':\n this._evtPointerUp(event as PointerEvent);\n break;\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('lm-dragenter', this);\n this.node.addEventListener('lm-dragleave', this);\n this.node.addEventListener('lm-dragover', this);\n this.node.addEventListener('lm-drop', this);\n this.node.addEventListener('pointerdown', this);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('lm-dragenter', this);\n this.node.removeEventListener('lm-dragleave', this);\n this.node.removeEventListener('lm-dragover', this);\n this.node.removeEventListener('lm-drop', this);\n this.node.removeEventListener('pointerdown', this);\n this._releaseMouse();\n }\n\n /**\n * A message handler invoked on a `'child-added'` message.\n */\n protected onChildAdded(msg: Widget.ChildMessage): void {\n // Ignore the generated tab bars.\n if (Private.isGeneratedTabBarProperty.get(msg.child)) {\n return;\n }\n\n // Add the widget class to the child.\n msg.child.addClass('lm-DockPanel-widget');\n }\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {\n // Ignore the generated tab bars.\n if (Private.isGeneratedTabBarProperty.get(msg.child)) {\n return;\n }\n\n // Remove the widget class from the child.\n msg.child.removeClass('lm-DockPanel-widget');\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Handle the `'lm-dragenter'` event for the dock panel.\n */\n private _evtDragEnter(event: Drag.Event): void {\n // If the factory mime type is present, mark the event as\n // handled in order to get the rest of the drag events.\n if (event.mimeData.hasData('application/vnd.lumino.widget-factory')) {\n event.preventDefault();\n event.stopPropagation();\n }\n }\n\n /**\n * Handle the `'lm-dragleave'` event for the dock panel.\n */\n private _evtDragLeave(event: Drag.Event): void {\n // Mark the event as handled.\n event.preventDefault();\n\n if (this._tabsConstrained && event.source !== this) return;\n\n event.stopPropagation();\n\n // The new target might be a descendant, so we might still handle the drop.\n // Hide asynchronously so that if a lm-dragover event bubbles up to us, the\n // hide is cancelled by the lm-dragover handler's show overlay logic.\n this.overlay.hide(1);\n }\n\n /**\n * Handle the `'lm-dragover'` event for the dock panel.\n */\n private _evtDragOver(event: Drag.Event): void {\n // Mark the event as handled.\n event.preventDefault();\n\n // Show the drop indicator overlay and update the drop\n // action based on the drop target zone under the mouse.\n if (\n (this._tabsConstrained && event.source !== this) ||\n this._showOverlay(event.clientX, event.clientY) === 'invalid'\n ) {\n event.dropAction = 'none';\n } else {\n event.stopPropagation();\n event.dropAction = event.proposedAction;\n }\n }\n\n /**\n * Handle the `'lm-drop'` event for the dock panel.\n */\n private _evtDrop(event: Drag.Event): void {\n // Mark the event as handled.\n event.preventDefault();\n\n // Hide the drop indicator overlay.\n this.overlay.hide(0);\n\n // Bail if the proposed action is to do nothing.\n if (event.proposedAction === 'none') {\n event.dropAction = 'none';\n return;\n }\n\n // Find the drop target under the mouse.\n let { clientX, clientY } = event;\n let { zone, target } = Private.findDropTarget(\n this,\n clientX,\n clientY,\n this._edges\n );\n\n // Bail if the drop zone is invalid.\n if (\n (this._tabsConstrained && event.source !== this) ||\n zone === 'invalid'\n ) {\n event.dropAction = 'none';\n return;\n }\n\n // Bail if the factory mime type has invalid data.\n let mimeData = event.mimeData;\n let factory = mimeData.getData('application/vnd.lumino.widget-factory');\n if (typeof factory !== 'function') {\n event.dropAction = 'none';\n return;\n }\n\n // Bail if the factory does not produce a widget.\n let widget = factory();\n if (!(widget instanceof Widget)) {\n event.dropAction = 'none';\n return;\n }\n\n // Bail if the widget is an ancestor of the dock panel.\n if (widget.contains(this)) {\n event.dropAction = 'none';\n return;\n }\n\n // Find the reference widget for the drop target.\n let ref = target ? Private.getDropRef(target.tabBar) : null;\n\n // Add the widget according to the indicated drop zone.\n switch (zone) {\n case 'root-all':\n this.addWidget(widget);\n break;\n case 'root-top':\n this.addWidget(widget, { mode: 'split-top' });\n break;\n case 'root-left':\n this.addWidget(widget, { mode: 'split-left' });\n break;\n case 'root-right':\n this.addWidget(widget, { mode: 'split-right' });\n break;\n case 'root-bottom':\n this.addWidget(widget, { mode: 'split-bottom' });\n break;\n case 'widget-all':\n this.addWidget(widget, { mode: 'tab-after', ref });\n break;\n case 'widget-top':\n this.addWidget(widget, { mode: 'split-top', ref });\n break;\n case 'widget-left':\n this.addWidget(widget, { mode: 'split-left', ref });\n break;\n case 'widget-right':\n this.addWidget(widget, { mode: 'split-right', ref });\n break;\n case 'widget-bottom':\n this.addWidget(widget, { mode: 'split-bottom', ref });\n break;\n case 'widget-tab':\n this.addWidget(widget, { mode: 'tab-after', ref });\n break;\n default:\n throw 'unreachable';\n }\n\n // Accept the proposed drop action.\n event.dropAction = event.proposedAction;\n\n // Stop propagation if we have not bailed so far.\n event.stopPropagation();\n\n // Activate the dropped widget.\n this.activateWidget(widget);\n }\n\n /**\n * Handle the `'keydown'` event for the dock panel.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // Stop input events during drag.\n event.preventDefault();\n event.stopPropagation();\n\n // Release the mouse if `Escape` is pressed.\n if (event.keyCode === 27) {\n // Finalize the mouse release.\n this._releaseMouse();\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n }\n\n /**\n * Handle the `'pointerdown'` event for the dock panel.\n */\n private _evtPointerDown(event: PointerEvent): void {\n // Do nothing if the left mouse button is not pressed.\n if (event.button !== 0) {\n return;\n }\n\n // Find the handle which contains the mouse target, if any.\n let layout = this.layout as DockLayout;\n let target = event.target as HTMLElement;\n let handle = find(layout.handles(), handle => handle.contains(target));\n if (!handle) {\n return;\n }\n\n // Stop the event when a handle is pressed.\n event.preventDefault();\n event.stopPropagation();\n\n // Add the extra document listeners.\n this._document.addEventListener('keydown', this, true);\n this._document.addEventListener('pointerup', this, true);\n this._document.addEventListener('pointermove', this, true);\n this._document.addEventListener('contextmenu', this, true);\n\n // Compute the offset deltas for the handle press.\n let rect = handle.getBoundingClientRect();\n let deltaX = event.clientX - rect.left;\n let deltaY = event.clientY - rect.top;\n\n // Override the cursor and store the press data.\n let style = window.getComputedStyle(handle);\n let override = Drag.overrideCursor(style.cursor!, this._document);\n this._pressData = { handle, deltaX, deltaY, override };\n }\n\n /**\n * Handle the `'pointermove'` event for the dock panel.\n */\n private _evtPointerMove(event: PointerEvent): void {\n // Bail early if no drag is in progress.\n if (!this._pressData) {\n return;\n }\n\n // Stop the event when dragging a handle.\n event.preventDefault();\n event.stopPropagation();\n\n // Compute the desired offset position for the handle.\n let rect = this.node.getBoundingClientRect();\n let xPos = event.clientX - rect.left - this._pressData.deltaX;\n let yPos = event.clientY - rect.top - this._pressData.deltaY;\n\n // Set the handle as close to the desired position as possible.\n let layout = this.layout as DockLayout;\n layout.moveHandle(this._pressData.handle, xPos, yPos);\n }\n\n /**\n * Handle the `'pointerup'` event for the dock panel.\n */\n private _evtPointerUp(event: PointerEvent): void {\n // Do nothing if the left mouse button is not released.\n if (event.button !== 0) {\n return;\n }\n\n // Stop the event when releasing a handle.\n event.preventDefault();\n event.stopPropagation();\n\n // Finalize the mouse release.\n this._releaseMouse();\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Release the mouse grab for the dock panel.\n */\n private _releaseMouse(): void {\n // Bail early if no drag is in progress.\n if (!this._pressData) {\n return;\n }\n\n // Clear the override cursor.\n this._pressData.override.dispose();\n this._pressData = null;\n\n // Remove the extra document listeners.\n this._document.removeEventListener('keydown', this, true);\n this._document.removeEventListener('pointerup', this, true);\n this._document.removeEventListener('pointermove', this, true);\n this._document.removeEventListener('contextmenu', this, true);\n }\n\n /**\n * Show the overlay indicator at the given client position.\n *\n * Returns the drop zone at the specified client position.\n *\n * #### Notes\n * If the position is not over a valid zone, the overlay is hidden.\n */\n private _showOverlay(clientX: number, clientY: number): Private.DropZone {\n // Find the dock target for the given client position.\n let { zone, target } = Private.findDropTarget(\n this,\n clientX,\n clientY,\n this._edges\n );\n\n // If the drop zone is invalid, hide the overlay and bail.\n if (zone === 'invalid') {\n this.overlay.hide(100);\n return zone;\n }\n\n // Setup the variables needed to compute the overlay geometry.\n let top: number;\n let left: number;\n let right: number;\n let bottom: number;\n let box = ElementExt.boxSizing(this.node); // TODO cache this?\n let rect = this.node.getBoundingClientRect();\n\n // Compute the overlay geometry based on the dock zone.\n switch (zone) {\n case 'root-all':\n top = box.paddingTop;\n left = box.paddingLeft;\n right = box.paddingRight;\n bottom = box.paddingBottom;\n break;\n case 'root-top':\n top = box.paddingTop;\n left = box.paddingLeft;\n right = box.paddingRight;\n bottom = rect.height * Private.GOLDEN_RATIO;\n break;\n case 'root-left':\n top = box.paddingTop;\n left = box.paddingLeft;\n right = rect.width * Private.GOLDEN_RATIO;\n bottom = box.paddingBottom;\n break;\n case 'root-right':\n top = box.paddingTop;\n left = rect.width * Private.GOLDEN_RATIO;\n right = box.paddingRight;\n bottom = box.paddingBottom;\n break;\n case 'root-bottom':\n top = rect.height * Private.GOLDEN_RATIO;\n left = box.paddingLeft;\n right = box.paddingRight;\n bottom = box.paddingBottom;\n break;\n case 'widget-all':\n top = target!.top;\n left = target!.left;\n right = target!.right;\n bottom = target!.bottom;\n break;\n case 'widget-top':\n top = target!.top;\n left = target!.left;\n right = target!.right;\n bottom = target!.bottom + target!.height / 2;\n break;\n case 'widget-left':\n top = target!.top;\n left = target!.left;\n right = target!.right + target!.width / 2;\n bottom = target!.bottom;\n break;\n case 'widget-right':\n top = target!.top;\n left = target!.left + target!.width / 2;\n right = target!.right;\n bottom = target!.bottom;\n break;\n case 'widget-bottom':\n top = target!.top + target!.height / 2;\n left = target!.left;\n right = target!.right;\n bottom = target!.bottom;\n break;\n case 'widget-tab': {\n const tabHeight = target!.tabBar.node.getBoundingClientRect().height;\n top = target!.top;\n left = target!.left;\n right = target!.right;\n bottom = target!.bottom + target!.height - tabHeight;\n break;\n }\n default:\n throw 'unreachable';\n }\n\n // Show the overlay with the computed geometry.\n this.overlay.show({ top, left, right, bottom });\n\n // Finally, return the computed drop zone.\n return zone;\n }\n\n /**\n * Create a new tab bar for use by the panel.\n */\n private _createTabBar(): TabBar {\n // Create the tab bar.\n let tabBar = this._renderer.createTabBar(this._document);\n\n // Set the generated tab bar property for the tab bar.\n Private.isGeneratedTabBarProperty.set(tabBar, true);\n\n // Hide the tab bar when in single document mode.\n if (this._mode === 'single-document') {\n tabBar.hide();\n }\n\n // Enforce necessary tab bar behavior.\n // TODO do we really want to enforce *all* of these?\n tabBar.tabsMovable = this._tabsMovable;\n tabBar.allowDeselect = false;\n tabBar.addButtonEnabled = this._addButtonEnabled;\n tabBar.removeBehavior = 'select-previous-tab';\n tabBar.insertBehavior = 'select-tab-if-needed';\n\n // Connect the signal handlers for the tab bar.\n tabBar.tabMoved.connect(this._onTabMoved, this);\n tabBar.currentChanged.connect(this._onCurrentChanged, this);\n tabBar.tabCloseRequested.connect(this._onTabCloseRequested, this);\n tabBar.tabDetachRequested.connect(this._onTabDetachRequested, this);\n tabBar.tabActivateRequested.connect(this._onTabActivateRequested, this);\n tabBar.addRequested.connect(this._onTabAddRequested, this);\n\n // Return the initialized tab bar.\n return tabBar;\n }\n\n /**\n * Create a new handle for use by the panel.\n */\n private _createHandle(): HTMLDivElement {\n return this._renderer.createHandle();\n }\n\n /**\n * Handle the `tabMoved` signal from a tab bar.\n */\n private _onTabMoved(): void {\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Handle the `currentChanged` signal from a tab bar.\n */\n private _onCurrentChanged(\n sender: TabBar,\n args: TabBar.ICurrentChangedArgs\n ): void {\n // Extract the previous and current title from the args.\n let { previousTitle, currentTitle } = args;\n\n // Hide the previous widget.\n if (previousTitle) {\n previousTitle.owner.hide();\n }\n\n // Show the current widget.\n if (currentTitle) {\n currentTitle.owner.show();\n }\n\n // Flush the message loop on IE and Edge to prevent flicker.\n if (Platform.IS_EDGE || Platform.IS_IE) {\n MessageLoop.flush();\n }\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Handle the `addRequested` signal from a tab bar.\n */\n private _onTabAddRequested(sender: TabBar): void {\n this._addRequested.emit(sender);\n }\n\n /**\n * Handle the `tabActivateRequested` signal from a tab bar.\n */\n private _onTabActivateRequested(\n sender: TabBar,\n args: TabBar.ITabActivateRequestedArgs\n ): void {\n args.title.owner.activate();\n }\n\n /**\n * Handle the `tabCloseRequested` signal from a tab bar.\n */\n private _onTabCloseRequested(\n sender: TabBar,\n args: TabBar.ITabCloseRequestedArgs\n ): void {\n args.title.owner.close();\n }\n\n /**\n * Handle the `tabDetachRequested` signal from a tab bar.\n */\n private _onTabDetachRequested(\n sender: TabBar,\n args: TabBar.ITabDetachRequestedArgs\n ): void {\n // Do nothing if a drag is already in progress.\n if (this._drag) {\n return;\n }\n\n // Release the tab bar's hold on the mouse.\n sender.releaseMouse();\n\n // Extract the data from the args.\n let { title, tab, clientX, clientY, offset } = args;\n\n // Setup the mime data for the drag operation.\n let mimeData = new MimeData();\n let factory = () => title.owner;\n mimeData.setData('application/vnd.lumino.widget-factory', factory);\n\n // Create the drag image for the drag operation.\n let dragImage = tab.cloneNode(true) as HTMLElement;\n if (offset) {\n dragImage.style.top = `-${offset.y}px`;\n dragImage.style.left = `-${offset.x}px`;\n }\n\n // Create the drag object to manage the drag-drop operation.\n this._drag = new Drag({\n document: this._document,\n mimeData,\n dragImage,\n proposedAction: 'move',\n supportedActions: 'move',\n source: this\n });\n\n // Hide the tab node in the original tab.\n tab.classList.add('lm-mod-hidden');\n let cleanup = () => {\n this._drag = null;\n tab.classList.remove('lm-mod-hidden');\n };\n\n // Start the drag operation and cleanup when done.\n this._drag.start(clientX, clientY).then(cleanup);\n }\n\n private _edges: DockPanel.IEdges;\n private _document: Document | ShadowRoot;\n private _mode: DockPanel.Mode;\n private _drag: Drag | null = null;\n private _renderer: DockPanel.IRenderer;\n private _tabsMovable: boolean = true;\n private _tabsConstrained: boolean = false;\n private _addButtonEnabled: boolean = false;\n private _pressData: Private.IPressData | null = null;\n private _layoutModified = new Signal(this);\n\n private _addRequested = new Signal>(this);\n}\n\n/**\n * The namespace for the `DockPanel` class statics.\n */\nexport namespace DockPanel {\n /**\n * An options object for creating a dock panel.\n */\n export interface IOptions {\n /**\n * The document to use with the dock panel.\n *\n * The default is the global `document` instance.\n */\n\n document?: Document | ShadowRoot;\n /**\n * The overlay to use with the dock panel.\n *\n * The default is a new `Overlay` instance.\n */\n overlay?: IOverlay;\n\n /**\n * The renderer to use for the dock panel.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n\n /**\n * The spacing between the items in the panel.\n *\n * The default is `4`.\n */\n spacing?: number;\n\n /**\n * The mode for the dock panel.\n *\n * The default is `'multiple-document'`.\n */\n mode?: DockPanel.Mode;\n\n /**\n * The sizes of the edge drop zones, in pixels.\n * If not given, default values will be used.\n */\n edges?: IEdges;\n\n /**\n * The method for hiding widgets.\n *\n * The default is `Widget.HiddenMode.Display`.\n */\n hiddenMode?: Widget.HiddenMode;\n\n /**\n * Allow tabs to be draggable / movable by user.\n *\n * The default is `'true'`.\n */\n tabsMovable?: boolean;\n\n /**\n * Constrain tabs to this dock panel\n *\n * The default is `'false'`.\n */\n tabsConstrained?: boolean;\n\n /**\n * Enable add buttons in each of the dock panel's tab bars.\n *\n * The default is `'false'`.\n */\n addButtonEnabled?: boolean;\n }\n\n /**\n * The sizes of the edge drop zones, in pixels.\n */\n export interface IEdges {\n /**\n * The size of the top edge drop zone.\n */\n top: number;\n\n /**\n * The size of the right edge drop zone.\n */\n right: number;\n\n /**\n * The size of the bottom edge drop zone.\n */\n bottom: number;\n\n /**\n * The size of the left edge drop zone.\n */\n left: number;\n }\n\n /**\n * A type alias for the supported dock panel modes.\n */\n export type Mode =\n | /**\n * The single document mode.\n *\n * In this mode, only a single widget is visible at a time, and that\n * widget fills the available layout space. No tab bars are visible.\n */\n 'single-document'\n\n /**\n * The multiple document mode.\n *\n * In this mode, multiple documents are displayed in separate tab\n * areas, and those areas can be individually resized by the user.\n */\n | 'multiple-document';\n\n /**\n * A type alias for a layout configuration object.\n */\n export type ILayoutConfig = DockLayout.ILayoutConfig;\n\n /**\n * A type alias for the supported insertion modes.\n */\n export type InsertMode = DockLayout.InsertMode;\n\n /**\n * A type alias for the add widget options.\n */\n export type IAddOptions = DockLayout.IAddOptions;\n\n /**\n * An object which holds the geometry for overlay positioning.\n */\n export interface IOverlayGeometry {\n /**\n * The distance between the overlay and parent top edges.\n */\n top: number;\n\n /**\n * The distance between the overlay and parent left edges.\n */\n left: number;\n\n /**\n * The distance between the overlay and parent right edges.\n */\n right: number;\n\n /**\n * The distance between the overlay and parent bottom edges.\n */\n bottom: number;\n }\n\n /**\n * An object which manages the overlay node for a dock panel.\n */\n export interface IOverlay {\n /**\n * The DOM node for the overlay.\n */\n readonly node: HTMLDivElement;\n\n /**\n * Show the overlay using the given overlay geometry.\n *\n * @param geo - The desired geometry for the overlay.\n *\n * #### Notes\n * The given geometry values assume the node will use absolute\n * positioning.\n *\n * This is called on every mouse move event during a drag in order\n * to update the position of the overlay. It should be efficient.\n */\n show(geo: IOverlayGeometry): void;\n\n /**\n * Hide the overlay node.\n *\n * @param delay - The delay (in ms) before hiding the overlay.\n * A delay value <= 0 should hide the overlay immediately.\n *\n * #### Notes\n * This is called whenever the overlay node should been hidden.\n */\n hide(delay: number): void;\n }\n\n /**\n * A concrete implementation of `IOverlay`.\n *\n * This is the default overlay implementation for a dock panel.\n */\n export class Overlay implements IOverlay {\n /**\n * Construct a new overlay.\n */\n constructor() {\n this.node = document.createElement('div');\n this.node.classList.add('lm-DockPanel-overlay');\n this.node.classList.add('lm-mod-hidden');\n this.node.style.position = 'absolute';\n this.node.style.contain = 'strict';\n }\n\n /**\n * The DOM node for the overlay.\n */\n readonly node: HTMLDivElement;\n\n /**\n * Show the overlay using the given overlay geometry.\n *\n * @param geo - The desired geometry for the overlay.\n */\n show(geo: IOverlayGeometry): void {\n // Update the position of the overlay.\n let style = this.node.style;\n style.top = `${geo.top}px`;\n style.left = `${geo.left}px`;\n style.right = `${geo.right}px`;\n style.bottom = `${geo.bottom}px`;\n\n // Clear any pending hide timer.\n clearTimeout(this._timer);\n this._timer = -1;\n\n // If the overlay is already visible, we're done.\n if (!this._hidden) {\n return;\n }\n\n // Clear the hidden flag.\n this._hidden = false;\n\n // Finally, show the overlay.\n this.node.classList.remove('lm-mod-hidden');\n }\n\n /**\n * Hide the overlay node.\n *\n * @param delay - The delay (in ms) before hiding the overlay.\n * A delay value <= 0 will hide the overlay immediately.\n */\n hide(delay: number): void {\n // Do nothing if the overlay is already hidden.\n if (this._hidden) {\n return;\n }\n\n // Hide immediately if the delay is <= 0.\n if (delay <= 0) {\n clearTimeout(this._timer);\n this._timer = -1;\n this._hidden = true;\n this.node.classList.add('lm-mod-hidden');\n return;\n }\n\n // Do nothing if a hide is already pending.\n if (this._timer !== -1) {\n return;\n }\n\n // Otherwise setup the hide timer.\n this._timer = window.setTimeout(() => {\n this._timer = -1;\n this._hidden = true;\n this.node.classList.add('lm-mod-hidden');\n }, delay);\n }\n\n private _timer = -1;\n private _hidden = true;\n }\n\n /**\n * A type alias for a dock panel renderer;\n */\n export type IRenderer = DockLayout.IRenderer;\n\n /**\n * The default implementation of `IRenderer`.\n */\n export class Renderer implements IRenderer {\n /**\n * Create a new tab bar for use with a dock panel.\n *\n * @returns A new tab bar for a dock panel.\n */\n createTabBar(document?: Document | ShadowRoot): TabBar {\n let bar = new TabBar({ document });\n bar.addClass('lm-DockPanel-tabBar');\n return bar;\n }\n\n /**\n * Create a new handle node for use with a dock panel.\n *\n * @returns A new handle node for a dock panel.\n */\n createHandle(): HTMLDivElement {\n let handle = document.createElement('div');\n handle.className = 'lm-DockPanel-handle';\n return handle;\n }\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * A fraction used for sizing root panels; ~= `1 / golden_ratio`.\n */\n export const GOLDEN_RATIO = 0.618;\n\n /**\n * The default sizes for the edge drop zones, in pixels.\n */\n export const DEFAULT_EDGES = {\n /**\n * The size of the top edge dock zone for the root panel, in pixels.\n * This is different from the others to distinguish between the top\n * tab bar and the top root zone.\n */\n top: 12,\n\n /**\n * The size of the edge dock zone for the root panel, in pixels.\n */\n right: 40,\n\n /**\n * The size of the edge dock zone for the root panel, in pixels.\n */\n bottom: 40,\n\n /**\n * The size of the edge dock zone for the root panel, in pixels.\n */\n left: 40\n };\n\n /**\n * A singleton `'layout-modified'` conflatable message.\n */\n export const LayoutModified = new ConflatableMessage('layout-modified');\n\n /**\n * An object which holds mouse press data.\n */\n export interface IPressData {\n /**\n * The handle which was pressed.\n */\n handle: HTMLDivElement;\n\n /**\n * The X offset of the press in handle coordinates.\n */\n deltaX: number;\n\n /**\n * The Y offset of the press in handle coordinates.\n */\n deltaY: number;\n\n /**\n * The disposable which will clear the override cursor.\n */\n override: IDisposable;\n }\n\n /**\n * A type alias for a drop zone.\n */\n export type DropZone =\n | /**\n * An invalid drop zone.\n */\n 'invalid'\n\n /**\n * The entirety of the root dock area.\n */\n | 'root-all'\n\n /**\n * The top portion of the root dock area.\n */\n | 'root-top'\n\n /**\n * The left portion of the root dock area.\n */\n | 'root-left'\n\n /**\n * The right portion of the root dock area.\n */\n | 'root-right'\n\n /**\n * The bottom portion of the root dock area.\n */\n | 'root-bottom'\n\n /**\n * The entirety of a tabbed widget area.\n */\n | 'widget-all'\n\n /**\n * The top portion of tabbed widget area.\n */\n | 'widget-top'\n\n /**\n * The left portion of tabbed widget area.\n */\n | 'widget-left'\n\n /**\n * The right portion of tabbed widget area.\n */\n | 'widget-right'\n\n /**\n * The bottom portion of tabbed widget area.\n */\n | 'widget-bottom'\n\n /**\n * The the bar of a tabbed widget area.\n */\n | 'widget-tab';\n\n /**\n * An object which holds the drop target zone and widget.\n */\n export interface IDropTarget {\n /**\n * The semantic zone for the mouse position.\n */\n zone: DropZone;\n\n /**\n * The tab area geometry for the drop zone, or `null`.\n */\n target: DockLayout.ITabAreaGeometry | null;\n }\n\n /**\n * An attached property used to track generated tab bars.\n */\n export const isGeneratedTabBarProperty = new AttachedProperty<\n Widget,\n boolean\n >({\n name: 'isGeneratedTabBar',\n create: () => false\n });\n\n /**\n * Create a single document config for the widgets in a dock panel.\n */\n export function createSingleDocumentConfig(\n panel: DockPanel\n ): DockPanel.ILayoutConfig {\n // Return an empty config if the panel is empty.\n if (panel.isEmpty) {\n return { main: null };\n }\n\n // Get a flat array of the widgets in the panel.\n let widgets = Array.from(panel.widgets());\n\n // Get the first selected widget in the panel.\n let selected = panel.selectedWidgets().next().value;\n\n // Compute the current index for the new config.\n let currentIndex = selected ? widgets.indexOf(selected) : -1;\n\n // Return the single document config.\n return { main: { type: 'tab-area', widgets, currentIndex } };\n }\n\n /**\n * Find the drop target at the given client position.\n */\n export function findDropTarget(\n panel: DockPanel,\n clientX: number,\n clientY: number,\n edges: DockPanel.IEdges\n ): IDropTarget {\n // Bail if the mouse is not over the dock panel.\n if (!ElementExt.hitTest(panel.node, clientX, clientY)) {\n return { zone: 'invalid', target: null };\n }\n\n // Look up the layout for the panel.\n let layout = panel.layout as DockLayout;\n\n // If the layout is empty, indicate the entire root drop zone.\n if (layout.isEmpty) {\n return { zone: 'root-all', target: null };\n }\n\n // Test the edge zones when in multiple document mode.\n if (panel.mode === 'multiple-document') {\n // Get the client rect for the dock panel.\n let panelRect = panel.node.getBoundingClientRect();\n\n // Compute the distance to each edge of the panel.\n let pl = clientX - panelRect.left + 1;\n let pt = clientY - panelRect.top + 1;\n let pr = panelRect.right - clientX;\n let pb = panelRect.bottom - clientY;\n\n // Find the minimum distance to an edge.\n let pd = Math.min(pt, pr, pb, pl);\n\n // Return a root zone if the mouse is within an edge.\n switch (pd) {\n case pt:\n if (pt < edges.top) {\n return { zone: 'root-top', target: null };\n }\n break;\n case pr:\n if (pr < edges.right) {\n return { zone: 'root-right', target: null };\n }\n break;\n case pb:\n if (pb < edges.bottom) {\n return { zone: 'root-bottom', target: null };\n }\n break;\n case pl:\n if (pl < edges.left) {\n return { zone: 'root-left', target: null };\n }\n break;\n default:\n throw 'unreachable';\n }\n }\n\n // Hit test the dock layout at the given client position.\n let target = layout.hitTestTabAreas(clientX, clientY);\n\n // Bail if no target area was found.\n if (!target) {\n return { zone: 'invalid', target: null };\n }\n\n // Return the whole tab area when in single document mode.\n if (panel.mode === 'single-document') {\n return { zone: 'widget-all', target };\n }\n\n // Compute the distance to each edge of the tab area.\n let al = target.x - target.left + 1;\n let at = target.y - target.top + 1;\n let ar = target.left + target.width - target.x;\n let ab = target.top + target.height - target.y;\n\n const tabHeight = target.tabBar.node.getBoundingClientRect().height;\n if (at < tabHeight) {\n return { zone: 'widget-tab', target };\n }\n\n // Get the X and Y edge sizes for the area.\n let rx = Math.round(target.width / 3);\n let ry = Math.round(target.height / 3);\n\n // If the mouse is not within an edge, indicate the entire area.\n if (al > rx && ar > rx && at > ry && ab > ry) {\n return { zone: 'widget-all', target };\n }\n\n // Scale the distances by the slenderness ratio.\n al /= rx;\n at /= ry;\n ar /= rx;\n ab /= ry;\n\n // Find the minimum distance to the area edge.\n let ad = Math.min(al, at, ar, ab);\n\n // Find the widget zone for the area edge.\n let zone: DropZone;\n switch (ad) {\n case al:\n zone = 'widget-left';\n break;\n case at:\n zone = 'widget-top';\n break;\n case ar:\n zone = 'widget-right';\n break;\n case ab:\n zone = 'widget-bottom';\n break;\n default:\n throw 'unreachable';\n }\n\n // Return the final drop target.\n return { zone, target };\n }\n\n /**\n * Get the drop reference widget for a tab bar.\n */\n export function getDropRef(tabBar: TabBar): Widget | null {\n if (tabBar.titles.length === 0) {\n return null;\n }\n if (tabBar.currentTitle) {\n return tabBar.currentTitle.owner;\n }\n return tabBar.titles[tabBar.titles.length - 1].owner;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt, find, max } from '@lumino/algorithm';\n\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { Widget } from './widget';\n\n/**\n * A class which tracks focus among a set of widgets.\n *\n * This class is useful when code needs to keep track of the most\n * recently focused widget(s) among a set of related widgets.\n */\nexport class FocusTracker implements IDisposable {\n /**\n * Dispose of the resources held by the tracker.\n */\n dispose(): void {\n // Do nothing if the tracker is already disposed.\n if (this._counter < 0) {\n return;\n }\n\n // Mark the tracker as disposed.\n this._counter = -1;\n\n // Clear the connections for the tracker.\n Signal.clearData(this);\n\n // Remove all event listeners.\n for (const widget of this._widgets) {\n widget.node.removeEventListener('focus', this, true);\n widget.node.removeEventListener('blur', this, true);\n }\n\n // Clear the internal data structures.\n this._activeWidget = null;\n this._currentWidget = null;\n this._nodes.clear();\n this._numbers.clear();\n this._widgets.length = 0;\n }\n\n /**\n * A signal emitted when the current widget has changed.\n */\n get currentChanged(): ISignal> {\n return this._currentChanged;\n }\n\n /**\n * A signal emitted when the active widget has changed.\n */\n get activeChanged(): ISignal> {\n return this._activeChanged;\n }\n\n /**\n * A flag indicating whether the tracker is disposed.\n */\n get isDisposed(): boolean {\n return this._counter < 0;\n }\n\n /**\n * The current widget in the tracker.\n *\n * #### Notes\n * The current widget is the widget among the tracked widgets which\n * has the *descendant node* which has most recently been focused.\n *\n * The current widget will not be updated if the node loses focus. It\n * will only be updated when a different tracked widget gains focus.\n *\n * If the current widget is removed from the tracker, the previous\n * current widget will be restored.\n *\n * This behavior is intended to follow a user's conceptual model of\n * a semantically \"current\" widget, where the \"last thing of type X\"\n * to be interacted with is the \"current instance of X\", regardless\n * of whether that instance still has focus.\n */\n get currentWidget(): T | null {\n return this._currentWidget;\n }\n\n /**\n * The active widget in the tracker.\n *\n * #### Notes\n * The active widget is the widget among the tracked widgets which\n * has the *descendant node* which is currently focused.\n */\n get activeWidget(): T | null {\n return this._activeWidget;\n }\n\n /**\n * A read only array of the widgets being tracked.\n */\n get widgets(): ReadonlyArray {\n return this._widgets;\n }\n\n /**\n * Get the focus number for a particular widget in the tracker.\n *\n * @param widget - The widget of interest.\n *\n * @returns The focus number for the given widget, or `-1` if the\n * widget has not had focus since being added to the tracker, or\n * is not contained by the tracker.\n *\n * #### Notes\n * The focus number indicates the relative order in which the widgets\n * have gained focus. A widget with a larger number has gained focus\n * more recently than a widget with a smaller number.\n *\n * The `currentWidget` will always have the largest focus number.\n *\n * All widgets start with a focus number of `-1`, which indicates that\n * the widget has not been focused since being added to the tracker.\n */\n focusNumber(widget: T): number {\n let n = this._numbers.get(widget);\n return n === undefined ? -1 : n;\n }\n\n /**\n * Test whether the focus tracker contains a given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns `true` if the widget is tracked, `false` otherwise.\n */\n has(widget: T): boolean {\n return this._numbers.has(widget);\n }\n\n /**\n * Add a widget to the focus tracker.\n *\n * @param widget - The widget of interest.\n *\n * #### Notes\n * A widget will be automatically removed from the tracker if it\n * is disposed after being added.\n *\n * If the widget is already tracked, this is a no-op.\n */\n add(widget: T): void {\n // Do nothing if the widget is already tracked.\n if (this._numbers.has(widget)) {\n return;\n }\n\n // Test whether the widget has focus.\n let focused = widget.node.contains(document.activeElement);\n\n // Set up the initial focus number.\n let n = focused ? this._counter++ : -1;\n\n // Add the widget to the internal data structures.\n this._widgets.push(widget);\n this._numbers.set(widget, n);\n this._nodes.set(widget.node, widget);\n\n // Set up the event listeners. The capturing phase must be used\n // since the 'focus' and 'blur' events don't bubble and Firefox\n // doesn't support the 'focusin' or 'focusout' events.\n widget.node.addEventListener('focus', this, true);\n widget.node.addEventListener('blur', this, true);\n\n // Connect the disposed signal handler.\n widget.disposed.connect(this._onWidgetDisposed, this);\n\n // Set the current and active widgets if needed.\n if (focused) {\n this._setWidgets(widget, widget);\n }\n }\n\n /**\n * Remove a widget from the focus tracker.\n *\n * #### Notes\n * If the widget is the `currentWidget`, the previous current widget\n * will become the new `currentWidget`.\n *\n * A widget will be automatically removed from the tracker if it\n * is disposed after being added.\n *\n * If the widget is not tracked, this is a no-op.\n */\n remove(widget: T): void {\n // Bail early if the widget is not tracked.\n if (!this._numbers.has(widget)) {\n return;\n }\n\n // Disconnect the disposed signal handler.\n widget.disposed.disconnect(this._onWidgetDisposed, this);\n\n // Remove the event listeners.\n widget.node.removeEventListener('focus', this, true);\n widget.node.removeEventListener('blur', this, true);\n\n // Remove the widget from the internal data structures.\n ArrayExt.removeFirstOf(this._widgets, widget);\n this._nodes.delete(widget.node);\n this._numbers.delete(widget);\n\n // Bail early if the widget is not the current widget.\n if (this._currentWidget !== widget) {\n return;\n }\n\n // Filter the widgets for those which have had focus.\n let valid = this._widgets.filter(w => this._numbers.get(w) !== -1);\n\n // Get the valid widget with the max focus number.\n let previous =\n max(valid, (first, second) => {\n let a = this._numbers.get(first)!;\n let b = this._numbers.get(second)!;\n return a - b;\n }) || null;\n\n // Set the current and active widgets.\n this._setWidgets(previous, null);\n }\n\n /**\n * Handle the DOM events for the focus tracker.\n *\n * @param event - The DOM event sent to the panel.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the tracked nodes. It should\n * not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'focus':\n this._evtFocus(event as FocusEvent);\n break;\n case 'blur':\n this._evtBlur(event as FocusEvent);\n break;\n }\n }\n\n /**\n * Set the current and active widgets for the tracker.\n */\n private _setWidgets(current: T | null, active: T | null): void {\n // Swap the current widget.\n let oldCurrent = this._currentWidget;\n this._currentWidget = current;\n\n // Swap the active widget.\n let oldActive = this._activeWidget;\n this._activeWidget = active;\n\n // Emit the `currentChanged` signal if needed.\n if (oldCurrent !== current) {\n this._currentChanged.emit({ oldValue: oldCurrent, newValue: current });\n }\n\n // Emit the `activeChanged` signal if needed.\n if (oldActive !== active) {\n this._activeChanged.emit({ oldValue: oldActive, newValue: active });\n }\n }\n\n /**\n * Handle the `'focus'` event for a tracked widget.\n */\n private _evtFocus(event: FocusEvent): void {\n // Find the widget which gained focus, which is known to exist.\n let widget = this._nodes.get(event.currentTarget as HTMLElement)!;\n\n // Update the focus number if necessary.\n if (widget !== this._currentWidget) {\n this._numbers.set(widget, this._counter++);\n }\n\n // Set the current and active widgets.\n this._setWidgets(widget, widget);\n }\n\n /**\n * Handle the `'blur'` event for a tracked widget.\n */\n private _evtBlur(event: FocusEvent): void {\n // Find the widget which lost focus, which is known to exist.\n let widget = this._nodes.get(event.currentTarget as HTMLElement)!;\n\n // Get the node which being focused after this blur.\n let focusTarget = event.relatedTarget as HTMLElement;\n\n // If no other node is being focused, clear the active widget.\n if (!focusTarget) {\n this._setWidgets(this._currentWidget, null);\n return;\n }\n\n // Bail if the focus widget is not changing.\n if (widget.node.contains(focusTarget)) {\n return;\n }\n\n // If no tracked widget is being focused, clear the active widget.\n if (!find(this._widgets, w => w.node.contains(focusTarget))) {\n this._setWidgets(this._currentWidget, null);\n return;\n }\n }\n\n /**\n * Handle the `disposed` signal for a tracked widget.\n */\n private _onWidgetDisposed(sender: T): void {\n this.remove(sender);\n }\n\n private _counter = 0;\n private _widgets: T[] = [];\n private _activeWidget: T | null = null;\n private _currentWidget: T | null = null;\n private _numbers = new Map();\n private _nodes = new Map();\n private _activeChanged = new Signal>(this);\n private _currentChanged = new Signal>(\n this\n );\n}\n\n/**\n * The namespace for the `FocusTracker` class statics.\n */\nexport namespace FocusTracker {\n /**\n * An arguments object for the changed signals.\n */\n export interface IChangedArgs {\n /**\n * The old value for the widget.\n */\n oldValue: T | null;\n\n /**\n * The new value for the widget.\n */\n newValue: T | null;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { BoxEngine, BoxSizer } from './boxengine';\n\nimport { Layout, LayoutItem } from './layout';\n\nimport { Widget } from './widget';\n\n/**\n * A layout which arranges its widgets in a grid.\n */\nexport class GridLayout extends Layout {\n /**\n * Construct a new grid layout.\n *\n * @param options - The options for initializing the layout.\n */\n constructor(options: GridLayout.IOptions = {}) {\n super(options);\n if (options.rowCount !== undefined) {\n Private.reallocSizers(this._rowSizers, options.rowCount);\n }\n if (options.columnCount !== undefined) {\n Private.reallocSizers(this._columnSizers, options.columnCount);\n }\n if (options.rowSpacing !== undefined) {\n this._rowSpacing = Private.clampValue(options.rowSpacing);\n }\n if (options.columnSpacing !== undefined) {\n this._columnSpacing = Private.clampValue(options.columnSpacing);\n }\n }\n\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n // Dispose of the widgets and layout items.\n for (const item of this._items) {\n let widget = item.widget;\n item.dispose();\n widget.dispose();\n }\n\n // Clear the layout state.\n this._box = null;\n this._items.length = 0;\n this._rowStarts.length = 0;\n this._rowSizers.length = 0;\n this._columnStarts.length = 0;\n this._columnSizers.length = 0;\n\n // Dispose of the rest of the layout.\n super.dispose();\n }\n\n /**\n * Get the number of rows in the layout.\n */\n get rowCount(): number {\n return this._rowSizers.length;\n }\n\n /**\n * Set the number of rows in the layout.\n *\n * #### Notes\n * The minimum row count is `1`.\n */\n set rowCount(value: number) {\n // Do nothing if the row count does not change.\n if (value === this.rowCount) {\n return;\n }\n\n // Reallocate the row sizers.\n Private.reallocSizers(this._rowSizers, value);\n\n // Schedule a fit of the parent.\n if (this.parent) {\n this.parent.fit();\n }\n }\n\n /**\n * Get the number of columns in the layout.\n */\n get columnCount(): number {\n return this._columnSizers.length;\n }\n\n /**\n * Set the number of columns in the layout.\n *\n * #### Notes\n * The minimum column count is `1`.\n */\n set columnCount(value: number) {\n // Do nothing if the column count does not change.\n if (value === this.columnCount) {\n return;\n }\n\n // Reallocate the column sizers.\n Private.reallocSizers(this._columnSizers, value);\n\n // Schedule a fit of the parent.\n if (this.parent) {\n this.parent.fit();\n }\n }\n\n /**\n * Get the row spacing for the layout.\n */\n get rowSpacing(): number {\n return this._rowSpacing;\n }\n\n /**\n * Set the row spacing for the layout.\n */\n set rowSpacing(value: number) {\n // Clamp the spacing to the allowed range.\n value = Private.clampValue(value);\n\n // Bail if the spacing does not change\n if (this._rowSpacing === value) {\n return;\n }\n\n // Update the internal spacing.\n this._rowSpacing = value;\n\n // Schedule a fit of the parent.\n if (this.parent) {\n this.parent.fit();\n }\n }\n\n /**\n * Get the column spacing for the layout.\n */\n get columnSpacing(): number {\n return this._columnSpacing;\n }\n\n /**\n * Set the col spacing for the layout.\n */\n set columnSpacing(value: number) {\n // Clamp the spacing to the allowed range.\n value = Private.clampValue(value);\n\n // Bail if the spacing does not change\n if (this._columnSpacing === value) {\n return;\n }\n\n // Update the internal spacing.\n this._columnSpacing = value;\n\n // Schedule a fit of the parent.\n if (this.parent) {\n this.parent.fit();\n }\n }\n\n /**\n * Get the stretch factor for a specific row.\n *\n * @param index - The row index of interest.\n *\n * @returns The stretch factor for the row.\n *\n * #### Notes\n * This returns `-1` if the index is out of range.\n */\n rowStretch(index: number): number {\n let sizer = this._rowSizers[index];\n return sizer ? sizer.stretch : -1;\n }\n\n /**\n * Set the stretch factor for a specific row.\n *\n * @param index - The row index of interest.\n *\n * @param value - The stretch factor for the row.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n setRowStretch(index: number, value: number): void {\n // Look up the row sizer.\n let sizer = this._rowSizers[index];\n\n // Bail if the index is out of range.\n if (!sizer) {\n return;\n }\n\n // Clamp the value to the allowed range.\n value = Private.clampValue(value);\n\n // Bail if the stretch does not change.\n if (sizer.stretch === value) {\n return;\n }\n\n // Update the sizer stretch.\n sizer.stretch = value;\n\n // Schedule an update of the parent.\n if (this.parent) {\n this.parent.update();\n }\n }\n\n /**\n * Get the stretch factor for a specific column.\n *\n * @param index - The column index of interest.\n *\n * @returns The stretch factor for the column.\n *\n * #### Notes\n * This returns `-1` if the index is out of range.\n */\n columnStretch(index: number): number {\n let sizer = this._columnSizers[index];\n return sizer ? sizer.stretch : -1;\n }\n\n /**\n * Set the stretch factor for a specific column.\n *\n * @param index - The column index of interest.\n *\n * @param value - The stretch factor for the column.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n setColumnStretch(index: number, value: number): void {\n // Look up the column sizer.\n let sizer = this._columnSizers[index];\n\n // Bail if the index is out of range.\n if (!sizer) {\n return;\n }\n\n // Clamp the value to the allowed range.\n value = Private.clampValue(value);\n\n // Bail if the stretch does not change.\n if (sizer.stretch === value) {\n return;\n }\n\n // Update the sizer stretch.\n sizer.stretch = value;\n\n // Schedule an update of the parent.\n if (this.parent) {\n this.parent.update();\n }\n }\n\n /**\n * Create an iterator over the widgets in the layout.\n *\n * @returns A new iterator over the widgets in the layout.\n */\n *[Symbol.iterator](): IterableIterator {\n for (const item of this._items) {\n yield item.widget;\n }\n }\n\n /**\n * Add a widget to the grid layout.\n *\n * @param widget - The widget to add to the layout.\n *\n * #### Notes\n * If the widget is already contained in the layout, this is no-op.\n */\n addWidget(widget: Widget): void {\n // Look up the index for the widget.\n let i = ArrayExt.findFirstIndex(this._items, it => it.widget === widget);\n\n // Bail if the widget is already in the layout.\n if (i !== -1) {\n return;\n }\n\n // Add the widget to the layout.\n this._items.push(new LayoutItem(widget));\n\n // Attach the widget to the parent.\n if (this.parent) {\n this.attachWidget(widget);\n }\n }\n\n /**\n * Remove a widget from the grid layout.\n *\n * @param widget - The widget to remove from the layout.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method does *not* modify the widget's `parent`.\n */\n removeWidget(widget: Widget): void {\n // Look up the index for the widget.\n let i = ArrayExt.findFirstIndex(this._items, it => it.widget === widget);\n\n // Bail if the widget is not in the layout.\n if (i === -1) {\n return;\n }\n\n // Remove the widget from the layout.\n let item = ArrayExt.removeAt(this._items, i)!;\n\n // Detach the widget from the parent.\n if (this.parent) {\n this.detachWidget(widget);\n }\n\n // Dispose the layout item.\n item.dispose();\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n super.init();\n for (const widget of this) {\n this.attachWidget(widget);\n }\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param widget - The widget to attach to the parent.\n */\n protected attachWidget(widget: Widget): void {\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget's node to the parent.\n this.parent!.node.appendChild(widget.node);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param widget - The widget to detach from the parent.\n */\n protected detachWidget(widget: Widget): void {\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n */\n protected onBeforeShow(msg: Message): void {\n super.onBeforeShow(msg);\n this.parent!.update();\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n super.onBeforeAttach(msg);\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n if (this.parent!.isVisible) {\n this._update(msg.width, msg.height);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.parent!.isVisible) {\n this._update(-1, -1);\n }\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n */\n protected onFitRequest(msg: Message): void {\n if (this.parent!.isAttached) {\n this._fit();\n }\n }\n\n /**\n * Fit the layout to the total size required by the widgets.\n */\n private _fit(): void {\n // Reset the min sizes of the sizers.\n for (let i = 0, n = this.rowCount; i < n; ++i) {\n this._rowSizers[i].minSize = 0;\n }\n for (let i = 0, n = this.columnCount; i < n; ++i) {\n this._columnSizers[i].minSize = 0;\n }\n\n // Filter for the visible layout items.\n let items = this._items.filter(it => !it.isHidden);\n\n // Fit the layout items.\n for (let i = 0, n = items.length; i < n; ++i) {\n items[i].fit();\n }\n\n // Get the max row and column index.\n let maxRow = this.rowCount - 1;\n let maxCol = this.columnCount - 1;\n\n // Sort the items by row span.\n items.sort(Private.rowSpanCmp);\n\n // Update the min sizes of the row sizers.\n for (let i = 0, n = items.length; i < n; ++i) {\n // Fetch the item.\n let item = items[i];\n\n // Get the row bounds for the item.\n let config = GridLayout.getCellConfig(item.widget);\n let r1 = Math.min(config.row, maxRow);\n let r2 = Math.min(config.row + config.rowSpan - 1, maxRow);\n\n // Distribute the minimum height to the sizers as needed.\n Private.distributeMin(this._rowSizers, r1, r2, item.minHeight);\n }\n\n // Sort the items by column span.\n items.sort(Private.columnSpanCmp);\n\n // Update the min sizes of the column sizers.\n for (let i = 0, n = items.length; i < n; ++i) {\n // Fetch the item.\n let item = items[i];\n\n // Get the column bounds for the item.\n let config = GridLayout.getCellConfig(item.widget);\n let c1 = Math.min(config.column, maxCol);\n let c2 = Math.min(config.column + config.columnSpan - 1, maxCol);\n\n // Distribute the minimum width to the sizers as needed.\n Private.distributeMin(this._columnSizers, c1, c2, item.minWidth);\n }\n\n // If no size constraint is needed, just update the parent.\n if (this.fitPolicy === 'set-no-constraint') {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n return;\n }\n\n // Set up the computed min size.\n let minH = maxRow * this._rowSpacing;\n let minW = maxCol * this._columnSpacing;\n\n // Add the sizer minimums to the computed min size.\n for (let i = 0, n = this.rowCount; i < n; ++i) {\n minH += this._rowSizers[i].minSize;\n }\n for (let i = 0, n = this.columnCount; i < n; ++i) {\n minW += this._columnSizers[i].minSize;\n }\n\n // Update the box sizing and add it to the computed min size.\n let box = (this._box = ElementExt.boxSizing(this.parent!.node));\n minW += box.horizontalSum;\n minH += box.verticalSum;\n\n // Update the parent's min size constraints.\n let style = this.parent!.node.style;\n style.minWidth = `${minW}px`;\n style.minHeight = `${minH}px`;\n\n // Set the dirty flag to ensure only a single update occurs.\n this._dirty = true;\n\n // Notify the ancestor that it should fit immediately. This may\n // cause a resize of the parent, fulfilling the required update.\n if (this.parent!.parent) {\n MessageLoop.sendMessage(this.parent!.parent!, Widget.Msg.FitRequest);\n }\n\n // If the dirty flag is still set, the parent was not resized.\n // Trigger the required update on the parent widget immediately.\n if (this._dirty) {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n }\n }\n\n /**\n * Update the layout position and size of the widgets.\n *\n * The parent offset dimensions should be `-1` if unknown.\n */\n private _update(offsetWidth: number, offsetHeight: number): void {\n // Clear the dirty flag to indicate the update occurred.\n this._dirty = false;\n\n // Measure the parent if the offset dimensions are unknown.\n if (offsetWidth < 0) {\n offsetWidth = this.parent!.node.offsetWidth;\n }\n if (offsetHeight < 0) {\n offsetHeight = this.parent!.node.offsetHeight;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent!.node);\n }\n\n // Compute the layout area adjusted for border and padding.\n let top = this._box.paddingTop;\n let left = this._box.paddingLeft;\n let width = offsetWidth - this._box.horizontalSum;\n let height = offsetHeight - this._box.verticalSum;\n\n // Get the max row and column index.\n let maxRow = this.rowCount - 1;\n let maxCol = this.columnCount - 1;\n\n // Compute the total fixed row and column space.\n let fixedRowSpace = maxRow * this._rowSpacing;\n let fixedColSpace = maxCol * this._columnSpacing;\n\n // Distribute the available space to the box sizers.\n BoxEngine.calc(this._rowSizers, Math.max(0, height - fixedRowSpace));\n BoxEngine.calc(this._columnSizers, Math.max(0, width - fixedColSpace));\n\n // Update the row start positions.\n for (let i = 0, pos = top, n = this.rowCount; i < n; ++i) {\n this._rowStarts[i] = pos;\n pos += this._rowSizers[i].size + this._rowSpacing;\n }\n\n // Update the column start positions.\n for (let i = 0, pos = left, n = this.columnCount; i < n; ++i) {\n this._columnStarts[i] = pos;\n pos += this._columnSizers[i].size + this._columnSpacing;\n }\n\n // Update the geometry of the layout items.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item.\n let item = this._items[i];\n\n // Ignore hidden items.\n if (item.isHidden) {\n continue;\n }\n\n // Fetch the cell bounds for the widget.\n let config = GridLayout.getCellConfig(item.widget);\n let r1 = Math.min(config.row, maxRow);\n let c1 = Math.min(config.column, maxCol);\n let r2 = Math.min(config.row + config.rowSpan - 1, maxRow);\n let c2 = Math.min(config.column + config.columnSpan - 1, maxCol);\n\n // Compute the cell geometry.\n let x = this._columnStarts[c1];\n let y = this._rowStarts[r1];\n let w = this._columnStarts[c2] + this._columnSizers[c2].size - x;\n let h = this._rowStarts[r2] + this._rowSizers[r2].size - y;\n\n // Update the geometry of the layout item.\n item.update(x, y, w, h);\n }\n }\n\n private _dirty = false;\n private _rowSpacing = 4;\n private _columnSpacing = 4;\n private _items: LayoutItem[] = [];\n private _rowStarts: number[] = [];\n private _columnStarts: number[] = [];\n private _rowSizers: BoxSizer[] = [new BoxSizer()];\n private _columnSizers: BoxSizer[] = [new BoxSizer()];\n private _box: ElementExt.IBoxSizing | null = null;\n}\n\n/**\n * The namespace for the `GridLayout` class statics.\n */\nexport namespace GridLayout {\n /**\n * An options object for initializing a grid layout.\n */\n export interface IOptions extends Layout.IOptions {\n /**\n * The initial row count for the layout.\n *\n * The default is `1`.\n */\n rowCount?: number;\n\n /**\n * The initial column count for the layout.\n *\n * The default is `1`.\n */\n columnCount?: number;\n\n /**\n * The spacing between rows in the layout.\n *\n * The default is `4`.\n */\n rowSpacing?: number;\n\n /**\n * The spacing between columns in the layout.\n *\n * The default is `4`.\n */\n columnSpacing?: number;\n }\n\n /**\n * An object which holds the cell configuration for a widget.\n */\n export interface ICellConfig {\n /**\n * The row index for the widget.\n */\n readonly row: number;\n\n /**\n * The column index for the widget.\n */\n readonly column: number;\n\n /**\n * The row span for the widget.\n */\n readonly rowSpan: number;\n\n /**\n * The column span for the widget.\n */\n readonly columnSpan: number;\n }\n\n /**\n * Get the cell config for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The cell config for the widget.\n */\n export function getCellConfig(widget: Widget): ICellConfig {\n return Private.cellConfigProperty.get(widget);\n }\n\n /**\n * Set the cell config for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the cell config.\n */\n export function setCellConfig(\n widget: Widget,\n value: Partial\n ): void {\n Private.cellConfigProperty.set(widget, Private.normalizeConfig(value));\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The property descriptor for the widget cell config.\n */\n export const cellConfigProperty = new AttachedProperty<\n Widget,\n GridLayout.ICellConfig\n >({\n name: 'cellConfig',\n create: () => ({ row: 0, column: 0, rowSpan: 1, columnSpan: 1 }),\n changed: onChildCellConfigChanged\n });\n\n /**\n * Normalize a partial cell config object.\n */\n export function normalizeConfig(\n config: Partial\n ): GridLayout.ICellConfig {\n let row = Math.max(0, Math.floor(config.row || 0));\n let column = Math.max(0, Math.floor(config.column || 0));\n let rowSpan = Math.max(1, Math.floor(config.rowSpan || 0));\n let columnSpan = Math.max(1, Math.floor(config.columnSpan || 0));\n return { row, column, rowSpan, columnSpan };\n }\n\n /**\n * Clamp a value to an integer >= 0.\n */\n export function clampValue(value: number): number {\n return Math.max(0, Math.floor(value));\n }\n\n /**\n * A sort comparison function for row spans.\n */\n export function rowSpanCmp(a: LayoutItem, b: LayoutItem): number {\n let c1 = cellConfigProperty.get(a.widget);\n let c2 = cellConfigProperty.get(b.widget);\n return c1.rowSpan - c2.rowSpan;\n }\n\n /**\n * A sort comparison function for column spans.\n */\n export function columnSpanCmp(a: LayoutItem, b: LayoutItem): number {\n let c1 = cellConfigProperty.get(a.widget);\n let c2 = cellConfigProperty.get(b.widget);\n return c1.columnSpan - c2.columnSpan;\n }\n\n /**\n * Reallocate the box sizers for the given grid dimensions.\n */\n export function reallocSizers(sizers: BoxSizer[], count: number): void {\n // Coerce the count to the valid range.\n count = Math.max(1, Math.floor(count));\n\n // Add the missing sizers.\n while (sizers.length < count) {\n sizers.push(new BoxSizer());\n }\n\n // Remove the extra sizers.\n if (sizers.length > count) {\n sizers.length = count;\n }\n }\n\n /**\n * Distribute a min size constraint across a range of sizers.\n */\n export function distributeMin(\n sizers: BoxSizer[],\n i1: number,\n i2: number,\n minSize: number\n ): void {\n // Sanity check the indices.\n if (i2 < i1) {\n return;\n }\n\n // Handle the simple case of no cell span.\n if (i1 === i2) {\n let sizer = sizers[i1];\n sizer.minSize = Math.max(sizer.minSize, minSize);\n return;\n }\n\n // Compute the total current min size of the span.\n let totalMin = 0;\n for (let i = i1; i <= i2; ++i) {\n totalMin += sizers[i].minSize;\n }\n\n // Do nothing if the total is greater than the required.\n if (totalMin >= minSize) {\n return;\n }\n\n // Compute the portion of the space to allocate to each sizer.\n let portion = (minSize - totalMin) / (i2 - i1 + 1);\n\n // Add the portion to each sizer.\n for (let i = i1; i <= i2; ++i) {\n sizers[i].minSize += portion;\n }\n }\n\n /**\n * The change handler for the child cell config property.\n */\n function onChildCellConfigChanged(child: Widget): void {\n if (child.parent && child.parent.layout instanceof GridLayout) {\n child.parent.fit();\n }\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { getKeyboardLayout } from '@lumino/keyboard';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { CommandRegistry } from '@lumino/commands';\n\nimport {\n ElementARIAAttrs,\n ElementDataset,\n h,\n VirtualDOM,\n VirtualElement\n} from '@lumino/virtualdom';\n\nimport { Menu } from './menu';\n\nimport { Title } from './title';\n\nimport { Widget } from './widget';\n\n/**\n * A widget which displays menus as a canonical menu bar.\n */\nexport class MenuBar extends Widget {\n /**\n * Construct a new menu bar.\n *\n * @param options - The options for initializing the menu bar.\n */\n constructor(options: MenuBar.IOptions = {}) {\n super({ node: Private.createNode() });\n this.addClass('lm-MenuBar');\n this.setFlag(Widget.Flag.DisallowLayout);\n this.renderer = options.renderer || MenuBar.defaultRenderer;\n this._forceItemsPosition = options.forceItemsPosition || {\n forceX: true,\n forceY: true\n };\n this._overflowMenuOptions = options.overflowMenuOptions || {\n isVisible: true\n };\n }\n\n /**\n * Dispose of the resources held by the widget.\n */\n dispose(): void {\n this._closeChildMenu();\n this._menus.length = 0;\n super.dispose();\n }\n\n /**\n * The renderer used by the menu bar.\n */\n readonly renderer: MenuBar.IRenderer;\n\n /**\n * The child menu of the menu bar.\n *\n * #### Notes\n * This will be `null` if the menu bar does not have an open menu.\n */\n get childMenu(): Menu | null {\n return this._childMenu;\n }\n\n /**\n * The overflow index of the menu bar.\n */\n get overflowIndex(): number {\n return this._overflowIndex;\n }\n\n /**\n * The overflow menu of the menu bar.\n */\n get overflowMenu(): Menu | null {\n return this._overflowMenu;\n }\n\n /**\n * Get the menu bar content node.\n *\n * #### Notes\n * This is the node which holds the menu title nodes.\n *\n * Modifying this node directly can lead to undefined behavior.\n */\n get contentNode(): HTMLUListElement {\n return this.node.getElementsByClassName(\n 'lm-MenuBar-content'\n )[0] as HTMLUListElement;\n }\n\n /**\n * Get the currently active menu.\n */\n get activeMenu(): Menu | null {\n return this._menus[this._activeIndex] || null;\n }\n\n /**\n * Set the currently active menu.\n *\n * #### Notes\n * If the menu does not exist, the menu will be set to `null`.\n */\n set activeMenu(value: Menu | null) {\n this.activeIndex = value ? this._menus.indexOf(value) : -1;\n }\n\n /**\n * Get the index of the currently active menu.\n *\n * #### Notes\n * This will be `-1` if no menu is active.\n */\n get activeIndex(): number {\n return this._activeIndex;\n }\n\n /**\n * Set the index of the currently active menu.\n *\n * #### Notes\n * If the menu cannot be activated, the index will be set to `-1`.\n */\n set activeIndex(value: number) {\n // Adjust the value for an out of range index.\n if (value < 0 || value >= this._menus.length) {\n value = -1;\n }\n\n // Bail early if the index will not change.\n if (this._activeIndex === value) {\n return;\n }\n\n // Update the active index.\n this._activeIndex = value;\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * A read-only array of the menus in the menu bar.\n */\n get menus(): ReadonlyArray {\n return this._menus;\n }\n\n /**\n * Open the active menu and activate its first menu item.\n *\n * #### Notes\n * If there is no active menu, this is a no-op.\n */\n openActiveMenu(): void {\n // Bail early if there is no active item.\n if (this._activeIndex === -1) {\n return;\n }\n\n // Open the child menu.\n this._openChildMenu();\n\n // Activate the first item in the child menu.\n if (this._childMenu) {\n this._childMenu.activeIndex = -1;\n this._childMenu.activateNextItem();\n }\n }\n\n /**\n * Add a menu to the end of the menu bar.\n *\n * @param menu - The menu to add to the menu bar.\n *\n * #### Notes\n * If the menu is already added to the menu bar, it will be moved.\n */\n addMenu(menu: Menu, update: boolean = true): void {\n this.insertMenu(this._menus.length, menu, update);\n }\n\n /**\n * Insert a menu into the menu bar at the specified index.\n *\n * @param index - The index at which to insert the menu.\n *\n * @param menu - The menu to insert into the menu bar.\n *\n * #### Notes\n * The index will be clamped to the bounds of the menus.\n *\n * If the menu is already added to the menu bar, it will be moved.\n */\n insertMenu(index: number, menu: Menu, update: boolean = true): void {\n // Close the child menu before making changes.\n this._closeChildMenu();\n\n // Look up the index of the menu.\n let i = this._menus.indexOf(menu);\n\n // Clamp the insert index to the array bounds.\n let j = Math.max(0, Math.min(index, this._menus.length));\n\n // If the menu is not in the array, insert it.\n if (i === -1) {\n // Insert the menu into the array.\n ArrayExt.insert(this._menus, j, menu);\n\n // Add the styling class to the menu.\n menu.addClass('lm-MenuBar-menu');\n\n // Connect to the menu signals.\n menu.aboutToClose.connect(this._onMenuAboutToClose, this);\n menu.menuRequested.connect(this._onMenuMenuRequested, this);\n menu.title.changed.connect(this._onTitleChanged, this);\n\n // Schedule an update of the items.\n if (update) {\n this.update();\n }\n\n // There is nothing more to do.\n return;\n }\n\n // Otherwise, the menu exists in the array and should be moved.\n\n // Adjust the index if the location is at the end of the array.\n if (j === this._menus.length) {\n j--;\n }\n\n // Bail if there is no effective move.\n if (i === j) {\n return;\n }\n\n // Move the menu to the new locations.\n ArrayExt.move(this._menus, i, j);\n\n // Schedule an update of the items.\n if (update) {\n this.update();\n }\n }\n\n /**\n * Remove a menu from the menu bar.\n *\n * @param menu - The menu to remove from the menu bar.\n *\n * #### Notes\n * This is a no-op if the menu is not in the menu bar.\n */\n removeMenu(menu: Menu, update: boolean = true): void {\n this.removeMenuAt(this._menus.indexOf(menu), update);\n }\n\n /**\n * Remove the menu at a given index from the menu bar.\n *\n * @param index - The index of the menu to remove.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n removeMenuAt(index: number, update: boolean = true): void {\n // Close the child menu before making changes.\n this._closeChildMenu();\n\n // Remove the menu from the array.\n let menu = ArrayExt.removeAt(this._menus, index);\n\n // Bail if the index is out of range.\n if (!menu) {\n return;\n }\n\n // Disconnect from the menu signals.\n menu.aboutToClose.disconnect(this._onMenuAboutToClose, this);\n menu.menuRequested.disconnect(this._onMenuMenuRequested, this);\n menu.title.changed.disconnect(this._onTitleChanged, this);\n\n // Remove the styling class from the menu.\n menu.removeClass('lm-MenuBar-menu');\n\n // Schedule an update of the items.\n if (update) {\n this.update();\n }\n }\n\n /**\n * Remove all menus from the menu bar.\n */\n clearMenus(): void {\n // Bail if there is nothing to remove.\n if (this._menus.length === 0) {\n return;\n }\n\n // Close the child menu before making changes.\n this._closeChildMenu();\n\n // Disconnect from the menu signals and remove the styling class.\n for (let menu of this._menus) {\n menu.aboutToClose.disconnect(this._onMenuAboutToClose, this);\n menu.menuRequested.disconnect(this._onMenuMenuRequested, this);\n menu.title.changed.disconnect(this._onTitleChanged, this);\n menu.removeClass('lm-MenuBar-menu');\n }\n\n // Clear the menus array.\n this._menus.length = 0;\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * Handle the DOM events for the menu bar.\n *\n * @param event - The DOM event sent to the menu bar.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the menu bar's DOM nodes. It\n * should not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'mousedown':\n this._evtMouseDown(event as MouseEvent);\n break;\n case 'mousemove':\n this._evtMouseMove(event as MouseEvent);\n break;\n case 'focusout':\n this._evtFocusOut(event as FocusEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('keydown', this);\n this.node.addEventListener('mousedown', this);\n this.node.addEventListener('mousemove', this);\n this.node.addEventListener('focusout', this);\n this.node.addEventListener('contextmenu', this);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('keydown', this);\n this.node.removeEventListener('mousedown', this);\n this.node.removeEventListener('mousemove', this);\n this.node.removeEventListener('focusout', this);\n this.node.removeEventListener('contextmenu', this);\n this._closeChildMenu();\n }\n\n /**\n * A message handler invoked on an `'activate-request'` message.\n */\n protected onActivateRequest(msg: Message): void {\n if (this.isAttached) {\n this._focusItemAt(0);\n }\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n this.update();\n super.onResize(msg);\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n let menus = this._menus;\n let renderer = this.renderer;\n let activeIndex = this._activeIndex;\n let tabFocusIndex =\n this._tabFocusIndex >= 0 && this._tabFocusIndex < menus.length\n ? this._tabFocusIndex\n : 0;\n let length = this._overflowIndex > -1 ? this._overflowIndex : menus.length;\n let totalMenuSize = 0;\n let isVisible = false;\n\n // Check that the overflow menu doesn't count\n length = this._overflowMenu !== null ? length - 1 : length;\n let content = new Array(length);\n\n // Render visible menus\n for (let i = 0; i < length; ++i) {\n content[i] = renderer.renderItem({\n title: menus[i].title,\n active: i === activeIndex,\n tabbable: i === tabFocusIndex,\n disabled: menus[i].items.length === 0,\n onfocus: () => {\n this._tabFocusIndex = i;\n this.activeIndex = i;\n }\n });\n // Calculate size of current menu\n totalMenuSize += this._menuItemSizes[i];\n // Check if overflow menu is already rendered\n if (menus[i].title.label === this._overflowMenuOptions.title) {\n isVisible = true;\n length--;\n }\n }\n // Render overflow menu if needed and active\n if (this._overflowMenuOptions.isVisible) {\n if (this._overflowIndex > -1 && !isVisible) {\n // Create overflow menu\n if (this._overflowMenu === null) {\n const overflowMenuTitle = this._overflowMenuOptions.title ?? '...';\n this._overflowMenu = new Menu({ commands: new CommandRegistry() });\n this._overflowMenu.title.label = overflowMenuTitle;\n this._overflowMenu.title.mnemonic = 0;\n this.addMenu(this._overflowMenu, false);\n }\n // Move menus to overflow menu\n for (let i = menus.length - 2; i >= length; i--) {\n const submenu = this.menus[i];\n submenu.title.mnemonic = 0;\n this._overflowMenu.insertItem(0, {\n type: 'submenu',\n submenu: submenu\n });\n this.removeMenu(submenu, false);\n }\n content[length] = renderer.renderItem({\n title: this._overflowMenu.title,\n active: length === activeIndex && menus[length].items.length !== 0,\n tabbable: length === tabFocusIndex,\n disabled: menus[length].items.length === 0,\n onfocus: () => {\n this._tabFocusIndex = length;\n this.activeIndex = length;\n }\n });\n length++;\n } else if (this._overflowMenu !== null) {\n // Remove submenus from overflow menu\n let overflowMenuItems = this._overflowMenu.items;\n let screenSize = this.node.offsetWidth;\n let n = this._overflowMenu.items.length;\n for (let i = 0; i < n; ++i) {\n let index = menus.length - 1 - i;\n if (screenSize - totalMenuSize > this._menuItemSizes[index]) {\n let menu = overflowMenuItems[0].submenu as Menu;\n this._overflowMenu.removeItemAt(0);\n this.insertMenu(length, menu, false);\n content[length] = renderer.renderItem({\n title: menu.title,\n active: false,\n tabbable: length === tabFocusIndex,\n disabled: menus[length].items.length === 0,\n onfocus: () => {\n this._tabFocusIndex = length;\n this.activeIndex = length;\n }\n });\n length++;\n }\n }\n if (this._overflowMenu.items.length === 0) {\n this.removeMenu(this._overflowMenu, false);\n content.pop();\n this._overflowMenu = null;\n this._overflowIndex = -1;\n }\n }\n }\n VirtualDOM.render(content, this.contentNode);\n this._updateOverflowIndex();\n }\n\n /**\n * Calculate and update the current overflow index.\n */\n private _updateOverflowIndex(): void {\n if (!this._overflowMenuOptions.isVisible) {\n return;\n }\n\n // Get elements visible in the main menu bar\n const itemMenus = this.contentNode.childNodes;\n let screenSize = this.node.offsetWidth;\n let totalMenuSize = 0;\n let index = -1;\n let n = itemMenus.length;\n\n if (this._menuItemSizes.length == 0) {\n // Check if it is the first resize and get info about menu items sizes\n for (let i = 0; i < n; i++) {\n let item = itemMenus[i] as HTMLLIElement;\n // Add sizes to array\n totalMenuSize += item.offsetWidth;\n this._menuItemSizes.push(item.offsetWidth);\n if (totalMenuSize > screenSize && index === -1) {\n index = i;\n }\n }\n } else {\n // Calculate current menu size\n for (let i = 0; i < this._menuItemSizes.length; i++) {\n totalMenuSize += this._menuItemSizes[i];\n if (totalMenuSize > screenSize) {\n index = i;\n break;\n }\n }\n }\n this._overflowIndex = index;\n }\n\n /**\n * Handle the `'keydown'` event for the menu bar.\n *\n * #### Notes\n * All keys are trapped except the tab key that is ignored.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // Fetch the key code for the event.\n let kc = event.keyCode;\n\n // Reset the active index on tab, but do not trap the tab key.\n if (kc === 9) {\n this.activeIndex = -1;\n return;\n }\n\n // A menu bar handles all other keydown events.\n event.preventDefault();\n event.stopPropagation();\n\n // Enter, Space, Up Arrow, Down Arrow\n if (kc === 13 || kc === 32 || kc === 38 || kc === 40) {\n // The active index may have changed (for example, user hovers over an\n // item with the mouse), so be sure to use the focus index.\n this.activeIndex = this._tabFocusIndex;\n if (this.activeIndex !== this._tabFocusIndex) {\n // Bail if the setter refused to set activeIndex to tabFocusIndex\n // because it means that the item at tabFocusIndex cannot be opened (for\n // example, it has an empty menu)\n return;\n }\n this.openActiveMenu();\n return;\n }\n\n // Escape\n if (kc === 27) {\n this._closeChildMenu();\n this._focusItemAt(this.activeIndex);\n return;\n }\n\n // Left or Right Arrow\n if (kc === 37 || kc === 39) {\n let direction = kc === 37 ? -1 : 1;\n let start = this._tabFocusIndex + direction;\n let n = this._menus.length;\n for (let i = 0; i < n; i++) {\n let index = (n + start + direction * i) % n;\n if (this._menus[index].items.length) {\n this._focusItemAt(index);\n return;\n }\n }\n return;\n }\n\n // Get the pressed key character.\n let key = getKeyboardLayout().keyForKeydownEvent(event);\n\n // Bail if the key is not valid.\n if (!key) {\n return;\n }\n\n // Search for the next best matching mnemonic item.\n let start = this._activeIndex + 1;\n let result = Private.findMnemonic(this._menus, key, start);\n\n // Handle the requested mnemonic based on the search results.\n // If exactly one mnemonic is matched, that menu is opened.\n // Otherwise, the next mnemonic is activated if available,\n // followed by the auto mnemonic if available.\n if (result.index !== -1 && !result.multiple) {\n this.activeIndex = result.index;\n this.openActiveMenu();\n } else if (result.index !== -1) {\n this.activeIndex = result.index;\n this._focusItemAt(this.activeIndex);\n } else if (result.auto !== -1) {\n this.activeIndex = result.auto;\n this._focusItemAt(this.activeIndex);\n }\n }\n\n /**\n * Handle the `'mousedown'` event for the menu bar.\n */\n private _evtMouseDown(event: MouseEvent): void {\n // Bail if the mouse press was not on the menu bar. This can occur\n // when the document listener is installed for an active menu bar.\n if (!ElementExt.hitTest(this.node, event.clientX, event.clientY)) {\n return;\n }\n\n // Stop the propagation of the event. Immediate propagation is\n // also stopped so that an open menu does not handle the event.\n event.stopPropagation();\n event.stopImmediatePropagation();\n\n // Check if the mouse is over one of the menu items.\n let index = ArrayExt.findFirstIndex(this.contentNode.children, node => {\n return ElementExt.hitTest(node, event.clientX, event.clientY);\n });\n\n // If the press was not on an item, close the child menu.\n if (index === -1) {\n this._closeChildMenu();\n return;\n }\n\n // If the press was not the left mouse button, do nothing further.\n if (event.button !== 0) {\n return;\n }\n\n // Otherwise, toggle the open state of the child menu.\n if (this._childMenu) {\n this._closeChildMenu();\n this.activeIndex = index;\n } else {\n // If we don't call preventDefault() here, then the item in the menu\n // bar will take focus over the menu that is being opened.\n event.preventDefault();\n const position = this._positionForMenu(index);\n Menu.saveWindowData();\n // Begin DOM modifications.\n this.activeIndex = index;\n this._openChildMenu(position);\n }\n }\n\n /**\n * Handle the `'mousemove'` event for the menu bar.\n */\n private _evtMouseMove(event: MouseEvent): void {\n // Check if the mouse is over one of the menu items.\n let index = ArrayExt.findFirstIndex(this.contentNode.children, node => {\n return ElementExt.hitTest(node, event.clientX, event.clientY);\n });\n\n // Bail early if the active index will not change.\n if (index === this._activeIndex) {\n return;\n }\n\n // Bail early if a child menu is open and the mouse is not over\n // an item. This allows the child menu to be kept open when the\n // mouse is over the empty part of the menu bar.\n if (index === -1 && this._childMenu) {\n return;\n }\n\n // Get position for the new menu >before< updating active index.\n const position =\n index >= 0 && this._childMenu ? this._positionForMenu(index) : null;\n\n // Before any modification, update window data.\n Menu.saveWindowData();\n\n // Begin DOM modifications.\n\n // Update the active index to the hovered item.\n this.activeIndex = index;\n\n // Open the new menu if a menu is already open.\n if (position) {\n this._openChildMenu(position);\n }\n }\n\n /**\n * Find initial position for the menu based on menubar item position.\n *\n * NOTE: this should be called before updating active index to avoid\n * an additional layout and style invalidation as changing active\n * index modifies DOM.\n */\n private _positionForMenu(index: number): Private.IPosition {\n let itemNode = this.contentNode.children[index];\n let { left, bottom } = (itemNode as HTMLElement).getBoundingClientRect();\n return {\n top: bottom,\n left\n };\n }\n\n /**\n * Handle the `'focusout'` event for the menu bar.\n */\n private _evtFocusOut(event: FocusEvent): void {\n // Reset the active index if there is no open menu and the menubar is losing focus.\n if (!this._childMenu && !this.node.contains(event.relatedTarget as Node)) {\n this.activeIndex = -1;\n }\n }\n\n /**\n * Focus an item in the menu bar.\n *\n * #### Notes\n * Does not open the associated menu.\n */\n private _focusItemAt(index: number): void {\n const itemNode = this.contentNode.childNodes[index] as HTMLElement | void;\n if (itemNode) {\n itemNode.focus();\n }\n }\n\n /**\n * Open the child menu at the active index immediately.\n *\n * If a different child menu is already open, it will be closed,\n * even if there is no active menu.\n */\n private _openChildMenu(options: { left?: number; top?: number } = {}): void {\n // If there is no active menu, close the current menu.\n let newMenu = this.activeMenu;\n if (!newMenu) {\n this._closeChildMenu();\n return;\n }\n\n // Bail if there is no effective menu change.\n let oldMenu = this._childMenu;\n if (oldMenu === newMenu) {\n return;\n }\n\n // Swap the internal menu reference.\n this._childMenu = newMenu;\n\n // Close the current menu, or setup for the new menu.\n if (oldMenu) {\n oldMenu.close();\n } else {\n document.addEventListener('mousedown', this, true);\n }\n\n // Update the tab focus index and ensure the menu bar is updated.\n this._tabFocusIndex = this.activeIndex;\n MessageLoop.sendMessage(this, Widget.Msg.UpdateRequest);\n\n // Get the positioning data for the new menu.\n let { left, top } = options;\n if (typeof left === 'undefined' || typeof top === 'undefined') {\n ({ left, top } = this._positionForMenu(this._activeIndex));\n }\n // Begin DOM modifications\n\n if (!oldMenu) {\n // Continue setup for new menu\n this.addClass('lm-mod-active');\n }\n\n // Open the new menu at the computed location.\n if (newMenu.items.length > 0) {\n newMenu.open(left, top, this._forceItemsPosition);\n }\n }\n\n /**\n * Close the child menu immediately.\n *\n * This is a no-op if a child menu is not open.\n */\n private _closeChildMenu(): void {\n // Bail if no child menu is open.\n if (!this._childMenu) {\n return;\n }\n // Remove the active class from the menu bar.\n this.removeClass('lm-mod-active');\n\n // Remove the document listeners.\n document.removeEventListener('mousedown', this, true);\n\n // Clear the internal menu reference.\n let menu = this._childMenu;\n this._childMenu = null;\n\n // Close the menu.\n menu.close();\n\n // Reset the active index.\n this.activeIndex = -1;\n }\n\n /**\n * Handle the `aboutToClose` signal of a menu.\n */\n private _onMenuAboutToClose(sender: Menu): void {\n // Bail if the sender is not the child menu.\n if (sender !== this._childMenu) {\n return;\n }\n\n // Remove the active class from the menu bar.\n this.removeClass('lm-mod-active');\n\n // Remove the document listeners.\n document.removeEventListener('mousedown', this, true);\n\n // Clear the internal menu reference.\n this._childMenu = null;\n\n // Reset the active index.\n this.activeIndex = -1;\n }\n\n /**\n * Handle the `menuRequested` signal of a child menu.\n */\n private _onMenuMenuRequested(sender: Menu, args: 'next' | 'previous'): void {\n // Bail if the sender is not the child menu.\n if (sender !== this._childMenu) {\n return;\n }\n\n // Look up the active index and menu count.\n let i = this._activeIndex;\n let n = this._menus.length;\n\n // Active the next requested index.\n switch (args) {\n case 'next':\n this.activeIndex = i === n - 1 ? 0 : i + 1;\n break;\n case 'previous':\n this.activeIndex = i === 0 ? n - 1 : i - 1;\n break;\n }\n\n // Open the active menu.\n this.openActiveMenu();\n }\n\n /**\n * Handle the `changed` signal of a title object.\n */\n private _onTitleChanged(): void {\n this.update();\n }\n\n // Track the index of the item that is currently focused or hovered. -1 means nothing focused or hovered.\n private _activeIndex = -1;\n // Track which item can be focused using the TAB key. Unlike _activeIndex will\n // always point to a menuitem. Whenever you update this value, it's important\n // to follow it with an \"update-request\" message so that the `tabindex`\n // attribute on each menubar item gets properly updated.\n private _tabFocusIndex = 0;\n private _forceItemsPosition: Menu.IOpenOptions;\n private _overflowMenuOptions: IOverflowMenuOptions;\n private _menus: Menu[] = [];\n private _childMenu: Menu | null = null;\n private _overflowMenu: Menu | null = null;\n private _menuItemSizes: number[] = [];\n private _overflowIndex: number = -1;\n}\n\n/**\n * The namespace for the `MenuBar` class statics.\n */\nexport namespace MenuBar {\n /**\n * An options object for creating a menu bar.\n */\n export interface IOptions {\n /**\n * A custom renderer for creating menu bar content.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n /**\n * Whether to force the position of the menu. The MenuBar forces the\n * coordinates of its menus by default. With this option you can disable it.\n *\n * Setting to `false` will enable the logic which repositions the\n * coordinates of the menu if it will not fit entirely on screen.\n *\n * The default is `true`.\n */\n forceItemsPosition?: Menu.IOpenOptions;\n /**\n * Whether to add a overflow menu if there's overflow.\n *\n * Setting to `true` will enable the logic that creates an overflow menu\n * to show the menu items that don't fit entirely on the screen.\n *\n * The default is `true`.\n */\n overflowMenuOptions?: IOverflowMenuOptions;\n }\n\n /**\n * An object which holds the data to render a menu bar item.\n */\n export interface IRenderData {\n /**\n * The title to be rendered.\n */\n readonly title: Title;\n\n /**\n * Whether the item is the active item.\n */\n readonly active: boolean;\n\n /**\n * Whether the user can tab to the item.\n */\n readonly tabbable: boolean;\n\n /**\n * Whether the item is disabled.\n *\n * #### Notes\n * A disabled item cannot be active.\n * A disabled item cannot be focussed.\n */\n readonly disabled?: boolean;\n\n readonly onfocus?: (event: FocusEvent) => void;\n }\n\n /**\n * A renderer for use with a menu bar.\n */\n export interface IRenderer {\n /**\n * Render the virtual element for a menu bar item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n */\n renderItem(data: IRenderData): VirtualElement;\n }\n\n /**\n * The default implementation of `IRenderer`.\n *\n * #### Notes\n * Subclasses are free to reimplement rendering methods as needed.\n */\n export class Renderer implements IRenderer {\n /**\n * Render the virtual element for a menu bar item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n */\n renderItem(data: IRenderData): VirtualElement {\n let className = this.createItemClass(data);\n let dataset = this.createItemDataset(data);\n let aria = this.createItemARIA(data);\n return h.li(\n {\n className,\n dataset,\n ...(data.disabled ? {} : { tabindex: data.tabbable ? '0' : '-1' }),\n onfocus: data.onfocus,\n ...aria\n },\n this.renderIcon(data),\n this.renderLabel(data)\n );\n }\n\n /**\n * Render the icon element for a menu bar item.\n *\n * @param data - The data to use for rendering the icon.\n *\n * @returns A virtual element representing the item icon.\n */\n renderIcon(data: IRenderData): VirtualElement {\n let className = this.createIconClass(data);\n\n // If data.title.icon is undefined, it will be ignored.\n return h.div({ className }, data.title.icon!, data.title.iconLabel);\n }\n\n /**\n * Render the label element for a menu item.\n *\n * @param data - The data to use for rendering the label.\n *\n * @returns A virtual element representing the item label.\n */\n renderLabel(data: IRenderData): VirtualElement {\n let content = this.formatLabel(data);\n return h.div({ className: 'lm-MenuBar-itemLabel' }, content);\n }\n\n /**\n * Create the class name for the menu bar item.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the menu item.\n */\n createItemClass(data: IRenderData): string {\n let name = 'lm-MenuBar-item';\n if (data.title.className) {\n name += ` ${data.title.className}`;\n }\n if (data.active && !data.disabled) {\n name += ' lm-mod-active';\n }\n return name;\n }\n\n /**\n * Create the dataset for a menu bar item.\n *\n * @param data - The data to use for the item.\n *\n * @returns The dataset for the menu bar item.\n */\n createItemDataset(data: IRenderData): ElementDataset {\n return data.title.dataset;\n }\n\n /**\n * Create the aria attributes for menu bar item.\n *\n * @param data - The data to use for the aria attributes.\n *\n * @returns The aria attributes object for the item.\n */\n createItemARIA(data: IRenderData): ElementARIAAttrs {\n return {\n role: 'menuitem',\n 'aria-haspopup': 'true',\n 'aria-disabled': data.disabled ? 'true' : 'false'\n };\n }\n\n /**\n * Create the class name for the menu bar item icon.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the item icon.\n */\n createIconClass(data: IRenderData): string {\n let name = 'lm-MenuBar-itemIcon';\n let extra = data.title.iconClass;\n return extra ? `${name} ${extra}` : name;\n }\n\n /**\n * Create the render content for the label node.\n *\n * @param data - The data to use for the label content.\n *\n * @returns The content to add to the label node.\n */\n formatLabel(data: IRenderData): h.Child {\n // Fetch the label text and mnemonic index.\n let { label, mnemonic } = data.title;\n\n // If the index is out of range, do not modify the label.\n if (mnemonic < 0 || mnemonic >= label.length) {\n return label;\n }\n\n // Split the label into parts.\n let prefix = label.slice(0, mnemonic);\n let suffix = label.slice(mnemonic + 1);\n let char = label[mnemonic];\n\n // Wrap the mnemonic character in a span.\n let span = h.span({ className: 'lm-MenuBar-itemMnemonic' }, char);\n\n // Return the content parts.\n return [prefix, span, suffix];\n }\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n}\n\n/**\n * Options for overflow menu.\n */\nexport interface IOverflowMenuOptions {\n /**\n * Determines if a overflow menu appears when the menu items overflow.\n *\n * Defaults to `true`.\n */\n isVisible: boolean;\n /**\n * Determines the title of the overflow menu.\n *\n * Default: `...`.\n */\n title?: string;\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Create the DOM node for a menu bar.\n */\n export function createNode(): HTMLDivElement {\n let node = document.createElement('div');\n let content = document.createElement('ul');\n content.className = 'lm-MenuBar-content';\n node.appendChild(content);\n content.setAttribute('role', 'menubar');\n return node;\n }\n\n /**\n * Position for the menu relative to top-left screen corner.\n */\n export interface IPosition {\n /**\n * Pixels right from screen origin.\n */\n left: number;\n /**\n * Pixels down from screen origin.\n */\n top: number;\n }\n\n /**\n * The results of a mnemonic search.\n */\n export interface IMnemonicResult {\n /**\n * The index of the first matching mnemonic item, or `-1`.\n */\n index: number;\n\n /**\n * Whether multiple mnemonic items matched.\n */\n multiple: boolean;\n\n /**\n * The index of the first auto matched non-mnemonic item.\n */\n auto: number;\n }\n\n /**\n * Find the best matching mnemonic item.\n *\n * The search starts at the given index and wraps around.\n */\n export function findMnemonic(\n menus: ReadonlyArray,\n key: string,\n start: number\n ): IMnemonicResult {\n // Setup the result variables.\n let index = -1;\n let auto = -1;\n let multiple = false;\n\n // Normalize the key to upper case.\n let upperKey = key.toUpperCase();\n\n // Search the items from the given start index.\n for (let i = 0, n = menus.length; i < n; ++i) {\n // Compute the wrapped index.\n let k = (i + start) % n;\n\n // Look up the menu title.\n let title = menus[k].title;\n\n // Ignore titles with an empty label.\n if (title.label.length === 0) {\n continue;\n }\n\n // Look up the mnemonic index for the label.\n let mn = title.mnemonic;\n\n // Handle a valid mnemonic index.\n if (mn >= 0 && mn < title.label.length) {\n if (title.label[mn].toUpperCase() === upperKey) {\n if (index === -1) {\n index = k;\n } else {\n multiple = true;\n }\n }\n continue;\n }\n\n // Finally, handle the auto index if possible.\n if (auto === -1 && title.label[0].toUpperCase() === upperKey) {\n auto = k;\n }\n }\n\n // Return the search results.\n return { index, multiple, auto };\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Drag } from '@lumino/dragdrop';\n\nimport { Message } from '@lumino/messaging';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { Widget } from './widget';\n\n/**\n * A widget which implements a canonical scroll bar.\n */\nexport class ScrollBar extends Widget {\n /**\n * Construct a new scroll bar.\n *\n * @param options - The options for initializing the scroll bar.\n */\n constructor(options: ScrollBar.IOptions = {}) {\n super({ node: Private.createNode() });\n this.addClass('lm-ScrollBar');\n this.setFlag(Widget.Flag.DisallowLayout);\n\n // Set the orientation.\n this._orientation = options.orientation || 'vertical';\n this.dataset['orientation'] = this._orientation;\n\n // Parse the rest of the options.\n if (options.maximum !== undefined) {\n this._maximum = Math.max(0, options.maximum);\n }\n if (options.page !== undefined) {\n this._page = Math.max(0, options.page);\n }\n if (options.value !== undefined) {\n this._value = Math.max(0, Math.min(options.value, this._maximum));\n }\n }\n\n /**\n * A signal emitted when the user moves the scroll thumb.\n *\n * #### Notes\n * The payload is the current value of the scroll bar.\n */\n get thumbMoved(): ISignal {\n return this._thumbMoved;\n }\n\n /**\n * A signal emitted when the user clicks a step button.\n *\n * #### Notes\n * The payload is whether a decrease or increase is requested.\n */\n get stepRequested(): ISignal {\n return this._stepRequested;\n }\n\n /**\n * A signal emitted when the user clicks the scroll track.\n *\n * #### Notes\n * The payload is whether a decrease or increase is requested.\n */\n get pageRequested(): ISignal {\n return this._pageRequested;\n }\n\n /**\n * Get the orientation of the scroll bar.\n */\n get orientation(): ScrollBar.Orientation {\n return this._orientation;\n }\n\n /**\n * Set the orientation of the scroll bar.\n */\n set orientation(value: ScrollBar.Orientation) {\n // Do nothing if the orientation does not change.\n if (this._orientation === value) {\n return;\n }\n\n // Release the mouse before making changes.\n this._releaseMouse();\n\n // Update the internal orientation.\n this._orientation = value;\n this.dataset['orientation'] = value;\n\n // Schedule an update the scroll bar.\n this.update();\n }\n\n /**\n * Get the current value of the scroll bar.\n */\n get value(): number {\n return this._value;\n }\n\n /**\n * Set the current value of the scroll bar.\n *\n * #### Notes\n * The value will be clamped to the range `[0, maximum]`.\n */\n set value(value: number) {\n // Clamp the value to the allowable range.\n value = Math.max(0, Math.min(value, this._maximum));\n\n // Do nothing if the value does not change.\n if (this._value === value) {\n return;\n }\n\n // Update the internal value.\n this._value = value;\n\n // Schedule an update the scroll bar.\n this.update();\n }\n\n /**\n * Get the page size of the scroll bar.\n *\n * #### Notes\n * The page size is the amount of visible content in the scrolled\n * region, expressed in data units. It determines the size of the\n * scroll bar thumb.\n */\n get page(): number {\n return this._page;\n }\n\n /**\n * Set the page size of the scroll bar.\n *\n * #### Notes\n * The page size will be clamped to the range `[0, Infinity]`.\n */\n set page(value: number) {\n // Clamp the page size to the allowable range.\n value = Math.max(0, value);\n\n // Do nothing if the value does not change.\n if (this._page === value) {\n return;\n }\n\n // Update the internal page size.\n this._page = value;\n\n // Schedule an update the scroll bar.\n this.update();\n }\n\n /**\n * Get the maximum value of the scroll bar.\n */\n get maximum(): number {\n return this._maximum;\n }\n\n /**\n * Set the maximum value of the scroll bar.\n *\n * #### Notes\n * The max size will be clamped to the range `[0, Infinity]`.\n */\n set maximum(value: number) {\n // Clamp the value to the allowable range.\n value = Math.max(0, value);\n\n // Do nothing if the value does not change.\n if (this._maximum === value) {\n return;\n }\n\n // Update the internal values.\n this._maximum = value;\n\n // Clamp the current value to the new range.\n this._value = Math.min(this._value, value);\n\n // Schedule an update the scroll bar.\n this.update();\n }\n\n /**\n * The scroll bar decrement button node.\n *\n * #### Notes\n * Modifying this node directly can lead to undefined behavior.\n */\n get decrementNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-ScrollBar-button'\n )[0] as HTMLDivElement;\n }\n\n /**\n * The scroll bar increment button node.\n *\n * #### Notes\n * Modifying this node directly can lead to undefined behavior.\n */\n get incrementNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-ScrollBar-button'\n )[1] as HTMLDivElement;\n }\n\n /**\n * The scroll bar track node.\n *\n * #### Notes\n * Modifying this node directly can lead to undefined behavior.\n */\n get trackNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-ScrollBar-track'\n )[0] as HTMLDivElement;\n }\n\n /**\n * The scroll bar thumb node.\n *\n * #### Notes\n * Modifying this node directly can lead to undefined behavior.\n */\n get thumbNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-ScrollBar-thumb'\n )[0] as HTMLDivElement;\n }\n\n /**\n * Handle the DOM events for the scroll bar.\n *\n * @param event - The DOM event sent to the scroll bar.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the scroll bar's DOM node.\n *\n * This should not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'mousedown':\n this._evtMouseDown(event as MouseEvent);\n break;\n case 'mousemove':\n this._evtMouseMove(event as MouseEvent);\n break;\n case 'mouseup':\n this._evtMouseUp(event as MouseEvent);\n break;\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A method invoked on a 'before-attach' message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('mousedown', this);\n this.update();\n }\n\n /**\n * A method invoked on an 'after-detach' message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('mousedown', this);\n this._releaseMouse();\n }\n\n /**\n * A method invoked on an 'update-request' message.\n */\n protected onUpdateRequest(msg: Message): void {\n // Convert the value and page into percentages.\n let value = (this._value * 100) / this._maximum;\n let page = (this._page * 100) / (this._page + this._maximum);\n\n // Clamp the value and page to the relevant range.\n value = Math.max(0, Math.min(value, 100));\n page = Math.max(0, Math.min(page, 100));\n\n // Fetch the thumb style.\n let thumbStyle = this.thumbNode.style;\n\n // Update the thumb style for the current orientation.\n if (this._orientation === 'horizontal') {\n thumbStyle.top = '';\n thumbStyle.height = '';\n thumbStyle.left = `${value}%`;\n thumbStyle.width = `${page}%`;\n thumbStyle.transform = `translate(${-value}%, 0%)`;\n } else {\n thumbStyle.left = '';\n thumbStyle.width = '';\n thumbStyle.top = `${value}%`;\n thumbStyle.height = `${page}%`;\n thumbStyle.transform = `translate(0%, ${-value}%)`;\n }\n }\n\n /**\n * Handle the `'keydown'` event for the scroll bar.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // Stop all input events during drag.\n event.preventDefault();\n event.stopPropagation();\n\n // Ignore anything except the `Escape` key.\n if (event.keyCode !== 27) {\n return;\n }\n\n // Fetch the previous scroll value.\n let value = this._pressData ? this._pressData.value : -1;\n\n // Release the mouse.\n this._releaseMouse();\n\n // Restore the old scroll value if possible.\n if (value !== -1) {\n this._moveThumb(value);\n }\n }\n\n /**\n * Handle the `'mousedown'` event for the scroll bar.\n */\n private _evtMouseDown(event: MouseEvent): void {\n // Do nothing if it's not a left mouse press.\n if (event.button !== 0) {\n return;\n }\n\n // Send an activate request to the scroll bar. This can be\n // used by message hooks to activate something relevant.\n this.activate();\n\n // Do nothing if the mouse is already captured.\n if (this._pressData) {\n return;\n }\n\n // Find the pressed scroll bar part.\n let part = Private.findPart(this, event.target as HTMLElement);\n\n // Do nothing if the part is not of interest.\n if (!part) {\n return;\n }\n\n // Stop the event propagation.\n event.preventDefault();\n event.stopPropagation();\n\n // Override the mouse cursor.\n let override = Drag.overrideCursor('default');\n\n // Set up the press data.\n this._pressData = {\n part,\n override,\n delta: -1,\n value: -1,\n mouseX: event.clientX,\n mouseY: event.clientY\n };\n\n // Add the extra event listeners.\n document.addEventListener('mousemove', this, true);\n document.addEventListener('mouseup', this, true);\n document.addEventListener('keydown', this, true);\n document.addEventListener('contextmenu', this, true);\n\n // Handle a thumb press.\n if (part === 'thumb') {\n // Fetch the thumb node.\n let thumbNode = this.thumbNode;\n\n // Fetch the client rect for the thumb.\n let thumbRect = thumbNode.getBoundingClientRect();\n\n // Update the press data delta for the current orientation.\n if (this._orientation === 'horizontal') {\n this._pressData.delta = event.clientX - thumbRect.left;\n } else {\n this._pressData.delta = event.clientY - thumbRect.top;\n }\n\n // Add the active class to the thumb node.\n thumbNode.classList.add('lm-mod-active');\n\n // Store the current value in the press data.\n this._pressData.value = this._value;\n\n // Finished.\n return;\n }\n\n // Handle a track press.\n if (part === 'track') {\n // Fetch the client rect for the thumb.\n let thumbRect = this.thumbNode.getBoundingClientRect();\n\n // Determine the direction for the page request.\n let dir: 'decrement' | 'increment';\n if (this._orientation === 'horizontal') {\n dir = event.clientX < thumbRect.left ? 'decrement' : 'increment';\n } else {\n dir = event.clientY < thumbRect.top ? 'decrement' : 'increment';\n }\n\n // Start the repeat timer.\n this._repeatTimer = window.setTimeout(this._onRepeat, 350);\n\n // Emit the page requested signal.\n this._pageRequested.emit(dir);\n\n // Finished.\n return;\n }\n\n // Handle a decrement button press.\n if (part === 'decrement') {\n // Add the active class to the decrement node.\n this.decrementNode.classList.add('lm-mod-active');\n\n // Start the repeat timer.\n this._repeatTimer = window.setTimeout(this._onRepeat, 350);\n\n // Emit the step requested signal.\n this._stepRequested.emit('decrement');\n\n // Finished.\n return;\n }\n\n // Handle an increment button press.\n if (part === 'increment') {\n // Add the active class to the increment node.\n this.incrementNode.classList.add('lm-mod-active');\n\n // Start the repeat timer.\n this._repeatTimer = window.setTimeout(this._onRepeat, 350);\n\n // Emit the step requested signal.\n this._stepRequested.emit('increment');\n\n // Finished.\n return;\n }\n }\n\n /**\n * Handle the `'mousemove'` event for the scroll bar.\n */\n private _evtMouseMove(event: MouseEvent): void {\n // Do nothing if no drag is in progress.\n if (!this._pressData) {\n return;\n }\n\n // Stop the event propagation.\n event.preventDefault();\n event.stopPropagation();\n\n // Update the mouse position.\n this._pressData.mouseX = event.clientX;\n this._pressData.mouseY = event.clientY;\n\n // Bail if the thumb is not being dragged.\n if (this._pressData.part !== 'thumb') {\n return;\n }\n\n // Get the client rect for the thumb and track.\n let thumbRect = this.thumbNode.getBoundingClientRect();\n let trackRect = this.trackNode.getBoundingClientRect();\n\n // Fetch the scroll geometry based on the orientation.\n let trackPos: number;\n let trackSpan: number;\n if (this._orientation === 'horizontal') {\n trackPos = event.clientX - trackRect.left - this._pressData.delta;\n trackSpan = trackRect.width - thumbRect.width;\n } else {\n trackPos = event.clientY - trackRect.top - this._pressData.delta;\n trackSpan = trackRect.height - thumbRect.height;\n }\n\n // Compute the desired value from the scroll geometry.\n let value = trackSpan === 0 ? 0 : (trackPos * this._maximum) / trackSpan;\n\n // Move the thumb to the computed value.\n this._moveThumb(value);\n }\n\n /**\n * Handle the `'mouseup'` event for the scroll bar.\n */\n private _evtMouseUp(event: MouseEvent): void {\n // Do nothing if it's not a left mouse release.\n if (event.button !== 0) {\n return;\n }\n\n // Stop the event propagation.\n event.preventDefault();\n event.stopPropagation();\n\n // Release the mouse.\n this._releaseMouse();\n }\n\n /**\n * Release the mouse and restore the node states.\n */\n private _releaseMouse(): void {\n // Bail if there is no press data.\n if (!this._pressData) {\n return;\n }\n\n // Clear the repeat timer.\n clearTimeout(this._repeatTimer);\n this._repeatTimer = -1;\n\n // Clear the press data.\n this._pressData.override.dispose();\n this._pressData = null;\n\n // Remove the extra event listeners.\n document.removeEventListener('mousemove', this, true);\n document.removeEventListener('mouseup', this, true);\n document.removeEventListener('keydown', this, true);\n document.removeEventListener('contextmenu', this, true);\n\n // Remove the active classes from the nodes.\n this.thumbNode.classList.remove('lm-mod-active');\n this.decrementNode.classList.remove('lm-mod-active');\n this.incrementNode.classList.remove('lm-mod-active');\n }\n\n /**\n * Move the thumb to the specified position.\n */\n private _moveThumb(value: number): void {\n // Clamp the value to the allowed range.\n value = Math.max(0, Math.min(value, this._maximum));\n\n // Bail if the value does not change.\n if (this._value === value) {\n return;\n }\n\n // Update the internal value.\n this._value = value;\n\n // Schedule an update of the scroll bar.\n this.update();\n\n // Emit the thumb moved signal.\n this._thumbMoved.emit(value);\n }\n\n /**\n * A timeout callback for repeating the mouse press.\n */\n private _onRepeat = () => {\n // Clear the repeat timer id.\n this._repeatTimer = -1;\n\n // Bail if the mouse has been released.\n if (!this._pressData) {\n return;\n }\n\n // Look up the part that was pressed.\n let part = this._pressData.part;\n\n // Bail if the thumb was pressed.\n if (part === 'thumb') {\n return;\n }\n\n // Schedule the timer for another repeat.\n this._repeatTimer = window.setTimeout(this._onRepeat, 20);\n\n // Get the current mouse position.\n let mouseX = this._pressData.mouseX;\n let mouseY = this._pressData.mouseY;\n\n // Handle a decrement button repeat.\n if (part === 'decrement') {\n // Bail if the mouse is not over the button.\n if (!ElementExt.hitTest(this.decrementNode, mouseX, mouseY)) {\n return;\n }\n\n // Emit the step requested signal.\n this._stepRequested.emit('decrement');\n\n // Finished.\n return;\n }\n\n // Handle an increment button repeat.\n if (part === 'increment') {\n // Bail if the mouse is not over the button.\n if (!ElementExt.hitTest(this.incrementNode, mouseX, mouseY)) {\n return;\n }\n\n // Emit the step requested signal.\n this._stepRequested.emit('increment');\n\n // Finished.\n return;\n }\n\n // Handle a track repeat.\n if (part === 'track') {\n // Bail if the mouse is not over the track.\n if (!ElementExt.hitTest(this.trackNode, mouseX, mouseY)) {\n return;\n }\n\n // Fetch the thumb node.\n let thumbNode = this.thumbNode;\n\n // Bail if the mouse is over the thumb.\n if (ElementExt.hitTest(thumbNode, mouseX, mouseY)) {\n return;\n }\n\n // Fetch the client rect for the thumb.\n let thumbRect = thumbNode.getBoundingClientRect();\n\n // Determine the direction for the page request.\n let dir: 'decrement' | 'increment';\n if (this._orientation === 'horizontal') {\n dir = mouseX < thumbRect.left ? 'decrement' : 'increment';\n } else {\n dir = mouseY < thumbRect.top ? 'decrement' : 'increment';\n }\n\n // Emit the page requested signal.\n this._pageRequested.emit(dir);\n\n // Finished.\n return;\n }\n };\n\n private _value = 0;\n private _page = 10;\n private _maximum = 100;\n private _repeatTimer = -1;\n private _orientation: ScrollBar.Orientation;\n private _pressData: Private.IPressData | null = null;\n private _thumbMoved = new Signal(this);\n private _stepRequested = new Signal(this);\n private _pageRequested = new Signal(this);\n}\n\n/**\n * The namespace for the `ScrollBar` class statics.\n */\nexport namespace ScrollBar {\n /**\n * A type alias for a scroll bar orientation.\n */\n export type Orientation = 'horizontal' | 'vertical';\n\n /**\n * An options object for creating a scroll bar.\n */\n export interface IOptions {\n /**\n * The orientation of the scroll bar.\n *\n * The default is `'vertical'`.\n */\n orientation?: Orientation;\n\n /**\n * The value for the scroll bar.\n *\n * The default is `0`.\n */\n value?: number;\n\n /**\n * The page size for the scroll bar.\n *\n * The default is `10`.\n */\n page?: number;\n\n /**\n * The maximum value for the scroll bar.\n *\n * The default is `100`.\n */\n maximum?: number;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * A type alias for the parts of a scroll bar.\n */\n export type ScrollBarPart = 'thumb' | 'track' | 'decrement' | 'increment';\n\n /**\n * An object which holds mouse press data.\n */\n export interface IPressData {\n /**\n * The scroll bar part which was pressed.\n */\n part: ScrollBarPart;\n\n /**\n * The offset of the press in thumb coordinates, or -1.\n */\n delta: number;\n\n /**\n * The scroll value at the time the thumb was pressed, or -1.\n */\n value: number;\n\n /**\n * The disposable which will clear the override cursor.\n */\n override: IDisposable;\n\n /**\n * The current X position of the mouse.\n */\n mouseX: number;\n\n /**\n * The current Y position of the mouse.\n */\n mouseY: number;\n }\n\n /**\n * Create the DOM node for a scroll bar.\n */\n export function createNode(): HTMLElement {\n let node = document.createElement('div');\n let decrement = document.createElement('div');\n let increment = document.createElement('div');\n let track = document.createElement('div');\n let thumb = document.createElement('div');\n decrement.className = 'lm-ScrollBar-button';\n increment.className = 'lm-ScrollBar-button';\n decrement.dataset['action'] = 'decrement';\n increment.dataset['action'] = 'increment';\n track.className = 'lm-ScrollBar-track';\n thumb.className = 'lm-ScrollBar-thumb';\n track.appendChild(thumb);\n node.appendChild(decrement);\n node.appendChild(track);\n node.appendChild(increment);\n return node;\n }\n\n /**\n * Find the scroll bar part which contains the given target.\n */\n export function findPart(\n scrollBar: ScrollBar,\n target: HTMLElement\n ): ScrollBarPart | null {\n // Test the thumb.\n if (scrollBar.thumbNode.contains(target)) {\n return 'thumb';\n }\n\n // Test the track.\n if (scrollBar.trackNode.contains(target)) {\n return 'track';\n }\n\n // Test the decrement button.\n if (scrollBar.decrementNode.contains(target)) {\n return 'decrement';\n }\n\n // Test the increment button.\n if (scrollBar.incrementNode.contains(target)) {\n return 'increment';\n }\n\n // Indicate no match.\n return null;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { MessageLoop } from '@lumino/messaging';\n\nimport { Layout } from './layout';\n\nimport { Widget } from './widget';\n\n/**\n * A concrete layout implementation which holds a single widget.\n *\n * #### Notes\n * This class is useful for creating simple container widgets which\n * hold a single child. The child should be positioned with CSS.\n */\nexport class SingletonLayout extends Layout {\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n if (this._widget) {\n let widget = this._widget;\n this._widget = null;\n widget.dispose();\n }\n super.dispose();\n }\n\n /**\n * Get the child widget for the layout.\n */\n get widget(): Widget | null {\n return this._widget;\n }\n\n /**\n * Set the child widget for the layout.\n *\n * #### Notes\n * Setting the child widget will cause the old child widget to be\n * automatically disposed. If that is not desired, set the parent\n * of the old child to `null` before assigning a new child.\n */\n set widget(widget: Widget | null) {\n // Remove the widget from its current parent. This is a no-op\n // if the widget's parent is already the layout parent widget.\n if (widget) {\n widget.parent = this.parent;\n }\n\n // Bail early if the widget does not change.\n if (this._widget === widget) {\n return;\n }\n\n // Dispose of the old child widget.\n if (this._widget) {\n this._widget.dispose();\n }\n\n // Update the internal widget.\n this._widget = widget;\n\n // Attach the new child widget if needed.\n if (this.parent && widget) {\n this.attachWidget(widget);\n }\n }\n\n /**\n * Create an iterator over the widgets in the layout.\n *\n * @returns A new iterator over the widgets in the layout.\n */\n *[Symbol.iterator](): IterableIterator {\n if (this._widget) {\n yield this._widget;\n }\n }\n\n /**\n * Remove a widget from the layout.\n *\n * @param widget - The widget to remove from the layout.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method does *not* modify the widget's `parent`.\n */\n removeWidget(widget: Widget): void {\n // Bail early if the widget does not exist in the layout.\n if (this._widget !== widget) {\n return;\n }\n\n // Clear the internal widget.\n this._widget = null;\n\n // If the layout is parented, detach the widget from the DOM.\n if (this.parent) {\n this.detachWidget(widget);\n }\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n super.init();\n for (const widget of this) {\n this.attachWidget(widget);\n }\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This method is called automatically by the single layout at the\n * appropriate time. It should not be called directly by user code.\n *\n * The default implementation adds the widgets's node to the parent's\n * node at the proper location, and sends the appropriate attach\n * messages to the widget if the parent is attached to the DOM.\n *\n * Subclasses may reimplement this method to control how the widget's\n * node is added to the parent's node.\n */\n protected attachWidget(widget: Widget): void {\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget's node to the parent.\n this.parent!.node.appendChild(widget.node);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This method is called automatically by the single layout at the\n * appropriate time. It should not be called directly by user code.\n *\n * The default implementation removes the widget's node from the\n * parent's node, and sends the appropriate detach messages to the\n * widget if the parent is attached to the DOM.\n *\n * Subclasses may reimplement this method to control how the widget's\n * node is removed from the parent's node.\n */\n protected detachWidget(widget: Widget): void {\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n }\n\n private _widget: Widget | null = null;\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { Layout, LayoutItem } from './layout';\n\nimport { PanelLayout } from './panellayout';\n\nimport { Widget } from './widget';\n\n/**\n * A layout where visible widgets are stacked atop one another.\n *\n * #### Notes\n * The Z-order of the visible widgets follows their layout order.\n */\nexport class StackedLayout extends PanelLayout {\n constructor(options: StackedLayout.IOptions = {}) {\n super(options);\n this._hiddenMode =\n options.hiddenMode !== undefined\n ? options.hiddenMode\n : Widget.HiddenMode.Display;\n }\n\n /**\n * The method for hiding widgets.\n *\n * #### Notes\n * If there is only one child widget, `Display` hiding mode will be used\n * regardless of this setting.\n */\n get hiddenMode(): Widget.HiddenMode {\n return this._hiddenMode;\n }\n\n /**\n * Set the method for hiding widgets.\n *\n * #### Notes\n * If there is only one child widget, `Display` hiding mode will be used\n * regardless of this setting.\n */\n set hiddenMode(v: Widget.HiddenMode) {\n if (this._hiddenMode === v) {\n return;\n }\n this._hiddenMode = v;\n if (this.widgets.length > 1) {\n this.widgets.forEach(w => {\n w.hiddenMode = this._hiddenMode;\n });\n }\n }\n\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n // Dispose of the layout items.\n for (const item of this._items) {\n item.dispose();\n }\n\n // Clear the layout state.\n this._box = null;\n this._items.length = 0;\n\n // Dispose of the rest of the layout.\n super.dispose();\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param index - The current index of the widget in the layout.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected attachWidget(index: number, widget: Widget): void {\n // Using transform create an additional layer in the pixel pipeline\n // to limit the number of layer, it is set only if there is more than one widget.\n if (\n this._hiddenMode === Widget.HiddenMode.Scale &&\n this._items.length > 0\n ) {\n if (this._items.length === 1) {\n this.widgets[0].hiddenMode = Widget.HiddenMode.Scale;\n }\n widget.hiddenMode = Widget.HiddenMode.Scale;\n } else {\n widget.hiddenMode = Widget.HiddenMode.Display;\n }\n\n // Create and add a new layout item for the widget.\n ArrayExt.insert(this._items, index, new LayoutItem(widget));\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget's node to the parent.\n this.parent!.node.appendChild(widget.node);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * Move a widget in the parent's DOM node.\n *\n * @param fromIndex - The previous index of the widget in the layout.\n *\n * @param toIndex - The current index of the widget in the layout.\n *\n * @param widget - The widget to move in the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected moveWidget(\n fromIndex: number,\n toIndex: number,\n widget: Widget\n ): void {\n // Move the layout item for the widget.\n ArrayExt.move(this._items, fromIndex, toIndex);\n\n // Post an update request for the parent widget.\n this.parent!.update();\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param index - The previous index of the widget in the layout.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected detachWidget(index: number, widget: Widget): void {\n // Remove the layout item for the widget.\n let item = ArrayExt.removeAt(this._items, index);\n\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Reset the z-index for the widget.\n item!.widget.node.style.zIndex = '';\n\n // Reset the hidden mode for the widget.\n if (this._hiddenMode === Widget.HiddenMode.Scale) {\n widget.hiddenMode = Widget.HiddenMode.Display;\n\n // Reset the hidden mode for the first widget if necessary.\n if (this._items.length === 1) {\n this._items[0].widget.hiddenMode = Widget.HiddenMode.Display;\n }\n }\n\n // Dispose of the layout item.\n item!.dispose();\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n */\n protected onBeforeShow(msg: Message): void {\n super.onBeforeShow(msg);\n this.parent!.update();\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n super.onBeforeAttach(msg);\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n if (this.parent!.isVisible) {\n this._update(msg.width, msg.height);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.parent!.isVisible) {\n this._update(-1, -1);\n }\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n */\n protected onFitRequest(msg: Message): void {\n if (this.parent!.isAttached) {\n this._fit();\n }\n }\n\n /**\n * Fit the layout to the total size required by the widgets.\n */\n private _fit(): void {\n // Set up the computed minimum size.\n let minW = 0;\n let minH = 0;\n\n // Update the computed minimum size.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item.\n let item = this._items[i];\n\n // Ignore hidden items.\n if (item.isHidden) {\n continue;\n }\n\n // Update the size limits for the item.\n item.fit();\n\n // Update the computed minimum size.\n minW = Math.max(minW, item.minWidth);\n minH = Math.max(minH, item.minHeight);\n }\n\n // Update the box sizing and add it to the computed min size.\n let box = (this._box = ElementExt.boxSizing(this.parent!.node));\n minW += box.horizontalSum;\n minH += box.verticalSum;\n\n // Update the parent's min size constraints.\n let style = this.parent!.node.style;\n style.minWidth = `${minW}px`;\n style.minHeight = `${minH}px`;\n\n // Set the dirty flag to ensure only a single update occurs.\n this._dirty = true;\n\n // Notify the ancestor that it should fit immediately. This may\n // cause a resize of the parent, fulfilling the required update.\n if (this.parent!.parent) {\n MessageLoop.sendMessage(this.parent!.parent!, Widget.Msg.FitRequest);\n }\n\n // If the dirty flag is still set, the parent was not resized.\n // Trigger the required update on the parent widget immediately.\n if (this._dirty) {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n }\n }\n\n /**\n * Update the layout position and size of the widgets.\n *\n * The parent offset dimensions should be `-1` if unknown.\n */\n private _update(offsetWidth: number, offsetHeight: number): void {\n // Clear the dirty flag to indicate the update occurred.\n this._dirty = false;\n\n // Compute the visible item count.\n let nVisible = 0;\n for (let i = 0, n = this._items.length; i < n; ++i) {\n nVisible += +!this._items[i].isHidden;\n }\n\n // Bail early if there are no visible items to layout.\n if (nVisible === 0) {\n return;\n }\n\n // Measure the parent if the offset dimensions are unknown.\n if (offsetWidth < 0) {\n offsetWidth = this.parent!.node.offsetWidth;\n }\n if (offsetHeight < 0) {\n offsetHeight = this.parent!.node.offsetHeight;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent!.node);\n }\n\n // Compute the actual layout bounds adjusted for border and padding.\n let top = this._box.paddingTop;\n let left = this._box.paddingLeft;\n let width = offsetWidth - this._box.horizontalSum;\n let height = offsetHeight - this._box.verticalSum;\n\n // Update the widget stacking order and layout geometry.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item.\n let item = this._items[i];\n\n // Ignore hidden items.\n if (item.isHidden) {\n continue;\n }\n\n // Set the z-index for the widget.\n item.widget.node.style.zIndex = `${i}`;\n\n // Update the item geometry.\n item.update(left, top, width, height);\n }\n }\n\n private _dirty = false;\n private _items: LayoutItem[] = [];\n private _box: ElementExt.IBoxSizing | null = null;\n private _hiddenMode: Widget.HiddenMode;\n}\n\n/**\n * The namespace for the `StackedLayout` class statics.\n */\nexport namespace StackedLayout {\n /**\n * An options object for initializing a stacked layout.\n */\n export interface IOptions extends Layout.IOptions {\n /**\n * The method for hiding widgets.\n *\n * The default is `Widget.HiddenMode.Display`.\n */\n hiddenMode?: Widget.HiddenMode;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { Panel } from './panel';\n\nimport { StackedLayout } from './stackedlayout';\n\nimport { Widget } from './widget';\n\n/**\n * A panel where visible widgets are stacked atop one another.\n *\n * #### Notes\n * This class provides a convenience wrapper around a {@link StackedLayout}.\n */\nexport class StackedPanel extends Panel {\n /**\n * Construct a new stacked panel.\n *\n * @param options - The options for initializing the panel.\n */\n constructor(options: StackedPanel.IOptions = {}) {\n super({ layout: Private.createLayout(options) });\n this.addClass('lm-StackedPanel');\n }\n\n /**\n * The method for hiding widgets.\n *\n * #### Notes\n * If there is only one child widget, `Display` hiding mode will be used\n * regardless of this setting.\n */\n get hiddenMode(): Widget.HiddenMode {\n return (this.layout as StackedLayout).hiddenMode;\n }\n\n /**\n * Set the method for hiding widgets.\n *\n * #### Notes\n * If there is only one child widget, `Display` hiding mode will be used\n * regardless of this setting.\n */\n set hiddenMode(v: Widget.HiddenMode) {\n (this.layout as StackedLayout).hiddenMode = v;\n }\n\n /**\n * A signal emitted when a widget is removed from a stacked panel.\n */\n get widgetRemoved(): ISignal {\n return this._widgetRemoved;\n }\n\n /**\n * A message handler invoked on a `'child-added'` message.\n */\n protected onChildAdded(msg: Widget.ChildMessage): void {\n msg.child.addClass('lm-StackedPanel-child');\n }\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {\n msg.child.removeClass('lm-StackedPanel-child');\n this._widgetRemoved.emit(msg.child);\n }\n\n private _widgetRemoved = new Signal(this);\n}\n\n/**\n * The namespace for the `StackedPanel` class statics.\n */\nexport namespace StackedPanel {\n /**\n * An options object for creating a stacked panel.\n */\n export interface IOptions {\n /**\n * The stacked layout to use for the stacked panel.\n *\n * The default is a new `StackedLayout`.\n */\n layout?: StackedLayout;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Create a stacked layout for the given panel options.\n */\n export function createLayout(options: StackedPanel.IOptions): StackedLayout {\n return options.layout || new StackedLayout();\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { Platform } from '@lumino/domutils';\n\nimport { MessageLoop } from '@lumino/messaging';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { BoxLayout } from './boxlayout';\n\nimport { StackedPanel } from './stackedpanel';\n\nimport { TabBar } from './tabbar';\n\nimport { Widget } from './widget';\n\n/**\n * A widget which combines a `TabBar` and a `StackedPanel`.\n *\n * #### Notes\n * This is a simple panel which handles the common case of a tab bar\n * placed next to a content area. The selected tab controls the widget\n * which is shown in the content area.\n *\n * For use cases which require more control than is provided by this\n * panel, the `TabBar` widget may be used independently.\n */\nexport class TabPanel extends Widget {\n /**\n * Construct a new tab panel.\n *\n * @param options - The options for initializing the tab panel.\n */\n constructor(options: TabPanel.IOptions = {}) {\n super();\n this.addClass('lm-TabPanel');\n\n // Create the tab bar and stacked panel.\n this.tabBar = new TabBar(options);\n this.tabBar.addClass('lm-TabPanel-tabBar');\n this.stackedPanel = new StackedPanel();\n this.stackedPanel.addClass('lm-TabPanel-stackedPanel');\n\n // Connect the tab bar signal handlers.\n this.tabBar.tabMoved.connect(this._onTabMoved, this);\n this.tabBar.currentChanged.connect(this._onCurrentChanged, this);\n this.tabBar.tabCloseRequested.connect(this._onTabCloseRequested, this);\n this.tabBar.tabActivateRequested.connect(\n this._onTabActivateRequested,\n this\n );\n this.tabBar.addRequested.connect(this._onTabAddRequested, this);\n\n // Connect the stacked panel signal handlers.\n this.stackedPanel.widgetRemoved.connect(this._onWidgetRemoved, this);\n\n // Get the data related to the placement.\n this._tabPlacement = options.tabPlacement || 'top';\n let direction = Private.directionFromPlacement(this._tabPlacement);\n let orientation = Private.orientationFromPlacement(this._tabPlacement);\n\n // Configure the tab bar for the placement.\n this.tabBar.orientation = orientation;\n this.tabBar.dataset['placement'] = this._tabPlacement;\n\n // Create the box layout.\n let layout = new BoxLayout({ direction, spacing: 0 });\n\n // Set the stretch factors for the child widgets.\n BoxLayout.setStretch(this.tabBar, 0);\n BoxLayout.setStretch(this.stackedPanel, 1);\n\n // Add the child widgets to the layout.\n layout.addWidget(this.tabBar);\n layout.addWidget(this.stackedPanel);\n\n // Install the layout on the tab panel.\n this.layout = layout;\n }\n\n /**\n * A signal emitted when the current tab is changed.\n *\n * #### Notes\n * This signal is emitted when the currently selected tab is changed\n * either through user or programmatic interaction.\n *\n * Notably, this signal is not emitted when the index of the current\n * tab changes due to tabs being inserted, removed, or moved. It is\n * only emitted when the actual current tab node is changed.\n */\n get currentChanged(): ISignal {\n return this._currentChanged;\n }\n\n /**\n * Get the index of the currently selected tab.\n *\n * #### Notes\n * This will be `-1` if no tab is selected.\n */\n get currentIndex(): number {\n return this.tabBar.currentIndex;\n }\n\n /**\n * Set the index of the currently selected tab.\n *\n * #### Notes\n * If the index is out of range, it will be set to `-1`.\n */\n set currentIndex(value: number) {\n this.tabBar.currentIndex = value;\n }\n\n /**\n * Get the currently selected widget.\n *\n * #### Notes\n * This will be `null` if there is no selected tab.\n */\n get currentWidget(): Widget | null {\n let title = this.tabBar.currentTitle;\n return title ? title.owner : null;\n }\n\n /**\n * Set the currently selected widget.\n *\n * #### Notes\n * If the widget is not in the panel, it will be set to `null`.\n */\n set currentWidget(value: Widget | null) {\n this.tabBar.currentTitle = value ? value.title : null;\n }\n\n /**\n * Get the whether the tabs are movable by the user.\n *\n * #### Notes\n * Tabs can always be moved programmatically.\n */\n get tabsMovable(): boolean {\n return this.tabBar.tabsMovable;\n }\n\n /**\n * Set the whether the tabs are movable by the user.\n *\n * #### Notes\n * Tabs can always be moved programmatically.\n */\n set tabsMovable(value: boolean) {\n this.tabBar.tabsMovable = value;\n }\n\n /**\n * Get the whether the add button is enabled.\n *\n */\n get addButtonEnabled(): boolean {\n return this.tabBar.addButtonEnabled;\n }\n\n /**\n * Set the whether the add button is enabled.\n *\n */\n set addButtonEnabled(value: boolean) {\n this.tabBar.addButtonEnabled = value;\n }\n\n /**\n * Get the tab placement for the tab panel.\n *\n * #### Notes\n * This controls the position of the tab bar relative to the content.\n */\n get tabPlacement(): TabPanel.TabPlacement {\n return this._tabPlacement;\n }\n\n /**\n * Set the tab placement for the tab panel.\n *\n * #### Notes\n * This controls the position of the tab bar relative to the content.\n */\n set tabPlacement(value: TabPanel.TabPlacement) {\n // Bail if the placement does not change.\n if (this._tabPlacement === value) {\n return;\n }\n\n // Update the internal value.\n this._tabPlacement = value;\n\n // Get the values related to the placement.\n let direction = Private.directionFromPlacement(value);\n let orientation = Private.orientationFromPlacement(value);\n\n // Configure the tab bar for the placement.\n this.tabBar.orientation = orientation;\n this.tabBar.dataset['placement'] = value;\n\n // Update the layout direction.\n (this.layout as BoxLayout).direction = direction;\n }\n\n /**\n * A signal emitted when the add button on a tab bar is clicked.\n *\n */\n get addRequested(): ISignal> {\n return this._addRequested;\n }\n\n /**\n * The tab bar used by the tab panel.\n *\n * #### Notes\n * Modifying the tab bar directly can lead to undefined behavior.\n */\n readonly tabBar: TabBar;\n\n /**\n * The stacked panel used by the tab panel.\n *\n * #### Notes\n * Modifying the panel directly can lead to undefined behavior.\n */\n readonly stackedPanel: StackedPanel;\n\n /**\n * A read-only array of the widgets in the panel.\n */\n get widgets(): ReadonlyArray {\n return this.stackedPanel.widgets;\n }\n\n /**\n * Add a widget to the end of the tab panel.\n *\n * @param widget - The widget to add to the tab panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n *\n * The widget's `title` is used to populate the tab.\n */\n addWidget(widget: Widget): void {\n this.insertWidget(this.widgets.length, widget);\n }\n\n /**\n * Insert a widget into the tab panel at a specified index.\n *\n * @param index - The index at which to insert the widget.\n *\n * @param widget - The widget to insert into to the tab panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n *\n * The widget's `title` is used to populate the tab.\n */\n insertWidget(index: number, widget: Widget): void {\n if (widget !== this.currentWidget) {\n widget.hide();\n }\n this.stackedPanel.insertWidget(index, widget);\n this.tabBar.insertTab(index, widget.title);\n\n widget.node.setAttribute('role', 'tabpanel');\n\n let renderer = this.tabBar.renderer;\n if (renderer instanceof TabBar.Renderer) {\n let tabId = renderer.createTabKey({\n title: widget.title,\n current: false,\n zIndex: 0\n });\n widget.node.setAttribute('aria-labelledby', tabId);\n }\n }\n\n /**\n * Handle the `currentChanged` signal from the tab bar.\n */\n private _onCurrentChanged(\n sender: TabBar,\n args: TabBar.ICurrentChangedArgs\n ): void {\n // Extract the previous and current title from the args.\n let { previousIndex, previousTitle, currentIndex, currentTitle } = args;\n\n // Extract the widgets from the titles.\n let previousWidget = previousTitle ? previousTitle.owner : null;\n let currentWidget = currentTitle ? currentTitle.owner : null;\n\n // Hide the previous widget.\n if (previousWidget) {\n previousWidget.hide();\n }\n\n // Show the current widget.\n if (currentWidget) {\n currentWidget.show();\n }\n\n // Emit the `currentChanged` signal for the tab panel.\n this._currentChanged.emit({\n previousIndex,\n previousWidget,\n currentIndex,\n currentWidget\n });\n\n // Flush the message loop on IE and Edge to prevent flicker.\n if (Platform.IS_EDGE || Platform.IS_IE) {\n MessageLoop.flush();\n }\n }\n\n /**\n * Handle the `tabAddRequested` signal from the tab bar.\n */\n private _onTabAddRequested(sender: TabBar, args: void): void {\n this._addRequested.emit(sender);\n }\n\n /**\n * Handle the `tabActivateRequested` signal from the tab bar.\n */\n private _onTabActivateRequested(\n sender: TabBar,\n args: TabBar.ITabActivateRequestedArgs\n ): void {\n args.title.owner.activate();\n }\n\n /**\n * Handle the `tabCloseRequested` signal from the tab bar.\n */\n private _onTabCloseRequested(\n sender: TabBar,\n args: TabBar.ITabCloseRequestedArgs\n ): void {\n args.title.owner.close();\n }\n\n /**\n * Handle the `tabMoved` signal from the tab bar.\n */\n private _onTabMoved(\n sender: TabBar,\n args: TabBar.ITabMovedArgs\n ): void {\n this.stackedPanel.insertWidget(args.toIndex, args.title.owner);\n }\n\n /**\n * Handle the `widgetRemoved` signal from the stacked panel.\n */\n private _onWidgetRemoved(sender: StackedPanel, widget: Widget): void {\n widget.node.removeAttribute('role');\n widget.node.removeAttribute('aria-labelledby');\n this.tabBar.removeTab(widget.title);\n }\n\n private _tabPlacement: TabPanel.TabPlacement;\n private _currentChanged = new Signal(\n this\n );\n\n private _addRequested = new Signal>(this);\n}\n\n/**\n * The namespace for the `TabPanel` class statics.\n */\nexport namespace TabPanel {\n /**\n * A type alias for tab placement in a tab bar.\n */\n export type TabPlacement =\n | /**\n * The tabs are placed as a row above the content.\n */\n 'top'\n\n /**\n * The tabs are placed as a column to the left of the content.\n */\n | 'left'\n\n /**\n * The tabs are placed as a column to the right of the content.\n */\n | 'right'\n\n /**\n * The tabs are placed as a row below the content.\n */\n | 'bottom';\n\n /**\n * An options object for initializing a tab panel.\n */\n export interface IOptions {\n /**\n * The document to use with the tab panel.\n *\n * The default is the global `document` instance.\n */\n document?: Document | ShadowRoot;\n\n /**\n * Whether the tabs are movable by the user.\n *\n * The default is `false`.\n */\n tabsMovable?: boolean;\n\n /**\n * Whether the button to add new tabs is enabled.\n *\n * The default is `false`.\n */\n addButtonEnabled?: boolean;\n\n /**\n * The placement of the tab bar relative to the content.\n *\n * The default is `'top'`.\n */\n tabPlacement?: TabPlacement;\n\n /**\n * The renderer for the panel's tab bar.\n *\n * The default is a shared renderer instance.\n */\n renderer?: TabBar.IRenderer;\n }\n\n /**\n * The arguments object for the `currentChanged` signal.\n */\n export interface ICurrentChangedArgs {\n /**\n * The previously selected index.\n */\n previousIndex: number;\n\n /**\n * The previously selected widget.\n */\n previousWidget: Widget | null;\n\n /**\n * The currently selected index.\n */\n currentIndex: number;\n\n /**\n * The currently selected widget.\n */\n currentWidget: Widget | null;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Convert a tab placement to tab bar orientation.\n */\n export function orientationFromPlacement(\n plc: TabPanel.TabPlacement\n ): TabBar.Orientation {\n return placementToOrientationMap[plc];\n }\n\n /**\n * Convert a tab placement to a box layout direction.\n */\n export function directionFromPlacement(\n plc: TabPanel.TabPlacement\n ): BoxLayout.Direction {\n return placementToDirectionMap[plc];\n }\n\n /**\n * A mapping of tab placement to tab bar orientation.\n */\n const placementToOrientationMap: { [key: string]: TabBar.Orientation } = {\n top: 'horizontal',\n left: 'vertical',\n right: 'vertical',\n bottom: 'horizontal'\n };\n\n /**\n * A mapping of tab placement to box layout direction.\n */\n const placementToDirectionMap: { [key: string]: BoxLayout.Direction } = {\n top: 'top-to-bottom',\n left: 'left-to-right',\n right: 'right-to-left',\n bottom: 'bottom-to-top'\n };\n}\n"],"names":["Private","Utils"],"mappings":"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"} +\ No newline at end of file +diff --git a/node_modules/@lumino/widgets/dist/index.js b/node_modules/@lumino/widgets/dist/index.js +index 89799d1..f50f43a 100644 +--- a/node_modules/@lumino/widgets/dist/index.js ++++ b/node_modules/@lumino/widgets/dist/index.js +@@ -6521,7 +6521,7 @@ + this.node.addEventListener('mouseenter', this); + this.node.addEventListener('mouseleave', this); + this.node.addEventListener('contextmenu', this); +- document.addEventListener('mousedown', this, true); ++ this.node.ownerDocument.addEventListener('mousedown', this, true); + } + /** + * A message handler invoked on an `'after-detach'` message. +@@ -6533,7 +6533,7 @@ + this.node.removeEventListener('mouseenter', this); + this.node.removeEventListener('mouseleave', this); + this.node.removeEventListener('contextmenu', this); +- document.removeEventListener('mousedown', this, true); ++ this.node.ownerDocument.removeEventListener('mousedown', this, true); + } + /** + * A message handler invoked on an `'activate-request'` message. +@@ -7299,7 +7299,7 @@ + style.opacity = '0'; + style.maxHeight = `${maxHeight}px`; + // Attach the menu to the document. +- Widget.attach(submenu, document.body); ++ Widget.attach(submenu, itemNode.ownerDocument.body); + // Measure the size of the menu. + let { width, height } = node.getBoundingClientRect(); + // Compute the box sizing for the menu. +@@ -13192,10 +13192,6 @@ + if (value < 0 || value >= this._menus.length) { + value = -1; + } +- // An empty menu cannot be active +- if (value > -1 && this._menus[value].items.length === 0) { +- value = -1; +- } + // Bail early if the index will not change. + if (this._activeIndex === value) { + return; +diff --git a/node_modules/@lumino/widgets/dist/index.js.map b/node_modules/@lumino/widgets/dist/index.js.map +index 47394ea..105a520 100644 +--- a/node_modules/@lumino/widgets/dist/index.js.map ++++ b/node_modules/@lumino/widgets/dist/index.js.map +@@ -1 +1 @@ +-{"version":3,"file":"index.js","sources":["../src/boxengine.ts","../src/title.ts","../src/widget.ts","../src/layout.ts","../src/panellayout.ts","../src/utils.ts","../src/splitlayout.ts","../src/accordionlayout.ts","../src/panel.ts","../src/splitpanel.ts","../src/accordionpanel.ts","../src/boxlayout.ts","../src/boxpanel.ts","../src/commandpalette.ts","../src/menu.ts","../src/contextmenu.ts","../src/tabbar.ts","../src/docklayout.ts","../src/dockpanel.ts","../src/focustracker.ts","../src/gridlayout.ts","../src/menubar.ts","../src/scrollbar.ts","../src/singletonlayout.ts","../src/stackedlayout.ts","../src/stackedpanel.ts","../src/tabpanel.ts"],"sourcesContent":["// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\n\n/**\n * A sizer object for use with the box engine layout functions.\n *\n * #### Notes\n * A box sizer holds the geometry information for an object along an\n * arbitrary layout orientation.\n *\n * For best performance, this class should be treated as a raw data\n * struct. It should not typically be subclassed.\n */\nexport class BoxSizer {\n /**\n * The preferred size for the sizer.\n *\n * #### Notes\n * The sizer will be given this initial size subject to its size\n * bounds. The sizer will not deviate from this size unless such\n * deviation is required to fit into the available layout space.\n *\n * There is no limit to this value, but it will be clamped to the\n * bounds defined by {@link minSize} and {@link maxSize}.\n *\n * The default value is `0`.\n */\n sizeHint = 0;\n\n /**\n * The minimum size of the sizer.\n *\n * #### Notes\n * The sizer will never be sized less than this value, even if\n * it means the sizer will overflow the available layout space.\n *\n * It is assumed that this value lies in the range `[0, Infinity)`\n * and that it is `<=` to {@link maxSize}. Failure to adhere to this\n * constraint will yield undefined results.\n *\n * The default value is `0`.\n */\n minSize = 0;\n\n /**\n * The maximum size of the sizer.\n *\n * #### Notes\n * The sizer will never be sized greater than this value, even if\n * it means the sizer will underflow the available layout space.\n *\n * It is assumed that this value lies in the range `[0, Infinity]`\n * and that it is `>=` to {@link minSize}. Failure to adhere to this\n * constraint will yield undefined results.\n *\n * The default value is `Infinity`.\n */\n maxSize = Infinity;\n\n /**\n * The stretch factor for the sizer.\n *\n * #### Notes\n * This controls how much the sizer stretches relative to its sibling\n * sizers when layout space is distributed. A stretch factor of zero\n * is special and will cause the sizer to only be resized after all\n * other sizers with a stretch factor greater than zero have been\n * resized to their limits.\n *\n * It is assumed that this value is an integer that lies in the range\n * `[0, Infinity)`. Failure to adhere to this constraint will yield\n * undefined results.\n *\n * The default value is `1`.\n */\n stretch = 1;\n\n /**\n * The computed size of the sizer.\n *\n * #### Notes\n * This value is the output of a call to {@link BoxEngine.calc}. It represents\n * the computed size for the object along the layout orientation,\n * and will always lie in the range `[minSize, maxSize]`.\n *\n * This value is output only.\n *\n * Changing this value will have no effect.\n */\n size = 0;\n\n /**\n * An internal storage property for the layout algorithm.\n *\n * #### Notes\n * This value is used as temporary storage by the layout algorithm.\n *\n * Changing this value will have no effect.\n */\n done = false;\n}\n\n/**\n * The namespace for the box engine layout functions.\n */\nexport namespace BoxEngine {\n /**\n * Calculate the optimal layout sizes for a sequence of box sizers.\n *\n * This distributes the available layout space among the box sizers\n * according to the following algorithm:\n *\n * 1. Initialize the sizers's size to its size hint and compute the\n * sums for each of size hint, min size, and max size.\n *\n * 2. If the total size hint equals the available space, return.\n *\n * 3. If the available space is less than the total min size, set all\n * sizers to their min size and return.\n *\n * 4. If the available space is greater than the total max size, set\n * all sizers to their max size and return.\n *\n * 5. If the layout space is less than the total size hint, distribute\n * the negative delta as follows:\n *\n * a. Shrink each sizer with a stretch factor greater than zero by\n * an amount proportional to the negative space and the sum of\n * stretch factors. If the sizer reaches its min size, remove\n * it and its stretch factor from the computation.\n *\n * b. If after adjusting all stretch sizers there remains negative\n * space, distribute the space equally among the sizers with a\n * stretch factor of zero. If a sizer reaches its min size,\n * remove it from the computation.\n *\n * 6. If the layout space is greater than the total size hint,\n * distribute the positive delta as follows:\n *\n * a. Expand each sizer with a stretch factor greater than zero by\n * an amount proportional to the postive space and the sum of\n * stretch factors. If the sizer reaches its max size, remove\n * it and its stretch factor from the computation.\n *\n * b. If after adjusting all stretch sizers there remains positive\n * space, distribute the space equally among the sizers with a\n * stretch factor of zero. If a sizer reaches its max size,\n * remove it from the computation.\n *\n * 7. return\n *\n * @param sizers - The sizers for a particular layout line.\n *\n * @param space - The available layout space for the sizers.\n *\n * @returns The delta between the provided available space and the\n * actual consumed space. This value will be zero if the sizers\n * can be adjusted to fit, negative if the available space is too\n * small, and positive if the available space is too large.\n *\n * #### Notes\n * The {@link BoxSizer.size} of each sizer is updated with the computed size.\n *\n * This function can be called at any time to recompute the layout for\n * an existing sequence of sizers. The previously computed results will\n * have no effect on the new output. It is therefore not necessary to\n * create new sizer objects on each resize event.\n */\n export function calc(sizers: ArrayLike, space: number): number {\n // Bail early if there is nothing to do.\n let count = sizers.length;\n if (count === 0) {\n return space;\n }\n\n // Setup the size and stretch counters.\n let totalMin = 0;\n let totalMax = 0;\n let totalSize = 0;\n let totalStretch = 0;\n let stretchCount = 0;\n\n // Setup the sizers and compute the totals.\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n let min = sizer.minSize;\n let max = sizer.maxSize;\n let hint = sizer.sizeHint;\n sizer.done = false;\n sizer.size = Math.max(min, Math.min(hint, max));\n totalSize += sizer.size;\n totalMin += min;\n totalMax += max;\n if (sizer.stretch > 0) {\n totalStretch += sizer.stretch;\n stretchCount++;\n }\n }\n\n // If the space is equal to the total size, return early.\n if (space === totalSize) {\n return 0;\n }\n\n // If the space is less than the total min, minimize each sizer.\n if (space <= totalMin) {\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n sizer.size = sizer.minSize;\n }\n return space - totalMin;\n }\n\n // If the space is greater than the total max, maximize each sizer.\n if (space >= totalMax) {\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n sizer.size = sizer.maxSize;\n }\n return space - totalMax;\n }\n\n // The loops below perform sub-pixel precision sizing. A near zero\n // value is used for compares instead of zero to ensure that the\n // loop terminates when the subdivided space is reasonably small.\n let nearZero = 0.01;\n\n // A counter which is decremented each time a sizer is resized to\n // its limit. This ensures the loops terminate even if there is\n // space remaining to distribute.\n let notDoneCount = count;\n\n // Distribute negative delta space.\n if (space < totalSize) {\n // Shrink each stretchable sizer by an amount proportional to its\n // stretch factor. If a sizer reaches its min size it's marked as\n // done. The loop progresses in phases where each sizer is given\n // a chance to consume its fair share for the pass, regardless of\n // whether a sizer before it reached its limit. This continues\n // until the stretchable sizers or the free space is exhausted.\n let freeSpace = totalSize - space;\n while (stretchCount > 0 && freeSpace > nearZero) {\n let distSpace = freeSpace;\n let distStretch = totalStretch;\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n if (sizer.done || sizer.stretch === 0) {\n continue;\n }\n let amt = (sizer.stretch * distSpace) / distStretch;\n if (sizer.size - amt <= sizer.minSize) {\n freeSpace -= sizer.size - sizer.minSize;\n totalStretch -= sizer.stretch;\n sizer.size = sizer.minSize;\n sizer.done = true;\n notDoneCount--;\n stretchCount--;\n } else {\n freeSpace -= amt;\n sizer.size -= amt;\n }\n }\n }\n // Distribute any remaining space evenly among the non-stretchable\n // sizers. This progresses in phases in the same manner as above.\n while (notDoneCount > 0 && freeSpace > nearZero) {\n let amt = freeSpace / notDoneCount;\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n if (sizer.done) {\n continue;\n }\n if (sizer.size - amt <= sizer.minSize) {\n freeSpace -= sizer.size - sizer.minSize;\n sizer.size = sizer.minSize;\n sizer.done = true;\n notDoneCount--;\n } else {\n freeSpace -= amt;\n sizer.size -= amt;\n }\n }\n }\n }\n // Distribute positive delta space.\n else {\n // Expand each stretchable sizer by an amount proportional to its\n // stretch factor. If a sizer reaches its max size it's marked as\n // done. The loop progresses in phases where each sizer is given\n // a chance to consume its fair share for the pass, regardless of\n // whether a sizer before it reached its limit. This continues\n // until the stretchable sizers or the free space is exhausted.\n let freeSpace = space - totalSize;\n while (stretchCount > 0 && freeSpace > nearZero) {\n let distSpace = freeSpace;\n let distStretch = totalStretch;\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n if (sizer.done || sizer.stretch === 0) {\n continue;\n }\n let amt = (sizer.stretch * distSpace) / distStretch;\n if (sizer.size + amt >= sizer.maxSize) {\n freeSpace -= sizer.maxSize - sizer.size;\n totalStretch -= sizer.stretch;\n sizer.size = sizer.maxSize;\n sizer.done = true;\n notDoneCount--;\n stretchCount--;\n } else {\n freeSpace -= amt;\n sizer.size += amt;\n }\n }\n }\n // Distribute any remaining space evenly among the non-stretchable\n // sizers. This progresses in phases in the same manner as above.\n while (notDoneCount > 0 && freeSpace > nearZero) {\n let amt = freeSpace / notDoneCount;\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n if (sizer.done) {\n continue;\n }\n if (sizer.size + amt >= sizer.maxSize) {\n freeSpace -= sizer.maxSize - sizer.size;\n sizer.size = sizer.maxSize;\n sizer.done = true;\n notDoneCount--;\n } else {\n freeSpace -= amt;\n sizer.size += amt;\n }\n }\n }\n }\n\n // Indicate that the consumed space equals the available space.\n return 0;\n }\n\n /**\n * Adjust a sizer by a delta and update its neighbors accordingly.\n *\n * @param sizers - The sizers which should be adjusted.\n *\n * @param index - The index of the sizer to grow.\n *\n * @param delta - The amount to adjust the sizer, positive or negative.\n *\n * #### Notes\n * This will adjust the indicated sizer by the specified amount, along\n * with the sizes of the appropriate neighbors, subject to the limits\n * specified by each of the sizers.\n *\n * This is useful when implementing box layouts where the boundaries\n * between the sizers are interactively adjustable by the user.\n */\n export function adjust(\n sizers: ArrayLike,\n index: number,\n delta: number\n ): void {\n // Bail early when there is nothing to do.\n if (sizers.length === 0 || delta === 0) {\n return;\n }\n\n // Dispatch to the proper implementation.\n if (delta > 0) {\n growSizer(sizers, index, delta);\n } else {\n shrinkSizer(sizers, index, -delta);\n }\n }\n\n /**\n * Grow a sizer by a positive delta and adjust neighbors.\n */\n function growSizer(\n sizers: ArrayLike,\n index: number,\n delta: number\n ): void {\n // Compute how much the items to the left can expand.\n let growLimit = 0;\n for (let i = 0; i <= index; ++i) {\n let sizer = sizers[i];\n growLimit += sizer.maxSize - sizer.size;\n }\n\n // Compute how much the items to the right can shrink.\n let shrinkLimit = 0;\n for (let i = index + 1, n = sizers.length; i < n; ++i) {\n let sizer = sizers[i];\n shrinkLimit += sizer.size - sizer.minSize;\n }\n\n // Clamp the delta adjustment to the limits.\n delta = Math.min(delta, growLimit, shrinkLimit);\n\n // Grow the sizers to the left by the delta.\n let grow = delta;\n for (let i = index; i >= 0 && grow > 0; --i) {\n let sizer = sizers[i];\n let limit = sizer.maxSize - sizer.size;\n if (limit >= grow) {\n sizer.sizeHint = sizer.size + grow;\n grow = 0;\n } else {\n sizer.sizeHint = sizer.size + limit;\n grow -= limit;\n }\n }\n\n // Shrink the sizers to the right by the delta.\n let shrink = delta;\n for (let i = index + 1, n = sizers.length; i < n && shrink > 0; ++i) {\n let sizer = sizers[i];\n let limit = sizer.size - sizer.minSize;\n if (limit >= shrink) {\n sizer.sizeHint = sizer.size - shrink;\n shrink = 0;\n } else {\n sizer.sizeHint = sizer.size - limit;\n shrink -= limit;\n }\n }\n }\n\n /**\n * Shrink a sizer by a positive delta and adjust neighbors.\n */\n function shrinkSizer(\n sizers: ArrayLike,\n index: number,\n delta: number\n ): void {\n // Compute how much the items to the right can expand.\n let growLimit = 0;\n for (let i = index + 1, n = sizers.length; i < n; ++i) {\n let sizer = sizers[i];\n growLimit += sizer.maxSize - sizer.size;\n }\n\n // Compute how much the items to the left can shrink.\n let shrinkLimit = 0;\n for (let i = 0; i <= index; ++i) {\n let sizer = sizers[i];\n shrinkLimit += sizer.size - sizer.minSize;\n }\n\n // Clamp the delta adjustment to the limits.\n delta = Math.min(delta, growLimit, shrinkLimit);\n\n // Grow the sizers to the right by the delta.\n let grow = delta;\n for (let i = index + 1, n = sizers.length; i < n && grow > 0; ++i) {\n let sizer = sizers[i];\n let limit = sizer.maxSize - sizer.size;\n if (limit >= grow) {\n sizer.sizeHint = sizer.size + grow;\n grow = 0;\n } else {\n sizer.sizeHint = sizer.size + limit;\n grow -= limit;\n }\n }\n\n // Shrink the sizers to the left by the delta.\n let shrink = delta;\n for (let i = index; i >= 0 && shrink > 0; --i) {\n let sizer = sizers[i];\n let limit = sizer.size - sizer.minSize;\n if (limit >= shrink) {\n sizer.sizeHint = sizer.size - shrink;\n shrink = 0;\n } else {\n sizer.sizeHint = sizer.size - limit;\n shrink -= limit;\n }\n }\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { VirtualElement } from '@lumino/virtualdom';\n\n/**\n * An object which holds data related to an object's title.\n *\n * #### Notes\n * A title object is intended to hold the data necessary to display a\n * header for a particular object. A common example is the `TabPanel`,\n * which uses the widget title to populate the tab for a child widget.\n *\n * It is the responsibility of the owner to call the title disposal.\n */\nexport class Title implements IDisposable {\n /**\n * Construct a new title.\n *\n * @param options - The options for initializing the title.\n */\n constructor(options: Title.IOptions) {\n this.owner = options.owner;\n if (options.label !== undefined) {\n this._label = options.label;\n }\n if (options.mnemonic !== undefined) {\n this._mnemonic = options.mnemonic;\n }\n if (options.icon !== undefined) {\n this._icon = options.icon;\n }\n\n if (options.iconClass !== undefined) {\n this._iconClass = options.iconClass;\n }\n if (options.iconLabel !== undefined) {\n this._iconLabel = options.iconLabel;\n }\n if (options.caption !== undefined) {\n this._caption = options.caption;\n }\n if (options.className !== undefined) {\n this._className = options.className;\n }\n if (options.closable !== undefined) {\n this._closable = options.closable;\n }\n this._dataset = options.dataset || {};\n }\n\n /**\n * A signal emitted when the state of the title changes.\n */\n get changed(): ISignal {\n return this._changed;\n }\n\n /**\n * The object which owns the title.\n */\n readonly owner: T;\n\n /**\n * Get the label for the title.\n *\n * #### Notes\n * The default value is an empty string.\n */\n get label(): string {\n return this._label;\n }\n\n /**\n * Set the label for the title.\n */\n set label(value: string) {\n if (this._label === value) {\n return;\n }\n this._label = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the mnemonic index for the title.\n *\n * #### Notes\n * The default value is `-1`.\n */\n get mnemonic(): number {\n return this._mnemonic;\n }\n\n /**\n * Set the mnemonic index for the title.\n */\n set mnemonic(value: number) {\n if (this._mnemonic === value) {\n return;\n }\n this._mnemonic = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the icon renderer for the title.\n *\n * #### Notes\n * The default value is undefined.\n */\n get icon(): VirtualElement.IRenderer | undefined {\n return this._icon;\n }\n\n /**\n * Set the icon renderer for the title.\n *\n * #### Notes\n * A renderer is an object that supplies a render and unrender function.\n */\n set icon(value: VirtualElement.IRenderer | undefined) {\n if (this._icon === value) {\n return;\n }\n this._icon = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the icon class name for the title.\n *\n * #### Notes\n * The default value is an empty string.\n */\n get iconClass(): string {\n return this._iconClass;\n }\n\n /**\n * Set the icon class name for the title.\n *\n * #### Notes\n * Multiple class names can be separated with whitespace.\n */\n set iconClass(value: string) {\n if (this._iconClass === value) {\n return;\n }\n this._iconClass = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the icon label for the title.\n *\n * #### Notes\n * The default value is an empty string.\n */\n get iconLabel(): string {\n return this._iconLabel;\n }\n\n /**\n * Set the icon label for the title.\n *\n * #### Notes\n * Multiple class names can be separated with whitespace.\n */\n set iconLabel(value: string) {\n if (this._iconLabel === value) {\n return;\n }\n this._iconLabel = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the caption for the title.\n *\n * #### Notes\n * The default value is an empty string.\n */\n get caption(): string {\n return this._caption;\n }\n\n /**\n * Set the caption for the title.\n */\n set caption(value: string) {\n if (this._caption === value) {\n return;\n }\n this._caption = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the extra class name for the title.\n *\n * #### Notes\n * The default value is an empty string.\n */\n get className(): string {\n return this._className;\n }\n\n /**\n * Set the extra class name for the title.\n *\n * #### Notes\n * Multiple class names can be separated with whitespace.\n */\n set className(value: string) {\n if (this._className === value) {\n return;\n }\n this._className = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the closable state for the title.\n *\n * #### Notes\n * The default value is `false`.\n */\n get closable(): boolean {\n return this._closable;\n }\n\n /**\n * Set the closable state for the title.\n *\n * #### Notes\n * This controls the presence of a close icon when applicable.\n */\n set closable(value: boolean) {\n if (this._closable === value) {\n return;\n }\n this._closable = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the dataset for the title.\n *\n * #### Notes\n * The default value is an empty dataset.\n */\n get dataset(): Title.Dataset {\n return this._dataset;\n }\n\n /**\n * Set the dataset for the title.\n *\n * #### Notes\n * This controls the data attributes when applicable.\n */\n set dataset(value: Title.Dataset) {\n if (this._dataset === value) {\n return;\n }\n this._dataset = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Test whether the title has been disposed.\n */\n get isDisposed(): boolean {\n return this._isDisposed;\n }\n\n /**\n * Dispose of the resources held by the title.\n *\n * #### Notes\n * It is the responsibility of the owner to call the title disposal.\n */\n dispose(): void {\n if (this.isDisposed) {\n return;\n }\n this._isDisposed = true;\n\n Signal.clearData(this);\n }\n\n private _label = '';\n private _caption = '';\n private _mnemonic = -1;\n private _icon: VirtualElement.IRenderer | undefined = undefined;\n private _iconClass = '';\n private _iconLabel = '';\n private _className = '';\n private _closable = false;\n private _dataset: Title.Dataset;\n private _changed = new Signal(this);\n private _isDisposed = false;\n}\n\n/**\n * The namespace for the `Title` class statics.\n */\nexport namespace Title {\n /**\n * A type alias for a simple immutable string dataset.\n */\n export type Dataset = { readonly [key: string]: string };\n\n /**\n * An options object for initializing a title.\n */\n export interface IOptions {\n /**\n * The object which owns the title.\n */\n owner: T;\n\n /**\n * The label for the title.\n */\n label?: string;\n\n /**\n * The mnemonic index for the title.\n */\n mnemonic?: number;\n\n /**\n * The icon renderer for the title.\n */\n icon?: VirtualElement.IRenderer;\n\n /**\n * The icon class name for the title.\n */\n iconClass?: string;\n\n /**\n * The icon label for the title.\n */\n iconLabel?: string;\n\n /**\n * The caption for the title.\n */\n caption?: string;\n\n /**\n * The extra class name for the title.\n */\n className?: string;\n\n /**\n * The closable state for the title.\n */\n closable?: boolean;\n\n /**\n * The dataset for the title.\n */\n dataset?: Dataset;\n }\n}\n","/* eslint-disable @typescript-eslint/no-empty-function */\n// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { IObservableDisposable } from '@lumino/disposable';\n\nimport {\n ConflatableMessage,\n IMessageHandler,\n Message,\n MessageLoop\n} from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { Layout } from './layout';\n\nimport { Title } from './title';\n\n/**\n * The base class of the lumino widget hierarchy.\n *\n * #### Notes\n * This class will typically be subclassed in order to create a useful\n * widget. However, it can be used directly to host externally created\n * content.\n */\nexport class Widget implements IMessageHandler, IObservableDisposable {\n /**\n * Construct a new widget.\n *\n * @param options - The options for initializing the widget.\n */\n constructor(options: Widget.IOptions = {}) {\n this.node = Private.createNode(options);\n this.addClass('lm-Widget');\n }\n\n /**\n * Dispose of the widget and its descendant widgets.\n *\n * #### Notes\n * It is unsafe to use the widget after it has been disposed.\n *\n * All calls made to this method after the first are a no-op.\n */\n dispose(): void {\n // Do nothing if the widget is already disposed.\n if (this.isDisposed) {\n return;\n }\n\n // Set the disposed flag and emit the disposed signal.\n this.setFlag(Widget.Flag.IsDisposed);\n this._disposed.emit(undefined);\n\n // Remove or detach the widget if necessary.\n if (this.parent) {\n this.parent = null;\n } else if (this.isAttached) {\n Widget.detach(this);\n }\n\n // Dispose of the widget layout.\n if (this._layout) {\n this._layout.dispose();\n this._layout = null;\n }\n\n // Dispose the title\n this.title.dispose();\n\n // Clear the extra data associated with the widget.\n Signal.clearData(this);\n MessageLoop.clearData(this);\n AttachedProperty.clearData(this);\n }\n\n /**\n * A signal emitted when the widget is disposed.\n */\n get disposed(): ISignal {\n return this._disposed;\n }\n\n /**\n * Get the DOM node owned by the widget.\n */\n readonly node: HTMLElement;\n\n /**\n * Test whether the widget has been disposed.\n */\n get isDisposed(): boolean {\n return this.testFlag(Widget.Flag.IsDisposed);\n }\n\n /**\n * Test whether the widget's node is attached to the DOM.\n */\n get isAttached(): boolean {\n return this.testFlag(Widget.Flag.IsAttached);\n }\n\n /**\n * Test whether the widget is explicitly hidden.\n */\n get isHidden(): boolean {\n return this.testFlag(Widget.Flag.IsHidden);\n }\n\n /**\n * Test whether the widget is visible.\n *\n * #### Notes\n * A widget is visible when it is attached to the DOM, is not\n * explicitly hidden, and has no explicitly hidden ancestors.\n */\n get isVisible(): boolean {\n return this.testFlag(Widget.Flag.IsVisible);\n }\n\n /**\n * The title object for the widget.\n *\n * #### Notes\n * The title object is used by some container widgets when displaying\n * the widget alongside some title, such as a tab panel or side bar.\n *\n * Since not all widgets will use the title, it is created on demand.\n *\n * The `owner` property of the title is set to this widget.\n */\n get title(): Title {\n return Private.titleProperty.get(this);\n }\n\n /**\n * Get the id of the widget's DOM node.\n */\n get id(): string {\n return this.node.id;\n }\n\n /**\n * Set the id of the widget's DOM node.\n */\n set id(value: string) {\n this.node.id = value;\n }\n\n /**\n * The dataset for the widget's DOM node.\n */\n get dataset(): DOMStringMap {\n return this.node.dataset;\n }\n\n /**\n * Get the method for hiding the widget.\n */\n get hiddenMode(): Widget.HiddenMode {\n return this._hiddenMode;\n }\n\n /**\n * Set the method for hiding the widget.\n */\n set hiddenMode(value: Widget.HiddenMode) {\n if (this._hiddenMode === value) {\n return;\n }\n\n if (this.isHidden) {\n // Reset styles set by previous mode.\n this._toggleHidden(false);\n }\n\n if (value == Widget.HiddenMode.Scale) {\n this.node.style.willChange = 'transform';\n } else {\n this.node.style.willChange = 'auto';\n }\n\n this._hiddenMode = value;\n\n if (this.isHidden) {\n // Set styles for new mode.\n this._toggleHidden(true);\n }\n }\n\n /**\n * Get the parent of the widget.\n */\n get parent(): Widget | null {\n return this._parent;\n }\n\n /**\n * Set the parent of the widget.\n *\n * #### Notes\n * Children are typically added to a widget by using a layout, which\n * means user code will not normally set the parent widget directly.\n *\n * The widget will be automatically removed from its old parent.\n *\n * This is a no-op if there is no effective parent change.\n */\n set parent(value: Widget | null) {\n if (this._parent === value) {\n return;\n }\n if (value && this.contains(value)) {\n throw new Error('Invalid parent widget.');\n }\n if (this._parent && !this._parent.isDisposed) {\n let msg = new Widget.ChildMessage('child-removed', this);\n MessageLoop.sendMessage(this._parent, msg);\n }\n this._parent = value;\n if (this._parent && !this._parent.isDisposed) {\n let msg = new Widget.ChildMessage('child-added', this);\n MessageLoop.sendMessage(this._parent, msg);\n }\n if (!this.isDisposed) {\n MessageLoop.sendMessage(this, Widget.Msg.ParentChanged);\n }\n }\n\n /**\n * Get the layout for the widget.\n */\n get layout(): Layout | null {\n return this._layout;\n }\n\n /**\n * Set the layout for the widget.\n *\n * #### Notes\n * The layout is single-use only. It cannot be changed after the\n * first assignment.\n *\n * The layout is disposed automatically when the widget is disposed.\n */\n set layout(value: Layout | null) {\n if (this._layout === value) {\n return;\n }\n if (this.testFlag(Widget.Flag.DisallowLayout)) {\n throw new Error('Cannot set widget layout.');\n }\n if (this._layout) {\n throw new Error('Cannot change widget layout.');\n }\n if (value!.parent) {\n throw new Error('Cannot change layout parent.');\n }\n this._layout = value;\n value!.parent = this;\n }\n\n /**\n * Create an iterator over the widget's children.\n *\n * @returns A new iterator over the children of the widget.\n *\n * #### Notes\n * The widget must have a populated layout in order to have children.\n *\n * If a layout is not installed, the returned iterator will be empty.\n */\n *children(): IterableIterator {\n if (this._layout) {\n yield* this._layout;\n }\n }\n\n /**\n * Test whether a widget is a descendant of this widget.\n *\n * @param widget - The descendant widget of interest.\n *\n * @returns `true` if the widget is a descendant, `false` otherwise.\n */\n contains(widget: Widget): boolean {\n for (let value: Widget | null = widget; value; value = value._parent) {\n if (value === this) {\n return true;\n }\n }\n return false;\n }\n\n /**\n * Test whether the widget's DOM node has the given class name.\n *\n * @param name - The class name of interest.\n *\n * @returns `true` if the node has the class, `false` otherwise.\n */\n hasClass(name: string): boolean {\n return this.node.classList.contains(name);\n }\n\n /**\n * Add a class name to the widget's DOM node.\n *\n * @param name - The class name to add to the node.\n *\n * #### Notes\n * If the class name is already added to the node, this is a no-op.\n *\n * The class name must not contain whitespace.\n */\n addClass(name: string): void {\n this.node.classList.add(name);\n }\n\n /**\n * Remove a class name from the widget's DOM node.\n *\n * @param name - The class name to remove from the node.\n *\n * #### Notes\n * If the class name is not yet added to the node, this is a no-op.\n *\n * The class name must not contain whitespace.\n */\n removeClass(name: string): void {\n this.node.classList.remove(name);\n }\n\n /**\n * Toggle a class name on the widget's DOM node.\n *\n * @param name - The class name to toggle on the node.\n *\n * @param force - Whether to force add the class (`true`) or force\n * remove the class (`false`). If not provided, the presence of\n * the class will be toggled from its current state.\n *\n * @returns `true` if the class is now present, `false` otherwise.\n *\n * #### Notes\n * The class name must not contain whitespace.\n */\n toggleClass(name: string, force?: boolean): boolean {\n if (force === true) {\n this.node.classList.add(name);\n return true;\n }\n if (force === false) {\n this.node.classList.remove(name);\n return false;\n }\n return this.node.classList.toggle(name);\n }\n\n /**\n * Post an `'update-request'` message to the widget.\n *\n * #### Notes\n * This is a simple convenience method for posting the message.\n */\n update(): void {\n MessageLoop.postMessage(this, Widget.Msg.UpdateRequest);\n }\n\n /**\n * Post a `'fit-request'` message to the widget.\n *\n * #### Notes\n * This is a simple convenience method for posting the message.\n */\n fit(): void {\n MessageLoop.postMessage(this, Widget.Msg.FitRequest);\n }\n\n /**\n * Post an `'activate-request'` message to the widget.\n *\n * #### Notes\n * This is a simple convenience method for posting the message.\n */\n activate(): void {\n MessageLoop.postMessage(this, Widget.Msg.ActivateRequest);\n }\n\n /**\n * Send a `'close-request'` message to the widget.\n *\n * #### Notes\n * This is a simple convenience method for sending the message.\n */\n close(): void {\n MessageLoop.sendMessage(this, Widget.Msg.CloseRequest);\n }\n\n /**\n * Show the widget and make it visible to its parent widget.\n *\n * #### Notes\n * This causes the {@link isHidden} property to be `false`.\n *\n * If the widget is not explicitly hidden, this is a no-op.\n */\n show(): void {\n if (!this.testFlag(Widget.Flag.IsHidden)) {\n return;\n }\n if (this.isAttached && (!this.parent || this.parent.isVisible)) {\n MessageLoop.sendMessage(this, Widget.Msg.BeforeShow);\n }\n this.clearFlag(Widget.Flag.IsHidden);\n this._toggleHidden(false);\n\n if (this.isAttached && (!this.parent || this.parent.isVisible)) {\n MessageLoop.sendMessage(this, Widget.Msg.AfterShow);\n }\n if (this.parent) {\n let msg = new Widget.ChildMessage('child-shown', this);\n MessageLoop.sendMessage(this.parent, msg);\n }\n }\n\n /**\n * Hide the widget and make it hidden to its parent widget.\n *\n * #### Notes\n * This causes the {@link isHidden} property to be `true`.\n *\n * If the widget is explicitly hidden, this is a no-op.\n */\n hide(): void {\n if (this.testFlag(Widget.Flag.IsHidden)) {\n return;\n }\n if (this.isAttached && (!this.parent || this.parent.isVisible)) {\n MessageLoop.sendMessage(this, Widget.Msg.BeforeHide);\n }\n this.setFlag(Widget.Flag.IsHidden);\n this._toggleHidden(true);\n\n if (this.isAttached && (!this.parent || this.parent.isVisible)) {\n MessageLoop.sendMessage(this, Widget.Msg.AfterHide);\n }\n if (this.parent) {\n let msg = new Widget.ChildMessage('child-hidden', this);\n MessageLoop.sendMessage(this.parent, msg);\n }\n }\n\n /**\n * Show or hide the widget according to a boolean value.\n *\n * @param hidden - `true` to hide the widget, or `false` to show it.\n *\n * #### Notes\n * This is a convenience method for `hide()` and `show()`.\n */\n setHidden(hidden: boolean): void {\n if (hidden) {\n this.hide();\n } else {\n this.show();\n }\n }\n\n /**\n * Test whether the given widget flag is set.\n *\n * #### Notes\n * This will not typically be called directly by user code.\n */\n testFlag(flag: Widget.Flag): boolean {\n return (this._flags & flag) !== 0;\n }\n\n /**\n * Set the given widget flag.\n *\n * #### Notes\n * This will not typically be called directly by user code.\n */\n setFlag(flag: Widget.Flag): void {\n this._flags |= flag;\n }\n\n /**\n * Clear the given widget flag.\n *\n * #### Notes\n * This will not typically be called directly by user code.\n */\n clearFlag(flag: Widget.Flag): void {\n this._flags &= ~flag;\n }\n\n /**\n * Process a message sent to the widget.\n *\n * @param msg - The message sent to the widget.\n *\n * #### Notes\n * Subclasses may reimplement this method as needed.\n */\n processMessage(msg: Message): void {\n switch (msg.type) {\n case 'resize':\n this.notifyLayout(msg);\n this.onResize(msg as Widget.ResizeMessage);\n break;\n case 'update-request':\n this.notifyLayout(msg);\n this.onUpdateRequest(msg);\n break;\n case 'fit-request':\n this.notifyLayout(msg);\n this.onFitRequest(msg);\n break;\n case 'before-show':\n this.notifyLayout(msg);\n this.onBeforeShow(msg);\n break;\n case 'after-show':\n this.setFlag(Widget.Flag.IsVisible);\n this.notifyLayout(msg);\n this.onAfterShow(msg);\n break;\n case 'before-hide':\n this.notifyLayout(msg);\n this.onBeforeHide(msg);\n break;\n case 'after-hide':\n this.clearFlag(Widget.Flag.IsVisible);\n this.notifyLayout(msg);\n this.onAfterHide(msg);\n break;\n case 'before-attach':\n this.notifyLayout(msg);\n this.onBeforeAttach(msg);\n break;\n case 'after-attach':\n if (!this.isHidden && (!this.parent || this.parent.isVisible)) {\n this.setFlag(Widget.Flag.IsVisible);\n }\n this.setFlag(Widget.Flag.IsAttached);\n this.notifyLayout(msg);\n this.onAfterAttach(msg);\n break;\n case 'before-detach':\n this.notifyLayout(msg);\n this.onBeforeDetach(msg);\n break;\n case 'after-detach':\n this.clearFlag(Widget.Flag.IsVisible);\n this.clearFlag(Widget.Flag.IsAttached);\n this.notifyLayout(msg);\n this.onAfterDetach(msg);\n break;\n case 'activate-request':\n this.notifyLayout(msg);\n this.onActivateRequest(msg);\n break;\n case 'close-request':\n this.notifyLayout(msg);\n this.onCloseRequest(msg);\n break;\n case 'child-added':\n this.notifyLayout(msg);\n this.onChildAdded(msg as Widget.ChildMessage);\n break;\n case 'child-removed':\n this.notifyLayout(msg);\n this.onChildRemoved(msg as Widget.ChildMessage);\n break;\n default:\n this.notifyLayout(msg);\n break;\n }\n }\n\n /**\n * Invoke the message processing routine of the widget's layout.\n *\n * @param msg - The message to dispatch to the layout.\n *\n * #### Notes\n * This is a no-op if the widget does not have a layout.\n *\n * This will not typically be called directly by user code.\n */\n protected notifyLayout(msg: Message): void {\n if (this._layout) {\n this._layout.processParentMessage(msg);\n }\n }\n\n /**\n * A message handler invoked on a `'close-request'` message.\n *\n * #### Notes\n * The default implementation unparents or detaches the widget.\n */\n protected onCloseRequest(msg: Message): void {\n if (this.parent) {\n this.parent = null;\n } else if (this.isAttached) {\n Widget.detach(this);\n }\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onResize(msg: Widget.ResizeMessage): void {}\n\n /**\n * A message handler invoked on an `'update-request'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onUpdateRequest(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onFitRequest(msg: Message): void {}\n\n /**\n * A message handler invoked on an `'activate-request'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onActivateRequest(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'before-show'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onBeforeShow(msg: Message): void {}\n\n /**\n * A message handler invoked on an `'after-show'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onAfterShow(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'before-hide'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onBeforeHide(msg: Message): void {}\n\n /**\n * A message handler invoked on an `'after-hide'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onAfterHide(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onBeforeAttach(msg: Message): void {}\n\n /**\n * A message handler invoked on an `'after-attach'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onAfterAttach(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'before-detach'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onBeforeDetach(msg: Message): void {}\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onAfterDetach(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'child-added'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onChildAdded(msg: Widget.ChildMessage): void {}\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {}\n\n private _toggleHidden(hidden: boolean) {\n if (hidden) {\n switch (this._hiddenMode) {\n case Widget.HiddenMode.Display:\n this.addClass('lm-mod-hidden');\n break;\n case Widget.HiddenMode.Scale:\n this.node.style.transform = 'scale(0)';\n this.node.setAttribute('aria-hidden', 'true');\n break;\n case Widget.HiddenMode.ContentVisibility:\n // @ts-expect-error content-visibility unknown by DOM lib types\n this.node.style.contentVisibility = 'hidden';\n this.node.style.zIndex = '-1';\n break;\n }\n } else {\n switch (this._hiddenMode) {\n case Widget.HiddenMode.Display:\n this.removeClass('lm-mod-hidden');\n break;\n case Widget.HiddenMode.Scale:\n this.node.style.transform = '';\n this.node.removeAttribute('aria-hidden');\n break;\n case Widget.HiddenMode.ContentVisibility:\n // @ts-expect-error content-visibility unknown by DOM lib types\n this.node.style.contentVisibility = '';\n this.node.style.zIndex = '';\n break;\n }\n }\n }\n\n private _flags = 0;\n private _layout: Layout | null = null;\n private _parent: Widget | null = null;\n private _disposed = new Signal(this);\n private _hiddenMode: Widget.HiddenMode = Widget.HiddenMode.Display;\n}\n\n/**\n * The namespace for the `Widget` class statics.\n */\nexport namespace Widget {\n /**\n * An options object for initializing a widget.\n */\n export interface IOptions {\n /**\n * The optional node to use for the widget.\n *\n * If a node is provided, the widget will assume full ownership\n * and control of the node, as if it had created the node itself.\n *\n * The default is a new `
`.\n */\n node?: HTMLElement;\n\n /**\n * The optional element tag, used for constructing the widget's node.\n *\n * If a pre-constructed node is provided via the `node` arg, this\n * value is ignored.\n */\n tag?: keyof HTMLElementTagNameMap;\n }\n\n /**\n * The method for hiding the widget.\n *\n * The default is Display.\n *\n * Using `Scale` will often increase performance as most browsers will not\n * trigger style computation for the `transform` action. This should be used\n * sparingly and tested, since increasing the number of composition layers\n * may slow things down.\n *\n * To ensure the transformation does not trigger style recomputation, you\n * may need to set the widget CSS style `will-change: transform`. This\n * should be used only when needed as it may overwhelm the browser with a\n * high number of layers. See\n * https://developer.mozilla.org/en-US/docs/Web/CSS/will-change\n */\n export enum HiddenMode {\n /**\n * Set a `lm-mod-hidden` CSS class to hide the widget using `display:none`\n * CSS from the standard Lumino CSS.\n */\n Display = 0,\n\n /**\n * Hide the widget by setting the `transform` to `'scale(0)'`.\n */\n Scale,\n\n /**\n *Hide the widget by setting the `content-visibility` to `'hidden'`.\n */\n ContentVisibility\n }\n\n /**\n * An enum of widget bit flags.\n */\n export enum Flag {\n /**\n * The widget has been disposed.\n */\n IsDisposed = 0x1,\n\n /**\n * The widget is attached to the DOM.\n */\n IsAttached = 0x2,\n\n /**\n * The widget is hidden.\n */\n IsHidden = 0x4,\n\n /**\n * The widget is visible.\n */\n IsVisible = 0x8,\n\n /**\n * A layout cannot be set on the widget.\n */\n DisallowLayout = 0x10\n }\n\n /**\n * A collection of stateless messages related to widgets.\n */\n export namespace Msg {\n /**\n * A singleton `'before-show'` message.\n *\n * #### Notes\n * This message is sent to a widget before it becomes visible.\n *\n * This message is **not** sent when the widget is being attached.\n */\n export const BeforeShow = new Message('before-show');\n\n /**\n * A singleton `'after-show'` message.\n *\n * #### Notes\n * This message is sent to a widget after it becomes visible.\n *\n * This message is **not** sent when the widget is being attached.\n */\n export const AfterShow = new Message('after-show');\n\n /**\n * A singleton `'before-hide'` message.\n *\n * #### Notes\n * This message is sent to a widget before it becomes not-visible.\n *\n * This message is **not** sent when the widget is being detached.\n */\n export const BeforeHide = new Message('before-hide');\n\n /**\n * A singleton `'after-hide'` message.\n *\n * #### Notes\n * This message is sent to a widget after it becomes not-visible.\n *\n * This message is **not** sent when the widget is being detached.\n */\n export const AfterHide = new Message('after-hide');\n\n /**\n * A singleton `'before-attach'` message.\n *\n * #### Notes\n * This message is sent to a widget before it is attached.\n */\n export const BeforeAttach = new Message('before-attach');\n\n /**\n * A singleton `'after-attach'` message.\n *\n * #### Notes\n * This message is sent to a widget after it is attached.\n */\n export const AfterAttach = new Message('after-attach');\n\n /**\n * A singleton `'before-detach'` message.\n *\n * #### Notes\n * This message is sent to a widget before it is detached.\n */\n export const BeforeDetach = new Message('before-detach');\n\n /**\n * A singleton `'after-detach'` message.\n *\n * #### Notes\n * This message is sent to a widget after it is detached.\n */\n export const AfterDetach = new Message('after-detach');\n\n /**\n * A singleton `'parent-changed'` message.\n *\n * #### Notes\n * This message is sent to a widget when its parent has changed.\n */\n export const ParentChanged = new Message('parent-changed');\n\n /**\n * A singleton conflatable `'update-request'` message.\n *\n * #### Notes\n * This message can be dispatched to supporting widgets in order to\n * update their content based on the current widget state. Not all\n * widgets will respond to messages of this type.\n *\n * For widgets with a layout, this message will inform the layout to\n * update the position and size of its child widgets.\n */\n export const UpdateRequest = new ConflatableMessage('update-request');\n\n /**\n * A singleton conflatable `'fit-request'` message.\n *\n * #### Notes\n * For widgets with a layout, this message will inform the layout to\n * recalculate its size constraints to fit the space requirements of\n * its child widgets, and to update their position and size. Not all\n * layouts will respond to messages of this type.\n */\n export const FitRequest = new ConflatableMessage('fit-request');\n\n /**\n * A singleton conflatable `'activate-request'` message.\n *\n * #### Notes\n * This message should be dispatched to a widget when it should\n * perform the actions necessary to activate the widget, which\n * may include focusing its node or descendant node.\n */\n export const ActivateRequest = new ConflatableMessage('activate-request');\n\n /**\n * A singleton conflatable `'close-request'` message.\n *\n * #### Notes\n * This message should be dispatched to a widget when it should close\n * and remove itself from the widget hierarchy.\n */\n export const CloseRequest = new ConflatableMessage('close-request');\n }\n\n /**\n * A message class for child related messages.\n */\n export class ChildMessage extends Message {\n /**\n * Construct a new child message.\n *\n * @param type - The message type.\n *\n * @param child - The child widget for the message.\n */\n constructor(type: string, child: Widget) {\n super(type);\n this.child = child;\n }\n\n /**\n * The child widget for the message.\n */\n readonly child: Widget;\n }\n\n /**\n * A message class for `'resize'` messages.\n */\n export class ResizeMessage extends Message {\n /**\n * Construct a new resize message.\n *\n * @param width - The **offset width** of the widget, or `-1` if\n * the width is not known.\n *\n * @param height - The **offset height** of the widget, or `-1` if\n * the height is not known.\n */\n constructor(width: number, height: number) {\n super('resize');\n this.width = width;\n this.height = height;\n }\n\n /**\n * The offset width of the widget.\n *\n * #### Notes\n * This will be `-1` if the width is unknown.\n */\n readonly width: number;\n\n /**\n * The offset height of the widget.\n *\n * #### Notes\n * This will be `-1` if the height is unknown.\n */\n readonly height: number;\n }\n\n /**\n * The namespace for the `ResizeMessage` class statics.\n */\n export namespace ResizeMessage {\n /**\n * A singleton `'resize'` message with an unknown size.\n */\n export const UnknownSize = new ResizeMessage(-1, -1);\n }\n\n /**\n * Attach a widget to a host DOM node.\n *\n * @param widget - The widget of interest.\n *\n * @param host - The DOM node to use as the widget's host.\n *\n * @param ref - The child of `host` to use as the reference element.\n * If this is provided, the widget will be inserted before this\n * node in the host. The default is `null`, which will cause the\n * widget to be added as the last child of the host.\n *\n * #### Notes\n * This will throw an error if the widget is not a root widget, if\n * the widget is already attached, or if the host is not attached\n * to the DOM.\n */\n export function attach(\n widget: Widget,\n host: HTMLElement,\n ref: HTMLElement | null = null\n ): void {\n if (widget.parent) {\n throw new Error('Cannot attach a child widget.');\n }\n if (widget.isAttached || widget.node.isConnected) {\n throw new Error('Widget is already attached.');\n }\n if (!host.isConnected) {\n throw new Error('Host is not attached.');\n }\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n host.insertBefore(widget.node, ref);\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n\n /**\n * Detach the widget from its host DOM node.\n *\n * @param widget - The widget of interest.\n *\n * #### Notes\n * This will throw an error if the widget is not a root widget,\n * or if the widget is not attached to the DOM.\n */\n export function detach(widget: Widget): void {\n if (widget.parent) {\n throw new Error('Cannot detach a child widget.');\n }\n if (!widget.isAttached || !widget.node.isConnected) {\n throw new Error('Widget is not attached.');\n }\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n widget.node.parentNode!.removeChild(widget.node);\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * An attached property for the widget title object.\n */\n export const titleProperty = new AttachedProperty>({\n name: 'title',\n create: owner => new Title({ owner })\n });\n\n /**\n * Create a DOM node for the given widget options.\n */\n export function createNode(options: Widget.IOptions): HTMLElement {\n return options.node || document.createElement(options.tag || 'div');\n }\n}\n","/* eslint-disable @typescript-eslint/no-empty-function */\n// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { Signal } from '@lumino/signaling';\n\nimport { Widget } from './widget';\n\n/**\n * An abstract base class for creating lumino layouts.\n *\n * #### Notes\n * A layout is used to add widgets to a parent and to arrange those\n * widgets within the parent's DOM node.\n *\n * This class implements the base functionality which is required of\n * nearly all layouts. It must be subclassed in order to be useful.\n *\n * Notably, this class does not define a uniform interface for adding\n * widgets to the layout. A subclass should define that API in a way\n * which is meaningful for its intended use.\n */\nexport abstract class Layout implements Iterable, IDisposable {\n /**\n * Construct a new layout.\n *\n * @param options - The options for initializing the layout.\n */\n constructor(options: Layout.IOptions = {}) {\n this._fitPolicy = options.fitPolicy || 'set-min-size';\n }\n\n /**\n * Dispose of the resources held by the layout.\n *\n * #### Notes\n * This should be reimplemented to clear and dispose of the widgets.\n *\n * All reimplementations should call the superclass method.\n *\n * This method is called automatically when the parent is disposed.\n */\n dispose(): void {\n this._parent = null;\n this._disposed = true;\n Signal.clearData(this);\n AttachedProperty.clearData(this);\n }\n\n /**\n * Test whether the layout is disposed.\n */\n get isDisposed(): boolean {\n return this._disposed;\n }\n\n /**\n * Get the parent widget of the layout.\n */\n get parent(): Widget | null {\n return this._parent;\n }\n\n /**\n * Set the parent widget of the layout.\n *\n * #### Notes\n * This is set automatically when installing the layout on the parent\n * widget. The parent widget should not be set directly by user code.\n */\n set parent(value: Widget | null) {\n if (this._parent === value) {\n return;\n }\n if (this._parent) {\n throw new Error('Cannot change parent widget.');\n }\n if (value!.layout !== this) {\n throw new Error('Invalid parent widget.');\n }\n this._parent = value;\n this.init();\n }\n\n /**\n * Get the fit policy for the layout.\n *\n * #### Notes\n * The fit policy controls the computed size constraints which are\n * applied to the parent widget by the layout.\n *\n * Some layout implementations may ignore the fit policy.\n */\n get fitPolicy(): Layout.FitPolicy {\n return this._fitPolicy;\n }\n\n /**\n * Set the fit policy for the layout.\n *\n * #### Notes\n * The fit policy controls the computed size constraints which are\n * applied to the parent widget by the layout.\n *\n * Some layout implementations may ignore the fit policy.\n *\n * Changing the fit policy will clear the current size constraint\n * for the parent widget and then re-fit the parent.\n */\n set fitPolicy(value: Layout.FitPolicy) {\n // Bail if the policy does not change\n if (this._fitPolicy === value) {\n return;\n }\n\n // Update the internal policy.\n this._fitPolicy = value;\n\n // Clear the size constraints and schedule a fit of the parent.\n if (this._parent) {\n let style = this._parent.node.style;\n style.minWidth = '';\n style.minHeight = '';\n style.maxWidth = '';\n style.maxHeight = '';\n this._parent.fit();\n }\n }\n\n /**\n * Create an iterator over the widgets in the layout.\n *\n * @returns A new iterator over the widgets in the layout.\n *\n * #### Notes\n * This abstract method must be implemented by a subclass.\n */\n abstract [Symbol.iterator](): IterableIterator;\n\n /**\n * Remove a widget from the layout.\n *\n * @param widget - The widget to remove from the layout.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method should *not* modify the widget's `parent`.\n */\n abstract removeWidget(widget: Widget): void;\n\n /**\n * Process a message sent to the parent widget.\n *\n * @param msg - The message sent to the parent widget.\n *\n * #### Notes\n * This method is called by the parent widget to process a message.\n *\n * Subclasses may reimplement this method as needed.\n */\n processParentMessage(msg: Message): void {\n switch (msg.type) {\n case 'resize':\n this.onResize(msg as Widget.ResizeMessage);\n break;\n case 'update-request':\n this.onUpdateRequest(msg);\n break;\n case 'fit-request':\n this.onFitRequest(msg);\n break;\n case 'before-show':\n this.onBeforeShow(msg);\n break;\n case 'after-show':\n this.onAfterShow(msg);\n break;\n case 'before-hide':\n this.onBeforeHide(msg);\n break;\n case 'after-hide':\n this.onAfterHide(msg);\n break;\n case 'before-attach':\n this.onBeforeAttach(msg);\n break;\n case 'after-attach':\n this.onAfterAttach(msg);\n break;\n case 'before-detach':\n this.onBeforeDetach(msg);\n break;\n case 'after-detach':\n this.onAfterDetach(msg);\n break;\n case 'child-removed':\n this.onChildRemoved(msg as Widget.ChildMessage);\n break;\n case 'child-shown':\n this.onChildShown(msg as Widget.ChildMessage);\n break;\n case 'child-hidden':\n this.onChildHidden(msg as Widget.ChildMessage);\n break;\n }\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n *\n * #### Notes\n * This method is invoked immediately after the layout is installed\n * on the parent widget.\n *\n * The default implementation reparents all of the widgets to the\n * layout parent widget.\n *\n * Subclasses should reimplement this method and attach the child\n * widget nodes to the parent widget's node.\n */\n protected init(): void {\n for (const widget of this) {\n widget.parent = this.parent;\n }\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n *\n * #### Notes\n * The layout should ensure that its widgets are resized according\n * to the specified layout space, and that they are sent a `'resize'`\n * message if appropriate.\n *\n * The default implementation of this method sends an `UnknownSize`\n * resize message to all widgets.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, Widget.ResizeMessage.UnknownSize);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n *\n * #### Notes\n * The layout should ensure that its widgets are resized according\n * to the available layout space, and that they are sent a `'resize'`\n * message if appropriate.\n *\n * The default implementation of this method sends an `UnknownSize`\n * resize message to all widgets.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onUpdateRequest(msg: Message): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, Widget.ResizeMessage.UnknownSize);\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message\n * to all widgets. It assumes all widget nodes are attached to the\n * parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onBeforeAttach(msg: Message): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n\n /**\n * A message handler invoked on an `'after-attach'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message\n * to all widgets. It assumes all widget nodes are attached to the\n * parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onAfterAttach(msg: Message): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n\n /**\n * A message handler invoked on a `'before-detach'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message\n * to all widgets. It assumes all widget nodes are attached to the\n * parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onBeforeDetach(msg: Message): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message\n * to all widgets. It assumes all widget nodes are attached to the\n * parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onAfterDetach(msg: Message): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message to\n * all non-hidden widgets. It assumes all widget nodes are attached\n * to the parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onBeforeShow(msg: Message): void {\n for (const widget of this) {\n if (!widget.isHidden) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n }\n\n /**\n * A message handler invoked on an `'after-show'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message to\n * all non-hidden widgets. It assumes all widget nodes are attached\n * to the parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onAfterShow(msg: Message): void {\n for (const widget of this) {\n if (!widget.isHidden) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n }\n\n /**\n * A message handler invoked on a `'before-hide'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message to\n * all non-hidden widgets. It assumes all widget nodes are attached\n * to the parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onBeforeHide(msg: Message): void {\n for (const widget of this) {\n if (!widget.isHidden) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n }\n\n /**\n * A message handler invoked on an `'after-hide'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message to\n * all non-hidden widgets. It assumes all widget nodes are attached\n * to the parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onAfterHide(msg: Message): void {\n for (const widget of this) {\n if (!widget.isHidden) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n }\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n *\n * #### Notes\n * This will remove the child widget from the layout.\n *\n * Subclasses should **not** typically reimplement this method.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {\n this.removeWidget(msg.child);\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onFitRequest(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {}\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {}\n\n private _disposed = false;\n private _fitPolicy: Layout.FitPolicy;\n private _parent: Widget | null = null;\n}\n\n/**\n * The namespace for the `Layout` class statics.\n */\nexport namespace Layout {\n /**\n * A type alias for the layout fit policy.\n *\n * #### Notes\n * The fit policy controls the computed size constraints which are\n * applied to the parent widget by the layout.\n *\n * Some layout implementations may ignore the fit policy.\n */\n export type FitPolicy =\n | /**\n * No size constraint will be applied to the parent widget.\n */\n 'set-no-constraint'\n\n /**\n * The computed min size will be applied to the parent widget.\n */\n | 'set-min-size';\n\n /**\n * An options object for initializing a layout.\n */\n export interface IOptions {\n /**\n * The fit policy for the layout.\n *\n * The default is `'set-min-size'`.\n */\n fitPolicy?: FitPolicy;\n }\n\n /**\n * A type alias for the horizontal alignment of a widget.\n */\n export type HorizontalAlignment = 'left' | 'center' | 'right';\n\n /**\n * A type alias for the vertical alignment of a widget.\n */\n export type VerticalAlignment = 'top' | 'center' | 'bottom';\n\n /**\n * Get the horizontal alignment for a widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The horizontal alignment for the widget.\n *\n * #### Notes\n * If the layout width allocated to a widget is larger than its max\n * width, the horizontal alignment controls how the widget is placed\n * within the extra horizontal space.\n *\n * If the allocated width is less than the widget's max width, the\n * horizontal alignment has no effect.\n *\n * Some layout implementations may ignore horizontal alignment.\n */\n export function getHorizontalAlignment(widget: Widget): HorizontalAlignment {\n return Private.horizontalAlignmentProperty.get(widget);\n }\n\n /**\n * Set the horizontal alignment for a widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the horizontal alignment.\n *\n * #### Notes\n * If the layout width allocated to a widget is larger than its max\n * width, the horizontal alignment controls how the widget is placed\n * within the extra horizontal space.\n *\n * If the allocated width is less than the widget's max width, the\n * horizontal alignment has no effect.\n *\n * Some layout implementations may ignore horizontal alignment.\n *\n * Changing the horizontal alignment will post an `update-request`\n * message to widget's parent, provided the parent has a layout\n * installed.\n */\n export function setHorizontalAlignment(\n widget: Widget,\n value: HorizontalAlignment\n ): void {\n Private.horizontalAlignmentProperty.set(widget, value);\n }\n\n /**\n * Get the vertical alignment for a widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The vertical alignment for the widget.\n *\n * #### Notes\n * If the layout height allocated to a widget is larger than its max\n * height, the vertical alignment controls how the widget is placed\n * within the extra vertical space.\n *\n * If the allocated height is less than the widget's max height, the\n * vertical alignment has no effect.\n *\n * Some layout implementations may ignore vertical alignment.\n */\n export function getVerticalAlignment(widget: Widget): VerticalAlignment {\n return Private.verticalAlignmentProperty.get(widget);\n }\n\n /**\n * Set the vertical alignment for a widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the vertical alignment.\n *\n * #### Notes\n * If the layout height allocated to a widget is larger than its max\n * height, the vertical alignment controls how the widget is placed\n * within the extra vertical space.\n *\n * If the allocated height is less than the widget's max height, the\n * vertical alignment has no effect.\n *\n * Some layout implementations may ignore vertical alignment.\n *\n * Changing the horizontal alignment will post an `update-request`\n * message to widget's parent, provided the parent has a layout\n * installed.\n */\n export function setVerticalAlignment(\n widget: Widget,\n value: VerticalAlignment\n ): void {\n Private.verticalAlignmentProperty.set(widget, value);\n }\n}\n\n/**\n * An object which assists in the absolute layout of widgets.\n *\n * #### Notes\n * This class is useful when implementing a layout which arranges its\n * widgets using absolute positioning.\n *\n * This class is used by nearly all of the built-in lumino layouts.\n */\nexport class LayoutItem implements IDisposable {\n /**\n * Construct a new layout item.\n *\n * @param widget - The widget to be managed by the item.\n *\n * #### Notes\n * The widget will be set to absolute positioning.\n * The widget will use strict CSS containment.\n */\n constructor(widget: Widget) {\n this.widget = widget;\n this.widget.node.style.position = 'absolute';\n this.widget.node.style.contain = 'strict';\n }\n\n /**\n * Dispose of the the layout item.\n *\n * #### Notes\n * This will reset the positioning of the widget.\n */\n dispose(): void {\n // Do nothing if the item is already disposed.\n if (this._disposed) {\n return;\n }\n\n // Mark the item as disposed.\n this._disposed = true;\n\n // Reset the widget style.\n let style = this.widget.node.style;\n style.position = '';\n style.top = '';\n style.left = '';\n style.width = '';\n style.height = '';\n style.contain = '';\n }\n\n /**\n * The widget managed by the layout item.\n */\n readonly widget: Widget;\n\n /**\n * The computed minimum width of the widget.\n *\n * #### Notes\n * This value can be updated by calling the `fit` method.\n */\n get minWidth(): number {\n return this._minWidth;\n }\n\n /**\n * The computed minimum height of the widget.\n *\n * #### Notes\n * This value can be updated by calling the `fit` method.\n */\n get minHeight(): number {\n return this._minHeight;\n }\n\n /**\n * The computed maximum width of the widget.\n *\n * #### Notes\n * This value can be updated by calling the `fit` method.\n */\n get maxWidth(): number {\n return this._maxWidth;\n }\n\n /**\n * The computed maximum height of the widget.\n *\n * #### Notes\n * This value can be updated by calling the `fit` method.\n */\n get maxHeight(): number {\n return this._maxHeight;\n }\n\n /**\n * Whether the layout item is disposed.\n */\n get isDisposed(): boolean {\n return this._disposed;\n }\n\n /**\n * Whether the managed widget is hidden.\n */\n get isHidden(): boolean {\n return this.widget.isHidden;\n }\n\n /**\n * Whether the managed widget is visible.\n */\n get isVisible(): boolean {\n return this.widget.isVisible;\n }\n\n /**\n * Whether the managed widget is attached.\n */\n get isAttached(): boolean {\n return this.widget.isAttached;\n }\n\n /**\n * Update the computed size limits of the managed widget.\n */\n fit(): void {\n let limits = ElementExt.sizeLimits(this.widget.node);\n this._minWidth = limits.minWidth;\n this._minHeight = limits.minHeight;\n this._maxWidth = limits.maxWidth;\n this._maxHeight = limits.maxHeight;\n }\n\n /**\n * Update the position and size of the managed widget.\n *\n * @param left - The left edge position of the layout box.\n *\n * @param top - The top edge position of the layout box.\n *\n * @param width - The width of the layout box.\n *\n * @param height - The height of the layout box.\n */\n update(left: number, top: number, width: number, height: number): void {\n // Clamp the size to the computed size limits.\n let clampW = Math.max(this._minWidth, Math.min(width, this._maxWidth));\n let clampH = Math.max(this._minHeight, Math.min(height, this._maxHeight));\n\n // Adjust the left edge for the horizontal alignment, if needed.\n if (clampW < width) {\n switch (Layout.getHorizontalAlignment(this.widget)) {\n case 'left':\n break;\n case 'center':\n left += (width - clampW) / 2;\n break;\n case 'right':\n left += width - clampW;\n break;\n default:\n throw 'unreachable';\n }\n }\n\n // Adjust the top edge for the vertical alignment, if needed.\n if (clampH < height) {\n switch (Layout.getVerticalAlignment(this.widget)) {\n case 'top':\n break;\n case 'center':\n top += (height - clampH) / 2;\n break;\n case 'bottom':\n top += height - clampH;\n break;\n default:\n throw 'unreachable';\n }\n }\n\n // Set up the resize variables.\n let resized = false;\n let style = this.widget.node.style;\n\n // Update the top edge of the widget if needed.\n if (this._top !== top) {\n this._top = top;\n style.top = `${top}px`;\n }\n\n // Update the left edge of the widget if needed.\n if (this._left !== left) {\n this._left = left;\n style.left = `${left}px`;\n }\n\n // Update the width of the widget if needed.\n if (this._width !== clampW) {\n resized = true;\n this._width = clampW;\n style.width = `${clampW}px`;\n }\n\n // Update the height of the widget if needed.\n if (this._height !== clampH) {\n resized = true;\n this._height = clampH;\n style.height = `${clampH}px`;\n }\n\n // Send a resize message to the widget if needed.\n if (resized) {\n let msg = new Widget.ResizeMessage(clampW, clampH);\n MessageLoop.sendMessage(this.widget, msg);\n }\n }\n\n private _top = NaN;\n private _left = NaN;\n private _width = NaN;\n private _height = NaN;\n private _minWidth = 0;\n private _minHeight = 0;\n private _maxWidth = Infinity;\n private _maxHeight = Infinity;\n private _disposed = false;\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The attached property for a widget horizontal alignment.\n */\n export const horizontalAlignmentProperty = new AttachedProperty<\n Widget,\n Layout.HorizontalAlignment\n >({\n name: 'horizontalAlignment',\n create: () => 'center',\n changed: onAlignmentChanged\n });\n\n /**\n * The attached property for a widget vertical alignment.\n */\n export const verticalAlignmentProperty = new AttachedProperty<\n Widget,\n Layout.VerticalAlignment\n >({\n name: 'verticalAlignment',\n create: () => 'top',\n changed: onAlignmentChanged\n });\n\n /**\n * The change handler for the attached alignment properties.\n */\n function onAlignmentChanged(child: Widget): void {\n if (child.parent && child.parent.layout) {\n child.parent.update();\n }\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { MessageLoop } from '@lumino/messaging';\n\nimport { Layout } from './layout';\n\nimport { Widget } from './widget';\n\n/**\n * A concrete layout implementation suitable for many use cases.\n *\n * #### Notes\n * This class is suitable as a base class for implementing a variety of\n * layouts, but can also be used directly with standard CSS to layout a\n * collection of widgets.\n */\nexport class PanelLayout extends Layout {\n /**\n * Dispose of the resources held by the layout.\n *\n * #### Notes\n * This will clear and dispose all widgets in the layout.\n *\n * All reimplementations should call the superclass method.\n *\n * This method is called automatically when the parent is disposed.\n */\n dispose(): void {\n while (this._widgets.length > 0) {\n this._widgets.pop()!.dispose();\n }\n super.dispose();\n }\n\n /**\n * A read-only array of the widgets in the layout.\n */\n get widgets(): ReadonlyArray {\n return this._widgets;\n }\n\n /**\n * Create an iterator over the widgets in the layout.\n *\n * @returns A new iterator over the widgets in the layout.\n */\n *[Symbol.iterator](): IterableIterator {\n yield* this._widgets;\n }\n\n /**\n * Add a widget to the end of the layout.\n *\n * @param widget - The widget to add to the layout.\n *\n * #### Notes\n * If the widget is already contained in the layout, it will be moved.\n */\n addWidget(widget: Widget): void {\n this.insertWidget(this._widgets.length, widget);\n }\n\n /**\n * Insert a widget into the layout at the specified index.\n *\n * @param index - The index at which to insert the widget.\n *\n * @param widget - The widget to insert into the layout.\n *\n * #### Notes\n * The index will be clamped to the bounds of the widgets.\n *\n * If the widget is already added to the layout, it will be moved.\n *\n * #### Undefined Behavior\n * An `index` which is non-integral.\n */\n insertWidget(index: number, widget: Widget): void {\n // Remove the widget from its current parent. This is a no-op\n // if the widget's parent is already the layout parent widget.\n widget.parent = this.parent;\n\n // Look up the current index of the widget.\n let i = this._widgets.indexOf(widget);\n\n // Clamp the insert index to the array bounds.\n let j = Math.max(0, Math.min(index, this._widgets.length));\n\n // If the widget is not in the array, insert it.\n if (i === -1) {\n // Insert the widget into the array.\n ArrayExt.insert(this._widgets, j, widget);\n\n // If the layout is parented, attach the widget to the DOM.\n if (this.parent) {\n this.attachWidget(j, widget);\n }\n\n // There is nothing more to do.\n return;\n }\n\n // Otherwise, the widget exists in the array and should be moved.\n\n // Adjust the index if the location is at the end of the array.\n if (j === this._widgets.length) {\n j--;\n }\n\n // Bail if there is no effective move.\n if (i === j) {\n return;\n }\n\n // Move the widget to the new location.\n ArrayExt.move(this._widgets, i, j);\n\n // If the layout is parented, move the widget in the DOM.\n if (this.parent) {\n this.moveWidget(i, j, widget);\n }\n }\n\n /**\n * Remove a widget from the layout.\n *\n * @param widget - The widget to remove from the layout.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method does *not* modify the widget's `parent`.\n */\n removeWidget(widget: Widget): void {\n this.removeWidgetAt(this._widgets.indexOf(widget));\n }\n\n /**\n * Remove the widget at a given index from the layout.\n *\n * @param index - The index of the widget to remove.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method does *not* modify the widget's `parent`.\n *\n * #### Undefined Behavior\n * An `index` which is non-integral.\n */\n removeWidgetAt(index: number): void {\n // Remove the widget from the array.\n let widget = ArrayExt.removeAt(this._widgets, index);\n\n // If the layout is parented, detach the widget from the DOM.\n if (widget && this.parent) {\n this.detachWidget(index, widget);\n }\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n super.init();\n let index = 0;\n for (const widget of this) {\n this.attachWidget(index++, widget);\n }\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param index - The current index of the widget in the layout.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This method is called automatically by the panel layout at the\n * appropriate time. It should not be called directly by user code.\n *\n * The default implementation adds the widgets's node to the parent's\n * node at the proper location, and sends the appropriate attach\n * messages to the widget if the parent is attached to the DOM.\n *\n * Subclasses may reimplement this method to control how the widget's\n * node is added to the parent's node.\n */\n protected attachWidget(index: number, widget: Widget): void {\n // Look up the next sibling reference node.\n let ref = this.parent!.node.children[index];\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Insert the widget's node before the sibling.\n this.parent!.node.insertBefore(widget.node, ref);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n }\n\n /**\n * Move a widget in the parent's DOM node.\n *\n * @param fromIndex - The previous index of the widget in the layout.\n *\n * @param toIndex - The current index of the widget in the layout.\n *\n * @param widget - The widget to move in the parent.\n *\n * #### Notes\n * This method is called automatically by the panel layout at the\n * appropriate time. It should not be called directly by user code.\n *\n * The default implementation moves the widget's node to the proper\n * location in the parent's node and sends the appropriate attach and\n * detach messages to the widget if the parent is attached to the DOM.\n *\n * Subclasses may reimplement this method to control how the widget's\n * node is moved in the parent's node.\n */\n protected moveWidget(\n fromIndex: number,\n toIndex: number,\n widget: Widget\n ): void {\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` and message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Look up the next sibling reference node.\n let ref = this.parent!.node.children[toIndex];\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Insert the widget's node before the sibling.\n this.parent!.node.insertBefore(widget.node, ref);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param index - The previous index of the widget in the layout.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This method is called automatically by the panel layout at the\n * appropriate time. It should not be called directly by user code.\n *\n * The default implementation removes the widget's node from the\n * parent's node, and sends the appropriate detach messages to the\n * widget if the parent is attached to the DOM.\n *\n * Subclasses may reimplement this method to control how the widget's\n * node is removed from the parent's node.\n */\n protected detachWidget(index: number, widget: Widget): void {\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n }\n\n private _widgets: Widget[] = [];\n}\n","/*\n * Copyright (c) Jupyter Development Team.\n * Distributed under the terms of the Modified BSD License.\n */\n\nexport namespace Utils {\n /**\n * Clamp a dimension value to an integer >= 0.\n */\n export function clampDimension(value: number): number {\n return Math.max(0, Math.floor(value));\n }\n}\n\nexport default Utils;\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { BoxEngine, BoxSizer } from './boxengine';\n\nimport { LayoutItem } from './layout';\n\nimport { PanelLayout } from './panellayout';\n\nimport { Utils } from './utils';\n\nimport { Widget } from './widget';\n\n/**\n * A layout which arranges its widgets into resizable sections.\n */\nexport class SplitLayout extends PanelLayout {\n /**\n * Construct a new split layout.\n *\n * @param options - The options for initializing the layout.\n */\n constructor(options: SplitLayout.IOptions) {\n super();\n this.renderer = options.renderer;\n if (options.orientation !== undefined) {\n this._orientation = options.orientation;\n }\n if (options.alignment !== undefined) {\n this._alignment = options.alignment;\n }\n if (options.spacing !== undefined) {\n this._spacing = Utils.clampDimension(options.spacing);\n }\n }\n\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n // Dispose of the layout items.\n for (const item of this._items) {\n item.dispose();\n }\n\n // Clear the layout state.\n this._box = null;\n this._items.length = 0;\n this._sizers.length = 0;\n this._handles.length = 0;\n\n // Dispose of the rest of the layout.\n super.dispose();\n }\n\n /**\n * The renderer used by the split layout.\n */\n readonly renderer: SplitLayout.IRenderer;\n\n /**\n * Get the layout orientation for the split layout.\n */\n get orientation(): SplitLayout.Orientation {\n return this._orientation;\n }\n\n /**\n * Set the layout orientation for the split layout.\n */\n set orientation(value: SplitLayout.Orientation) {\n if (this._orientation === value) {\n return;\n }\n this._orientation = value;\n if (!this.parent) {\n return;\n }\n this.parent.dataset['orientation'] = value;\n this.parent.fit();\n }\n\n /**\n * Get the content alignment for the split layout.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire split layout.\n */\n get alignment(): SplitLayout.Alignment {\n return this._alignment;\n }\n\n /**\n * Set the content alignment for the split layout.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire split layout.\n */\n set alignment(value: SplitLayout.Alignment) {\n if (this._alignment === value) {\n return;\n }\n this._alignment = value;\n if (!this.parent) {\n return;\n }\n this.parent.dataset['alignment'] = value;\n this.parent.update();\n }\n\n /**\n * Get the inter-element spacing for the split layout.\n */\n get spacing(): number {\n return this._spacing;\n }\n\n /**\n * Set the inter-element spacing for the split layout.\n */\n set spacing(value: number) {\n value = Utils.clampDimension(value);\n if (this._spacing === value) {\n return;\n }\n this._spacing = value;\n if (!this.parent) {\n return;\n }\n this.parent.fit();\n }\n\n /**\n * A read-only array of the split handles in the layout.\n */\n get handles(): ReadonlyArray {\n return this._handles;\n }\n\n /**\n * Get the absolute sizes of the widgets in the layout.\n *\n * @returns A new array of the absolute sizes of the widgets.\n *\n * This method **does not** measure the DOM nodes.\n */\n absoluteSizes(): number[] {\n return this._sizers.map(sizer => sizer.size);\n }\n\n /**\n * Get the relative sizes of the widgets in the layout.\n *\n * @returns A new array of the relative sizes of the widgets.\n *\n * #### Notes\n * The returned sizes reflect the sizes of the widgets normalized\n * relative to their siblings.\n *\n * This method **does not** measure the DOM nodes.\n */\n relativeSizes(): number[] {\n return Private.normalize(this._sizers.map(sizer => sizer.size));\n }\n\n /**\n * Set the relative sizes for the widgets in the layout.\n *\n * @param sizes - The relative sizes for the widgets in the panel.\n * @param update - Update the layout after setting relative sizes.\n * Default is True.\n *\n * #### Notes\n * Extra values are ignored, too few will yield an undefined layout.\n *\n * The actual geometry of the DOM nodes is updated asynchronously.\n */\n setRelativeSizes(sizes: number[], update = true): void {\n // Copy the sizes and pad with zeros as needed.\n let n = this._sizers.length;\n let temp = sizes.slice(0, n);\n while (temp.length < n) {\n temp.push(0);\n }\n\n // Normalize the padded sizes.\n let normed = Private.normalize(temp);\n\n // Apply the normalized sizes to the sizers.\n for (let i = 0; i < n; ++i) {\n let sizer = this._sizers[i];\n sizer.sizeHint = normed[i];\n sizer.size = normed[i];\n }\n\n // Set the flag indicating the sizes are normalized.\n this._hasNormedSizes = true;\n\n // Trigger an update of the parent widget.\n if (update && this.parent) {\n this.parent.update();\n }\n }\n\n /**\n * Move the offset position of a split handle.\n *\n * @param index - The index of the handle of the interest.\n *\n * @param position - The desired offset position of the handle.\n *\n * #### Notes\n * The position is relative to the offset parent.\n *\n * This will move the handle as close as possible to the desired\n * position. The sibling widgets will be adjusted as necessary.\n */\n moveHandle(index: number, position: number): void {\n // Bail if the index is invalid or the handle is hidden.\n let handle = this._handles[index];\n if (!handle || handle.classList.contains('lm-mod-hidden')) {\n return;\n }\n\n // Compute the desired delta movement for the handle.\n let delta: number;\n if (this._orientation === 'horizontal') {\n delta = position - handle.offsetLeft;\n } else {\n delta = position - handle.offsetTop;\n }\n\n // Bail if there is no handle movement.\n if (delta === 0) {\n return;\n }\n\n // Prevent widget resizing unless needed.\n for (let sizer of this._sizers) {\n if (sizer.size > 0) {\n sizer.sizeHint = sizer.size;\n }\n }\n\n // Adjust the sizers to reflect the handle movement.\n BoxEngine.adjust(this._sizers, index, delta);\n\n // Update the layout of the widgets.\n if (this.parent) {\n this.parent.update();\n }\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n this.parent!.dataset['orientation'] = this.orientation;\n this.parent!.dataset['alignment'] = this.alignment;\n super.init();\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param index - The current index of the widget in the layout.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected attachWidget(index: number, widget: Widget): void {\n // Create the item, handle, and sizer for the new widget.\n let item = new LayoutItem(widget);\n let handle = Private.createHandle(this.renderer);\n let average = Private.averageSize(this._sizers);\n let sizer = Private.createSizer(average);\n\n // Insert the item, handle, and sizer into the internal arrays.\n ArrayExt.insert(this._items, index, item);\n ArrayExt.insert(this._sizers, index, sizer);\n ArrayExt.insert(this._handles, index, handle);\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget and handle nodes to the parent.\n this.parent!.node.appendChild(widget.node);\n this.parent!.node.appendChild(handle);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * Move a widget in the parent's DOM node.\n *\n * @param fromIndex - The previous index of the widget in the layout.\n *\n * @param toIndex - The current index of the widget in the layout.\n *\n * @param widget - The widget to move in the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected moveWidget(\n fromIndex: number,\n toIndex: number,\n widget: Widget\n ): void {\n // Move the item, sizer, and handle for the widget.\n ArrayExt.move(this._items, fromIndex, toIndex);\n ArrayExt.move(this._sizers, fromIndex, toIndex);\n ArrayExt.move(this._handles, fromIndex, toIndex);\n\n // Post a fit request to the parent to show/hide last handle.\n this.parent!.fit();\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param index - The previous index of the widget in the layout.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected detachWidget(index: number, widget: Widget): void {\n // Remove the item, handle, and sizer for the widget.\n let item = ArrayExt.removeAt(this._items, index);\n let handle = ArrayExt.removeAt(this._handles, index);\n ArrayExt.removeAt(this._sizers, index);\n\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget and handle nodes from the parent.\n this.parent!.node.removeChild(widget.node);\n this.parent!.node.removeChild(handle!);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Dispose of the layout item.\n item!.dispose();\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n */\n protected onBeforeShow(msg: Message): void {\n super.onBeforeShow(msg);\n this.parent!.update();\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n super.onBeforeAttach(msg);\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n if (this.parent!.isVisible) {\n this._update(msg.width, msg.height);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.parent!.isVisible) {\n this._update(-1, -1);\n }\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n */\n protected onFitRequest(msg: Message): void {\n if (this.parent!.isAttached) {\n this._fit();\n }\n }\n\n /**\n * Update the item position.\n *\n * @param i Item index\n * @param isHorizontal Whether the layout is horizontal or not\n * @param left Left position in pixels\n * @param top Top position in pixels\n * @param height Item height\n * @param width Item width\n * @param size Item size\n */\n protected updateItemPosition(\n i: number,\n isHorizontal: boolean,\n left: number,\n top: number,\n height: number,\n width: number,\n size: number\n ): void {\n const item = this._items[i];\n if (item.isHidden) {\n return;\n }\n\n // Fetch the style for the handle.\n let handleStyle = this._handles[i].style;\n\n // Update the widget and handle, and advance the relevant edge.\n if (isHorizontal) {\n left += this.widgetOffset;\n item.update(left, top, size, height);\n left += size;\n handleStyle.top = `${top}px`;\n handleStyle.left = `${left}px`;\n handleStyle.width = `${this._spacing}px`;\n handleStyle.height = `${height}px`;\n } else {\n top += this.widgetOffset;\n item.update(left, top, width, size);\n top += size;\n handleStyle.top = `${top}px`;\n handleStyle.left = `${left}px`;\n handleStyle.width = `${width}px`;\n handleStyle.height = `${this._spacing}px`;\n }\n }\n\n /**\n * Fit the layout to the total size required by the widgets.\n */\n private _fit(): void {\n // Update the handles and track the visible widget count.\n let nVisible = 0;\n let lastHandleIndex = -1;\n for (let i = 0, n = this._items.length; i < n; ++i) {\n if (this._items[i].isHidden) {\n this._handles[i].classList.add('lm-mod-hidden');\n } else {\n this._handles[i].classList.remove('lm-mod-hidden');\n lastHandleIndex = i;\n nVisible++;\n }\n }\n\n // Hide the handle for the last visible widget.\n if (lastHandleIndex !== -1) {\n this._handles[lastHandleIndex].classList.add('lm-mod-hidden');\n }\n\n // Update the fixed space for the visible items.\n this._fixed =\n this._spacing * Math.max(0, nVisible - 1) +\n this.widgetOffset * this._items.length;\n\n // Setup the computed minimum size.\n let horz = this._orientation === 'horizontal';\n let minW = horz ? this._fixed : 0;\n let minH = horz ? 0 : this._fixed;\n\n // Update the sizers and computed size limits.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item and corresponding box sizer.\n let item = this._items[i];\n let sizer = this._sizers[i];\n\n // Prevent resizing unless necessary.\n if (sizer.size > 0) {\n sizer.sizeHint = sizer.size;\n }\n\n // If the item is hidden, it should consume zero size.\n if (item.isHidden) {\n sizer.minSize = 0;\n sizer.maxSize = 0;\n continue;\n }\n\n // Update the size limits for the item.\n item.fit();\n\n // Update the stretch factor.\n sizer.stretch = SplitLayout.getStretch(item.widget);\n\n // Update the sizer limits and computed min size.\n if (horz) {\n sizer.minSize = item.minWidth;\n sizer.maxSize = item.maxWidth;\n minW += item.minWidth;\n minH = Math.max(minH, item.minHeight);\n } else {\n sizer.minSize = item.minHeight;\n sizer.maxSize = item.maxHeight;\n minH += item.minHeight;\n minW = Math.max(minW, item.minWidth);\n }\n }\n\n // Update the box sizing and add it to the computed min size.\n let box = (this._box = ElementExt.boxSizing(this.parent!.node));\n minW += box.horizontalSum;\n minH += box.verticalSum;\n\n // Update the parent's min size constraints.\n let style = this.parent!.node.style;\n style.minWidth = `${minW}px`;\n style.minHeight = `${minH}px`;\n\n // Set the dirty flag to ensure only a single update occurs.\n this._dirty = true;\n\n // Notify the ancestor that it should fit immediately. This may\n // cause a resize of the parent, fulfilling the required update.\n if (this.parent!.parent) {\n MessageLoop.sendMessage(this.parent!.parent!, Widget.Msg.FitRequest);\n }\n\n // If the dirty flag is still set, the parent was not resized.\n // Trigger the required update on the parent widget immediately.\n if (this._dirty) {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n }\n }\n\n /**\n * Update the layout position and size of the widgets.\n *\n * The parent offset dimensions should be `-1` if unknown.\n */\n private _update(offsetWidth: number, offsetHeight: number): void {\n // Clear the dirty flag to indicate the update occurred.\n this._dirty = false;\n\n // Compute the visible item count.\n let nVisible = 0;\n for (let i = 0, n = this._items.length; i < n; ++i) {\n nVisible += +!this._items[i].isHidden;\n }\n\n // Bail early if there are no visible items to layout.\n if (nVisible === 0 && this.widgetOffset === 0) {\n return;\n }\n\n // Measure the parent if the offset dimensions are unknown.\n if (offsetWidth < 0) {\n offsetWidth = this.parent!.node.offsetWidth;\n }\n if (offsetHeight < 0) {\n offsetHeight = this.parent!.node.offsetHeight;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent!.node);\n }\n\n // Compute the actual layout bounds adjusted for border and padding.\n let top = this._box.paddingTop;\n let left = this._box.paddingLeft;\n let width = offsetWidth - this._box.horizontalSum;\n let height = offsetHeight - this._box.verticalSum;\n\n // Set up the variables for justification and alignment offset.\n let extra = 0;\n let offset = 0;\n let horz = this._orientation === 'horizontal';\n\n if (nVisible > 0) {\n // Compute the adjusted layout space.\n let space: number;\n if (horz) {\n // left += this.widgetOffset;\n space = Math.max(0, width - this._fixed);\n } else {\n // top += this.widgetOffset;\n space = Math.max(0, height - this._fixed);\n }\n\n // Scale the size hints if they are normalized.\n if (this._hasNormedSizes) {\n for (let sizer of this._sizers) {\n sizer.sizeHint *= space;\n }\n this._hasNormedSizes = false;\n }\n\n // Distribute the layout space to the box sizers.\n let delta = BoxEngine.calc(this._sizers, space);\n\n // Account for alignment if there is extra layout space.\n if (delta > 0) {\n switch (this._alignment) {\n case 'start':\n break;\n case 'center':\n extra = 0;\n offset = delta / 2;\n break;\n case 'end':\n extra = 0;\n offset = delta;\n break;\n case 'justify':\n extra = delta / nVisible;\n offset = 0;\n break;\n default:\n throw 'unreachable';\n }\n }\n }\n\n // Layout the items using the computed box sizes.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item.\n const item = this._items[i];\n\n // Fetch the computed size for the widget.\n const size = item.isHidden ? 0 : this._sizers[i].size + extra;\n\n this.updateItemPosition(\n i,\n horz,\n horz ? left + offset : left,\n horz ? top : top + offset,\n height,\n width,\n size\n );\n\n const fullOffset =\n this.widgetOffset +\n (this._handles[i].classList.contains('lm-mod-hidden')\n ? 0\n : this._spacing);\n\n if (horz) {\n left += size + fullOffset;\n } else {\n top += size + fullOffset;\n }\n }\n }\n\n protected widgetOffset = 0;\n private _fixed = 0;\n private _spacing = 4;\n private _dirty = false;\n private _hasNormedSizes = false;\n private _sizers: BoxSizer[] = [];\n private _items: LayoutItem[] = [];\n private _handles: HTMLDivElement[] = [];\n private _box: ElementExt.IBoxSizing | null = null;\n private _alignment: SplitLayout.Alignment = 'start';\n private _orientation: SplitLayout.Orientation = 'horizontal';\n}\n\n/**\n * The namespace for the `SplitLayout` class statics.\n */\nexport namespace SplitLayout {\n /**\n * A type alias for a split layout orientation.\n */\n export type Orientation = 'horizontal' | 'vertical';\n\n /**\n * A type alias for a split layout alignment.\n */\n export type Alignment = 'start' | 'center' | 'end' | 'justify';\n\n /**\n * An options object for initializing a split layout.\n */\n export interface IOptions {\n /**\n * The renderer to use for the split layout.\n */\n renderer: IRenderer;\n\n /**\n * The orientation of the layout.\n *\n * The default is `'horizontal'`.\n */\n orientation?: Orientation;\n\n /**\n * The content alignment of the layout.\n *\n * The default is `'start'`.\n */\n alignment?: Alignment;\n\n /**\n * The spacing between items in the layout.\n *\n * The default is `4`.\n */\n spacing?: number;\n }\n\n /**\n * A renderer for use with a split layout.\n */\n export interface IRenderer {\n /**\n * Create a new handle for use with a split layout.\n *\n * @returns A new handle element.\n */\n createHandle(): HTMLDivElement;\n }\n\n /**\n * Get the split layout stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The split layout stretch factor for the widget.\n */\n export function getStretch(widget: Widget): number {\n return Private.stretchProperty.get(widget);\n }\n\n /**\n * Set the split layout stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the stretch factor.\n */\n export function setStretch(widget: Widget, value: number): void {\n Private.stretchProperty.set(widget, value);\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The property descriptor for a widget stretch factor.\n */\n export const stretchProperty = new AttachedProperty({\n name: 'stretch',\n create: () => 0,\n coerce: (owner, value) => Math.max(0, Math.floor(value)),\n changed: onChildSizingChanged\n });\n\n /**\n * Create a new box sizer with the given size hint.\n */\n export function createSizer(size: number): BoxSizer {\n let sizer = new BoxSizer();\n sizer.sizeHint = Math.floor(size);\n return sizer;\n }\n\n /**\n * Create a new split handle node using the given renderer.\n */\n export function createHandle(\n renderer: SplitLayout.IRenderer\n ): HTMLDivElement {\n let handle = renderer.createHandle();\n handle.style.position = 'absolute';\n // Do not use size containment to allow the handle to fill the available space\n handle.style.contain = 'style';\n return handle;\n }\n\n /**\n * Compute the average size of an array of box sizers.\n */\n export function averageSize(sizers: BoxSizer[]): number {\n return sizers.reduce((v, s) => v + s.size, 0) / sizers.length || 0;\n }\n\n /**\n * Normalize an array of values.\n */\n export function normalize(values: number[]): number[] {\n let n = values.length;\n if (n === 0) {\n return [];\n }\n let sum = values.reduce((a, b) => a + Math.abs(b), 0);\n return sum === 0 ? values.map(v => 1 / n) : values.map(v => v / sum);\n }\n\n /**\n * The change handler for the attached sizing properties.\n */\n function onChildSizingChanged(child: Widget): void {\n if (child.parent && child.parent.layout instanceof SplitLayout) {\n child.parent.fit();\n }\n }\n}\n","/*\n * Copyright (c) Jupyter Development Team.\n * Distributed under the terms of the Modified BSD License.\n */\n\nimport { ArrayExt } from '@lumino/algorithm';\nimport { UUID } from '@lumino/coreutils';\nimport { SplitLayout } from './splitlayout';\nimport { Title } from './title';\nimport Utils from './utils';\nimport { Widget } from './widget';\n\n/**\n * A layout which arranges its widgets into collapsible resizable sections.\n */\nexport class AccordionLayout extends SplitLayout {\n /**\n * Construct a new accordion layout.\n *\n * @param options - The options for initializing the layout.\n *\n * #### Notes\n * The default orientation will be vertical.\n *\n * Titles must be rotated for horizontal accordion panel using CSS: see accordionpanel.css\n */\n constructor(options: AccordionLayout.IOptions) {\n super({ ...options, orientation: options.orientation || 'vertical' });\n this.titleSpace = options.titleSpace || 22;\n }\n\n /**\n * The section title height or width depending on the orientation.\n */\n get titleSpace(): number {\n return this.widgetOffset;\n }\n set titleSpace(value: number) {\n value = Utils.clampDimension(value);\n if (this.widgetOffset === value) {\n return;\n }\n this.widgetOffset = value;\n if (!this.parent) {\n return;\n }\n this.parent.fit();\n }\n\n /**\n * A read-only array of the section titles in the panel.\n */\n get titles(): ReadonlyArray {\n return this._titles;\n }\n\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n if (this.isDisposed) {\n return;\n }\n\n // Clear the layout state.\n this._titles.length = 0;\n\n // Dispose of the rest of the layout.\n super.dispose();\n }\n\n /**\n * The renderer used by the accordion layout.\n */\n readonly renderer: AccordionLayout.IRenderer;\n\n public updateTitle(index: number, widget: Widget): void {\n const oldTitle = this._titles[index];\n const expanded = oldTitle.classList.contains('lm-mod-expanded');\n const newTitle = Private.createTitle(this.renderer, widget.title, expanded);\n this._titles[index] = newTitle;\n\n // Add the title node to the parent before the widget.\n this.parent!.node.replaceChild(newTitle, oldTitle);\n }\n\n /**\n * Insert a widget into the layout at the specified index.\n *\n * @param index - The index at which to insert the widget.\n *\n * @param widget - The widget to insert into the layout.\n *\n * #### Notes\n * The index will be clamped to the bounds of the widgets.\n *\n * If the widget is already added to the layout, it will be moved.\n *\n * #### Undefined Behavior\n * An `index` which is non-integral.\n */\n insertWidget(index: number, widget: Widget): void {\n if (!widget.id) {\n widget.id = `id-${UUID.uuid4()}`;\n }\n super.insertWidget(index, widget);\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param index - The current index of the widget in the layout.\n *\n * @param widget - The widget to attach to the parent.\n */\n protected attachWidget(index: number, widget: Widget): void {\n const title = Private.createTitle(this.renderer, widget.title);\n\n ArrayExt.insert(this._titles, index, title);\n\n // Add the title node to the parent before the widget.\n this.parent!.node.appendChild(title);\n\n widget.node.setAttribute('role', 'region');\n widget.node.setAttribute('aria-labelledby', title.id);\n\n super.attachWidget(index, widget);\n }\n\n /**\n * Move a widget in the parent's DOM node.\n *\n * @param fromIndex - The previous index of the widget in the layout.\n *\n * @param toIndex - The current index of the widget in the layout.\n *\n * @param widget - The widget to move in the parent.\n */\n protected moveWidget(\n fromIndex: number,\n toIndex: number,\n widget: Widget\n ): void {\n ArrayExt.move(this._titles, fromIndex, toIndex);\n super.moveWidget(fromIndex, toIndex, widget);\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param index - The previous index of the widget in the layout.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected detachWidget(index: number, widget: Widget): void {\n const title = ArrayExt.removeAt(this._titles, index);\n\n this.parent!.node.removeChild(title!);\n\n super.detachWidget(index, widget);\n }\n\n /**\n * Update the item position.\n *\n * @param i Item index\n * @param isHorizontal Whether the layout is horizontal or not\n * @param left Left position in pixels\n * @param top Top position in pixels\n * @param height Item height\n * @param width Item width\n * @param size Item size\n */\n protected updateItemPosition(\n i: number,\n isHorizontal: boolean,\n left: number,\n top: number,\n height: number,\n width: number,\n size: number\n ): void {\n const titleStyle = this._titles[i].style;\n\n // Titles must be rotated for horizontal accordion panel using CSS: see accordionpanel.css\n titleStyle.top = `${top}px`;\n titleStyle.left = `${left}px`;\n titleStyle.height = `${this.widgetOffset}px`;\n if (isHorizontal) {\n titleStyle.width = `${height}px`;\n } else {\n titleStyle.width = `${width}px`;\n }\n\n super.updateItemPosition(i, isHorizontal, left, top, height, width, size);\n }\n\n private _titles: HTMLElement[] = [];\n}\n\nexport namespace AccordionLayout {\n /**\n * A type alias for a accordion layout orientation.\n */\n export type Orientation = SplitLayout.Orientation;\n\n /**\n * A type alias for a accordion layout alignment.\n */\n export type Alignment = SplitLayout.Alignment;\n\n /**\n * An options object for initializing a accordion layout.\n */\n export interface IOptions extends SplitLayout.IOptions {\n /**\n * The renderer to use for the accordion layout.\n */\n renderer: IRenderer;\n\n /**\n * The section title height or width depending on the orientation.\n *\n * The default is `22`.\n */\n titleSpace?: number;\n }\n\n /**\n * A renderer for use with an accordion layout.\n */\n export interface IRenderer extends SplitLayout.IRenderer {\n /**\n * Common class name for all accordion titles.\n */\n readonly titleClassName: string;\n\n /**\n * Render the element for a section title.\n *\n * @param title - The data to use for rendering the section title.\n *\n * @returns A element representing the section title.\n */\n createSectionTitle(title: Title): HTMLElement;\n }\n}\n\nnamespace Private {\n /**\n * Create the title HTML element.\n *\n * @param renderer Accordion renderer\n * @param data Widget title\n * @returns Title HTML element\n */\n export function createTitle(\n renderer: AccordionLayout.IRenderer,\n data: Title,\n expanded: boolean = true\n ): HTMLElement {\n const title = renderer.createSectionTitle(data);\n title.style.position = 'absolute';\n title.style.contain = 'strict';\n title.setAttribute('aria-label', `${data.label} Section`);\n title.setAttribute('aria-expanded', expanded ? 'true' : 'false');\n title.setAttribute('aria-controls', data.owner.id);\n if (expanded) {\n title.classList.add('lm-mod-expanded');\n }\n return title;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { PanelLayout } from './panellayout';\n\nimport { Widget } from './widget';\n\n/**\n * A simple and convenient panel widget class.\n *\n * #### Notes\n * This class is suitable as a base class for implementing a variety of\n * convenience panel widgets, but can also be used directly with CSS to\n * arrange a collection of widgets.\n *\n * This class provides a convenience wrapper around a {@link PanelLayout}.\n */\nexport class Panel extends Widget {\n /**\n * Construct a new panel.\n *\n * @param options - The options for initializing the panel.\n */\n constructor(options: Panel.IOptions = {}) {\n super();\n this.addClass('lm-Panel');\n this.layout = Private.createLayout(options);\n }\n\n /**\n * A read-only array of the widgets in the panel.\n */\n get widgets(): ReadonlyArray {\n return (this.layout as PanelLayout).widgets;\n }\n\n /**\n * Add a widget to the end of the panel.\n *\n * @param widget - The widget to add to the panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n */\n addWidget(widget: Widget): void {\n (this.layout as PanelLayout).addWidget(widget);\n }\n\n /**\n * Insert a widget at the specified index.\n *\n * @param index - The index at which to insert the widget.\n *\n * @param widget - The widget to insert into to the panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n */\n insertWidget(index: number, widget: Widget): void {\n (this.layout as PanelLayout).insertWidget(index, widget);\n }\n}\n\n/**\n * The namespace for the `Panel` class statics.\n */\nexport namespace Panel {\n /**\n * An options object for creating a panel.\n */\n export interface IOptions {\n /**\n * The panel layout to use for the panel.\n *\n * The default is a new `PanelLayout`.\n */\n layout?: PanelLayout;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Create a panel layout for the given panel options.\n */\n export function createLayout(options: Panel.IOptions): PanelLayout {\n return options.layout || new PanelLayout();\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { IDisposable } from '@lumino/disposable';\n\nimport { Drag } from '@lumino/dragdrop';\n\nimport { Message } from '@lumino/messaging';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { Panel } from './panel';\n\nimport { SplitLayout } from './splitlayout';\n\nimport { Widget } from './widget';\n\n/**\n * A panel which arranges its widgets into resizable sections.\n *\n * #### Notes\n * This class provides a convenience wrapper around a {@link SplitLayout}.\n */\nexport class SplitPanel extends Panel {\n /**\n * Construct a new split panel.\n *\n * @param options - The options for initializing the split panel.\n */\n constructor(options: SplitPanel.IOptions = {}) {\n super({ layout: Private.createLayout(options) });\n this.addClass('lm-SplitPanel');\n }\n\n /**\n * Dispose of the resources held by the panel.\n */\n dispose(): void {\n this._releaseMouse();\n super.dispose();\n }\n\n /**\n * Get the layout orientation for the split panel.\n */\n get orientation(): SplitPanel.Orientation {\n return (this.layout as SplitLayout).orientation;\n }\n\n /**\n * Set the layout orientation for the split panel.\n */\n set orientation(value: SplitPanel.Orientation) {\n (this.layout as SplitLayout).orientation = value;\n }\n\n /**\n * Get the content alignment for the split panel.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire split panel.\n */\n get alignment(): SplitPanel.Alignment {\n return (this.layout as SplitLayout).alignment;\n }\n\n /**\n * Set the content alignment for the split panel.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire split panel.\n */\n set alignment(value: SplitPanel.Alignment) {\n (this.layout as SplitLayout).alignment = value;\n }\n\n /**\n * Get the inter-element spacing for the split panel.\n */\n get spacing(): number {\n return (this.layout as SplitLayout).spacing;\n }\n\n /**\n * Set the inter-element spacing for the split panel.\n */\n set spacing(value: number) {\n (this.layout as SplitLayout).spacing = value;\n }\n\n /**\n * The renderer used by the split panel.\n */\n get renderer(): SplitPanel.IRenderer {\n return (this.layout as SplitLayout).renderer;\n }\n\n /**\n * A signal emitted when a split handle has moved.\n */\n get handleMoved(): ISignal {\n return this._handleMoved;\n }\n\n /**\n * A read-only array of the split handles in the panel.\n */\n get handles(): ReadonlyArray {\n return (this.layout as SplitLayout).handles;\n }\n\n /**\n * Get the relative sizes of the widgets in the panel.\n *\n * @returns A new array of the relative sizes of the widgets.\n *\n * #### Notes\n * The returned sizes reflect the sizes of the widgets normalized\n * relative to their siblings.\n *\n * This method **does not** measure the DOM nodes.\n */\n relativeSizes(): number[] {\n return (this.layout as SplitLayout).relativeSizes();\n }\n\n /**\n * Set the relative sizes for the widgets in the panel.\n *\n * @param sizes - The relative sizes for the widgets in the panel.\n * @param update - Update the layout after setting relative sizes.\n * Default is True.\n *\n * #### Notes\n * Extra values are ignored, too few will yield an undefined layout.\n *\n * The actual geometry of the DOM nodes is updated asynchronously.\n */\n setRelativeSizes(sizes: number[], update = true): void {\n (this.layout as SplitLayout).setRelativeSizes(sizes, update);\n }\n\n /**\n * Handle the DOM events for the split panel.\n *\n * @param event - The DOM event sent to the panel.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the panel's DOM node. It should\n * not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'pointerdown':\n this._evtPointerDown(event as PointerEvent);\n break;\n case 'pointermove':\n this._evtPointerMove(event as PointerEvent);\n break;\n case 'pointerup':\n this._evtPointerUp(event as PointerEvent);\n break;\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('pointerdown', this);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('pointerdown', this);\n this._releaseMouse();\n }\n\n /**\n * A message handler invoked on a `'child-added'` message.\n */\n protected onChildAdded(msg: Widget.ChildMessage): void {\n msg.child.addClass('lm-SplitPanel-child');\n this._releaseMouse();\n }\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {\n msg.child.removeClass('lm-SplitPanel-child');\n this._releaseMouse();\n }\n\n /**\n * Handle the `'keydown'` event for the split panel.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // Stop input events during drag.\n if (this._pressData) {\n event.preventDefault();\n event.stopPropagation();\n }\n\n // Release the mouse if `Escape` is pressed.\n if (event.keyCode === 27) {\n this._releaseMouse();\n }\n }\n\n /**\n * Handle the `'pointerdown'` event for the split panel.\n */\n private _evtPointerDown(event: PointerEvent): void {\n // Do nothing if the primary button is not pressed.\n if (event.button !== 0) {\n return;\n }\n\n // Find the handle which contains the target, if any.\n let layout = this.layout as SplitLayout;\n let index = ArrayExt.findFirstIndex(layout.handles, handle => {\n return handle.contains(event.target as HTMLElement);\n });\n\n // Bail early if the mouse press was not on a handle.\n if (index === -1) {\n return;\n }\n\n // Stop the event when a split handle is pressed.\n event.preventDefault();\n event.stopPropagation();\n\n // Add the extra document listeners.\n document.addEventListener('pointerup', this, true);\n document.addEventListener('pointermove', this, true);\n document.addEventListener('keydown', this, true);\n document.addEventListener('contextmenu', this, true);\n\n // Compute the offset delta for the handle press.\n let delta: number;\n let handle = layout.handles[index];\n let rect = handle.getBoundingClientRect();\n if (layout.orientation === 'horizontal') {\n delta = event.clientX - rect.left;\n } else {\n delta = event.clientY - rect.top;\n }\n\n // Override the cursor and store the press data.\n let style = window.getComputedStyle(handle);\n let override = Drag.overrideCursor(style.cursor!);\n this._pressData = { index, delta, override };\n }\n\n /**\n * Handle the `'pointermove'` event for the split panel.\n */\n private _evtPointerMove(event: PointerEvent): void {\n // Stop the event when dragging a split handle.\n event.preventDefault();\n event.stopPropagation();\n\n // Compute the desired offset position for the handle.\n let pos: number;\n let layout = this.layout as SplitLayout;\n let rect = this.node.getBoundingClientRect();\n if (layout.orientation === 'horizontal') {\n pos = event.clientX - rect.left - this._pressData!.delta;\n } else {\n pos = event.clientY - rect.top - this._pressData!.delta;\n }\n\n // Move the handle as close to the desired position as possible.\n layout.moveHandle(this._pressData!.index, pos);\n }\n\n /**\n * Handle the `'pointerup'` event for the split panel.\n */\n private _evtPointerUp(event: PointerEvent): void {\n // Do nothing if the primary button is not released.\n if (event.button !== 0) {\n return;\n }\n\n // Stop the event when releasing a handle.\n event.preventDefault();\n event.stopPropagation();\n\n // Finalize the mouse release.\n this._releaseMouse();\n }\n\n /**\n * Release the mouse grab for the split panel.\n */\n private _releaseMouse(): void {\n // Bail early if no drag is in progress.\n if (!this._pressData) {\n return;\n }\n\n // Clear the override cursor.\n this._pressData.override.dispose();\n this._pressData = null;\n\n // Emit the handle moved signal.\n this._handleMoved.emit();\n\n // Remove the extra document listeners.\n document.removeEventListener('keydown', this, true);\n document.removeEventListener('pointerup', this, true);\n document.removeEventListener('pointermove', this, true);\n document.removeEventListener('contextmenu', this, true);\n }\n\n private _handleMoved = new Signal(this);\n private _pressData: Private.IPressData | null = null;\n}\n\n/**\n * The namespace for the `SplitPanel` class statics.\n */\nexport namespace SplitPanel {\n /**\n * A type alias for a split panel orientation.\n */\n export type Orientation = SplitLayout.Orientation;\n\n /**\n * A type alias for a split panel alignment.\n */\n export type Alignment = SplitLayout.Alignment;\n\n /**\n * A type alias for a split panel renderer.\n */\n export type IRenderer = SplitLayout.IRenderer;\n\n /**\n * An options object for initializing a split panel.\n */\n export interface IOptions {\n /**\n * The renderer to use for the split panel.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n\n /**\n * The layout orientation of the panel.\n *\n * The default is `'horizontal'`.\n */\n orientation?: Orientation;\n\n /**\n * The content alignment of the panel.\n *\n * The default is `'start'`.\n */\n alignment?: Alignment;\n\n /**\n * The spacing between items in the panel.\n *\n * The default is `4`.\n */\n spacing?: number;\n\n /**\n * The split layout to use for the split panel.\n *\n * If this is provided, the other options are ignored.\n *\n * The default is a new `SplitLayout`.\n */\n layout?: SplitLayout;\n }\n\n /**\n * The default implementation of `IRenderer`.\n */\n export class Renderer implements IRenderer {\n /**\n * Create a new handle for use with a split panel.\n *\n * @returns A new handle element for a split panel.\n */\n createHandle(): HTMLDivElement {\n let handle = document.createElement('div');\n handle.className = 'lm-SplitPanel-handle';\n return handle;\n }\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n\n /**\n * Get the split panel stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The split panel stretch factor for the widget.\n */\n export function getStretch(widget: Widget): number {\n return SplitLayout.getStretch(widget);\n }\n\n /**\n * Set the split panel stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the stretch factor.\n */\n export function setStretch(widget: Widget, value: number): void {\n SplitLayout.setStretch(widget, value);\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * An object which holds mouse press data.\n */\n export interface IPressData {\n /**\n * The index of the pressed handle.\n */\n index: number;\n\n /**\n * The offset of the press in handle coordinates.\n */\n delta: number;\n\n /**\n * The disposable which will clear the override cursor.\n */\n override: IDisposable;\n }\n\n /**\n * Create a split layout for the given panel options.\n */\n export function createLayout(options: SplitPanel.IOptions): SplitLayout {\n return (\n options.layout ||\n new SplitLayout({\n renderer: options.renderer || SplitPanel.defaultRenderer,\n orientation: options.orientation,\n alignment: options.alignment,\n spacing: options.spacing\n })\n );\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n\nimport { ArrayExt } from '@lumino/algorithm';\nimport { Message } from '@lumino/messaging';\nimport { ISignal, Signal } from '@lumino/signaling';\nimport { AccordionLayout } from './accordionlayout';\nimport { SplitLayout } from './splitlayout';\nimport { SplitPanel } from './splitpanel';\nimport { Title } from './title';\nimport { Widget } from './widget';\n\n/**\n * A panel which arranges its widgets into resizable sections separated by a title widget.\n *\n * #### Notes\n * This class provides a convenience wrapper around {@link AccordionLayout}.\n */\nexport class AccordionPanel extends SplitPanel {\n /**\n * Construct a new accordion panel.\n *\n * @param options - The options for initializing the accordion panel.\n */\n constructor(options: AccordionPanel.IOptions = {}) {\n super({ ...options, layout: Private.createLayout(options) });\n this.addClass('lm-AccordionPanel');\n }\n\n /**\n * The renderer used by the accordion panel.\n */\n get renderer(): AccordionPanel.IRenderer {\n return (this.layout as AccordionLayout).renderer;\n }\n\n /**\n * The section title space.\n *\n * This is the height if the panel is vertical and the width if it is\n * horizontal.\n */\n get titleSpace(): number {\n return (this.layout as AccordionLayout).titleSpace;\n }\n set titleSpace(value: number) {\n (this.layout as AccordionLayout).titleSpace = value;\n }\n\n /**\n * A read-only array of the section titles in the panel.\n */\n get titles(): ReadonlyArray {\n return (this.layout as AccordionLayout).titles;\n }\n\n /**\n * A signal emitted when a widget of the AccordionPanel is collapsed or expanded.\n */\n get expansionToggled(): ISignal {\n return this._expansionToggled;\n }\n\n /**\n * Add a widget to the end of the panel.\n *\n * @param widget - The widget to add to the panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n */\n addWidget(widget: Widget): void {\n super.addWidget(widget);\n widget.title.changed.connect(this._onTitleChanged, this);\n }\n\n /**\n * Collapse the widget at position `index`.\n *\n * #### Notes\n * If no widget is found for `index`, this will bail.\n *\n * @param index Widget index\n */\n collapse(index: number): void {\n const widget = (this.layout as AccordionLayout).widgets[index];\n\n if (widget && !widget.isHidden) {\n this._toggleExpansion(index);\n }\n }\n\n /**\n * Expand the widget at position `index`.\n *\n * #### Notes\n * If no widget is found for `index`, this will bail.\n *\n * @param index Widget index\n */\n expand(index: number): void {\n const widget = (this.layout as AccordionLayout).widgets[index];\n\n if (widget && widget.isHidden) {\n this._toggleExpansion(index);\n }\n }\n\n /**\n * Insert a widget at the specified index.\n *\n * @param index - The index at which to insert the widget.\n *\n * @param widget - The widget to insert into to the panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n */\n insertWidget(index: number, widget: Widget): void {\n super.insertWidget(index, widget);\n widget.title.changed.connect(this._onTitleChanged, this);\n }\n\n /**\n * Handle the DOM events for the accordion panel.\n *\n * @param event - The DOM event sent to the panel.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the panel's DOM node. It should\n * not be called directly by user code.\n */\n handleEvent(event: Event): void {\n super.handleEvent(event);\n switch (event.type) {\n case 'click':\n this._evtClick(event as MouseEvent);\n break;\n case 'keydown':\n this._eventKeyDown(event as KeyboardEvent);\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('click', this);\n this.node.addEventListener('keydown', this);\n super.onBeforeAttach(msg);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n super.onAfterDetach(msg);\n this.node.removeEventListener('click', this);\n this.node.removeEventListener('keydown', this);\n }\n\n /**\n * Handle the `changed` signal of a title object.\n */\n private _onTitleChanged(sender: Title): void {\n const index = ArrayExt.findFirstIndex(this.widgets, widget => {\n return widget.contains(sender.owner);\n });\n\n if (index >= 0) {\n (this.layout as AccordionLayout).updateTitle(index, sender.owner);\n this.update();\n }\n }\n\n /**\n * Compute the size of widgets in this panel on the title click event.\n * On closing, the size of the widget is cached and we will try to expand\n * the last opened widget.\n * On opening, we will use the cached size if it is available to restore the\n * widget.\n * In both cases, if we can not compute the size of widgets, we will let\n * `SplitLayout` decide.\n *\n * @param index - The index of widget to be opened of closed\n *\n * @returns Relative size of widgets in this panel, if this size can\n * not be computed, return `undefined`\n */\n private _computeWidgetSize(index: number): number[] | undefined {\n const layout = this.layout as AccordionLayout;\n\n const widget = layout.widgets[index];\n if (!widget) {\n return undefined;\n }\n const isHidden = widget.isHidden;\n const widgetSizes = layout.absoluteSizes();\n const delta = (isHidden ? -1 : 1) * this.spacing;\n const totalSize = widgetSizes.reduce(\n (prev: number, curr: number) => prev + curr\n );\n\n let newSize = [...widgetSizes];\n\n if (!isHidden) {\n // Hide the widget\n const currentSize = widgetSizes[index];\n\n this._widgetSizesCache.set(widget, currentSize);\n newSize[index] = 0;\n\n const widgetToCollapse = newSize.map(sz => sz > 0).lastIndexOf(true);\n if (widgetToCollapse === -1) {\n // All widget are closed, let the `SplitLayout` compute widget sizes.\n return undefined;\n }\n\n newSize[widgetToCollapse] =\n widgetSizes[widgetToCollapse] + currentSize + delta;\n } else {\n // Show the widget\n const previousSize = this._widgetSizesCache.get(widget);\n if (!previousSize) {\n // Previous size is unavailable, let the `SplitLayout` compute widget sizes.\n return undefined;\n }\n newSize[index] += previousSize;\n\n const widgetToCollapse = newSize\n .map(sz => sz - previousSize > 0)\n .lastIndexOf(true);\n if (widgetToCollapse === -1) {\n // Can not reduce the size of one widget, reduce all opened widgets\n // proportionally with its size.\n newSize.forEach((_, idx) => {\n if (idx !== index) {\n newSize[idx] -=\n (widgetSizes[idx] / totalSize) * (previousSize - delta);\n }\n });\n } else {\n newSize[widgetToCollapse] -= previousSize - delta;\n }\n }\n return newSize.map(sz => sz / (totalSize + delta));\n }\n /**\n * Handle the `'click'` event for the accordion panel\n */\n private _evtClick(event: MouseEvent): void {\n const target = event.target as HTMLElement | null;\n\n if (target) {\n const index = ArrayExt.findFirstIndex(this.titles, title => {\n return title.contains(target);\n });\n\n if (index >= 0) {\n event.preventDefault();\n event.stopPropagation();\n this._toggleExpansion(index);\n }\n }\n }\n\n /**\n * Handle the `'keydown'` event for the accordion panel.\n */\n private _eventKeyDown(event: KeyboardEvent): void {\n if (event.defaultPrevented) {\n return;\n }\n\n const target = event.target as HTMLElement | null;\n let handled = false;\n if (target) {\n const index = ArrayExt.findFirstIndex(this.titles, title => {\n return title.contains(target);\n });\n\n if (index >= 0) {\n const keyCode = event.keyCode.toString();\n\n // If Space or Enter is pressed on title, emulate click event\n if (event.key.match(/Space|Enter/) || keyCode.match(/13|32/)) {\n target.click();\n handled = true;\n } else if (\n this.orientation === 'horizontal'\n ? event.key.match(/ArrowLeft|ArrowRight/) || keyCode.match(/37|39/)\n : event.key.match(/ArrowUp|ArrowDown/) || keyCode.match(/38|40/)\n ) {\n // If Up or Down (for vertical) / Left or Right (for horizontal) is pressed on title, loop on titles\n const direction =\n event.key.match(/ArrowLeft|ArrowUp/) || keyCode.match(/37|38/)\n ? -1\n : 1;\n const length = this.titles.length;\n const newIndex = (index + length + direction) % length;\n\n this.titles[newIndex].focus();\n handled = true;\n } else if (event.key === 'End' || keyCode === '35') {\n // If End is pressed on title, focus on the last title\n this.titles[this.titles.length - 1].focus();\n handled = true;\n } else if (event.key === 'Home' || keyCode === '36') {\n // If Home is pressed on title, focus on the first title\n this.titles[0].focus();\n handled = true;\n }\n }\n\n if (handled) {\n event.preventDefault();\n }\n }\n }\n\n private _toggleExpansion(index: number) {\n const title = this.titles[index];\n const widget = (this.layout as AccordionLayout).widgets[index];\n\n const newSize = this._computeWidgetSize(index);\n if (newSize) {\n this.setRelativeSizes(newSize, false);\n }\n\n if (widget.isHidden) {\n title.classList.add('lm-mod-expanded');\n title.setAttribute('aria-expanded', 'true');\n widget.show();\n } else {\n title.classList.remove('lm-mod-expanded');\n title.setAttribute('aria-expanded', 'false');\n widget.hide();\n }\n\n // Emit the expansion state signal.\n this._expansionToggled.emit(index);\n }\n\n private _widgetSizesCache: WeakMap = new WeakMap();\n private _expansionToggled = new Signal(this);\n}\n\n/**\n * The namespace for the `AccordionPanel` class statics.\n */\nexport namespace AccordionPanel {\n /**\n * A type alias for a accordion panel orientation.\n */\n export type Orientation = SplitLayout.Orientation;\n\n /**\n * A type alias for a accordion panel alignment.\n */\n export type Alignment = SplitLayout.Alignment;\n\n /**\n * A type alias for a accordion panel renderer.\n */\n export type IRenderer = AccordionLayout.IRenderer;\n\n /**\n * An options object for initializing a accordion panel.\n */\n export interface IOptions extends Partial {\n /**\n * The accordion layout to use for the accordion panel.\n *\n * If this is provided, the other options are ignored.\n *\n * The default is a new `AccordionLayout`.\n */\n layout?: AccordionLayout;\n }\n\n /**\n * The default implementation of `IRenderer`.\n */\n export class Renderer extends SplitPanel.Renderer implements IRenderer {\n constructor() {\n super();\n this._uuid = ++Renderer._nInstance;\n }\n /**\n * A selector which matches any title node in the accordion.\n */\n readonly titleClassName = 'lm-AccordionPanel-title';\n\n /**\n * Render the collapse indicator for a section title.\n *\n * @param data - The data to use for rendering the section title.\n *\n * @returns A element representing the collapse indicator.\n */\n createCollapseIcon(data: Title): HTMLElement {\n return document.createElement('span');\n }\n\n /**\n * Render the element for a section title.\n *\n * @param data - The data to use for rendering the section title.\n *\n * @returns A element representing the section title.\n */\n createSectionTitle(data: Title): HTMLElement {\n const handle = document.createElement('h3');\n handle.setAttribute('tabindex', '0');\n handle.id = this.createTitleKey(data);\n handle.className = this.titleClassName;\n for (const aData in data.dataset) {\n handle.dataset[aData] = data.dataset[aData];\n }\n\n const collapser = handle.appendChild(this.createCollapseIcon(data));\n collapser.className = 'lm-AccordionPanel-titleCollapser';\n\n const label = handle.appendChild(document.createElement('span'));\n label.className = 'lm-AccordionPanel-titleLabel';\n label.textContent = data.label;\n label.title = data.caption || data.label;\n\n return handle;\n }\n\n /**\n * Create a unique render key for the title.\n *\n * @param data - The data to use for the title.\n *\n * @returns The unique render key for the title.\n *\n * #### Notes\n * This method caches the key against the section title the first time\n * the key is generated.\n */\n createTitleKey(data: Title): string {\n let key = this._titleKeys.get(data);\n if (key === undefined) {\n key = `title-key-${this._uuid}-${this._titleID++}`;\n this._titleKeys.set(data, key);\n }\n return key;\n }\n\n private static _nInstance = 0;\n private readonly _uuid: number;\n private _titleID = 0;\n private _titleKeys = new WeakMap, string>();\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n}\n\nnamespace Private {\n /**\n * Create an accordion layout for the given panel options.\n *\n * @param options Panel options\n * @returns Panel layout\n */\n export function createLayout(\n options: AccordionPanel.IOptions\n ): AccordionLayout {\n return (\n options.layout ||\n new AccordionLayout({\n renderer: options.renderer || AccordionPanel.defaultRenderer,\n orientation: options.orientation,\n alignment: options.alignment,\n spacing: options.spacing,\n titleSpace: options.titleSpace\n })\n );\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { BoxEngine, BoxSizer } from './boxengine';\n\nimport { LayoutItem } from './layout';\n\nimport { PanelLayout } from './panellayout';\n\nimport Utils from './utils';\n\nimport { Widget } from './widget';\n\n/**\n * A layout which arranges its widgets in a single row or column.\n */\nexport class BoxLayout extends PanelLayout {\n /**\n * Construct a new box layout.\n *\n * @param options - The options for initializing the layout.\n */\n constructor(options: BoxLayout.IOptions = {}) {\n super();\n if (options.direction !== undefined) {\n this._direction = options.direction;\n }\n if (options.alignment !== undefined) {\n this._alignment = options.alignment;\n }\n if (options.spacing !== undefined) {\n this._spacing = Utils.clampDimension(options.spacing);\n }\n }\n\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n // Dispose of the layout items.\n for (const item of this._items) {\n item.dispose();\n }\n\n // Clear the layout state.\n this._box = null;\n this._items.length = 0;\n this._sizers.length = 0;\n\n // Dispose of the rest of the layout.\n super.dispose();\n }\n\n /**\n * Get the layout direction for the box layout.\n */\n get direction(): BoxLayout.Direction {\n return this._direction;\n }\n\n /**\n * Set the layout direction for the box layout.\n */\n set direction(value: BoxLayout.Direction) {\n if (this._direction === value) {\n return;\n }\n this._direction = value;\n if (!this.parent) {\n return;\n }\n this.parent.dataset['direction'] = value;\n this.parent.fit();\n }\n\n /**\n * Get the content alignment for the box layout.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire box layout.\n */\n get alignment(): BoxLayout.Alignment {\n return this._alignment;\n }\n\n /**\n * Set the content alignment for the box layout.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire box layout.\n */\n set alignment(value: BoxLayout.Alignment) {\n if (this._alignment === value) {\n return;\n }\n this._alignment = value;\n if (!this.parent) {\n return;\n }\n this.parent.dataset['alignment'] = value;\n this.parent.update();\n }\n\n /**\n * Get the inter-element spacing for the box layout.\n */\n get spacing(): number {\n return this._spacing;\n }\n\n /**\n * Set the inter-element spacing for the box layout.\n */\n set spacing(value: number) {\n value = Utils.clampDimension(value);\n if (this._spacing === value) {\n return;\n }\n this._spacing = value;\n if (!this.parent) {\n return;\n }\n this.parent.fit();\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n this.parent!.dataset['direction'] = this.direction;\n this.parent!.dataset['alignment'] = this.alignment;\n super.init();\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param index - The current index of the widget in the layout.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected attachWidget(index: number, widget: Widget): void {\n // Create and add a new layout item for the widget.\n ArrayExt.insert(this._items, index, new LayoutItem(widget));\n\n // Create and add a new sizer for the widget.\n ArrayExt.insert(this._sizers, index, new BoxSizer());\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget's node to the parent.\n this.parent!.node.appendChild(widget.node);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * Move a widget in the parent's DOM node.\n *\n * @param fromIndex - The previous index of the widget in the layout.\n *\n * @param toIndex - The current index of the widget in the layout.\n *\n * @param widget - The widget to move in the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected moveWidget(\n fromIndex: number,\n toIndex: number,\n widget: Widget\n ): void {\n // Move the layout item for the widget.\n ArrayExt.move(this._items, fromIndex, toIndex);\n\n // Move the sizer for the widget.\n ArrayExt.move(this._sizers, fromIndex, toIndex);\n\n // Post an update request for the parent widget.\n this.parent!.update();\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param index - The previous index of the widget in the layout.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected detachWidget(index: number, widget: Widget): void {\n // Remove the layout item for the widget.\n let item = ArrayExt.removeAt(this._items, index);\n\n // Remove the sizer for the widget.\n ArrayExt.removeAt(this._sizers, index);\n\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Dispose of the layout item.\n item!.dispose();\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n */\n protected onBeforeShow(msg: Message): void {\n super.onBeforeShow(msg);\n this.parent!.update();\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n super.onBeforeAttach(msg);\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n if (this.parent!.isVisible) {\n this._update(msg.width, msg.height);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.parent!.isVisible) {\n this._update(-1, -1);\n }\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n */\n protected onFitRequest(msg: Message): void {\n if (this.parent!.isAttached) {\n this._fit();\n }\n }\n\n /**\n * Fit the layout to the total size required by the widgets.\n */\n private _fit(): void {\n // Compute the visible item count.\n let nVisible = 0;\n for (let i = 0, n = this._items.length; i < n; ++i) {\n nVisible += +!this._items[i].isHidden;\n }\n\n // Update the fixed space for the visible items.\n this._fixed = this._spacing * Math.max(0, nVisible - 1);\n\n // Setup the computed minimum size.\n let horz = Private.isHorizontal(this._direction);\n let minW = horz ? this._fixed : 0;\n let minH = horz ? 0 : this._fixed;\n\n // Update the sizers and computed minimum size.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item and corresponding box sizer.\n let item = this._items[i];\n let sizer = this._sizers[i];\n\n // If the item is hidden, it should consume zero size.\n if (item.isHidden) {\n sizer.minSize = 0;\n sizer.maxSize = 0;\n continue;\n }\n\n // Update the size limits for the item.\n item.fit();\n\n // Update the size basis and stretch factor.\n sizer.sizeHint = BoxLayout.getSizeBasis(item.widget);\n sizer.stretch = BoxLayout.getStretch(item.widget);\n\n // Update the sizer limits and computed min size.\n if (horz) {\n sizer.minSize = item.minWidth;\n sizer.maxSize = item.maxWidth;\n minW += item.minWidth;\n minH = Math.max(minH, item.minHeight);\n } else {\n sizer.minSize = item.minHeight;\n sizer.maxSize = item.maxHeight;\n minH += item.minHeight;\n minW = Math.max(minW, item.minWidth);\n }\n }\n\n // Update the box sizing and add it to the computed min size.\n let box = (this._box = ElementExt.boxSizing(this.parent!.node));\n minW += box.horizontalSum;\n minH += box.verticalSum;\n\n // Update the parent's min size constraints.\n let style = this.parent!.node.style;\n style.minWidth = `${minW}px`;\n style.minHeight = `${minH}px`;\n\n // Set the dirty flag to ensure only a single update occurs.\n this._dirty = true;\n\n // Notify the ancestor that it should fit immediately. This may\n // cause a resize of the parent, fulfilling the required update.\n if (this.parent!.parent) {\n MessageLoop.sendMessage(this.parent!.parent!, Widget.Msg.FitRequest);\n }\n\n // If the dirty flag is still set, the parent was not resized.\n // Trigger the required update on the parent widget immediately.\n if (this._dirty) {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n }\n }\n\n /**\n * Update the layout position and size of the widgets.\n *\n * The parent offset dimensions should be `-1` if unknown.\n */\n private _update(offsetWidth: number, offsetHeight: number): void {\n // Clear the dirty flag to indicate the update occurred.\n this._dirty = false;\n\n // Compute the visible item count.\n let nVisible = 0;\n for (let i = 0, n = this._items.length; i < n; ++i) {\n nVisible += +!this._items[i].isHidden;\n }\n\n // Bail early if there are no visible items to layout.\n if (nVisible === 0) {\n return;\n }\n\n // Measure the parent if the offset dimensions are unknown.\n if (offsetWidth < 0) {\n offsetWidth = this.parent!.node.offsetWidth;\n }\n if (offsetHeight < 0) {\n offsetHeight = this.parent!.node.offsetHeight;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent!.node);\n }\n\n // Compute the layout area adjusted for border and padding.\n let top = this._box.paddingTop;\n let left = this._box.paddingLeft;\n let width = offsetWidth - this._box.horizontalSum;\n let height = offsetHeight - this._box.verticalSum;\n\n // Distribute the layout space and adjust the start position.\n let delta: number;\n switch (this._direction) {\n case 'left-to-right':\n delta = BoxEngine.calc(this._sizers, Math.max(0, width - this._fixed));\n break;\n case 'top-to-bottom':\n delta = BoxEngine.calc(this._sizers, Math.max(0, height - this._fixed));\n break;\n case 'right-to-left':\n delta = BoxEngine.calc(this._sizers, Math.max(0, width - this._fixed));\n left += width;\n break;\n case 'bottom-to-top':\n delta = BoxEngine.calc(this._sizers, Math.max(0, height - this._fixed));\n top += height;\n break;\n default:\n throw 'unreachable';\n }\n\n // Setup the variables for justification and alignment offset.\n let extra = 0;\n let offset = 0;\n\n // Account for alignment if there is extra layout space.\n if (delta > 0) {\n switch (this._alignment) {\n case 'start':\n break;\n case 'center':\n extra = 0;\n offset = delta / 2;\n break;\n case 'end':\n extra = 0;\n offset = delta;\n break;\n case 'justify':\n extra = delta / nVisible;\n offset = 0;\n break;\n default:\n throw 'unreachable';\n }\n }\n\n // Layout the items using the computed box sizes.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item.\n let item = this._items[i];\n\n // Ignore hidden items.\n if (item.isHidden) {\n continue;\n }\n\n // Fetch the computed size for the widget.\n let size = this._sizers[i].size;\n\n // Update the widget geometry and advance the relevant edge.\n switch (this._direction) {\n case 'left-to-right':\n item.update(left + offset, top, size + extra, height);\n left += size + extra + this._spacing;\n break;\n case 'top-to-bottom':\n item.update(left, top + offset, width, size + extra);\n top += size + extra + this._spacing;\n break;\n case 'right-to-left':\n item.update(left - offset - size - extra, top, size + extra, height);\n left -= size + extra + this._spacing;\n break;\n case 'bottom-to-top':\n item.update(left, top - offset - size - extra, width, size + extra);\n top -= size + extra + this._spacing;\n break;\n default:\n throw 'unreachable';\n }\n }\n }\n\n private _fixed = 0;\n private _spacing = 4;\n private _dirty = false;\n private _sizers: BoxSizer[] = [];\n private _items: LayoutItem[] = [];\n private _box: ElementExt.IBoxSizing | null = null;\n private _alignment: BoxLayout.Alignment = 'start';\n private _direction: BoxLayout.Direction = 'top-to-bottom';\n}\n\n/**\n * The namespace for the `BoxLayout` class statics.\n */\nexport namespace BoxLayout {\n /**\n * A type alias for a box layout direction.\n */\n export type Direction =\n | 'left-to-right'\n | 'right-to-left'\n | 'top-to-bottom'\n | 'bottom-to-top';\n\n /**\n * A type alias for a box layout alignment.\n */\n export type Alignment = 'start' | 'center' | 'end' | 'justify';\n\n /**\n * An options object for initializing a box layout.\n */\n export interface IOptions {\n /**\n * The direction of the layout.\n *\n * The default is `'top-to-bottom'`.\n */\n direction?: Direction;\n\n /**\n * The content alignment of the layout.\n *\n * The default is `'start'`.\n */\n alignment?: Alignment;\n\n /**\n * The spacing between items in the layout.\n *\n * The default is `4`.\n */\n spacing?: number;\n }\n\n /**\n * Get the box layout stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The box layout stretch factor for the widget.\n */\n export function getStretch(widget: Widget): number {\n return Private.stretchProperty.get(widget);\n }\n\n /**\n * Set the box layout stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the stretch factor.\n */\n export function setStretch(widget: Widget, value: number): void {\n Private.stretchProperty.set(widget, value);\n }\n\n /**\n * Get the box layout size basis for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The box layout size basis for the widget.\n */\n export function getSizeBasis(widget: Widget): number {\n return Private.sizeBasisProperty.get(widget);\n }\n\n /**\n * Set the box layout size basis for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the size basis.\n */\n export function setSizeBasis(widget: Widget, value: number): void {\n Private.sizeBasisProperty.set(widget, value);\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The property descriptor for a widget stretch factor.\n */\n export const stretchProperty = new AttachedProperty({\n name: 'stretch',\n create: () => 0,\n coerce: (owner, value) => Math.max(0, Math.floor(value)),\n changed: onChildSizingChanged\n });\n\n /**\n * The property descriptor for a widget size basis.\n */\n export const sizeBasisProperty = new AttachedProperty({\n name: 'sizeBasis',\n create: () => 0,\n coerce: (owner, value) => Math.max(0, Math.floor(value)),\n changed: onChildSizingChanged\n });\n\n /**\n * Test whether a direction has horizontal orientation.\n */\n export function isHorizontal(dir: BoxLayout.Direction): boolean {\n return dir === 'left-to-right' || dir === 'right-to-left';\n }\n\n /**\n * Clamp a spacing value to an integer >= 0.\n */\n export function clampSpacing(value: number): number {\n return Math.max(0, Math.floor(value));\n }\n\n /**\n * The change handler for the attached sizing properties.\n */\n function onChildSizingChanged(child: Widget): void {\n if (child.parent && child.parent.layout instanceof BoxLayout) {\n child.parent.fit();\n }\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { BoxLayout } from './boxlayout';\n\nimport { Panel } from './panel';\n\nimport { Widget } from './widget';\n\n/**\n * A panel which arranges its widgets in a single row or column.\n *\n * #### Notes\n * This class provides a convenience wrapper around a {@link BoxLayout}.\n */\nexport class BoxPanel extends Panel {\n /**\n * Construct a new box panel.\n *\n * @param options - The options for initializing the box panel.\n */\n constructor(options: BoxPanel.IOptions = {}) {\n super({ layout: Private.createLayout(options) });\n this.addClass('lm-BoxPanel');\n }\n\n /**\n * Get the layout direction for the box panel.\n */\n get direction(): BoxPanel.Direction {\n return (this.layout as BoxLayout).direction;\n }\n\n /**\n * Set the layout direction for the box panel.\n */\n set direction(value: BoxPanel.Direction) {\n (this.layout as BoxLayout).direction = value;\n }\n\n /**\n * Get the content alignment for the box panel.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire box layout.\n */\n get alignment(): BoxPanel.Alignment {\n return (this.layout as BoxLayout).alignment;\n }\n\n /**\n * Set the content alignment for the box panel.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire box layout.\n */\n set alignment(value: BoxPanel.Alignment) {\n (this.layout as BoxLayout).alignment = value;\n }\n\n /**\n * Get the inter-element spacing for the box panel.\n */\n get spacing(): number {\n return (this.layout as BoxLayout).spacing;\n }\n\n /**\n * Set the inter-element spacing for the box panel.\n */\n set spacing(value: number) {\n (this.layout as BoxLayout).spacing = value;\n }\n\n /**\n * A message handler invoked on a `'child-added'` message.\n */\n protected onChildAdded(msg: Widget.ChildMessage): void {\n msg.child.addClass('lm-BoxPanel-child');\n }\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {\n msg.child.removeClass('lm-BoxPanel-child');\n }\n}\n\n/**\n * The namespace for the `BoxPanel` class statics.\n */\nexport namespace BoxPanel {\n /**\n * A type alias for a box panel direction.\n */\n export type Direction = BoxLayout.Direction;\n\n /**\n * A type alias for a box panel alignment.\n */\n export type Alignment = BoxLayout.Alignment;\n\n /**\n * An options object for initializing a box panel.\n */\n export interface IOptions {\n /**\n * The layout direction of the panel.\n *\n * The default is `'top-to-bottom'`.\n */\n direction?: Direction;\n\n /**\n * The content alignment of the panel.\n *\n * The default is `'start'`.\n */\n alignment?: Alignment;\n\n /**\n * The spacing between items in the panel.\n *\n * The default is `4`.\n */\n spacing?: number;\n\n /**\n * The box layout to use for the box panel.\n *\n * If this is provided, the other options are ignored.\n *\n * The default is a new `BoxLayout`.\n */\n layout?: BoxLayout;\n }\n\n /**\n * Get the box panel stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The box panel stretch factor for the widget.\n */\n export function getStretch(widget: Widget): number {\n return BoxLayout.getStretch(widget);\n }\n\n /**\n * Set the box panel stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the stretch factor.\n */\n export function setStretch(widget: Widget, value: number): void {\n BoxLayout.setStretch(widget, value);\n }\n\n /**\n * Get the box panel size basis for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The box panel size basis for the widget.\n */\n export function getSizeBasis(widget: Widget): number {\n return BoxLayout.getSizeBasis(widget);\n }\n\n /**\n * Set the box panel size basis for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the size basis.\n */\n export function setSizeBasis(widget: Widget, value: number): void {\n BoxLayout.setSizeBasis(widget, value);\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Create a box layout for the given panel options.\n */\n export function createLayout(options: BoxPanel.IOptions): BoxLayout {\n return options.layout || new BoxLayout(options);\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt, StringExt } from '@lumino/algorithm';\n\nimport { JSONExt, ReadonlyJSONObject } from '@lumino/coreutils';\n\nimport { CommandRegistry } from '@lumino/commands';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message } from '@lumino/messaging';\n\nimport {\n ElementDataset,\n h,\n VirtualDOM,\n VirtualElement\n} from '@lumino/virtualdom';\n\nimport { Widget } from './widget';\n\n/**\n * A widget which displays command items as a searchable palette.\n */\nexport class CommandPalette extends Widget {\n /**\n * Construct a new command palette.\n *\n * @param options - The options for initializing the palette.\n */\n constructor(options: CommandPalette.IOptions) {\n super({ node: Private.createNode() });\n this.addClass('lm-CommandPalette');\n this.setFlag(Widget.Flag.DisallowLayout);\n this.commands = options.commands;\n this.renderer = options.renderer || CommandPalette.defaultRenderer;\n this.commands.commandChanged.connect(this._onGenericChange, this);\n this.commands.keyBindingChanged.connect(this._onGenericChange, this);\n }\n\n /**\n * Dispose of the resources held by the widget.\n */\n dispose(): void {\n this._items.length = 0;\n this._results = null;\n super.dispose();\n }\n\n /**\n * The command registry used by the command palette.\n */\n readonly commands: CommandRegistry;\n\n /**\n * The renderer used by the command palette.\n */\n readonly renderer: CommandPalette.IRenderer;\n\n /**\n * The command palette search node.\n *\n * #### Notes\n * This is the node which contains the search-related elements.\n */\n get searchNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-CommandPalette-search'\n )[0] as HTMLDivElement;\n }\n\n /**\n * The command palette input node.\n *\n * #### Notes\n * This is the actual input node for the search area.\n */\n get inputNode(): HTMLInputElement {\n return this.node.getElementsByClassName(\n 'lm-CommandPalette-input'\n )[0] as HTMLInputElement;\n }\n\n /**\n * The command palette content node.\n *\n * #### Notes\n * This is the node which holds the command item nodes.\n *\n * Modifying this node directly can lead to undefined behavior.\n */\n get contentNode(): HTMLUListElement {\n return this.node.getElementsByClassName(\n 'lm-CommandPalette-content'\n )[0] as HTMLUListElement;\n }\n\n /**\n * A read-only array of the command items in the palette.\n */\n get items(): ReadonlyArray {\n return this._items;\n }\n\n /**\n * Add a command item to the command palette.\n *\n * @param options - The options for creating the command item.\n *\n * @returns The command item added to the palette.\n */\n addItem(options: CommandPalette.IItemOptions): CommandPalette.IItem {\n // Create a new command item for the options.\n let item = Private.createItem(this.commands, options);\n\n // Add the item to the array.\n this._items.push(item);\n\n // Refresh the search results.\n this.refresh();\n\n // Return the item added to the palette.\n return item;\n }\n\n /**\n * Adds command items to the command palette.\n *\n * @param items - An array of options for creating each command item.\n *\n * @returns The command items added to the palette.\n */\n addItems(items: CommandPalette.IItemOptions[]): CommandPalette.IItem[] {\n const newItems = items.map(item => Private.createItem(this.commands, item));\n newItems.forEach(item => this._items.push(item));\n this.refresh();\n return newItems;\n }\n\n /**\n * Remove an item from the command palette.\n *\n * @param item - The item to remove from the palette.\n *\n * #### Notes\n * This is a no-op if the item is not in the palette.\n */\n removeItem(item: CommandPalette.IItem): void {\n this.removeItemAt(this._items.indexOf(item));\n }\n\n /**\n * Remove the item at a given index from the command palette.\n *\n * @param index - The index of the item to remove.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n removeItemAt(index: number): void {\n // Remove the item from the array.\n let item = ArrayExt.removeAt(this._items, index);\n\n // Bail if the index is out of range.\n if (!item) {\n return;\n }\n\n // Refresh the search results.\n this.refresh();\n }\n\n /**\n * Remove all items from the command palette.\n */\n clearItems(): void {\n // Bail if there is nothing to remove.\n if (this._items.length === 0) {\n return;\n }\n\n // Clear the array of items.\n this._items.length = 0;\n\n // Refresh the search results.\n this.refresh();\n }\n\n /**\n * Clear the search results and schedule an update.\n *\n * #### Notes\n * This should be called whenever the search results of the palette\n * should be updated.\n *\n * This is typically called automatically by the palette as needed,\n * but can be called manually if the input text is programatically\n * changed.\n *\n * The rendered results are updated asynchronously.\n */\n refresh(): void {\n this._results = null;\n if (this.inputNode.value !== '') {\n let clear = this.node.getElementsByClassName(\n 'lm-close-icon'\n )[0] as HTMLInputElement;\n clear.style.display = 'inherit';\n } else {\n let clear = this.node.getElementsByClassName(\n 'lm-close-icon'\n )[0] as HTMLInputElement;\n clear.style.display = 'none';\n }\n this.update();\n }\n\n /**\n * Handle the DOM events for the command palette.\n *\n * @param event - The DOM event sent to the command palette.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the command palette's DOM node.\n * It should not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'click':\n this._evtClick(event as MouseEvent);\n break;\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'input':\n this.refresh();\n break;\n case 'focus':\n case 'blur':\n this._toggleFocused();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('click', this);\n this.node.addEventListener('keydown', this);\n this.node.addEventListener('input', this);\n this.node.addEventListener('focus', this, true);\n this.node.addEventListener('blur', this, true);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('click', this);\n this.node.removeEventListener('keydown', this);\n this.node.removeEventListener('input', this);\n this.node.removeEventListener('focus', this, true);\n this.node.removeEventListener('blur', this, true);\n }\n\n /**\n * A message handler invoked on an `'after-show'` message.\n */\n protected onAfterShow(msg: Message): void {\n this.update();\n super.onAfterShow(msg);\n }\n\n /**\n * A message handler invoked on an `'activate-request'` message.\n */\n protected onActivateRequest(msg: Message): void {\n if (this.isAttached) {\n let input = this.inputNode;\n input.focus();\n input.select();\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.isHidden) {\n return;\n }\n\n // Fetch the current query text and content node.\n let query = this.inputNode.value;\n let contentNode = this.contentNode;\n\n // Ensure the search results are generated.\n let results = this._results;\n if (!results) {\n // Generate and store the new search results.\n results = this._results = Private.search(this._items, query);\n\n // Reset the active index.\n this._activeIndex = query\n ? ArrayExt.findFirstIndex(results, Private.canActivate)\n : -1;\n }\n\n // If there is no query and no results, clear the content.\n if (!query && results.length === 0) {\n VirtualDOM.render(null, contentNode);\n return;\n }\n\n // If the is a query but no results, render the empty message.\n if (query && results.length === 0) {\n let content = this.renderer.renderEmptyMessage({ query });\n VirtualDOM.render(content, contentNode);\n return;\n }\n\n // Create the render content for the search results.\n let renderer = this.renderer;\n let activeIndex = this._activeIndex;\n let content = new Array(results.length);\n for (let i = 0, n = results.length; i < n; ++i) {\n let result = results[i];\n if (result.type === 'header') {\n let indices = result.indices;\n let category = result.category;\n content[i] = renderer.renderHeader({ category, indices });\n } else {\n let item = result.item;\n let indices = result.indices;\n let active = i === activeIndex;\n content[i] = renderer.renderItem({ item, indices, active });\n }\n }\n\n // Render the search result content.\n VirtualDOM.render(content, contentNode);\n\n // Adjust the scroll position as needed.\n if (activeIndex < 0 || activeIndex >= results.length) {\n contentNode.scrollTop = 0;\n } else {\n let element = contentNode.children[activeIndex];\n ElementExt.scrollIntoViewIfNeeded(contentNode, element);\n }\n }\n\n /**\n * Handle the `'click'` event for the command palette.\n */\n private _evtClick(event: MouseEvent): void {\n // Bail if the click is not the left button.\n if (event.button !== 0) {\n return;\n }\n\n // Clear input if the target is clear button\n if ((event.target as HTMLElement).classList.contains('lm-close-icon')) {\n this.inputNode.value = '';\n this.refresh();\n return;\n }\n\n // Find the index of the item which was clicked.\n let index = ArrayExt.findFirstIndex(this.contentNode.children, node => {\n return node.contains(event.target as HTMLElement);\n });\n\n // Bail if the click was not on an item.\n if (index === -1) {\n return;\n }\n\n // Kill the event when a content item is clicked.\n event.preventDefault();\n event.stopPropagation();\n\n // Execute the item if possible.\n this._execute(index);\n }\n\n /**\n * Handle the `'keydown'` event for the command palette.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n if (event.altKey || event.ctrlKey || event.metaKey || event.shiftKey) {\n return;\n }\n switch (event.keyCode) {\n case 13: // Enter\n event.preventDefault();\n event.stopPropagation();\n this._execute(this._activeIndex);\n break;\n case 38: // Up Arrow\n event.preventDefault();\n event.stopPropagation();\n this._activatePreviousItem();\n break;\n case 40: // Down Arrow\n event.preventDefault();\n event.stopPropagation();\n this._activateNextItem();\n break;\n }\n }\n\n /**\n * Activate the next enabled command item.\n */\n private _activateNextItem(): void {\n // Bail if there are no search results.\n if (!this._results || this._results.length === 0) {\n return;\n }\n\n // Find the next enabled item index.\n let ai = this._activeIndex;\n let n = this._results.length;\n let start = ai < n - 1 ? ai + 1 : 0;\n let stop = start === 0 ? n - 1 : start - 1;\n this._activeIndex = ArrayExt.findFirstIndex(\n this._results,\n Private.canActivate,\n start,\n stop\n );\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * Activate the previous enabled command item.\n */\n private _activatePreviousItem(): void {\n // Bail if there are no search results.\n if (!this._results || this._results.length === 0) {\n return;\n }\n\n // Find the previous enabled item index.\n let ai = this._activeIndex;\n let n = this._results.length;\n let start = ai <= 0 ? n - 1 : ai - 1;\n let stop = start === n - 1 ? 0 : start + 1;\n this._activeIndex = ArrayExt.findLastIndex(\n this._results,\n Private.canActivate,\n start,\n stop\n );\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * Execute the command item at the given index, if possible.\n */\n private _execute(index: number): void {\n // Bail if there are no search results.\n if (!this._results) {\n return;\n }\n\n // Bail if the index is out of range.\n let part = this._results[index];\n if (!part) {\n return;\n }\n\n // Update the search text if the item is a header.\n if (part.type === 'header') {\n let input = this.inputNode;\n input.value = `${part.category.toLowerCase()} `;\n input.focus();\n this.refresh();\n return;\n }\n\n // Bail if item is not enabled.\n if (!part.item.isEnabled) {\n return;\n }\n\n // Execute the item.\n this.commands.execute(part.item.command, part.item.args);\n\n // Clear the query text.\n this.inputNode.value = '';\n\n // Refresh the search results.\n this.refresh();\n }\n\n /**\n * Toggle the focused modifier based on the input node focus state.\n */\n private _toggleFocused(): void {\n let focused = document.activeElement === this.inputNode;\n this.toggleClass('lm-mod-focused', focused);\n }\n\n /**\n * A signal handler for generic command changes.\n */\n private _onGenericChange(): void {\n this.refresh();\n }\n\n private _activeIndex = -1;\n private _items: CommandPalette.IItem[] = [];\n private _results: Private.SearchResult[] | null = null;\n}\n\n/**\n * The namespace for the `CommandPalette` class statics.\n */\nexport namespace CommandPalette {\n /**\n * An options object for creating a command palette.\n */\n export interface IOptions {\n /**\n * The command registry for use with the command palette.\n */\n commands: CommandRegistry;\n\n /**\n * A custom renderer for use with the command palette.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n }\n\n /**\n * An options object for creating a command item.\n */\n export interface IItemOptions {\n /**\n * The category for the item.\n */\n category: string;\n\n /**\n * The command to execute when the item is triggered.\n */\n command: string;\n\n /**\n * The arguments for the command.\n *\n * The default value is an empty object.\n */\n args?: ReadonlyJSONObject;\n\n /**\n * The rank for the command item.\n *\n * The rank is used as a tie-breaker when ordering command items\n * for display. Items are sorted in the following order:\n * 1. Text match (lower is better)\n * 2. Category (locale order)\n * 3. Rank (lower is better)\n * 4. Label (locale order)\n *\n * The default rank is `Infinity`.\n */\n rank?: number;\n }\n\n /**\n * An object which represents an item in a command palette.\n *\n * #### Notes\n * Item objects are created automatically by a command palette.\n */\n export interface IItem {\n /**\n * The command to execute when the item is triggered.\n */\n readonly command: string;\n\n /**\n * The arguments for the command.\n */\n readonly args: ReadonlyJSONObject;\n\n /**\n * The category for the command item.\n */\n readonly category: string;\n\n /**\n * The rank for the command item.\n */\n readonly rank: number;\n\n /**\n * The display label for the command item.\n */\n readonly label: string;\n\n /**\n * The display caption for the command item.\n */\n readonly caption: string;\n\n /**\n * The icon renderer for the command item.\n */\n readonly icon: VirtualElement.IRenderer | undefined;\n\n /**\n * The icon class for the command item.\n */\n readonly iconClass: string;\n\n /**\n * The icon label for the command item.\n */\n readonly iconLabel: string;\n\n /**\n * The extra class name for the command item.\n */\n readonly className: string;\n\n /**\n * The dataset for the command item.\n */\n readonly dataset: CommandRegistry.Dataset;\n\n /**\n * Whether the command item is enabled.\n */\n readonly isEnabled: boolean;\n\n /**\n * Whether the command item is toggled.\n */\n readonly isToggled: boolean;\n\n /**\n * Whether the command item is toggleable.\n */\n readonly isToggleable: boolean;\n\n /**\n * Whether the command item is visible.\n */\n readonly isVisible: boolean;\n\n /**\n * The key binding for the command item.\n */\n readonly keyBinding: CommandRegistry.IKeyBinding | null;\n }\n\n /**\n * The render data for a command palette header.\n */\n export interface IHeaderRenderData {\n /**\n * The category of the header.\n */\n readonly category: string;\n\n /**\n * The indices of the matched characters in the category.\n */\n readonly indices: ReadonlyArray | null;\n }\n\n /**\n * The render data for a command palette item.\n */\n export interface IItemRenderData {\n /**\n * The command palette item to render.\n */\n readonly item: IItem;\n\n /**\n * The indices of the matched characters in the label.\n */\n readonly indices: ReadonlyArray | null;\n\n /**\n * Whether the item is the active item.\n */\n readonly active: boolean;\n }\n\n /**\n * The render data for a command palette empty message.\n */\n export interface IEmptyMessageRenderData {\n /**\n * The query which failed to match any commands.\n */\n query: string;\n }\n\n /**\n * A renderer for use with a command palette.\n */\n export interface IRenderer {\n /**\n * Render the virtual element for a command palette header.\n *\n * @param data - The data to use for rendering the header.\n *\n * @returns A virtual element representing the header.\n */\n renderHeader(data: IHeaderRenderData): VirtualElement;\n\n /**\n * Render the virtual element for a command palette item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n *\n * #### Notes\n * The command palette will not render invisible items.\n */\n renderItem(data: IItemRenderData): VirtualElement;\n\n /**\n * Render the empty results message for a command palette.\n *\n * @param data - The data to use for rendering the message.\n *\n * @returns A virtual element representing the message.\n */\n renderEmptyMessage(data: IEmptyMessageRenderData): VirtualElement;\n }\n\n /**\n * The default implementation of `IRenderer`.\n */\n export class Renderer implements IRenderer {\n /**\n * Render the virtual element for a command palette header.\n *\n * @param data - The data to use for rendering the header.\n *\n * @returns A virtual element representing the header.\n */\n renderHeader(data: IHeaderRenderData): VirtualElement {\n let content = this.formatHeader(data);\n return h.li({ className: 'lm-CommandPalette-header' }, content);\n }\n\n /**\n * Render the virtual element for a command palette item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n */\n renderItem(data: IItemRenderData): VirtualElement {\n let className = this.createItemClass(data);\n let dataset = this.createItemDataset(data);\n if (data.item.isToggleable) {\n return h.li(\n {\n className,\n dataset,\n role: 'menuitemcheckbox',\n 'aria-checked': `${data.item.isToggled}`\n },\n this.renderItemIcon(data),\n this.renderItemContent(data),\n this.renderItemShortcut(data)\n );\n }\n return h.li(\n {\n className,\n dataset,\n role: 'menuitem'\n },\n this.renderItemIcon(data),\n this.renderItemContent(data),\n this.renderItemShortcut(data)\n );\n }\n\n /**\n * Render the empty results message for a command palette.\n *\n * @param data - The data to use for rendering the message.\n *\n * @returns A virtual element representing the message.\n */\n renderEmptyMessage(data: IEmptyMessageRenderData): VirtualElement {\n let content = this.formatEmptyMessage(data);\n return h.li({ className: 'lm-CommandPalette-emptyMessage' }, content);\n }\n\n /**\n * Render the icon for a command palette item.\n *\n * @param data - The data to use for rendering the icon.\n *\n * @returns A virtual element representing the icon.\n */\n renderItemIcon(data: IItemRenderData): VirtualElement {\n let className = this.createIconClass(data);\n\n // If data.item.icon is undefined, it will be ignored.\n return h.div({ className }, data.item.icon!, data.item.iconLabel);\n }\n\n /**\n * Render the content for a command palette item.\n *\n * @param data - The data to use for rendering the content.\n *\n * @returns A virtual element representing the content.\n */\n renderItemContent(data: IItemRenderData): VirtualElement {\n return h.div(\n { className: 'lm-CommandPalette-itemContent' },\n this.renderItemLabel(data),\n this.renderItemCaption(data)\n );\n }\n\n /**\n * Render the label for a command palette item.\n *\n * @param data - The data to use for rendering the label.\n *\n * @returns A virtual element representing the label.\n */\n renderItemLabel(data: IItemRenderData): VirtualElement {\n let content = this.formatItemLabel(data);\n return h.div({ className: 'lm-CommandPalette-itemLabel' }, content);\n }\n\n /**\n * Render the caption for a command palette item.\n *\n * @param data - The data to use for rendering the caption.\n *\n * @returns A virtual element representing the caption.\n */\n renderItemCaption(data: IItemRenderData): VirtualElement {\n let content = this.formatItemCaption(data);\n return h.div({ className: 'lm-CommandPalette-itemCaption' }, content);\n }\n\n /**\n * Render the shortcut for a command palette item.\n *\n * @param data - The data to use for rendering the shortcut.\n *\n * @returns A virtual element representing the shortcut.\n */\n renderItemShortcut(data: IItemRenderData): VirtualElement {\n let content = this.formatItemShortcut(data);\n return h.div({ className: 'lm-CommandPalette-itemShortcut' }, content);\n }\n\n /**\n * Create the class name for the command palette item.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the command palette item.\n */\n createItemClass(data: IItemRenderData): string {\n // Set up the initial class name.\n let name = 'lm-CommandPalette-item';\n\n // Add the boolean state classes.\n if (!data.item.isEnabled) {\n name += ' lm-mod-disabled';\n }\n if (data.item.isToggled) {\n name += ' lm-mod-toggled';\n }\n if (data.active) {\n name += ' lm-mod-active';\n }\n\n // Add the extra class.\n let extra = data.item.className;\n if (extra) {\n name += ` ${extra}`;\n }\n\n // Return the complete class name.\n return name;\n }\n\n /**\n * Create the dataset for the command palette item.\n *\n * @param data - The data to use for creating the dataset.\n *\n * @returns The dataset for the command palette item.\n */\n createItemDataset(data: IItemRenderData): ElementDataset {\n return { ...data.item.dataset, command: data.item.command };\n }\n\n /**\n * Create the class name for the command item icon.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the item icon.\n */\n createIconClass(data: IItemRenderData): string {\n let name = 'lm-CommandPalette-itemIcon';\n let extra = data.item.iconClass;\n return extra ? `${name} ${extra}` : name;\n }\n\n /**\n * Create the render content for the header node.\n *\n * @param data - The data to use for the header content.\n *\n * @returns The content to add to the header node.\n */\n formatHeader(data: IHeaderRenderData): h.Child {\n if (!data.indices || data.indices.length === 0) {\n return data.category;\n }\n return StringExt.highlight(data.category, data.indices, h.mark);\n }\n\n /**\n * Create the render content for the empty message node.\n *\n * @param data - The data to use for the empty message content.\n *\n * @returns The content to add to the empty message node.\n */\n formatEmptyMessage(data: IEmptyMessageRenderData): h.Child {\n return `No commands found that match '${data.query}'`;\n }\n\n /**\n * Create the render content for the item shortcut node.\n *\n * @param data - The data to use for the shortcut content.\n *\n * @returns The content to add to the shortcut node.\n */\n formatItemShortcut(data: IItemRenderData): h.Child {\n let kb = data.item.keyBinding;\n return kb ? CommandRegistry.formatKeystroke(kb.keys) : null;\n }\n\n /**\n * Create the render content for the item label node.\n *\n * @param data - The data to use for the label content.\n *\n * @returns The content to add to the label node.\n */\n formatItemLabel(data: IItemRenderData): h.Child {\n if (!data.indices || data.indices.length === 0) {\n return data.item.label;\n }\n return StringExt.highlight(data.item.label, data.indices, h.mark);\n }\n\n /**\n * Create the render content for the item caption node.\n *\n * @param data - The data to use for the caption content.\n *\n * @returns The content to add to the caption node.\n */\n formatItemCaption(data: IItemRenderData): h.Child {\n return data.item.caption;\n }\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Create the DOM node for a command palette.\n */\n export function createNode(): HTMLDivElement {\n let node = document.createElement('div');\n let search = document.createElement('div');\n let wrapper = document.createElement('div');\n let input = document.createElement('input');\n let content = document.createElement('ul');\n let clear = document.createElement('button');\n search.className = 'lm-CommandPalette-search';\n wrapper.className = 'lm-CommandPalette-wrapper';\n input.className = 'lm-CommandPalette-input';\n clear.className = 'lm-close-icon';\n\n content.className = 'lm-CommandPalette-content';\n content.setAttribute('role', 'menu');\n input.spellcheck = false;\n wrapper.appendChild(input);\n wrapper.appendChild(clear);\n search.appendChild(wrapper);\n node.appendChild(search);\n node.appendChild(content);\n return node;\n }\n\n /**\n * Create a new command item from a command registry and options.\n */\n export function createItem(\n commands: CommandRegistry,\n options: CommandPalette.IItemOptions\n ): CommandPalette.IItem {\n return new CommandItem(commands, options);\n }\n\n /**\n * A search result object for a header label.\n */\n export interface IHeaderResult {\n /**\n * The discriminated type of the object.\n */\n readonly type: 'header';\n\n /**\n * The category for the header.\n */\n readonly category: string;\n\n /**\n * The indices of the matched category characters.\n */\n readonly indices: ReadonlyArray | null;\n }\n\n /**\n * A search result object for a command item.\n */\n export interface IItemResult {\n /**\n * The discriminated type of the object.\n */\n readonly type: 'item';\n\n /**\n * The command item which was matched.\n */\n readonly item: CommandPalette.IItem;\n\n /**\n * The indices of the matched label characters.\n */\n readonly indices: ReadonlyArray | null;\n }\n\n /**\n * A type alias for a search result item.\n */\n export type SearchResult = IHeaderResult | IItemResult;\n\n /**\n * Search an array of command items for fuzzy matches.\n */\n export function search(\n items: CommandPalette.IItem[],\n query: string\n ): SearchResult[] {\n // Fuzzy match the items for the query.\n let scores = matchItems(items, query);\n\n // Sort the items based on their score.\n scores.sort(scoreCmp);\n\n // Create the results for the search.\n return createResults(scores);\n }\n\n /**\n * Test whether a result item can be activated.\n */\n export function canActivate(result: SearchResult): boolean {\n return result.type === 'item' && result.item.isEnabled;\n }\n\n /**\n * Normalize a category for a command item.\n */\n function normalizeCategory(category: string): string {\n return category.trim().replace(/\\s+/g, ' ');\n }\n\n /**\n * Normalize the query text for a fuzzy search.\n */\n function normalizeQuery(text: string): string {\n return text.replace(/\\s+/g, '').toLowerCase();\n }\n\n /**\n * An enum of the supported match types.\n */\n const enum MatchType {\n Label,\n Category,\n Split,\n Default\n }\n\n /**\n * A text match score with associated command item.\n */\n interface IScore {\n /**\n * The numerical type for the text match.\n */\n matchType: MatchType;\n\n /**\n * The numerical score for the text match.\n */\n score: number;\n\n /**\n * The indices of the matched category characters.\n */\n categoryIndices: number[] | null;\n\n /**\n * The indices of the matched label characters.\n */\n labelIndices: number[] | null;\n\n /**\n * The command item associated with the match.\n */\n item: CommandPalette.IItem;\n }\n\n /**\n * Perform a fuzzy match on an array of command items.\n */\n function matchItems(items: CommandPalette.IItem[], query: string): IScore[] {\n // Normalize the query text to lower case with no whitespace.\n query = normalizeQuery(query);\n\n // Create the array to hold the scores.\n let scores: IScore[] = [];\n\n // Iterate over the items and match against the query.\n for (let i = 0, n = items.length; i < n; ++i) {\n // Ignore items which are not visible.\n let item = items[i];\n if (!item.isVisible) {\n continue;\n }\n\n // If the query is empty, all items are matched by default.\n if (!query) {\n scores.push({\n matchType: MatchType.Default,\n categoryIndices: null,\n labelIndices: null,\n score: 0,\n item\n });\n continue;\n }\n\n // Run the fuzzy search for the item and query.\n let score = fuzzySearch(item, query);\n\n // Ignore the item if it is not a match.\n if (!score) {\n continue;\n }\n\n // Penalize disabled items.\n // TODO - push disabled items all the way down in sort cmp?\n if (!item.isEnabled) {\n score.score += 1000;\n }\n\n // Add the score to the results.\n scores.push(score);\n }\n\n // Return the final array of scores.\n return scores;\n }\n\n /**\n * Perform a fuzzy search on a single command item.\n */\n function fuzzySearch(\n item: CommandPalette.IItem,\n query: string\n ): IScore | null {\n // Create the source text to be searched.\n let category = item.category.toLowerCase();\n let label = item.label.toLowerCase();\n let source = `${category} ${label}`;\n\n // Set up the match score and indices array.\n let score = Infinity;\n let indices: number[] | null = null;\n\n // The regex for search word boundaries\n let rgx = /\\b\\w/g;\n\n // Search the source by word boundary.\n // eslint-disable-next-line no-constant-condition\n while (true) {\n // Find the next word boundary in the source.\n let rgxMatch = rgx.exec(source);\n\n // Break if there is no more source context.\n if (!rgxMatch) {\n break;\n }\n\n // Run the string match on the relevant substring.\n let match = StringExt.matchSumOfDeltas(source, query, rgxMatch.index);\n\n // Break if there is no match.\n if (!match) {\n break;\n }\n\n // Update the match if the score is better.\n if (match.score <= score) {\n score = match.score;\n indices = match.indices;\n }\n }\n\n // Bail if there was no match.\n if (!indices || score === Infinity) {\n return null;\n }\n\n // Compute the pivot index between category and label text.\n let pivot = category.length + 1;\n\n // Find the slice index to separate matched indices.\n let j = ArrayExt.lowerBound(indices, pivot, (a, b) => a - b);\n\n // Extract the matched category and label indices.\n let categoryIndices = indices.slice(0, j);\n let labelIndices = indices.slice(j);\n\n // Adjust the label indices for the pivot offset.\n for (let i = 0, n = labelIndices.length; i < n; ++i) {\n labelIndices[i] -= pivot;\n }\n\n // Handle a pure label match.\n if (categoryIndices.length === 0) {\n return {\n matchType: MatchType.Label,\n categoryIndices: null,\n labelIndices,\n score,\n item\n };\n }\n\n // Handle a pure category match.\n if (labelIndices.length === 0) {\n return {\n matchType: MatchType.Category,\n categoryIndices,\n labelIndices: null,\n score,\n item\n };\n }\n\n // Handle a split match.\n return {\n matchType: MatchType.Split,\n categoryIndices,\n labelIndices,\n score,\n item\n };\n }\n\n /**\n * A sort comparison function for a match score.\n */\n function scoreCmp(a: IScore, b: IScore): number {\n // First compare based on the match type\n let m1 = a.matchType - b.matchType;\n if (m1 !== 0) {\n return m1;\n }\n\n // Otherwise, compare based on the match score.\n let d1 = a.score - b.score;\n if (d1 !== 0) {\n return d1;\n }\n\n // Find the match index based on the match type.\n let i1 = 0;\n let i2 = 0;\n switch (a.matchType) {\n case MatchType.Label:\n i1 = a.labelIndices![0];\n i2 = b.labelIndices![0];\n break;\n case MatchType.Category:\n case MatchType.Split:\n i1 = a.categoryIndices![0];\n i2 = b.categoryIndices![0];\n break;\n }\n\n // Compare based on the match index.\n if (i1 !== i2) {\n return i1 - i2;\n }\n\n // Otherwise, compare by category.\n let d2 = a.item.category.localeCompare(b.item.category);\n if (d2 !== 0) {\n return d2;\n }\n\n // Otherwise, compare by rank.\n let r1 = a.item.rank;\n let r2 = b.item.rank;\n if (r1 !== r2) {\n return r1 < r2 ? -1 : 1; // Infinity safe\n }\n\n // Finally, compare by label.\n return a.item.label.localeCompare(b.item.label);\n }\n\n /**\n * Create the results from an array of sorted scores.\n */\n function createResults(scores: IScore[]): SearchResult[] {\n // Set up the search results array.\n let results: SearchResult[] = [];\n\n // Iterate over each score in the array.\n for (let i = 0, n = scores.length; i < n; ++i) {\n // Extract the current item and indices.\n let { item, categoryIndices, labelIndices } = scores[i];\n\n // Extract the category for the current item.\n let category = item.category;\n\n // Is this the same category as the preceding result?\n if (i === 0 || category !== scores[i - 1].item.category) {\n // Add the header result for the category.\n results.push({ type: 'header', category, indices: categoryIndices });\n }\n\n // Create the item result for the score.\n results.push({ type: 'item', item, indices: labelIndices });\n }\n\n // Return the final results.\n return results;\n }\n\n /**\n * A concrete implementation of `CommandPalette.IItem`.\n */\n class CommandItem implements CommandPalette.IItem {\n /**\n * Construct a new command item.\n */\n constructor(\n commands: CommandRegistry,\n options: CommandPalette.IItemOptions\n ) {\n this._commands = commands;\n this.category = normalizeCategory(options.category);\n this.command = options.command;\n this.args = options.args || JSONExt.emptyObject;\n this.rank = options.rank !== undefined ? options.rank : Infinity;\n }\n\n /**\n * The category for the command item.\n */\n readonly category: string;\n\n /**\n * The command to execute when the item is triggered.\n */\n readonly command: string;\n\n /**\n * The arguments for the command.\n */\n readonly args: ReadonlyJSONObject;\n\n /**\n * The rank for the command item.\n */\n readonly rank: number;\n\n /**\n * The display label for the command item.\n */\n get label(): string {\n return this._commands.label(this.command, this.args);\n }\n\n /**\n * The icon renderer for the command item.\n */\n get icon(): VirtualElement.IRenderer | undefined {\n return this._commands.icon(this.command, this.args);\n }\n\n /**\n * The icon class for the command item.\n */\n get iconClass(): string {\n return this._commands.iconClass(this.command, this.args);\n }\n\n /**\n * The icon label for the command item.\n */\n get iconLabel(): string {\n return this._commands.iconLabel(this.command, this.args);\n }\n\n /**\n * The display caption for the command item.\n */\n get caption(): string {\n return this._commands.caption(this.command, this.args);\n }\n\n /**\n * The extra class name for the command item.\n */\n get className(): string {\n return this._commands.className(this.command, this.args);\n }\n\n /**\n * The dataset for the command item.\n */\n get dataset(): CommandRegistry.Dataset {\n return this._commands.dataset(this.command, this.args);\n }\n\n /**\n * Whether the command item is enabled.\n */\n get isEnabled(): boolean {\n return this._commands.isEnabled(this.command, this.args);\n }\n\n /**\n * Whether the command item is toggled.\n */\n get isToggled(): boolean {\n return this._commands.isToggled(this.command, this.args);\n }\n\n /**\n * Whether the command item is toggleable.\n */\n get isToggleable(): boolean {\n return this._commands.isToggleable(this.command, this.args);\n }\n\n /**\n * Whether the command item is visible.\n */\n get isVisible(): boolean {\n return this._commands.isVisible(this.command, this.args);\n }\n\n /**\n * The key binding for the command item.\n */\n get keyBinding(): CommandRegistry.IKeyBinding | null {\n let { command, args } = this;\n return (\n ArrayExt.findLastValue(this._commands.keyBindings, kb => {\n return kb.command === command && JSONExt.deepEqual(kb.args, args);\n }) || null\n );\n }\n\n private _commands: CommandRegistry;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { CommandRegistry } from '@lumino/commands';\n\nimport { JSONExt, ReadonlyJSONObject } from '@lumino/coreutils';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { getKeyboardLayout } from '@lumino/keyboard';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport {\n ARIAAttrNames,\n ElementARIAAttrs,\n ElementDataset,\n h,\n VirtualDOM,\n VirtualElement\n} from '@lumino/virtualdom';\n\nimport { Widget } from './widget';\n\ninterface IWindowData {\n pageXOffset: number;\n pageYOffset: number;\n clientWidth: number;\n clientHeight: number;\n}\n\n/**\n * A widget which displays items as a canonical menu.\n */\nexport class Menu extends Widget {\n /**\n * Construct a new menu.\n *\n * @param options - The options for initializing the menu.\n */\n constructor(options: Menu.IOptions) {\n super({ node: Private.createNode() });\n this.addClass('lm-Menu');\n this.setFlag(Widget.Flag.DisallowLayout);\n this.commands = options.commands;\n this.renderer = options.renderer || Menu.defaultRenderer;\n }\n\n /**\n * Dispose of the resources held by the menu.\n */\n dispose(): void {\n this.close();\n this._items.length = 0;\n super.dispose();\n }\n\n /**\n * A signal emitted just before the menu is closed.\n *\n * #### Notes\n * This signal is emitted when the menu receives a `'close-request'`\n * message, just before it removes itself from the DOM.\n *\n * This signal is not emitted if the menu is already detached from\n * the DOM when it receives the `'close-request'` message.\n */\n get aboutToClose(): ISignal {\n return this._aboutToClose;\n }\n\n /**\n * A signal emitted when a new menu is requested by the user.\n *\n * #### Notes\n * This signal is emitted whenever the user presses the right or left\n * arrow keys, and a submenu cannot be opened or closed in response.\n *\n * This signal is useful when implementing menu bars in order to open\n * the next or previous menu in response to a user key press.\n *\n * This signal is only emitted for the root menu in a hierarchy.\n */\n get menuRequested(): ISignal {\n return this._menuRequested;\n }\n\n /**\n * The command registry used by the menu.\n */\n readonly commands: CommandRegistry;\n\n /**\n * The renderer used by the menu.\n */\n readonly renderer: Menu.IRenderer;\n\n /**\n * The parent menu of the menu.\n *\n * #### Notes\n * This is `null` unless the menu is an open submenu.\n */\n get parentMenu(): Menu | null {\n return this._parentMenu;\n }\n\n /**\n * The child menu of the menu.\n *\n * #### Notes\n * This is `null` unless the menu has an open submenu.\n */\n get childMenu(): Menu | null {\n return this._childMenu;\n }\n\n /**\n * The root menu of the menu hierarchy.\n */\n get rootMenu(): Menu {\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n let menu: Menu = this;\n while (menu._parentMenu) {\n menu = menu._parentMenu;\n }\n return menu;\n }\n\n /**\n * The leaf menu of the menu hierarchy.\n */\n get leafMenu(): Menu {\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n let menu: Menu = this;\n while (menu._childMenu) {\n menu = menu._childMenu;\n }\n return menu;\n }\n\n /**\n * The menu content node.\n *\n * #### Notes\n * This is the node which holds the menu item nodes.\n *\n * Modifying this node directly can lead to undefined behavior.\n */\n get contentNode(): HTMLUListElement {\n return this.node.getElementsByClassName(\n 'lm-Menu-content'\n )[0] as HTMLUListElement;\n }\n\n /**\n * Get the currently active menu item.\n */\n get activeItem(): Menu.IItem | null {\n return this._items[this._activeIndex] || null;\n }\n\n /**\n * Set the currently active menu item.\n *\n * #### Notes\n * If the item cannot be activated, the item will be set to `null`.\n */\n set activeItem(value: Menu.IItem | null) {\n this.activeIndex = value ? this._items.indexOf(value) : -1;\n }\n\n /**\n * Get the index of the currently active menu item.\n *\n * #### Notes\n * This will be `-1` if no menu item is active.\n */\n get activeIndex(): number {\n return this._activeIndex;\n }\n\n /**\n * Set the index of the currently active menu item.\n *\n * #### Notes\n * If the item cannot be activated, the index will be set to `-1`.\n */\n set activeIndex(value: number) {\n // Adjust the value for an out of range index.\n if (value < 0 || value >= this._items.length) {\n value = -1;\n }\n\n // Ensure the item can be activated.\n if (value !== -1 && !Private.canActivate(this._items[value])) {\n value = -1;\n }\n\n // Bail if the index will not change.\n if (this._activeIndex === value) {\n return;\n }\n\n // Update the active index.\n this._activeIndex = value;\n\n // Make active element in focus\n if (\n this._activeIndex >= 0 &&\n this.contentNode.childNodes[this._activeIndex]\n ) {\n (this.contentNode.childNodes[this._activeIndex] as HTMLElement).focus();\n }\n\n // schedule an update of the items.\n this.update();\n }\n\n /**\n * A read-only array of the menu items in the menu.\n */\n get items(): ReadonlyArray {\n return this._items;\n }\n\n /**\n * Activate the next selectable item in the menu.\n *\n * #### Notes\n * If no item is selectable, the index will be set to `-1`.\n */\n activateNextItem(): void {\n let n = this._items.length;\n let ai = this._activeIndex;\n let start = ai < n - 1 ? ai + 1 : 0;\n let stop = start === 0 ? n - 1 : start - 1;\n this.activeIndex = ArrayExt.findFirstIndex(\n this._items,\n Private.canActivate,\n start,\n stop\n );\n }\n\n /**\n * Activate the previous selectable item in the menu.\n *\n * #### Notes\n * If no item is selectable, the index will be set to `-1`.\n */\n activatePreviousItem(): void {\n let n = this._items.length;\n let ai = this._activeIndex;\n let start = ai <= 0 ? n - 1 : ai - 1;\n let stop = start === n - 1 ? 0 : start + 1;\n this.activeIndex = ArrayExt.findLastIndex(\n this._items,\n Private.canActivate,\n start,\n stop\n );\n }\n\n /**\n * Trigger the active menu item.\n *\n * #### Notes\n * If the active item is a submenu, it will be opened and the first\n * item will be activated.\n *\n * If the active item is a command, the command will be executed.\n *\n * If the menu is not attached, this is a no-op.\n *\n * If there is no active item, this is a no-op.\n */\n triggerActiveItem(): void {\n // Bail if the menu is not attached.\n if (!this.isAttached) {\n return;\n }\n\n // Bail if there is no active item.\n let item = this.activeItem;\n if (!item) {\n return;\n }\n\n // Cancel the pending timers.\n this._cancelOpenTimer();\n this._cancelCloseTimer();\n\n // If the item is a submenu, open it.\n if (item.type === 'submenu') {\n this._openChildMenu(true);\n return;\n }\n\n // Close the root menu before executing the command.\n this.rootMenu.close();\n\n // Execute the command for the item.\n let { command, args } = item;\n if (this.commands.isEnabled(command, args)) {\n this.commands.execute(command, args);\n } else {\n console.log(`Command '${command}' is disabled.`);\n }\n }\n\n /**\n * Add a menu item to the end of the menu.\n *\n * @param options - The options for creating the menu item.\n *\n * @returns The menu item added to the menu.\n */\n addItem(options: Menu.IItemOptions): Menu.IItem {\n return this.insertItem(this._items.length, options);\n }\n\n /**\n * Insert a menu item into the menu at the specified index.\n *\n * @param index - The index at which to insert the item.\n *\n * @param options - The options for creating the menu item.\n *\n * @returns The menu item added to the menu.\n *\n * #### Notes\n * The index will be clamped to the bounds of the items.\n */\n insertItem(index: number, options: Menu.IItemOptions): Menu.IItem {\n // Close the menu if it's attached.\n if (this.isAttached) {\n this.close();\n }\n\n // Reset the active index.\n this.activeIndex = -1;\n\n // Clamp the insert index to the array bounds.\n let i = Math.max(0, Math.min(index, this._items.length));\n\n // Create the item for the options.\n let item = Private.createItem(this, options);\n\n // Insert the item into the array.\n ArrayExt.insert(this._items, i, item);\n\n // Schedule an update of the items.\n this.update();\n\n // Return the item added to the menu.\n return item;\n }\n\n /**\n * Remove an item from the menu.\n *\n * @param item - The item to remove from the menu.\n *\n * #### Notes\n * This is a no-op if the item is not in the menu.\n */\n removeItem(item: Menu.IItem): void {\n this.removeItemAt(this._items.indexOf(item));\n }\n\n /**\n * Remove the item at a given index from the menu.\n *\n * @param index - The index of the item to remove.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n removeItemAt(index: number): void {\n // Close the menu if it's attached.\n if (this.isAttached) {\n this.close();\n }\n\n // Reset the active index.\n this.activeIndex = -1;\n\n // Remove the item from the array.\n let item = ArrayExt.removeAt(this._items, index);\n\n // Bail if the index is out of range.\n if (!item) {\n return;\n }\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * Remove all menu items from the menu.\n */\n clearItems(): void {\n // Close the menu if it's attached.\n if (this.isAttached) {\n this.close();\n }\n\n // Reset the active index.\n this.activeIndex = -1;\n\n // Bail if there is nothing to remove.\n if (this._items.length === 0) {\n return;\n }\n\n // Clear the items.\n this._items.length = 0;\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * Open the menu at the specified location.\n *\n * @param x - The client X coordinate of the menu location.\n *\n * @param y - The client Y coordinate of the menu location.\n *\n * @param options - The additional options for opening the menu.\n *\n * #### Notes\n * The menu will be opened at the given location unless it will not\n * fully fit on the screen. If it will not fit, it will be adjusted\n * to fit naturally on the screen.\n *\n * The menu will be attached under the `host` element in the DOM\n * (or `document.body` if `host` is `null`) and before the `ref`\n * element (or as the last child of `host` if `ref` is `null`).\n * The menu may be displayed outside of the `host` element\n * following the rules of CSS absolute positioning.\n *\n * This is a no-op if the menu is already attached to the DOM.\n */\n open(x: number, y: number, options: Menu.IOpenOptions = {}): void {\n // Bail early if the menu is already attached.\n if (this.isAttached) {\n return;\n }\n\n // Extract the menu options.\n let forceX = options.forceX || false;\n let forceY = options.forceY || false;\n const host = options.host ?? null;\n const ref = options.ref ?? null;\n\n // Open the menu as a root menu.\n Private.openRootMenu(this, x, y, forceX, forceY, host, ref);\n\n // Activate the menu to accept keyboard input.\n this.activate();\n }\n\n /**\n * Handle the DOM events for the menu.\n *\n * @param event - The DOM event sent to the menu.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the menu's DOM nodes. It should\n * not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'mouseup':\n this._evtMouseUp(event as MouseEvent);\n break;\n case 'mousemove':\n this._evtMouseMove(event as MouseEvent);\n break;\n case 'mouseenter':\n this._evtMouseEnter(event as MouseEvent);\n break;\n case 'mouseleave':\n this._evtMouseLeave(event as MouseEvent);\n break;\n case 'mousedown':\n this._evtMouseDown(event as MouseEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('keydown', this);\n this.node.addEventListener('mouseup', this);\n this.node.addEventListener('mousemove', this);\n this.node.addEventListener('mouseenter', this);\n this.node.addEventListener('mouseleave', this);\n this.node.addEventListener('contextmenu', this);\n document.addEventListener('mousedown', this, true);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('keydown', this);\n this.node.removeEventListener('mouseup', this);\n this.node.removeEventListener('mousemove', this);\n this.node.removeEventListener('mouseenter', this);\n this.node.removeEventListener('mouseleave', this);\n this.node.removeEventListener('contextmenu', this);\n document.removeEventListener('mousedown', this, true);\n }\n\n /**\n * A message handler invoked on an `'activate-request'` message.\n */\n protected onActivateRequest(msg: Message): void {\n if (this.isAttached) {\n this.node.focus();\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n let items = this._items;\n let renderer = this.renderer;\n let activeIndex = this._activeIndex;\n let collapsedFlags = Private.computeCollapsed(items);\n let content = new Array(items.length);\n for (let i = 0, n = items.length; i < n; ++i) {\n let item = items[i];\n let active = i === activeIndex;\n let collapsed = collapsedFlags[i];\n content[i] = renderer.renderItem({\n item,\n active,\n collapsed,\n onfocus: () => {\n this.activeIndex = i;\n }\n });\n }\n VirtualDOM.render(content, this.contentNode);\n }\n\n /**\n * A message handler invoked on a `'close-request'` message.\n */\n protected onCloseRequest(msg: Message): void {\n // Cancel the pending timers.\n this._cancelOpenTimer();\n this._cancelCloseTimer();\n\n // Reset the active index.\n this.activeIndex = -1;\n\n // Close any open child menu.\n let childMenu = this._childMenu;\n if (childMenu) {\n this._childIndex = -1;\n this._childMenu = null;\n childMenu._parentMenu = null;\n childMenu.close();\n }\n\n // Remove this menu from its parent and activate the parent.\n let parentMenu = this._parentMenu;\n if (parentMenu) {\n this._parentMenu = null;\n parentMenu._childIndex = -1;\n parentMenu._childMenu = null;\n parentMenu.activate();\n }\n\n // Emit the `aboutToClose` signal if the menu is attached.\n if (this.isAttached) {\n this._aboutToClose.emit(undefined);\n }\n\n // Finish closing the menu.\n super.onCloseRequest(msg);\n }\n\n /**\n * Handle the `'keydown'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the menu node.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // A menu handles all keydown events.\n event.preventDefault();\n event.stopPropagation();\n\n // Fetch the key code for the event.\n let kc = event.keyCode;\n\n // Enter\n if (kc === 13) {\n this.triggerActiveItem();\n return;\n }\n\n // Escape\n if (kc === 27) {\n this.close();\n return;\n }\n\n // Left Arrow\n if (kc === 37) {\n if (this._parentMenu) {\n this.close();\n } else {\n this._menuRequested.emit('previous');\n }\n return;\n }\n\n // Up Arrow\n if (kc === 38) {\n this.activatePreviousItem();\n return;\n }\n\n // Right Arrow\n if (kc === 39) {\n let item = this.activeItem;\n if (item && item.type === 'submenu') {\n this.triggerActiveItem();\n } else {\n this.rootMenu._menuRequested.emit('next');\n }\n return;\n }\n\n // Down Arrow\n if (kc === 40) {\n this.activateNextItem();\n return;\n }\n\n // Get the pressed key character.\n let key = getKeyboardLayout().keyForKeydownEvent(event);\n\n // Bail if the key is not valid.\n if (!key) {\n return;\n }\n\n // Search for the next best matching mnemonic item.\n let start = this._activeIndex + 1;\n let result = Private.findMnemonic(this._items, key, start);\n\n // Handle the requested mnemonic based on the search results.\n // If exactly one mnemonic is matched, that item is triggered.\n // Otherwise, the next mnemonic is activated if available,\n // followed by the auto mnemonic if available.\n if (result.index !== -1 && !result.multiple) {\n this.activeIndex = result.index;\n this.triggerActiveItem();\n } else if (result.index !== -1) {\n this.activeIndex = result.index;\n } else if (result.auto !== -1) {\n this.activeIndex = result.auto;\n }\n }\n\n /**\n * Handle the `'mouseup'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the menu node.\n */\n private _evtMouseUp(event: MouseEvent): void {\n if (event.button !== 0) {\n return;\n }\n event.preventDefault();\n event.stopPropagation();\n this.triggerActiveItem();\n }\n\n /**\n * Handle the `'mousemove'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the menu node.\n */\n private _evtMouseMove(event: MouseEvent): void {\n // Hit test the item nodes for the item under the mouse.\n let index = ArrayExt.findFirstIndex(this.contentNode.children, node => {\n return ElementExt.hitTest(node, event.clientX, event.clientY);\n });\n\n // Bail early if the mouse is already over the active index.\n if (index === this._activeIndex) {\n return;\n }\n\n // Update and coerce the active index.\n this.activeIndex = index;\n index = this.activeIndex;\n\n // If the index is the current child index, cancel the timers.\n if (index === this._childIndex) {\n this._cancelOpenTimer();\n this._cancelCloseTimer();\n return;\n }\n\n // If a child menu is currently open, start the close timer.\n if (this._childIndex !== -1) {\n this._startCloseTimer();\n }\n\n // Cancel the open timer to give a full delay for opening.\n this._cancelOpenTimer();\n\n // Bail if the active item is not a valid submenu item.\n let item = this.activeItem;\n if (!item || item.type !== 'submenu' || !item.submenu) {\n return;\n }\n\n // Start the open timer to open the active item submenu.\n this._startOpenTimer();\n }\n\n /**\n * Handle the `'mouseenter'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the menu node.\n */\n private _evtMouseEnter(event: MouseEvent): void {\n // Synchronize the active ancestor items.\n for (let menu = this._parentMenu; menu; menu = menu._parentMenu) {\n menu._cancelOpenTimer();\n menu._cancelCloseTimer();\n menu.activeIndex = menu._childIndex;\n }\n }\n\n /**\n * Handle the `'mouseleave'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the menu node.\n */\n private _evtMouseLeave(event: MouseEvent): void {\n // Cancel any pending submenu opening.\n this._cancelOpenTimer();\n\n // If there is no open child menu, just reset the active index.\n if (!this._childMenu) {\n this.activeIndex = -1;\n return;\n }\n\n // If the mouse is over the child menu, cancel the close timer.\n let { clientX, clientY } = event;\n if (ElementExt.hitTest(this._childMenu.node, clientX, clientY)) {\n this._cancelCloseTimer();\n return;\n }\n\n // Otherwise, reset the active index and start the close timer.\n this.activeIndex = -1;\n this._startCloseTimer();\n }\n\n /**\n * Handle the `'mousedown'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the document node.\n */\n private _evtMouseDown(event: MouseEvent): void {\n // Bail if the menu is not a root menu.\n if (this._parentMenu) {\n return;\n }\n\n // The mouse button which is pressed is irrelevant. If the press\n // is not on a menu, the entire hierarchy is closed and the event\n // is allowed to propagate. This allows other code to act on the\n // event, such as focusing the clicked element.\n if (Private.hitTestMenus(this, event.clientX, event.clientY)) {\n event.preventDefault();\n event.stopPropagation();\n } else {\n this.close();\n }\n }\n\n /**\n * Open the child menu at the active index immediately.\n *\n * If a different child menu is already open, it will be closed,\n * even if the active item is not a valid submenu.\n */\n private _openChildMenu(activateFirst = false): void {\n // If the item is not a valid submenu, close the child menu.\n let item = this.activeItem;\n if (!item || item.type !== 'submenu' || !item.submenu) {\n this._closeChildMenu();\n return;\n }\n\n // Do nothing if the child menu will not change.\n let submenu = item.submenu;\n if (submenu === this._childMenu) {\n return;\n }\n\n // Prior to any DOM modifications save window data\n Menu.saveWindowData();\n\n // Ensure the current child menu is closed.\n this._closeChildMenu();\n\n // Update the private child state.\n this._childMenu = submenu;\n this._childIndex = this._activeIndex;\n\n // Set the parent menu reference for the child.\n submenu._parentMenu = this;\n\n // Ensure the menu is updated and lookup the item node.\n MessageLoop.sendMessage(this, Widget.Msg.UpdateRequest);\n let itemNode = this.contentNode.children[this._activeIndex];\n\n // Open the submenu at the active node.\n Private.openSubmenu(submenu, itemNode as HTMLElement);\n\n // Activate the first item if desired.\n if (activateFirst) {\n submenu.activeIndex = -1;\n submenu.activateNextItem();\n }\n\n // Activate the child menu.\n submenu.activate();\n }\n\n /**\n * Close the child menu immediately.\n *\n * This is a no-op if a child menu is not open.\n */\n private _closeChildMenu(): void {\n if (this._childMenu) {\n this._childMenu.close();\n }\n }\n\n /**\n * Start the open timer, unless it is already pending.\n */\n private _startOpenTimer(): void {\n if (this._openTimerID === 0) {\n this._openTimerID = window.setTimeout(() => {\n this._openTimerID = 0;\n this._openChildMenu();\n }, Private.TIMER_DELAY);\n }\n }\n\n /**\n * Start the close timer, unless it is already pending.\n */\n private _startCloseTimer(): void {\n if (this._closeTimerID === 0) {\n this._closeTimerID = window.setTimeout(() => {\n this._closeTimerID = 0;\n this._closeChildMenu();\n }, Private.TIMER_DELAY);\n }\n }\n\n /**\n * Cancel the open timer, if the timer is pending.\n */\n private _cancelOpenTimer(): void {\n if (this._openTimerID !== 0) {\n clearTimeout(this._openTimerID);\n this._openTimerID = 0;\n }\n }\n\n /**\n * Cancel the close timer, if the timer is pending.\n */\n private _cancelCloseTimer(): void {\n if (this._closeTimerID !== 0) {\n clearTimeout(this._closeTimerID);\n this._closeTimerID = 0;\n }\n }\n\n /**\n * Save window data used for menu positioning in transient cache.\n *\n * In order to avoid layout trashing it is recommended to invoke this\n * method immediately prior to opening the menu and any DOM modifications\n * (like closing previously visible menu, or adding a class to menu widget).\n *\n * The transient cache will be released upon `open()` call.\n */\n static saveWindowData(): void {\n Private.saveWindowData();\n }\n\n private _childIndex = -1;\n private _activeIndex = -1;\n private _openTimerID = 0;\n private _closeTimerID = 0;\n private _items: Menu.IItem[] = [];\n private _childMenu: Menu | null = null;\n private _parentMenu: Menu | null = null;\n private _aboutToClose = new Signal(this);\n private _menuRequested = new Signal(this);\n}\n\n/**\n * The namespace for the `Menu` class statics.\n */\nexport namespace Menu {\n /**\n * An options object for creating a menu.\n */\n export interface IOptions {\n /**\n * The command registry for use with the menu.\n */\n commands: CommandRegistry;\n\n /**\n * A custom renderer for use with the menu.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n }\n\n /**\n * An options object for the `open` method on a menu.\n */\n export interface IOpenOptions {\n /**\n * Whether to force the X position of the menu.\n *\n * Setting to `true` will disable the logic which repositions the\n * X coordinate of the menu if it will not fit entirely on screen.\n *\n * The default is `false`.\n */\n forceX?: boolean;\n\n /**\n * Whether to force the Y position of the menu.\n *\n * Setting to `true` will disable the logic which repositions the\n * Y coordinate of the menu if it will not fit entirely on screen.\n *\n * The default is `false`.\n */\n forceY?: boolean;\n\n /**\n * The DOM node to use as the menu's host.\n *\n * If not specified then uses `document.body`.\n */\n host?: HTMLElement;\n\n /**\n * The child of `host` to use as the reference element.\n * If this is provided, the menu will be inserted before this\n * node in the host. The default is `null`, which will cause the\n * menu to be added as the last child of the host.\n */\n ref?: HTMLElement;\n }\n\n /**\n * A type alias for a menu item type.\n */\n export type ItemType = 'command' | 'submenu' | 'separator';\n\n /**\n * An options object for creating a menu item.\n */\n export interface IItemOptions {\n /**\n * The type of the menu item.\n *\n * The default value is `'command'`.\n */\n type?: ItemType;\n\n /**\n * The command to execute when the item is triggered.\n *\n * The default value is an empty string.\n */\n command?: string;\n\n /**\n * The arguments for the command.\n *\n * The default value is an empty object.\n */\n args?: ReadonlyJSONObject;\n\n /**\n * The submenu for a `'submenu'` type item.\n *\n * The default value is `null`.\n */\n submenu?: Menu | null;\n }\n\n /**\n * An object which represents a menu item.\n *\n * #### Notes\n * Item objects are created automatically by a menu.\n */\n export interface IItem {\n /**\n * The type of the menu item.\n */\n readonly type: ItemType;\n\n /**\n * The command to execute when the item is triggered.\n */\n readonly command: string;\n\n /**\n * The arguments for the command.\n */\n readonly args: ReadonlyJSONObject;\n\n /**\n * The submenu for a `'submenu'` type item.\n */\n readonly submenu: Menu | null;\n\n /**\n * The display label for the menu item.\n */\n readonly label: string;\n\n /**\n * The mnemonic index for the menu item.\n */\n readonly mnemonic: number;\n\n /**\n * The icon renderer for the menu item.\n */\n readonly icon: VirtualElement.IRenderer | undefined;\n\n /**\n * The icon class for the menu item.\n */\n readonly iconClass: string;\n\n /**\n * The icon label for the menu item.\n */\n readonly iconLabel: string;\n\n /**\n * The display caption for the menu item.\n */\n readonly caption: string;\n\n /**\n * The extra class name for the menu item.\n */\n readonly className: string;\n\n /**\n * The dataset for the menu item.\n */\n readonly dataset: CommandRegistry.Dataset;\n\n /**\n * Whether the menu item is enabled.\n */\n readonly isEnabled: boolean;\n\n /**\n * Whether the menu item is toggled.\n */\n readonly isToggled: boolean;\n\n /**\n * Whether the menu item is visible.\n */\n readonly isVisible: boolean;\n\n /**\n * The key binding for the menu item.\n */\n readonly keyBinding: CommandRegistry.IKeyBinding | null;\n }\n\n /**\n * An object which holds the data to render a menu item.\n */\n export interface IRenderData {\n /**\n * The item to be rendered.\n */\n readonly item: IItem;\n\n /**\n * Whether the item is the active item.\n */\n readonly active: boolean;\n\n /**\n * Whether the item should be collapsed.\n */\n readonly collapsed: boolean;\n\n /**\n * Handler for when element is in focus.\n */\n readonly onfocus?: () => void;\n }\n\n /**\n * A renderer for use with a menu.\n */\n export interface IRenderer {\n /**\n * Render the virtual element for a menu item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n */\n renderItem(data: IRenderData): VirtualElement;\n }\n\n /**\n * The default implementation of `IRenderer`.\n *\n * #### Notes\n * Subclasses are free to reimplement rendering methods as needed.\n */\n export class Renderer implements IRenderer {\n /**\n * Render the virtual element for a menu item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n */\n renderItem(data: IRenderData): VirtualElement {\n let className = this.createItemClass(data);\n let dataset = this.createItemDataset(data);\n let aria = this.createItemARIA(data);\n return h.li(\n {\n className,\n dataset,\n tabindex: '0',\n onfocus: data.onfocus,\n ...aria\n },\n this.renderIcon(data),\n this.renderLabel(data),\n this.renderShortcut(data),\n this.renderSubmenu(data)\n );\n }\n\n /**\n * Render the icon element for a menu item.\n *\n * @param data - The data to use for rendering the icon.\n *\n * @returns A virtual element representing the item icon.\n */\n renderIcon(data: IRenderData): VirtualElement {\n let className = this.createIconClass(data);\n\n // If data.item.icon is undefined, it will be ignored.\n return h.div({ className }, data.item.icon!, data.item.iconLabel);\n }\n\n /**\n * Render the label element for a menu item.\n *\n * @param data - The data to use for rendering the label.\n *\n * @returns A virtual element representing the item label.\n */\n renderLabel(data: IRenderData): VirtualElement {\n let content = this.formatLabel(data);\n return h.div({ className: 'lm-Menu-itemLabel' }, content);\n }\n\n /**\n * Render the shortcut element for a menu item.\n *\n * @param data - The data to use for rendering the shortcut.\n *\n * @returns A virtual element representing the item shortcut.\n */\n renderShortcut(data: IRenderData): VirtualElement {\n let content = this.formatShortcut(data);\n return h.div({ className: 'lm-Menu-itemShortcut' }, content);\n }\n\n /**\n * Render the submenu icon element for a menu item.\n *\n * @param data - The data to use for rendering the submenu icon.\n *\n * @returns A virtual element representing the submenu icon.\n */\n renderSubmenu(data: IRenderData): VirtualElement {\n return h.div({ className: 'lm-Menu-itemSubmenuIcon' });\n }\n\n /**\n * Create the class name for the menu item.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the menu item.\n */\n createItemClass(data: IRenderData): string {\n // Setup the initial class name.\n let name = 'lm-Menu-item';\n\n // Add the boolean state classes.\n if (!data.item.isEnabled) {\n name += ' lm-mod-disabled';\n }\n if (data.item.isToggled) {\n name += ' lm-mod-toggled';\n }\n if (!data.item.isVisible) {\n name += ' lm-mod-hidden';\n }\n if (data.active) {\n name += ' lm-mod-active';\n }\n if (data.collapsed) {\n name += ' lm-mod-collapsed';\n }\n\n // Add the extra class.\n let extra = data.item.className;\n if (extra) {\n name += ` ${extra}`;\n }\n\n // Return the complete class name.\n return name;\n }\n\n /**\n * Create the dataset for the menu item.\n *\n * @param data - The data to use for creating the dataset.\n *\n * @returns The dataset for the menu item.\n */\n createItemDataset(data: IRenderData): ElementDataset {\n let result: ElementDataset;\n let { type, command, dataset } = data.item;\n if (type === 'command') {\n result = { ...dataset, type, command };\n } else {\n result = { ...dataset, type };\n }\n return result;\n }\n\n /**\n * Create the class name for the menu item icon.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the item icon.\n */\n createIconClass(data: IRenderData): string {\n let name = 'lm-Menu-itemIcon';\n let extra = data.item.iconClass;\n return extra ? `${name} ${extra}` : name;\n }\n\n /**\n * Create the aria attributes for menu item.\n *\n * @param data - The data to use for the aria attributes.\n *\n * @returns The aria attributes object for the item.\n */\n createItemARIA(data: IRenderData): ElementARIAAttrs {\n let aria: { [T in ARIAAttrNames]?: string } = {};\n switch (data.item.type) {\n case 'separator':\n aria.role = 'presentation';\n break;\n case 'submenu':\n aria['aria-haspopup'] = 'true';\n if (!data.item.isEnabled) {\n aria['aria-disabled'] = 'true';\n }\n break;\n default:\n if (!data.item.isEnabled) {\n aria['aria-disabled'] = 'true';\n }\n aria.role = 'menuitem';\n }\n return aria;\n }\n\n /**\n * Create the render content for the label node.\n *\n * @param data - The data to use for the label content.\n *\n * @returns The content to add to the label node.\n */\n formatLabel(data: IRenderData): h.Child {\n // Fetch the label text and mnemonic index.\n let { label, mnemonic } = data.item;\n\n // If the index is out of range, do not modify the label.\n if (mnemonic < 0 || mnemonic >= label.length) {\n return label;\n }\n\n // Split the label into parts.\n let prefix = label.slice(0, mnemonic);\n let suffix = label.slice(mnemonic + 1);\n let char = label[mnemonic];\n\n // Wrap the mnemonic character in a span.\n let span = h.span({ className: 'lm-Menu-itemMnemonic' }, char);\n\n // Return the content parts.\n return [prefix, span, suffix];\n }\n\n /**\n * Create the render content for the shortcut node.\n *\n * @param data - The data to use for the shortcut content.\n *\n * @returns The content to add to the shortcut node.\n */\n formatShortcut(data: IRenderData): h.Child {\n let kb = data.item.keyBinding;\n return kb ? CommandRegistry.formatKeystroke(kb.keys) : null;\n }\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The ms delay for opening and closing a submenu.\n */\n export const TIMER_DELAY = 300;\n\n /**\n * The horizontal pixel overlap for an open submenu.\n */\n export const SUBMENU_OVERLAP = 3;\n\n let transientWindowDataCache: IWindowData | null = null;\n let transientCacheCounter: number = 0;\n\n function getWindowData(): IWindowData {\n // if transient cache is in use, take one from it\n if (transientCacheCounter > 0) {\n transientCacheCounter--;\n return transientWindowDataCache!;\n }\n return _getWindowData();\n }\n\n /**\n * Store window data in transient cache.\n *\n * The transient cache will be released upon `getWindowData()` call.\n * If this function is called multiple times, the cache will be\n * retained until as many calls to `getWindowData()` were made.\n *\n * Note: should be called before any DOM modifications.\n */\n export function saveWindowData(): void {\n transientWindowDataCache = _getWindowData();\n transientCacheCounter++;\n }\n\n /**\n * Create the DOM node for a menu.\n */\n export function createNode(): HTMLDivElement {\n let node = document.createElement('div');\n let content = document.createElement('ul');\n content.className = 'lm-Menu-content';\n node.appendChild(content);\n content.setAttribute('role', 'menu');\n node.tabIndex = 0;\n return node;\n }\n\n /**\n * Test whether a menu item can be activated.\n */\n export function canActivate(item: Menu.IItem): boolean {\n return item.type !== 'separator' && item.isEnabled && item.isVisible;\n }\n\n /**\n * Create a new menu item for an owner menu.\n */\n export function createItem(\n owner: Menu,\n options: Menu.IItemOptions\n ): Menu.IItem {\n return new MenuItem(owner.commands, options);\n }\n\n /**\n * Hit test a menu hierarchy starting at the given root.\n */\n export function hitTestMenus(menu: Menu, x: number, y: number): boolean {\n for (let temp: Menu | null = menu; temp; temp = temp.childMenu) {\n if (ElementExt.hitTest(temp.node, x, y)) {\n return true;\n }\n }\n return false;\n }\n\n /**\n * Compute which extra separator items should be collapsed.\n */\n export function computeCollapsed(\n items: ReadonlyArray\n ): boolean[] {\n // Allocate the return array and fill it with `false`.\n let result = new Array(items.length);\n ArrayExt.fill(result, false);\n\n // Collapse the leading separators.\n let k1 = 0;\n let n = items.length;\n for (; k1 < n; ++k1) {\n let item = items[k1];\n if (!item.isVisible) {\n continue;\n }\n if (item.type !== 'separator') {\n break;\n }\n result[k1] = true;\n }\n\n // Hide the trailing separators.\n let k2 = n - 1;\n for (; k2 >= 0; --k2) {\n let item = items[k2];\n if (!item.isVisible) {\n continue;\n }\n if (item.type !== 'separator') {\n break;\n }\n result[k2] = true;\n }\n\n // Hide the remaining consecutive separators.\n let hide = false;\n while (++k1 < k2) {\n let item = items[k1];\n if (!item.isVisible) {\n continue;\n }\n if (item.type !== 'separator') {\n hide = false;\n } else if (hide) {\n result[k1] = true;\n } else {\n hide = true;\n }\n }\n\n // Return the resulting flags.\n return result;\n }\n\n function _getWindowData(): IWindowData {\n return {\n pageXOffset: window.pageXOffset,\n pageYOffset: window.pageYOffset,\n clientWidth: document.documentElement.clientWidth,\n clientHeight: document.documentElement.clientHeight\n };\n }\n\n /**\n * Open a menu as a root menu at the target location.\n */\n export function openRootMenu(\n menu: Menu,\n x: number,\n y: number,\n forceX: boolean,\n forceY: boolean,\n host: HTMLElement | null,\n ref: HTMLElement | null\n ): void {\n // Get the current position and size of the main viewport.\n const windowData = getWindowData();\n let px = windowData.pageXOffset;\n let py = windowData.pageYOffset;\n let cw = windowData.clientWidth;\n let ch = windowData.clientHeight;\n\n // Ensure the menu is updated before attaching and measuring.\n MessageLoop.sendMessage(menu, Widget.Msg.UpdateRequest);\n\n // Compute the maximum allowed height for the menu.\n let maxHeight = ch - (forceY ? y : 0);\n\n // Fetch common variables.\n let node = menu.node;\n let style = node.style;\n\n // Clear the menu geometry and prepare it for measuring.\n style.opacity = '0';\n style.maxHeight = `${maxHeight}px`;\n\n // Attach the menu to the document.\n Widget.attach(menu, host || document.body, ref);\n\n // Measure the size of the menu.\n let { width, height } = node.getBoundingClientRect();\n\n // Adjust the X position of the menu to fit on-screen.\n if (!forceX && x + width > px + cw) {\n x = px + cw - width;\n }\n\n // Adjust the Y position of the menu to fit on-screen.\n if (!forceY && y + height > py + ch) {\n if (y > py + ch) {\n y = py + ch - height;\n } else {\n y = y - height;\n }\n }\n\n // Update the position of the menu to the computed position.\n style.transform = `translate(${Math.max(0, x)}px, ${Math.max(0, y)}px`;\n\n // Finally, make the menu visible on the screen.\n style.opacity = '1';\n }\n\n /**\n * Open a menu as a submenu using an item node for positioning.\n */\n export function openSubmenu(submenu: Menu, itemNode: HTMLElement): void {\n // Get the current position and size of the main viewport.\n const windowData = getWindowData();\n let px = windowData.pageXOffset;\n let py = windowData.pageYOffset;\n let cw = windowData.clientWidth;\n let ch = windowData.clientHeight;\n\n // Ensure the menu is updated before opening.\n MessageLoop.sendMessage(submenu, Widget.Msg.UpdateRequest);\n\n // Compute the maximum allowed height for the menu.\n let maxHeight = ch;\n\n // Fetch common variables.\n let node = submenu.node;\n let style = node.style;\n\n // Clear the menu geometry and prepare it for measuring.\n style.opacity = '0';\n style.maxHeight = `${maxHeight}px`;\n\n // Attach the menu to the document.\n Widget.attach(submenu, document.body);\n\n // Measure the size of the menu.\n let { width, height } = node.getBoundingClientRect();\n\n // Compute the box sizing for the menu.\n let box = ElementExt.boxSizing(submenu.node);\n\n // Get the bounding rect for the target item node.\n let itemRect = itemNode.getBoundingClientRect();\n\n // Compute the target X position.\n let x = itemRect.right - SUBMENU_OVERLAP;\n\n // Adjust the X position to fit on the screen.\n if (x + width > px + cw) {\n x = itemRect.left + SUBMENU_OVERLAP - width;\n }\n\n // Compute the target Y position.\n let y = itemRect.top - box.borderTop - box.paddingTop;\n\n // Adjust the Y position to fit on the screen.\n if (y + height > py + ch) {\n y = itemRect.bottom + box.borderBottom + box.paddingBottom - height;\n }\n\n // Update the position of the menu to the computed position.\n style.transform = `translate(${Math.max(0, x)}px, ${Math.max(0, y)}px`;\n\n // Finally, make the menu visible on the screen.\n style.opacity = '1';\n }\n\n /**\n * The results of a mnemonic search.\n */\n export interface IMnemonicResult {\n /**\n * The index of the first matching mnemonic item, or `-1`.\n */\n index: number;\n\n /**\n * Whether multiple mnemonic items matched.\n */\n multiple: boolean;\n\n /**\n * The index of the first auto matched non-mnemonic item.\n */\n auto: number;\n }\n\n /**\n * Find the best matching mnemonic item.\n *\n * The search starts at the given index and wraps around.\n */\n export function findMnemonic(\n items: ReadonlyArray,\n key: string,\n start: number\n ): IMnemonicResult {\n // Setup the result variables.\n let index = -1;\n let auto = -1;\n let multiple = false;\n\n // Normalize the key to upper case.\n let upperKey = key.toUpperCase();\n\n // Search the items from the given start index.\n for (let i = 0, n = items.length; i < n; ++i) {\n // Compute the wrapped index.\n let k = (i + start) % n;\n\n // Lookup the item\n let item = items[k];\n\n // Ignore items which cannot be activated.\n if (!canActivate(item)) {\n continue;\n }\n\n // Ignore items with an empty label.\n let label = item.label;\n if (label.length === 0) {\n continue;\n }\n\n // Lookup the mnemonic index for the label.\n let mn = item.mnemonic;\n\n // Handle a valid mnemonic index.\n if (mn >= 0 && mn < label.length) {\n if (label[mn].toUpperCase() === upperKey) {\n if (index === -1) {\n index = k;\n } else {\n multiple = true;\n }\n }\n continue;\n }\n\n // Finally, handle the auto index if possible.\n if (auto === -1 && label[0].toUpperCase() === upperKey) {\n auto = k;\n }\n }\n\n // Return the search results.\n return { index, multiple, auto };\n }\n\n /**\n * A concrete implementation of `Menu.IItem`.\n */\n class MenuItem implements Menu.IItem {\n /**\n * Construct a new menu item.\n */\n constructor(commands: CommandRegistry, options: Menu.IItemOptions) {\n this._commands = commands;\n this.type = options.type || 'command';\n this.command = options.command || '';\n this.args = options.args || JSONExt.emptyObject;\n this.submenu = options.submenu || null;\n }\n\n /**\n * The type of the menu item.\n */\n readonly type: Menu.ItemType;\n\n /**\n * The command to execute when the item is triggered.\n */\n readonly command: string;\n\n /**\n * The arguments for the command.\n */\n readonly args: ReadonlyJSONObject;\n\n /**\n * The submenu for a `'submenu'` type item.\n */\n readonly submenu: Menu | null;\n\n /**\n * The display label for the menu item.\n */\n get label(): string {\n if (this.type === 'command') {\n return this._commands.label(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.label;\n }\n return '';\n }\n\n /**\n * The mnemonic index for the menu item.\n */\n get mnemonic(): number {\n if (this.type === 'command') {\n return this._commands.mnemonic(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.mnemonic;\n }\n return -1;\n }\n\n /**\n * The icon renderer for the menu item.\n */\n get icon(): VirtualElement.IRenderer | undefined {\n if (this.type === 'command') {\n return this._commands.icon(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.icon;\n }\n return undefined;\n }\n\n /**\n * The icon class for the menu item.\n */\n get iconClass(): string {\n if (this.type === 'command') {\n return this._commands.iconClass(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.iconClass;\n }\n return '';\n }\n\n /**\n * The icon label for the menu item.\n */\n get iconLabel(): string {\n if (this.type === 'command') {\n return this._commands.iconLabel(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.iconLabel;\n }\n return '';\n }\n\n /**\n * The display caption for the menu item.\n */\n get caption(): string {\n if (this.type === 'command') {\n return this._commands.caption(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.caption;\n }\n return '';\n }\n\n /**\n * The extra class name for the menu item.\n */\n get className(): string {\n if (this.type === 'command') {\n return this._commands.className(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.className;\n }\n return '';\n }\n\n /**\n * The dataset for the menu item.\n */\n get dataset(): CommandRegistry.Dataset {\n if (this.type === 'command') {\n return this._commands.dataset(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.dataset;\n }\n return {};\n }\n\n /**\n * Whether the menu item is enabled.\n */\n get isEnabled(): boolean {\n if (this.type === 'command') {\n return this._commands.isEnabled(this.command, this.args);\n }\n if (this.type === 'submenu') {\n return this.submenu !== null;\n }\n return true;\n }\n\n /**\n * Whether the menu item is toggled.\n */\n get isToggled(): boolean {\n if (this.type === 'command') {\n return this._commands.isToggled(this.command, this.args);\n }\n return false;\n }\n\n /**\n * Whether the menu item is visible.\n */\n get isVisible(): boolean {\n if (this.type === 'command') {\n return this._commands.isVisible(this.command, this.args);\n }\n if (this.type === 'submenu') {\n return this.submenu !== null;\n }\n return true;\n }\n\n /**\n * The key binding for the menu item.\n */\n get keyBinding(): CommandRegistry.IKeyBinding | null {\n if (this.type === 'command') {\n let { command, args } = this;\n return (\n ArrayExt.findLastValue(this._commands.keyBindings, kb => {\n return kb.command === command && JSONExt.deepEqual(kb.args, args);\n }) || null\n );\n }\n return null;\n }\n\n private _commands: CommandRegistry;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { CommandRegistry } from '@lumino/commands';\n\nimport { DisposableDelegate, IDisposable } from '@lumino/disposable';\n\nimport { Selector } from '@lumino/domutils';\n\nimport { Menu } from './menu';\n\n/**\n * An object which implements a universal context menu.\n *\n * #### Notes\n * The items shown in the context menu are determined by CSS selector\n * matching against the DOM hierarchy at the site of the mouse click.\n * This is similar in concept to how keyboard shortcuts are matched\n * in the command registry.\n */\nexport class ContextMenu {\n /**\n * Construct a new context menu.\n *\n * @param options - The options for initializing the menu.\n */\n constructor(options: ContextMenu.IOptions) {\n const { groupByTarget, sortBySelector, ...others } = options;\n this.menu = new Menu(others);\n this._groupByTarget = groupByTarget !== false;\n this._sortBySelector = sortBySelector !== false;\n }\n\n /**\n * The menu widget which displays the matched context items.\n */\n readonly menu: Menu;\n\n /**\n * Add an item to the context menu.\n *\n * @param options - The options for creating the item.\n *\n * @returns A disposable which will remove the item from the menu.\n */\n addItem(options: ContextMenu.IItemOptions): IDisposable {\n // Create an item from the given options.\n let item = Private.createItem(options, this._idTick++);\n\n // Add the item to the internal array.\n this._items.push(item);\n\n // Return a disposable which will remove the item.\n return new DisposableDelegate(() => {\n ArrayExt.removeFirstOf(this._items, item);\n });\n }\n\n /**\n * Open the context menu in response to a `'contextmenu'` event.\n *\n * @param event - The `'contextmenu'` event of interest.\n *\n * @returns `true` if the menu was opened, or `false` if no items\n * matched the event and the menu was not opened.\n *\n * #### Notes\n * This method will populate the context menu with items which match\n * the propagation path of the event, then open the menu at the mouse\n * position indicated by the event.\n */\n open(event: MouseEvent): boolean {\n // Prior to any DOM modifications update the window data.\n Menu.saveWindowData();\n\n // Clear the current contents of the context menu.\n this.menu.clearItems();\n\n // Bail early if there are no items to match.\n if (this._items.length === 0) {\n return false;\n }\n\n // Find the matching items for the event.\n let items = Private.matchItems(\n this._items,\n event,\n this._groupByTarget,\n this._sortBySelector\n );\n\n // Bail if there are no matching items.\n if (!items || items.length === 0) {\n return false;\n }\n\n // Add the filtered items to the menu.\n for (const item of items) {\n this.menu.addItem(item);\n }\n\n // Open the context menu at the current mouse position.\n this.menu.open(event.clientX, event.clientY);\n\n // Indicate success.\n return true;\n }\n\n private _groupByTarget: boolean = true;\n private _idTick = 0;\n private _items: Private.IItem[] = [];\n private _sortBySelector: boolean = true;\n}\n\n/**\n * The namespace for the `ContextMenu` class statics.\n */\nexport namespace ContextMenu {\n /**\n * An options object for initializing a context menu.\n */\n export interface IOptions {\n /**\n * The command registry to use with the context menu.\n */\n commands: CommandRegistry;\n\n /**\n * A custom renderer for use with the context menu.\n */\n renderer?: Menu.IRenderer;\n\n /**\n * Whether to sort by selector and rank or only rank.\n *\n * Default true.\n */\n sortBySelector?: boolean;\n\n /**\n * Whether to group items following the DOM hierarchy.\n *\n * Default true.\n *\n * #### Note\n * If true, when the mouse event occurs on element `span` within `div.top`,\n * the items matching `div.top` will be shown before the ones matching `body`.\n */\n groupByTarget?: boolean;\n }\n\n /**\n * An options object for creating a context menu item.\n */\n export interface IItemOptions extends Menu.IItemOptions {\n /**\n * The CSS selector for the context menu item.\n *\n * The context menu item will only be displayed in the context menu\n * when the selector matches a node on the propagation path of the\n * contextmenu event. This allows the menu item to be restricted to\n * user-defined contexts.\n *\n * The selector must not contain commas.\n */\n selector: string;\n\n /**\n * The rank for the item.\n *\n * The rank is used as a tie-breaker when ordering context menu\n * items for display. Items are sorted in the following order:\n * 1. Depth in the DOM tree (deeper is better)\n * 2. Selector specificity (higher is better)\n * 3. Rank (lower is better)\n * 4. Insertion order\n *\n * The default rank is `Infinity`.\n */\n rank?: number;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * A normalized item for a context menu.\n */\n export interface IItem extends Menu.IItemOptions {\n /**\n * The selector for the item.\n */\n selector: string;\n\n /**\n * The rank for the item.\n */\n rank: number;\n\n /**\n * The tie-breaking id for the item.\n */\n id: number;\n }\n\n /**\n * Create a normalized context menu item from an options object.\n */\n export function createItem(\n options: ContextMenu.IItemOptions,\n id: number\n ): IItem {\n let selector = validateSelector(options.selector);\n let rank = options.rank !== undefined ? options.rank : Infinity;\n return { ...options, selector, rank, id };\n }\n\n /**\n * Find the items which match a context menu event.\n *\n * The results are sorted by DOM level, specificity, and rank.\n */\n export function matchItems(\n items: IItem[],\n event: MouseEvent,\n groupByTarget: boolean,\n sortBySelector: boolean\n ): IItem[] | null {\n // Look up the target of the event.\n let target = event.target as Element | null;\n\n // Bail if there is no target.\n if (!target) {\n return null;\n }\n\n // Look up the current target of the event.\n let currentTarget = event.currentTarget as Element | null;\n\n // Bail if there is no current target.\n if (!currentTarget) {\n return null;\n }\n\n // There are some third party libraries that cause the `target` to\n // be detached from the DOM before lumino can process the event.\n // If that happens, search for a new target node by point. If that\n // node is still dangling, bail.\n if (!currentTarget.contains(target)) {\n target = document.elementFromPoint(event.clientX, event.clientY);\n if (!target || !currentTarget.contains(target)) {\n return null;\n }\n }\n\n // Set up the result array.\n let result: IItem[] = [];\n\n // Copy the items array to allow in-place modification.\n let availableItems: Array = items.slice();\n\n // Walk up the DOM hierarchy searching for matches.\n while (target !== null) {\n // Set up the match array for this DOM level.\n let matches: IItem[] = [];\n\n // Search the remaining items for matches.\n for (let i = 0, n = availableItems.length; i < n; ++i) {\n // Fetch the item.\n let item = availableItems[i];\n\n // Skip items which are already consumed.\n if (!item) {\n continue;\n }\n\n // Skip items which do not match the element.\n if (!Selector.matches(target, item.selector)) {\n continue;\n }\n\n // Add the matched item to the result for this DOM level.\n matches.push(item);\n\n // Mark the item as consumed.\n availableItems[i] = null;\n }\n\n // Sort the matches for this level and add them to the results.\n if (matches.length !== 0) {\n if (groupByTarget) {\n matches.sort(sortBySelector ? itemCmp : itemCmpRank);\n }\n result.push(...matches);\n }\n\n // Stop searching at the limits of the DOM range.\n if (target === currentTarget) {\n break;\n }\n\n // Step to the parent DOM level.\n target = target.parentElement;\n }\n\n if (!groupByTarget) {\n result.sort(sortBySelector ? itemCmp : itemCmpRank);\n }\n\n // Return the matched and sorted results.\n return result;\n }\n\n /**\n * Validate the selector for a menu item.\n *\n * This returns the validated selector, or throws if the selector is\n * invalid or contains commas.\n */\n function validateSelector(selector: string): string {\n if (selector.indexOf(',') !== -1) {\n throw new Error(`Selector cannot contain commas: ${selector}`);\n }\n if (!Selector.isValid(selector)) {\n throw new Error(`Invalid selector: ${selector}`);\n }\n return selector;\n }\n\n /**\n * A sort comparison function for a context menu item by ranks.\n */\n function itemCmpRank(a: IItem, b: IItem): number {\n // Sort based on rank.\n let r1 = a.rank;\n let r2 = b.rank;\n if (r1 !== r2) {\n return r1 < r2 ? -1 : 1; // Infinity-safe\n }\n\n // When all else fails, sort by item id.\n return a.id - b.id;\n }\n\n /**\n * A sort comparison function for a context menu item by selectors and ranks.\n */\n function itemCmp(a: IItem, b: IItem): number {\n // Sort first based on selector specificity.\n let s1 = Selector.calculateSpecificity(a.selector);\n let s2 = Selector.calculateSpecificity(b.selector);\n if (s1 !== s2) {\n return s2 - s1;\n }\n\n // If specificities are equal\n return itemCmpRank(a, b);\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Drag } from '@lumino/dragdrop';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport {\n ElementARIAAttrs,\n ElementBaseAttrs,\n ElementDataset,\n ElementInlineStyle,\n h,\n VirtualDOM,\n VirtualElement\n} from '@lumino/virtualdom';\n\nimport { Title } from './title';\n\nimport { Widget } from './widget';\n\nconst ARROW_KEYS = [\n 'ArrowLeft',\n 'ArrowUp',\n 'ArrowRight',\n 'ArrowDown',\n 'Home',\n 'End'\n];\n\n/**\n * A widget which displays titles as a single row or column of tabs.\n *\n * #### Notes\n * If CSS transforms are used to rotate nodes for vertically oriented\n * text, then tab dragging will not work correctly. The `tabsMovable`\n * property should be set to `false` when rotating nodes from CSS.\n */\nexport class TabBar extends Widget {\n /**\n * Construct a new tab bar.\n *\n * @param options - The options for initializing the tab bar.\n */\n constructor(options: TabBar.IOptions = {}) {\n super({ node: Private.createNode() });\n this.addClass('lm-TabBar');\n this.contentNode.setAttribute('role', 'tablist');\n this.setFlag(Widget.Flag.DisallowLayout);\n this._document = options.document || document;\n this.tabsMovable = options.tabsMovable || false;\n this.titlesEditable = options.titlesEditable || false;\n this.allowDeselect = options.allowDeselect || false;\n this.addButtonEnabled = options.addButtonEnabled || false;\n this.insertBehavior = options.insertBehavior || 'select-tab-if-needed';\n this.name = options.name || '';\n this.orientation = options.orientation || 'horizontal';\n this.removeBehavior = options.removeBehavior || 'select-tab-after';\n this.renderer = options.renderer || TabBar.defaultRenderer;\n }\n\n /**\n * Dispose of the resources held by the widget.\n */\n dispose(): void {\n this._releaseMouse();\n this._titles.length = 0;\n this._previousTitle = null;\n super.dispose();\n }\n\n /**\n * A signal emitted when the current tab is changed.\n *\n * #### Notes\n * This signal is emitted when the currently selected tab is changed\n * either through user or programmatic interaction.\n *\n * Notably, this signal is not emitted when the index of the current\n * tab changes due to tabs being inserted, removed, or moved. It is\n * only emitted when the actual current tab node is changed.\n */\n get currentChanged(): ISignal> {\n return this._currentChanged;\n }\n\n /**\n * A signal emitted when a tab is moved by the user.\n *\n * #### Notes\n * This signal is emitted when a tab is moved by user interaction.\n *\n * This signal is not emitted when a tab is moved programmatically.\n */\n get tabMoved(): ISignal> {\n return this._tabMoved;\n }\n\n /**\n * A signal emitted when a tab is clicked by the user.\n *\n * #### Notes\n * If the clicked tab is not the current tab, the clicked tab will be\n * made current and the `currentChanged` signal will be emitted first.\n *\n * This signal is emitted even if the clicked tab is the current tab.\n */\n get tabActivateRequested(): ISignal<\n this,\n TabBar.ITabActivateRequestedArgs\n > {\n return this._tabActivateRequested;\n }\n\n /**\n * A signal emitted when the tab bar add button is clicked.\n */\n get addRequested(): ISignal {\n return this._addRequested;\n }\n\n /**\n * A signal emitted when a tab close icon is clicked.\n *\n * #### Notes\n * This signal is not emitted unless the tab title is `closable`.\n */\n get tabCloseRequested(): ISignal> {\n return this._tabCloseRequested;\n }\n\n /**\n * A signal emitted when a tab is dragged beyond the detach threshold.\n *\n * #### Notes\n * This signal is emitted when the user drags a tab with the mouse,\n * and mouse is dragged beyond the detach threshold.\n *\n * The consumer of the signal should call `releaseMouse` and remove\n * the tab in order to complete the detach.\n *\n * This signal is only emitted once per drag cycle.\n */\n get tabDetachRequested(): ISignal> {\n return this._tabDetachRequested;\n }\n\n /**\n * The renderer used by the tab bar.\n */\n readonly renderer: TabBar.IRenderer;\n\n /**\n * The document to use with the tab bar.\n *\n * The default is the global `document` instance.\n */\n get document(): Document | ShadowRoot {\n return this._document;\n }\n\n /**\n * Whether the tabs are movable by the user.\n *\n * #### Notes\n * Tabs can always be moved programmatically.\n */\n tabsMovable: boolean;\n\n /**\n * Whether the titles can be user-edited.\n *\n */\n get titlesEditable(): boolean {\n return this._titlesEditable;\n }\n\n /**\n * Set whether titles can be user edited.\n *\n */\n set titlesEditable(value: boolean) {\n this._titlesEditable = value;\n }\n\n /**\n * Whether a tab can be deselected by the user.\n *\n * #### Notes\n * Tabs can be always be deselected programmatically.\n */\n allowDeselect: boolean;\n\n /**\n * The selection behavior when inserting a tab.\n */\n insertBehavior: TabBar.InsertBehavior;\n\n /**\n * The selection behavior when removing a tab.\n */\n removeBehavior: TabBar.RemoveBehavior;\n\n /**\n * Get the currently selected title.\n *\n * #### Notes\n * This will be `null` if no tab is selected.\n */\n get currentTitle(): Title | null {\n return this._titles[this._currentIndex] || null;\n }\n\n /**\n * Set the currently selected title.\n *\n * #### Notes\n * If the title does not exist, the title will be set to `null`.\n */\n set currentTitle(value: Title | null) {\n this.currentIndex = value ? this._titles.indexOf(value) : -1;\n }\n\n /**\n * Get the index of the currently selected tab.\n *\n * #### Notes\n * This will be `-1` if no tab is selected.\n */\n get currentIndex(): number {\n return this._currentIndex;\n }\n\n /**\n * Set the index of the currently selected tab.\n *\n * #### Notes\n * If the value is out of range, the index will be set to `-1`.\n */\n set currentIndex(value: number) {\n // Adjust for an out of range index.\n if (value < 0 || value >= this._titles.length) {\n value = -1;\n }\n\n // Bail early if the index will not change.\n if (this._currentIndex === value) {\n return;\n }\n\n // Look up the previous index and title.\n let pi = this._currentIndex;\n let pt = this._titles[pi] || null;\n\n // Look up the current index and title.\n let ci = value;\n let ct = this._titles[ci] || null;\n\n // Update the current index and previous title.\n this._currentIndex = ci;\n this._previousTitle = pt;\n\n // Schedule an update of the tabs.\n this.update();\n\n // Emit the current changed signal.\n this._currentChanged.emit({\n previousIndex: pi,\n previousTitle: pt,\n currentIndex: ci,\n currentTitle: ct\n });\n }\n\n /**\n * Get the name of the tab bar.\n */\n get name(): string {\n return this._name;\n }\n\n /**\n * Set the name of the tab bar.\n */\n set name(value: string) {\n this._name = value;\n if (value) {\n this.contentNode.setAttribute('aria-label', value);\n } else {\n this.contentNode.removeAttribute('aria-label');\n }\n }\n\n /**\n * Get the orientation of the tab bar.\n *\n * #### Notes\n * This controls whether the tabs are arranged in a row or column.\n */\n get orientation(): TabBar.Orientation {\n return this._orientation;\n }\n\n /**\n * Set the orientation of the tab bar.\n *\n * #### Notes\n * This controls whether the tabs are arranged in a row or column.\n */\n set orientation(value: TabBar.Orientation) {\n // Do nothing if the orientation does not change.\n if (this._orientation === value) {\n return;\n }\n\n // Release the mouse before making any changes.\n this._releaseMouse();\n\n // Toggle the orientation values.\n this._orientation = value;\n this.dataset['orientation'] = value;\n this.contentNode.setAttribute('aria-orientation', value);\n }\n\n /**\n * Whether the add button is enabled.\n */\n get addButtonEnabled(): boolean {\n return this._addButtonEnabled;\n }\n\n /**\n * Set whether the add button is enabled.\n */\n set addButtonEnabled(value: boolean) {\n // Do nothing if the value does not change.\n if (this._addButtonEnabled === value) {\n return;\n }\n\n this._addButtonEnabled = value;\n if (value) {\n this.addButtonNode.classList.remove('lm-mod-hidden');\n } else {\n this.addButtonNode.classList.add('lm-mod-hidden');\n }\n }\n\n /**\n * A read-only array of the titles in the tab bar.\n */\n get titles(): ReadonlyArray> {\n return this._titles;\n }\n\n /**\n * The tab bar content node.\n *\n * #### Notes\n * This is the node which holds the tab nodes.\n *\n * Modifying this node directly can lead to undefined behavior.\n */\n get contentNode(): HTMLUListElement {\n return this.node.getElementsByClassName(\n 'lm-TabBar-content'\n )[0] as HTMLUListElement;\n }\n\n /**\n * The tab bar add button node.\n *\n * #### Notes\n * This is the node which holds the add button.\n *\n * Modifying this node directly can lead to undefined behavior.\n */\n get addButtonNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-TabBar-addButton'\n )[0] as HTMLDivElement;\n }\n\n /**\n * Add a tab to the end of the tab bar.\n *\n * @param value - The title which holds the data for the tab,\n * or an options object to convert to a title.\n *\n * @returns The title object added to the tab bar.\n *\n * #### Notes\n * If the title is already added to the tab bar, it will be moved.\n */\n addTab(value: Title | Title.IOptions): Title {\n return this.insertTab(this._titles.length, value);\n }\n\n /**\n * Insert a tab into the tab bar at the specified index.\n *\n * @param index - The index at which to insert the tab.\n *\n * @param value - The title which holds the data for the tab,\n * or an options object to convert to a title.\n *\n * @returns The title object added to the tab bar.\n *\n * #### Notes\n * The index will be clamped to the bounds of the tabs.\n *\n * If the title is already added to the tab bar, it will be moved.\n */\n insertTab(index: number, value: Title | Title.IOptions): Title {\n // Release the mouse before making any changes.\n this._releaseMouse();\n\n // Coerce the value to a title.\n let title = Private.asTitle(value);\n\n // Look up the index of the title.\n let i = this._titles.indexOf(title);\n\n // Clamp the insert index to the array bounds.\n let j = Math.max(0, Math.min(index, this._titles.length));\n\n // If the title is not in the array, insert it.\n if (i === -1) {\n // Insert the title into the array.\n ArrayExt.insert(this._titles, j, title);\n\n // Connect to the title changed signal.\n title.changed.connect(this._onTitleChanged, this);\n\n // Schedule an update of the tabs.\n this.update();\n\n // Adjust the current index for the insert.\n this._adjustCurrentForInsert(j, title);\n\n // Return the title added to the tab bar.\n return title;\n }\n\n // Otherwise, the title exists in the array and should be moved.\n\n // Adjust the index if the location is at the end of the array.\n if (j === this._titles.length) {\n j--;\n }\n\n // Bail if there is no effective move.\n if (i === j) {\n return title;\n }\n\n // Move the title to the new location.\n ArrayExt.move(this._titles, i, j);\n\n // Schedule an update of the tabs.\n this.update();\n\n // Adjust the current index for the move.\n this._adjustCurrentForMove(i, j);\n\n // Return the title added to the tab bar.\n return title;\n }\n\n /**\n * Remove a tab from the tab bar.\n *\n * @param title - The title for the tab to remove.\n *\n * #### Notes\n * This is a no-op if the title is not in the tab bar.\n */\n removeTab(title: Title): void {\n this.removeTabAt(this._titles.indexOf(title));\n }\n\n /**\n * Remove the tab at a given index from the tab bar.\n *\n * @param index - The index of the tab to remove.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n removeTabAt(index: number): void {\n // Release the mouse before making any changes.\n this._releaseMouse();\n\n // Remove the title from the array.\n let title = ArrayExt.removeAt(this._titles, index);\n\n // Bail if the index is out of range.\n if (!title) {\n return;\n }\n\n // Disconnect from the title changed signal.\n title.changed.disconnect(this._onTitleChanged, this);\n\n // Clear the previous title if it's being removed.\n if (title === this._previousTitle) {\n this._previousTitle = null;\n }\n\n // Schedule an update of the tabs.\n this.update();\n\n // Adjust the current index for the remove.\n this._adjustCurrentForRemove(index, title);\n }\n\n /**\n * Remove all tabs from the tab bar.\n */\n clearTabs(): void {\n // Bail if there is nothing to remove.\n if (this._titles.length === 0) {\n return;\n }\n\n // Release the mouse before making any changes.\n this._releaseMouse();\n\n // Disconnect from the title changed signals.\n for (let title of this._titles) {\n title.changed.disconnect(this._onTitleChanged, this);\n }\n\n // Get the current index and title.\n let pi = this.currentIndex;\n let pt = this.currentTitle;\n\n // Reset the current index and previous title.\n this._currentIndex = -1;\n this._previousTitle = null;\n\n // Clear the title array.\n this._titles.length = 0;\n\n // Schedule an update of the tabs.\n this.update();\n\n // If no tab was selected, there's nothing else to do.\n if (pi === -1) {\n return;\n }\n\n // Emit the current changed signal.\n this._currentChanged.emit({\n previousIndex: pi,\n previousTitle: pt,\n currentIndex: -1,\n currentTitle: null\n });\n }\n\n /**\n * Release the mouse and restore the non-dragged tab positions.\n *\n * #### Notes\n * This will cause the tab bar to stop handling mouse events and to\n * restore the tabs to their non-dragged positions.\n */\n releaseMouse(): void {\n this._releaseMouse();\n }\n\n /**\n * Handle the DOM events for the tab bar.\n *\n * @param event - The DOM event sent to the tab bar.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the tab bar's DOM node.\n *\n * This should not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'pointerdown':\n this._evtPointerDown(event as PointerEvent);\n break;\n case 'pointermove':\n this._evtPointerMove(event as PointerEvent);\n break;\n case 'pointerup':\n this._evtPointerUp(event as PointerEvent);\n break;\n case 'dblclick':\n this._evtDblClick(event as MouseEvent);\n break;\n case 'keydown':\n event.eventPhase === Event.CAPTURING_PHASE\n ? this._evtKeyDownCapturing(event as KeyboardEvent)\n : this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('pointerdown', this);\n this.node.addEventListener('dblclick', this);\n this.node.addEventListener('keydown', this);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('pointerdown', this);\n this.node.removeEventListener('dblclick', this);\n this.node.removeEventListener('keydown', this);\n this._releaseMouse();\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n let titles = this._titles;\n let renderer = this.renderer;\n let currentTitle = this.currentTitle;\n let content = new Array(titles.length);\n // Keep the tabindex=\"0\" attribute to the tab which handled it before the update.\n // If the add button handles it, no need to do anything. If no element of the tab\n // bar handles it, set it on the current or the first tab to ensure one element\n // handles it after update.\n const tabHandlingTabindex =\n this._getCurrentTabindex() ??\n (this._currentIndex > -1 ? this._currentIndex : 0);\n\n for (let i = 0, n = titles.length; i < n; ++i) {\n let title = titles[i];\n let current = title === currentTitle;\n let zIndex = current ? n : n - i - 1;\n let tabIndex = tabHandlingTabindex === i ? 0 : -1;\n content[i] = renderer.renderTab({ title, current, zIndex, tabIndex });\n }\n VirtualDOM.render(content, this.contentNode);\n }\n\n /**\n * Get the index of the tab which handles tabindex=\"0\".\n * If the add button handles tabindex=\"0\", -1 is returned.\n * If none of the previous handles tabindex=\"0\", null is returned.\n */\n private _getCurrentTabindex(): number | null {\n let index = null;\n const elemTabindex = this.contentNode.querySelector('li[tabindex=\"0\"]');\n if (elemTabindex) {\n index = [...this.contentNode.children].indexOf(elemTabindex);\n } else if (\n this._addButtonEnabled &&\n this.addButtonNode.getAttribute('tabindex') === '0'\n ) {\n index = -1;\n }\n return index;\n }\n\n /**\n * Handle the `'dblclick'` event for the tab bar.\n */\n private _evtDblClick(event: MouseEvent): void {\n // Do nothing if titles are not editable\n if (!this.titlesEditable) {\n return;\n }\n\n let tabs = this.contentNode.children;\n\n // Find the index of the targeted tab.\n let index = ArrayExt.findFirstIndex(tabs, tab => {\n return ElementExt.hitTest(tab, event.clientX, event.clientY);\n });\n\n // Do nothing if the press is not on a tab.\n if (index === -1) {\n return;\n }\n\n let title = this.titles[index];\n let label = tabs[index].querySelector('.lm-TabBar-tabLabel') as HTMLElement;\n if (label && label.contains(event.target as HTMLElement)) {\n let value = title.label || '';\n\n // Clear the label element\n let oldValue = label.innerHTML;\n label.innerHTML = '';\n\n let input = document.createElement('input');\n input.classList.add('lm-TabBar-tabInput');\n input.value = value;\n label.appendChild(input);\n\n let onblur = () => {\n input.removeEventListener('blur', onblur);\n label.innerHTML = oldValue;\n this.node.addEventListener('keydown', this);\n };\n\n input.addEventListener('dblclick', (event: Event) =>\n event.stopPropagation()\n );\n input.addEventListener('blur', onblur);\n input.addEventListener('keydown', (event: KeyboardEvent) => {\n if (event.key === 'Enter') {\n if (input.value !== '') {\n title.label = title.caption = input.value;\n }\n onblur();\n } else if (event.key === 'Escape') {\n onblur();\n }\n });\n this.node.removeEventListener('keydown', this);\n input.select();\n input.focus();\n\n if (label.children.length > 0) {\n (label.children[0] as HTMLElement).focus();\n }\n }\n }\n\n /**\n * Handle the `'keydown'` event for the tab bar at capturing phase.\n */\n private _evtKeyDownCapturing(event: KeyboardEvent): void {\n if (event.eventPhase !== Event.CAPTURING_PHASE) {\n return;\n }\n\n // Stop all input events during drag.\n event.preventDefault();\n event.stopPropagation();\n\n // Release the mouse if `Escape` is pressed.\n if (event.key === 'Escape') {\n this._releaseMouse();\n }\n }\n\n /**\n * Handle the `'keydown'` event for the tab bar at target phase.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // Allow for navigation using tab key\n if (event.key === 'Tab' || event.eventPhase === Event.CAPTURING_PHASE) {\n return;\n }\n\n // Check if Enter or Spacebar key has been pressed and open that tab\n if (\n event.key === 'Enter' ||\n event.key === 'Spacebar' ||\n event.key === ' '\n ) {\n // Get focus element that is in focus by the tab key\n const focusedElement = document.activeElement;\n\n // Test first if the focus is on the add button node\n if (\n this.addButtonEnabled &&\n this.addButtonNode.contains(focusedElement)\n ) {\n event.preventDefault();\n event.stopPropagation();\n this._addRequested.emit();\n } else {\n const index = ArrayExt.findFirstIndex(this.contentNode.children, tab =>\n tab.contains(focusedElement)\n );\n if (index >= 0) {\n event.preventDefault();\n event.stopPropagation();\n this.currentIndex = index;\n }\n }\n // Handle the arrow keys to switch tabs.\n } else if (ARROW_KEYS.includes(event.key)) {\n // Create a list of all focusable elements in the tab bar.\n const focusable: Element[] = [...this.contentNode.children];\n if (this.addButtonEnabled) {\n focusable.push(this.addButtonNode);\n }\n // If the tab bar contains only one element, nothing to do.\n if (focusable.length <= 1) {\n return;\n }\n event.preventDefault();\n event.stopPropagation();\n\n // Get the current focused element.\n let focusedIndex = focusable.indexOf(document.activeElement as Element);\n if (focusedIndex === -1) {\n focusedIndex = this._currentIndex;\n }\n\n // Find the next element to focus on.\n let nextFocused: Element | null | undefined;\n if (\n (event.key === 'ArrowRight' && this._orientation === 'horizontal') ||\n (event.key === 'ArrowDown' && this._orientation === 'vertical')\n ) {\n nextFocused = focusable[focusedIndex + 1] ?? focusable[0];\n } else if (\n (event.key === 'ArrowLeft' && this._orientation === 'horizontal') ||\n (event.key === 'ArrowUp' && this._orientation === 'vertical')\n ) {\n nextFocused =\n focusable[focusedIndex - 1] ?? focusable[focusable.length - 1];\n } else if (event.key === 'Home') {\n nextFocused = focusable[0];\n } else if (event.key === 'End') {\n nextFocused = focusable[focusable.length - 1];\n }\n\n // Change the focused element and the tabindex value.\n if (nextFocused) {\n focusable[focusedIndex]?.setAttribute('tabindex', '-1');\n nextFocused?.setAttribute('tabindex', '0');\n (nextFocused as HTMLElement).focus();\n }\n }\n }\n\n /**\n * Handle the `'pointerdown'` event for the tab bar.\n */\n private _evtPointerDown(event: PointerEvent | MouseEvent): void {\n // Do nothing if it's not a left or middle mouse press.\n if (event.button !== 0 && event.button !== 1) {\n return;\n }\n\n // Do nothing if a drag is in progress.\n if (this._dragData) {\n return;\n }\n\n // Do nothing if a title editable input was clicked.\n if (\n (event.target as HTMLElement).classList.contains('lm-TabBar-tabInput')\n ) {\n return;\n }\n\n // Check if the add button was clicked.\n let addButtonClicked =\n this.addButtonEnabled &&\n this.addButtonNode.contains(event.target as HTMLElement);\n\n // Lookup the tab nodes.\n let tabs = this.contentNode.children;\n\n // Find the index of the pressed tab.\n let index = ArrayExt.findFirstIndex(tabs, tab => {\n return ElementExt.hitTest(tab, event.clientX, event.clientY);\n });\n\n // Do nothing if the press is not on a tab or the add button.\n if (index === -1 && !addButtonClicked) {\n return;\n }\n\n // Pressing on a tab stops the event propagation.\n event.preventDefault();\n event.stopPropagation();\n\n // Initialize the non-measured parts of the drag data.\n this._dragData = {\n tab: tabs[index] as HTMLElement,\n index: index,\n pressX: event.clientX,\n pressY: event.clientY,\n tabPos: -1,\n tabSize: -1,\n tabPressPos: -1,\n targetIndex: -1,\n tabLayout: null,\n contentRect: null,\n override: null,\n dragActive: false,\n dragAborted: false,\n detachRequested: false\n };\n\n // Add the document pointer up listener.\n this.document.addEventListener('pointerup', this, true);\n\n // Do nothing else if the middle button or add button is clicked.\n if (event.button === 1 || addButtonClicked) {\n return;\n }\n\n // Do nothing else if the close icon is clicked.\n let icon = tabs[index].querySelector(this.renderer.closeIconSelector);\n if (icon && icon.contains(event.target as HTMLElement)) {\n return;\n }\n\n // Add the extra listeners if the tabs are movable.\n if (this.tabsMovable) {\n this.document.addEventListener('pointermove', this, true);\n this.document.addEventListener('keydown', this, true);\n this.document.addEventListener('contextmenu', this, true);\n }\n\n // Update the current index as appropriate.\n if (this.allowDeselect && this.currentIndex === index) {\n this.currentIndex = -1;\n } else {\n this.currentIndex = index;\n }\n\n // Do nothing else if there is no current tab.\n if (this.currentIndex === -1) {\n return;\n }\n\n // Emit the tab activate request signal.\n this._tabActivateRequested.emit({\n index: this.currentIndex,\n title: this.currentTitle!\n });\n }\n\n /**\n * Handle the `'pointermove'` event for the tab bar.\n */\n private _evtPointerMove(event: PointerEvent | MouseEvent): void {\n // Do nothing if no drag is in progress.\n let data = this._dragData;\n if (!data) {\n return;\n }\n\n // Suppress the event during a drag.\n event.preventDefault();\n event.stopPropagation();\n\n // Lookup the tab nodes.\n let tabs = this.contentNode.children;\n\n // Bail early if the drag threshold has not been met.\n if (!data.dragActive && !Private.dragExceeded(data, event)) {\n return;\n }\n\n // Activate the drag if necessary.\n if (!data.dragActive) {\n // Fill in the rest of the drag data measurements.\n let tabRect = data.tab.getBoundingClientRect();\n if (this._orientation === 'horizontal') {\n data.tabPos = data.tab.offsetLeft;\n data.tabSize = tabRect.width;\n data.tabPressPos = data.pressX - tabRect.left;\n } else {\n data.tabPos = data.tab.offsetTop;\n data.tabSize = tabRect.height;\n data.tabPressPos = data.pressY - tabRect.top;\n }\n data.tabPressOffset = {\n x: data.pressX - tabRect.left,\n y: data.pressY - tabRect.top\n };\n data.tabLayout = Private.snapTabLayout(tabs, this._orientation);\n data.contentRect = this.contentNode.getBoundingClientRect();\n data.override = Drag.overrideCursor('default');\n\n // Add the dragging style classes.\n data.tab.classList.add('lm-mod-dragging');\n this.addClass('lm-mod-dragging');\n\n // Mark the drag as active.\n data.dragActive = true;\n }\n\n // Emit the detach requested signal if the threshold is exceeded.\n if (!data.detachRequested && Private.detachExceeded(data, event)) {\n // Only emit the signal once per drag cycle.\n data.detachRequested = true;\n\n // Setup the arguments for the signal.\n let index = data.index;\n let clientX = event.clientX;\n let clientY = event.clientY;\n let tab = tabs[index] as HTMLElement;\n let title = this._titles[index];\n\n // Emit the tab detach requested signal.\n this._tabDetachRequested.emit({\n index,\n title,\n tab,\n clientX,\n clientY,\n offset: data.tabPressOffset\n });\n\n // Bail if the signal handler aborted the drag.\n if (data.dragAborted) {\n return;\n }\n }\n\n // Update the positions of the tabs.\n Private.layoutTabs(tabs, data, event, this._orientation);\n }\n\n /**\n * Handle the `'pointerup'` event for the document.\n */\n private _evtPointerUp(event: PointerEvent | MouseEvent): void {\n // Do nothing if it's not a left or middle mouse release.\n if (event.button !== 0 && event.button !== 1) {\n return;\n }\n\n // Do nothing if no drag is in progress.\n const data = this._dragData;\n if (!data) {\n return;\n }\n\n // Stop the event propagation.\n event.preventDefault();\n event.stopPropagation();\n\n // Remove the extra mouse event listeners.\n this.document.removeEventListener('pointermove', this, true);\n this.document.removeEventListener('pointerup', this, true);\n this.document.removeEventListener('keydown', this, true);\n this.document.removeEventListener('contextmenu', this, true);\n\n // Handle a release when the drag is not active.\n if (!data.dragActive) {\n // Clear the drag data.\n this._dragData = null;\n\n // Handle clicking the add button.\n let addButtonClicked =\n this.addButtonEnabled &&\n this.addButtonNode.contains(event.target as HTMLElement);\n if (addButtonClicked) {\n this._addRequested.emit(undefined);\n return;\n }\n\n // Lookup the tab nodes.\n let tabs = this.contentNode.children;\n\n // Find the index of the released tab.\n let index = ArrayExt.findFirstIndex(tabs, tab => {\n return ElementExt.hitTest(tab, event.clientX, event.clientY);\n });\n\n // Do nothing if the release is not on the original pressed tab.\n if (index !== data.index) {\n return;\n }\n\n // Ignore the release if the title is not closable.\n let title = this._titles[index];\n if (!title.closable) {\n return;\n }\n\n // Emit the close requested signal if the middle button is released.\n if (event.button === 1) {\n this._tabCloseRequested.emit({ index, title });\n return;\n }\n\n // Emit the close requested signal if the close icon was released.\n let icon = tabs[index].querySelector(this.renderer.closeIconSelector);\n if (icon && icon.contains(event.target as HTMLElement)) {\n this._tabCloseRequested.emit({ index, title });\n return;\n }\n\n // Otherwise, there is nothing left to do.\n return;\n }\n\n // Do nothing if the left button is not released.\n if (event.button !== 0) {\n return;\n }\n\n // Position the tab at its final resting position.\n Private.finalizeTabPosition(data, this._orientation);\n\n // Remove the dragging class from the tab so it can be transitioned.\n data.tab.classList.remove('lm-mod-dragging');\n\n // Parse the transition duration for releasing the tab.\n let duration = Private.parseTransitionDuration(data.tab);\n\n // Complete the release on a timer to allow the tab to transition.\n setTimeout(() => {\n // Do nothing if the drag has been aborted.\n if (data.dragAborted) {\n return;\n }\n\n // Clear the drag data reference.\n this._dragData = null;\n\n // Reset the positions of the tabs.\n Private.resetTabPositions(this.contentNode.children, this._orientation);\n\n // Clear the cursor grab.\n data.override!.dispose();\n\n // Remove the remaining dragging style.\n this.removeClass('lm-mod-dragging');\n\n // If the tab was not moved, there is nothing else to do.\n let i = data.index;\n let j = data.targetIndex;\n if (j === -1 || i === j) {\n return;\n }\n\n // Move the title to the new locations.\n ArrayExt.move(this._titles, i, j);\n\n // Adjust the current index for the move.\n this._adjustCurrentForMove(i, j);\n\n // Emit the tab moved signal.\n this._tabMoved.emit({\n fromIndex: i,\n toIndex: j,\n title: this._titles[j]\n });\n\n // Update the tabs immediately to prevent flicker.\n MessageLoop.sendMessage(this, Widget.Msg.UpdateRequest);\n }, duration);\n }\n\n /**\n * Release the mouse and restore the non-dragged tab positions.\n */\n private _releaseMouse(): void {\n // Do nothing if no drag is in progress.\n let data = this._dragData;\n if (!data) {\n return;\n }\n\n // Clear the drag data reference.\n this._dragData = null;\n\n // Remove the extra document event listeners.\n this.document.removeEventListener('pointermove', this, true);\n this.document.removeEventListener('pointerup', this, true);\n this.document.removeEventListener('keydown', this, true);\n this.document.removeEventListener('contextmenu', this, true);\n\n // Indicate the drag has been aborted. This allows the mouse\n // event handlers to return early when the drag is canceled.\n data.dragAborted = true;\n\n // If the drag is not active, there's nothing more to do.\n if (!data.dragActive) {\n return;\n }\n\n // Reset the tabs to their non-dragged positions.\n Private.resetTabPositions(this.contentNode.children, this._orientation);\n\n // Clear the cursor override.\n data.override!.dispose();\n\n // Clear the dragging style classes.\n data.tab.classList.remove('lm-mod-dragging');\n this.removeClass('lm-mod-dragging');\n }\n\n /**\n * Adjust the current index for a tab insert operation.\n *\n * This method accounts for the tab bar's insertion behavior when\n * adjusting the current index and emitting the changed signal.\n */\n private _adjustCurrentForInsert(i: number, title: Title): void {\n // Lookup commonly used variables.\n let ct = this.currentTitle;\n let ci = this._currentIndex;\n let bh = this.insertBehavior;\n\n // TODO: do we need to do an update to update the aria-selected attribute?\n\n // Handle the behavior where the new tab is always selected,\n // or the behavior where the new tab is selected if needed.\n if (bh === 'select-tab' || (bh === 'select-tab-if-needed' && ci === -1)) {\n this._currentIndex = i;\n this._previousTitle = ct;\n this._currentChanged.emit({\n previousIndex: ci,\n previousTitle: ct,\n currentIndex: i,\n currentTitle: title\n });\n return;\n }\n\n // Otherwise, silently adjust the current index if needed.\n if (ci >= i) {\n this._currentIndex++;\n }\n }\n\n /**\n * Adjust the current index for a tab move operation.\n *\n * This method will not cause the actual current tab to change.\n * It silently adjusts the index to account for the given move.\n */\n private _adjustCurrentForMove(i: number, j: number): void {\n if (this._currentIndex === i) {\n this._currentIndex = j;\n } else if (this._currentIndex < i && this._currentIndex >= j) {\n this._currentIndex++;\n } else if (this._currentIndex > i && this._currentIndex <= j) {\n this._currentIndex--;\n }\n }\n\n /**\n * Adjust the current index for a tab remove operation.\n *\n * This method accounts for the tab bar's remove behavior when\n * adjusting the current index and emitting the changed signal.\n */\n private _adjustCurrentForRemove(i: number, title: Title): void {\n // Lookup commonly used variables.\n let ci = this._currentIndex;\n let bh = this.removeBehavior;\n\n // Silently adjust the index if the current tab is not removed.\n if (ci !== i) {\n if (ci > i) {\n this._currentIndex--;\n }\n return;\n }\n\n // TODO: do we need to do an update to adjust the aria-selected value?\n\n // No tab gets selected if the tab bar is empty.\n if (this._titles.length === 0) {\n this._currentIndex = -1;\n this._currentChanged.emit({\n previousIndex: i,\n previousTitle: title,\n currentIndex: -1,\n currentTitle: null\n });\n return;\n }\n\n // Handle behavior where the next sibling tab is selected.\n if (bh === 'select-tab-after') {\n this._currentIndex = Math.min(i, this._titles.length - 1);\n this._currentChanged.emit({\n previousIndex: i,\n previousTitle: title,\n currentIndex: this._currentIndex,\n currentTitle: this.currentTitle\n });\n return;\n }\n\n // Handle behavior where the previous sibling tab is selected.\n if (bh === 'select-tab-before') {\n this._currentIndex = Math.max(0, i - 1);\n this._currentChanged.emit({\n previousIndex: i,\n previousTitle: title,\n currentIndex: this._currentIndex,\n currentTitle: this.currentTitle\n });\n return;\n }\n\n // Handle behavior where the previous history tab is selected.\n if (bh === 'select-previous-tab') {\n if (this._previousTitle) {\n this._currentIndex = this._titles.indexOf(this._previousTitle);\n this._previousTitle = null;\n } else {\n this._currentIndex = Math.min(i, this._titles.length - 1);\n }\n this._currentChanged.emit({\n previousIndex: i,\n previousTitle: title,\n currentIndex: this._currentIndex,\n currentTitle: this.currentTitle\n });\n return;\n }\n\n // Otherwise, no tab gets selected.\n this._currentIndex = -1;\n this._currentChanged.emit({\n previousIndex: i,\n previousTitle: title,\n currentIndex: -1,\n currentTitle: null\n });\n }\n\n /**\n * Handle the `changed` signal of a title object.\n */\n private _onTitleChanged(sender: Title): void {\n this.update();\n }\n\n private _name: string;\n private _currentIndex = -1;\n private _titles: Title[] = [];\n private _orientation: TabBar.Orientation;\n private _document: Document | ShadowRoot;\n private _titlesEditable: boolean = false;\n private _previousTitle: Title | null = null;\n private _dragData: Private.IDragData | null = null;\n private _addButtonEnabled: boolean = false;\n private _tabMoved = new Signal>(this);\n private _currentChanged = new Signal>(\n this\n );\n private _addRequested = new Signal(this);\n private _tabCloseRequested = new Signal<\n this,\n TabBar.ITabCloseRequestedArgs\n >(this);\n private _tabDetachRequested = new Signal<\n this,\n TabBar.ITabDetachRequestedArgs\n >(this);\n private _tabActivateRequested = new Signal<\n this,\n TabBar.ITabActivateRequestedArgs\n >(this);\n}\n\n/**\n * The namespace for the `TabBar` class statics.\n */\nexport namespace TabBar {\n /**\n * A type alias for a tab bar orientation.\n */\n export type Orientation =\n | /**\n * The tabs are arranged in a single row, left-to-right.\n *\n * The tab text orientation is horizontal.\n */\n 'horizontal'\n\n /**\n * The tabs are arranged in a single column, top-to-bottom.\n *\n * The tab text orientation is horizontal.\n */\n | 'vertical';\n\n /**\n * A type alias for the selection behavior on tab insert.\n */\n export type InsertBehavior =\n | /**\n * The selected tab will not be changed.\n */\n 'none'\n\n /**\n * The inserted tab will be selected.\n */\n | 'select-tab'\n\n /**\n * The inserted tab will be selected if the current tab is null.\n */\n | 'select-tab-if-needed';\n\n /**\n * A type alias for the selection behavior on tab remove.\n */\n export type RemoveBehavior =\n | /**\n * No tab will be selected.\n */\n 'none'\n\n /**\n * The tab after the removed tab will be selected if possible.\n */\n | 'select-tab-after'\n\n /**\n * The tab before the removed tab will be selected if possible.\n */\n | 'select-tab-before'\n\n /**\n * The previously selected tab will be selected if possible.\n */\n | 'select-previous-tab';\n\n /**\n * An options object for creating a tab bar.\n */\n export interface IOptions {\n /**\n * The document to use with the tab bar.\n *\n * The default is the global `document` instance.\n */\n\n document?: Document | ShadowRoot;\n\n /**\n * Name of the tab bar.\n *\n * This is used for accessibility reasons. The default is the empty string.\n */\n name?: string;\n\n /**\n * The layout orientation of the tab bar.\n *\n * The default is `horizontal`.\n */\n orientation?: TabBar.Orientation;\n\n /**\n * Whether the tabs are movable by the user.\n *\n * The default is `false`.\n */\n tabsMovable?: boolean;\n\n /**\n * Whether a tab can be deselected by the user.\n *\n * The default is `false`.\n */\n allowDeselect?: boolean;\n\n /**\n * Whether the titles can be directly edited by the user.\n *\n * The default is `false`.\n */\n titlesEditable?: boolean;\n\n /**\n * Whether the add button is enabled.\n *\n * The default is `false`.\n */\n addButtonEnabled?: boolean;\n\n /**\n * The selection behavior when inserting a tab.\n *\n * The default is `'select-tab-if-needed'`.\n */\n insertBehavior?: TabBar.InsertBehavior;\n\n /**\n * The selection behavior when removing a tab.\n *\n * The default is `'select-tab-after'`.\n */\n removeBehavior?: TabBar.RemoveBehavior;\n\n /**\n * A renderer to use with the tab bar.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n }\n\n /**\n * The arguments object for the `currentChanged` signal.\n */\n export interface ICurrentChangedArgs {\n /**\n * The previously selected index.\n */\n readonly previousIndex: number;\n\n /**\n * The previously selected title.\n */\n readonly previousTitle: Title | null;\n\n /**\n * The currently selected index.\n */\n readonly currentIndex: number;\n\n /**\n * The currently selected title.\n */\n readonly currentTitle: Title | null;\n }\n\n /**\n * The arguments object for the `tabMoved` signal.\n */\n export interface ITabMovedArgs {\n /**\n * The previous index of the tab.\n */\n readonly fromIndex: number;\n\n /**\n * The current index of the tab.\n */\n readonly toIndex: number;\n\n /**\n * The title for the tab.\n */\n readonly title: Title;\n }\n\n /**\n * The arguments object for the `tabActivateRequested` signal.\n */\n export interface ITabActivateRequestedArgs {\n /**\n * The index of the tab to activate.\n */\n readonly index: number;\n\n /**\n * The title for the tab.\n */\n readonly title: Title;\n }\n\n /**\n * The arguments object for the `tabCloseRequested` signal.\n */\n export interface ITabCloseRequestedArgs {\n /**\n * The index of the tab to close.\n */\n readonly index: number;\n\n /**\n * The title for the tab.\n */\n readonly title: Title;\n }\n\n /**\n * The arguments object for the `tabDetachRequested` signal.\n */\n export interface ITabDetachRequestedArgs {\n /**\n * The index of the tab to detach.\n */\n readonly index: number;\n\n /**\n * The title for the tab.\n */\n readonly title: Title;\n\n /**\n * The node representing the tab.\n */\n readonly tab: HTMLElement;\n\n /**\n * The current client X position of the mouse.\n */\n readonly clientX: number;\n\n /**\n * The current client Y position of the mouse.\n */\n readonly clientY: number;\n\n /**\n * The mouse position in the tab coordinate.\n */\n readonly offset?: { x: number; y: number };\n }\n\n /**\n * An object which holds the data to render a tab.\n */\n export interface IRenderData {\n /**\n * The title associated with the tab.\n */\n readonly title: Title;\n\n /**\n * Whether the tab is the current tab.\n */\n readonly current: boolean;\n\n /**\n * The z-index for the tab.\n */\n readonly zIndex: number;\n\n /**\n * The tabindex value for the tab.\n */\n readonly tabIndex?: number;\n }\n\n /**\n * A renderer for use with a tab bar.\n */\n export interface IRenderer {\n /**\n * A selector which matches the close icon node in a tab.\n */\n readonly closeIconSelector: string;\n\n /**\n * Render the virtual element for a tab.\n *\n * @param data - The data to use for rendering the tab.\n *\n * @returns A virtual element representing the tab.\n */\n renderTab(data: IRenderData): VirtualElement;\n }\n\n /**\n * The default implementation of `IRenderer`.\n *\n * #### Notes\n * Subclasses are free to reimplement rendering methods as needed.\n */\n export class Renderer implements IRenderer {\n constructor() {\n this._uuid = ++Renderer._nInstance;\n }\n /**\n * A selector which matches the close icon node in a tab.\n */\n readonly closeIconSelector = '.lm-TabBar-tabCloseIcon';\n\n /**\n * Render the virtual element for a tab.\n *\n * @param data - The data to use for rendering the tab.\n *\n * @returns A virtual element representing the tab.\n */\n renderTab(data: IRenderData): VirtualElement {\n let title = data.title.caption;\n let key = this.createTabKey(data);\n let id = key;\n let style = this.createTabStyle(data);\n let className = this.createTabClass(data);\n let dataset = this.createTabDataset(data);\n let aria = this.createTabARIA(data);\n if (data.title.closable) {\n return h.li(\n { id, key, className, title, style, dataset, ...aria },\n this.renderIcon(data),\n this.renderLabel(data),\n this.renderCloseIcon(data)\n );\n } else {\n return h.li(\n { id, key, className, title, style, dataset, ...aria },\n this.renderIcon(data),\n this.renderLabel(data)\n );\n }\n }\n\n /**\n * Render the icon element for a tab.\n *\n * @param data - The data to use for rendering the tab.\n *\n * @returns A virtual element representing the tab icon.\n */\n renderIcon(data: IRenderData): VirtualElement {\n const { title } = data;\n let className = this.createIconClass(data);\n\n // If title.icon is undefined, it will be ignored.\n return h.div({ className }, title.icon!, title.iconLabel);\n }\n\n /**\n * Render the label element for a tab.\n *\n * @param data - The data to use for rendering the tab.\n *\n * @returns A virtual element representing the tab label.\n */\n renderLabel(data: IRenderData): VirtualElement {\n return h.div({ className: 'lm-TabBar-tabLabel' }, data.title.label);\n }\n\n /**\n * Render the close icon element for a tab.\n *\n * @param data - The data to use for rendering the tab.\n *\n * @returns A virtual element representing the tab close icon.\n */\n renderCloseIcon(data: IRenderData): VirtualElement {\n return h.div({ className: 'lm-TabBar-tabCloseIcon' });\n }\n\n /**\n * Create a unique render key for the tab.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The unique render key for the tab.\n *\n * #### Notes\n * This method caches the key against the tab title the first time\n * the key is generated. This enables efficient rendering of moved\n * tabs and avoids subtle hover style artifacts.\n */\n createTabKey(data: IRenderData): string {\n let key = this._tabKeys.get(data.title);\n if (key === undefined) {\n key = `tab-key-${this._uuid}-${this._tabID++}`;\n this._tabKeys.set(data.title, key);\n }\n return key;\n }\n\n /**\n * Create the inline style object for a tab.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The inline style data for the tab.\n */\n createTabStyle(data: IRenderData): ElementInlineStyle {\n return { zIndex: `${data.zIndex}` };\n }\n\n /**\n * Create the class name for the tab.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The full class name for the tab.\n */\n createTabClass(data: IRenderData): string {\n let name = 'lm-TabBar-tab';\n if (data.title.className) {\n name += ` ${data.title.className}`;\n }\n if (data.title.closable) {\n name += ' lm-mod-closable';\n }\n if (data.current) {\n name += ' lm-mod-current';\n }\n return name;\n }\n\n /**\n * Create the dataset for a tab.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The dataset for the tab.\n */\n createTabDataset(data: IRenderData): ElementDataset {\n return data.title.dataset;\n }\n\n /**\n * Create the ARIA attributes for a tab.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The ARIA attributes for the tab.\n */\n createTabARIA(data: IRenderData): ElementARIAAttrs | ElementBaseAttrs {\n return {\n role: 'tab',\n 'aria-selected': data.current.toString(),\n tabindex: `${data.tabIndex ?? '-1'}`\n };\n }\n\n /**\n * Create the class name for the tab icon.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The full class name for the tab icon.\n */\n createIconClass(data: IRenderData): string {\n let name = 'lm-TabBar-tabIcon';\n let extra = data.title.iconClass;\n return extra ? `${name} ${extra}` : name;\n }\n\n private static _nInstance = 0;\n private readonly _uuid: number;\n private _tabID = 0;\n private _tabKeys = new WeakMap, string>();\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n\n /**\n * A selector which matches the add button node in the tab bar.\n */\n export const addButtonSelector = '.lm-TabBar-addButton';\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The start drag distance threshold.\n */\n export const DRAG_THRESHOLD = 5;\n\n /**\n * The detach distance threshold.\n */\n export const DETACH_THRESHOLD = 20;\n\n /**\n * A struct which holds the drag data for a tab bar.\n */\n export interface IDragData {\n /**\n * The tab node being dragged.\n */\n tab: HTMLElement;\n\n /**\n * The index of the tab being dragged.\n */\n index: number;\n\n /**\n * The mouse press client X position.\n */\n pressX: number;\n\n /**\n * The mouse press client Y position.\n */\n pressY: number;\n\n /**\n * The offset left/top of the tab being dragged.\n *\n * This will be `-1` if the drag is not active.\n */\n tabPos: number;\n\n /**\n * The offset width/height of the tab being dragged.\n *\n * This will be `-1` if the drag is not active.\n */\n tabSize: number;\n\n /**\n * The original mouse X/Y position in tab coordinates.\n *\n * This will be `-1` if the drag is not active.\n */\n tabPressPos: number;\n\n /**\n * The original mouse position in tab coordinates.\n *\n * This is undefined if the drag is not active.\n */\n tabPressOffset?: { x: number; y: number };\n\n /**\n * The tab target index upon mouse release.\n *\n * This will be `-1` if the drag is not active.\n */\n targetIndex: number;\n\n /**\n * The array of tab layout objects snapped at drag start.\n *\n * This will be `null` if the drag is not active.\n */\n tabLayout: ITabLayout[] | null;\n\n /**\n * The bounding client rect of the tab bar content node.\n *\n * This will be `null` if the drag is not active.\n */\n contentRect: DOMRect | null;\n\n /**\n * The disposable to clean up the cursor override.\n *\n * This will be `null` if the drag is not active.\n */\n override: IDisposable | null;\n\n /**\n * Whether the drag is currently active.\n */\n dragActive: boolean;\n\n /**\n * Whether the drag has been aborted.\n */\n dragAborted: boolean;\n\n /**\n * Whether a detach request as been made.\n */\n detachRequested: boolean;\n }\n\n /**\n * An object which holds layout data for a tab.\n */\n export interface ITabLayout {\n /**\n * The left/top margin value for the tab.\n */\n margin: number;\n\n /**\n * The offset left/top position of the tab.\n */\n pos: number;\n\n /**\n * The offset width/height of the tab.\n */\n size: number;\n }\n\n /**\n * Create the DOM node for a tab bar.\n */\n export function createNode(): HTMLDivElement {\n let node = document.createElement('div');\n let content = document.createElement('ul');\n content.setAttribute('role', 'tablist');\n content.className = 'lm-TabBar-content';\n node.appendChild(content);\n\n let add = document.createElement('div');\n add.className = 'lm-TabBar-addButton lm-mod-hidden';\n add.setAttribute('tabindex', '-1');\n add.setAttribute('role', 'button');\n node.appendChild(add);\n return node;\n }\n\n /**\n * Coerce a title or options into a real title.\n */\n export function asTitle(value: Title | Title.IOptions): Title {\n return value instanceof Title ? value : new Title(value);\n }\n\n /**\n * Parse the transition duration for a tab node.\n */\n export function parseTransitionDuration(tab: HTMLElement): number {\n let style = window.getComputedStyle(tab);\n return 1000 * (parseFloat(style.transitionDuration!) || 0);\n }\n\n /**\n * Get a snapshot of the current tab layout values.\n */\n export function snapTabLayout(\n tabs: HTMLCollection,\n orientation: TabBar.Orientation\n ): ITabLayout[] {\n let layout = new Array(tabs.length);\n for (let i = 0, n = tabs.length; i < n; ++i) {\n let node = tabs[i] as HTMLElement;\n let style = window.getComputedStyle(node);\n if (orientation === 'horizontal') {\n layout[i] = {\n pos: node.offsetLeft,\n size: node.offsetWidth,\n margin: parseFloat(style.marginLeft!) || 0\n };\n } else {\n layout[i] = {\n pos: node.offsetTop,\n size: node.offsetHeight,\n margin: parseFloat(style.marginTop!) || 0\n };\n }\n }\n return layout;\n }\n\n /**\n * Test if the event exceeds the drag threshold.\n */\n export function dragExceeded(data: IDragData, event: MouseEvent): boolean {\n let dx = Math.abs(event.clientX - data.pressX);\n let dy = Math.abs(event.clientY - data.pressY);\n return dx >= DRAG_THRESHOLD || dy >= DRAG_THRESHOLD;\n }\n\n /**\n * Test if the event exceeds the drag detach threshold.\n */\n export function detachExceeded(data: IDragData, event: MouseEvent): boolean {\n let rect = data.contentRect!;\n return (\n event.clientX < rect.left - DETACH_THRESHOLD ||\n event.clientX >= rect.right + DETACH_THRESHOLD ||\n event.clientY < rect.top - DETACH_THRESHOLD ||\n event.clientY >= rect.bottom + DETACH_THRESHOLD\n );\n }\n\n /**\n * Update the relative tab positions and computed target index.\n */\n export function layoutTabs(\n tabs: HTMLCollection,\n data: IDragData,\n event: MouseEvent,\n orientation: TabBar.Orientation\n ): void {\n // Compute the orientation-sensitive values.\n let pressPos: number;\n let localPos: number;\n let clientPos: number;\n let clientSize: number;\n if (orientation === 'horizontal') {\n pressPos = data.pressX;\n localPos = event.clientX - data.contentRect!.left;\n clientPos = event.clientX;\n clientSize = data.contentRect!.width;\n } else {\n pressPos = data.pressY;\n localPos = event.clientY - data.contentRect!.top;\n clientPos = event.clientY;\n clientSize = data.contentRect!.height;\n }\n\n // Compute the target data.\n let targetIndex = data.index;\n let targetPos = localPos - data.tabPressPos;\n let targetEnd = targetPos + data.tabSize;\n\n // Update the relative tab positions.\n for (let i = 0, n = tabs.length; i < n; ++i) {\n let pxPos: string;\n let layout = data.tabLayout![i];\n let threshold = layout.pos + (layout.size >> 1);\n if (i < data.index && targetPos < threshold) {\n pxPos = `${data.tabSize + data.tabLayout![i + 1].margin}px`;\n targetIndex = Math.min(targetIndex, i);\n } else if (i > data.index && targetEnd > threshold) {\n pxPos = `${-data.tabSize - layout.margin}px`;\n targetIndex = Math.max(targetIndex, i);\n } else if (i === data.index) {\n let ideal = clientPos - pressPos;\n let limit = clientSize - (data.tabPos + data.tabSize);\n pxPos = `${Math.max(-data.tabPos, Math.min(ideal, limit))}px`;\n } else {\n pxPos = '';\n }\n if (orientation === 'horizontal') {\n (tabs[i] as HTMLElement).style.left = pxPos;\n } else {\n (tabs[i] as HTMLElement).style.top = pxPos;\n }\n }\n\n // Update the computed target index.\n data.targetIndex = targetIndex;\n }\n\n /**\n * Position the drag tab at its final resting relative position.\n */\n export function finalizeTabPosition(\n data: IDragData,\n orientation: TabBar.Orientation\n ): void {\n // Compute the orientation-sensitive client size.\n let clientSize: number;\n if (orientation === 'horizontal') {\n clientSize = data.contentRect!.width;\n } else {\n clientSize = data.contentRect!.height;\n }\n\n // Compute the ideal final tab position.\n let ideal: number;\n if (data.targetIndex === data.index) {\n ideal = 0;\n } else if (data.targetIndex > data.index) {\n let tgt = data.tabLayout![data.targetIndex];\n ideal = tgt.pos + tgt.size - data.tabSize - data.tabPos;\n } else {\n let tgt = data.tabLayout![data.targetIndex];\n ideal = tgt.pos - data.tabPos;\n }\n\n // Compute the tab position limit.\n let limit = clientSize - (data.tabPos + data.tabSize);\n let final = Math.max(-data.tabPos, Math.min(ideal, limit));\n\n // Set the final orientation-sensitive position.\n if (orientation === 'horizontal') {\n data.tab.style.left = `${final}px`;\n } else {\n data.tab.style.top = `${final}px`;\n }\n }\n\n /**\n * Reset the relative positions of the given tabs.\n */\n export function resetTabPositions(\n tabs: HTMLCollection,\n orientation: TabBar.Orientation\n ): void {\n for (const tab of tabs) {\n if (orientation === 'horizontal') {\n (tab as HTMLElement).style.left = '';\n } else {\n (tab as HTMLElement).style.top = '';\n }\n }\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt, empty } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { BoxEngine, BoxSizer } from './boxengine';\n\nimport { Layout, LayoutItem } from './layout';\n\nimport { TabBar } from './tabbar';\n\nimport Utils from './utils';\n\nimport { Widget } from './widget';\n\n/**\n * A layout which provides a flexible docking arrangement.\n *\n * #### Notes\n * The consumer of this layout is responsible for handling all signals\n * from the generated tab bars and managing the visibility of widgets\n * and tab bars as needed.\n */\nexport class DockLayout extends Layout {\n /**\n * Construct a new dock layout.\n *\n * @param options - The options for initializing the layout.\n */\n constructor(options: DockLayout.IOptions) {\n super();\n this.renderer = options.renderer;\n if (options.spacing !== undefined) {\n this._spacing = Utils.clampDimension(options.spacing);\n }\n this._document = options.document || document;\n this._hiddenMode =\n options.hiddenMode !== undefined\n ? options.hiddenMode\n : Widget.HiddenMode.Display;\n }\n\n /**\n * Dispose of the resources held by the layout.\n *\n * #### Notes\n * This will clear and dispose all widgets in the layout.\n */\n dispose(): void {\n // Get an iterator over the widgets in the layout.\n let widgets = this[Symbol.iterator]();\n\n // Dispose of the layout items.\n this._items.forEach(item => {\n item.dispose();\n });\n\n // Clear the layout state before disposing the widgets.\n this._box = null;\n this._root = null;\n this._items.clear();\n\n // Dispose of the widgets contained in the old layout root.\n for (const widget of widgets) {\n widget.dispose();\n }\n\n // Dispose of the base class.\n super.dispose();\n }\n\n /**\n * The renderer used by the dock layout.\n */\n readonly renderer: DockLayout.IRenderer;\n\n /**\n * The method for hiding child widgets.\n *\n * #### Notes\n * If there is only one child widget, `Display` hiding mode will be used\n * regardless of this setting.\n */\n get hiddenMode(): Widget.HiddenMode {\n return this._hiddenMode;\n }\n set hiddenMode(v: Widget.HiddenMode) {\n if (this._hiddenMode === v) {\n return;\n }\n this._hiddenMode = v;\n for (const bar of this.tabBars()) {\n if (bar.titles.length > 1) {\n for (const title of bar.titles) {\n title.owner.hiddenMode = this._hiddenMode;\n }\n }\n }\n }\n\n /**\n * Get the inter-element spacing for the dock layout.\n */\n get spacing(): number {\n return this._spacing;\n }\n\n /**\n * Set the inter-element spacing for the dock layout.\n */\n set spacing(value: number) {\n value = Utils.clampDimension(value);\n if (this._spacing === value) {\n return;\n }\n this._spacing = value;\n if (!this.parent) {\n return;\n }\n this.parent.fit();\n }\n\n /**\n * Whether the dock layout is empty.\n */\n get isEmpty(): boolean {\n return this._root === null;\n }\n\n /**\n * Create an iterator over all widgets in the layout.\n *\n * @returns A new iterator over the widgets in the layout.\n *\n * #### Notes\n * This iterator includes the generated tab bars.\n */\n [Symbol.iterator](): IterableIterator {\n return this._root ? this._root.iterAllWidgets() : empty();\n }\n\n /**\n * Create an iterator over the user widgets in the layout.\n *\n * @returns A new iterator over the user widgets in the layout.\n *\n * #### Notes\n * This iterator does not include the generated tab bars.\n */\n widgets(): IterableIterator {\n return this._root ? this._root.iterUserWidgets() : empty();\n }\n\n /**\n * Create an iterator over the selected widgets in the layout.\n *\n * @returns A new iterator over the selected user widgets.\n *\n * #### Notes\n * This iterator yields the widgets corresponding to the current tab\n * of each tab bar in the layout.\n */\n selectedWidgets(): IterableIterator {\n return this._root ? this._root.iterSelectedWidgets() : empty();\n }\n\n /**\n * Create an iterator over the tab bars in the layout.\n *\n * @returns A new iterator over the tab bars in the layout.\n *\n * #### Notes\n * This iterator does not include the user widgets.\n */\n tabBars(): IterableIterator> {\n return this._root ? this._root.iterTabBars() : empty();\n }\n\n /**\n * Create an iterator over the handles in the layout.\n *\n * @returns A new iterator over the handles in the layout.\n */\n handles(): IterableIterator {\n return this._root ? this._root.iterHandles() : empty();\n }\n\n /**\n * Move a handle to the given offset position.\n *\n * @param handle - The handle to move.\n *\n * @param offsetX - The desired offset X position of the handle.\n *\n * @param offsetY - The desired offset Y position of the handle.\n *\n * #### Notes\n * If the given handle is not contained in the layout, this is no-op.\n *\n * The handle will be moved as close as possible to the desired\n * position without violating any of the layout constraints.\n *\n * Only one of the coordinates is used depending on the orientation\n * of the handle. This method accepts both coordinates to make it\n * easy to invoke from a mouse move event without needing to know\n * the handle orientation.\n */\n moveHandle(handle: HTMLDivElement, offsetX: number, offsetY: number): void {\n // Bail early if there is no root or if the handle is hidden.\n let hidden = handle.classList.contains('lm-mod-hidden');\n if (!this._root || hidden) {\n return;\n }\n\n // Lookup the split node for the handle.\n let data = this._root.findSplitNode(handle);\n if (!data) {\n return;\n }\n\n // Compute the desired delta movement for the handle.\n let delta: number;\n if (data.node.orientation === 'horizontal') {\n delta = offsetX - handle.offsetLeft;\n } else {\n delta = offsetY - handle.offsetTop;\n }\n\n // Bail if there is no handle movement.\n if (delta === 0) {\n return;\n }\n\n // Prevent sibling resizing unless needed.\n data.node.holdSizes();\n\n // Adjust the sizers to reflect the handle movement.\n BoxEngine.adjust(data.node.sizers, data.index, delta);\n\n // Update the layout of the widgets.\n if (this.parent) {\n this.parent.update();\n }\n }\n\n /**\n * Save the current configuration of the dock layout.\n *\n * @returns A new config object for the current layout state.\n *\n * #### Notes\n * The return value can be provided to the `restoreLayout` method\n * in order to restore the layout to its current configuration.\n */\n saveLayout(): DockLayout.ILayoutConfig {\n // Bail early if there is no root.\n if (!this._root) {\n return { main: null };\n }\n\n // Hold the current sizes in the layout tree.\n this._root.holdAllSizes();\n\n // Return the layout config.\n return { main: this._root.createConfig() };\n }\n\n /**\n * Restore the layout to a previously saved configuration.\n *\n * @param config - The layout configuration to restore.\n *\n * #### Notes\n * Widgets which currently belong to the layout but which are not\n * contained in the config will be unparented.\n */\n restoreLayout(config: DockLayout.ILayoutConfig): void {\n // Create the widget set for validating the config.\n let widgetSet = new Set();\n\n // Normalize the main area config and collect the widgets.\n let mainConfig: DockLayout.AreaConfig | null;\n if (config.main) {\n mainConfig = Private.normalizeAreaConfig(config.main, widgetSet);\n } else {\n mainConfig = null;\n }\n\n // Create iterators over the old content.\n let oldWidgets = this.widgets();\n let oldTabBars = this.tabBars();\n let oldHandles = this.handles();\n\n // Clear the root before removing the old content.\n this._root = null;\n\n // Unparent the old widgets which are not in the new config.\n for (const widget of oldWidgets) {\n if (!widgetSet.has(widget)) {\n widget.parent = null;\n }\n }\n\n // Dispose of the old tab bars.\n for (const tabBar of oldTabBars) {\n tabBar.dispose();\n }\n\n // Remove the old handles.\n for (const handle of oldHandles) {\n if (handle.parentNode) {\n handle.parentNode.removeChild(handle);\n }\n }\n\n // Reparent the new widgets to the current parent.\n for (const widget of widgetSet) {\n widget.parent = this.parent;\n }\n\n // Create the root node for the new config.\n if (mainConfig) {\n this._root = Private.realizeAreaConfig(\n mainConfig,\n {\n // Ignoring optional `document` argument as we must reuse `this._document`\n createTabBar: (document?: Document | ShadowRoot) =>\n this._createTabBar(),\n createHandle: () => this._createHandle()\n },\n this._document\n );\n } else {\n this._root = null;\n }\n\n // If there is no parent, there is nothing more to do.\n if (!this.parent) {\n return;\n }\n\n // Attach the new widgets to the parent.\n widgetSet.forEach(widget => {\n this.attachWidget(widget);\n });\n\n // Post a fit request to the parent.\n this.parent.fit();\n }\n\n /**\n * Add a widget to the dock layout.\n *\n * @param widget - The widget to add to the dock layout.\n *\n * @param options - The additional options for adding the widget.\n *\n * #### Notes\n * The widget will be moved if it is already contained in the layout.\n *\n * An error will be thrown if the reference widget is invalid.\n */\n addWidget(widget: Widget, options: DockLayout.IAddOptions = {}): void {\n // Parse the options.\n let ref = options.ref || null;\n let mode = options.mode || 'tab-after';\n\n // Find the tab node which holds the reference widget.\n let refNode: Private.TabLayoutNode | null = null;\n if (this._root && ref) {\n refNode = this._root.findTabNode(ref);\n }\n\n // Throw an error if the reference widget is invalid.\n if (ref && !refNode) {\n throw new Error('Reference widget is not in the layout.');\n }\n\n // Reparent the widget to the current layout parent.\n widget.parent = this.parent;\n\n // Insert the widget according to the insert mode.\n switch (mode) {\n case 'tab-after':\n this._insertTab(widget, ref, refNode, true);\n break;\n case 'tab-before':\n this._insertTab(widget, ref, refNode, false);\n break;\n case 'split-top':\n this._insertSplit(widget, ref, refNode, 'vertical', false);\n break;\n case 'split-left':\n this._insertSplit(widget, ref, refNode, 'horizontal', false);\n break;\n case 'split-right':\n this._insertSplit(widget, ref, refNode, 'horizontal', true);\n break;\n case 'split-bottom':\n this._insertSplit(widget, ref, refNode, 'vertical', true);\n break;\n case 'merge-top':\n this._insertSplit(widget, ref, refNode, 'vertical', false, true);\n break;\n case 'merge-left':\n this._insertSplit(widget, ref, refNode, 'horizontal', false, true);\n break;\n case 'merge-right':\n this._insertSplit(widget, ref, refNode, 'horizontal', true, true);\n break;\n case 'merge-bottom':\n this._insertSplit(widget, ref, refNode, 'vertical', true, true);\n break;\n }\n\n // Do nothing else if there is no parent widget.\n if (!this.parent) {\n return;\n }\n\n // Ensure the widget is attached to the parent widget.\n this.attachWidget(widget);\n\n // Post a fit request for the parent widget.\n this.parent.fit();\n }\n\n /**\n * Remove a widget from the layout.\n *\n * @param widget - The widget to remove from the layout.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method does *not* modify the widget's `parent`.\n */\n removeWidget(widget: Widget): void {\n // Remove the widget from its current layout location.\n this._removeWidget(widget);\n\n // Do nothing else if there is no parent widget.\n if (!this.parent) {\n return;\n }\n\n // Detach the widget from the parent widget.\n this.detachWidget(widget);\n\n // Post a fit request for the parent widget.\n this.parent.fit();\n }\n\n /**\n * Find the tab area which contains the given client position.\n *\n * @param clientX - The client X position of interest.\n *\n * @param clientY - The client Y position of interest.\n *\n * @returns The geometry of the tab area at the given position, or\n * `null` if there is no tab area at the given position.\n */\n hitTestTabAreas(\n clientX: number,\n clientY: number\n ): DockLayout.ITabAreaGeometry | null {\n // Bail early if hit testing cannot produce valid results.\n if (!this._root || !this.parent || !this.parent.isVisible) {\n return null;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent.node);\n }\n\n // Convert from client to local coordinates.\n let rect = this.parent.node.getBoundingClientRect();\n let x = clientX - rect.left - this._box.borderLeft;\n let y = clientY - rect.top - this._box.borderTop;\n\n // Find the tab layout node at the local position.\n let tabNode = this._root.hitTestTabNodes(x, y);\n\n // Bail if a tab layout node was not found.\n if (!tabNode) {\n return null;\n }\n\n // Extract the data from the tab node.\n let { tabBar, top, left, width, height } = tabNode;\n\n // Compute the right and bottom edges of the tab area.\n let borderWidth = this._box.borderLeft + this._box.borderRight;\n let borderHeight = this._box.borderTop + this._box.borderBottom;\n let right = rect.width - borderWidth - (left + width);\n let bottom = rect.height - borderHeight - (top + height);\n\n // Return the hit test results.\n return { tabBar, x, y, top, left, right, bottom, width, height };\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n // Perform superclass initialization.\n super.init();\n\n // Attach each widget to the parent.\n for (const widget of this) {\n this.attachWidget(widget);\n }\n\n // Attach each handle to the parent.\n for (const handle of this.handles()) {\n this.parent!.node.appendChild(handle);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * Attach the widget to the layout parent widget.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This is a no-op if the widget is already attached.\n */\n protected attachWidget(widget: Widget): void {\n // Do nothing if the widget is already attached.\n if (this.parent!.node === widget.node.parentNode) {\n return;\n }\n\n // Create the layout item for the widget.\n this._items.set(widget, new LayoutItem(widget));\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget's node to the parent.\n this.parent!.node.appendChild(widget.node);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n }\n\n /**\n * Detach the widget from the layout parent widget.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This is a no-op if the widget is not attached.\n */\n protected detachWidget(widget: Widget): void {\n // Do nothing if the widget is not attached.\n if (this.parent!.node !== widget.node.parentNode) {\n return;\n }\n\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Delete the layout item for the widget.\n let item = this._items.get(widget);\n if (item) {\n this._items.delete(widget);\n item.dispose();\n }\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n */\n protected onBeforeShow(msg: Message): void {\n super.onBeforeShow(msg);\n this.parent!.update();\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n super.onBeforeAttach(msg);\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n if (this.parent!.isVisible) {\n this._update(msg.width, msg.height);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.parent!.isVisible) {\n this._update(-1, -1);\n }\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n */\n protected onFitRequest(msg: Message): void {\n if (this.parent!.isAttached) {\n this._fit();\n }\n }\n\n /**\n * Remove the specified widget from the layout structure.\n *\n * #### Notes\n * This is a no-op if the widget is not in the layout tree.\n *\n * This does not detach the widget from the parent node.\n */\n private _removeWidget(widget: Widget): void {\n // Bail early if there is no layout root.\n if (!this._root) {\n return;\n }\n\n // Find the tab node which contains the given widget.\n let tabNode = this._root.findTabNode(widget);\n\n // Bail early if the tab node is not found.\n if (!tabNode) {\n return;\n }\n\n Private.removeAria(widget);\n\n // If there are multiple tabs, just remove the widget's tab.\n if (tabNode.tabBar.titles.length > 1) {\n tabNode.tabBar.removeTab(widget.title);\n if (\n this._hiddenMode === Widget.HiddenMode.Scale &&\n tabNode.tabBar.titles.length == 1\n ) {\n const existingWidget = tabNode.tabBar.titles[0].owner;\n existingWidget.hiddenMode = Widget.HiddenMode.Display;\n }\n return;\n }\n\n // Otherwise, the tab node needs to be removed...\n\n // Dispose the tab bar.\n tabNode.tabBar.dispose();\n\n // Handle the case where the tab node is the root.\n if (this._root === tabNode) {\n this._root = null;\n return;\n }\n\n // Otherwise, remove the tab node from its parent...\n\n // Prevent widget resizing unless needed.\n this._root.holdAllSizes();\n\n // Clear the parent reference on the tab node.\n let splitNode = tabNode.parent!;\n tabNode.parent = null;\n\n // Remove the tab node from its parent split node.\n let i = ArrayExt.removeFirstOf(splitNode.children, tabNode);\n let handle = ArrayExt.removeAt(splitNode.handles, i)!;\n ArrayExt.removeAt(splitNode.sizers, i);\n\n // Remove the handle from its parent DOM node.\n if (handle.parentNode) {\n handle.parentNode.removeChild(handle);\n }\n\n // If there are multiple children, just update the handles.\n if (splitNode.children.length > 1) {\n splitNode.syncHandles();\n return;\n }\n\n // Otherwise, the split node also needs to be removed...\n\n // Clear the parent reference on the split node.\n let maybeParent = splitNode.parent;\n splitNode.parent = null;\n\n // Lookup the remaining child node and handle.\n let childNode = splitNode.children[0];\n let childHandle = splitNode.handles[0];\n\n // Clear the split node data.\n splitNode.children.length = 0;\n splitNode.handles.length = 0;\n splitNode.sizers.length = 0;\n\n // Remove the child handle from its parent node.\n if (childHandle.parentNode) {\n childHandle.parentNode.removeChild(childHandle);\n }\n\n // Handle the case where the split node is the root.\n if (this._root === splitNode) {\n childNode.parent = null;\n this._root = childNode;\n return;\n }\n\n // Otherwise, move the child node to the parent node...\n let parentNode = maybeParent!;\n\n // Lookup the index of the split node.\n let j = parentNode.children.indexOf(splitNode);\n\n // Handle the case where the child node is a tab node.\n if (childNode instanceof Private.TabLayoutNode) {\n childNode.parent = parentNode;\n parentNode.children[j] = childNode;\n return;\n }\n\n // Remove the split data from the parent.\n let splitHandle = ArrayExt.removeAt(parentNode.handles, j)!;\n ArrayExt.removeAt(parentNode.children, j);\n ArrayExt.removeAt(parentNode.sizers, j);\n\n // Remove the handle from its parent node.\n if (splitHandle.parentNode) {\n splitHandle.parentNode.removeChild(splitHandle);\n }\n\n // The child node and the split parent node will have the same\n // orientation. Merge the grand-children with the parent node.\n for (let i = 0, n = childNode.children.length; i < n; ++i) {\n let gChild = childNode.children[i];\n let gHandle = childNode.handles[i];\n let gSizer = childNode.sizers[i];\n ArrayExt.insert(parentNode.children, j + i, gChild);\n ArrayExt.insert(parentNode.handles, j + i, gHandle);\n ArrayExt.insert(parentNode.sizers, j + i, gSizer);\n gChild.parent = parentNode;\n }\n\n // Clear the child node.\n childNode.children.length = 0;\n childNode.handles.length = 0;\n childNode.sizers.length = 0;\n childNode.parent = null;\n\n // Sync the handles on the parent node.\n parentNode.syncHandles();\n }\n\n /**\n * Create the tab layout node to hold the widget.\n */\n private _createTabNode(widget: Widget): Private.TabLayoutNode {\n let tabNode = new Private.TabLayoutNode(this._createTabBar());\n tabNode.tabBar.addTab(widget.title);\n Private.addAria(widget, tabNode.tabBar);\n return tabNode;\n }\n\n /**\n * Insert a widget next to an existing tab.\n *\n * #### Notes\n * This does not attach the widget to the parent widget.\n */\n private _insertTab(\n widget: Widget,\n ref: Widget | null,\n refNode: Private.TabLayoutNode | null,\n after: boolean\n ): void {\n // Do nothing if the tab is inserted next to itself.\n if (widget === ref) {\n return;\n }\n\n // Create the root if it does not exist.\n if (!this._root) {\n let tabNode = new Private.TabLayoutNode(this._createTabBar());\n tabNode.tabBar.addTab(widget.title);\n this._root = tabNode;\n Private.addAria(widget, tabNode.tabBar);\n return;\n }\n\n // Use the first tab node as the ref node if needed.\n if (!refNode) {\n refNode = this._root.findFirstTabNode()!;\n }\n\n // If the widget is not contained in the ref node, ensure it is\n // removed from the layout and hidden before being added again.\n if (refNode.tabBar.titles.indexOf(widget.title) === -1) {\n this._removeWidget(widget);\n widget.hide();\n }\n\n // Lookup the target index for inserting the tab.\n let index: number;\n if (ref) {\n index = refNode.tabBar.titles.indexOf(ref.title);\n } else {\n index = refNode.tabBar.currentIndex;\n }\n\n // Using transform create an additional layer in the pixel pipeline\n // to limit the number of layer, it is set only if there is more than one widget.\n if (this._hiddenMode === Widget.HiddenMode.Scale) {\n if (refNode.tabBar.titles.length === 0) {\n // Singular tab should use display mode to limit number of layers.\n widget.hiddenMode = Widget.HiddenMode.Display;\n } else if (refNode.tabBar.titles.length == 1) {\n // If we are adding a second tab, switch the existing tab back to scale.\n const existingWidget = refNode.tabBar.titles[0].owner;\n existingWidget.hiddenMode = Widget.HiddenMode.Scale;\n } else {\n // For the third and subsequent tabs no special action is needed.\n widget.hiddenMode = Widget.HiddenMode.Scale;\n }\n } else {\n // For all other modes just propagate the current mode.\n widget.hiddenMode = this._hiddenMode;\n }\n\n // Insert the widget's tab relative to the target index.\n refNode.tabBar.insertTab(index + (after ? 1 : 0), widget.title);\n Private.addAria(widget, refNode.tabBar);\n }\n\n /**\n * Insert a widget as a new split area.\n *\n * #### Notes\n * This does not attach the widget to the parent widget.\n */\n private _insertSplit(\n widget: Widget,\n ref: Widget | null,\n refNode: Private.TabLayoutNode | null,\n orientation: Private.Orientation,\n after: boolean,\n merge: boolean = false\n ): void {\n // Do nothing if there is no effective split.\n if (widget === ref && refNode && refNode.tabBar.titles.length === 1) {\n return;\n }\n\n // Ensure the widget is removed from the current layout.\n this._removeWidget(widget);\n\n // Set the root if it does not exist.\n if (!this._root) {\n this._root = this._createTabNode(widget);\n return;\n }\n\n // If the ref node parent is null, split the root.\n if (!refNode || !refNode.parent) {\n // Ensure the root is split with the correct orientation.\n let root = this._splitRoot(orientation);\n\n // Determine the insert index for the new tab node.\n let i = after ? root.children.length : 0;\n\n // Normalize the split node.\n root.normalizeSizes();\n\n // Create the sizer for new tab node.\n let sizer = Private.createSizer(refNode ? 1 : Private.GOLDEN_RATIO);\n\n // Insert the tab node sized to the golden ratio.\n let tabNode = this._createTabNode(widget);\n ArrayExt.insert(root.children, i, tabNode);\n ArrayExt.insert(root.sizers, i, sizer);\n ArrayExt.insert(root.handles, i, this._createHandle());\n tabNode.parent = root;\n\n // Re-normalize the split node to maintain the ratios.\n root.normalizeSizes();\n\n // Finally, synchronize the visibility of the handles.\n root.syncHandles();\n return;\n }\n\n // Lookup the split node for the ref widget.\n let splitNode = refNode.parent;\n\n // If the split node already had the correct orientation,\n // the widget can be inserted into the split node directly.\n if (splitNode.orientation === orientation) {\n // Find the index of the ref node.\n let i = splitNode.children.indexOf(refNode);\n\n // Conditionally reuse a tab layout found in the wanted position.\n if (merge) {\n let j = i + (after ? 1 : -1);\n let sibling = splitNode.children[j];\n if (sibling instanceof Private.TabLayoutNode) {\n this._insertTab(widget, null, sibling, true);\n ++sibling.tabBar.currentIndex;\n return;\n }\n }\n\n // Normalize the split node.\n splitNode.normalizeSizes();\n\n // Consume half the space for the insert location.\n let s = (splitNode.sizers[i].sizeHint /= 2);\n\n // Insert the tab node sized to the other half.\n let j = i + (after ? 1 : 0);\n let tabNode = this._createTabNode(widget);\n ArrayExt.insert(splitNode.children, j, tabNode);\n ArrayExt.insert(splitNode.sizers, j, Private.createSizer(s));\n ArrayExt.insert(splitNode.handles, j, this._createHandle());\n tabNode.parent = splitNode;\n\n // Finally, synchronize the visibility of the handles.\n splitNode.syncHandles();\n return;\n }\n\n // Remove the ref node from the split node.\n let i = ArrayExt.removeFirstOf(splitNode.children, refNode);\n\n // Create a new normalized split node for the children.\n let childNode = new Private.SplitLayoutNode(orientation);\n childNode.normalized = true;\n\n // Add the ref node sized to half the space.\n childNode.children.push(refNode);\n childNode.sizers.push(Private.createSizer(0.5));\n childNode.handles.push(this._createHandle());\n refNode.parent = childNode;\n\n // Add the tab node sized to the other half.\n let j = after ? 1 : 0;\n let tabNode = this._createTabNode(widget);\n ArrayExt.insert(childNode.children, j, tabNode);\n ArrayExt.insert(childNode.sizers, j, Private.createSizer(0.5));\n ArrayExt.insert(childNode.handles, j, this._createHandle());\n tabNode.parent = childNode;\n\n // Synchronize the visibility of the handles.\n childNode.syncHandles();\n\n // Finally, add the new child node to the original split node.\n ArrayExt.insert(splitNode.children, i, childNode);\n childNode.parent = splitNode;\n }\n\n /**\n * Ensure the root is a split node with the given orientation.\n */\n private _splitRoot(\n orientation: Private.Orientation\n ): Private.SplitLayoutNode {\n // Bail early if the root already meets the requirements.\n let oldRoot = this._root;\n if (oldRoot instanceof Private.SplitLayoutNode) {\n if (oldRoot.orientation === orientation) {\n return oldRoot;\n }\n }\n\n // Create a new root node with the specified orientation.\n let newRoot = (this._root = new Private.SplitLayoutNode(orientation));\n\n // Add the old root to the new root.\n if (oldRoot) {\n newRoot.children.push(oldRoot);\n newRoot.sizers.push(Private.createSizer(0));\n newRoot.handles.push(this._createHandle());\n oldRoot.parent = newRoot;\n }\n\n // Return the new root as a convenience.\n return newRoot;\n }\n\n /**\n * Fit the layout to the total size required by the widgets.\n */\n private _fit(): void {\n // Set up the computed minimum size.\n let minW = 0;\n let minH = 0;\n\n // Update the size limits for the layout tree.\n if (this._root) {\n let limits = this._root.fit(this._spacing, this._items);\n minW = limits.minWidth;\n minH = limits.minHeight;\n }\n\n // Update the box sizing and add it to the computed min size.\n let box = (this._box = ElementExt.boxSizing(this.parent!.node));\n minW += box.horizontalSum;\n minH += box.verticalSum;\n\n // Update the parent's min size constraints.\n let style = this.parent!.node.style;\n style.minWidth = `${minW}px`;\n style.minHeight = `${minH}px`;\n\n // Set the dirty flag to ensure only a single update occurs.\n this._dirty = true;\n\n // Notify the ancestor that it should fit immediately. This may\n // cause a resize of the parent, fulfilling the required update.\n if (this.parent!.parent) {\n MessageLoop.sendMessage(this.parent!.parent!, Widget.Msg.FitRequest);\n }\n\n // If the dirty flag is still set, the parent was not resized.\n // Trigger the required update on the parent widget immediately.\n if (this._dirty) {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n }\n }\n\n /**\n * Update the layout position and size of the widgets.\n *\n * The parent offset dimensions should be `-1` if unknown.\n */\n private _update(offsetWidth: number, offsetHeight: number): void {\n // Clear the dirty flag to indicate the update occurred.\n this._dirty = false;\n\n // Bail early if there is no root layout node.\n if (!this._root) {\n return;\n }\n\n // Measure the parent if the offset dimensions are unknown.\n if (offsetWidth < 0) {\n offsetWidth = this.parent!.node.offsetWidth;\n }\n if (offsetHeight < 0) {\n offsetHeight = this.parent!.node.offsetHeight;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent!.node);\n }\n\n // Compute the actual layout bounds adjusted for border and padding.\n let x = this._box.paddingTop;\n let y = this._box.paddingLeft;\n let width = offsetWidth - this._box.horizontalSum;\n let height = offsetHeight - this._box.verticalSum;\n\n // Update the geometry of the layout tree.\n this._root.update(x, y, width, height, this._spacing, this._items);\n }\n\n /**\n * Create a new tab bar for use by the dock layout.\n *\n * #### Notes\n * The tab bar will be attached to the parent if it exists.\n */\n private _createTabBar(): TabBar {\n // Create the tab bar using the renderer.\n let tabBar = this.renderer.createTabBar(this._document);\n\n // Enforce necessary tab bar behavior.\n tabBar.orientation = 'horizontal';\n\n // Attach the tab bar to the parent if possible.\n if (this.parent) {\n this.attachWidget(tabBar);\n }\n\n // Return the initialized tab bar.\n return tabBar;\n }\n\n /**\n * Create a new handle for the dock layout.\n *\n * #### Notes\n * The handle will be attached to the parent if it exists.\n */\n private _createHandle(): HTMLDivElement {\n // Create the handle using the renderer.\n let handle = this.renderer.createHandle();\n\n // Initialize the handle layout behavior.\n let style = handle.style;\n style.position = 'absolute';\n style.contain = 'strict';\n style.top = '0';\n style.left = '0';\n style.width = '0';\n style.height = '0';\n\n // Attach the handle to the parent if it exists.\n if (this.parent) {\n this.parent.node.appendChild(handle);\n }\n\n // Return the initialized handle.\n return handle;\n }\n\n private _spacing = 4;\n private _dirty = false;\n private _root: Private.LayoutNode | null = null;\n private _box: ElementExt.IBoxSizing | null = null;\n private _document: Document | ShadowRoot;\n private _hiddenMode: Widget.HiddenMode;\n private _items: Private.ItemMap = new Map();\n}\n\n/**\n * The namespace for the `DockLayout` class statics.\n */\nexport namespace DockLayout {\n /**\n * An options object for creating a dock layout.\n */\n export interface IOptions {\n /**\n * The document to use with the dock panel.\n *\n * The default is the global `document` instance.\n */\n document?: Document | ShadowRoot;\n\n /**\n * The method for hiding widgets.\n *\n * The default is `Widget.HiddenMode.Display`.\n */\n hiddenMode?: Widget.HiddenMode;\n\n /**\n * The renderer to use for the dock layout.\n */\n renderer: IRenderer;\n\n /**\n * The spacing between items in the layout.\n *\n * The default is `4`.\n */\n spacing?: number;\n }\n\n /**\n * A renderer for use with a dock layout.\n */\n export interface IRenderer {\n /**\n * Create a new tab bar for use with a dock layout.\n *\n * @returns A new tab bar for a dock layout.\n */\n createTabBar(document?: Document | ShadowRoot): TabBar;\n\n /**\n * Create a new handle node for use with a dock layout.\n *\n * @returns A new handle node for a dock layout.\n */\n createHandle(): HTMLDivElement;\n }\n\n /**\n * A type alias for the supported insertion modes.\n *\n * An insert mode is used to specify how a widget should be added\n * to the dock layout relative to a reference widget.\n */\n export type InsertMode =\n | /**\n * The area to the top of the reference widget.\n *\n * The widget will be inserted just above the reference widget.\n *\n * If the reference widget is null or invalid, the widget will be\n * inserted at the top edge of the dock layout.\n */\n 'split-top'\n\n /**\n * The area to the left of the reference widget.\n *\n * The widget will be inserted just left of the reference widget.\n *\n * If the reference widget is null or invalid, the widget will be\n * inserted at the left edge of the dock layout.\n */\n | 'split-left'\n\n /**\n * The area to the right of the reference widget.\n *\n * The widget will be inserted just right of the reference widget.\n *\n * If the reference widget is null or invalid, the widget will be\n * inserted at the right edge of the dock layout.\n */\n | 'split-right'\n\n /**\n * The area to the bottom of the reference widget.\n *\n * The widget will be inserted just below the reference widget.\n *\n * If the reference widget is null or invalid, the widget will be\n * inserted at the bottom edge of the dock layout.\n */\n | 'split-bottom'\n\n /**\n * Like `split-top` but if a tab layout exists above the reference widget,\n * it behaves like `tab-after` with reference to that instead.\n */\n | 'merge-top'\n\n /**\n * Like `split-left` but if a tab layout exists left of the reference widget,\n * it behaves like `tab-after` with reference to that instead.\n */\n | 'merge-left'\n\n /**\n * Like `split-right` but if a tab layout exists right of the reference widget,\n * it behaves like `tab-after` with reference to that instead.\n */\n | 'merge-right'\n\n /**\n * Like `split-bottom` but if a tab layout exists below the reference widget,\n * it behaves like `tab-after` with reference to that instead.\n */\n | 'merge-bottom'\n\n /**\n * The tab position before the reference widget.\n *\n * The widget will be added as a tab before the reference widget.\n *\n * If the reference widget is null or invalid, a sensible default\n * will be used.\n */\n | 'tab-before'\n\n /**\n * The tab position after the reference widget.\n *\n * The widget will be added as a tab after the reference widget.\n *\n * If the reference widget is null or invalid, a sensible default\n * will be used.\n */\n | 'tab-after';\n\n /**\n * An options object for adding a widget to the dock layout.\n */\n export interface IAddOptions {\n /**\n * The insertion mode for adding the widget.\n *\n * The default is `'tab-after'`.\n */\n mode?: InsertMode;\n\n /**\n * The reference widget for the insert location.\n *\n * The default is `null`.\n */\n ref?: Widget | null;\n }\n\n /**\n * A layout config object for a tab area.\n */\n export interface ITabAreaConfig {\n /**\n * The discriminated type of the config object.\n */\n type: 'tab-area';\n\n /**\n * The widgets contained in the tab area.\n */\n widgets: Widget[];\n\n /**\n * The index of the selected tab.\n */\n currentIndex: number;\n }\n\n /**\n * A layout config object for a split area.\n */\n export interface ISplitAreaConfig {\n /**\n * The discriminated type of the config object.\n */\n type: 'split-area';\n\n /**\n * The orientation of the split area.\n */\n orientation: 'horizontal' | 'vertical';\n\n /**\n * The children in the split area.\n */\n children: AreaConfig[];\n\n /**\n * The relative sizes of the children.\n */\n sizes: number[];\n }\n\n /**\n * A type alias for a general area config.\n */\n export type AreaConfig = ITabAreaConfig | ISplitAreaConfig;\n\n /**\n * A dock layout configuration object.\n */\n export interface ILayoutConfig {\n /**\n * The layout config for the main dock area.\n */\n main: AreaConfig | null;\n }\n\n /**\n * An object which represents the geometry of a tab area.\n */\n export interface ITabAreaGeometry {\n /**\n * The tab bar for the tab area.\n */\n tabBar: TabBar;\n\n /**\n * The local X position of the hit test in the dock area.\n *\n * #### Notes\n * This is the distance from the left edge of the layout parent\n * widget, to the local X coordinate of the hit test query.\n */\n x: number;\n\n /**\n * The local Y position of the hit test in the dock area.\n *\n * #### Notes\n * This is the distance from the top edge of the layout parent\n * widget, to the local Y coordinate of the hit test query.\n */\n y: number;\n\n /**\n * The local coordinate of the top edge of the tab area.\n *\n * #### Notes\n * This is the distance from the top edge of the layout parent\n * widget, to the top edge of the tab area.\n */\n top: number;\n\n /**\n * The local coordinate of the left edge of the tab area.\n *\n * #### Notes\n * This is the distance from the left edge of the layout parent\n * widget, to the left edge of the tab area.\n */\n left: number;\n\n /**\n * The local coordinate of the right edge of the tab area.\n *\n * #### Notes\n * This is the distance from the right edge of the layout parent\n * widget, to the right edge of the tab area.\n */\n right: number;\n\n /**\n * The local coordinate of the bottom edge of the tab area.\n *\n * #### Notes\n * This is the distance from the bottom edge of the layout parent\n * widget, to the bottom edge of the tab area.\n */\n bottom: number;\n\n /**\n * The width of the tab area.\n *\n * #### Notes\n * This is total width allocated for the tab area.\n */\n width: number;\n\n /**\n * The height of the tab area.\n *\n * #### Notes\n * This is total height allocated for the tab area.\n */\n height: number;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * A fraction used for sizing root panels; ~= `1 / golden_ratio`.\n */\n export const GOLDEN_RATIO = 0.618;\n\n /**\n * A type alias for a dock layout node.\n */\n export type LayoutNode = TabLayoutNode | SplitLayoutNode;\n\n /**\n * A type alias for the orientation of a split layout node.\n */\n export type Orientation = 'horizontal' | 'vertical';\n\n /**\n * A type alias for a layout item map.\n */\n export type ItemMap = Map;\n\n /**\n * Create a box sizer with an initial size hint.\n */\n export function createSizer(hint: number): BoxSizer {\n let sizer = new BoxSizer();\n sizer.sizeHint = hint;\n sizer.size = hint;\n return sizer;\n }\n\n /**\n * Normalize an area config object and collect the visited widgets.\n */\n export function normalizeAreaConfig(\n config: DockLayout.AreaConfig,\n widgetSet: Set\n ): DockLayout.AreaConfig | null {\n let result: DockLayout.AreaConfig | null;\n if (config.type === 'tab-area') {\n result = normalizeTabAreaConfig(config, widgetSet);\n } else {\n result = normalizeSplitAreaConfig(config, widgetSet);\n }\n return result;\n }\n\n /**\n * Convert a normalized area config into a layout tree.\n */\n export function realizeAreaConfig(\n config: DockLayout.AreaConfig,\n renderer: DockLayout.IRenderer,\n document: Document | ShadowRoot\n ): LayoutNode {\n let node: LayoutNode;\n if (config.type === 'tab-area') {\n node = realizeTabAreaConfig(config, renderer, document);\n } else {\n node = realizeSplitAreaConfig(config, renderer, document);\n }\n return node;\n }\n\n /**\n * A layout node which holds the data for a tabbed area.\n */\n export class TabLayoutNode {\n /**\n * Construct a new tab layout node.\n *\n * @param tabBar - The tab bar to use for the layout node.\n */\n constructor(tabBar: TabBar) {\n let tabSizer = new BoxSizer();\n let widgetSizer = new BoxSizer();\n tabSizer.stretch = 0;\n widgetSizer.stretch = 1;\n this.tabBar = tabBar;\n this.sizers = [tabSizer, widgetSizer];\n }\n\n /**\n * The parent of the layout node.\n */\n parent: SplitLayoutNode | null = null;\n\n /**\n * The tab bar for the layout node.\n */\n readonly tabBar: TabBar;\n\n /**\n * The sizers for the layout node.\n */\n readonly sizers: [BoxSizer, BoxSizer];\n\n /**\n * The most recent value for the `top` edge of the layout box.\n */\n get top(): number {\n return this._top;\n }\n\n /**\n * The most recent value for the `left` edge of the layout box.\n */\n get left(): number {\n return this._left;\n }\n\n /**\n * The most recent value for the `width` of the layout box.\n */\n get width(): number {\n return this._width;\n }\n\n /**\n * The most recent value for the `height` of the layout box.\n */\n get height(): number {\n return this._height;\n }\n\n /**\n * Create an iterator for all widgets in the layout tree.\n */\n *iterAllWidgets(): IterableIterator {\n yield this.tabBar;\n yield* this.iterUserWidgets();\n }\n\n /**\n * Create an iterator for the user widgets in the layout tree.\n */\n *iterUserWidgets(): IterableIterator {\n for (const title of this.tabBar.titles) {\n yield title.owner;\n }\n }\n\n /**\n * Create an iterator for the selected widgets in the layout tree.\n */\n *iterSelectedWidgets(): IterableIterator {\n let title = this.tabBar.currentTitle;\n if (title) {\n yield title.owner;\n }\n }\n\n /**\n * Create an iterator for the tab bars in the layout tree.\n */\n *iterTabBars(): IterableIterator> {\n yield this.tabBar;\n }\n\n /**\n * Create an iterator for the handles in the layout tree.\n */\n // eslint-disable-next-line require-yield\n *iterHandles(): IterableIterator {\n return;\n }\n\n /**\n * Find the tab layout node which contains the given widget.\n */\n findTabNode(widget: Widget): TabLayoutNode | null {\n return this.tabBar.titles.indexOf(widget.title) !== -1 ? this : null;\n }\n\n /**\n * Find the split layout node which contains the given handle.\n */\n findSplitNode(\n handle: HTMLDivElement\n ): { index: number; node: SplitLayoutNode } | null {\n return null;\n }\n\n /**\n * Find the first tab layout node in a layout tree.\n */\n findFirstTabNode(): TabLayoutNode | null {\n return this;\n }\n\n /**\n * Find the tab layout node which contains the local point.\n */\n hitTestTabNodes(x: number, y: number): TabLayoutNode | null {\n if (x < this._left || x >= this._left + this._width) {\n return null;\n }\n if (y < this._top || y >= this._top + this._height) {\n return null;\n }\n return this;\n }\n\n /**\n * Create a configuration object for the layout tree.\n */\n createConfig(): DockLayout.ITabAreaConfig {\n let widgets = this.tabBar.titles.map(title => title.owner);\n let currentIndex = this.tabBar.currentIndex;\n return { type: 'tab-area', widgets, currentIndex };\n }\n\n /**\n * Recursively hold all of the sizes in the layout tree.\n *\n * This ignores the sizers of tab layout nodes.\n */\n holdAllSizes(): void {\n return;\n }\n\n /**\n * Fit the layout tree.\n */\n fit(spacing: number, items: ItemMap): ElementExt.ISizeLimits {\n // Set up the limit variables.\n let minWidth = 0;\n let minHeight = 0;\n let maxWidth = Infinity;\n let maxHeight = Infinity;\n\n // Lookup the tab bar layout item.\n let tabBarItem = items.get(this.tabBar);\n\n // Lookup the widget layout item.\n let current = this.tabBar.currentTitle;\n let widgetItem = current ? items.get(current.owner) : undefined;\n\n // Lookup the tab bar and widget sizers.\n let [tabBarSizer, widgetSizer] = this.sizers;\n\n // Update the tab bar limits.\n if (tabBarItem) {\n tabBarItem.fit();\n }\n\n // Update the widget limits.\n if (widgetItem) {\n widgetItem.fit();\n }\n\n // Update the results and sizer for the tab bar.\n if (tabBarItem && !tabBarItem.isHidden) {\n minWidth = Math.max(minWidth, tabBarItem.minWidth);\n minHeight += tabBarItem.minHeight;\n tabBarSizer.minSize = tabBarItem.minHeight;\n tabBarSizer.maxSize = tabBarItem.maxHeight;\n } else {\n tabBarSizer.minSize = 0;\n tabBarSizer.maxSize = 0;\n }\n\n // Update the results and sizer for the current widget.\n if (widgetItem && !widgetItem.isHidden) {\n minWidth = Math.max(minWidth, widgetItem.minWidth);\n minHeight += widgetItem.minHeight;\n widgetSizer.minSize = widgetItem.minHeight;\n widgetSizer.maxSize = Infinity;\n } else {\n widgetSizer.minSize = 0;\n widgetSizer.maxSize = Infinity;\n }\n\n // Return the computed size limits for the layout node.\n return { minWidth, minHeight, maxWidth, maxHeight };\n }\n\n /**\n * Update the layout tree.\n */\n update(\n left: number,\n top: number,\n width: number,\n height: number,\n spacing: number,\n items: ItemMap\n ): void {\n // Update the layout box values.\n this._top = top;\n this._left = left;\n this._width = width;\n this._height = height;\n\n // Lookup the tab bar layout item.\n let tabBarItem = items.get(this.tabBar);\n\n // Lookup the widget layout item.\n let current = this.tabBar.currentTitle;\n let widgetItem = current ? items.get(current.owner) : undefined;\n\n // Distribute the layout space to the sizers.\n BoxEngine.calc(this.sizers, height);\n\n // Update the tab bar item using the computed size.\n if (tabBarItem && !tabBarItem.isHidden) {\n let size = this.sizers[0].size;\n tabBarItem.update(left, top, width, size);\n top += size;\n }\n\n // Layout the widget using the computed size.\n if (widgetItem && !widgetItem.isHidden) {\n let size = this.sizers[1].size;\n widgetItem.update(left, top, width, size);\n }\n }\n\n private _top = 0;\n private _left = 0;\n private _width = 0;\n private _height = 0;\n }\n\n /**\n * A layout node which holds the data for a split area.\n */\n export class SplitLayoutNode {\n /**\n * Construct a new split layout node.\n *\n * @param orientation - The orientation of the node.\n */\n constructor(orientation: Orientation) {\n this.orientation = orientation;\n }\n\n /**\n * The parent of the layout node.\n */\n parent: SplitLayoutNode | null = null;\n\n /**\n * Whether the sizers have been normalized.\n */\n normalized = false;\n\n /**\n * The orientation of the node.\n */\n readonly orientation: Orientation;\n\n /**\n * The child nodes for the split node.\n */\n readonly children: LayoutNode[] = [];\n\n /**\n * The box sizers for the layout children.\n */\n readonly sizers: BoxSizer[] = [];\n\n /**\n * The handles for the layout children.\n */\n readonly handles: HTMLDivElement[] = [];\n\n /**\n * Create an iterator for all widgets in the layout tree.\n */\n *iterAllWidgets(): IterableIterator {\n for (const child of this.children) {\n yield* child.iterAllWidgets();\n }\n }\n\n /**\n * Create an iterator for the user widgets in the layout tree.\n */\n *iterUserWidgets(): IterableIterator {\n for (const child of this.children) {\n yield* child.iterUserWidgets();\n }\n }\n\n /**\n * Create an iterator for the selected widgets in the layout tree.\n */\n *iterSelectedWidgets(): IterableIterator {\n for (const child of this.children) {\n yield* child.iterSelectedWidgets();\n }\n }\n\n /**\n * Create an iterator for the tab bars in the layout tree.\n */\n *iterTabBars(): IterableIterator> {\n for (const child of this.children) {\n yield* child.iterTabBars();\n }\n }\n\n /**\n * Create an iterator for the handles in the layout tree.\n */\n *iterHandles(): IterableIterator {\n yield* this.handles;\n for (const child of this.children) {\n yield* child.iterHandles();\n }\n }\n\n /**\n * Find the tab layout node which contains the given widget.\n */\n findTabNode(widget: Widget): TabLayoutNode | null {\n for (let i = 0, n = this.children.length; i < n; ++i) {\n let result = this.children[i].findTabNode(widget);\n if (result) {\n return result;\n }\n }\n return null;\n }\n\n /**\n * Find the split layout node which contains the given handle.\n */\n findSplitNode(\n handle: HTMLDivElement\n ): { index: number; node: SplitLayoutNode } | null {\n let index = this.handles.indexOf(handle);\n if (index !== -1) {\n return { index, node: this };\n }\n for (let i = 0, n = this.children.length; i < n; ++i) {\n let result = this.children[i].findSplitNode(handle);\n if (result) {\n return result;\n }\n }\n return null;\n }\n\n /**\n * Find the first tab layout node in a layout tree.\n */\n findFirstTabNode(): TabLayoutNode | null {\n if (this.children.length === 0) {\n return null;\n }\n return this.children[0].findFirstTabNode();\n }\n\n /**\n * Find the tab layout node which contains the local point.\n */\n hitTestTabNodes(x: number, y: number): TabLayoutNode | null {\n for (let i = 0, n = this.children.length; i < n; ++i) {\n let result = this.children[i].hitTestTabNodes(x, y);\n if (result) {\n return result;\n }\n }\n return null;\n }\n\n /**\n * Create a configuration object for the layout tree.\n */\n createConfig(): DockLayout.ISplitAreaConfig {\n let orientation = this.orientation;\n let sizes = this.createNormalizedSizes();\n let children = this.children.map(child => child.createConfig());\n return { type: 'split-area', orientation, children, sizes };\n }\n\n /**\n * Sync the visibility and orientation of the handles.\n */\n syncHandles(): void {\n this.handles.forEach((handle, i) => {\n handle.setAttribute('data-orientation', this.orientation);\n if (i === this.handles.length - 1) {\n handle.classList.add('lm-mod-hidden');\n } else {\n handle.classList.remove('lm-mod-hidden');\n }\n });\n }\n\n /**\n * Hold the current sizes of the box sizers.\n *\n * This sets the size hint of each sizer to its current size.\n */\n holdSizes(): void {\n for (const sizer of this.sizers) {\n sizer.sizeHint = sizer.size;\n }\n }\n\n /**\n * Recursively hold all of the sizes in the layout tree.\n *\n * This ignores the sizers of tab layout nodes.\n */\n holdAllSizes(): void {\n for (const child of this.children) {\n child.holdAllSizes();\n }\n this.holdSizes();\n }\n\n /**\n * Normalize the sizes of the split layout node.\n */\n normalizeSizes(): void {\n // Bail early if the sizers are empty.\n let n = this.sizers.length;\n if (n === 0) {\n return;\n }\n\n // Hold the current sizes of the sizers.\n this.holdSizes();\n\n // Compute the sum of the sizes.\n let sum = this.sizers.reduce((v, sizer) => v + sizer.sizeHint, 0);\n\n // Normalize the sizes based on the sum.\n if (sum === 0) {\n for (const sizer of this.sizers) {\n sizer.size = sizer.sizeHint = 1 / n;\n }\n } else {\n for (const sizer of this.sizers) {\n sizer.size = sizer.sizeHint /= sum;\n }\n }\n\n // Mark the sizes as normalized.\n this.normalized = true;\n }\n\n /**\n * Snap the normalized sizes of the split layout node.\n */\n createNormalizedSizes(): number[] {\n // Bail early if the sizers are empty.\n let n = this.sizers.length;\n if (n === 0) {\n return [];\n }\n\n // Grab the current sizes of the sizers.\n let sizes = this.sizers.map(sizer => sizer.size);\n\n // Compute the sum of the sizes.\n let sum = sizes.reduce((v, size) => v + size, 0);\n\n // Normalize the sizes based on the sum.\n if (sum === 0) {\n for (let i = sizes.length - 1; i > -1; i--) {\n sizes[i] = 1 / n;\n }\n } else {\n for (let i = sizes.length - 1; i > -1; i--) {\n sizes[i] /= sum;\n }\n }\n\n // Return the normalized sizes.\n return sizes;\n }\n\n /**\n * Fit the layout tree.\n */\n fit(spacing: number, items: ItemMap): ElementExt.ISizeLimits {\n // Compute the required fixed space.\n let horizontal = this.orientation === 'horizontal';\n let fixed = Math.max(0, this.children.length - 1) * spacing;\n\n // Set up the limit variables.\n let minWidth = horizontal ? fixed : 0;\n let minHeight = horizontal ? 0 : fixed;\n let maxWidth = Infinity;\n let maxHeight = Infinity;\n\n // Fit the children and update the limits.\n for (let i = 0, n = this.children.length; i < n; ++i) {\n let limits = this.children[i].fit(spacing, items);\n if (horizontal) {\n minHeight = Math.max(minHeight, limits.minHeight);\n minWidth += limits.minWidth;\n this.sizers[i].minSize = limits.minWidth;\n } else {\n minWidth = Math.max(minWidth, limits.minWidth);\n minHeight += limits.minHeight;\n this.sizers[i].minSize = limits.minHeight;\n }\n }\n\n // Return the computed limits for the layout node.\n return { minWidth, minHeight, maxWidth, maxHeight };\n }\n\n /**\n * Update the layout tree.\n */\n update(\n left: number,\n top: number,\n width: number,\n height: number,\n spacing: number,\n items: ItemMap\n ): void {\n // Compute the available layout space.\n let horizontal = this.orientation === 'horizontal';\n let fixed = Math.max(0, this.children.length - 1) * spacing;\n let space = Math.max(0, (horizontal ? width : height) - fixed);\n\n // De-normalize the sizes if needed.\n if (this.normalized) {\n for (const sizer of this.sizers) {\n sizer.sizeHint *= space;\n }\n this.normalized = false;\n }\n\n // Distribute the layout space to the sizers.\n BoxEngine.calc(this.sizers, space);\n\n // Update the geometry of the child nodes and handles.\n for (let i = 0, n = this.children.length; i < n; ++i) {\n let child = this.children[i];\n let size = this.sizers[i].size;\n let handleStyle = this.handles[i].style;\n if (horizontal) {\n child.update(left, top, size, height, spacing, items);\n left += size;\n handleStyle.top = `${top}px`;\n handleStyle.left = `${left}px`;\n handleStyle.width = `${spacing}px`;\n handleStyle.height = `${height}px`;\n left += spacing;\n } else {\n child.update(left, top, width, size, spacing, items);\n top += size;\n handleStyle.top = `${top}px`;\n handleStyle.left = `${left}px`;\n handleStyle.width = `${width}px`;\n handleStyle.height = `${spacing}px`;\n top += spacing;\n }\n }\n }\n }\n\n export function addAria(widget: Widget, tabBar: TabBar): void {\n widget.node.setAttribute('role', 'tabpanel');\n let renderer = tabBar.renderer;\n if (renderer instanceof TabBar.Renderer) {\n let tabId = renderer.createTabKey({\n title: widget.title,\n current: false,\n zIndex: 0\n });\n widget.node.setAttribute('aria-labelledby', tabId);\n }\n }\n\n export function removeAria(widget: Widget): void {\n widget.node.removeAttribute('role');\n widget.node.removeAttribute('aria-labelledby');\n }\n\n /**\n * Normalize a tab area config and collect the visited widgets.\n */\n function normalizeTabAreaConfig(\n config: DockLayout.ITabAreaConfig,\n widgetSet: Set\n ): DockLayout.ITabAreaConfig | null {\n // Bail early if there is no content.\n if (config.widgets.length === 0) {\n return null;\n }\n\n // Setup the filtered widgets array.\n let widgets: Widget[] = [];\n\n // Filter the config for unique widgets.\n for (const widget of config.widgets) {\n if (!widgetSet.has(widget)) {\n widgetSet.add(widget);\n widgets.push(widget);\n }\n }\n\n // Bail if there are no effective widgets.\n if (widgets.length === 0) {\n return null;\n }\n\n // Normalize the current index.\n let index = config.currentIndex;\n if (index !== -1 && (index < 0 || index >= widgets.length)) {\n index = 0;\n }\n\n // Return a normalized config object.\n return { type: 'tab-area', widgets, currentIndex: index };\n }\n\n /**\n * Normalize a split area config and collect the visited widgets.\n */\n function normalizeSplitAreaConfig(\n config: DockLayout.ISplitAreaConfig,\n widgetSet: Set\n ): DockLayout.AreaConfig | null {\n // Set up the result variables.\n let orientation = config.orientation;\n let children: DockLayout.AreaConfig[] = [];\n let sizes: number[] = [];\n\n // Normalize the config children.\n for (let i = 0, n = config.children.length; i < n; ++i) {\n // Normalize the child config.\n let child = normalizeAreaConfig(config.children[i], widgetSet);\n\n // Ignore an empty child.\n if (!child) {\n continue;\n }\n\n // Add the child or hoist its content as appropriate.\n if (child.type === 'tab-area' || child.orientation !== orientation) {\n children.push(child);\n sizes.push(Math.abs(config.sizes[i] || 0));\n } else {\n children.push(...child.children);\n sizes.push(...child.sizes);\n }\n }\n\n // Bail if there are no effective children.\n if (children.length === 0) {\n return null;\n }\n\n // If there is only one effective child, return that child.\n if (children.length === 1) {\n return children[0];\n }\n\n // Return a normalized config object.\n return { type: 'split-area', orientation, children, sizes };\n }\n\n /**\n * Convert a normalized tab area config into a layout tree.\n */\n function realizeTabAreaConfig(\n config: DockLayout.ITabAreaConfig,\n renderer: DockLayout.IRenderer,\n document: Document | ShadowRoot\n ): TabLayoutNode {\n // Create the tab bar for the layout node.\n let tabBar = renderer.createTabBar(document);\n\n // Hide each widget and add it to the tab bar.\n for (const widget of config.widgets) {\n widget.hide();\n tabBar.addTab(widget.title);\n Private.addAria(widget, tabBar);\n }\n\n // Set the current index of the tab bar.\n tabBar.currentIndex = config.currentIndex;\n\n // Return the new tab layout node.\n return new TabLayoutNode(tabBar);\n }\n\n /**\n * Convert a normalized split area config into a layout tree.\n */\n function realizeSplitAreaConfig(\n config: DockLayout.ISplitAreaConfig,\n renderer: DockLayout.IRenderer,\n document: Document | ShadowRoot\n ): SplitLayoutNode {\n // Create the split layout node.\n let node = new SplitLayoutNode(config.orientation);\n\n // Add each child to the layout node.\n config.children.forEach((child, i) => {\n // Create the child data for the layout node.\n let childNode = realizeAreaConfig(child, renderer, document);\n let sizer = createSizer(config.sizes[i]);\n let handle = renderer.createHandle();\n\n // Add the child data to the layout node.\n node.children.push(childNode);\n node.handles.push(handle);\n node.sizers.push(sizer);\n\n // Update the parent for the child node.\n childNode.parent = node;\n });\n\n // Synchronize the handle state for the layout node.\n node.syncHandles();\n\n // Normalize the sizes for the layout node.\n node.normalizeSizes();\n\n // Return the new layout node.\n return node;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { find } from '@lumino/algorithm';\n\nimport { MimeData } from '@lumino/coreutils';\n\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ElementExt, Platform } from '@lumino/domutils';\n\nimport { Drag } from '@lumino/dragdrop';\n\nimport { ConflatableMessage, Message, MessageLoop } from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { DockLayout } from './docklayout';\n\nimport { TabBar } from './tabbar';\n\nimport { Widget } from './widget';\n\n/**\n * A widget which provides a flexible docking area for widgets.\n */\nexport class DockPanel extends Widget {\n /**\n * Construct a new dock panel.\n *\n * @param options - The options for initializing the panel.\n */\n constructor(options: DockPanel.IOptions = {}) {\n super();\n this.addClass('lm-DockPanel');\n this._document = options.document || document;\n this._mode = options.mode || 'multiple-document';\n this._renderer = options.renderer || DockPanel.defaultRenderer;\n this._edges = options.edges || Private.DEFAULT_EDGES;\n if (options.tabsMovable !== undefined) {\n this._tabsMovable = options.tabsMovable;\n }\n if (options.tabsConstrained !== undefined) {\n this._tabsConstrained = options.tabsConstrained;\n }\n if (options.addButtonEnabled !== undefined) {\n this._addButtonEnabled = options.addButtonEnabled;\n }\n\n // Toggle the CSS mode attribute.\n this.dataset['mode'] = this._mode;\n\n // Create the delegate renderer for the layout.\n let renderer: DockPanel.IRenderer = {\n createTabBar: () => this._createTabBar(),\n createHandle: () => this._createHandle()\n };\n\n // Set up the dock layout for the panel.\n this.layout = new DockLayout({\n document: this._document,\n renderer,\n spacing: options.spacing,\n hiddenMode: options.hiddenMode\n });\n\n // Set up the overlay drop indicator.\n this.overlay = options.overlay || new DockPanel.Overlay();\n this.node.appendChild(this.overlay.node);\n }\n\n /**\n * Dispose of the resources held by the panel.\n */\n dispose(): void {\n // Ensure the mouse is released.\n this._releaseMouse();\n\n // Hide the overlay.\n this.overlay.hide(0);\n\n // Cancel a drag if one is in progress.\n if (this._drag) {\n this._drag.dispose();\n }\n\n // Dispose of the base class.\n super.dispose();\n }\n\n /**\n * The method for hiding widgets.\n */\n get hiddenMode(): Widget.HiddenMode {\n return (this.layout as DockLayout).hiddenMode;\n }\n\n /**\n * Set the method for hiding widgets.\n */\n set hiddenMode(v: Widget.HiddenMode) {\n (this.layout as DockLayout).hiddenMode = v;\n }\n\n /**\n * A signal emitted when the layout configuration is modified.\n *\n * #### Notes\n * This signal is emitted whenever the current layout configuration\n * may have changed.\n *\n * This signal is emitted asynchronously in a collapsed fashion, so\n * that multiple synchronous modifications results in only a single\n * emit of the signal.\n */\n get layoutModified(): ISignal {\n return this._layoutModified;\n }\n\n /**\n * A signal emitted when the add button on a tab bar is clicked.\n *\n */\n get addRequested(): ISignal> {\n return this._addRequested;\n }\n\n /**\n * The overlay used by the dock panel.\n */\n readonly overlay: DockPanel.IOverlay;\n\n /**\n * The renderer used by the dock panel.\n */\n get renderer(): DockPanel.IRenderer {\n return (this.layout as DockLayout).renderer;\n }\n\n /**\n * Get the spacing between the widgets.\n */\n get spacing(): number {\n return (this.layout as DockLayout).spacing;\n }\n\n /**\n * Set the spacing between the widgets.\n */\n set spacing(value: number) {\n (this.layout as DockLayout).spacing = value;\n }\n\n /**\n * Get the mode for the dock panel.\n */\n get mode(): DockPanel.Mode {\n return this._mode;\n }\n\n /**\n * Set the mode for the dock panel.\n *\n * #### Notes\n * Changing the mode is a destructive operation with respect to the\n * panel's layout configuration. If layout state must be preserved,\n * save the current layout config before changing the mode.\n */\n set mode(value: DockPanel.Mode) {\n // Bail early if the mode does not change.\n if (this._mode === value) {\n return;\n }\n\n // Update the internal mode.\n this._mode = value;\n\n // Toggle the CSS mode attribute.\n this.dataset['mode'] = value;\n\n // Get the layout for the panel.\n let layout = this.layout as DockLayout;\n\n // Configure the layout for the specified mode.\n switch (value) {\n case 'multiple-document':\n for (const tabBar of layout.tabBars()) {\n tabBar.show();\n }\n break;\n case 'single-document':\n layout.restoreLayout(Private.createSingleDocumentConfig(this));\n break;\n default:\n throw 'unreachable';\n }\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Whether the tabs can be dragged / moved at runtime.\n */\n get tabsMovable(): boolean {\n return this._tabsMovable;\n }\n\n /**\n * Enable / Disable draggable / movable tabs.\n */\n set tabsMovable(value: boolean) {\n this._tabsMovable = value;\n for (const tabBar of this.tabBars()) {\n tabBar.tabsMovable = value;\n }\n }\n\n /**\n * Whether the tabs are constrained to their source dock panel\n */\n get tabsConstrained(): boolean {\n return this._tabsConstrained;\n }\n\n /**\n * Constrain/Allow tabs to be dragged outside of this dock panel\n */\n set tabsConstrained(value: boolean) {\n this._tabsConstrained = value;\n }\n\n /**\n * Whether the add buttons for each tab bar are enabled.\n */\n get addButtonEnabled(): boolean {\n return this._addButtonEnabled;\n }\n\n /**\n * Set whether the add buttons for each tab bar are enabled.\n */\n set addButtonEnabled(value: boolean) {\n this._addButtonEnabled = value;\n for (const tabBar of this.tabBars()) {\n tabBar.addButtonEnabled = value;\n }\n }\n\n /**\n * Whether the dock panel is empty.\n */\n get isEmpty(): boolean {\n return (this.layout as DockLayout).isEmpty;\n }\n\n /**\n * Create an iterator over the user widgets in the panel.\n *\n * @returns A new iterator over the user widgets in the panel.\n *\n * #### Notes\n * This iterator does not include the generated tab bars.\n */\n *widgets(): IterableIterator {\n yield* (this.layout as DockLayout).widgets();\n }\n\n /**\n * Create an iterator over the selected widgets in the panel.\n *\n * @returns A new iterator over the selected user widgets.\n *\n * #### Notes\n * This iterator yields the widgets corresponding to the current tab\n * of each tab bar in the panel.\n */\n *selectedWidgets(): IterableIterator {\n yield* (this.layout as DockLayout).selectedWidgets();\n }\n\n /**\n * Create an iterator over the tab bars in the panel.\n *\n * @returns A new iterator over the tab bars in the panel.\n *\n * #### Notes\n * This iterator does not include the user widgets.\n */\n *tabBars(): IterableIterator> {\n yield* (this.layout as DockLayout).tabBars();\n }\n\n /**\n * Create an iterator over the handles in the panel.\n *\n * @returns A new iterator over the handles in the panel.\n */\n *handles(): IterableIterator {\n yield* (this.layout as DockLayout).handles();\n }\n\n /**\n * Select a specific widget in the dock panel.\n *\n * @param widget - The widget of interest.\n *\n * #### Notes\n * This will make the widget the current widget in its tab area.\n */\n selectWidget(widget: Widget): void {\n // Find the tab bar which contains the widget.\n let tabBar = find(this.tabBars(), bar => {\n return bar.titles.indexOf(widget.title) !== -1;\n });\n\n // Throw an error if no tab bar is found.\n if (!tabBar) {\n throw new Error('Widget is not contained in the dock panel.');\n }\n\n // Ensure the widget is the current widget.\n tabBar.currentTitle = widget.title;\n }\n\n /**\n * Activate a specified widget in the dock panel.\n *\n * @param widget - The widget of interest.\n *\n * #### Notes\n * This will select and activate the given widget.\n */\n activateWidget(widget: Widget): void {\n this.selectWidget(widget);\n widget.activate();\n }\n\n /**\n * Save the current layout configuration of the dock panel.\n *\n * @returns A new config object for the current layout state.\n *\n * #### Notes\n * The return value can be provided to the `restoreLayout` method\n * in order to restore the layout to its current configuration.\n */\n saveLayout(): DockPanel.ILayoutConfig {\n return (this.layout as DockLayout).saveLayout();\n }\n\n /**\n * Restore the layout to a previously saved configuration.\n *\n * @param config - The layout configuration to restore.\n *\n * #### Notes\n * Widgets which currently belong to the layout but which are not\n * contained in the config will be unparented.\n *\n * The dock panel automatically reverts to `'multiple-document'`\n * mode when a layout config is restored.\n */\n restoreLayout(config: DockPanel.ILayoutConfig): void {\n // Reset the mode.\n this._mode = 'multiple-document';\n\n // Restore the layout.\n (this.layout as DockLayout).restoreLayout(config);\n\n // Flush the message loop on IE and Edge to prevent flicker.\n if (Platform.IS_EDGE || Platform.IS_IE) {\n MessageLoop.flush();\n }\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Add a widget to the dock panel.\n *\n * @param widget - The widget to add to the dock panel.\n *\n * @param options - The additional options for adding the widget.\n *\n * #### Notes\n * If the panel is in single document mode, the options are ignored\n * and the widget is always added as tab in the hidden tab bar.\n */\n addWidget(widget: Widget, options: DockPanel.IAddOptions = {}): void {\n // Add the widget to the layout.\n if (this._mode === 'single-document') {\n (this.layout as DockLayout).addWidget(widget);\n } else {\n (this.layout as DockLayout).addWidget(widget, options);\n }\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Process a message sent to the widget.\n *\n * @param msg - The message sent to the widget.\n */\n processMessage(msg: Message): void {\n if (msg.type === 'layout-modified') {\n this._layoutModified.emit(undefined);\n } else {\n super.processMessage(msg);\n }\n }\n\n /**\n * Handle the DOM events for the dock panel.\n *\n * @param event - The DOM event sent to the panel.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the panel's DOM node. It should\n * not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'lm-dragenter':\n this._evtDragEnter(event as Drag.Event);\n break;\n case 'lm-dragleave':\n this._evtDragLeave(event as Drag.Event);\n break;\n case 'lm-dragover':\n this._evtDragOver(event as Drag.Event);\n break;\n case 'lm-drop':\n this._evtDrop(event as Drag.Event);\n break;\n case 'pointerdown':\n this._evtPointerDown(event as PointerEvent);\n break;\n case 'pointermove':\n this._evtPointerMove(event as PointerEvent);\n break;\n case 'pointerup':\n this._evtPointerUp(event as PointerEvent);\n break;\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('lm-dragenter', this);\n this.node.addEventListener('lm-dragleave', this);\n this.node.addEventListener('lm-dragover', this);\n this.node.addEventListener('lm-drop', this);\n this.node.addEventListener('pointerdown', this);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('lm-dragenter', this);\n this.node.removeEventListener('lm-dragleave', this);\n this.node.removeEventListener('lm-dragover', this);\n this.node.removeEventListener('lm-drop', this);\n this.node.removeEventListener('pointerdown', this);\n this._releaseMouse();\n }\n\n /**\n * A message handler invoked on a `'child-added'` message.\n */\n protected onChildAdded(msg: Widget.ChildMessage): void {\n // Ignore the generated tab bars.\n if (Private.isGeneratedTabBarProperty.get(msg.child)) {\n return;\n }\n\n // Add the widget class to the child.\n msg.child.addClass('lm-DockPanel-widget');\n }\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {\n // Ignore the generated tab bars.\n if (Private.isGeneratedTabBarProperty.get(msg.child)) {\n return;\n }\n\n // Remove the widget class from the child.\n msg.child.removeClass('lm-DockPanel-widget');\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Handle the `'lm-dragenter'` event for the dock panel.\n */\n private _evtDragEnter(event: Drag.Event): void {\n // If the factory mime type is present, mark the event as\n // handled in order to get the rest of the drag events.\n if (event.mimeData.hasData('application/vnd.lumino.widget-factory')) {\n event.preventDefault();\n event.stopPropagation();\n }\n }\n\n /**\n * Handle the `'lm-dragleave'` event for the dock panel.\n */\n private _evtDragLeave(event: Drag.Event): void {\n // Mark the event as handled.\n event.preventDefault();\n\n if (this._tabsConstrained && event.source !== this) return;\n\n event.stopPropagation();\n\n // The new target might be a descendant, so we might still handle the drop.\n // Hide asynchronously so that if a lm-dragover event bubbles up to us, the\n // hide is cancelled by the lm-dragover handler's show overlay logic.\n this.overlay.hide(1);\n }\n\n /**\n * Handle the `'lm-dragover'` event for the dock panel.\n */\n private _evtDragOver(event: Drag.Event): void {\n // Mark the event as handled.\n event.preventDefault();\n\n // Show the drop indicator overlay and update the drop\n // action based on the drop target zone under the mouse.\n if (\n (this._tabsConstrained && event.source !== this) ||\n this._showOverlay(event.clientX, event.clientY) === 'invalid'\n ) {\n event.dropAction = 'none';\n } else {\n event.stopPropagation();\n event.dropAction = event.proposedAction;\n }\n }\n\n /**\n * Handle the `'lm-drop'` event for the dock panel.\n */\n private _evtDrop(event: Drag.Event): void {\n // Mark the event as handled.\n event.preventDefault();\n\n // Hide the drop indicator overlay.\n this.overlay.hide(0);\n\n // Bail if the proposed action is to do nothing.\n if (event.proposedAction === 'none') {\n event.dropAction = 'none';\n return;\n }\n\n // Find the drop target under the mouse.\n let { clientX, clientY } = event;\n let { zone, target } = Private.findDropTarget(\n this,\n clientX,\n clientY,\n this._edges\n );\n\n // Bail if the drop zone is invalid.\n if (\n (this._tabsConstrained && event.source !== this) ||\n zone === 'invalid'\n ) {\n event.dropAction = 'none';\n return;\n }\n\n // Bail if the factory mime type has invalid data.\n let mimeData = event.mimeData;\n let factory = mimeData.getData('application/vnd.lumino.widget-factory');\n if (typeof factory !== 'function') {\n event.dropAction = 'none';\n return;\n }\n\n // Bail if the factory does not produce a widget.\n let widget = factory();\n if (!(widget instanceof Widget)) {\n event.dropAction = 'none';\n return;\n }\n\n // Bail if the widget is an ancestor of the dock panel.\n if (widget.contains(this)) {\n event.dropAction = 'none';\n return;\n }\n\n // Find the reference widget for the drop target.\n let ref = target ? Private.getDropRef(target.tabBar) : null;\n\n // Add the widget according to the indicated drop zone.\n switch (zone) {\n case 'root-all':\n this.addWidget(widget);\n break;\n case 'root-top':\n this.addWidget(widget, { mode: 'split-top' });\n break;\n case 'root-left':\n this.addWidget(widget, { mode: 'split-left' });\n break;\n case 'root-right':\n this.addWidget(widget, { mode: 'split-right' });\n break;\n case 'root-bottom':\n this.addWidget(widget, { mode: 'split-bottom' });\n break;\n case 'widget-all':\n this.addWidget(widget, { mode: 'tab-after', ref });\n break;\n case 'widget-top':\n this.addWidget(widget, { mode: 'split-top', ref });\n break;\n case 'widget-left':\n this.addWidget(widget, { mode: 'split-left', ref });\n break;\n case 'widget-right':\n this.addWidget(widget, { mode: 'split-right', ref });\n break;\n case 'widget-bottom':\n this.addWidget(widget, { mode: 'split-bottom', ref });\n break;\n case 'widget-tab':\n this.addWidget(widget, { mode: 'tab-after', ref });\n break;\n default:\n throw 'unreachable';\n }\n\n // Accept the proposed drop action.\n event.dropAction = event.proposedAction;\n\n // Stop propagation if we have not bailed so far.\n event.stopPropagation();\n\n // Activate the dropped widget.\n this.activateWidget(widget);\n }\n\n /**\n * Handle the `'keydown'` event for the dock panel.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // Stop input events during drag.\n event.preventDefault();\n event.stopPropagation();\n\n // Release the mouse if `Escape` is pressed.\n if (event.keyCode === 27) {\n // Finalize the mouse release.\n this._releaseMouse();\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n }\n\n /**\n * Handle the `'pointerdown'` event for the dock panel.\n */\n private _evtPointerDown(event: PointerEvent): void {\n // Do nothing if the left mouse button is not pressed.\n if (event.button !== 0) {\n return;\n }\n\n // Find the handle which contains the mouse target, if any.\n let layout = this.layout as DockLayout;\n let target = event.target as HTMLElement;\n let handle = find(layout.handles(), handle => handle.contains(target));\n if (!handle) {\n return;\n }\n\n // Stop the event when a handle is pressed.\n event.preventDefault();\n event.stopPropagation();\n\n // Add the extra document listeners.\n this._document.addEventListener('keydown', this, true);\n this._document.addEventListener('pointerup', this, true);\n this._document.addEventListener('pointermove', this, true);\n this._document.addEventListener('contextmenu', this, true);\n\n // Compute the offset deltas for the handle press.\n let rect = handle.getBoundingClientRect();\n let deltaX = event.clientX - rect.left;\n let deltaY = event.clientY - rect.top;\n\n // Override the cursor and store the press data.\n let style = window.getComputedStyle(handle);\n let override = Drag.overrideCursor(style.cursor!, this._document);\n this._pressData = { handle, deltaX, deltaY, override };\n }\n\n /**\n * Handle the `'pointermove'` event for the dock panel.\n */\n private _evtPointerMove(event: PointerEvent): void {\n // Bail early if no drag is in progress.\n if (!this._pressData) {\n return;\n }\n\n // Stop the event when dragging a handle.\n event.preventDefault();\n event.stopPropagation();\n\n // Compute the desired offset position for the handle.\n let rect = this.node.getBoundingClientRect();\n let xPos = event.clientX - rect.left - this._pressData.deltaX;\n let yPos = event.clientY - rect.top - this._pressData.deltaY;\n\n // Set the handle as close to the desired position as possible.\n let layout = this.layout as DockLayout;\n layout.moveHandle(this._pressData.handle, xPos, yPos);\n }\n\n /**\n * Handle the `'pointerup'` event for the dock panel.\n */\n private _evtPointerUp(event: PointerEvent): void {\n // Do nothing if the left mouse button is not released.\n if (event.button !== 0) {\n return;\n }\n\n // Stop the event when releasing a handle.\n event.preventDefault();\n event.stopPropagation();\n\n // Finalize the mouse release.\n this._releaseMouse();\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Release the mouse grab for the dock panel.\n */\n private _releaseMouse(): void {\n // Bail early if no drag is in progress.\n if (!this._pressData) {\n return;\n }\n\n // Clear the override cursor.\n this._pressData.override.dispose();\n this._pressData = null;\n\n // Remove the extra document listeners.\n this._document.removeEventListener('keydown', this, true);\n this._document.removeEventListener('pointerup', this, true);\n this._document.removeEventListener('pointermove', this, true);\n this._document.removeEventListener('contextmenu', this, true);\n }\n\n /**\n * Show the overlay indicator at the given client position.\n *\n * Returns the drop zone at the specified client position.\n *\n * #### Notes\n * If the position is not over a valid zone, the overlay is hidden.\n */\n private _showOverlay(clientX: number, clientY: number): Private.DropZone {\n // Find the dock target for the given client position.\n let { zone, target } = Private.findDropTarget(\n this,\n clientX,\n clientY,\n this._edges\n );\n\n // If the drop zone is invalid, hide the overlay and bail.\n if (zone === 'invalid') {\n this.overlay.hide(100);\n return zone;\n }\n\n // Setup the variables needed to compute the overlay geometry.\n let top: number;\n let left: number;\n let right: number;\n let bottom: number;\n let box = ElementExt.boxSizing(this.node); // TODO cache this?\n let rect = this.node.getBoundingClientRect();\n\n // Compute the overlay geometry based on the dock zone.\n switch (zone) {\n case 'root-all':\n top = box.paddingTop;\n left = box.paddingLeft;\n right = box.paddingRight;\n bottom = box.paddingBottom;\n break;\n case 'root-top':\n top = box.paddingTop;\n left = box.paddingLeft;\n right = box.paddingRight;\n bottom = rect.height * Private.GOLDEN_RATIO;\n break;\n case 'root-left':\n top = box.paddingTop;\n left = box.paddingLeft;\n right = rect.width * Private.GOLDEN_RATIO;\n bottom = box.paddingBottom;\n break;\n case 'root-right':\n top = box.paddingTop;\n left = rect.width * Private.GOLDEN_RATIO;\n right = box.paddingRight;\n bottom = box.paddingBottom;\n break;\n case 'root-bottom':\n top = rect.height * Private.GOLDEN_RATIO;\n left = box.paddingLeft;\n right = box.paddingRight;\n bottom = box.paddingBottom;\n break;\n case 'widget-all':\n top = target!.top;\n left = target!.left;\n right = target!.right;\n bottom = target!.bottom;\n break;\n case 'widget-top':\n top = target!.top;\n left = target!.left;\n right = target!.right;\n bottom = target!.bottom + target!.height / 2;\n break;\n case 'widget-left':\n top = target!.top;\n left = target!.left;\n right = target!.right + target!.width / 2;\n bottom = target!.bottom;\n break;\n case 'widget-right':\n top = target!.top;\n left = target!.left + target!.width / 2;\n right = target!.right;\n bottom = target!.bottom;\n break;\n case 'widget-bottom':\n top = target!.top + target!.height / 2;\n left = target!.left;\n right = target!.right;\n bottom = target!.bottom;\n break;\n case 'widget-tab': {\n const tabHeight = target!.tabBar.node.getBoundingClientRect().height;\n top = target!.top;\n left = target!.left;\n right = target!.right;\n bottom = target!.bottom + target!.height - tabHeight;\n break;\n }\n default:\n throw 'unreachable';\n }\n\n // Show the overlay with the computed geometry.\n this.overlay.show({ top, left, right, bottom });\n\n // Finally, return the computed drop zone.\n return zone;\n }\n\n /**\n * Create a new tab bar for use by the panel.\n */\n private _createTabBar(): TabBar {\n // Create the tab bar.\n let tabBar = this._renderer.createTabBar(this._document);\n\n // Set the generated tab bar property for the tab bar.\n Private.isGeneratedTabBarProperty.set(tabBar, true);\n\n // Hide the tab bar when in single document mode.\n if (this._mode === 'single-document') {\n tabBar.hide();\n }\n\n // Enforce necessary tab bar behavior.\n // TODO do we really want to enforce *all* of these?\n tabBar.tabsMovable = this._tabsMovable;\n tabBar.allowDeselect = false;\n tabBar.addButtonEnabled = this._addButtonEnabled;\n tabBar.removeBehavior = 'select-previous-tab';\n tabBar.insertBehavior = 'select-tab-if-needed';\n\n // Connect the signal handlers for the tab bar.\n tabBar.tabMoved.connect(this._onTabMoved, this);\n tabBar.currentChanged.connect(this._onCurrentChanged, this);\n tabBar.tabCloseRequested.connect(this._onTabCloseRequested, this);\n tabBar.tabDetachRequested.connect(this._onTabDetachRequested, this);\n tabBar.tabActivateRequested.connect(this._onTabActivateRequested, this);\n tabBar.addRequested.connect(this._onTabAddRequested, this);\n\n // Return the initialized tab bar.\n return tabBar;\n }\n\n /**\n * Create a new handle for use by the panel.\n */\n private _createHandle(): HTMLDivElement {\n return this._renderer.createHandle();\n }\n\n /**\n * Handle the `tabMoved` signal from a tab bar.\n */\n private _onTabMoved(): void {\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Handle the `currentChanged` signal from a tab bar.\n */\n private _onCurrentChanged(\n sender: TabBar,\n args: TabBar.ICurrentChangedArgs\n ): void {\n // Extract the previous and current title from the args.\n let { previousTitle, currentTitle } = args;\n\n // Hide the previous widget.\n if (previousTitle) {\n previousTitle.owner.hide();\n }\n\n // Show the current widget.\n if (currentTitle) {\n currentTitle.owner.show();\n }\n\n // Flush the message loop on IE and Edge to prevent flicker.\n if (Platform.IS_EDGE || Platform.IS_IE) {\n MessageLoop.flush();\n }\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Handle the `addRequested` signal from a tab bar.\n */\n private _onTabAddRequested(sender: TabBar): void {\n this._addRequested.emit(sender);\n }\n\n /**\n * Handle the `tabActivateRequested` signal from a tab bar.\n */\n private _onTabActivateRequested(\n sender: TabBar,\n args: TabBar.ITabActivateRequestedArgs\n ): void {\n args.title.owner.activate();\n }\n\n /**\n * Handle the `tabCloseRequested` signal from a tab bar.\n */\n private _onTabCloseRequested(\n sender: TabBar,\n args: TabBar.ITabCloseRequestedArgs\n ): void {\n args.title.owner.close();\n }\n\n /**\n * Handle the `tabDetachRequested` signal from a tab bar.\n */\n private _onTabDetachRequested(\n sender: TabBar,\n args: TabBar.ITabDetachRequestedArgs\n ): void {\n // Do nothing if a drag is already in progress.\n if (this._drag) {\n return;\n }\n\n // Release the tab bar's hold on the mouse.\n sender.releaseMouse();\n\n // Extract the data from the args.\n let { title, tab, clientX, clientY, offset } = args;\n\n // Setup the mime data for the drag operation.\n let mimeData = new MimeData();\n let factory = () => title.owner;\n mimeData.setData('application/vnd.lumino.widget-factory', factory);\n\n // Create the drag image for the drag operation.\n let dragImage = tab.cloneNode(true) as HTMLElement;\n if (offset) {\n dragImage.style.top = `-${offset.y}px`;\n dragImage.style.left = `-${offset.x}px`;\n }\n\n // Create the drag object to manage the drag-drop operation.\n this._drag = new Drag({\n document: this._document,\n mimeData,\n dragImage,\n proposedAction: 'move',\n supportedActions: 'move',\n source: this\n });\n\n // Hide the tab node in the original tab.\n tab.classList.add('lm-mod-hidden');\n let cleanup = () => {\n this._drag = null;\n tab.classList.remove('lm-mod-hidden');\n };\n\n // Start the drag operation and cleanup when done.\n this._drag.start(clientX, clientY).then(cleanup);\n }\n\n private _edges: DockPanel.IEdges;\n private _document: Document | ShadowRoot;\n private _mode: DockPanel.Mode;\n private _drag: Drag | null = null;\n private _renderer: DockPanel.IRenderer;\n private _tabsMovable: boolean = true;\n private _tabsConstrained: boolean = false;\n private _addButtonEnabled: boolean = false;\n private _pressData: Private.IPressData | null = null;\n private _layoutModified = new Signal(this);\n\n private _addRequested = new Signal>(this);\n}\n\n/**\n * The namespace for the `DockPanel` class statics.\n */\nexport namespace DockPanel {\n /**\n * An options object for creating a dock panel.\n */\n export interface IOptions {\n /**\n * The document to use with the dock panel.\n *\n * The default is the global `document` instance.\n */\n\n document?: Document | ShadowRoot;\n /**\n * The overlay to use with the dock panel.\n *\n * The default is a new `Overlay` instance.\n */\n overlay?: IOverlay;\n\n /**\n * The renderer to use for the dock panel.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n\n /**\n * The spacing between the items in the panel.\n *\n * The default is `4`.\n */\n spacing?: number;\n\n /**\n * The mode for the dock panel.\n *\n * The default is `'multiple-document'`.\n */\n mode?: DockPanel.Mode;\n\n /**\n * The sizes of the edge drop zones, in pixels.\n * If not given, default values will be used.\n */\n edges?: IEdges;\n\n /**\n * The method for hiding widgets.\n *\n * The default is `Widget.HiddenMode.Display`.\n */\n hiddenMode?: Widget.HiddenMode;\n\n /**\n * Allow tabs to be draggable / movable by user.\n *\n * The default is `'true'`.\n */\n tabsMovable?: boolean;\n\n /**\n * Constrain tabs to this dock panel\n *\n * The default is `'false'`.\n */\n tabsConstrained?: boolean;\n\n /**\n * Enable add buttons in each of the dock panel's tab bars.\n *\n * The default is `'false'`.\n */\n addButtonEnabled?: boolean;\n }\n\n /**\n * The sizes of the edge drop zones, in pixels.\n */\n export interface IEdges {\n /**\n * The size of the top edge drop zone.\n */\n top: number;\n\n /**\n * The size of the right edge drop zone.\n */\n right: number;\n\n /**\n * The size of the bottom edge drop zone.\n */\n bottom: number;\n\n /**\n * The size of the left edge drop zone.\n */\n left: number;\n }\n\n /**\n * A type alias for the supported dock panel modes.\n */\n export type Mode =\n | /**\n * The single document mode.\n *\n * In this mode, only a single widget is visible at a time, and that\n * widget fills the available layout space. No tab bars are visible.\n */\n 'single-document'\n\n /**\n * The multiple document mode.\n *\n * In this mode, multiple documents are displayed in separate tab\n * areas, and those areas can be individually resized by the user.\n */\n | 'multiple-document';\n\n /**\n * A type alias for a layout configuration object.\n */\n export type ILayoutConfig = DockLayout.ILayoutConfig;\n\n /**\n * A type alias for the supported insertion modes.\n */\n export type InsertMode = DockLayout.InsertMode;\n\n /**\n * A type alias for the add widget options.\n */\n export type IAddOptions = DockLayout.IAddOptions;\n\n /**\n * An object which holds the geometry for overlay positioning.\n */\n export interface IOverlayGeometry {\n /**\n * The distance between the overlay and parent top edges.\n */\n top: number;\n\n /**\n * The distance between the overlay and parent left edges.\n */\n left: number;\n\n /**\n * The distance between the overlay and parent right edges.\n */\n right: number;\n\n /**\n * The distance between the overlay and parent bottom edges.\n */\n bottom: number;\n }\n\n /**\n * An object which manages the overlay node for a dock panel.\n */\n export interface IOverlay {\n /**\n * The DOM node for the overlay.\n */\n readonly node: HTMLDivElement;\n\n /**\n * Show the overlay using the given overlay geometry.\n *\n * @param geo - The desired geometry for the overlay.\n *\n * #### Notes\n * The given geometry values assume the node will use absolute\n * positioning.\n *\n * This is called on every mouse move event during a drag in order\n * to update the position of the overlay. It should be efficient.\n */\n show(geo: IOverlayGeometry): void;\n\n /**\n * Hide the overlay node.\n *\n * @param delay - The delay (in ms) before hiding the overlay.\n * A delay value <= 0 should hide the overlay immediately.\n *\n * #### Notes\n * This is called whenever the overlay node should been hidden.\n */\n hide(delay: number): void;\n }\n\n /**\n * A concrete implementation of `IOverlay`.\n *\n * This is the default overlay implementation for a dock panel.\n */\n export class Overlay implements IOverlay {\n /**\n * Construct a new overlay.\n */\n constructor() {\n this.node = document.createElement('div');\n this.node.classList.add('lm-DockPanel-overlay');\n this.node.classList.add('lm-mod-hidden');\n this.node.style.position = 'absolute';\n this.node.style.contain = 'strict';\n }\n\n /**\n * The DOM node for the overlay.\n */\n readonly node: HTMLDivElement;\n\n /**\n * Show the overlay using the given overlay geometry.\n *\n * @param geo - The desired geometry for the overlay.\n */\n show(geo: IOverlayGeometry): void {\n // Update the position of the overlay.\n let style = this.node.style;\n style.top = `${geo.top}px`;\n style.left = `${geo.left}px`;\n style.right = `${geo.right}px`;\n style.bottom = `${geo.bottom}px`;\n\n // Clear any pending hide timer.\n clearTimeout(this._timer);\n this._timer = -1;\n\n // If the overlay is already visible, we're done.\n if (!this._hidden) {\n return;\n }\n\n // Clear the hidden flag.\n this._hidden = false;\n\n // Finally, show the overlay.\n this.node.classList.remove('lm-mod-hidden');\n }\n\n /**\n * Hide the overlay node.\n *\n * @param delay - The delay (in ms) before hiding the overlay.\n * A delay value <= 0 will hide the overlay immediately.\n */\n hide(delay: number): void {\n // Do nothing if the overlay is already hidden.\n if (this._hidden) {\n return;\n }\n\n // Hide immediately if the delay is <= 0.\n if (delay <= 0) {\n clearTimeout(this._timer);\n this._timer = -1;\n this._hidden = true;\n this.node.classList.add('lm-mod-hidden');\n return;\n }\n\n // Do nothing if a hide is already pending.\n if (this._timer !== -1) {\n return;\n }\n\n // Otherwise setup the hide timer.\n this._timer = window.setTimeout(() => {\n this._timer = -1;\n this._hidden = true;\n this.node.classList.add('lm-mod-hidden');\n }, delay);\n }\n\n private _timer = -1;\n private _hidden = true;\n }\n\n /**\n * A type alias for a dock panel renderer;\n */\n export type IRenderer = DockLayout.IRenderer;\n\n /**\n * The default implementation of `IRenderer`.\n */\n export class Renderer implements IRenderer {\n /**\n * Create a new tab bar for use with a dock panel.\n *\n * @returns A new tab bar for a dock panel.\n */\n createTabBar(document?: Document | ShadowRoot): TabBar {\n let bar = new TabBar({ document });\n bar.addClass('lm-DockPanel-tabBar');\n return bar;\n }\n\n /**\n * Create a new handle node for use with a dock panel.\n *\n * @returns A new handle node for a dock panel.\n */\n createHandle(): HTMLDivElement {\n let handle = document.createElement('div');\n handle.className = 'lm-DockPanel-handle';\n return handle;\n }\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * A fraction used for sizing root panels; ~= `1 / golden_ratio`.\n */\n export const GOLDEN_RATIO = 0.618;\n\n /**\n * The default sizes for the edge drop zones, in pixels.\n */\n export const DEFAULT_EDGES = {\n /**\n * The size of the top edge dock zone for the root panel, in pixels.\n * This is different from the others to distinguish between the top\n * tab bar and the top root zone.\n */\n top: 12,\n\n /**\n * The size of the edge dock zone for the root panel, in pixels.\n */\n right: 40,\n\n /**\n * The size of the edge dock zone for the root panel, in pixels.\n */\n bottom: 40,\n\n /**\n * The size of the edge dock zone for the root panel, in pixels.\n */\n left: 40\n };\n\n /**\n * A singleton `'layout-modified'` conflatable message.\n */\n export const LayoutModified = new ConflatableMessage('layout-modified');\n\n /**\n * An object which holds mouse press data.\n */\n export interface IPressData {\n /**\n * The handle which was pressed.\n */\n handle: HTMLDivElement;\n\n /**\n * The X offset of the press in handle coordinates.\n */\n deltaX: number;\n\n /**\n * The Y offset of the press in handle coordinates.\n */\n deltaY: number;\n\n /**\n * The disposable which will clear the override cursor.\n */\n override: IDisposable;\n }\n\n /**\n * A type alias for a drop zone.\n */\n export type DropZone =\n | /**\n * An invalid drop zone.\n */\n 'invalid'\n\n /**\n * The entirety of the root dock area.\n */\n | 'root-all'\n\n /**\n * The top portion of the root dock area.\n */\n | 'root-top'\n\n /**\n * The left portion of the root dock area.\n */\n | 'root-left'\n\n /**\n * The right portion of the root dock area.\n */\n | 'root-right'\n\n /**\n * The bottom portion of the root dock area.\n */\n | 'root-bottom'\n\n /**\n * The entirety of a tabbed widget area.\n */\n | 'widget-all'\n\n /**\n * The top portion of tabbed widget area.\n */\n | 'widget-top'\n\n /**\n * The left portion of tabbed widget area.\n */\n | 'widget-left'\n\n /**\n * The right portion of tabbed widget area.\n */\n | 'widget-right'\n\n /**\n * The bottom portion of tabbed widget area.\n */\n | 'widget-bottom'\n\n /**\n * The the bar of a tabbed widget area.\n */\n | 'widget-tab';\n\n /**\n * An object which holds the drop target zone and widget.\n */\n export interface IDropTarget {\n /**\n * The semantic zone for the mouse position.\n */\n zone: DropZone;\n\n /**\n * The tab area geometry for the drop zone, or `null`.\n */\n target: DockLayout.ITabAreaGeometry | null;\n }\n\n /**\n * An attached property used to track generated tab bars.\n */\n export const isGeneratedTabBarProperty = new AttachedProperty<\n Widget,\n boolean\n >({\n name: 'isGeneratedTabBar',\n create: () => false\n });\n\n /**\n * Create a single document config for the widgets in a dock panel.\n */\n export function createSingleDocumentConfig(\n panel: DockPanel\n ): DockPanel.ILayoutConfig {\n // Return an empty config if the panel is empty.\n if (panel.isEmpty) {\n return { main: null };\n }\n\n // Get a flat array of the widgets in the panel.\n let widgets = Array.from(panel.widgets());\n\n // Get the first selected widget in the panel.\n let selected = panel.selectedWidgets().next().value;\n\n // Compute the current index for the new config.\n let currentIndex = selected ? widgets.indexOf(selected) : -1;\n\n // Return the single document config.\n return { main: { type: 'tab-area', widgets, currentIndex } };\n }\n\n /**\n * Find the drop target at the given client position.\n */\n export function findDropTarget(\n panel: DockPanel,\n clientX: number,\n clientY: number,\n edges: DockPanel.IEdges\n ): IDropTarget {\n // Bail if the mouse is not over the dock panel.\n if (!ElementExt.hitTest(panel.node, clientX, clientY)) {\n return { zone: 'invalid', target: null };\n }\n\n // Look up the layout for the panel.\n let layout = panel.layout as DockLayout;\n\n // If the layout is empty, indicate the entire root drop zone.\n if (layout.isEmpty) {\n return { zone: 'root-all', target: null };\n }\n\n // Test the edge zones when in multiple document mode.\n if (panel.mode === 'multiple-document') {\n // Get the client rect for the dock panel.\n let panelRect = panel.node.getBoundingClientRect();\n\n // Compute the distance to each edge of the panel.\n let pl = clientX - panelRect.left + 1;\n let pt = clientY - panelRect.top + 1;\n let pr = panelRect.right - clientX;\n let pb = panelRect.bottom - clientY;\n\n // Find the minimum distance to an edge.\n let pd = Math.min(pt, pr, pb, pl);\n\n // Return a root zone if the mouse is within an edge.\n switch (pd) {\n case pt:\n if (pt < edges.top) {\n return { zone: 'root-top', target: null };\n }\n break;\n case pr:\n if (pr < edges.right) {\n return { zone: 'root-right', target: null };\n }\n break;\n case pb:\n if (pb < edges.bottom) {\n return { zone: 'root-bottom', target: null };\n }\n break;\n case pl:\n if (pl < edges.left) {\n return { zone: 'root-left', target: null };\n }\n break;\n default:\n throw 'unreachable';\n }\n }\n\n // Hit test the dock layout at the given client position.\n let target = layout.hitTestTabAreas(clientX, clientY);\n\n // Bail if no target area was found.\n if (!target) {\n return { zone: 'invalid', target: null };\n }\n\n // Return the whole tab area when in single document mode.\n if (panel.mode === 'single-document') {\n return { zone: 'widget-all', target };\n }\n\n // Compute the distance to each edge of the tab area.\n let al = target.x - target.left + 1;\n let at = target.y - target.top + 1;\n let ar = target.left + target.width - target.x;\n let ab = target.top + target.height - target.y;\n\n const tabHeight = target.tabBar.node.getBoundingClientRect().height;\n if (at < tabHeight) {\n return { zone: 'widget-tab', target };\n }\n\n // Get the X and Y edge sizes for the area.\n let rx = Math.round(target.width / 3);\n let ry = Math.round(target.height / 3);\n\n // If the mouse is not within an edge, indicate the entire area.\n if (al > rx && ar > rx && at > ry && ab > ry) {\n return { zone: 'widget-all', target };\n }\n\n // Scale the distances by the slenderness ratio.\n al /= rx;\n at /= ry;\n ar /= rx;\n ab /= ry;\n\n // Find the minimum distance to the area edge.\n let ad = Math.min(al, at, ar, ab);\n\n // Find the widget zone for the area edge.\n let zone: DropZone;\n switch (ad) {\n case al:\n zone = 'widget-left';\n break;\n case at:\n zone = 'widget-top';\n break;\n case ar:\n zone = 'widget-right';\n break;\n case ab:\n zone = 'widget-bottom';\n break;\n default:\n throw 'unreachable';\n }\n\n // Return the final drop target.\n return { zone, target };\n }\n\n /**\n * Get the drop reference widget for a tab bar.\n */\n export function getDropRef(tabBar: TabBar): Widget | null {\n if (tabBar.titles.length === 0) {\n return null;\n }\n if (tabBar.currentTitle) {\n return tabBar.currentTitle.owner;\n }\n return tabBar.titles[tabBar.titles.length - 1].owner;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt, find, max } from '@lumino/algorithm';\n\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { Widget } from './widget';\n\n/**\n * A class which tracks focus among a set of widgets.\n *\n * This class is useful when code needs to keep track of the most\n * recently focused widget(s) among a set of related widgets.\n */\nexport class FocusTracker implements IDisposable {\n /**\n * Dispose of the resources held by the tracker.\n */\n dispose(): void {\n // Do nothing if the tracker is already disposed.\n if (this._counter < 0) {\n return;\n }\n\n // Mark the tracker as disposed.\n this._counter = -1;\n\n // Clear the connections for the tracker.\n Signal.clearData(this);\n\n // Remove all event listeners.\n for (const widget of this._widgets) {\n widget.node.removeEventListener('focus', this, true);\n widget.node.removeEventListener('blur', this, true);\n }\n\n // Clear the internal data structures.\n this._activeWidget = null;\n this._currentWidget = null;\n this._nodes.clear();\n this._numbers.clear();\n this._widgets.length = 0;\n }\n\n /**\n * A signal emitted when the current widget has changed.\n */\n get currentChanged(): ISignal> {\n return this._currentChanged;\n }\n\n /**\n * A signal emitted when the active widget has changed.\n */\n get activeChanged(): ISignal> {\n return this._activeChanged;\n }\n\n /**\n * A flag indicating whether the tracker is disposed.\n */\n get isDisposed(): boolean {\n return this._counter < 0;\n }\n\n /**\n * The current widget in the tracker.\n *\n * #### Notes\n * The current widget is the widget among the tracked widgets which\n * has the *descendant node* which has most recently been focused.\n *\n * The current widget will not be updated if the node loses focus. It\n * will only be updated when a different tracked widget gains focus.\n *\n * If the current widget is removed from the tracker, the previous\n * current widget will be restored.\n *\n * This behavior is intended to follow a user's conceptual model of\n * a semantically \"current\" widget, where the \"last thing of type X\"\n * to be interacted with is the \"current instance of X\", regardless\n * of whether that instance still has focus.\n */\n get currentWidget(): T | null {\n return this._currentWidget;\n }\n\n /**\n * The active widget in the tracker.\n *\n * #### Notes\n * The active widget is the widget among the tracked widgets which\n * has the *descendant node* which is currently focused.\n */\n get activeWidget(): T | null {\n return this._activeWidget;\n }\n\n /**\n * A read only array of the widgets being tracked.\n */\n get widgets(): ReadonlyArray {\n return this._widgets;\n }\n\n /**\n * Get the focus number for a particular widget in the tracker.\n *\n * @param widget - The widget of interest.\n *\n * @returns The focus number for the given widget, or `-1` if the\n * widget has not had focus since being added to the tracker, or\n * is not contained by the tracker.\n *\n * #### Notes\n * The focus number indicates the relative order in which the widgets\n * have gained focus. A widget with a larger number has gained focus\n * more recently than a widget with a smaller number.\n *\n * The `currentWidget` will always have the largest focus number.\n *\n * All widgets start with a focus number of `-1`, which indicates that\n * the widget has not been focused since being added to the tracker.\n */\n focusNumber(widget: T): number {\n let n = this._numbers.get(widget);\n return n === undefined ? -1 : n;\n }\n\n /**\n * Test whether the focus tracker contains a given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns `true` if the widget is tracked, `false` otherwise.\n */\n has(widget: T): boolean {\n return this._numbers.has(widget);\n }\n\n /**\n * Add a widget to the focus tracker.\n *\n * @param widget - The widget of interest.\n *\n * #### Notes\n * A widget will be automatically removed from the tracker if it\n * is disposed after being added.\n *\n * If the widget is already tracked, this is a no-op.\n */\n add(widget: T): void {\n // Do nothing if the widget is already tracked.\n if (this._numbers.has(widget)) {\n return;\n }\n\n // Test whether the widget has focus.\n let focused = widget.node.contains(document.activeElement);\n\n // Set up the initial focus number.\n let n = focused ? this._counter++ : -1;\n\n // Add the widget to the internal data structures.\n this._widgets.push(widget);\n this._numbers.set(widget, n);\n this._nodes.set(widget.node, widget);\n\n // Set up the event listeners. The capturing phase must be used\n // since the 'focus' and 'blur' events don't bubble and Firefox\n // doesn't support the 'focusin' or 'focusout' events.\n widget.node.addEventListener('focus', this, true);\n widget.node.addEventListener('blur', this, true);\n\n // Connect the disposed signal handler.\n widget.disposed.connect(this._onWidgetDisposed, this);\n\n // Set the current and active widgets if needed.\n if (focused) {\n this._setWidgets(widget, widget);\n }\n }\n\n /**\n * Remove a widget from the focus tracker.\n *\n * #### Notes\n * If the widget is the `currentWidget`, the previous current widget\n * will become the new `currentWidget`.\n *\n * A widget will be automatically removed from the tracker if it\n * is disposed after being added.\n *\n * If the widget is not tracked, this is a no-op.\n */\n remove(widget: T): void {\n // Bail early if the widget is not tracked.\n if (!this._numbers.has(widget)) {\n return;\n }\n\n // Disconnect the disposed signal handler.\n widget.disposed.disconnect(this._onWidgetDisposed, this);\n\n // Remove the event listeners.\n widget.node.removeEventListener('focus', this, true);\n widget.node.removeEventListener('blur', this, true);\n\n // Remove the widget from the internal data structures.\n ArrayExt.removeFirstOf(this._widgets, widget);\n this._nodes.delete(widget.node);\n this._numbers.delete(widget);\n\n // Bail early if the widget is not the current widget.\n if (this._currentWidget !== widget) {\n return;\n }\n\n // Filter the widgets for those which have had focus.\n let valid = this._widgets.filter(w => this._numbers.get(w) !== -1);\n\n // Get the valid widget with the max focus number.\n let previous =\n max(valid, (first, second) => {\n let a = this._numbers.get(first)!;\n let b = this._numbers.get(second)!;\n return a - b;\n }) || null;\n\n // Set the current and active widgets.\n this._setWidgets(previous, null);\n }\n\n /**\n * Handle the DOM events for the focus tracker.\n *\n * @param event - The DOM event sent to the panel.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the tracked nodes. It should\n * not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'focus':\n this._evtFocus(event as FocusEvent);\n break;\n case 'blur':\n this._evtBlur(event as FocusEvent);\n break;\n }\n }\n\n /**\n * Set the current and active widgets for the tracker.\n */\n private _setWidgets(current: T | null, active: T | null): void {\n // Swap the current widget.\n let oldCurrent = this._currentWidget;\n this._currentWidget = current;\n\n // Swap the active widget.\n let oldActive = this._activeWidget;\n this._activeWidget = active;\n\n // Emit the `currentChanged` signal if needed.\n if (oldCurrent !== current) {\n this._currentChanged.emit({ oldValue: oldCurrent, newValue: current });\n }\n\n // Emit the `activeChanged` signal if needed.\n if (oldActive !== active) {\n this._activeChanged.emit({ oldValue: oldActive, newValue: active });\n }\n }\n\n /**\n * Handle the `'focus'` event for a tracked widget.\n */\n private _evtFocus(event: FocusEvent): void {\n // Find the widget which gained focus, which is known to exist.\n let widget = this._nodes.get(event.currentTarget as HTMLElement)!;\n\n // Update the focus number if necessary.\n if (widget !== this._currentWidget) {\n this._numbers.set(widget, this._counter++);\n }\n\n // Set the current and active widgets.\n this._setWidgets(widget, widget);\n }\n\n /**\n * Handle the `'blur'` event for a tracked widget.\n */\n private _evtBlur(event: FocusEvent): void {\n // Find the widget which lost focus, which is known to exist.\n let widget = this._nodes.get(event.currentTarget as HTMLElement)!;\n\n // Get the node which being focused after this blur.\n let focusTarget = event.relatedTarget as HTMLElement;\n\n // If no other node is being focused, clear the active widget.\n if (!focusTarget) {\n this._setWidgets(this._currentWidget, null);\n return;\n }\n\n // Bail if the focus widget is not changing.\n if (widget.node.contains(focusTarget)) {\n return;\n }\n\n // If no tracked widget is being focused, clear the active widget.\n if (!find(this._widgets, w => w.node.contains(focusTarget))) {\n this._setWidgets(this._currentWidget, null);\n return;\n }\n }\n\n /**\n * Handle the `disposed` signal for a tracked widget.\n */\n private _onWidgetDisposed(sender: T): void {\n this.remove(sender);\n }\n\n private _counter = 0;\n private _widgets: T[] = [];\n private _activeWidget: T | null = null;\n private _currentWidget: T | null = null;\n private _numbers = new Map();\n private _nodes = new Map();\n private _activeChanged = new Signal>(this);\n private _currentChanged = new Signal>(\n this\n );\n}\n\n/**\n * The namespace for the `FocusTracker` class statics.\n */\nexport namespace FocusTracker {\n /**\n * An arguments object for the changed signals.\n */\n export interface IChangedArgs {\n /**\n * The old value for the widget.\n */\n oldValue: T | null;\n\n /**\n * The new value for the widget.\n */\n newValue: T | null;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { BoxEngine, BoxSizer } from './boxengine';\n\nimport { Layout, LayoutItem } from './layout';\n\nimport { Widget } from './widget';\n\n/**\n * A layout which arranges its widgets in a grid.\n */\nexport class GridLayout extends Layout {\n /**\n * Construct a new grid layout.\n *\n * @param options - The options for initializing the layout.\n */\n constructor(options: GridLayout.IOptions = {}) {\n super(options);\n if (options.rowCount !== undefined) {\n Private.reallocSizers(this._rowSizers, options.rowCount);\n }\n if (options.columnCount !== undefined) {\n Private.reallocSizers(this._columnSizers, options.columnCount);\n }\n if (options.rowSpacing !== undefined) {\n this._rowSpacing = Private.clampValue(options.rowSpacing);\n }\n if (options.columnSpacing !== undefined) {\n this._columnSpacing = Private.clampValue(options.columnSpacing);\n }\n }\n\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n // Dispose of the widgets and layout items.\n for (const item of this._items) {\n let widget = item.widget;\n item.dispose();\n widget.dispose();\n }\n\n // Clear the layout state.\n this._box = null;\n this._items.length = 0;\n this._rowStarts.length = 0;\n this._rowSizers.length = 0;\n this._columnStarts.length = 0;\n this._columnSizers.length = 0;\n\n // Dispose of the rest of the layout.\n super.dispose();\n }\n\n /**\n * Get the number of rows in the layout.\n */\n get rowCount(): number {\n return this._rowSizers.length;\n }\n\n /**\n * Set the number of rows in the layout.\n *\n * #### Notes\n * The minimum row count is `1`.\n */\n set rowCount(value: number) {\n // Do nothing if the row count does not change.\n if (value === this.rowCount) {\n return;\n }\n\n // Reallocate the row sizers.\n Private.reallocSizers(this._rowSizers, value);\n\n // Schedule a fit of the parent.\n if (this.parent) {\n this.parent.fit();\n }\n }\n\n /**\n * Get the number of columns in the layout.\n */\n get columnCount(): number {\n return this._columnSizers.length;\n }\n\n /**\n * Set the number of columns in the layout.\n *\n * #### Notes\n * The minimum column count is `1`.\n */\n set columnCount(value: number) {\n // Do nothing if the column count does not change.\n if (value === this.columnCount) {\n return;\n }\n\n // Reallocate the column sizers.\n Private.reallocSizers(this._columnSizers, value);\n\n // Schedule a fit of the parent.\n if (this.parent) {\n this.parent.fit();\n }\n }\n\n /**\n * Get the row spacing for the layout.\n */\n get rowSpacing(): number {\n return this._rowSpacing;\n }\n\n /**\n * Set the row spacing for the layout.\n */\n set rowSpacing(value: number) {\n // Clamp the spacing to the allowed range.\n value = Private.clampValue(value);\n\n // Bail if the spacing does not change\n if (this._rowSpacing === value) {\n return;\n }\n\n // Update the internal spacing.\n this._rowSpacing = value;\n\n // Schedule a fit of the parent.\n if (this.parent) {\n this.parent.fit();\n }\n }\n\n /**\n * Get the column spacing for the layout.\n */\n get columnSpacing(): number {\n return this._columnSpacing;\n }\n\n /**\n * Set the col spacing for the layout.\n */\n set columnSpacing(value: number) {\n // Clamp the spacing to the allowed range.\n value = Private.clampValue(value);\n\n // Bail if the spacing does not change\n if (this._columnSpacing === value) {\n return;\n }\n\n // Update the internal spacing.\n this._columnSpacing = value;\n\n // Schedule a fit of the parent.\n if (this.parent) {\n this.parent.fit();\n }\n }\n\n /**\n * Get the stretch factor for a specific row.\n *\n * @param index - The row index of interest.\n *\n * @returns The stretch factor for the row.\n *\n * #### Notes\n * This returns `-1` if the index is out of range.\n */\n rowStretch(index: number): number {\n let sizer = this._rowSizers[index];\n return sizer ? sizer.stretch : -1;\n }\n\n /**\n * Set the stretch factor for a specific row.\n *\n * @param index - The row index of interest.\n *\n * @param value - The stretch factor for the row.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n setRowStretch(index: number, value: number): void {\n // Look up the row sizer.\n let sizer = this._rowSizers[index];\n\n // Bail if the index is out of range.\n if (!sizer) {\n return;\n }\n\n // Clamp the value to the allowed range.\n value = Private.clampValue(value);\n\n // Bail if the stretch does not change.\n if (sizer.stretch === value) {\n return;\n }\n\n // Update the sizer stretch.\n sizer.stretch = value;\n\n // Schedule an update of the parent.\n if (this.parent) {\n this.parent.update();\n }\n }\n\n /**\n * Get the stretch factor for a specific column.\n *\n * @param index - The column index of interest.\n *\n * @returns The stretch factor for the column.\n *\n * #### Notes\n * This returns `-1` if the index is out of range.\n */\n columnStretch(index: number): number {\n let sizer = this._columnSizers[index];\n return sizer ? sizer.stretch : -1;\n }\n\n /**\n * Set the stretch factor for a specific column.\n *\n * @param index - The column index of interest.\n *\n * @param value - The stretch factor for the column.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n setColumnStretch(index: number, value: number): void {\n // Look up the column sizer.\n let sizer = this._columnSizers[index];\n\n // Bail if the index is out of range.\n if (!sizer) {\n return;\n }\n\n // Clamp the value to the allowed range.\n value = Private.clampValue(value);\n\n // Bail if the stretch does not change.\n if (sizer.stretch === value) {\n return;\n }\n\n // Update the sizer stretch.\n sizer.stretch = value;\n\n // Schedule an update of the parent.\n if (this.parent) {\n this.parent.update();\n }\n }\n\n /**\n * Create an iterator over the widgets in the layout.\n *\n * @returns A new iterator over the widgets in the layout.\n */\n *[Symbol.iterator](): IterableIterator {\n for (const item of this._items) {\n yield item.widget;\n }\n }\n\n /**\n * Add a widget to the grid layout.\n *\n * @param widget - The widget to add to the layout.\n *\n * #### Notes\n * If the widget is already contained in the layout, this is no-op.\n */\n addWidget(widget: Widget): void {\n // Look up the index for the widget.\n let i = ArrayExt.findFirstIndex(this._items, it => it.widget === widget);\n\n // Bail if the widget is already in the layout.\n if (i !== -1) {\n return;\n }\n\n // Add the widget to the layout.\n this._items.push(new LayoutItem(widget));\n\n // Attach the widget to the parent.\n if (this.parent) {\n this.attachWidget(widget);\n }\n }\n\n /**\n * Remove a widget from the grid layout.\n *\n * @param widget - The widget to remove from the layout.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method does *not* modify the widget's `parent`.\n */\n removeWidget(widget: Widget): void {\n // Look up the index for the widget.\n let i = ArrayExt.findFirstIndex(this._items, it => it.widget === widget);\n\n // Bail if the widget is not in the layout.\n if (i === -1) {\n return;\n }\n\n // Remove the widget from the layout.\n let item = ArrayExt.removeAt(this._items, i)!;\n\n // Detach the widget from the parent.\n if (this.parent) {\n this.detachWidget(widget);\n }\n\n // Dispose the layout item.\n item.dispose();\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n super.init();\n for (const widget of this) {\n this.attachWidget(widget);\n }\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param widget - The widget to attach to the parent.\n */\n protected attachWidget(widget: Widget): void {\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget's node to the parent.\n this.parent!.node.appendChild(widget.node);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param widget - The widget to detach from the parent.\n */\n protected detachWidget(widget: Widget): void {\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n */\n protected onBeforeShow(msg: Message): void {\n super.onBeforeShow(msg);\n this.parent!.update();\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n super.onBeforeAttach(msg);\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n if (this.parent!.isVisible) {\n this._update(msg.width, msg.height);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.parent!.isVisible) {\n this._update(-1, -1);\n }\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n */\n protected onFitRequest(msg: Message): void {\n if (this.parent!.isAttached) {\n this._fit();\n }\n }\n\n /**\n * Fit the layout to the total size required by the widgets.\n */\n private _fit(): void {\n // Reset the min sizes of the sizers.\n for (let i = 0, n = this.rowCount; i < n; ++i) {\n this._rowSizers[i].minSize = 0;\n }\n for (let i = 0, n = this.columnCount; i < n; ++i) {\n this._columnSizers[i].minSize = 0;\n }\n\n // Filter for the visible layout items.\n let items = this._items.filter(it => !it.isHidden);\n\n // Fit the layout items.\n for (let i = 0, n = items.length; i < n; ++i) {\n items[i].fit();\n }\n\n // Get the max row and column index.\n let maxRow = this.rowCount - 1;\n let maxCol = this.columnCount - 1;\n\n // Sort the items by row span.\n items.sort(Private.rowSpanCmp);\n\n // Update the min sizes of the row sizers.\n for (let i = 0, n = items.length; i < n; ++i) {\n // Fetch the item.\n let item = items[i];\n\n // Get the row bounds for the item.\n let config = GridLayout.getCellConfig(item.widget);\n let r1 = Math.min(config.row, maxRow);\n let r2 = Math.min(config.row + config.rowSpan - 1, maxRow);\n\n // Distribute the minimum height to the sizers as needed.\n Private.distributeMin(this._rowSizers, r1, r2, item.minHeight);\n }\n\n // Sort the items by column span.\n items.sort(Private.columnSpanCmp);\n\n // Update the min sizes of the column sizers.\n for (let i = 0, n = items.length; i < n; ++i) {\n // Fetch the item.\n let item = items[i];\n\n // Get the column bounds for the item.\n let config = GridLayout.getCellConfig(item.widget);\n let c1 = Math.min(config.column, maxCol);\n let c2 = Math.min(config.column + config.columnSpan - 1, maxCol);\n\n // Distribute the minimum width to the sizers as needed.\n Private.distributeMin(this._columnSizers, c1, c2, item.minWidth);\n }\n\n // If no size constraint is needed, just update the parent.\n if (this.fitPolicy === 'set-no-constraint') {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n return;\n }\n\n // Set up the computed min size.\n let minH = maxRow * this._rowSpacing;\n let minW = maxCol * this._columnSpacing;\n\n // Add the sizer minimums to the computed min size.\n for (let i = 0, n = this.rowCount; i < n; ++i) {\n minH += this._rowSizers[i].minSize;\n }\n for (let i = 0, n = this.columnCount; i < n; ++i) {\n minW += this._columnSizers[i].minSize;\n }\n\n // Update the box sizing and add it to the computed min size.\n let box = (this._box = ElementExt.boxSizing(this.parent!.node));\n minW += box.horizontalSum;\n minH += box.verticalSum;\n\n // Update the parent's min size constraints.\n let style = this.parent!.node.style;\n style.minWidth = `${minW}px`;\n style.minHeight = `${minH}px`;\n\n // Set the dirty flag to ensure only a single update occurs.\n this._dirty = true;\n\n // Notify the ancestor that it should fit immediately. This may\n // cause a resize of the parent, fulfilling the required update.\n if (this.parent!.parent) {\n MessageLoop.sendMessage(this.parent!.parent!, Widget.Msg.FitRequest);\n }\n\n // If the dirty flag is still set, the parent was not resized.\n // Trigger the required update on the parent widget immediately.\n if (this._dirty) {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n }\n }\n\n /**\n * Update the layout position and size of the widgets.\n *\n * The parent offset dimensions should be `-1` if unknown.\n */\n private _update(offsetWidth: number, offsetHeight: number): void {\n // Clear the dirty flag to indicate the update occurred.\n this._dirty = false;\n\n // Measure the parent if the offset dimensions are unknown.\n if (offsetWidth < 0) {\n offsetWidth = this.parent!.node.offsetWidth;\n }\n if (offsetHeight < 0) {\n offsetHeight = this.parent!.node.offsetHeight;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent!.node);\n }\n\n // Compute the layout area adjusted for border and padding.\n let top = this._box.paddingTop;\n let left = this._box.paddingLeft;\n let width = offsetWidth - this._box.horizontalSum;\n let height = offsetHeight - this._box.verticalSum;\n\n // Get the max row and column index.\n let maxRow = this.rowCount - 1;\n let maxCol = this.columnCount - 1;\n\n // Compute the total fixed row and column space.\n let fixedRowSpace = maxRow * this._rowSpacing;\n let fixedColSpace = maxCol * this._columnSpacing;\n\n // Distribute the available space to the box sizers.\n BoxEngine.calc(this._rowSizers, Math.max(0, height - fixedRowSpace));\n BoxEngine.calc(this._columnSizers, Math.max(0, width - fixedColSpace));\n\n // Update the row start positions.\n for (let i = 0, pos = top, n = this.rowCount; i < n; ++i) {\n this._rowStarts[i] = pos;\n pos += this._rowSizers[i].size + this._rowSpacing;\n }\n\n // Update the column start positions.\n for (let i = 0, pos = left, n = this.columnCount; i < n; ++i) {\n this._columnStarts[i] = pos;\n pos += this._columnSizers[i].size + this._columnSpacing;\n }\n\n // Update the geometry of the layout items.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item.\n let item = this._items[i];\n\n // Ignore hidden items.\n if (item.isHidden) {\n continue;\n }\n\n // Fetch the cell bounds for the widget.\n let config = GridLayout.getCellConfig(item.widget);\n let r1 = Math.min(config.row, maxRow);\n let c1 = Math.min(config.column, maxCol);\n let r2 = Math.min(config.row + config.rowSpan - 1, maxRow);\n let c2 = Math.min(config.column + config.columnSpan - 1, maxCol);\n\n // Compute the cell geometry.\n let x = this._columnStarts[c1];\n let y = this._rowStarts[r1];\n let w = this._columnStarts[c2] + this._columnSizers[c2].size - x;\n let h = this._rowStarts[r2] + this._rowSizers[r2].size - y;\n\n // Update the geometry of the layout item.\n item.update(x, y, w, h);\n }\n }\n\n private _dirty = false;\n private _rowSpacing = 4;\n private _columnSpacing = 4;\n private _items: LayoutItem[] = [];\n private _rowStarts: number[] = [];\n private _columnStarts: number[] = [];\n private _rowSizers: BoxSizer[] = [new BoxSizer()];\n private _columnSizers: BoxSizer[] = [new BoxSizer()];\n private _box: ElementExt.IBoxSizing | null = null;\n}\n\n/**\n * The namespace for the `GridLayout` class statics.\n */\nexport namespace GridLayout {\n /**\n * An options object for initializing a grid layout.\n */\n export interface IOptions extends Layout.IOptions {\n /**\n * The initial row count for the layout.\n *\n * The default is `1`.\n */\n rowCount?: number;\n\n /**\n * The initial column count for the layout.\n *\n * The default is `1`.\n */\n columnCount?: number;\n\n /**\n * The spacing between rows in the layout.\n *\n * The default is `4`.\n */\n rowSpacing?: number;\n\n /**\n * The spacing between columns in the layout.\n *\n * The default is `4`.\n */\n columnSpacing?: number;\n }\n\n /**\n * An object which holds the cell configuration for a widget.\n */\n export interface ICellConfig {\n /**\n * The row index for the widget.\n */\n readonly row: number;\n\n /**\n * The column index for the widget.\n */\n readonly column: number;\n\n /**\n * The row span for the widget.\n */\n readonly rowSpan: number;\n\n /**\n * The column span for the widget.\n */\n readonly columnSpan: number;\n }\n\n /**\n * Get the cell config for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The cell config for the widget.\n */\n export function getCellConfig(widget: Widget): ICellConfig {\n return Private.cellConfigProperty.get(widget);\n }\n\n /**\n * Set the cell config for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the cell config.\n */\n export function setCellConfig(\n widget: Widget,\n value: Partial\n ): void {\n Private.cellConfigProperty.set(widget, Private.normalizeConfig(value));\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The property descriptor for the widget cell config.\n */\n export const cellConfigProperty = new AttachedProperty<\n Widget,\n GridLayout.ICellConfig\n >({\n name: 'cellConfig',\n create: () => ({ row: 0, column: 0, rowSpan: 1, columnSpan: 1 }),\n changed: onChildCellConfigChanged\n });\n\n /**\n * Normalize a partial cell config object.\n */\n export function normalizeConfig(\n config: Partial\n ): GridLayout.ICellConfig {\n let row = Math.max(0, Math.floor(config.row || 0));\n let column = Math.max(0, Math.floor(config.column || 0));\n let rowSpan = Math.max(1, Math.floor(config.rowSpan || 0));\n let columnSpan = Math.max(1, Math.floor(config.columnSpan || 0));\n return { row, column, rowSpan, columnSpan };\n }\n\n /**\n * Clamp a value to an integer >= 0.\n */\n export function clampValue(value: number): number {\n return Math.max(0, Math.floor(value));\n }\n\n /**\n * A sort comparison function for row spans.\n */\n export function rowSpanCmp(a: LayoutItem, b: LayoutItem): number {\n let c1 = cellConfigProperty.get(a.widget);\n let c2 = cellConfigProperty.get(b.widget);\n return c1.rowSpan - c2.rowSpan;\n }\n\n /**\n * A sort comparison function for column spans.\n */\n export function columnSpanCmp(a: LayoutItem, b: LayoutItem): number {\n let c1 = cellConfigProperty.get(a.widget);\n let c2 = cellConfigProperty.get(b.widget);\n return c1.columnSpan - c2.columnSpan;\n }\n\n /**\n * Reallocate the box sizers for the given grid dimensions.\n */\n export function reallocSizers(sizers: BoxSizer[], count: number): void {\n // Coerce the count to the valid range.\n count = Math.max(1, Math.floor(count));\n\n // Add the missing sizers.\n while (sizers.length < count) {\n sizers.push(new BoxSizer());\n }\n\n // Remove the extra sizers.\n if (sizers.length > count) {\n sizers.length = count;\n }\n }\n\n /**\n * Distribute a min size constraint across a range of sizers.\n */\n export function distributeMin(\n sizers: BoxSizer[],\n i1: number,\n i2: number,\n minSize: number\n ): void {\n // Sanity check the indices.\n if (i2 < i1) {\n return;\n }\n\n // Handle the simple case of no cell span.\n if (i1 === i2) {\n let sizer = sizers[i1];\n sizer.minSize = Math.max(sizer.minSize, minSize);\n return;\n }\n\n // Compute the total current min size of the span.\n let totalMin = 0;\n for (let i = i1; i <= i2; ++i) {\n totalMin += sizers[i].minSize;\n }\n\n // Do nothing if the total is greater than the required.\n if (totalMin >= minSize) {\n return;\n }\n\n // Compute the portion of the space to allocate to each sizer.\n let portion = (minSize - totalMin) / (i2 - i1 + 1);\n\n // Add the portion to each sizer.\n for (let i = i1; i <= i2; ++i) {\n sizers[i].minSize += portion;\n }\n }\n\n /**\n * The change handler for the child cell config property.\n */\n function onChildCellConfigChanged(child: Widget): void {\n if (child.parent && child.parent.layout instanceof GridLayout) {\n child.parent.fit();\n }\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { getKeyboardLayout } from '@lumino/keyboard';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { CommandRegistry } from '@lumino/commands';\n\nimport {\n ElementARIAAttrs,\n ElementDataset,\n h,\n VirtualDOM,\n VirtualElement\n} from '@lumino/virtualdom';\n\nimport { Menu } from './menu';\n\nimport { Title } from './title';\n\nimport { Widget } from './widget';\n\n/**\n * A widget which displays menus as a canonical menu bar.\n */\nexport class MenuBar extends Widget {\n /**\n * Construct a new menu bar.\n *\n * @param options - The options for initializing the menu bar.\n */\n constructor(options: MenuBar.IOptions = {}) {\n super({ node: Private.createNode() });\n this.addClass('lm-MenuBar');\n this.setFlag(Widget.Flag.DisallowLayout);\n this.renderer = options.renderer || MenuBar.defaultRenderer;\n this._forceItemsPosition = options.forceItemsPosition || {\n forceX: true,\n forceY: true\n };\n this._overflowMenuOptions = options.overflowMenuOptions || {\n isVisible: true\n };\n }\n\n /**\n * Dispose of the resources held by the widget.\n */\n dispose(): void {\n this._closeChildMenu();\n this._menus.length = 0;\n super.dispose();\n }\n\n /**\n * The renderer used by the menu bar.\n */\n readonly renderer: MenuBar.IRenderer;\n\n /**\n * The child menu of the menu bar.\n *\n * #### Notes\n * This will be `null` if the menu bar does not have an open menu.\n */\n get childMenu(): Menu | null {\n return this._childMenu;\n }\n\n /**\n * The overflow index of the menu bar.\n */\n get overflowIndex(): number {\n return this._overflowIndex;\n }\n\n /**\n * The overflow menu of the menu bar.\n */\n get overflowMenu(): Menu | null {\n return this._overflowMenu;\n }\n\n /**\n * Get the menu bar content node.\n *\n * #### Notes\n * This is the node which holds the menu title nodes.\n *\n * Modifying this node directly can lead to undefined behavior.\n */\n get contentNode(): HTMLUListElement {\n return this.node.getElementsByClassName(\n 'lm-MenuBar-content'\n )[0] as HTMLUListElement;\n }\n\n /**\n * Get the currently active menu.\n */\n get activeMenu(): Menu | null {\n return this._menus[this._activeIndex] || null;\n }\n\n /**\n * Set the currently active menu.\n *\n * #### Notes\n * If the menu does not exist, the menu will be set to `null`.\n */\n set activeMenu(value: Menu | null) {\n this.activeIndex = value ? this._menus.indexOf(value) : -1;\n }\n\n /**\n * Get the index of the currently active menu.\n *\n * #### Notes\n * This will be `-1` if no menu is active.\n */\n get activeIndex(): number {\n return this._activeIndex;\n }\n\n /**\n * Set the index of the currently active menu.\n *\n * #### Notes\n * If the menu cannot be activated, the index will be set to `-1`.\n */\n set activeIndex(value: number) {\n // Adjust the value for an out of range index.\n if (value < 0 || value >= this._menus.length) {\n value = -1;\n }\n\n // An empty menu cannot be active\n if (value > -1 && this._menus[value].items.length === 0) {\n value = -1;\n }\n\n // Bail early if the index will not change.\n if (this._activeIndex === value) {\n return;\n }\n\n // Update the active index.\n this._activeIndex = value;\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * A read-only array of the menus in the menu bar.\n */\n get menus(): ReadonlyArray {\n return this._menus;\n }\n\n /**\n * Open the active menu and activate its first menu item.\n *\n * #### Notes\n * If there is no active menu, this is a no-op.\n */\n openActiveMenu(): void {\n // Bail early if there is no active item.\n if (this._activeIndex === -1) {\n return;\n }\n\n // Open the child menu.\n this._openChildMenu();\n\n // Activate the first item in the child menu.\n if (this._childMenu) {\n this._childMenu.activeIndex = -1;\n this._childMenu.activateNextItem();\n }\n }\n\n /**\n * Add a menu to the end of the menu bar.\n *\n * @param menu - The menu to add to the menu bar.\n *\n * #### Notes\n * If the menu is already added to the menu bar, it will be moved.\n */\n addMenu(menu: Menu, update: boolean = true): void {\n this.insertMenu(this._menus.length, menu, update);\n }\n\n /**\n * Insert a menu into the menu bar at the specified index.\n *\n * @param index - The index at which to insert the menu.\n *\n * @param menu - The menu to insert into the menu bar.\n *\n * #### Notes\n * The index will be clamped to the bounds of the menus.\n *\n * If the menu is already added to the menu bar, it will be moved.\n */\n insertMenu(index: number, menu: Menu, update: boolean = true): void {\n // Close the child menu before making changes.\n this._closeChildMenu();\n\n // Look up the index of the menu.\n let i = this._menus.indexOf(menu);\n\n // Clamp the insert index to the array bounds.\n let j = Math.max(0, Math.min(index, this._menus.length));\n\n // If the menu is not in the array, insert it.\n if (i === -1) {\n // Insert the menu into the array.\n ArrayExt.insert(this._menus, j, menu);\n\n // Add the styling class to the menu.\n menu.addClass('lm-MenuBar-menu');\n\n // Connect to the menu signals.\n menu.aboutToClose.connect(this._onMenuAboutToClose, this);\n menu.menuRequested.connect(this._onMenuMenuRequested, this);\n menu.title.changed.connect(this._onTitleChanged, this);\n\n // Schedule an update of the items.\n if (update) {\n this.update();\n }\n\n // There is nothing more to do.\n return;\n }\n\n // Otherwise, the menu exists in the array and should be moved.\n\n // Adjust the index if the location is at the end of the array.\n if (j === this._menus.length) {\n j--;\n }\n\n // Bail if there is no effective move.\n if (i === j) {\n return;\n }\n\n // Move the menu to the new locations.\n ArrayExt.move(this._menus, i, j);\n\n // Schedule an update of the items.\n if (update) {\n this.update();\n }\n }\n\n /**\n * Remove a menu from the menu bar.\n *\n * @param menu - The menu to remove from the menu bar.\n *\n * #### Notes\n * This is a no-op if the menu is not in the menu bar.\n */\n removeMenu(menu: Menu, update: boolean = true): void {\n this.removeMenuAt(this._menus.indexOf(menu), update);\n }\n\n /**\n * Remove the menu at a given index from the menu bar.\n *\n * @param index - The index of the menu to remove.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n removeMenuAt(index: number, update: boolean = true): void {\n // Close the child menu before making changes.\n this._closeChildMenu();\n\n // Remove the menu from the array.\n let menu = ArrayExt.removeAt(this._menus, index);\n\n // Bail if the index is out of range.\n if (!menu) {\n return;\n }\n\n // Disconnect from the menu signals.\n menu.aboutToClose.disconnect(this._onMenuAboutToClose, this);\n menu.menuRequested.disconnect(this._onMenuMenuRequested, this);\n menu.title.changed.disconnect(this._onTitleChanged, this);\n\n // Remove the styling class from the menu.\n menu.removeClass('lm-MenuBar-menu');\n\n // Schedule an update of the items.\n if (update) {\n this.update();\n }\n }\n\n /**\n * Remove all menus from the menu bar.\n */\n clearMenus(): void {\n // Bail if there is nothing to remove.\n if (this._menus.length === 0) {\n return;\n }\n\n // Close the child menu before making changes.\n this._closeChildMenu();\n\n // Disconnect from the menu signals and remove the styling class.\n for (let menu of this._menus) {\n menu.aboutToClose.disconnect(this._onMenuAboutToClose, this);\n menu.menuRequested.disconnect(this._onMenuMenuRequested, this);\n menu.title.changed.disconnect(this._onTitleChanged, this);\n menu.removeClass('lm-MenuBar-menu');\n }\n\n // Clear the menus array.\n this._menus.length = 0;\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * Handle the DOM events for the menu bar.\n *\n * @param event - The DOM event sent to the menu bar.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the menu bar's DOM nodes. It\n * should not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'mousedown':\n this._evtMouseDown(event as MouseEvent);\n break;\n case 'mousemove':\n this._evtMouseMove(event as MouseEvent);\n break;\n case 'focusout':\n this._evtFocusOut(event as FocusEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('keydown', this);\n this.node.addEventListener('mousedown', this);\n this.node.addEventListener('mousemove', this);\n this.node.addEventListener('focusout', this);\n this.node.addEventListener('contextmenu', this);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('keydown', this);\n this.node.removeEventListener('mousedown', this);\n this.node.removeEventListener('mousemove', this);\n this.node.removeEventListener('focusout', this);\n this.node.removeEventListener('contextmenu', this);\n this._closeChildMenu();\n }\n\n /**\n * A message handler invoked on an `'activate-request'` message.\n */\n protected onActivateRequest(msg: Message): void {\n if (this.isAttached) {\n this._focusItemAt(0);\n }\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n this.update();\n super.onResize(msg);\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n let menus = this._menus;\n let renderer = this.renderer;\n let activeIndex = this._activeIndex;\n let tabFocusIndex =\n this._tabFocusIndex >= 0 && this._tabFocusIndex < menus.length\n ? this._tabFocusIndex\n : 0;\n let length = this._overflowIndex > -1 ? this._overflowIndex : menus.length;\n let totalMenuSize = 0;\n let isVisible = false;\n\n // Check that the overflow menu doesn't count\n length = this._overflowMenu !== null ? length - 1 : length;\n let content = new Array(length);\n\n // Render visible menus\n for (let i = 0; i < length; ++i) {\n content[i] = renderer.renderItem({\n title: menus[i].title,\n active: i === activeIndex,\n tabbable: i === tabFocusIndex,\n disabled: menus[i].items.length === 0,\n onfocus: () => {\n this._tabFocusIndex = i;\n this.activeIndex = i;\n }\n });\n // Calculate size of current menu\n totalMenuSize += this._menuItemSizes[i];\n // Check if overflow menu is already rendered\n if (menus[i].title.label === this._overflowMenuOptions.title) {\n isVisible = true;\n length--;\n }\n }\n // Render overflow menu if needed and active\n if (this._overflowMenuOptions.isVisible) {\n if (this._overflowIndex > -1 && !isVisible) {\n // Create overflow menu\n if (this._overflowMenu === null) {\n const overflowMenuTitle = this._overflowMenuOptions.title ?? '...';\n this._overflowMenu = new Menu({ commands: new CommandRegistry() });\n this._overflowMenu.title.label = overflowMenuTitle;\n this._overflowMenu.title.mnemonic = 0;\n this.addMenu(this._overflowMenu, false);\n }\n // Move menus to overflow menu\n for (let i = menus.length - 2; i >= length; i--) {\n const submenu = this.menus[i];\n submenu.title.mnemonic = 0;\n this._overflowMenu.insertItem(0, {\n type: 'submenu',\n submenu: submenu\n });\n this.removeMenu(submenu, false);\n }\n content[length] = renderer.renderItem({\n title: this._overflowMenu.title,\n active: length === activeIndex && menus[length].items.length !== 0,\n tabbable: length === tabFocusIndex,\n disabled: menus[length].items.length === 0,\n onfocus: () => {\n this._tabFocusIndex = length;\n this.activeIndex = length;\n }\n });\n length++;\n } else if (this._overflowMenu !== null) {\n // Remove submenus from overflow menu\n let overflowMenuItems = this._overflowMenu.items;\n let screenSize = this.node.offsetWidth;\n let n = this._overflowMenu.items.length;\n for (let i = 0; i < n; ++i) {\n let index = menus.length - 1 - i;\n if (screenSize - totalMenuSize > this._menuItemSizes[index]) {\n let menu = overflowMenuItems[0].submenu as Menu;\n this._overflowMenu.removeItemAt(0);\n this.insertMenu(length, menu, false);\n content[length] = renderer.renderItem({\n title: menu.title,\n active: false,\n tabbable: length === tabFocusIndex,\n disabled: menus[length].items.length === 0,\n onfocus: () => {\n this._tabFocusIndex = length;\n this.activeIndex = length;\n }\n });\n length++;\n }\n }\n if (this._overflowMenu.items.length === 0) {\n this.removeMenu(this._overflowMenu, false);\n content.pop();\n this._overflowMenu = null;\n this._overflowIndex = -1;\n }\n }\n }\n VirtualDOM.render(content, this.contentNode);\n this._updateOverflowIndex();\n }\n\n /**\n * Calculate and update the current overflow index.\n */\n private _updateOverflowIndex(): void {\n if (!this._overflowMenuOptions.isVisible) {\n return;\n }\n\n // Get elements visible in the main menu bar\n const itemMenus = this.contentNode.childNodes;\n let screenSize = this.node.offsetWidth;\n let totalMenuSize = 0;\n let index = -1;\n let n = itemMenus.length;\n\n if (this._menuItemSizes.length == 0) {\n // Check if it is the first resize and get info about menu items sizes\n for (let i = 0; i < n; i++) {\n let item = itemMenus[i] as HTMLLIElement;\n // Add sizes to array\n totalMenuSize += item.offsetWidth;\n this._menuItemSizes.push(item.offsetWidth);\n if (totalMenuSize > screenSize && index === -1) {\n index = i;\n }\n }\n } else {\n // Calculate current menu size\n for (let i = 0; i < this._menuItemSizes.length; i++) {\n totalMenuSize += this._menuItemSizes[i];\n if (totalMenuSize > screenSize) {\n index = i;\n break;\n }\n }\n }\n this._overflowIndex = index;\n }\n\n /**\n * Handle the `'keydown'` event for the menu bar.\n *\n * #### Notes\n * All keys are trapped except the tab key that is ignored.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // Fetch the key code for the event.\n let kc = event.keyCode;\n\n // Reset the active index on tab, but do not trap the tab key.\n if (kc === 9) {\n this.activeIndex = -1;\n return;\n }\n\n // A menu bar handles all other keydown events.\n event.preventDefault();\n event.stopPropagation();\n\n // Enter, Space, Up Arrow, Down Arrow\n if (kc === 13 || kc === 32 || kc === 38 || kc === 40) {\n // The active index may have changed (for example, user hovers over an\n // item with the mouse), so be sure to use the focus index.\n this.activeIndex = this._tabFocusIndex;\n if (this.activeIndex !== this._tabFocusIndex) {\n // Bail if the setter refused to set activeIndex to tabFocusIndex\n // because it means that the item at tabFocusIndex cannot be opened (for\n // example, it has an empty menu)\n return;\n }\n this.openActiveMenu();\n return;\n }\n\n // Escape\n if (kc === 27) {\n this._closeChildMenu();\n this._focusItemAt(this.activeIndex);\n return;\n }\n\n // Left or Right Arrow\n if (kc === 37 || kc === 39) {\n let direction = kc === 37 ? -1 : 1;\n let start = this._tabFocusIndex + direction;\n let n = this._menus.length;\n for (let i = 0; i < n; i++) {\n let index = (n + start + direction * i) % n;\n if (this._menus[index].items.length) {\n this._focusItemAt(index);\n return;\n }\n }\n return;\n }\n\n // Get the pressed key character.\n let key = getKeyboardLayout().keyForKeydownEvent(event);\n\n // Bail if the key is not valid.\n if (!key) {\n return;\n }\n\n // Search for the next best matching mnemonic item.\n let start = this._activeIndex + 1;\n let result = Private.findMnemonic(this._menus, key, start);\n\n // Handle the requested mnemonic based on the search results.\n // If exactly one mnemonic is matched, that menu is opened.\n // Otherwise, the next mnemonic is activated if available,\n // followed by the auto mnemonic if available.\n if (result.index !== -1 && !result.multiple) {\n this.activeIndex = result.index;\n this.openActiveMenu();\n } else if (result.index !== -1) {\n this.activeIndex = result.index;\n this._focusItemAt(this.activeIndex);\n } else if (result.auto !== -1) {\n this.activeIndex = result.auto;\n this._focusItemAt(this.activeIndex);\n }\n }\n\n /**\n * Handle the `'mousedown'` event for the menu bar.\n */\n private _evtMouseDown(event: MouseEvent): void {\n // Bail if the mouse press was not on the menu bar. This can occur\n // when the document listener is installed for an active menu bar.\n if (!ElementExt.hitTest(this.node, event.clientX, event.clientY)) {\n return;\n }\n\n // Stop the propagation of the event. Immediate propagation is\n // also stopped so that an open menu does not handle the event.\n event.stopPropagation();\n event.stopImmediatePropagation();\n\n // Check if the mouse is over one of the menu items.\n let index = ArrayExt.findFirstIndex(this.contentNode.children, node => {\n return ElementExt.hitTest(node, event.clientX, event.clientY);\n });\n\n // If the press was not on an item, close the child menu.\n if (index === -1) {\n this._closeChildMenu();\n return;\n }\n\n // If the press was not the left mouse button, do nothing further.\n if (event.button !== 0) {\n return;\n }\n\n // Otherwise, toggle the open state of the child menu.\n if (this._childMenu) {\n this._closeChildMenu();\n this.activeIndex = index;\n } else {\n // If we don't call preventDefault() here, then the item in the menu\n // bar will take focus over the menu that is being opened.\n event.preventDefault();\n const position = this._positionForMenu(index);\n Menu.saveWindowData();\n // Begin DOM modifications.\n this.activeIndex = index;\n this._openChildMenu(position);\n }\n }\n\n /**\n * Handle the `'mousemove'` event for the menu bar.\n */\n private _evtMouseMove(event: MouseEvent): void {\n // Check if the mouse is over one of the menu items.\n let index = ArrayExt.findFirstIndex(this.contentNode.children, node => {\n return ElementExt.hitTest(node, event.clientX, event.clientY);\n });\n\n // Bail early if the active index will not change.\n if (index === this._activeIndex) {\n return;\n }\n\n // Bail early if a child menu is open and the mouse is not over\n // an item. This allows the child menu to be kept open when the\n // mouse is over the empty part of the menu bar.\n if (index === -1 && this._childMenu) {\n return;\n }\n\n // Get position for the new menu >before< updating active index.\n const position =\n index >= 0 && this._childMenu ? this._positionForMenu(index) : null;\n\n // Before any modification, update window data.\n Menu.saveWindowData();\n\n // Begin DOM modifications.\n\n // Update the active index to the hovered item.\n this.activeIndex = index;\n\n // Open the new menu if a menu is already open.\n if (position) {\n this._openChildMenu(position);\n }\n }\n\n /**\n * Find initial position for the menu based on menubar item position.\n *\n * NOTE: this should be called before updating active index to avoid\n * an additional layout and style invalidation as changing active\n * index modifies DOM.\n */\n private _positionForMenu(index: number): Private.IPosition {\n let itemNode = this.contentNode.children[index];\n let { left, bottom } = (itemNode as HTMLElement).getBoundingClientRect();\n return {\n top: bottom,\n left\n };\n }\n\n /**\n * Handle the `'focusout'` event for the menu bar.\n */\n private _evtFocusOut(event: FocusEvent): void {\n // Reset the active index if there is no open menu and the menubar is losing focus.\n if (!this._childMenu && !this.node.contains(event.relatedTarget as Node)) {\n this.activeIndex = -1;\n }\n }\n\n /**\n * Focus an item in the menu bar.\n *\n * #### Notes\n * Does not open the associated menu.\n */\n private _focusItemAt(index: number): void {\n const itemNode = this.contentNode.childNodes[index] as HTMLElement | void;\n if (itemNode) {\n itemNode.focus();\n }\n }\n\n /**\n * Open the child menu at the active index immediately.\n *\n * If a different child menu is already open, it will be closed,\n * even if there is no active menu.\n */\n private _openChildMenu(options: { left?: number; top?: number } = {}): void {\n // If there is no active menu, close the current menu.\n let newMenu = this.activeMenu;\n if (!newMenu) {\n this._closeChildMenu();\n return;\n }\n\n // Bail if there is no effective menu change.\n let oldMenu = this._childMenu;\n if (oldMenu === newMenu) {\n return;\n }\n\n // Swap the internal menu reference.\n this._childMenu = newMenu;\n\n // Close the current menu, or setup for the new menu.\n if (oldMenu) {\n oldMenu.close();\n } else {\n document.addEventListener('mousedown', this, true);\n }\n\n // Update the tab focus index and ensure the menu bar is updated.\n this._tabFocusIndex = this.activeIndex;\n MessageLoop.sendMessage(this, Widget.Msg.UpdateRequest);\n\n // Get the positioning data for the new menu.\n let { left, top } = options;\n if (typeof left === 'undefined' || typeof top === 'undefined') {\n ({ left, top } = this._positionForMenu(this._activeIndex));\n }\n // Begin DOM modifications\n\n if (!oldMenu) {\n // Continue setup for new menu\n this.addClass('lm-mod-active');\n }\n\n // Open the new menu at the computed location.\n if (newMenu.items.length > 0) {\n newMenu.open(left, top, this._forceItemsPosition);\n }\n }\n\n /**\n * Close the child menu immediately.\n *\n * This is a no-op if a child menu is not open.\n */\n private _closeChildMenu(): void {\n // Bail if no child menu is open.\n if (!this._childMenu) {\n return;\n }\n // Remove the active class from the menu bar.\n this.removeClass('lm-mod-active');\n\n // Remove the document listeners.\n document.removeEventListener('mousedown', this, true);\n\n // Clear the internal menu reference.\n let menu = this._childMenu;\n this._childMenu = null;\n\n // Close the menu.\n menu.close();\n\n // Reset the active index.\n this.activeIndex = -1;\n }\n\n /**\n * Handle the `aboutToClose` signal of a menu.\n */\n private _onMenuAboutToClose(sender: Menu): void {\n // Bail if the sender is not the child menu.\n if (sender !== this._childMenu) {\n return;\n }\n\n // Remove the active class from the menu bar.\n this.removeClass('lm-mod-active');\n\n // Remove the document listeners.\n document.removeEventListener('mousedown', this, true);\n\n // Clear the internal menu reference.\n this._childMenu = null;\n\n // Reset the active index.\n this.activeIndex = -1;\n }\n\n /**\n * Handle the `menuRequested` signal of a child menu.\n */\n private _onMenuMenuRequested(sender: Menu, args: 'next' | 'previous'): void {\n // Bail if the sender is not the child menu.\n if (sender !== this._childMenu) {\n return;\n }\n\n // Look up the active index and menu count.\n let i = this._activeIndex;\n let n = this._menus.length;\n\n // Active the next requested index.\n switch (args) {\n case 'next':\n this.activeIndex = i === n - 1 ? 0 : i + 1;\n break;\n case 'previous':\n this.activeIndex = i === 0 ? n - 1 : i - 1;\n break;\n }\n\n // Open the active menu.\n this.openActiveMenu();\n }\n\n /**\n * Handle the `changed` signal of a title object.\n */\n private _onTitleChanged(): void {\n this.update();\n }\n\n // Track the index of the item that is currently focused or hovered. -1 means nothing focused or hovered.\n private _activeIndex = -1;\n // Track which item can be focused using the TAB key. Unlike _activeIndex will\n // always point to a menuitem. Whenever you update this value, it's important\n // to follow it with an \"update-request\" message so that the `tabindex`\n // attribute on each menubar item gets properly updated.\n private _tabFocusIndex = 0;\n private _forceItemsPosition: Menu.IOpenOptions;\n private _overflowMenuOptions: IOverflowMenuOptions;\n private _menus: Menu[] = [];\n private _childMenu: Menu | null = null;\n private _overflowMenu: Menu | null = null;\n private _menuItemSizes: number[] = [];\n private _overflowIndex: number = -1;\n}\n\n/**\n * The namespace for the `MenuBar` class statics.\n */\nexport namespace MenuBar {\n /**\n * An options object for creating a menu bar.\n */\n export interface IOptions {\n /**\n * A custom renderer for creating menu bar content.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n /**\n * Whether to force the position of the menu. The MenuBar forces the\n * coordinates of its menus by default. With this option you can disable it.\n *\n * Setting to `false` will enable the logic which repositions the\n * coordinates of the menu if it will not fit entirely on screen.\n *\n * The default is `true`.\n */\n forceItemsPosition?: Menu.IOpenOptions;\n /**\n * Whether to add a overflow menu if there's overflow.\n *\n * Setting to `true` will enable the logic that creates an overflow menu\n * to show the menu items that don't fit entirely on the screen.\n *\n * The default is `true`.\n */\n overflowMenuOptions?: IOverflowMenuOptions;\n }\n\n /**\n * An object which holds the data to render a menu bar item.\n */\n export interface IRenderData {\n /**\n * The title to be rendered.\n */\n readonly title: Title;\n\n /**\n * Whether the item is the active item.\n */\n readonly active: boolean;\n\n /**\n * Whether the user can tab to the item.\n */\n readonly tabbable: boolean;\n\n /**\n * Whether the item is disabled.\n *\n * #### Notes\n * A disabled item cannot be active.\n * A disabled item cannot be focussed.\n */\n readonly disabled?: boolean;\n\n readonly onfocus?: (event: FocusEvent) => void;\n }\n\n /**\n * A renderer for use with a menu bar.\n */\n export interface IRenderer {\n /**\n * Render the virtual element for a menu bar item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n */\n renderItem(data: IRenderData): VirtualElement;\n }\n\n /**\n * The default implementation of `IRenderer`.\n *\n * #### Notes\n * Subclasses are free to reimplement rendering methods as needed.\n */\n export class Renderer implements IRenderer {\n /**\n * Render the virtual element for a menu bar item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n */\n renderItem(data: IRenderData): VirtualElement {\n let className = this.createItemClass(data);\n let dataset = this.createItemDataset(data);\n let aria = this.createItemARIA(data);\n return h.li(\n {\n className,\n dataset,\n ...(data.disabled ? {} : { tabindex: data.tabbable ? '0' : '-1' }),\n onfocus: data.onfocus,\n ...aria\n },\n this.renderIcon(data),\n this.renderLabel(data)\n );\n }\n\n /**\n * Render the icon element for a menu bar item.\n *\n * @param data - The data to use for rendering the icon.\n *\n * @returns A virtual element representing the item icon.\n */\n renderIcon(data: IRenderData): VirtualElement {\n let className = this.createIconClass(data);\n\n // If data.title.icon is undefined, it will be ignored.\n return h.div({ className }, data.title.icon!, data.title.iconLabel);\n }\n\n /**\n * Render the label element for a menu item.\n *\n * @param data - The data to use for rendering the label.\n *\n * @returns A virtual element representing the item label.\n */\n renderLabel(data: IRenderData): VirtualElement {\n let content = this.formatLabel(data);\n return h.div({ className: 'lm-MenuBar-itemLabel' }, content);\n }\n\n /**\n * Create the class name for the menu bar item.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the menu item.\n */\n createItemClass(data: IRenderData): string {\n let name = 'lm-MenuBar-item';\n if (data.title.className) {\n name += ` ${data.title.className}`;\n }\n if (data.active && !data.disabled) {\n name += ' lm-mod-active';\n }\n return name;\n }\n\n /**\n * Create the dataset for a menu bar item.\n *\n * @param data - The data to use for the item.\n *\n * @returns The dataset for the menu bar item.\n */\n createItemDataset(data: IRenderData): ElementDataset {\n return data.title.dataset;\n }\n\n /**\n * Create the aria attributes for menu bar item.\n *\n * @param data - The data to use for the aria attributes.\n *\n * @returns The aria attributes object for the item.\n */\n createItemARIA(data: IRenderData): ElementARIAAttrs {\n return {\n role: 'menuitem',\n 'aria-haspopup': 'true',\n 'aria-disabled': data.disabled ? 'true' : 'false'\n };\n }\n\n /**\n * Create the class name for the menu bar item icon.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the item icon.\n */\n createIconClass(data: IRenderData): string {\n let name = 'lm-MenuBar-itemIcon';\n let extra = data.title.iconClass;\n return extra ? `${name} ${extra}` : name;\n }\n\n /**\n * Create the render content for the label node.\n *\n * @param data - The data to use for the label content.\n *\n * @returns The content to add to the label node.\n */\n formatLabel(data: IRenderData): h.Child {\n // Fetch the label text and mnemonic index.\n let { label, mnemonic } = data.title;\n\n // If the index is out of range, do not modify the label.\n if (mnemonic < 0 || mnemonic >= label.length) {\n return label;\n }\n\n // Split the label into parts.\n let prefix = label.slice(0, mnemonic);\n let suffix = label.slice(mnemonic + 1);\n let char = label[mnemonic];\n\n // Wrap the mnemonic character in a span.\n let span = h.span({ className: 'lm-MenuBar-itemMnemonic' }, char);\n\n // Return the content parts.\n return [prefix, span, suffix];\n }\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n}\n\n/**\n * Options for overflow menu.\n */\nexport interface IOverflowMenuOptions {\n /**\n * Determines if a overflow menu appears when the menu items overflow.\n *\n * Defaults to `true`.\n */\n isVisible: boolean;\n /**\n * Determines the title of the overflow menu.\n *\n * Default: `...`.\n */\n title?: string;\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Create the DOM node for a menu bar.\n */\n export function createNode(): HTMLDivElement {\n let node = document.createElement('div');\n let content = document.createElement('ul');\n content.className = 'lm-MenuBar-content';\n node.appendChild(content);\n content.setAttribute('role', 'menubar');\n return node;\n }\n\n /**\n * Position for the menu relative to top-left screen corner.\n */\n export interface IPosition {\n /**\n * Pixels right from screen origin.\n */\n left: number;\n /**\n * Pixels down from screen origin.\n */\n top: number;\n }\n\n /**\n * The results of a mnemonic search.\n */\n export interface IMnemonicResult {\n /**\n * The index of the first matching mnemonic item, or `-1`.\n */\n index: number;\n\n /**\n * Whether multiple mnemonic items matched.\n */\n multiple: boolean;\n\n /**\n * The index of the first auto matched non-mnemonic item.\n */\n auto: number;\n }\n\n /**\n * Find the best matching mnemonic item.\n *\n * The search starts at the given index and wraps around.\n */\n export function findMnemonic(\n menus: ReadonlyArray,\n key: string,\n start: number\n ): IMnemonicResult {\n // Setup the result variables.\n let index = -1;\n let auto = -1;\n let multiple = false;\n\n // Normalize the key to upper case.\n let upperKey = key.toUpperCase();\n\n // Search the items from the given start index.\n for (let i = 0, n = menus.length; i < n; ++i) {\n // Compute the wrapped index.\n let k = (i + start) % n;\n\n // Look up the menu title.\n let title = menus[k].title;\n\n // Ignore titles with an empty label.\n if (title.label.length === 0) {\n continue;\n }\n\n // Look up the mnemonic index for the label.\n let mn = title.mnemonic;\n\n // Handle a valid mnemonic index.\n if (mn >= 0 && mn < title.label.length) {\n if (title.label[mn].toUpperCase() === upperKey) {\n if (index === -1) {\n index = k;\n } else {\n multiple = true;\n }\n }\n continue;\n }\n\n // Finally, handle the auto index if possible.\n if (auto === -1 && title.label[0].toUpperCase() === upperKey) {\n auto = k;\n }\n }\n\n // Return the search results.\n return { index, multiple, auto };\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Drag } from '@lumino/dragdrop';\n\nimport { Message } from '@lumino/messaging';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { Widget } from './widget';\n\n/**\n * A widget which implements a canonical scroll bar.\n */\nexport class ScrollBar extends Widget {\n /**\n * Construct a new scroll bar.\n *\n * @param options - The options for initializing the scroll bar.\n */\n constructor(options: ScrollBar.IOptions = {}) {\n super({ node: Private.createNode() });\n this.addClass('lm-ScrollBar');\n this.setFlag(Widget.Flag.DisallowLayout);\n\n // Set the orientation.\n this._orientation = options.orientation || 'vertical';\n this.dataset['orientation'] = this._orientation;\n\n // Parse the rest of the options.\n if (options.maximum !== undefined) {\n this._maximum = Math.max(0, options.maximum);\n }\n if (options.page !== undefined) {\n this._page = Math.max(0, options.page);\n }\n if (options.value !== undefined) {\n this._value = Math.max(0, Math.min(options.value, this._maximum));\n }\n }\n\n /**\n * A signal emitted when the user moves the scroll thumb.\n *\n * #### Notes\n * The payload is the current value of the scroll bar.\n */\n get thumbMoved(): ISignal {\n return this._thumbMoved;\n }\n\n /**\n * A signal emitted when the user clicks a step button.\n *\n * #### Notes\n * The payload is whether a decrease or increase is requested.\n */\n get stepRequested(): ISignal {\n return this._stepRequested;\n }\n\n /**\n * A signal emitted when the user clicks the scroll track.\n *\n * #### Notes\n * The payload is whether a decrease or increase is requested.\n */\n get pageRequested(): ISignal {\n return this._pageRequested;\n }\n\n /**\n * Get the orientation of the scroll bar.\n */\n get orientation(): ScrollBar.Orientation {\n return this._orientation;\n }\n\n /**\n * Set the orientation of the scroll bar.\n */\n set orientation(value: ScrollBar.Orientation) {\n // Do nothing if the orientation does not change.\n if (this._orientation === value) {\n return;\n }\n\n // Release the mouse before making changes.\n this._releaseMouse();\n\n // Update the internal orientation.\n this._orientation = value;\n this.dataset['orientation'] = value;\n\n // Schedule an update the scroll bar.\n this.update();\n }\n\n /**\n * Get the current value of the scroll bar.\n */\n get value(): number {\n return this._value;\n }\n\n /**\n * Set the current value of the scroll bar.\n *\n * #### Notes\n * The value will be clamped to the range `[0, maximum]`.\n */\n set value(value: number) {\n // Clamp the value to the allowable range.\n value = Math.max(0, Math.min(value, this._maximum));\n\n // Do nothing if the value does not change.\n if (this._value === value) {\n return;\n }\n\n // Update the internal value.\n this._value = value;\n\n // Schedule an update the scroll bar.\n this.update();\n }\n\n /**\n * Get the page size of the scroll bar.\n *\n * #### Notes\n * The page size is the amount of visible content in the scrolled\n * region, expressed in data units. It determines the size of the\n * scroll bar thumb.\n */\n get page(): number {\n return this._page;\n }\n\n /**\n * Set the page size of the scroll bar.\n *\n * #### Notes\n * The page size will be clamped to the range `[0, Infinity]`.\n */\n set page(value: number) {\n // Clamp the page size to the allowable range.\n value = Math.max(0, value);\n\n // Do nothing if the value does not change.\n if (this._page === value) {\n return;\n }\n\n // Update the internal page size.\n this._page = value;\n\n // Schedule an update the scroll bar.\n this.update();\n }\n\n /**\n * Get the maximum value of the scroll bar.\n */\n get maximum(): number {\n return this._maximum;\n }\n\n /**\n * Set the maximum value of the scroll bar.\n *\n * #### Notes\n * The max size will be clamped to the range `[0, Infinity]`.\n */\n set maximum(value: number) {\n // Clamp the value to the allowable range.\n value = Math.max(0, value);\n\n // Do nothing if the value does not change.\n if (this._maximum === value) {\n return;\n }\n\n // Update the internal values.\n this._maximum = value;\n\n // Clamp the current value to the new range.\n this._value = Math.min(this._value, value);\n\n // Schedule an update the scroll bar.\n this.update();\n }\n\n /**\n * The scroll bar decrement button node.\n *\n * #### Notes\n * Modifying this node directly can lead to undefined behavior.\n */\n get decrementNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-ScrollBar-button'\n )[0] as HTMLDivElement;\n }\n\n /**\n * The scroll bar increment button node.\n *\n * #### Notes\n * Modifying this node directly can lead to undefined behavior.\n */\n get incrementNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-ScrollBar-button'\n )[1] as HTMLDivElement;\n }\n\n /**\n * The scroll bar track node.\n *\n * #### Notes\n * Modifying this node directly can lead to undefined behavior.\n */\n get trackNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-ScrollBar-track'\n )[0] as HTMLDivElement;\n }\n\n /**\n * The scroll bar thumb node.\n *\n * #### Notes\n * Modifying this node directly can lead to undefined behavior.\n */\n get thumbNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-ScrollBar-thumb'\n )[0] as HTMLDivElement;\n }\n\n /**\n * Handle the DOM events for the scroll bar.\n *\n * @param event - The DOM event sent to the scroll bar.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the scroll bar's DOM node.\n *\n * This should not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'mousedown':\n this._evtMouseDown(event as MouseEvent);\n break;\n case 'mousemove':\n this._evtMouseMove(event as MouseEvent);\n break;\n case 'mouseup':\n this._evtMouseUp(event as MouseEvent);\n break;\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A method invoked on a 'before-attach' message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('mousedown', this);\n this.update();\n }\n\n /**\n * A method invoked on an 'after-detach' message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('mousedown', this);\n this._releaseMouse();\n }\n\n /**\n * A method invoked on an 'update-request' message.\n */\n protected onUpdateRequest(msg: Message): void {\n // Convert the value and page into percentages.\n let value = (this._value * 100) / this._maximum;\n let page = (this._page * 100) / (this._page + this._maximum);\n\n // Clamp the value and page to the relevant range.\n value = Math.max(0, Math.min(value, 100));\n page = Math.max(0, Math.min(page, 100));\n\n // Fetch the thumb style.\n let thumbStyle = this.thumbNode.style;\n\n // Update the thumb style for the current orientation.\n if (this._orientation === 'horizontal') {\n thumbStyle.top = '';\n thumbStyle.height = '';\n thumbStyle.left = `${value}%`;\n thumbStyle.width = `${page}%`;\n thumbStyle.transform = `translate(${-value}%, 0%)`;\n } else {\n thumbStyle.left = '';\n thumbStyle.width = '';\n thumbStyle.top = `${value}%`;\n thumbStyle.height = `${page}%`;\n thumbStyle.transform = `translate(0%, ${-value}%)`;\n }\n }\n\n /**\n * Handle the `'keydown'` event for the scroll bar.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // Stop all input events during drag.\n event.preventDefault();\n event.stopPropagation();\n\n // Ignore anything except the `Escape` key.\n if (event.keyCode !== 27) {\n return;\n }\n\n // Fetch the previous scroll value.\n let value = this._pressData ? this._pressData.value : -1;\n\n // Release the mouse.\n this._releaseMouse();\n\n // Restore the old scroll value if possible.\n if (value !== -1) {\n this._moveThumb(value);\n }\n }\n\n /**\n * Handle the `'mousedown'` event for the scroll bar.\n */\n private _evtMouseDown(event: MouseEvent): void {\n // Do nothing if it's not a left mouse press.\n if (event.button !== 0) {\n return;\n }\n\n // Send an activate request to the scroll bar. This can be\n // used by message hooks to activate something relevant.\n this.activate();\n\n // Do nothing if the mouse is already captured.\n if (this._pressData) {\n return;\n }\n\n // Find the pressed scroll bar part.\n let part = Private.findPart(this, event.target as HTMLElement);\n\n // Do nothing if the part is not of interest.\n if (!part) {\n return;\n }\n\n // Stop the event propagation.\n event.preventDefault();\n event.stopPropagation();\n\n // Override the mouse cursor.\n let override = Drag.overrideCursor('default');\n\n // Set up the press data.\n this._pressData = {\n part,\n override,\n delta: -1,\n value: -1,\n mouseX: event.clientX,\n mouseY: event.clientY\n };\n\n // Add the extra event listeners.\n document.addEventListener('mousemove', this, true);\n document.addEventListener('mouseup', this, true);\n document.addEventListener('keydown', this, true);\n document.addEventListener('contextmenu', this, true);\n\n // Handle a thumb press.\n if (part === 'thumb') {\n // Fetch the thumb node.\n let thumbNode = this.thumbNode;\n\n // Fetch the client rect for the thumb.\n let thumbRect = thumbNode.getBoundingClientRect();\n\n // Update the press data delta for the current orientation.\n if (this._orientation === 'horizontal') {\n this._pressData.delta = event.clientX - thumbRect.left;\n } else {\n this._pressData.delta = event.clientY - thumbRect.top;\n }\n\n // Add the active class to the thumb node.\n thumbNode.classList.add('lm-mod-active');\n\n // Store the current value in the press data.\n this._pressData.value = this._value;\n\n // Finished.\n return;\n }\n\n // Handle a track press.\n if (part === 'track') {\n // Fetch the client rect for the thumb.\n let thumbRect = this.thumbNode.getBoundingClientRect();\n\n // Determine the direction for the page request.\n let dir: 'decrement' | 'increment';\n if (this._orientation === 'horizontal') {\n dir = event.clientX < thumbRect.left ? 'decrement' : 'increment';\n } else {\n dir = event.clientY < thumbRect.top ? 'decrement' : 'increment';\n }\n\n // Start the repeat timer.\n this._repeatTimer = window.setTimeout(this._onRepeat, 350);\n\n // Emit the page requested signal.\n this._pageRequested.emit(dir);\n\n // Finished.\n return;\n }\n\n // Handle a decrement button press.\n if (part === 'decrement') {\n // Add the active class to the decrement node.\n this.decrementNode.classList.add('lm-mod-active');\n\n // Start the repeat timer.\n this._repeatTimer = window.setTimeout(this._onRepeat, 350);\n\n // Emit the step requested signal.\n this._stepRequested.emit('decrement');\n\n // Finished.\n return;\n }\n\n // Handle an increment button press.\n if (part === 'increment') {\n // Add the active class to the increment node.\n this.incrementNode.classList.add('lm-mod-active');\n\n // Start the repeat timer.\n this._repeatTimer = window.setTimeout(this._onRepeat, 350);\n\n // Emit the step requested signal.\n this._stepRequested.emit('increment');\n\n // Finished.\n return;\n }\n }\n\n /**\n * Handle the `'mousemove'` event for the scroll bar.\n */\n private _evtMouseMove(event: MouseEvent): void {\n // Do nothing if no drag is in progress.\n if (!this._pressData) {\n return;\n }\n\n // Stop the event propagation.\n event.preventDefault();\n event.stopPropagation();\n\n // Update the mouse position.\n this._pressData.mouseX = event.clientX;\n this._pressData.mouseY = event.clientY;\n\n // Bail if the thumb is not being dragged.\n if (this._pressData.part !== 'thumb') {\n return;\n }\n\n // Get the client rect for the thumb and track.\n let thumbRect = this.thumbNode.getBoundingClientRect();\n let trackRect = this.trackNode.getBoundingClientRect();\n\n // Fetch the scroll geometry based on the orientation.\n let trackPos: number;\n let trackSpan: number;\n if (this._orientation === 'horizontal') {\n trackPos = event.clientX - trackRect.left - this._pressData.delta;\n trackSpan = trackRect.width - thumbRect.width;\n } else {\n trackPos = event.clientY - trackRect.top - this._pressData.delta;\n trackSpan = trackRect.height - thumbRect.height;\n }\n\n // Compute the desired value from the scroll geometry.\n let value = trackSpan === 0 ? 0 : (trackPos * this._maximum) / trackSpan;\n\n // Move the thumb to the computed value.\n this._moveThumb(value);\n }\n\n /**\n * Handle the `'mouseup'` event for the scroll bar.\n */\n private _evtMouseUp(event: MouseEvent): void {\n // Do nothing if it's not a left mouse release.\n if (event.button !== 0) {\n return;\n }\n\n // Stop the event propagation.\n event.preventDefault();\n event.stopPropagation();\n\n // Release the mouse.\n this._releaseMouse();\n }\n\n /**\n * Release the mouse and restore the node states.\n */\n private _releaseMouse(): void {\n // Bail if there is no press data.\n if (!this._pressData) {\n return;\n }\n\n // Clear the repeat timer.\n clearTimeout(this._repeatTimer);\n this._repeatTimer = -1;\n\n // Clear the press data.\n this._pressData.override.dispose();\n this._pressData = null;\n\n // Remove the extra event listeners.\n document.removeEventListener('mousemove', this, true);\n document.removeEventListener('mouseup', this, true);\n document.removeEventListener('keydown', this, true);\n document.removeEventListener('contextmenu', this, true);\n\n // Remove the active classes from the nodes.\n this.thumbNode.classList.remove('lm-mod-active');\n this.decrementNode.classList.remove('lm-mod-active');\n this.incrementNode.classList.remove('lm-mod-active');\n }\n\n /**\n * Move the thumb to the specified position.\n */\n private _moveThumb(value: number): void {\n // Clamp the value to the allowed range.\n value = Math.max(0, Math.min(value, this._maximum));\n\n // Bail if the value does not change.\n if (this._value === value) {\n return;\n }\n\n // Update the internal value.\n this._value = value;\n\n // Schedule an update of the scroll bar.\n this.update();\n\n // Emit the thumb moved signal.\n this._thumbMoved.emit(value);\n }\n\n /**\n * A timeout callback for repeating the mouse press.\n */\n private _onRepeat = () => {\n // Clear the repeat timer id.\n this._repeatTimer = -1;\n\n // Bail if the mouse has been released.\n if (!this._pressData) {\n return;\n }\n\n // Look up the part that was pressed.\n let part = this._pressData.part;\n\n // Bail if the thumb was pressed.\n if (part === 'thumb') {\n return;\n }\n\n // Schedule the timer for another repeat.\n this._repeatTimer = window.setTimeout(this._onRepeat, 20);\n\n // Get the current mouse position.\n let mouseX = this._pressData.mouseX;\n let mouseY = this._pressData.mouseY;\n\n // Handle a decrement button repeat.\n if (part === 'decrement') {\n // Bail if the mouse is not over the button.\n if (!ElementExt.hitTest(this.decrementNode, mouseX, mouseY)) {\n return;\n }\n\n // Emit the step requested signal.\n this._stepRequested.emit('decrement');\n\n // Finished.\n return;\n }\n\n // Handle an increment button repeat.\n if (part === 'increment') {\n // Bail if the mouse is not over the button.\n if (!ElementExt.hitTest(this.incrementNode, mouseX, mouseY)) {\n return;\n }\n\n // Emit the step requested signal.\n this._stepRequested.emit('increment');\n\n // Finished.\n return;\n }\n\n // Handle a track repeat.\n if (part === 'track') {\n // Bail if the mouse is not over the track.\n if (!ElementExt.hitTest(this.trackNode, mouseX, mouseY)) {\n return;\n }\n\n // Fetch the thumb node.\n let thumbNode = this.thumbNode;\n\n // Bail if the mouse is over the thumb.\n if (ElementExt.hitTest(thumbNode, mouseX, mouseY)) {\n return;\n }\n\n // Fetch the client rect for the thumb.\n let thumbRect = thumbNode.getBoundingClientRect();\n\n // Determine the direction for the page request.\n let dir: 'decrement' | 'increment';\n if (this._orientation === 'horizontal') {\n dir = mouseX < thumbRect.left ? 'decrement' : 'increment';\n } else {\n dir = mouseY < thumbRect.top ? 'decrement' : 'increment';\n }\n\n // Emit the page requested signal.\n this._pageRequested.emit(dir);\n\n // Finished.\n return;\n }\n };\n\n private _value = 0;\n private _page = 10;\n private _maximum = 100;\n private _repeatTimer = -1;\n private _orientation: ScrollBar.Orientation;\n private _pressData: Private.IPressData | null = null;\n private _thumbMoved = new Signal(this);\n private _stepRequested = new Signal(this);\n private _pageRequested = new Signal(this);\n}\n\n/**\n * The namespace for the `ScrollBar` class statics.\n */\nexport namespace ScrollBar {\n /**\n * A type alias for a scroll bar orientation.\n */\n export type Orientation = 'horizontal' | 'vertical';\n\n /**\n * An options object for creating a scroll bar.\n */\n export interface IOptions {\n /**\n * The orientation of the scroll bar.\n *\n * The default is `'vertical'`.\n */\n orientation?: Orientation;\n\n /**\n * The value for the scroll bar.\n *\n * The default is `0`.\n */\n value?: number;\n\n /**\n * The page size for the scroll bar.\n *\n * The default is `10`.\n */\n page?: number;\n\n /**\n * The maximum value for the scroll bar.\n *\n * The default is `100`.\n */\n maximum?: number;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * A type alias for the parts of a scroll bar.\n */\n export type ScrollBarPart = 'thumb' | 'track' | 'decrement' | 'increment';\n\n /**\n * An object which holds mouse press data.\n */\n export interface IPressData {\n /**\n * The scroll bar part which was pressed.\n */\n part: ScrollBarPart;\n\n /**\n * The offset of the press in thumb coordinates, or -1.\n */\n delta: number;\n\n /**\n * The scroll value at the time the thumb was pressed, or -1.\n */\n value: number;\n\n /**\n * The disposable which will clear the override cursor.\n */\n override: IDisposable;\n\n /**\n * The current X position of the mouse.\n */\n mouseX: number;\n\n /**\n * The current Y position of the mouse.\n */\n mouseY: number;\n }\n\n /**\n * Create the DOM node for a scroll bar.\n */\n export function createNode(): HTMLElement {\n let node = document.createElement('div');\n let decrement = document.createElement('div');\n let increment = document.createElement('div');\n let track = document.createElement('div');\n let thumb = document.createElement('div');\n decrement.className = 'lm-ScrollBar-button';\n increment.className = 'lm-ScrollBar-button';\n decrement.dataset['action'] = 'decrement';\n increment.dataset['action'] = 'increment';\n track.className = 'lm-ScrollBar-track';\n thumb.className = 'lm-ScrollBar-thumb';\n track.appendChild(thumb);\n node.appendChild(decrement);\n node.appendChild(track);\n node.appendChild(increment);\n return node;\n }\n\n /**\n * Find the scroll bar part which contains the given target.\n */\n export function findPart(\n scrollBar: ScrollBar,\n target: HTMLElement\n ): ScrollBarPart | null {\n // Test the thumb.\n if (scrollBar.thumbNode.contains(target)) {\n return 'thumb';\n }\n\n // Test the track.\n if (scrollBar.trackNode.contains(target)) {\n return 'track';\n }\n\n // Test the decrement button.\n if (scrollBar.decrementNode.contains(target)) {\n return 'decrement';\n }\n\n // Test the increment button.\n if (scrollBar.incrementNode.contains(target)) {\n return 'increment';\n }\n\n // Indicate no match.\n return null;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { MessageLoop } from '@lumino/messaging';\n\nimport { Layout } from './layout';\n\nimport { Widget } from './widget';\n\n/**\n * A concrete layout implementation which holds a single widget.\n *\n * #### Notes\n * This class is useful for creating simple container widgets which\n * hold a single child. The child should be positioned with CSS.\n */\nexport class SingletonLayout extends Layout {\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n if (this._widget) {\n let widget = this._widget;\n this._widget = null;\n widget.dispose();\n }\n super.dispose();\n }\n\n /**\n * Get the child widget for the layout.\n */\n get widget(): Widget | null {\n return this._widget;\n }\n\n /**\n * Set the child widget for the layout.\n *\n * #### Notes\n * Setting the child widget will cause the old child widget to be\n * automatically disposed. If that is not desired, set the parent\n * of the old child to `null` before assigning a new child.\n */\n set widget(widget: Widget | null) {\n // Remove the widget from its current parent. This is a no-op\n // if the widget's parent is already the layout parent widget.\n if (widget) {\n widget.parent = this.parent;\n }\n\n // Bail early if the widget does not change.\n if (this._widget === widget) {\n return;\n }\n\n // Dispose of the old child widget.\n if (this._widget) {\n this._widget.dispose();\n }\n\n // Update the internal widget.\n this._widget = widget;\n\n // Attach the new child widget if needed.\n if (this.parent && widget) {\n this.attachWidget(widget);\n }\n }\n\n /**\n * Create an iterator over the widgets in the layout.\n *\n * @returns A new iterator over the widgets in the layout.\n */\n *[Symbol.iterator](): IterableIterator {\n if (this._widget) {\n yield this._widget;\n }\n }\n\n /**\n * Remove a widget from the layout.\n *\n * @param widget - The widget to remove from the layout.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method does *not* modify the widget's `parent`.\n */\n removeWidget(widget: Widget): void {\n // Bail early if the widget does not exist in the layout.\n if (this._widget !== widget) {\n return;\n }\n\n // Clear the internal widget.\n this._widget = null;\n\n // If the layout is parented, detach the widget from the DOM.\n if (this.parent) {\n this.detachWidget(widget);\n }\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n super.init();\n for (const widget of this) {\n this.attachWidget(widget);\n }\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This method is called automatically by the single layout at the\n * appropriate time. It should not be called directly by user code.\n *\n * The default implementation adds the widgets's node to the parent's\n * node at the proper location, and sends the appropriate attach\n * messages to the widget if the parent is attached to the DOM.\n *\n * Subclasses may reimplement this method to control how the widget's\n * node is added to the parent's node.\n */\n protected attachWidget(widget: Widget): void {\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget's node to the parent.\n this.parent!.node.appendChild(widget.node);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This method is called automatically by the single layout at the\n * appropriate time. It should not be called directly by user code.\n *\n * The default implementation removes the widget's node from the\n * parent's node, and sends the appropriate detach messages to the\n * widget if the parent is attached to the DOM.\n *\n * Subclasses may reimplement this method to control how the widget's\n * node is removed from the parent's node.\n */\n protected detachWidget(widget: Widget): void {\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n }\n\n private _widget: Widget | null = null;\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { Layout, LayoutItem } from './layout';\n\nimport { PanelLayout } from './panellayout';\n\nimport { Widget } from './widget';\n\n/**\n * A layout where visible widgets are stacked atop one another.\n *\n * #### Notes\n * The Z-order of the visible widgets follows their layout order.\n */\nexport class StackedLayout extends PanelLayout {\n constructor(options: StackedLayout.IOptions = {}) {\n super(options);\n this._hiddenMode =\n options.hiddenMode !== undefined\n ? options.hiddenMode\n : Widget.HiddenMode.Display;\n }\n\n /**\n * The method for hiding widgets.\n *\n * #### Notes\n * If there is only one child widget, `Display` hiding mode will be used\n * regardless of this setting.\n */\n get hiddenMode(): Widget.HiddenMode {\n return this._hiddenMode;\n }\n\n /**\n * Set the method for hiding widgets.\n *\n * #### Notes\n * If there is only one child widget, `Display` hiding mode will be used\n * regardless of this setting.\n */\n set hiddenMode(v: Widget.HiddenMode) {\n if (this._hiddenMode === v) {\n return;\n }\n this._hiddenMode = v;\n if (this.widgets.length > 1) {\n this.widgets.forEach(w => {\n w.hiddenMode = this._hiddenMode;\n });\n }\n }\n\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n // Dispose of the layout items.\n for (const item of this._items) {\n item.dispose();\n }\n\n // Clear the layout state.\n this._box = null;\n this._items.length = 0;\n\n // Dispose of the rest of the layout.\n super.dispose();\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param index - The current index of the widget in the layout.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected attachWidget(index: number, widget: Widget): void {\n // Using transform create an additional layer in the pixel pipeline\n // to limit the number of layer, it is set only if there is more than one widget.\n if (\n this._hiddenMode === Widget.HiddenMode.Scale &&\n this._items.length > 0\n ) {\n if (this._items.length === 1) {\n this.widgets[0].hiddenMode = Widget.HiddenMode.Scale;\n }\n widget.hiddenMode = Widget.HiddenMode.Scale;\n } else {\n widget.hiddenMode = Widget.HiddenMode.Display;\n }\n\n // Create and add a new layout item for the widget.\n ArrayExt.insert(this._items, index, new LayoutItem(widget));\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget's node to the parent.\n this.parent!.node.appendChild(widget.node);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * Move a widget in the parent's DOM node.\n *\n * @param fromIndex - The previous index of the widget in the layout.\n *\n * @param toIndex - The current index of the widget in the layout.\n *\n * @param widget - The widget to move in the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected moveWidget(\n fromIndex: number,\n toIndex: number,\n widget: Widget\n ): void {\n // Move the layout item for the widget.\n ArrayExt.move(this._items, fromIndex, toIndex);\n\n // Post an update request for the parent widget.\n this.parent!.update();\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param index - The previous index of the widget in the layout.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected detachWidget(index: number, widget: Widget): void {\n // Remove the layout item for the widget.\n let item = ArrayExt.removeAt(this._items, index);\n\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Reset the z-index for the widget.\n item!.widget.node.style.zIndex = '';\n\n // Reset the hidden mode for the widget.\n if (this._hiddenMode === Widget.HiddenMode.Scale) {\n widget.hiddenMode = Widget.HiddenMode.Display;\n\n // Reset the hidden mode for the first widget if necessary.\n if (this._items.length === 1) {\n this._items[0].widget.hiddenMode = Widget.HiddenMode.Display;\n }\n }\n\n // Dispose of the layout item.\n item!.dispose();\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n */\n protected onBeforeShow(msg: Message): void {\n super.onBeforeShow(msg);\n this.parent!.update();\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n super.onBeforeAttach(msg);\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n if (this.parent!.isVisible) {\n this._update(msg.width, msg.height);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.parent!.isVisible) {\n this._update(-1, -1);\n }\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n */\n protected onFitRequest(msg: Message): void {\n if (this.parent!.isAttached) {\n this._fit();\n }\n }\n\n /**\n * Fit the layout to the total size required by the widgets.\n */\n private _fit(): void {\n // Set up the computed minimum size.\n let minW = 0;\n let minH = 0;\n\n // Update the computed minimum size.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item.\n let item = this._items[i];\n\n // Ignore hidden items.\n if (item.isHidden) {\n continue;\n }\n\n // Update the size limits for the item.\n item.fit();\n\n // Update the computed minimum size.\n minW = Math.max(minW, item.minWidth);\n minH = Math.max(minH, item.minHeight);\n }\n\n // Update the box sizing and add it to the computed min size.\n let box = (this._box = ElementExt.boxSizing(this.parent!.node));\n minW += box.horizontalSum;\n minH += box.verticalSum;\n\n // Update the parent's min size constraints.\n let style = this.parent!.node.style;\n style.minWidth = `${minW}px`;\n style.minHeight = `${minH}px`;\n\n // Set the dirty flag to ensure only a single update occurs.\n this._dirty = true;\n\n // Notify the ancestor that it should fit immediately. This may\n // cause a resize of the parent, fulfilling the required update.\n if (this.parent!.parent) {\n MessageLoop.sendMessage(this.parent!.parent!, Widget.Msg.FitRequest);\n }\n\n // If the dirty flag is still set, the parent was not resized.\n // Trigger the required update on the parent widget immediately.\n if (this._dirty) {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n }\n }\n\n /**\n * Update the layout position and size of the widgets.\n *\n * The parent offset dimensions should be `-1` if unknown.\n */\n private _update(offsetWidth: number, offsetHeight: number): void {\n // Clear the dirty flag to indicate the update occurred.\n this._dirty = false;\n\n // Compute the visible item count.\n let nVisible = 0;\n for (let i = 0, n = this._items.length; i < n; ++i) {\n nVisible += +!this._items[i].isHidden;\n }\n\n // Bail early if there are no visible items to layout.\n if (nVisible === 0) {\n return;\n }\n\n // Measure the parent if the offset dimensions are unknown.\n if (offsetWidth < 0) {\n offsetWidth = this.parent!.node.offsetWidth;\n }\n if (offsetHeight < 0) {\n offsetHeight = this.parent!.node.offsetHeight;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent!.node);\n }\n\n // Compute the actual layout bounds adjusted for border and padding.\n let top = this._box.paddingTop;\n let left = this._box.paddingLeft;\n let width = offsetWidth - this._box.horizontalSum;\n let height = offsetHeight - this._box.verticalSum;\n\n // Update the widget stacking order and layout geometry.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item.\n let item = this._items[i];\n\n // Ignore hidden items.\n if (item.isHidden) {\n continue;\n }\n\n // Set the z-index for the widget.\n item.widget.node.style.zIndex = `${i}`;\n\n // Update the item geometry.\n item.update(left, top, width, height);\n }\n }\n\n private _dirty = false;\n private _items: LayoutItem[] = [];\n private _box: ElementExt.IBoxSizing | null = null;\n private _hiddenMode: Widget.HiddenMode;\n}\n\n/**\n * The namespace for the `StackedLayout` class statics.\n */\nexport namespace StackedLayout {\n /**\n * An options object for initializing a stacked layout.\n */\n export interface IOptions extends Layout.IOptions {\n /**\n * The method for hiding widgets.\n *\n * The default is `Widget.HiddenMode.Display`.\n */\n hiddenMode?: Widget.HiddenMode;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { Panel } from './panel';\n\nimport { StackedLayout } from './stackedlayout';\n\nimport { Widget } from './widget';\n\n/**\n * A panel where visible widgets are stacked atop one another.\n *\n * #### Notes\n * This class provides a convenience wrapper around a {@link StackedLayout}.\n */\nexport class StackedPanel extends Panel {\n /**\n * Construct a new stacked panel.\n *\n * @param options - The options for initializing the panel.\n */\n constructor(options: StackedPanel.IOptions = {}) {\n super({ layout: Private.createLayout(options) });\n this.addClass('lm-StackedPanel');\n }\n\n /**\n * The method for hiding widgets.\n *\n * #### Notes\n * If there is only one child widget, `Display` hiding mode will be used\n * regardless of this setting.\n */\n get hiddenMode(): Widget.HiddenMode {\n return (this.layout as StackedLayout).hiddenMode;\n }\n\n /**\n * Set the method for hiding widgets.\n *\n * #### Notes\n * If there is only one child widget, `Display` hiding mode will be used\n * regardless of this setting.\n */\n set hiddenMode(v: Widget.HiddenMode) {\n (this.layout as StackedLayout).hiddenMode = v;\n }\n\n /**\n * A signal emitted when a widget is removed from a stacked panel.\n */\n get widgetRemoved(): ISignal {\n return this._widgetRemoved;\n }\n\n /**\n * A message handler invoked on a `'child-added'` message.\n */\n protected onChildAdded(msg: Widget.ChildMessage): void {\n msg.child.addClass('lm-StackedPanel-child');\n }\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {\n msg.child.removeClass('lm-StackedPanel-child');\n this._widgetRemoved.emit(msg.child);\n }\n\n private _widgetRemoved = new Signal(this);\n}\n\n/**\n * The namespace for the `StackedPanel` class statics.\n */\nexport namespace StackedPanel {\n /**\n * An options object for creating a stacked panel.\n */\n export interface IOptions {\n /**\n * The stacked layout to use for the stacked panel.\n *\n * The default is a new `StackedLayout`.\n */\n layout?: StackedLayout;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Create a stacked layout for the given panel options.\n */\n export function createLayout(options: StackedPanel.IOptions): StackedLayout {\n return options.layout || new StackedLayout();\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { Platform } from '@lumino/domutils';\n\nimport { MessageLoop } from '@lumino/messaging';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { BoxLayout } from './boxlayout';\n\nimport { StackedPanel } from './stackedpanel';\n\nimport { TabBar } from './tabbar';\n\nimport { Widget } from './widget';\n\n/**\n * A widget which combines a `TabBar` and a `StackedPanel`.\n *\n * #### Notes\n * This is a simple panel which handles the common case of a tab bar\n * placed next to a content area. The selected tab controls the widget\n * which is shown in the content area.\n *\n * For use cases which require more control than is provided by this\n * panel, the `TabBar` widget may be used independently.\n */\nexport class TabPanel extends Widget {\n /**\n * Construct a new tab panel.\n *\n * @param options - The options for initializing the tab panel.\n */\n constructor(options: TabPanel.IOptions = {}) {\n super();\n this.addClass('lm-TabPanel');\n\n // Create the tab bar and stacked panel.\n this.tabBar = new TabBar(options);\n this.tabBar.addClass('lm-TabPanel-tabBar');\n this.stackedPanel = new StackedPanel();\n this.stackedPanel.addClass('lm-TabPanel-stackedPanel');\n\n // Connect the tab bar signal handlers.\n this.tabBar.tabMoved.connect(this._onTabMoved, this);\n this.tabBar.currentChanged.connect(this._onCurrentChanged, this);\n this.tabBar.tabCloseRequested.connect(this._onTabCloseRequested, this);\n this.tabBar.tabActivateRequested.connect(\n this._onTabActivateRequested,\n this\n );\n this.tabBar.addRequested.connect(this._onTabAddRequested, this);\n\n // Connect the stacked panel signal handlers.\n this.stackedPanel.widgetRemoved.connect(this._onWidgetRemoved, this);\n\n // Get the data related to the placement.\n this._tabPlacement = options.tabPlacement || 'top';\n let direction = Private.directionFromPlacement(this._tabPlacement);\n let orientation = Private.orientationFromPlacement(this._tabPlacement);\n\n // Configure the tab bar for the placement.\n this.tabBar.orientation = orientation;\n this.tabBar.dataset['placement'] = this._tabPlacement;\n\n // Create the box layout.\n let layout = new BoxLayout({ direction, spacing: 0 });\n\n // Set the stretch factors for the child widgets.\n BoxLayout.setStretch(this.tabBar, 0);\n BoxLayout.setStretch(this.stackedPanel, 1);\n\n // Add the child widgets to the layout.\n layout.addWidget(this.tabBar);\n layout.addWidget(this.stackedPanel);\n\n // Install the layout on the tab panel.\n this.layout = layout;\n }\n\n /**\n * A signal emitted when the current tab is changed.\n *\n * #### Notes\n * This signal is emitted when the currently selected tab is changed\n * either through user or programmatic interaction.\n *\n * Notably, this signal is not emitted when the index of the current\n * tab changes due to tabs being inserted, removed, or moved. It is\n * only emitted when the actual current tab node is changed.\n */\n get currentChanged(): ISignal {\n return this._currentChanged;\n }\n\n /**\n * Get the index of the currently selected tab.\n *\n * #### Notes\n * This will be `-1` if no tab is selected.\n */\n get currentIndex(): number {\n return this.tabBar.currentIndex;\n }\n\n /**\n * Set the index of the currently selected tab.\n *\n * #### Notes\n * If the index is out of range, it will be set to `-1`.\n */\n set currentIndex(value: number) {\n this.tabBar.currentIndex = value;\n }\n\n /**\n * Get the currently selected widget.\n *\n * #### Notes\n * This will be `null` if there is no selected tab.\n */\n get currentWidget(): Widget | null {\n let title = this.tabBar.currentTitle;\n return title ? title.owner : null;\n }\n\n /**\n * Set the currently selected widget.\n *\n * #### Notes\n * If the widget is not in the panel, it will be set to `null`.\n */\n set currentWidget(value: Widget | null) {\n this.tabBar.currentTitle = value ? value.title : null;\n }\n\n /**\n * Get the whether the tabs are movable by the user.\n *\n * #### Notes\n * Tabs can always be moved programmatically.\n */\n get tabsMovable(): boolean {\n return this.tabBar.tabsMovable;\n }\n\n /**\n * Set the whether the tabs are movable by the user.\n *\n * #### Notes\n * Tabs can always be moved programmatically.\n */\n set tabsMovable(value: boolean) {\n this.tabBar.tabsMovable = value;\n }\n\n /**\n * Get the whether the add button is enabled.\n *\n */\n get addButtonEnabled(): boolean {\n return this.tabBar.addButtonEnabled;\n }\n\n /**\n * Set the whether the add button is enabled.\n *\n */\n set addButtonEnabled(value: boolean) {\n this.tabBar.addButtonEnabled = value;\n }\n\n /**\n * Get the tab placement for the tab panel.\n *\n * #### Notes\n * This controls the position of the tab bar relative to the content.\n */\n get tabPlacement(): TabPanel.TabPlacement {\n return this._tabPlacement;\n }\n\n /**\n * Set the tab placement for the tab panel.\n *\n * #### Notes\n * This controls the position of the tab bar relative to the content.\n */\n set tabPlacement(value: TabPanel.TabPlacement) {\n // Bail if the placement does not change.\n if (this._tabPlacement === value) {\n return;\n }\n\n // Update the internal value.\n this._tabPlacement = value;\n\n // Get the values related to the placement.\n let direction = Private.directionFromPlacement(value);\n let orientation = Private.orientationFromPlacement(value);\n\n // Configure the tab bar for the placement.\n this.tabBar.orientation = orientation;\n this.tabBar.dataset['placement'] = value;\n\n // Update the layout direction.\n (this.layout as BoxLayout).direction = direction;\n }\n\n /**\n * A signal emitted when the add button on a tab bar is clicked.\n *\n */\n get addRequested(): ISignal> {\n return this._addRequested;\n }\n\n /**\n * The tab bar used by the tab panel.\n *\n * #### Notes\n * Modifying the tab bar directly can lead to undefined behavior.\n */\n readonly tabBar: TabBar;\n\n /**\n * The stacked panel used by the tab panel.\n *\n * #### Notes\n * Modifying the panel directly can lead to undefined behavior.\n */\n readonly stackedPanel: StackedPanel;\n\n /**\n * A read-only array of the widgets in the panel.\n */\n get widgets(): ReadonlyArray {\n return this.stackedPanel.widgets;\n }\n\n /**\n * Add a widget to the end of the tab panel.\n *\n * @param widget - The widget to add to the tab panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n *\n * The widget's `title` is used to populate the tab.\n */\n addWidget(widget: Widget): void {\n this.insertWidget(this.widgets.length, widget);\n }\n\n /**\n * Insert a widget into the tab panel at a specified index.\n *\n * @param index - The index at which to insert the widget.\n *\n * @param widget - The widget to insert into to the tab panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n *\n * The widget's `title` is used to populate the tab.\n */\n insertWidget(index: number, widget: Widget): void {\n if (widget !== this.currentWidget) {\n widget.hide();\n }\n this.stackedPanel.insertWidget(index, widget);\n this.tabBar.insertTab(index, widget.title);\n\n widget.node.setAttribute('role', 'tabpanel');\n\n let renderer = this.tabBar.renderer;\n if (renderer instanceof TabBar.Renderer) {\n let tabId = renderer.createTabKey({\n title: widget.title,\n current: false,\n zIndex: 0\n });\n widget.node.setAttribute('aria-labelledby', tabId);\n }\n }\n\n /**\n * Handle the `currentChanged` signal from the tab bar.\n */\n private _onCurrentChanged(\n sender: TabBar,\n args: TabBar.ICurrentChangedArgs\n ): void {\n // Extract the previous and current title from the args.\n let { previousIndex, previousTitle, currentIndex, currentTitle } = args;\n\n // Extract the widgets from the titles.\n let previousWidget = previousTitle ? previousTitle.owner : null;\n let currentWidget = currentTitle ? currentTitle.owner : null;\n\n // Hide the previous widget.\n if (previousWidget) {\n previousWidget.hide();\n }\n\n // Show the current widget.\n if (currentWidget) {\n currentWidget.show();\n }\n\n // Emit the `currentChanged` signal for the tab panel.\n this._currentChanged.emit({\n previousIndex,\n previousWidget,\n currentIndex,\n currentWidget\n });\n\n // Flush the message loop on IE and Edge to prevent flicker.\n if (Platform.IS_EDGE || Platform.IS_IE) {\n MessageLoop.flush();\n }\n }\n\n /**\n * Handle the `tabAddRequested` signal from the tab bar.\n */\n private _onTabAddRequested(sender: TabBar, args: void): void {\n this._addRequested.emit(sender);\n }\n\n /**\n * Handle the `tabActivateRequested` signal from the tab bar.\n */\n private _onTabActivateRequested(\n sender: TabBar,\n args: TabBar.ITabActivateRequestedArgs\n ): void {\n args.title.owner.activate();\n }\n\n /**\n * Handle the `tabCloseRequested` signal from the tab bar.\n */\n private _onTabCloseRequested(\n sender: TabBar,\n args: TabBar.ITabCloseRequestedArgs\n ): void {\n args.title.owner.close();\n }\n\n /**\n * Handle the `tabMoved` signal from the tab bar.\n */\n private _onTabMoved(\n sender: TabBar,\n args: TabBar.ITabMovedArgs\n ): void {\n this.stackedPanel.insertWidget(args.toIndex, args.title.owner);\n }\n\n /**\n * Handle the `widgetRemoved` signal from the stacked panel.\n */\n private _onWidgetRemoved(sender: StackedPanel, widget: Widget): void {\n widget.node.removeAttribute('role');\n widget.node.removeAttribute('aria-labelledby');\n this.tabBar.removeTab(widget.title);\n }\n\n private _tabPlacement: TabPanel.TabPlacement;\n private _currentChanged = new Signal(\n this\n );\n\n private _addRequested = new Signal>(this);\n}\n\n/**\n * The namespace for the `TabPanel` class statics.\n */\nexport namespace TabPanel {\n /**\n * A type alias for tab placement in a tab bar.\n */\n export type TabPlacement =\n | /**\n * The tabs are placed as a row above the content.\n */\n 'top'\n\n /**\n * The tabs are placed as a column to the left of the content.\n */\n | 'left'\n\n /**\n * The tabs are placed as a column to the right of the content.\n */\n | 'right'\n\n /**\n * The tabs are placed as a row below the content.\n */\n | 'bottom';\n\n /**\n * An options object for initializing a tab panel.\n */\n export interface IOptions {\n /**\n * The document to use with the tab panel.\n *\n * The default is the global `document` instance.\n */\n document?: Document | ShadowRoot;\n\n /**\n * Whether the tabs are movable by the user.\n *\n * The default is `false`.\n */\n tabsMovable?: boolean;\n\n /**\n * Whether the button to add new tabs is enabled.\n *\n * The default is `false`.\n */\n addButtonEnabled?: boolean;\n\n /**\n * The placement of the tab bar relative to the content.\n *\n * The default is `'top'`.\n */\n tabPlacement?: TabPlacement;\n\n /**\n * The renderer for the panel's tab bar.\n *\n * The default is a shared renderer instance.\n */\n renderer?: TabBar.IRenderer;\n }\n\n /**\n * The arguments object for the `currentChanged` signal.\n */\n export interface ICurrentChangedArgs {\n /**\n * The previously selected index.\n */\n previousIndex: number;\n\n /**\n * The previously selected widget.\n */\n previousWidget: Widget | null;\n\n /**\n * The currently selected index.\n */\n currentIndex: number;\n\n /**\n * The currently selected widget.\n */\n currentWidget: Widget | null;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Convert a tab placement to tab bar orientation.\n */\n export function orientationFromPlacement(\n plc: TabPanel.TabPlacement\n ): TabBar.Orientation {\n return placementToOrientationMap[plc];\n }\n\n /**\n * Convert a tab placement to a box layout direction.\n */\n export function directionFromPlacement(\n plc: TabPanel.TabPlacement\n ): BoxLayout.Direction {\n return placementToDirectionMap[plc];\n }\n\n /**\n * A mapping of tab placement to tab bar orientation.\n */\n const placementToOrientationMap: { [key: string]: TabBar.Orientation } = {\n top: 'horizontal',\n left: 'vertical',\n right: 'vertical',\n bottom: 'horizontal'\n };\n\n /**\n * A mapping of tab placement to box layout direction.\n */\n const placementToDirectionMap: { [key: string]: BoxLayout.Direction } = {\n top: 'top-to-bottom',\n left: 'left-to-right',\n right: 'right-to-left',\n bottom: 'bottom-to-top'\n };\n}\n"],"names":["BoxEngine","Signal","Private","MessageLoop","AttachedProperty","Message","ConflatableMessage","ElementExt","ArrayExt","Utils","UUID","Drag","VirtualDOM","h","StringExt","CommandRegistry","JSONExt","getKeyboardLayout","DisposableDelegate","Selector","empty","find","Platform","MimeData","max"],"mappings":"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"} +\ No newline at end of file ++{"version":3,"file":"index.js","sources":["../src/boxengine.ts","../src/title.ts","../src/widget.ts","../src/layout.ts","../src/panellayout.ts","../src/utils.ts","../src/splitlayout.ts","../src/accordionlayout.ts","../src/panel.ts","../src/splitpanel.ts","../src/accordionpanel.ts","../src/boxlayout.ts","../src/boxpanel.ts","../src/commandpalette.ts","../src/menu.ts","../src/contextmenu.ts","../src/tabbar.ts","../src/docklayout.ts","../src/dockpanel.ts","../src/focustracker.ts","../src/gridlayout.ts","../src/menubar.ts","../src/scrollbar.ts","../src/singletonlayout.ts","../src/stackedlayout.ts","../src/stackedpanel.ts","../src/tabpanel.ts"],"sourcesContent":["// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\n\n/**\n * A sizer object for use with the box engine layout functions.\n *\n * #### Notes\n * A box sizer holds the geometry information for an object along an\n * arbitrary layout orientation.\n *\n * For best performance, this class should be treated as a raw data\n * struct. It should not typically be subclassed.\n */\nexport class BoxSizer {\n /**\n * The preferred size for the sizer.\n *\n * #### Notes\n * The sizer will be given this initial size subject to its size\n * bounds. The sizer will not deviate from this size unless such\n * deviation is required to fit into the available layout space.\n *\n * There is no limit to this value, but it will be clamped to the\n * bounds defined by {@link minSize} and {@link maxSize}.\n *\n * The default value is `0`.\n */\n sizeHint = 0;\n\n /**\n * The minimum size of the sizer.\n *\n * #### Notes\n * The sizer will never be sized less than this value, even if\n * it means the sizer will overflow the available layout space.\n *\n * It is assumed that this value lies in the range `[0, Infinity)`\n * and that it is `<=` to {@link maxSize}. Failure to adhere to this\n * constraint will yield undefined results.\n *\n * The default value is `0`.\n */\n minSize = 0;\n\n /**\n * The maximum size of the sizer.\n *\n * #### Notes\n * The sizer will never be sized greater than this value, even if\n * it means the sizer will underflow the available layout space.\n *\n * It is assumed that this value lies in the range `[0, Infinity]`\n * and that it is `>=` to {@link minSize}. Failure to adhere to this\n * constraint will yield undefined results.\n *\n * The default value is `Infinity`.\n */\n maxSize = Infinity;\n\n /**\n * The stretch factor for the sizer.\n *\n * #### Notes\n * This controls how much the sizer stretches relative to its sibling\n * sizers when layout space is distributed. A stretch factor of zero\n * is special and will cause the sizer to only be resized after all\n * other sizers with a stretch factor greater than zero have been\n * resized to their limits.\n *\n * It is assumed that this value is an integer that lies in the range\n * `[0, Infinity)`. Failure to adhere to this constraint will yield\n * undefined results.\n *\n * The default value is `1`.\n */\n stretch = 1;\n\n /**\n * The computed size of the sizer.\n *\n * #### Notes\n * This value is the output of a call to {@link BoxEngine.calc}. It represents\n * the computed size for the object along the layout orientation,\n * and will always lie in the range `[minSize, maxSize]`.\n *\n * This value is output only.\n *\n * Changing this value will have no effect.\n */\n size = 0;\n\n /**\n * An internal storage property for the layout algorithm.\n *\n * #### Notes\n * This value is used as temporary storage by the layout algorithm.\n *\n * Changing this value will have no effect.\n */\n done = false;\n}\n\n/**\n * The namespace for the box engine layout functions.\n */\nexport namespace BoxEngine {\n /**\n * Calculate the optimal layout sizes for a sequence of box sizers.\n *\n * This distributes the available layout space among the box sizers\n * according to the following algorithm:\n *\n * 1. Initialize the sizers's size to its size hint and compute the\n * sums for each of size hint, min size, and max size.\n *\n * 2. If the total size hint equals the available space, return.\n *\n * 3. If the available space is less than the total min size, set all\n * sizers to their min size and return.\n *\n * 4. If the available space is greater than the total max size, set\n * all sizers to their max size and return.\n *\n * 5. If the layout space is less than the total size hint, distribute\n * the negative delta as follows:\n *\n * a. Shrink each sizer with a stretch factor greater than zero by\n * an amount proportional to the negative space and the sum of\n * stretch factors. If the sizer reaches its min size, remove\n * it and its stretch factor from the computation.\n *\n * b. If after adjusting all stretch sizers there remains negative\n * space, distribute the space equally among the sizers with a\n * stretch factor of zero. If a sizer reaches its min size,\n * remove it from the computation.\n *\n * 6. If the layout space is greater than the total size hint,\n * distribute the positive delta as follows:\n *\n * a. Expand each sizer with a stretch factor greater than zero by\n * an amount proportional to the postive space and the sum of\n * stretch factors. If the sizer reaches its max size, remove\n * it and its stretch factor from the computation.\n *\n * b. If after adjusting all stretch sizers there remains positive\n * space, distribute the space equally among the sizers with a\n * stretch factor of zero. If a sizer reaches its max size,\n * remove it from the computation.\n *\n * 7. return\n *\n * @param sizers - The sizers for a particular layout line.\n *\n * @param space - The available layout space for the sizers.\n *\n * @returns The delta between the provided available space and the\n * actual consumed space. This value will be zero if the sizers\n * can be adjusted to fit, negative if the available space is too\n * small, and positive if the available space is too large.\n *\n * #### Notes\n * The {@link BoxSizer.size} of each sizer is updated with the computed size.\n *\n * This function can be called at any time to recompute the layout for\n * an existing sequence of sizers. The previously computed results will\n * have no effect on the new output. It is therefore not necessary to\n * create new sizer objects on each resize event.\n */\n export function calc(sizers: ArrayLike, space: number): number {\n // Bail early if there is nothing to do.\n let count = sizers.length;\n if (count === 0) {\n return space;\n }\n\n // Setup the size and stretch counters.\n let totalMin = 0;\n let totalMax = 0;\n let totalSize = 0;\n let totalStretch = 0;\n let stretchCount = 0;\n\n // Setup the sizers and compute the totals.\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n let min = sizer.minSize;\n let max = sizer.maxSize;\n let hint = sizer.sizeHint;\n sizer.done = false;\n sizer.size = Math.max(min, Math.min(hint, max));\n totalSize += sizer.size;\n totalMin += min;\n totalMax += max;\n if (sizer.stretch > 0) {\n totalStretch += sizer.stretch;\n stretchCount++;\n }\n }\n\n // If the space is equal to the total size, return early.\n if (space === totalSize) {\n return 0;\n }\n\n // If the space is less than the total min, minimize each sizer.\n if (space <= totalMin) {\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n sizer.size = sizer.minSize;\n }\n return space - totalMin;\n }\n\n // If the space is greater than the total max, maximize each sizer.\n if (space >= totalMax) {\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n sizer.size = sizer.maxSize;\n }\n return space - totalMax;\n }\n\n // The loops below perform sub-pixel precision sizing. A near zero\n // value is used for compares instead of zero to ensure that the\n // loop terminates when the subdivided space is reasonably small.\n let nearZero = 0.01;\n\n // A counter which is decremented each time a sizer is resized to\n // its limit. This ensures the loops terminate even if there is\n // space remaining to distribute.\n let notDoneCount = count;\n\n // Distribute negative delta space.\n if (space < totalSize) {\n // Shrink each stretchable sizer by an amount proportional to its\n // stretch factor. If a sizer reaches its min size it's marked as\n // done. The loop progresses in phases where each sizer is given\n // a chance to consume its fair share for the pass, regardless of\n // whether a sizer before it reached its limit. This continues\n // until the stretchable sizers or the free space is exhausted.\n let freeSpace = totalSize - space;\n while (stretchCount > 0 && freeSpace > nearZero) {\n let distSpace = freeSpace;\n let distStretch = totalStretch;\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n if (sizer.done || sizer.stretch === 0) {\n continue;\n }\n let amt = (sizer.stretch * distSpace) / distStretch;\n if (sizer.size - amt <= sizer.minSize) {\n freeSpace -= sizer.size - sizer.minSize;\n totalStretch -= sizer.stretch;\n sizer.size = sizer.minSize;\n sizer.done = true;\n notDoneCount--;\n stretchCount--;\n } else {\n freeSpace -= amt;\n sizer.size -= amt;\n }\n }\n }\n // Distribute any remaining space evenly among the non-stretchable\n // sizers. This progresses in phases in the same manner as above.\n while (notDoneCount > 0 && freeSpace > nearZero) {\n let amt = freeSpace / notDoneCount;\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n if (sizer.done) {\n continue;\n }\n if (sizer.size - amt <= sizer.minSize) {\n freeSpace -= sizer.size - sizer.minSize;\n sizer.size = sizer.minSize;\n sizer.done = true;\n notDoneCount--;\n } else {\n freeSpace -= amt;\n sizer.size -= amt;\n }\n }\n }\n }\n // Distribute positive delta space.\n else {\n // Expand each stretchable sizer by an amount proportional to its\n // stretch factor. If a sizer reaches its max size it's marked as\n // done. The loop progresses in phases where each sizer is given\n // a chance to consume its fair share for the pass, regardless of\n // whether a sizer before it reached its limit. This continues\n // until the stretchable sizers or the free space is exhausted.\n let freeSpace = space - totalSize;\n while (stretchCount > 0 && freeSpace > nearZero) {\n let distSpace = freeSpace;\n let distStretch = totalStretch;\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n if (sizer.done || sizer.stretch === 0) {\n continue;\n }\n let amt = (sizer.stretch * distSpace) / distStretch;\n if (sizer.size + amt >= sizer.maxSize) {\n freeSpace -= sizer.maxSize - sizer.size;\n totalStretch -= sizer.stretch;\n sizer.size = sizer.maxSize;\n sizer.done = true;\n notDoneCount--;\n stretchCount--;\n } else {\n freeSpace -= amt;\n sizer.size += amt;\n }\n }\n }\n // Distribute any remaining space evenly among the non-stretchable\n // sizers. This progresses in phases in the same manner as above.\n while (notDoneCount > 0 && freeSpace > nearZero) {\n let amt = freeSpace / notDoneCount;\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n if (sizer.done) {\n continue;\n }\n if (sizer.size + amt >= sizer.maxSize) {\n freeSpace -= sizer.maxSize - sizer.size;\n sizer.size = sizer.maxSize;\n sizer.done = true;\n notDoneCount--;\n } else {\n freeSpace -= amt;\n sizer.size += amt;\n }\n }\n }\n }\n\n // Indicate that the consumed space equals the available space.\n return 0;\n }\n\n /**\n * Adjust a sizer by a delta and update its neighbors accordingly.\n *\n * @param sizers - The sizers which should be adjusted.\n *\n * @param index - The index of the sizer to grow.\n *\n * @param delta - The amount to adjust the sizer, positive or negative.\n *\n * #### Notes\n * This will adjust the indicated sizer by the specified amount, along\n * with the sizes of the appropriate neighbors, subject to the limits\n * specified by each of the sizers.\n *\n * This is useful when implementing box layouts where the boundaries\n * between the sizers are interactively adjustable by the user.\n */\n export function adjust(\n sizers: ArrayLike,\n index: number,\n delta: number\n ): void {\n // Bail early when there is nothing to do.\n if (sizers.length === 0 || delta === 0) {\n return;\n }\n\n // Dispatch to the proper implementation.\n if (delta > 0) {\n growSizer(sizers, index, delta);\n } else {\n shrinkSizer(sizers, index, -delta);\n }\n }\n\n /**\n * Grow a sizer by a positive delta and adjust neighbors.\n */\n function growSizer(\n sizers: ArrayLike,\n index: number,\n delta: number\n ): void {\n // Compute how much the items to the left can expand.\n let growLimit = 0;\n for (let i = 0; i <= index; ++i) {\n let sizer = sizers[i];\n growLimit += sizer.maxSize - sizer.size;\n }\n\n // Compute how much the items to the right can shrink.\n let shrinkLimit = 0;\n for (let i = index + 1, n = sizers.length; i < n; ++i) {\n let sizer = sizers[i];\n shrinkLimit += sizer.size - sizer.minSize;\n }\n\n // Clamp the delta adjustment to the limits.\n delta = Math.min(delta, growLimit, shrinkLimit);\n\n // Grow the sizers to the left by the delta.\n let grow = delta;\n for (let i = index; i >= 0 && grow > 0; --i) {\n let sizer = sizers[i];\n let limit = sizer.maxSize - sizer.size;\n if (limit >= grow) {\n sizer.sizeHint = sizer.size + grow;\n grow = 0;\n } else {\n sizer.sizeHint = sizer.size + limit;\n grow -= limit;\n }\n }\n\n // Shrink the sizers to the right by the delta.\n let shrink = delta;\n for (let i = index + 1, n = sizers.length; i < n && shrink > 0; ++i) {\n let sizer = sizers[i];\n let limit = sizer.size - sizer.minSize;\n if (limit >= shrink) {\n sizer.sizeHint = sizer.size - shrink;\n shrink = 0;\n } else {\n sizer.sizeHint = sizer.size - limit;\n shrink -= limit;\n }\n }\n }\n\n /**\n * Shrink a sizer by a positive delta and adjust neighbors.\n */\n function shrinkSizer(\n sizers: ArrayLike,\n index: number,\n delta: number\n ): void {\n // Compute how much the items to the right can expand.\n let growLimit = 0;\n for (let i = index + 1, n = sizers.length; i < n; ++i) {\n let sizer = sizers[i];\n growLimit += sizer.maxSize - sizer.size;\n }\n\n // Compute how much the items to the left can shrink.\n let shrinkLimit = 0;\n for (let i = 0; i <= index; ++i) {\n let sizer = sizers[i];\n shrinkLimit += sizer.size - sizer.minSize;\n }\n\n // Clamp the delta adjustment to the limits.\n delta = Math.min(delta, growLimit, shrinkLimit);\n\n // Grow the sizers to the right by the delta.\n let grow = delta;\n for (let i = index + 1, n = sizers.length; i < n && grow > 0; ++i) {\n let sizer = sizers[i];\n let limit = sizer.maxSize - sizer.size;\n if (limit >= grow) {\n sizer.sizeHint = sizer.size + grow;\n grow = 0;\n } else {\n sizer.sizeHint = sizer.size + limit;\n grow -= limit;\n }\n }\n\n // Shrink the sizers to the left by the delta.\n let shrink = delta;\n for (let i = index; i >= 0 && shrink > 0; --i) {\n let sizer = sizers[i];\n let limit = sizer.size - sizer.minSize;\n if (limit >= shrink) {\n sizer.sizeHint = sizer.size - shrink;\n shrink = 0;\n } else {\n sizer.sizeHint = sizer.size - limit;\n shrink -= limit;\n }\n }\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { VirtualElement } from '@lumino/virtualdom';\n\n/**\n * An object which holds data related to an object's title.\n *\n * #### Notes\n * A title object is intended to hold the data necessary to display a\n * header for a particular object. A common example is the `TabPanel`,\n * which uses the widget title to populate the tab for a child widget.\n *\n * It is the responsibility of the owner to call the title disposal.\n */\nexport class Title implements IDisposable {\n /**\n * Construct a new title.\n *\n * @param options - The options for initializing the title.\n */\n constructor(options: Title.IOptions) {\n this.owner = options.owner;\n if (options.label !== undefined) {\n this._label = options.label;\n }\n if (options.mnemonic !== undefined) {\n this._mnemonic = options.mnemonic;\n }\n if (options.icon !== undefined) {\n this._icon = options.icon;\n }\n\n if (options.iconClass !== undefined) {\n this._iconClass = options.iconClass;\n }\n if (options.iconLabel !== undefined) {\n this._iconLabel = options.iconLabel;\n }\n if (options.caption !== undefined) {\n this._caption = options.caption;\n }\n if (options.className !== undefined) {\n this._className = options.className;\n }\n if (options.closable !== undefined) {\n this._closable = options.closable;\n }\n this._dataset = options.dataset || {};\n }\n\n /**\n * A signal emitted when the state of the title changes.\n */\n get changed(): ISignal {\n return this._changed;\n }\n\n /**\n * The object which owns the title.\n */\n readonly owner: T;\n\n /**\n * Get the label for the title.\n *\n * #### Notes\n * The default value is an empty string.\n */\n get label(): string {\n return this._label;\n }\n\n /**\n * Set the label for the title.\n */\n set label(value: string) {\n if (this._label === value) {\n return;\n }\n this._label = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the mnemonic index for the title.\n *\n * #### Notes\n * The default value is `-1`.\n */\n get mnemonic(): number {\n return this._mnemonic;\n }\n\n /**\n * Set the mnemonic index for the title.\n */\n set mnemonic(value: number) {\n if (this._mnemonic === value) {\n return;\n }\n this._mnemonic = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the icon renderer for the title.\n *\n * #### Notes\n * The default value is undefined.\n */\n get icon(): VirtualElement.IRenderer | undefined {\n return this._icon;\n }\n\n /**\n * Set the icon renderer for the title.\n *\n * #### Notes\n * A renderer is an object that supplies a render and unrender function.\n */\n set icon(value: VirtualElement.IRenderer | undefined) {\n if (this._icon === value) {\n return;\n }\n this._icon = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the icon class name for the title.\n *\n * #### Notes\n * The default value is an empty string.\n */\n get iconClass(): string {\n return this._iconClass;\n }\n\n /**\n * Set the icon class name for the title.\n *\n * #### Notes\n * Multiple class names can be separated with whitespace.\n */\n set iconClass(value: string) {\n if (this._iconClass === value) {\n return;\n }\n this._iconClass = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the icon label for the title.\n *\n * #### Notes\n * The default value is an empty string.\n */\n get iconLabel(): string {\n return this._iconLabel;\n }\n\n /**\n * Set the icon label for the title.\n *\n * #### Notes\n * Multiple class names can be separated with whitespace.\n */\n set iconLabel(value: string) {\n if (this._iconLabel === value) {\n return;\n }\n this._iconLabel = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the caption for the title.\n *\n * #### Notes\n * The default value is an empty string.\n */\n get caption(): string {\n return this._caption;\n }\n\n /**\n * Set the caption for the title.\n */\n set caption(value: string) {\n if (this._caption === value) {\n return;\n }\n this._caption = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the extra class name for the title.\n *\n * #### Notes\n * The default value is an empty string.\n */\n get className(): string {\n return this._className;\n }\n\n /**\n * Set the extra class name for the title.\n *\n * #### Notes\n * Multiple class names can be separated with whitespace.\n */\n set className(value: string) {\n if (this._className === value) {\n return;\n }\n this._className = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the closable state for the title.\n *\n * #### Notes\n * The default value is `false`.\n */\n get closable(): boolean {\n return this._closable;\n }\n\n /**\n * Set the closable state for the title.\n *\n * #### Notes\n * This controls the presence of a close icon when applicable.\n */\n set closable(value: boolean) {\n if (this._closable === value) {\n return;\n }\n this._closable = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the dataset for the title.\n *\n * #### Notes\n * The default value is an empty dataset.\n */\n get dataset(): Title.Dataset {\n return this._dataset;\n }\n\n /**\n * Set the dataset for the title.\n *\n * #### Notes\n * This controls the data attributes when applicable.\n */\n set dataset(value: Title.Dataset) {\n if (this._dataset === value) {\n return;\n }\n this._dataset = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Test whether the title has been disposed.\n */\n get isDisposed(): boolean {\n return this._isDisposed;\n }\n\n /**\n * Dispose of the resources held by the title.\n *\n * #### Notes\n * It is the responsibility of the owner to call the title disposal.\n */\n dispose(): void {\n if (this.isDisposed) {\n return;\n }\n this._isDisposed = true;\n\n Signal.clearData(this);\n }\n\n private _label = '';\n private _caption = '';\n private _mnemonic = -1;\n private _icon: VirtualElement.IRenderer | undefined = undefined;\n private _iconClass = '';\n private _iconLabel = '';\n private _className = '';\n private _closable = false;\n private _dataset: Title.Dataset;\n private _changed = new Signal(this);\n private _isDisposed = false;\n}\n\n/**\n * The namespace for the `Title` class statics.\n */\nexport namespace Title {\n /**\n * A type alias for a simple immutable string dataset.\n */\n export type Dataset = { readonly [key: string]: string };\n\n /**\n * An options object for initializing a title.\n */\n export interface IOptions {\n /**\n * The object which owns the title.\n */\n owner: T;\n\n /**\n * The label for the title.\n */\n label?: string;\n\n /**\n * The mnemonic index for the title.\n */\n mnemonic?: number;\n\n /**\n * The icon renderer for the title.\n */\n icon?: VirtualElement.IRenderer;\n\n /**\n * The icon class name for the title.\n */\n iconClass?: string;\n\n /**\n * The icon label for the title.\n */\n iconLabel?: string;\n\n /**\n * The caption for the title.\n */\n caption?: string;\n\n /**\n * The extra class name for the title.\n */\n className?: string;\n\n /**\n * The closable state for the title.\n */\n closable?: boolean;\n\n /**\n * The dataset for the title.\n */\n dataset?: Dataset;\n }\n}\n","/* eslint-disable @typescript-eslint/no-empty-function */\n// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { IObservableDisposable } from '@lumino/disposable';\n\nimport {\n ConflatableMessage,\n IMessageHandler,\n Message,\n MessageLoop\n} from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { Layout } from './layout';\n\nimport { Title } from './title';\n\n/**\n * The base class of the lumino widget hierarchy.\n *\n * #### Notes\n * This class will typically be subclassed in order to create a useful\n * widget. However, it can be used directly to host externally created\n * content.\n */\nexport class Widget implements IMessageHandler, IObservableDisposable {\n /**\n * Construct a new widget.\n *\n * @param options - The options for initializing the widget.\n */\n constructor(options: Widget.IOptions = {}) {\n this.node = Private.createNode(options);\n this.addClass('lm-Widget');\n }\n\n /**\n * Dispose of the widget and its descendant widgets.\n *\n * #### Notes\n * It is unsafe to use the widget after it has been disposed.\n *\n * All calls made to this method after the first are a no-op.\n */\n dispose(): void {\n // Do nothing if the widget is already disposed.\n if (this.isDisposed) {\n return;\n }\n\n // Set the disposed flag and emit the disposed signal.\n this.setFlag(Widget.Flag.IsDisposed);\n this._disposed.emit(undefined);\n\n // Remove or detach the widget if necessary.\n if (this.parent) {\n this.parent = null;\n } else if (this.isAttached) {\n Widget.detach(this);\n }\n\n // Dispose of the widget layout.\n if (this._layout) {\n this._layout.dispose();\n this._layout = null;\n }\n\n // Dispose the title\n this.title.dispose();\n\n // Clear the extra data associated with the widget.\n Signal.clearData(this);\n MessageLoop.clearData(this);\n AttachedProperty.clearData(this);\n }\n\n /**\n * A signal emitted when the widget is disposed.\n */\n get disposed(): ISignal {\n return this._disposed;\n }\n\n /**\n * Get the DOM node owned by the widget.\n */\n readonly node: HTMLElement;\n\n /**\n * Test whether the widget has been disposed.\n */\n get isDisposed(): boolean {\n return this.testFlag(Widget.Flag.IsDisposed);\n }\n\n /**\n * Test whether the widget's node is attached to the DOM.\n */\n get isAttached(): boolean {\n return this.testFlag(Widget.Flag.IsAttached);\n }\n\n /**\n * Test whether the widget is explicitly hidden.\n */\n get isHidden(): boolean {\n return this.testFlag(Widget.Flag.IsHidden);\n }\n\n /**\n * Test whether the widget is visible.\n *\n * #### Notes\n * A widget is visible when it is attached to the DOM, is not\n * explicitly hidden, and has no explicitly hidden ancestors.\n */\n get isVisible(): boolean {\n return this.testFlag(Widget.Flag.IsVisible);\n }\n\n /**\n * The title object for the widget.\n *\n * #### Notes\n * The title object is used by some container widgets when displaying\n * the widget alongside some title, such as a tab panel or side bar.\n *\n * Since not all widgets will use the title, it is created on demand.\n *\n * The `owner` property of the title is set to this widget.\n */\n get title(): Title {\n return Private.titleProperty.get(this);\n }\n\n /**\n * Get the id of the widget's DOM node.\n */\n get id(): string {\n return this.node.id;\n }\n\n /**\n * Set the id of the widget's DOM node.\n */\n set id(value: string) {\n this.node.id = value;\n }\n\n /**\n * The dataset for the widget's DOM node.\n */\n get dataset(): DOMStringMap {\n return this.node.dataset;\n }\n\n /**\n * Get the method for hiding the widget.\n */\n get hiddenMode(): Widget.HiddenMode {\n return this._hiddenMode;\n }\n\n /**\n * Set the method for hiding the widget.\n */\n set hiddenMode(value: Widget.HiddenMode) {\n if (this._hiddenMode === value) {\n return;\n }\n\n if (this.isHidden) {\n // Reset styles set by previous mode.\n this._toggleHidden(false);\n }\n\n if (value == Widget.HiddenMode.Scale) {\n this.node.style.willChange = 'transform';\n } else {\n this.node.style.willChange = 'auto';\n }\n\n this._hiddenMode = value;\n\n if (this.isHidden) {\n // Set styles for new mode.\n this._toggleHidden(true);\n }\n }\n\n /**\n * Get the parent of the widget.\n */\n get parent(): Widget | null {\n return this._parent;\n }\n\n /**\n * Set the parent of the widget.\n *\n * #### Notes\n * Children are typically added to a widget by using a layout, which\n * means user code will not normally set the parent widget directly.\n *\n * The widget will be automatically removed from its old parent.\n *\n * This is a no-op if there is no effective parent change.\n */\n set parent(value: Widget | null) {\n if (this._parent === value) {\n return;\n }\n if (value && this.contains(value)) {\n throw new Error('Invalid parent widget.');\n }\n if (this._parent && !this._parent.isDisposed) {\n let msg = new Widget.ChildMessage('child-removed', this);\n MessageLoop.sendMessage(this._parent, msg);\n }\n this._parent = value;\n if (this._parent && !this._parent.isDisposed) {\n let msg = new Widget.ChildMessage('child-added', this);\n MessageLoop.sendMessage(this._parent, msg);\n }\n if (!this.isDisposed) {\n MessageLoop.sendMessage(this, Widget.Msg.ParentChanged);\n }\n }\n\n /**\n * Get the layout for the widget.\n */\n get layout(): Layout | null {\n return this._layout;\n }\n\n /**\n * Set the layout for the widget.\n *\n * #### Notes\n * The layout is single-use only. It cannot be changed after the\n * first assignment.\n *\n * The layout is disposed automatically when the widget is disposed.\n */\n set layout(value: Layout | null) {\n if (this._layout === value) {\n return;\n }\n if (this.testFlag(Widget.Flag.DisallowLayout)) {\n throw new Error('Cannot set widget layout.');\n }\n if (this._layout) {\n throw new Error('Cannot change widget layout.');\n }\n if (value!.parent) {\n throw new Error('Cannot change layout parent.');\n }\n this._layout = value;\n value!.parent = this;\n }\n\n /**\n * Create an iterator over the widget's children.\n *\n * @returns A new iterator over the children of the widget.\n *\n * #### Notes\n * The widget must have a populated layout in order to have children.\n *\n * If a layout is not installed, the returned iterator will be empty.\n */\n *children(): IterableIterator {\n if (this._layout) {\n yield* this._layout;\n }\n }\n\n /**\n * Test whether a widget is a descendant of this widget.\n *\n * @param widget - The descendant widget of interest.\n *\n * @returns `true` if the widget is a descendant, `false` otherwise.\n */\n contains(widget: Widget): boolean {\n for (let value: Widget | null = widget; value; value = value._parent) {\n if (value === this) {\n return true;\n }\n }\n return false;\n }\n\n /**\n * Test whether the widget's DOM node has the given class name.\n *\n * @param name - The class name of interest.\n *\n * @returns `true` if the node has the class, `false` otherwise.\n */\n hasClass(name: string): boolean {\n return this.node.classList.contains(name);\n }\n\n /**\n * Add a class name to the widget's DOM node.\n *\n * @param name - The class name to add to the node.\n *\n * #### Notes\n * If the class name is already added to the node, this is a no-op.\n *\n * The class name must not contain whitespace.\n */\n addClass(name: string): void {\n this.node.classList.add(name);\n }\n\n /**\n * Remove a class name from the widget's DOM node.\n *\n * @param name - The class name to remove from the node.\n *\n * #### Notes\n * If the class name is not yet added to the node, this is a no-op.\n *\n * The class name must not contain whitespace.\n */\n removeClass(name: string): void {\n this.node.classList.remove(name);\n }\n\n /**\n * Toggle a class name on the widget's DOM node.\n *\n * @param name - The class name to toggle on the node.\n *\n * @param force - Whether to force add the class (`true`) or force\n * remove the class (`false`). If not provided, the presence of\n * the class will be toggled from its current state.\n *\n * @returns `true` if the class is now present, `false` otherwise.\n *\n * #### Notes\n * The class name must not contain whitespace.\n */\n toggleClass(name: string, force?: boolean): boolean {\n if (force === true) {\n this.node.classList.add(name);\n return true;\n }\n if (force === false) {\n this.node.classList.remove(name);\n return false;\n }\n return this.node.classList.toggle(name);\n }\n\n /**\n * Post an `'update-request'` message to the widget.\n *\n * #### Notes\n * This is a simple convenience method for posting the message.\n */\n update(): void {\n MessageLoop.postMessage(this, Widget.Msg.UpdateRequest);\n }\n\n /**\n * Post a `'fit-request'` message to the widget.\n *\n * #### Notes\n * This is a simple convenience method for posting the message.\n */\n fit(): void {\n MessageLoop.postMessage(this, Widget.Msg.FitRequest);\n }\n\n /**\n * Post an `'activate-request'` message to the widget.\n *\n * #### Notes\n * This is a simple convenience method for posting the message.\n */\n activate(): void {\n MessageLoop.postMessage(this, Widget.Msg.ActivateRequest);\n }\n\n /**\n * Send a `'close-request'` message to the widget.\n *\n * #### Notes\n * This is a simple convenience method for sending the message.\n */\n close(): void {\n MessageLoop.sendMessage(this, Widget.Msg.CloseRequest);\n }\n\n /**\n * Show the widget and make it visible to its parent widget.\n *\n * #### Notes\n * This causes the {@link isHidden} property to be `false`.\n *\n * If the widget is not explicitly hidden, this is a no-op.\n */\n show(): void {\n if (!this.testFlag(Widget.Flag.IsHidden)) {\n return;\n }\n if (this.isAttached && (!this.parent || this.parent.isVisible)) {\n MessageLoop.sendMessage(this, Widget.Msg.BeforeShow);\n }\n this.clearFlag(Widget.Flag.IsHidden);\n this._toggleHidden(false);\n\n if (this.isAttached && (!this.parent || this.parent.isVisible)) {\n MessageLoop.sendMessage(this, Widget.Msg.AfterShow);\n }\n if (this.parent) {\n let msg = new Widget.ChildMessage('child-shown', this);\n MessageLoop.sendMessage(this.parent, msg);\n }\n }\n\n /**\n * Hide the widget and make it hidden to its parent widget.\n *\n * #### Notes\n * This causes the {@link isHidden} property to be `true`.\n *\n * If the widget is explicitly hidden, this is a no-op.\n */\n hide(): void {\n if (this.testFlag(Widget.Flag.IsHidden)) {\n return;\n }\n if (this.isAttached && (!this.parent || this.parent.isVisible)) {\n MessageLoop.sendMessage(this, Widget.Msg.BeforeHide);\n }\n this.setFlag(Widget.Flag.IsHidden);\n this._toggleHidden(true);\n\n if (this.isAttached && (!this.parent || this.parent.isVisible)) {\n MessageLoop.sendMessage(this, Widget.Msg.AfterHide);\n }\n if (this.parent) {\n let msg = new Widget.ChildMessage('child-hidden', this);\n MessageLoop.sendMessage(this.parent, msg);\n }\n }\n\n /**\n * Show or hide the widget according to a boolean value.\n *\n * @param hidden - `true` to hide the widget, or `false` to show it.\n *\n * #### Notes\n * This is a convenience method for `hide()` and `show()`.\n */\n setHidden(hidden: boolean): void {\n if (hidden) {\n this.hide();\n } else {\n this.show();\n }\n }\n\n /**\n * Test whether the given widget flag is set.\n *\n * #### Notes\n * This will not typically be called directly by user code.\n */\n testFlag(flag: Widget.Flag): boolean {\n return (this._flags & flag) !== 0;\n }\n\n /**\n * Set the given widget flag.\n *\n * #### Notes\n * This will not typically be called directly by user code.\n */\n setFlag(flag: Widget.Flag): void {\n this._flags |= flag;\n }\n\n /**\n * Clear the given widget flag.\n *\n * #### Notes\n * This will not typically be called directly by user code.\n */\n clearFlag(flag: Widget.Flag): void {\n this._flags &= ~flag;\n }\n\n /**\n * Process a message sent to the widget.\n *\n * @param msg - The message sent to the widget.\n *\n * #### Notes\n * Subclasses may reimplement this method as needed.\n */\n processMessage(msg: Message): void {\n switch (msg.type) {\n case 'resize':\n this.notifyLayout(msg);\n this.onResize(msg as Widget.ResizeMessage);\n break;\n case 'update-request':\n this.notifyLayout(msg);\n this.onUpdateRequest(msg);\n break;\n case 'fit-request':\n this.notifyLayout(msg);\n this.onFitRequest(msg);\n break;\n case 'before-show':\n this.notifyLayout(msg);\n this.onBeforeShow(msg);\n break;\n case 'after-show':\n this.setFlag(Widget.Flag.IsVisible);\n this.notifyLayout(msg);\n this.onAfterShow(msg);\n break;\n case 'before-hide':\n this.notifyLayout(msg);\n this.onBeforeHide(msg);\n break;\n case 'after-hide':\n this.clearFlag(Widget.Flag.IsVisible);\n this.notifyLayout(msg);\n this.onAfterHide(msg);\n break;\n case 'before-attach':\n this.notifyLayout(msg);\n this.onBeforeAttach(msg);\n break;\n case 'after-attach':\n if (!this.isHidden && (!this.parent || this.parent.isVisible)) {\n this.setFlag(Widget.Flag.IsVisible);\n }\n this.setFlag(Widget.Flag.IsAttached);\n this.notifyLayout(msg);\n this.onAfterAttach(msg);\n break;\n case 'before-detach':\n this.notifyLayout(msg);\n this.onBeforeDetach(msg);\n break;\n case 'after-detach':\n this.clearFlag(Widget.Flag.IsVisible);\n this.clearFlag(Widget.Flag.IsAttached);\n this.notifyLayout(msg);\n this.onAfterDetach(msg);\n break;\n case 'activate-request':\n this.notifyLayout(msg);\n this.onActivateRequest(msg);\n break;\n case 'close-request':\n this.notifyLayout(msg);\n this.onCloseRequest(msg);\n break;\n case 'child-added':\n this.notifyLayout(msg);\n this.onChildAdded(msg as Widget.ChildMessage);\n break;\n case 'child-removed':\n this.notifyLayout(msg);\n this.onChildRemoved(msg as Widget.ChildMessage);\n break;\n default:\n this.notifyLayout(msg);\n break;\n }\n }\n\n /**\n * Invoke the message processing routine of the widget's layout.\n *\n * @param msg - The message to dispatch to the layout.\n *\n * #### Notes\n * This is a no-op if the widget does not have a layout.\n *\n * This will not typically be called directly by user code.\n */\n protected notifyLayout(msg: Message): void {\n if (this._layout) {\n this._layout.processParentMessage(msg);\n }\n }\n\n /**\n * A message handler invoked on a `'close-request'` message.\n *\n * #### Notes\n * The default implementation unparents or detaches the widget.\n */\n protected onCloseRequest(msg: Message): void {\n if (this.parent) {\n this.parent = null;\n } else if (this.isAttached) {\n Widget.detach(this);\n }\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onResize(msg: Widget.ResizeMessage): void {}\n\n /**\n * A message handler invoked on an `'update-request'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onUpdateRequest(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onFitRequest(msg: Message): void {}\n\n /**\n * A message handler invoked on an `'activate-request'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onActivateRequest(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'before-show'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onBeforeShow(msg: Message): void {}\n\n /**\n * A message handler invoked on an `'after-show'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onAfterShow(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'before-hide'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onBeforeHide(msg: Message): void {}\n\n /**\n * A message handler invoked on an `'after-hide'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onAfterHide(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onBeforeAttach(msg: Message): void {}\n\n /**\n * A message handler invoked on an `'after-attach'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onAfterAttach(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'before-detach'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onBeforeDetach(msg: Message): void {}\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onAfterDetach(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'child-added'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onChildAdded(msg: Widget.ChildMessage): void {}\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {}\n\n private _toggleHidden(hidden: boolean) {\n if (hidden) {\n switch (this._hiddenMode) {\n case Widget.HiddenMode.Display:\n this.addClass('lm-mod-hidden');\n break;\n case Widget.HiddenMode.Scale:\n this.node.style.transform = 'scale(0)';\n this.node.setAttribute('aria-hidden', 'true');\n break;\n case Widget.HiddenMode.ContentVisibility:\n // @ts-expect-error content-visibility unknown by DOM lib types\n this.node.style.contentVisibility = 'hidden';\n this.node.style.zIndex = '-1';\n break;\n }\n } else {\n switch (this._hiddenMode) {\n case Widget.HiddenMode.Display:\n this.removeClass('lm-mod-hidden');\n break;\n case Widget.HiddenMode.Scale:\n this.node.style.transform = '';\n this.node.removeAttribute('aria-hidden');\n break;\n case Widget.HiddenMode.ContentVisibility:\n // @ts-expect-error content-visibility unknown by DOM lib types\n this.node.style.contentVisibility = '';\n this.node.style.zIndex = '';\n break;\n }\n }\n }\n\n private _flags = 0;\n private _layout: Layout | null = null;\n private _parent: Widget | null = null;\n private _disposed = new Signal(this);\n private _hiddenMode: Widget.HiddenMode = Widget.HiddenMode.Display;\n}\n\n/**\n * The namespace for the `Widget` class statics.\n */\nexport namespace Widget {\n /**\n * An options object for initializing a widget.\n */\n export interface IOptions {\n /**\n * The optional node to use for the widget.\n *\n * If a node is provided, the widget will assume full ownership\n * and control of the node, as if it had created the node itself.\n *\n * The default is a new `
`.\n */\n node?: HTMLElement;\n\n /**\n * The optional element tag, used for constructing the widget's node.\n *\n * If a pre-constructed node is provided via the `node` arg, this\n * value is ignored.\n */\n tag?: keyof HTMLElementTagNameMap;\n }\n\n /**\n * The method for hiding the widget.\n *\n * The default is Display.\n *\n * Using `Scale` will often increase performance as most browsers will not\n * trigger style computation for the `transform` action. This should be used\n * sparingly and tested, since increasing the number of composition layers\n * may slow things down.\n *\n * To ensure the transformation does not trigger style recomputation, you\n * may need to set the widget CSS style `will-change: transform`. This\n * should be used only when needed as it may overwhelm the browser with a\n * high number of layers. See\n * https://developer.mozilla.org/en-US/docs/Web/CSS/will-change\n */\n export enum HiddenMode {\n /**\n * Set a `lm-mod-hidden` CSS class to hide the widget using `display:none`\n * CSS from the standard Lumino CSS.\n */\n Display = 0,\n\n /**\n * Hide the widget by setting the `transform` to `'scale(0)'`.\n */\n Scale,\n\n /**\n *Hide the widget by setting the `content-visibility` to `'hidden'`.\n */\n ContentVisibility\n }\n\n /**\n * An enum of widget bit flags.\n */\n export enum Flag {\n /**\n * The widget has been disposed.\n */\n IsDisposed = 0x1,\n\n /**\n * The widget is attached to the DOM.\n */\n IsAttached = 0x2,\n\n /**\n * The widget is hidden.\n */\n IsHidden = 0x4,\n\n /**\n * The widget is visible.\n */\n IsVisible = 0x8,\n\n /**\n * A layout cannot be set on the widget.\n */\n DisallowLayout = 0x10\n }\n\n /**\n * A collection of stateless messages related to widgets.\n */\n export namespace Msg {\n /**\n * A singleton `'before-show'` message.\n *\n * #### Notes\n * This message is sent to a widget before it becomes visible.\n *\n * This message is **not** sent when the widget is being attached.\n */\n export const BeforeShow = new Message('before-show');\n\n /**\n * A singleton `'after-show'` message.\n *\n * #### Notes\n * This message is sent to a widget after it becomes visible.\n *\n * This message is **not** sent when the widget is being attached.\n */\n export const AfterShow = new Message('after-show');\n\n /**\n * A singleton `'before-hide'` message.\n *\n * #### Notes\n * This message is sent to a widget before it becomes not-visible.\n *\n * This message is **not** sent when the widget is being detached.\n */\n export const BeforeHide = new Message('before-hide');\n\n /**\n * A singleton `'after-hide'` message.\n *\n * #### Notes\n * This message is sent to a widget after it becomes not-visible.\n *\n * This message is **not** sent when the widget is being detached.\n */\n export const AfterHide = new Message('after-hide');\n\n /**\n * A singleton `'before-attach'` message.\n *\n * #### Notes\n * This message is sent to a widget before it is attached.\n */\n export const BeforeAttach = new Message('before-attach');\n\n /**\n * A singleton `'after-attach'` message.\n *\n * #### Notes\n * This message is sent to a widget after it is attached.\n */\n export const AfterAttach = new Message('after-attach');\n\n /**\n * A singleton `'before-detach'` message.\n *\n * #### Notes\n * This message is sent to a widget before it is detached.\n */\n export const BeforeDetach = new Message('before-detach');\n\n /**\n * A singleton `'after-detach'` message.\n *\n * #### Notes\n * This message is sent to a widget after it is detached.\n */\n export const AfterDetach = new Message('after-detach');\n\n /**\n * A singleton `'parent-changed'` message.\n *\n * #### Notes\n * This message is sent to a widget when its parent has changed.\n */\n export const ParentChanged = new Message('parent-changed');\n\n /**\n * A singleton conflatable `'update-request'` message.\n *\n * #### Notes\n * This message can be dispatched to supporting widgets in order to\n * update their content based on the current widget state. Not all\n * widgets will respond to messages of this type.\n *\n * For widgets with a layout, this message will inform the layout to\n * update the position and size of its child widgets.\n */\n export const UpdateRequest = new ConflatableMessage('update-request');\n\n /**\n * A singleton conflatable `'fit-request'` message.\n *\n * #### Notes\n * For widgets with a layout, this message will inform the layout to\n * recalculate its size constraints to fit the space requirements of\n * its child widgets, and to update their position and size. Not all\n * layouts will respond to messages of this type.\n */\n export const FitRequest = new ConflatableMessage('fit-request');\n\n /**\n * A singleton conflatable `'activate-request'` message.\n *\n * #### Notes\n * This message should be dispatched to a widget when it should\n * perform the actions necessary to activate the widget, which\n * may include focusing its node or descendant node.\n */\n export const ActivateRequest = new ConflatableMessage('activate-request');\n\n /**\n * A singleton conflatable `'close-request'` message.\n *\n * #### Notes\n * This message should be dispatched to a widget when it should close\n * and remove itself from the widget hierarchy.\n */\n export const CloseRequest = new ConflatableMessage('close-request');\n }\n\n /**\n * A message class for child related messages.\n */\n export class ChildMessage extends Message {\n /**\n * Construct a new child message.\n *\n * @param type - The message type.\n *\n * @param child - The child widget for the message.\n */\n constructor(type: string, child: Widget) {\n super(type);\n this.child = child;\n }\n\n /**\n * The child widget for the message.\n */\n readonly child: Widget;\n }\n\n /**\n * A message class for `'resize'` messages.\n */\n export class ResizeMessage extends Message {\n /**\n * Construct a new resize message.\n *\n * @param width - The **offset width** of the widget, or `-1` if\n * the width is not known.\n *\n * @param height - The **offset height** of the widget, or `-1` if\n * the height is not known.\n */\n constructor(width: number, height: number) {\n super('resize');\n this.width = width;\n this.height = height;\n }\n\n /**\n * The offset width of the widget.\n *\n * #### Notes\n * This will be `-1` if the width is unknown.\n */\n readonly width: number;\n\n /**\n * The offset height of the widget.\n *\n * #### Notes\n * This will be `-1` if the height is unknown.\n */\n readonly height: number;\n }\n\n /**\n * The namespace for the `ResizeMessage` class statics.\n */\n export namespace ResizeMessage {\n /**\n * A singleton `'resize'` message with an unknown size.\n */\n export const UnknownSize = new ResizeMessage(-1, -1);\n }\n\n /**\n * Attach a widget to a host DOM node.\n *\n * @param widget - The widget of interest.\n *\n * @param host - The DOM node to use as the widget's host.\n *\n * @param ref - The child of `host` to use as the reference element.\n * If this is provided, the widget will be inserted before this\n * node in the host. The default is `null`, which will cause the\n * widget to be added as the last child of the host.\n *\n * #### Notes\n * This will throw an error if the widget is not a root widget, if\n * the widget is already attached, or if the host is not attached\n * to the DOM.\n */\n export function attach(\n widget: Widget,\n host: HTMLElement,\n ref: HTMLElement | null = null\n ): void {\n if (widget.parent) {\n throw new Error('Cannot attach a child widget.');\n }\n if (widget.isAttached || widget.node.isConnected) {\n throw new Error('Widget is already attached.');\n }\n if (!host.isConnected) {\n throw new Error('Host is not attached.');\n }\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n host.insertBefore(widget.node, ref);\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n\n /**\n * Detach the widget from its host DOM node.\n *\n * @param widget - The widget of interest.\n *\n * #### Notes\n * This will throw an error if the widget is not a root widget,\n * or if the widget is not attached to the DOM.\n */\n export function detach(widget: Widget): void {\n if (widget.parent) {\n throw new Error('Cannot detach a child widget.');\n }\n if (!widget.isAttached || !widget.node.isConnected) {\n throw new Error('Widget is not attached.');\n }\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n widget.node.parentNode!.removeChild(widget.node);\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * An attached property for the widget title object.\n */\n export const titleProperty = new AttachedProperty>({\n name: 'title',\n create: owner => new Title({ owner })\n });\n\n /**\n * Create a DOM node for the given widget options.\n */\n export function createNode(options: Widget.IOptions): HTMLElement {\n return options.node || document.createElement(options.tag || 'div');\n }\n}\n","/* eslint-disable @typescript-eslint/no-empty-function */\n// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { Signal } from '@lumino/signaling';\n\nimport { Widget } from './widget';\n\n/**\n * An abstract base class for creating lumino layouts.\n *\n * #### Notes\n * A layout is used to add widgets to a parent and to arrange those\n * widgets within the parent's DOM node.\n *\n * This class implements the base functionality which is required of\n * nearly all layouts. It must be subclassed in order to be useful.\n *\n * Notably, this class does not define a uniform interface for adding\n * widgets to the layout. A subclass should define that API in a way\n * which is meaningful for its intended use.\n */\nexport abstract class Layout implements Iterable, IDisposable {\n /**\n * Construct a new layout.\n *\n * @param options - The options for initializing the layout.\n */\n constructor(options: Layout.IOptions = {}) {\n this._fitPolicy = options.fitPolicy || 'set-min-size';\n }\n\n /**\n * Dispose of the resources held by the layout.\n *\n * #### Notes\n * This should be reimplemented to clear and dispose of the widgets.\n *\n * All reimplementations should call the superclass method.\n *\n * This method is called automatically when the parent is disposed.\n */\n dispose(): void {\n this._parent = null;\n this._disposed = true;\n Signal.clearData(this);\n AttachedProperty.clearData(this);\n }\n\n /**\n * Test whether the layout is disposed.\n */\n get isDisposed(): boolean {\n return this._disposed;\n }\n\n /**\n * Get the parent widget of the layout.\n */\n get parent(): Widget | null {\n return this._parent;\n }\n\n /**\n * Set the parent widget of the layout.\n *\n * #### Notes\n * This is set automatically when installing the layout on the parent\n * widget. The parent widget should not be set directly by user code.\n */\n set parent(value: Widget | null) {\n if (this._parent === value) {\n return;\n }\n if (this._parent) {\n throw new Error('Cannot change parent widget.');\n }\n if (value!.layout !== this) {\n throw new Error('Invalid parent widget.');\n }\n this._parent = value;\n this.init();\n }\n\n /**\n * Get the fit policy for the layout.\n *\n * #### Notes\n * The fit policy controls the computed size constraints which are\n * applied to the parent widget by the layout.\n *\n * Some layout implementations may ignore the fit policy.\n */\n get fitPolicy(): Layout.FitPolicy {\n return this._fitPolicy;\n }\n\n /**\n * Set the fit policy for the layout.\n *\n * #### Notes\n * The fit policy controls the computed size constraints which are\n * applied to the parent widget by the layout.\n *\n * Some layout implementations may ignore the fit policy.\n *\n * Changing the fit policy will clear the current size constraint\n * for the parent widget and then re-fit the parent.\n */\n set fitPolicy(value: Layout.FitPolicy) {\n // Bail if the policy does not change\n if (this._fitPolicy === value) {\n return;\n }\n\n // Update the internal policy.\n this._fitPolicy = value;\n\n // Clear the size constraints and schedule a fit of the parent.\n if (this._parent) {\n let style = this._parent.node.style;\n style.minWidth = '';\n style.minHeight = '';\n style.maxWidth = '';\n style.maxHeight = '';\n this._parent.fit();\n }\n }\n\n /**\n * Create an iterator over the widgets in the layout.\n *\n * @returns A new iterator over the widgets in the layout.\n *\n * #### Notes\n * This abstract method must be implemented by a subclass.\n */\n abstract [Symbol.iterator](): IterableIterator;\n\n /**\n * Remove a widget from the layout.\n *\n * @param widget - The widget to remove from the layout.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method should *not* modify the widget's `parent`.\n */\n abstract removeWidget(widget: Widget): void;\n\n /**\n * Process a message sent to the parent widget.\n *\n * @param msg - The message sent to the parent widget.\n *\n * #### Notes\n * This method is called by the parent widget to process a message.\n *\n * Subclasses may reimplement this method as needed.\n */\n processParentMessage(msg: Message): void {\n switch (msg.type) {\n case 'resize':\n this.onResize(msg as Widget.ResizeMessage);\n break;\n case 'update-request':\n this.onUpdateRequest(msg);\n break;\n case 'fit-request':\n this.onFitRequest(msg);\n break;\n case 'before-show':\n this.onBeforeShow(msg);\n break;\n case 'after-show':\n this.onAfterShow(msg);\n break;\n case 'before-hide':\n this.onBeforeHide(msg);\n break;\n case 'after-hide':\n this.onAfterHide(msg);\n break;\n case 'before-attach':\n this.onBeforeAttach(msg);\n break;\n case 'after-attach':\n this.onAfterAttach(msg);\n break;\n case 'before-detach':\n this.onBeforeDetach(msg);\n break;\n case 'after-detach':\n this.onAfterDetach(msg);\n break;\n case 'child-removed':\n this.onChildRemoved(msg as Widget.ChildMessage);\n break;\n case 'child-shown':\n this.onChildShown(msg as Widget.ChildMessage);\n break;\n case 'child-hidden':\n this.onChildHidden(msg as Widget.ChildMessage);\n break;\n }\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n *\n * #### Notes\n * This method is invoked immediately after the layout is installed\n * on the parent widget.\n *\n * The default implementation reparents all of the widgets to the\n * layout parent widget.\n *\n * Subclasses should reimplement this method and attach the child\n * widget nodes to the parent widget's node.\n */\n protected init(): void {\n for (const widget of this) {\n widget.parent = this.parent;\n }\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n *\n * #### Notes\n * The layout should ensure that its widgets are resized according\n * to the specified layout space, and that they are sent a `'resize'`\n * message if appropriate.\n *\n * The default implementation of this method sends an `UnknownSize`\n * resize message to all widgets.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, Widget.ResizeMessage.UnknownSize);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n *\n * #### Notes\n * The layout should ensure that its widgets are resized according\n * to the available layout space, and that they are sent a `'resize'`\n * message if appropriate.\n *\n * The default implementation of this method sends an `UnknownSize`\n * resize message to all widgets.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onUpdateRequest(msg: Message): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, Widget.ResizeMessage.UnknownSize);\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message\n * to all widgets. It assumes all widget nodes are attached to the\n * parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onBeforeAttach(msg: Message): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n\n /**\n * A message handler invoked on an `'after-attach'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message\n * to all widgets. It assumes all widget nodes are attached to the\n * parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onAfterAttach(msg: Message): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n\n /**\n * A message handler invoked on a `'before-detach'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message\n * to all widgets. It assumes all widget nodes are attached to the\n * parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onBeforeDetach(msg: Message): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message\n * to all widgets. It assumes all widget nodes are attached to the\n * parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onAfterDetach(msg: Message): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message to\n * all non-hidden widgets. It assumes all widget nodes are attached\n * to the parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onBeforeShow(msg: Message): void {\n for (const widget of this) {\n if (!widget.isHidden) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n }\n\n /**\n * A message handler invoked on an `'after-show'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message to\n * all non-hidden widgets. It assumes all widget nodes are attached\n * to the parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onAfterShow(msg: Message): void {\n for (const widget of this) {\n if (!widget.isHidden) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n }\n\n /**\n * A message handler invoked on a `'before-hide'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message to\n * all non-hidden widgets. It assumes all widget nodes are attached\n * to the parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onBeforeHide(msg: Message): void {\n for (const widget of this) {\n if (!widget.isHidden) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n }\n\n /**\n * A message handler invoked on an `'after-hide'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message to\n * all non-hidden widgets. It assumes all widget nodes are attached\n * to the parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onAfterHide(msg: Message): void {\n for (const widget of this) {\n if (!widget.isHidden) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n }\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n *\n * #### Notes\n * This will remove the child widget from the layout.\n *\n * Subclasses should **not** typically reimplement this method.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {\n this.removeWidget(msg.child);\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onFitRequest(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {}\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {}\n\n private _disposed = false;\n private _fitPolicy: Layout.FitPolicy;\n private _parent: Widget | null = null;\n}\n\n/**\n * The namespace for the `Layout` class statics.\n */\nexport namespace Layout {\n /**\n * A type alias for the layout fit policy.\n *\n * #### Notes\n * The fit policy controls the computed size constraints which are\n * applied to the parent widget by the layout.\n *\n * Some layout implementations may ignore the fit policy.\n */\n export type FitPolicy =\n | /**\n * No size constraint will be applied to the parent widget.\n */\n 'set-no-constraint'\n\n /**\n * The computed min size will be applied to the parent widget.\n */\n | 'set-min-size';\n\n /**\n * An options object for initializing a layout.\n */\n export interface IOptions {\n /**\n * The fit policy for the layout.\n *\n * The default is `'set-min-size'`.\n */\n fitPolicy?: FitPolicy;\n }\n\n /**\n * A type alias for the horizontal alignment of a widget.\n */\n export type HorizontalAlignment = 'left' | 'center' | 'right';\n\n /**\n * A type alias for the vertical alignment of a widget.\n */\n export type VerticalAlignment = 'top' | 'center' | 'bottom';\n\n /**\n * Get the horizontal alignment for a widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The horizontal alignment for the widget.\n *\n * #### Notes\n * If the layout width allocated to a widget is larger than its max\n * width, the horizontal alignment controls how the widget is placed\n * within the extra horizontal space.\n *\n * If the allocated width is less than the widget's max width, the\n * horizontal alignment has no effect.\n *\n * Some layout implementations may ignore horizontal alignment.\n */\n export function getHorizontalAlignment(widget: Widget): HorizontalAlignment {\n return Private.horizontalAlignmentProperty.get(widget);\n }\n\n /**\n * Set the horizontal alignment for a widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the horizontal alignment.\n *\n * #### Notes\n * If the layout width allocated to a widget is larger than its max\n * width, the horizontal alignment controls how the widget is placed\n * within the extra horizontal space.\n *\n * If the allocated width is less than the widget's max width, the\n * horizontal alignment has no effect.\n *\n * Some layout implementations may ignore horizontal alignment.\n *\n * Changing the horizontal alignment will post an `update-request`\n * message to widget's parent, provided the parent has a layout\n * installed.\n */\n export function setHorizontalAlignment(\n widget: Widget,\n value: HorizontalAlignment\n ): void {\n Private.horizontalAlignmentProperty.set(widget, value);\n }\n\n /**\n * Get the vertical alignment for a widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The vertical alignment for the widget.\n *\n * #### Notes\n * If the layout height allocated to a widget is larger than its max\n * height, the vertical alignment controls how the widget is placed\n * within the extra vertical space.\n *\n * If the allocated height is less than the widget's max height, the\n * vertical alignment has no effect.\n *\n * Some layout implementations may ignore vertical alignment.\n */\n export function getVerticalAlignment(widget: Widget): VerticalAlignment {\n return Private.verticalAlignmentProperty.get(widget);\n }\n\n /**\n * Set the vertical alignment for a widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the vertical alignment.\n *\n * #### Notes\n * If the layout height allocated to a widget is larger than its max\n * height, the vertical alignment controls how the widget is placed\n * within the extra vertical space.\n *\n * If the allocated height is less than the widget's max height, the\n * vertical alignment has no effect.\n *\n * Some layout implementations may ignore vertical alignment.\n *\n * Changing the horizontal alignment will post an `update-request`\n * message to widget's parent, provided the parent has a layout\n * installed.\n */\n export function setVerticalAlignment(\n widget: Widget,\n value: VerticalAlignment\n ): void {\n Private.verticalAlignmentProperty.set(widget, value);\n }\n}\n\n/**\n * An object which assists in the absolute layout of widgets.\n *\n * #### Notes\n * This class is useful when implementing a layout which arranges its\n * widgets using absolute positioning.\n *\n * This class is used by nearly all of the built-in lumino layouts.\n */\nexport class LayoutItem implements IDisposable {\n /**\n * Construct a new layout item.\n *\n * @param widget - The widget to be managed by the item.\n *\n * #### Notes\n * The widget will be set to absolute positioning.\n * The widget will use strict CSS containment.\n */\n constructor(widget: Widget) {\n this.widget = widget;\n this.widget.node.style.position = 'absolute';\n this.widget.node.style.contain = 'strict';\n }\n\n /**\n * Dispose of the the layout item.\n *\n * #### Notes\n * This will reset the positioning of the widget.\n */\n dispose(): void {\n // Do nothing if the item is already disposed.\n if (this._disposed) {\n return;\n }\n\n // Mark the item as disposed.\n this._disposed = true;\n\n // Reset the widget style.\n let style = this.widget.node.style;\n style.position = '';\n style.top = '';\n style.left = '';\n style.width = '';\n style.height = '';\n style.contain = '';\n }\n\n /**\n * The widget managed by the layout item.\n */\n readonly widget: Widget;\n\n /**\n * The computed minimum width of the widget.\n *\n * #### Notes\n * This value can be updated by calling the `fit` method.\n */\n get minWidth(): number {\n return this._minWidth;\n }\n\n /**\n * The computed minimum height of the widget.\n *\n * #### Notes\n * This value can be updated by calling the `fit` method.\n */\n get minHeight(): number {\n return this._minHeight;\n }\n\n /**\n * The computed maximum width of the widget.\n *\n * #### Notes\n * This value can be updated by calling the `fit` method.\n */\n get maxWidth(): number {\n return this._maxWidth;\n }\n\n /**\n * The computed maximum height of the widget.\n *\n * #### Notes\n * This value can be updated by calling the `fit` method.\n */\n get maxHeight(): number {\n return this._maxHeight;\n }\n\n /**\n * Whether the layout item is disposed.\n */\n get isDisposed(): boolean {\n return this._disposed;\n }\n\n /**\n * Whether the managed widget is hidden.\n */\n get isHidden(): boolean {\n return this.widget.isHidden;\n }\n\n /**\n * Whether the managed widget is visible.\n */\n get isVisible(): boolean {\n return this.widget.isVisible;\n }\n\n /**\n * Whether the managed widget is attached.\n */\n get isAttached(): boolean {\n return this.widget.isAttached;\n }\n\n /**\n * Update the computed size limits of the managed widget.\n */\n fit(): void {\n let limits = ElementExt.sizeLimits(this.widget.node);\n this._minWidth = limits.minWidth;\n this._minHeight = limits.minHeight;\n this._maxWidth = limits.maxWidth;\n this._maxHeight = limits.maxHeight;\n }\n\n /**\n * Update the position and size of the managed widget.\n *\n * @param left - The left edge position of the layout box.\n *\n * @param top - The top edge position of the layout box.\n *\n * @param width - The width of the layout box.\n *\n * @param height - The height of the layout box.\n */\n update(left: number, top: number, width: number, height: number): void {\n // Clamp the size to the computed size limits.\n let clampW = Math.max(this._minWidth, Math.min(width, this._maxWidth));\n let clampH = Math.max(this._minHeight, Math.min(height, this._maxHeight));\n\n // Adjust the left edge for the horizontal alignment, if needed.\n if (clampW < width) {\n switch (Layout.getHorizontalAlignment(this.widget)) {\n case 'left':\n break;\n case 'center':\n left += (width - clampW) / 2;\n break;\n case 'right':\n left += width - clampW;\n break;\n default:\n throw 'unreachable';\n }\n }\n\n // Adjust the top edge for the vertical alignment, if needed.\n if (clampH < height) {\n switch (Layout.getVerticalAlignment(this.widget)) {\n case 'top':\n break;\n case 'center':\n top += (height - clampH) / 2;\n break;\n case 'bottom':\n top += height - clampH;\n break;\n default:\n throw 'unreachable';\n }\n }\n\n // Set up the resize variables.\n let resized = false;\n let style = this.widget.node.style;\n\n // Update the top edge of the widget if needed.\n if (this._top !== top) {\n this._top = top;\n style.top = `${top}px`;\n }\n\n // Update the left edge of the widget if needed.\n if (this._left !== left) {\n this._left = left;\n style.left = `${left}px`;\n }\n\n // Update the width of the widget if needed.\n if (this._width !== clampW) {\n resized = true;\n this._width = clampW;\n style.width = `${clampW}px`;\n }\n\n // Update the height of the widget if needed.\n if (this._height !== clampH) {\n resized = true;\n this._height = clampH;\n style.height = `${clampH}px`;\n }\n\n // Send a resize message to the widget if needed.\n if (resized) {\n let msg = new Widget.ResizeMessage(clampW, clampH);\n MessageLoop.sendMessage(this.widget, msg);\n }\n }\n\n private _top = NaN;\n private _left = NaN;\n private _width = NaN;\n private _height = NaN;\n private _minWidth = 0;\n private _minHeight = 0;\n private _maxWidth = Infinity;\n private _maxHeight = Infinity;\n private _disposed = false;\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The attached property for a widget horizontal alignment.\n */\n export const horizontalAlignmentProperty = new AttachedProperty<\n Widget,\n Layout.HorizontalAlignment\n >({\n name: 'horizontalAlignment',\n create: () => 'center',\n changed: onAlignmentChanged\n });\n\n /**\n * The attached property for a widget vertical alignment.\n */\n export const verticalAlignmentProperty = new AttachedProperty<\n Widget,\n Layout.VerticalAlignment\n >({\n name: 'verticalAlignment',\n create: () => 'top',\n changed: onAlignmentChanged\n });\n\n /**\n * The change handler for the attached alignment properties.\n */\n function onAlignmentChanged(child: Widget): void {\n if (child.parent && child.parent.layout) {\n child.parent.update();\n }\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { MessageLoop } from '@lumino/messaging';\n\nimport { Layout } from './layout';\n\nimport { Widget } from './widget';\n\n/**\n * A concrete layout implementation suitable for many use cases.\n *\n * #### Notes\n * This class is suitable as a base class for implementing a variety of\n * layouts, but can also be used directly with standard CSS to layout a\n * collection of widgets.\n */\nexport class PanelLayout extends Layout {\n /**\n * Dispose of the resources held by the layout.\n *\n * #### Notes\n * This will clear and dispose all widgets in the layout.\n *\n * All reimplementations should call the superclass method.\n *\n * This method is called automatically when the parent is disposed.\n */\n dispose(): void {\n while (this._widgets.length > 0) {\n this._widgets.pop()!.dispose();\n }\n super.dispose();\n }\n\n /**\n * A read-only array of the widgets in the layout.\n */\n get widgets(): ReadonlyArray {\n return this._widgets;\n }\n\n /**\n * Create an iterator over the widgets in the layout.\n *\n * @returns A new iterator over the widgets in the layout.\n */\n *[Symbol.iterator](): IterableIterator {\n yield* this._widgets;\n }\n\n /**\n * Add a widget to the end of the layout.\n *\n * @param widget - The widget to add to the layout.\n *\n * #### Notes\n * If the widget is already contained in the layout, it will be moved.\n */\n addWidget(widget: Widget): void {\n this.insertWidget(this._widgets.length, widget);\n }\n\n /**\n * Insert a widget into the layout at the specified index.\n *\n * @param index - The index at which to insert the widget.\n *\n * @param widget - The widget to insert into the layout.\n *\n * #### Notes\n * The index will be clamped to the bounds of the widgets.\n *\n * If the widget is already added to the layout, it will be moved.\n *\n * #### Undefined Behavior\n * An `index` which is non-integral.\n */\n insertWidget(index: number, widget: Widget): void {\n // Remove the widget from its current parent. This is a no-op\n // if the widget's parent is already the layout parent widget.\n widget.parent = this.parent;\n\n // Look up the current index of the widget.\n let i = this._widgets.indexOf(widget);\n\n // Clamp the insert index to the array bounds.\n let j = Math.max(0, Math.min(index, this._widgets.length));\n\n // If the widget is not in the array, insert it.\n if (i === -1) {\n // Insert the widget into the array.\n ArrayExt.insert(this._widgets, j, widget);\n\n // If the layout is parented, attach the widget to the DOM.\n if (this.parent) {\n this.attachWidget(j, widget);\n }\n\n // There is nothing more to do.\n return;\n }\n\n // Otherwise, the widget exists in the array and should be moved.\n\n // Adjust the index if the location is at the end of the array.\n if (j === this._widgets.length) {\n j--;\n }\n\n // Bail if there is no effective move.\n if (i === j) {\n return;\n }\n\n // Move the widget to the new location.\n ArrayExt.move(this._widgets, i, j);\n\n // If the layout is parented, move the widget in the DOM.\n if (this.parent) {\n this.moveWidget(i, j, widget);\n }\n }\n\n /**\n * Remove a widget from the layout.\n *\n * @param widget - The widget to remove from the layout.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method does *not* modify the widget's `parent`.\n */\n removeWidget(widget: Widget): void {\n this.removeWidgetAt(this._widgets.indexOf(widget));\n }\n\n /**\n * Remove the widget at a given index from the layout.\n *\n * @param index - The index of the widget to remove.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method does *not* modify the widget's `parent`.\n *\n * #### Undefined Behavior\n * An `index` which is non-integral.\n */\n removeWidgetAt(index: number): void {\n // Remove the widget from the array.\n let widget = ArrayExt.removeAt(this._widgets, index);\n\n // If the layout is parented, detach the widget from the DOM.\n if (widget && this.parent) {\n this.detachWidget(index, widget);\n }\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n super.init();\n let index = 0;\n for (const widget of this) {\n this.attachWidget(index++, widget);\n }\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param index - The current index of the widget in the layout.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This method is called automatically by the panel layout at the\n * appropriate time. It should not be called directly by user code.\n *\n * The default implementation adds the widgets's node to the parent's\n * node at the proper location, and sends the appropriate attach\n * messages to the widget if the parent is attached to the DOM.\n *\n * Subclasses may reimplement this method to control how the widget's\n * node is added to the parent's node.\n */\n protected attachWidget(index: number, widget: Widget): void {\n // Look up the next sibling reference node.\n let ref = this.parent!.node.children[index];\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Insert the widget's node before the sibling.\n this.parent!.node.insertBefore(widget.node, ref);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n }\n\n /**\n * Move a widget in the parent's DOM node.\n *\n * @param fromIndex - The previous index of the widget in the layout.\n *\n * @param toIndex - The current index of the widget in the layout.\n *\n * @param widget - The widget to move in the parent.\n *\n * #### Notes\n * This method is called automatically by the panel layout at the\n * appropriate time. It should not be called directly by user code.\n *\n * The default implementation moves the widget's node to the proper\n * location in the parent's node and sends the appropriate attach and\n * detach messages to the widget if the parent is attached to the DOM.\n *\n * Subclasses may reimplement this method to control how the widget's\n * node is moved in the parent's node.\n */\n protected moveWidget(\n fromIndex: number,\n toIndex: number,\n widget: Widget\n ): void {\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` and message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Look up the next sibling reference node.\n let ref = this.parent!.node.children[toIndex];\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Insert the widget's node before the sibling.\n this.parent!.node.insertBefore(widget.node, ref);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param index - The previous index of the widget in the layout.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This method is called automatically by the panel layout at the\n * appropriate time. It should not be called directly by user code.\n *\n * The default implementation removes the widget's node from the\n * parent's node, and sends the appropriate detach messages to the\n * widget if the parent is attached to the DOM.\n *\n * Subclasses may reimplement this method to control how the widget's\n * node is removed from the parent's node.\n */\n protected detachWidget(index: number, widget: Widget): void {\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n }\n\n private _widgets: Widget[] = [];\n}\n","/*\n * Copyright (c) Jupyter Development Team.\n * Distributed under the terms of the Modified BSD License.\n */\n\nexport namespace Utils {\n /**\n * Clamp a dimension value to an integer >= 0.\n */\n export function clampDimension(value: number): number {\n return Math.max(0, Math.floor(value));\n }\n}\n\nexport default Utils;\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { BoxEngine, BoxSizer } from './boxengine';\n\nimport { LayoutItem } from './layout';\n\nimport { PanelLayout } from './panellayout';\n\nimport { Utils } from './utils';\n\nimport { Widget } from './widget';\n\n/**\n * A layout which arranges its widgets into resizable sections.\n */\nexport class SplitLayout extends PanelLayout {\n /**\n * Construct a new split layout.\n *\n * @param options - The options for initializing the layout.\n */\n constructor(options: SplitLayout.IOptions) {\n super();\n this.renderer = options.renderer;\n if (options.orientation !== undefined) {\n this._orientation = options.orientation;\n }\n if (options.alignment !== undefined) {\n this._alignment = options.alignment;\n }\n if (options.spacing !== undefined) {\n this._spacing = Utils.clampDimension(options.spacing);\n }\n }\n\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n // Dispose of the layout items.\n for (const item of this._items) {\n item.dispose();\n }\n\n // Clear the layout state.\n this._box = null;\n this._items.length = 0;\n this._sizers.length = 0;\n this._handles.length = 0;\n\n // Dispose of the rest of the layout.\n super.dispose();\n }\n\n /**\n * The renderer used by the split layout.\n */\n readonly renderer: SplitLayout.IRenderer;\n\n /**\n * Get the layout orientation for the split layout.\n */\n get orientation(): SplitLayout.Orientation {\n return this._orientation;\n }\n\n /**\n * Set the layout orientation for the split layout.\n */\n set orientation(value: SplitLayout.Orientation) {\n if (this._orientation === value) {\n return;\n }\n this._orientation = value;\n if (!this.parent) {\n return;\n }\n this.parent.dataset['orientation'] = value;\n this.parent.fit();\n }\n\n /**\n * Get the content alignment for the split layout.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire split layout.\n */\n get alignment(): SplitLayout.Alignment {\n return this._alignment;\n }\n\n /**\n * Set the content alignment for the split layout.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire split layout.\n */\n set alignment(value: SplitLayout.Alignment) {\n if (this._alignment === value) {\n return;\n }\n this._alignment = value;\n if (!this.parent) {\n return;\n }\n this.parent.dataset['alignment'] = value;\n this.parent.update();\n }\n\n /**\n * Get the inter-element spacing for the split layout.\n */\n get spacing(): number {\n return this._spacing;\n }\n\n /**\n * Set the inter-element spacing for the split layout.\n */\n set spacing(value: number) {\n value = Utils.clampDimension(value);\n if (this._spacing === value) {\n return;\n }\n this._spacing = value;\n if (!this.parent) {\n return;\n }\n this.parent.fit();\n }\n\n /**\n * A read-only array of the split handles in the layout.\n */\n get handles(): ReadonlyArray {\n return this._handles;\n }\n\n /**\n * Get the absolute sizes of the widgets in the layout.\n *\n * @returns A new array of the absolute sizes of the widgets.\n *\n * This method **does not** measure the DOM nodes.\n */\n absoluteSizes(): number[] {\n return this._sizers.map(sizer => sizer.size);\n }\n\n /**\n * Get the relative sizes of the widgets in the layout.\n *\n * @returns A new array of the relative sizes of the widgets.\n *\n * #### Notes\n * The returned sizes reflect the sizes of the widgets normalized\n * relative to their siblings.\n *\n * This method **does not** measure the DOM nodes.\n */\n relativeSizes(): number[] {\n return Private.normalize(this._sizers.map(sizer => sizer.size));\n }\n\n /**\n * Set the relative sizes for the widgets in the layout.\n *\n * @param sizes - The relative sizes for the widgets in the panel.\n * @param update - Update the layout after setting relative sizes.\n * Default is True.\n *\n * #### Notes\n * Extra values are ignored, too few will yield an undefined layout.\n *\n * The actual geometry of the DOM nodes is updated asynchronously.\n */\n setRelativeSizes(sizes: number[], update = true): void {\n // Copy the sizes and pad with zeros as needed.\n let n = this._sizers.length;\n let temp = sizes.slice(0, n);\n while (temp.length < n) {\n temp.push(0);\n }\n\n // Normalize the padded sizes.\n let normed = Private.normalize(temp);\n\n // Apply the normalized sizes to the sizers.\n for (let i = 0; i < n; ++i) {\n let sizer = this._sizers[i];\n sizer.sizeHint = normed[i];\n sizer.size = normed[i];\n }\n\n // Set the flag indicating the sizes are normalized.\n this._hasNormedSizes = true;\n\n // Trigger an update of the parent widget.\n if (update && this.parent) {\n this.parent.update();\n }\n }\n\n /**\n * Move the offset position of a split handle.\n *\n * @param index - The index of the handle of the interest.\n *\n * @param position - The desired offset position of the handle.\n *\n * #### Notes\n * The position is relative to the offset parent.\n *\n * This will move the handle as close as possible to the desired\n * position. The sibling widgets will be adjusted as necessary.\n */\n moveHandle(index: number, position: number): void {\n // Bail if the index is invalid or the handle is hidden.\n let handle = this._handles[index];\n if (!handle || handle.classList.contains('lm-mod-hidden')) {\n return;\n }\n\n // Compute the desired delta movement for the handle.\n let delta: number;\n if (this._orientation === 'horizontal') {\n delta = position - handle.offsetLeft;\n } else {\n delta = position - handle.offsetTop;\n }\n\n // Bail if there is no handle movement.\n if (delta === 0) {\n return;\n }\n\n // Prevent widget resizing unless needed.\n for (let sizer of this._sizers) {\n if (sizer.size > 0) {\n sizer.sizeHint = sizer.size;\n }\n }\n\n // Adjust the sizers to reflect the handle movement.\n BoxEngine.adjust(this._sizers, index, delta);\n\n // Update the layout of the widgets.\n if (this.parent) {\n this.parent.update();\n }\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n this.parent!.dataset['orientation'] = this.orientation;\n this.parent!.dataset['alignment'] = this.alignment;\n super.init();\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param index - The current index of the widget in the layout.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected attachWidget(index: number, widget: Widget): void {\n // Create the item, handle, and sizer for the new widget.\n let item = new LayoutItem(widget);\n let handle = Private.createHandle(this.renderer);\n let average = Private.averageSize(this._sizers);\n let sizer = Private.createSizer(average);\n\n // Insert the item, handle, and sizer into the internal arrays.\n ArrayExt.insert(this._items, index, item);\n ArrayExt.insert(this._sizers, index, sizer);\n ArrayExt.insert(this._handles, index, handle);\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget and handle nodes to the parent.\n this.parent!.node.appendChild(widget.node);\n this.parent!.node.appendChild(handle);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * Move a widget in the parent's DOM node.\n *\n * @param fromIndex - The previous index of the widget in the layout.\n *\n * @param toIndex - The current index of the widget in the layout.\n *\n * @param widget - The widget to move in the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected moveWidget(\n fromIndex: number,\n toIndex: number,\n widget: Widget\n ): void {\n // Move the item, sizer, and handle for the widget.\n ArrayExt.move(this._items, fromIndex, toIndex);\n ArrayExt.move(this._sizers, fromIndex, toIndex);\n ArrayExt.move(this._handles, fromIndex, toIndex);\n\n // Post a fit request to the parent to show/hide last handle.\n this.parent!.fit();\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param index - The previous index of the widget in the layout.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected detachWidget(index: number, widget: Widget): void {\n // Remove the item, handle, and sizer for the widget.\n let item = ArrayExt.removeAt(this._items, index);\n let handle = ArrayExt.removeAt(this._handles, index);\n ArrayExt.removeAt(this._sizers, index);\n\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget and handle nodes from the parent.\n this.parent!.node.removeChild(widget.node);\n this.parent!.node.removeChild(handle!);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Dispose of the layout item.\n item!.dispose();\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n */\n protected onBeforeShow(msg: Message): void {\n super.onBeforeShow(msg);\n this.parent!.update();\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n super.onBeforeAttach(msg);\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n if (this.parent!.isVisible) {\n this._update(msg.width, msg.height);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.parent!.isVisible) {\n this._update(-1, -1);\n }\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n */\n protected onFitRequest(msg: Message): void {\n if (this.parent!.isAttached) {\n this._fit();\n }\n }\n\n /**\n * Update the item position.\n *\n * @param i Item index\n * @param isHorizontal Whether the layout is horizontal or not\n * @param left Left position in pixels\n * @param top Top position in pixels\n * @param height Item height\n * @param width Item width\n * @param size Item size\n */\n protected updateItemPosition(\n i: number,\n isHorizontal: boolean,\n left: number,\n top: number,\n height: number,\n width: number,\n size: number\n ): void {\n const item = this._items[i];\n if (item.isHidden) {\n return;\n }\n\n // Fetch the style for the handle.\n let handleStyle = this._handles[i].style;\n\n // Update the widget and handle, and advance the relevant edge.\n if (isHorizontal) {\n left += this.widgetOffset;\n item.update(left, top, size, height);\n left += size;\n handleStyle.top = `${top}px`;\n handleStyle.left = `${left}px`;\n handleStyle.width = `${this._spacing}px`;\n handleStyle.height = `${height}px`;\n } else {\n top += this.widgetOffset;\n item.update(left, top, width, size);\n top += size;\n handleStyle.top = `${top}px`;\n handleStyle.left = `${left}px`;\n handleStyle.width = `${width}px`;\n handleStyle.height = `${this._spacing}px`;\n }\n }\n\n /**\n * Fit the layout to the total size required by the widgets.\n */\n private _fit(): void {\n // Update the handles and track the visible widget count.\n let nVisible = 0;\n let lastHandleIndex = -1;\n for (let i = 0, n = this._items.length; i < n; ++i) {\n if (this._items[i].isHidden) {\n this._handles[i].classList.add('lm-mod-hidden');\n } else {\n this._handles[i].classList.remove('lm-mod-hidden');\n lastHandleIndex = i;\n nVisible++;\n }\n }\n\n // Hide the handle for the last visible widget.\n if (lastHandleIndex !== -1) {\n this._handles[lastHandleIndex].classList.add('lm-mod-hidden');\n }\n\n // Update the fixed space for the visible items.\n this._fixed =\n this._spacing * Math.max(0, nVisible - 1) +\n this.widgetOffset * this._items.length;\n\n // Setup the computed minimum size.\n let horz = this._orientation === 'horizontal';\n let minW = horz ? this._fixed : 0;\n let minH = horz ? 0 : this._fixed;\n\n // Update the sizers and computed size limits.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item and corresponding box sizer.\n let item = this._items[i];\n let sizer = this._sizers[i];\n\n // Prevent resizing unless necessary.\n if (sizer.size > 0) {\n sizer.sizeHint = sizer.size;\n }\n\n // If the item is hidden, it should consume zero size.\n if (item.isHidden) {\n sizer.minSize = 0;\n sizer.maxSize = 0;\n continue;\n }\n\n // Update the size limits for the item.\n item.fit();\n\n // Update the stretch factor.\n sizer.stretch = SplitLayout.getStretch(item.widget);\n\n // Update the sizer limits and computed min size.\n if (horz) {\n sizer.minSize = item.minWidth;\n sizer.maxSize = item.maxWidth;\n minW += item.minWidth;\n minH = Math.max(minH, item.minHeight);\n } else {\n sizer.minSize = item.minHeight;\n sizer.maxSize = item.maxHeight;\n minH += item.minHeight;\n minW = Math.max(minW, item.minWidth);\n }\n }\n\n // Update the box sizing and add it to the computed min size.\n let box = (this._box = ElementExt.boxSizing(this.parent!.node));\n minW += box.horizontalSum;\n minH += box.verticalSum;\n\n // Update the parent's min size constraints.\n let style = this.parent!.node.style;\n style.minWidth = `${minW}px`;\n style.minHeight = `${minH}px`;\n\n // Set the dirty flag to ensure only a single update occurs.\n this._dirty = true;\n\n // Notify the ancestor that it should fit immediately. This may\n // cause a resize of the parent, fulfilling the required update.\n if (this.parent!.parent) {\n MessageLoop.sendMessage(this.parent!.parent!, Widget.Msg.FitRequest);\n }\n\n // If the dirty flag is still set, the parent was not resized.\n // Trigger the required update on the parent widget immediately.\n if (this._dirty) {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n }\n }\n\n /**\n * Update the layout position and size of the widgets.\n *\n * The parent offset dimensions should be `-1` if unknown.\n */\n private _update(offsetWidth: number, offsetHeight: number): void {\n // Clear the dirty flag to indicate the update occurred.\n this._dirty = false;\n\n // Compute the visible item count.\n let nVisible = 0;\n for (let i = 0, n = this._items.length; i < n; ++i) {\n nVisible += +!this._items[i].isHidden;\n }\n\n // Bail early if there are no visible items to layout.\n if (nVisible === 0 && this.widgetOffset === 0) {\n return;\n }\n\n // Measure the parent if the offset dimensions are unknown.\n if (offsetWidth < 0) {\n offsetWidth = this.parent!.node.offsetWidth;\n }\n if (offsetHeight < 0) {\n offsetHeight = this.parent!.node.offsetHeight;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent!.node);\n }\n\n // Compute the actual layout bounds adjusted for border and padding.\n let top = this._box.paddingTop;\n let left = this._box.paddingLeft;\n let width = offsetWidth - this._box.horizontalSum;\n let height = offsetHeight - this._box.verticalSum;\n\n // Set up the variables for justification and alignment offset.\n let extra = 0;\n let offset = 0;\n let horz = this._orientation === 'horizontal';\n\n if (nVisible > 0) {\n // Compute the adjusted layout space.\n let space: number;\n if (horz) {\n // left += this.widgetOffset;\n space = Math.max(0, width - this._fixed);\n } else {\n // top += this.widgetOffset;\n space = Math.max(0, height - this._fixed);\n }\n\n // Scale the size hints if they are normalized.\n if (this._hasNormedSizes) {\n for (let sizer of this._sizers) {\n sizer.sizeHint *= space;\n }\n this._hasNormedSizes = false;\n }\n\n // Distribute the layout space to the box sizers.\n let delta = BoxEngine.calc(this._sizers, space);\n\n // Account for alignment if there is extra layout space.\n if (delta > 0) {\n switch (this._alignment) {\n case 'start':\n break;\n case 'center':\n extra = 0;\n offset = delta / 2;\n break;\n case 'end':\n extra = 0;\n offset = delta;\n break;\n case 'justify':\n extra = delta / nVisible;\n offset = 0;\n break;\n default:\n throw 'unreachable';\n }\n }\n }\n\n // Layout the items using the computed box sizes.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item.\n const item = this._items[i];\n\n // Fetch the computed size for the widget.\n const size = item.isHidden ? 0 : this._sizers[i].size + extra;\n\n this.updateItemPosition(\n i,\n horz,\n horz ? left + offset : left,\n horz ? top : top + offset,\n height,\n width,\n size\n );\n\n const fullOffset =\n this.widgetOffset +\n (this._handles[i].classList.contains('lm-mod-hidden')\n ? 0\n : this._spacing);\n\n if (horz) {\n left += size + fullOffset;\n } else {\n top += size + fullOffset;\n }\n }\n }\n\n protected widgetOffset = 0;\n private _fixed = 0;\n private _spacing = 4;\n private _dirty = false;\n private _hasNormedSizes = false;\n private _sizers: BoxSizer[] = [];\n private _items: LayoutItem[] = [];\n private _handles: HTMLDivElement[] = [];\n private _box: ElementExt.IBoxSizing | null = null;\n private _alignment: SplitLayout.Alignment = 'start';\n private _orientation: SplitLayout.Orientation = 'horizontal';\n}\n\n/**\n * The namespace for the `SplitLayout` class statics.\n */\nexport namespace SplitLayout {\n /**\n * A type alias for a split layout orientation.\n */\n export type Orientation = 'horizontal' | 'vertical';\n\n /**\n * A type alias for a split layout alignment.\n */\n export type Alignment = 'start' | 'center' | 'end' | 'justify';\n\n /**\n * An options object for initializing a split layout.\n */\n export interface IOptions {\n /**\n * The renderer to use for the split layout.\n */\n renderer: IRenderer;\n\n /**\n * The orientation of the layout.\n *\n * The default is `'horizontal'`.\n */\n orientation?: Orientation;\n\n /**\n * The content alignment of the layout.\n *\n * The default is `'start'`.\n */\n alignment?: Alignment;\n\n /**\n * The spacing between items in the layout.\n *\n * The default is `4`.\n */\n spacing?: number;\n }\n\n /**\n * A renderer for use with a split layout.\n */\n export interface IRenderer {\n /**\n * Create a new handle for use with a split layout.\n *\n * @returns A new handle element.\n */\n createHandle(): HTMLDivElement;\n }\n\n /**\n * Get the split layout stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The split layout stretch factor for the widget.\n */\n export function getStretch(widget: Widget): number {\n return Private.stretchProperty.get(widget);\n }\n\n /**\n * Set the split layout stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the stretch factor.\n */\n export function setStretch(widget: Widget, value: number): void {\n Private.stretchProperty.set(widget, value);\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The property descriptor for a widget stretch factor.\n */\n export const stretchProperty = new AttachedProperty({\n name: 'stretch',\n create: () => 0,\n coerce: (owner, value) => Math.max(0, Math.floor(value)),\n changed: onChildSizingChanged\n });\n\n /**\n * Create a new box sizer with the given size hint.\n */\n export function createSizer(size: number): BoxSizer {\n let sizer = new BoxSizer();\n sizer.sizeHint = Math.floor(size);\n return sizer;\n }\n\n /**\n * Create a new split handle node using the given renderer.\n */\n export function createHandle(\n renderer: SplitLayout.IRenderer\n ): HTMLDivElement {\n let handle = renderer.createHandle();\n handle.style.position = 'absolute';\n // Do not use size containment to allow the handle to fill the available space\n handle.style.contain = 'style';\n return handle;\n }\n\n /**\n * Compute the average size of an array of box sizers.\n */\n export function averageSize(sizers: BoxSizer[]): number {\n return sizers.reduce((v, s) => v + s.size, 0) / sizers.length || 0;\n }\n\n /**\n * Normalize an array of values.\n */\n export function normalize(values: number[]): number[] {\n let n = values.length;\n if (n === 0) {\n return [];\n }\n let sum = values.reduce((a, b) => a + Math.abs(b), 0);\n return sum === 0 ? values.map(v => 1 / n) : values.map(v => v / sum);\n }\n\n /**\n * The change handler for the attached sizing properties.\n */\n function onChildSizingChanged(child: Widget): void {\n if (child.parent && child.parent.layout instanceof SplitLayout) {\n child.parent.fit();\n }\n }\n}\n","/*\n * Copyright (c) Jupyter Development Team.\n * Distributed under the terms of the Modified BSD License.\n */\n\nimport { ArrayExt } from '@lumino/algorithm';\nimport { UUID } from '@lumino/coreutils';\nimport { SplitLayout } from './splitlayout';\nimport { Title } from './title';\nimport Utils from './utils';\nimport { Widget } from './widget';\n\n/**\n * A layout which arranges its widgets into collapsible resizable sections.\n */\nexport class AccordionLayout extends SplitLayout {\n /**\n * Construct a new accordion layout.\n *\n * @param options - The options for initializing the layout.\n *\n * #### Notes\n * The default orientation will be vertical.\n *\n * Titles must be rotated for horizontal accordion panel using CSS: see accordionpanel.css\n */\n constructor(options: AccordionLayout.IOptions) {\n super({ ...options, orientation: options.orientation || 'vertical' });\n this.titleSpace = options.titleSpace || 22;\n }\n\n /**\n * The section title height or width depending on the orientation.\n */\n get titleSpace(): number {\n return this.widgetOffset;\n }\n set titleSpace(value: number) {\n value = Utils.clampDimension(value);\n if (this.widgetOffset === value) {\n return;\n }\n this.widgetOffset = value;\n if (!this.parent) {\n return;\n }\n this.parent.fit();\n }\n\n /**\n * A read-only array of the section titles in the panel.\n */\n get titles(): ReadonlyArray {\n return this._titles;\n }\n\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n if (this.isDisposed) {\n return;\n }\n\n // Clear the layout state.\n this._titles.length = 0;\n\n // Dispose of the rest of the layout.\n super.dispose();\n }\n\n /**\n * The renderer used by the accordion layout.\n */\n readonly renderer: AccordionLayout.IRenderer;\n\n public updateTitle(index: number, widget: Widget): void {\n const oldTitle = this._titles[index];\n const expanded = oldTitle.classList.contains('lm-mod-expanded');\n const newTitle = Private.createTitle(this.renderer, widget.title, expanded);\n this._titles[index] = newTitle;\n\n // Add the title node to the parent before the widget.\n this.parent!.node.replaceChild(newTitle, oldTitle);\n }\n\n /**\n * Insert a widget into the layout at the specified index.\n *\n * @param index - The index at which to insert the widget.\n *\n * @param widget - The widget to insert into the layout.\n *\n * #### Notes\n * The index will be clamped to the bounds of the widgets.\n *\n * If the widget is already added to the layout, it will be moved.\n *\n * #### Undefined Behavior\n * An `index` which is non-integral.\n */\n insertWidget(index: number, widget: Widget): void {\n if (!widget.id) {\n widget.id = `id-${UUID.uuid4()}`;\n }\n super.insertWidget(index, widget);\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param index - The current index of the widget in the layout.\n *\n * @param widget - The widget to attach to the parent.\n */\n protected attachWidget(index: number, widget: Widget): void {\n const title = Private.createTitle(this.renderer, widget.title);\n\n ArrayExt.insert(this._titles, index, title);\n\n // Add the title node to the parent before the widget.\n this.parent!.node.appendChild(title);\n\n widget.node.setAttribute('role', 'region');\n widget.node.setAttribute('aria-labelledby', title.id);\n\n super.attachWidget(index, widget);\n }\n\n /**\n * Move a widget in the parent's DOM node.\n *\n * @param fromIndex - The previous index of the widget in the layout.\n *\n * @param toIndex - The current index of the widget in the layout.\n *\n * @param widget - The widget to move in the parent.\n */\n protected moveWidget(\n fromIndex: number,\n toIndex: number,\n widget: Widget\n ): void {\n ArrayExt.move(this._titles, fromIndex, toIndex);\n super.moveWidget(fromIndex, toIndex, widget);\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param index - The previous index of the widget in the layout.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected detachWidget(index: number, widget: Widget): void {\n const title = ArrayExt.removeAt(this._titles, index);\n\n this.parent!.node.removeChild(title!);\n\n super.detachWidget(index, widget);\n }\n\n /**\n * Update the item position.\n *\n * @param i Item index\n * @param isHorizontal Whether the layout is horizontal or not\n * @param left Left position in pixels\n * @param top Top position in pixels\n * @param height Item height\n * @param width Item width\n * @param size Item size\n */\n protected updateItemPosition(\n i: number,\n isHorizontal: boolean,\n left: number,\n top: number,\n height: number,\n width: number,\n size: number\n ): void {\n const titleStyle = this._titles[i].style;\n\n // Titles must be rotated for horizontal accordion panel using CSS: see accordionpanel.css\n titleStyle.top = `${top}px`;\n titleStyle.left = `${left}px`;\n titleStyle.height = `${this.widgetOffset}px`;\n if (isHorizontal) {\n titleStyle.width = `${height}px`;\n } else {\n titleStyle.width = `${width}px`;\n }\n\n super.updateItemPosition(i, isHorizontal, left, top, height, width, size);\n }\n\n private _titles: HTMLElement[] = [];\n}\n\nexport namespace AccordionLayout {\n /**\n * A type alias for a accordion layout orientation.\n */\n export type Orientation = SplitLayout.Orientation;\n\n /**\n * A type alias for a accordion layout alignment.\n */\n export type Alignment = SplitLayout.Alignment;\n\n /**\n * An options object for initializing a accordion layout.\n */\n export interface IOptions extends SplitLayout.IOptions {\n /**\n * The renderer to use for the accordion layout.\n */\n renderer: IRenderer;\n\n /**\n * The section title height or width depending on the orientation.\n *\n * The default is `22`.\n */\n titleSpace?: number;\n }\n\n /**\n * A renderer for use with an accordion layout.\n */\n export interface IRenderer extends SplitLayout.IRenderer {\n /**\n * Common class name for all accordion titles.\n */\n readonly titleClassName: string;\n\n /**\n * Render the element for a section title.\n *\n * @param title - The data to use for rendering the section title.\n *\n * @returns A element representing the section title.\n */\n createSectionTitle(title: Title): HTMLElement;\n }\n}\n\nnamespace Private {\n /**\n * Create the title HTML element.\n *\n * @param renderer Accordion renderer\n * @param data Widget title\n * @returns Title HTML element\n */\n export function createTitle(\n renderer: AccordionLayout.IRenderer,\n data: Title,\n expanded: boolean = true\n ): HTMLElement {\n const title = renderer.createSectionTitle(data);\n title.style.position = 'absolute';\n title.style.contain = 'strict';\n title.setAttribute('aria-label', `${data.label} Section`);\n title.setAttribute('aria-expanded', expanded ? 'true' : 'false');\n title.setAttribute('aria-controls', data.owner.id);\n if (expanded) {\n title.classList.add('lm-mod-expanded');\n }\n return title;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { PanelLayout } from './panellayout';\n\nimport { Widget } from './widget';\n\n/**\n * A simple and convenient panel widget class.\n *\n * #### Notes\n * This class is suitable as a base class for implementing a variety of\n * convenience panel widgets, but can also be used directly with CSS to\n * arrange a collection of widgets.\n *\n * This class provides a convenience wrapper around a {@link PanelLayout}.\n */\nexport class Panel extends Widget {\n /**\n * Construct a new panel.\n *\n * @param options - The options for initializing the panel.\n */\n constructor(options: Panel.IOptions = {}) {\n super();\n this.addClass('lm-Panel');\n this.layout = Private.createLayout(options);\n }\n\n /**\n * A read-only array of the widgets in the panel.\n */\n get widgets(): ReadonlyArray {\n return (this.layout as PanelLayout).widgets;\n }\n\n /**\n * Add a widget to the end of the panel.\n *\n * @param widget - The widget to add to the panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n */\n addWidget(widget: Widget): void {\n (this.layout as PanelLayout).addWidget(widget);\n }\n\n /**\n * Insert a widget at the specified index.\n *\n * @param index - The index at which to insert the widget.\n *\n * @param widget - The widget to insert into to the panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n */\n insertWidget(index: number, widget: Widget): void {\n (this.layout as PanelLayout).insertWidget(index, widget);\n }\n}\n\n/**\n * The namespace for the `Panel` class statics.\n */\nexport namespace Panel {\n /**\n * An options object for creating a panel.\n */\n export interface IOptions {\n /**\n * The panel layout to use for the panel.\n *\n * The default is a new `PanelLayout`.\n */\n layout?: PanelLayout;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Create a panel layout for the given panel options.\n */\n export function createLayout(options: Panel.IOptions): PanelLayout {\n return options.layout || new PanelLayout();\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { IDisposable } from '@lumino/disposable';\n\nimport { Drag } from '@lumino/dragdrop';\n\nimport { Message } from '@lumino/messaging';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { Panel } from './panel';\n\nimport { SplitLayout } from './splitlayout';\n\nimport { Widget } from './widget';\n\n/**\n * A panel which arranges its widgets into resizable sections.\n *\n * #### Notes\n * This class provides a convenience wrapper around a {@link SplitLayout}.\n */\nexport class SplitPanel extends Panel {\n /**\n * Construct a new split panel.\n *\n * @param options - The options for initializing the split panel.\n */\n constructor(options: SplitPanel.IOptions = {}) {\n super({ layout: Private.createLayout(options) });\n this.addClass('lm-SplitPanel');\n }\n\n /**\n * Dispose of the resources held by the panel.\n */\n dispose(): void {\n this._releaseMouse();\n super.dispose();\n }\n\n /**\n * Get the layout orientation for the split panel.\n */\n get orientation(): SplitPanel.Orientation {\n return (this.layout as SplitLayout).orientation;\n }\n\n /**\n * Set the layout orientation for the split panel.\n */\n set orientation(value: SplitPanel.Orientation) {\n (this.layout as SplitLayout).orientation = value;\n }\n\n /**\n * Get the content alignment for the split panel.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire split panel.\n */\n get alignment(): SplitPanel.Alignment {\n return (this.layout as SplitLayout).alignment;\n }\n\n /**\n * Set the content alignment for the split panel.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire split panel.\n */\n set alignment(value: SplitPanel.Alignment) {\n (this.layout as SplitLayout).alignment = value;\n }\n\n /**\n * Get the inter-element spacing for the split panel.\n */\n get spacing(): number {\n return (this.layout as SplitLayout).spacing;\n }\n\n /**\n * Set the inter-element spacing for the split panel.\n */\n set spacing(value: number) {\n (this.layout as SplitLayout).spacing = value;\n }\n\n /**\n * The renderer used by the split panel.\n */\n get renderer(): SplitPanel.IRenderer {\n return (this.layout as SplitLayout).renderer;\n }\n\n /**\n * A signal emitted when a split handle has moved.\n */\n get handleMoved(): ISignal {\n return this._handleMoved;\n }\n\n /**\n * A read-only array of the split handles in the panel.\n */\n get handles(): ReadonlyArray {\n return (this.layout as SplitLayout).handles;\n }\n\n /**\n * Get the relative sizes of the widgets in the panel.\n *\n * @returns A new array of the relative sizes of the widgets.\n *\n * #### Notes\n * The returned sizes reflect the sizes of the widgets normalized\n * relative to their siblings.\n *\n * This method **does not** measure the DOM nodes.\n */\n relativeSizes(): number[] {\n return (this.layout as SplitLayout).relativeSizes();\n }\n\n /**\n * Set the relative sizes for the widgets in the panel.\n *\n * @param sizes - The relative sizes for the widgets in the panel.\n * @param update - Update the layout after setting relative sizes.\n * Default is True.\n *\n * #### Notes\n * Extra values are ignored, too few will yield an undefined layout.\n *\n * The actual geometry of the DOM nodes is updated asynchronously.\n */\n setRelativeSizes(sizes: number[], update = true): void {\n (this.layout as SplitLayout).setRelativeSizes(sizes, update);\n }\n\n /**\n * Handle the DOM events for the split panel.\n *\n * @param event - The DOM event sent to the panel.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the panel's DOM node. It should\n * not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'pointerdown':\n this._evtPointerDown(event as PointerEvent);\n break;\n case 'pointermove':\n this._evtPointerMove(event as PointerEvent);\n break;\n case 'pointerup':\n this._evtPointerUp(event as PointerEvent);\n break;\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('pointerdown', this);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('pointerdown', this);\n this._releaseMouse();\n }\n\n /**\n * A message handler invoked on a `'child-added'` message.\n */\n protected onChildAdded(msg: Widget.ChildMessage): void {\n msg.child.addClass('lm-SplitPanel-child');\n this._releaseMouse();\n }\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {\n msg.child.removeClass('lm-SplitPanel-child');\n this._releaseMouse();\n }\n\n /**\n * Handle the `'keydown'` event for the split panel.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // Stop input events during drag.\n if (this._pressData) {\n event.preventDefault();\n event.stopPropagation();\n }\n\n // Release the mouse if `Escape` is pressed.\n if (event.keyCode === 27) {\n this._releaseMouse();\n }\n }\n\n /**\n * Handle the `'pointerdown'` event for the split panel.\n */\n private _evtPointerDown(event: PointerEvent): void {\n // Do nothing if the primary button is not pressed.\n if (event.button !== 0) {\n return;\n }\n\n // Find the handle which contains the target, if any.\n let layout = this.layout as SplitLayout;\n let index = ArrayExt.findFirstIndex(layout.handles, handle => {\n return handle.contains(event.target as HTMLElement);\n });\n\n // Bail early if the mouse press was not on a handle.\n if (index === -1) {\n return;\n }\n\n // Stop the event when a split handle is pressed.\n event.preventDefault();\n event.stopPropagation();\n\n // Add the extra document listeners.\n document.addEventListener('pointerup', this, true);\n document.addEventListener('pointermove', this, true);\n document.addEventListener('keydown', this, true);\n document.addEventListener('contextmenu', this, true);\n\n // Compute the offset delta for the handle press.\n let delta: number;\n let handle = layout.handles[index];\n let rect = handle.getBoundingClientRect();\n if (layout.orientation === 'horizontal') {\n delta = event.clientX - rect.left;\n } else {\n delta = event.clientY - rect.top;\n }\n\n // Override the cursor and store the press data.\n let style = window.getComputedStyle(handle);\n let override = Drag.overrideCursor(style.cursor!);\n this._pressData = { index, delta, override };\n }\n\n /**\n * Handle the `'pointermove'` event for the split panel.\n */\n private _evtPointerMove(event: PointerEvent): void {\n // Stop the event when dragging a split handle.\n event.preventDefault();\n event.stopPropagation();\n\n // Compute the desired offset position for the handle.\n let pos: number;\n let layout = this.layout as SplitLayout;\n let rect = this.node.getBoundingClientRect();\n if (layout.orientation === 'horizontal') {\n pos = event.clientX - rect.left - this._pressData!.delta;\n } else {\n pos = event.clientY - rect.top - this._pressData!.delta;\n }\n\n // Move the handle as close to the desired position as possible.\n layout.moveHandle(this._pressData!.index, pos);\n }\n\n /**\n * Handle the `'pointerup'` event for the split panel.\n */\n private _evtPointerUp(event: PointerEvent): void {\n // Do nothing if the primary button is not released.\n if (event.button !== 0) {\n return;\n }\n\n // Stop the event when releasing a handle.\n event.preventDefault();\n event.stopPropagation();\n\n // Finalize the mouse release.\n this._releaseMouse();\n }\n\n /**\n * Release the mouse grab for the split panel.\n */\n private _releaseMouse(): void {\n // Bail early if no drag is in progress.\n if (!this._pressData) {\n return;\n }\n\n // Clear the override cursor.\n this._pressData.override.dispose();\n this._pressData = null;\n\n // Emit the handle moved signal.\n this._handleMoved.emit();\n\n // Remove the extra document listeners.\n document.removeEventListener('keydown', this, true);\n document.removeEventListener('pointerup', this, true);\n document.removeEventListener('pointermove', this, true);\n document.removeEventListener('contextmenu', this, true);\n }\n\n private _handleMoved = new Signal(this);\n private _pressData: Private.IPressData | null = null;\n}\n\n/**\n * The namespace for the `SplitPanel` class statics.\n */\nexport namespace SplitPanel {\n /**\n * A type alias for a split panel orientation.\n */\n export type Orientation = SplitLayout.Orientation;\n\n /**\n * A type alias for a split panel alignment.\n */\n export type Alignment = SplitLayout.Alignment;\n\n /**\n * A type alias for a split panel renderer.\n */\n export type IRenderer = SplitLayout.IRenderer;\n\n /**\n * An options object for initializing a split panel.\n */\n export interface IOptions {\n /**\n * The renderer to use for the split panel.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n\n /**\n * The layout orientation of the panel.\n *\n * The default is `'horizontal'`.\n */\n orientation?: Orientation;\n\n /**\n * The content alignment of the panel.\n *\n * The default is `'start'`.\n */\n alignment?: Alignment;\n\n /**\n * The spacing between items in the panel.\n *\n * The default is `4`.\n */\n spacing?: number;\n\n /**\n * The split layout to use for the split panel.\n *\n * If this is provided, the other options are ignored.\n *\n * The default is a new `SplitLayout`.\n */\n layout?: SplitLayout;\n }\n\n /**\n * The default implementation of `IRenderer`.\n */\n export class Renderer implements IRenderer {\n /**\n * Create a new handle for use with a split panel.\n *\n * @returns A new handle element for a split panel.\n */\n createHandle(): HTMLDivElement {\n let handle = document.createElement('div');\n handle.className = 'lm-SplitPanel-handle';\n return handle;\n }\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n\n /**\n * Get the split panel stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The split panel stretch factor for the widget.\n */\n export function getStretch(widget: Widget): number {\n return SplitLayout.getStretch(widget);\n }\n\n /**\n * Set the split panel stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the stretch factor.\n */\n export function setStretch(widget: Widget, value: number): void {\n SplitLayout.setStretch(widget, value);\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * An object which holds mouse press data.\n */\n export interface IPressData {\n /**\n * The index of the pressed handle.\n */\n index: number;\n\n /**\n * The offset of the press in handle coordinates.\n */\n delta: number;\n\n /**\n * The disposable which will clear the override cursor.\n */\n override: IDisposable;\n }\n\n /**\n * Create a split layout for the given panel options.\n */\n export function createLayout(options: SplitPanel.IOptions): SplitLayout {\n return (\n options.layout ||\n new SplitLayout({\n renderer: options.renderer || SplitPanel.defaultRenderer,\n orientation: options.orientation,\n alignment: options.alignment,\n spacing: options.spacing\n })\n );\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n\nimport { ArrayExt } from '@lumino/algorithm';\nimport { Message } from '@lumino/messaging';\nimport { ISignal, Signal } from '@lumino/signaling';\nimport { AccordionLayout } from './accordionlayout';\nimport { SplitLayout } from './splitlayout';\nimport { SplitPanel } from './splitpanel';\nimport { Title } from './title';\nimport { Widget } from './widget';\n\n/**\n * A panel which arranges its widgets into resizable sections separated by a title widget.\n *\n * #### Notes\n * This class provides a convenience wrapper around {@link AccordionLayout}.\n */\nexport class AccordionPanel extends SplitPanel {\n /**\n * Construct a new accordion panel.\n *\n * @param options - The options for initializing the accordion panel.\n */\n constructor(options: AccordionPanel.IOptions = {}) {\n super({ ...options, layout: Private.createLayout(options) });\n this.addClass('lm-AccordionPanel');\n }\n\n /**\n * The renderer used by the accordion panel.\n */\n get renderer(): AccordionPanel.IRenderer {\n return (this.layout as AccordionLayout).renderer;\n }\n\n /**\n * The section title space.\n *\n * This is the height if the panel is vertical and the width if it is\n * horizontal.\n */\n get titleSpace(): number {\n return (this.layout as AccordionLayout).titleSpace;\n }\n set titleSpace(value: number) {\n (this.layout as AccordionLayout).titleSpace = value;\n }\n\n /**\n * A read-only array of the section titles in the panel.\n */\n get titles(): ReadonlyArray {\n return (this.layout as AccordionLayout).titles;\n }\n\n /**\n * A signal emitted when a widget of the AccordionPanel is collapsed or expanded.\n */\n get expansionToggled(): ISignal {\n return this._expansionToggled;\n }\n\n /**\n * Add a widget to the end of the panel.\n *\n * @param widget - The widget to add to the panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n */\n addWidget(widget: Widget): void {\n super.addWidget(widget);\n widget.title.changed.connect(this._onTitleChanged, this);\n }\n\n /**\n * Collapse the widget at position `index`.\n *\n * #### Notes\n * If no widget is found for `index`, this will bail.\n *\n * @param index Widget index\n */\n collapse(index: number): void {\n const widget = (this.layout as AccordionLayout).widgets[index];\n\n if (widget && !widget.isHidden) {\n this._toggleExpansion(index);\n }\n }\n\n /**\n * Expand the widget at position `index`.\n *\n * #### Notes\n * If no widget is found for `index`, this will bail.\n *\n * @param index Widget index\n */\n expand(index: number): void {\n const widget = (this.layout as AccordionLayout).widgets[index];\n\n if (widget && widget.isHidden) {\n this._toggleExpansion(index);\n }\n }\n\n /**\n * Insert a widget at the specified index.\n *\n * @param index - The index at which to insert the widget.\n *\n * @param widget - The widget to insert into to the panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n */\n insertWidget(index: number, widget: Widget): void {\n super.insertWidget(index, widget);\n widget.title.changed.connect(this._onTitleChanged, this);\n }\n\n /**\n * Handle the DOM events for the accordion panel.\n *\n * @param event - The DOM event sent to the panel.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the panel's DOM node. It should\n * not be called directly by user code.\n */\n handleEvent(event: Event): void {\n super.handleEvent(event);\n switch (event.type) {\n case 'click':\n this._evtClick(event as MouseEvent);\n break;\n case 'keydown':\n this._eventKeyDown(event as KeyboardEvent);\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('click', this);\n this.node.addEventListener('keydown', this);\n super.onBeforeAttach(msg);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n super.onAfterDetach(msg);\n this.node.removeEventListener('click', this);\n this.node.removeEventListener('keydown', this);\n }\n\n /**\n * Handle the `changed` signal of a title object.\n */\n private _onTitleChanged(sender: Title): void {\n const index = ArrayExt.findFirstIndex(this.widgets, widget => {\n return widget.contains(sender.owner);\n });\n\n if (index >= 0) {\n (this.layout as AccordionLayout).updateTitle(index, sender.owner);\n this.update();\n }\n }\n\n /**\n * Compute the size of widgets in this panel on the title click event.\n * On closing, the size of the widget is cached and we will try to expand\n * the last opened widget.\n * On opening, we will use the cached size if it is available to restore the\n * widget.\n * In both cases, if we can not compute the size of widgets, we will let\n * `SplitLayout` decide.\n *\n * @param index - The index of widget to be opened of closed\n *\n * @returns Relative size of widgets in this panel, if this size can\n * not be computed, return `undefined`\n */\n private _computeWidgetSize(index: number): number[] | undefined {\n const layout = this.layout as AccordionLayout;\n\n const widget = layout.widgets[index];\n if (!widget) {\n return undefined;\n }\n const isHidden = widget.isHidden;\n const widgetSizes = layout.absoluteSizes();\n const delta = (isHidden ? -1 : 1) * this.spacing;\n const totalSize = widgetSizes.reduce(\n (prev: number, curr: number) => prev + curr\n );\n\n let newSize = [...widgetSizes];\n\n if (!isHidden) {\n // Hide the widget\n const currentSize = widgetSizes[index];\n\n this._widgetSizesCache.set(widget, currentSize);\n newSize[index] = 0;\n\n const widgetToCollapse = newSize.map(sz => sz > 0).lastIndexOf(true);\n if (widgetToCollapse === -1) {\n // All widget are closed, let the `SplitLayout` compute widget sizes.\n return undefined;\n }\n\n newSize[widgetToCollapse] =\n widgetSizes[widgetToCollapse] + currentSize + delta;\n } else {\n // Show the widget\n const previousSize = this._widgetSizesCache.get(widget);\n if (!previousSize) {\n // Previous size is unavailable, let the `SplitLayout` compute widget sizes.\n return undefined;\n }\n newSize[index] += previousSize;\n\n const widgetToCollapse = newSize\n .map(sz => sz - previousSize > 0)\n .lastIndexOf(true);\n if (widgetToCollapse === -1) {\n // Can not reduce the size of one widget, reduce all opened widgets\n // proportionally with its size.\n newSize.forEach((_, idx) => {\n if (idx !== index) {\n newSize[idx] -=\n (widgetSizes[idx] / totalSize) * (previousSize - delta);\n }\n });\n } else {\n newSize[widgetToCollapse] -= previousSize - delta;\n }\n }\n return newSize.map(sz => sz / (totalSize + delta));\n }\n /**\n * Handle the `'click'` event for the accordion panel\n */\n private _evtClick(event: MouseEvent): void {\n const target = event.target as HTMLElement | null;\n\n if (target) {\n const index = ArrayExt.findFirstIndex(this.titles, title => {\n return title.contains(target);\n });\n\n if (index >= 0) {\n event.preventDefault();\n event.stopPropagation();\n this._toggleExpansion(index);\n }\n }\n }\n\n /**\n * Handle the `'keydown'` event for the accordion panel.\n */\n private _eventKeyDown(event: KeyboardEvent): void {\n if (event.defaultPrevented) {\n return;\n }\n\n const target = event.target as HTMLElement | null;\n let handled = false;\n if (target) {\n const index = ArrayExt.findFirstIndex(this.titles, title => {\n return title.contains(target);\n });\n\n if (index >= 0) {\n const keyCode = event.keyCode.toString();\n\n // If Space or Enter is pressed on title, emulate click event\n if (event.key.match(/Space|Enter/) || keyCode.match(/13|32/)) {\n target.click();\n handled = true;\n } else if (\n this.orientation === 'horizontal'\n ? event.key.match(/ArrowLeft|ArrowRight/) || keyCode.match(/37|39/)\n : event.key.match(/ArrowUp|ArrowDown/) || keyCode.match(/38|40/)\n ) {\n // If Up or Down (for vertical) / Left or Right (for horizontal) is pressed on title, loop on titles\n const direction =\n event.key.match(/ArrowLeft|ArrowUp/) || keyCode.match(/37|38/)\n ? -1\n : 1;\n const length = this.titles.length;\n const newIndex = (index + length + direction) % length;\n\n this.titles[newIndex].focus();\n handled = true;\n } else if (event.key === 'End' || keyCode === '35') {\n // If End is pressed on title, focus on the last title\n this.titles[this.titles.length - 1].focus();\n handled = true;\n } else if (event.key === 'Home' || keyCode === '36') {\n // If Home is pressed on title, focus on the first title\n this.titles[0].focus();\n handled = true;\n }\n }\n\n if (handled) {\n event.preventDefault();\n }\n }\n }\n\n private _toggleExpansion(index: number) {\n const title = this.titles[index];\n const widget = (this.layout as AccordionLayout).widgets[index];\n\n const newSize = this._computeWidgetSize(index);\n if (newSize) {\n this.setRelativeSizes(newSize, false);\n }\n\n if (widget.isHidden) {\n title.classList.add('lm-mod-expanded');\n title.setAttribute('aria-expanded', 'true');\n widget.show();\n } else {\n title.classList.remove('lm-mod-expanded');\n title.setAttribute('aria-expanded', 'false');\n widget.hide();\n }\n\n // Emit the expansion state signal.\n this._expansionToggled.emit(index);\n }\n\n private _widgetSizesCache: WeakMap = new WeakMap();\n private _expansionToggled = new Signal(this);\n}\n\n/**\n * The namespace for the `AccordionPanel` class statics.\n */\nexport namespace AccordionPanel {\n /**\n * A type alias for a accordion panel orientation.\n */\n export type Orientation = SplitLayout.Orientation;\n\n /**\n * A type alias for a accordion panel alignment.\n */\n export type Alignment = SplitLayout.Alignment;\n\n /**\n * A type alias for a accordion panel renderer.\n */\n export type IRenderer = AccordionLayout.IRenderer;\n\n /**\n * An options object for initializing a accordion panel.\n */\n export interface IOptions extends Partial {\n /**\n * The accordion layout to use for the accordion panel.\n *\n * If this is provided, the other options are ignored.\n *\n * The default is a new `AccordionLayout`.\n */\n layout?: AccordionLayout;\n }\n\n /**\n * The default implementation of `IRenderer`.\n */\n export class Renderer extends SplitPanel.Renderer implements IRenderer {\n constructor() {\n super();\n this._uuid = ++Renderer._nInstance;\n }\n /**\n * A selector which matches any title node in the accordion.\n */\n readonly titleClassName = 'lm-AccordionPanel-title';\n\n /**\n * Render the collapse indicator for a section title.\n *\n * @param data - The data to use for rendering the section title.\n *\n * @returns A element representing the collapse indicator.\n */\n createCollapseIcon(data: Title): HTMLElement {\n return document.createElement('span');\n }\n\n /**\n * Render the element for a section title.\n *\n * @param data - The data to use for rendering the section title.\n *\n * @returns A element representing the section title.\n */\n createSectionTitle(data: Title): HTMLElement {\n const handle = document.createElement('h3');\n handle.setAttribute('tabindex', '0');\n handle.id = this.createTitleKey(data);\n handle.className = this.titleClassName;\n for (const aData in data.dataset) {\n handle.dataset[aData] = data.dataset[aData];\n }\n\n const collapser = handle.appendChild(this.createCollapseIcon(data));\n collapser.className = 'lm-AccordionPanel-titleCollapser';\n\n const label = handle.appendChild(document.createElement('span'));\n label.className = 'lm-AccordionPanel-titleLabel';\n label.textContent = data.label;\n label.title = data.caption || data.label;\n\n return handle;\n }\n\n /**\n * Create a unique render key for the title.\n *\n * @param data - The data to use for the title.\n *\n * @returns The unique render key for the title.\n *\n * #### Notes\n * This method caches the key against the section title the first time\n * the key is generated.\n */\n createTitleKey(data: Title): string {\n let key = this._titleKeys.get(data);\n if (key === undefined) {\n key = `title-key-${this._uuid}-${this._titleID++}`;\n this._titleKeys.set(data, key);\n }\n return key;\n }\n\n private static _nInstance = 0;\n private readonly _uuid: number;\n private _titleID = 0;\n private _titleKeys = new WeakMap, string>();\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n}\n\nnamespace Private {\n /**\n * Create an accordion layout for the given panel options.\n *\n * @param options Panel options\n * @returns Panel layout\n */\n export function createLayout(\n options: AccordionPanel.IOptions\n ): AccordionLayout {\n return (\n options.layout ||\n new AccordionLayout({\n renderer: options.renderer || AccordionPanel.defaultRenderer,\n orientation: options.orientation,\n alignment: options.alignment,\n spacing: options.spacing,\n titleSpace: options.titleSpace\n })\n );\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { BoxEngine, BoxSizer } from './boxengine';\n\nimport { LayoutItem } from './layout';\n\nimport { PanelLayout } from './panellayout';\n\nimport Utils from './utils';\n\nimport { Widget } from './widget';\n\n/**\n * A layout which arranges its widgets in a single row or column.\n */\nexport class BoxLayout extends PanelLayout {\n /**\n * Construct a new box layout.\n *\n * @param options - The options for initializing the layout.\n */\n constructor(options: BoxLayout.IOptions = {}) {\n super();\n if (options.direction !== undefined) {\n this._direction = options.direction;\n }\n if (options.alignment !== undefined) {\n this._alignment = options.alignment;\n }\n if (options.spacing !== undefined) {\n this._spacing = Utils.clampDimension(options.spacing);\n }\n }\n\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n // Dispose of the layout items.\n for (const item of this._items) {\n item.dispose();\n }\n\n // Clear the layout state.\n this._box = null;\n this._items.length = 0;\n this._sizers.length = 0;\n\n // Dispose of the rest of the layout.\n super.dispose();\n }\n\n /**\n * Get the layout direction for the box layout.\n */\n get direction(): BoxLayout.Direction {\n return this._direction;\n }\n\n /**\n * Set the layout direction for the box layout.\n */\n set direction(value: BoxLayout.Direction) {\n if (this._direction === value) {\n return;\n }\n this._direction = value;\n if (!this.parent) {\n return;\n }\n this.parent.dataset['direction'] = value;\n this.parent.fit();\n }\n\n /**\n * Get the content alignment for the box layout.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire box layout.\n */\n get alignment(): BoxLayout.Alignment {\n return this._alignment;\n }\n\n /**\n * Set the content alignment for the box layout.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire box layout.\n */\n set alignment(value: BoxLayout.Alignment) {\n if (this._alignment === value) {\n return;\n }\n this._alignment = value;\n if (!this.parent) {\n return;\n }\n this.parent.dataset['alignment'] = value;\n this.parent.update();\n }\n\n /**\n * Get the inter-element spacing for the box layout.\n */\n get spacing(): number {\n return this._spacing;\n }\n\n /**\n * Set the inter-element spacing for the box layout.\n */\n set spacing(value: number) {\n value = Utils.clampDimension(value);\n if (this._spacing === value) {\n return;\n }\n this._spacing = value;\n if (!this.parent) {\n return;\n }\n this.parent.fit();\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n this.parent!.dataset['direction'] = this.direction;\n this.parent!.dataset['alignment'] = this.alignment;\n super.init();\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param index - The current index of the widget in the layout.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected attachWidget(index: number, widget: Widget): void {\n // Create and add a new layout item for the widget.\n ArrayExt.insert(this._items, index, new LayoutItem(widget));\n\n // Create and add a new sizer for the widget.\n ArrayExt.insert(this._sizers, index, new BoxSizer());\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget's node to the parent.\n this.parent!.node.appendChild(widget.node);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * Move a widget in the parent's DOM node.\n *\n * @param fromIndex - The previous index of the widget in the layout.\n *\n * @param toIndex - The current index of the widget in the layout.\n *\n * @param widget - The widget to move in the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected moveWidget(\n fromIndex: number,\n toIndex: number,\n widget: Widget\n ): void {\n // Move the layout item for the widget.\n ArrayExt.move(this._items, fromIndex, toIndex);\n\n // Move the sizer for the widget.\n ArrayExt.move(this._sizers, fromIndex, toIndex);\n\n // Post an update request for the parent widget.\n this.parent!.update();\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param index - The previous index of the widget in the layout.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected detachWidget(index: number, widget: Widget): void {\n // Remove the layout item for the widget.\n let item = ArrayExt.removeAt(this._items, index);\n\n // Remove the sizer for the widget.\n ArrayExt.removeAt(this._sizers, index);\n\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Dispose of the layout item.\n item!.dispose();\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n */\n protected onBeforeShow(msg: Message): void {\n super.onBeforeShow(msg);\n this.parent!.update();\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n super.onBeforeAttach(msg);\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n if (this.parent!.isVisible) {\n this._update(msg.width, msg.height);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.parent!.isVisible) {\n this._update(-1, -1);\n }\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n */\n protected onFitRequest(msg: Message): void {\n if (this.parent!.isAttached) {\n this._fit();\n }\n }\n\n /**\n * Fit the layout to the total size required by the widgets.\n */\n private _fit(): void {\n // Compute the visible item count.\n let nVisible = 0;\n for (let i = 0, n = this._items.length; i < n; ++i) {\n nVisible += +!this._items[i].isHidden;\n }\n\n // Update the fixed space for the visible items.\n this._fixed = this._spacing * Math.max(0, nVisible - 1);\n\n // Setup the computed minimum size.\n let horz = Private.isHorizontal(this._direction);\n let minW = horz ? this._fixed : 0;\n let minH = horz ? 0 : this._fixed;\n\n // Update the sizers and computed minimum size.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item and corresponding box sizer.\n let item = this._items[i];\n let sizer = this._sizers[i];\n\n // If the item is hidden, it should consume zero size.\n if (item.isHidden) {\n sizer.minSize = 0;\n sizer.maxSize = 0;\n continue;\n }\n\n // Update the size limits for the item.\n item.fit();\n\n // Update the size basis and stretch factor.\n sizer.sizeHint = BoxLayout.getSizeBasis(item.widget);\n sizer.stretch = BoxLayout.getStretch(item.widget);\n\n // Update the sizer limits and computed min size.\n if (horz) {\n sizer.minSize = item.minWidth;\n sizer.maxSize = item.maxWidth;\n minW += item.minWidth;\n minH = Math.max(minH, item.minHeight);\n } else {\n sizer.minSize = item.minHeight;\n sizer.maxSize = item.maxHeight;\n minH += item.minHeight;\n minW = Math.max(minW, item.minWidth);\n }\n }\n\n // Update the box sizing and add it to the computed min size.\n let box = (this._box = ElementExt.boxSizing(this.parent!.node));\n minW += box.horizontalSum;\n minH += box.verticalSum;\n\n // Update the parent's min size constraints.\n let style = this.parent!.node.style;\n style.minWidth = `${minW}px`;\n style.minHeight = `${minH}px`;\n\n // Set the dirty flag to ensure only a single update occurs.\n this._dirty = true;\n\n // Notify the ancestor that it should fit immediately. This may\n // cause a resize of the parent, fulfilling the required update.\n if (this.parent!.parent) {\n MessageLoop.sendMessage(this.parent!.parent!, Widget.Msg.FitRequest);\n }\n\n // If the dirty flag is still set, the parent was not resized.\n // Trigger the required update on the parent widget immediately.\n if (this._dirty) {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n }\n }\n\n /**\n * Update the layout position and size of the widgets.\n *\n * The parent offset dimensions should be `-1` if unknown.\n */\n private _update(offsetWidth: number, offsetHeight: number): void {\n // Clear the dirty flag to indicate the update occurred.\n this._dirty = false;\n\n // Compute the visible item count.\n let nVisible = 0;\n for (let i = 0, n = this._items.length; i < n; ++i) {\n nVisible += +!this._items[i].isHidden;\n }\n\n // Bail early if there are no visible items to layout.\n if (nVisible === 0) {\n return;\n }\n\n // Measure the parent if the offset dimensions are unknown.\n if (offsetWidth < 0) {\n offsetWidth = this.parent!.node.offsetWidth;\n }\n if (offsetHeight < 0) {\n offsetHeight = this.parent!.node.offsetHeight;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent!.node);\n }\n\n // Compute the layout area adjusted for border and padding.\n let top = this._box.paddingTop;\n let left = this._box.paddingLeft;\n let width = offsetWidth - this._box.horizontalSum;\n let height = offsetHeight - this._box.verticalSum;\n\n // Distribute the layout space and adjust the start position.\n let delta: number;\n switch (this._direction) {\n case 'left-to-right':\n delta = BoxEngine.calc(this._sizers, Math.max(0, width - this._fixed));\n break;\n case 'top-to-bottom':\n delta = BoxEngine.calc(this._sizers, Math.max(0, height - this._fixed));\n break;\n case 'right-to-left':\n delta = BoxEngine.calc(this._sizers, Math.max(0, width - this._fixed));\n left += width;\n break;\n case 'bottom-to-top':\n delta = BoxEngine.calc(this._sizers, Math.max(0, height - this._fixed));\n top += height;\n break;\n default:\n throw 'unreachable';\n }\n\n // Setup the variables for justification and alignment offset.\n let extra = 0;\n let offset = 0;\n\n // Account for alignment if there is extra layout space.\n if (delta > 0) {\n switch (this._alignment) {\n case 'start':\n break;\n case 'center':\n extra = 0;\n offset = delta / 2;\n break;\n case 'end':\n extra = 0;\n offset = delta;\n break;\n case 'justify':\n extra = delta / nVisible;\n offset = 0;\n break;\n default:\n throw 'unreachable';\n }\n }\n\n // Layout the items using the computed box sizes.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item.\n let item = this._items[i];\n\n // Ignore hidden items.\n if (item.isHidden) {\n continue;\n }\n\n // Fetch the computed size for the widget.\n let size = this._sizers[i].size;\n\n // Update the widget geometry and advance the relevant edge.\n switch (this._direction) {\n case 'left-to-right':\n item.update(left + offset, top, size + extra, height);\n left += size + extra + this._spacing;\n break;\n case 'top-to-bottom':\n item.update(left, top + offset, width, size + extra);\n top += size + extra + this._spacing;\n break;\n case 'right-to-left':\n item.update(left - offset - size - extra, top, size + extra, height);\n left -= size + extra + this._spacing;\n break;\n case 'bottom-to-top':\n item.update(left, top - offset - size - extra, width, size + extra);\n top -= size + extra + this._spacing;\n break;\n default:\n throw 'unreachable';\n }\n }\n }\n\n private _fixed = 0;\n private _spacing = 4;\n private _dirty = false;\n private _sizers: BoxSizer[] = [];\n private _items: LayoutItem[] = [];\n private _box: ElementExt.IBoxSizing | null = null;\n private _alignment: BoxLayout.Alignment = 'start';\n private _direction: BoxLayout.Direction = 'top-to-bottom';\n}\n\n/**\n * The namespace for the `BoxLayout` class statics.\n */\nexport namespace BoxLayout {\n /**\n * A type alias for a box layout direction.\n */\n export type Direction =\n | 'left-to-right'\n | 'right-to-left'\n | 'top-to-bottom'\n | 'bottom-to-top';\n\n /**\n * A type alias for a box layout alignment.\n */\n export type Alignment = 'start' | 'center' | 'end' | 'justify';\n\n /**\n * An options object for initializing a box layout.\n */\n export interface IOptions {\n /**\n * The direction of the layout.\n *\n * The default is `'top-to-bottom'`.\n */\n direction?: Direction;\n\n /**\n * The content alignment of the layout.\n *\n * The default is `'start'`.\n */\n alignment?: Alignment;\n\n /**\n * The spacing between items in the layout.\n *\n * The default is `4`.\n */\n spacing?: number;\n }\n\n /**\n * Get the box layout stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The box layout stretch factor for the widget.\n */\n export function getStretch(widget: Widget): number {\n return Private.stretchProperty.get(widget);\n }\n\n /**\n * Set the box layout stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the stretch factor.\n */\n export function setStretch(widget: Widget, value: number): void {\n Private.stretchProperty.set(widget, value);\n }\n\n /**\n * Get the box layout size basis for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The box layout size basis for the widget.\n */\n export function getSizeBasis(widget: Widget): number {\n return Private.sizeBasisProperty.get(widget);\n }\n\n /**\n * Set the box layout size basis for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the size basis.\n */\n export function setSizeBasis(widget: Widget, value: number): void {\n Private.sizeBasisProperty.set(widget, value);\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The property descriptor for a widget stretch factor.\n */\n export const stretchProperty = new AttachedProperty({\n name: 'stretch',\n create: () => 0,\n coerce: (owner, value) => Math.max(0, Math.floor(value)),\n changed: onChildSizingChanged\n });\n\n /**\n * The property descriptor for a widget size basis.\n */\n export const sizeBasisProperty = new AttachedProperty({\n name: 'sizeBasis',\n create: () => 0,\n coerce: (owner, value) => Math.max(0, Math.floor(value)),\n changed: onChildSizingChanged\n });\n\n /**\n * Test whether a direction has horizontal orientation.\n */\n export function isHorizontal(dir: BoxLayout.Direction): boolean {\n return dir === 'left-to-right' || dir === 'right-to-left';\n }\n\n /**\n * Clamp a spacing value to an integer >= 0.\n */\n export function clampSpacing(value: number): number {\n return Math.max(0, Math.floor(value));\n }\n\n /**\n * The change handler for the attached sizing properties.\n */\n function onChildSizingChanged(child: Widget): void {\n if (child.parent && child.parent.layout instanceof BoxLayout) {\n child.parent.fit();\n }\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { BoxLayout } from './boxlayout';\n\nimport { Panel } from './panel';\n\nimport { Widget } from './widget';\n\n/**\n * A panel which arranges its widgets in a single row or column.\n *\n * #### Notes\n * This class provides a convenience wrapper around a {@link BoxLayout}.\n */\nexport class BoxPanel extends Panel {\n /**\n * Construct a new box panel.\n *\n * @param options - The options for initializing the box panel.\n */\n constructor(options: BoxPanel.IOptions = {}) {\n super({ layout: Private.createLayout(options) });\n this.addClass('lm-BoxPanel');\n }\n\n /**\n * Get the layout direction for the box panel.\n */\n get direction(): BoxPanel.Direction {\n return (this.layout as BoxLayout).direction;\n }\n\n /**\n * Set the layout direction for the box panel.\n */\n set direction(value: BoxPanel.Direction) {\n (this.layout as BoxLayout).direction = value;\n }\n\n /**\n * Get the content alignment for the box panel.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire box layout.\n */\n get alignment(): BoxPanel.Alignment {\n return (this.layout as BoxLayout).alignment;\n }\n\n /**\n * Set the content alignment for the box panel.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire box layout.\n */\n set alignment(value: BoxPanel.Alignment) {\n (this.layout as BoxLayout).alignment = value;\n }\n\n /**\n * Get the inter-element spacing for the box panel.\n */\n get spacing(): number {\n return (this.layout as BoxLayout).spacing;\n }\n\n /**\n * Set the inter-element spacing for the box panel.\n */\n set spacing(value: number) {\n (this.layout as BoxLayout).spacing = value;\n }\n\n /**\n * A message handler invoked on a `'child-added'` message.\n */\n protected onChildAdded(msg: Widget.ChildMessage): void {\n msg.child.addClass('lm-BoxPanel-child');\n }\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {\n msg.child.removeClass('lm-BoxPanel-child');\n }\n}\n\n/**\n * The namespace for the `BoxPanel` class statics.\n */\nexport namespace BoxPanel {\n /**\n * A type alias for a box panel direction.\n */\n export type Direction = BoxLayout.Direction;\n\n /**\n * A type alias for a box panel alignment.\n */\n export type Alignment = BoxLayout.Alignment;\n\n /**\n * An options object for initializing a box panel.\n */\n export interface IOptions {\n /**\n * The layout direction of the panel.\n *\n * The default is `'top-to-bottom'`.\n */\n direction?: Direction;\n\n /**\n * The content alignment of the panel.\n *\n * The default is `'start'`.\n */\n alignment?: Alignment;\n\n /**\n * The spacing between items in the panel.\n *\n * The default is `4`.\n */\n spacing?: number;\n\n /**\n * The box layout to use for the box panel.\n *\n * If this is provided, the other options are ignored.\n *\n * The default is a new `BoxLayout`.\n */\n layout?: BoxLayout;\n }\n\n /**\n * Get the box panel stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The box panel stretch factor for the widget.\n */\n export function getStretch(widget: Widget): number {\n return BoxLayout.getStretch(widget);\n }\n\n /**\n * Set the box panel stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the stretch factor.\n */\n export function setStretch(widget: Widget, value: number): void {\n BoxLayout.setStretch(widget, value);\n }\n\n /**\n * Get the box panel size basis for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The box panel size basis for the widget.\n */\n export function getSizeBasis(widget: Widget): number {\n return BoxLayout.getSizeBasis(widget);\n }\n\n /**\n * Set the box panel size basis for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the size basis.\n */\n export function setSizeBasis(widget: Widget, value: number): void {\n BoxLayout.setSizeBasis(widget, value);\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Create a box layout for the given panel options.\n */\n export function createLayout(options: BoxPanel.IOptions): BoxLayout {\n return options.layout || new BoxLayout(options);\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt, StringExt } from '@lumino/algorithm';\n\nimport { JSONExt, ReadonlyJSONObject } from '@lumino/coreutils';\n\nimport { CommandRegistry } from '@lumino/commands';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message } from '@lumino/messaging';\n\nimport {\n ElementDataset,\n h,\n VirtualDOM,\n VirtualElement\n} from '@lumino/virtualdom';\n\nimport { Widget } from './widget';\n\n/**\n * A widget which displays command items as a searchable palette.\n */\nexport class CommandPalette extends Widget {\n /**\n * Construct a new command palette.\n *\n * @param options - The options for initializing the palette.\n */\n constructor(options: CommandPalette.IOptions) {\n super({ node: Private.createNode() });\n this.addClass('lm-CommandPalette');\n this.setFlag(Widget.Flag.DisallowLayout);\n this.commands = options.commands;\n this.renderer = options.renderer || CommandPalette.defaultRenderer;\n this.commands.commandChanged.connect(this._onGenericChange, this);\n this.commands.keyBindingChanged.connect(this._onGenericChange, this);\n }\n\n /**\n * Dispose of the resources held by the widget.\n */\n dispose(): void {\n this._items.length = 0;\n this._results = null;\n super.dispose();\n }\n\n /**\n * The command registry used by the command palette.\n */\n readonly commands: CommandRegistry;\n\n /**\n * The renderer used by the command palette.\n */\n readonly renderer: CommandPalette.IRenderer;\n\n /**\n * The command palette search node.\n *\n * #### Notes\n * This is the node which contains the search-related elements.\n */\n get searchNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-CommandPalette-search'\n )[0] as HTMLDivElement;\n }\n\n /**\n * The command palette input node.\n *\n * #### Notes\n * This is the actual input node for the search area.\n */\n get inputNode(): HTMLInputElement {\n return this.node.getElementsByClassName(\n 'lm-CommandPalette-input'\n )[0] as HTMLInputElement;\n }\n\n /**\n * The command palette content node.\n *\n * #### Notes\n * This is the node which holds the command item nodes.\n *\n * Modifying this node directly can lead to undefined behavior.\n */\n get contentNode(): HTMLUListElement {\n return this.node.getElementsByClassName(\n 'lm-CommandPalette-content'\n )[0] as HTMLUListElement;\n }\n\n /**\n * A read-only array of the command items in the palette.\n */\n get items(): ReadonlyArray {\n return this._items;\n }\n\n /**\n * Add a command item to the command palette.\n *\n * @param options - The options for creating the command item.\n *\n * @returns The command item added to the palette.\n */\n addItem(options: CommandPalette.IItemOptions): CommandPalette.IItem {\n // Create a new command item for the options.\n let item = Private.createItem(this.commands, options);\n\n // Add the item to the array.\n this._items.push(item);\n\n // Refresh the search results.\n this.refresh();\n\n // Return the item added to the palette.\n return item;\n }\n\n /**\n * Adds command items to the command palette.\n *\n * @param items - An array of options for creating each command item.\n *\n * @returns The command items added to the palette.\n */\n addItems(items: CommandPalette.IItemOptions[]): CommandPalette.IItem[] {\n const newItems = items.map(item => Private.createItem(this.commands, item));\n newItems.forEach(item => this._items.push(item));\n this.refresh();\n return newItems;\n }\n\n /**\n * Remove an item from the command palette.\n *\n * @param item - The item to remove from the palette.\n *\n * #### Notes\n * This is a no-op if the item is not in the palette.\n */\n removeItem(item: CommandPalette.IItem): void {\n this.removeItemAt(this._items.indexOf(item));\n }\n\n /**\n * Remove the item at a given index from the command palette.\n *\n * @param index - The index of the item to remove.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n removeItemAt(index: number): void {\n // Remove the item from the array.\n let item = ArrayExt.removeAt(this._items, index);\n\n // Bail if the index is out of range.\n if (!item) {\n return;\n }\n\n // Refresh the search results.\n this.refresh();\n }\n\n /**\n * Remove all items from the command palette.\n */\n clearItems(): void {\n // Bail if there is nothing to remove.\n if (this._items.length === 0) {\n return;\n }\n\n // Clear the array of items.\n this._items.length = 0;\n\n // Refresh the search results.\n this.refresh();\n }\n\n /**\n * Clear the search results and schedule an update.\n *\n * #### Notes\n * This should be called whenever the search results of the palette\n * should be updated.\n *\n * This is typically called automatically by the palette as needed,\n * but can be called manually if the input text is programatically\n * changed.\n *\n * The rendered results are updated asynchronously.\n */\n refresh(): void {\n this._results = null;\n if (this.inputNode.value !== '') {\n let clear = this.node.getElementsByClassName(\n 'lm-close-icon'\n )[0] as HTMLInputElement;\n clear.style.display = 'inherit';\n } else {\n let clear = this.node.getElementsByClassName(\n 'lm-close-icon'\n )[0] as HTMLInputElement;\n clear.style.display = 'none';\n }\n this.update();\n }\n\n /**\n * Handle the DOM events for the command palette.\n *\n * @param event - The DOM event sent to the command palette.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the command palette's DOM node.\n * It should not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'click':\n this._evtClick(event as MouseEvent);\n break;\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'input':\n this.refresh();\n break;\n case 'focus':\n case 'blur':\n this._toggleFocused();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('click', this);\n this.node.addEventListener('keydown', this);\n this.node.addEventListener('input', this);\n this.node.addEventListener('focus', this, true);\n this.node.addEventListener('blur', this, true);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('click', this);\n this.node.removeEventListener('keydown', this);\n this.node.removeEventListener('input', this);\n this.node.removeEventListener('focus', this, true);\n this.node.removeEventListener('blur', this, true);\n }\n\n /**\n * A message handler invoked on an `'after-show'` message.\n */\n protected onAfterShow(msg: Message): void {\n this.update();\n super.onAfterShow(msg);\n }\n\n /**\n * A message handler invoked on an `'activate-request'` message.\n */\n protected onActivateRequest(msg: Message): void {\n if (this.isAttached) {\n let input = this.inputNode;\n input.focus();\n input.select();\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.isHidden) {\n return;\n }\n\n // Fetch the current query text and content node.\n let query = this.inputNode.value;\n let contentNode = this.contentNode;\n\n // Ensure the search results are generated.\n let results = this._results;\n if (!results) {\n // Generate and store the new search results.\n results = this._results = Private.search(this._items, query);\n\n // Reset the active index.\n this._activeIndex = query\n ? ArrayExt.findFirstIndex(results, Private.canActivate)\n : -1;\n }\n\n // If there is no query and no results, clear the content.\n if (!query && results.length === 0) {\n VirtualDOM.render(null, contentNode);\n return;\n }\n\n // If the is a query but no results, render the empty message.\n if (query && results.length === 0) {\n let content = this.renderer.renderEmptyMessage({ query });\n VirtualDOM.render(content, contentNode);\n return;\n }\n\n // Create the render content for the search results.\n let renderer = this.renderer;\n let activeIndex = this._activeIndex;\n let content = new Array(results.length);\n for (let i = 0, n = results.length; i < n; ++i) {\n let result = results[i];\n if (result.type === 'header') {\n let indices = result.indices;\n let category = result.category;\n content[i] = renderer.renderHeader({ category, indices });\n } else {\n let item = result.item;\n let indices = result.indices;\n let active = i === activeIndex;\n content[i] = renderer.renderItem({ item, indices, active });\n }\n }\n\n // Render the search result content.\n VirtualDOM.render(content, contentNode);\n\n // Adjust the scroll position as needed.\n if (activeIndex < 0 || activeIndex >= results.length) {\n contentNode.scrollTop = 0;\n } else {\n let element = contentNode.children[activeIndex];\n ElementExt.scrollIntoViewIfNeeded(contentNode, element);\n }\n }\n\n /**\n * Handle the `'click'` event for the command palette.\n */\n private _evtClick(event: MouseEvent): void {\n // Bail if the click is not the left button.\n if (event.button !== 0) {\n return;\n }\n\n // Clear input if the target is clear button\n if ((event.target as HTMLElement).classList.contains('lm-close-icon')) {\n this.inputNode.value = '';\n this.refresh();\n return;\n }\n\n // Find the index of the item which was clicked.\n let index = ArrayExt.findFirstIndex(this.contentNode.children, node => {\n return node.contains(event.target as HTMLElement);\n });\n\n // Bail if the click was not on an item.\n if (index === -1) {\n return;\n }\n\n // Kill the event when a content item is clicked.\n event.preventDefault();\n event.stopPropagation();\n\n // Execute the item if possible.\n this._execute(index);\n }\n\n /**\n * Handle the `'keydown'` event for the command palette.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n if (event.altKey || event.ctrlKey || event.metaKey || event.shiftKey) {\n return;\n }\n switch (event.keyCode) {\n case 13: // Enter\n event.preventDefault();\n event.stopPropagation();\n this._execute(this._activeIndex);\n break;\n case 38: // Up Arrow\n event.preventDefault();\n event.stopPropagation();\n this._activatePreviousItem();\n break;\n case 40: // Down Arrow\n event.preventDefault();\n event.stopPropagation();\n this._activateNextItem();\n break;\n }\n }\n\n /**\n * Activate the next enabled command item.\n */\n private _activateNextItem(): void {\n // Bail if there are no search results.\n if (!this._results || this._results.length === 0) {\n return;\n }\n\n // Find the next enabled item index.\n let ai = this._activeIndex;\n let n = this._results.length;\n let start = ai < n - 1 ? ai + 1 : 0;\n let stop = start === 0 ? n - 1 : start - 1;\n this._activeIndex = ArrayExt.findFirstIndex(\n this._results,\n Private.canActivate,\n start,\n stop\n );\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * Activate the previous enabled command item.\n */\n private _activatePreviousItem(): void {\n // Bail if there are no search results.\n if (!this._results || this._results.length === 0) {\n return;\n }\n\n // Find the previous enabled item index.\n let ai = this._activeIndex;\n let n = this._results.length;\n let start = ai <= 0 ? n - 1 : ai - 1;\n let stop = start === n - 1 ? 0 : start + 1;\n this._activeIndex = ArrayExt.findLastIndex(\n this._results,\n Private.canActivate,\n start,\n stop\n );\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * Execute the command item at the given index, if possible.\n */\n private _execute(index: number): void {\n // Bail if there are no search results.\n if (!this._results) {\n return;\n }\n\n // Bail if the index is out of range.\n let part = this._results[index];\n if (!part) {\n return;\n }\n\n // Update the search text if the item is a header.\n if (part.type === 'header') {\n let input = this.inputNode;\n input.value = `${part.category.toLowerCase()} `;\n input.focus();\n this.refresh();\n return;\n }\n\n // Bail if item is not enabled.\n if (!part.item.isEnabled) {\n return;\n }\n\n // Execute the item.\n this.commands.execute(part.item.command, part.item.args);\n\n // Clear the query text.\n this.inputNode.value = '';\n\n // Refresh the search results.\n this.refresh();\n }\n\n /**\n * Toggle the focused modifier based on the input node focus state.\n */\n private _toggleFocused(): void {\n let focused = document.activeElement === this.inputNode;\n this.toggleClass('lm-mod-focused', focused);\n }\n\n /**\n * A signal handler for generic command changes.\n */\n private _onGenericChange(): void {\n this.refresh();\n }\n\n private _activeIndex = -1;\n private _items: CommandPalette.IItem[] = [];\n private _results: Private.SearchResult[] | null = null;\n}\n\n/**\n * The namespace for the `CommandPalette` class statics.\n */\nexport namespace CommandPalette {\n /**\n * An options object for creating a command palette.\n */\n export interface IOptions {\n /**\n * The command registry for use with the command palette.\n */\n commands: CommandRegistry;\n\n /**\n * A custom renderer for use with the command palette.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n }\n\n /**\n * An options object for creating a command item.\n */\n export interface IItemOptions {\n /**\n * The category for the item.\n */\n category: string;\n\n /**\n * The command to execute when the item is triggered.\n */\n command: string;\n\n /**\n * The arguments for the command.\n *\n * The default value is an empty object.\n */\n args?: ReadonlyJSONObject;\n\n /**\n * The rank for the command item.\n *\n * The rank is used as a tie-breaker when ordering command items\n * for display. Items are sorted in the following order:\n * 1. Text match (lower is better)\n * 2. Category (locale order)\n * 3. Rank (lower is better)\n * 4. Label (locale order)\n *\n * The default rank is `Infinity`.\n */\n rank?: number;\n }\n\n /**\n * An object which represents an item in a command palette.\n *\n * #### Notes\n * Item objects are created automatically by a command palette.\n */\n export interface IItem {\n /**\n * The command to execute when the item is triggered.\n */\n readonly command: string;\n\n /**\n * The arguments for the command.\n */\n readonly args: ReadonlyJSONObject;\n\n /**\n * The category for the command item.\n */\n readonly category: string;\n\n /**\n * The rank for the command item.\n */\n readonly rank: number;\n\n /**\n * The display label for the command item.\n */\n readonly label: string;\n\n /**\n * The display caption for the command item.\n */\n readonly caption: string;\n\n /**\n * The icon renderer for the command item.\n */\n readonly icon: VirtualElement.IRenderer | undefined;\n\n /**\n * The icon class for the command item.\n */\n readonly iconClass: string;\n\n /**\n * The icon label for the command item.\n */\n readonly iconLabel: string;\n\n /**\n * The extra class name for the command item.\n */\n readonly className: string;\n\n /**\n * The dataset for the command item.\n */\n readonly dataset: CommandRegistry.Dataset;\n\n /**\n * Whether the command item is enabled.\n */\n readonly isEnabled: boolean;\n\n /**\n * Whether the command item is toggled.\n */\n readonly isToggled: boolean;\n\n /**\n * Whether the command item is toggleable.\n */\n readonly isToggleable: boolean;\n\n /**\n * Whether the command item is visible.\n */\n readonly isVisible: boolean;\n\n /**\n * The key binding for the command item.\n */\n readonly keyBinding: CommandRegistry.IKeyBinding | null;\n }\n\n /**\n * The render data for a command palette header.\n */\n export interface IHeaderRenderData {\n /**\n * The category of the header.\n */\n readonly category: string;\n\n /**\n * The indices of the matched characters in the category.\n */\n readonly indices: ReadonlyArray | null;\n }\n\n /**\n * The render data for a command palette item.\n */\n export interface IItemRenderData {\n /**\n * The command palette item to render.\n */\n readonly item: IItem;\n\n /**\n * The indices of the matched characters in the label.\n */\n readonly indices: ReadonlyArray | null;\n\n /**\n * Whether the item is the active item.\n */\n readonly active: boolean;\n }\n\n /**\n * The render data for a command palette empty message.\n */\n export interface IEmptyMessageRenderData {\n /**\n * The query which failed to match any commands.\n */\n query: string;\n }\n\n /**\n * A renderer for use with a command palette.\n */\n export interface IRenderer {\n /**\n * Render the virtual element for a command palette header.\n *\n * @param data - The data to use for rendering the header.\n *\n * @returns A virtual element representing the header.\n */\n renderHeader(data: IHeaderRenderData): VirtualElement;\n\n /**\n * Render the virtual element for a command palette item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n *\n * #### Notes\n * The command palette will not render invisible items.\n */\n renderItem(data: IItemRenderData): VirtualElement;\n\n /**\n * Render the empty results message for a command palette.\n *\n * @param data - The data to use for rendering the message.\n *\n * @returns A virtual element representing the message.\n */\n renderEmptyMessage(data: IEmptyMessageRenderData): VirtualElement;\n }\n\n /**\n * The default implementation of `IRenderer`.\n */\n export class Renderer implements IRenderer {\n /**\n * Render the virtual element for a command palette header.\n *\n * @param data - The data to use for rendering the header.\n *\n * @returns A virtual element representing the header.\n */\n renderHeader(data: IHeaderRenderData): VirtualElement {\n let content = this.formatHeader(data);\n return h.li({ className: 'lm-CommandPalette-header' }, content);\n }\n\n /**\n * Render the virtual element for a command palette item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n */\n renderItem(data: IItemRenderData): VirtualElement {\n let className = this.createItemClass(data);\n let dataset = this.createItemDataset(data);\n if (data.item.isToggleable) {\n return h.li(\n {\n className,\n dataset,\n role: 'menuitemcheckbox',\n 'aria-checked': `${data.item.isToggled}`\n },\n this.renderItemIcon(data),\n this.renderItemContent(data),\n this.renderItemShortcut(data)\n );\n }\n return h.li(\n {\n className,\n dataset,\n role: 'menuitem'\n },\n this.renderItemIcon(data),\n this.renderItemContent(data),\n this.renderItemShortcut(data)\n );\n }\n\n /**\n * Render the empty results message for a command palette.\n *\n * @param data - The data to use for rendering the message.\n *\n * @returns A virtual element representing the message.\n */\n renderEmptyMessage(data: IEmptyMessageRenderData): VirtualElement {\n let content = this.formatEmptyMessage(data);\n return h.li({ className: 'lm-CommandPalette-emptyMessage' }, content);\n }\n\n /**\n * Render the icon for a command palette item.\n *\n * @param data - The data to use for rendering the icon.\n *\n * @returns A virtual element representing the icon.\n */\n renderItemIcon(data: IItemRenderData): VirtualElement {\n let className = this.createIconClass(data);\n\n // If data.item.icon is undefined, it will be ignored.\n return h.div({ className }, data.item.icon!, data.item.iconLabel);\n }\n\n /**\n * Render the content for a command palette item.\n *\n * @param data - The data to use for rendering the content.\n *\n * @returns A virtual element representing the content.\n */\n renderItemContent(data: IItemRenderData): VirtualElement {\n return h.div(\n { className: 'lm-CommandPalette-itemContent' },\n this.renderItemLabel(data),\n this.renderItemCaption(data)\n );\n }\n\n /**\n * Render the label for a command palette item.\n *\n * @param data - The data to use for rendering the label.\n *\n * @returns A virtual element representing the label.\n */\n renderItemLabel(data: IItemRenderData): VirtualElement {\n let content = this.formatItemLabel(data);\n return h.div({ className: 'lm-CommandPalette-itemLabel' }, content);\n }\n\n /**\n * Render the caption for a command palette item.\n *\n * @param data - The data to use for rendering the caption.\n *\n * @returns A virtual element representing the caption.\n */\n renderItemCaption(data: IItemRenderData): VirtualElement {\n let content = this.formatItemCaption(data);\n return h.div({ className: 'lm-CommandPalette-itemCaption' }, content);\n }\n\n /**\n * Render the shortcut for a command palette item.\n *\n * @param data - The data to use for rendering the shortcut.\n *\n * @returns A virtual element representing the shortcut.\n */\n renderItemShortcut(data: IItemRenderData): VirtualElement {\n let content = this.formatItemShortcut(data);\n return h.div({ className: 'lm-CommandPalette-itemShortcut' }, content);\n }\n\n /**\n * Create the class name for the command palette item.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the command palette item.\n */\n createItemClass(data: IItemRenderData): string {\n // Set up the initial class name.\n let name = 'lm-CommandPalette-item';\n\n // Add the boolean state classes.\n if (!data.item.isEnabled) {\n name += ' lm-mod-disabled';\n }\n if (data.item.isToggled) {\n name += ' lm-mod-toggled';\n }\n if (data.active) {\n name += ' lm-mod-active';\n }\n\n // Add the extra class.\n let extra = data.item.className;\n if (extra) {\n name += ` ${extra}`;\n }\n\n // Return the complete class name.\n return name;\n }\n\n /**\n * Create the dataset for the command palette item.\n *\n * @param data - The data to use for creating the dataset.\n *\n * @returns The dataset for the command palette item.\n */\n createItemDataset(data: IItemRenderData): ElementDataset {\n return { ...data.item.dataset, command: data.item.command };\n }\n\n /**\n * Create the class name for the command item icon.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the item icon.\n */\n createIconClass(data: IItemRenderData): string {\n let name = 'lm-CommandPalette-itemIcon';\n let extra = data.item.iconClass;\n return extra ? `${name} ${extra}` : name;\n }\n\n /**\n * Create the render content for the header node.\n *\n * @param data - The data to use for the header content.\n *\n * @returns The content to add to the header node.\n */\n formatHeader(data: IHeaderRenderData): h.Child {\n if (!data.indices || data.indices.length === 0) {\n return data.category;\n }\n return StringExt.highlight(data.category, data.indices, h.mark);\n }\n\n /**\n * Create the render content for the empty message node.\n *\n * @param data - The data to use for the empty message content.\n *\n * @returns The content to add to the empty message node.\n */\n formatEmptyMessage(data: IEmptyMessageRenderData): h.Child {\n return `No commands found that match '${data.query}'`;\n }\n\n /**\n * Create the render content for the item shortcut node.\n *\n * @param data - The data to use for the shortcut content.\n *\n * @returns The content to add to the shortcut node.\n */\n formatItemShortcut(data: IItemRenderData): h.Child {\n let kb = data.item.keyBinding;\n return kb ? CommandRegistry.formatKeystroke(kb.keys) : null;\n }\n\n /**\n * Create the render content for the item label node.\n *\n * @param data - The data to use for the label content.\n *\n * @returns The content to add to the label node.\n */\n formatItemLabel(data: IItemRenderData): h.Child {\n if (!data.indices || data.indices.length === 0) {\n return data.item.label;\n }\n return StringExt.highlight(data.item.label, data.indices, h.mark);\n }\n\n /**\n * Create the render content for the item caption node.\n *\n * @param data - The data to use for the caption content.\n *\n * @returns The content to add to the caption node.\n */\n formatItemCaption(data: IItemRenderData): h.Child {\n return data.item.caption;\n }\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Create the DOM node for a command palette.\n */\n export function createNode(): HTMLDivElement {\n let node = document.createElement('div');\n let search = document.createElement('div');\n let wrapper = document.createElement('div');\n let input = document.createElement('input');\n let content = document.createElement('ul');\n let clear = document.createElement('button');\n search.className = 'lm-CommandPalette-search';\n wrapper.className = 'lm-CommandPalette-wrapper';\n input.className = 'lm-CommandPalette-input';\n clear.className = 'lm-close-icon';\n\n content.className = 'lm-CommandPalette-content';\n content.setAttribute('role', 'menu');\n input.spellcheck = false;\n wrapper.appendChild(input);\n wrapper.appendChild(clear);\n search.appendChild(wrapper);\n node.appendChild(search);\n node.appendChild(content);\n return node;\n }\n\n /**\n * Create a new command item from a command registry and options.\n */\n export function createItem(\n commands: CommandRegistry,\n options: CommandPalette.IItemOptions\n ): CommandPalette.IItem {\n return new CommandItem(commands, options);\n }\n\n /**\n * A search result object for a header label.\n */\n export interface IHeaderResult {\n /**\n * The discriminated type of the object.\n */\n readonly type: 'header';\n\n /**\n * The category for the header.\n */\n readonly category: string;\n\n /**\n * The indices of the matched category characters.\n */\n readonly indices: ReadonlyArray | null;\n }\n\n /**\n * A search result object for a command item.\n */\n export interface IItemResult {\n /**\n * The discriminated type of the object.\n */\n readonly type: 'item';\n\n /**\n * The command item which was matched.\n */\n readonly item: CommandPalette.IItem;\n\n /**\n * The indices of the matched label characters.\n */\n readonly indices: ReadonlyArray | null;\n }\n\n /**\n * A type alias for a search result item.\n */\n export type SearchResult = IHeaderResult | IItemResult;\n\n /**\n * Search an array of command items for fuzzy matches.\n */\n export function search(\n items: CommandPalette.IItem[],\n query: string\n ): SearchResult[] {\n // Fuzzy match the items for the query.\n let scores = matchItems(items, query);\n\n // Sort the items based on their score.\n scores.sort(scoreCmp);\n\n // Create the results for the search.\n return createResults(scores);\n }\n\n /**\n * Test whether a result item can be activated.\n */\n export function canActivate(result: SearchResult): boolean {\n return result.type === 'item' && result.item.isEnabled;\n }\n\n /**\n * Normalize a category for a command item.\n */\n function normalizeCategory(category: string): string {\n return category.trim().replace(/\\s+/g, ' ');\n }\n\n /**\n * Normalize the query text for a fuzzy search.\n */\n function normalizeQuery(text: string): string {\n return text.replace(/\\s+/g, '').toLowerCase();\n }\n\n /**\n * An enum of the supported match types.\n */\n const enum MatchType {\n Label,\n Category,\n Split,\n Default\n }\n\n /**\n * A text match score with associated command item.\n */\n interface IScore {\n /**\n * The numerical type for the text match.\n */\n matchType: MatchType;\n\n /**\n * The numerical score for the text match.\n */\n score: number;\n\n /**\n * The indices of the matched category characters.\n */\n categoryIndices: number[] | null;\n\n /**\n * The indices of the matched label characters.\n */\n labelIndices: number[] | null;\n\n /**\n * The command item associated with the match.\n */\n item: CommandPalette.IItem;\n }\n\n /**\n * Perform a fuzzy match on an array of command items.\n */\n function matchItems(items: CommandPalette.IItem[], query: string): IScore[] {\n // Normalize the query text to lower case with no whitespace.\n query = normalizeQuery(query);\n\n // Create the array to hold the scores.\n let scores: IScore[] = [];\n\n // Iterate over the items and match against the query.\n for (let i = 0, n = items.length; i < n; ++i) {\n // Ignore items which are not visible.\n let item = items[i];\n if (!item.isVisible) {\n continue;\n }\n\n // If the query is empty, all items are matched by default.\n if (!query) {\n scores.push({\n matchType: MatchType.Default,\n categoryIndices: null,\n labelIndices: null,\n score: 0,\n item\n });\n continue;\n }\n\n // Run the fuzzy search for the item and query.\n let score = fuzzySearch(item, query);\n\n // Ignore the item if it is not a match.\n if (!score) {\n continue;\n }\n\n // Penalize disabled items.\n // TODO - push disabled items all the way down in sort cmp?\n if (!item.isEnabled) {\n score.score += 1000;\n }\n\n // Add the score to the results.\n scores.push(score);\n }\n\n // Return the final array of scores.\n return scores;\n }\n\n /**\n * Perform a fuzzy search on a single command item.\n */\n function fuzzySearch(\n item: CommandPalette.IItem,\n query: string\n ): IScore | null {\n // Create the source text to be searched.\n let category = item.category.toLowerCase();\n let label = item.label.toLowerCase();\n let source = `${category} ${label}`;\n\n // Set up the match score and indices array.\n let score = Infinity;\n let indices: number[] | null = null;\n\n // The regex for search word boundaries\n let rgx = /\\b\\w/g;\n\n // Search the source by word boundary.\n // eslint-disable-next-line no-constant-condition\n while (true) {\n // Find the next word boundary in the source.\n let rgxMatch = rgx.exec(source);\n\n // Break if there is no more source context.\n if (!rgxMatch) {\n break;\n }\n\n // Run the string match on the relevant substring.\n let match = StringExt.matchSumOfDeltas(source, query, rgxMatch.index);\n\n // Break if there is no match.\n if (!match) {\n break;\n }\n\n // Update the match if the score is better.\n if (match.score <= score) {\n score = match.score;\n indices = match.indices;\n }\n }\n\n // Bail if there was no match.\n if (!indices || score === Infinity) {\n return null;\n }\n\n // Compute the pivot index between category and label text.\n let pivot = category.length + 1;\n\n // Find the slice index to separate matched indices.\n let j = ArrayExt.lowerBound(indices, pivot, (a, b) => a - b);\n\n // Extract the matched category and label indices.\n let categoryIndices = indices.slice(0, j);\n let labelIndices = indices.slice(j);\n\n // Adjust the label indices for the pivot offset.\n for (let i = 0, n = labelIndices.length; i < n; ++i) {\n labelIndices[i] -= pivot;\n }\n\n // Handle a pure label match.\n if (categoryIndices.length === 0) {\n return {\n matchType: MatchType.Label,\n categoryIndices: null,\n labelIndices,\n score,\n item\n };\n }\n\n // Handle a pure category match.\n if (labelIndices.length === 0) {\n return {\n matchType: MatchType.Category,\n categoryIndices,\n labelIndices: null,\n score,\n item\n };\n }\n\n // Handle a split match.\n return {\n matchType: MatchType.Split,\n categoryIndices,\n labelIndices,\n score,\n item\n };\n }\n\n /**\n * A sort comparison function for a match score.\n */\n function scoreCmp(a: IScore, b: IScore): number {\n // First compare based on the match type\n let m1 = a.matchType - b.matchType;\n if (m1 !== 0) {\n return m1;\n }\n\n // Otherwise, compare based on the match score.\n let d1 = a.score - b.score;\n if (d1 !== 0) {\n return d1;\n }\n\n // Find the match index based on the match type.\n let i1 = 0;\n let i2 = 0;\n switch (a.matchType) {\n case MatchType.Label:\n i1 = a.labelIndices![0];\n i2 = b.labelIndices![0];\n break;\n case MatchType.Category:\n case MatchType.Split:\n i1 = a.categoryIndices![0];\n i2 = b.categoryIndices![0];\n break;\n }\n\n // Compare based on the match index.\n if (i1 !== i2) {\n return i1 - i2;\n }\n\n // Otherwise, compare by category.\n let d2 = a.item.category.localeCompare(b.item.category);\n if (d2 !== 0) {\n return d2;\n }\n\n // Otherwise, compare by rank.\n let r1 = a.item.rank;\n let r2 = b.item.rank;\n if (r1 !== r2) {\n return r1 < r2 ? -1 : 1; // Infinity safe\n }\n\n // Finally, compare by label.\n return a.item.label.localeCompare(b.item.label);\n }\n\n /**\n * Create the results from an array of sorted scores.\n */\n function createResults(scores: IScore[]): SearchResult[] {\n // Set up the search results array.\n let results: SearchResult[] = [];\n\n // Iterate over each score in the array.\n for (let i = 0, n = scores.length; i < n; ++i) {\n // Extract the current item and indices.\n let { item, categoryIndices, labelIndices } = scores[i];\n\n // Extract the category for the current item.\n let category = item.category;\n\n // Is this the same category as the preceding result?\n if (i === 0 || category !== scores[i - 1].item.category) {\n // Add the header result for the category.\n results.push({ type: 'header', category, indices: categoryIndices });\n }\n\n // Create the item result for the score.\n results.push({ type: 'item', item, indices: labelIndices });\n }\n\n // Return the final results.\n return results;\n }\n\n /**\n * A concrete implementation of `CommandPalette.IItem`.\n */\n class CommandItem implements CommandPalette.IItem {\n /**\n * Construct a new command item.\n */\n constructor(\n commands: CommandRegistry,\n options: CommandPalette.IItemOptions\n ) {\n this._commands = commands;\n this.category = normalizeCategory(options.category);\n this.command = options.command;\n this.args = options.args || JSONExt.emptyObject;\n this.rank = options.rank !== undefined ? options.rank : Infinity;\n }\n\n /**\n * The category for the command item.\n */\n readonly category: string;\n\n /**\n * The command to execute when the item is triggered.\n */\n readonly command: string;\n\n /**\n * The arguments for the command.\n */\n readonly args: ReadonlyJSONObject;\n\n /**\n * The rank for the command item.\n */\n readonly rank: number;\n\n /**\n * The display label for the command item.\n */\n get label(): string {\n return this._commands.label(this.command, this.args);\n }\n\n /**\n * The icon renderer for the command item.\n */\n get icon(): VirtualElement.IRenderer | undefined {\n return this._commands.icon(this.command, this.args);\n }\n\n /**\n * The icon class for the command item.\n */\n get iconClass(): string {\n return this._commands.iconClass(this.command, this.args);\n }\n\n /**\n * The icon label for the command item.\n */\n get iconLabel(): string {\n return this._commands.iconLabel(this.command, this.args);\n }\n\n /**\n * The display caption for the command item.\n */\n get caption(): string {\n return this._commands.caption(this.command, this.args);\n }\n\n /**\n * The extra class name for the command item.\n */\n get className(): string {\n return this._commands.className(this.command, this.args);\n }\n\n /**\n * The dataset for the command item.\n */\n get dataset(): CommandRegistry.Dataset {\n return this._commands.dataset(this.command, this.args);\n }\n\n /**\n * Whether the command item is enabled.\n */\n get isEnabled(): boolean {\n return this._commands.isEnabled(this.command, this.args);\n }\n\n /**\n * Whether the command item is toggled.\n */\n get isToggled(): boolean {\n return this._commands.isToggled(this.command, this.args);\n }\n\n /**\n * Whether the command item is toggleable.\n */\n get isToggleable(): boolean {\n return this._commands.isToggleable(this.command, this.args);\n }\n\n /**\n * Whether the command item is visible.\n */\n get isVisible(): boolean {\n return this._commands.isVisible(this.command, this.args);\n }\n\n /**\n * The key binding for the command item.\n */\n get keyBinding(): CommandRegistry.IKeyBinding | null {\n let { command, args } = this;\n return (\n ArrayExt.findLastValue(this._commands.keyBindings, kb => {\n return kb.command === command && JSONExt.deepEqual(kb.args, args);\n }) || null\n );\n }\n\n private _commands: CommandRegistry;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { CommandRegistry } from '@lumino/commands';\n\nimport { JSONExt, ReadonlyJSONObject } from '@lumino/coreutils';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { getKeyboardLayout } from '@lumino/keyboard';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport {\n ARIAAttrNames,\n ElementARIAAttrs,\n ElementDataset,\n h,\n VirtualDOM,\n VirtualElement\n} from '@lumino/virtualdom';\n\nimport { Widget } from './widget';\n\ninterface IWindowData {\n pageXOffset: number;\n pageYOffset: number;\n clientWidth: number;\n clientHeight: number;\n}\n\n/**\n * A widget which displays items as a canonical menu.\n */\nexport class Menu extends Widget {\n /**\n * Construct a new menu.\n *\n * @param options - The options for initializing the menu.\n */\n constructor(options: Menu.IOptions) {\n super({ node: Private.createNode() });\n this.addClass('lm-Menu');\n this.setFlag(Widget.Flag.DisallowLayout);\n this.commands = options.commands;\n this.renderer = options.renderer || Menu.defaultRenderer;\n }\n\n /**\n * Dispose of the resources held by the menu.\n */\n dispose(): void {\n this.close();\n this._items.length = 0;\n super.dispose();\n }\n\n /**\n * A signal emitted just before the menu is closed.\n *\n * #### Notes\n * This signal is emitted when the menu receives a `'close-request'`\n * message, just before it removes itself from the DOM.\n *\n * This signal is not emitted if the menu is already detached from\n * the DOM when it receives the `'close-request'` message.\n */\n get aboutToClose(): ISignal {\n return this._aboutToClose;\n }\n\n /**\n * A signal emitted when a new menu is requested by the user.\n *\n * #### Notes\n * This signal is emitted whenever the user presses the right or left\n * arrow keys, and a submenu cannot be opened or closed in response.\n *\n * This signal is useful when implementing menu bars in order to open\n * the next or previous menu in response to a user key press.\n *\n * This signal is only emitted for the root menu in a hierarchy.\n */\n get menuRequested(): ISignal {\n return this._menuRequested;\n }\n\n /**\n * The command registry used by the menu.\n */\n readonly commands: CommandRegistry;\n\n /**\n * The renderer used by the menu.\n */\n readonly renderer: Menu.IRenderer;\n\n /**\n * The parent menu of the menu.\n *\n * #### Notes\n * This is `null` unless the menu is an open submenu.\n */\n get parentMenu(): Menu | null {\n return this._parentMenu;\n }\n\n /**\n * The child menu of the menu.\n *\n * #### Notes\n * This is `null` unless the menu has an open submenu.\n */\n get childMenu(): Menu | null {\n return this._childMenu;\n }\n\n /**\n * The root menu of the menu hierarchy.\n */\n get rootMenu(): Menu {\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n let menu: Menu = this;\n while (menu._parentMenu) {\n menu = menu._parentMenu;\n }\n return menu;\n }\n\n /**\n * The leaf menu of the menu hierarchy.\n */\n get leafMenu(): Menu {\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n let menu: Menu = this;\n while (menu._childMenu) {\n menu = menu._childMenu;\n }\n return menu;\n }\n\n /**\n * The menu content node.\n *\n * #### Notes\n * This is the node which holds the menu item nodes.\n *\n * Modifying this node directly can lead to undefined behavior.\n */\n get contentNode(): HTMLUListElement {\n return this.node.getElementsByClassName(\n 'lm-Menu-content'\n )[0] as HTMLUListElement;\n }\n\n /**\n * Get the currently active menu item.\n */\n get activeItem(): Menu.IItem | null {\n return this._items[this._activeIndex] || null;\n }\n\n /**\n * Set the currently active menu item.\n *\n * #### Notes\n * If the item cannot be activated, the item will be set to `null`.\n */\n set activeItem(value: Menu.IItem | null) {\n this.activeIndex = value ? this._items.indexOf(value) : -1;\n }\n\n /**\n * Get the index of the currently active menu item.\n *\n * #### Notes\n * This will be `-1` if no menu item is active.\n */\n get activeIndex(): number {\n return this._activeIndex;\n }\n\n /**\n * Set the index of the currently active menu item.\n *\n * #### Notes\n * If the item cannot be activated, the index will be set to `-1`.\n */\n set activeIndex(value: number) {\n // Adjust the value for an out of range index.\n if (value < 0 || value >= this._items.length) {\n value = -1;\n }\n\n // Ensure the item can be activated.\n if (value !== -1 && !Private.canActivate(this._items[value])) {\n value = -1;\n }\n\n // Bail if the index will not change.\n if (this._activeIndex === value) {\n return;\n }\n\n // Update the active index.\n this._activeIndex = value;\n\n // Make active element in focus\n if (\n this._activeIndex >= 0 &&\n this.contentNode.childNodes[this._activeIndex]\n ) {\n (this.contentNode.childNodes[this._activeIndex] as HTMLElement).focus();\n }\n\n // schedule an update of the items.\n this.update();\n }\n\n /**\n * A read-only array of the menu items in the menu.\n */\n get items(): ReadonlyArray {\n return this._items;\n }\n\n /**\n * Activate the next selectable item in the menu.\n *\n * #### Notes\n * If no item is selectable, the index will be set to `-1`.\n */\n activateNextItem(): void {\n let n = this._items.length;\n let ai = this._activeIndex;\n let start = ai < n - 1 ? ai + 1 : 0;\n let stop = start === 0 ? n - 1 : start - 1;\n this.activeIndex = ArrayExt.findFirstIndex(\n this._items,\n Private.canActivate,\n start,\n stop\n );\n }\n\n /**\n * Activate the previous selectable item in the menu.\n *\n * #### Notes\n * If no item is selectable, the index will be set to `-1`.\n */\n activatePreviousItem(): void {\n let n = this._items.length;\n let ai = this._activeIndex;\n let start = ai <= 0 ? n - 1 : ai - 1;\n let stop = start === n - 1 ? 0 : start + 1;\n this.activeIndex = ArrayExt.findLastIndex(\n this._items,\n Private.canActivate,\n start,\n stop\n );\n }\n\n /**\n * Trigger the active menu item.\n *\n * #### Notes\n * If the active item is a submenu, it will be opened and the first\n * item will be activated.\n *\n * If the active item is a command, the command will be executed.\n *\n * If the menu is not attached, this is a no-op.\n *\n * If there is no active item, this is a no-op.\n */\n triggerActiveItem(): void {\n // Bail if the menu is not attached.\n if (!this.isAttached) {\n return;\n }\n\n // Bail if there is no active item.\n let item = this.activeItem;\n if (!item) {\n return;\n }\n\n // Cancel the pending timers.\n this._cancelOpenTimer();\n this._cancelCloseTimer();\n\n // If the item is a submenu, open it.\n if (item.type === 'submenu') {\n this._openChildMenu(true);\n return;\n }\n\n // Close the root menu before executing the command.\n this.rootMenu.close();\n\n // Execute the command for the item.\n let { command, args } = item;\n if (this.commands.isEnabled(command, args)) {\n this.commands.execute(command, args);\n } else {\n console.log(`Command '${command}' is disabled.`);\n }\n }\n\n /**\n * Add a menu item to the end of the menu.\n *\n * @param options - The options for creating the menu item.\n *\n * @returns The menu item added to the menu.\n */\n addItem(options: Menu.IItemOptions): Menu.IItem {\n return this.insertItem(this._items.length, options);\n }\n\n /**\n * Insert a menu item into the menu at the specified index.\n *\n * @param index - The index at which to insert the item.\n *\n * @param options - The options for creating the menu item.\n *\n * @returns The menu item added to the menu.\n *\n * #### Notes\n * The index will be clamped to the bounds of the items.\n */\n insertItem(index: number, options: Menu.IItemOptions): Menu.IItem {\n // Close the menu if it's attached.\n if (this.isAttached) {\n this.close();\n }\n\n // Reset the active index.\n this.activeIndex = -1;\n\n // Clamp the insert index to the array bounds.\n let i = Math.max(0, Math.min(index, this._items.length));\n\n // Create the item for the options.\n let item = Private.createItem(this, options);\n\n // Insert the item into the array.\n ArrayExt.insert(this._items, i, item);\n\n // Schedule an update of the items.\n this.update();\n\n // Return the item added to the menu.\n return item;\n }\n\n /**\n * Remove an item from the menu.\n *\n * @param item - The item to remove from the menu.\n *\n * #### Notes\n * This is a no-op if the item is not in the menu.\n */\n removeItem(item: Menu.IItem): void {\n this.removeItemAt(this._items.indexOf(item));\n }\n\n /**\n * Remove the item at a given index from the menu.\n *\n * @param index - The index of the item to remove.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n removeItemAt(index: number): void {\n // Close the menu if it's attached.\n if (this.isAttached) {\n this.close();\n }\n\n // Reset the active index.\n this.activeIndex = -1;\n\n // Remove the item from the array.\n let item = ArrayExt.removeAt(this._items, index);\n\n // Bail if the index is out of range.\n if (!item) {\n return;\n }\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * Remove all menu items from the menu.\n */\n clearItems(): void {\n // Close the menu if it's attached.\n if (this.isAttached) {\n this.close();\n }\n\n // Reset the active index.\n this.activeIndex = -1;\n\n // Bail if there is nothing to remove.\n if (this._items.length === 0) {\n return;\n }\n\n // Clear the items.\n this._items.length = 0;\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * Open the menu at the specified location.\n *\n * @param x - The client X coordinate of the menu location.\n *\n * @param y - The client Y coordinate of the menu location.\n *\n * @param options - The additional options for opening the menu.\n *\n * #### Notes\n * The menu will be opened at the given location unless it will not\n * fully fit on the screen. If it will not fit, it will be adjusted\n * to fit naturally on the screen.\n *\n * The menu will be attached under the `host` element in the DOM\n * (or `document.body` if `host` is `null`) and before the `ref`\n * element (or as the last child of `host` if `ref` is `null`).\n * The menu may be displayed outside of the `host` element\n * following the rules of CSS absolute positioning.\n *\n * This is a no-op if the menu is already attached to the DOM.\n */\n open(x: number, y: number, options: Menu.IOpenOptions = {}): void {\n // Bail early if the menu is already attached.\n if (this.isAttached) {\n return;\n }\n\n // Extract the menu options.\n let forceX = options.forceX || false;\n let forceY = options.forceY || false;\n const host = options.host ?? null;\n const ref = options.ref ?? null;\n\n // Open the menu as a root menu.\n Private.openRootMenu(this, x, y, forceX, forceY, host, ref);\n\n // Activate the menu to accept keyboard input.\n this.activate();\n }\n\n /**\n * Handle the DOM events for the menu.\n *\n * @param event - The DOM event sent to the menu.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the menu's DOM nodes. It should\n * not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'mouseup':\n this._evtMouseUp(event as MouseEvent);\n break;\n case 'mousemove':\n this._evtMouseMove(event as MouseEvent);\n break;\n case 'mouseenter':\n this._evtMouseEnter(event as MouseEvent);\n break;\n case 'mouseleave':\n this._evtMouseLeave(event as MouseEvent);\n break;\n case 'mousedown':\n this._evtMouseDown(event as MouseEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('keydown', this);\n this.node.addEventListener('mouseup', this);\n this.node.addEventListener('mousemove', this);\n this.node.addEventListener('mouseenter', this);\n this.node.addEventListener('mouseleave', this);\n this.node.addEventListener('contextmenu', this);\n this.node.ownerDocument.addEventListener('mousedown', this, true);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('keydown', this);\n this.node.removeEventListener('mouseup', this);\n this.node.removeEventListener('mousemove', this);\n this.node.removeEventListener('mouseenter', this);\n this.node.removeEventListener('mouseleave', this);\n this.node.removeEventListener('contextmenu', this);\n this.node.ownerDocument.removeEventListener('mousedown', this, true);\n }\n\n /**\n * A message handler invoked on an `'activate-request'` message.\n */\n protected onActivateRequest(msg: Message): void {\n if (this.isAttached) {\n this.node.focus();\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n let items = this._items;\n let renderer = this.renderer;\n let activeIndex = this._activeIndex;\n let collapsedFlags = Private.computeCollapsed(items);\n let content = new Array(items.length);\n for (let i = 0, n = items.length; i < n; ++i) {\n let item = items[i];\n let active = i === activeIndex;\n let collapsed = collapsedFlags[i];\n content[i] = renderer.renderItem({\n item,\n active,\n collapsed,\n onfocus: () => {\n this.activeIndex = i;\n }\n });\n }\n VirtualDOM.render(content, this.contentNode);\n }\n\n /**\n * A message handler invoked on a `'close-request'` message.\n */\n protected onCloseRequest(msg: Message): void {\n // Cancel the pending timers.\n this._cancelOpenTimer();\n this._cancelCloseTimer();\n\n // Reset the active index.\n this.activeIndex = -1;\n\n // Close any open child menu.\n let childMenu = this._childMenu;\n if (childMenu) {\n this._childIndex = -1;\n this._childMenu = null;\n childMenu._parentMenu = null;\n childMenu.close();\n }\n\n // Remove this menu from its parent and activate the parent.\n let parentMenu = this._parentMenu;\n if (parentMenu) {\n this._parentMenu = null;\n parentMenu._childIndex = -1;\n parentMenu._childMenu = null;\n parentMenu.activate();\n }\n\n // Emit the `aboutToClose` signal if the menu is attached.\n if (this.isAttached) {\n this._aboutToClose.emit(undefined);\n }\n\n // Finish closing the menu.\n super.onCloseRequest(msg);\n }\n\n /**\n * Handle the `'keydown'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the menu node.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // A menu handles all keydown events.\n event.preventDefault();\n event.stopPropagation();\n\n // Fetch the key code for the event.\n let kc = event.keyCode;\n\n // Enter\n if (kc === 13) {\n this.triggerActiveItem();\n return;\n }\n\n // Escape\n if (kc === 27) {\n this.close();\n return;\n }\n\n // Left Arrow\n if (kc === 37) {\n if (this._parentMenu) {\n this.close();\n } else {\n this._menuRequested.emit('previous');\n }\n return;\n }\n\n // Up Arrow\n if (kc === 38) {\n this.activatePreviousItem();\n return;\n }\n\n // Right Arrow\n if (kc === 39) {\n let item = this.activeItem;\n if (item && item.type === 'submenu') {\n this.triggerActiveItem();\n } else {\n this.rootMenu._menuRequested.emit('next');\n }\n return;\n }\n\n // Down Arrow\n if (kc === 40) {\n this.activateNextItem();\n return;\n }\n\n // Get the pressed key character.\n let key = getKeyboardLayout().keyForKeydownEvent(event);\n\n // Bail if the key is not valid.\n if (!key) {\n return;\n }\n\n // Search for the next best matching mnemonic item.\n let start = this._activeIndex + 1;\n let result = Private.findMnemonic(this._items, key, start);\n\n // Handle the requested mnemonic based on the search results.\n // If exactly one mnemonic is matched, that item is triggered.\n // Otherwise, the next mnemonic is activated if available,\n // followed by the auto mnemonic if available.\n if (result.index !== -1 && !result.multiple) {\n this.activeIndex = result.index;\n this.triggerActiveItem();\n } else if (result.index !== -1) {\n this.activeIndex = result.index;\n } else if (result.auto !== -1) {\n this.activeIndex = result.auto;\n }\n }\n\n /**\n * Handle the `'mouseup'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the menu node.\n */\n private _evtMouseUp(event: MouseEvent): void {\n if (event.button !== 0) {\n return;\n }\n event.preventDefault();\n event.stopPropagation();\n this.triggerActiveItem();\n }\n\n /**\n * Handle the `'mousemove'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the menu node.\n */\n private _evtMouseMove(event: MouseEvent): void {\n // Hit test the item nodes for the item under the mouse.\n let index = ArrayExt.findFirstIndex(this.contentNode.children, node => {\n return ElementExt.hitTest(node, event.clientX, event.clientY);\n });\n\n // Bail early if the mouse is already over the active index.\n if (index === this._activeIndex) {\n return;\n }\n\n // Update and coerce the active index.\n this.activeIndex = index;\n index = this.activeIndex;\n\n // If the index is the current child index, cancel the timers.\n if (index === this._childIndex) {\n this._cancelOpenTimer();\n this._cancelCloseTimer();\n return;\n }\n\n // If a child menu is currently open, start the close timer.\n if (this._childIndex !== -1) {\n this._startCloseTimer();\n }\n\n // Cancel the open timer to give a full delay for opening.\n this._cancelOpenTimer();\n\n // Bail if the active item is not a valid submenu item.\n let item = this.activeItem;\n if (!item || item.type !== 'submenu' || !item.submenu) {\n return;\n }\n\n // Start the open timer to open the active item submenu.\n this._startOpenTimer();\n }\n\n /**\n * Handle the `'mouseenter'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the menu node.\n */\n private _evtMouseEnter(event: MouseEvent): void {\n // Synchronize the active ancestor items.\n for (let menu = this._parentMenu; menu; menu = menu._parentMenu) {\n menu._cancelOpenTimer();\n menu._cancelCloseTimer();\n menu.activeIndex = menu._childIndex;\n }\n }\n\n /**\n * Handle the `'mouseleave'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the menu node.\n */\n private _evtMouseLeave(event: MouseEvent): void {\n // Cancel any pending submenu opening.\n this._cancelOpenTimer();\n\n // If there is no open child menu, just reset the active index.\n if (!this._childMenu) {\n this.activeIndex = -1;\n return;\n }\n\n // If the mouse is over the child menu, cancel the close timer.\n let { clientX, clientY } = event;\n if (ElementExt.hitTest(this._childMenu.node, clientX, clientY)) {\n this._cancelCloseTimer();\n return;\n }\n\n // Otherwise, reset the active index and start the close timer.\n this.activeIndex = -1;\n this._startCloseTimer();\n }\n\n /**\n * Handle the `'mousedown'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the document node.\n */\n private _evtMouseDown(event: MouseEvent): void {\n // Bail if the menu is not a root menu.\n if (this._parentMenu) {\n return;\n }\n\n // The mouse button which is pressed is irrelevant. If the press\n // is not on a menu, the entire hierarchy is closed and the event\n // is allowed to propagate. This allows other code to act on the\n // event, such as focusing the clicked element.\n if (Private.hitTestMenus(this, event.clientX, event.clientY)) {\n event.preventDefault();\n event.stopPropagation();\n } else {\n this.close();\n }\n }\n\n /**\n * Open the child menu at the active index immediately.\n *\n * If a different child menu is already open, it will be closed,\n * even if the active item is not a valid submenu.\n */\n private _openChildMenu(activateFirst = false): void {\n // If the item is not a valid submenu, close the child menu.\n let item = this.activeItem;\n if (!item || item.type !== 'submenu' || !item.submenu) {\n this._closeChildMenu();\n return;\n }\n\n // Do nothing if the child menu will not change.\n let submenu = item.submenu;\n if (submenu === this._childMenu) {\n return;\n }\n\n // Prior to any DOM modifications save window data\n Menu.saveWindowData();\n\n // Ensure the current child menu is closed.\n this._closeChildMenu();\n\n // Update the private child state.\n this._childMenu = submenu;\n this._childIndex = this._activeIndex;\n\n // Set the parent menu reference for the child.\n submenu._parentMenu = this;\n\n // Ensure the menu is updated and lookup the item node.\n MessageLoop.sendMessage(this, Widget.Msg.UpdateRequest);\n let itemNode = this.contentNode.children[this._activeIndex];\n\n // Open the submenu at the active node.\n Private.openSubmenu(submenu, itemNode as HTMLElement);\n\n // Activate the first item if desired.\n if (activateFirst) {\n submenu.activeIndex = -1;\n submenu.activateNextItem();\n }\n\n // Activate the child menu.\n submenu.activate();\n }\n\n /**\n * Close the child menu immediately.\n *\n * This is a no-op if a child menu is not open.\n */\n private _closeChildMenu(): void {\n if (this._childMenu) {\n this._childMenu.close();\n }\n }\n\n /**\n * Start the open timer, unless it is already pending.\n */\n private _startOpenTimer(): void {\n if (this._openTimerID === 0) {\n this._openTimerID = window.setTimeout(() => {\n this._openTimerID = 0;\n this._openChildMenu();\n }, Private.TIMER_DELAY);\n }\n }\n\n /**\n * Start the close timer, unless it is already pending.\n */\n private _startCloseTimer(): void {\n if (this._closeTimerID === 0) {\n this._closeTimerID = window.setTimeout(() => {\n this._closeTimerID = 0;\n this._closeChildMenu();\n }, Private.TIMER_DELAY);\n }\n }\n\n /**\n * Cancel the open timer, if the timer is pending.\n */\n private _cancelOpenTimer(): void {\n if (this._openTimerID !== 0) {\n clearTimeout(this._openTimerID);\n this._openTimerID = 0;\n }\n }\n\n /**\n * Cancel the close timer, if the timer is pending.\n */\n private _cancelCloseTimer(): void {\n if (this._closeTimerID !== 0) {\n clearTimeout(this._closeTimerID);\n this._closeTimerID = 0;\n }\n }\n\n /**\n * Save window data used for menu positioning in transient cache.\n *\n * In order to avoid layout trashing it is recommended to invoke this\n * method immediately prior to opening the menu and any DOM modifications\n * (like closing previously visible menu, or adding a class to menu widget).\n *\n * The transient cache will be released upon `open()` call.\n */\n static saveWindowData(): void {\n Private.saveWindowData();\n }\n\n private _childIndex = -1;\n private _activeIndex = -1;\n private _openTimerID = 0;\n private _closeTimerID = 0;\n private _items: Menu.IItem[] = [];\n private _childMenu: Menu | null = null;\n private _parentMenu: Menu | null = null;\n private _aboutToClose = new Signal(this);\n private _menuRequested = new Signal(this);\n}\n\n/**\n * The namespace for the `Menu` class statics.\n */\nexport namespace Menu {\n /**\n * An options object for creating a menu.\n */\n export interface IOptions {\n /**\n * The command registry for use with the menu.\n */\n commands: CommandRegistry;\n\n /**\n * A custom renderer for use with the menu.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n }\n\n /**\n * An options object for the `open` method on a menu.\n */\n export interface IOpenOptions {\n /**\n * Whether to force the X position of the menu.\n *\n * Setting to `true` will disable the logic which repositions the\n * X coordinate of the menu if it will not fit entirely on screen.\n *\n * The default is `false`.\n */\n forceX?: boolean;\n\n /**\n * Whether to force the Y position of the menu.\n *\n * Setting to `true` will disable the logic which repositions the\n * Y coordinate of the menu if it will not fit entirely on screen.\n *\n * The default is `false`.\n */\n forceY?: boolean;\n\n /**\n * The DOM node to use as the menu's host.\n *\n * If not specified then uses `document.body`.\n */\n host?: HTMLElement;\n\n /**\n * The child of `host` to use as the reference element.\n * If this is provided, the menu will be inserted before this\n * node in the host. The default is `null`, which will cause the\n * menu to be added as the last child of the host.\n */\n ref?: HTMLElement;\n }\n\n /**\n * A type alias for a menu item type.\n */\n export type ItemType = 'command' | 'submenu' | 'separator';\n\n /**\n * An options object for creating a menu item.\n */\n export interface IItemOptions {\n /**\n * The type of the menu item.\n *\n * The default value is `'command'`.\n */\n type?: ItemType;\n\n /**\n * The command to execute when the item is triggered.\n *\n * The default value is an empty string.\n */\n command?: string;\n\n /**\n * The arguments for the command.\n *\n * The default value is an empty object.\n */\n args?: ReadonlyJSONObject;\n\n /**\n * The submenu for a `'submenu'` type item.\n *\n * The default value is `null`.\n */\n submenu?: Menu | null;\n }\n\n /**\n * An object which represents a menu item.\n *\n * #### Notes\n * Item objects are created automatically by a menu.\n */\n export interface IItem {\n /**\n * The type of the menu item.\n */\n readonly type: ItemType;\n\n /**\n * The command to execute when the item is triggered.\n */\n readonly command: string;\n\n /**\n * The arguments for the command.\n */\n readonly args: ReadonlyJSONObject;\n\n /**\n * The submenu for a `'submenu'` type item.\n */\n readonly submenu: Menu | null;\n\n /**\n * The display label for the menu item.\n */\n readonly label: string;\n\n /**\n * The mnemonic index for the menu item.\n */\n readonly mnemonic: number;\n\n /**\n * The icon renderer for the menu item.\n */\n readonly icon: VirtualElement.IRenderer | undefined;\n\n /**\n * The icon class for the menu item.\n */\n readonly iconClass: string;\n\n /**\n * The icon label for the menu item.\n */\n readonly iconLabel: string;\n\n /**\n * The display caption for the menu item.\n */\n readonly caption: string;\n\n /**\n * The extra class name for the menu item.\n */\n readonly className: string;\n\n /**\n * The dataset for the menu item.\n */\n readonly dataset: CommandRegistry.Dataset;\n\n /**\n * Whether the menu item is enabled.\n */\n readonly isEnabled: boolean;\n\n /**\n * Whether the menu item is toggled.\n */\n readonly isToggled: boolean;\n\n /**\n * Whether the menu item is visible.\n */\n readonly isVisible: boolean;\n\n /**\n * The key binding for the menu item.\n */\n readonly keyBinding: CommandRegistry.IKeyBinding | null;\n }\n\n /**\n * An object which holds the data to render a menu item.\n */\n export interface IRenderData {\n /**\n * The item to be rendered.\n */\n readonly item: IItem;\n\n /**\n * Whether the item is the active item.\n */\n readonly active: boolean;\n\n /**\n * Whether the item should be collapsed.\n */\n readonly collapsed: boolean;\n\n /**\n * Handler for when element is in focus.\n */\n readonly onfocus?: () => void;\n }\n\n /**\n * A renderer for use with a menu.\n */\n export interface IRenderer {\n /**\n * Render the virtual element for a menu item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n */\n renderItem(data: IRenderData): VirtualElement;\n }\n\n /**\n * The default implementation of `IRenderer`.\n *\n * #### Notes\n * Subclasses are free to reimplement rendering methods as needed.\n */\n export class Renderer implements IRenderer {\n /**\n * Render the virtual element for a menu item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n */\n renderItem(data: IRenderData): VirtualElement {\n let className = this.createItemClass(data);\n let dataset = this.createItemDataset(data);\n let aria = this.createItemARIA(data);\n return h.li(\n {\n className,\n dataset,\n tabindex: '0',\n onfocus: data.onfocus,\n ...aria\n },\n this.renderIcon(data),\n this.renderLabel(data),\n this.renderShortcut(data),\n this.renderSubmenu(data)\n );\n }\n\n /**\n * Render the icon element for a menu item.\n *\n * @param data - The data to use for rendering the icon.\n *\n * @returns A virtual element representing the item icon.\n */\n renderIcon(data: IRenderData): VirtualElement {\n let className = this.createIconClass(data);\n\n // If data.item.icon is undefined, it will be ignored.\n return h.div({ className }, data.item.icon!, data.item.iconLabel);\n }\n\n /**\n * Render the label element for a menu item.\n *\n * @param data - The data to use for rendering the label.\n *\n * @returns A virtual element representing the item label.\n */\n renderLabel(data: IRenderData): VirtualElement {\n let content = this.formatLabel(data);\n return h.div({ className: 'lm-Menu-itemLabel' }, content);\n }\n\n /**\n * Render the shortcut element for a menu item.\n *\n * @param data - The data to use for rendering the shortcut.\n *\n * @returns A virtual element representing the item shortcut.\n */\n renderShortcut(data: IRenderData): VirtualElement {\n let content = this.formatShortcut(data);\n return h.div({ className: 'lm-Menu-itemShortcut' }, content);\n }\n\n /**\n * Render the submenu icon element for a menu item.\n *\n * @param data - The data to use for rendering the submenu icon.\n *\n * @returns A virtual element representing the submenu icon.\n */\n renderSubmenu(data: IRenderData): VirtualElement {\n return h.div({ className: 'lm-Menu-itemSubmenuIcon' });\n }\n\n /**\n * Create the class name for the menu item.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the menu item.\n */\n createItemClass(data: IRenderData): string {\n // Setup the initial class name.\n let name = 'lm-Menu-item';\n\n // Add the boolean state classes.\n if (!data.item.isEnabled) {\n name += ' lm-mod-disabled';\n }\n if (data.item.isToggled) {\n name += ' lm-mod-toggled';\n }\n if (!data.item.isVisible) {\n name += ' lm-mod-hidden';\n }\n if (data.active) {\n name += ' lm-mod-active';\n }\n if (data.collapsed) {\n name += ' lm-mod-collapsed';\n }\n\n // Add the extra class.\n let extra = data.item.className;\n if (extra) {\n name += ` ${extra}`;\n }\n\n // Return the complete class name.\n return name;\n }\n\n /**\n * Create the dataset for the menu item.\n *\n * @param data - The data to use for creating the dataset.\n *\n * @returns The dataset for the menu item.\n */\n createItemDataset(data: IRenderData): ElementDataset {\n let result: ElementDataset;\n let { type, command, dataset } = data.item;\n if (type === 'command') {\n result = { ...dataset, type, command };\n } else {\n result = { ...dataset, type };\n }\n return result;\n }\n\n /**\n * Create the class name for the menu item icon.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the item icon.\n */\n createIconClass(data: IRenderData): string {\n let name = 'lm-Menu-itemIcon';\n let extra = data.item.iconClass;\n return extra ? `${name} ${extra}` : name;\n }\n\n /**\n * Create the aria attributes for menu item.\n *\n * @param data - The data to use for the aria attributes.\n *\n * @returns The aria attributes object for the item.\n */\n createItemARIA(data: IRenderData): ElementARIAAttrs {\n let aria: { [T in ARIAAttrNames]?: string } = {};\n switch (data.item.type) {\n case 'separator':\n aria.role = 'presentation';\n break;\n case 'submenu':\n aria['aria-haspopup'] = 'true';\n if (!data.item.isEnabled) {\n aria['aria-disabled'] = 'true';\n }\n break;\n default:\n if (!data.item.isEnabled) {\n aria['aria-disabled'] = 'true';\n }\n aria.role = 'menuitem';\n }\n return aria;\n }\n\n /**\n * Create the render content for the label node.\n *\n * @param data - The data to use for the label content.\n *\n * @returns The content to add to the label node.\n */\n formatLabel(data: IRenderData): h.Child {\n // Fetch the label text and mnemonic index.\n let { label, mnemonic } = data.item;\n\n // If the index is out of range, do not modify the label.\n if (mnemonic < 0 || mnemonic >= label.length) {\n return label;\n }\n\n // Split the label into parts.\n let prefix = label.slice(0, mnemonic);\n let suffix = label.slice(mnemonic + 1);\n let char = label[mnemonic];\n\n // Wrap the mnemonic character in a span.\n let span = h.span({ className: 'lm-Menu-itemMnemonic' }, char);\n\n // Return the content parts.\n return [prefix, span, suffix];\n }\n\n /**\n * Create the render content for the shortcut node.\n *\n * @param data - The data to use for the shortcut content.\n *\n * @returns The content to add to the shortcut node.\n */\n formatShortcut(data: IRenderData): h.Child {\n let kb = data.item.keyBinding;\n return kb ? CommandRegistry.formatKeystroke(kb.keys) : null;\n }\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The ms delay for opening and closing a submenu.\n */\n export const TIMER_DELAY = 300;\n\n /**\n * The horizontal pixel overlap for an open submenu.\n */\n export const SUBMENU_OVERLAP = 3;\n\n let transientWindowDataCache: IWindowData | null = null;\n let transientCacheCounter: number = 0;\n\n function getWindowData(): IWindowData {\n // if transient cache is in use, take one from it\n if (transientCacheCounter > 0) {\n transientCacheCounter--;\n return transientWindowDataCache!;\n }\n return _getWindowData();\n }\n\n /**\n * Store window data in transient cache.\n *\n * The transient cache will be released upon `getWindowData()` call.\n * If this function is called multiple times, the cache will be\n * retained until as many calls to `getWindowData()` were made.\n *\n * Note: should be called before any DOM modifications.\n */\n export function saveWindowData(): void {\n transientWindowDataCache = _getWindowData();\n transientCacheCounter++;\n }\n\n /**\n * Create the DOM node for a menu.\n */\n export function createNode(): HTMLDivElement {\n let node = document.createElement('div');\n let content = document.createElement('ul');\n content.className = 'lm-Menu-content';\n node.appendChild(content);\n content.setAttribute('role', 'menu');\n node.tabIndex = 0;\n return node;\n }\n\n /**\n * Test whether a menu item can be activated.\n */\n export function canActivate(item: Menu.IItem): boolean {\n return item.type !== 'separator' && item.isEnabled && item.isVisible;\n }\n\n /**\n * Create a new menu item for an owner menu.\n */\n export function createItem(\n owner: Menu,\n options: Menu.IItemOptions\n ): Menu.IItem {\n return new MenuItem(owner.commands, options);\n }\n\n /**\n * Hit test a menu hierarchy starting at the given root.\n */\n export function hitTestMenus(menu: Menu, x: number, y: number): boolean {\n for (let temp: Menu | null = menu; temp; temp = temp.childMenu) {\n if (ElementExt.hitTest(temp.node, x, y)) {\n return true;\n }\n }\n return false;\n }\n\n /**\n * Compute which extra separator items should be collapsed.\n */\n export function computeCollapsed(\n items: ReadonlyArray\n ): boolean[] {\n // Allocate the return array and fill it with `false`.\n let result = new Array(items.length);\n ArrayExt.fill(result, false);\n\n // Collapse the leading separators.\n let k1 = 0;\n let n = items.length;\n for (; k1 < n; ++k1) {\n let item = items[k1];\n if (!item.isVisible) {\n continue;\n }\n if (item.type !== 'separator') {\n break;\n }\n result[k1] = true;\n }\n\n // Hide the trailing separators.\n let k2 = n - 1;\n for (; k2 >= 0; --k2) {\n let item = items[k2];\n if (!item.isVisible) {\n continue;\n }\n if (item.type !== 'separator') {\n break;\n }\n result[k2] = true;\n }\n\n // Hide the remaining consecutive separators.\n let hide = false;\n while (++k1 < k2) {\n let item = items[k1];\n if (!item.isVisible) {\n continue;\n }\n if (item.type !== 'separator') {\n hide = false;\n } else if (hide) {\n result[k1] = true;\n } else {\n hide = true;\n }\n }\n\n // Return the resulting flags.\n return result;\n }\n\n function _getWindowData(): IWindowData {\n return {\n pageXOffset: window.pageXOffset,\n pageYOffset: window.pageYOffset,\n clientWidth: document.documentElement.clientWidth,\n clientHeight: document.documentElement.clientHeight\n };\n }\n\n /**\n * Open a menu as a root menu at the target location.\n */\n export function openRootMenu(\n menu: Menu,\n x: number,\n y: number,\n forceX: boolean,\n forceY: boolean,\n host: HTMLElement | null,\n ref: HTMLElement | null\n ): void {\n // Get the current position and size of the main viewport.\n const windowData = getWindowData();\n let px = windowData.pageXOffset;\n let py = windowData.pageYOffset;\n let cw = windowData.clientWidth;\n let ch = windowData.clientHeight;\n\n // Ensure the menu is updated before attaching and measuring.\n MessageLoop.sendMessage(menu, Widget.Msg.UpdateRequest);\n\n // Compute the maximum allowed height for the menu.\n let maxHeight = ch - (forceY ? y : 0);\n\n // Fetch common variables.\n let node = menu.node;\n let style = node.style;\n\n // Clear the menu geometry and prepare it for measuring.\n style.opacity = '0';\n style.maxHeight = `${maxHeight}px`;\n\n // Attach the menu to the document.\n Widget.attach(menu, host || document.body, ref);\n\n // Measure the size of the menu.\n let { width, height } = node.getBoundingClientRect();\n\n // Adjust the X position of the menu to fit on-screen.\n if (!forceX && x + width > px + cw) {\n x = px + cw - width;\n }\n\n // Adjust the Y position of the menu to fit on-screen.\n if (!forceY && y + height > py + ch) {\n if (y > py + ch) {\n y = py + ch - height;\n } else {\n y = y - height;\n }\n }\n\n // Update the position of the menu to the computed position.\n style.transform = `translate(${Math.max(0, x)}px, ${Math.max(0, y)}px`;\n\n // Finally, make the menu visible on the screen.\n style.opacity = '1';\n }\n\n /**\n * Open a menu as a submenu using an item node for positioning.\n */\n export function openSubmenu(submenu: Menu, itemNode: HTMLElement): void {\n // Get the current position and size of the main viewport.\n const windowData = getWindowData();\n let px = windowData.pageXOffset;\n let py = windowData.pageYOffset;\n let cw = windowData.clientWidth;\n let ch = windowData.clientHeight;\n\n // Ensure the menu is updated before opening.\n MessageLoop.sendMessage(submenu, Widget.Msg.UpdateRequest);\n\n // Compute the maximum allowed height for the menu.\n let maxHeight = ch;\n\n // Fetch common variables.\n let node = submenu.node;\n let style = node.style;\n\n // Clear the menu geometry and prepare it for measuring.\n style.opacity = '0';\n style.maxHeight = `${maxHeight}px`;\n\n // Attach the menu to the document.\n Widget.attach(submenu, itemNode.ownerDocument.body);\n\n // Measure the size of the menu.\n let { width, height } = node.getBoundingClientRect();\n\n // Compute the box sizing for the menu.\n let box = ElementExt.boxSizing(submenu.node);\n\n // Get the bounding rect for the target item node.\n let itemRect = itemNode.getBoundingClientRect();\n\n // Compute the target X position.\n let x = itemRect.right - SUBMENU_OVERLAP;\n\n // Adjust the X position to fit on the screen.\n if (x + width > px + cw) {\n x = itemRect.left + SUBMENU_OVERLAP - width;\n }\n\n // Compute the target Y position.\n let y = itemRect.top - box.borderTop - box.paddingTop;\n\n // Adjust the Y position to fit on the screen.\n if (y + height > py + ch) {\n y = itemRect.bottom + box.borderBottom + box.paddingBottom - height;\n }\n\n // Update the position of the menu to the computed position.\n style.transform = `translate(${Math.max(0, x)}px, ${Math.max(0, y)}px`;\n\n // Finally, make the menu visible on the screen.\n style.opacity = '1';\n }\n\n /**\n * The results of a mnemonic search.\n */\n export interface IMnemonicResult {\n /**\n * The index of the first matching mnemonic item, or `-1`.\n */\n index: number;\n\n /**\n * Whether multiple mnemonic items matched.\n */\n multiple: boolean;\n\n /**\n * The index of the first auto matched non-mnemonic item.\n */\n auto: number;\n }\n\n /**\n * Find the best matching mnemonic item.\n *\n * The search starts at the given index and wraps around.\n */\n export function findMnemonic(\n items: ReadonlyArray,\n key: string,\n start: number\n ): IMnemonicResult {\n // Setup the result variables.\n let index = -1;\n let auto = -1;\n let multiple = false;\n\n // Normalize the key to upper case.\n let upperKey = key.toUpperCase();\n\n // Search the items from the given start index.\n for (let i = 0, n = items.length; i < n; ++i) {\n // Compute the wrapped index.\n let k = (i + start) % n;\n\n // Lookup the item\n let item = items[k];\n\n // Ignore items which cannot be activated.\n if (!canActivate(item)) {\n continue;\n }\n\n // Ignore items with an empty label.\n let label = item.label;\n if (label.length === 0) {\n continue;\n }\n\n // Lookup the mnemonic index for the label.\n let mn = item.mnemonic;\n\n // Handle a valid mnemonic index.\n if (mn >= 0 && mn < label.length) {\n if (label[mn].toUpperCase() === upperKey) {\n if (index === -1) {\n index = k;\n } else {\n multiple = true;\n }\n }\n continue;\n }\n\n // Finally, handle the auto index if possible.\n if (auto === -1 && label[0].toUpperCase() === upperKey) {\n auto = k;\n }\n }\n\n // Return the search results.\n return { index, multiple, auto };\n }\n\n /**\n * A concrete implementation of `Menu.IItem`.\n */\n class MenuItem implements Menu.IItem {\n /**\n * Construct a new menu item.\n */\n constructor(commands: CommandRegistry, options: Menu.IItemOptions) {\n this._commands = commands;\n this.type = options.type || 'command';\n this.command = options.command || '';\n this.args = options.args || JSONExt.emptyObject;\n this.submenu = options.submenu || null;\n }\n\n /**\n * The type of the menu item.\n */\n readonly type: Menu.ItemType;\n\n /**\n * The command to execute when the item is triggered.\n */\n readonly command: string;\n\n /**\n * The arguments for the command.\n */\n readonly args: ReadonlyJSONObject;\n\n /**\n * The submenu for a `'submenu'` type item.\n */\n readonly submenu: Menu | null;\n\n /**\n * The display label for the menu item.\n */\n get label(): string {\n if (this.type === 'command') {\n return this._commands.label(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.label;\n }\n return '';\n }\n\n /**\n * The mnemonic index for the menu item.\n */\n get mnemonic(): number {\n if (this.type === 'command') {\n return this._commands.mnemonic(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.mnemonic;\n }\n return -1;\n }\n\n /**\n * The icon renderer for the menu item.\n */\n get icon(): VirtualElement.IRenderer | undefined {\n if (this.type === 'command') {\n return this._commands.icon(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.icon;\n }\n return undefined;\n }\n\n /**\n * The icon class for the menu item.\n */\n get iconClass(): string {\n if (this.type === 'command') {\n return this._commands.iconClass(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.iconClass;\n }\n return '';\n }\n\n /**\n * The icon label for the menu item.\n */\n get iconLabel(): string {\n if (this.type === 'command') {\n return this._commands.iconLabel(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.iconLabel;\n }\n return '';\n }\n\n /**\n * The display caption for the menu item.\n */\n get caption(): string {\n if (this.type === 'command') {\n return this._commands.caption(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.caption;\n }\n return '';\n }\n\n /**\n * The extra class name for the menu item.\n */\n get className(): string {\n if (this.type === 'command') {\n return this._commands.className(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.className;\n }\n return '';\n }\n\n /**\n * The dataset for the menu item.\n */\n get dataset(): CommandRegistry.Dataset {\n if (this.type === 'command') {\n return this._commands.dataset(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.dataset;\n }\n return {};\n }\n\n /**\n * Whether the menu item is enabled.\n */\n get isEnabled(): boolean {\n if (this.type === 'command') {\n return this._commands.isEnabled(this.command, this.args);\n }\n if (this.type === 'submenu') {\n return this.submenu !== null;\n }\n return true;\n }\n\n /**\n * Whether the menu item is toggled.\n */\n get isToggled(): boolean {\n if (this.type === 'command') {\n return this._commands.isToggled(this.command, this.args);\n }\n return false;\n }\n\n /**\n * Whether the menu item is visible.\n */\n get isVisible(): boolean {\n if (this.type === 'command') {\n return this._commands.isVisible(this.command, this.args);\n }\n if (this.type === 'submenu') {\n return this.submenu !== null;\n }\n return true;\n }\n\n /**\n * The key binding for the menu item.\n */\n get keyBinding(): CommandRegistry.IKeyBinding | null {\n if (this.type === 'command') {\n let { command, args } = this;\n return (\n ArrayExt.findLastValue(this._commands.keyBindings, kb => {\n return kb.command === command && JSONExt.deepEqual(kb.args, args);\n }) || null\n );\n }\n return null;\n }\n\n private _commands: CommandRegistry;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { CommandRegistry } from '@lumino/commands';\n\nimport { DisposableDelegate, IDisposable } from '@lumino/disposable';\n\nimport { Selector } from '@lumino/domutils';\n\nimport { Menu } from './menu';\n\n/**\n * An object which implements a universal context menu.\n *\n * #### Notes\n * The items shown in the context menu are determined by CSS selector\n * matching against the DOM hierarchy at the site of the mouse click.\n * This is similar in concept to how keyboard shortcuts are matched\n * in the command registry.\n */\nexport class ContextMenu {\n /**\n * Construct a new context menu.\n *\n * @param options - The options for initializing the menu.\n */\n constructor(options: ContextMenu.IOptions) {\n const { groupByTarget, sortBySelector, ...others } = options;\n this.menu = new Menu(others);\n this._groupByTarget = groupByTarget !== false;\n this._sortBySelector = sortBySelector !== false;\n }\n\n /**\n * The menu widget which displays the matched context items.\n */\n readonly menu: Menu;\n\n /**\n * Add an item to the context menu.\n *\n * @param options - The options for creating the item.\n *\n * @returns A disposable which will remove the item from the menu.\n */\n addItem(options: ContextMenu.IItemOptions): IDisposable {\n // Create an item from the given options.\n let item = Private.createItem(options, this._idTick++);\n\n // Add the item to the internal array.\n this._items.push(item);\n\n // Return a disposable which will remove the item.\n return new DisposableDelegate(() => {\n ArrayExt.removeFirstOf(this._items, item);\n });\n }\n\n /**\n * Open the context menu in response to a `'contextmenu'` event.\n *\n * @param event - The `'contextmenu'` event of interest.\n *\n * @returns `true` if the menu was opened, or `false` if no items\n * matched the event and the menu was not opened.\n *\n * #### Notes\n * This method will populate the context menu with items which match\n * the propagation path of the event, then open the menu at the mouse\n * position indicated by the event.\n */\n open(event: MouseEvent): boolean {\n // Prior to any DOM modifications update the window data.\n Menu.saveWindowData();\n\n // Clear the current contents of the context menu.\n this.menu.clearItems();\n\n // Bail early if there are no items to match.\n if (this._items.length === 0) {\n return false;\n }\n\n // Find the matching items for the event.\n let items = Private.matchItems(\n this._items,\n event,\n this._groupByTarget,\n this._sortBySelector\n );\n\n // Bail if there are no matching items.\n if (!items || items.length === 0) {\n return false;\n }\n\n // Add the filtered items to the menu.\n for (const item of items) {\n this.menu.addItem(item);\n }\n\n // Open the context menu at the current mouse position.\n this.menu.open(event.clientX, event.clientY);\n\n // Indicate success.\n return true;\n }\n\n private _groupByTarget: boolean = true;\n private _idTick = 0;\n private _items: Private.IItem[] = [];\n private _sortBySelector: boolean = true;\n}\n\n/**\n * The namespace for the `ContextMenu` class statics.\n */\nexport namespace ContextMenu {\n /**\n * An options object for initializing a context menu.\n */\n export interface IOptions {\n /**\n * The command registry to use with the context menu.\n */\n commands: CommandRegistry;\n\n /**\n * A custom renderer for use with the context menu.\n */\n renderer?: Menu.IRenderer;\n\n /**\n * Whether to sort by selector and rank or only rank.\n *\n * Default true.\n */\n sortBySelector?: boolean;\n\n /**\n * Whether to group items following the DOM hierarchy.\n *\n * Default true.\n *\n * #### Note\n * If true, when the mouse event occurs on element `span` within `div.top`,\n * the items matching `div.top` will be shown before the ones matching `body`.\n */\n groupByTarget?: boolean;\n }\n\n /**\n * An options object for creating a context menu item.\n */\n export interface IItemOptions extends Menu.IItemOptions {\n /**\n * The CSS selector for the context menu item.\n *\n * The context menu item will only be displayed in the context menu\n * when the selector matches a node on the propagation path of the\n * contextmenu event. This allows the menu item to be restricted to\n * user-defined contexts.\n *\n * The selector must not contain commas.\n */\n selector: string;\n\n /**\n * The rank for the item.\n *\n * The rank is used as a tie-breaker when ordering context menu\n * items for display. Items are sorted in the following order:\n * 1. Depth in the DOM tree (deeper is better)\n * 2. Selector specificity (higher is better)\n * 3. Rank (lower is better)\n * 4. Insertion order\n *\n * The default rank is `Infinity`.\n */\n rank?: number;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * A normalized item for a context menu.\n */\n export interface IItem extends Menu.IItemOptions {\n /**\n * The selector for the item.\n */\n selector: string;\n\n /**\n * The rank for the item.\n */\n rank: number;\n\n /**\n * The tie-breaking id for the item.\n */\n id: number;\n }\n\n /**\n * Create a normalized context menu item from an options object.\n */\n export function createItem(\n options: ContextMenu.IItemOptions,\n id: number\n ): IItem {\n let selector = validateSelector(options.selector);\n let rank = options.rank !== undefined ? options.rank : Infinity;\n return { ...options, selector, rank, id };\n }\n\n /**\n * Find the items which match a context menu event.\n *\n * The results are sorted by DOM level, specificity, and rank.\n */\n export function matchItems(\n items: IItem[],\n event: MouseEvent,\n groupByTarget: boolean,\n sortBySelector: boolean\n ): IItem[] | null {\n // Look up the target of the event.\n let target = event.target as Element | null;\n\n // Bail if there is no target.\n if (!target) {\n return null;\n }\n\n // Look up the current target of the event.\n let currentTarget = event.currentTarget as Element | null;\n\n // Bail if there is no current target.\n if (!currentTarget) {\n return null;\n }\n\n // There are some third party libraries that cause the `target` to\n // be detached from the DOM before lumino can process the event.\n // If that happens, search for a new target node by point. If that\n // node is still dangling, bail.\n if (!currentTarget.contains(target)) {\n target = document.elementFromPoint(event.clientX, event.clientY);\n if (!target || !currentTarget.contains(target)) {\n return null;\n }\n }\n\n // Set up the result array.\n let result: IItem[] = [];\n\n // Copy the items array to allow in-place modification.\n let availableItems: Array = items.slice();\n\n // Walk up the DOM hierarchy searching for matches.\n while (target !== null) {\n // Set up the match array for this DOM level.\n let matches: IItem[] = [];\n\n // Search the remaining items for matches.\n for (let i = 0, n = availableItems.length; i < n; ++i) {\n // Fetch the item.\n let item = availableItems[i];\n\n // Skip items which are already consumed.\n if (!item) {\n continue;\n }\n\n // Skip items which do not match the element.\n if (!Selector.matches(target, item.selector)) {\n continue;\n }\n\n // Add the matched item to the result for this DOM level.\n matches.push(item);\n\n // Mark the item as consumed.\n availableItems[i] = null;\n }\n\n // Sort the matches for this level and add them to the results.\n if (matches.length !== 0) {\n if (groupByTarget) {\n matches.sort(sortBySelector ? itemCmp : itemCmpRank);\n }\n result.push(...matches);\n }\n\n // Stop searching at the limits of the DOM range.\n if (target === currentTarget) {\n break;\n }\n\n // Step to the parent DOM level.\n target = target.parentElement;\n }\n\n if (!groupByTarget) {\n result.sort(sortBySelector ? itemCmp : itemCmpRank);\n }\n\n // Return the matched and sorted results.\n return result;\n }\n\n /**\n * Validate the selector for a menu item.\n *\n * This returns the validated selector, or throws if the selector is\n * invalid or contains commas.\n */\n function validateSelector(selector: string): string {\n if (selector.indexOf(',') !== -1) {\n throw new Error(`Selector cannot contain commas: ${selector}`);\n }\n if (!Selector.isValid(selector)) {\n throw new Error(`Invalid selector: ${selector}`);\n }\n return selector;\n }\n\n /**\n * A sort comparison function for a context menu item by ranks.\n */\n function itemCmpRank(a: IItem, b: IItem): number {\n // Sort based on rank.\n let r1 = a.rank;\n let r2 = b.rank;\n if (r1 !== r2) {\n return r1 < r2 ? -1 : 1; // Infinity-safe\n }\n\n // When all else fails, sort by item id.\n return a.id - b.id;\n }\n\n /**\n * A sort comparison function for a context menu item by selectors and ranks.\n */\n function itemCmp(a: IItem, b: IItem): number {\n // Sort first based on selector specificity.\n let s1 = Selector.calculateSpecificity(a.selector);\n let s2 = Selector.calculateSpecificity(b.selector);\n if (s1 !== s2) {\n return s2 - s1;\n }\n\n // If specificities are equal\n return itemCmpRank(a, b);\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Drag } from '@lumino/dragdrop';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport {\n ElementARIAAttrs,\n ElementBaseAttrs,\n ElementDataset,\n ElementInlineStyle,\n h,\n VirtualDOM,\n VirtualElement\n} from '@lumino/virtualdom';\n\nimport { Title } from './title';\n\nimport { Widget } from './widget';\n\nconst ARROW_KEYS = [\n 'ArrowLeft',\n 'ArrowUp',\n 'ArrowRight',\n 'ArrowDown',\n 'Home',\n 'End'\n];\n\n/**\n * A widget which displays titles as a single row or column of tabs.\n *\n * #### Notes\n * If CSS transforms are used to rotate nodes for vertically oriented\n * text, then tab dragging will not work correctly. The `tabsMovable`\n * property should be set to `false` when rotating nodes from CSS.\n */\nexport class TabBar extends Widget {\n /**\n * Construct a new tab bar.\n *\n * @param options - The options for initializing the tab bar.\n */\n constructor(options: TabBar.IOptions = {}) {\n super({ node: Private.createNode() });\n this.addClass('lm-TabBar');\n this.contentNode.setAttribute('role', 'tablist');\n this.setFlag(Widget.Flag.DisallowLayout);\n this._document = options.document || document;\n this.tabsMovable = options.tabsMovable || false;\n this.titlesEditable = options.titlesEditable || false;\n this.allowDeselect = options.allowDeselect || false;\n this.addButtonEnabled = options.addButtonEnabled || false;\n this.insertBehavior = options.insertBehavior || 'select-tab-if-needed';\n this.name = options.name || '';\n this.orientation = options.orientation || 'horizontal';\n this.removeBehavior = options.removeBehavior || 'select-tab-after';\n this.renderer = options.renderer || TabBar.defaultRenderer;\n }\n\n /**\n * Dispose of the resources held by the widget.\n */\n dispose(): void {\n this._releaseMouse();\n this._titles.length = 0;\n this._previousTitle = null;\n super.dispose();\n }\n\n /**\n * A signal emitted when the current tab is changed.\n *\n * #### Notes\n * This signal is emitted when the currently selected tab is changed\n * either through user or programmatic interaction.\n *\n * Notably, this signal is not emitted when the index of the current\n * tab changes due to tabs being inserted, removed, or moved. It is\n * only emitted when the actual current tab node is changed.\n */\n get currentChanged(): ISignal> {\n return this._currentChanged;\n }\n\n /**\n * A signal emitted when a tab is moved by the user.\n *\n * #### Notes\n * This signal is emitted when a tab is moved by user interaction.\n *\n * This signal is not emitted when a tab is moved programmatically.\n */\n get tabMoved(): ISignal> {\n return this._tabMoved;\n }\n\n /**\n * A signal emitted when a tab is clicked by the user.\n *\n * #### Notes\n * If the clicked tab is not the current tab, the clicked tab will be\n * made current and the `currentChanged` signal will be emitted first.\n *\n * This signal is emitted even if the clicked tab is the current tab.\n */\n get tabActivateRequested(): ISignal<\n this,\n TabBar.ITabActivateRequestedArgs\n > {\n return this._tabActivateRequested;\n }\n\n /**\n * A signal emitted when the tab bar add button is clicked.\n */\n get addRequested(): ISignal {\n return this._addRequested;\n }\n\n /**\n * A signal emitted when a tab close icon is clicked.\n *\n * #### Notes\n * This signal is not emitted unless the tab title is `closable`.\n */\n get tabCloseRequested(): ISignal> {\n return this._tabCloseRequested;\n }\n\n /**\n * A signal emitted when a tab is dragged beyond the detach threshold.\n *\n * #### Notes\n * This signal is emitted when the user drags a tab with the mouse,\n * and mouse is dragged beyond the detach threshold.\n *\n * The consumer of the signal should call `releaseMouse` and remove\n * the tab in order to complete the detach.\n *\n * This signal is only emitted once per drag cycle.\n */\n get tabDetachRequested(): ISignal> {\n return this._tabDetachRequested;\n }\n\n /**\n * The renderer used by the tab bar.\n */\n readonly renderer: TabBar.IRenderer;\n\n /**\n * The document to use with the tab bar.\n *\n * The default is the global `document` instance.\n */\n get document(): Document | ShadowRoot {\n return this._document;\n }\n\n /**\n * Whether the tabs are movable by the user.\n *\n * #### Notes\n * Tabs can always be moved programmatically.\n */\n tabsMovable: boolean;\n\n /**\n * Whether the titles can be user-edited.\n *\n */\n get titlesEditable(): boolean {\n return this._titlesEditable;\n }\n\n /**\n * Set whether titles can be user edited.\n *\n */\n set titlesEditable(value: boolean) {\n this._titlesEditable = value;\n }\n\n /**\n * Whether a tab can be deselected by the user.\n *\n * #### Notes\n * Tabs can be always be deselected programmatically.\n */\n allowDeselect: boolean;\n\n /**\n * The selection behavior when inserting a tab.\n */\n insertBehavior: TabBar.InsertBehavior;\n\n /**\n * The selection behavior when removing a tab.\n */\n removeBehavior: TabBar.RemoveBehavior;\n\n /**\n * Get the currently selected title.\n *\n * #### Notes\n * This will be `null` if no tab is selected.\n */\n get currentTitle(): Title | null {\n return this._titles[this._currentIndex] || null;\n }\n\n /**\n * Set the currently selected title.\n *\n * #### Notes\n * If the title does not exist, the title will be set to `null`.\n */\n set currentTitle(value: Title | null) {\n this.currentIndex = value ? this._titles.indexOf(value) : -1;\n }\n\n /**\n * Get the index of the currently selected tab.\n *\n * #### Notes\n * This will be `-1` if no tab is selected.\n */\n get currentIndex(): number {\n return this._currentIndex;\n }\n\n /**\n * Set the index of the currently selected tab.\n *\n * #### Notes\n * If the value is out of range, the index will be set to `-1`.\n */\n set currentIndex(value: number) {\n // Adjust for an out of range index.\n if (value < 0 || value >= this._titles.length) {\n value = -1;\n }\n\n // Bail early if the index will not change.\n if (this._currentIndex === value) {\n return;\n }\n\n // Look up the previous index and title.\n let pi = this._currentIndex;\n let pt = this._titles[pi] || null;\n\n // Look up the current index and title.\n let ci = value;\n let ct = this._titles[ci] || null;\n\n // Update the current index and previous title.\n this._currentIndex = ci;\n this._previousTitle = pt;\n\n // Schedule an update of the tabs.\n this.update();\n\n // Emit the current changed signal.\n this._currentChanged.emit({\n previousIndex: pi,\n previousTitle: pt,\n currentIndex: ci,\n currentTitle: ct\n });\n }\n\n /**\n * Get the name of the tab bar.\n */\n get name(): string {\n return this._name;\n }\n\n /**\n * Set the name of the tab bar.\n */\n set name(value: string) {\n this._name = value;\n if (value) {\n this.contentNode.setAttribute('aria-label', value);\n } else {\n this.contentNode.removeAttribute('aria-label');\n }\n }\n\n /**\n * Get the orientation of the tab bar.\n *\n * #### Notes\n * This controls whether the tabs are arranged in a row or column.\n */\n get orientation(): TabBar.Orientation {\n return this._orientation;\n }\n\n /**\n * Set the orientation of the tab bar.\n *\n * #### Notes\n * This controls whether the tabs are arranged in a row or column.\n */\n set orientation(value: TabBar.Orientation) {\n // Do nothing if the orientation does not change.\n if (this._orientation === value) {\n return;\n }\n\n // Release the mouse before making any changes.\n this._releaseMouse();\n\n // Toggle the orientation values.\n this._orientation = value;\n this.dataset['orientation'] = value;\n this.contentNode.setAttribute('aria-orientation', value);\n }\n\n /**\n * Whether the add button is enabled.\n */\n get addButtonEnabled(): boolean {\n return this._addButtonEnabled;\n }\n\n /**\n * Set whether the add button is enabled.\n */\n set addButtonEnabled(value: boolean) {\n // Do nothing if the value does not change.\n if (this._addButtonEnabled === value) {\n return;\n }\n\n this._addButtonEnabled = value;\n if (value) {\n this.addButtonNode.classList.remove('lm-mod-hidden');\n } else {\n this.addButtonNode.classList.add('lm-mod-hidden');\n }\n }\n\n /**\n * A read-only array of the titles in the tab bar.\n */\n get titles(): ReadonlyArray> {\n return this._titles;\n }\n\n /**\n * The tab bar content node.\n *\n * #### Notes\n * This is the node which holds the tab nodes.\n *\n * Modifying this node directly can lead to undefined behavior.\n */\n get contentNode(): HTMLUListElement {\n return this.node.getElementsByClassName(\n 'lm-TabBar-content'\n )[0] as HTMLUListElement;\n }\n\n /**\n * The tab bar add button node.\n *\n * #### Notes\n * This is the node which holds the add button.\n *\n * Modifying this node directly can lead to undefined behavior.\n */\n get addButtonNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-TabBar-addButton'\n )[0] as HTMLDivElement;\n }\n\n /**\n * Add a tab to the end of the tab bar.\n *\n * @param value - The title which holds the data for the tab,\n * or an options object to convert to a title.\n *\n * @returns The title object added to the tab bar.\n *\n * #### Notes\n * If the title is already added to the tab bar, it will be moved.\n */\n addTab(value: Title | Title.IOptions): Title {\n return this.insertTab(this._titles.length, value);\n }\n\n /**\n * Insert a tab into the tab bar at the specified index.\n *\n * @param index - The index at which to insert the tab.\n *\n * @param value - The title which holds the data for the tab,\n * or an options object to convert to a title.\n *\n * @returns The title object added to the tab bar.\n *\n * #### Notes\n * The index will be clamped to the bounds of the tabs.\n *\n * If the title is already added to the tab bar, it will be moved.\n */\n insertTab(index: number, value: Title | Title.IOptions): Title {\n // Release the mouse before making any changes.\n this._releaseMouse();\n\n // Coerce the value to a title.\n let title = Private.asTitle(value);\n\n // Look up the index of the title.\n let i = this._titles.indexOf(title);\n\n // Clamp the insert index to the array bounds.\n let j = Math.max(0, Math.min(index, this._titles.length));\n\n // If the title is not in the array, insert it.\n if (i === -1) {\n // Insert the title into the array.\n ArrayExt.insert(this._titles, j, title);\n\n // Connect to the title changed signal.\n title.changed.connect(this._onTitleChanged, this);\n\n // Schedule an update of the tabs.\n this.update();\n\n // Adjust the current index for the insert.\n this._adjustCurrentForInsert(j, title);\n\n // Return the title added to the tab bar.\n return title;\n }\n\n // Otherwise, the title exists in the array and should be moved.\n\n // Adjust the index if the location is at the end of the array.\n if (j === this._titles.length) {\n j--;\n }\n\n // Bail if there is no effective move.\n if (i === j) {\n return title;\n }\n\n // Move the title to the new location.\n ArrayExt.move(this._titles, i, j);\n\n // Schedule an update of the tabs.\n this.update();\n\n // Adjust the current index for the move.\n this._adjustCurrentForMove(i, j);\n\n // Return the title added to the tab bar.\n return title;\n }\n\n /**\n * Remove a tab from the tab bar.\n *\n * @param title - The title for the tab to remove.\n *\n * #### Notes\n * This is a no-op if the title is not in the tab bar.\n */\n removeTab(title: Title): void {\n this.removeTabAt(this._titles.indexOf(title));\n }\n\n /**\n * Remove the tab at a given index from the tab bar.\n *\n * @param index - The index of the tab to remove.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n removeTabAt(index: number): void {\n // Release the mouse before making any changes.\n this._releaseMouse();\n\n // Remove the title from the array.\n let title = ArrayExt.removeAt(this._titles, index);\n\n // Bail if the index is out of range.\n if (!title) {\n return;\n }\n\n // Disconnect from the title changed signal.\n title.changed.disconnect(this._onTitleChanged, this);\n\n // Clear the previous title if it's being removed.\n if (title === this._previousTitle) {\n this._previousTitle = null;\n }\n\n // Schedule an update of the tabs.\n this.update();\n\n // Adjust the current index for the remove.\n this._adjustCurrentForRemove(index, title);\n }\n\n /**\n * Remove all tabs from the tab bar.\n */\n clearTabs(): void {\n // Bail if there is nothing to remove.\n if (this._titles.length === 0) {\n return;\n }\n\n // Release the mouse before making any changes.\n this._releaseMouse();\n\n // Disconnect from the title changed signals.\n for (let title of this._titles) {\n title.changed.disconnect(this._onTitleChanged, this);\n }\n\n // Get the current index and title.\n let pi = this.currentIndex;\n let pt = this.currentTitle;\n\n // Reset the current index and previous title.\n this._currentIndex = -1;\n this._previousTitle = null;\n\n // Clear the title array.\n this._titles.length = 0;\n\n // Schedule an update of the tabs.\n this.update();\n\n // If no tab was selected, there's nothing else to do.\n if (pi === -1) {\n return;\n }\n\n // Emit the current changed signal.\n this._currentChanged.emit({\n previousIndex: pi,\n previousTitle: pt,\n currentIndex: -1,\n currentTitle: null\n });\n }\n\n /**\n * Release the mouse and restore the non-dragged tab positions.\n *\n * #### Notes\n * This will cause the tab bar to stop handling mouse events and to\n * restore the tabs to their non-dragged positions.\n */\n releaseMouse(): void {\n this._releaseMouse();\n }\n\n /**\n * Handle the DOM events for the tab bar.\n *\n * @param event - The DOM event sent to the tab bar.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the tab bar's DOM node.\n *\n * This should not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'pointerdown':\n this._evtPointerDown(event as PointerEvent);\n break;\n case 'pointermove':\n this._evtPointerMove(event as PointerEvent);\n break;\n case 'pointerup':\n this._evtPointerUp(event as PointerEvent);\n break;\n case 'dblclick':\n this._evtDblClick(event as MouseEvent);\n break;\n case 'keydown':\n event.eventPhase === Event.CAPTURING_PHASE\n ? this._evtKeyDownCapturing(event as KeyboardEvent)\n : this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('pointerdown', this);\n this.node.addEventListener('dblclick', this);\n this.node.addEventListener('keydown', this);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('pointerdown', this);\n this.node.removeEventListener('dblclick', this);\n this.node.removeEventListener('keydown', this);\n this._releaseMouse();\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n let titles = this._titles;\n let renderer = this.renderer;\n let currentTitle = this.currentTitle;\n let content = new Array(titles.length);\n // Keep the tabindex=\"0\" attribute to the tab which handled it before the update.\n // If the add button handles it, no need to do anything. If no element of the tab\n // bar handles it, set it on the current or the first tab to ensure one element\n // handles it after update.\n const tabHandlingTabindex =\n this._getCurrentTabindex() ??\n (this._currentIndex > -1 ? this._currentIndex : 0);\n\n for (let i = 0, n = titles.length; i < n; ++i) {\n let title = titles[i];\n let current = title === currentTitle;\n let zIndex = current ? n : n - i - 1;\n let tabIndex = tabHandlingTabindex === i ? 0 : -1;\n content[i] = renderer.renderTab({ title, current, zIndex, tabIndex });\n }\n VirtualDOM.render(content, this.contentNode);\n }\n\n /**\n * Get the index of the tab which handles tabindex=\"0\".\n * If the add button handles tabindex=\"0\", -1 is returned.\n * If none of the previous handles tabindex=\"0\", null is returned.\n */\n private _getCurrentTabindex(): number | null {\n let index = null;\n const elemTabindex = this.contentNode.querySelector('li[tabindex=\"0\"]');\n if (elemTabindex) {\n index = [...this.contentNode.children].indexOf(elemTabindex);\n } else if (\n this._addButtonEnabled &&\n this.addButtonNode.getAttribute('tabindex') === '0'\n ) {\n index = -1;\n }\n return index;\n }\n\n /**\n * Handle the `'dblclick'` event for the tab bar.\n */\n private _evtDblClick(event: MouseEvent): void {\n // Do nothing if titles are not editable\n if (!this.titlesEditable) {\n return;\n }\n\n let tabs = this.contentNode.children;\n\n // Find the index of the targeted tab.\n let index = ArrayExt.findFirstIndex(tabs, tab => {\n return ElementExt.hitTest(tab, event.clientX, event.clientY);\n });\n\n // Do nothing if the press is not on a tab.\n if (index === -1) {\n return;\n }\n\n let title = this.titles[index];\n let label = tabs[index].querySelector('.lm-TabBar-tabLabel') as HTMLElement;\n if (label && label.contains(event.target as HTMLElement)) {\n let value = title.label || '';\n\n // Clear the label element\n let oldValue = label.innerHTML;\n label.innerHTML = '';\n\n let input = document.createElement('input');\n input.classList.add('lm-TabBar-tabInput');\n input.value = value;\n label.appendChild(input);\n\n let onblur = () => {\n input.removeEventListener('blur', onblur);\n label.innerHTML = oldValue;\n this.node.addEventListener('keydown', this);\n };\n\n input.addEventListener('dblclick', (event: Event) =>\n event.stopPropagation()\n );\n input.addEventListener('blur', onblur);\n input.addEventListener('keydown', (event: KeyboardEvent) => {\n if (event.key === 'Enter') {\n if (input.value !== '') {\n title.label = title.caption = input.value;\n }\n onblur();\n } else if (event.key === 'Escape') {\n onblur();\n }\n });\n this.node.removeEventListener('keydown', this);\n input.select();\n input.focus();\n\n if (label.children.length > 0) {\n (label.children[0] as HTMLElement).focus();\n }\n }\n }\n\n /**\n * Handle the `'keydown'` event for the tab bar at capturing phase.\n */\n private _evtKeyDownCapturing(event: KeyboardEvent): void {\n if (event.eventPhase !== Event.CAPTURING_PHASE) {\n return;\n }\n\n // Stop all input events during drag.\n event.preventDefault();\n event.stopPropagation();\n\n // Release the mouse if `Escape` is pressed.\n if (event.key === 'Escape') {\n this._releaseMouse();\n }\n }\n\n /**\n * Handle the `'keydown'` event for the tab bar at target phase.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // Allow for navigation using tab key\n if (event.key === 'Tab' || event.eventPhase === Event.CAPTURING_PHASE) {\n return;\n }\n\n // Check if Enter or Spacebar key has been pressed and open that tab\n if (\n event.key === 'Enter' ||\n event.key === 'Spacebar' ||\n event.key === ' '\n ) {\n // Get focus element that is in focus by the tab key\n const focusedElement = document.activeElement;\n\n // Test first if the focus is on the add button node\n if (\n this.addButtonEnabled &&\n this.addButtonNode.contains(focusedElement)\n ) {\n event.preventDefault();\n event.stopPropagation();\n this._addRequested.emit();\n } else {\n const index = ArrayExt.findFirstIndex(this.contentNode.children, tab =>\n tab.contains(focusedElement)\n );\n if (index >= 0) {\n event.preventDefault();\n event.stopPropagation();\n this.currentIndex = index;\n }\n }\n // Handle the arrow keys to switch tabs.\n } else if (ARROW_KEYS.includes(event.key)) {\n // Create a list of all focusable elements in the tab bar.\n const focusable: Element[] = [...this.contentNode.children];\n if (this.addButtonEnabled) {\n focusable.push(this.addButtonNode);\n }\n // If the tab bar contains only one element, nothing to do.\n if (focusable.length <= 1) {\n return;\n }\n event.preventDefault();\n event.stopPropagation();\n\n // Get the current focused element.\n let focusedIndex = focusable.indexOf(document.activeElement as Element);\n if (focusedIndex === -1) {\n focusedIndex = this._currentIndex;\n }\n\n // Find the next element to focus on.\n let nextFocused: Element | null | undefined;\n if (\n (event.key === 'ArrowRight' && this._orientation === 'horizontal') ||\n (event.key === 'ArrowDown' && this._orientation === 'vertical')\n ) {\n nextFocused = focusable[focusedIndex + 1] ?? focusable[0];\n } else if (\n (event.key === 'ArrowLeft' && this._orientation === 'horizontal') ||\n (event.key === 'ArrowUp' && this._orientation === 'vertical')\n ) {\n nextFocused =\n focusable[focusedIndex - 1] ?? focusable[focusable.length - 1];\n } else if (event.key === 'Home') {\n nextFocused = focusable[0];\n } else if (event.key === 'End') {\n nextFocused = focusable[focusable.length - 1];\n }\n\n // Change the focused element and the tabindex value.\n if (nextFocused) {\n focusable[focusedIndex]?.setAttribute('tabindex', '-1');\n nextFocused?.setAttribute('tabindex', '0');\n (nextFocused as HTMLElement).focus();\n }\n }\n }\n\n /**\n * Handle the `'pointerdown'` event for the tab bar.\n */\n private _evtPointerDown(event: PointerEvent | MouseEvent): void {\n // Do nothing if it's not a left or middle mouse press.\n if (event.button !== 0 && event.button !== 1) {\n return;\n }\n\n // Do nothing if a drag is in progress.\n if (this._dragData) {\n return;\n }\n\n // Do nothing if a title editable input was clicked.\n if (\n (event.target as HTMLElement).classList.contains('lm-TabBar-tabInput')\n ) {\n return;\n }\n\n // Check if the add button was clicked.\n let addButtonClicked =\n this.addButtonEnabled &&\n this.addButtonNode.contains(event.target as HTMLElement);\n\n // Lookup the tab nodes.\n let tabs = this.contentNode.children;\n\n // Find the index of the pressed tab.\n let index = ArrayExt.findFirstIndex(tabs, tab => {\n return ElementExt.hitTest(tab, event.clientX, event.clientY);\n });\n\n // Do nothing if the press is not on a tab or the add button.\n if (index === -1 && !addButtonClicked) {\n return;\n }\n\n // Pressing on a tab stops the event propagation.\n event.preventDefault();\n event.stopPropagation();\n\n // Initialize the non-measured parts of the drag data.\n this._dragData = {\n tab: tabs[index] as HTMLElement,\n index: index,\n pressX: event.clientX,\n pressY: event.clientY,\n tabPos: -1,\n tabSize: -1,\n tabPressPos: -1,\n targetIndex: -1,\n tabLayout: null,\n contentRect: null,\n override: null,\n dragActive: false,\n dragAborted: false,\n detachRequested: false\n };\n\n // Add the document pointer up listener.\n this.document.addEventListener('pointerup', this, true);\n\n // Do nothing else if the middle button or add button is clicked.\n if (event.button === 1 || addButtonClicked) {\n return;\n }\n\n // Do nothing else if the close icon is clicked.\n let icon = tabs[index].querySelector(this.renderer.closeIconSelector);\n if (icon && icon.contains(event.target as HTMLElement)) {\n return;\n }\n\n // Add the extra listeners if the tabs are movable.\n if (this.tabsMovable) {\n this.document.addEventListener('pointermove', this, true);\n this.document.addEventListener('keydown', this, true);\n this.document.addEventListener('contextmenu', this, true);\n }\n\n // Update the current index as appropriate.\n if (this.allowDeselect && this.currentIndex === index) {\n this.currentIndex = -1;\n } else {\n this.currentIndex = index;\n }\n\n // Do nothing else if there is no current tab.\n if (this.currentIndex === -1) {\n return;\n }\n\n // Emit the tab activate request signal.\n this._tabActivateRequested.emit({\n index: this.currentIndex,\n title: this.currentTitle!\n });\n }\n\n /**\n * Handle the `'pointermove'` event for the tab bar.\n */\n private _evtPointerMove(event: PointerEvent | MouseEvent): void {\n // Do nothing if no drag is in progress.\n let data = this._dragData;\n if (!data) {\n return;\n }\n\n // Suppress the event during a drag.\n event.preventDefault();\n event.stopPropagation();\n\n // Lookup the tab nodes.\n let tabs = this.contentNode.children;\n\n // Bail early if the drag threshold has not been met.\n if (!data.dragActive && !Private.dragExceeded(data, event)) {\n return;\n }\n\n // Activate the drag if necessary.\n if (!data.dragActive) {\n // Fill in the rest of the drag data measurements.\n let tabRect = data.tab.getBoundingClientRect();\n if (this._orientation === 'horizontal') {\n data.tabPos = data.tab.offsetLeft;\n data.tabSize = tabRect.width;\n data.tabPressPos = data.pressX - tabRect.left;\n } else {\n data.tabPos = data.tab.offsetTop;\n data.tabSize = tabRect.height;\n data.tabPressPos = data.pressY - tabRect.top;\n }\n data.tabPressOffset = {\n x: data.pressX - tabRect.left,\n y: data.pressY - tabRect.top\n };\n data.tabLayout = Private.snapTabLayout(tabs, this._orientation);\n data.contentRect = this.contentNode.getBoundingClientRect();\n data.override = Drag.overrideCursor('default');\n\n // Add the dragging style classes.\n data.tab.classList.add('lm-mod-dragging');\n this.addClass('lm-mod-dragging');\n\n // Mark the drag as active.\n data.dragActive = true;\n }\n\n // Emit the detach requested signal if the threshold is exceeded.\n if (!data.detachRequested && Private.detachExceeded(data, event)) {\n // Only emit the signal once per drag cycle.\n data.detachRequested = true;\n\n // Setup the arguments for the signal.\n let index = data.index;\n let clientX = event.clientX;\n let clientY = event.clientY;\n let tab = tabs[index] as HTMLElement;\n let title = this._titles[index];\n\n // Emit the tab detach requested signal.\n this._tabDetachRequested.emit({\n index,\n title,\n tab,\n clientX,\n clientY,\n offset: data.tabPressOffset\n });\n\n // Bail if the signal handler aborted the drag.\n if (data.dragAborted) {\n return;\n }\n }\n\n // Update the positions of the tabs.\n Private.layoutTabs(tabs, data, event, this._orientation);\n }\n\n /**\n * Handle the `'pointerup'` event for the document.\n */\n private _evtPointerUp(event: PointerEvent | MouseEvent): void {\n // Do nothing if it's not a left or middle mouse release.\n if (event.button !== 0 && event.button !== 1) {\n return;\n }\n\n // Do nothing if no drag is in progress.\n const data = this._dragData;\n if (!data) {\n return;\n }\n\n // Stop the event propagation.\n event.preventDefault();\n event.stopPropagation();\n\n // Remove the extra mouse event listeners.\n this.document.removeEventListener('pointermove', this, true);\n this.document.removeEventListener('pointerup', this, true);\n this.document.removeEventListener('keydown', this, true);\n this.document.removeEventListener('contextmenu', this, true);\n\n // Handle a release when the drag is not active.\n if (!data.dragActive) {\n // Clear the drag data.\n this._dragData = null;\n\n // Handle clicking the add button.\n let addButtonClicked =\n this.addButtonEnabled &&\n this.addButtonNode.contains(event.target as HTMLElement);\n if (addButtonClicked) {\n this._addRequested.emit(undefined);\n return;\n }\n\n // Lookup the tab nodes.\n let tabs = this.contentNode.children;\n\n // Find the index of the released tab.\n let index = ArrayExt.findFirstIndex(tabs, tab => {\n return ElementExt.hitTest(tab, event.clientX, event.clientY);\n });\n\n // Do nothing if the release is not on the original pressed tab.\n if (index !== data.index) {\n return;\n }\n\n // Ignore the release if the title is not closable.\n let title = this._titles[index];\n if (!title.closable) {\n return;\n }\n\n // Emit the close requested signal if the middle button is released.\n if (event.button === 1) {\n this._tabCloseRequested.emit({ index, title });\n return;\n }\n\n // Emit the close requested signal if the close icon was released.\n let icon = tabs[index].querySelector(this.renderer.closeIconSelector);\n if (icon && icon.contains(event.target as HTMLElement)) {\n this._tabCloseRequested.emit({ index, title });\n return;\n }\n\n // Otherwise, there is nothing left to do.\n return;\n }\n\n // Do nothing if the left button is not released.\n if (event.button !== 0) {\n return;\n }\n\n // Position the tab at its final resting position.\n Private.finalizeTabPosition(data, this._orientation);\n\n // Remove the dragging class from the tab so it can be transitioned.\n data.tab.classList.remove('lm-mod-dragging');\n\n // Parse the transition duration for releasing the tab.\n let duration = Private.parseTransitionDuration(data.tab);\n\n // Complete the release on a timer to allow the tab to transition.\n setTimeout(() => {\n // Do nothing if the drag has been aborted.\n if (data.dragAborted) {\n return;\n }\n\n // Clear the drag data reference.\n this._dragData = null;\n\n // Reset the positions of the tabs.\n Private.resetTabPositions(this.contentNode.children, this._orientation);\n\n // Clear the cursor grab.\n data.override!.dispose();\n\n // Remove the remaining dragging style.\n this.removeClass('lm-mod-dragging');\n\n // If the tab was not moved, there is nothing else to do.\n let i = data.index;\n let j = data.targetIndex;\n if (j === -1 || i === j) {\n return;\n }\n\n // Move the title to the new locations.\n ArrayExt.move(this._titles, i, j);\n\n // Adjust the current index for the move.\n this._adjustCurrentForMove(i, j);\n\n // Emit the tab moved signal.\n this._tabMoved.emit({\n fromIndex: i,\n toIndex: j,\n title: this._titles[j]\n });\n\n // Update the tabs immediately to prevent flicker.\n MessageLoop.sendMessage(this, Widget.Msg.UpdateRequest);\n }, duration);\n }\n\n /**\n * Release the mouse and restore the non-dragged tab positions.\n */\n private _releaseMouse(): void {\n // Do nothing if no drag is in progress.\n let data = this._dragData;\n if (!data) {\n return;\n }\n\n // Clear the drag data reference.\n this._dragData = null;\n\n // Remove the extra document event listeners.\n this.document.removeEventListener('pointermove', this, true);\n this.document.removeEventListener('pointerup', this, true);\n this.document.removeEventListener('keydown', this, true);\n this.document.removeEventListener('contextmenu', this, true);\n\n // Indicate the drag has been aborted. This allows the mouse\n // event handlers to return early when the drag is canceled.\n data.dragAborted = true;\n\n // If the drag is not active, there's nothing more to do.\n if (!data.dragActive) {\n return;\n }\n\n // Reset the tabs to their non-dragged positions.\n Private.resetTabPositions(this.contentNode.children, this._orientation);\n\n // Clear the cursor override.\n data.override!.dispose();\n\n // Clear the dragging style classes.\n data.tab.classList.remove('lm-mod-dragging');\n this.removeClass('lm-mod-dragging');\n }\n\n /**\n * Adjust the current index for a tab insert operation.\n *\n * This method accounts for the tab bar's insertion behavior when\n * adjusting the current index and emitting the changed signal.\n */\n private _adjustCurrentForInsert(i: number, title: Title): void {\n // Lookup commonly used variables.\n let ct = this.currentTitle;\n let ci = this._currentIndex;\n let bh = this.insertBehavior;\n\n // TODO: do we need to do an update to update the aria-selected attribute?\n\n // Handle the behavior where the new tab is always selected,\n // or the behavior where the new tab is selected if needed.\n if (bh === 'select-tab' || (bh === 'select-tab-if-needed' && ci === -1)) {\n this._currentIndex = i;\n this._previousTitle = ct;\n this._currentChanged.emit({\n previousIndex: ci,\n previousTitle: ct,\n currentIndex: i,\n currentTitle: title\n });\n return;\n }\n\n // Otherwise, silently adjust the current index if needed.\n if (ci >= i) {\n this._currentIndex++;\n }\n }\n\n /**\n * Adjust the current index for a tab move operation.\n *\n * This method will not cause the actual current tab to change.\n * It silently adjusts the index to account for the given move.\n */\n private _adjustCurrentForMove(i: number, j: number): void {\n if (this._currentIndex === i) {\n this._currentIndex = j;\n } else if (this._currentIndex < i && this._currentIndex >= j) {\n this._currentIndex++;\n } else if (this._currentIndex > i && this._currentIndex <= j) {\n this._currentIndex--;\n }\n }\n\n /**\n * Adjust the current index for a tab remove operation.\n *\n * This method accounts for the tab bar's remove behavior when\n * adjusting the current index and emitting the changed signal.\n */\n private _adjustCurrentForRemove(i: number, title: Title): void {\n // Lookup commonly used variables.\n let ci = this._currentIndex;\n let bh = this.removeBehavior;\n\n // Silently adjust the index if the current tab is not removed.\n if (ci !== i) {\n if (ci > i) {\n this._currentIndex--;\n }\n return;\n }\n\n // TODO: do we need to do an update to adjust the aria-selected value?\n\n // No tab gets selected if the tab bar is empty.\n if (this._titles.length === 0) {\n this._currentIndex = -1;\n this._currentChanged.emit({\n previousIndex: i,\n previousTitle: title,\n currentIndex: -1,\n currentTitle: null\n });\n return;\n }\n\n // Handle behavior where the next sibling tab is selected.\n if (bh === 'select-tab-after') {\n this._currentIndex = Math.min(i, this._titles.length - 1);\n this._currentChanged.emit({\n previousIndex: i,\n previousTitle: title,\n currentIndex: this._currentIndex,\n currentTitle: this.currentTitle\n });\n return;\n }\n\n // Handle behavior where the previous sibling tab is selected.\n if (bh === 'select-tab-before') {\n this._currentIndex = Math.max(0, i - 1);\n this._currentChanged.emit({\n previousIndex: i,\n previousTitle: title,\n currentIndex: this._currentIndex,\n currentTitle: this.currentTitle\n });\n return;\n }\n\n // Handle behavior where the previous history tab is selected.\n if (bh === 'select-previous-tab') {\n if (this._previousTitle) {\n this._currentIndex = this._titles.indexOf(this._previousTitle);\n this._previousTitle = null;\n } else {\n this._currentIndex = Math.min(i, this._titles.length - 1);\n }\n this._currentChanged.emit({\n previousIndex: i,\n previousTitle: title,\n currentIndex: this._currentIndex,\n currentTitle: this.currentTitle\n });\n return;\n }\n\n // Otherwise, no tab gets selected.\n this._currentIndex = -1;\n this._currentChanged.emit({\n previousIndex: i,\n previousTitle: title,\n currentIndex: -1,\n currentTitle: null\n });\n }\n\n /**\n * Handle the `changed` signal of a title object.\n */\n private _onTitleChanged(sender: Title): void {\n this.update();\n }\n\n private _name: string;\n private _currentIndex = -1;\n private _titles: Title[] = [];\n private _orientation: TabBar.Orientation;\n private _document: Document | ShadowRoot;\n private _titlesEditable: boolean = false;\n private _previousTitle: Title | null = null;\n private _dragData: Private.IDragData | null = null;\n private _addButtonEnabled: boolean = false;\n private _tabMoved = new Signal>(this);\n private _currentChanged = new Signal>(\n this\n );\n private _addRequested = new Signal(this);\n private _tabCloseRequested = new Signal<\n this,\n TabBar.ITabCloseRequestedArgs\n >(this);\n private _tabDetachRequested = new Signal<\n this,\n TabBar.ITabDetachRequestedArgs\n >(this);\n private _tabActivateRequested = new Signal<\n this,\n TabBar.ITabActivateRequestedArgs\n >(this);\n}\n\n/**\n * The namespace for the `TabBar` class statics.\n */\nexport namespace TabBar {\n /**\n * A type alias for a tab bar orientation.\n */\n export type Orientation =\n | /**\n * The tabs are arranged in a single row, left-to-right.\n *\n * The tab text orientation is horizontal.\n */\n 'horizontal'\n\n /**\n * The tabs are arranged in a single column, top-to-bottom.\n *\n * The tab text orientation is horizontal.\n */\n | 'vertical';\n\n /**\n * A type alias for the selection behavior on tab insert.\n */\n export type InsertBehavior =\n | /**\n * The selected tab will not be changed.\n */\n 'none'\n\n /**\n * The inserted tab will be selected.\n */\n | 'select-tab'\n\n /**\n * The inserted tab will be selected if the current tab is null.\n */\n | 'select-tab-if-needed';\n\n /**\n * A type alias for the selection behavior on tab remove.\n */\n export type RemoveBehavior =\n | /**\n * No tab will be selected.\n */\n 'none'\n\n /**\n * The tab after the removed tab will be selected if possible.\n */\n | 'select-tab-after'\n\n /**\n * The tab before the removed tab will be selected if possible.\n */\n | 'select-tab-before'\n\n /**\n * The previously selected tab will be selected if possible.\n */\n | 'select-previous-tab';\n\n /**\n * An options object for creating a tab bar.\n */\n export interface IOptions {\n /**\n * The document to use with the tab bar.\n *\n * The default is the global `document` instance.\n */\n\n document?: Document | ShadowRoot;\n\n /**\n * Name of the tab bar.\n *\n * This is used for accessibility reasons. The default is the empty string.\n */\n name?: string;\n\n /**\n * The layout orientation of the tab bar.\n *\n * The default is `horizontal`.\n */\n orientation?: TabBar.Orientation;\n\n /**\n * Whether the tabs are movable by the user.\n *\n * The default is `false`.\n */\n tabsMovable?: boolean;\n\n /**\n * Whether a tab can be deselected by the user.\n *\n * The default is `false`.\n */\n allowDeselect?: boolean;\n\n /**\n * Whether the titles can be directly edited by the user.\n *\n * The default is `false`.\n */\n titlesEditable?: boolean;\n\n /**\n * Whether the add button is enabled.\n *\n * The default is `false`.\n */\n addButtonEnabled?: boolean;\n\n /**\n * The selection behavior when inserting a tab.\n *\n * The default is `'select-tab-if-needed'`.\n */\n insertBehavior?: TabBar.InsertBehavior;\n\n /**\n * The selection behavior when removing a tab.\n *\n * The default is `'select-tab-after'`.\n */\n removeBehavior?: TabBar.RemoveBehavior;\n\n /**\n * A renderer to use with the tab bar.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n }\n\n /**\n * The arguments object for the `currentChanged` signal.\n */\n export interface ICurrentChangedArgs {\n /**\n * The previously selected index.\n */\n readonly previousIndex: number;\n\n /**\n * The previously selected title.\n */\n readonly previousTitle: Title | null;\n\n /**\n * The currently selected index.\n */\n readonly currentIndex: number;\n\n /**\n * The currently selected title.\n */\n readonly currentTitle: Title | null;\n }\n\n /**\n * The arguments object for the `tabMoved` signal.\n */\n export interface ITabMovedArgs {\n /**\n * The previous index of the tab.\n */\n readonly fromIndex: number;\n\n /**\n * The current index of the tab.\n */\n readonly toIndex: number;\n\n /**\n * The title for the tab.\n */\n readonly title: Title;\n }\n\n /**\n * The arguments object for the `tabActivateRequested` signal.\n */\n export interface ITabActivateRequestedArgs {\n /**\n * The index of the tab to activate.\n */\n readonly index: number;\n\n /**\n * The title for the tab.\n */\n readonly title: Title;\n }\n\n /**\n * The arguments object for the `tabCloseRequested` signal.\n */\n export interface ITabCloseRequestedArgs {\n /**\n * The index of the tab to close.\n */\n readonly index: number;\n\n /**\n * The title for the tab.\n */\n readonly title: Title;\n }\n\n /**\n * The arguments object for the `tabDetachRequested` signal.\n */\n export interface ITabDetachRequestedArgs {\n /**\n * The index of the tab to detach.\n */\n readonly index: number;\n\n /**\n * The title for the tab.\n */\n readonly title: Title;\n\n /**\n * The node representing the tab.\n */\n readonly tab: HTMLElement;\n\n /**\n * The current client X position of the mouse.\n */\n readonly clientX: number;\n\n /**\n * The current client Y position of the mouse.\n */\n readonly clientY: number;\n\n /**\n * The mouse position in the tab coordinate.\n */\n readonly offset?: { x: number; y: number };\n }\n\n /**\n * An object which holds the data to render a tab.\n */\n export interface IRenderData {\n /**\n * The title associated with the tab.\n */\n readonly title: Title;\n\n /**\n * Whether the tab is the current tab.\n */\n readonly current: boolean;\n\n /**\n * The z-index for the tab.\n */\n readonly zIndex: number;\n\n /**\n * The tabindex value for the tab.\n */\n readonly tabIndex?: number;\n }\n\n /**\n * A renderer for use with a tab bar.\n */\n export interface IRenderer {\n /**\n * A selector which matches the close icon node in a tab.\n */\n readonly closeIconSelector: string;\n\n /**\n * Render the virtual element for a tab.\n *\n * @param data - The data to use for rendering the tab.\n *\n * @returns A virtual element representing the tab.\n */\n renderTab(data: IRenderData): VirtualElement;\n }\n\n /**\n * The default implementation of `IRenderer`.\n *\n * #### Notes\n * Subclasses are free to reimplement rendering methods as needed.\n */\n export class Renderer implements IRenderer {\n constructor() {\n this._uuid = ++Renderer._nInstance;\n }\n /**\n * A selector which matches the close icon node in a tab.\n */\n readonly closeIconSelector = '.lm-TabBar-tabCloseIcon';\n\n /**\n * Render the virtual element for a tab.\n *\n * @param data - The data to use for rendering the tab.\n *\n * @returns A virtual element representing the tab.\n */\n renderTab(data: IRenderData): VirtualElement {\n let title = data.title.caption;\n let key = this.createTabKey(data);\n let id = key;\n let style = this.createTabStyle(data);\n let className = this.createTabClass(data);\n let dataset = this.createTabDataset(data);\n let aria = this.createTabARIA(data);\n if (data.title.closable) {\n return h.li(\n { id, key, className, title, style, dataset, ...aria },\n this.renderIcon(data),\n this.renderLabel(data),\n this.renderCloseIcon(data)\n );\n } else {\n return h.li(\n { id, key, className, title, style, dataset, ...aria },\n this.renderIcon(data),\n this.renderLabel(data)\n );\n }\n }\n\n /**\n * Render the icon element for a tab.\n *\n * @param data - The data to use for rendering the tab.\n *\n * @returns A virtual element representing the tab icon.\n */\n renderIcon(data: IRenderData): VirtualElement {\n const { title } = data;\n let className = this.createIconClass(data);\n\n // If title.icon is undefined, it will be ignored.\n return h.div({ className }, title.icon!, title.iconLabel);\n }\n\n /**\n * Render the label element for a tab.\n *\n * @param data - The data to use for rendering the tab.\n *\n * @returns A virtual element representing the tab label.\n */\n renderLabel(data: IRenderData): VirtualElement {\n return h.div({ className: 'lm-TabBar-tabLabel' }, data.title.label);\n }\n\n /**\n * Render the close icon element for a tab.\n *\n * @param data - The data to use for rendering the tab.\n *\n * @returns A virtual element representing the tab close icon.\n */\n renderCloseIcon(data: IRenderData): VirtualElement {\n return h.div({ className: 'lm-TabBar-tabCloseIcon' });\n }\n\n /**\n * Create a unique render key for the tab.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The unique render key for the tab.\n *\n * #### Notes\n * This method caches the key against the tab title the first time\n * the key is generated. This enables efficient rendering of moved\n * tabs and avoids subtle hover style artifacts.\n */\n createTabKey(data: IRenderData): string {\n let key = this._tabKeys.get(data.title);\n if (key === undefined) {\n key = `tab-key-${this._uuid}-${this._tabID++}`;\n this._tabKeys.set(data.title, key);\n }\n return key;\n }\n\n /**\n * Create the inline style object for a tab.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The inline style data for the tab.\n */\n createTabStyle(data: IRenderData): ElementInlineStyle {\n return { zIndex: `${data.zIndex}` };\n }\n\n /**\n * Create the class name for the tab.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The full class name for the tab.\n */\n createTabClass(data: IRenderData): string {\n let name = 'lm-TabBar-tab';\n if (data.title.className) {\n name += ` ${data.title.className}`;\n }\n if (data.title.closable) {\n name += ' lm-mod-closable';\n }\n if (data.current) {\n name += ' lm-mod-current';\n }\n return name;\n }\n\n /**\n * Create the dataset for a tab.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The dataset for the tab.\n */\n createTabDataset(data: IRenderData): ElementDataset {\n return data.title.dataset;\n }\n\n /**\n * Create the ARIA attributes for a tab.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The ARIA attributes for the tab.\n */\n createTabARIA(data: IRenderData): ElementARIAAttrs | ElementBaseAttrs {\n return {\n role: 'tab',\n 'aria-selected': data.current.toString(),\n tabindex: `${data.tabIndex ?? '-1'}`\n };\n }\n\n /**\n * Create the class name for the tab icon.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The full class name for the tab icon.\n */\n createIconClass(data: IRenderData): string {\n let name = 'lm-TabBar-tabIcon';\n let extra = data.title.iconClass;\n return extra ? `${name} ${extra}` : name;\n }\n\n private static _nInstance = 0;\n private readonly _uuid: number;\n private _tabID = 0;\n private _tabKeys = new WeakMap, string>();\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n\n /**\n * A selector which matches the add button node in the tab bar.\n */\n export const addButtonSelector = '.lm-TabBar-addButton';\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The start drag distance threshold.\n */\n export const DRAG_THRESHOLD = 5;\n\n /**\n * The detach distance threshold.\n */\n export const DETACH_THRESHOLD = 20;\n\n /**\n * A struct which holds the drag data for a tab bar.\n */\n export interface IDragData {\n /**\n * The tab node being dragged.\n */\n tab: HTMLElement;\n\n /**\n * The index of the tab being dragged.\n */\n index: number;\n\n /**\n * The mouse press client X position.\n */\n pressX: number;\n\n /**\n * The mouse press client Y position.\n */\n pressY: number;\n\n /**\n * The offset left/top of the tab being dragged.\n *\n * This will be `-1` if the drag is not active.\n */\n tabPos: number;\n\n /**\n * The offset width/height of the tab being dragged.\n *\n * This will be `-1` if the drag is not active.\n */\n tabSize: number;\n\n /**\n * The original mouse X/Y position in tab coordinates.\n *\n * This will be `-1` if the drag is not active.\n */\n tabPressPos: number;\n\n /**\n * The original mouse position in tab coordinates.\n *\n * This is undefined if the drag is not active.\n */\n tabPressOffset?: { x: number; y: number };\n\n /**\n * The tab target index upon mouse release.\n *\n * This will be `-1` if the drag is not active.\n */\n targetIndex: number;\n\n /**\n * The array of tab layout objects snapped at drag start.\n *\n * This will be `null` if the drag is not active.\n */\n tabLayout: ITabLayout[] | null;\n\n /**\n * The bounding client rect of the tab bar content node.\n *\n * This will be `null` if the drag is not active.\n */\n contentRect: DOMRect | null;\n\n /**\n * The disposable to clean up the cursor override.\n *\n * This will be `null` if the drag is not active.\n */\n override: IDisposable | null;\n\n /**\n * Whether the drag is currently active.\n */\n dragActive: boolean;\n\n /**\n * Whether the drag has been aborted.\n */\n dragAborted: boolean;\n\n /**\n * Whether a detach request as been made.\n */\n detachRequested: boolean;\n }\n\n /**\n * An object which holds layout data for a tab.\n */\n export interface ITabLayout {\n /**\n * The left/top margin value for the tab.\n */\n margin: number;\n\n /**\n * The offset left/top position of the tab.\n */\n pos: number;\n\n /**\n * The offset width/height of the tab.\n */\n size: number;\n }\n\n /**\n * Create the DOM node for a tab bar.\n */\n export function createNode(): HTMLDivElement {\n let node = document.createElement('div');\n let content = document.createElement('ul');\n content.setAttribute('role', 'tablist');\n content.className = 'lm-TabBar-content';\n node.appendChild(content);\n\n let add = document.createElement('div');\n add.className = 'lm-TabBar-addButton lm-mod-hidden';\n add.setAttribute('tabindex', '-1');\n add.setAttribute('role', 'button');\n node.appendChild(add);\n return node;\n }\n\n /**\n * Coerce a title or options into a real title.\n */\n export function asTitle(value: Title | Title.IOptions): Title {\n return value instanceof Title ? value : new Title(value);\n }\n\n /**\n * Parse the transition duration for a tab node.\n */\n export function parseTransitionDuration(tab: HTMLElement): number {\n let style = window.getComputedStyle(tab);\n return 1000 * (parseFloat(style.transitionDuration!) || 0);\n }\n\n /**\n * Get a snapshot of the current tab layout values.\n */\n export function snapTabLayout(\n tabs: HTMLCollection,\n orientation: TabBar.Orientation\n ): ITabLayout[] {\n let layout = new Array(tabs.length);\n for (let i = 0, n = tabs.length; i < n; ++i) {\n let node = tabs[i] as HTMLElement;\n let style = window.getComputedStyle(node);\n if (orientation === 'horizontal') {\n layout[i] = {\n pos: node.offsetLeft,\n size: node.offsetWidth,\n margin: parseFloat(style.marginLeft!) || 0\n };\n } else {\n layout[i] = {\n pos: node.offsetTop,\n size: node.offsetHeight,\n margin: parseFloat(style.marginTop!) || 0\n };\n }\n }\n return layout;\n }\n\n /**\n * Test if the event exceeds the drag threshold.\n */\n export function dragExceeded(data: IDragData, event: MouseEvent): boolean {\n let dx = Math.abs(event.clientX - data.pressX);\n let dy = Math.abs(event.clientY - data.pressY);\n return dx >= DRAG_THRESHOLD || dy >= DRAG_THRESHOLD;\n }\n\n /**\n * Test if the event exceeds the drag detach threshold.\n */\n export function detachExceeded(data: IDragData, event: MouseEvent): boolean {\n let rect = data.contentRect!;\n return (\n event.clientX < rect.left - DETACH_THRESHOLD ||\n event.clientX >= rect.right + DETACH_THRESHOLD ||\n event.clientY < rect.top - DETACH_THRESHOLD ||\n event.clientY >= rect.bottom + DETACH_THRESHOLD\n );\n }\n\n /**\n * Update the relative tab positions and computed target index.\n */\n export function layoutTabs(\n tabs: HTMLCollection,\n data: IDragData,\n event: MouseEvent,\n orientation: TabBar.Orientation\n ): void {\n // Compute the orientation-sensitive values.\n let pressPos: number;\n let localPos: number;\n let clientPos: number;\n let clientSize: number;\n if (orientation === 'horizontal') {\n pressPos = data.pressX;\n localPos = event.clientX - data.contentRect!.left;\n clientPos = event.clientX;\n clientSize = data.contentRect!.width;\n } else {\n pressPos = data.pressY;\n localPos = event.clientY - data.contentRect!.top;\n clientPos = event.clientY;\n clientSize = data.contentRect!.height;\n }\n\n // Compute the target data.\n let targetIndex = data.index;\n let targetPos = localPos - data.tabPressPos;\n let targetEnd = targetPos + data.tabSize;\n\n // Update the relative tab positions.\n for (let i = 0, n = tabs.length; i < n; ++i) {\n let pxPos: string;\n let layout = data.tabLayout![i];\n let threshold = layout.pos + (layout.size >> 1);\n if (i < data.index && targetPos < threshold) {\n pxPos = `${data.tabSize + data.tabLayout![i + 1].margin}px`;\n targetIndex = Math.min(targetIndex, i);\n } else if (i > data.index && targetEnd > threshold) {\n pxPos = `${-data.tabSize - layout.margin}px`;\n targetIndex = Math.max(targetIndex, i);\n } else if (i === data.index) {\n let ideal = clientPos - pressPos;\n let limit = clientSize - (data.tabPos + data.tabSize);\n pxPos = `${Math.max(-data.tabPos, Math.min(ideal, limit))}px`;\n } else {\n pxPos = '';\n }\n if (orientation === 'horizontal') {\n (tabs[i] as HTMLElement).style.left = pxPos;\n } else {\n (tabs[i] as HTMLElement).style.top = pxPos;\n }\n }\n\n // Update the computed target index.\n data.targetIndex = targetIndex;\n }\n\n /**\n * Position the drag tab at its final resting relative position.\n */\n export function finalizeTabPosition(\n data: IDragData,\n orientation: TabBar.Orientation\n ): void {\n // Compute the orientation-sensitive client size.\n let clientSize: number;\n if (orientation === 'horizontal') {\n clientSize = data.contentRect!.width;\n } else {\n clientSize = data.contentRect!.height;\n }\n\n // Compute the ideal final tab position.\n let ideal: number;\n if (data.targetIndex === data.index) {\n ideal = 0;\n } else if (data.targetIndex > data.index) {\n let tgt = data.tabLayout![data.targetIndex];\n ideal = tgt.pos + tgt.size - data.tabSize - data.tabPos;\n } else {\n let tgt = data.tabLayout![data.targetIndex];\n ideal = tgt.pos - data.tabPos;\n }\n\n // Compute the tab position limit.\n let limit = clientSize - (data.tabPos + data.tabSize);\n let final = Math.max(-data.tabPos, Math.min(ideal, limit));\n\n // Set the final orientation-sensitive position.\n if (orientation === 'horizontal') {\n data.tab.style.left = `${final}px`;\n } else {\n data.tab.style.top = `${final}px`;\n }\n }\n\n /**\n * Reset the relative positions of the given tabs.\n */\n export function resetTabPositions(\n tabs: HTMLCollection,\n orientation: TabBar.Orientation\n ): void {\n for (const tab of tabs) {\n if (orientation === 'horizontal') {\n (tab as HTMLElement).style.left = '';\n } else {\n (tab as HTMLElement).style.top = '';\n }\n }\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt, empty } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { BoxEngine, BoxSizer } from './boxengine';\n\nimport { Layout, LayoutItem } from './layout';\n\nimport { TabBar } from './tabbar';\n\nimport Utils from './utils';\n\nimport { Widget } from './widget';\n\n/**\n * A layout which provides a flexible docking arrangement.\n *\n * #### Notes\n * The consumer of this layout is responsible for handling all signals\n * from the generated tab bars and managing the visibility of widgets\n * and tab bars as needed.\n */\nexport class DockLayout extends Layout {\n /**\n * Construct a new dock layout.\n *\n * @param options - The options for initializing the layout.\n */\n constructor(options: DockLayout.IOptions) {\n super();\n this.renderer = options.renderer;\n if (options.spacing !== undefined) {\n this._spacing = Utils.clampDimension(options.spacing);\n }\n this._document = options.document || document;\n this._hiddenMode =\n options.hiddenMode !== undefined\n ? options.hiddenMode\n : Widget.HiddenMode.Display;\n }\n\n /**\n * Dispose of the resources held by the layout.\n *\n * #### Notes\n * This will clear and dispose all widgets in the layout.\n */\n dispose(): void {\n // Get an iterator over the widgets in the layout.\n let widgets = this[Symbol.iterator]();\n\n // Dispose of the layout items.\n this._items.forEach(item => {\n item.dispose();\n });\n\n // Clear the layout state before disposing the widgets.\n this._box = null;\n this._root = null;\n this._items.clear();\n\n // Dispose of the widgets contained in the old layout root.\n for (const widget of widgets) {\n widget.dispose();\n }\n\n // Dispose of the base class.\n super.dispose();\n }\n\n /**\n * The renderer used by the dock layout.\n */\n readonly renderer: DockLayout.IRenderer;\n\n /**\n * The method for hiding child widgets.\n *\n * #### Notes\n * If there is only one child widget, `Display` hiding mode will be used\n * regardless of this setting.\n */\n get hiddenMode(): Widget.HiddenMode {\n return this._hiddenMode;\n }\n set hiddenMode(v: Widget.HiddenMode) {\n if (this._hiddenMode === v) {\n return;\n }\n this._hiddenMode = v;\n for (const bar of this.tabBars()) {\n if (bar.titles.length > 1) {\n for (const title of bar.titles) {\n title.owner.hiddenMode = this._hiddenMode;\n }\n }\n }\n }\n\n /**\n * Get the inter-element spacing for the dock layout.\n */\n get spacing(): number {\n return this._spacing;\n }\n\n /**\n * Set the inter-element spacing for the dock layout.\n */\n set spacing(value: number) {\n value = Utils.clampDimension(value);\n if (this._spacing === value) {\n return;\n }\n this._spacing = value;\n if (!this.parent) {\n return;\n }\n this.parent.fit();\n }\n\n /**\n * Whether the dock layout is empty.\n */\n get isEmpty(): boolean {\n return this._root === null;\n }\n\n /**\n * Create an iterator over all widgets in the layout.\n *\n * @returns A new iterator over the widgets in the layout.\n *\n * #### Notes\n * This iterator includes the generated tab bars.\n */\n [Symbol.iterator](): IterableIterator {\n return this._root ? this._root.iterAllWidgets() : empty();\n }\n\n /**\n * Create an iterator over the user widgets in the layout.\n *\n * @returns A new iterator over the user widgets in the layout.\n *\n * #### Notes\n * This iterator does not include the generated tab bars.\n */\n widgets(): IterableIterator {\n return this._root ? this._root.iterUserWidgets() : empty();\n }\n\n /**\n * Create an iterator over the selected widgets in the layout.\n *\n * @returns A new iterator over the selected user widgets.\n *\n * #### Notes\n * This iterator yields the widgets corresponding to the current tab\n * of each tab bar in the layout.\n */\n selectedWidgets(): IterableIterator {\n return this._root ? this._root.iterSelectedWidgets() : empty();\n }\n\n /**\n * Create an iterator over the tab bars in the layout.\n *\n * @returns A new iterator over the tab bars in the layout.\n *\n * #### Notes\n * This iterator does not include the user widgets.\n */\n tabBars(): IterableIterator> {\n return this._root ? this._root.iterTabBars() : empty();\n }\n\n /**\n * Create an iterator over the handles in the layout.\n *\n * @returns A new iterator over the handles in the layout.\n */\n handles(): IterableIterator {\n return this._root ? this._root.iterHandles() : empty();\n }\n\n /**\n * Move a handle to the given offset position.\n *\n * @param handle - The handle to move.\n *\n * @param offsetX - The desired offset X position of the handle.\n *\n * @param offsetY - The desired offset Y position of the handle.\n *\n * #### Notes\n * If the given handle is not contained in the layout, this is no-op.\n *\n * The handle will be moved as close as possible to the desired\n * position without violating any of the layout constraints.\n *\n * Only one of the coordinates is used depending on the orientation\n * of the handle. This method accepts both coordinates to make it\n * easy to invoke from a mouse move event without needing to know\n * the handle orientation.\n */\n moveHandle(handle: HTMLDivElement, offsetX: number, offsetY: number): void {\n // Bail early if there is no root or if the handle is hidden.\n let hidden = handle.classList.contains('lm-mod-hidden');\n if (!this._root || hidden) {\n return;\n }\n\n // Lookup the split node for the handle.\n let data = this._root.findSplitNode(handle);\n if (!data) {\n return;\n }\n\n // Compute the desired delta movement for the handle.\n let delta: number;\n if (data.node.orientation === 'horizontal') {\n delta = offsetX - handle.offsetLeft;\n } else {\n delta = offsetY - handle.offsetTop;\n }\n\n // Bail if there is no handle movement.\n if (delta === 0) {\n return;\n }\n\n // Prevent sibling resizing unless needed.\n data.node.holdSizes();\n\n // Adjust the sizers to reflect the handle movement.\n BoxEngine.adjust(data.node.sizers, data.index, delta);\n\n // Update the layout of the widgets.\n if (this.parent) {\n this.parent.update();\n }\n }\n\n /**\n * Save the current configuration of the dock layout.\n *\n * @returns A new config object for the current layout state.\n *\n * #### Notes\n * The return value can be provided to the `restoreLayout` method\n * in order to restore the layout to its current configuration.\n */\n saveLayout(): DockLayout.ILayoutConfig {\n // Bail early if there is no root.\n if (!this._root) {\n return { main: null };\n }\n\n // Hold the current sizes in the layout tree.\n this._root.holdAllSizes();\n\n // Return the layout config.\n return { main: this._root.createConfig() };\n }\n\n /**\n * Restore the layout to a previously saved configuration.\n *\n * @param config - The layout configuration to restore.\n *\n * #### Notes\n * Widgets which currently belong to the layout but which are not\n * contained in the config will be unparented.\n */\n restoreLayout(config: DockLayout.ILayoutConfig): void {\n // Create the widget set for validating the config.\n let widgetSet = new Set();\n\n // Normalize the main area config and collect the widgets.\n let mainConfig: DockLayout.AreaConfig | null;\n if (config.main) {\n mainConfig = Private.normalizeAreaConfig(config.main, widgetSet);\n } else {\n mainConfig = null;\n }\n\n // Create iterators over the old content.\n let oldWidgets = this.widgets();\n let oldTabBars = this.tabBars();\n let oldHandles = this.handles();\n\n // Clear the root before removing the old content.\n this._root = null;\n\n // Unparent the old widgets which are not in the new config.\n for (const widget of oldWidgets) {\n if (!widgetSet.has(widget)) {\n widget.parent = null;\n }\n }\n\n // Dispose of the old tab bars.\n for (const tabBar of oldTabBars) {\n tabBar.dispose();\n }\n\n // Remove the old handles.\n for (const handle of oldHandles) {\n if (handle.parentNode) {\n handle.parentNode.removeChild(handle);\n }\n }\n\n // Reparent the new widgets to the current parent.\n for (const widget of widgetSet) {\n widget.parent = this.parent;\n }\n\n // Create the root node for the new config.\n if (mainConfig) {\n this._root = Private.realizeAreaConfig(\n mainConfig,\n {\n // Ignoring optional `document` argument as we must reuse `this._document`\n createTabBar: (document?: Document | ShadowRoot) =>\n this._createTabBar(),\n createHandle: () => this._createHandle()\n },\n this._document\n );\n } else {\n this._root = null;\n }\n\n // If there is no parent, there is nothing more to do.\n if (!this.parent) {\n return;\n }\n\n // Attach the new widgets to the parent.\n widgetSet.forEach(widget => {\n this.attachWidget(widget);\n });\n\n // Post a fit request to the parent.\n this.parent.fit();\n }\n\n /**\n * Add a widget to the dock layout.\n *\n * @param widget - The widget to add to the dock layout.\n *\n * @param options - The additional options for adding the widget.\n *\n * #### Notes\n * The widget will be moved if it is already contained in the layout.\n *\n * An error will be thrown if the reference widget is invalid.\n */\n addWidget(widget: Widget, options: DockLayout.IAddOptions = {}): void {\n // Parse the options.\n let ref = options.ref || null;\n let mode = options.mode || 'tab-after';\n\n // Find the tab node which holds the reference widget.\n let refNode: Private.TabLayoutNode | null = null;\n if (this._root && ref) {\n refNode = this._root.findTabNode(ref);\n }\n\n // Throw an error if the reference widget is invalid.\n if (ref && !refNode) {\n throw new Error('Reference widget is not in the layout.');\n }\n\n // Reparent the widget to the current layout parent.\n widget.parent = this.parent;\n\n // Insert the widget according to the insert mode.\n switch (mode) {\n case 'tab-after':\n this._insertTab(widget, ref, refNode, true);\n break;\n case 'tab-before':\n this._insertTab(widget, ref, refNode, false);\n break;\n case 'split-top':\n this._insertSplit(widget, ref, refNode, 'vertical', false);\n break;\n case 'split-left':\n this._insertSplit(widget, ref, refNode, 'horizontal', false);\n break;\n case 'split-right':\n this._insertSplit(widget, ref, refNode, 'horizontal', true);\n break;\n case 'split-bottom':\n this._insertSplit(widget, ref, refNode, 'vertical', true);\n break;\n case 'merge-top':\n this._insertSplit(widget, ref, refNode, 'vertical', false, true);\n break;\n case 'merge-left':\n this._insertSplit(widget, ref, refNode, 'horizontal', false, true);\n break;\n case 'merge-right':\n this._insertSplit(widget, ref, refNode, 'horizontal', true, true);\n break;\n case 'merge-bottom':\n this._insertSplit(widget, ref, refNode, 'vertical', true, true);\n break;\n }\n\n // Do nothing else if there is no parent widget.\n if (!this.parent) {\n return;\n }\n\n // Ensure the widget is attached to the parent widget.\n this.attachWidget(widget);\n\n // Post a fit request for the parent widget.\n this.parent.fit();\n }\n\n /**\n * Remove a widget from the layout.\n *\n * @param widget - The widget to remove from the layout.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method does *not* modify the widget's `parent`.\n */\n removeWidget(widget: Widget): void {\n // Remove the widget from its current layout location.\n this._removeWidget(widget);\n\n // Do nothing else if there is no parent widget.\n if (!this.parent) {\n return;\n }\n\n // Detach the widget from the parent widget.\n this.detachWidget(widget);\n\n // Post a fit request for the parent widget.\n this.parent.fit();\n }\n\n /**\n * Find the tab area which contains the given client position.\n *\n * @param clientX - The client X position of interest.\n *\n * @param clientY - The client Y position of interest.\n *\n * @returns The geometry of the tab area at the given position, or\n * `null` if there is no tab area at the given position.\n */\n hitTestTabAreas(\n clientX: number,\n clientY: number\n ): DockLayout.ITabAreaGeometry | null {\n // Bail early if hit testing cannot produce valid results.\n if (!this._root || !this.parent || !this.parent.isVisible) {\n return null;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent.node);\n }\n\n // Convert from client to local coordinates.\n let rect = this.parent.node.getBoundingClientRect();\n let x = clientX - rect.left - this._box.borderLeft;\n let y = clientY - rect.top - this._box.borderTop;\n\n // Find the tab layout node at the local position.\n let tabNode = this._root.hitTestTabNodes(x, y);\n\n // Bail if a tab layout node was not found.\n if (!tabNode) {\n return null;\n }\n\n // Extract the data from the tab node.\n let { tabBar, top, left, width, height } = tabNode;\n\n // Compute the right and bottom edges of the tab area.\n let borderWidth = this._box.borderLeft + this._box.borderRight;\n let borderHeight = this._box.borderTop + this._box.borderBottom;\n let right = rect.width - borderWidth - (left + width);\n let bottom = rect.height - borderHeight - (top + height);\n\n // Return the hit test results.\n return { tabBar, x, y, top, left, right, bottom, width, height };\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n // Perform superclass initialization.\n super.init();\n\n // Attach each widget to the parent.\n for (const widget of this) {\n this.attachWidget(widget);\n }\n\n // Attach each handle to the parent.\n for (const handle of this.handles()) {\n this.parent!.node.appendChild(handle);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * Attach the widget to the layout parent widget.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This is a no-op if the widget is already attached.\n */\n protected attachWidget(widget: Widget): void {\n // Do nothing if the widget is already attached.\n if (this.parent!.node === widget.node.parentNode) {\n return;\n }\n\n // Create the layout item for the widget.\n this._items.set(widget, new LayoutItem(widget));\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget's node to the parent.\n this.parent!.node.appendChild(widget.node);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n }\n\n /**\n * Detach the widget from the layout parent widget.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This is a no-op if the widget is not attached.\n */\n protected detachWidget(widget: Widget): void {\n // Do nothing if the widget is not attached.\n if (this.parent!.node !== widget.node.parentNode) {\n return;\n }\n\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Delete the layout item for the widget.\n let item = this._items.get(widget);\n if (item) {\n this._items.delete(widget);\n item.dispose();\n }\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n */\n protected onBeforeShow(msg: Message): void {\n super.onBeforeShow(msg);\n this.parent!.update();\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n super.onBeforeAttach(msg);\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n if (this.parent!.isVisible) {\n this._update(msg.width, msg.height);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.parent!.isVisible) {\n this._update(-1, -1);\n }\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n */\n protected onFitRequest(msg: Message): void {\n if (this.parent!.isAttached) {\n this._fit();\n }\n }\n\n /**\n * Remove the specified widget from the layout structure.\n *\n * #### Notes\n * This is a no-op if the widget is not in the layout tree.\n *\n * This does not detach the widget from the parent node.\n */\n private _removeWidget(widget: Widget): void {\n // Bail early if there is no layout root.\n if (!this._root) {\n return;\n }\n\n // Find the tab node which contains the given widget.\n let tabNode = this._root.findTabNode(widget);\n\n // Bail early if the tab node is not found.\n if (!tabNode) {\n return;\n }\n\n Private.removeAria(widget);\n\n // If there are multiple tabs, just remove the widget's tab.\n if (tabNode.tabBar.titles.length > 1) {\n tabNode.tabBar.removeTab(widget.title);\n if (\n this._hiddenMode === Widget.HiddenMode.Scale &&\n tabNode.tabBar.titles.length == 1\n ) {\n const existingWidget = tabNode.tabBar.titles[0].owner;\n existingWidget.hiddenMode = Widget.HiddenMode.Display;\n }\n return;\n }\n\n // Otherwise, the tab node needs to be removed...\n\n // Dispose the tab bar.\n tabNode.tabBar.dispose();\n\n // Handle the case where the tab node is the root.\n if (this._root === tabNode) {\n this._root = null;\n return;\n }\n\n // Otherwise, remove the tab node from its parent...\n\n // Prevent widget resizing unless needed.\n this._root.holdAllSizes();\n\n // Clear the parent reference on the tab node.\n let splitNode = tabNode.parent!;\n tabNode.parent = null;\n\n // Remove the tab node from its parent split node.\n let i = ArrayExt.removeFirstOf(splitNode.children, tabNode);\n let handle = ArrayExt.removeAt(splitNode.handles, i)!;\n ArrayExt.removeAt(splitNode.sizers, i);\n\n // Remove the handle from its parent DOM node.\n if (handle.parentNode) {\n handle.parentNode.removeChild(handle);\n }\n\n // If there are multiple children, just update the handles.\n if (splitNode.children.length > 1) {\n splitNode.syncHandles();\n return;\n }\n\n // Otherwise, the split node also needs to be removed...\n\n // Clear the parent reference on the split node.\n let maybeParent = splitNode.parent;\n splitNode.parent = null;\n\n // Lookup the remaining child node and handle.\n let childNode = splitNode.children[0];\n let childHandle = splitNode.handles[0];\n\n // Clear the split node data.\n splitNode.children.length = 0;\n splitNode.handles.length = 0;\n splitNode.sizers.length = 0;\n\n // Remove the child handle from its parent node.\n if (childHandle.parentNode) {\n childHandle.parentNode.removeChild(childHandle);\n }\n\n // Handle the case where the split node is the root.\n if (this._root === splitNode) {\n childNode.parent = null;\n this._root = childNode;\n return;\n }\n\n // Otherwise, move the child node to the parent node...\n let parentNode = maybeParent!;\n\n // Lookup the index of the split node.\n let j = parentNode.children.indexOf(splitNode);\n\n // Handle the case where the child node is a tab node.\n if (childNode instanceof Private.TabLayoutNode) {\n childNode.parent = parentNode;\n parentNode.children[j] = childNode;\n return;\n }\n\n // Remove the split data from the parent.\n let splitHandle = ArrayExt.removeAt(parentNode.handles, j)!;\n ArrayExt.removeAt(parentNode.children, j);\n ArrayExt.removeAt(parentNode.sizers, j);\n\n // Remove the handle from its parent node.\n if (splitHandle.parentNode) {\n splitHandle.parentNode.removeChild(splitHandle);\n }\n\n // The child node and the split parent node will have the same\n // orientation. Merge the grand-children with the parent node.\n for (let i = 0, n = childNode.children.length; i < n; ++i) {\n let gChild = childNode.children[i];\n let gHandle = childNode.handles[i];\n let gSizer = childNode.sizers[i];\n ArrayExt.insert(parentNode.children, j + i, gChild);\n ArrayExt.insert(parentNode.handles, j + i, gHandle);\n ArrayExt.insert(parentNode.sizers, j + i, gSizer);\n gChild.parent = parentNode;\n }\n\n // Clear the child node.\n childNode.children.length = 0;\n childNode.handles.length = 0;\n childNode.sizers.length = 0;\n childNode.parent = null;\n\n // Sync the handles on the parent node.\n parentNode.syncHandles();\n }\n\n /**\n * Create the tab layout node to hold the widget.\n */\n private _createTabNode(widget: Widget): Private.TabLayoutNode {\n let tabNode = new Private.TabLayoutNode(this._createTabBar());\n tabNode.tabBar.addTab(widget.title);\n Private.addAria(widget, tabNode.tabBar);\n return tabNode;\n }\n\n /**\n * Insert a widget next to an existing tab.\n *\n * #### Notes\n * This does not attach the widget to the parent widget.\n */\n private _insertTab(\n widget: Widget,\n ref: Widget | null,\n refNode: Private.TabLayoutNode | null,\n after: boolean\n ): void {\n // Do nothing if the tab is inserted next to itself.\n if (widget === ref) {\n return;\n }\n\n // Create the root if it does not exist.\n if (!this._root) {\n let tabNode = new Private.TabLayoutNode(this._createTabBar());\n tabNode.tabBar.addTab(widget.title);\n this._root = tabNode;\n Private.addAria(widget, tabNode.tabBar);\n return;\n }\n\n // Use the first tab node as the ref node if needed.\n if (!refNode) {\n refNode = this._root.findFirstTabNode()!;\n }\n\n // If the widget is not contained in the ref node, ensure it is\n // removed from the layout and hidden before being added again.\n if (refNode.tabBar.titles.indexOf(widget.title) === -1) {\n this._removeWidget(widget);\n widget.hide();\n }\n\n // Lookup the target index for inserting the tab.\n let index: number;\n if (ref) {\n index = refNode.tabBar.titles.indexOf(ref.title);\n } else {\n index = refNode.tabBar.currentIndex;\n }\n\n // Using transform create an additional layer in the pixel pipeline\n // to limit the number of layer, it is set only if there is more than one widget.\n if (this._hiddenMode === Widget.HiddenMode.Scale) {\n if (refNode.tabBar.titles.length === 0) {\n // Singular tab should use display mode to limit number of layers.\n widget.hiddenMode = Widget.HiddenMode.Display;\n } else if (refNode.tabBar.titles.length == 1) {\n // If we are adding a second tab, switch the existing tab back to scale.\n const existingWidget = refNode.tabBar.titles[0].owner;\n existingWidget.hiddenMode = Widget.HiddenMode.Scale;\n } else {\n // For the third and subsequent tabs no special action is needed.\n widget.hiddenMode = Widget.HiddenMode.Scale;\n }\n } else {\n // For all other modes just propagate the current mode.\n widget.hiddenMode = this._hiddenMode;\n }\n\n // Insert the widget's tab relative to the target index.\n refNode.tabBar.insertTab(index + (after ? 1 : 0), widget.title);\n Private.addAria(widget, refNode.tabBar);\n }\n\n /**\n * Insert a widget as a new split area.\n *\n * #### Notes\n * This does not attach the widget to the parent widget.\n */\n private _insertSplit(\n widget: Widget,\n ref: Widget | null,\n refNode: Private.TabLayoutNode | null,\n orientation: Private.Orientation,\n after: boolean,\n merge: boolean = false\n ): void {\n // Do nothing if there is no effective split.\n if (widget === ref && refNode && refNode.tabBar.titles.length === 1) {\n return;\n }\n\n // Ensure the widget is removed from the current layout.\n this._removeWidget(widget);\n\n // Set the root if it does not exist.\n if (!this._root) {\n this._root = this._createTabNode(widget);\n return;\n }\n\n // If the ref node parent is null, split the root.\n if (!refNode || !refNode.parent) {\n // Ensure the root is split with the correct orientation.\n let root = this._splitRoot(orientation);\n\n // Determine the insert index for the new tab node.\n let i = after ? root.children.length : 0;\n\n // Normalize the split node.\n root.normalizeSizes();\n\n // Create the sizer for new tab node.\n let sizer = Private.createSizer(refNode ? 1 : Private.GOLDEN_RATIO);\n\n // Insert the tab node sized to the golden ratio.\n let tabNode = this._createTabNode(widget);\n ArrayExt.insert(root.children, i, tabNode);\n ArrayExt.insert(root.sizers, i, sizer);\n ArrayExt.insert(root.handles, i, this._createHandle());\n tabNode.parent = root;\n\n // Re-normalize the split node to maintain the ratios.\n root.normalizeSizes();\n\n // Finally, synchronize the visibility of the handles.\n root.syncHandles();\n return;\n }\n\n // Lookup the split node for the ref widget.\n let splitNode = refNode.parent;\n\n // If the split node already had the correct orientation,\n // the widget can be inserted into the split node directly.\n if (splitNode.orientation === orientation) {\n // Find the index of the ref node.\n let i = splitNode.children.indexOf(refNode);\n\n // Conditionally reuse a tab layout found in the wanted position.\n if (merge) {\n let j = i + (after ? 1 : -1);\n let sibling = splitNode.children[j];\n if (sibling instanceof Private.TabLayoutNode) {\n this._insertTab(widget, null, sibling, true);\n ++sibling.tabBar.currentIndex;\n return;\n }\n }\n\n // Normalize the split node.\n splitNode.normalizeSizes();\n\n // Consume half the space for the insert location.\n let s = (splitNode.sizers[i].sizeHint /= 2);\n\n // Insert the tab node sized to the other half.\n let j = i + (after ? 1 : 0);\n let tabNode = this._createTabNode(widget);\n ArrayExt.insert(splitNode.children, j, tabNode);\n ArrayExt.insert(splitNode.sizers, j, Private.createSizer(s));\n ArrayExt.insert(splitNode.handles, j, this._createHandle());\n tabNode.parent = splitNode;\n\n // Finally, synchronize the visibility of the handles.\n splitNode.syncHandles();\n return;\n }\n\n // Remove the ref node from the split node.\n let i = ArrayExt.removeFirstOf(splitNode.children, refNode);\n\n // Create a new normalized split node for the children.\n let childNode = new Private.SplitLayoutNode(orientation);\n childNode.normalized = true;\n\n // Add the ref node sized to half the space.\n childNode.children.push(refNode);\n childNode.sizers.push(Private.createSizer(0.5));\n childNode.handles.push(this._createHandle());\n refNode.parent = childNode;\n\n // Add the tab node sized to the other half.\n let j = after ? 1 : 0;\n let tabNode = this._createTabNode(widget);\n ArrayExt.insert(childNode.children, j, tabNode);\n ArrayExt.insert(childNode.sizers, j, Private.createSizer(0.5));\n ArrayExt.insert(childNode.handles, j, this._createHandle());\n tabNode.parent = childNode;\n\n // Synchronize the visibility of the handles.\n childNode.syncHandles();\n\n // Finally, add the new child node to the original split node.\n ArrayExt.insert(splitNode.children, i, childNode);\n childNode.parent = splitNode;\n }\n\n /**\n * Ensure the root is a split node with the given orientation.\n */\n private _splitRoot(\n orientation: Private.Orientation\n ): Private.SplitLayoutNode {\n // Bail early if the root already meets the requirements.\n let oldRoot = this._root;\n if (oldRoot instanceof Private.SplitLayoutNode) {\n if (oldRoot.orientation === orientation) {\n return oldRoot;\n }\n }\n\n // Create a new root node with the specified orientation.\n let newRoot = (this._root = new Private.SplitLayoutNode(orientation));\n\n // Add the old root to the new root.\n if (oldRoot) {\n newRoot.children.push(oldRoot);\n newRoot.sizers.push(Private.createSizer(0));\n newRoot.handles.push(this._createHandle());\n oldRoot.parent = newRoot;\n }\n\n // Return the new root as a convenience.\n return newRoot;\n }\n\n /**\n * Fit the layout to the total size required by the widgets.\n */\n private _fit(): void {\n // Set up the computed minimum size.\n let minW = 0;\n let minH = 0;\n\n // Update the size limits for the layout tree.\n if (this._root) {\n let limits = this._root.fit(this._spacing, this._items);\n minW = limits.minWidth;\n minH = limits.minHeight;\n }\n\n // Update the box sizing and add it to the computed min size.\n let box = (this._box = ElementExt.boxSizing(this.parent!.node));\n minW += box.horizontalSum;\n minH += box.verticalSum;\n\n // Update the parent's min size constraints.\n let style = this.parent!.node.style;\n style.minWidth = `${minW}px`;\n style.minHeight = `${minH}px`;\n\n // Set the dirty flag to ensure only a single update occurs.\n this._dirty = true;\n\n // Notify the ancestor that it should fit immediately. This may\n // cause a resize of the parent, fulfilling the required update.\n if (this.parent!.parent) {\n MessageLoop.sendMessage(this.parent!.parent!, Widget.Msg.FitRequest);\n }\n\n // If the dirty flag is still set, the parent was not resized.\n // Trigger the required update on the parent widget immediately.\n if (this._dirty) {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n }\n }\n\n /**\n * Update the layout position and size of the widgets.\n *\n * The parent offset dimensions should be `-1` if unknown.\n */\n private _update(offsetWidth: number, offsetHeight: number): void {\n // Clear the dirty flag to indicate the update occurred.\n this._dirty = false;\n\n // Bail early if there is no root layout node.\n if (!this._root) {\n return;\n }\n\n // Measure the parent if the offset dimensions are unknown.\n if (offsetWidth < 0) {\n offsetWidth = this.parent!.node.offsetWidth;\n }\n if (offsetHeight < 0) {\n offsetHeight = this.parent!.node.offsetHeight;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent!.node);\n }\n\n // Compute the actual layout bounds adjusted for border and padding.\n let x = this._box.paddingTop;\n let y = this._box.paddingLeft;\n let width = offsetWidth - this._box.horizontalSum;\n let height = offsetHeight - this._box.verticalSum;\n\n // Update the geometry of the layout tree.\n this._root.update(x, y, width, height, this._spacing, this._items);\n }\n\n /**\n * Create a new tab bar for use by the dock layout.\n *\n * #### Notes\n * The tab bar will be attached to the parent if it exists.\n */\n private _createTabBar(): TabBar {\n // Create the tab bar using the renderer.\n let tabBar = this.renderer.createTabBar(this._document);\n\n // Enforce necessary tab bar behavior.\n tabBar.orientation = 'horizontal';\n\n // Attach the tab bar to the parent if possible.\n if (this.parent) {\n this.attachWidget(tabBar);\n }\n\n // Return the initialized tab bar.\n return tabBar;\n }\n\n /**\n * Create a new handle for the dock layout.\n *\n * #### Notes\n * The handle will be attached to the parent if it exists.\n */\n private _createHandle(): HTMLDivElement {\n // Create the handle using the renderer.\n let handle = this.renderer.createHandle();\n\n // Initialize the handle layout behavior.\n let style = handle.style;\n style.position = 'absolute';\n style.contain = 'strict';\n style.top = '0';\n style.left = '0';\n style.width = '0';\n style.height = '0';\n\n // Attach the handle to the parent if it exists.\n if (this.parent) {\n this.parent.node.appendChild(handle);\n }\n\n // Return the initialized handle.\n return handle;\n }\n\n private _spacing = 4;\n private _dirty = false;\n private _root: Private.LayoutNode | null = null;\n private _box: ElementExt.IBoxSizing | null = null;\n private _document: Document | ShadowRoot;\n private _hiddenMode: Widget.HiddenMode;\n private _items: Private.ItemMap = new Map();\n}\n\n/**\n * The namespace for the `DockLayout` class statics.\n */\nexport namespace DockLayout {\n /**\n * An options object for creating a dock layout.\n */\n export interface IOptions {\n /**\n * The document to use with the dock panel.\n *\n * The default is the global `document` instance.\n */\n document?: Document | ShadowRoot;\n\n /**\n * The method for hiding widgets.\n *\n * The default is `Widget.HiddenMode.Display`.\n */\n hiddenMode?: Widget.HiddenMode;\n\n /**\n * The renderer to use for the dock layout.\n */\n renderer: IRenderer;\n\n /**\n * The spacing between items in the layout.\n *\n * The default is `4`.\n */\n spacing?: number;\n }\n\n /**\n * A renderer for use with a dock layout.\n */\n export interface IRenderer {\n /**\n * Create a new tab bar for use with a dock layout.\n *\n * @returns A new tab bar for a dock layout.\n */\n createTabBar(document?: Document | ShadowRoot): TabBar;\n\n /**\n * Create a new handle node for use with a dock layout.\n *\n * @returns A new handle node for a dock layout.\n */\n createHandle(): HTMLDivElement;\n }\n\n /**\n * A type alias for the supported insertion modes.\n *\n * An insert mode is used to specify how a widget should be added\n * to the dock layout relative to a reference widget.\n */\n export type InsertMode =\n | /**\n * The area to the top of the reference widget.\n *\n * The widget will be inserted just above the reference widget.\n *\n * If the reference widget is null or invalid, the widget will be\n * inserted at the top edge of the dock layout.\n */\n 'split-top'\n\n /**\n * The area to the left of the reference widget.\n *\n * The widget will be inserted just left of the reference widget.\n *\n * If the reference widget is null or invalid, the widget will be\n * inserted at the left edge of the dock layout.\n */\n | 'split-left'\n\n /**\n * The area to the right of the reference widget.\n *\n * The widget will be inserted just right of the reference widget.\n *\n * If the reference widget is null or invalid, the widget will be\n * inserted at the right edge of the dock layout.\n */\n | 'split-right'\n\n /**\n * The area to the bottom of the reference widget.\n *\n * The widget will be inserted just below the reference widget.\n *\n * If the reference widget is null or invalid, the widget will be\n * inserted at the bottom edge of the dock layout.\n */\n | 'split-bottom'\n\n /**\n * Like `split-top` but if a tab layout exists above the reference widget,\n * it behaves like `tab-after` with reference to that instead.\n */\n | 'merge-top'\n\n /**\n * Like `split-left` but if a tab layout exists left of the reference widget,\n * it behaves like `tab-after` with reference to that instead.\n */\n | 'merge-left'\n\n /**\n * Like `split-right` but if a tab layout exists right of the reference widget,\n * it behaves like `tab-after` with reference to that instead.\n */\n | 'merge-right'\n\n /**\n * Like `split-bottom` but if a tab layout exists below the reference widget,\n * it behaves like `tab-after` with reference to that instead.\n */\n | 'merge-bottom'\n\n /**\n * The tab position before the reference widget.\n *\n * The widget will be added as a tab before the reference widget.\n *\n * If the reference widget is null or invalid, a sensible default\n * will be used.\n */\n | 'tab-before'\n\n /**\n * The tab position after the reference widget.\n *\n * The widget will be added as a tab after the reference widget.\n *\n * If the reference widget is null or invalid, a sensible default\n * will be used.\n */\n | 'tab-after';\n\n /**\n * An options object for adding a widget to the dock layout.\n */\n export interface IAddOptions {\n /**\n * The insertion mode for adding the widget.\n *\n * The default is `'tab-after'`.\n */\n mode?: InsertMode;\n\n /**\n * The reference widget for the insert location.\n *\n * The default is `null`.\n */\n ref?: Widget | null;\n }\n\n /**\n * A layout config object for a tab area.\n */\n export interface ITabAreaConfig {\n /**\n * The discriminated type of the config object.\n */\n type: 'tab-area';\n\n /**\n * The widgets contained in the tab area.\n */\n widgets: Widget[];\n\n /**\n * The index of the selected tab.\n */\n currentIndex: number;\n }\n\n /**\n * A layout config object for a split area.\n */\n export interface ISplitAreaConfig {\n /**\n * The discriminated type of the config object.\n */\n type: 'split-area';\n\n /**\n * The orientation of the split area.\n */\n orientation: 'horizontal' | 'vertical';\n\n /**\n * The children in the split area.\n */\n children: AreaConfig[];\n\n /**\n * The relative sizes of the children.\n */\n sizes: number[];\n }\n\n /**\n * A type alias for a general area config.\n */\n export type AreaConfig = ITabAreaConfig | ISplitAreaConfig;\n\n /**\n * A dock layout configuration object.\n */\n export interface ILayoutConfig {\n /**\n * The layout config for the main dock area.\n */\n main: AreaConfig | null;\n }\n\n /**\n * An object which represents the geometry of a tab area.\n */\n export interface ITabAreaGeometry {\n /**\n * The tab bar for the tab area.\n */\n tabBar: TabBar;\n\n /**\n * The local X position of the hit test in the dock area.\n *\n * #### Notes\n * This is the distance from the left edge of the layout parent\n * widget, to the local X coordinate of the hit test query.\n */\n x: number;\n\n /**\n * The local Y position of the hit test in the dock area.\n *\n * #### Notes\n * This is the distance from the top edge of the layout parent\n * widget, to the local Y coordinate of the hit test query.\n */\n y: number;\n\n /**\n * The local coordinate of the top edge of the tab area.\n *\n * #### Notes\n * This is the distance from the top edge of the layout parent\n * widget, to the top edge of the tab area.\n */\n top: number;\n\n /**\n * The local coordinate of the left edge of the tab area.\n *\n * #### Notes\n * This is the distance from the left edge of the layout parent\n * widget, to the left edge of the tab area.\n */\n left: number;\n\n /**\n * The local coordinate of the right edge of the tab area.\n *\n * #### Notes\n * This is the distance from the right edge of the layout parent\n * widget, to the right edge of the tab area.\n */\n right: number;\n\n /**\n * The local coordinate of the bottom edge of the tab area.\n *\n * #### Notes\n * This is the distance from the bottom edge of the layout parent\n * widget, to the bottom edge of the tab area.\n */\n bottom: number;\n\n /**\n * The width of the tab area.\n *\n * #### Notes\n * This is total width allocated for the tab area.\n */\n width: number;\n\n /**\n * The height of the tab area.\n *\n * #### Notes\n * This is total height allocated for the tab area.\n */\n height: number;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * A fraction used for sizing root panels; ~= `1 / golden_ratio`.\n */\n export const GOLDEN_RATIO = 0.618;\n\n /**\n * A type alias for a dock layout node.\n */\n export type LayoutNode = TabLayoutNode | SplitLayoutNode;\n\n /**\n * A type alias for the orientation of a split layout node.\n */\n export type Orientation = 'horizontal' | 'vertical';\n\n /**\n * A type alias for a layout item map.\n */\n export type ItemMap = Map;\n\n /**\n * Create a box sizer with an initial size hint.\n */\n export function createSizer(hint: number): BoxSizer {\n let sizer = new BoxSizer();\n sizer.sizeHint = hint;\n sizer.size = hint;\n return sizer;\n }\n\n /**\n * Normalize an area config object and collect the visited widgets.\n */\n export function normalizeAreaConfig(\n config: DockLayout.AreaConfig,\n widgetSet: Set\n ): DockLayout.AreaConfig | null {\n let result: DockLayout.AreaConfig | null;\n if (config.type === 'tab-area') {\n result = normalizeTabAreaConfig(config, widgetSet);\n } else {\n result = normalizeSplitAreaConfig(config, widgetSet);\n }\n return result;\n }\n\n /**\n * Convert a normalized area config into a layout tree.\n */\n export function realizeAreaConfig(\n config: DockLayout.AreaConfig,\n renderer: DockLayout.IRenderer,\n document: Document | ShadowRoot\n ): LayoutNode {\n let node: LayoutNode;\n if (config.type === 'tab-area') {\n node = realizeTabAreaConfig(config, renderer, document);\n } else {\n node = realizeSplitAreaConfig(config, renderer, document);\n }\n return node;\n }\n\n /**\n * A layout node which holds the data for a tabbed area.\n */\n export class TabLayoutNode {\n /**\n * Construct a new tab layout node.\n *\n * @param tabBar - The tab bar to use for the layout node.\n */\n constructor(tabBar: TabBar) {\n let tabSizer = new BoxSizer();\n let widgetSizer = new BoxSizer();\n tabSizer.stretch = 0;\n widgetSizer.stretch = 1;\n this.tabBar = tabBar;\n this.sizers = [tabSizer, widgetSizer];\n }\n\n /**\n * The parent of the layout node.\n */\n parent: SplitLayoutNode | null = null;\n\n /**\n * The tab bar for the layout node.\n */\n readonly tabBar: TabBar;\n\n /**\n * The sizers for the layout node.\n */\n readonly sizers: [BoxSizer, BoxSizer];\n\n /**\n * The most recent value for the `top` edge of the layout box.\n */\n get top(): number {\n return this._top;\n }\n\n /**\n * The most recent value for the `left` edge of the layout box.\n */\n get left(): number {\n return this._left;\n }\n\n /**\n * The most recent value for the `width` of the layout box.\n */\n get width(): number {\n return this._width;\n }\n\n /**\n * The most recent value for the `height` of the layout box.\n */\n get height(): number {\n return this._height;\n }\n\n /**\n * Create an iterator for all widgets in the layout tree.\n */\n *iterAllWidgets(): IterableIterator {\n yield this.tabBar;\n yield* this.iterUserWidgets();\n }\n\n /**\n * Create an iterator for the user widgets in the layout tree.\n */\n *iterUserWidgets(): IterableIterator {\n for (const title of this.tabBar.titles) {\n yield title.owner;\n }\n }\n\n /**\n * Create an iterator for the selected widgets in the layout tree.\n */\n *iterSelectedWidgets(): IterableIterator {\n let title = this.tabBar.currentTitle;\n if (title) {\n yield title.owner;\n }\n }\n\n /**\n * Create an iterator for the tab bars in the layout tree.\n */\n *iterTabBars(): IterableIterator> {\n yield this.tabBar;\n }\n\n /**\n * Create an iterator for the handles in the layout tree.\n */\n // eslint-disable-next-line require-yield\n *iterHandles(): IterableIterator {\n return;\n }\n\n /**\n * Find the tab layout node which contains the given widget.\n */\n findTabNode(widget: Widget): TabLayoutNode | null {\n return this.tabBar.titles.indexOf(widget.title) !== -1 ? this : null;\n }\n\n /**\n * Find the split layout node which contains the given handle.\n */\n findSplitNode(\n handle: HTMLDivElement\n ): { index: number; node: SplitLayoutNode } | null {\n return null;\n }\n\n /**\n * Find the first tab layout node in a layout tree.\n */\n findFirstTabNode(): TabLayoutNode | null {\n return this;\n }\n\n /**\n * Find the tab layout node which contains the local point.\n */\n hitTestTabNodes(x: number, y: number): TabLayoutNode | null {\n if (x < this._left || x >= this._left + this._width) {\n return null;\n }\n if (y < this._top || y >= this._top + this._height) {\n return null;\n }\n return this;\n }\n\n /**\n * Create a configuration object for the layout tree.\n */\n createConfig(): DockLayout.ITabAreaConfig {\n let widgets = this.tabBar.titles.map(title => title.owner);\n let currentIndex = this.tabBar.currentIndex;\n return { type: 'tab-area', widgets, currentIndex };\n }\n\n /**\n * Recursively hold all of the sizes in the layout tree.\n *\n * This ignores the sizers of tab layout nodes.\n */\n holdAllSizes(): void {\n return;\n }\n\n /**\n * Fit the layout tree.\n */\n fit(spacing: number, items: ItemMap): ElementExt.ISizeLimits {\n // Set up the limit variables.\n let minWidth = 0;\n let minHeight = 0;\n let maxWidth = Infinity;\n let maxHeight = Infinity;\n\n // Lookup the tab bar layout item.\n let tabBarItem = items.get(this.tabBar);\n\n // Lookup the widget layout item.\n let current = this.tabBar.currentTitle;\n let widgetItem = current ? items.get(current.owner) : undefined;\n\n // Lookup the tab bar and widget sizers.\n let [tabBarSizer, widgetSizer] = this.sizers;\n\n // Update the tab bar limits.\n if (tabBarItem) {\n tabBarItem.fit();\n }\n\n // Update the widget limits.\n if (widgetItem) {\n widgetItem.fit();\n }\n\n // Update the results and sizer for the tab bar.\n if (tabBarItem && !tabBarItem.isHidden) {\n minWidth = Math.max(minWidth, tabBarItem.minWidth);\n minHeight += tabBarItem.minHeight;\n tabBarSizer.minSize = tabBarItem.minHeight;\n tabBarSizer.maxSize = tabBarItem.maxHeight;\n } else {\n tabBarSizer.minSize = 0;\n tabBarSizer.maxSize = 0;\n }\n\n // Update the results and sizer for the current widget.\n if (widgetItem && !widgetItem.isHidden) {\n minWidth = Math.max(minWidth, widgetItem.minWidth);\n minHeight += widgetItem.minHeight;\n widgetSizer.minSize = widgetItem.minHeight;\n widgetSizer.maxSize = Infinity;\n } else {\n widgetSizer.minSize = 0;\n widgetSizer.maxSize = Infinity;\n }\n\n // Return the computed size limits for the layout node.\n return { minWidth, minHeight, maxWidth, maxHeight };\n }\n\n /**\n * Update the layout tree.\n */\n update(\n left: number,\n top: number,\n width: number,\n height: number,\n spacing: number,\n items: ItemMap\n ): void {\n // Update the layout box values.\n this._top = top;\n this._left = left;\n this._width = width;\n this._height = height;\n\n // Lookup the tab bar layout item.\n let tabBarItem = items.get(this.tabBar);\n\n // Lookup the widget layout item.\n let current = this.tabBar.currentTitle;\n let widgetItem = current ? items.get(current.owner) : undefined;\n\n // Distribute the layout space to the sizers.\n BoxEngine.calc(this.sizers, height);\n\n // Update the tab bar item using the computed size.\n if (tabBarItem && !tabBarItem.isHidden) {\n let size = this.sizers[0].size;\n tabBarItem.update(left, top, width, size);\n top += size;\n }\n\n // Layout the widget using the computed size.\n if (widgetItem && !widgetItem.isHidden) {\n let size = this.sizers[1].size;\n widgetItem.update(left, top, width, size);\n }\n }\n\n private _top = 0;\n private _left = 0;\n private _width = 0;\n private _height = 0;\n }\n\n /**\n * A layout node which holds the data for a split area.\n */\n export class SplitLayoutNode {\n /**\n * Construct a new split layout node.\n *\n * @param orientation - The orientation of the node.\n */\n constructor(orientation: Orientation) {\n this.orientation = orientation;\n }\n\n /**\n * The parent of the layout node.\n */\n parent: SplitLayoutNode | null = null;\n\n /**\n * Whether the sizers have been normalized.\n */\n normalized = false;\n\n /**\n * The orientation of the node.\n */\n readonly orientation: Orientation;\n\n /**\n * The child nodes for the split node.\n */\n readonly children: LayoutNode[] = [];\n\n /**\n * The box sizers for the layout children.\n */\n readonly sizers: BoxSizer[] = [];\n\n /**\n * The handles for the layout children.\n */\n readonly handles: HTMLDivElement[] = [];\n\n /**\n * Create an iterator for all widgets in the layout tree.\n */\n *iterAllWidgets(): IterableIterator {\n for (const child of this.children) {\n yield* child.iterAllWidgets();\n }\n }\n\n /**\n * Create an iterator for the user widgets in the layout tree.\n */\n *iterUserWidgets(): IterableIterator {\n for (const child of this.children) {\n yield* child.iterUserWidgets();\n }\n }\n\n /**\n * Create an iterator for the selected widgets in the layout tree.\n */\n *iterSelectedWidgets(): IterableIterator {\n for (const child of this.children) {\n yield* child.iterSelectedWidgets();\n }\n }\n\n /**\n * Create an iterator for the tab bars in the layout tree.\n */\n *iterTabBars(): IterableIterator> {\n for (const child of this.children) {\n yield* child.iterTabBars();\n }\n }\n\n /**\n * Create an iterator for the handles in the layout tree.\n */\n *iterHandles(): IterableIterator {\n yield* this.handles;\n for (const child of this.children) {\n yield* child.iterHandles();\n }\n }\n\n /**\n * Find the tab layout node which contains the given widget.\n */\n findTabNode(widget: Widget): TabLayoutNode | null {\n for (let i = 0, n = this.children.length; i < n; ++i) {\n let result = this.children[i].findTabNode(widget);\n if (result) {\n return result;\n }\n }\n return null;\n }\n\n /**\n * Find the split layout node which contains the given handle.\n */\n findSplitNode(\n handle: HTMLDivElement\n ): { index: number; node: SplitLayoutNode } | null {\n let index = this.handles.indexOf(handle);\n if (index !== -1) {\n return { index, node: this };\n }\n for (let i = 0, n = this.children.length; i < n; ++i) {\n let result = this.children[i].findSplitNode(handle);\n if (result) {\n return result;\n }\n }\n return null;\n }\n\n /**\n * Find the first tab layout node in a layout tree.\n */\n findFirstTabNode(): TabLayoutNode | null {\n if (this.children.length === 0) {\n return null;\n }\n return this.children[0].findFirstTabNode();\n }\n\n /**\n * Find the tab layout node which contains the local point.\n */\n hitTestTabNodes(x: number, y: number): TabLayoutNode | null {\n for (let i = 0, n = this.children.length; i < n; ++i) {\n let result = this.children[i].hitTestTabNodes(x, y);\n if (result) {\n return result;\n }\n }\n return null;\n }\n\n /**\n * Create a configuration object for the layout tree.\n */\n createConfig(): DockLayout.ISplitAreaConfig {\n let orientation = this.orientation;\n let sizes = this.createNormalizedSizes();\n let children = this.children.map(child => child.createConfig());\n return { type: 'split-area', orientation, children, sizes };\n }\n\n /**\n * Sync the visibility and orientation of the handles.\n */\n syncHandles(): void {\n this.handles.forEach((handle, i) => {\n handle.setAttribute('data-orientation', this.orientation);\n if (i === this.handles.length - 1) {\n handle.classList.add('lm-mod-hidden');\n } else {\n handle.classList.remove('lm-mod-hidden');\n }\n });\n }\n\n /**\n * Hold the current sizes of the box sizers.\n *\n * This sets the size hint of each sizer to its current size.\n */\n holdSizes(): void {\n for (const sizer of this.sizers) {\n sizer.sizeHint = sizer.size;\n }\n }\n\n /**\n * Recursively hold all of the sizes in the layout tree.\n *\n * This ignores the sizers of tab layout nodes.\n */\n holdAllSizes(): void {\n for (const child of this.children) {\n child.holdAllSizes();\n }\n this.holdSizes();\n }\n\n /**\n * Normalize the sizes of the split layout node.\n */\n normalizeSizes(): void {\n // Bail early if the sizers are empty.\n let n = this.sizers.length;\n if (n === 0) {\n return;\n }\n\n // Hold the current sizes of the sizers.\n this.holdSizes();\n\n // Compute the sum of the sizes.\n let sum = this.sizers.reduce((v, sizer) => v + sizer.sizeHint, 0);\n\n // Normalize the sizes based on the sum.\n if (sum === 0) {\n for (const sizer of this.sizers) {\n sizer.size = sizer.sizeHint = 1 / n;\n }\n } else {\n for (const sizer of this.sizers) {\n sizer.size = sizer.sizeHint /= sum;\n }\n }\n\n // Mark the sizes as normalized.\n this.normalized = true;\n }\n\n /**\n * Snap the normalized sizes of the split layout node.\n */\n createNormalizedSizes(): number[] {\n // Bail early if the sizers are empty.\n let n = this.sizers.length;\n if (n === 0) {\n return [];\n }\n\n // Grab the current sizes of the sizers.\n let sizes = this.sizers.map(sizer => sizer.size);\n\n // Compute the sum of the sizes.\n let sum = sizes.reduce((v, size) => v + size, 0);\n\n // Normalize the sizes based on the sum.\n if (sum === 0) {\n for (let i = sizes.length - 1; i > -1; i--) {\n sizes[i] = 1 / n;\n }\n } else {\n for (let i = sizes.length - 1; i > -1; i--) {\n sizes[i] /= sum;\n }\n }\n\n // Return the normalized sizes.\n return sizes;\n }\n\n /**\n * Fit the layout tree.\n */\n fit(spacing: number, items: ItemMap): ElementExt.ISizeLimits {\n // Compute the required fixed space.\n let horizontal = this.orientation === 'horizontal';\n let fixed = Math.max(0, this.children.length - 1) * spacing;\n\n // Set up the limit variables.\n let minWidth = horizontal ? fixed : 0;\n let minHeight = horizontal ? 0 : fixed;\n let maxWidth = Infinity;\n let maxHeight = Infinity;\n\n // Fit the children and update the limits.\n for (let i = 0, n = this.children.length; i < n; ++i) {\n let limits = this.children[i].fit(spacing, items);\n if (horizontal) {\n minHeight = Math.max(minHeight, limits.minHeight);\n minWidth += limits.minWidth;\n this.sizers[i].minSize = limits.minWidth;\n } else {\n minWidth = Math.max(minWidth, limits.minWidth);\n minHeight += limits.minHeight;\n this.sizers[i].minSize = limits.minHeight;\n }\n }\n\n // Return the computed limits for the layout node.\n return { minWidth, minHeight, maxWidth, maxHeight };\n }\n\n /**\n * Update the layout tree.\n */\n update(\n left: number,\n top: number,\n width: number,\n height: number,\n spacing: number,\n items: ItemMap\n ): void {\n // Compute the available layout space.\n let horizontal = this.orientation === 'horizontal';\n let fixed = Math.max(0, this.children.length - 1) * spacing;\n let space = Math.max(0, (horizontal ? width : height) - fixed);\n\n // De-normalize the sizes if needed.\n if (this.normalized) {\n for (const sizer of this.sizers) {\n sizer.sizeHint *= space;\n }\n this.normalized = false;\n }\n\n // Distribute the layout space to the sizers.\n BoxEngine.calc(this.sizers, space);\n\n // Update the geometry of the child nodes and handles.\n for (let i = 0, n = this.children.length; i < n; ++i) {\n let child = this.children[i];\n let size = this.sizers[i].size;\n let handleStyle = this.handles[i].style;\n if (horizontal) {\n child.update(left, top, size, height, spacing, items);\n left += size;\n handleStyle.top = `${top}px`;\n handleStyle.left = `${left}px`;\n handleStyle.width = `${spacing}px`;\n handleStyle.height = `${height}px`;\n left += spacing;\n } else {\n child.update(left, top, width, size, spacing, items);\n top += size;\n handleStyle.top = `${top}px`;\n handleStyle.left = `${left}px`;\n handleStyle.width = `${width}px`;\n handleStyle.height = `${spacing}px`;\n top += spacing;\n }\n }\n }\n }\n\n export function addAria(widget: Widget, tabBar: TabBar): void {\n widget.node.setAttribute('role', 'tabpanel');\n let renderer = tabBar.renderer;\n if (renderer instanceof TabBar.Renderer) {\n let tabId = renderer.createTabKey({\n title: widget.title,\n current: false,\n zIndex: 0\n });\n widget.node.setAttribute('aria-labelledby', tabId);\n }\n }\n\n export function removeAria(widget: Widget): void {\n widget.node.removeAttribute('role');\n widget.node.removeAttribute('aria-labelledby');\n }\n\n /**\n * Normalize a tab area config and collect the visited widgets.\n */\n function normalizeTabAreaConfig(\n config: DockLayout.ITabAreaConfig,\n widgetSet: Set\n ): DockLayout.ITabAreaConfig | null {\n // Bail early if there is no content.\n if (config.widgets.length === 0) {\n return null;\n }\n\n // Setup the filtered widgets array.\n let widgets: Widget[] = [];\n\n // Filter the config for unique widgets.\n for (const widget of config.widgets) {\n if (!widgetSet.has(widget)) {\n widgetSet.add(widget);\n widgets.push(widget);\n }\n }\n\n // Bail if there are no effective widgets.\n if (widgets.length === 0) {\n return null;\n }\n\n // Normalize the current index.\n let index = config.currentIndex;\n if (index !== -1 && (index < 0 || index >= widgets.length)) {\n index = 0;\n }\n\n // Return a normalized config object.\n return { type: 'tab-area', widgets, currentIndex: index };\n }\n\n /**\n * Normalize a split area config and collect the visited widgets.\n */\n function normalizeSplitAreaConfig(\n config: DockLayout.ISplitAreaConfig,\n widgetSet: Set\n ): DockLayout.AreaConfig | null {\n // Set up the result variables.\n let orientation = config.orientation;\n let children: DockLayout.AreaConfig[] = [];\n let sizes: number[] = [];\n\n // Normalize the config children.\n for (let i = 0, n = config.children.length; i < n; ++i) {\n // Normalize the child config.\n let child = normalizeAreaConfig(config.children[i], widgetSet);\n\n // Ignore an empty child.\n if (!child) {\n continue;\n }\n\n // Add the child or hoist its content as appropriate.\n if (child.type === 'tab-area' || child.orientation !== orientation) {\n children.push(child);\n sizes.push(Math.abs(config.sizes[i] || 0));\n } else {\n children.push(...child.children);\n sizes.push(...child.sizes);\n }\n }\n\n // Bail if there are no effective children.\n if (children.length === 0) {\n return null;\n }\n\n // If there is only one effective child, return that child.\n if (children.length === 1) {\n return children[0];\n }\n\n // Return a normalized config object.\n return { type: 'split-area', orientation, children, sizes };\n }\n\n /**\n * Convert a normalized tab area config into a layout tree.\n */\n function realizeTabAreaConfig(\n config: DockLayout.ITabAreaConfig,\n renderer: DockLayout.IRenderer,\n document: Document | ShadowRoot\n ): TabLayoutNode {\n // Create the tab bar for the layout node.\n let tabBar = renderer.createTabBar(document);\n\n // Hide each widget and add it to the tab bar.\n for (const widget of config.widgets) {\n widget.hide();\n tabBar.addTab(widget.title);\n Private.addAria(widget, tabBar);\n }\n\n // Set the current index of the tab bar.\n tabBar.currentIndex = config.currentIndex;\n\n // Return the new tab layout node.\n return new TabLayoutNode(tabBar);\n }\n\n /**\n * Convert a normalized split area config into a layout tree.\n */\n function realizeSplitAreaConfig(\n config: DockLayout.ISplitAreaConfig,\n renderer: DockLayout.IRenderer,\n document: Document | ShadowRoot\n ): SplitLayoutNode {\n // Create the split layout node.\n let node = new SplitLayoutNode(config.orientation);\n\n // Add each child to the layout node.\n config.children.forEach((child, i) => {\n // Create the child data for the layout node.\n let childNode = realizeAreaConfig(child, renderer, document);\n let sizer = createSizer(config.sizes[i]);\n let handle = renderer.createHandle();\n\n // Add the child data to the layout node.\n node.children.push(childNode);\n node.handles.push(handle);\n node.sizers.push(sizer);\n\n // Update the parent for the child node.\n childNode.parent = node;\n });\n\n // Synchronize the handle state for the layout node.\n node.syncHandles();\n\n // Normalize the sizes for the layout node.\n node.normalizeSizes();\n\n // Return the new layout node.\n return node;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { find } from '@lumino/algorithm';\n\nimport { MimeData } from '@lumino/coreutils';\n\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ElementExt, Platform } from '@lumino/domutils';\n\nimport { Drag } from '@lumino/dragdrop';\n\nimport { ConflatableMessage, Message, MessageLoop } from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { DockLayout } from './docklayout';\n\nimport { TabBar } from './tabbar';\n\nimport { Widget } from './widget';\n\n/**\n * A widget which provides a flexible docking area for widgets.\n */\nexport class DockPanel extends Widget {\n /**\n * Construct a new dock panel.\n *\n * @param options - The options for initializing the panel.\n */\n constructor(options: DockPanel.IOptions = {}) {\n super();\n this.addClass('lm-DockPanel');\n this._document = options.document || document;\n this._mode = options.mode || 'multiple-document';\n this._renderer = options.renderer || DockPanel.defaultRenderer;\n this._edges = options.edges || Private.DEFAULT_EDGES;\n if (options.tabsMovable !== undefined) {\n this._tabsMovable = options.tabsMovable;\n }\n if (options.tabsConstrained !== undefined) {\n this._tabsConstrained = options.tabsConstrained;\n }\n if (options.addButtonEnabled !== undefined) {\n this._addButtonEnabled = options.addButtonEnabled;\n }\n\n // Toggle the CSS mode attribute.\n this.dataset['mode'] = this._mode;\n\n // Create the delegate renderer for the layout.\n let renderer: DockPanel.IRenderer = {\n createTabBar: () => this._createTabBar(),\n createHandle: () => this._createHandle()\n };\n\n // Set up the dock layout for the panel.\n this.layout = new DockLayout({\n document: this._document,\n renderer,\n spacing: options.spacing,\n hiddenMode: options.hiddenMode\n });\n\n // Set up the overlay drop indicator.\n this.overlay = options.overlay || new DockPanel.Overlay();\n this.node.appendChild(this.overlay.node);\n }\n\n /**\n * Dispose of the resources held by the panel.\n */\n dispose(): void {\n // Ensure the mouse is released.\n this._releaseMouse();\n\n // Hide the overlay.\n this.overlay.hide(0);\n\n // Cancel a drag if one is in progress.\n if (this._drag) {\n this._drag.dispose();\n }\n\n // Dispose of the base class.\n super.dispose();\n }\n\n /**\n * The method for hiding widgets.\n */\n get hiddenMode(): Widget.HiddenMode {\n return (this.layout as DockLayout).hiddenMode;\n }\n\n /**\n * Set the method for hiding widgets.\n */\n set hiddenMode(v: Widget.HiddenMode) {\n (this.layout as DockLayout).hiddenMode = v;\n }\n\n /**\n * A signal emitted when the layout configuration is modified.\n *\n * #### Notes\n * This signal is emitted whenever the current layout configuration\n * may have changed.\n *\n * This signal is emitted asynchronously in a collapsed fashion, so\n * that multiple synchronous modifications results in only a single\n * emit of the signal.\n */\n get layoutModified(): ISignal {\n return this._layoutModified;\n }\n\n /**\n * A signal emitted when the add button on a tab bar is clicked.\n *\n */\n get addRequested(): ISignal> {\n return this._addRequested;\n }\n\n /**\n * The overlay used by the dock panel.\n */\n readonly overlay: DockPanel.IOverlay;\n\n /**\n * The renderer used by the dock panel.\n */\n get renderer(): DockPanel.IRenderer {\n return (this.layout as DockLayout).renderer;\n }\n\n /**\n * Get the spacing between the widgets.\n */\n get spacing(): number {\n return (this.layout as DockLayout).spacing;\n }\n\n /**\n * Set the spacing between the widgets.\n */\n set spacing(value: number) {\n (this.layout as DockLayout).spacing = value;\n }\n\n /**\n * Get the mode for the dock panel.\n */\n get mode(): DockPanel.Mode {\n return this._mode;\n }\n\n /**\n * Set the mode for the dock panel.\n *\n * #### Notes\n * Changing the mode is a destructive operation with respect to the\n * panel's layout configuration. If layout state must be preserved,\n * save the current layout config before changing the mode.\n */\n set mode(value: DockPanel.Mode) {\n // Bail early if the mode does not change.\n if (this._mode === value) {\n return;\n }\n\n // Update the internal mode.\n this._mode = value;\n\n // Toggle the CSS mode attribute.\n this.dataset['mode'] = value;\n\n // Get the layout for the panel.\n let layout = this.layout as DockLayout;\n\n // Configure the layout for the specified mode.\n switch (value) {\n case 'multiple-document':\n for (const tabBar of layout.tabBars()) {\n tabBar.show();\n }\n break;\n case 'single-document':\n layout.restoreLayout(Private.createSingleDocumentConfig(this));\n break;\n default:\n throw 'unreachable';\n }\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Whether the tabs can be dragged / moved at runtime.\n */\n get tabsMovable(): boolean {\n return this._tabsMovable;\n }\n\n /**\n * Enable / Disable draggable / movable tabs.\n */\n set tabsMovable(value: boolean) {\n this._tabsMovable = value;\n for (const tabBar of this.tabBars()) {\n tabBar.tabsMovable = value;\n }\n }\n\n /**\n * Whether the tabs are constrained to their source dock panel\n */\n get tabsConstrained(): boolean {\n return this._tabsConstrained;\n }\n\n /**\n * Constrain/Allow tabs to be dragged outside of this dock panel\n */\n set tabsConstrained(value: boolean) {\n this._tabsConstrained = value;\n }\n\n /**\n * Whether the add buttons for each tab bar are enabled.\n */\n get addButtonEnabled(): boolean {\n return this._addButtonEnabled;\n }\n\n /**\n * Set whether the add buttons for each tab bar are enabled.\n */\n set addButtonEnabled(value: boolean) {\n this._addButtonEnabled = value;\n for (const tabBar of this.tabBars()) {\n tabBar.addButtonEnabled = value;\n }\n }\n\n /**\n * Whether the dock panel is empty.\n */\n get isEmpty(): boolean {\n return (this.layout as DockLayout).isEmpty;\n }\n\n /**\n * Create an iterator over the user widgets in the panel.\n *\n * @returns A new iterator over the user widgets in the panel.\n *\n * #### Notes\n * This iterator does not include the generated tab bars.\n */\n *widgets(): IterableIterator {\n yield* (this.layout as DockLayout).widgets();\n }\n\n /**\n * Create an iterator over the selected widgets in the panel.\n *\n * @returns A new iterator over the selected user widgets.\n *\n * #### Notes\n * This iterator yields the widgets corresponding to the current tab\n * of each tab bar in the panel.\n */\n *selectedWidgets(): IterableIterator {\n yield* (this.layout as DockLayout).selectedWidgets();\n }\n\n /**\n * Create an iterator over the tab bars in the panel.\n *\n * @returns A new iterator over the tab bars in the panel.\n *\n * #### Notes\n * This iterator does not include the user widgets.\n */\n *tabBars(): IterableIterator> {\n yield* (this.layout as DockLayout).tabBars();\n }\n\n /**\n * Create an iterator over the handles in the panel.\n *\n * @returns A new iterator over the handles in the panel.\n */\n *handles(): IterableIterator {\n yield* (this.layout as DockLayout).handles();\n }\n\n /**\n * Select a specific widget in the dock panel.\n *\n * @param widget - The widget of interest.\n *\n * #### Notes\n * This will make the widget the current widget in its tab area.\n */\n selectWidget(widget: Widget): void {\n // Find the tab bar which contains the widget.\n let tabBar = find(this.tabBars(), bar => {\n return bar.titles.indexOf(widget.title) !== -1;\n });\n\n // Throw an error if no tab bar is found.\n if (!tabBar) {\n throw new Error('Widget is not contained in the dock panel.');\n }\n\n // Ensure the widget is the current widget.\n tabBar.currentTitle = widget.title;\n }\n\n /**\n * Activate a specified widget in the dock panel.\n *\n * @param widget - The widget of interest.\n *\n * #### Notes\n * This will select and activate the given widget.\n */\n activateWidget(widget: Widget): void {\n this.selectWidget(widget);\n widget.activate();\n }\n\n /**\n * Save the current layout configuration of the dock panel.\n *\n * @returns A new config object for the current layout state.\n *\n * #### Notes\n * The return value can be provided to the `restoreLayout` method\n * in order to restore the layout to its current configuration.\n */\n saveLayout(): DockPanel.ILayoutConfig {\n return (this.layout as DockLayout).saveLayout();\n }\n\n /**\n * Restore the layout to a previously saved configuration.\n *\n * @param config - The layout configuration to restore.\n *\n * #### Notes\n * Widgets which currently belong to the layout but which are not\n * contained in the config will be unparented.\n *\n * The dock panel automatically reverts to `'multiple-document'`\n * mode when a layout config is restored.\n */\n restoreLayout(config: DockPanel.ILayoutConfig): void {\n // Reset the mode.\n this._mode = 'multiple-document';\n\n // Restore the layout.\n (this.layout as DockLayout).restoreLayout(config);\n\n // Flush the message loop on IE and Edge to prevent flicker.\n if (Platform.IS_EDGE || Platform.IS_IE) {\n MessageLoop.flush();\n }\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Add a widget to the dock panel.\n *\n * @param widget - The widget to add to the dock panel.\n *\n * @param options - The additional options for adding the widget.\n *\n * #### Notes\n * If the panel is in single document mode, the options are ignored\n * and the widget is always added as tab in the hidden tab bar.\n */\n addWidget(widget: Widget, options: DockPanel.IAddOptions = {}): void {\n // Add the widget to the layout.\n if (this._mode === 'single-document') {\n (this.layout as DockLayout).addWidget(widget);\n } else {\n (this.layout as DockLayout).addWidget(widget, options);\n }\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Process a message sent to the widget.\n *\n * @param msg - The message sent to the widget.\n */\n processMessage(msg: Message): void {\n if (msg.type === 'layout-modified') {\n this._layoutModified.emit(undefined);\n } else {\n super.processMessage(msg);\n }\n }\n\n /**\n * Handle the DOM events for the dock panel.\n *\n * @param event - The DOM event sent to the panel.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the panel's DOM node. It should\n * not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'lm-dragenter':\n this._evtDragEnter(event as Drag.Event);\n break;\n case 'lm-dragleave':\n this._evtDragLeave(event as Drag.Event);\n break;\n case 'lm-dragover':\n this._evtDragOver(event as Drag.Event);\n break;\n case 'lm-drop':\n this._evtDrop(event as Drag.Event);\n break;\n case 'pointerdown':\n this._evtPointerDown(event as PointerEvent);\n break;\n case 'pointermove':\n this._evtPointerMove(event as PointerEvent);\n break;\n case 'pointerup':\n this._evtPointerUp(event as PointerEvent);\n break;\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('lm-dragenter', this);\n this.node.addEventListener('lm-dragleave', this);\n this.node.addEventListener('lm-dragover', this);\n this.node.addEventListener('lm-drop', this);\n this.node.addEventListener('pointerdown', this);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('lm-dragenter', this);\n this.node.removeEventListener('lm-dragleave', this);\n this.node.removeEventListener('lm-dragover', this);\n this.node.removeEventListener('lm-drop', this);\n this.node.removeEventListener('pointerdown', this);\n this._releaseMouse();\n }\n\n /**\n * A message handler invoked on a `'child-added'` message.\n */\n protected onChildAdded(msg: Widget.ChildMessage): void {\n // Ignore the generated tab bars.\n if (Private.isGeneratedTabBarProperty.get(msg.child)) {\n return;\n }\n\n // Add the widget class to the child.\n msg.child.addClass('lm-DockPanel-widget');\n }\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {\n // Ignore the generated tab bars.\n if (Private.isGeneratedTabBarProperty.get(msg.child)) {\n return;\n }\n\n // Remove the widget class from the child.\n msg.child.removeClass('lm-DockPanel-widget');\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Handle the `'lm-dragenter'` event for the dock panel.\n */\n private _evtDragEnter(event: Drag.Event): void {\n // If the factory mime type is present, mark the event as\n // handled in order to get the rest of the drag events.\n if (event.mimeData.hasData('application/vnd.lumino.widget-factory')) {\n event.preventDefault();\n event.stopPropagation();\n }\n }\n\n /**\n * Handle the `'lm-dragleave'` event for the dock panel.\n */\n private _evtDragLeave(event: Drag.Event): void {\n // Mark the event as handled.\n event.preventDefault();\n\n if (this._tabsConstrained && event.source !== this) return;\n\n event.stopPropagation();\n\n // The new target might be a descendant, so we might still handle the drop.\n // Hide asynchronously so that if a lm-dragover event bubbles up to us, the\n // hide is cancelled by the lm-dragover handler's show overlay logic.\n this.overlay.hide(1);\n }\n\n /**\n * Handle the `'lm-dragover'` event for the dock panel.\n */\n private _evtDragOver(event: Drag.Event): void {\n // Mark the event as handled.\n event.preventDefault();\n\n // Show the drop indicator overlay and update the drop\n // action based on the drop target zone under the mouse.\n if (\n (this._tabsConstrained && event.source !== this) ||\n this._showOverlay(event.clientX, event.clientY) === 'invalid'\n ) {\n event.dropAction = 'none';\n } else {\n event.stopPropagation();\n event.dropAction = event.proposedAction;\n }\n }\n\n /**\n * Handle the `'lm-drop'` event for the dock panel.\n */\n private _evtDrop(event: Drag.Event): void {\n // Mark the event as handled.\n event.preventDefault();\n\n // Hide the drop indicator overlay.\n this.overlay.hide(0);\n\n // Bail if the proposed action is to do nothing.\n if (event.proposedAction === 'none') {\n event.dropAction = 'none';\n return;\n }\n\n // Find the drop target under the mouse.\n let { clientX, clientY } = event;\n let { zone, target } = Private.findDropTarget(\n this,\n clientX,\n clientY,\n this._edges\n );\n\n // Bail if the drop zone is invalid.\n if (\n (this._tabsConstrained && event.source !== this) ||\n zone === 'invalid'\n ) {\n event.dropAction = 'none';\n return;\n }\n\n // Bail if the factory mime type has invalid data.\n let mimeData = event.mimeData;\n let factory = mimeData.getData('application/vnd.lumino.widget-factory');\n if (typeof factory !== 'function') {\n event.dropAction = 'none';\n return;\n }\n\n // Bail if the factory does not produce a widget.\n let widget = factory();\n if (!(widget instanceof Widget)) {\n event.dropAction = 'none';\n return;\n }\n\n // Bail if the widget is an ancestor of the dock panel.\n if (widget.contains(this)) {\n event.dropAction = 'none';\n return;\n }\n\n // Find the reference widget for the drop target.\n let ref = target ? Private.getDropRef(target.tabBar) : null;\n\n // Add the widget according to the indicated drop zone.\n switch (zone) {\n case 'root-all':\n this.addWidget(widget);\n break;\n case 'root-top':\n this.addWidget(widget, { mode: 'split-top' });\n break;\n case 'root-left':\n this.addWidget(widget, { mode: 'split-left' });\n break;\n case 'root-right':\n this.addWidget(widget, { mode: 'split-right' });\n break;\n case 'root-bottom':\n this.addWidget(widget, { mode: 'split-bottom' });\n break;\n case 'widget-all':\n this.addWidget(widget, { mode: 'tab-after', ref });\n break;\n case 'widget-top':\n this.addWidget(widget, { mode: 'split-top', ref });\n break;\n case 'widget-left':\n this.addWidget(widget, { mode: 'split-left', ref });\n break;\n case 'widget-right':\n this.addWidget(widget, { mode: 'split-right', ref });\n break;\n case 'widget-bottom':\n this.addWidget(widget, { mode: 'split-bottom', ref });\n break;\n case 'widget-tab':\n this.addWidget(widget, { mode: 'tab-after', ref });\n break;\n default:\n throw 'unreachable';\n }\n\n // Accept the proposed drop action.\n event.dropAction = event.proposedAction;\n\n // Stop propagation if we have not bailed so far.\n event.stopPropagation();\n\n // Activate the dropped widget.\n this.activateWidget(widget);\n }\n\n /**\n * Handle the `'keydown'` event for the dock panel.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // Stop input events during drag.\n event.preventDefault();\n event.stopPropagation();\n\n // Release the mouse if `Escape` is pressed.\n if (event.keyCode === 27) {\n // Finalize the mouse release.\n this._releaseMouse();\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n }\n\n /**\n * Handle the `'pointerdown'` event for the dock panel.\n */\n private _evtPointerDown(event: PointerEvent): void {\n // Do nothing if the left mouse button is not pressed.\n if (event.button !== 0) {\n return;\n }\n\n // Find the handle which contains the mouse target, if any.\n let layout = this.layout as DockLayout;\n let target = event.target as HTMLElement;\n let handle = find(layout.handles(), handle => handle.contains(target));\n if (!handle) {\n return;\n }\n\n // Stop the event when a handle is pressed.\n event.preventDefault();\n event.stopPropagation();\n\n // Add the extra document listeners.\n this._document.addEventListener('keydown', this, true);\n this._document.addEventListener('pointerup', this, true);\n this._document.addEventListener('pointermove', this, true);\n this._document.addEventListener('contextmenu', this, true);\n\n // Compute the offset deltas for the handle press.\n let rect = handle.getBoundingClientRect();\n let deltaX = event.clientX - rect.left;\n let deltaY = event.clientY - rect.top;\n\n // Override the cursor and store the press data.\n let style = window.getComputedStyle(handle);\n let override = Drag.overrideCursor(style.cursor!, this._document);\n this._pressData = { handle, deltaX, deltaY, override };\n }\n\n /**\n * Handle the `'pointermove'` event for the dock panel.\n */\n private _evtPointerMove(event: PointerEvent): void {\n // Bail early if no drag is in progress.\n if (!this._pressData) {\n return;\n }\n\n // Stop the event when dragging a handle.\n event.preventDefault();\n event.stopPropagation();\n\n // Compute the desired offset position for the handle.\n let rect = this.node.getBoundingClientRect();\n let xPos = event.clientX - rect.left - this._pressData.deltaX;\n let yPos = event.clientY - rect.top - this._pressData.deltaY;\n\n // Set the handle as close to the desired position as possible.\n let layout = this.layout as DockLayout;\n layout.moveHandle(this._pressData.handle, xPos, yPos);\n }\n\n /**\n * Handle the `'pointerup'` event for the dock panel.\n */\n private _evtPointerUp(event: PointerEvent): void {\n // Do nothing if the left mouse button is not released.\n if (event.button !== 0) {\n return;\n }\n\n // Stop the event when releasing a handle.\n event.preventDefault();\n event.stopPropagation();\n\n // Finalize the mouse release.\n this._releaseMouse();\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Release the mouse grab for the dock panel.\n */\n private _releaseMouse(): void {\n // Bail early if no drag is in progress.\n if (!this._pressData) {\n return;\n }\n\n // Clear the override cursor.\n this._pressData.override.dispose();\n this._pressData = null;\n\n // Remove the extra document listeners.\n this._document.removeEventListener('keydown', this, true);\n this._document.removeEventListener('pointerup', this, true);\n this._document.removeEventListener('pointermove', this, true);\n this._document.removeEventListener('contextmenu', this, true);\n }\n\n /**\n * Show the overlay indicator at the given client position.\n *\n * Returns the drop zone at the specified client position.\n *\n * #### Notes\n * If the position is not over a valid zone, the overlay is hidden.\n */\n private _showOverlay(clientX: number, clientY: number): Private.DropZone {\n // Find the dock target for the given client position.\n let { zone, target } = Private.findDropTarget(\n this,\n clientX,\n clientY,\n this._edges\n );\n\n // If the drop zone is invalid, hide the overlay and bail.\n if (zone === 'invalid') {\n this.overlay.hide(100);\n return zone;\n }\n\n // Setup the variables needed to compute the overlay geometry.\n let top: number;\n let left: number;\n let right: number;\n let bottom: number;\n let box = ElementExt.boxSizing(this.node); // TODO cache this?\n let rect = this.node.getBoundingClientRect();\n\n // Compute the overlay geometry based on the dock zone.\n switch (zone) {\n case 'root-all':\n top = box.paddingTop;\n left = box.paddingLeft;\n right = box.paddingRight;\n bottom = box.paddingBottom;\n break;\n case 'root-top':\n top = box.paddingTop;\n left = box.paddingLeft;\n right = box.paddingRight;\n bottom = rect.height * Private.GOLDEN_RATIO;\n break;\n case 'root-left':\n top = box.paddingTop;\n left = box.paddingLeft;\n right = rect.width * Private.GOLDEN_RATIO;\n bottom = box.paddingBottom;\n break;\n case 'root-right':\n top = box.paddingTop;\n left = rect.width * Private.GOLDEN_RATIO;\n right = box.paddingRight;\n bottom = box.paddingBottom;\n break;\n case 'root-bottom':\n top = rect.height * Private.GOLDEN_RATIO;\n left = box.paddingLeft;\n right = box.paddingRight;\n bottom = box.paddingBottom;\n break;\n case 'widget-all':\n top = target!.top;\n left = target!.left;\n right = target!.right;\n bottom = target!.bottom;\n break;\n case 'widget-top':\n top = target!.top;\n left = target!.left;\n right = target!.right;\n bottom = target!.bottom + target!.height / 2;\n break;\n case 'widget-left':\n top = target!.top;\n left = target!.left;\n right = target!.right + target!.width / 2;\n bottom = target!.bottom;\n break;\n case 'widget-right':\n top = target!.top;\n left = target!.left + target!.width / 2;\n right = target!.right;\n bottom = target!.bottom;\n break;\n case 'widget-bottom':\n top = target!.top + target!.height / 2;\n left = target!.left;\n right = target!.right;\n bottom = target!.bottom;\n break;\n case 'widget-tab': {\n const tabHeight = target!.tabBar.node.getBoundingClientRect().height;\n top = target!.top;\n left = target!.left;\n right = target!.right;\n bottom = target!.bottom + target!.height - tabHeight;\n break;\n }\n default:\n throw 'unreachable';\n }\n\n // Show the overlay with the computed geometry.\n this.overlay.show({ top, left, right, bottom });\n\n // Finally, return the computed drop zone.\n return zone;\n }\n\n /**\n * Create a new tab bar for use by the panel.\n */\n private _createTabBar(): TabBar {\n // Create the tab bar.\n let tabBar = this._renderer.createTabBar(this._document);\n\n // Set the generated tab bar property for the tab bar.\n Private.isGeneratedTabBarProperty.set(tabBar, true);\n\n // Hide the tab bar when in single document mode.\n if (this._mode === 'single-document') {\n tabBar.hide();\n }\n\n // Enforce necessary tab bar behavior.\n // TODO do we really want to enforce *all* of these?\n tabBar.tabsMovable = this._tabsMovable;\n tabBar.allowDeselect = false;\n tabBar.addButtonEnabled = this._addButtonEnabled;\n tabBar.removeBehavior = 'select-previous-tab';\n tabBar.insertBehavior = 'select-tab-if-needed';\n\n // Connect the signal handlers for the tab bar.\n tabBar.tabMoved.connect(this._onTabMoved, this);\n tabBar.currentChanged.connect(this._onCurrentChanged, this);\n tabBar.tabCloseRequested.connect(this._onTabCloseRequested, this);\n tabBar.tabDetachRequested.connect(this._onTabDetachRequested, this);\n tabBar.tabActivateRequested.connect(this._onTabActivateRequested, this);\n tabBar.addRequested.connect(this._onTabAddRequested, this);\n\n // Return the initialized tab bar.\n return tabBar;\n }\n\n /**\n * Create a new handle for use by the panel.\n */\n private _createHandle(): HTMLDivElement {\n return this._renderer.createHandle();\n }\n\n /**\n * Handle the `tabMoved` signal from a tab bar.\n */\n private _onTabMoved(): void {\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Handle the `currentChanged` signal from a tab bar.\n */\n private _onCurrentChanged(\n sender: TabBar,\n args: TabBar.ICurrentChangedArgs\n ): void {\n // Extract the previous and current title from the args.\n let { previousTitle, currentTitle } = args;\n\n // Hide the previous widget.\n if (previousTitle) {\n previousTitle.owner.hide();\n }\n\n // Show the current widget.\n if (currentTitle) {\n currentTitle.owner.show();\n }\n\n // Flush the message loop on IE and Edge to prevent flicker.\n if (Platform.IS_EDGE || Platform.IS_IE) {\n MessageLoop.flush();\n }\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Handle the `addRequested` signal from a tab bar.\n */\n private _onTabAddRequested(sender: TabBar): void {\n this._addRequested.emit(sender);\n }\n\n /**\n * Handle the `tabActivateRequested` signal from a tab bar.\n */\n private _onTabActivateRequested(\n sender: TabBar,\n args: TabBar.ITabActivateRequestedArgs\n ): void {\n args.title.owner.activate();\n }\n\n /**\n * Handle the `tabCloseRequested` signal from a tab bar.\n */\n private _onTabCloseRequested(\n sender: TabBar,\n args: TabBar.ITabCloseRequestedArgs\n ): void {\n args.title.owner.close();\n }\n\n /**\n * Handle the `tabDetachRequested` signal from a tab bar.\n */\n private _onTabDetachRequested(\n sender: TabBar,\n args: TabBar.ITabDetachRequestedArgs\n ): void {\n // Do nothing if a drag is already in progress.\n if (this._drag) {\n return;\n }\n\n // Release the tab bar's hold on the mouse.\n sender.releaseMouse();\n\n // Extract the data from the args.\n let { title, tab, clientX, clientY, offset } = args;\n\n // Setup the mime data for the drag operation.\n let mimeData = new MimeData();\n let factory = () => title.owner;\n mimeData.setData('application/vnd.lumino.widget-factory', factory);\n\n // Create the drag image for the drag operation.\n let dragImage = tab.cloneNode(true) as HTMLElement;\n if (offset) {\n dragImage.style.top = `-${offset.y}px`;\n dragImage.style.left = `-${offset.x}px`;\n }\n\n // Create the drag object to manage the drag-drop operation.\n this._drag = new Drag({\n document: this._document,\n mimeData,\n dragImage,\n proposedAction: 'move',\n supportedActions: 'move',\n source: this\n });\n\n // Hide the tab node in the original tab.\n tab.classList.add('lm-mod-hidden');\n let cleanup = () => {\n this._drag = null;\n tab.classList.remove('lm-mod-hidden');\n };\n\n // Start the drag operation and cleanup when done.\n this._drag.start(clientX, clientY).then(cleanup);\n }\n\n private _edges: DockPanel.IEdges;\n private _document: Document | ShadowRoot;\n private _mode: DockPanel.Mode;\n private _drag: Drag | null = null;\n private _renderer: DockPanel.IRenderer;\n private _tabsMovable: boolean = true;\n private _tabsConstrained: boolean = false;\n private _addButtonEnabled: boolean = false;\n private _pressData: Private.IPressData | null = null;\n private _layoutModified = new Signal(this);\n\n private _addRequested = new Signal>(this);\n}\n\n/**\n * The namespace for the `DockPanel` class statics.\n */\nexport namespace DockPanel {\n /**\n * An options object for creating a dock panel.\n */\n export interface IOptions {\n /**\n * The document to use with the dock panel.\n *\n * The default is the global `document` instance.\n */\n\n document?: Document | ShadowRoot;\n /**\n * The overlay to use with the dock panel.\n *\n * The default is a new `Overlay` instance.\n */\n overlay?: IOverlay;\n\n /**\n * The renderer to use for the dock panel.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n\n /**\n * The spacing between the items in the panel.\n *\n * The default is `4`.\n */\n spacing?: number;\n\n /**\n * The mode for the dock panel.\n *\n * The default is `'multiple-document'`.\n */\n mode?: DockPanel.Mode;\n\n /**\n * The sizes of the edge drop zones, in pixels.\n * If not given, default values will be used.\n */\n edges?: IEdges;\n\n /**\n * The method for hiding widgets.\n *\n * The default is `Widget.HiddenMode.Display`.\n */\n hiddenMode?: Widget.HiddenMode;\n\n /**\n * Allow tabs to be draggable / movable by user.\n *\n * The default is `'true'`.\n */\n tabsMovable?: boolean;\n\n /**\n * Constrain tabs to this dock panel\n *\n * The default is `'false'`.\n */\n tabsConstrained?: boolean;\n\n /**\n * Enable add buttons in each of the dock panel's tab bars.\n *\n * The default is `'false'`.\n */\n addButtonEnabled?: boolean;\n }\n\n /**\n * The sizes of the edge drop zones, in pixels.\n */\n export interface IEdges {\n /**\n * The size of the top edge drop zone.\n */\n top: number;\n\n /**\n * The size of the right edge drop zone.\n */\n right: number;\n\n /**\n * The size of the bottom edge drop zone.\n */\n bottom: number;\n\n /**\n * The size of the left edge drop zone.\n */\n left: number;\n }\n\n /**\n * A type alias for the supported dock panel modes.\n */\n export type Mode =\n | /**\n * The single document mode.\n *\n * In this mode, only a single widget is visible at a time, and that\n * widget fills the available layout space. No tab bars are visible.\n */\n 'single-document'\n\n /**\n * The multiple document mode.\n *\n * In this mode, multiple documents are displayed in separate tab\n * areas, and those areas can be individually resized by the user.\n */\n | 'multiple-document';\n\n /**\n * A type alias for a layout configuration object.\n */\n export type ILayoutConfig = DockLayout.ILayoutConfig;\n\n /**\n * A type alias for the supported insertion modes.\n */\n export type InsertMode = DockLayout.InsertMode;\n\n /**\n * A type alias for the add widget options.\n */\n export type IAddOptions = DockLayout.IAddOptions;\n\n /**\n * An object which holds the geometry for overlay positioning.\n */\n export interface IOverlayGeometry {\n /**\n * The distance between the overlay and parent top edges.\n */\n top: number;\n\n /**\n * The distance between the overlay and parent left edges.\n */\n left: number;\n\n /**\n * The distance between the overlay and parent right edges.\n */\n right: number;\n\n /**\n * The distance between the overlay and parent bottom edges.\n */\n bottom: number;\n }\n\n /**\n * An object which manages the overlay node for a dock panel.\n */\n export interface IOverlay {\n /**\n * The DOM node for the overlay.\n */\n readonly node: HTMLDivElement;\n\n /**\n * Show the overlay using the given overlay geometry.\n *\n * @param geo - The desired geometry for the overlay.\n *\n * #### Notes\n * The given geometry values assume the node will use absolute\n * positioning.\n *\n * This is called on every mouse move event during a drag in order\n * to update the position of the overlay. It should be efficient.\n */\n show(geo: IOverlayGeometry): void;\n\n /**\n * Hide the overlay node.\n *\n * @param delay - The delay (in ms) before hiding the overlay.\n * A delay value <= 0 should hide the overlay immediately.\n *\n * #### Notes\n * This is called whenever the overlay node should been hidden.\n */\n hide(delay: number): void;\n }\n\n /**\n * A concrete implementation of `IOverlay`.\n *\n * This is the default overlay implementation for a dock panel.\n */\n export class Overlay implements IOverlay {\n /**\n * Construct a new overlay.\n */\n constructor() {\n this.node = document.createElement('div');\n this.node.classList.add('lm-DockPanel-overlay');\n this.node.classList.add('lm-mod-hidden');\n this.node.style.position = 'absolute';\n this.node.style.contain = 'strict';\n }\n\n /**\n * The DOM node for the overlay.\n */\n readonly node: HTMLDivElement;\n\n /**\n * Show the overlay using the given overlay geometry.\n *\n * @param geo - The desired geometry for the overlay.\n */\n show(geo: IOverlayGeometry): void {\n // Update the position of the overlay.\n let style = this.node.style;\n style.top = `${geo.top}px`;\n style.left = `${geo.left}px`;\n style.right = `${geo.right}px`;\n style.bottom = `${geo.bottom}px`;\n\n // Clear any pending hide timer.\n clearTimeout(this._timer);\n this._timer = -1;\n\n // If the overlay is already visible, we're done.\n if (!this._hidden) {\n return;\n }\n\n // Clear the hidden flag.\n this._hidden = false;\n\n // Finally, show the overlay.\n this.node.classList.remove('lm-mod-hidden');\n }\n\n /**\n * Hide the overlay node.\n *\n * @param delay - The delay (in ms) before hiding the overlay.\n * A delay value <= 0 will hide the overlay immediately.\n */\n hide(delay: number): void {\n // Do nothing if the overlay is already hidden.\n if (this._hidden) {\n return;\n }\n\n // Hide immediately if the delay is <= 0.\n if (delay <= 0) {\n clearTimeout(this._timer);\n this._timer = -1;\n this._hidden = true;\n this.node.classList.add('lm-mod-hidden');\n return;\n }\n\n // Do nothing if a hide is already pending.\n if (this._timer !== -1) {\n return;\n }\n\n // Otherwise setup the hide timer.\n this._timer = window.setTimeout(() => {\n this._timer = -1;\n this._hidden = true;\n this.node.classList.add('lm-mod-hidden');\n }, delay);\n }\n\n private _timer = -1;\n private _hidden = true;\n }\n\n /**\n * A type alias for a dock panel renderer;\n */\n export type IRenderer = DockLayout.IRenderer;\n\n /**\n * The default implementation of `IRenderer`.\n */\n export class Renderer implements IRenderer {\n /**\n * Create a new tab bar for use with a dock panel.\n *\n * @returns A new tab bar for a dock panel.\n */\n createTabBar(document?: Document | ShadowRoot): TabBar {\n let bar = new TabBar({ document });\n bar.addClass('lm-DockPanel-tabBar');\n return bar;\n }\n\n /**\n * Create a new handle node for use with a dock panel.\n *\n * @returns A new handle node for a dock panel.\n */\n createHandle(): HTMLDivElement {\n let handle = document.createElement('div');\n handle.className = 'lm-DockPanel-handle';\n return handle;\n }\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * A fraction used for sizing root panels; ~= `1 / golden_ratio`.\n */\n export const GOLDEN_RATIO = 0.618;\n\n /**\n * The default sizes for the edge drop zones, in pixels.\n */\n export const DEFAULT_EDGES = {\n /**\n * The size of the top edge dock zone for the root panel, in pixels.\n * This is different from the others to distinguish between the top\n * tab bar and the top root zone.\n */\n top: 12,\n\n /**\n * The size of the edge dock zone for the root panel, in pixels.\n */\n right: 40,\n\n /**\n * The size of the edge dock zone for the root panel, in pixels.\n */\n bottom: 40,\n\n /**\n * The size of the edge dock zone for the root panel, in pixels.\n */\n left: 40\n };\n\n /**\n * A singleton `'layout-modified'` conflatable message.\n */\n export const LayoutModified = new ConflatableMessage('layout-modified');\n\n /**\n * An object which holds mouse press data.\n */\n export interface IPressData {\n /**\n * The handle which was pressed.\n */\n handle: HTMLDivElement;\n\n /**\n * The X offset of the press in handle coordinates.\n */\n deltaX: number;\n\n /**\n * The Y offset of the press in handle coordinates.\n */\n deltaY: number;\n\n /**\n * The disposable which will clear the override cursor.\n */\n override: IDisposable;\n }\n\n /**\n * A type alias for a drop zone.\n */\n export type DropZone =\n | /**\n * An invalid drop zone.\n */\n 'invalid'\n\n /**\n * The entirety of the root dock area.\n */\n | 'root-all'\n\n /**\n * The top portion of the root dock area.\n */\n | 'root-top'\n\n /**\n * The left portion of the root dock area.\n */\n | 'root-left'\n\n /**\n * The right portion of the root dock area.\n */\n | 'root-right'\n\n /**\n * The bottom portion of the root dock area.\n */\n | 'root-bottom'\n\n /**\n * The entirety of a tabbed widget area.\n */\n | 'widget-all'\n\n /**\n * The top portion of tabbed widget area.\n */\n | 'widget-top'\n\n /**\n * The left portion of tabbed widget area.\n */\n | 'widget-left'\n\n /**\n * The right portion of tabbed widget area.\n */\n | 'widget-right'\n\n /**\n * The bottom portion of tabbed widget area.\n */\n | 'widget-bottom'\n\n /**\n * The the bar of a tabbed widget area.\n */\n | 'widget-tab';\n\n /**\n * An object which holds the drop target zone and widget.\n */\n export interface IDropTarget {\n /**\n * The semantic zone for the mouse position.\n */\n zone: DropZone;\n\n /**\n * The tab area geometry for the drop zone, or `null`.\n */\n target: DockLayout.ITabAreaGeometry | null;\n }\n\n /**\n * An attached property used to track generated tab bars.\n */\n export const isGeneratedTabBarProperty = new AttachedProperty<\n Widget,\n boolean\n >({\n name: 'isGeneratedTabBar',\n create: () => false\n });\n\n /**\n * Create a single document config for the widgets in a dock panel.\n */\n export function createSingleDocumentConfig(\n panel: DockPanel\n ): DockPanel.ILayoutConfig {\n // Return an empty config if the panel is empty.\n if (panel.isEmpty) {\n return { main: null };\n }\n\n // Get a flat array of the widgets in the panel.\n let widgets = Array.from(panel.widgets());\n\n // Get the first selected widget in the panel.\n let selected = panel.selectedWidgets().next().value;\n\n // Compute the current index for the new config.\n let currentIndex = selected ? widgets.indexOf(selected) : -1;\n\n // Return the single document config.\n return { main: { type: 'tab-area', widgets, currentIndex } };\n }\n\n /**\n * Find the drop target at the given client position.\n */\n export function findDropTarget(\n panel: DockPanel,\n clientX: number,\n clientY: number,\n edges: DockPanel.IEdges\n ): IDropTarget {\n // Bail if the mouse is not over the dock panel.\n if (!ElementExt.hitTest(panel.node, clientX, clientY)) {\n return { zone: 'invalid', target: null };\n }\n\n // Look up the layout for the panel.\n let layout = panel.layout as DockLayout;\n\n // If the layout is empty, indicate the entire root drop zone.\n if (layout.isEmpty) {\n return { zone: 'root-all', target: null };\n }\n\n // Test the edge zones when in multiple document mode.\n if (panel.mode === 'multiple-document') {\n // Get the client rect for the dock panel.\n let panelRect = panel.node.getBoundingClientRect();\n\n // Compute the distance to each edge of the panel.\n let pl = clientX - panelRect.left + 1;\n let pt = clientY - panelRect.top + 1;\n let pr = panelRect.right - clientX;\n let pb = panelRect.bottom - clientY;\n\n // Find the minimum distance to an edge.\n let pd = Math.min(pt, pr, pb, pl);\n\n // Return a root zone if the mouse is within an edge.\n switch (pd) {\n case pt:\n if (pt < edges.top) {\n return { zone: 'root-top', target: null };\n }\n break;\n case pr:\n if (pr < edges.right) {\n return { zone: 'root-right', target: null };\n }\n break;\n case pb:\n if (pb < edges.bottom) {\n return { zone: 'root-bottom', target: null };\n }\n break;\n case pl:\n if (pl < edges.left) {\n return { zone: 'root-left', target: null };\n }\n break;\n default:\n throw 'unreachable';\n }\n }\n\n // Hit test the dock layout at the given client position.\n let target = layout.hitTestTabAreas(clientX, clientY);\n\n // Bail if no target area was found.\n if (!target) {\n return { zone: 'invalid', target: null };\n }\n\n // Return the whole tab area when in single document mode.\n if (panel.mode === 'single-document') {\n return { zone: 'widget-all', target };\n }\n\n // Compute the distance to each edge of the tab area.\n let al = target.x - target.left + 1;\n let at = target.y - target.top + 1;\n let ar = target.left + target.width - target.x;\n let ab = target.top + target.height - target.y;\n\n const tabHeight = target.tabBar.node.getBoundingClientRect().height;\n if (at < tabHeight) {\n return { zone: 'widget-tab', target };\n }\n\n // Get the X and Y edge sizes for the area.\n let rx = Math.round(target.width / 3);\n let ry = Math.round(target.height / 3);\n\n // If the mouse is not within an edge, indicate the entire area.\n if (al > rx && ar > rx && at > ry && ab > ry) {\n return { zone: 'widget-all', target };\n }\n\n // Scale the distances by the slenderness ratio.\n al /= rx;\n at /= ry;\n ar /= rx;\n ab /= ry;\n\n // Find the minimum distance to the area edge.\n let ad = Math.min(al, at, ar, ab);\n\n // Find the widget zone for the area edge.\n let zone: DropZone;\n switch (ad) {\n case al:\n zone = 'widget-left';\n break;\n case at:\n zone = 'widget-top';\n break;\n case ar:\n zone = 'widget-right';\n break;\n case ab:\n zone = 'widget-bottom';\n break;\n default:\n throw 'unreachable';\n }\n\n // Return the final drop target.\n return { zone, target };\n }\n\n /**\n * Get the drop reference widget for a tab bar.\n */\n export function getDropRef(tabBar: TabBar): Widget | null {\n if (tabBar.titles.length === 0) {\n return null;\n }\n if (tabBar.currentTitle) {\n return tabBar.currentTitle.owner;\n }\n return tabBar.titles[tabBar.titles.length - 1].owner;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt, find, max } from '@lumino/algorithm';\n\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { Widget } from './widget';\n\n/**\n * A class which tracks focus among a set of widgets.\n *\n * This class is useful when code needs to keep track of the most\n * recently focused widget(s) among a set of related widgets.\n */\nexport class FocusTracker implements IDisposable {\n /**\n * Dispose of the resources held by the tracker.\n */\n dispose(): void {\n // Do nothing if the tracker is already disposed.\n if (this._counter < 0) {\n return;\n }\n\n // Mark the tracker as disposed.\n this._counter = -1;\n\n // Clear the connections for the tracker.\n Signal.clearData(this);\n\n // Remove all event listeners.\n for (const widget of this._widgets) {\n widget.node.removeEventListener('focus', this, true);\n widget.node.removeEventListener('blur', this, true);\n }\n\n // Clear the internal data structures.\n this._activeWidget = null;\n this._currentWidget = null;\n this._nodes.clear();\n this._numbers.clear();\n this._widgets.length = 0;\n }\n\n /**\n * A signal emitted when the current widget has changed.\n */\n get currentChanged(): ISignal> {\n return this._currentChanged;\n }\n\n /**\n * A signal emitted when the active widget has changed.\n */\n get activeChanged(): ISignal> {\n return this._activeChanged;\n }\n\n /**\n * A flag indicating whether the tracker is disposed.\n */\n get isDisposed(): boolean {\n return this._counter < 0;\n }\n\n /**\n * The current widget in the tracker.\n *\n * #### Notes\n * The current widget is the widget among the tracked widgets which\n * has the *descendant node* which has most recently been focused.\n *\n * The current widget will not be updated if the node loses focus. It\n * will only be updated when a different tracked widget gains focus.\n *\n * If the current widget is removed from the tracker, the previous\n * current widget will be restored.\n *\n * This behavior is intended to follow a user's conceptual model of\n * a semantically \"current\" widget, where the \"last thing of type X\"\n * to be interacted with is the \"current instance of X\", regardless\n * of whether that instance still has focus.\n */\n get currentWidget(): T | null {\n return this._currentWidget;\n }\n\n /**\n * The active widget in the tracker.\n *\n * #### Notes\n * The active widget is the widget among the tracked widgets which\n * has the *descendant node* which is currently focused.\n */\n get activeWidget(): T | null {\n return this._activeWidget;\n }\n\n /**\n * A read only array of the widgets being tracked.\n */\n get widgets(): ReadonlyArray {\n return this._widgets;\n }\n\n /**\n * Get the focus number for a particular widget in the tracker.\n *\n * @param widget - The widget of interest.\n *\n * @returns The focus number for the given widget, or `-1` if the\n * widget has not had focus since being added to the tracker, or\n * is not contained by the tracker.\n *\n * #### Notes\n * The focus number indicates the relative order in which the widgets\n * have gained focus. A widget with a larger number has gained focus\n * more recently than a widget with a smaller number.\n *\n * The `currentWidget` will always have the largest focus number.\n *\n * All widgets start with a focus number of `-1`, which indicates that\n * the widget has not been focused since being added to the tracker.\n */\n focusNumber(widget: T): number {\n let n = this._numbers.get(widget);\n return n === undefined ? -1 : n;\n }\n\n /**\n * Test whether the focus tracker contains a given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns `true` if the widget is tracked, `false` otherwise.\n */\n has(widget: T): boolean {\n return this._numbers.has(widget);\n }\n\n /**\n * Add a widget to the focus tracker.\n *\n * @param widget - The widget of interest.\n *\n * #### Notes\n * A widget will be automatically removed from the tracker if it\n * is disposed after being added.\n *\n * If the widget is already tracked, this is a no-op.\n */\n add(widget: T): void {\n // Do nothing if the widget is already tracked.\n if (this._numbers.has(widget)) {\n return;\n }\n\n // Test whether the widget has focus.\n let focused = widget.node.contains(document.activeElement);\n\n // Set up the initial focus number.\n let n = focused ? this._counter++ : -1;\n\n // Add the widget to the internal data structures.\n this._widgets.push(widget);\n this._numbers.set(widget, n);\n this._nodes.set(widget.node, widget);\n\n // Set up the event listeners. The capturing phase must be used\n // since the 'focus' and 'blur' events don't bubble and Firefox\n // doesn't support the 'focusin' or 'focusout' events.\n widget.node.addEventListener('focus', this, true);\n widget.node.addEventListener('blur', this, true);\n\n // Connect the disposed signal handler.\n widget.disposed.connect(this._onWidgetDisposed, this);\n\n // Set the current and active widgets if needed.\n if (focused) {\n this._setWidgets(widget, widget);\n }\n }\n\n /**\n * Remove a widget from the focus tracker.\n *\n * #### Notes\n * If the widget is the `currentWidget`, the previous current widget\n * will become the new `currentWidget`.\n *\n * A widget will be automatically removed from the tracker if it\n * is disposed after being added.\n *\n * If the widget is not tracked, this is a no-op.\n */\n remove(widget: T): void {\n // Bail early if the widget is not tracked.\n if (!this._numbers.has(widget)) {\n return;\n }\n\n // Disconnect the disposed signal handler.\n widget.disposed.disconnect(this._onWidgetDisposed, this);\n\n // Remove the event listeners.\n widget.node.removeEventListener('focus', this, true);\n widget.node.removeEventListener('blur', this, true);\n\n // Remove the widget from the internal data structures.\n ArrayExt.removeFirstOf(this._widgets, widget);\n this._nodes.delete(widget.node);\n this._numbers.delete(widget);\n\n // Bail early if the widget is not the current widget.\n if (this._currentWidget !== widget) {\n return;\n }\n\n // Filter the widgets for those which have had focus.\n let valid = this._widgets.filter(w => this._numbers.get(w) !== -1);\n\n // Get the valid widget with the max focus number.\n let previous =\n max(valid, (first, second) => {\n let a = this._numbers.get(first)!;\n let b = this._numbers.get(second)!;\n return a - b;\n }) || null;\n\n // Set the current and active widgets.\n this._setWidgets(previous, null);\n }\n\n /**\n * Handle the DOM events for the focus tracker.\n *\n * @param event - The DOM event sent to the panel.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the tracked nodes. It should\n * not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'focus':\n this._evtFocus(event as FocusEvent);\n break;\n case 'blur':\n this._evtBlur(event as FocusEvent);\n break;\n }\n }\n\n /**\n * Set the current and active widgets for the tracker.\n */\n private _setWidgets(current: T | null, active: T | null): void {\n // Swap the current widget.\n let oldCurrent = this._currentWidget;\n this._currentWidget = current;\n\n // Swap the active widget.\n let oldActive = this._activeWidget;\n this._activeWidget = active;\n\n // Emit the `currentChanged` signal if needed.\n if (oldCurrent !== current) {\n this._currentChanged.emit({ oldValue: oldCurrent, newValue: current });\n }\n\n // Emit the `activeChanged` signal if needed.\n if (oldActive !== active) {\n this._activeChanged.emit({ oldValue: oldActive, newValue: active });\n }\n }\n\n /**\n * Handle the `'focus'` event for a tracked widget.\n */\n private _evtFocus(event: FocusEvent): void {\n // Find the widget which gained focus, which is known to exist.\n let widget = this._nodes.get(event.currentTarget as HTMLElement)!;\n\n // Update the focus number if necessary.\n if (widget !== this._currentWidget) {\n this._numbers.set(widget, this._counter++);\n }\n\n // Set the current and active widgets.\n this._setWidgets(widget, widget);\n }\n\n /**\n * Handle the `'blur'` event for a tracked widget.\n */\n private _evtBlur(event: FocusEvent): void {\n // Find the widget which lost focus, which is known to exist.\n let widget = this._nodes.get(event.currentTarget as HTMLElement)!;\n\n // Get the node which being focused after this blur.\n let focusTarget = event.relatedTarget as HTMLElement;\n\n // If no other node is being focused, clear the active widget.\n if (!focusTarget) {\n this._setWidgets(this._currentWidget, null);\n return;\n }\n\n // Bail if the focus widget is not changing.\n if (widget.node.contains(focusTarget)) {\n return;\n }\n\n // If no tracked widget is being focused, clear the active widget.\n if (!find(this._widgets, w => w.node.contains(focusTarget))) {\n this._setWidgets(this._currentWidget, null);\n return;\n }\n }\n\n /**\n * Handle the `disposed` signal for a tracked widget.\n */\n private _onWidgetDisposed(sender: T): void {\n this.remove(sender);\n }\n\n private _counter = 0;\n private _widgets: T[] = [];\n private _activeWidget: T | null = null;\n private _currentWidget: T | null = null;\n private _numbers = new Map();\n private _nodes = new Map();\n private _activeChanged = new Signal>(this);\n private _currentChanged = new Signal>(\n this\n );\n}\n\n/**\n * The namespace for the `FocusTracker` class statics.\n */\nexport namespace FocusTracker {\n /**\n * An arguments object for the changed signals.\n */\n export interface IChangedArgs {\n /**\n * The old value for the widget.\n */\n oldValue: T | null;\n\n /**\n * The new value for the widget.\n */\n newValue: T | null;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { BoxEngine, BoxSizer } from './boxengine';\n\nimport { Layout, LayoutItem } from './layout';\n\nimport { Widget } from './widget';\n\n/**\n * A layout which arranges its widgets in a grid.\n */\nexport class GridLayout extends Layout {\n /**\n * Construct a new grid layout.\n *\n * @param options - The options for initializing the layout.\n */\n constructor(options: GridLayout.IOptions = {}) {\n super(options);\n if (options.rowCount !== undefined) {\n Private.reallocSizers(this._rowSizers, options.rowCount);\n }\n if (options.columnCount !== undefined) {\n Private.reallocSizers(this._columnSizers, options.columnCount);\n }\n if (options.rowSpacing !== undefined) {\n this._rowSpacing = Private.clampValue(options.rowSpacing);\n }\n if (options.columnSpacing !== undefined) {\n this._columnSpacing = Private.clampValue(options.columnSpacing);\n }\n }\n\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n // Dispose of the widgets and layout items.\n for (const item of this._items) {\n let widget = item.widget;\n item.dispose();\n widget.dispose();\n }\n\n // Clear the layout state.\n this._box = null;\n this._items.length = 0;\n this._rowStarts.length = 0;\n this._rowSizers.length = 0;\n this._columnStarts.length = 0;\n this._columnSizers.length = 0;\n\n // Dispose of the rest of the layout.\n super.dispose();\n }\n\n /**\n * Get the number of rows in the layout.\n */\n get rowCount(): number {\n return this._rowSizers.length;\n }\n\n /**\n * Set the number of rows in the layout.\n *\n * #### Notes\n * The minimum row count is `1`.\n */\n set rowCount(value: number) {\n // Do nothing if the row count does not change.\n if (value === this.rowCount) {\n return;\n }\n\n // Reallocate the row sizers.\n Private.reallocSizers(this._rowSizers, value);\n\n // Schedule a fit of the parent.\n if (this.parent) {\n this.parent.fit();\n }\n }\n\n /**\n * Get the number of columns in the layout.\n */\n get columnCount(): number {\n return this._columnSizers.length;\n }\n\n /**\n * Set the number of columns in the layout.\n *\n * #### Notes\n * The minimum column count is `1`.\n */\n set columnCount(value: number) {\n // Do nothing if the column count does not change.\n if (value === this.columnCount) {\n return;\n }\n\n // Reallocate the column sizers.\n Private.reallocSizers(this._columnSizers, value);\n\n // Schedule a fit of the parent.\n if (this.parent) {\n this.parent.fit();\n }\n }\n\n /**\n * Get the row spacing for the layout.\n */\n get rowSpacing(): number {\n return this._rowSpacing;\n }\n\n /**\n * Set the row spacing for the layout.\n */\n set rowSpacing(value: number) {\n // Clamp the spacing to the allowed range.\n value = Private.clampValue(value);\n\n // Bail if the spacing does not change\n if (this._rowSpacing === value) {\n return;\n }\n\n // Update the internal spacing.\n this._rowSpacing = value;\n\n // Schedule a fit of the parent.\n if (this.parent) {\n this.parent.fit();\n }\n }\n\n /**\n * Get the column spacing for the layout.\n */\n get columnSpacing(): number {\n return this._columnSpacing;\n }\n\n /**\n * Set the col spacing for the layout.\n */\n set columnSpacing(value: number) {\n // Clamp the spacing to the allowed range.\n value = Private.clampValue(value);\n\n // Bail if the spacing does not change\n if (this._columnSpacing === value) {\n return;\n }\n\n // Update the internal spacing.\n this._columnSpacing = value;\n\n // Schedule a fit of the parent.\n if (this.parent) {\n this.parent.fit();\n }\n }\n\n /**\n * Get the stretch factor for a specific row.\n *\n * @param index - The row index of interest.\n *\n * @returns The stretch factor for the row.\n *\n * #### Notes\n * This returns `-1` if the index is out of range.\n */\n rowStretch(index: number): number {\n let sizer = this._rowSizers[index];\n return sizer ? sizer.stretch : -1;\n }\n\n /**\n * Set the stretch factor for a specific row.\n *\n * @param index - The row index of interest.\n *\n * @param value - The stretch factor for the row.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n setRowStretch(index: number, value: number): void {\n // Look up the row sizer.\n let sizer = this._rowSizers[index];\n\n // Bail if the index is out of range.\n if (!sizer) {\n return;\n }\n\n // Clamp the value to the allowed range.\n value = Private.clampValue(value);\n\n // Bail if the stretch does not change.\n if (sizer.stretch === value) {\n return;\n }\n\n // Update the sizer stretch.\n sizer.stretch = value;\n\n // Schedule an update of the parent.\n if (this.parent) {\n this.parent.update();\n }\n }\n\n /**\n * Get the stretch factor for a specific column.\n *\n * @param index - The column index of interest.\n *\n * @returns The stretch factor for the column.\n *\n * #### Notes\n * This returns `-1` if the index is out of range.\n */\n columnStretch(index: number): number {\n let sizer = this._columnSizers[index];\n return sizer ? sizer.stretch : -1;\n }\n\n /**\n * Set the stretch factor for a specific column.\n *\n * @param index - The column index of interest.\n *\n * @param value - The stretch factor for the column.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n setColumnStretch(index: number, value: number): void {\n // Look up the column sizer.\n let sizer = this._columnSizers[index];\n\n // Bail if the index is out of range.\n if (!sizer) {\n return;\n }\n\n // Clamp the value to the allowed range.\n value = Private.clampValue(value);\n\n // Bail if the stretch does not change.\n if (sizer.stretch === value) {\n return;\n }\n\n // Update the sizer stretch.\n sizer.stretch = value;\n\n // Schedule an update of the parent.\n if (this.parent) {\n this.parent.update();\n }\n }\n\n /**\n * Create an iterator over the widgets in the layout.\n *\n * @returns A new iterator over the widgets in the layout.\n */\n *[Symbol.iterator](): IterableIterator {\n for (const item of this._items) {\n yield item.widget;\n }\n }\n\n /**\n * Add a widget to the grid layout.\n *\n * @param widget - The widget to add to the layout.\n *\n * #### Notes\n * If the widget is already contained in the layout, this is no-op.\n */\n addWidget(widget: Widget): void {\n // Look up the index for the widget.\n let i = ArrayExt.findFirstIndex(this._items, it => it.widget === widget);\n\n // Bail if the widget is already in the layout.\n if (i !== -1) {\n return;\n }\n\n // Add the widget to the layout.\n this._items.push(new LayoutItem(widget));\n\n // Attach the widget to the parent.\n if (this.parent) {\n this.attachWidget(widget);\n }\n }\n\n /**\n * Remove a widget from the grid layout.\n *\n * @param widget - The widget to remove from the layout.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method does *not* modify the widget's `parent`.\n */\n removeWidget(widget: Widget): void {\n // Look up the index for the widget.\n let i = ArrayExt.findFirstIndex(this._items, it => it.widget === widget);\n\n // Bail if the widget is not in the layout.\n if (i === -1) {\n return;\n }\n\n // Remove the widget from the layout.\n let item = ArrayExt.removeAt(this._items, i)!;\n\n // Detach the widget from the parent.\n if (this.parent) {\n this.detachWidget(widget);\n }\n\n // Dispose the layout item.\n item.dispose();\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n super.init();\n for (const widget of this) {\n this.attachWidget(widget);\n }\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param widget - The widget to attach to the parent.\n */\n protected attachWidget(widget: Widget): void {\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget's node to the parent.\n this.parent!.node.appendChild(widget.node);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param widget - The widget to detach from the parent.\n */\n protected detachWidget(widget: Widget): void {\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n */\n protected onBeforeShow(msg: Message): void {\n super.onBeforeShow(msg);\n this.parent!.update();\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n super.onBeforeAttach(msg);\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n if (this.parent!.isVisible) {\n this._update(msg.width, msg.height);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.parent!.isVisible) {\n this._update(-1, -1);\n }\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n */\n protected onFitRequest(msg: Message): void {\n if (this.parent!.isAttached) {\n this._fit();\n }\n }\n\n /**\n * Fit the layout to the total size required by the widgets.\n */\n private _fit(): void {\n // Reset the min sizes of the sizers.\n for (let i = 0, n = this.rowCount; i < n; ++i) {\n this._rowSizers[i].minSize = 0;\n }\n for (let i = 0, n = this.columnCount; i < n; ++i) {\n this._columnSizers[i].minSize = 0;\n }\n\n // Filter for the visible layout items.\n let items = this._items.filter(it => !it.isHidden);\n\n // Fit the layout items.\n for (let i = 0, n = items.length; i < n; ++i) {\n items[i].fit();\n }\n\n // Get the max row and column index.\n let maxRow = this.rowCount - 1;\n let maxCol = this.columnCount - 1;\n\n // Sort the items by row span.\n items.sort(Private.rowSpanCmp);\n\n // Update the min sizes of the row sizers.\n for (let i = 0, n = items.length; i < n; ++i) {\n // Fetch the item.\n let item = items[i];\n\n // Get the row bounds for the item.\n let config = GridLayout.getCellConfig(item.widget);\n let r1 = Math.min(config.row, maxRow);\n let r2 = Math.min(config.row + config.rowSpan - 1, maxRow);\n\n // Distribute the minimum height to the sizers as needed.\n Private.distributeMin(this._rowSizers, r1, r2, item.minHeight);\n }\n\n // Sort the items by column span.\n items.sort(Private.columnSpanCmp);\n\n // Update the min sizes of the column sizers.\n for (let i = 0, n = items.length; i < n; ++i) {\n // Fetch the item.\n let item = items[i];\n\n // Get the column bounds for the item.\n let config = GridLayout.getCellConfig(item.widget);\n let c1 = Math.min(config.column, maxCol);\n let c2 = Math.min(config.column + config.columnSpan - 1, maxCol);\n\n // Distribute the minimum width to the sizers as needed.\n Private.distributeMin(this._columnSizers, c1, c2, item.minWidth);\n }\n\n // If no size constraint is needed, just update the parent.\n if (this.fitPolicy === 'set-no-constraint') {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n return;\n }\n\n // Set up the computed min size.\n let minH = maxRow * this._rowSpacing;\n let minW = maxCol * this._columnSpacing;\n\n // Add the sizer minimums to the computed min size.\n for (let i = 0, n = this.rowCount; i < n; ++i) {\n minH += this._rowSizers[i].minSize;\n }\n for (let i = 0, n = this.columnCount; i < n; ++i) {\n minW += this._columnSizers[i].minSize;\n }\n\n // Update the box sizing and add it to the computed min size.\n let box = (this._box = ElementExt.boxSizing(this.parent!.node));\n minW += box.horizontalSum;\n minH += box.verticalSum;\n\n // Update the parent's min size constraints.\n let style = this.parent!.node.style;\n style.minWidth = `${minW}px`;\n style.minHeight = `${minH}px`;\n\n // Set the dirty flag to ensure only a single update occurs.\n this._dirty = true;\n\n // Notify the ancestor that it should fit immediately. This may\n // cause a resize of the parent, fulfilling the required update.\n if (this.parent!.parent) {\n MessageLoop.sendMessage(this.parent!.parent!, Widget.Msg.FitRequest);\n }\n\n // If the dirty flag is still set, the parent was not resized.\n // Trigger the required update on the parent widget immediately.\n if (this._dirty) {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n }\n }\n\n /**\n * Update the layout position and size of the widgets.\n *\n * The parent offset dimensions should be `-1` if unknown.\n */\n private _update(offsetWidth: number, offsetHeight: number): void {\n // Clear the dirty flag to indicate the update occurred.\n this._dirty = false;\n\n // Measure the parent if the offset dimensions are unknown.\n if (offsetWidth < 0) {\n offsetWidth = this.parent!.node.offsetWidth;\n }\n if (offsetHeight < 0) {\n offsetHeight = this.parent!.node.offsetHeight;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent!.node);\n }\n\n // Compute the layout area adjusted for border and padding.\n let top = this._box.paddingTop;\n let left = this._box.paddingLeft;\n let width = offsetWidth - this._box.horizontalSum;\n let height = offsetHeight - this._box.verticalSum;\n\n // Get the max row and column index.\n let maxRow = this.rowCount - 1;\n let maxCol = this.columnCount - 1;\n\n // Compute the total fixed row and column space.\n let fixedRowSpace = maxRow * this._rowSpacing;\n let fixedColSpace = maxCol * this._columnSpacing;\n\n // Distribute the available space to the box sizers.\n BoxEngine.calc(this._rowSizers, Math.max(0, height - fixedRowSpace));\n BoxEngine.calc(this._columnSizers, Math.max(0, width - fixedColSpace));\n\n // Update the row start positions.\n for (let i = 0, pos = top, n = this.rowCount; i < n; ++i) {\n this._rowStarts[i] = pos;\n pos += this._rowSizers[i].size + this._rowSpacing;\n }\n\n // Update the column start positions.\n for (let i = 0, pos = left, n = this.columnCount; i < n; ++i) {\n this._columnStarts[i] = pos;\n pos += this._columnSizers[i].size + this._columnSpacing;\n }\n\n // Update the geometry of the layout items.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item.\n let item = this._items[i];\n\n // Ignore hidden items.\n if (item.isHidden) {\n continue;\n }\n\n // Fetch the cell bounds for the widget.\n let config = GridLayout.getCellConfig(item.widget);\n let r1 = Math.min(config.row, maxRow);\n let c1 = Math.min(config.column, maxCol);\n let r2 = Math.min(config.row + config.rowSpan - 1, maxRow);\n let c2 = Math.min(config.column + config.columnSpan - 1, maxCol);\n\n // Compute the cell geometry.\n let x = this._columnStarts[c1];\n let y = this._rowStarts[r1];\n let w = this._columnStarts[c2] + this._columnSizers[c2].size - x;\n let h = this._rowStarts[r2] + this._rowSizers[r2].size - y;\n\n // Update the geometry of the layout item.\n item.update(x, y, w, h);\n }\n }\n\n private _dirty = false;\n private _rowSpacing = 4;\n private _columnSpacing = 4;\n private _items: LayoutItem[] = [];\n private _rowStarts: number[] = [];\n private _columnStarts: number[] = [];\n private _rowSizers: BoxSizer[] = [new BoxSizer()];\n private _columnSizers: BoxSizer[] = [new BoxSizer()];\n private _box: ElementExt.IBoxSizing | null = null;\n}\n\n/**\n * The namespace for the `GridLayout` class statics.\n */\nexport namespace GridLayout {\n /**\n * An options object for initializing a grid layout.\n */\n export interface IOptions extends Layout.IOptions {\n /**\n * The initial row count for the layout.\n *\n * The default is `1`.\n */\n rowCount?: number;\n\n /**\n * The initial column count for the layout.\n *\n * The default is `1`.\n */\n columnCount?: number;\n\n /**\n * The spacing between rows in the layout.\n *\n * The default is `4`.\n */\n rowSpacing?: number;\n\n /**\n * The spacing between columns in the layout.\n *\n * The default is `4`.\n */\n columnSpacing?: number;\n }\n\n /**\n * An object which holds the cell configuration for a widget.\n */\n export interface ICellConfig {\n /**\n * The row index for the widget.\n */\n readonly row: number;\n\n /**\n * The column index for the widget.\n */\n readonly column: number;\n\n /**\n * The row span for the widget.\n */\n readonly rowSpan: number;\n\n /**\n * The column span for the widget.\n */\n readonly columnSpan: number;\n }\n\n /**\n * Get the cell config for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The cell config for the widget.\n */\n export function getCellConfig(widget: Widget): ICellConfig {\n return Private.cellConfigProperty.get(widget);\n }\n\n /**\n * Set the cell config for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the cell config.\n */\n export function setCellConfig(\n widget: Widget,\n value: Partial\n ): void {\n Private.cellConfigProperty.set(widget, Private.normalizeConfig(value));\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The property descriptor for the widget cell config.\n */\n export const cellConfigProperty = new AttachedProperty<\n Widget,\n GridLayout.ICellConfig\n >({\n name: 'cellConfig',\n create: () => ({ row: 0, column: 0, rowSpan: 1, columnSpan: 1 }),\n changed: onChildCellConfigChanged\n });\n\n /**\n * Normalize a partial cell config object.\n */\n export function normalizeConfig(\n config: Partial\n ): GridLayout.ICellConfig {\n let row = Math.max(0, Math.floor(config.row || 0));\n let column = Math.max(0, Math.floor(config.column || 0));\n let rowSpan = Math.max(1, Math.floor(config.rowSpan || 0));\n let columnSpan = Math.max(1, Math.floor(config.columnSpan || 0));\n return { row, column, rowSpan, columnSpan };\n }\n\n /**\n * Clamp a value to an integer >= 0.\n */\n export function clampValue(value: number): number {\n return Math.max(0, Math.floor(value));\n }\n\n /**\n * A sort comparison function for row spans.\n */\n export function rowSpanCmp(a: LayoutItem, b: LayoutItem): number {\n let c1 = cellConfigProperty.get(a.widget);\n let c2 = cellConfigProperty.get(b.widget);\n return c1.rowSpan - c2.rowSpan;\n }\n\n /**\n * A sort comparison function for column spans.\n */\n export function columnSpanCmp(a: LayoutItem, b: LayoutItem): number {\n let c1 = cellConfigProperty.get(a.widget);\n let c2 = cellConfigProperty.get(b.widget);\n return c1.columnSpan - c2.columnSpan;\n }\n\n /**\n * Reallocate the box sizers for the given grid dimensions.\n */\n export function reallocSizers(sizers: BoxSizer[], count: number): void {\n // Coerce the count to the valid range.\n count = Math.max(1, Math.floor(count));\n\n // Add the missing sizers.\n while (sizers.length < count) {\n sizers.push(new BoxSizer());\n }\n\n // Remove the extra sizers.\n if (sizers.length > count) {\n sizers.length = count;\n }\n }\n\n /**\n * Distribute a min size constraint across a range of sizers.\n */\n export function distributeMin(\n sizers: BoxSizer[],\n i1: number,\n i2: number,\n minSize: number\n ): void {\n // Sanity check the indices.\n if (i2 < i1) {\n return;\n }\n\n // Handle the simple case of no cell span.\n if (i1 === i2) {\n let sizer = sizers[i1];\n sizer.minSize = Math.max(sizer.minSize, minSize);\n return;\n }\n\n // Compute the total current min size of the span.\n let totalMin = 0;\n for (let i = i1; i <= i2; ++i) {\n totalMin += sizers[i].minSize;\n }\n\n // Do nothing if the total is greater than the required.\n if (totalMin >= minSize) {\n return;\n }\n\n // Compute the portion of the space to allocate to each sizer.\n let portion = (minSize - totalMin) / (i2 - i1 + 1);\n\n // Add the portion to each sizer.\n for (let i = i1; i <= i2; ++i) {\n sizers[i].minSize += portion;\n }\n }\n\n /**\n * The change handler for the child cell config property.\n */\n function onChildCellConfigChanged(child: Widget): void {\n if (child.parent && child.parent.layout instanceof GridLayout) {\n child.parent.fit();\n }\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { getKeyboardLayout } from '@lumino/keyboard';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { CommandRegistry } from '@lumino/commands';\n\nimport {\n ElementARIAAttrs,\n ElementDataset,\n h,\n VirtualDOM,\n VirtualElement\n} from '@lumino/virtualdom';\n\nimport { Menu } from './menu';\n\nimport { Title } from './title';\n\nimport { Widget } from './widget';\n\n/**\n * A widget which displays menus as a canonical menu bar.\n */\nexport class MenuBar extends Widget {\n /**\n * Construct a new menu bar.\n *\n * @param options - The options for initializing the menu bar.\n */\n constructor(options: MenuBar.IOptions = {}) {\n super({ node: Private.createNode() });\n this.addClass('lm-MenuBar');\n this.setFlag(Widget.Flag.DisallowLayout);\n this.renderer = options.renderer || MenuBar.defaultRenderer;\n this._forceItemsPosition = options.forceItemsPosition || {\n forceX: true,\n forceY: true\n };\n this._overflowMenuOptions = options.overflowMenuOptions || {\n isVisible: true\n };\n }\n\n /**\n * Dispose of the resources held by the widget.\n */\n dispose(): void {\n this._closeChildMenu();\n this._menus.length = 0;\n super.dispose();\n }\n\n /**\n * The renderer used by the menu bar.\n */\n readonly renderer: MenuBar.IRenderer;\n\n /**\n * The child menu of the menu bar.\n *\n * #### Notes\n * This will be `null` if the menu bar does not have an open menu.\n */\n get childMenu(): Menu | null {\n return this._childMenu;\n }\n\n /**\n * The overflow index of the menu bar.\n */\n get overflowIndex(): number {\n return this._overflowIndex;\n }\n\n /**\n * The overflow menu of the menu bar.\n */\n get overflowMenu(): Menu | null {\n return this._overflowMenu;\n }\n\n /**\n * Get the menu bar content node.\n *\n * #### Notes\n * This is the node which holds the menu title nodes.\n *\n * Modifying this node directly can lead to undefined behavior.\n */\n get contentNode(): HTMLUListElement {\n return this.node.getElementsByClassName(\n 'lm-MenuBar-content'\n )[0] as HTMLUListElement;\n }\n\n /**\n * Get the currently active menu.\n */\n get activeMenu(): Menu | null {\n return this._menus[this._activeIndex] || null;\n }\n\n /**\n * Set the currently active menu.\n *\n * #### Notes\n * If the menu does not exist, the menu will be set to `null`.\n */\n set activeMenu(value: Menu | null) {\n this.activeIndex = value ? this._menus.indexOf(value) : -1;\n }\n\n /**\n * Get the index of the currently active menu.\n *\n * #### Notes\n * This will be `-1` if no menu is active.\n */\n get activeIndex(): number {\n return this._activeIndex;\n }\n\n /**\n * Set the index of the currently active menu.\n *\n * #### Notes\n * If the menu cannot be activated, the index will be set to `-1`.\n */\n set activeIndex(value: number) {\n // Adjust the value for an out of range index.\n if (value < 0 || value >= this._menus.length) {\n value = -1;\n }\n\n // Bail early if the index will not change.\n if (this._activeIndex === value) {\n return;\n }\n\n // Update the active index.\n this._activeIndex = value;\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * A read-only array of the menus in the menu bar.\n */\n get menus(): ReadonlyArray {\n return this._menus;\n }\n\n /**\n * Open the active menu and activate its first menu item.\n *\n * #### Notes\n * If there is no active menu, this is a no-op.\n */\n openActiveMenu(): void {\n // Bail early if there is no active item.\n if (this._activeIndex === -1) {\n return;\n }\n\n // Open the child menu.\n this._openChildMenu();\n\n // Activate the first item in the child menu.\n if (this._childMenu) {\n this._childMenu.activeIndex = -1;\n this._childMenu.activateNextItem();\n }\n }\n\n /**\n * Add a menu to the end of the menu bar.\n *\n * @param menu - The menu to add to the menu bar.\n *\n * #### Notes\n * If the menu is already added to the menu bar, it will be moved.\n */\n addMenu(menu: Menu, update: boolean = true): void {\n this.insertMenu(this._menus.length, menu, update);\n }\n\n /**\n * Insert a menu into the menu bar at the specified index.\n *\n * @param index - The index at which to insert the menu.\n *\n * @param menu - The menu to insert into the menu bar.\n *\n * #### Notes\n * The index will be clamped to the bounds of the menus.\n *\n * If the menu is already added to the menu bar, it will be moved.\n */\n insertMenu(index: number, menu: Menu, update: boolean = true): void {\n // Close the child menu before making changes.\n this._closeChildMenu();\n\n // Look up the index of the menu.\n let i = this._menus.indexOf(menu);\n\n // Clamp the insert index to the array bounds.\n let j = Math.max(0, Math.min(index, this._menus.length));\n\n // If the menu is not in the array, insert it.\n if (i === -1) {\n // Insert the menu into the array.\n ArrayExt.insert(this._menus, j, menu);\n\n // Add the styling class to the menu.\n menu.addClass('lm-MenuBar-menu');\n\n // Connect to the menu signals.\n menu.aboutToClose.connect(this._onMenuAboutToClose, this);\n menu.menuRequested.connect(this._onMenuMenuRequested, this);\n menu.title.changed.connect(this._onTitleChanged, this);\n\n // Schedule an update of the items.\n if (update) {\n this.update();\n }\n\n // There is nothing more to do.\n return;\n }\n\n // Otherwise, the menu exists in the array and should be moved.\n\n // Adjust the index if the location is at the end of the array.\n if (j === this._menus.length) {\n j--;\n }\n\n // Bail if there is no effective move.\n if (i === j) {\n return;\n }\n\n // Move the menu to the new locations.\n ArrayExt.move(this._menus, i, j);\n\n // Schedule an update of the items.\n if (update) {\n this.update();\n }\n }\n\n /**\n * Remove a menu from the menu bar.\n *\n * @param menu - The menu to remove from the menu bar.\n *\n * #### Notes\n * This is a no-op if the menu is not in the menu bar.\n */\n removeMenu(menu: Menu, update: boolean = true): void {\n this.removeMenuAt(this._menus.indexOf(menu), update);\n }\n\n /**\n * Remove the menu at a given index from the menu bar.\n *\n * @param index - The index of the menu to remove.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n removeMenuAt(index: number, update: boolean = true): void {\n // Close the child menu before making changes.\n this._closeChildMenu();\n\n // Remove the menu from the array.\n let menu = ArrayExt.removeAt(this._menus, index);\n\n // Bail if the index is out of range.\n if (!menu) {\n return;\n }\n\n // Disconnect from the menu signals.\n menu.aboutToClose.disconnect(this._onMenuAboutToClose, this);\n menu.menuRequested.disconnect(this._onMenuMenuRequested, this);\n menu.title.changed.disconnect(this._onTitleChanged, this);\n\n // Remove the styling class from the menu.\n menu.removeClass('lm-MenuBar-menu');\n\n // Schedule an update of the items.\n if (update) {\n this.update();\n }\n }\n\n /**\n * Remove all menus from the menu bar.\n */\n clearMenus(): void {\n // Bail if there is nothing to remove.\n if (this._menus.length === 0) {\n return;\n }\n\n // Close the child menu before making changes.\n this._closeChildMenu();\n\n // Disconnect from the menu signals and remove the styling class.\n for (let menu of this._menus) {\n menu.aboutToClose.disconnect(this._onMenuAboutToClose, this);\n menu.menuRequested.disconnect(this._onMenuMenuRequested, this);\n menu.title.changed.disconnect(this._onTitleChanged, this);\n menu.removeClass('lm-MenuBar-menu');\n }\n\n // Clear the menus array.\n this._menus.length = 0;\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * Handle the DOM events for the menu bar.\n *\n * @param event - The DOM event sent to the menu bar.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the menu bar's DOM nodes. It\n * should not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'mousedown':\n this._evtMouseDown(event as MouseEvent);\n break;\n case 'mousemove':\n this._evtMouseMove(event as MouseEvent);\n break;\n case 'focusout':\n this._evtFocusOut(event as FocusEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('keydown', this);\n this.node.addEventListener('mousedown', this);\n this.node.addEventListener('mousemove', this);\n this.node.addEventListener('focusout', this);\n this.node.addEventListener('contextmenu', this);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('keydown', this);\n this.node.removeEventListener('mousedown', this);\n this.node.removeEventListener('mousemove', this);\n this.node.removeEventListener('focusout', this);\n this.node.removeEventListener('contextmenu', this);\n this._closeChildMenu();\n }\n\n /**\n * A message handler invoked on an `'activate-request'` message.\n */\n protected onActivateRequest(msg: Message): void {\n if (this.isAttached) {\n this._focusItemAt(0);\n }\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n this.update();\n super.onResize(msg);\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n let menus = this._menus;\n let renderer = this.renderer;\n let activeIndex = this._activeIndex;\n let tabFocusIndex =\n this._tabFocusIndex >= 0 && this._tabFocusIndex < menus.length\n ? this._tabFocusIndex\n : 0;\n let length = this._overflowIndex > -1 ? this._overflowIndex : menus.length;\n let totalMenuSize = 0;\n let isVisible = false;\n\n // Check that the overflow menu doesn't count\n length = this._overflowMenu !== null ? length - 1 : length;\n let content = new Array(length);\n\n // Render visible menus\n for (let i = 0; i < length; ++i) {\n content[i] = renderer.renderItem({\n title: menus[i].title,\n active: i === activeIndex,\n tabbable: i === tabFocusIndex,\n disabled: menus[i].items.length === 0,\n onfocus: () => {\n this._tabFocusIndex = i;\n this.activeIndex = i;\n }\n });\n // Calculate size of current menu\n totalMenuSize += this._menuItemSizes[i];\n // Check if overflow menu is already rendered\n if (menus[i].title.label === this._overflowMenuOptions.title) {\n isVisible = true;\n length--;\n }\n }\n // Render overflow menu if needed and active\n if (this._overflowMenuOptions.isVisible) {\n if (this._overflowIndex > -1 && !isVisible) {\n // Create overflow menu\n if (this._overflowMenu === null) {\n const overflowMenuTitle = this._overflowMenuOptions.title ?? '...';\n this._overflowMenu = new Menu({ commands: new CommandRegistry() });\n this._overflowMenu.title.label = overflowMenuTitle;\n this._overflowMenu.title.mnemonic = 0;\n this.addMenu(this._overflowMenu, false);\n }\n // Move menus to overflow menu\n for (let i = menus.length - 2; i >= length; i--) {\n const submenu = this.menus[i];\n submenu.title.mnemonic = 0;\n this._overflowMenu.insertItem(0, {\n type: 'submenu',\n submenu: submenu\n });\n this.removeMenu(submenu, false);\n }\n content[length] = renderer.renderItem({\n title: this._overflowMenu.title,\n active: length === activeIndex && menus[length].items.length !== 0,\n tabbable: length === tabFocusIndex,\n disabled: menus[length].items.length === 0,\n onfocus: () => {\n this._tabFocusIndex = length;\n this.activeIndex = length;\n }\n });\n length++;\n } else if (this._overflowMenu !== null) {\n // Remove submenus from overflow menu\n let overflowMenuItems = this._overflowMenu.items;\n let screenSize = this.node.offsetWidth;\n let n = this._overflowMenu.items.length;\n for (let i = 0; i < n; ++i) {\n let index = menus.length - 1 - i;\n if (screenSize - totalMenuSize > this._menuItemSizes[index]) {\n let menu = overflowMenuItems[0].submenu as Menu;\n this._overflowMenu.removeItemAt(0);\n this.insertMenu(length, menu, false);\n content[length] = renderer.renderItem({\n title: menu.title,\n active: false,\n tabbable: length === tabFocusIndex,\n disabled: menus[length].items.length === 0,\n onfocus: () => {\n this._tabFocusIndex = length;\n this.activeIndex = length;\n }\n });\n length++;\n }\n }\n if (this._overflowMenu.items.length === 0) {\n this.removeMenu(this._overflowMenu, false);\n content.pop();\n this._overflowMenu = null;\n this._overflowIndex = -1;\n }\n }\n }\n VirtualDOM.render(content, this.contentNode);\n this._updateOverflowIndex();\n }\n\n /**\n * Calculate and update the current overflow index.\n */\n private _updateOverflowIndex(): void {\n if (!this._overflowMenuOptions.isVisible) {\n return;\n }\n\n // Get elements visible in the main menu bar\n const itemMenus = this.contentNode.childNodes;\n let screenSize = this.node.offsetWidth;\n let totalMenuSize = 0;\n let index = -1;\n let n = itemMenus.length;\n\n if (this._menuItemSizes.length == 0) {\n // Check if it is the first resize and get info about menu items sizes\n for (let i = 0; i < n; i++) {\n let item = itemMenus[i] as HTMLLIElement;\n // Add sizes to array\n totalMenuSize += item.offsetWidth;\n this._menuItemSizes.push(item.offsetWidth);\n if (totalMenuSize > screenSize && index === -1) {\n index = i;\n }\n }\n } else {\n // Calculate current menu size\n for (let i = 0; i < this._menuItemSizes.length; i++) {\n totalMenuSize += this._menuItemSizes[i];\n if (totalMenuSize > screenSize) {\n index = i;\n break;\n }\n }\n }\n this._overflowIndex = index;\n }\n\n /**\n * Handle the `'keydown'` event for the menu bar.\n *\n * #### Notes\n * All keys are trapped except the tab key that is ignored.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // Fetch the key code for the event.\n let kc = event.keyCode;\n\n // Reset the active index on tab, but do not trap the tab key.\n if (kc === 9) {\n this.activeIndex = -1;\n return;\n }\n\n // A menu bar handles all other keydown events.\n event.preventDefault();\n event.stopPropagation();\n\n // Enter, Space, Up Arrow, Down Arrow\n if (kc === 13 || kc === 32 || kc === 38 || kc === 40) {\n // The active index may have changed (for example, user hovers over an\n // item with the mouse), so be sure to use the focus index.\n this.activeIndex = this._tabFocusIndex;\n if (this.activeIndex !== this._tabFocusIndex) {\n // Bail if the setter refused to set activeIndex to tabFocusIndex\n // because it means that the item at tabFocusIndex cannot be opened (for\n // example, it has an empty menu)\n return;\n }\n this.openActiveMenu();\n return;\n }\n\n // Escape\n if (kc === 27) {\n this._closeChildMenu();\n this._focusItemAt(this.activeIndex);\n return;\n }\n\n // Left or Right Arrow\n if (kc === 37 || kc === 39) {\n let direction = kc === 37 ? -1 : 1;\n let start = this._tabFocusIndex + direction;\n let n = this._menus.length;\n for (let i = 0; i < n; i++) {\n let index = (n + start + direction * i) % n;\n if (this._menus[index].items.length) {\n this._focusItemAt(index);\n return;\n }\n }\n return;\n }\n\n // Get the pressed key character.\n let key = getKeyboardLayout().keyForKeydownEvent(event);\n\n // Bail if the key is not valid.\n if (!key) {\n return;\n }\n\n // Search for the next best matching mnemonic item.\n let start = this._activeIndex + 1;\n let result = Private.findMnemonic(this._menus, key, start);\n\n // Handle the requested mnemonic based on the search results.\n // If exactly one mnemonic is matched, that menu is opened.\n // Otherwise, the next mnemonic is activated if available,\n // followed by the auto mnemonic if available.\n if (result.index !== -1 && !result.multiple) {\n this.activeIndex = result.index;\n this.openActiveMenu();\n } else if (result.index !== -1) {\n this.activeIndex = result.index;\n this._focusItemAt(this.activeIndex);\n } else if (result.auto !== -1) {\n this.activeIndex = result.auto;\n this._focusItemAt(this.activeIndex);\n }\n }\n\n /**\n * Handle the `'mousedown'` event for the menu bar.\n */\n private _evtMouseDown(event: MouseEvent): void {\n // Bail if the mouse press was not on the menu bar. This can occur\n // when the document listener is installed for an active menu bar.\n if (!ElementExt.hitTest(this.node, event.clientX, event.clientY)) {\n return;\n }\n\n // Stop the propagation of the event. Immediate propagation is\n // also stopped so that an open menu does not handle the event.\n event.stopPropagation();\n event.stopImmediatePropagation();\n\n // Check if the mouse is over one of the menu items.\n let index = ArrayExt.findFirstIndex(this.contentNode.children, node => {\n return ElementExt.hitTest(node, event.clientX, event.clientY);\n });\n\n // If the press was not on an item, close the child menu.\n if (index === -1) {\n this._closeChildMenu();\n return;\n }\n\n // If the press was not the left mouse button, do nothing further.\n if (event.button !== 0) {\n return;\n }\n\n // Otherwise, toggle the open state of the child menu.\n if (this._childMenu) {\n this._closeChildMenu();\n this.activeIndex = index;\n } else {\n // If we don't call preventDefault() here, then the item in the menu\n // bar will take focus over the menu that is being opened.\n event.preventDefault();\n const position = this._positionForMenu(index);\n Menu.saveWindowData();\n // Begin DOM modifications.\n this.activeIndex = index;\n this._openChildMenu(position);\n }\n }\n\n /**\n * Handle the `'mousemove'` event for the menu bar.\n */\n private _evtMouseMove(event: MouseEvent): void {\n // Check if the mouse is over one of the menu items.\n let index = ArrayExt.findFirstIndex(this.contentNode.children, node => {\n return ElementExt.hitTest(node, event.clientX, event.clientY);\n });\n\n // Bail early if the active index will not change.\n if (index === this._activeIndex) {\n return;\n }\n\n // Bail early if a child menu is open and the mouse is not over\n // an item. This allows the child menu to be kept open when the\n // mouse is over the empty part of the menu bar.\n if (index === -1 && this._childMenu) {\n return;\n }\n\n // Get position for the new menu >before< updating active index.\n const position =\n index >= 0 && this._childMenu ? this._positionForMenu(index) : null;\n\n // Before any modification, update window data.\n Menu.saveWindowData();\n\n // Begin DOM modifications.\n\n // Update the active index to the hovered item.\n this.activeIndex = index;\n\n // Open the new menu if a menu is already open.\n if (position) {\n this._openChildMenu(position);\n }\n }\n\n /**\n * Find initial position for the menu based on menubar item position.\n *\n * NOTE: this should be called before updating active index to avoid\n * an additional layout and style invalidation as changing active\n * index modifies DOM.\n */\n private _positionForMenu(index: number): Private.IPosition {\n let itemNode = this.contentNode.children[index];\n let { left, bottom } = (itemNode as HTMLElement).getBoundingClientRect();\n return {\n top: bottom,\n left\n };\n }\n\n /**\n * Handle the `'focusout'` event for the menu bar.\n */\n private _evtFocusOut(event: FocusEvent): void {\n // Reset the active index if there is no open menu and the menubar is losing focus.\n if (!this._childMenu && !this.node.contains(event.relatedTarget as Node)) {\n this.activeIndex = -1;\n }\n }\n\n /**\n * Focus an item in the menu bar.\n *\n * #### Notes\n * Does not open the associated menu.\n */\n private _focusItemAt(index: number): void {\n const itemNode = this.contentNode.childNodes[index] as HTMLElement | void;\n if (itemNode) {\n itemNode.focus();\n }\n }\n\n /**\n * Open the child menu at the active index immediately.\n *\n * If a different child menu is already open, it will be closed,\n * even if there is no active menu.\n */\n private _openChildMenu(options: { left?: number; top?: number } = {}): void {\n // If there is no active menu, close the current menu.\n let newMenu = this.activeMenu;\n if (!newMenu) {\n this._closeChildMenu();\n return;\n }\n\n // Bail if there is no effective menu change.\n let oldMenu = this._childMenu;\n if (oldMenu === newMenu) {\n return;\n }\n\n // Swap the internal menu reference.\n this._childMenu = newMenu;\n\n // Close the current menu, or setup for the new menu.\n if (oldMenu) {\n oldMenu.close();\n } else {\n document.addEventListener('mousedown', this, true);\n }\n\n // Update the tab focus index and ensure the menu bar is updated.\n this._tabFocusIndex = this.activeIndex;\n MessageLoop.sendMessage(this, Widget.Msg.UpdateRequest);\n\n // Get the positioning data for the new menu.\n let { left, top } = options;\n if (typeof left === 'undefined' || typeof top === 'undefined') {\n ({ left, top } = this._positionForMenu(this._activeIndex));\n }\n // Begin DOM modifications\n\n if (!oldMenu) {\n // Continue setup for new menu\n this.addClass('lm-mod-active');\n }\n\n // Open the new menu at the computed location.\n if (newMenu.items.length > 0) {\n newMenu.open(left, top, this._forceItemsPosition);\n }\n }\n\n /**\n * Close the child menu immediately.\n *\n * This is a no-op if a child menu is not open.\n */\n private _closeChildMenu(): void {\n // Bail if no child menu is open.\n if (!this._childMenu) {\n return;\n }\n // Remove the active class from the menu bar.\n this.removeClass('lm-mod-active');\n\n // Remove the document listeners.\n document.removeEventListener('mousedown', this, true);\n\n // Clear the internal menu reference.\n let menu = this._childMenu;\n this._childMenu = null;\n\n // Close the menu.\n menu.close();\n\n // Reset the active index.\n this.activeIndex = -1;\n }\n\n /**\n * Handle the `aboutToClose` signal of a menu.\n */\n private _onMenuAboutToClose(sender: Menu): void {\n // Bail if the sender is not the child menu.\n if (sender !== this._childMenu) {\n return;\n }\n\n // Remove the active class from the menu bar.\n this.removeClass('lm-mod-active');\n\n // Remove the document listeners.\n document.removeEventListener('mousedown', this, true);\n\n // Clear the internal menu reference.\n this._childMenu = null;\n\n // Reset the active index.\n this.activeIndex = -1;\n }\n\n /**\n * Handle the `menuRequested` signal of a child menu.\n */\n private _onMenuMenuRequested(sender: Menu, args: 'next' | 'previous'): void {\n // Bail if the sender is not the child menu.\n if (sender !== this._childMenu) {\n return;\n }\n\n // Look up the active index and menu count.\n let i = this._activeIndex;\n let n = this._menus.length;\n\n // Active the next requested index.\n switch (args) {\n case 'next':\n this.activeIndex = i === n - 1 ? 0 : i + 1;\n break;\n case 'previous':\n this.activeIndex = i === 0 ? n - 1 : i - 1;\n break;\n }\n\n // Open the active menu.\n this.openActiveMenu();\n }\n\n /**\n * Handle the `changed` signal of a title object.\n */\n private _onTitleChanged(): void {\n this.update();\n }\n\n // Track the index of the item that is currently focused or hovered. -1 means nothing focused or hovered.\n private _activeIndex = -1;\n // Track which item can be focused using the TAB key. Unlike _activeIndex will\n // always point to a menuitem. Whenever you update this value, it's important\n // to follow it with an \"update-request\" message so that the `tabindex`\n // attribute on each menubar item gets properly updated.\n private _tabFocusIndex = 0;\n private _forceItemsPosition: Menu.IOpenOptions;\n private _overflowMenuOptions: IOverflowMenuOptions;\n private _menus: Menu[] = [];\n private _childMenu: Menu | null = null;\n private _overflowMenu: Menu | null = null;\n private _menuItemSizes: number[] = [];\n private _overflowIndex: number = -1;\n}\n\n/**\n * The namespace for the `MenuBar` class statics.\n */\nexport namespace MenuBar {\n /**\n * An options object for creating a menu bar.\n */\n export interface IOptions {\n /**\n * A custom renderer for creating menu bar content.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n /**\n * Whether to force the position of the menu. The MenuBar forces the\n * coordinates of its menus by default. With this option you can disable it.\n *\n * Setting to `false` will enable the logic which repositions the\n * coordinates of the menu if it will not fit entirely on screen.\n *\n * The default is `true`.\n */\n forceItemsPosition?: Menu.IOpenOptions;\n /**\n * Whether to add a overflow menu if there's overflow.\n *\n * Setting to `true` will enable the logic that creates an overflow menu\n * to show the menu items that don't fit entirely on the screen.\n *\n * The default is `true`.\n */\n overflowMenuOptions?: IOverflowMenuOptions;\n }\n\n /**\n * An object which holds the data to render a menu bar item.\n */\n export interface IRenderData {\n /**\n * The title to be rendered.\n */\n readonly title: Title;\n\n /**\n * Whether the item is the active item.\n */\n readonly active: boolean;\n\n /**\n * Whether the user can tab to the item.\n */\n readonly tabbable: boolean;\n\n /**\n * Whether the item is disabled.\n *\n * #### Notes\n * A disabled item cannot be active.\n * A disabled item cannot be focussed.\n */\n readonly disabled?: boolean;\n\n readonly onfocus?: (event: FocusEvent) => void;\n }\n\n /**\n * A renderer for use with a menu bar.\n */\n export interface IRenderer {\n /**\n * Render the virtual element for a menu bar item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n */\n renderItem(data: IRenderData): VirtualElement;\n }\n\n /**\n * The default implementation of `IRenderer`.\n *\n * #### Notes\n * Subclasses are free to reimplement rendering methods as needed.\n */\n export class Renderer implements IRenderer {\n /**\n * Render the virtual element for a menu bar item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n */\n renderItem(data: IRenderData): VirtualElement {\n let className = this.createItemClass(data);\n let dataset = this.createItemDataset(data);\n let aria = this.createItemARIA(data);\n return h.li(\n {\n className,\n dataset,\n ...(data.disabled ? {} : { tabindex: data.tabbable ? '0' : '-1' }),\n onfocus: data.onfocus,\n ...aria\n },\n this.renderIcon(data),\n this.renderLabel(data)\n );\n }\n\n /**\n * Render the icon element for a menu bar item.\n *\n * @param data - The data to use for rendering the icon.\n *\n * @returns A virtual element representing the item icon.\n */\n renderIcon(data: IRenderData): VirtualElement {\n let className = this.createIconClass(data);\n\n // If data.title.icon is undefined, it will be ignored.\n return h.div({ className }, data.title.icon!, data.title.iconLabel);\n }\n\n /**\n * Render the label element for a menu item.\n *\n * @param data - The data to use for rendering the label.\n *\n * @returns A virtual element representing the item label.\n */\n renderLabel(data: IRenderData): VirtualElement {\n let content = this.formatLabel(data);\n return h.div({ className: 'lm-MenuBar-itemLabel' }, content);\n }\n\n /**\n * Create the class name for the menu bar item.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the menu item.\n */\n createItemClass(data: IRenderData): string {\n let name = 'lm-MenuBar-item';\n if (data.title.className) {\n name += ` ${data.title.className}`;\n }\n if (data.active && !data.disabled) {\n name += ' lm-mod-active';\n }\n return name;\n }\n\n /**\n * Create the dataset for a menu bar item.\n *\n * @param data - The data to use for the item.\n *\n * @returns The dataset for the menu bar item.\n */\n createItemDataset(data: IRenderData): ElementDataset {\n return data.title.dataset;\n }\n\n /**\n * Create the aria attributes for menu bar item.\n *\n * @param data - The data to use for the aria attributes.\n *\n * @returns The aria attributes object for the item.\n */\n createItemARIA(data: IRenderData): ElementARIAAttrs {\n return {\n role: 'menuitem',\n 'aria-haspopup': 'true',\n 'aria-disabled': data.disabled ? 'true' : 'false'\n };\n }\n\n /**\n * Create the class name for the menu bar item icon.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the item icon.\n */\n createIconClass(data: IRenderData): string {\n let name = 'lm-MenuBar-itemIcon';\n let extra = data.title.iconClass;\n return extra ? `${name} ${extra}` : name;\n }\n\n /**\n * Create the render content for the label node.\n *\n * @param data - The data to use for the label content.\n *\n * @returns The content to add to the label node.\n */\n formatLabel(data: IRenderData): h.Child {\n // Fetch the label text and mnemonic index.\n let { label, mnemonic } = data.title;\n\n // If the index is out of range, do not modify the label.\n if (mnemonic < 0 || mnemonic >= label.length) {\n return label;\n }\n\n // Split the label into parts.\n let prefix = label.slice(0, mnemonic);\n let suffix = label.slice(mnemonic + 1);\n let char = label[mnemonic];\n\n // Wrap the mnemonic character in a span.\n let span = h.span({ className: 'lm-MenuBar-itemMnemonic' }, char);\n\n // Return the content parts.\n return [prefix, span, suffix];\n }\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n}\n\n/**\n * Options for overflow menu.\n */\nexport interface IOverflowMenuOptions {\n /**\n * Determines if a overflow menu appears when the menu items overflow.\n *\n * Defaults to `true`.\n */\n isVisible: boolean;\n /**\n * Determines the title of the overflow menu.\n *\n * Default: `...`.\n */\n title?: string;\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Create the DOM node for a menu bar.\n */\n export function createNode(): HTMLDivElement {\n let node = document.createElement('div');\n let content = document.createElement('ul');\n content.className = 'lm-MenuBar-content';\n node.appendChild(content);\n content.setAttribute('role', 'menubar');\n return node;\n }\n\n /**\n * Position for the menu relative to top-left screen corner.\n */\n export interface IPosition {\n /**\n * Pixels right from screen origin.\n */\n left: number;\n /**\n * Pixels down from screen origin.\n */\n top: number;\n }\n\n /**\n * The results of a mnemonic search.\n */\n export interface IMnemonicResult {\n /**\n * The index of the first matching mnemonic item, or `-1`.\n */\n index: number;\n\n /**\n * Whether multiple mnemonic items matched.\n */\n multiple: boolean;\n\n /**\n * The index of the first auto matched non-mnemonic item.\n */\n auto: number;\n }\n\n /**\n * Find the best matching mnemonic item.\n *\n * The search starts at the given index and wraps around.\n */\n export function findMnemonic(\n menus: ReadonlyArray,\n key: string,\n start: number\n ): IMnemonicResult {\n // Setup the result variables.\n let index = -1;\n let auto = -1;\n let multiple = false;\n\n // Normalize the key to upper case.\n let upperKey = key.toUpperCase();\n\n // Search the items from the given start index.\n for (let i = 0, n = menus.length; i < n; ++i) {\n // Compute the wrapped index.\n let k = (i + start) % n;\n\n // Look up the menu title.\n let title = menus[k].title;\n\n // Ignore titles with an empty label.\n if (title.label.length === 0) {\n continue;\n }\n\n // Look up the mnemonic index for the label.\n let mn = title.mnemonic;\n\n // Handle a valid mnemonic index.\n if (mn >= 0 && mn < title.label.length) {\n if (title.label[mn].toUpperCase() === upperKey) {\n if (index === -1) {\n index = k;\n } else {\n multiple = true;\n }\n }\n continue;\n }\n\n // Finally, handle the auto index if possible.\n if (auto === -1 && title.label[0].toUpperCase() === upperKey) {\n auto = k;\n }\n }\n\n // Return the search results.\n return { index, multiple, auto };\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Drag } from '@lumino/dragdrop';\n\nimport { Message } from '@lumino/messaging';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { Widget } from './widget';\n\n/**\n * A widget which implements a canonical scroll bar.\n */\nexport class ScrollBar extends Widget {\n /**\n * Construct a new scroll bar.\n *\n * @param options - The options for initializing the scroll bar.\n */\n constructor(options: ScrollBar.IOptions = {}) {\n super({ node: Private.createNode() });\n this.addClass('lm-ScrollBar');\n this.setFlag(Widget.Flag.DisallowLayout);\n\n // Set the orientation.\n this._orientation = options.orientation || 'vertical';\n this.dataset['orientation'] = this._orientation;\n\n // Parse the rest of the options.\n if (options.maximum !== undefined) {\n this._maximum = Math.max(0, options.maximum);\n }\n if (options.page !== undefined) {\n this._page = Math.max(0, options.page);\n }\n if (options.value !== undefined) {\n this._value = Math.max(0, Math.min(options.value, this._maximum));\n }\n }\n\n /**\n * A signal emitted when the user moves the scroll thumb.\n *\n * #### Notes\n * The payload is the current value of the scroll bar.\n */\n get thumbMoved(): ISignal {\n return this._thumbMoved;\n }\n\n /**\n * A signal emitted when the user clicks a step button.\n *\n * #### Notes\n * The payload is whether a decrease or increase is requested.\n */\n get stepRequested(): ISignal {\n return this._stepRequested;\n }\n\n /**\n * A signal emitted when the user clicks the scroll track.\n *\n * #### Notes\n * The payload is whether a decrease or increase is requested.\n */\n get pageRequested(): ISignal {\n return this._pageRequested;\n }\n\n /**\n * Get the orientation of the scroll bar.\n */\n get orientation(): ScrollBar.Orientation {\n return this._orientation;\n }\n\n /**\n * Set the orientation of the scroll bar.\n */\n set orientation(value: ScrollBar.Orientation) {\n // Do nothing if the orientation does not change.\n if (this._orientation === value) {\n return;\n }\n\n // Release the mouse before making changes.\n this._releaseMouse();\n\n // Update the internal orientation.\n this._orientation = value;\n this.dataset['orientation'] = value;\n\n // Schedule an update the scroll bar.\n this.update();\n }\n\n /**\n * Get the current value of the scroll bar.\n */\n get value(): number {\n return this._value;\n }\n\n /**\n * Set the current value of the scroll bar.\n *\n * #### Notes\n * The value will be clamped to the range `[0, maximum]`.\n */\n set value(value: number) {\n // Clamp the value to the allowable range.\n value = Math.max(0, Math.min(value, this._maximum));\n\n // Do nothing if the value does not change.\n if (this._value === value) {\n return;\n }\n\n // Update the internal value.\n this._value = value;\n\n // Schedule an update the scroll bar.\n this.update();\n }\n\n /**\n * Get the page size of the scroll bar.\n *\n * #### Notes\n * The page size is the amount of visible content in the scrolled\n * region, expressed in data units. It determines the size of the\n * scroll bar thumb.\n */\n get page(): number {\n return this._page;\n }\n\n /**\n * Set the page size of the scroll bar.\n *\n * #### Notes\n * The page size will be clamped to the range `[0, Infinity]`.\n */\n set page(value: number) {\n // Clamp the page size to the allowable range.\n value = Math.max(0, value);\n\n // Do nothing if the value does not change.\n if (this._page === value) {\n return;\n }\n\n // Update the internal page size.\n this._page = value;\n\n // Schedule an update the scroll bar.\n this.update();\n }\n\n /**\n * Get the maximum value of the scroll bar.\n */\n get maximum(): number {\n return this._maximum;\n }\n\n /**\n * Set the maximum value of the scroll bar.\n *\n * #### Notes\n * The max size will be clamped to the range `[0, Infinity]`.\n */\n set maximum(value: number) {\n // Clamp the value to the allowable range.\n value = Math.max(0, value);\n\n // Do nothing if the value does not change.\n if (this._maximum === value) {\n return;\n }\n\n // Update the internal values.\n this._maximum = value;\n\n // Clamp the current value to the new range.\n this._value = Math.min(this._value, value);\n\n // Schedule an update the scroll bar.\n this.update();\n }\n\n /**\n * The scroll bar decrement button node.\n *\n * #### Notes\n * Modifying this node directly can lead to undefined behavior.\n */\n get decrementNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-ScrollBar-button'\n )[0] as HTMLDivElement;\n }\n\n /**\n * The scroll bar increment button node.\n *\n * #### Notes\n * Modifying this node directly can lead to undefined behavior.\n */\n get incrementNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-ScrollBar-button'\n )[1] as HTMLDivElement;\n }\n\n /**\n * The scroll bar track node.\n *\n * #### Notes\n * Modifying this node directly can lead to undefined behavior.\n */\n get trackNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-ScrollBar-track'\n )[0] as HTMLDivElement;\n }\n\n /**\n * The scroll bar thumb node.\n *\n * #### Notes\n * Modifying this node directly can lead to undefined behavior.\n */\n get thumbNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-ScrollBar-thumb'\n )[0] as HTMLDivElement;\n }\n\n /**\n * Handle the DOM events for the scroll bar.\n *\n * @param event - The DOM event sent to the scroll bar.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the scroll bar's DOM node.\n *\n * This should not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'mousedown':\n this._evtMouseDown(event as MouseEvent);\n break;\n case 'mousemove':\n this._evtMouseMove(event as MouseEvent);\n break;\n case 'mouseup':\n this._evtMouseUp(event as MouseEvent);\n break;\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A method invoked on a 'before-attach' message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('mousedown', this);\n this.update();\n }\n\n /**\n * A method invoked on an 'after-detach' message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('mousedown', this);\n this._releaseMouse();\n }\n\n /**\n * A method invoked on an 'update-request' message.\n */\n protected onUpdateRequest(msg: Message): void {\n // Convert the value and page into percentages.\n let value = (this._value * 100) / this._maximum;\n let page = (this._page * 100) / (this._page + this._maximum);\n\n // Clamp the value and page to the relevant range.\n value = Math.max(0, Math.min(value, 100));\n page = Math.max(0, Math.min(page, 100));\n\n // Fetch the thumb style.\n let thumbStyle = this.thumbNode.style;\n\n // Update the thumb style for the current orientation.\n if (this._orientation === 'horizontal') {\n thumbStyle.top = '';\n thumbStyle.height = '';\n thumbStyle.left = `${value}%`;\n thumbStyle.width = `${page}%`;\n thumbStyle.transform = `translate(${-value}%, 0%)`;\n } else {\n thumbStyle.left = '';\n thumbStyle.width = '';\n thumbStyle.top = `${value}%`;\n thumbStyle.height = `${page}%`;\n thumbStyle.transform = `translate(0%, ${-value}%)`;\n }\n }\n\n /**\n * Handle the `'keydown'` event for the scroll bar.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // Stop all input events during drag.\n event.preventDefault();\n event.stopPropagation();\n\n // Ignore anything except the `Escape` key.\n if (event.keyCode !== 27) {\n return;\n }\n\n // Fetch the previous scroll value.\n let value = this._pressData ? this._pressData.value : -1;\n\n // Release the mouse.\n this._releaseMouse();\n\n // Restore the old scroll value if possible.\n if (value !== -1) {\n this._moveThumb(value);\n }\n }\n\n /**\n * Handle the `'mousedown'` event for the scroll bar.\n */\n private _evtMouseDown(event: MouseEvent): void {\n // Do nothing if it's not a left mouse press.\n if (event.button !== 0) {\n return;\n }\n\n // Send an activate request to the scroll bar. This can be\n // used by message hooks to activate something relevant.\n this.activate();\n\n // Do nothing if the mouse is already captured.\n if (this._pressData) {\n return;\n }\n\n // Find the pressed scroll bar part.\n let part = Private.findPart(this, event.target as HTMLElement);\n\n // Do nothing if the part is not of interest.\n if (!part) {\n return;\n }\n\n // Stop the event propagation.\n event.preventDefault();\n event.stopPropagation();\n\n // Override the mouse cursor.\n let override = Drag.overrideCursor('default');\n\n // Set up the press data.\n this._pressData = {\n part,\n override,\n delta: -1,\n value: -1,\n mouseX: event.clientX,\n mouseY: event.clientY\n };\n\n // Add the extra event listeners.\n document.addEventListener('mousemove', this, true);\n document.addEventListener('mouseup', this, true);\n document.addEventListener('keydown', this, true);\n document.addEventListener('contextmenu', this, true);\n\n // Handle a thumb press.\n if (part === 'thumb') {\n // Fetch the thumb node.\n let thumbNode = this.thumbNode;\n\n // Fetch the client rect for the thumb.\n let thumbRect = thumbNode.getBoundingClientRect();\n\n // Update the press data delta for the current orientation.\n if (this._orientation === 'horizontal') {\n this._pressData.delta = event.clientX - thumbRect.left;\n } else {\n this._pressData.delta = event.clientY - thumbRect.top;\n }\n\n // Add the active class to the thumb node.\n thumbNode.classList.add('lm-mod-active');\n\n // Store the current value in the press data.\n this._pressData.value = this._value;\n\n // Finished.\n return;\n }\n\n // Handle a track press.\n if (part === 'track') {\n // Fetch the client rect for the thumb.\n let thumbRect = this.thumbNode.getBoundingClientRect();\n\n // Determine the direction for the page request.\n let dir: 'decrement' | 'increment';\n if (this._orientation === 'horizontal') {\n dir = event.clientX < thumbRect.left ? 'decrement' : 'increment';\n } else {\n dir = event.clientY < thumbRect.top ? 'decrement' : 'increment';\n }\n\n // Start the repeat timer.\n this._repeatTimer = window.setTimeout(this._onRepeat, 350);\n\n // Emit the page requested signal.\n this._pageRequested.emit(dir);\n\n // Finished.\n return;\n }\n\n // Handle a decrement button press.\n if (part === 'decrement') {\n // Add the active class to the decrement node.\n this.decrementNode.classList.add('lm-mod-active');\n\n // Start the repeat timer.\n this._repeatTimer = window.setTimeout(this._onRepeat, 350);\n\n // Emit the step requested signal.\n this._stepRequested.emit('decrement');\n\n // Finished.\n return;\n }\n\n // Handle an increment button press.\n if (part === 'increment') {\n // Add the active class to the increment node.\n this.incrementNode.classList.add('lm-mod-active');\n\n // Start the repeat timer.\n this._repeatTimer = window.setTimeout(this._onRepeat, 350);\n\n // Emit the step requested signal.\n this._stepRequested.emit('increment');\n\n // Finished.\n return;\n }\n }\n\n /**\n * Handle the `'mousemove'` event for the scroll bar.\n */\n private _evtMouseMove(event: MouseEvent): void {\n // Do nothing if no drag is in progress.\n if (!this._pressData) {\n return;\n }\n\n // Stop the event propagation.\n event.preventDefault();\n event.stopPropagation();\n\n // Update the mouse position.\n this._pressData.mouseX = event.clientX;\n this._pressData.mouseY = event.clientY;\n\n // Bail if the thumb is not being dragged.\n if (this._pressData.part !== 'thumb') {\n return;\n }\n\n // Get the client rect for the thumb and track.\n let thumbRect = this.thumbNode.getBoundingClientRect();\n let trackRect = this.trackNode.getBoundingClientRect();\n\n // Fetch the scroll geometry based on the orientation.\n let trackPos: number;\n let trackSpan: number;\n if (this._orientation === 'horizontal') {\n trackPos = event.clientX - trackRect.left - this._pressData.delta;\n trackSpan = trackRect.width - thumbRect.width;\n } else {\n trackPos = event.clientY - trackRect.top - this._pressData.delta;\n trackSpan = trackRect.height - thumbRect.height;\n }\n\n // Compute the desired value from the scroll geometry.\n let value = trackSpan === 0 ? 0 : (trackPos * this._maximum) / trackSpan;\n\n // Move the thumb to the computed value.\n this._moveThumb(value);\n }\n\n /**\n * Handle the `'mouseup'` event for the scroll bar.\n */\n private _evtMouseUp(event: MouseEvent): void {\n // Do nothing if it's not a left mouse release.\n if (event.button !== 0) {\n return;\n }\n\n // Stop the event propagation.\n event.preventDefault();\n event.stopPropagation();\n\n // Release the mouse.\n this._releaseMouse();\n }\n\n /**\n * Release the mouse and restore the node states.\n */\n private _releaseMouse(): void {\n // Bail if there is no press data.\n if (!this._pressData) {\n return;\n }\n\n // Clear the repeat timer.\n clearTimeout(this._repeatTimer);\n this._repeatTimer = -1;\n\n // Clear the press data.\n this._pressData.override.dispose();\n this._pressData = null;\n\n // Remove the extra event listeners.\n document.removeEventListener('mousemove', this, true);\n document.removeEventListener('mouseup', this, true);\n document.removeEventListener('keydown', this, true);\n document.removeEventListener('contextmenu', this, true);\n\n // Remove the active classes from the nodes.\n this.thumbNode.classList.remove('lm-mod-active');\n this.decrementNode.classList.remove('lm-mod-active');\n this.incrementNode.classList.remove('lm-mod-active');\n }\n\n /**\n * Move the thumb to the specified position.\n */\n private _moveThumb(value: number): void {\n // Clamp the value to the allowed range.\n value = Math.max(0, Math.min(value, this._maximum));\n\n // Bail if the value does not change.\n if (this._value === value) {\n return;\n }\n\n // Update the internal value.\n this._value = value;\n\n // Schedule an update of the scroll bar.\n this.update();\n\n // Emit the thumb moved signal.\n this._thumbMoved.emit(value);\n }\n\n /**\n * A timeout callback for repeating the mouse press.\n */\n private _onRepeat = () => {\n // Clear the repeat timer id.\n this._repeatTimer = -1;\n\n // Bail if the mouse has been released.\n if (!this._pressData) {\n return;\n }\n\n // Look up the part that was pressed.\n let part = this._pressData.part;\n\n // Bail if the thumb was pressed.\n if (part === 'thumb') {\n return;\n }\n\n // Schedule the timer for another repeat.\n this._repeatTimer = window.setTimeout(this._onRepeat, 20);\n\n // Get the current mouse position.\n let mouseX = this._pressData.mouseX;\n let mouseY = this._pressData.mouseY;\n\n // Handle a decrement button repeat.\n if (part === 'decrement') {\n // Bail if the mouse is not over the button.\n if (!ElementExt.hitTest(this.decrementNode, mouseX, mouseY)) {\n return;\n }\n\n // Emit the step requested signal.\n this._stepRequested.emit('decrement');\n\n // Finished.\n return;\n }\n\n // Handle an increment button repeat.\n if (part === 'increment') {\n // Bail if the mouse is not over the button.\n if (!ElementExt.hitTest(this.incrementNode, mouseX, mouseY)) {\n return;\n }\n\n // Emit the step requested signal.\n this._stepRequested.emit('increment');\n\n // Finished.\n return;\n }\n\n // Handle a track repeat.\n if (part === 'track') {\n // Bail if the mouse is not over the track.\n if (!ElementExt.hitTest(this.trackNode, mouseX, mouseY)) {\n return;\n }\n\n // Fetch the thumb node.\n let thumbNode = this.thumbNode;\n\n // Bail if the mouse is over the thumb.\n if (ElementExt.hitTest(thumbNode, mouseX, mouseY)) {\n return;\n }\n\n // Fetch the client rect for the thumb.\n let thumbRect = thumbNode.getBoundingClientRect();\n\n // Determine the direction for the page request.\n let dir: 'decrement' | 'increment';\n if (this._orientation === 'horizontal') {\n dir = mouseX < thumbRect.left ? 'decrement' : 'increment';\n } else {\n dir = mouseY < thumbRect.top ? 'decrement' : 'increment';\n }\n\n // Emit the page requested signal.\n this._pageRequested.emit(dir);\n\n // Finished.\n return;\n }\n };\n\n private _value = 0;\n private _page = 10;\n private _maximum = 100;\n private _repeatTimer = -1;\n private _orientation: ScrollBar.Orientation;\n private _pressData: Private.IPressData | null = null;\n private _thumbMoved = new Signal(this);\n private _stepRequested = new Signal(this);\n private _pageRequested = new Signal(this);\n}\n\n/**\n * The namespace for the `ScrollBar` class statics.\n */\nexport namespace ScrollBar {\n /**\n * A type alias for a scroll bar orientation.\n */\n export type Orientation = 'horizontal' | 'vertical';\n\n /**\n * An options object for creating a scroll bar.\n */\n export interface IOptions {\n /**\n * The orientation of the scroll bar.\n *\n * The default is `'vertical'`.\n */\n orientation?: Orientation;\n\n /**\n * The value for the scroll bar.\n *\n * The default is `0`.\n */\n value?: number;\n\n /**\n * The page size for the scroll bar.\n *\n * The default is `10`.\n */\n page?: number;\n\n /**\n * The maximum value for the scroll bar.\n *\n * The default is `100`.\n */\n maximum?: number;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * A type alias for the parts of a scroll bar.\n */\n export type ScrollBarPart = 'thumb' | 'track' | 'decrement' | 'increment';\n\n /**\n * An object which holds mouse press data.\n */\n export interface IPressData {\n /**\n * The scroll bar part which was pressed.\n */\n part: ScrollBarPart;\n\n /**\n * The offset of the press in thumb coordinates, or -1.\n */\n delta: number;\n\n /**\n * The scroll value at the time the thumb was pressed, or -1.\n */\n value: number;\n\n /**\n * The disposable which will clear the override cursor.\n */\n override: IDisposable;\n\n /**\n * The current X position of the mouse.\n */\n mouseX: number;\n\n /**\n * The current Y position of the mouse.\n */\n mouseY: number;\n }\n\n /**\n * Create the DOM node for a scroll bar.\n */\n export function createNode(): HTMLElement {\n let node = document.createElement('div');\n let decrement = document.createElement('div');\n let increment = document.createElement('div');\n let track = document.createElement('div');\n let thumb = document.createElement('div');\n decrement.className = 'lm-ScrollBar-button';\n increment.className = 'lm-ScrollBar-button';\n decrement.dataset['action'] = 'decrement';\n increment.dataset['action'] = 'increment';\n track.className = 'lm-ScrollBar-track';\n thumb.className = 'lm-ScrollBar-thumb';\n track.appendChild(thumb);\n node.appendChild(decrement);\n node.appendChild(track);\n node.appendChild(increment);\n return node;\n }\n\n /**\n * Find the scroll bar part which contains the given target.\n */\n export function findPart(\n scrollBar: ScrollBar,\n target: HTMLElement\n ): ScrollBarPart | null {\n // Test the thumb.\n if (scrollBar.thumbNode.contains(target)) {\n return 'thumb';\n }\n\n // Test the track.\n if (scrollBar.trackNode.contains(target)) {\n return 'track';\n }\n\n // Test the decrement button.\n if (scrollBar.decrementNode.contains(target)) {\n return 'decrement';\n }\n\n // Test the increment button.\n if (scrollBar.incrementNode.contains(target)) {\n return 'increment';\n }\n\n // Indicate no match.\n return null;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { MessageLoop } from '@lumino/messaging';\n\nimport { Layout } from './layout';\n\nimport { Widget } from './widget';\n\n/**\n * A concrete layout implementation which holds a single widget.\n *\n * #### Notes\n * This class is useful for creating simple container widgets which\n * hold a single child. The child should be positioned with CSS.\n */\nexport class SingletonLayout extends Layout {\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n if (this._widget) {\n let widget = this._widget;\n this._widget = null;\n widget.dispose();\n }\n super.dispose();\n }\n\n /**\n * Get the child widget for the layout.\n */\n get widget(): Widget | null {\n return this._widget;\n }\n\n /**\n * Set the child widget for the layout.\n *\n * #### Notes\n * Setting the child widget will cause the old child widget to be\n * automatically disposed. If that is not desired, set the parent\n * of the old child to `null` before assigning a new child.\n */\n set widget(widget: Widget | null) {\n // Remove the widget from its current parent. This is a no-op\n // if the widget's parent is already the layout parent widget.\n if (widget) {\n widget.parent = this.parent;\n }\n\n // Bail early if the widget does not change.\n if (this._widget === widget) {\n return;\n }\n\n // Dispose of the old child widget.\n if (this._widget) {\n this._widget.dispose();\n }\n\n // Update the internal widget.\n this._widget = widget;\n\n // Attach the new child widget if needed.\n if (this.parent && widget) {\n this.attachWidget(widget);\n }\n }\n\n /**\n * Create an iterator over the widgets in the layout.\n *\n * @returns A new iterator over the widgets in the layout.\n */\n *[Symbol.iterator](): IterableIterator {\n if (this._widget) {\n yield this._widget;\n }\n }\n\n /**\n * Remove a widget from the layout.\n *\n * @param widget - The widget to remove from the layout.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method does *not* modify the widget's `parent`.\n */\n removeWidget(widget: Widget): void {\n // Bail early if the widget does not exist in the layout.\n if (this._widget !== widget) {\n return;\n }\n\n // Clear the internal widget.\n this._widget = null;\n\n // If the layout is parented, detach the widget from the DOM.\n if (this.parent) {\n this.detachWidget(widget);\n }\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n super.init();\n for (const widget of this) {\n this.attachWidget(widget);\n }\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This method is called automatically by the single layout at the\n * appropriate time. It should not be called directly by user code.\n *\n * The default implementation adds the widgets's node to the parent's\n * node at the proper location, and sends the appropriate attach\n * messages to the widget if the parent is attached to the DOM.\n *\n * Subclasses may reimplement this method to control how the widget's\n * node is added to the parent's node.\n */\n protected attachWidget(widget: Widget): void {\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget's node to the parent.\n this.parent!.node.appendChild(widget.node);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This method is called automatically by the single layout at the\n * appropriate time. It should not be called directly by user code.\n *\n * The default implementation removes the widget's node from the\n * parent's node, and sends the appropriate detach messages to the\n * widget if the parent is attached to the DOM.\n *\n * Subclasses may reimplement this method to control how the widget's\n * node is removed from the parent's node.\n */\n protected detachWidget(widget: Widget): void {\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n }\n\n private _widget: Widget | null = null;\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { Layout, LayoutItem } from './layout';\n\nimport { PanelLayout } from './panellayout';\n\nimport { Widget } from './widget';\n\n/**\n * A layout where visible widgets are stacked atop one another.\n *\n * #### Notes\n * The Z-order of the visible widgets follows their layout order.\n */\nexport class StackedLayout extends PanelLayout {\n constructor(options: StackedLayout.IOptions = {}) {\n super(options);\n this._hiddenMode =\n options.hiddenMode !== undefined\n ? options.hiddenMode\n : Widget.HiddenMode.Display;\n }\n\n /**\n * The method for hiding widgets.\n *\n * #### Notes\n * If there is only one child widget, `Display` hiding mode will be used\n * regardless of this setting.\n */\n get hiddenMode(): Widget.HiddenMode {\n return this._hiddenMode;\n }\n\n /**\n * Set the method for hiding widgets.\n *\n * #### Notes\n * If there is only one child widget, `Display` hiding mode will be used\n * regardless of this setting.\n */\n set hiddenMode(v: Widget.HiddenMode) {\n if (this._hiddenMode === v) {\n return;\n }\n this._hiddenMode = v;\n if (this.widgets.length > 1) {\n this.widgets.forEach(w => {\n w.hiddenMode = this._hiddenMode;\n });\n }\n }\n\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n // Dispose of the layout items.\n for (const item of this._items) {\n item.dispose();\n }\n\n // Clear the layout state.\n this._box = null;\n this._items.length = 0;\n\n // Dispose of the rest of the layout.\n super.dispose();\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param index - The current index of the widget in the layout.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected attachWidget(index: number, widget: Widget): void {\n // Using transform create an additional layer in the pixel pipeline\n // to limit the number of layer, it is set only if there is more than one widget.\n if (\n this._hiddenMode === Widget.HiddenMode.Scale &&\n this._items.length > 0\n ) {\n if (this._items.length === 1) {\n this.widgets[0].hiddenMode = Widget.HiddenMode.Scale;\n }\n widget.hiddenMode = Widget.HiddenMode.Scale;\n } else {\n widget.hiddenMode = Widget.HiddenMode.Display;\n }\n\n // Create and add a new layout item for the widget.\n ArrayExt.insert(this._items, index, new LayoutItem(widget));\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget's node to the parent.\n this.parent!.node.appendChild(widget.node);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * Move a widget in the parent's DOM node.\n *\n * @param fromIndex - The previous index of the widget in the layout.\n *\n * @param toIndex - The current index of the widget in the layout.\n *\n * @param widget - The widget to move in the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected moveWidget(\n fromIndex: number,\n toIndex: number,\n widget: Widget\n ): void {\n // Move the layout item for the widget.\n ArrayExt.move(this._items, fromIndex, toIndex);\n\n // Post an update request for the parent widget.\n this.parent!.update();\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param index - The previous index of the widget in the layout.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected detachWidget(index: number, widget: Widget): void {\n // Remove the layout item for the widget.\n let item = ArrayExt.removeAt(this._items, index);\n\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Reset the z-index for the widget.\n item!.widget.node.style.zIndex = '';\n\n // Reset the hidden mode for the widget.\n if (this._hiddenMode === Widget.HiddenMode.Scale) {\n widget.hiddenMode = Widget.HiddenMode.Display;\n\n // Reset the hidden mode for the first widget if necessary.\n if (this._items.length === 1) {\n this._items[0].widget.hiddenMode = Widget.HiddenMode.Display;\n }\n }\n\n // Dispose of the layout item.\n item!.dispose();\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n */\n protected onBeforeShow(msg: Message): void {\n super.onBeforeShow(msg);\n this.parent!.update();\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n super.onBeforeAttach(msg);\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n if (this.parent!.isVisible) {\n this._update(msg.width, msg.height);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.parent!.isVisible) {\n this._update(-1, -1);\n }\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n */\n protected onFitRequest(msg: Message): void {\n if (this.parent!.isAttached) {\n this._fit();\n }\n }\n\n /**\n * Fit the layout to the total size required by the widgets.\n */\n private _fit(): void {\n // Set up the computed minimum size.\n let minW = 0;\n let minH = 0;\n\n // Update the computed minimum size.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item.\n let item = this._items[i];\n\n // Ignore hidden items.\n if (item.isHidden) {\n continue;\n }\n\n // Update the size limits for the item.\n item.fit();\n\n // Update the computed minimum size.\n minW = Math.max(minW, item.minWidth);\n minH = Math.max(minH, item.minHeight);\n }\n\n // Update the box sizing and add it to the computed min size.\n let box = (this._box = ElementExt.boxSizing(this.parent!.node));\n minW += box.horizontalSum;\n minH += box.verticalSum;\n\n // Update the parent's min size constraints.\n let style = this.parent!.node.style;\n style.minWidth = `${minW}px`;\n style.minHeight = `${minH}px`;\n\n // Set the dirty flag to ensure only a single update occurs.\n this._dirty = true;\n\n // Notify the ancestor that it should fit immediately. This may\n // cause a resize of the parent, fulfilling the required update.\n if (this.parent!.parent) {\n MessageLoop.sendMessage(this.parent!.parent!, Widget.Msg.FitRequest);\n }\n\n // If the dirty flag is still set, the parent was not resized.\n // Trigger the required update on the parent widget immediately.\n if (this._dirty) {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n }\n }\n\n /**\n * Update the layout position and size of the widgets.\n *\n * The parent offset dimensions should be `-1` if unknown.\n */\n private _update(offsetWidth: number, offsetHeight: number): void {\n // Clear the dirty flag to indicate the update occurred.\n this._dirty = false;\n\n // Compute the visible item count.\n let nVisible = 0;\n for (let i = 0, n = this._items.length; i < n; ++i) {\n nVisible += +!this._items[i].isHidden;\n }\n\n // Bail early if there are no visible items to layout.\n if (nVisible === 0) {\n return;\n }\n\n // Measure the parent if the offset dimensions are unknown.\n if (offsetWidth < 0) {\n offsetWidth = this.parent!.node.offsetWidth;\n }\n if (offsetHeight < 0) {\n offsetHeight = this.parent!.node.offsetHeight;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent!.node);\n }\n\n // Compute the actual layout bounds adjusted for border and padding.\n let top = this._box.paddingTop;\n let left = this._box.paddingLeft;\n let width = offsetWidth - this._box.horizontalSum;\n let height = offsetHeight - this._box.verticalSum;\n\n // Update the widget stacking order and layout geometry.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item.\n let item = this._items[i];\n\n // Ignore hidden items.\n if (item.isHidden) {\n continue;\n }\n\n // Set the z-index for the widget.\n item.widget.node.style.zIndex = `${i}`;\n\n // Update the item geometry.\n item.update(left, top, width, height);\n }\n }\n\n private _dirty = false;\n private _items: LayoutItem[] = [];\n private _box: ElementExt.IBoxSizing | null = null;\n private _hiddenMode: Widget.HiddenMode;\n}\n\n/**\n * The namespace for the `StackedLayout` class statics.\n */\nexport namespace StackedLayout {\n /**\n * An options object for initializing a stacked layout.\n */\n export interface IOptions extends Layout.IOptions {\n /**\n * The method for hiding widgets.\n *\n * The default is `Widget.HiddenMode.Display`.\n */\n hiddenMode?: Widget.HiddenMode;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { Panel } from './panel';\n\nimport { StackedLayout } from './stackedlayout';\n\nimport { Widget } from './widget';\n\n/**\n * A panel where visible widgets are stacked atop one another.\n *\n * #### Notes\n * This class provides a convenience wrapper around a {@link StackedLayout}.\n */\nexport class StackedPanel extends Panel {\n /**\n * Construct a new stacked panel.\n *\n * @param options - The options for initializing the panel.\n */\n constructor(options: StackedPanel.IOptions = {}) {\n super({ layout: Private.createLayout(options) });\n this.addClass('lm-StackedPanel');\n }\n\n /**\n * The method for hiding widgets.\n *\n * #### Notes\n * If there is only one child widget, `Display` hiding mode will be used\n * regardless of this setting.\n */\n get hiddenMode(): Widget.HiddenMode {\n return (this.layout as StackedLayout).hiddenMode;\n }\n\n /**\n * Set the method for hiding widgets.\n *\n * #### Notes\n * If there is only one child widget, `Display` hiding mode will be used\n * regardless of this setting.\n */\n set hiddenMode(v: Widget.HiddenMode) {\n (this.layout as StackedLayout).hiddenMode = v;\n }\n\n /**\n * A signal emitted when a widget is removed from a stacked panel.\n */\n get widgetRemoved(): ISignal {\n return this._widgetRemoved;\n }\n\n /**\n * A message handler invoked on a `'child-added'` message.\n */\n protected onChildAdded(msg: Widget.ChildMessage): void {\n msg.child.addClass('lm-StackedPanel-child');\n }\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {\n msg.child.removeClass('lm-StackedPanel-child');\n this._widgetRemoved.emit(msg.child);\n }\n\n private _widgetRemoved = new Signal(this);\n}\n\n/**\n * The namespace for the `StackedPanel` class statics.\n */\nexport namespace StackedPanel {\n /**\n * An options object for creating a stacked panel.\n */\n export interface IOptions {\n /**\n * The stacked layout to use for the stacked panel.\n *\n * The default is a new `StackedLayout`.\n */\n layout?: StackedLayout;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Create a stacked layout for the given panel options.\n */\n export function createLayout(options: StackedPanel.IOptions): StackedLayout {\n return options.layout || new StackedLayout();\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { Platform } from '@lumino/domutils';\n\nimport { MessageLoop } from '@lumino/messaging';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { BoxLayout } from './boxlayout';\n\nimport { StackedPanel } from './stackedpanel';\n\nimport { TabBar } from './tabbar';\n\nimport { Widget } from './widget';\n\n/**\n * A widget which combines a `TabBar` and a `StackedPanel`.\n *\n * #### Notes\n * This is a simple panel which handles the common case of a tab bar\n * placed next to a content area. The selected tab controls the widget\n * which is shown in the content area.\n *\n * For use cases which require more control than is provided by this\n * panel, the `TabBar` widget may be used independently.\n */\nexport class TabPanel extends Widget {\n /**\n * Construct a new tab panel.\n *\n * @param options - The options for initializing the tab panel.\n */\n constructor(options: TabPanel.IOptions = {}) {\n super();\n this.addClass('lm-TabPanel');\n\n // Create the tab bar and stacked panel.\n this.tabBar = new TabBar(options);\n this.tabBar.addClass('lm-TabPanel-tabBar');\n this.stackedPanel = new StackedPanel();\n this.stackedPanel.addClass('lm-TabPanel-stackedPanel');\n\n // Connect the tab bar signal handlers.\n this.tabBar.tabMoved.connect(this._onTabMoved, this);\n this.tabBar.currentChanged.connect(this._onCurrentChanged, this);\n this.tabBar.tabCloseRequested.connect(this._onTabCloseRequested, this);\n this.tabBar.tabActivateRequested.connect(\n this._onTabActivateRequested,\n this\n );\n this.tabBar.addRequested.connect(this._onTabAddRequested, this);\n\n // Connect the stacked panel signal handlers.\n this.stackedPanel.widgetRemoved.connect(this._onWidgetRemoved, this);\n\n // Get the data related to the placement.\n this._tabPlacement = options.tabPlacement || 'top';\n let direction = Private.directionFromPlacement(this._tabPlacement);\n let orientation = Private.orientationFromPlacement(this._tabPlacement);\n\n // Configure the tab bar for the placement.\n this.tabBar.orientation = orientation;\n this.tabBar.dataset['placement'] = this._tabPlacement;\n\n // Create the box layout.\n let layout = new BoxLayout({ direction, spacing: 0 });\n\n // Set the stretch factors for the child widgets.\n BoxLayout.setStretch(this.tabBar, 0);\n BoxLayout.setStretch(this.stackedPanel, 1);\n\n // Add the child widgets to the layout.\n layout.addWidget(this.tabBar);\n layout.addWidget(this.stackedPanel);\n\n // Install the layout on the tab panel.\n this.layout = layout;\n }\n\n /**\n * A signal emitted when the current tab is changed.\n *\n * #### Notes\n * This signal is emitted when the currently selected tab is changed\n * either through user or programmatic interaction.\n *\n * Notably, this signal is not emitted when the index of the current\n * tab changes due to tabs being inserted, removed, or moved. It is\n * only emitted when the actual current tab node is changed.\n */\n get currentChanged(): ISignal {\n return this._currentChanged;\n }\n\n /**\n * Get the index of the currently selected tab.\n *\n * #### Notes\n * This will be `-1` if no tab is selected.\n */\n get currentIndex(): number {\n return this.tabBar.currentIndex;\n }\n\n /**\n * Set the index of the currently selected tab.\n *\n * #### Notes\n * If the index is out of range, it will be set to `-1`.\n */\n set currentIndex(value: number) {\n this.tabBar.currentIndex = value;\n }\n\n /**\n * Get the currently selected widget.\n *\n * #### Notes\n * This will be `null` if there is no selected tab.\n */\n get currentWidget(): Widget | null {\n let title = this.tabBar.currentTitle;\n return title ? title.owner : null;\n }\n\n /**\n * Set the currently selected widget.\n *\n * #### Notes\n * If the widget is not in the panel, it will be set to `null`.\n */\n set currentWidget(value: Widget | null) {\n this.tabBar.currentTitle = value ? value.title : null;\n }\n\n /**\n * Get the whether the tabs are movable by the user.\n *\n * #### Notes\n * Tabs can always be moved programmatically.\n */\n get tabsMovable(): boolean {\n return this.tabBar.tabsMovable;\n }\n\n /**\n * Set the whether the tabs are movable by the user.\n *\n * #### Notes\n * Tabs can always be moved programmatically.\n */\n set tabsMovable(value: boolean) {\n this.tabBar.tabsMovable = value;\n }\n\n /**\n * Get the whether the add button is enabled.\n *\n */\n get addButtonEnabled(): boolean {\n return this.tabBar.addButtonEnabled;\n }\n\n /**\n * Set the whether the add button is enabled.\n *\n */\n set addButtonEnabled(value: boolean) {\n this.tabBar.addButtonEnabled = value;\n }\n\n /**\n * Get the tab placement for the tab panel.\n *\n * #### Notes\n * This controls the position of the tab bar relative to the content.\n */\n get tabPlacement(): TabPanel.TabPlacement {\n return this._tabPlacement;\n }\n\n /**\n * Set the tab placement for the tab panel.\n *\n * #### Notes\n * This controls the position of the tab bar relative to the content.\n */\n set tabPlacement(value: TabPanel.TabPlacement) {\n // Bail if the placement does not change.\n if (this._tabPlacement === value) {\n return;\n }\n\n // Update the internal value.\n this._tabPlacement = value;\n\n // Get the values related to the placement.\n let direction = Private.directionFromPlacement(value);\n let orientation = Private.orientationFromPlacement(value);\n\n // Configure the tab bar for the placement.\n this.tabBar.orientation = orientation;\n this.tabBar.dataset['placement'] = value;\n\n // Update the layout direction.\n (this.layout as BoxLayout).direction = direction;\n }\n\n /**\n * A signal emitted when the add button on a tab bar is clicked.\n *\n */\n get addRequested(): ISignal> {\n return this._addRequested;\n }\n\n /**\n * The tab bar used by the tab panel.\n *\n * #### Notes\n * Modifying the tab bar directly can lead to undefined behavior.\n */\n readonly tabBar: TabBar;\n\n /**\n * The stacked panel used by the tab panel.\n *\n * #### Notes\n * Modifying the panel directly can lead to undefined behavior.\n */\n readonly stackedPanel: StackedPanel;\n\n /**\n * A read-only array of the widgets in the panel.\n */\n get widgets(): ReadonlyArray {\n return this.stackedPanel.widgets;\n }\n\n /**\n * Add a widget to the end of the tab panel.\n *\n * @param widget - The widget to add to the tab panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n *\n * The widget's `title` is used to populate the tab.\n */\n addWidget(widget: Widget): void {\n this.insertWidget(this.widgets.length, widget);\n }\n\n /**\n * Insert a widget into the tab panel at a specified index.\n *\n * @param index - The index at which to insert the widget.\n *\n * @param widget - The widget to insert into to the tab panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n *\n * The widget's `title` is used to populate the tab.\n */\n insertWidget(index: number, widget: Widget): void {\n if (widget !== this.currentWidget) {\n widget.hide();\n }\n this.stackedPanel.insertWidget(index, widget);\n this.tabBar.insertTab(index, widget.title);\n\n widget.node.setAttribute('role', 'tabpanel');\n\n let renderer = this.tabBar.renderer;\n if (renderer instanceof TabBar.Renderer) {\n let tabId = renderer.createTabKey({\n title: widget.title,\n current: false,\n zIndex: 0\n });\n widget.node.setAttribute('aria-labelledby', tabId);\n }\n }\n\n /**\n * Handle the `currentChanged` signal from the tab bar.\n */\n private _onCurrentChanged(\n sender: TabBar,\n args: TabBar.ICurrentChangedArgs\n ): void {\n // Extract the previous and current title from the args.\n let { previousIndex, previousTitle, currentIndex, currentTitle } = args;\n\n // Extract the widgets from the titles.\n let previousWidget = previousTitle ? previousTitle.owner : null;\n let currentWidget = currentTitle ? currentTitle.owner : null;\n\n // Hide the previous widget.\n if (previousWidget) {\n previousWidget.hide();\n }\n\n // Show the current widget.\n if (currentWidget) {\n currentWidget.show();\n }\n\n // Emit the `currentChanged` signal for the tab panel.\n this._currentChanged.emit({\n previousIndex,\n previousWidget,\n currentIndex,\n currentWidget\n });\n\n // Flush the message loop on IE and Edge to prevent flicker.\n if (Platform.IS_EDGE || Platform.IS_IE) {\n MessageLoop.flush();\n }\n }\n\n /**\n * Handle the `tabAddRequested` signal from the tab bar.\n */\n private _onTabAddRequested(sender: TabBar, args: void): void {\n this._addRequested.emit(sender);\n }\n\n /**\n * Handle the `tabActivateRequested` signal from the tab bar.\n */\n private _onTabActivateRequested(\n sender: TabBar,\n args: TabBar.ITabActivateRequestedArgs\n ): void {\n args.title.owner.activate();\n }\n\n /**\n * Handle the `tabCloseRequested` signal from the tab bar.\n */\n private _onTabCloseRequested(\n sender: TabBar,\n args: TabBar.ITabCloseRequestedArgs\n ): void {\n args.title.owner.close();\n }\n\n /**\n * Handle the `tabMoved` signal from the tab bar.\n */\n private _onTabMoved(\n sender: TabBar,\n args: TabBar.ITabMovedArgs\n ): void {\n this.stackedPanel.insertWidget(args.toIndex, args.title.owner);\n }\n\n /**\n * Handle the `widgetRemoved` signal from the stacked panel.\n */\n private _onWidgetRemoved(sender: StackedPanel, widget: Widget): void {\n widget.node.removeAttribute('role');\n widget.node.removeAttribute('aria-labelledby');\n this.tabBar.removeTab(widget.title);\n }\n\n private _tabPlacement: TabPanel.TabPlacement;\n private _currentChanged = new Signal(\n this\n );\n\n private _addRequested = new Signal>(this);\n}\n\n/**\n * The namespace for the `TabPanel` class statics.\n */\nexport namespace TabPanel {\n /**\n * A type alias for tab placement in a tab bar.\n */\n export type TabPlacement =\n | /**\n * The tabs are placed as a row above the content.\n */\n 'top'\n\n /**\n * The tabs are placed as a column to the left of the content.\n */\n | 'left'\n\n /**\n * The tabs are placed as a column to the right of the content.\n */\n | 'right'\n\n /**\n * The tabs are placed as a row below the content.\n */\n | 'bottom';\n\n /**\n * An options object for initializing a tab panel.\n */\n export interface IOptions {\n /**\n * The document to use with the tab panel.\n *\n * The default is the global `document` instance.\n */\n document?: Document | ShadowRoot;\n\n /**\n * Whether the tabs are movable by the user.\n *\n * The default is `false`.\n */\n tabsMovable?: boolean;\n\n /**\n * Whether the button to add new tabs is enabled.\n *\n * The default is `false`.\n */\n addButtonEnabled?: boolean;\n\n /**\n * The placement of the tab bar relative to the content.\n *\n * The default is `'top'`.\n */\n tabPlacement?: TabPlacement;\n\n /**\n * The renderer for the panel's tab bar.\n *\n * The default is a shared renderer instance.\n */\n renderer?: TabBar.IRenderer;\n }\n\n /**\n * The arguments object for the `currentChanged` signal.\n */\n export interface ICurrentChangedArgs {\n /**\n * The previously selected index.\n */\n previousIndex: number;\n\n /**\n * The previously selected widget.\n */\n previousWidget: Widget | null;\n\n /**\n * The currently selected index.\n */\n currentIndex: number;\n\n /**\n * The currently selected widget.\n */\n currentWidget: Widget | null;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Convert a tab placement to tab bar orientation.\n */\n export function orientationFromPlacement(\n plc: TabPanel.TabPlacement\n ): TabBar.Orientation {\n return placementToOrientationMap[plc];\n }\n\n /**\n * Convert a tab placement to a box layout direction.\n */\n export function directionFromPlacement(\n plc: TabPanel.TabPlacement\n ): BoxLayout.Direction {\n return placementToDirectionMap[plc];\n }\n\n /**\n * A mapping of tab placement to tab bar orientation.\n */\n const placementToOrientationMap: { [key: string]: TabBar.Orientation } = {\n top: 'horizontal',\n left: 'vertical',\n right: 'vertical',\n bottom: 'horizontal'\n };\n\n /**\n * A mapping of tab placement to box layout direction.\n */\n const placementToDirectionMap: { [key: string]: BoxLayout.Direction } = {\n top: 'top-to-bottom',\n left: 'left-to-right',\n right: 'right-to-left',\n bottom: 'bottom-to-top'\n };\n}\n"],"names":["BoxEngine","Signal","Private","MessageLoop","AttachedProperty","Message","ConflatableMessage","ElementExt","ArrayExt","Utils","UUID","Drag","VirtualDOM","h","StringExt","CommandRegistry","JSONExt","getKeyboardLayout","DisposableDelegate","Selector","empty","find","Platform","MimeData","max"],"mappings":"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"} +\ No newline at end of file +diff --git a/node_modules/@lumino/widgets/dist/index.min.js b/node_modules/@lumino/widgets/dist/index.min.js +index 7b6ebcc..c227a41 100644 +--- a/node_modules/@lumino/widgets/dist/index.min.js ++++ b/node_modules/@lumino/widgets/dist/index.min.js +@@ -1,2 +1,2 @@ +-!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@lumino/algorithm"),require("@lumino/coreutils"),require("@lumino/domutils"),require("@lumino/messaging"),require("@lumino/properties"),require("@lumino/signaling"),require("@lumino/dragdrop"),require("@lumino/commands"),require("@lumino/virtualdom"),require("@lumino/disposable"),require("@lumino/keyboard")):"function"==typeof define&&define.amd?define(["exports","@lumino/algorithm","@lumino/coreutils","@lumino/domutils","@lumino/messaging","@lumino/properties","@lumino/signaling","@lumino/dragdrop","@lumino/commands","@lumino/virtualdom","@lumino/disposable","@lumino/keyboard"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).lumino_widgets={},e.lumino_algorithm,e.lumino_coreutils,e.lumino_domutils,e.lumino_messaging,e.lumino_properties,e.lumino_signaling,e.lumino_dragdrop,e.lumino_commands,e.lumino_virtualdom,e.lumino_disposable,e.lumino_keyboard)}(this,(function(e,t,i,s,n,a,r,o,h,d,l,c){"use strict";class u{constructor(){this.sizeHint=0,this.minSize=0,this.maxSize=1/0,this.stretch=1,this.size=0,this.done=!1}}var m,g,p,_;e.BoxEngine=void 0,(m=e.BoxEngine||(e.BoxEngine={})).calc=function(e,t){let i=e.length;if(0===i)return t;let s=0,n=0,a=0,r=0,o=0;for(let t=0;t0&&(r+=i.stretch,o++)}if(t===a)return 0;if(t<=s){for(let t=0;t=n){for(let t=0;t0&&s>h;){let t=s,n=r;for(let a=0;a0&&s>h;){let t=s/d;for(let n=0;n0&&s>h;){let t=s,n=r;for(let a=0;a=i.maxSize?(s-=i.maxSize-i.size,r-=i.stretch,i.size=i.maxSize,i.done=!0,d--,o--):(s-=h,i.size+=h)}}for(;d>0&&s>h;){let t=s/d;for(let n=0;n=i.maxSize?(s-=i.maxSize-i.size,i.size=i.maxSize,i.done=!0,d--):(s-=t,i.size+=t))}}}return 0},m.adjust=function(e,t,i){0!==e.length&&0!==i&&(i>0?function(e,t,i){let s=0;for(let i=0;i<=t;++i){let t=e[i];s+=t.maxSize-t.size}let n=0;for(let i=t+1,s=e.length;i=0&&a>0;--i){let t=e[i],s=t.maxSize-t.size;s>=a?(t.sizeHint=t.size+a,a=0):(t.sizeHint=t.size+s,a-=s)}let r=i;for(let i=t+1,s=e.length;i0;++i){let t=e[i],s=t.size-t.minSize;s>=r?(t.sizeHint=t.size-r,r=0):(t.sizeHint=t.size-s,r-=s)}}(e,t,i):function(e,t,i){let s=0;for(let i=t+1,n=e.length;i0;++i){let t=e[i],s=t.maxSize-t.size;s>=a?(t.sizeHint=t.size+a,a=0):(t.sizeHint=t.size+s,a-=s)}let r=i;for(let i=t;i>=0&&r>0;--i){let t=e[i],s=t.size-t.minSize;s>=r?(t.sizeHint=t.size-r,r=0):(t.sizeHint=t.size-s,r-=s)}}(e,t,-i))};class f{constructor(e){this._label="",this._caption="",this._mnemonic=-1,this._icon=void 0,this._iconClass="",this._iconLabel="",this._className="",this._closable=!1,this._changed=new r.Signal(this),this._isDisposed=!1,this.owner=e.owner,void 0!==e.label&&(this._label=e.label),void 0!==e.mnemonic&&(this._mnemonic=e.mnemonic),void 0!==e.icon&&(this._icon=e.icon),void 0!==e.iconClass&&(this._iconClass=e.iconClass),void 0!==e.iconLabel&&(this._iconLabel=e.iconLabel),void 0!==e.caption&&(this._caption=e.caption),void 0!==e.className&&(this._className=e.className),void 0!==e.closable&&(this._closable=e.closable),this._dataset=e.dataset||{}}get changed(){return this._changed}get label(){return this._label}set label(e){this._label!==e&&(this._label=e,this._changed.emit(void 0))}get mnemonic(){return this._mnemonic}set mnemonic(e){this._mnemonic!==e&&(this._mnemonic=e,this._changed.emit(void 0))}get icon(){return this._icon}set icon(e){this._icon!==e&&(this._icon=e,this._changed.emit(void 0))}get iconClass(){return this._iconClass}set iconClass(e){this._iconClass!==e&&(this._iconClass=e,this._changed.emit(void 0))}get iconLabel(){return this._iconLabel}set iconLabel(e){this._iconLabel!==e&&(this._iconLabel=e,this._changed.emit(void 0))}get caption(){return this._caption}set caption(e){this._caption!==e&&(this._caption=e,this._changed.emit(void 0))}get className(){return this._className}set className(e){this._className!==e&&(this._className=e,this._changed.emit(void 0))}get closable(){return this._closable}set closable(e){this._closable!==e&&(this._closable=e,this._changed.emit(void 0))}get dataset(){return this._dataset}set dataset(e){this._dataset!==e&&(this._dataset=e,this._changed.emit(void 0))}get isDisposed(){return this._isDisposed}dispose(){this.isDisposed||(this._isDisposed=!0,r.Signal.clearData(this))}}class b{constructor(e={}){this._flags=0,this._layout=null,this._parent=null,this._disposed=new r.Signal(this),this._hiddenMode=b.HiddenMode.Display,this.node=g.createNode(e),this.addClass("lm-Widget")}dispose(){this.isDisposed||(this.setFlag(b.Flag.IsDisposed),this._disposed.emit(void 0),this.parent?this.parent=null:this.isAttached&&b.detach(this),this._layout&&(this._layout.dispose(),this._layout=null),this.title.dispose(),r.Signal.clearData(this),n.MessageLoop.clearData(this),a.AttachedProperty.clearData(this))}get disposed(){return this._disposed}get isDisposed(){return this.testFlag(b.Flag.IsDisposed)}get isAttached(){return this.testFlag(b.Flag.IsAttached)}get isHidden(){return this.testFlag(b.Flag.IsHidden)}get isVisible(){return this.testFlag(b.Flag.IsVisible)}get title(){return g.titleProperty.get(this)}get id(){return this.node.id}set id(e){this.node.id=e}get dataset(){return this.node.dataset}get hiddenMode(){return this._hiddenMode}set hiddenMode(e){this._hiddenMode!==e&&(this.isHidden&&this._toggleHidden(!1),e==b.HiddenMode.Scale?this.node.style.willChange="transform":this.node.style.willChange="auto",this._hiddenMode=e,this.isHidden&&this._toggleHidden(!0))}get parent(){return this._parent}set parent(e){if(this._parent!==e){if(e&&this.contains(e))throw new Error("Invalid parent widget.");if(this._parent&&!this._parent.isDisposed){let e=new b.ChildMessage("child-removed",this);n.MessageLoop.sendMessage(this._parent,e)}if(this._parent=e,this._parent&&!this._parent.isDisposed){let e=new b.ChildMessage("child-added",this);n.MessageLoop.sendMessage(this._parent,e)}this.isDisposed||n.MessageLoop.sendMessage(this,b.Msg.ParentChanged)}}get layout(){return this._layout}set layout(e){if(this._layout!==e){if(this.testFlag(b.Flag.DisallowLayout))throw new Error("Cannot set widget layout.");if(this._layout)throw new Error("Cannot change widget layout.");if(e.parent)throw new Error("Cannot change layout parent.");this._layout=e,e.parent=this}}*children(){this._layout&&(yield*this._layout)}contains(e){for(let t=e;t;t=t._parent)if(t===this)return!0;return!1}hasClass(e){return this.node.classList.contains(e)}addClass(e){this.node.classList.add(e)}removeClass(e){this.node.classList.remove(e)}toggleClass(e,t){return!0===t?(this.node.classList.add(e),!0):!1===t?(this.node.classList.remove(e),!1):this.node.classList.toggle(e)}update(){n.MessageLoop.postMessage(this,b.Msg.UpdateRequest)}fit(){n.MessageLoop.postMessage(this,b.Msg.FitRequest)}activate(){n.MessageLoop.postMessage(this,b.Msg.ActivateRequest)}close(){n.MessageLoop.sendMessage(this,b.Msg.CloseRequest)}show(){if(this.testFlag(b.Flag.IsHidden)&&(!this.isAttached||this.parent&&!this.parent.isVisible||n.MessageLoop.sendMessage(this,b.Msg.BeforeShow),this.clearFlag(b.Flag.IsHidden),this._toggleHidden(!1),!this.isAttached||this.parent&&!this.parent.isVisible||n.MessageLoop.sendMessage(this,b.Msg.AfterShow),this.parent)){let e=new b.ChildMessage("child-shown",this);n.MessageLoop.sendMessage(this.parent,e)}}hide(){if(!this.testFlag(b.Flag.IsHidden)&&(!this.isAttached||this.parent&&!this.parent.isVisible||n.MessageLoop.sendMessage(this,b.Msg.BeforeHide),this.setFlag(b.Flag.IsHidden),this._toggleHidden(!0),!this.isAttached||this.parent&&!this.parent.isVisible||n.MessageLoop.sendMessage(this,b.Msg.AfterHide),this.parent)){let e=new b.ChildMessage("child-hidden",this);n.MessageLoop.sendMessage(this.parent,e)}}setHidden(e){e?this.hide():this.show()}testFlag(e){return 0!=(this._flags&e)}setFlag(e){this._flags|=e}clearFlag(e){this._flags&=~e}processMessage(e){switch(e.type){case"resize":this.notifyLayout(e),this.onResize(e);break;case"update-request":this.notifyLayout(e),this.onUpdateRequest(e);break;case"fit-request":this.notifyLayout(e),this.onFitRequest(e);break;case"before-show":this.notifyLayout(e),this.onBeforeShow(e);break;case"after-show":this.setFlag(b.Flag.IsVisible),this.notifyLayout(e),this.onAfterShow(e);break;case"before-hide":this.notifyLayout(e),this.onBeforeHide(e);break;case"after-hide":this.clearFlag(b.Flag.IsVisible),this.notifyLayout(e),this.onAfterHide(e);break;case"before-attach":this.notifyLayout(e),this.onBeforeAttach(e);break;case"after-attach":this.isHidden||this.parent&&!this.parent.isVisible||this.setFlag(b.Flag.IsVisible),this.setFlag(b.Flag.IsAttached),this.notifyLayout(e),this.onAfterAttach(e);break;case"before-detach":this.notifyLayout(e),this.onBeforeDetach(e);break;case"after-detach":this.clearFlag(b.Flag.IsVisible),this.clearFlag(b.Flag.IsAttached),this.notifyLayout(e),this.onAfterDetach(e);break;case"activate-request":this.notifyLayout(e),this.onActivateRequest(e);break;case"close-request":this.notifyLayout(e),this.onCloseRequest(e);break;case"child-added":this.notifyLayout(e),this.onChildAdded(e);break;case"child-removed":this.notifyLayout(e),this.onChildRemoved(e);break;default:this.notifyLayout(e)}}notifyLayout(e){this._layout&&this._layout.processParentMessage(e)}onCloseRequest(e){this.parent?this.parent=null:this.isAttached&&b.detach(this)}onResize(e){}onUpdateRequest(e){}onFitRequest(e){}onActivateRequest(e){}onBeforeShow(e){}onAfterShow(e){}onBeforeHide(e){}onAfterHide(e){}onBeforeAttach(e){}onAfterAttach(e){}onBeforeDetach(e){}onAfterDetach(e){}onChildAdded(e){}onChildRemoved(e){}_toggleHidden(e){if(e)switch(this._hiddenMode){case b.HiddenMode.Display:this.addClass("lm-mod-hidden");break;case b.HiddenMode.Scale:this.node.style.transform="scale(0)",this.node.setAttribute("aria-hidden","true");break;case b.HiddenMode.ContentVisibility:this.node.style.contentVisibility="hidden",this.node.style.zIndex="-1"}else switch(this._hiddenMode){case b.HiddenMode.Display:this.removeClass("lm-mod-hidden");break;case b.HiddenMode.Scale:this.node.style.transform="",this.node.removeAttribute("aria-hidden");break;case b.HiddenMode.ContentVisibility:this.node.style.contentVisibility="",this.node.style.zIndex=""}}}!function(e){var t,i,s;(t=e.HiddenMode||(e.HiddenMode={}))[t.Display=0]="Display",t[t.Scale=1]="Scale",t[t.ContentVisibility=2]="ContentVisibility",(i=e.Flag||(e.Flag={}))[i.IsDisposed=1]="IsDisposed",i[i.IsAttached=2]="IsAttached",i[i.IsHidden=4]="IsHidden",i[i.IsVisible=8]="IsVisible",i[i.DisallowLayout=16]="DisallowLayout",(s=e.Msg||(e.Msg={})).BeforeShow=new n.Message("before-show"),s.AfterShow=new n.Message("after-show"),s.BeforeHide=new n.Message("before-hide"),s.AfterHide=new n.Message("after-hide"),s.BeforeAttach=new n.Message("before-attach"),s.AfterAttach=new n.Message("after-attach"),s.BeforeDetach=new n.Message("before-detach"),s.AfterDetach=new n.Message("after-detach"),s.ParentChanged=new n.Message("parent-changed"),s.UpdateRequest=new n.ConflatableMessage("update-request"),s.FitRequest=new n.ConflatableMessage("fit-request"),s.ActivateRequest=new n.ConflatableMessage("activate-request"),s.CloseRequest=new n.ConflatableMessage("close-request");class a extends n.Message{constructor(e,t){super(e),this.child=t}}e.ChildMessage=a;class r extends n.Message{constructor(e,t){super("resize"),this.width=e,this.height=t}}e.ResizeMessage=r,function(e){e.UnknownSize=new e(-1,-1)}(r=e.ResizeMessage||(e.ResizeMessage={})),e.attach=function(t,i,s=null){if(t.parent)throw new Error("Cannot attach a child widget.");if(t.isAttached||t.node.isConnected)throw new Error("Widget is already attached.");if(!i.isConnected)throw new Error("Host is not attached.");n.MessageLoop.sendMessage(t,e.Msg.BeforeAttach),i.insertBefore(t.node,s),n.MessageLoop.sendMessage(t,e.Msg.AfterAttach)},e.detach=function(t){if(t.parent)throw new Error("Cannot detach a child widget.");if(!t.isAttached||!t.node.isConnected)throw new Error("Widget is not attached.");n.MessageLoop.sendMessage(t,e.Msg.BeforeDetach),t.node.parentNode.removeChild(t.node),n.MessageLoop.sendMessage(t,e.Msg.AfterDetach)}}(b||(b={})),function(e){e.titleProperty=new a.AttachedProperty({name:"title",create:e=>new f({owner:e})}),e.createNode=function(e){return e.node||document.createElement(e.tag||"div")}}(g||(g={}));class v{constructor(e={}){this._disposed=!1,this._parent=null,this._fitPolicy=e.fitPolicy||"set-min-size"}dispose(){this._parent=null,this._disposed=!0,r.Signal.clearData(this),a.AttachedProperty.clearData(this)}get isDisposed(){return this._disposed}get parent(){return this._parent}set parent(e){if(this._parent!==e){if(this._parent)throw new Error("Cannot change parent widget.");if(e.layout!==this)throw new Error("Invalid parent widget.");this._parent=e,this.init()}}get fitPolicy(){return this._fitPolicy}set fitPolicy(e){if(this._fitPolicy!==e&&(this._fitPolicy=e,this._parent)){let e=this._parent.node.style;e.minWidth="",e.minHeight="",e.maxWidth="",e.maxHeight="",this._parent.fit()}}processParentMessage(e){switch(e.type){case"resize":this.onResize(e);break;case"update-request":this.onUpdateRequest(e);break;case"fit-request":this.onFitRequest(e);break;case"before-show":this.onBeforeShow(e);break;case"after-show":this.onAfterShow(e);break;case"before-hide":this.onBeforeHide(e);break;case"after-hide":this.onAfterHide(e);break;case"before-attach":this.onBeforeAttach(e);break;case"after-attach":this.onAfterAttach(e);break;case"before-detach":this.onBeforeDetach(e);break;case"after-detach":this.onAfterDetach(e);break;case"child-removed":this.onChildRemoved(e);break;case"child-shown":this.onChildShown(e);break;case"child-hidden":this.onChildHidden(e)}}init(){for(const e of this)e.parent=this.parent}onResize(e){for(const e of this)n.MessageLoop.sendMessage(e,b.ResizeMessage.UnknownSize)}onUpdateRequest(e){for(const e of this)n.MessageLoop.sendMessage(e,b.ResizeMessage.UnknownSize)}onBeforeAttach(e){for(const t of this)n.MessageLoop.sendMessage(t,e)}onAfterAttach(e){for(const t of this)n.MessageLoop.sendMessage(t,e)}onBeforeDetach(e){for(const t of this)n.MessageLoop.sendMessage(t,e)}onAfterDetach(e){for(const t of this)n.MessageLoop.sendMessage(t,e)}onBeforeShow(e){for(const t of this)t.isHidden||n.MessageLoop.sendMessage(t,e)}onAfterShow(e){for(const t of this)t.isHidden||n.MessageLoop.sendMessage(t,e)}onBeforeHide(e){for(const t of this)t.isHidden||n.MessageLoop.sendMessage(t,e)}onAfterHide(e){for(const t of this)t.isHidden||n.MessageLoop.sendMessage(t,e)}onChildRemoved(e){this.removeWidget(e.child)}onFitRequest(e){}onChildShown(e){}onChildHidden(e){}}!function(e){e.getHorizontalAlignment=function(e){return p.horizontalAlignmentProperty.get(e)},e.setHorizontalAlignment=function(e,t){p.horizontalAlignmentProperty.set(e,t)},e.getVerticalAlignment=function(e){return p.verticalAlignmentProperty.get(e)},e.setVerticalAlignment=function(e,t){p.verticalAlignmentProperty.set(e,t)}}(v||(v={}));class x{constructor(e){this._top=NaN,this._left=NaN,this._width=NaN,this._height=NaN,this._minWidth=0,this._minHeight=0,this._maxWidth=1/0,this._maxHeight=1/0,this._disposed=!1,this.widget=e,this.widget.node.style.position="absolute",this.widget.node.style.contain="strict"}dispose(){if(this._disposed)return;this._disposed=!0;let e=this.widget.node.style;e.position="",e.top="",e.left="",e.width="",e.height="",e.contain=""}get minWidth(){return this._minWidth}get minHeight(){return this._minHeight}get maxWidth(){return this._maxWidth}get maxHeight(){return this._maxHeight}get isDisposed(){return this._disposed}get isHidden(){return this.widget.isHidden}get isVisible(){return this.widget.isVisible}get isAttached(){return this.widget.isAttached}fit(){let e=s.ElementExt.sizeLimits(this.widget.node);this._minWidth=e.minWidth,this._minHeight=e.minHeight,this._maxWidth=e.maxWidth,this._maxHeight=e.maxHeight}update(e,t,i,s){let a=Math.max(this._minWidth,Math.min(i,this._maxWidth)),r=Math.max(this._minHeight,Math.min(s,this._maxHeight));if(a"center",changed:t}),e.verticalAlignmentProperty=new a.AttachedProperty({name:"verticalAlignment",create:()=>"top",changed:t})}(p||(p={}));class M extends v{constructor(){super(...arguments),this._widgets=[]}dispose(){for(;this._widgets.length>0;)this._widgets.pop().dispose();super.dispose()}get widgets(){return this._widgets}*[Symbol.iterator](){yield*this._widgets}addWidget(e){this.insertWidget(this._widgets.length,e)}insertWidget(e,i){i.parent=this.parent;let s=this._widgets.indexOf(i),n=Math.max(0,Math.min(e,this._widgets.length));if(-1===s)return t.ArrayExt.insert(this._widgets,n,i),void(this.parent&&this.attachWidget(n,i));n===this._widgets.length&&n--,s!==n&&(t.ArrayExt.move(this._widgets,s,n),this.parent&&this.moveWidget(s,n,i))}removeWidget(e){this.removeWidgetAt(this._widgets.indexOf(e))}removeWidgetAt(e){let i=t.ArrayExt.removeAt(this._widgets,e);i&&this.parent&&this.detachWidget(e,i)}init(){super.init();let e=0;for(const t of this)this.attachWidget(e++,t)}attachWidget(e,t){let i=this.parent.node.children[e];this.parent.isAttached&&n.MessageLoop.sendMessage(t,b.Msg.BeforeAttach),this.parent.node.insertBefore(t.node,i),this.parent.isAttached&&n.MessageLoop.sendMessage(t,b.Msg.AfterAttach)}moveWidget(e,t,i){this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.BeforeDetach),this.parent.node.removeChild(i.node),this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.AfterDetach);let s=this.parent.node.children[t];this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.BeforeAttach),this.parent.node.insertBefore(i.node,s),this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.AfterAttach)}detachWidget(e,t){this.parent.isAttached&&n.MessageLoop.sendMessage(t,b.Msg.BeforeDetach),this.parent.node.removeChild(t.node),this.parent.isAttached&&n.MessageLoop.sendMessage(t,b.Msg.AfterDetach)}}!function(e){e.clampDimension=function(e){return Math.max(0,Math.floor(e))}}(_||(_={}));var y,w,A,E,C,S,I,z,L,T,D=_;class B extends M{constructor(e){super(),this.widgetOffset=0,this._fixed=0,this._spacing=4,this._dirty=!1,this._hasNormedSizes=!1,this._sizers=[],this._items=[],this._handles=[],this._box=null,this._alignment="start",this._orientation="horizontal",this.renderer=e.renderer,void 0!==e.orientation&&(this._orientation=e.orientation),void 0!==e.alignment&&(this._alignment=e.alignment),void 0!==e.spacing&&(this._spacing=_.clampDimension(e.spacing))}dispose(){for(const e of this._items)e.dispose();this._box=null,this._items.length=0,this._sizers.length=0,this._handles.length=0,super.dispose()}get orientation(){return this._orientation}set orientation(e){this._orientation!==e&&(this._orientation=e,this.parent&&(this.parent.dataset.orientation=e,this.parent.fit()))}get alignment(){return this._alignment}set alignment(e){this._alignment!==e&&(this._alignment=e,this.parent&&(this.parent.dataset.alignment=e,this.parent.update()))}get spacing(){return this._spacing}set spacing(e){e=_.clampDimension(e),this._spacing!==e&&(this._spacing=e,this.parent&&this.parent.fit())}get handles(){return this._handles}absoluteSizes(){return this._sizers.map((e=>e.size))}relativeSizes(){return y.normalize(this._sizers.map((e=>e.size)))}setRelativeSizes(e,t=!0){let i=this._sizers.length,s=e.slice(0,i);for(;s.length0&&(e.sizeHint=e.size);e.BoxEngine.adjust(this._sizers,t,s),this.parent&&this.parent.update()}}init(){this.parent.dataset.orientation=this.orientation,this.parent.dataset.alignment=this.alignment,super.init()}attachWidget(e,i){let s=new x(i),a=y.createHandle(this.renderer),r=y.averageSize(this._sizers),o=y.createSizer(r);t.ArrayExt.insert(this._items,e,s),t.ArrayExt.insert(this._sizers,e,o),t.ArrayExt.insert(this._handles,e,a),this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.BeforeAttach),this.parent.node.appendChild(i.node),this.parent.node.appendChild(a),this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.AfterAttach),this.parent.fit()}moveWidget(e,i,s){t.ArrayExt.move(this._items,e,i),t.ArrayExt.move(this._sizers,e,i),t.ArrayExt.move(this._handles,e,i),this.parent.fit()}detachWidget(e,i){let s=t.ArrayExt.removeAt(this._items,e),a=t.ArrayExt.removeAt(this._handles,e);t.ArrayExt.removeAt(this._sizers,e),this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.BeforeDetach),this.parent.node.removeChild(i.node),this.parent.node.removeChild(a),this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.AfterDetach),s.dispose(),this.parent.fit()}onBeforeShow(e){super.onBeforeShow(e),this.parent.update()}onBeforeAttach(e){super.onBeforeAttach(e),this.parent.fit()}onChildShown(e){this.parent.fit()}onChildHidden(e){this.parent.fit()}onResize(e){this.parent.isVisible&&this._update(e.width,e.height)}onUpdateRequest(e){this.parent.isVisible&&this._update(-1,-1)}onFitRequest(e){this.parent.isAttached&&this._fit()}updateItemPosition(e,t,i,s,n,a,r){const o=this._items[e];if(o.isHidden)return;let h=this._handles[e].style;t?(i+=this.widgetOffset,o.update(i,s,r,n),i+=r,h.top=`${s}px`,h.left=`${i}px`,h.width=`${this._spacing}px`,h.height=`${n}px`):(s+=this.widgetOffset,o.update(i,s,a,r),s+=r,h.top=`${s}px`,h.left=`${i}px`,h.width=`${a}px`,h.height=`${this._spacing}px`)}_fit(){let e=0,t=-1;for(let i=0,s=this._items.length;i0&&(s.sizeHint=s.size),t.isHidden?(s.minSize=0,s.maxSize=0):(t.fit(),s.stretch=B.getStretch(t.widget),i?(s.minSize=t.minWidth,s.maxSize=t.maxWidth,a+=t.minWidth,r=Math.max(r,t.minHeight)):(s.minSize=t.minHeight,s.maxSize=t.maxHeight,r+=t.minHeight,a=Math.max(a,t.minWidth)))}let o=this._box=s.ElementExt.boxSizing(this.parent.node);a+=o.horizontalSum,r+=o.verticalSum;let h=this.parent.node.style;h.minWidth=`${a}px`,h.minHeight=`${r}px`,this._dirty=!0,this.parent.parent&&n.MessageLoop.sendMessage(this.parent.parent,b.Msg.FitRequest),this._dirty&&n.MessageLoop.sendMessage(this.parent,b.Msg.UpdateRequest)}_update(t,i){this._dirty=!1;let n=0;for(let e=0,t=this._items.length;e0){let t;if(t=c?Math.max(0,o-this._fixed):Math.max(0,h-this._fixed),this._hasNormedSizes){for(let e of this._sizers)e.sizeHint*=t;this._hasNormedSizes=!1}let i=e.BoxEngine.calc(this._sizers,t);if(i>0)switch(this._alignment){case"start":break;case"center":d=0,l=i/2;break;case"end":d=0,l=i;break;case"justify":d=i/n,l=0;break;default:throw"unreachable"}}for(let e=0,t=this._items.length;e0,coerce:(e,t)=>Math.max(0,Math.floor(t)),changed:function(e){e.parent&&e.parent.layout instanceof B&&e.parent.fit()}}),e.createSizer=function(e){let t=new u;return t.sizeHint=Math.floor(e),t},e.createHandle=function(e){let t=e.createHandle();return t.style.position="absolute",t.style.contain="style",t},e.averageSize=function(e){return e.reduce(((e,t)=>e+t.size),0)/e.length||0},e.normalize=function(e){let t=e.length;if(0===t)return[];let i=e.reduce(((e,t)=>e+Math.abs(t)),0);return 0===i?e.map((e=>1/t)):e.map((e=>e/i))}}(y||(y={}));class k extends B{constructor(e){super({...e,orientation:e.orientation||"vertical"}),this._titles=[],this.titleSpace=e.titleSpace||22}get titleSpace(){return this.widgetOffset}set titleSpace(e){e=D.clampDimension(e),this.widgetOffset!==e&&(this.widgetOffset=e,this.parent&&this.parent.fit())}get titles(){return this._titles}dispose(){this.isDisposed||(this._titles.length=0,super.dispose())}updateTitle(e,t){const i=this._titles[e],s=i.classList.contains("lm-mod-expanded"),n=w.createTitle(this.renderer,t.title,s);this._titles[e]=n,this.parent.node.replaceChild(n,i)}insertWidget(e,t){t.id||(t.id=`id-${i.UUID.uuid4()}`),super.insertWidget(e,t)}attachWidget(e,i){const s=w.createTitle(this.renderer,i.title);t.ArrayExt.insert(this._titles,e,s),this.parent.node.appendChild(s),i.node.setAttribute("role","region"),i.node.setAttribute("aria-labelledby",s.id),super.attachWidget(e,i)}moveWidget(e,i,s){t.ArrayExt.move(this._titles,e,i),super.moveWidget(e,i,s)}detachWidget(e,i){const s=t.ArrayExt.removeAt(this._titles,e);this.parent.node.removeChild(s),super.detachWidget(e,i)}updateItemPosition(e,t,i,s,n,a,r){const o=this._titles[e].style;o.top=`${s}px`,o.left=`${i}px`,o.height=`${this.widgetOffset}px`,o.width=t?`${n}px`:`${a}px`,super.updateItemPosition(e,t,i,s,n,a,r)}}!function(e){e.createTitle=function(e,t,i=!0){const s=e.createSectionTitle(t);return s.style.position="absolute",s.style.contain="strict",s.setAttribute("aria-label",`${t.label} Section`),s.setAttribute("aria-expanded",i?"true":"false"),s.setAttribute("aria-controls",t.owner.id),i&&s.classList.add("lm-mod-expanded"),s}}(w||(w={}));class R extends b{constructor(e={}){super(),this.addClass("lm-Panel"),this.layout=A.createLayout(e)}get widgets(){return this.layout.widgets}addWidget(e){this.layout.addWidget(e)}insertWidget(e,t){this.layout.insertWidget(e,t)}}!function(e){e.createLayout=function(e){return e.layout||new M}}(A||(A={}));class N extends R{constructor(e={}){super({layout:E.createLayout(e)}),this._handleMoved=new r.Signal(this),this._pressData=null,this.addClass("lm-SplitPanel")}dispose(){this._releaseMouse(),super.dispose()}get orientation(){return this.layout.orientation}set orientation(e){this.layout.orientation=e}get alignment(){return this.layout.alignment}set alignment(e){this.layout.alignment=e}get spacing(){return this.layout.spacing}set spacing(e){this.layout.spacing=e}get renderer(){return this.layout.renderer}get handleMoved(){return this._handleMoved}get handles(){return this.layout.handles}relativeSizes(){return this.layout.relativeSizes()}setRelativeSizes(e,t=!0){this.layout.setRelativeSizes(e,t)}handleEvent(e){switch(e.type){case"pointerdown":this._evtPointerDown(e);break;case"pointermove":this._evtPointerMove(e);break;case"pointerup":this._evtPointerUp(e);break;case"keydown":this._evtKeyDown(e);break;case"contextmenu":e.preventDefault(),e.stopPropagation()}}onBeforeAttach(e){this.node.addEventListener("pointerdown",this)}onAfterDetach(e){this.node.removeEventListener("pointerdown",this),this._releaseMouse()}onChildAdded(e){e.child.addClass("lm-SplitPanel-child"),this._releaseMouse()}onChildRemoved(e){e.child.removeClass("lm-SplitPanel-child"),this._releaseMouse()}_evtKeyDown(e){this._pressData&&(e.preventDefault(),e.stopPropagation()),27===e.keyCode&&this._releaseMouse()}_evtPointerDown(e){if(0!==e.button)return;let i,s=this.layout,n=t.ArrayExt.findFirstIndex(s.handles,(t=>t.contains(e.target)));if(-1===n)return;e.preventDefault(),e.stopPropagation(),document.addEventListener("pointerup",this,!0),document.addEventListener("pointermove",this,!0),document.addEventListener("keydown",this,!0),document.addEventListener("contextmenu",this,!0);let a=s.handles[n],r=a.getBoundingClientRect();i="horizontal"===s.orientation?e.clientX-r.left:e.clientY-r.top;let h=window.getComputedStyle(a),d=o.Drag.overrideCursor(h.cursor);this._pressData={index:n,delta:i,override:d}}_evtPointerMove(e){let t;e.preventDefault(),e.stopPropagation();let i=this.layout,s=this.node.getBoundingClientRect();t="horizontal"===i.orientation?e.clientX-s.left-this._pressData.delta:e.clientY-s.top-this._pressData.delta,i.moveHandle(this._pressData.index,t)}_evtPointerUp(e){0===e.button&&(e.preventDefault(),e.stopPropagation(),this._releaseMouse())}_releaseMouse(){this._pressData&&(this._pressData.override.dispose(),this._pressData=null,this._handleMoved.emit(),document.removeEventListener("keydown",this,!0),document.removeEventListener("pointerup",this,!0),document.removeEventListener("pointermove",this,!0),document.removeEventListener("contextmenu",this,!0))}}!function(e){class t{createHandle(){let e=document.createElement("div");return e.className="lm-SplitPanel-handle",e}}e.Renderer=t,e.defaultRenderer=new t,e.getStretch=function(e){return B.getStretch(e)},e.setStretch=function(e,t){B.setStretch(e,t)}}(N||(N={})),function(e){e.createLayout=function(e){return e.layout||new B({renderer:e.renderer||N.defaultRenderer,orientation:e.orientation,alignment:e.alignment,spacing:e.spacing})}}(E||(E={}));class H extends N{constructor(e={}){super({...e,layout:C.createLayout(e)}),this._widgetSizesCache=new WeakMap,this._expansionToggled=new r.Signal(this),this.addClass("lm-AccordionPanel")}get renderer(){return this.layout.renderer}get titleSpace(){return this.layout.titleSpace}set titleSpace(e){this.layout.titleSpace=e}get titles(){return this.layout.titles}get expansionToggled(){return this._expansionToggled}addWidget(e){super.addWidget(e),e.title.changed.connect(this._onTitleChanged,this)}collapse(e){const t=this.layout.widgets[e];t&&!t.isHidden&&this._toggleExpansion(e)}expand(e){const t=this.layout.widgets[e];t&&t.isHidden&&this._toggleExpansion(e)}insertWidget(e,t){super.insertWidget(e,t),t.title.changed.connect(this._onTitleChanged,this)}handleEvent(e){switch(super.handleEvent(e),e.type){case"click":this._evtClick(e);break;case"keydown":this._eventKeyDown(e)}}onBeforeAttach(e){this.node.addEventListener("click",this),this.node.addEventListener("keydown",this),super.onBeforeAttach(e)}onAfterDetach(e){super.onAfterDetach(e),this.node.removeEventListener("click",this),this.node.removeEventListener("keydown",this)}_onTitleChanged(e){const i=t.ArrayExt.findFirstIndex(this.widgets,(t=>t.contains(e.owner)));i>=0&&(this.layout.updateTitle(i,e.owner),this.update())}_computeWidgetSize(e){const t=this.layout,i=t.widgets[e];if(!i)return;const s=i.isHidden,n=t.absoluteSizes(),a=(s?-1:1)*this.spacing,r=n.reduce(((e,t)=>e+t));let o=[...n];if(s){const t=this._widgetSizesCache.get(i);if(!t)return;o[e]+=t;const s=o.map((e=>e-t>0)).lastIndexOf(!0);-1===s?o.forEach(((i,s)=>{s!==e&&(o[s]-=n[s]/r*(t-a))})):o[s]-=t-a}else{const t=n[e];this._widgetSizesCache.set(i,t),o[e]=0;const s=o.map((e=>e>0)).lastIndexOf(!0);if(-1===s)return;o[s]=n[s]+t+a}return o.map((e=>e/(r+a)))}_evtClick(e){const i=e.target;if(i){const s=t.ArrayExt.findFirstIndex(this.titles,(e=>e.contains(i)));s>=0&&(e.preventDefault(),e.stopPropagation(),this._toggleExpansion(s))}}_eventKeyDown(e){if(e.defaultPrevented)return;const i=e.target;let s=!1;if(i){const n=t.ArrayExt.findFirstIndex(this.titles,(e=>e.contains(i)));if(n>=0){const t=e.keyCode.toString();if(e.key.match(/Space|Enter/)||t.match(/13|32/))i.click(),s=!0;else if("horizontal"===this.orientation?e.key.match(/ArrowLeft|ArrowRight/)||t.match(/37|39/):e.key.match(/ArrowUp|ArrowDown/)||t.match(/38|40/)){const i=e.key.match(/ArrowLeft|ArrowUp/)||t.match(/37|38/)?-1:1,a=this.titles.length,r=(n+a+i)%a;this.titles[r].focus(),s=!0}else"End"===e.key||"35"===t?(this.titles[this.titles.length-1].focus(),s=!0):"Home"!==e.key&&"36"!==t||(this.titles[0].focus(),s=!0)}s&&e.preventDefault()}}_toggleExpansion(e){const t=this.titles[e],i=this.layout.widgets[e],s=this._computeWidgetSize(e);s&&this.setRelativeSizes(s,!1),i.isHidden?(t.classList.add("lm-mod-expanded"),t.setAttribute("aria-expanded","true"),i.show()):(t.classList.remove("lm-mod-expanded"),t.setAttribute("aria-expanded","false"),i.hide()),this._expansionToggled.emit(e)}}!function(e){class t extends N.Renderer{constructor(){super(),this.titleClassName="lm-AccordionPanel-title",this._titleID=0,this._titleKeys=new WeakMap,this._uuid=++t._nInstance}createCollapseIcon(e){return document.createElement("span")}createSectionTitle(e){const t=document.createElement("h3");t.setAttribute("tabindex","0"),t.id=this.createTitleKey(e),t.className=this.titleClassName;for(const i in e.dataset)t.dataset[i]=e.dataset[i];t.appendChild(this.createCollapseIcon(e)).className="lm-AccordionPanel-titleCollapser";const i=t.appendChild(document.createElement("span"));return i.className="lm-AccordionPanel-titleLabel",i.textContent=e.label,i.title=e.caption||e.label,t}createTitleKey(e){let t=this._titleKeys.get(e);return void 0===t&&(t=`title-key-${this._uuid}-${this._titleID++}`,this._titleKeys.set(e,t)),t}}t._nInstance=0,e.Renderer=t,e.defaultRenderer=new t}(H||(H={})),function(e){e.createLayout=function(e){return e.layout||new k({renderer:e.renderer||H.defaultRenderer,orientation:e.orientation,alignment:e.alignment,spacing:e.spacing,titleSpace:e.titleSpace})}}(C||(C={}));class P extends M{constructor(e={}){super(),this._fixed=0,this._spacing=4,this._dirty=!1,this._sizers=[],this._items=[],this._box=null,this._alignment="start",this._direction="top-to-bottom",void 0!==e.direction&&(this._direction=e.direction),void 0!==e.alignment&&(this._alignment=e.alignment),void 0!==e.spacing&&(this._spacing=D.clampDimension(e.spacing))}dispose(){for(const e of this._items)e.dispose();this._box=null,this._items.length=0,this._sizers.length=0,super.dispose()}get direction(){return this._direction}set direction(e){this._direction!==e&&(this._direction=e,this.parent&&(this.parent.dataset.direction=e,this.parent.fit()))}get alignment(){return this._alignment}set alignment(e){this._alignment!==e&&(this._alignment=e,this.parent&&(this.parent.dataset.alignment=e,this.parent.update()))}get spacing(){return this._spacing}set spacing(e){e=D.clampDimension(e),this._spacing!==e&&(this._spacing=e,this.parent&&this.parent.fit())}init(){this.parent.dataset.direction=this.direction,this.parent.dataset.alignment=this.alignment,super.init()}attachWidget(e,i){t.ArrayExt.insert(this._items,e,new x(i)),t.ArrayExt.insert(this._sizers,e,new u),this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.BeforeAttach),this.parent.node.appendChild(i.node),this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.AfterAttach),this.parent.fit()}moveWidget(e,i,s){t.ArrayExt.move(this._items,e,i),t.ArrayExt.move(this._sizers,e,i),this.parent.update()}detachWidget(e,i){let s=t.ArrayExt.removeAt(this._items,e);t.ArrayExt.removeAt(this._sizers,e),this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.BeforeDetach),this.parent.node.removeChild(i.node),this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.AfterDetach),s.dispose(),this.parent.fit()}onBeforeShow(e){super.onBeforeShow(e),this.parent.update()}onBeforeAttach(e){super.onBeforeAttach(e),this.parent.fit()}onChildShown(e){this.parent.fit()}onChildHidden(e){this.parent.fit()}onResize(e){this.parent.isVisible&&this._update(e.width,e.height)}onUpdateRequest(e){this.parent.isVisible&&this._update(-1,-1)}onFitRequest(e){this.parent.isAttached&&this._fit()}_fit(){let e=0;for(let t=0,i=this._items.length;t0)switch(this._alignment){case"start":break;case"center":l=0,c=a/2;break;case"end":l=0,c=a;break;case"justify":l=a/n,c=0;break;default:throw"unreachable"}for(let e=0,t=this._items.length;e0,coerce:(e,t)=>Math.max(0,Math.floor(t)),changed:t}),e.sizeBasisProperty=new a.AttachedProperty({name:"sizeBasis",create:()=>0,coerce:(e,t)=>Math.max(0,Math.floor(t)),changed:t}),e.isHorizontal=function(e){return"left-to-right"===e||"right-to-left"===e},e.clampSpacing=function(e){return Math.max(0,Math.floor(e))}}(S||(S={}));class W extends R{constructor(e={}){super({layout:I.createLayout(e)}),this.addClass("lm-BoxPanel")}get direction(){return this.layout.direction}set direction(e){this.layout.direction=e}get alignment(){return this.layout.alignment}set alignment(e){this.layout.alignment=e}get spacing(){return this.layout.spacing}set spacing(e){this.layout.spacing=e}onChildAdded(e){e.child.addClass("lm-BoxPanel-child")}onChildRemoved(e){e.child.removeClass("lm-BoxPanel-child")}}!function(e){e.getStretch=function(e){return P.getStretch(e)},e.setStretch=function(e,t){P.setStretch(e,t)},e.getSizeBasis=function(e){return P.getSizeBasis(e)},e.setSizeBasis=function(e,t){P.setSizeBasis(e,t)}}(W||(W={})),function(e){e.createLayout=function(e){return e.layout||new P(e)}}(I||(I={}));class q extends b{constructor(e){super({node:z.createNode()}),this._activeIndex=-1,this._items=[],this._results=null,this.addClass("lm-CommandPalette"),this.setFlag(b.Flag.DisallowLayout),this.commands=e.commands,this.renderer=e.renderer||q.defaultRenderer,this.commands.commandChanged.connect(this._onGenericChange,this),this.commands.keyBindingChanged.connect(this._onGenericChange,this)}dispose(){this._items.length=0,this._results=null,super.dispose()}get searchNode(){return this.node.getElementsByClassName("lm-CommandPalette-search")[0]}get inputNode(){return this.node.getElementsByClassName("lm-CommandPalette-input")[0]}get contentNode(){return this.node.getElementsByClassName("lm-CommandPalette-content")[0]}get items(){return this._items}addItem(e){let t=z.createItem(this.commands,e);return this._items.push(t),this.refresh(),t}addItems(e){const t=e.map((e=>z.createItem(this.commands,e)));return t.forEach((e=>this._items.push(e))),this.refresh(),t}removeItem(e){this.removeItemAt(this._items.indexOf(e))}removeItemAt(e){t.ArrayExt.removeAt(this._items,e)&&this.refresh()}clearItems(){0!==this._items.length&&(this._items.length=0,this.refresh())}refresh(){if(this._results=null,""!==this.inputNode.value){this.node.getElementsByClassName("lm-close-icon")[0].style.display="inherit"}else{this.node.getElementsByClassName("lm-close-icon")[0].style.display="none"}this.update()}handleEvent(e){switch(e.type){case"click":this._evtClick(e);break;case"keydown":this._evtKeyDown(e);break;case"input":this.refresh();break;case"focus":case"blur":this._toggleFocused()}}onBeforeAttach(e){this.node.addEventListener("click",this),this.node.addEventListener("keydown",this),this.node.addEventListener("input",this),this.node.addEventListener("focus",this,!0),this.node.addEventListener("blur",this,!0)}onAfterDetach(e){this.node.removeEventListener("click",this),this.node.removeEventListener("keydown",this),this.node.removeEventListener("input",this),this.node.removeEventListener("focus",this,!0),this.node.removeEventListener("blur",this,!0)}onAfterShow(e){this.update(),super.onAfterShow(e)}onActivateRequest(e){if(this.isAttached){let e=this.inputNode;e.focus(),e.select()}}onUpdateRequest(e){if(this.isHidden)return;let i=this.inputNode.value,n=this.contentNode,a=this._results;if(a||(a=this._results=z.search(this._items,i),this._activeIndex=i?t.ArrayExt.findFirstIndex(a,z.canActivate):-1),!i&&0===a.length)return void d.VirtualDOM.render(null,n);if(i&&0===a.length){let e=this.renderer.renderEmptyMessage({query:i});return void d.VirtualDOM.render(e,n)}let r=this.renderer,o=this._activeIndex,h=new Array(a.length);for(let e=0,t=a.length;e=a.length)n.scrollTop=0;else{let e=n.children[o];s.ElementExt.scrollIntoViewIfNeeded(n,e)}}_evtClick(e){if(0!==e.button)return;if(e.target.classList.contains("lm-close-icon"))return this.inputNode.value="",void this.refresh();let i=t.ArrayExt.findFirstIndex(this.contentNode.children,(t=>t.contains(e.target)));-1!==i&&(e.preventDefault(),e.stopPropagation(),this._execute(i))}_evtKeyDown(e){if(!(e.altKey||e.ctrlKey||e.metaKey||e.shiftKey))switch(e.keyCode){case 13:e.preventDefault(),e.stopPropagation(),this._execute(this._activeIndex);break;case 38:e.preventDefault(),e.stopPropagation(),this._activatePreviousItem();break;case 40:e.preventDefault(),e.stopPropagation(),this._activateNextItem()}}_activateNextItem(){if(!this._results||0===this._results.length)return;let e=this._activeIndex,i=this._results.length,s=ee-t)),l=r.slice(0,d),c=r.slice(d);for(let e=0,t=c.length;et.command===e&&i.JSONExt.deepEqual(t.args,s)))||null}}}(z||(z={}));class F extends b{constructor(e){super({node:L.createNode()}),this._childIndex=-1,this._activeIndex=-1,this._openTimerID=0,this._closeTimerID=0,this._items=[],this._childMenu=null,this._parentMenu=null,this._aboutToClose=new r.Signal(this),this._menuRequested=new r.Signal(this),this.addClass("lm-Menu"),this.setFlag(b.Flag.DisallowLayout),this.commands=e.commands,this.renderer=e.renderer||F.defaultRenderer}dispose(){this.close(),this._items.length=0,super.dispose()}get aboutToClose(){return this._aboutToClose}get menuRequested(){return this._menuRequested}get parentMenu(){return this._parentMenu}get childMenu(){return this._childMenu}get rootMenu(){let e=this;for(;e._parentMenu;)e=e._parentMenu;return e}get leafMenu(){let e=this;for(;e._childMenu;)e=e._childMenu;return e}get contentNode(){return this.node.getElementsByClassName("lm-Menu-content")[0]}get activeItem(){return this._items[this._activeIndex]||null}set activeItem(e){this.activeIndex=e?this._items.indexOf(e):-1}get activeIndex(){return this._activeIndex}set activeIndex(e){(e<0||e>=this._items.length)&&(e=-1),-1===e||L.canActivate(this._items[e])||(e=-1),this._activeIndex!==e&&(this._activeIndex=e,this._activeIndex>=0&&this.contentNode.childNodes[this._activeIndex]&&this.contentNode.childNodes[this._activeIndex].focus(),this.update())}get items(){return this._items}activateNextItem(){let e=this._items.length,i=this._activeIndex,s=i{this.activeIndex=e}})}d.VirtualDOM.render(a,this.contentNode)}onCloseRequest(e){this._cancelOpenTimer(),this._cancelCloseTimer(),this.activeIndex=-1;let t=this._childMenu;t&&(this._childIndex=-1,this._childMenu=null,t._parentMenu=null,t.close());let i=this._parentMenu;i&&(this._parentMenu=null,i._childIndex=-1,i._childMenu=null,i.activate()),this.isAttached&&this._aboutToClose.emit(void 0),super.onCloseRequest(e)}_evtKeyDown(e){e.preventDefault(),e.stopPropagation();let t=e.keyCode;if(13===t)return void this.triggerActiveItem();if(27===t)return void this.close();if(37===t)return void(this._parentMenu?this.close():this._menuRequested.emit("previous"));if(38===t)return void this.activatePreviousItem();if(39===t){let e=this.activeItem;return void(e&&"submenu"===e.type?this.triggerActiveItem():this.rootMenu._menuRequested.emit("next"))}if(40===t)return void this.activateNextItem();let i=c.getKeyboardLayout().keyForKeydownEvent(e);if(!i)return;let s=this._activeIndex+1,n=L.findMnemonic(this._items,i,s);-1===n.index||n.multiple?-1!==n.index?this.activeIndex=n.index:-1!==n.auto&&(this.activeIndex=n.auto):(this.activeIndex=n.index,this.triggerActiveItem())}_evtMouseUp(e){0===e.button&&(e.preventDefault(),e.stopPropagation(),this.triggerActiveItem())}_evtMouseMove(e){let i=t.ArrayExt.findFirstIndex(this.contentNode.children,(t=>s.ElementExt.hitTest(t,e.clientX,e.clientY)));if(i===this._activeIndex)return;if(this.activeIndex=i,i=this.activeIndex,i===this._childIndex)return this._cancelOpenTimer(),void this._cancelCloseTimer();-1!==this._childIndex&&this._startCloseTimer(),this._cancelOpenTimer();let n=this.activeItem;n&&"submenu"===n.type&&n.submenu&&this._startOpenTimer()}_evtMouseEnter(e){for(let e=this._parentMenu;e;e=e._parentMenu)e._cancelOpenTimer(),e._cancelCloseTimer(),e.activeIndex=e._childIndex}_evtMouseLeave(e){if(this._cancelOpenTimer(),!this._childMenu)return void(this.activeIndex=-1);let{clientX:t,clientY:i}=e;s.ElementExt.hitTest(this._childMenu.node,t,i)?this._cancelCloseTimer():(this.activeIndex=-1,this._startCloseTimer())}_evtMouseDown(e){this._parentMenu||(L.hitTestMenus(this,e.clientX,e.clientY)?(e.preventDefault(),e.stopPropagation()):this.close())}_openChildMenu(e=!1){let t=this.activeItem;if(!t||"submenu"!==t.type||!t.submenu)return void this._closeChildMenu();let i=t.submenu;if(i===this._childMenu)return;F.saveWindowData(),this._closeChildMenu(),this._childMenu=i,this._childIndex=this._activeIndex,i._parentMenu=this,n.MessageLoop.sendMessage(this,b.Msg.UpdateRequest);let s=this.contentNode.children[this._activeIndex];L.openSubmenu(i,s),e&&(i.activeIndex=-1,i.activateNextItem()),i.activate()}_closeChildMenu(){this._childMenu&&this._childMenu.close()}_startOpenTimer(){0===this._openTimerID&&(this._openTimerID=window.setTimeout((()=>{this._openTimerID=0,this._openChildMenu()}),L.TIMER_DELAY))}_startCloseTimer(){0===this._closeTimerID&&(this._closeTimerID=window.setTimeout((()=>{this._closeTimerID=0,this._closeChildMenu()}),L.TIMER_DELAY))}_cancelOpenTimer(){0!==this._openTimerID&&(clearTimeout(this._openTimerID),this._openTimerID=0)}_cancelCloseTimer(){0!==this._closeTimerID&&(clearTimeout(this._closeTimerID),this._closeTimerID=0)}static saveWindowData(){L.saveWindowData()}}!function(e){class t{renderItem(e){let t=this.createItemClass(e),i=this.createItemDataset(e),s=this.createItemARIA(e);return d.h.li({className:t,dataset:i,tabindex:"0",onfocus:e.onfocus,...s},this.renderIcon(e),this.renderLabel(e),this.renderShortcut(e),this.renderSubmenu(e))}renderIcon(e){let t=this.createIconClass(e);return d.h.div({className:t},e.item.icon,e.item.iconLabel)}renderLabel(e){let t=this.formatLabel(e);return d.h.div({className:"lm-Menu-itemLabel"},t)}renderShortcut(e){let t=this.formatShortcut(e);return d.h.div({className:"lm-Menu-itemShortcut"},t)}renderSubmenu(e){return d.h.div({className:"lm-Menu-itemSubmenuIcon"})}createItemClass(e){let t="lm-Menu-item";e.item.isEnabled||(t+=" lm-mod-disabled"),e.item.isToggled&&(t+=" lm-mod-toggled"),e.item.isVisible||(t+=" lm-mod-hidden"),e.active&&(t+=" lm-mod-active"),e.collapsed&&(t+=" lm-mod-collapsed");let i=e.item.className;return i&&(t+=` ${i}`),t}createItemDataset(e){let t,{type:i,command:s,dataset:n}=e.item;return t="command"===i?{...n,type:i,command:s}:{...n,type:i},t}createIconClass(e){let t="lm-Menu-itemIcon",i=e.item.iconClass;return i?`${t} ${i}`:t}createItemARIA(e){let t={};switch(e.item.type){case"separator":t.role="presentation";break;case"submenu":t["aria-haspopup"]="true",e.item.isEnabled||(t["aria-disabled"]="true");break;default:e.item.isEnabled||(t["aria-disabled"]="true"),t.role="menuitem"}return t}formatLabel(e){let{label:t,mnemonic:i}=e.item;if(i<0||i>=t.length)return t;let s=t.slice(0,i),n=t.slice(i+1),a=t[i];return[s,d.h.span({className:"lm-Menu-itemMnemonic"},a),n]}formatShortcut(e){let t=e.item.keyBinding;return t?h.CommandRegistry.formatKeystroke(t.keys):null}}e.Renderer=t,e.defaultRenderer=new t}(F||(F={})),function(e){e.TIMER_DELAY=300,e.SUBMENU_OVERLAP=3;let a=null,r=0;function o(){return r>0?(r--,a):d()}function h(e){return"separator"!==e.type&&e.isEnabled&&e.isVisible}function d(){return{pageXOffset:window.pageXOffset,pageYOffset:window.pageYOffset,clientWidth:document.documentElement.clientWidth,clientHeight:document.documentElement.clientHeight}}e.saveWindowData=function(){a=d(),r++},e.createNode=function(){let e=document.createElement("div"),t=document.createElement("ul");return t.className="lm-Menu-content",e.appendChild(t),t.setAttribute("role","menu"),e.tabIndex=0,e},e.canActivate=h,e.createItem=function(e,t){return new l(e.commands,t)},e.hitTestMenus=function(e,t,i){for(let n=e;n;n=n.childMenu)if(s.ElementExt.hitTest(n.node,t,i))return!0;return!1},e.computeCollapsed=function(e){let i=new Array(e.length);t.ArrayExt.fill(i,!1);let s=0,n=e.length;for(;s=0;--a){let t=e[a];if(t.isVisible){if("separator"!==t.type)break;i[a]=!0}}let r=!1;for(;++sl+u&&(t=l+u-f),!a&&i+v>c+m&&(i>c+m?i=c+m-v:i-=v),_.transform=`translate(${Math.max(0,t)}px, ${Math.max(0,i)}px`,_.opacity="1"},e.openSubmenu=function(t,i){const a=o();let r=a.pageXOffset,h=a.pageYOffset,d=a.clientWidth,l=a.clientHeight;n.MessageLoop.sendMessage(t,b.Msg.UpdateRequest);let c=l,u=t.node,m=u.style;m.opacity="0",m.maxHeight=`${c}px`,b.attach(t,document.body);let{width:g,height:p}=u.getBoundingClientRect(),_=s.ElementExt.boxSizing(t.node),f=i.getBoundingClientRect(),v=f.right-e.SUBMENU_OVERLAP;v+g>r+d&&(v=f.left+e.SUBMENU_OVERLAP-g);let x=f.top-_.borderTop-_.paddingTop;x+p>h+l&&(x=f.bottom+_.borderBottom+_.paddingBottom-p),m.transform=`translate(${Math.max(0,v)}px, ${Math.max(0,x)}px`,m.opacity="1"},e.findMnemonic=function(e,t,i){let s=-1,n=-1,a=!1,r=t.toUpperCase();for(let t=0,o=e.length;t=0&&ut.command===e&&i.JSONExt.deepEqual(t.args,s)))||null}return null}}}(L||(L={}));!function(e){function t(e,t){let i=e.rank,s=t.rank;return i!==s?i=this._titles.length)&&(e=-1),this._currentIndex===e)return;let t=this._currentIndex,i=this._titles[t]||null,s=e,n=this._titles[s]||null;this._currentIndex=s,this._previousTitle=i,this.update(),this._currentChanged.emit({previousIndex:t,previousTitle:i,currentIndex:s,currentTitle:n})}get name(){return this._name}set name(e){this._name=e,e?this.contentNode.setAttribute("aria-label",e):this.contentNode.removeAttribute("aria-label")}get orientation(){return this._orientation}set orientation(e){this._orientation!==e&&(this._releaseMouse(),this._orientation=e,this.dataset.orientation=e,this.contentNode.setAttribute("aria-orientation",e))}get addButtonEnabled(){return this._addButtonEnabled}set addButtonEnabled(e){this._addButtonEnabled!==e&&(this._addButtonEnabled=e,e?this.addButtonNode.classList.remove("lm-mod-hidden"):this.addButtonNode.classList.add("lm-mod-hidden"))}get titles(){return this._titles}get contentNode(){return this.node.getElementsByClassName("lm-TabBar-content")[0]}get addButtonNode(){return this.node.getElementsByClassName("lm-TabBar-addButton")[0]}addTab(e){return this.insertTab(this._titles.length,e)}insertTab(e,i){this._releaseMouse();let s=V.asTitle(i),n=this._titles.indexOf(s),a=Math.max(0,Math.min(e,this._titles.length));return-1===n?(t.ArrayExt.insert(this._titles,a,s),s.changed.connect(this._onTitleChanged,this),this.update(),this._adjustCurrentForInsert(a,s),s):(a===this._titles.length&&a--,n===a||(t.ArrayExt.move(this._titles,n,a),this.update(),this._adjustCurrentForMove(n,a)),s)}removeTab(e){this.removeTabAt(this._titles.indexOf(e))}removeTabAt(e){this._releaseMouse();let i=t.ArrayExt.removeAt(this._titles,e);i&&(i.changed.disconnect(this._onTitleChanged,this),i===this._previousTitle&&(this._previousTitle=null),this.update(),this._adjustCurrentForRemove(e,i))}clearTabs(){if(0===this._titles.length)return;this._releaseMouse();for(let e of this._titles)e.changed.disconnect(this._onTitleChanged,this);let e=this.currentIndex,t=this.currentTitle;this._currentIndex=-1,this._previousTitle=null,this._titles.length=0,this.update(),-1!==e&&this._currentChanged.emit({previousIndex:e,previousTitle:t,currentIndex:-1,currentTitle:null})}releaseMouse(){this._releaseMouse()}handleEvent(e){switch(e.type){case"pointerdown":this._evtPointerDown(e);break;case"pointermove":this._evtPointerMove(e);break;case"pointerup":this._evtPointerUp(e);break;case"dblclick":this._evtDblClick(e);break;case"keydown":e.eventPhase===Event.CAPTURING_PHASE?this._evtKeyDownCapturing(e):this._evtKeyDown(e);break;case"contextmenu":e.preventDefault(),e.stopPropagation()}}onBeforeAttach(e){this.node.addEventListener("pointerdown",this),this.node.addEventListener("dblclick",this),this.node.addEventListener("keydown",this)}onAfterDetach(e){this.node.removeEventListener("pointerdown",this),this.node.removeEventListener("dblclick",this),this.node.removeEventListener("keydown",this),this._releaseMouse()}onUpdateRequest(e){var t;let i=this._titles,s=this.renderer,n=this.currentTitle,a=new Array(i.length);const r=null!==(t=this._getCurrentTabindex())&&void 0!==t?t:this._currentIndex>-1?this._currentIndex:0;for(let e=0,t=i.length;es.ElementExt.hitTest(t,e.clientX,e.clientY)));if(-1===n)return;let a=this.titles[n],r=i[n].querySelector(".lm-TabBar-tabLabel");if(r&&r.contains(e.target)){let e=a.label||"",t=r.innerHTML;r.innerHTML="";let i=document.createElement("input");i.classList.add("lm-TabBar-tabInput"),i.value=e,r.appendChild(i);let s=()=>{i.removeEventListener("blur",s),r.innerHTML=t,this.node.addEventListener("keydown",this)};i.addEventListener("dblclick",(e=>e.stopPropagation())),i.addEventListener("blur",s),i.addEventListener("keydown",(e=>{"Enter"===e.key?(""!==i.value&&(a.label=a.caption=i.value),s()):"Escape"===e.key&&s()})),this.node.removeEventListener("keydown",this),i.select(),i.focus(),r.children.length>0&&r.children[0].focus()}}_evtKeyDownCapturing(e){e.eventPhase===Event.CAPTURING_PHASE&&(e.preventDefault(),e.stopPropagation(),"Escape"===e.key&&this._releaseMouse())}_evtKeyDown(e){var i,s,n;if("Tab"!==e.key&&e.eventPhase!==Event.CAPTURING_PHASE)if("Enter"===e.key||"Spacebar"===e.key||" "===e.key){const i=document.activeElement;if(this.addButtonEnabled&&this.addButtonNode.contains(i))e.preventDefault(),e.stopPropagation(),this._addRequested.emit();else{const s=t.ArrayExt.findFirstIndex(this.contentNode.children,(e=>e.contains(i)));s>=0&&(e.preventDefault(),e.stopPropagation(),this.currentIndex=s)}}else if(O.includes(e.key)){const t=[...this.contentNode.children];if(this.addButtonEnabled&&t.push(this.addButtonNode),t.length<=1)return;e.preventDefault(),e.stopPropagation();let a,r=t.indexOf(document.activeElement);-1===r&&(r=this._currentIndex),"ArrowRight"===e.key&&"horizontal"===this._orientation||"ArrowDown"===e.key&&"vertical"===this._orientation?a=null!==(i=t[r+1])&&void 0!==i?i:t[0]:"ArrowLeft"===e.key&&"horizontal"===this._orientation||"ArrowUp"===e.key&&"vertical"===this._orientation?a=null!==(s=t[r-1])&&void 0!==s?s:t[t.length-1]:"Home"===e.key?a=t[0]:"End"===e.key&&(a=t[t.length-1]),a&&(null===(n=t[r])||void 0===n||n.setAttribute("tabindex","-1"),null==a||a.setAttribute("tabindex","0"),a.focus())}}_evtPointerDown(e){if(0!==e.button&&1!==e.button)return;if(this._dragData)return;if(e.target.classList.contains("lm-TabBar-tabInput"))return;let i=this.addButtonEnabled&&this.addButtonNode.contains(e.target),n=this.contentNode.children,a=t.ArrayExt.findFirstIndex(n,(t=>s.ElementExt.hitTest(t,e.clientX,e.clientY)));if(-1===a&&!i)return;if(e.preventDefault(),e.stopPropagation(),this._dragData={tab:n[a],index:a,pressX:e.clientX,pressY:e.clientY,tabPos:-1,tabSize:-1,tabPressPos:-1,targetIndex:-1,tabLayout:null,contentRect:null,override:null,dragActive:!1,dragAborted:!1,detachRequested:!1},this.document.addEventListener("pointerup",this,!0),1===e.button||i)return;let r=n[a].querySelector(this.renderer.closeIconSelector);r&&r.contains(e.target)||(this.tabsMovable&&(this.document.addEventListener("pointermove",this,!0),this.document.addEventListener("keydown",this,!0),this.document.addEventListener("contextmenu",this,!0)),this.allowDeselect&&this.currentIndex===a?this.currentIndex=-1:this.currentIndex=a,-1!==this.currentIndex&&this._tabActivateRequested.emit({index:this.currentIndex,title:this.currentTitle}))}_evtPointerMove(e){let t=this._dragData;if(!t)return;e.preventDefault(),e.stopPropagation();let i=this.contentNode.children;if(t.dragActive||V.dragExceeded(t,e)){if(!t.dragActive){let e=t.tab.getBoundingClientRect();"horizontal"===this._orientation?(t.tabPos=t.tab.offsetLeft,t.tabSize=e.width,t.tabPressPos=t.pressX-e.left):(t.tabPos=t.tab.offsetTop,t.tabSize=e.height,t.tabPressPos=t.pressY-e.top),t.tabPressOffset={x:t.pressX-e.left,y:t.pressY-e.top},t.tabLayout=V.snapTabLayout(i,this._orientation),t.contentRect=this.contentNode.getBoundingClientRect(),t.override=o.Drag.overrideCursor("default"),t.tab.classList.add("lm-mod-dragging"),this.addClass("lm-mod-dragging"),t.dragActive=!0}if(!t.detachRequested&&V.detachExceeded(t,e)){t.detachRequested=!0;let s=t.index,n=e.clientX,a=e.clientY,r=i[s],o=this._titles[s];if(this._tabDetachRequested.emit({index:s,title:o,tab:r,clientX:n,clientY:a,offset:t.tabPressOffset}),t.dragAborted)return}V.layoutTabs(i,t,e,this._orientation)}}_evtPointerUp(e){if(0!==e.button&&1!==e.button)return;const i=this._dragData;if(!i)return;if(e.preventDefault(),e.stopPropagation(),this.document.removeEventListener("pointermove",this,!0),this.document.removeEventListener("pointerup",this,!0),this.document.removeEventListener("keydown",this,!0),this.document.removeEventListener("contextmenu",this,!0),!i.dragActive){if(this._dragData=null,this.addButtonEnabled&&this.addButtonNode.contains(e.target))return void this._addRequested.emit(void 0);let n=this.contentNode.children,a=t.ArrayExt.findFirstIndex(n,(t=>s.ElementExt.hitTest(t,e.clientX,e.clientY)));if(a!==i.index)return;let r=this._titles[a];if(!r.closable)return;if(1===e.button)return void this._tabCloseRequested.emit({index:a,title:r});let o=n[a].querySelector(this.renderer.closeIconSelector);return o&&o.contains(e.target)?void this._tabCloseRequested.emit({index:a,title:r}):void 0}if(0!==e.button)return;V.finalizeTabPosition(i,this._orientation),i.tab.classList.remove("lm-mod-dragging");let a=V.parseTransitionDuration(i.tab);setTimeout((()=>{if(i.dragAborted)return;this._dragData=null,V.resetTabPositions(this.contentNode.children,this._orientation),i.override.dispose(),this.removeClass("lm-mod-dragging");let e=i.index,s=i.targetIndex;-1!==s&&e!==s&&(t.ArrayExt.move(this._titles,e,s),this._adjustCurrentForMove(e,s),this._tabMoved.emit({fromIndex:e,toIndex:s,title:this._titles[s]}),n.MessageLoop.sendMessage(this,b.Msg.UpdateRequest))}),a)}_releaseMouse(){let e=this._dragData;e&&(this._dragData=null,this.document.removeEventListener("pointermove",this,!0),this.document.removeEventListener("pointerup",this,!0),this.document.removeEventListener("keydown",this,!0),this.document.removeEventListener("contextmenu",this,!0),e.dragAborted=!0,e.dragActive&&(V.resetTabPositions(this.contentNode.children,this._orientation),e.override.dispose(),e.tab.classList.remove("lm-mod-dragging"),this.removeClass("lm-mod-dragging")))}_adjustCurrentForInsert(e,t){let i=this.currentTitle,s=this._currentIndex,n=this.insertBehavior;if("select-tab"===n||"select-tab-if-needed"===n&&-1===s)return this._currentIndex=e,this._previousTitle=i,void this._currentChanged.emit({previousIndex:s,previousTitle:i,currentIndex:e,currentTitle:t});s>=e&&this._currentIndex++}_adjustCurrentForMove(e,t){this._currentIndex===e?this._currentIndex=t:this._currentIndex=t?this._currentIndex++:this._currentIndex>e&&this._currentIndex<=t&&this._currentIndex--}_adjustCurrentForRemove(e,t){let i=this._currentIndex,s=this.removeBehavior;if(i===e){if(0===this._titles.length)return this._currentIndex=-1,void this._currentChanged.emit({previousIndex:e,previousTitle:t,currentIndex:-1,currentTitle:null});if("select-tab-after"===s)return this._currentIndex=Math.min(e,this._titles.length-1),void this._currentChanged.emit({previousIndex:e,previousTitle:t,currentIndex:this._currentIndex,currentTitle:this.currentTitle});if("select-tab-before"===s)return this._currentIndex=Math.max(0,e-1),void this._currentChanged.emit({previousIndex:e,previousTitle:t,currentIndex:this._currentIndex,currentTitle:this.currentTitle});if("select-previous-tab"===s)return this._previousTitle?(this._currentIndex=this._titles.indexOf(this._previousTitle),this._previousTitle=null):this._currentIndex=Math.min(e,this._titles.length-1),void this._currentChanged.emit({previousIndex:e,previousTitle:t,currentIndex:this._currentIndex,currentTitle:this.currentTitle});this._currentIndex=-1,this._currentChanged.emit({previousIndex:e,previousTitle:t,currentIndex:-1,currentTitle:null})}else i>e&&this._currentIndex--}_onTitleChanged(e){this.update()}}var V,U,Y,X,K,G,j,J;!function(e){class t{constructor(){this.closeIconSelector=".lm-TabBar-tabCloseIcon",this._tabID=0,this._tabKeys=new WeakMap,this._uuid=++t._nInstance}renderTab(e){let t=e.title.caption,i=this.createTabKey(e),s=i,n=this.createTabStyle(e),a=this.createTabClass(e),r=this.createTabDataset(e),o=this.createTabARIA(e);return e.title.closable?d.h.li({id:s,key:i,className:a,title:t,style:n,dataset:r,...o},this.renderIcon(e),this.renderLabel(e),this.renderCloseIcon(e)):d.h.li({id:s,key:i,className:a,title:t,style:n,dataset:r,...o},this.renderIcon(e),this.renderLabel(e))}renderIcon(e){const{title:t}=e;let i=this.createIconClass(e);return d.h.div({className:i},t.icon,t.iconLabel)}renderLabel(e){return d.h.div({className:"lm-TabBar-tabLabel"},e.title.label)}renderCloseIcon(e){return d.h.div({className:"lm-TabBar-tabCloseIcon"})}createTabKey(e){let t=this._tabKeys.get(e.title);return void 0===t&&(t=`tab-key-${this._uuid}-${this._tabID++}`,this._tabKeys.set(e.title,t)),t}createTabStyle(e){return{zIndex:`${e.zIndex}`}}createTabClass(e){let t="lm-TabBar-tab";return e.title.className&&(t+=` ${e.title.className}`),e.title.closable&&(t+=" lm-mod-closable"),e.current&&(t+=" lm-mod-current"),t}createTabDataset(e){return e.title.dataset}createTabARIA(e){var t;return{role:"tab","aria-selected":e.current.toString(),tabindex:`${null!==(t=e.tabIndex)&&void 0!==t?t:"-1"}`}}createIconClass(e){let t="lm-TabBar-tabIcon",i=e.title.iconClass;return i?`${t} ${i}`:t}}t._nInstance=0,e.Renderer=t,e.defaultRenderer=new t,e.addButtonSelector=".lm-TabBar-addButton"}($||($={})),function(e){e.DRAG_THRESHOLD=5,e.DETACH_THRESHOLD=20,e.createNode=function(){let e=document.createElement("div"),t=document.createElement("ul");t.setAttribute("role","tablist"),t.className="lm-TabBar-content",e.appendChild(t);let i=document.createElement("div");return i.className="lm-TabBar-addButton lm-mod-hidden",i.setAttribute("tabindex","-1"),i.setAttribute("role","button"),e.appendChild(i),e},e.asTitle=function(e){return e instanceof f?e:new f(e)},e.parseTransitionDuration=function(e){let t=window.getComputedStyle(e);return 1e3*(parseFloat(t.transitionDuration)||0)},e.snapTabLayout=function(e,t){let i=new Array(e.length);for(let s=0,n=e.length;s=e.DRAG_THRESHOLD||n>=e.DRAG_THRESHOLD},e.detachExceeded=function(t,i){let s=t.contentRect;return i.clientX=s.right+e.DETACH_THRESHOLD||i.clientY=s.bottom+e.DETACH_THRESHOLD},e.layoutTabs=function(e,t,i,s){let n,a,r,o;"horizontal"===s?(n=t.pressX,a=i.clientX-t.contentRect.left,r=i.clientX,o=t.contentRect.width):(n=t.pressY,a=i.clientY-t.contentRect.top,r=i.clientY,o=t.contentRect.height);let h=t.index,d=a-t.tabPressPos,l=d+t.tabSize;for(let i=0,a=e.length;i>1);if(it.index&&l>u)a=-t.tabSize-c.margin+"px",h=Math.max(h,i);else if(i===t.index){let e=r-n,i=o-(t.tabPos+t.tabSize);a=`${Math.max(-t.tabPos,Math.min(e,i))}px`}else a="";"horizontal"===s?e[i].style.left=a:e[i].style.top=a}t.targetIndex=h},e.finalizeTabPosition=function(e,t){let i,s;if(i="horizontal"===t?e.contentRect.width:e.contentRect.height,e.targetIndex===e.index)s=0;else if(e.targetIndex>e.index){let t=e.tabLayout[e.targetIndex];s=t.pos+t.size-e.tabSize-e.tabPos}else{s=e.tabLayout[e.targetIndex].pos-e.tabPos}let n=i-(e.tabPos+e.tabSize),a=Math.max(-e.tabPos,Math.min(s,n));"horizontal"===t?e.tab.style.left=`${a}px`:e.tab.style.top=`${a}px`},e.resetTabPositions=function(e,t){for(const i of e)"horizontal"===t?i.style.left="":i.style.top=""}}(V||(V={}));class Q extends v{constructor(e){super(),this._spacing=4,this._dirty=!1,this._root=null,this._box=null,this._items=new Map,this.renderer=e.renderer,void 0!==e.spacing&&(this._spacing=D.clampDimension(e.spacing)),this._document=e.document||document,this._hiddenMode=void 0!==e.hiddenMode?e.hiddenMode:b.HiddenMode.Display}dispose(){let e=this[Symbol.iterator]();this._items.forEach((e=>{e.dispose()})),this._box=null,this._root=null,this._items.clear();for(const t of e)t.dispose();super.dispose()}get hiddenMode(){return this._hiddenMode}set hiddenMode(e){if(this._hiddenMode!==e){this._hiddenMode=e;for(const e of this.tabBars())if(e.titles.length>1)for(const t of e.titles)t.owner.hiddenMode=this._hiddenMode}}get spacing(){return this._spacing}set spacing(e){e=D.clampDimension(e),this._spacing!==e&&(this._spacing=e,this.parent&&this.parent.fit())}get isEmpty(){return null===this._root}[Symbol.iterator](){return this._root?this._root.iterAllWidgets():t.empty()}widgets(){return this._root?this._root.iterUserWidgets():t.empty()}selectedWidgets(){return this._root?this._root.iterSelectedWidgets():t.empty()}tabBars(){return this._root?this._root.iterTabBars():t.empty()}handles(){return this._root?this._root.iterHandles():t.empty()}moveHandle(t,i,s){let n=t.classList.contains("lm-mod-hidden");if(!this._root||n)return;let a,r=this._root.findSplitNode(t);r&&(a="horizontal"===r.node.orientation?i-t.offsetLeft:s-t.offsetTop,0!==a&&(r.node.holdSizes(),e.BoxEngine.adjust(r.node.sizers,r.index,a),this.parent&&this.parent.update()))}saveLayout(){return this._root?(this._root.holdAllSizes(),{main:this._root.createConfig()}):{main:null}}restoreLayout(e){let t,i=new Set;t=e.main?U.normalizeAreaConfig(e.main,i):null;let s=this.widgets(),n=this.tabBars(),a=this.handles();this._root=null;for(const e of s)i.has(e)||(e.parent=null);for(const e of n)e.dispose();for(const e of a)e.parentNode&&e.parentNode.removeChild(e);for(const e of i)e.parent=this.parent;this._root=t?U.realizeAreaConfig(t,{createTabBar:e=>this._createTabBar(),createHandle:()=>this._createHandle()},this._document):null,this.parent&&(i.forEach((e=>{this.attachWidget(e)})),this.parent.fit())}addWidget(e,t={}){let i=t.ref||null,s=t.mode||"tab-after",n=null;if(this._root&&i&&(n=this._root.findTabNode(i)),i&&!n)throw new Error("Reference widget is not in the layout.");switch(e.parent=this.parent,s){case"tab-after":this._insertTab(e,i,n,!0);break;case"tab-before":this._insertTab(e,i,n,!1);break;case"split-top":this._insertSplit(e,i,n,"vertical",!1);break;case"split-left":this._insertSplit(e,i,n,"horizontal",!1);break;case"split-right":this._insertSplit(e,i,n,"horizontal",!0);break;case"split-bottom":this._insertSplit(e,i,n,"vertical",!0);break;case"merge-top":this._insertSplit(e,i,n,"vertical",!1,!0);break;case"merge-left":this._insertSplit(e,i,n,"horizontal",!1,!0);break;case"merge-right":this._insertSplit(e,i,n,"horizontal",!0,!0);break;case"merge-bottom":this._insertSplit(e,i,n,"vertical",!0,!0)}this.parent&&(this.attachWidget(e),this.parent.fit())}removeWidget(e){this._removeWidget(e),this.parent&&(this.detachWidget(e),this.parent.fit())}hitTestTabAreas(e,t){if(!this._root||!this.parent||!this.parent.isVisible)return null;this._box||(this._box=s.ElementExt.boxSizing(this.parent.node));let i=this.parent.node.getBoundingClientRect(),n=e-i.left-this._box.borderLeft,a=t-i.top-this._box.borderTop,r=this._root.hitTestTabNodes(n,a);if(!r)return null;let{tabBar:o,top:h,left:d,width:l,height:c}=r,u=this._box.borderLeft+this._box.borderRight,m=this._box.borderTop+this._box.borderBottom;return{tabBar:o,x:n,y:a,top:h,left:d,right:i.width-u-(d+l),bottom:i.height-m-(h+c),width:l,height:c}}init(){super.init();for(const e of this)this.attachWidget(e);for(const e of this.handles())this.parent.node.appendChild(e);this.parent.fit()}attachWidget(e){this.parent.node!==e.node.parentNode&&(this._items.set(e,new x(e)),this.parent.isAttached&&n.MessageLoop.sendMessage(e,b.Msg.BeforeAttach),this.parent.node.appendChild(e.node),this.parent.isAttached&&n.MessageLoop.sendMessage(e,b.Msg.AfterAttach))}detachWidget(e){if(this.parent.node!==e.node.parentNode)return;this.parent.isAttached&&n.MessageLoop.sendMessage(e,b.Msg.BeforeDetach),this.parent.node.removeChild(e.node),this.parent.isAttached&&n.MessageLoop.sendMessage(e,b.Msg.AfterDetach);let t=this._items.get(e);t&&(this._items.delete(e),t.dispose())}onBeforeShow(e){super.onBeforeShow(e),this.parent.update()}onBeforeAttach(e){super.onBeforeAttach(e),this.parent.fit()}onChildShown(e){this.parent.fit()}onChildHidden(e){this.parent.fit()}onResize(e){this.parent.isVisible&&this._update(e.width,e.height)}onUpdateRequest(e){this.parent.isVisible&&this._update(-1,-1)}onFitRequest(e){this.parent.isAttached&&this._fit()}_removeWidget(e){if(!this._root)return;let i=this._root.findTabNode(e);if(!i)return;if(U.removeAria(e),i.tabBar.titles.length>1){if(i.tabBar.removeTab(e.title),this._hiddenMode===b.HiddenMode.Scale&&1==i.tabBar.titles.length){i.tabBar.titles[0].owner.hiddenMode=b.HiddenMode.Display}return}if(i.tabBar.dispose(),this._root===i)return void(this._root=null);this._root.holdAllSizes();let s=i.parent;i.parent=null;let n=t.ArrayExt.removeFirstOf(s.children,i),a=t.ArrayExt.removeAt(s.handles,n);if(t.ArrayExt.removeAt(s.sizers,n),a.parentNode&&a.parentNode.removeChild(a),s.children.length>1)return void s.syncHandles();let r=s.parent;s.parent=null;let o=s.children[0],h=s.handles[0];if(s.children.length=0,s.handles.length=0,s.sizers.length=0,h.parentNode&&h.parentNode.removeChild(h),this._root===s)return o.parent=null,void(this._root=o);let d=r,l=d.children.indexOf(s);if(o instanceof U.TabLayoutNode)return o.parent=d,void(d.children[l]=o);let c=t.ArrayExt.removeAt(d.handles,l);t.ArrayExt.removeAt(d.children,l),t.ArrayExt.removeAt(d.sizers,l),c.parentNode&&c.parentNode.removeChild(c);for(let e=0,i=o.children.length;e=i.length)&&(s=0);return{type:"tab-area",widgets:i,currentIndex:s}}(e,t):function(e,t){let i=e.orientation,n=[],a=[];for(let r=0,o=e.children.length;r{let h=n(r,t,s),d=i(e.sizes[o]),l=t.createHandle();a.children.push(h),a.handles.push(l),a.sizers.push(d),h.parent=a})),a.syncHandles(),a.normalizeSizes(),a}(e,s,o),h}t.GOLDEN_RATIO=.618,t.createSizer=i,t.normalizeAreaConfig=s,t.realizeAreaConfig=n;class a{constructor(e){this.parent=null,this._top=0,this._left=0,this._width=0,this._height=0;let t=new u,i=new u;t.stretch=0,i.stretch=1,this.tabBar=e,this.sizers=[t,i]}get top(){return this._top}get left(){return this._left}get width(){return this._width}get height(){return this._height}*iterAllWidgets(){yield this.tabBar,yield*this.iterUserWidgets()}*iterUserWidgets(){for(const e of this.tabBar.titles)yield e.owner}*iterSelectedWidgets(){let e=this.tabBar.currentTitle;e&&(yield e.owner)}*iterTabBars(){yield this.tabBar}*iterHandles(){}findTabNode(e){return-1!==this.tabBar.titles.indexOf(e.title)?this:null}findSplitNode(e){return null}findFirstTabNode(){return this}hitTestTabNodes(e,t){return e=this._left+this._width||t=this._top+this._height?null:this}createConfig(){return{type:"tab-area",widgets:this.tabBar.titles.map((e=>e.owner)),currentIndex:this.tabBar.currentIndex}}holdAllSizes(){}fit(e,t){let i=0,s=0,n=t.get(this.tabBar),a=this.tabBar.currentTitle,r=a?t.get(a.owner):void 0,[o,h]=this.sizers;return n&&n.fit(),r&&r.fit(),n&&!n.isHidden?(i=Math.max(i,n.minWidth),s+=n.minHeight,o.minSize=n.minHeight,o.maxSize=n.maxHeight):(o.minSize=0,o.maxSize=0),r&&!r.isHidden?(i=Math.max(i,r.minWidth),s+=r.minHeight,h.minSize=r.minHeight,h.maxSize=1/0):(h.minSize=0,h.maxSize=1/0),{minWidth:i,minHeight:s,maxWidth:Infinity,maxHeight:Infinity}}update(t,i,s,n,a,r){this._top=i,this._left=t,this._width=s,this._height=n;let o=r.get(this.tabBar),h=this.tabBar.currentTitle,d=h?r.get(h.owner):void 0;if(e.BoxEngine.calc(this.sizers,n),o&&!o.isHidden){let e=this.sizers[0].size;o.update(t,i,s,e),i+=e}if(d&&!d.isHidden){let e=this.sizers[1].size;d.update(t,i,s,e)}}}t.TabLayoutNode=a;class r{constructor(e){this.parent=null,this.normalized=!1,this.children=[],this.sizers=[],this.handles=[],this.orientation=e}*iterAllWidgets(){for(const e of this.children)yield*e.iterAllWidgets()}*iterUserWidgets(){for(const e of this.children)yield*e.iterUserWidgets()}*iterSelectedWidgets(){for(const e of this.children)yield*e.iterSelectedWidgets()}*iterTabBars(){for(const e of this.children)yield*e.iterTabBars()}*iterHandles(){yield*this.handles;for(const e of this.children)yield*e.iterHandles()}findTabNode(e){for(let t=0,i=this.children.length;te.createConfig())),sizes:t}}syncHandles(){this.handles.forEach(((e,t)=>{e.setAttribute("data-orientation",this.orientation),t===this.handles.length-1?e.classList.add("lm-mod-hidden"):e.classList.remove("lm-mod-hidden")}))}holdSizes(){for(const e of this.sizers)e.sizeHint=e.size}holdAllSizes(){for(const e of this.children)e.holdAllSizes();this.holdSizes()}normalizeSizes(){let e=this.sizers.length;if(0===e)return;this.holdSizes();let t=this.sizers.reduce(((e,t)=>e+t.sizeHint),0);if(0===t)for(const t of this.sizers)t.size=t.sizeHint=1/e;else for(const e of this.sizers)e.size=e.sizeHint/=t;this.normalized=!0}createNormalizedSizes(){let e=this.sizers.length;if(0===e)return[];let t=this.sizers.map((e=>e.size)),i=t.reduce(((e,t)=>e+t),0);if(0===i)for(let i=t.length-1;i>-1;i--)t[i]=1/e;else for(let e=t.length-1;e>-1;e--)t[e]/=i;return t}fit(e,t){let i="horizontal"===this.orientation,s=Math.max(0,this.children.length-1)*e,n=i?s:0,a=i?0:s;for(let s=0,r=this.children.length;sthis._createTabBar(),createHandle:()=>this._createHandle()};this.layout=new Q({document:this._document,renderer:t,spacing:e.spacing,hiddenMode:e.hiddenMode}),this.overlay=e.overlay||new Z.Overlay,this.node.appendChild(this.overlay.node)}dispose(){this._releaseMouse(),this.overlay.hide(0),this._drag&&this._drag.dispose(),super.dispose()}get hiddenMode(){return this.layout.hiddenMode}set hiddenMode(e){this.layout.hiddenMode=e}get layoutModified(){return this._layoutModified}get addRequested(){return this._addRequested}get renderer(){return this.layout.renderer}get spacing(){return this.layout.spacing}set spacing(e){this.layout.spacing=e}get mode(){return this._mode}set mode(e){if(this._mode===e)return;this._mode=e,this.dataset.mode=e;let t=this.layout;switch(e){case"multiple-document":for(const e of t.tabBars())e.show();break;case"single-document":t.restoreLayout(Y.createSingleDocumentConfig(this));break;default:throw"unreachable"}n.MessageLoop.postMessage(this,Y.LayoutModified)}get tabsMovable(){return this._tabsMovable}set tabsMovable(e){this._tabsMovable=e;for(const t of this.tabBars())t.tabsMovable=e}get tabsConstrained(){return this._tabsConstrained}set tabsConstrained(e){this._tabsConstrained=e}get addButtonEnabled(){return this._addButtonEnabled}set addButtonEnabled(e){this._addButtonEnabled=e;for(const t of this.tabBars())t.addButtonEnabled=e}get isEmpty(){return this.layout.isEmpty}*widgets(){yield*this.layout.widgets()}*selectedWidgets(){yield*this.layout.selectedWidgets()}*tabBars(){yield*this.layout.tabBars()}*handles(){yield*this.layout.handles()}selectWidget(e){let i=t.find(this.tabBars(),(t=>-1!==t.titles.indexOf(e.title)));if(!i)throw new Error("Widget is not contained in the dock panel.");i.currentTitle=e.title}activateWidget(e){this.selectWidget(e),e.activate()}saveLayout(){return this.layout.saveLayout()}restoreLayout(e){this._mode="multiple-document",this.layout.restoreLayout(e),(s.Platform.IS_EDGE||s.Platform.IS_IE)&&n.MessageLoop.flush(),n.MessageLoop.postMessage(this,Y.LayoutModified)}addWidget(e,t={}){"single-document"===this._mode?this.layout.addWidget(e):this.layout.addWidget(e,t),n.MessageLoop.postMessage(this,Y.LayoutModified)}processMessage(e){"layout-modified"===e.type?this._layoutModified.emit(void 0):super.processMessage(e)}handleEvent(e){switch(e.type){case"lm-dragenter":this._evtDragEnter(e);break;case"lm-dragleave":this._evtDragLeave(e);break;case"lm-dragover":this._evtDragOver(e);break;case"lm-drop":this._evtDrop(e);break;case"pointerdown":this._evtPointerDown(e);break;case"pointermove":this._evtPointerMove(e);break;case"pointerup":this._evtPointerUp(e);break;case"keydown":this._evtKeyDown(e);break;case"contextmenu":e.preventDefault(),e.stopPropagation()}}onBeforeAttach(e){this.node.addEventListener("lm-dragenter",this),this.node.addEventListener("lm-dragleave",this),this.node.addEventListener("lm-dragover",this),this.node.addEventListener("lm-drop",this),this.node.addEventListener("pointerdown",this)}onAfterDetach(e){this.node.removeEventListener("lm-dragenter",this),this.node.removeEventListener("lm-dragleave",this),this.node.removeEventListener("lm-dragover",this),this.node.removeEventListener("lm-drop",this),this.node.removeEventListener("pointerdown",this),this._releaseMouse()}onChildAdded(e){Y.isGeneratedTabBarProperty.get(e.child)||e.child.addClass("lm-DockPanel-widget")}onChildRemoved(e){Y.isGeneratedTabBarProperty.get(e.child)||(e.child.removeClass("lm-DockPanel-widget"),n.MessageLoop.postMessage(this,Y.LayoutModified))}_evtDragEnter(e){e.mimeData.hasData("application/vnd.lumino.widget-factory")&&(e.preventDefault(),e.stopPropagation())}_evtDragLeave(e){e.preventDefault(),this._tabsConstrained&&e.source!==this||(e.stopPropagation(),this.overlay.hide(1))}_evtDragOver(e){e.preventDefault(),this._tabsConstrained&&e.source!==this||"invalid"===this._showOverlay(e.clientX,e.clientY)?e.dropAction="none":(e.stopPropagation(),e.dropAction=e.proposedAction)}_evtDrop(e){if(e.preventDefault(),this.overlay.hide(0),"none"===e.proposedAction)return void(e.dropAction="none");let{clientX:t,clientY:i}=e,{zone:s,target:n}=Y.findDropTarget(this,t,i,this._edges);if(this._tabsConstrained&&e.source!==this||"invalid"===s)return void(e.dropAction="none");let a=e.mimeData.getData("application/vnd.lumino.widget-factory");if("function"!=typeof a)return void(e.dropAction="none");let r=a();if(!(r instanceof b))return void(e.dropAction="none");if(r.contains(this))return void(e.dropAction="none");let o=n?Y.getDropRef(n.tabBar):null;switch(s){case"root-all":this.addWidget(r);break;case"root-top":this.addWidget(r,{mode:"split-top"});break;case"root-left":this.addWidget(r,{mode:"split-left"});break;case"root-right":this.addWidget(r,{mode:"split-right"});break;case"root-bottom":this.addWidget(r,{mode:"split-bottom"});break;case"widget-all":case"widget-tab":this.addWidget(r,{mode:"tab-after",ref:o});break;case"widget-top":this.addWidget(r,{mode:"split-top",ref:o});break;case"widget-left":this.addWidget(r,{mode:"split-left",ref:o});break;case"widget-right":this.addWidget(r,{mode:"split-right",ref:o});break;case"widget-bottom":this.addWidget(r,{mode:"split-bottom",ref:o});break;default:throw"unreachable"}e.dropAction=e.proposedAction,e.stopPropagation(),this.activateWidget(r)}_evtKeyDown(e){e.preventDefault(),e.stopPropagation(),27===e.keyCode&&(this._releaseMouse(),n.MessageLoop.postMessage(this,Y.LayoutModified))}_evtPointerDown(e){if(0!==e.button)return;let i=this.layout,s=e.target,n=t.find(i.handles(),(e=>e.contains(s)));if(!n)return;e.preventDefault(),e.stopPropagation(),this._document.addEventListener("keydown",this,!0),this._document.addEventListener("pointerup",this,!0),this._document.addEventListener("pointermove",this,!0),this._document.addEventListener("contextmenu",this,!0);let a=n.getBoundingClientRect(),r=e.clientX-a.left,h=e.clientY-a.top,d=window.getComputedStyle(n),l=o.Drag.overrideCursor(d.cursor,this._document);this._pressData={handle:n,deltaX:r,deltaY:h,override:l}}_evtPointerMove(e){if(!this._pressData)return;e.preventDefault(),e.stopPropagation();let t=this.node.getBoundingClientRect(),i=e.clientX-t.left-this._pressData.deltaX,s=e.clientY-t.top-this._pressData.deltaY;this.layout.moveHandle(this._pressData.handle,i,s)}_evtPointerUp(e){0===e.button&&(e.preventDefault(),e.stopPropagation(),this._releaseMouse(),n.MessageLoop.postMessage(this,Y.LayoutModified))}_releaseMouse(){this._pressData&&(this._pressData.override.dispose(),this._pressData=null,this._document.removeEventListener("keydown",this,!0),this._document.removeEventListener("pointerup",this,!0),this._document.removeEventListener("pointermove",this,!0),this._document.removeEventListener("contextmenu",this,!0))}_showOverlay(e,t){let i,n,a,r,{zone:o,target:h}=Y.findDropTarget(this,e,t,this._edges);if("invalid"===o)return this.overlay.hide(100),o;let d=s.ElementExt.boxSizing(this.node),l=this.node.getBoundingClientRect();switch(o){case"root-all":i=d.paddingTop,n=d.paddingLeft,a=d.paddingRight,r=d.paddingBottom;break;case"root-top":i=d.paddingTop,n=d.paddingLeft,a=d.paddingRight,r=l.height*Y.GOLDEN_RATIO;break;case"root-left":i=d.paddingTop,n=d.paddingLeft,a=l.width*Y.GOLDEN_RATIO,r=d.paddingBottom;break;case"root-right":i=d.paddingTop,n=l.width*Y.GOLDEN_RATIO,a=d.paddingRight,r=d.paddingBottom;break;case"root-bottom":i=l.height*Y.GOLDEN_RATIO,n=d.paddingLeft,a=d.paddingRight,r=d.paddingBottom;break;case"widget-all":i=h.top,n=h.left,a=h.right,r=h.bottom;break;case"widget-top":i=h.top,n=h.left,a=h.right,r=h.bottom+h.height/2;break;case"widget-left":i=h.top,n=h.left,a=h.right+h.width/2,r=h.bottom;break;case"widget-right":i=h.top,n=h.left+h.width/2,a=h.right,r=h.bottom;break;case"widget-bottom":i=h.top+h.height/2,n=h.left,a=h.right,r=h.bottom;break;case"widget-tab":{const e=h.tabBar.node.getBoundingClientRect().height;i=h.top,n=h.left,a=h.right,r=h.bottom+h.height-e;break}default:throw"unreachable"}return this.overlay.show({top:i,left:n,right:a,bottom:r}),o}_createTabBar(){let e=this._renderer.createTabBar(this._document);return Y.isGeneratedTabBarProperty.set(e,!0),"single-document"===this._mode&&e.hide(),e.tabsMovable=this._tabsMovable,e.allowDeselect=!1,e.addButtonEnabled=this._addButtonEnabled,e.removeBehavior="select-previous-tab",e.insertBehavior="select-tab-if-needed",e.tabMoved.connect(this._onTabMoved,this),e.currentChanged.connect(this._onCurrentChanged,this),e.tabCloseRequested.connect(this._onTabCloseRequested,this),e.tabDetachRequested.connect(this._onTabDetachRequested,this),e.tabActivateRequested.connect(this._onTabActivateRequested,this),e.addRequested.connect(this._onTabAddRequested,this),e}_createHandle(){return this._renderer.createHandle()}_onTabMoved(){n.MessageLoop.postMessage(this,Y.LayoutModified)}_onCurrentChanged(e,t){let{previousTitle:i,currentTitle:a}=t;i&&i.owner.hide(),a&&a.owner.show(),(s.Platform.IS_EDGE||s.Platform.IS_IE)&&n.MessageLoop.flush(),n.MessageLoop.postMessage(this,Y.LayoutModified)}_onTabAddRequested(e){this._addRequested.emit(e)}_onTabActivateRequested(e,t){t.title.owner.activate()}_onTabCloseRequested(e,t){t.title.owner.close()}_onTabDetachRequested(e,t){if(this._drag)return;e.releaseMouse();let{title:s,tab:n,clientX:a,clientY:r,offset:h}=t,d=new i.MimeData;d.setData("application/vnd.lumino.widget-factory",(()=>s.owner));let l=n.cloneNode(!0);h&&(l.style.top=`-${h.y}px`,l.style.left=`-${h.x}px`),this._drag=new o.Drag({document:this._document,mimeData:d,dragImage:l,proposedAction:"move",supportedActions:"move",source:this}),n.classList.add("lm-mod-hidden");this._drag.start(a,r).then((()=>{this._drag=null,n.classList.remove("lm-mod-hidden")}))}}!function(e){e.Overlay=class{constructor(){this._timer=-1,this._hidden=!0,this.node=document.createElement("div"),this.node.classList.add("lm-DockPanel-overlay"),this.node.classList.add("lm-mod-hidden"),this.node.style.position="absolute",this.node.style.contain="strict"}show(e){let t=this.node.style;t.top=`${e.top}px`,t.left=`${e.left}px`,t.right=`${e.right}px`,t.bottom=`${e.bottom}px`,clearTimeout(this._timer),this._timer=-1,this._hidden&&(this._hidden=!1,this.node.classList.remove("lm-mod-hidden"))}hide(e){if(!this._hidden)return e<=0?(clearTimeout(this._timer),this._timer=-1,this._hidden=!0,void this.node.classList.add("lm-mod-hidden")):void(-1===this._timer&&(this._timer=window.setTimeout((()=>{this._timer=-1,this._hidden=!0,this.node.classList.add("lm-mod-hidden")}),e)))}};class t{createTabBar(e){let t=new $({document:e});return t.addClass("lm-DockPanel-tabBar"),t}createHandle(){let e=document.createElement("div");return e.className="lm-DockPanel-handle",e}}e.Renderer=t,e.defaultRenderer=new t}(Z||(Z={})),function(e){e.GOLDEN_RATIO=.618,e.DEFAULT_EDGES={top:12,right:40,bottom:40,left:40},e.LayoutModified=new n.ConflatableMessage("layout-modified"),e.isGeneratedTabBarProperty=new a.AttachedProperty({name:"isGeneratedTabBar",create:()=>!1}),e.createSingleDocumentConfig=function(e){if(e.isEmpty)return{main:null};let t=Array.from(e.widgets()),i=e.selectedWidgets().next().value,s=i?t.indexOf(i):-1;return{main:{type:"tab-area",widgets:t,currentIndex:s}}},e.findDropTarget=function(e,t,i,n){if(!s.ElementExt.hitTest(e.node,t,i))return{zone:"invalid",target:null};let a=e.layout;if(a.isEmpty)return{zone:"root-all",target:null};if("multiple-document"===e.mode){let s=e.node.getBoundingClientRect(),a=t-s.left+1,r=i-s.top+1,o=s.right-t,h=s.bottom-i;switch(Math.min(r,o,h,a)){case r:if(ru&&d>u&&h>m&&l>m)return{zone:"widget-all",target:r};switch(o/=u,h/=m,d/=u,l/=m,Math.min(o,h,d,l)){case o:c="widget-left";break;case h:c="widget-top";break;case d:c="widget-right";break;case l:c="widget-bottom";break;default:throw"unreachable"}return{zone:c,target:r}},e.getDropRef=function(e){return 0===e.titles.length?null:e.currentTitle?e.currentTitle.owner:e.titles[e.titles.length-1].owner}}(Y||(Y={}));class ee extends v{constructor(e={}){super(e),this._dirty=!1,this._rowSpacing=4,this._columnSpacing=4,this._items=[],this._rowStarts=[],this._columnStarts=[],this._rowSizers=[new u],this._columnSizers=[new u],this._box=null,void 0!==e.rowCount&&X.reallocSizers(this._rowSizers,e.rowCount),void 0!==e.columnCount&&X.reallocSizers(this._columnSizers,e.columnCount),void 0!==e.rowSpacing&&(this._rowSpacing=X.clampValue(e.rowSpacing)),void 0!==e.columnSpacing&&(this._columnSpacing=X.clampValue(e.columnSpacing))}dispose(){for(const e of this._items){let t=e.widget;e.dispose(),t.dispose()}this._box=null,this._items.length=0,this._rowStarts.length=0,this._rowSizers.length=0,this._columnStarts.length=0,this._columnSizers.length=0,super.dispose()}get rowCount(){return this._rowSizers.length}set rowCount(e){e!==this.rowCount&&(X.reallocSizers(this._rowSizers,e),this.parent&&this.parent.fit())}get columnCount(){return this._columnSizers.length}set columnCount(e){e!==this.columnCount&&(X.reallocSizers(this._columnSizers,e),this.parent&&this.parent.fit())}get rowSpacing(){return this._rowSpacing}set rowSpacing(e){e=X.clampValue(e),this._rowSpacing!==e&&(this._rowSpacing=e,this.parent&&this.parent.fit())}get columnSpacing(){return this._columnSpacing}set columnSpacing(e){e=X.clampValue(e),this._columnSpacing!==e&&(this._columnSpacing=e,this.parent&&this.parent.fit())}rowStretch(e){let t=this._rowSizers[e];return t?t.stretch:-1}setRowStretch(e,t){let i=this._rowSizers[e];i&&(t=X.clampValue(t),i.stretch!==t&&(i.stretch=t,this.parent&&this.parent.update()))}columnStretch(e){let t=this._columnSizers[e];return t?t.stretch:-1}setColumnStretch(e,t){let i=this._columnSizers[e];i&&(t=X.clampValue(t),i.stretch!==t&&(i.stretch=t,this.parent&&this.parent.update()))}*[Symbol.iterator](){for(const e of this._items)yield e.widget}addWidget(e){-1===t.ArrayExt.findFirstIndex(this._items,(t=>t.widget===e))&&(this._items.push(new x(e)),this.parent&&this.attachWidget(e))}removeWidget(e){let i=t.ArrayExt.findFirstIndex(this._items,(t=>t.widget===e));if(-1===i)return;let s=t.ArrayExt.removeAt(this._items,i);this.parent&&this.detachWidget(e),s.dispose()}init(){super.init();for(const e of this)this.attachWidget(e)}attachWidget(e){this.parent.isAttached&&n.MessageLoop.sendMessage(e,b.Msg.BeforeAttach),this.parent.node.appendChild(e.node),this.parent.isAttached&&n.MessageLoop.sendMessage(e,b.Msg.AfterAttach),this.parent.fit()}detachWidget(e){this.parent.isAttached&&n.MessageLoop.sendMessage(e,b.Msg.BeforeDetach),this.parent.node.removeChild(e.node),this.parent.isAttached&&n.MessageLoop.sendMessage(e,b.Msg.AfterDetach),this.parent.fit()}onBeforeShow(e){super.onBeforeShow(e),this.parent.update()}onBeforeAttach(e){super.onBeforeAttach(e),this.parent.fit()}onChildShown(e){this.parent.fit()}onChildHidden(e){this.parent.fit()}onResize(e){this.parent.isVisible&&this._update(e.width,e.height)}onUpdateRequest(e){this.parent.isVisible&&this._update(-1,-1)}onFitRequest(e){this.parent.isAttached&&this._fit()}_fit(){for(let e=0,t=this.rowCount;e!e.isHidden));for(let t=0,i=e.length;t({row:0,column:0,rowSpan:1,columnSpan:1}),changed:function(e){e.parent&&e.parent.layout instanceof ee&&e.parent.fit()}}),e.normalizeConfig=function(e){return{row:Math.max(0,Math.floor(e.row||0)),column:Math.max(0,Math.floor(e.column||0)),rowSpan:Math.max(1,Math.floor(e.rowSpan||0)),columnSpan:Math.max(1,Math.floor(e.columnSpan||0))}},e.clampValue=function(e){return Math.max(0,Math.floor(e))},e.rowSpanCmp=function(t,i){let s=e.cellConfigProperty.get(t.widget),n=e.cellConfigProperty.get(i.widget);return s.rowSpan-n.rowSpan},e.columnSpanCmp=function(t,i){let s=e.cellConfigProperty.get(t.widget),n=e.cellConfigProperty.get(i.widget);return s.columnSpan-n.columnSpan},e.reallocSizers=function(e,t){for(t=Math.max(1,Math.floor(t));e.lengtht&&(e.length=t)},e.distributeMin=function(e,t,i,s){if(i=s)return;let a=(s-n)/(i-t+1);for(let s=t;s<=i;++s)e[s].minSize+=a}}(X||(X={}));class te extends b{constructor(e={}){super({node:K.createNode()}),this._activeIndex=-1,this._tabFocusIndex=0,this._menus=[],this._childMenu=null,this._overflowMenu=null,this._menuItemSizes=[],this._overflowIndex=-1,this.addClass("lm-MenuBar"),this.setFlag(b.Flag.DisallowLayout),this.renderer=e.renderer||te.defaultRenderer,this._forceItemsPosition=e.forceItemsPosition||{forceX:!0,forceY:!0},this._overflowMenuOptions=e.overflowMenuOptions||{isVisible:!0}}dispose(){this._closeChildMenu(),this._menus.length=0,super.dispose()}get childMenu(){return this._childMenu}get overflowIndex(){return this._overflowIndex}get overflowMenu(){return this._overflowMenu}get contentNode(){return this.node.getElementsByClassName("lm-MenuBar-content")[0]}get activeMenu(){return this._menus[this._activeIndex]||null}set activeMenu(e){this.activeIndex=e?this._menus.indexOf(e):-1}get activeIndex(){return this._activeIndex}set activeIndex(e){(e<0||e>=this._menus.length)&&(e=-1),e>-1&&0===this._menus[e].items.length&&(e=-1),this._activeIndex!==e&&(this._activeIndex=e,this.update())}get menus(){return this._menus}openActiveMenu(){-1!==this._activeIndex&&(this._openChildMenu(),this._childMenu&&(this._childMenu.activeIndex=-1,this._childMenu.activateNextItem()))}addMenu(e,t=!0){this.insertMenu(this._menus.length,e,t)}insertMenu(e,i,s=!0){this._closeChildMenu();let n=this._menus.indexOf(i),a=Math.max(0,Math.min(e,this._menus.length));if(-1===n)return t.ArrayExt.insert(this._menus,a,i),i.addClass("lm-MenuBar-menu"),i.aboutToClose.connect(this._onMenuAboutToClose,this),i.menuRequested.connect(this._onMenuMenuRequested,this),i.title.changed.connect(this._onTitleChanged,this),void(s&&this.update());a===this._menus.length&&a--,n!==a&&(t.ArrayExt.move(this._menus,n,a),s&&this.update())}removeMenu(e,t=!0){this.removeMenuAt(this._menus.indexOf(e),t)}removeMenuAt(e,i=!0){this._closeChildMenu();let s=t.ArrayExt.removeAt(this._menus,e);s&&(s.aboutToClose.disconnect(this._onMenuAboutToClose,this),s.menuRequested.disconnect(this._onMenuMenuRequested,this),s.title.changed.disconnect(this._onTitleChanged,this),s.removeClass("lm-MenuBar-menu"),i&&this.update())}clearMenus(){if(0!==this._menus.length){this._closeChildMenu();for(let e of this._menus)e.aboutToClose.disconnect(this._onMenuAboutToClose,this),e.menuRequested.disconnect(this._onMenuMenuRequested,this),e.title.changed.disconnect(this._onTitleChanged,this),e.removeClass("lm-MenuBar-menu");this._menus.length=0,this.update()}}handleEvent(e){switch(e.type){case"keydown":this._evtKeyDown(e);break;case"mousedown":this._evtMouseDown(e);break;case"mousemove":this._evtMouseMove(e);break;case"focusout":this._evtFocusOut(e);break;case"contextmenu":e.preventDefault(),e.stopPropagation()}}onBeforeAttach(e){this.node.addEventListener("keydown",this),this.node.addEventListener("mousedown",this),this.node.addEventListener("mousemove",this),this.node.addEventListener("focusout",this),this.node.addEventListener("contextmenu",this)}onAfterDetach(e){this.node.removeEventListener("keydown",this),this.node.removeEventListener("mousedown",this),this.node.removeEventListener("mousemove",this),this.node.removeEventListener("focusout",this),this.node.removeEventListener("contextmenu",this),this._closeChildMenu()}onActivateRequest(e){this.isAttached&&this._focusItemAt(0)}onResize(e){this.update(),super.onResize(e)}onUpdateRequest(e){var t;let i=this._menus,s=this.renderer,n=this._activeIndex,a=this._tabFocusIndex>=0&&this._tabFocusIndex-1?this._overflowIndex:i.length,o=0,l=!1;r=null!==this._overflowMenu?r-1:r;let c=new Array(r);for(let e=0;e{this._tabFocusIndex=e,this.activeIndex=e}}),o+=this._menuItemSizes[e],i[e].title.label===this._overflowMenuOptions.title&&(l=!0,r--);if(this._overflowMenuOptions.isVisible)if(this._overflowIndex>-1&&!l){if(null===this._overflowMenu){const e=null!==(t=this._overflowMenuOptions.title)&&void 0!==t?t:"...";this._overflowMenu=new F({commands:new h.CommandRegistry}),this._overflowMenu.title.label=e,this._overflowMenu.title.mnemonic=0,this.addMenu(this._overflowMenu,!1)}for(let e=i.length-2;e>=r;e--){const t=this.menus[e];t.title.mnemonic=0,this._overflowMenu.insertItem(0,{type:"submenu",submenu:t}),this.removeMenu(t,!1)}c[r]=s.renderItem({title:this._overflowMenu.title,active:r===n&&0!==i[r].items.length,tabbable:r===a,disabled:0===i[r].items.length,onfocus:()=>{this._tabFocusIndex=r,this.activeIndex=r}}),r++}else if(null!==this._overflowMenu){let e=this._overflowMenu.items,t=this.node.offsetWidth,n=this._overflowMenu.items.length;for(let h=0;hthis._menuItemSizes[n]){let t=e[0].submenu;this._overflowMenu.removeItemAt(0),this.insertMenu(r,t,!1),c[r]=s.renderItem({title:t.title,active:!1,tabbable:r===a,disabled:0===i[r].items.length,onfocus:()=>{this._tabFocusIndex=r,this.activeIndex=r}}),r++}}0===this._overflowMenu.items.length&&(this.removeMenu(this._overflowMenu,!1),c.pop(),this._overflowMenu=null,this._overflowIndex=-1)}d.VirtualDOM.render(c,this.contentNode),this._updateOverflowIndex()}_updateOverflowIndex(){if(!this._overflowMenuOptions.isVisible)return;const e=this.contentNode.childNodes;let t=this.node.offsetWidth,i=0,s=-1,n=e.length;if(0==this._menuItemSizes.length)for(let a=0;at&&-1===s&&(s=a)}else for(let e=0;et){s=e;break}this._overflowIndex=s}_evtKeyDown(e){let t=e.keyCode;if(9===t)return void(this.activeIndex=-1);if(e.preventDefault(),e.stopPropagation(),13===t||32===t||38===t||40===t){if(this.activeIndex=this._tabFocusIndex,this.activeIndex!==this._tabFocusIndex)return;return void this.openActiveMenu()}if(27===t)return this._closeChildMenu(),void this._focusItemAt(this.activeIndex);if(37===t||39===t){let e=37===t?-1:1,i=this._tabFocusIndex+e,s=this._menus.length;for(let t=0;ts.ElementExt.hitTest(t,e.clientX,e.clientY)));if(-1!==i){if(0===e.button)if(this._childMenu)this._closeChildMenu(),this.activeIndex=i;else{e.preventDefault();const t=this._positionForMenu(i);F.saveWindowData(),this.activeIndex=i,this._openChildMenu(t)}}else this._closeChildMenu()}_evtMouseMove(e){let i=t.ArrayExt.findFirstIndex(this.contentNode.children,(t=>s.ElementExt.hitTest(t,e.clientX,e.clientY)));if(i===this._activeIndex)return;if(-1===i&&this._childMenu)return;const n=i>=0&&this._childMenu?this._positionForMenu(i):null;F.saveWindowData(),this.activeIndex=i,n&&this._openChildMenu(n)}_positionForMenu(e){let t=this.contentNode.children[e],{left:i,bottom:s}=t.getBoundingClientRect();return{top:s,left:i}}_evtFocusOut(e){this._childMenu||this.node.contains(e.relatedTarget)||(this.activeIndex=-1)}_focusItemAt(e){const t=this.contentNode.childNodes[e];t&&t.focus()}_openChildMenu(e={}){let t=this.activeMenu;if(!t)return void this._closeChildMenu();let i=this._childMenu;if(i===t)return;this._childMenu=t,i?i.close():document.addEventListener("mousedown",this,!0),this._tabFocusIndex=this.activeIndex,n.MessageLoop.sendMessage(this,b.Msg.UpdateRequest);let{left:s,top:a}=e;void 0!==s&&void 0!==a||({left:s,top:a}=this._positionForMenu(this._activeIndex)),i||this.addClass("lm-mod-active"),t.items.length>0&&t.open(s,a,this._forceItemsPosition)}_closeChildMenu(){if(!this._childMenu)return;this.removeClass("lm-mod-active"),document.removeEventListener("mousedown",this,!0);let e=this._childMenu;this._childMenu=null,e.close(),this.activeIndex=-1}_onMenuAboutToClose(e){e===this._childMenu&&(this.removeClass("lm-mod-active"),document.removeEventListener("mousedown",this,!0),this._childMenu=null,this.activeIndex=-1)}_onMenuMenuRequested(e,t){if(e!==this._childMenu)return;let i=this._activeIndex,s=this._menus.length;switch(t){case"next":this.activeIndex=i===s-1?0:i+1;break;case"previous":this.activeIndex=0===i?s-1:i-1}this.openActiveMenu()}_onTitleChanged(){this.update()}}!function(e){class t{renderItem(e){let t=this.createItemClass(e),i=this.createItemDataset(e),s=this.createItemARIA(e);return d.h.li({className:t,dataset:i,...e.disabled?{}:{tabindex:e.tabbable?"0":"-1"},onfocus:e.onfocus,...s},this.renderIcon(e),this.renderLabel(e))}renderIcon(e){let t=this.createIconClass(e);return d.h.div({className:t},e.title.icon,e.title.iconLabel)}renderLabel(e){let t=this.formatLabel(e);return d.h.div({className:"lm-MenuBar-itemLabel"},t)}createItemClass(e){let t="lm-MenuBar-item";return e.title.className&&(t+=` ${e.title.className}`),e.active&&!e.disabled&&(t+=" lm-mod-active"),t}createItemDataset(e){return e.title.dataset}createItemARIA(e){return{role:"menuitem","aria-haspopup":"true","aria-disabled":e.disabled?"true":"false"}}createIconClass(e){let t="lm-MenuBar-itemIcon",i=e.title.iconClass;return i?`${t} ${i}`:t}formatLabel(e){let{label:t,mnemonic:i}=e.title;if(i<0||i>=t.length)return t;let s=t.slice(0,i),n=t.slice(i+1),a=t[i];return[s,d.h.span({className:"lm-MenuBar-itemMnemonic"},a),n]}}e.Renderer=t,e.defaultRenderer=new t}(te||(te={})),function(e){e.createNode=function(){let e=document.createElement("div"),t=document.createElement("ul");return t.className="lm-MenuBar-content",e.appendChild(t),t.setAttribute("role","menubar"),e},e.findMnemonic=function(e,t,i){let s=-1,n=-1,a=!1,r=t.toUpperCase();for(let t=0,o=e.length;t=0&&l1&&this.widgets.forEach((e=>{e.hiddenMode=this._hiddenMode})))}dispose(){for(const e of this._items)e.dispose();this._box=null,this._items.length=0,super.dispose()}attachWidget(e,i){this._hiddenMode===b.HiddenMode.Scale&&this._items.length>0?(1===this._items.length&&(this.widgets[0].hiddenMode=b.HiddenMode.Scale),i.hiddenMode=b.HiddenMode.Scale):i.hiddenMode=b.HiddenMode.Display,t.ArrayExt.insert(this._items,e,new x(i)),this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.BeforeAttach),this.parent.node.appendChild(i.node),this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.AfterAttach),this.parent.fit()}moveWidget(e,i,s){t.ArrayExt.move(this._items,e,i),this.parent.update()}detachWidget(e,i){let s=t.ArrayExt.removeAt(this._items,e);this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.BeforeDetach),this.parent.node.removeChild(i.node),this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.AfterDetach),s.widget.node.style.zIndex="",this._hiddenMode===b.HiddenMode.Scale&&(i.hiddenMode=b.HiddenMode.Display,1===this._items.length&&(this._items[0].widget.hiddenMode=b.HiddenMode.Display)),s.dispose(),this.parent.fit()}onBeforeShow(e){super.onBeforeShow(e),this.parent.update()}onBeforeAttach(e){super.onBeforeAttach(e),this.parent.fit()}onChildShown(e){this.parent.fit()}onChildHidden(e){this.parent.fit()}onResize(e){this.parent.isVisible&&this._update(e.width,e.height)}onUpdateRequest(e){this.parent.isVisible&&this._update(-1,-1)}onFitRequest(e){this.parent.isAttached&&this._fit()}_fit(){let e=0,t=0;for(let i=0,s=this._items.length;i{t.ArrayExt.removeFirstOf(this._items,i)}))}open(e){if(F.saveWindowData(),this.menu.clearItems(),0===this._items.length)return!1;let t=T.matchItems(this._items,e,this._groupByTarget,this._sortBySelector);if(!t||0===t.length)return!1;for(const e of t)this.menu.addItem(e);return this.menu.open(e.clientX,e.clientY),!0}},e.DockLayout=Q,e.DockPanel=Z,e.FocusTracker=class{constructor(){this._counter=0,this._widgets=[],this._activeWidget=null,this._currentWidget=null,this._numbers=new Map,this._nodes=new Map,this._activeChanged=new r.Signal(this),this._currentChanged=new r.Signal(this)}dispose(){if(!(this._counter<0)){this._counter=-1,r.Signal.clearData(this);for(const e of this._widgets)e.node.removeEventListener("focus",this,!0),e.node.removeEventListener("blur",this,!0);this._activeWidget=null,this._currentWidget=null,this._nodes.clear(),this._numbers.clear(),this._widgets.length=0}}get currentChanged(){return this._currentChanged}get activeChanged(){return this._activeChanged}get isDisposed(){return this._counter<0}get currentWidget(){return this._currentWidget}get activeWidget(){return this._activeWidget}get widgets(){return this._widgets}focusNumber(e){let t=this._numbers.get(e);return void 0===t?-1:t}has(e){return this._numbers.has(e)}add(e){if(this._numbers.has(e))return;let t=e.node.contains(document.activeElement),i=t?this._counter++:-1;this._widgets.push(e),this._numbers.set(e,i),this._nodes.set(e.node,e),e.node.addEventListener("focus",this,!0),e.node.addEventListener("blur",this,!0),e.disposed.connect(this._onWidgetDisposed,this),t&&this._setWidgets(e,e)}remove(e){if(!this._numbers.has(e))return;if(e.disposed.disconnect(this._onWidgetDisposed,this),e.node.removeEventListener("focus",this,!0),e.node.removeEventListener("blur",this,!0),t.ArrayExt.removeFirstOf(this._widgets,e),this._nodes.delete(e.node),this._numbers.delete(e),this._currentWidget!==e)return;let i=this._widgets.filter((e=>-1!==this._numbers.get(e))),s=t.max(i,((e,t)=>this._numbers.get(e)-this._numbers.get(t)))||null;this._setWidgets(s,null)}handleEvent(e){switch(e.type){case"focus":this._evtFocus(e);break;case"blur":this._evtBlur(e)}}_setWidgets(e,t){let i=this._currentWidget;this._currentWidget=e;let s=this._activeWidget;this._activeWidget=t,i!==e&&this._currentChanged.emit({oldValue:i,newValue:e}),s!==t&&this._activeChanged.emit({oldValue:s,newValue:t})}_evtFocus(e){let t=this._nodes.get(e.currentTarget);t!==this._currentWidget&&this._numbers.set(t,this._counter++),this._setWidgets(t,t)}_evtBlur(e){let i=this._nodes.get(e.currentTarget),s=e.relatedTarget;s&&(i.node.contains(s)||t.find(this._widgets,(e=>e.node.contains(s))))||this._setWidgets(this._currentWidget,null)}_onWidgetDisposed(e){this.remove(e)}},e.GridLayout=ee,e.Layout=v,e.LayoutItem=x,e.Menu=F,e.MenuBar=te,e.Panel=R,e.PanelLayout=M,e.ScrollBar=class extends b{constructor(e={}){super({node:G.createNode()}),this._onRepeat=()=>{if(this._repeatTimer=-1,!this._pressData)return;let e=this._pressData.part;if("thumb"===e)return;this._repeatTimer=window.setTimeout(this._onRepeat,20);let t=this._pressData.mouseX,i=this._pressData.mouseY;if("decrement"!==e)if("increment"!==e){if("track"===e){if(!s.ElementExt.hitTest(this.trackNode,t,i))return;let e=this.thumbNode;if(s.ElementExt.hitTest(e,t,i))return;let n,a=e.getBoundingClientRect();return n="horizontal"===this._orientation?t0&&(r+=i.stretch,o++)}if(t===a)return 0;if(t<=s){for(let t=0;t=n){for(let t=0;t0&&s>h;){let t=s,n=r;for(let a=0;a0&&s>h;){let t=s/d;for(let n=0;n0&&s>h;){let t=s,n=r;for(let a=0;a=i.maxSize?(s-=i.maxSize-i.size,r-=i.stretch,i.size=i.maxSize,i.done=!0,d--,o--):(s-=h,i.size+=h)}}for(;d>0&&s>h;){let t=s/d;for(let n=0;n=i.maxSize?(s-=i.maxSize-i.size,i.size=i.maxSize,i.done=!0,d--):(s-=t,i.size+=t))}}}return 0},m.adjust=function(e,t,i){0!==e.length&&0!==i&&(i>0?function(e,t,i){let s=0;for(let i=0;i<=t;++i){let t=e[i];s+=t.maxSize-t.size}let n=0;for(let i=t+1,s=e.length;i=0&&a>0;--i){let t=e[i],s=t.maxSize-t.size;s>=a?(t.sizeHint=t.size+a,a=0):(t.sizeHint=t.size+s,a-=s)}let r=i;for(let i=t+1,s=e.length;i0;++i){let t=e[i],s=t.size-t.minSize;s>=r?(t.sizeHint=t.size-r,r=0):(t.sizeHint=t.size-s,r-=s)}}(e,t,i):function(e,t,i){let s=0;for(let i=t+1,n=e.length;i0;++i){let t=e[i],s=t.maxSize-t.size;s>=a?(t.sizeHint=t.size+a,a=0):(t.sizeHint=t.size+s,a-=s)}let r=i;for(let i=t;i>=0&&r>0;--i){let t=e[i],s=t.size-t.minSize;s>=r?(t.sizeHint=t.size-r,r=0):(t.sizeHint=t.size-s,r-=s)}}(e,t,-i))};class f{constructor(e){this._label="",this._caption="",this._mnemonic=-1,this._icon=void 0,this._iconClass="",this._iconLabel="",this._className="",this._closable=!1,this._changed=new r.Signal(this),this._isDisposed=!1,this.owner=e.owner,void 0!==e.label&&(this._label=e.label),void 0!==e.mnemonic&&(this._mnemonic=e.mnemonic),void 0!==e.icon&&(this._icon=e.icon),void 0!==e.iconClass&&(this._iconClass=e.iconClass),void 0!==e.iconLabel&&(this._iconLabel=e.iconLabel),void 0!==e.caption&&(this._caption=e.caption),void 0!==e.className&&(this._className=e.className),void 0!==e.closable&&(this._closable=e.closable),this._dataset=e.dataset||{}}get changed(){return this._changed}get label(){return this._label}set label(e){this._label!==e&&(this._label=e,this._changed.emit(void 0))}get mnemonic(){return this._mnemonic}set mnemonic(e){this._mnemonic!==e&&(this._mnemonic=e,this._changed.emit(void 0))}get icon(){return this._icon}set icon(e){this._icon!==e&&(this._icon=e,this._changed.emit(void 0))}get iconClass(){return this._iconClass}set iconClass(e){this._iconClass!==e&&(this._iconClass=e,this._changed.emit(void 0))}get iconLabel(){return this._iconLabel}set iconLabel(e){this._iconLabel!==e&&(this._iconLabel=e,this._changed.emit(void 0))}get caption(){return this._caption}set caption(e){this._caption!==e&&(this._caption=e,this._changed.emit(void 0))}get className(){return this._className}set className(e){this._className!==e&&(this._className=e,this._changed.emit(void 0))}get closable(){return this._closable}set closable(e){this._closable!==e&&(this._closable=e,this._changed.emit(void 0))}get dataset(){return this._dataset}set dataset(e){this._dataset!==e&&(this._dataset=e,this._changed.emit(void 0))}get isDisposed(){return this._isDisposed}dispose(){this.isDisposed||(this._isDisposed=!0,r.Signal.clearData(this))}}class b{constructor(e={}){this._flags=0,this._layout=null,this._parent=null,this._disposed=new r.Signal(this),this._hiddenMode=b.HiddenMode.Display,this.node=g.createNode(e),this.addClass("lm-Widget")}dispose(){this.isDisposed||(this.setFlag(b.Flag.IsDisposed),this._disposed.emit(void 0),this.parent?this.parent=null:this.isAttached&&b.detach(this),this._layout&&(this._layout.dispose(),this._layout=null),this.title.dispose(),r.Signal.clearData(this),n.MessageLoop.clearData(this),a.AttachedProperty.clearData(this))}get disposed(){return this._disposed}get isDisposed(){return this.testFlag(b.Flag.IsDisposed)}get isAttached(){return this.testFlag(b.Flag.IsAttached)}get isHidden(){return this.testFlag(b.Flag.IsHidden)}get isVisible(){return this.testFlag(b.Flag.IsVisible)}get title(){return g.titleProperty.get(this)}get id(){return this.node.id}set id(e){this.node.id=e}get dataset(){return this.node.dataset}get hiddenMode(){return this._hiddenMode}set hiddenMode(e){this._hiddenMode!==e&&(this.isHidden&&this._toggleHidden(!1),e==b.HiddenMode.Scale?this.node.style.willChange="transform":this.node.style.willChange="auto",this._hiddenMode=e,this.isHidden&&this._toggleHidden(!0))}get parent(){return this._parent}set parent(e){if(this._parent!==e){if(e&&this.contains(e))throw new Error("Invalid parent widget.");if(this._parent&&!this._parent.isDisposed){let e=new b.ChildMessage("child-removed",this);n.MessageLoop.sendMessage(this._parent,e)}if(this._parent=e,this._parent&&!this._parent.isDisposed){let e=new b.ChildMessage("child-added",this);n.MessageLoop.sendMessage(this._parent,e)}this.isDisposed||n.MessageLoop.sendMessage(this,b.Msg.ParentChanged)}}get layout(){return this._layout}set layout(e){if(this._layout!==e){if(this.testFlag(b.Flag.DisallowLayout))throw new Error("Cannot set widget layout.");if(this._layout)throw new Error("Cannot change widget layout.");if(e.parent)throw new Error("Cannot change layout parent.");this._layout=e,e.parent=this}}*children(){this._layout&&(yield*this._layout)}contains(e){for(let t=e;t;t=t._parent)if(t===this)return!0;return!1}hasClass(e){return this.node.classList.contains(e)}addClass(e){this.node.classList.add(e)}removeClass(e){this.node.classList.remove(e)}toggleClass(e,t){return!0===t?(this.node.classList.add(e),!0):!1===t?(this.node.classList.remove(e),!1):this.node.classList.toggle(e)}update(){n.MessageLoop.postMessage(this,b.Msg.UpdateRequest)}fit(){n.MessageLoop.postMessage(this,b.Msg.FitRequest)}activate(){n.MessageLoop.postMessage(this,b.Msg.ActivateRequest)}close(){n.MessageLoop.sendMessage(this,b.Msg.CloseRequest)}show(){if(this.testFlag(b.Flag.IsHidden)&&(!this.isAttached||this.parent&&!this.parent.isVisible||n.MessageLoop.sendMessage(this,b.Msg.BeforeShow),this.clearFlag(b.Flag.IsHidden),this._toggleHidden(!1),!this.isAttached||this.parent&&!this.parent.isVisible||n.MessageLoop.sendMessage(this,b.Msg.AfterShow),this.parent)){let e=new b.ChildMessage("child-shown",this);n.MessageLoop.sendMessage(this.parent,e)}}hide(){if(!this.testFlag(b.Flag.IsHidden)&&(!this.isAttached||this.parent&&!this.parent.isVisible||n.MessageLoop.sendMessage(this,b.Msg.BeforeHide),this.setFlag(b.Flag.IsHidden),this._toggleHidden(!0),!this.isAttached||this.parent&&!this.parent.isVisible||n.MessageLoop.sendMessage(this,b.Msg.AfterHide),this.parent)){let e=new b.ChildMessage("child-hidden",this);n.MessageLoop.sendMessage(this.parent,e)}}setHidden(e){e?this.hide():this.show()}testFlag(e){return 0!=(this._flags&e)}setFlag(e){this._flags|=e}clearFlag(e){this._flags&=~e}processMessage(e){switch(e.type){case"resize":this.notifyLayout(e),this.onResize(e);break;case"update-request":this.notifyLayout(e),this.onUpdateRequest(e);break;case"fit-request":this.notifyLayout(e),this.onFitRequest(e);break;case"before-show":this.notifyLayout(e),this.onBeforeShow(e);break;case"after-show":this.setFlag(b.Flag.IsVisible),this.notifyLayout(e),this.onAfterShow(e);break;case"before-hide":this.notifyLayout(e),this.onBeforeHide(e);break;case"after-hide":this.clearFlag(b.Flag.IsVisible),this.notifyLayout(e),this.onAfterHide(e);break;case"before-attach":this.notifyLayout(e),this.onBeforeAttach(e);break;case"after-attach":this.isHidden||this.parent&&!this.parent.isVisible||this.setFlag(b.Flag.IsVisible),this.setFlag(b.Flag.IsAttached),this.notifyLayout(e),this.onAfterAttach(e);break;case"before-detach":this.notifyLayout(e),this.onBeforeDetach(e);break;case"after-detach":this.clearFlag(b.Flag.IsVisible),this.clearFlag(b.Flag.IsAttached),this.notifyLayout(e),this.onAfterDetach(e);break;case"activate-request":this.notifyLayout(e),this.onActivateRequest(e);break;case"close-request":this.notifyLayout(e),this.onCloseRequest(e);break;case"child-added":this.notifyLayout(e),this.onChildAdded(e);break;case"child-removed":this.notifyLayout(e),this.onChildRemoved(e);break;default:this.notifyLayout(e)}}notifyLayout(e){this._layout&&this._layout.processParentMessage(e)}onCloseRequest(e){this.parent?this.parent=null:this.isAttached&&b.detach(this)}onResize(e){}onUpdateRequest(e){}onFitRequest(e){}onActivateRequest(e){}onBeforeShow(e){}onAfterShow(e){}onBeforeHide(e){}onAfterHide(e){}onBeforeAttach(e){}onAfterAttach(e){}onBeforeDetach(e){}onAfterDetach(e){}onChildAdded(e){}onChildRemoved(e){}_toggleHidden(e){if(e)switch(this._hiddenMode){case b.HiddenMode.Display:this.addClass("lm-mod-hidden");break;case b.HiddenMode.Scale:this.node.style.transform="scale(0)",this.node.setAttribute("aria-hidden","true");break;case b.HiddenMode.ContentVisibility:this.node.style.contentVisibility="hidden",this.node.style.zIndex="-1"}else switch(this._hiddenMode){case b.HiddenMode.Display:this.removeClass("lm-mod-hidden");break;case b.HiddenMode.Scale:this.node.style.transform="",this.node.removeAttribute("aria-hidden");break;case b.HiddenMode.ContentVisibility:this.node.style.contentVisibility="",this.node.style.zIndex=""}}}!function(e){var t,i,s;(t=e.HiddenMode||(e.HiddenMode={}))[t.Display=0]="Display",t[t.Scale=1]="Scale",t[t.ContentVisibility=2]="ContentVisibility",(i=e.Flag||(e.Flag={}))[i.IsDisposed=1]="IsDisposed",i[i.IsAttached=2]="IsAttached",i[i.IsHidden=4]="IsHidden",i[i.IsVisible=8]="IsVisible",i[i.DisallowLayout=16]="DisallowLayout",(s=e.Msg||(e.Msg={})).BeforeShow=new n.Message("before-show"),s.AfterShow=new n.Message("after-show"),s.BeforeHide=new n.Message("before-hide"),s.AfterHide=new n.Message("after-hide"),s.BeforeAttach=new n.Message("before-attach"),s.AfterAttach=new n.Message("after-attach"),s.BeforeDetach=new n.Message("before-detach"),s.AfterDetach=new n.Message("after-detach"),s.ParentChanged=new n.Message("parent-changed"),s.UpdateRequest=new n.ConflatableMessage("update-request"),s.FitRequest=new n.ConflatableMessage("fit-request"),s.ActivateRequest=new n.ConflatableMessage("activate-request"),s.CloseRequest=new n.ConflatableMessage("close-request");class a extends n.Message{constructor(e,t){super(e),this.child=t}}e.ChildMessage=a;class r extends n.Message{constructor(e,t){super("resize"),this.width=e,this.height=t}}e.ResizeMessage=r,function(e){e.UnknownSize=new e(-1,-1)}(r=e.ResizeMessage||(e.ResizeMessage={})),e.attach=function(t,i,s=null){if(t.parent)throw new Error("Cannot attach a child widget.");if(t.isAttached||t.node.isConnected)throw new Error("Widget is already attached.");if(!i.isConnected)throw new Error("Host is not attached.");n.MessageLoop.sendMessage(t,e.Msg.BeforeAttach),i.insertBefore(t.node,s),n.MessageLoop.sendMessage(t,e.Msg.AfterAttach)},e.detach=function(t){if(t.parent)throw new Error("Cannot detach a child widget.");if(!t.isAttached||!t.node.isConnected)throw new Error("Widget is not attached.");n.MessageLoop.sendMessage(t,e.Msg.BeforeDetach),t.node.parentNode.removeChild(t.node),n.MessageLoop.sendMessage(t,e.Msg.AfterDetach)}}(b||(b={})),function(e){e.titleProperty=new a.AttachedProperty({name:"title",create:e=>new f({owner:e})}),e.createNode=function(e){return e.node||document.createElement(e.tag||"div")}}(g||(g={}));class v{constructor(e={}){this._disposed=!1,this._parent=null,this._fitPolicy=e.fitPolicy||"set-min-size"}dispose(){this._parent=null,this._disposed=!0,r.Signal.clearData(this),a.AttachedProperty.clearData(this)}get isDisposed(){return this._disposed}get parent(){return this._parent}set parent(e){if(this._parent!==e){if(this._parent)throw new Error("Cannot change parent widget.");if(e.layout!==this)throw new Error("Invalid parent widget.");this._parent=e,this.init()}}get fitPolicy(){return this._fitPolicy}set fitPolicy(e){if(this._fitPolicy!==e&&(this._fitPolicy=e,this._parent)){let e=this._parent.node.style;e.minWidth="",e.minHeight="",e.maxWidth="",e.maxHeight="",this._parent.fit()}}processParentMessage(e){switch(e.type){case"resize":this.onResize(e);break;case"update-request":this.onUpdateRequest(e);break;case"fit-request":this.onFitRequest(e);break;case"before-show":this.onBeforeShow(e);break;case"after-show":this.onAfterShow(e);break;case"before-hide":this.onBeforeHide(e);break;case"after-hide":this.onAfterHide(e);break;case"before-attach":this.onBeforeAttach(e);break;case"after-attach":this.onAfterAttach(e);break;case"before-detach":this.onBeforeDetach(e);break;case"after-detach":this.onAfterDetach(e);break;case"child-removed":this.onChildRemoved(e);break;case"child-shown":this.onChildShown(e);break;case"child-hidden":this.onChildHidden(e)}}init(){for(const e of this)e.parent=this.parent}onResize(e){for(const e of this)n.MessageLoop.sendMessage(e,b.ResizeMessage.UnknownSize)}onUpdateRequest(e){for(const e of this)n.MessageLoop.sendMessage(e,b.ResizeMessage.UnknownSize)}onBeforeAttach(e){for(const t of this)n.MessageLoop.sendMessage(t,e)}onAfterAttach(e){for(const t of this)n.MessageLoop.sendMessage(t,e)}onBeforeDetach(e){for(const t of this)n.MessageLoop.sendMessage(t,e)}onAfterDetach(e){for(const t of this)n.MessageLoop.sendMessage(t,e)}onBeforeShow(e){for(const t of this)t.isHidden||n.MessageLoop.sendMessage(t,e)}onAfterShow(e){for(const t of this)t.isHidden||n.MessageLoop.sendMessage(t,e)}onBeforeHide(e){for(const t of this)t.isHidden||n.MessageLoop.sendMessage(t,e)}onAfterHide(e){for(const t of this)t.isHidden||n.MessageLoop.sendMessage(t,e)}onChildRemoved(e){this.removeWidget(e.child)}onFitRequest(e){}onChildShown(e){}onChildHidden(e){}}!function(e){e.getHorizontalAlignment=function(e){return p.horizontalAlignmentProperty.get(e)},e.setHorizontalAlignment=function(e,t){p.horizontalAlignmentProperty.set(e,t)},e.getVerticalAlignment=function(e){return p.verticalAlignmentProperty.get(e)},e.setVerticalAlignment=function(e,t){p.verticalAlignmentProperty.set(e,t)}}(v||(v={}));class x{constructor(e){this._top=NaN,this._left=NaN,this._width=NaN,this._height=NaN,this._minWidth=0,this._minHeight=0,this._maxWidth=1/0,this._maxHeight=1/0,this._disposed=!1,this.widget=e,this.widget.node.style.position="absolute",this.widget.node.style.contain="strict"}dispose(){if(this._disposed)return;this._disposed=!0;let e=this.widget.node.style;e.position="",e.top="",e.left="",e.width="",e.height="",e.contain=""}get minWidth(){return this._minWidth}get minHeight(){return this._minHeight}get maxWidth(){return this._maxWidth}get maxHeight(){return this._maxHeight}get isDisposed(){return this._disposed}get isHidden(){return this.widget.isHidden}get isVisible(){return this.widget.isVisible}get isAttached(){return this.widget.isAttached}fit(){let e=s.ElementExt.sizeLimits(this.widget.node);this._minWidth=e.minWidth,this._minHeight=e.minHeight,this._maxWidth=e.maxWidth,this._maxHeight=e.maxHeight}update(e,t,i,s){let a=Math.max(this._minWidth,Math.min(i,this._maxWidth)),r=Math.max(this._minHeight,Math.min(s,this._maxHeight));if(a"center",changed:t}),e.verticalAlignmentProperty=new a.AttachedProperty({name:"verticalAlignment",create:()=>"top",changed:t})}(p||(p={}));class M extends v{constructor(){super(...arguments),this._widgets=[]}dispose(){for(;this._widgets.length>0;)this._widgets.pop().dispose();super.dispose()}get widgets(){return this._widgets}*[Symbol.iterator](){yield*this._widgets}addWidget(e){this.insertWidget(this._widgets.length,e)}insertWidget(e,i){i.parent=this.parent;let s=this._widgets.indexOf(i),n=Math.max(0,Math.min(e,this._widgets.length));if(-1===s)return t.ArrayExt.insert(this._widgets,n,i),void(this.parent&&this.attachWidget(n,i));n===this._widgets.length&&n--,s!==n&&(t.ArrayExt.move(this._widgets,s,n),this.parent&&this.moveWidget(s,n,i))}removeWidget(e){this.removeWidgetAt(this._widgets.indexOf(e))}removeWidgetAt(e){let i=t.ArrayExt.removeAt(this._widgets,e);i&&this.parent&&this.detachWidget(e,i)}init(){super.init();let e=0;for(const t of this)this.attachWidget(e++,t)}attachWidget(e,t){let i=this.parent.node.children[e];this.parent.isAttached&&n.MessageLoop.sendMessage(t,b.Msg.BeforeAttach),this.parent.node.insertBefore(t.node,i),this.parent.isAttached&&n.MessageLoop.sendMessage(t,b.Msg.AfterAttach)}moveWidget(e,t,i){this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.BeforeDetach),this.parent.node.removeChild(i.node),this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.AfterDetach);let s=this.parent.node.children[t];this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.BeforeAttach),this.parent.node.insertBefore(i.node,s),this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.AfterAttach)}detachWidget(e,t){this.parent.isAttached&&n.MessageLoop.sendMessage(t,b.Msg.BeforeDetach),this.parent.node.removeChild(t.node),this.parent.isAttached&&n.MessageLoop.sendMessage(t,b.Msg.AfterDetach)}}!function(e){e.clampDimension=function(e){return Math.max(0,Math.floor(e))}}(_||(_={}));var y,w,A,E,C,S,I,z,L,T,D=_;class B extends M{constructor(e){super(),this.widgetOffset=0,this._fixed=0,this._spacing=4,this._dirty=!1,this._hasNormedSizes=!1,this._sizers=[],this._items=[],this._handles=[],this._box=null,this._alignment="start",this._orientation="horizontal",this.renderer=e.renderer,void 0!==e.orientation&&(this._orientation=e.orientation),void 0!==e.alignment&&(this._alignment=e.alignment),void 0!==e.spacing&&(this._spacing=_.clampDimension(e.spacing))}dispose(){for(const e of this._items)e.dispose();this._box=null,this._items.length=0,this._sizers.length=0,this._handles.length=0,super.dispose()}get orientation(){return this._orientation}set orientation(e){this._orientation!==e&&(this._orientation=e,this.parent&&(this.parent.dataset.orientation=e,this.parent.fit()))}get alignment(){return this._alignment}set alignment(e){this._alignment!==e&&(this._alignment=e,this.parent&&(this.parent.dataset.alignment=e,this.parent.update()))}get spacing(){return this._spacing}set spacing(e){e=_.clampDimension(e),this._spacing!==e&&(this._spacing=e,this.parent&&this.parent.fit())}get handles(){return this._handles}absoluteSizes(){return this._sizers.map((e=>e.size))}relativeSizes(){return y.normalize(this._sizers.map((e=>e.size)))}setRelativeSizes(e,t=!0){let i=this._sizers.length,s=e.slice(0,i);for(;s.length0&&(e.sizeHint=e.size);e.BoxEngine.adjust(this._sizers,t,s),this.parent&&this.parent.update()}}init(){this.parent.dataset.orientation=this.orientation,this.parent.dataset.alignment=this.alignment,super.init()}attachWidget(e,i){let s=new x(i),a=y.createHandle(this.renderer),r=y.averageSize(this._sizers),o=y.createSizer(r);t.ArrayExt.insert(this._items,e,s),t.ArrayExt.insert(this._sizers,e,o),t.ArrayExt.insert(this._handles,e,a),this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.BeforeAttach),this.parent.node.appendChild(i.node),this.parent.node.appendChild(a),this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.AfterAttach),this.parent.fit()}moveWidget(e,i,s){t.ArrayExt.move(this._items,e,i),t.ArrayExt.move(this._sizers,e,i),t.ArrayExt.move(this._handles,e,i),this.parent.fit()}detachWidget(e,i){let s=t.ArrayExt.removeAt(this._items,e),a=t.ArrayExt.removeAt(this._handles,e);t.ArrayExt.removeAt(this._sizers,e),this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.BeforeDetach),this.parent.node.removeChild(i.node),this.parent.node.removeChild(a),this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.AfterDetach),s.dispose(),this.parent.fit()}onBeforeShow(e){super.onBeforeShow(e),this.parent.update()}onBeforeAttach(e){super.onBeforeAttach(e),this.parent.fit()}onChildShown(e){this.parent.fit()}onChildHidden(e){this.parent.fit()}onResize(e){this.parent.isVisible&&this._update(e.width,e.height)}onUpdateRequest(e){this.parent.isVisible&&this._update(-1,-1)}onFitRequest(e){this.parent.isAttached&&this._fit()}updateItemPosition(e,t,i,s,n,a,r){const o=this._items[e];if(o.isHidden)return;let h=this._handles[e].style;t?(i+=this.widgetOffset,o.update(i,s,r,n),i+=r,h.top=`${s}px`,h.left=`${i}px`,h.width=`${this._spacing}px`,h.height=`${n}px`):(s+=this.widgetOffset,o.update(i,s,a,r),s+=r,h.top=`${s}px`,h.left=`${i}px`,h.width=`${a}px`,h.height=`${this._spacing}px`)}_fit(){let e=0,t=-1;for(let i=0,s=this._items.length;i0&&(s.sizeHint=s.size),t.isHidden?(s.minSize=0,s.maxSize=0):(t.fit(),s.stretch=B.getStretch(t.widget),i?(s.minSize=t.minWidth,s.maxSize=t.maxWidth,a+=t.minWidth,r=Math.max(r,t.minHeight)):(s.minSize=t.minHeight,s.maxSize=t.maxHeight,r+=t.minHeight,a=Math.max(a,t.minWidth)))}let o=this._box=s.ElementExt.boxSizing(this.parent.node);a+=o.horizontalSum,r+=o.verticalSum;let h=this.parent.node.style;h.minWidth=`${a}px`,h.minHeight=`${r}px`,this._dirty=!0,this.parent.parent&&n.MessageLoop.sendMessage(this.parent.parent,b.Msg.FitRequest),this._dirty&&n.MessageLoop.sendMessage(this.parent,b.Msg.UpdateRequest)}_update(t,i){this._dirty=!1;let n=0;for(let e=0,t=this._items.length;e0){let t;if(t=c?Math.max(0,o-this._fixed):Math.max(0,h-this._fixed),this._hasNormedSizes){for(let e of this._sizers)e.sizeHint*=t;this._hasNormedSizes=!1}let i=e.BoxEngine.calc(this._sizers,t);if(i>0)switch(this._alignment){case"start":break;case"center":d=0,l=i/2;break;case"end":d=0,l=i;break;case"justify":d=i/n,l=0;break;default:throw"unreachable"}}for(let e=0,t=this._items.length;e0,coerce:(e,t)=>Math.max(0,Math.floor(t)),changed:function(e){e.parent&&e.parent.layout instanceof B&&e.parent.fit()}}),e.createSizer=function(e){let t=new u;return t.sizeHint=Math.floor(e),t},e.createHandle=function(e){let t=e.createHandle();return t.style.position="absolute",t.style.contain="style",t},e.averageSize=function(e){return e.reduce(((e,t)=>e+t.size),0)/e.length||0},e.normalize=function(e){let t=e.length;if(0===t)return[];let i=e.reduce(((e,t)=>e+Math.abs(t)),0);return 0===i?e.map((e=>1/t)):e.map((e=>e/i))}}(y||(y={}));class k extends B{constructor(e){super({...e,orientation:e.orientation||"vertical"}),this._titles=[],this.titleSpace=e.titleSpace||22}get titleSpace(){return this.widgetOffset}set titleSpace(e){e=D.clampDimension(e),this.widgetOffset!==e&&(this.widgetOffset=e,this.parent&&this.parent.fit())}get titles(){return this._titles}dispose(){this.isDisposed||(this._titles.length=0,super.dispose())}updateTitle(e,t){const i=this._titles[e],s=i.classList.contains("lm-mod-expanded"),n=w.createTitle(this.renderer,t.title,s);this._titles[e]=n,this.parent.node.replaceChild(n,i)}insertWidget(e,t){t.id||(t.id=`id-${i.UUID.uuid4()}`),super.insertWidget(e,t)}attachWidget(e,i){const s=w.createTitle(this.renderer,i.title);t.ArrayExt.insert(this._titles,e,s),this.parent.node.appendChild(s),i.node.setAttribute("role","region"),i.node.setAttribute("aria-labelledby",s.id),super.attachWidget(e,i)}moveWidget(e,i,s){t.ArrayExt.move(this._titles,e,i),super.moveWidget(e,i,s)}detachWidget(e,i){const s=t.ArrayExt.removeAt(this._titles,e);this.parent.node.removeChild(s),super.detachWidget(e,i)}updateItemPosition(e,t,i,s,n,a,r){const o=this._titles[e].style;o.top=`${s}px`,o.left=`${i}px`,o.height=`${this.widgetOffset}px`,o.width=t?`${n}px`:`${a}px`,super.updateItemPosition(e,t,i,s,n,a,r)}}!function(e){e.createTitle=function(e,t,i=!0){const s=e.createSectionTitle(t);return s.style.position="absolute",s.style.contain="strict",s.setAttribute("aria-label",`${t.label} Section`),s.setAttribute("aria-expanded",i?"true":"false"),s.setAttribute("aria-controls",t.owner.id),i&&s.classList.add("lm-mod-expanded"),s}}(w||(w={}));class R extends b{constructor(e={}){super(),this.addClass("lm-Panel"),this.layout=A.createLayout(e)}get widgets(){return this.layout.widgets}addWidget(e){this.layout.addWidget(e)}insertWidget(e,t){this.layout.insertWidget(e,t)}}!function(e){e.createLayout=function(e){return e.layout||new M}}(A||(A={}));class N extends R{constructor(e={}){super({layout:E.createLayout(e)}),this._handleMoved=new r.Signal(this),this._pressData=null,this.addClass("lm-SplitPanel")}dispose(){this._releaseMouse(),super.dispose()}get orientation(){return this.layout.orientation}set orientation(e){this.layout.orientation=e}get alignment(){return this.layout.alignment}set alignment(e){this.layout.alignment=e}get spacing(){return this.layout.spacing}set spacing(e){this.layout.spacing=e}get renderer(){return this.layout.renderer}get handleMoved(){return this._handleMoved}get handles(){return this.layout.handles}relativeSizes(){return this.layout.relativeSizes()}setRelativeSizes(e,t=!0){this.layout.setRelativeSizes(e,t)}handleEvent(e){switch(e.type){case"pointerdown":this._evtPointerDown(e);break;case"pointermove":this._evtPointerMove(e);break;case"pointerup":this._evtPointerUp(e);break;case"keydown":this._evtKeyDown(e);break;case"contextmenu":e.preventDefault(),e.stopPropagation()}}onBeforeAttach(e){this.node.addEventListener("pointerdown",this)}onAfterDetach(e){this.node.removeEventListener("pointerdown",this),this._releaseMouse()}onChildAdded(e){e.child.addClass("lm-SplitPanel-child"),this._releaseMouse()}onChildRemoved(e){e.child.removeClass("lm-SplitPanel-child"),this._releaseMouse()}_evtKeyDown(e){this._pressData&&(e.preventDefault(),e.stopPropagation()),27===e.keyCode&&this._releaseMouse()}_evtPointerDown(e){if(0!==e.button)return;let i,s=this.layout,n=t.ArrayExt.findFirstIndex(s.handles,(t=>t.contains(e.target)));if(-1===n)return;e.preventDefault(),e.stopPropagation(),document.addEventListener("pointerup",this,!0),document.addEventListener("pointermove",this,!0),document.addEventListener("keydown",this,!0),document.addEventListener("contextmenu",this,!0);let a=s.handles[n],r=a.getBoundingClientRect();i="horizontal"===s.orientation?e.clientX-r.left:e.clientY-r.top;let h=window.getComputedStyle(a),d=o.Drag.overrideCursor(h.cursor);this._pressData={index:n,delta:i,override:d}}_evtPointerMove(e){let t;e.preventDefault(),e.stopPropagation();let i=this.layout,s=this.node.getBoundingClientRect();t="horizontal"===i.orientation?e.clientX-s.left-this._pressData.delta:e.clientY-s.top-this._pressData.delta,i.moveHandle(this._pressData.index,t)}_evtPointerUp(e){0===e.button&&(e.preventDefault(),e.stopPropagation(),this._releaseMouse())}_releaseMouse(){this._pressData&&(this._pressData.override.dispose(),this._pressData=null,this._handleMoved.emit(),document.removeEventListener("keydown",this,!0),document.removeEventListener("pointerup",this,!0),document.removeEventListener("pointermove",this,!0),document.removeEventListener("contextmenu",this,!0))}}!function(e){class t{createHandle(){let e=document.createElement("div");return e.className="lm-SplitPanel-handle",e}}e.Renderer=t,e.defaultRenderer=new t,e.getStretch=function(e){return B.getStretch(e)},e.setStretch=function(e,t){B.setStretch(e,t)}}(N||(N={})),function(e){e.createLayout=function(e){return e.layout||new B({renderer:e.renderer||N.defaultRenderer,orientation:e.orientation,alignment:e.alignment,spacing:e.spacing})}}(E||(E={}));class H extends N{constructor(e={}){super({...e,layout:C.createLayout(e)}),this._widgetSizesCache=new WeakMap,this._expansionToggled=new r.Signal(this),this.addClass("lm-AccordionPanel")}get renderer(){return this.layout.renderer}get titleSpace(){return this.layout.titleSpace}set titleSpace(e){this.layout.titleSpace=e}get titles(){return this.layout.titles}get expansionToggled(){return this._expansionToggled}addWidget(e){super.addWidget(e),e.title.changed.connect(this._onTitleChanged,this)}collapse(e){const t=this.layout.widgets[e];t&&!t.isHidden&&this._toggleExpansion(e)}expand(e){const t=this.layout.widgets[e];t&&t.isHidden&&this._toggleExpansion(e)}insertWidget(e,t){super.insertWidget(e,t),t.title.changed.connect(this._onTitleChanged,this)}handleEvent(e){switch(super.handleEvent(e),e.type){case"click":this._evtClick(e);break;case"keydown":this._eventKeyDown(e)}}onBeforeAttach(e){this.node.addEventListener("click",this),this.node.addEventListener("keydown",this),super.onBeforeAttach(e)}onAfterDetach(e){super.onAfterDetach(e),this.node.removeEventListener("click",this),this.node.removeEventListener("keydown",this)}_onTitleChanged(e){const i=t.ArrayExt.findFirstIndex(this.widgets,(t=>t.contains(e.owner)));i>=0&&(this.layout.updateTitle(i,e.owner),this.update())}_computeWidgetSize(e){const t=this.layout,i=t.widgets[e];if(!i)return;const s=i.isHidden,n=t.absoluteSizes(),a=(s?-1:1)*this.spacing,r=n.reduce(((e,t)=>e+t));let o=[...n];if(s){const t=this._widgetSizesCache.get(i);if(!t)return;o[e]+=t;const s=o.map((e=>e-t>0)).lastIndexOf(!0);-1===s?o.forEach(((i,s)=>{s!==e&&(o[s]-=n[s]/r*(t-a))})):o[s]-=t-a}else{const t=n[e];this._widgetSizesCache.set(i,t),o[e]=0;const s=o.map((e=>e>0)).lastIndexOf(!0);if(-1===s)return;o[s]=n[s]+t+a}return o.map((e=>e/(r+a)))}_evtClick(e){const i=e.target;if(i){const s=t.ArrayExt.findFirstIndex(this.titles,(e=>e.contains(i)));s>=0&&(e.preventDefault(),e.stopPropagation(),this._toggleExpansion(s))}}_eventKeyDown(e){if(e.defaultPrevented)return;const i=e.target;let s=!1;if(i){const n=t.ArrayExt.findFirstIndex(this.titles,(e=>e.contains(i)));if(n>=0){const t=e.keyCode.toString();if(e.key.match(/Space|Enter/)||t.match(/13|32/))i.click(),s=!0;else if("horizontal"===this.orientation?e.key.match(/ArrowLeft|ArrowRight/)||t.match(/37|39/):e.key.match(/ArrowUp|ArrowDown/)||t.match(/38|40/)){const i=e.key.match(/ArrowLeft|ArrowUp/)||t.match(/37|38/)?-1:1,a=this.titles.length,r=(n+a+i)%a;this.titles[r].focus(),s=!0}else"End"===e.key||"35"===t?(this.titles[this.titles.length-1].focus(),s=!0):"Home"!==e.key&&"36"!==t||(this.titles[0].focus(),s=!0)}s&&e.preventDefault()}}_toggleExpansion(e){const t=this.titles[e],i=this.layout.widgets[e],s=this._computeWidgetSize(e);s&&this.setRelativeSizes(s,!1),i.isHidden?(t.classList.add("lm-mod-expanded"),t.setAttribute("aria-expanded","true"),i.show()):(t.classList.remove("lm-mod-expanded"),t.setAttribute("aria-expanded","false"),i.hide()),this._expansionToggled.emit(e)}}!function(e){class t extends N.Renderer{constructor(){super(),this.titleClassName="lm-AccordionPanel-title",this._titleID=0,this._titleKeys=new WeakMap,this._uuid=++t._nInstance}createCollapseIcon(e){return document.createElement("span")}createSectionTitle(e){const t=document.createElement("h3");t.setAttribute("tabindex","0"),t.id=this.createTitleKey(e),t.className=this.titleClassName;for(const i in e.dataset)t.dataset[i]=e.dataset[i];t.appendChild(this.createCollapseIcon(e)).className="lm-AccordionPanel-titleCollapser";const i=t.appendChild(document.createElement("span"));return i.className="lm-AccordionPanel-titleLabel",i.textContent=e.label,i.title=e.caption||e.label,t}createTitleKey(e){let t=this._titleKeys.get(e);return void 0===t&&(t=`title-key-${this._uuid}-${this._titleID++}`,this._titleKeys.set(e,t)),t}}t._nInstance=0,e.Renderer=t,e.defaultRenderer=new t}(H||(H={})),function(e){e.createLayout=function(e){return e.layout||new k({renderer:e.renderer||H.defaultRenderer,orientation:e.orientation,alignment:e.alignment,spacing:e.spacing,titleSpace:e.titleSpace})}}(C||(C={}));class P extends M{constructor(e={}){super(),this._fixed=0,this._spacing=4,this._dirty=!1,this._sizers=[],this._items=[],this._box=null,this._alignment="start",this._direction="top-to-bottom",void 0!==e.direction&&(this._direction=e.direction),void 0!==e.alignment&&(this._alignment=e.alignment),void 0!==e.spacing&&(this._spacing=D.clampDimension(e.spacing))}dispose(){for(const e of this._items)e.dispose();this._box=null,this._items.length=0,this._sizers.length=0,super.dispose()}get direction(){return this._direction}set direction(e){this._direction!==e&&(this._direction=e,this.parent&&(this.parent.dataset.direction=e,this.parent.fit()))}get alignment(){return this._alignment}set alignment(e){this._alignment!==e&&(this._alignment=e,this.parent&&(this.parent.dataset.alignment=e,this.parent.update()))}get spacing(){return this._spacing}set spacing(e){e=D.clampDimension(e),this._spacing!==e&&(this._spacing=e,this.parent&&this.parent.fit())}init(){this.parent.dataset.direction=this.direction,this.parent.dataset.alignment=this.alignment,super.init()}attachWidget(e,i){t.ArrayExt.insert(this._items,e,new x(i)),t.ArrayExt.insert(this._sizers,e,new u),this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.BeforeAttach),this.parent.node.appendChild(i.node),this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.AfterAttach),this.parent.fit()}moveWidget(e,i,s){t.ArrayExt.move(this._items,e,i),t.ArrayExt.move(this._sizers,e,i),this.parent.update()}detachWidget(e,i){let s=t.ArrayExt.removeAt(this._items,e);t.ArrayExt.removeAt(this._sizers,e),this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.BeforeDetach),this.parent.node.removeChild(i.node),this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.AfterDetach),s.dispose(),this.parent.fit()}onBeforeShow(e){super.onBeforeShow(e),this.parent.update()}onBeforeAttach(e){super.onBeforeAttach(e),this.parent.fit()}onChildShown(e){this.parent.fit()}onChildHidden(e){this.parent.fit()}onResize(e){this.parent.isVisible&&this._update(e.width,e.height)}onUpdateRequest(e){this.parent.isVisible&&this._update(-1,-1)}onFitRequest(e){this.parent.isAttached&&this._fit()}_fit(){let e=0;for(let t=0,i=this._items.length;t0)switch(this._alignment){case"start":break;case"center":l=0,c=a/2;break;case"end":l=0,c=a;break;case"justify":l=a/n,c=0;break;default:throw"unreachable"}for(let e=0,t=this._items.length;e0,coerce:(e,t)=>Math.max(0,Math.floor(t)),changed:t}),e.sizeBasisProperty=new a.AttachedProperty({name:"sizeBasis",create:()=>0,coerce:(e,t)=>Math.max(0,Math.floor(t)),changed:t}),e.isHorizontal=function(e){return"left-to-right"===e||"right-to-left"===e},e.clampSpacing=function(e){return Math.max(0,Math.floor(e))}}(S||(S={}));class W extends R{constructor(e={}){super({layout:I.createLayout(e)}),this.addClass("lm-BoxPanel")}get direction(){return this.layout.direction}set direction(e){this.layout.direction=e}get alignment(){return this.layout.alignment}set alignment(e){this.layout.alignment=e}get spacing(){return this.layout.spacing}set spacing(e){this.layout.spacing=e}onChildAdded(e){e.child.addClass("lm-BoxPanel-child")}onChildRemoved(e){e.child.removeClass("lm-BoxPanel-child")}}!function(e){e.getStretch=function(e){return P.getStretch(e)},e.setStretch=function(e,t){P.setStretch(e,t)},e.getSizeBasis=function(e){return P.getSizeBasis(e)},e.setSizeBasis=function(e,t){P.setSizeBasis(e,t)}}(W||(W={})),function(e){e.createLayout=function(e){return e.layout||new P(e)}}(I||(I={}));class q extends b{constructor(e){super({node:z.createNode()}),this._activeIndex=-1,this._items=[],this._results=null,this.addClass("lm-CommandPalette"),this.setFlag(b.Flag.DisallowLayout),this.commands=e.commands,this.renderer=e.renderer||q.defaultRenderer,this.commands.commandChanged.connect(this._onGenericChange,this),this.commands.keyBindingChanged.connect(this._onGenericChange,this)}dispose(){this._items.length=0,this._results=null,super.dispose()}get searchNode(){return this.node.getElementsByClassName("lm-CommandPalette-search")[0]}get inputNode(){return this.node.getElementsByClassName("lm-CommandPalette-input")[0]}get contentNode(){return this.node.getElementsByClassName("lm-CommandPalette-content")[0]}get items(){return this._items}addItem(e){let t=z.createItem(this.commands,e);return this._items.push(t),this.refresh(),t}addItems(e){const t=e.map((e=>z.createItem(this.commands,e)));return t.forEach((e=>this._items.push(e))),this.refresh(),t}removeItem(e){this.removeItemAt(this._items.indexOf(e))}removeItemAt(e){t.ArrayExt.removeAt(this._items,e)&&this.refresh()}clearItems(){0!==this._items.length&&(this._items.length=0,this.refresh())}refresh(){if(this._results=null,""!==this.inputNode.value){this.node.getElementsByClassName("lm-close-icon")[0].style.display="inherit"}else{this.node.getElementsByClassName("lm-close-icon")[0].style.display="none"}this.update()}handleEvent(e){switch(e.type){case"click":this._evtClick(e);break;case"keydown":this._evtKeyDown(e);break;case"input":this.refresh();break;case"focus":case"blur":this._toggleFocused()}}onBeforeAttach(e){this.node.addEventListener("click",this),this.node.addEventListener("keydown",this),this.node.addEventListener("input",this),this.node.addEventListener("focus",this,!0),this.node.addEventListener("blur",this,!0)}onAfterDetach(e){this.node.removeEventListener("click",this),this.node.removeEventListener("keydown",this),this.node.removeEventListener("input",this),this.node.removeEventListener("focus",this,!0),this.node.removeEventListener("blur",this,!0)}onAfterShow(e){this.update(),super.onAfterShow(e)}onActivateRequest(e){if(this.isAttached){let e=this.inputNode;e.focus(),e.select()}}onUpdateRequest(e){if(this.isHidden)return;let i=this.inputNode.value,n=this.contentNode,a=this._results;if(a||(a=this._results=z.search(this._items,i),this._activeIndex=i?t.ArrayExt.findFirstIndex(a,z.canActivate):-1),!i&&0===a.length)return void d.VirtualDOM.render(null,n);if(i&&0===a.length){let e=this.renderer.renderEmptyMessage({query:i});return void d.VirtualDOM.render(e,n)}let r=this.renderer,o=this._activeIndex,h=new Array(a.length);for(let e=0,t=a.length;e=a.length)n.scrollTop=0;else{let e=n.children[o];s.ElementExt.scrollIntoViewIfNeeded(n,e)}}_evtClick(e){if(0!==e.button)return;if(e.target.classList.contains("lm-close-icon"))return this.inputNode.value="",void this.refresh();let i=t.ArrayExt.findFirstIndex(this.contentNode.children,(t=>t.contains(e.target)));-1!==i&&(e.preventDefault(),e.stopPropagation(),this._execute(i))}_evtKeyDown(e){if(!(e.altKey||e.ctrlKey||e.metaKey||e.shiftKey))switch(e.keyCode){case 13:e.preventDefault(),e.stopPropagation(),this._execute(this._activeIndex);break;case 38:e.preventDefault(),e.stopPropagation(),this._activatePreviousItem();break;case 40:e.preventDefault(),e.stopPropagation(),this._activateNextItem()}}_activateNextItem(){if(!this._results||0===this._results.length)return;let e=this._activeIndex,i=this._results.length,s=ee-t)),l=r.slice(0,d),c=r.slice(d);for(let e=0,t=c.length;et.command===e&&i.JSONExt.deepEqual(t.args,s)))||null}}}(z||(z={}));class F extends b{constructor(e){super({node:L.createNode()}),this._childIndex=-1,this._activeIndex=-1,this._openTimerID=0,this._closeTimerID=0,this._items=[],this._childMenu=null,this._parentMenu=null,this._aboutToClose=new r.Signal(this),this._menuRequested=new r.Signal(this),this.addClass("lm-Menu"),this.setFlag(b.Flag.DisallowLayout),this.commands=e.commands,this.renderer=e.renderer||F.defaultRenderer}dispose(){this.close(),this._items.length=0,super.dispose()}get aboutToClose(){return this._aboutToClose}get menuRequested(){return this._menuRequested}get parentMenu(){return this._parentMenu}get childMenu(){return this._childMenu}get rootMenu(){let e=this;for(;e._parentMenu;)e=e._parentMenu;return e}get leafMenu(){let e=this;for(;e._childMenu;)e=e._childMenu;return e}get contentNode(){return this.node.getElementsByClassName("lm-Menu-content")[0]}get activeItem(){return this._items[this._activeIndex]||null}set activeItem(e){this.activeIndex=e?this._items.indexOf(e):-1}get activeIndex(){return this._activeIndex}set activeIndex(e){(e<0||e>=this._items.length)&&(e=-1),-1===e||L.canActivate(this._items[e])||(e=-1),this._activeIndex!==e&&(this._activeIndex=e,this._activeIndex>=0&&this.contentNode.childNodes[this._activeIndex]&&this.contentNode.childNodes[this._activeIndex].focus(),this.update())}get items(){return this._items}activateNextItem(){let e=this._items.length,i=this._activeIndex,s=i{this.activeIndex=e}})}d.VirtualDOM.render(a,this.contentNode)}onCloseRequest(e){this._cancelOpenTimer(),this._cancelCloseTimer(),this.activeIndex=-1;let t=this._childMenu;t&&(this._childIndex=-1,this._childMenu=null,t._parentMenu=null,t.close());let i=this._parentMenu;i&&(this._parentMenu=null,i._childIndex=-1,i._childMenu=null,i.activate()),this.isAttached&&this._aboutToClose.emit(void 0),super.onCloseRequest(e)}_evtKeyDown(e){e.preventDefault(),e.stopPropagation();let t=e.keyCode;if(13===t)return void this.triggerActiveItem();if(27===t)return void this.close();if(37===t)return void(this._parentMenu?this.close():this._menuRequested.emit("previous"));if(38===t)return void this.activatePreviousItem();if(39===t){let e=this.activeItem;return void(e&&"submenu"===e.type?this.triggerActiveItem():this.rootMenu._menuRequested.emit("next"))}if(40===t)return void this.activateNextItem();let i=c.getKeyboardLayout().keyForKeydownEvent(e);if(!i)return;let s=this._activeIndex+1,n=L.findMnemonic(this._items,i,s);-1===n.index||n.multiple?-1!==n.index?this.activeIndex=n.index:-1!==n.auto&&(this.activeIndex=n.auto):(this.activeIndex=n.index,this.triggerActiveItem())}_evtMouseUp(e){0===e.button&&(e.preventDefault(),e.stopPropagation(),this.triggerActiveItem())}_evtMouseMove(e){let i=t.ArrayExt.findFirstIndex(this.contentNode.children,(t=>s.ElementExt.hitTest(t,e.clientX,e.clientY)));if(i===this._activeIndex)return;if(this.activeIndex=i,i=this.activeIndex,i===this._childIndex)return this._cancelOpenTimer(),void this._cancelCloseTimer();-1!==this._childIndex&&this._startCloseTimer(),this._cancelOpenTimer();let n=this.activeItem;n&&"submenu"===n.type&&n.submenu&&this._startOpenTimer()}_evtMouseEnter(e){for(let e=this._parentMenu;e;e=e._parentMenu)e._cancelOpenTimer(),e._cancelCloseTimer(),e.activeIndex=e._childIndex}_evtMouseLeave(e){if(this._cancelOpenTimer(),!this._childMenu)return void(this.activeIndex=-1);let{clientX:t,clientY:i}=e;s.ElementExt.hitTest(this._childMenu.node,t,i)?this._cancelCloseTimer():(this.activeIndex=-1,this._startCloseTimer())}_evtMouseDown(e){this._parentMenu||(L.hitTestMenus(this,e.clientX,e.clientY)?(e.preventDefault(),e.stopPropagation()):this.close())}_openChildMenu(e=!1){let t=this.activeItem;if(!t||"submenu"!==t.type||!t.submenu)return void this._closeChildMenu();let i=t.submenu;if(i===this._childMenu)return;F.saveWindowData(),this._closeChildMenu(),this._childMenu=i,this._childIndex=this._activeIndex,i._parentMenu=this,n.MessageLoop.sendMessage(this,b.Msg.UpdateRequest);let s=this.contentNode.children[this._activeIndex];L.openSubmenu(i,s),e&&(i.activeIndex=-1,i.activateNextItem()),i.activate()}_closeChildMenu(){this._childMenu&&this._childMenu.close()}_startOpenTimer(){0===this._openTimerID&&(this._openTimerID=window.setTimeout((()=>{this._openTimerID=0,this._openChildMenu()}),L.TIMER_DELAY))}_startCloseTimer(){0===this._closeTimerID&&(this._closeTimerID=window.setTimeout((()=>{this._closeTimerID=0,this._closeChildMenu()}),L.TIMER_DELAY))}_cancelOpenTimer(){0!==this._openTimerID&&(clearTimeout(this._openTimerID),this._openTimerID=0)}_cancelCloseTimer(){0!==this._closeTimerID&&(clearTimeout(this._closeTimerID),this._closeTimerID=0)}static saveWindowData(){L.saveWindowData()}}!function(e){class t{renderItem(e){let t=this.createItemClass(e),i=this.createItemDataset(e),s=this.createItemARIA(e);return d.h.li({className:t,dataset:i,tabindex:"0",onfocus:e.onfocus,...s},this.renderIcon(e),this.renderLabel(e),this.renderShortcut(e),this.renderSubmenu(e))}renderIcon(e){let t=this.createIconClass(e);return d.h.div({className:t},e.item.icon,e.item.iconLabel)}renderLabel(e){let t=this.formatLabel(e);return d.h.div({className:"lm-Menu-itemLabel"},t)}renderShortcut(e){let t=this.formatShortcut(e);return d.h.div({className:"lm-Menu-itemShortcut"},t)}renderSubmenu(e){return d.h.div({className:"lm-Menu-itemSubmenuIcon"})}createItemClass(e){let t="lm-Menu-item";e.item.isEnabled||(t+=" lm-mod-disabled"),e.item.isToggled&&(t+=" lm-mod-toggled"),e.item.isVisible||(t+=" lm-mod-hidden"),e.active&&(t+=" lm-mod-active"),e.collapsed&&(t+=" lm-mod-collapsed");let i=e.item.className;return i&&(t+=` ${i}`),t}createItemDataset(e){let t,{type:i,command:s,dataset:n}=e.item;return t="command"===i?{...n,type:i,command:s}:{...n,type:i},t}createIconClass(e){let t="lm-Menu-itemIcon",i=e.item.iconClass;return i?`${t} ${i}`:t}createItemARIA(e){let t={};switch(e.item.type){case"separator":t.role="presentation";break;case"submenu":t["aria-haspopup"]="true",e.item.isEnabled||(t["aria-disabled"]="true");break;default:e.item.isEnabled||(t["aria-disabled"]="true"),t.role="menuitem"}return t}formatLabel(e){let{label:t,mnemonic:i}=e.item;if(i<0||i>=t.length)return t;let s=t.slice(0,i),n=t.slice(i+1),a=t[i];return[s,d.h.span({className:"lm-Menu-itemMnemonic"},a),n]}formatShortcut(e){let t=e.item.keyBinding;return t?h.CommandRegistry.formatKeystroke(t.keys):null}}e.Renderer=t,e.defaultRenderer=new t}(F||(F={})),function(e){e.TIMER_DELAY=300,e.SUBMENU_OVERLAP=3;let a=null,r=0;function o(){return r>0?(r--,a):d()}function h(e){return"separator"!==e.type&&e.isEnabled&&e.isVisible}function d(){return{pageXOffset:window.pageXOffset,pageYOffset:window.pageYOffset,clientWidth:document.documentElement.clientWidth,clientHeight:document.documentElement.clientHeight}}e.saveWindowData=function(){a=d(),r++},e.createNode=function(){let e=document.createElement("div"),t=document.createElement("ul");return t.className="lm-Menu-content",e.appendChild(t),t.setAttribute("role","menu"),e.tabIndex=0,e},e.canActivate=h,e.createItem=function(e,t){return new l(e.commands,t)},e.hitTestMenus=function(e,t,i){for(let n=e;n;n=n.childMenu)if(s.ElementExt.hitTest(n.node,t,i))return!0;return!1},e.computeCollapsed=function(e){let i=new Array(e.length);t.ArrayExt.fill(i,!1);let s=0,n=e.length;for(;s=0;--a){let t=e[a];if(t.isVisible){if("separator"!==t.type)break;i[a]=!0}}let r=!1;for(;++sl+u&&(t=l+u-f),!a&&i+v>c+m&&(i>c+m?i=c+m-v:i-=v),_.transform=`translate(${Math.max(0,t)}px, ${Math.max(0,i)}px`,_.opacity="1"},e.openSubmenu=function(t,i){const a=o();let r=a.pageXOffset,h=a.pageYOffset,d=a.clientWidth,l=a.clientHeight;n.MessageLoop.sendMessage(t,b.Msg.UpdateRequest);let c=l,u=t.node,m=u.style;m.opacity="0",m.maxHeight=`${c}px`,b.attach(t,i.ownerDocument.body);let{width:g,height:p}=u.getBoundingClientRect(),_=s.ElementExt.boxSizing(t.node),f=i.getBoundingClientRect(),v=f.right-e.SUBMENU_OVERLAP;v+g>r+d&&(v=f.left+e.SUBMENU_OVERLAP-g);let x=f.top-_.borderTop-_.paddingTop;x+p>h+l&&(x=f.bottom+_.borderBottom+_.paddingBottom-p),m.transform=`translate(${Math.max(0,v)}px, ${Math.max(0,x)}px`,m.opacity="1"},e.findMnemonic=function(e,t,i){let s=-1,n=-1,a=!1,r=t.toUpperCase();for(let t=0,o=e.length;t=0&&ut.command===e&&i.JSONExt.deepEqual(t.args,s)))||null}return null}}}(L||(L={}));!function(e){function t(e,t){let i=e.rank,s=t.rank;return i!==s?i=this._titles.length)&&(e=-1),this._currentIndex===e)return;let t=this._currentIndex,i=this._titles[t]||null,s=e,n=this._titles[s]||null;this._currentIndex=s,this._previousTitle=i,this.update(),this._currentChanged.emit({previousIndex:t,previousTitle:i,currentIndex:s,currentTitle:n})}get name(){return this._name}set name(e){this._name=e,e?this.contentNode.setAttribute("aria-label",e):this.contentNode.removeAttribute("aria-label")}get orientation(){return this._orientation}set orientation(e){this._orientation!==e&&(this._releaseMouse(),this._orientation=e,this.dataset.orientation=e,this.contentNode.setAttribute("aria-orientation",e))}get addButtonEnabled(){return this._addButtonEnabled}set addButtonEnabled(e){this._addButtonEnabled!==e&&(this._addButtonEnabled=e,e?this.addButtonNode.classList.remove("lm-mod-hidden"):this.addButtonNode.classList.add("lm-mod-hidden"))}get titles(){return this._titles}get contentNode(){return this.node.getElementsByClassName("lm-TabBar-content")[0]}get addButtonNode(){return this.node.getElementsByClassName("lm-TabBar-addButton")[0]}addTab(e){return this.insertTab(this._titles.length,e)}insertTab(e,i){this._releaseMouse();let s=V.asTitle(i),n=this._titles.indexOf(s),a=Math.max(0,Math.min(e,this._titles.length));return-1===n?(t.ArrayExt.insert(this._titles,a,s),s.changed.connect(this._onTitleChanged,this),this.update(),this._adjustCurrentForInsert(a,s),s):(a===this._titles.length&&a--,n===a||(t.ArrayExt.move(this._titles,n,a),this.update(),this._adjustCurrentForMove(n,a)),s)}removeTab(e){this.removeTabAt(this._titles.indexOf(e))}removeTabAt(e){this._releaseMouse();let i=t.ArrayExt.removeAt(this._titles,e);i&&(i.changed.disconnect(this._onTitleChanged,this),i===this._previousTitle&&(this._previousTitle=null),this.update(),this._adjustCurrentForRemove(e,i))}clearTabs(){if(0===this._titles.length)return;this._releaseMouse();for(let e of this._titles)e.changed.disconnect(this._onTitleChanged,this);let e=this.currentIndex,t=this.currentTitle;this._currentIndex=-1,this._previousTitle=null,this._titles.length=0,this.update(),-1!==e&&this._currentChanged.emit({previousIndex:e,previousTitle:t,currentIndex:-1,currentTitle:null})}releaseMouse(){this._releaseMouse()}handleEvent(e){switch(e.type){case"pointerdown":this._evtPointerDown(e);break;case"pointermove":this._evtPointerMove(e);break;case"pointerup":this._evtPointerUp(e);break;case"dblclick":this._evtDblClick(e);break;case"keydown":e.eventPhase===Event.CAPTURING_PHASE?this._evtKeyDownCapturing(e):this._evtKeyDown(e);break;case"contextmenu":e.preventDefault(),e.stopPropagation()}}onBeforeAttach(e){this.node.addEventListener("pointerdown",this),this.node.addEventListener("dblclick",this),this.node.addEventListener("keydown",this)}onAfterDetach(e){this.node.removeEventListener("pointerdown",this),this.node.removeEventListener("dblclick",this),this.node.removeEventListener("keydown",this),this._releaseMouse()}onUpdateRequest(e){var t;let i=this._titles,s=this.renderer,n=this.currentTitle,a=new Array(i.length);const r=null!==(t=this._getCurrentTabindex())&&void 0!==t?t:this._currentIndex>-1?this._currentIndex:0;for(let e=0,t=i.length;es.ElementExt.hitTest(t,e.clientX,e.clientY)));if(-1===n)return;let a=this.titles[n],r=i[n].querySelector(".lm-TabBar-tabLabel");if(r&&r.contains(e.target)){let e=a.label||"",t=r.innerHTML;r.innerHTML="";let i=document.createElement("input");i.classList.add("lm-TabBar-tabInput"),i.value=e,r.appendChild(i);let s=()=>{i.removeEventListener("blur",s),r.innerHTML=t,this.node.addEventListener("keydown",this)};i.addEventListener("dblclick",(e=>e.stopPropagation())),i.addEventListener("blur",s),i.addEventListener("keydown",(e=>{"Enter"===e.key?(""!==i.value&&(a.label=a.caption=i.value),s()):"Escape"===e.key&&s()})),this.node.removeEventListener("keydown",this),i.select(),i.focus(),r.children.length>0&&r.children[0].focus()}}_evtKeyDownCapturing(e){e.eventPhase===Event.CAPTURING_PHASE&&(e.preventDefault(),e.stopPropagation(),"Escape"===e.key&&this._releaseMouse())}_evtKeyDown(e){var i,s,n;if("Tab"!==e.key&&e.eventPhase!==Event.CAPTURING_PHASE)if("Enter"===e.key||"Spacebar"===e.key||" "===e.key){const i=document.activeElement;if(this.addButtonEnabled&&this.addButtonNode.contains(i))e.preventDefault(),e.stopPropagation(),this._addRequested.emit();else{const s=t.ArrayExt.findFirstIndex(this.contentNode.children,(e=>e.contains(i)));s>=0&&(e.preventDefault(),e.stopPropagation(),this.currentIndex=s)}}else if(O.includes(e.key)){const t=[...this.contentNode.children];if(this.addButtonEnabled&&t.push(this.addButtonNode),t.length<=1)return;e.preventDefault(),e.stopPropagation();let a,r=t.indexOf(document.activeElement);-1===r&&(r=this._currentIndex),"ArrowRight"===e.key&&"horizontal"===this._orientation||"ArrowDown"===e.key&&"vertical"===this._orientation?a=null!==(i=t[r+1])&&void 0!==i?i:t[0]:"ArrowLeft"===e.key&&"horizontal"===this._orientation||"ArrowUp"===e.key&&"vertical"===this._orientation?a=null!==(s=t[r-1])&&void 0!==s?s:t[t.length-1]:"Home"===e.key?a=t[0]:"End"===e.key&&(a=t[t.length-1]),a&&(null===(n=t[r])||void 0===n||n.setAttribute("tabindex","-1"),null==a||a.setAttribute("tabindex","0"),a.focus())}}_evtPointerDown(e){if(0!==e.button&&1!==e.button)return;if(this._dragData)return;if(e.target.classList.contains("lm-TabBar-tabInput"))return;let i=this.addButtonEnabled&&this.addButtonNode.contains(e.target),n=this.contentNode.children,a=t.ArrayExt.findFirstIndex(n,(t=>s.ElementExt.hitTest(t,e.clientX,e.clientY)));if(-1===a&&!i)return;if(e.preventDefault(),e.stopPropagation(),this._dragData={tab:n[a],index:a,pressX:e.clientX,pressY:e.clientY,tabPos:-1,tabSize:-1,tabPressPos:-1,targetIndex:-1,tabLayout:null,contentRect:null,override:null,dragActive:!1,dragAborted:!1,detachRequested:!1},this.document.addEventListener("pointerup",this,!0),1===e.button||i)return;let r=n[a].querySelector(this.renderer.closeIconSelector);r&&r.contains(e.target)||(this.tabsMovable&&(this.document.addEventListener("pointermove",this,!0),this.document.addEventListener("keydown",this,!0),this.document.addEventListener("contextmenu",this,!0)),this.allowDeselect&&this.currentIndex===a?this.currentIndex=-1:this.currentIndex=a,-1!==this.currentIndex&&this._tabActivateRequested.emit({index:this.currentIndex,title:this.currentTitle}))}_evtPointerMove(e){let t=this._dragData;if(!t)return;e.preventDefault(),e.stopPropagation();let i=this.contentNode.children;if(t.dragActive||V.dragExceeded(t,e)){if(!t.dragActive){let e=t.tab.getBoundingClientRect();"horizontal"===this._orientation?(t.tabPos=t.tab.offsetLeft,t.tabSize=e.width,t.tabPressPos=t.pressX-e.left):(t.tabPos=t.tab.offsetTop,t.tabSize=e.height,t.tabPressPos=t.pressY-e.top),t.tabPressOffset={x:t.pressX-e.left,y:t.pressY-e.top},t.tabLayout=V.snapTabLayout(i,this._orientation),t.contentRect=this.contentNode.getBoundingClientRect(),t.override=o.Drag.overrideCursor("default"),t.tab.classList.add("lm-mod-dragging"),this.addClass("lm-mod-dragging"),t.dragActive=!0}if(!t.detachRequested&&V.detachExceeded(t,e)){t.detachRequested=!0;let s=t.index,n=e.clientX,a=e.clientY,r=i[s],o=this._titles[s];if(this._tabDetachRequested.emit({index:s,title:o,tab:r,clientX:n,clientY:a,offset:t.tabPressOffset}),t.dragAborted)return}V.layoutTabs(i,t,e,this._orientation)}}_evtPointerUp(e){if(0!==e.button&&1!==e.button)return;const i=this._dragData;if(!i)return;if(e.preventDefault(),e.stopPropagation(),this.document.removeEventListener("pointermove",this,!0),this.document.removeEventListener("pointerup",this,!0),this.document.removeEventListener("keydown",this,!0),this.document.removeEventListener("contextmenu",this,!0),!i.dragActive){if(this._dragData=null,this.addButtonEnabled&&this.addButtonNode.contains(e.target))return void this._addRequested.emit(void 0);let n=this.contentNode.children,a=t.ArrayExt.findFirstIndex(n,(t=>s.ElementExt.hitTest(t,e.clientX,e.clientY)));if(a!==i.index)return;let r=this._titles[a];if(!r.closable)return;if(1===e.button)return void this._tabCloseRequested.emit({index:a,title:r});let o=n[a].querySelector(this.renderer.closeIconSelector);return o&&o.contains(e.target)?void this._tabCloseRequested.emit({index:a,title:r}):void 0}if(0!==e.button)return;V.finalizeTabPosition(i,this._orientation),i.tab.classList.remove("lm-mod-dragging");let a=V.parseTransitionDuration(i.tab);setTimeout((()=>{if(i.dragAborted)return;this._dragData=null,V.resetTabPositions(this.contentNode.children,this._orientation),i.override.dispose(),this.removeClass("lm-mod-dragging");let e=i.index,s=i.targetIndex;-1!==s&&e!==s&&(t.ArrayExt.move(this._titles,e,s),this._adjustCurrentForMove(e,s),this._tabMoved.emit({fromIndex:e,toIndex:s,title:this._titles[s]}),n.MessageLoop.sendMessage(this,b.Msg.UpdateRequest))}),a)}_releaseMouse(){let e=this._dragData;e&&(this._dragData=null,this.document.removeEventListener("pointermove",this,!0),this.document.removeEventListener("pointerup",this,!0),this.document.removeEventListener("keydown",this,!0),this.document.removeEventListener("contextmenu",this,!0),e.dragAborted=!0,e.dragActive&&(V.resetTabPositions(this.contentNode.children,this._orientation),e.override.dispose(),e.tab.classList.remove("lm-mod-dragging"),this.removeClass("lm-mod-dragging")))}_adjustCurrentForInsert(e,t){let i=this.currentTitle,s=this._currentIndex,n=this.insertBehavior;if("select-tab"===n||"select-tab-if-needed"===n&&-1===s)return this._currentIndex=e,this._previousTitle=i,void this._currentChanged.emit({previousIndex:s,previousTitle:i,currentIndex:e,currentTitle:t});s>=e&&this._currentIndex++}_adjustCurrentForMove(e,t){this._currentIndex===e?this._currentIndex=t:this._currentIndex=t?this._currentIndex++:this._currentIndex>e&&this._currentIndex<=t&&this._currentIndex--}_adjustCurrentForRemove(e,t){let i=this._currentIndex,s=this.removeBehavior;if(i===e){if(0===this._titles.length)return this._currentIndex=-1,void this._currentChanged.emit({previousIndex:e,previousTitle:t,currentIndex:-1,currentTitle:null});if("select-tab-after"===s)return this._currentIndex=Math.min(e,this._titles.length-1),void this._currentChanged.emit({previousIndex:e,previousTitle:t,currentIndex:this._currentIndex,currentTitle:this.currentTitle});if("select-tab-before"===s)return this._currentIndex=Math.max(0,e-1),void this._currentChanged.emit({previousIndex:e,previousTitle:t,currentIndex:this._currentIndex,currentTitle:this.currentTitle});if("select-previous-tab"===s)return this._previousTitle?(this._currentIndex=this._titles.indexOf(this._previousTitle),this._previousTitle=null):this._currentIndex=Math.min(e,this._titles.length-1),void this._currentChanged.emit({previousIndex:e,previousTitle:t,currentIndex:this._currentIndex,currentTitle:this.currentTitle});this._currentIndex=-1,this._currentChanged.emit({previousIndex:e,previousTitle:t,currentIndex:-1,currentTitle:null})}else i>e&&this._currentIndex--}_onTitleChanged(e){this.update()}}var V,U,Y,X,K,G,j,J;!function(e){class t{constructor(){this.closeIconSelector=".lm-TabBar-tabCloseIcon",this._tabID=0,this._tabKeys=new WeakMap,this._uuid=++t._nInstance}renderTab(e){let t=e.title.caption,i=this.createTabKey(e),s=i,n=this.createTabStyle(e),a=this.createTabClass(e),r=this.createTabDataset(e),o=this.createTabARIA(e);return e.title.closable?d.h.li({id:s,key:i,className:a,title:t,style:n,dataset:r,...o},this.renderIcon(e),this.renderLabel(e),this.renderCloseIcon(e)):d.h.li({id:s,key:i,className:a,title:t,style:n,dataset:r,...o},this.renderIcon(e),this.renderLabel(e))}renderIcon(e){const{title:t}=e;let i=this.createIconClass(e);return d.h.div({className:i},t.icon,t.iconLabel)}renderLabel(e){return d.h.div({className:"lm-TabBar-tabLabel"},e.title.label)}renderCloseIcon(e){return d.h.div({className:"lm-TabBar-tabCloseIcon"})}createTabKey(e){let t=this._tabKeys.get(e.title);return void 0===t&&(t=`tab-key-${this._uuid}-${this._tabID++}`,this._tabKeys.set(e.title,t)),t}createTabStyle(e){return{zIndex:`${e.zIndex}`}}createTabClass(e){let t="lm-TabBar-tab";return e.title.className&&(t+=` ${e.title.className}`),e.title.closable&&(t+=" lm-mod-closable"),e.current&&(t+=" lm-mod-current"),t}createTabDataset(e){return e.title.dataset}createTabARIA(e){var t;return{role:"tab","aria-selected":e.current.toString(),tabindex:`${null!==(t=e.tabIndex)&&void 0!==t?t:"-1"}`}}createIconClass(e){let t="lm-TabBar-tabIcon",i=e.title.iconClass;return i?`${t} ${i}`:t}}t._nInstance=0,e.Renderer=t,e.defaultRenderer=new t,e.addButtonSelector=".lm-TabBar-addButton"}($||($={})),function(e){e.DRAG_THRESHOLD=5,e.DETACH_THRESHOLD=20,e.createNode=function(){let e=document.createElement("div"),t=document.createElement("ul");t.setAttribute("role","tablist"),t.className="lm-TabBar-content",e.appendChild(t);let i=document.createElement("div");return i.className="lm-TabBar-addButton lm-mod-hidden",i.setAttribute("tabindex","-1"),i.setAttribute("role","button"),e.appendChild(i),e},e.asTitle=function(e){return e instanceof f?e:new f(e)},e.parseTransitionDuration=function(e){let t=window.getComputedStyle(e);return 1e3*(parseFloat(t.transitionDuration)||0)},e.snapTabLayout=function(e,t){let i=new Array(e.length);for(let s=0,n=e.length;s=e.DRAG_THRESHOLD||n>=e.DRAG_THRESHOLD},e.detachExceeded=function(t,i){let s=t.contentRect;return i.clientX=s.right+e.DETACH_THRESHOLD||i.clientY=s.bottom+e.DETACH_THRESHOLD},e.layoutTabs=function(e,t,i,s){let n,a,r,o;"horizontal"===s?(n=t.pressX,a=i.clientX-t.contentRect.left,r=i.clientX,o=t.contentRect.width):(n=t.pressY,a=i.clientY-t.contentRect.top,r=i.clientY,o=t.contentRect.height);let h=t.index,d=a-t.tabPressPos,l=d+t.tabSize;for(let i=0,a=e.length;i>1);if(it.index&&l>u)a=-t.tabSize-c.margin+"px",h=Math.max(h,i);else if(i===t.index){let e=r-n,i=o-(t.tabPos+t.tabSize);a=`${Math.max(-t.tabPos,Math.min(e,i))}px`}else a="";"horizontal"===s?e[i].style.left=a:e[i].style.top=a}t.targetIndex=h},e.finalizeTabPosition=function(e,t){let i,s;if(i="horizontal"===t?e.contentRect.width:e.contentRect.height,e.targetIndex===e.index)s=0;else if(e.targetIndex>e.index){let t=e.tabLayout[e.targetIndex];s=t.pos+t.size-e.tabSize-e.tabPos}else{s=e.tabLayout[e.targetIndex].pos-e.tabPos}let n=i-(e.tabPos+e.tabSize),a=Math.max(-e.tabPos,Math.min(s,n));"horizontal"===t?e.tab.style.left=`${a}px`:e.tab.style.top=`${a}px`},e.resetTabPositions=function(e,t){for(const i of e)"horizontal"===t?i.style.left="":i.style.top=""}}(V||(V={}));class Q extends v{constructor(e){super(),this._spacing=4,this._dirty=!1,this._root=null,this._box=null,this._items=new Map,this.renderer=e.renderer,void 0!==e.spacing&&(this._spacing=D.clampDimension(e.spacing)),this._document=e.document||document,this._hiddenMode=void 0!==e.hiddenMode?e.hiddenMode:b.HiddenMode.Display}dispose(){let e=this[Symbol.iterator]();this._items.forEach((e=>{e.dispose()})),this._box=null,this._root=null,this._items.clear();for(const t of e)t.dispose();super.dispose()}get hiddenMode(){return this._hiddenMode}set hiddenMode(e){if(this._hiddenMode!==e){this._hiddenMode=e;for(const e of this.tabBars())if(e.titles.length>1)for(const t of e.titles)t.owner.hiddenMode=this._hiddenMode}}get spacing(){return this._spacing}set spacing(e){e=D.clampDimension(e),this._spacing!==e&&(this._spacing=e,this.parent&&this.parent.fit())}get isEmpty(){return null===this._root}[Symbol.iterator](){return this._root?this._root.iterAllWidgets():t.empty()}widgets(){return this._root?this._root.iterUserWidgets():t.empty()}selectedWidgets(){return this._root?this._root.iterSelectedWidgets():t.empty()}tabBars(){return this._root?this._root.iterTabBars():t.empty()}handles(){return this._root?this._root.iterHandles():t.empty()}moveHandle(t,i,s){let n=t.classList.contains("lm-mod-hidden");if(!this._root||n)return;let a,r=this._root.findSplitNode(t);r&&(a="horizontal"===r.node.orientation?i-t.offsetLeft:s-t.offsetTop,0!==a&&(r.node.holdSizes(),e.BoxEngine.adjust(r.node.sizers,r.index,a),this.parent&&this.parent.update()))}saveLayout(){return this._root?(this._root.holdAllSizes(),{main:this._root.createConfig()}):{main:null}}restoreLayout(e){let t,i=new Set;t=e.main?U.normalizeAreaConfig(e.main,i):null;let s=this.widgets(),n=this.tabBars(),a=this.handles();this._root=null;for(const e of s)i.has(e)||(e.parent=null);for(const e of n)e.dispose();for(const e of a)e.parentNode&&e.parentNode.removeChild(e);for(const e of i)e.parent=this.parent;this._root=t?U.realizeAreaConfig(t,{createTabBar:e=>this._createTabBar(),createHandle:()=>this._createHandle()},this._document):null,this.parent&&(i.forEach((e=>{this.attachWidget(e)})),this.parent.fit())}addWidget(e,t={}){let i=t.ref||null,s=t.mode||"tab-after",n=null;if(this._root&&i&&(n=this._root.findTabNode(i)),i&&!n)throw new Error("Reference widget is not in the layout.");switch(e.parent=this.parent,s){case"tab-after":this._insertTab(e,i,n,!0);break;case"tab-before":this._insertTab(e,i,n,!1);break;case"split-top":this._insertSplit(e,i,n,"vertical",!1);break;case"split-left":this._insertSplit(e,i,n,"horizontal",!1);break;case"split-right":this._insertSplit(e,i,n,"horizontal",!0);break;case"split-bottom":this._insertSplit(e,i,n,"vertical",!0);break;case"merge-top":this._insertSplit(e,i,n,"vertical",!1,!0);break;case"merge-left":this._insertSplit(e,i,n,"horizontal",!1,!0);break;case"merge-right":this._insertSplit(e,i,n,"horizontal",!0,!0);break;case"merge-bottom":this._insertSplit(e,i,n,"vertical",!0,!0)}this.parent&&(this.attachWidget(e),this.parent.fit())}removeWidget(e){this._removeWidget(e),this.parent&&(this.detachWidget(e),this.parent.fit())}hitTestTabAreas(e,t){if(!this._root||!this.parent||!this.parent.isVisible)return null;this._box||(this._box=s.ElementExt.boxSizing(this.parent.node));let i=this.parent.node.getBoundingClientRect(),n=e-i.left-this._box.borderLeft,a=t-i.top-this._box.borderTop,r=this._root.hitTestTabNodes(n,a);if(!r)return null;let{tabBar:o,top:h,left:d,width:l,height:c}=r,u=this._box.borderLeft+this._box.borderRight,m=this._box.borderTop+this._box.borderBottom;return{tabBar:o,x:n,y:a,top:h,left:d,right:i.width-u-(d+l),bottom:i.height-m-(h+c),width:l,height:c}}init(){super.init();for(const e of this)this.attachWidget(e);for(const e of this.handles())this.parent.node.appendChild(e);this.parent.fit()}attachWidget(e){this.parent.node!==e.node.parentNode&&(this._items.set(e,new x(e)),this.parent.isAttached&&n.MessageLoop.sendMessage(e,b.Msg.BeforeAttach),this.parent.node.appendChild(e.node),this.parent.isAttached&&n.MessageLoop.sendMessage(e,b.Msg.AfterAttach))}detachWidget(e){if(this.parent.node!==e.node.parentNode)return;this.parent.isAttached&&n.MessageLoop.sendMessage(e,b.Msg.BeforeDetach),this.parent.node.removeChild(e.node),this.parent.isAttached&&n.MessageLoop.sendMessage(e,b.Msg.AfterDetach);let t=this._items.get(e);t&&(this._items.delete(e),t.dispose())}onBeforeShow(e){super.onBeforeShow(e),this.parent.update()}onBeforeAttach(e){super.onBeforeAttach(e),this.parent.fit()}onChildShown(e){this.parent.fit()}onChildHidden(e){this.parent.fit()}onResize(e){this.parent.isVisible&&this._update(e.width,e.height)}onUpdateRequest(e){this.parent.isVisible&&this._update(-1,-1)}onFitRequest(e){this.parent.isAttached&&this._fit()}_removeWidget(e){if(!this._root)return;let i=this._root.findTabNode(e);if(!i)return;if(U.removeAria(e),i.tabBar.titles.length>1){if(i.tabBar.removeTab(e.title),this._hiddenMode===b.HiddenMode.Scale&&1==i.tabBar.titles.length){i.tabBar.titles[0].owner.hiddenMode=b.HiddenMode.Display}return}if(i.tabBar.dispose(),this._root===i)return void(this._root=null);this._root.holdAllSizes();let s=i.parent;i.parent=null;let n=t.ArrayExt.removeFirstOf(s.children,i),a=t.ArrayExt.removeAt(s.handles,n);if(t.ArrayExt.removeAt(s.sizers,n),a.parentNode&&a.parentNode.removeChild(a),s.children.length>1)return void s.syncHandles();let r=s.parent;s.parent=null;let o=s.children[0],h=s.handles[0];if(s.children.length=0,s.handles.length=0,s.sizers.length=0,h.parentNode&&h.parentNode.removeChild(h),this._root===s)return o.parent=null,void(this._root=o);let d=r,l=d.children.indexOf(s);if(o instanceof U.TabLayoutNode)return o.parent=d,void(d.children[l]=o);let c=t.ArrayExt.removeAt(d.handles,l);t.ArrayExt.removeAt(d.children,l),t.ArrayExt.removeAt(d.sizers,l),c.parentNode&&c.parentNode.removeChild(c);for(let e=0,i=o.children.length;e=i.length)&&(s=0);return{type:"tab-area",widgets:i,currentIndex:s}}(e,t):function(e,t){let i=e.orientation,n=[],a=[];for(let r=0,o=e.children.length;r{let h=n(r,t,s),d=i(e.sizes[o]),l=t.createHandle();a.children.push(h),a.handles.push(l),a.sizers.push(d),h.parent=a})),a.syncHandles(),a.normalizeSizes(),a}(e,s,o),h}t.GOLDEN_RATIO=.618,t.createSizer=i,t.normalizeAreaConfig=s,t.realizeAreaConfig=n;class a{constructor(e){this.parent=null,this._top=0,this._left=0,this._width=0,this._height=0;let t=new u,i=new u;t.stretch=0,i.stretch=1,this.tabBar=e,this.sizers=[t,i]}get top(){return this._top}get left(){return this._left}get width(){return this._width}get height(){return this._height}*iterAllWidgets(){yield this.tabBar,yield*this.iterUserWidgets()}*iterUserWidgets(){for(const e of this.tabBar.titles)yield e.owner}*iterSelectedWidgets(){let e=this.tabBar.currentTitle;e&&(yield e.owner)}*iterTabBars(){yield this.tabBar}*iterHandles(){}findTabNode(e){return-1!==this.tabBar.titles.indexOf(e.title)?this:null}findSplitNode(e){return null}findFirstTabNode(){return this}hitTestTabNodes(e,t){return e=this._left+this._width||t=this._top+this._height?null:this}createConfig(){return{type:"tab-area",widgets:this.tabBar.titles.map((e=>e.owner)),currentIndex:this.tabBar.currentIndex}}holdAllSizes(){}fit(e,t){let i=0,s=0,n=t.get(this.tabBar),a=this.tabBar.currentTitle,r=a?t.get(a.owner):void 0,[o,h]=this.sizers;return n&&n.fit(),r&&r.fit(),n&&!n.isHidden?(i=Math.max(i,n.minWidth),s+=n.minHeight,o.minSize=n.minHeight,o.maxSize=n.maxHeight):(o.minSize=0,o.maxSize=0),r&&!r.isHidden?(i=Math.max(i,r.minWidth),s+=r.minHeight,h.minSize=r.minHeight,h.maxSize=1/0):(h.minSize=0,h.maxSize=1/0),{minWidth:i,minHeight:s,maxWidth:Infinity,maxHeight:Infinity}}update(t,i,s,n,a,r){this._top=i,this._left=t,this._width=s,this._height=n;let o=r.get(this.tabBar),h=this.tabBar.currentTitle,d=h?r.get(h.owner):void 0;if(e.BoxEngine.calc(this.sizers,n),o&&!o.isHidden){let e=this.sizers[0].size;o.update(t,i,s,e),i+=e}if(d&&!d.isHidden){let e=this.sizers[1].size;d.update(t,i,s,e)}}}t.TabLayoutNode=a;class r{constructor(e){this.parent=null,this.normalized=!1,this.children=[],this.sizers=[],this.handles=[],this.orientation=e}*iterAllWidgets(){for(const e of this.children)yield*e.iterAllWidgets()}*iterUserWidgets(){for(const e of this.children)yield*e.iterUserWidgets()}*iterSelectedWidgets(){for(const e of this.children)yield*e.iterSelectedWidgets()}*iterTabBars(){for(const e of this.children)yield*e.iterTabBars()}*iterHandles(){yield*this.handles;for(const e of this.children)yield*e.iterHandles()}findTabNode(e){for(let t=0,i=this.children.length;te.createConfig())),sizes:t}}syncHandles(){this.handles.forEach(((e,t)=>{e.setAttribute("data-orientation",this.orientation),t===this.handles.length-1?e.classList.add("lm-mod-hidden"):e.classList.remove("lm-mod-hidden")}))}holdSizes(){for(const e of this.sizers)e.sizeHint=e.size}holdAllSizes(){for(const e of this.children)e.holdAllSizes();this.holdSizes()}normalizeSizes(){let e=this.sizers.length;if(0===e)return;this.holdSizes();let t=this.sizers.reduce(((e,t)=>e+t.sizeHint),0);if(0===t)for(const t of this.sizers)t.size=t.sizeHint=1/e;else for(const e of this.sizers)e.size=e.sizeHint/=t;this.normalized=!0}createNormalizedSizes(){let e=this.sizers.length;if(0===e)return[];let t=this.sizers.map((e=>e.size)),i=t.reduce(((e,t)=>e+t),0);if(0===i)for(let i=t.length-1;i>-1;i--)t[i]=1/e;else for(let e=t.length-1;e>-1;e--)t[e]/=i;return t}fit(e,t){let i="horizontal"===this.orientation,s=Math.max(0,this.children.length-1)*e,n=i?s:0,a=i?0:s;for(let s=0,r=this.children.length;sthis._createTabBar(),createHandle:()=>this._createHandle()};this.layout=new Q({document:this._document,renderer:t,spacing:e.spacing,hiddenMode:e.hiddenMode}),this.overlay=e.overlay||new Z.Overlay,this.node.appendChild(this.overlay.node)}dispose(){this._releaseMouse(),this.overlay.hide(0),this._drag&&this._drag.dispose(),super.dispose()}get hiddenMode(){return this.layout.hiddenMode}set hiddenMode(e){this.layout.hiddenMode=e}get layoutModified(){return this._layoutModified}get addRequested(){return this._addRequested}get renderer(){return this.layout.renderer}get spacing(){return this.layout.spacing}set spacing(e){this.layout.spacing=e}get mode(){return this._mode}set mode(e){if(this._mode===e)return;this._mode=e,this.dataset.mode=e;let t=this.layout;switch(e){case"multiple-document":for(const e of t.tabBars())e.show();break;case"single-document":t.restoreLayout(Y.createSingleDocumentConfig(this));break;default:throw"unreachable"}n.MessageLoop.postMessage(this,Y.LayoutModified)}get tabsMovable(){return this._tabsMovable}set tabsMovable(e){this._tabsMovable=e;for(const t of this.tabBars())t.tabsMovable=e}get tabsConstrained(){return this._tabsConstrained}set tabsConstrained(e){this._tabsConstrained=e}get addButtonEnabled(){return this._addButtonEnabled}set addButtonEnabled(e){this._addButtonEnabled=e;for(const t of this.tabBars())t.addButtonEnabled=e}get isEmpty(){return this.layout.isEmpty}*widgets(){yield*this.layout.widgets()}*selectedWidgets(){yield*this.layout.selectedWidgets()}*tabBars(){yield*this.layout.tabBars()}*handles(){yield*this.layout.handles()}selectWidget(e){let i=t.find(this.tabBars(),(t=>-1!==t.titles.indexOf(e.title)));if(!i)throw new Error("Widget is not contained in the dock panel.");i.currentTitle=e.title}activateWidget(e){this.selectWidget(e),e.activate()}saveLayout(){return this.layout.saveLayout()}restoreLayout(e){this._mode="multiple-document",this.layout.restoreLayout(e),(s.Platform.IS_EDGE||s.Platform.IS_IE)&&n.MessageLoop.flush(),n.MessageLoop.postMessage(this,Y.LayoutModified)}addWidget(e,t={}){"single-document"===this._mode?this.layout.addWidget(e):this.layout.addWidget(e,t),n.MessageLoop.postMessage(this,Y.LayoutModified)}processMessage(e){"layout-modified"===e.type?this._layoutModified.emit(void 0):super.processMessage(e)}handleEvent(e){switch(e.type){case"lm-dragenter":this._evtDragEnter(e);break;case"lm-dragleave":this._evtDragLeave(e);break;case"lm-dragover":this._evtDragOver(e);break;case"lm-drop":this._evtDrop(e);break;case"pointerdown":this._evtPointerDown(e);break;case"pointermove":this._evtPointerMove(e);break;case"pointerup":this._evtPointerUp(e);break;case"keydown":this._evtKeyDown(e);break;case"contextmenu":e.preventDefault(),e.stopPropagation()}}onBeforeAttach(e){this.node.addEventListener("lm-dragenter",this),this.node.addEventListener("lm-dragleave",this),this.node.addEventListener("lm-dragover",this),this.node.addEventListener("lm-drop",this),this.node.addEventListener("pointerdown",this)}onAfterDetach(e){this.node.removeEventListener("lm-dragenter",this),this.node.removeEventListener("lm-dragleave",this),this.node.removeEventListener("lm-dragover",this),this.node.removeEventListener("lm-drop",this),this.node.removeEventListener("pointerdown",this),this._releaseMouse()}onChildAdded(e){Y.isGeneratedTabBarProperty.get(e.child)||e.child.addClass("lm-DockPanel-widget")}onChildRemoved(e){Y.isGeneratedTabBarProperty.get(e.child)||(e.child.removeClass("lm-DockPanel-widget"),n.MessageLoop.postMessage(this,Y.LayoutModified))}_evtDragEnter(e){e.mimeData.hasData("application/vnd.lumino.widget-factory")&&(e.preventDefault(),e.stopPropagation())}_evtDragLeave(e){e.preventDefault(),this._tabsConstrained&&e.source!==this||(e.stopPropagation(),this.overlay.hide(1))}_evtDragOver(e){e.preventDefault(),this._tabsConstrained&&e.source!==this||"invalid"===this._showOverlay(e.clientX,e.clientY)?e.dropAction="none":(e.stopPropagation(),e.dropAction=e.proposedAction)}_evtDrop(e){if(e.preventDefault(),this.overlay.hide(0),"none"===e.proposedAction)return void(e.dropAction="none");let{clientX:t,clientY:i}=e,{zone:s,target:n}=Y.findDropTarget(this,t,i,this._edges);if(this._tabsConstrained&&e.source!==this||"invalid"===s)return void(e.dropAction="none");let a=e.mimeData.getData("application/vnd.lumino.widget-factory");if("function"!=typeof a)return void(e.dropAction="none");let r=a();if(!(r instanceof b))return void(e.dropAction="none");if(r.contains(this))return void(e.dropAction="none");let o=n?Y.getDropRef(n.tabBar):null;switch(s){case"root-all":this.addWidget(r);break;case"root-top":this.addWidget(r,{mode:"split-top"});break;case"root-left":this.addWidget(r,{mode:"split-left"});break;case"root-right":this.addWidget(r,{mode:"split-right"});break;case"root-bottom":this.addWidget(r,{mode:"split-bottom"});break;case"widget-all":case"widget-tab":this.addWidget(r,{mode:"tab-after",ref:o});break;case"widget-top":this.addWidget(r,{mode:"split-top",ref:o});break;case"widget-left":this.addWidget(r,{mode:"split-left",ref:o});break;case"widget-right":this.addWidget(r,{mode:"split-right",ref:o});break;case"widget-bottom":this.addWidget(r,{mode:"split-bottom",ref:o});break;default:throw"unreachable"}e.dropAction=e.proposedAction,e.stopPropagation(),this.activateWidget(r)}_evtKeyDown(e){e.preventDefault(),e.stopPropagation(),27===e.keyCode&&(this._releaseMouse(),n.MessageLoop.postMessage(this,Y.LayoutModified))}_evtPointerDown(e){if(0!==e.button)return;let i=this.layout,s=e.target,n=t.find(i.handles(),(e=>e.contains(s)));if(!n)return;e.preventDefault(),e.stopPropagation(),this._document.addEventListener("keydown",this,!0),this._document.addEventListener("pointerup",this,!0),this._document.addEventListener("pointermove",this,!0),this._document.addEventListener("contextmenu",this,!0);let a=n.getBoundingClientRect(),r=e.clientX-a.left,h=e.clientY-a.top,d=window.getComputedStyle(n),l=o.Drag.overrideCursor(d.cursor,this._document);this._pressData={handle:n,deltaX:r,deltaY:h,override:l}}_evtPointerMove(e){if(!this._pressData)return;e.preventDefault(),e.stopPropagation();let t=this.node.getBoundingClientRect(),i=e.clientX-t.left-this._pressData.deltaX,s=e.clientY-t.top-this._pressData.deltaY;this.layout.moveHandle(this._pressData.handle,i,s)}_evtPointerUp(e){0===e.button&&(e.preventDefault(),e.stopPropagation(),this._releaseMouse(),n.MessageLoop.postMessage(this,Y.LayoutModified))}_releaseMouse(){this._pressData&&(this._pressData.override.dispose(),this._pressData=null,this._document.removeEventListener("keydown",this,!0),this._document.removeEventListener("pointerup",this,!0),this._document.removeEventListener("pointermove",this,!0),this._document.removeEventListener("contextmenu",this,!0))}_showOverlay(e,t){let i,n,a,r,{zone:o,target:h}=Y.findDropTarget(this,e,t,this._edges);if("invalid"===o)return this.overlay.hide(100),o;let d=s.ElementExt.boxSizing(this.node),l=this.node.getBoundingClientRect();switch(o){case"root-all":i=d.paddingTop,n=d.paddingLeft,a=d.paddingRight,r=d.paddingBottom;break;case"root-top":i=d.paddingTop,n=d.paddingLeft,a=d.paddingRight,r=l.height*Y.GOLDEN_RATIO;break;case"root-left":i=d.paddingTop,n=d.paddingLeft,a=l.width*Y.GOLDEN_RATIO,r=d.paddingBottom;break;case"root-right":i=d.paddingTop,n=l.width*Y.GOLDEN_RATIO,a=d.paddingRight,r=d.paddingBottom;break;case"root-bottom":i=l.height*Y.GOLDEN_RATIO,n=d.paddingLeft,a=d.paddingRight,r=d.paddingBottom;break;case"widget-all":i=h.top,n=h.left,a=h.right,r=h.bottom;break;case"widget-top":i=h.top,n=h.left,a=h.right,r=h.bottom+h.height/2;break;case"widget-left":i=h.top,n=h.left,a=h.right+h.width/2,r=h.bottom;break;case"widget-right":i=h.top,n=h.left+h.width/2,a=h.right,r=h.bottom;break;case"widget-bottom":i=h.top+h.height/2,n=h.left,a=h.right,r=h.bottom;break;case"widget-tab":{const e=h.tabBar.node.getBoundingClientRect().height;i=h.top,n=h.left,a=h.right,r=h.bottom+h.height-e;break}default:throw"unreachable"}return this.overlay.show({top:i,left:n,right:a,bottom:r}),o}_createTabBar(){let e=this._renderer.createTabBar(this._document);return Y.isGeneratedTabBarProperty.set(e,!0),"single-document"===this._mode&&e.hide(),e.tabsMovable=this._tabsMovable,e.allowDeselect=!1,e.addButtonEnabled=this._addButtonEnabled,e.removeBehavior="select-previous-tab",e.insertBehavior="select-tab-if-needed",e.tabMoved.connect(this._onTabMoved,this),e.currentChanged.connect(this._onCurrentChanged,this),e.tabCloseRequested.connect(this._onTabCloseRequested,this),e.tabDetachRequested.connect(this._onTabDetachRequested,this),e.tabActivateRequested.connect(this._onTabActivateRequested,this),e.addRequested.connect(this._onTabAddRequested,this),e}_createHandle(){return this._renderer.createHandle()}_onTabMoved(){n.MessageLoop.postMessage(this,Y.LayoutModified)}_onCurrentChanged(e,t){let{previousTitle:i,currentTitle:a}=t;i&&i.owner.hide(),a&&a.owner.show(),(s.Platform.IS_EDGE||s.Platform.IS_IE)&&n.MessageLoop.flush(),n.MessageLoop.postMessage(this,Y.LayoutModified)}_onTabAddRequested(e){this._addRequested.emit(e)}_onTabActivateRequested(e,t){t.title.owner.activate()}_onTabCloseRequested(e,t){t.title.owner.close()}_onTabDetachRequested(e,t){if(this._drag)return;e.releaseMouse();let{title:s,tab:n,clientX:a,clientY:r,offset:h}=t,d=new i.MimeData;d.setData("application/vnd.lumino.widget-factory",(()=>s.owner));let l=n.cloneNode(!0);h&&(l.style.top=`-${h.y}px`,l.style.left=`-${h.x}px`),this._drag=new o.Drag({document:this._document,mimeData:d,dragImage:l,proposedAction:"move",supportedActions:"move",source:this}),n.classList.add("lm-mod-hidden");this._drag.start(a,r).then((()=>{this._drag=null,n.classList.remove("lm-mod-hidden")}))}}!function(e){e.Overlay=class{constructor(){this._timer=-1,this._hidden=!0,this.node=document.createElement("div"),this.node.classList.add("lm-DockPanel-overlay"),this.node.classList.add("lm-mod-hidden"),this.node.style.position="absolute",this.node.style.contain="strict"}show(e){let t=this.node.style;t.top=`${e.top}px`,t.left=`${e.left}px`,t.right=`${e.right}px`,t.bottom=`${e.bottom}px`,clearTimeout(this._timer),this._timer=-1,this._hidden&&(this._hidden=!1,this.node.classList.remove("lm-mod-hidden"))}hide(e){if(!this._hidden)return e<=0?(clearTimeout(this._timer),this._timer=-1,this._hidden=!0,void this.node.classList.add("lm-mod-hidden")):void(-1===this._timer&&(this._timer=window.setTimeout((()=>{this._timer=-1,this._hidden=!0,this.node.classList.add("lm-mod-hidden")}),e)))}};class t{createTabBar(e){let t=new $({document:e});return t.addClass("lm-DockPanel-tabBar"),t}createHandle(){let e=document.createElement("div");return e.className="lm-DockPanel-handle",e}}e.Renderer=t,e.defaultRenderer=new t}(Z||(Z={})),function(e){e.GOLDEN_RATIO=.618,e.DEFAULT_EDGES={top:12,right:40,bottom:40,left:40},e.LayoutModified=new n.ConflatableMessage("layout-modified"),e.isGeneratedTabBarProperty=new a.AttachedProperty({name:"isGeneratedTabBar",create:()=>!1}),e.createSingleDocumentConfig=function(e){if(e.isEmpty)return{main:null};let t=Array.from(e.widgets()),i=e.selectedWidgets().next().value,s=i?t.indexOf(i):-1;return{main:{type:"tab-area",widgets:t,currentIndex:s}}},e.findDropTarget=function(e,t,i,n){if(!s.ElementExt.hitTest(e.node,t,i))return{zone:"invalid",target:null};let a=e.layout;if(a.isEmpty)return{zone:"root-all",target:null};if("multiple-document"===e.mode){let s=e.node.getBoundingClientRect(),a=t-s.left+1,r=i-s.top+1,o=s.right-t,h=s.bottom-i;switch(Math.min(r,o,h,a)){case r:if(ru&&d>u&&h>m&&l>m)return{zone:"widget-all",target:r};switch(o/=u,h/=m,d/=u,l/=m,Math.min(o,h,d,l)){case o:c="widget-left";break;case h:c="widget-top";break;case d:c="widget-right";break;case l:c="widget-bottom";break;default:throw"unreachable"}return{zone:c,target:r}},e.getDropRef=function(e){return 0===e.titles.length?null:e.currentTitle?e.currentTitle.owner:e.titles[e.titles.length-1].owner}}(Y||(Y={}));class ee extends v{constructor(e={}){super(e),this._dirty=!1,this._rowSpacing=4,this._columnSpacing=4,this._items=[],this._rowStarts=[],this._columnStarts=[],this._rowSizers=[new u],this._columnSizers=[new u],this._box=null,void 0!==e.rowCount&&X.reallocSizers(this._rowSizers,e.rowCount),void 0!==e.columnCount&&X.reallocSizers(this._columnSizers,e.columnCount),void 0!==e.rowSpacing&&(this._rowSpacing=X.clampValue(e.rowSpacing)),void 0!==e.columnSpacing&&(this._columnSpacing=X.clampValue(e.columnSpacing))}dispose(){for(const e of this._items){let t=e.widget;e.dispose(),t.dispose()}this._box=null,this._items.length=0,this._rowStarts.length=0,this._rowSizers.length=0,this._columnStarts.length=0,this._columnSizers.length=0,super.dispose()}get rowCount(){return this._rowSizers.length}set rowCount(e){e!==this.rowCount&&(X.reallocSizers(this._rowSizers,e),this.parent&&this.parent.fit())}get columnCount(){return this._columnSizers.length}set columnCount(e){e!==this.columnCount&&(X.reallocSizers(this._columnSizers,e),this.parent&&this.parent.fit())}get rowSpacing(){return this._rowSpacing}set rowSpacing(e){e=X.clampValue(e),this._rowSpacing!==e&&(this._rowSpacing=e,this.parent&&this.parent.fit())}get columnSpacing(){return this._columnSpacing}set columnSpacing(e){e=X.clampValue(e),this._columnSpacing!==e&&(this._columnSpacing=e,this.parent&&this.parent.fit())}rowStretch(e){let t=this._rowSizers[e];return t?t.stretch:-1}setRowStretch(e,t){let i=this._rowSizers[e];i&&(t=X.clampValue(t),i.stretch!==t&&(i.stretch=t,this.parent&&this.parent.update()))}columnStretch(e){let t=this._columnSizers[e];return t?t.stretch:-1}setColumnStretch(e,t){let i=this._columnSizers[e];i&&(t=X.clampValue(t),i.stretch!==t&&(i.stretch=t,this.parent&&this.parent.update()))}*[Symbol.iterator](){for(const e of this._items)yield e.widget}addWidget(e){-1===t.ArrayExt.findFirstIndex(this._items,(t=>t.widget===e))&&(this._items.push(new x(e)),this.parent&&this.attachWidget(e))}removeWidget(e){let i=t.ArrayExt.findFirstIndex(this._items,(t=>t.widget===e));if(-1===i)return;let s=t.ArrayExt.removeAt(this._items,i);this.parent&&this.detachWidget(e),s.dispose()}init(){super.init();for(const e of this)this.attachWidget(e)}attachWidget(e){this.parent.isAttached&&n.MessageLoop.sendMessage(e,b.Msg.BeforeAttach),this.parent.node.appendChild(e.node),this.parent.isAttached&&n.MessageLoop.sendMessage(e,b.Msg.AfterAttach),this.parent.fit()}detachWidget(e){this.parent.isAttached&&n.MessageLoop.sendMessage(e,b.Msg.BeforeDetach),this.parent.node.removeChild(e.node),this.parent.isAttached&&n.MessageLoop.sendMessage(e,b.Msg.AfterDetach),this.parent.fit()}onBeforeShow(e){super.onBeforeShow(e),this.parent.update()}onBeforeAttach(e){super.onBeforeAttach(e),this.parent.fit()}onChildShown(e){this.parent.fit()}onChildHidden(e){this.parent.fit()}onResize(e){this.parent.isVisible&&this._update(e.width,e.height)}onUpdateRequest(e){this.parent.isVisible&&this._update(-1,-1)}onFitRequest(e){this.parent.isAttached&&this._fit()}_fit(){for(let e=0,t=this.rowCount;e!e.isHidden));for(let t=0,i=e.length;t({row:0,column:0,rowSpan:1,columnSpan:1}),changed:function(e){e.parent&&e.parent.layout instanceof ee&&e.parent.fit()}}),e.normalizeConfig=function(e){return{row:Math.max(0,Math.floor(e.row||0)),column:Math.max(0,Math.floor(e.column||0)),rowSpan:Math.max(1,Math.floor(e.rowSpan||0)),columnSpan:Math.max(1,Math.floor(e.columnSpan||0))}},e.clampValue=function(e){return Math.max(0,Math.floor(e))},e.rowSpanCmp=function(t,i){let s=e.cellConfigProperty.get(t.widget),n=e.cellConfigProperty.get(i.widget);return s.rowSpan-n.rowSpan},e.columnSpanCmp=function(t,i){let s=e.cellConfigProperty.get(t.widget),n=e.cellConfigProperty.get(i.widget);return s.columnSpan-n.columnSpan},e.reallocSizers=function(e,t){for(t=Math.max(1,Math.floor(t));e.lengtht&&(e.length=t)},e.distributeMin=function(e,t,i,s){if(i=s)return;let a=(s-n)/(i-t+1);for(let s=t;s<=i;++s)e[s].minSize+=a}}(X||(X={}));class te extends b{constructor(e={}){super({node:K.createNode()}),this._activeIndex=-1,this._tabFocusIndex=0,this._menus=[],this._childMenu=null,this._overflowMenu=null,this._menuItemSizes=[],this._overflowIndex=-1,this.addClass("lm-MenuBar"),this.setFlag(b.Flag.DisallowLayout),this.renderer=e.renderer||te.defaultRenderer,this._forceItemsPosition=e.forceItemsPosition||{forceX:!0,forceY:!0},this._overflowMenuOptions=e.overflowMenuOptions||{isVisible:!0}}dispose(){this._closeChildMenu(),this._menus.length=0,super.dispose()}get childMenu(){return this._childMenu}get overflowIndex(){return this._overflowIndex}get overflowMenu(){return this._overflowMenu}get contentNode(){return this.node.getElementsByClassName("lm-MenuBar-content")[0]}get activeMenu(){return this._menus[this._activeIndex]||null}set activeMenu(e){this.activeIndex=e?this._menus.indexOf(e):-1}get activeIndex(){return this._activeIndex}set activeIndex(e){(e<0||e>=this._menus.length)&&(e=-1),this._activeIndex!==e&&(this._activeIndex=e,this.update())}get menus(){return this._menus}openActiveMenu(){-1!==this._activeIndex&&(this._openChildMenu(),this._childMenu&&(this._childMenu.activeIndex=-1,this._childMenu.activateNextItem()))}addMenu(e,t=!0){this.insertMenu(this._menus.length,e,t)}insertMenu(e,i,s=!0){this._closeChildMenu();let n=this._menus.indexOf(i),a=Math.max(0,Math.min(e,this._menus.length));if(-1===n)return t.ArrayExt.insert(this._menus,a,i),i.addClass("lm-MenuBar-menu"),i.aboutToClose.connect(this._onMenuAboutToClose,this),i.menuRequested.connect(this._onMenuMenuRequested,this),i.title.changed.connect(this._onTitleChanged,this),void(s&&this.update());a===this._menus.length&&a--,n!==a&&(t.ArrayExt.move(this._menus,n,a),s&&this.update())}removeMenu(e,t=!0){this.removeMenuAt(this._menus.indexOf(e),t)}removeMenuAt(e,i=!0){this._closeChildMenu();let s=t.ArrayExt.removeAt(this._menus,e);s&&(s.aboutToClose.disconnect(this._onMenuAboutToClose,this),s.menuRequested.disconnect(this._onMenuMenuRequested,this),s.title.changed.disconnect(this._onTitleChanged,this),s.removeClass("lm-MenuBar-menu"),i&&this.update())}clearMenus(){if(0!==this._menus.length){this._closeChildMenu();for(let e of this._menus)e.aboutToClose.disconnect(this._onMenuAboutToClose,this),e.menuRequested.disconnect(this._onMenuMenuRequested,this),e.title.changed.disconnect(this._onTitleChanged,this),e.removeClass("lm-MenuBar-menu");this._menus.length=0,this.update()}}handleEvent(e){switch(e.type){case"keydown":this._evtKeyDown(e);break;case"mousedown":this._evtMouseDown(e);break;case"mousemove":this._evtMouseMove(e);break;case"focusout":this._evtFocusOut(e);break;case"contextmenu":e.preventDefault(),e.stopPropagation()}}onBeforeAttach(e){this.node.addEventListener("keydown",this),this.node.addEventListener("mousedown",this),this.node.addEventListener("mousemove",this),this.node.addEventListener("focusout",this),this.node.addEventListener("contextmenu",this)}onAfterDetach(e){this.node.removeEventListener("keydown",this),this.node.removeEventListener("mousedown",this),this.node.removeEventListener("mousemove",this),this.node.removeEventListener("focusout",this),this.node.removeEventListener("contextmenu",this),this._closeChildMenu()}onActivateRequest(e){this.isAttached&&this._focusItemAt(0)}onResize(e){this.update(),super.onResize(e)}onUpdateRequest(e){var t;let i=this._menus,s=this.renderer,n=this._activeIndex,a=this._tabFocusIndex>=0&&this._tabFocusIndex-1?this._overflowIndex:i.length,o=0,l=!1;r=null!==this._overflowMenu?r-1:r;let c=new Array(r);for(let e=0;e{this._tabFocusIndex=e,this.activeIndex=e}}),o+=this._menuItemSizes[e],i[e].title.label===this._overflowMenuOptions.title&&(l=!0,r--);if(this._overflowMenuOptions.isVisible)if(this._overflowIndex>-1&&!l){if(null===this._overflowMenu){const e=null!==(t=this._overflowMenuOptions.title)&&void 0!==t?t:"...";this._overflowMenu=new F({commands:new h.CommandRegistry}),this._overflowMenu.title.label=e,this._overflowMenu.title.mnemonic=0,this.addMenu(this._overflowMenu,!1)}for(let e=i.length-2;e>=r;e--){const t=this.menus[e];t.title.mnemonic=0,this._overflowMenu.insertItem(0,{type:"submenu",submenu:t}),this.removeMenu(t,!1)}c[r]=s.renderItem({title:this._overflowMenu.title,active:r===n&&0!==i[r].items.length,tabbable:r===a,disabled:0===i[r].items.length,onfocus:()=>{this._tabFocusIndex=r,this.activeIndex=r}}),r++}else if(null!==this._overflowMenu){let e=this._overflowMenu.items,t=this.node.offsetWidth,n=this._overflowMenu.items.length;for(let h=0;hthis._menuItemSizes[n]){let t=e[0].submenu;this._overflowMenu.removeItemAt(0),this.insertMenu(r,t,!1),c[r]=s.renderItem({title:t.title,active:!1,tabbable:r===a,disabled:0===i[r].items.length,onfocus:()=>{this._tabFocusIndex=r,this.activeIndex=r}}),r++}}0===this._overflowMenu.items.length&&(this.removeMenu(this._overflowMenu,!1),c.pop(),this._overflowMenu=null,this._overflowIndex=-1)}d.VirtualDOM.render(c,this.contentNode),this._updateOverflowIndex()}_updateOverflowIndex(){if(!this._overflowMenuOptions.isVisible)return;const e=this.contentNode.childNodes;let t=this.node.offsetWidth,i=0,s=-1,n=e.length;if(0==this._menuItemSizes.length)for(let a=0;at&&-1===s&&(s=a)}else for(let e=0;et){s=e;break}this._overflowIndex=s}_evtKeyDown(e){let t=e.keyCode;if(9===t)return void(this.activeIndex=-1);if(e.preventDefault(),e.stopPropagation(),13===t||32===t||38===t||40===t){if(this.activeIndex=this._tabFocusIndex,this.activeIndex!==this._tabFocusIndex)return;return void this.openActiveMenu()}if(27===t)return this._closeChildMenu(),void this._focusItemAt(this.activeIndex);if(37===t||39===t){let e=37===t?-1:1,i=this._tabFocusIndex+e,s=this._menus.length;for(let t=0;ts.ElementExt.hitTest(t,e.clientX,e.clientY)));if(-1!==i){if(0===e.button)if(this._childMenu)this._closeChildMenu(),this.activeIndex=i;else{e.preventDefault();const t=this._positionForMenu(i);F.saveWindowData(),this.activeIndex=i,this._openChildMenu(t)}}else this._closeChildMenu()}_evtMouseMove(e){let i=t.ArrayExt.findFirstIndex(this.contentNode.children,(t=>s.ElementExt.hitTest(t,e.clientX,e.clientY)));if(i===this._activeIndex)return;if(-1===i&&this._childMenu)return;const n=i>=0&&this._childMenu?this._positionForMenu(i):null;F.saveWindowData(),this.activeIndex=i,n&&this._openChildMenu(n)}_positionForMenu(e){let t=this.contentNode.children[e],{left:i,bottom:s}=t.getBoundingClientRect();return{top:s,left:i}}_evtFocusOut(e){this._childMenu||this.node.contains(e.relatedTarget)||(this.activeIndex=-1)}_focusItemAt(e){const t=this.contentNode.childNodes[e];t&&t.focus()}_openChildMenu(e={}){let t=this.activeMenu;if(!t)return void this._closeChildMenu();let i=this._childMenu;if(i===t)return;this._childMenu=t,i?i.close():document.addEventListener("mousedown",this,!0),this._tabFocusIndex=this.activeIndex,n.MessageLoop.sendMessage(this,b.Msg.UpdateRequest);let{left:s,top:a}=e;void 0!==s&&void 0!==a||({left:s,top:a}=this._positionForMenu(this._activeIndex)),i||this.addClass("lm-mod-active"),t.items.length>0&&t.open(s,a,this._forceItemsPosition)}_closeChildMenu(){if(!this._childMenu)return;this.removeClass("lm-mod-active"),document.removeEventListener("mousedown",this,!0);let e=this._childMenu;this._childMenu=null,e.close(),this.activeIndex=-1}_onMenuAboutToClose(e){e===this._childMenu&&(this.removeClass("lm-mod-active"),document.removeEventListener("mousedown",this,!0),this._childMenu=null,this.activeIndex=-1)}_onMenuMenuRequested(e,t){if(e!==this._childMenu)return;let i=this._activeIndex,s=this._menus.length;switch(t){case"next":this.activeIndex=i===s-1?0:i+1;break;case"previous":this.activeIndex=0===i?s-1:i-1}this.openActiveMenu()}_onTitleChanged(){this.update()}}!function(e){class t{renderItem(e){let t=this.createItemClass(e),i=this.createItemDataset(e),s=this.createItemARIA(e);return d.h.li({className:t,dataset:i,...e.disabled?{}:{tabindex:e.tabbable?"0":"-1"},onfocus:e.onfocus,...s},this.renderIcon(e),this.renderLabel(e))}renderIcon(e){let t=this.createIconClass(e);return d.h.div({className:t},e.title.icon,e.title.iconLabel)}renderLabel(e){let t=this.formatLabel(e);return d.h.div({className:"lm-MenuBar-itemLabel"},t)}createItemClass(e){let t="lm-MenuBar-item";return e.title.className&&(t+=` ${e.title.className}`),e.active&&!e.disabled&&(t+=" lm-mod-active"),t}createItemDataset(e){return e.title.dataset}createItemARIA(e){return{role:"menuitem","aria-haspopup":"true","aria-disabled":e.disabled?"true":"false"}}createIconClass(e){let t="lm-MenuBar-itemIcon",i=e.title.iconClass;return i?`${t} ${i}`:t}formatLabel(e){let{label:t,mnemonic:i}=e.title;if(i<0||i>=t.length)return t;let s=t.slice(0,i),n=t.slice(i+1),a=t[i];return[s,d.h.span({className:"lm-MenuBar-itemMnemonic"},a),n]}}e.Renderer=t,e.defaultRenderer=new t}(te||(te={})),function(e){e.createNode=function(){let e=document.createElement("div"),t=document.createElement("ul");return t.className="lm-MenuBar-content",e.appendChild(t),t.setAttribute("role","menubar"),e},e.findMnemonic=function(e,t,i){let s=-1,n=-1,a=!1,r=t.toUpperCase();for(let t=0,o=e.length;t=0&&l1&&this.widgets.forEach((e=>{e.hiddenMode=this._hiddenMode})))}dispose(){for(const e of this._items)e.dispose();this._box=null,this._items.length=0,super.dispose()}attachWidget(e,i){this._hiddenMode===b.HiddenMode.Scale&&this._items.length>0?(1===this._items.length&&(this.widgets[0].hiddenMode=b.HiddenMode.Scale),i.hiddenMode=b.HiddenMode.Scale):i.hiddenMode=b.HiddenMode.Display,t.ArrayExt.insert(this._items,e,new x(i)),this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.BeforeAttach),this.parent.node.appendChild(i.node),this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.AfterAttach),this.parent.fit()}moveWidget(e,i,s){t.ArrayExt.move(this._items,e,i),this.parent.update()}detachWidget(e,i){let s=t.ArrayExt.removeAt(this._items,e);this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.BeforeDetach),this.parent.node.removeChild(i.node),this.parent.isAttached&&n.MessageLoop.sendMessage(i,b.Msg.AfterDetach),s.widget.node.style.zIndex="",this._hiddenMode===b.HiddenMode.Scale&&(i.hiddenMode=b.HiddenMode.Display,1===this._items.length&&(this._items[0].widget.hiddenMode=b.HiddenMode.Display)),s.dispose(),this.parent.fit()}onBeforeShow(e){super.onBeforeShow(e),this.parent.update()}onBeforeAttach(e){super.onBeforeAttach(e),this.parent.fit()}onChildShown(e){this.parent.fit()}onChildHidden(e){this.parent.fit()}onResize(e){this.parent.isVisible&&this._update(e.width,e.height)}onUpdateRequest(e){this.parent.isVisible&&this._update(-1,-1)}onFitRequest(e){this.parent.isAttached&&this._fit()}_fit(){let e=0,t=0;for(let i=0,s=this._items.length;i{t.ArrayExt.removeFirstOf(this._items,i)}))}open(e){if(F.saveWindowData(),this.menu.clearItems(),0===this._items.length)return!1;let t=T.matchItems(this._items,e,this._groupByTarget,this._sortBySelector);if(!t||0===t.length)return!1;for(const e of t)this.menu.addItem(e);return this.menu.open(e.clientX,e.clientY),!0}},e.DockLayout=Q,e.DockPanel=Z,e.FocusTracker=class{constructor(){this._counter=0,this._widgets=[],this._activeWidget=null,this._currentWidget=null,this._numbers=new Map,this._nodes=new Map,this._activeChanged=new r.Signal(this),this._currentChanged=new r.Signal(this)}dispose(){if(!(this._counter<0)){this._counter=-1,r.Signal.clearData(this);for(const e of this._widgets)e.node.removeEventListener("focus",this,!0),e.node.removeEventListener("blur",this,!0);this._activeWidget=null,this._currentWidget=null,this._nodes.clear(),this._numbers.clear(),this._widgets.length=0}}get currentChanged(){return this._currentChanged}get activeChanged(){return this._activeChanged}get isDisposed(){return this._counter<0}get currentWidget(){return this._currentWidget}get activeWidget(){return this._activeWidget}get widgets(){return this._widgets}focusNumber(e){let t=this._numbers.get(e);return void 0===t?-1:t}has(e){return this._numbers.has(e)}add(e){if(this._numbers.has(e))return;let t=e.node.contains(document.activeElement),i=t?this._counter++:-1;this._widgets.push(e),this._numbers.set(e,i),this._nodes.set(e.node,e),e.node.addEventListener("focus",this,!0),e.node.addEventListener("blur",this,!0),e.disposed.connect(this._onWidgetDisposed,this),t&&this._setWidgets(e,e)}remove(e){if(!this._numbers.has(e))return;if(e.disposed.disconnect(this._onWidgetDisposed,this),e.node.removeEventListener("focus",this,!0),e.node.removeEventListener("blur",this,!0),t.ArrayExt.removeFirstOf(this._widgets,e),this._nodes.delete(e.node),this._numbers.delete(e),this._currentWidget!==e)return;let i=this._widgets.filter((e=>-1!==this._numbers.get(e))),s=t.max(i,((e,t)=>this._numbers.get(e)-this._numbers.get(t)))||null;this._setWidgets(s,null)}handleEvent(e){switch(e.type){case"focus":this._evtFocus(e);break;case"blur":this._evtBlur(e)}}_setWidgets(e,t){let i=this._currentWidget;this._currentWidget=e;let s=this._activeWidget;this._activeWidget=t,i!==e&&this._currentChanged.emit({oldValue:i,newValue:e}),s!==t&&this._activeChanged.emit({oldValue:s,newValue:t})}_evtFocus(e){let t=this._nodes.get(e.currentTarget);t!==this._currentWidget&&this._numbers.set(t,this._counter++),this._setWidgets(t,t)}_evtBlur(e){let i=this._nodes.get(e.currentTarget),s=e.relatedTarget;s&&(i.node.contains(s)||t.find(this._widgets,(e=>e.node.contains(s))))||this._setWidgets(this._currentWidget,null)}_onWidgetDisposed(e){this.remove(e)}},e.GridLayout=ee,e.Layout=v,e.LayoutItem=x,e.Menu=F,e.MenuBar=te,e.Panel=R,e.PanelLayout=M,e.ScrollBar=class extends b{constructor(e={}){super({node:G.createNode()}),this._onRepeat=()=>{if(this._repeatTimer=-1,!this._pressData)return;let e=this._pressData.part;if("thumb"===e)return;this._repeatTimer=window.setTimeout(this._onRepeat,20);let t=this._pressData.mouseX,i=this._pressData.mouseY;if("decrement"!==e)if("increment"!==e){if("track"===e){if(!s.ElementExt.hitTest(this.trackNode,t,i))return;let e=this.thumbNode;if(s.ElementExt.hitTest(e,t,i))return;let n,a=e.getBoundingClientRect();return n="horizontal"===this._orientation?t=` to {@link minSize}. Failure to adhere to this\n * constraint will yield undefined results.\n *\n * The default value is `Infinity`.\n */\n maxSize = Infinity;\n\n /**\n * The stretch factor for the sizer.\n *\n * #### Notes\n * This controls how much the sizer stretches relative to its sibling\n * sizers when layout space is distributed. A stretch factor of zero\n * is special and will cause the sizer to only be resized after all\n * other sizers with a stretch factor greater than zero have been\n * resized to their limits.\n *\n * It is assumed that this value is an integer that lies in the range\n * `[0, Infinity)`. Failure to adhere to this constraint will yield\n * undefined results.\n *\n * The default value is `1`.\n */\n stretch = 1;\n\n /**\n * The computed size of the sizer.\n *\n * #### Notes\n * This value is the output of a call to {@link BoxEngine.calc}. It represents\n * the computed size for the object along the layout orientation,\n * and will always lie in the range `[minSize, maxSize]`.\n *\n * This value is output only.\n *\n * Changing this value will have no effect.\n */\n size = 0;\n\n /**\n * An internal storage property for the layout algorithm.\n *\n * #### Notes\n * This value is used as temporary storage by the layout algorithm.\n *\n * Changing this value will have no effect.\n */\n done = false;\n}\n\n/**\n * The namespace for the box engine layout functions.\n */\nexport namespace BoxEngine {\n /**\n * Calculate the optimal layout sizes for a sequence of box sizers.\n *\n * This distributes the available layout space among the box sizers\n * according to the following algorithm:\n *\n * 1. Initialize the sizers's size to its size hint and compute the\n * sums for each of size hint, min size, and max size.\n *\n * 2. If the total size hint equals the available space, return.\n *\n * 3. If the available space is less than the total min size, set all\n * sizers to their min size and return.\n *\n * 4. If the available space is greater than the total max size, set\n * all sizers to their max size and return.\n *\n * 5. If the layout space is less than the total size hint, distribute\n * the negative delta as follows:\n *\n * a. Shrink each sizer with a stretch factor greater than zero by\n * an amount proportional to the negative space and the sum of\n * stretch factors. If the sizer reaches its min size, remove\n * it and its stretch factor from the computation.\n *\n * b. If after adjusting all stretch sizers there remains negative\n * space, distribute the space equally among the sizers with a\n * stretch factor of zero. If a sizer reaches its min size,\n * remove it from the computation.\n *\n * 6. If the layout space is greater than the total size hint,\n * distribute the positive delta as follows:\n *\n * a. Expand each sizer with a stretch factor greater than zero by\n * an amount proportional to the postive space and the sum of\n * stretch factors. If the sizer reaches its max size, remove\n * it and its stretch factor from the computation.\n *\n * b. If after adjusting all stretch sizers there remains positive\n * space, distribute the space equally among the sizers with a\n * stretch factor of zero. If a sizer reaches its max size,\n * remove it from the computation.\n *\n * 7. return\n *\n * @param sizers - The sizers for a particular layout line.\n *\n * @param space - The available layout space for the sizers.\n *\n * @returns The delta between the provided available space and the\n * actual consumed space. This value will be zero if the sizers\n * can be adjusted to fit, negative if the available space is too\n * small, and positive if the available space is too large.\n *\n * #### Notes\n * The {@link BoxSizer.size} of each sizer is updated with the computed size.\n *\n * This function can be called at any time to recompute the layout for\n * an existing sequence of sizers. The previously computed results will\n * have no effect on the new output. It is therefore not necessary to\n * create new sizer objects on each resize event.\n */\n export function calc(sizers: ArrayLike, space: number): number {\n // Bail early if there is nothing to do.\n let count = sizers.length;\n if (count === 0) {\n return space;\n }\n\n // Setup the size and stretch counters.\n let totalMin = 0;\n let totalMax = 0;\n let totalSize = 0;\n let totalStretch = 0;\n let stretchCount = 0;\n\n // Setup the sizers and compute the totals.\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n let min = sizer.minSize;\n let max = sizer.maxSize;\n let hint = sizer.sizeHint;\n sizer.done = false;\n sizer.size = Math.max(min, Math.min(hint, max));\n totalSize += sizer.size;\n totalMin += min;\n totalMax += max;\n if (sizer.stretch > 0) {\n totalStretch += sizer.stretch;\n stretchCount++;\n }\n }\n\n // If the space is equal to the total size, return early.\n if (space === totalSize) {\n return 0;\n }\n\n // If the space is less than the total min, minimize each sizer.\n if (space <= totalMin) {\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n sizer.size = sizer.minSize;\n }\n return space - totalMin;\n }\n\n // If the space is greater than the total max, maximize each sizer.\n if (space >= totalMax) {\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n sizer.size = sizer.maxSize;\n }\n return space - totalMax;\n }\n\n // The loops below perform sub-pixel precision sizing. A near zero\n // value is used for compares instead of zero to ensure that the\n // loop terminates when the subdivided space is reasonably small.\n let nearZero = 0.01;\n\n // A counter which is decremented each time a sizer is resized to\n // its limit. This ensures the loops terminate even if there is\n // space remaining to distribute.\n let notDoneCount = count;\n\n // Distribute negative delta space.\n if (space < totalSize) {\n // Shrink each stretchable sizer by an amount proportional to its\n // stretch factor. If a sizer reaches its min size it's marked as\n // done. The loop progresses in phases where each sizer is given\n // a chance to consume its fair share for the pass, regardless of\n // whether a sizer before it reached its limit. This continues\n // until the stretchable sizers or the free space is exhausted.\n let freeSpace = totalSize - space;\n while (stretchCount > 0 && freeSpace > nearZero) {\n let distSpace = freeSpace;\n let distStretch = totalStretch;\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n if (sizer.done || sizer.stretch === 0) {\n continue;\n }\n let amt = (sizer.stretch * distSpace) / distStretch;\n if (sizer.size - amt <= sizer.minSize) {\n freeSpace -= sizer.size - sizer.minSize;\n totalStretch -= sizer.stretch;\n sizer.size = sizer.minSize;\n sizer.done = true;\n notDoneCount--;\n stretchCount--;\n } else {\n freeSpace -= amt;\n sizer.size -= amt;\n }\n }\n }\n // Distribute any remaining space evenly among the non-stretchable\n // sizers. This progresses in phases in the same manner as above.\n while (notDoneCount > 0 && freeSpace > nearZero) {\n let amt = freeSpace / notDoneCount;\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n if (sizer.done) {\n continue;\n }\n if (sizer.size - amt <= sizer.minSize) {\n freeSpace -= sizer.size - sizer.minSize;\n sizer.size = sizer.minSize;\n sizer.done = true;\n notDoneCount--;\n } else {\n freeSpace -= amt;\n sizer.size -= amt;\n }\n }\n }\n }\n // Distribute positive delta space.\n else {\n // Expand each stretchable sizer by an amount proportional to its\n // stretch factor. If a sizer reaches its max size it's marked as\n // done. The loop progresses in phases where each sizer is given\n // a chance to consume its fair share for the pass, regardless of\n // whether a sizer before it reached its limit. This continues\n // until the stretchable sizers or the free space is exhausted.\n let freeSpace = space - totalSize;\n while (stretchCount > 0 && freeSpace > nearZero) {\n let distSpace = freeSpace;\n let distStretch = totalStretch;\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n if (sizer.done || sizer.stretch === 0) {\n continue;\n }\n let amt = (sizer.stretch * distSpace) / distStretch;\n if (sizer.size + amt >= sizer.maxSize) {\n freeSpace -= sizer.maxSize - sizer.size;\n totalStretch -= sizer.stretch;\n sizer.size = sizer.maxSize;\n sizer.done = true;\n notDoneCount--;\n stretchCount--;\n } else {\n freeSpace -= amt;\n sizer.size += amt;\n }\n }\n }\n // Distribute any remaining space evenly among the non-stretchable\n // sizers. This progresses in phases in the same manner as above.\n while (notDoneCount > 0 && freeSpace > nearZero) {\n let amt = freeSpace / notDoneCount;\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n if (sizer.done) {\n continue;\n }\n if (sizer.size + amt >= sizer.maxSize) {\n freeSpace -= sizer.maxSize - sizer.size;\n sizer.size = sizer.maxSize;\n sizer.done = true;\n notDoneCount--;\n } else {\n freeSpace -= amt;\n sizer.size += amt;\n }\n }\n }\n }\n\n // Indicate that the consumed space equals the available space.\n return 0;\n }\n\n /**\n * Adjust a sizer by a delta and update its neighbors accordingly.\n *\n * @param sizers - The sizers which should be adjusted.\n *\n * @param index - The index of the sizer to grow.\n *\n * @param delta - The amount to adjust the sizer, positive or negative.\n *\n * #### Notes\n * This will adjust the indicated sizer by the specified amount, along\n * with the sizes of the appropriate neighbors, subject to the limits\n * specified by each of the sizers.\n *\n * This is useful when implementing box layouts where the boundaries\n * between the sizers are interactively adjustable by the user.\n */\n export function adjust(\n sizers: ArrayLike,\n index: number,\n delta: number\n ): void {\n // Bail early when there is nothing to do.\n if (sizers.length === 0 || delta === 0) {\n return;\n }\n\n // Dispatch to the proper implementation.\n if (delta > 0) {\n growSizer(sizers, index, delta);\n } else {\n shrinkSizer(sizers, index, -delta);\n }\n }\n\n /**\n * Grow a sizer by a positive delta and adjust neighbors.\n */\n function growSizer(\n sizers: ArrayLike,\n index: number,\n delta: number\n ): void {\n // Compute how much the items to the left can expand.\n let growLimit = 0;\n for (let i = 0; i <= index; ++i) {\n let sizer = sizers[i];\n growLimit += sizer.maxSize - sizer.size;\n }\n\n // Compute how much the items to the right can shrink.\n let shrinkLimit = 0;\n for (let i = index + 1, n = sizers.length; i < n; ++i) {\n let sizer = sizers[i];\n shrinkLimit += sizer.size - sizer.minSize;\n }\n\n // Clamp the delta adjustment to the limits.\n delta = Math.min(delta, growLimit, shrinkLimit);\n\n // Grow the sizers to the left by the delta.\n let grow = delta;\n for (let i = index; i >= 0 && grow > 0; --i) {\n let sizer = sizers[i];\n let limit = sizer.maxSize - sizer.size;\n if (limit >= grow) {\n sizer.sizeHint = sizer.size + grow;\n grow = 0;\n } else {\n sizer.sizeHint = sizer.size + limit;\n grow -= limit;\n }\n }\n\n // Shrink the sizers to the right by the delta.\n let shrink = delta;\n for (let i = index + 1, n = sizers.length; i < n && shrink > 0; ++i) {\n let sizer = sizers[i];\n let limit = sizer.size - sizer.minSize;\n if (limit >= shrink) {\n sizer.sizeHint = sizer.size - shrink;\n shrink = 0;\n } else {\n sizer.sizeHint = sizer.size - limit;\n shrink -= limit;\n }\n }\n }\n\n /**\n * Shrink a sizer by a positive delta and adjust neighbors.\n */\n function shrinkSizer(\n sizers: ArrayLike,\n index: number,\n delta: number\n ): void {\n // Compute how much the items to the right can expand.\n let growLimit = 0;\n for (let i = index + 1, n = sizers.length; i < n; ++i) {\n let sizer = sizers[i];\n growLimit += sizer.maxSize - sizer.size;\n }\n\n // Compute how much the items to the left can shrink.\n let shrinkLimit = 0;\n for (let i = 0; i <= index; ++i) {\n let sizer = sizers[i];\n shrinkLimit += sizer.size - sizer.minSize;\n }\n\n // Clamp the delta adjustment to the limits.\n delta = Math.min(delta, growLimit, shrinkLimit);\n\n // Grow the sizers to the right by the delta.\n let grow = delta;\n for (let i = index + 1, n = sizers.length; i < n && grow > 0; ++i) {\n let sizer = sizers[i];\n let limit = sizer.maxSize - sizer.size;\n if (limit >= grow) {\n sizer.sizeHint = sizer.size + grow;\n grow = 0;\n } else {\n sizer.sizeHint = sizer.size + limit;\n grow -= limit;\n }\n }\n\n // Shrink the sizers to the left by the delta.\n let shrink = delta;\n for (let i = index; i >= 0 && shrink > 0; --i) {\n let sizer = sizers[i];\n let limit = sizer.size - sizer.minSize;\n if (limit >= shrink) {\n sizer.sizeHint = sizer.size - shrink;\n shrink = 0;\n } else {\n sizer.sizeHint = sizer.size - limit;\n shrink -= limit;\n }\n }\n }\n}\n","/* eslint-disable @typescript-eslint/no-empty-function */\n// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { IObservableDisposable } from '@lumino/disposable';\n\nimport {\n ConflatableMessage,\n IMessageHandler,\n Message,\n MessageLoop\n} from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { Layout } from './layout';\n\nimport { Title } from './title';\n\n/**\n * The base class of the lumino widget hierarchy.\n *\n * #### Notes\n * This class will typically be subclassed in order to create a useful\n * widget. However, it can be used directly to host externally created\n * content.\n */\nexport class Widget implements IMessageHandler, IObservableDisposable {\n /**\n * Construct a new widget.\n *\n * @param options - The options for initializing the widget.\n */\n constructor(options: Widget.IOptions = {}) {\n this.node = Private.createNode(options);\n this.addClass('lm-Widget');\n }\n\n /**\n * Dispose of the widget and its descendant widgets.\n *\n * #### Notes\n * It is unsafe to use the widget after it has been disposed.\n *\n * All calls made to this method after the first are a no-op.\n */\n dispose(): void {\n // Do nothing if the widget is already disposed.\n if (this.isDisposed) {\n return;\n }\n\n // Set the disposed flag and emit the disposed signal.\n this.setFlag(Widget.Flag.IsDisposed);\n this._disposed.emit(undefined);\n\n // Remove or detach the widget if necessary.\n if (this.parent) {\n this.parent = null;\n } else if (this.isAttached) {\n Widget.detach(this);\n }\n\n // Dispose of the widget layout.\n if (this._layout) {\n this._layout.dispose();\n this._layout = null;\n }\n\n // Dispose the title\n this.title.dispose();\n\n // Clear the extra data associated with the widget.\n Signal.clearData(this);\n MessageLoop.clearData(this);\n AttachedProperty.clearData(this);\n }\n\n /**\n * A signal emitted when the widget is disposed.\n */\n get disposed(): ISignal {\n return this._disposed;\n }\n\n /**\n * Get the DOM node owned by the widget.\n */\n readonly node: HTMLElement;\n\n /**\n * Test whether the widget has been disposed.\n */\n get isDisposed(): boolean {\n return this.testFlag(Widget.Flag.IsDisposed);\n }\n\n /**\n * Test whether the widget's node is attached to the DOM.\n */\n get isAttached(): boolean {\n return this.testFlag(Widget.Flag.IsAttached);\n }\n\n /**\n * Test whether the widget is explicitly hidden.\n */\n get isHidden(): boolean {\n return this.testFlag(Widget.Flag.IsHidden);\n }\n\n /**\n * Test whether the widget is visible.\n *\n * #### Notes\n * A widget is visible when it is attached to the DOM, is not\n * explicitly hidden, and has no explicitly hidden ancestors.\n */\n get isVisible(): boolean {\n return this.testFlag(Widget.Flag.IsVisible);\n }\n\n /**\n * The title object for the widget.\n *\n * #### Notes\n * The title object is used by some container widgets when displaying\n * the widget alongside some title, such as a tab panel or side bar.\n *\n * Since not all widgets will use the title, it is created on demand.\n *\n * The `owner` property of the title is set to this widget.\n */\n get title(): Title {\n return Private.titleProperty.get(this);\n }\n\n /**\n * Get the id of the widget's DOM node.\n */\n get id(): string {\n return this.node.id;\n }\n\n /**\n * Set the id of the widget's DOM node.\n */\n set id(value: string) {\n this.node.id = value;\n }\n\n /**\n * The dataset for the widget's DOM node.\n */\n get dataset(): DOMStringMap {\n return this.node.dataset;\n }\n\n /**\n * Get the method for hiding the widget.\n */\n get hiddenMode(): Widget.HiddenMode {\n return this._hiddenMode;\n }\n\n /**\n * Set the method for hiding the widget.\n */\n set hiddenMode(value: Widget.HiddenMode) {\n if (this._hiddenMode === value) {\n return;\n }\n\n if (this.isHidden) {\n // Reset styles set by previous mode.\n this._toggleHidden(false);\n }\n\n if (value == Widget.HiddenMode.Scale) {\n this.node.style.willChange = 'transform';\n } else {\n this.node.style.willChange = 'auto';\n }\n\n this._hiddenMode = value;\n\n if (this.isHidden) {\n // Set styles for new mode.\n this._toggleHidden(true);\n }\n }\n\n /**\n * Get the parent of the widget.\n */\n get parent(): Widget | null {\n return this._parent;\n }\n\n /**\n * Set the parent of the widget.\n *\n * #### Notes\n * Children are typically added to a widget by using a layout, which\n * means user code will not normally set the parent widget directly.\n *\n * The widget will be automatically removed from its old parent.\n *\n * This is a no-op if there is no effective parent change.\n */\n set parent(value: Widget | null) {\n if (this._parent === value) {\n return;\n }\n if (value && this.contains(value)) {\n throw new Error('Invalid parent widget.');\n }\n if (this._parent && !this._parent.isDisposed) {\n let msg = new Widget.ChildMessage('child-removed', this);\n MessageLoop.sendMessage(this._parent, msg);\n }\n this._parent = value;\n if (this._parent && !this._parent.isDisposed) {\n let msg = new Widget.ChildMessage('child-added', this);\n MessageLoop.sendMessage(this._parent, msg);\n }\n if (!this.isDisposed) {\n MessageLoop.sendMessage(this, Widget.Msg.ParentChanged);\n }\n }\n\n /**\n * Get the layout for the widget.\n */\n get layout(): Layout | null {\n return this._layout;\n }\n\n /**\n * Set the layout for the widget.\n *\n * #### Notes\n * The layout is single-use only. It cannot be changed after the\n * first assignment.\n *\n * The layout is disposed automatically when the widget is disposed.\n */\n set layout(value: Layout | null) {\n if (this._layout === value) {\n return;\n }\n if (this.testFlag(Widget.Flag.DisallowLayout)) {\n throw new Error('Cannot set widget layout.');\n }\n if (this._layout) {\n throw new Error('Cannot change widget layout.');\n }\n if (value!.parent) {\n throw new Error('Cannot change layout parent.');\n }\n this._layout = value;\n value!.parent = this;\n }\n\n /**\n * Create an iterator over the widget's children.\n *\n * @returns A new iterator over the children of the widget.\n *\n * #### Notes\n * The widget must have a populated layout in order to have children.\n *\n * If a layout is not installed, the returned iterator will be empty.\n */\n *children(): IterableIterator {\n if (this._layout) {\n yield* this._layout;\n }\n }\n\n /**\n * Test whether a widget is a descendant of this widget.\n *\n * @param widget - The descendant widget of interest.\n *\n * @returns `true` if the widget is a descendant, `false` otherwise.\n */\n contains(widget: Widget): boolean {\n for (let value: Widget | null = widget; value; value = value._parent) {\n if (value === this) {\n return true;\n }\n }\n return false;\n }\n\n /**\n * Test whether the widget's DOM node has the given class name.\n *\n * @param name - The class name of interest.\n *\n * @returns `true` if the node has the class, `false` otherwise.\n */\n hasClass(name: string): boolean {\n return this.node.classList.contains(name);\n }\n\n /**\n * Add a class name to the widget's DOM node.\n *\n * @param name - The class name to add to the node.\n *\n * #### Notes\n * If the class name is already added to the node, this is a no-op.\n *\n * The class name must not contain whitespace.\n */\n addClass(name: string): void {\n this.node.classList.add(name);\n }\n\n /**\n * Remove a class name from the widget's DOM node.\n *\n * @param name - The class name to remove from the node.\n *\n * #### Notes\n * If the class name is not yet added to the node, this is a no-op.\n *\n * The class name must not contain whitespace.\n */\n removeClass(name: string): void {\n this.node.classList.remove(name);\n }\n\n /**\n * Toggle a class name on the widget's DOM node.\n *\n * @param name - The class name to toggle on the node.\n *\n * @param force - Whether to force add the class (`true`) or force\n * remove the class (`false`). If not provided, the presence of\n * the class will be toggled from its current state.\n *\n * @returns `true` if the class is now present, `false` otherwise.\n *\n * #### Notes\n * The class name must not contain whitespace.\n */\n toggleClass(name: string, force?: boolean): boolean {\n if (force === true) {\n this.node.classList.add(name);\n return true;\n }\n if (force === false) {\n this.node.classList.remove(name);\n return false;\n }\n return this.node.classList.toggle(name);\n }\n\n /**\n * Post an `'update-request'` message to the widget.\n *\n * #### Notes\n * This is a simple convenience method for posting the message.\n */\n update(): void {\n MessageLoop.postMessage(this, Widget.Msg.UpdateRequest);\n }\n\n /**\n * Post a `'fit-request'` message to the widget.\n *\n * #### Notes\n * This is a simple convenience method for posting the message.\n */\n fit(): void {\n MessageLoop.postMessage(this, Widget.Msg.FitRequest);\n }\n\n /**\n * Post an `'activate-request'` message to the widget.\n *\n * #### Notes\n * This is a simple convenience method for posting the message.\n */\n activate(): void {\n MessageLoop.postMessage(this, Widget.Msg.ActivateRequest);\n }\n\n /**\n * Send a `'close-request'` message to the widget.\n *\n * #### Notes\n * This is a simple convenience method for sending the message.\n */\n close(): void {\n MessageLoop.sendMessage(this, Widget.Msg.CloseRequest);\n }\n\n /**\n * Show the widget and make it visible to its parent widget.\n *\n * #### Notes\n * This causes the {@link isHidden} property to be `false`.\n *\n * If the widget is not explicitly hidden, this is a no-op.\n */\n show(): void {\n if (!this.testFlag(Widget.Flag.IsHidden)) {\n return;\n }\n if (this.isAttached && (!this.parent || this.parent.isVisible)) {\n MessageLoop.sendMessage(this, Widget.Msg.BeforeShow);\n }\n this.clearFlag(Widget.Flag.IsHidden);\n this._toggleHidden(false);\n\n if (this.isAttached && (!this.parent || this.parent.isVisible)) {\n MessageLoop.sendMessage(this, Widget.Msg.AfterShow);\n }\n if (this.parent) {\n let msg = new Widget.ChildMessage('child-shown', this);\n MessageLoop.sendMessage(this.parent, msg);\n }\n }\n\n /**\n * Hide the widget and make it hidden to its parent widget.\n *\n * #### Notes\n * This causes the {@link isHidden} property to be `true`.\n *\n * If the widget is explicitly hidden, this is a no-op.\n */\n hide(): void {\n if (this.testFlag(Widget.Flag.IsHidden)) {\n return;\n }\n if (this.isAttached && (!this.parent || this.parent.isVisible)) {\n MessageLoop.sendMessage(this, Widget.Msg.BeforeHide);\n }\n this.setFlag(Widget.Flag.IsHidden);\n this._toggleHidden(true);\n\n if (this.isAttached && (!this.parent || this.parent.isVisible)) {\n MessageLoop.sendMessage(this, Widget.Msg.AfterHide);\n }\n if (this.parent) {\n let msg = new Widget.ChildMessage('child-hidden', this);\n MessageLoop.sendMessage(this.parent, msg);\n }\n }\n\n /**\n * Show or hide the widget according to a boolean value.\n *\n * @param hidden - `true` to hide the widget, or `false` to show it.\n *\n * #### Notes\n * This is a convenience method for `hide()` and `show()`.\n */\n setHidden(hidden: boolean): void {\n if (hidden) {\n this.hide();\n } else {\n this.show();\n }\n }\n\n /**\n * Test whether the given widget flag is set.\n *\n * #### Notes\n * This will not typically be called directly by user code.\n */\n testFlag(flag: Widget.Flag): boolean {\n return (this._flags & flag) !== 0;\n }\n\n /**\n * Set the given widget flag.\n *\n * #### Notes\n * This will not typically be called directly by user code.\n */\n setFlag(flag: Widget.Flag): void {\n this._flags |= flag;\n }\n\n /**\n * Clear the given widget flag.\n *\n * #### Notes\n * This will not typically be called directly by user code.\n */\n clearFlag(flag: Widget.Flag): void {\n this._flags &= ~flag;\n }\n\n /**\n * Process a message sent to the widget.\n *\n * @param msg - The message sent to the widget.\n *\n * #### Notes\n * Subclasses may reimplement this method as needed.\n */\n processMessage(msg: Message): void {\n switch (msg.type) {\n case 'resize':\n this.notifyLayout(msg);\n this.onResize(msg as Widget.ResizeMessage);\n break;\n case 'update-request':\n this.notifyLayout(msg);\n this.onUpdateRequest(msg);\n break;\n case 'fit-request':\n this.notifyLayout(msg);\n this.onFitRequest(msg);\n break;\n case 'before-show':\n this.notifyLayout(msg);\n this.onBeforeShow(msg);\n break;\n case 'after-show':\n this.setFlag(Widget.Flag.IsVisible);\n this.notifyLayout(msg);\n this.onAfterShow(msg);\n break;\n case 'before-hide':\n this.notifyLayout(msg);\n this.onBeforeHide(msg);\n break;\n case 'after-hide':\n this.clearFlag(Widget.Flag.IsVisible);\n this.notifyLayout(msg);\n this.onAfterHide(msg);\n break;\n case 'before-attach':\n this.notifyLayout(msg);\n this.onBeforeAttach(msg);\n break;\n case 'after-attach':\n if (!this.isHidden && (!this.parent || this.parent.isVisible)) {\n this.setFlag(Widget.Flag.IsVisible);\n }\n this.setFlag(Widget.Flag.IsAttached);\n this.notifyLayout(msg);\n this.onAfterAttach(msg);\n break;\n case 'before-detach':\n this.notifyLayout(msg);\n this.onBeforeDetach(msg);\n break;\n case 'after-detach':\n this.clearFlag(Widget.Flag.IsVisible);\n this.clearFlag(Widget.Flag.IsAttached);\n this.notifyLayout(msg);\n this.onAfterDetach(msg);\n break;\n case 'activate-request':\n this.notifyLayout(msg);\n this.onActivateRequest(msg);\n break;\n case 'close-request':\n this.notifyLayout(msg);\n this.onCloseRequest(msg);\n break;\n case 'child-added':\n this.notifyLayout(msg);\n this.onChildAdded(msg as Widget.ChildMessage);\n break;\n case 'child-removed':\n this.notifyLayout(msg);\n this.onChildRemoved(msg as Widget.ChildMessage);\n break;\n default:\n this.notifyLayout(msg);\n break;\n }\n }\n\n /**\n * Invoke the message processing routine of the widget's layout.\n *\n * @param msg - The message to dispatch to the layout.\n *\n * #### Notes\n * This is a no-op if the widget does not have a layout.\n *\n * This will not typically be called directly by user code.\n */\n protected notifyLayout(msg: Message): void {\n if (this._layout) {\n this._layout.processParentMessage(msg);\n }\n }\n\n /**\n * A message handler invoked on a `'close-request'` message.\n *\n * #### Notes\n * The default implementation unparents or detaches the widget.\n */\n protected onCloseRequest(msg: Message): void {\n if (this.parent) {\n this.parent = null;\n } else if (this.isAttached) {\n Widget.detach(this);\n }\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onResize(msg: Widget.ResizeMessage): void {}\n\n /**\n * A message handler invoked on an `'update-request'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onUpdateRequest(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onFitRequest(msg: Message): void {}\n\n /**\n * A message handler invoked on an `'activate-request'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onActivateRequest(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'before-show'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onBeforeShow(msg: Message): void {}\n\n /**\n * A message handler invoked on an `'after-show'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onAfterShow(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'before-hide'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onBeforeHide(msg: Message): void {}\n\n /**\n * A message handler invoked on an `'after-hide'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onAfterHide(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onBeforeAttach(msg: Message): void {}\n\n /**\n * A message handler invoked on an `'after-attach'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onAfterAttach(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'before-detach'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onBeforeDetach(msg: Message): void {}\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onAfterDetach(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'child-added'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onChildAdded(msg: Widget.ChildMessage): void {}\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {}\n\n private _toggleHidden(hidden: boolean) {\n if (hidden) {\n switch (this._hiddenMode) {\n case Widget.HiddenMode.Display:\n this.addClass('lm-mod-hidden');\n break;\n case Widget.HiddenMode.Scale:\n this.node.style.transform = 'scale(0)';\n this.node.setAttribute('aria-hidden', 'true');\n break;\n case Widget.HiddenMode.ContentVisibility:\n // @ts-expect-error content-visibility unknown by DOM lib types\n this.node.style.contentVisibility = 'hidden';\n this.node.style.zIndex = '-1';\n break;\n }\n } else {\n switch (this._hiddenMode) {\n case Widget.HiddenMode.Display:\n this.removeClass('lm-mod-hidden');\n break;\n case Widget.HiddenMode.Scale:\n this.node.style.transform = '';\n this.node.removeAttribute('aria-hidden');\n break;\n case Widget.HiddenMode.ContentVisibility:\n // @ts-expect-error content-visibility unknown by DOM lib types\n this.node.style.contentVisibility = '';\n this.node.style.zIndex = '';\n break;\n }\n }\n }\n\n private _flags = 0;\n private _layout: Layout | null = null;\n private _parent: Widget | null = null;\n private _disposed = new Signal(this);\n private _hiddenMode: Widget.HiddenMode = Widget.HiddenMode.Display;\n}\n\n/**\n * The namespace for the `Widget` class statics.\n */\nexport namespace Widget {\n /**\n * An options object for initializing a widget.\n */\n export interface IOptions {\n /**\n * The optional node to use for the widget.\n *\n * If a node is provided, the widget will assume full ownership\n * and control of the node, as if it had created the node itself.\n *\n * The default is a new `
`.\n */\n node?: HTMLElement;\n\n /**\n * The optional element tag, used for constructing the widget's node.\n *\n * If a pre-constructed node is provided via the `node` arg, this\n * value is ignored.\n */\n tag?: keyof HTMLElementTagNameMap;\n }\n\n /**\n * The method for hiding the widget.\n *\n * The default is Display.\n *\n * Using `Scale` will often increase performance as most browsers will not\n * trigger style computation for the `transform` action. This should be used\n * sparingly and tested, since increasing the number of composition layers\n * may slow things down.\n *\n * To ensure the transformation does not trigger style recomputation, you\n * may need to set the widget CSS style `will-change: transform`. This\n * should be used only when needed as it may overwhelm the browser with a\n * high number of layers. See\n * https://developer.mozilla.org/en-US/docs/Web/CSS/will-change\n */\n export enum HiddenMode {\n /**\n * Set a `lm-mod-hidden` CSS class to hide the widget using `display:none`\n * CSS from the standard Lumino CSS.\n */\n Display = 0,\n\n /**\n * Hide the widget by setting the `transform` to `'scale(0)'`.\n */\n Scale,\n\n /**\n *Hide the widget by setting the `content-visibility` to `'hidden'`.\n */\n ContentVisibility\n }\n\n /**\n * An enum of widget bit flags.\n */\n export enum Flag {\n /**\n * The widget has been disposed.\n */\n IsDisposed = 0x1,\n\n /**\n * The widget is attached to the DOM.\n */\n IsAttached = 0x2,\n\n /**\n * The widget is hidden.\n */\n IsHidden = 0x4,\n\n /**\n * The widget is visible.\n */\n IsVisible = 0x8,\n\n /**\n * A layout cannot be set on the widget.\n */\n DisallowLayout = 0x10\n }\n\n /**\n * A collection of stateless messages related to widgets.\n */\n export namespace Msg {\n /**\n * A singleton `'before-show'` message.\n *\n * #### Notes\n * This message is sent to a widget before it becomes visible.\n *\n * This message is **not** sent when the widget is being attached.\n */\n export const BeforeShow = new Message('before-show');\n\n /**\n * A singleton `'after-show'` message.\n *\n * #### Notes\n * This message is sent to a widget after it becomes visible.\n *\n * This message is **not** sent when the widget is being attached.\n */\n export const AfterShow = new Message('after-show');\n\n /**\n * A singleton `'before-hide'` message.\n *\n * #### Notes\n * This message is sent to a widget before it becomes not-visible.\n *\n * This message is **not** sent when the widget is being detached.\n */\n export const BeforeHide = new Message('before-hide');\n\n /**\n * A singleton `'after-hide'` message.\n *\n * #### Notes\n * This message is sent to a widget after it becomes not-visible.\n *\n * This message is **not** sent when the widget is being detached.\n */\n export const AfterHide = new Message('after-hide');\n\n /**\n * A singleton `'before-attach'` message.\n *\n * #### Notes\n * This message is sent to a widget before it is attached.\n */\n export const BeforeAttach = new Message('before-attach');\n\n /**\n * A singleton `'after-attach'` message.\n *\n * #### Notes\n * This message is sent to a widget after it is attached.\n */\n export const AfterAttach = new Message('after-attach');\n\n /**\n * A singleton `'before-detach'` message.\n *\n * #### Notes\n * This message is sent to a widget before it is detached.\n */\n export const BeforeDetach = new Message('before-detach');\n\n /**\n * A singleton `'after-detach'` message.\n *\n * #### Notes\n * This message is sent to a widget after it is detached.\n */\n export const AfterDetach = new Message('after-detach');\n\n /**\n * A singleton `'parent-changed'` message.\n *\n * #### Notes\n * This message is sent to a widget when its parent has changed.\n */\n export const ParentChanged = new Message('parent-changed');\n\n /**\n * A singleton conflatable `'update-request'` message.\n *\n * #### Notes\n * This message can be dispatched to supporting widgets in order to\n * update their content based on the current widget state. Not all\n * widgets will respond to messages of this type.\n *\n * For widgets with a layout, this message will inform the layout to\n * update the position and size of its child widgets.\n */\n export const UpdateRequest = new ConflatableMessage('update-request');\n\n /**\n * A singleton conflatable `'fit-request'` message.\n *\n * #### Notes\n * For widgets with a layout, this message will inform the layout to\n * recalculate its size constraints to fit the space requirements of\n * its child widgets, and to update their position and size. Not all\n * layouts will respond to messages of this type.\n */\n export const FitRequest = new ConflatableMessage('fit-request');\n\n /**\n * A singleton conflatable `'activate-request'` message.\n *\n * #### Notes\n * This message should be dispatched to a widget when it should\n * perform the actions necessary to activate the widget, which\n * may include focusing its node or descendant node.\n */\n export const ActivateRequest = new ConflatableMessage('activate-request');\n\n /**\n * A singleton conflatable `'close-request'` message.\n *\n * #### Notes\n * This message should be dispatched to a widget when it should close\n * and remove itself from the widget hierarchy.\n */\n export const CloseRequest = new ConflatableMessage('close-request');\n }\n\n /**\n * A message class for child related messages.\n */\n export class ChildMessage extends Message {\n /**\n * Construct a new child message.\n *\n * @param type - The message type.\n *\n * @param child - The child widget for the message.\n */\n constructor(type: string, child: Widget) {\n super(type);\n this.child = child;\n }\n\n /**\n * The child widget for the message.\n */\n readonly child: Widget;\n }\n\n /**\n * A message class for `'resize'` messages.\n */\n export class ResizeMessage extends Message {\n /**\n * Construct a new resize message.\n *\n * @param width - The **offset width** of the widget, or `-1` if\n * the width is not known.\n *\n * @param height - The **offset height** of the widget, or `-1` if\n * the height is not known.\n */\n constructor(width: number, height: number) {\n super('resize');\n this.width = width;\n this.height = height;\n }\n\n /**\n * The offset width of the widget.\n *\n * #### Notes\n * This will be `-1` if the width is unknown.\n */\n readonly width: number;\n\n /**\n * The offset height of the widget.\n *\n * #### Notes\n * This will be `-1` if the height is unknown.\n */\n readonly height: number;\n }\n\n /**\n * The namespace for the `ResizeMessage` class statics.\n */\n export namespace ResizeMessage {\n /**\n * A singleton `'resize'` message with an unknown size.\n */\n export const UnknownSize = new ResizeMessage(-1, -1);\n }\n\n /**\n * Attach a widget to a host DOM node.\n *\n * @param widget - The widget of interest.\n *\n * @param host - The DOM node to use as the widget's host.\n *\n * @param ref - The child of `host` to use as the reference element.\n * If this is provided, the widget will be inserted before this\n * node in the host. The default is `null`, which will cause the\n * widget to be added as the last child of the host.\n *\n * #### Notes\n * This will throw an error if the widget is not a root widget, if\n * the widget is already attached, or if the host is not attached\n * to the DOM.\n */\n export function attach(\n widget: Widget,\n host: HTMLElement,\n ref: HTMLElement | null = null\n ): void {\n if (widget.parent) {\n throw new Error('Cannot attach a child widget.');\n }\n if (widget.isAttached || widget.node.isConnected) {\n throw new Error('Widget is already attached.');\n }\n if (!host.isConnected) {\n throw new Error('Host is not attached.');\n }\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n host.insertBefore(widget.node, ref);\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n\n /**\n * Detach the widget from its host DOM node.\n *\n * @param widget - The widget of interest.\n *\n * #### Notes\n * This will throw an error if the widget is not a root widget,\n * or if the widget is not attached to the DOM.\n */\n export function detach(widget: Widget): void {\n if (widget.parent) {\n throw new Error('Cannot detach a child widget.');\n }\n if (!widget.isAttached || !widget.node.isConnected) {\n throw new Error('Widget is not attached.');\n }\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n widget.node.parentNode!.removeChild(widget.node);\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * An attached property for the widget title object.\n */\n export const titleProperty = new AttachedProperty>({\n name: 'title',\n create: owner => new Title({ owner })\n });\n\n /**\n * Create a DOM node for the given widget options.\n */\n export function createNode(options: Widget.IOptions): HTMLElement {\n return options.node || document.createElement(options.tag || 'div');\n }\n}\n","/* eslint-disable @typescript-eslint/no-empty-function */\n// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { Signal } from '@lumino/signaling';\n\nimport { Widget } from './widget';\n\n/**\n * An abstract base class for creating lumino layouts.\n *\n * #### Notes\n * A layout is used to add widgets to a parent and to arrange those\n * widgets within the parent's DOM node.\n *\n * This class implements the base functionality which is required of\n * nearly all layouts. It must be subclassed in order to be useful.\n *\n * Notably, this class does not define a uniform interface for adding\n * widgets to the layout. A subclass should define that API in a way\n * which is meaningful for its intended use.\n */\nexport abstract class Layout implements Iterable, IDisposable {\n /**\n * Construct a new layout.\n *\n * @param options - The options for initializing the layout.\n */\n constructor(options: Layout.IOptions = {}) {\n this._fitPolicy = options.fitPolicy || 'set-min-size';\n }\n\n /**\n * Dispose of the resources held by the layout.\n *\n * #### Notes\n * This should be reimplemented to clear and dispose of the widgets.\n *\n * All reimplementations should call the superclass method.\n *\n * This method is called automatically when the parent is disposed.\n */\n dispose(): void {\n this._parent = null;\n this._disposed = true;\n Signal.clearData(this);\n AttachedProperty.clearData(this);\n }\n\n /**\n * Test whether the layout is disposed.\n */\n get isDisposed(): boolean {\n return this._disposed;\n }\n\n /**\n * Get the parent widget of the layout.\n */\n get parent(): Widget | null {\n return this._parent;\n }\n\n /**\n * Set the parent widget of the layout.\n *\n * #### Notes\n * This is set automatically when installing the layout on the parent\n * widget. The parent widget should not be set directly by user code.\n */\n set parent(value: Widget | null) {\n if (this._parent === value) {\n return;\n }\n if (this._parent) {\n throw new Error('Cannot change parent widget.');\n }\n if (value!.layout !== this) {\n throw new Error('Invalid parent widget.');\n }\n this._parent = value;\n this.init();\n }\n\n /**\n * Get the fit policy for the layout.\n *\n * #### Notes\n * The fit policy controls the computed size constraints which are\n * applied to the parent widget by the layout.\n *\n * Some layout implementations may ignore the fit policy.\n */\n get fitPolicy(): Layout.FitPolicy {\n return this._fitPolicy;\n }\n\n /**\n * Set the fit policy for the layout.\n *\n * #### Notes\n * The fit policy controls the computed size constraints which are\n * applied to the parent widget by the layout.\n *\n * Some layout implementations may ignore the fit policy.\n *\n * Changing the fit policy will clear the current size constraint\n * for the parent widget and then re-fit the parent.\n */\n set fitPolicy(value: Layout.FitPolicy) {\n // Bail if the policy does not change\n if (this._fitPolicy === value) {\n return;\n }\n\n // Update the internal policy.\n this._fitPolicy = value;\n\n // Clear the size constraints and schedule a fit of the parent.\n if (this._parent) {\n let style = this._parent.node.style;\n style.minWidth = '';\n style.minHeight = '';\n style.maxWidth = '';\n style.maxHeight = '';\n this._parent.fit();\n }\n }\n\n /**\n * Create an iterator over the widgets in the layout.\n *\n * @returns A new iterator over the widgets in the layout.\n *\n * #### Notes\n * This abstract method must be implemented by a subclass.\n */\n abstract [Symbol.iterator](): IterableIterator;\n\n /**\n * Remove a widget from the layout.\n *\n * @param widget - The widget to remove from the layout.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method should *not* modify the widget's `parent`.\n */\n abstract removeWidget(widget: Widget): void;\n\n /**\n * Process a message sent to the parent widget.\n *\n * @param msg - The message sent to the parent widget.\n *\n * #### Notes\n * This method is called by the parent widget to process a message.\n *\n * Subclasses may reimplement this method as needed.\n */\n processParentMessage(msg: Message): void {\n switch (msg.type) {\n case 'resize':\n this.onResize(msg as Widget.ResizeMessage);\n break;\n case 'update-request':\n this.onUpdateRequest(msg);\n break;\n case 'fit-request':\n this.onFitRequest(msg);\n break;\n case 'before-show':\n this.onBeforeShow(msg);\n break;\n case 'after-show':\n this.onAfterShow(msg);\n break;\n case 'before-hide':\n this.onBeforeHide(msg);\n break;\n case 'after-hide':\n this.onAfterHide(msg);\n break;\n case 'before-attach':\n this.onBeforeAttach(msg);\n break;\n case 'after-attach':\n this.onAfterAttach(msg);\n break;\n case 'before-detach':\n this.onBeforeDetach(msg);\n break;\n case 'after-detach':\n this.onAfterDetach(msg);\n break;\n case 'child-removed':\n this.onChildRemoved(msg as Widget.ChildMessage);\n break;\n case 'child-shown':\n this.onChildShown(msg as Widget.ChildMessage);\n break;\n case 'child-hidden':\n this.onChildHidden(msg as Widget.ChildMessage);\n break;\n }\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n *\n * #### Notes\n * This method is invoked immediately after the layout is installed\n * on the parent widget.\n *\n * The default implementation reparents all of the widgets to the\n * layout parent widget.\n *\n * Subclasses should reimplement this method and attach the child\n * widget nodes to the parent widget's node.\n */\n protected init(): void {\n for (const widget of this) {\n widget.parent = this.parent;\n }\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n *\n * #### Notes\n * The layout should ensure that its widgets are resized according\n * to the specified layout space, and that they are sent a `'resize'`\n * message if appropriate.\n *\n * The default implementation of this method sends an `UnknownSize`\n * resize message to all widgets.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, Widget.ResizeMessage.UnknownSize);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n *\n * #### Notes\n * The layout should ensure that its widgets are resized according\n * to the available layout space, and that they are sent a `'resize'`\n * message if appropriate.\n *\n * The default implementation of this method sends an `UnknownSize`\n * resize message to all widgets.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onUpdateRequest(msg: Message): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, Widget.ResizeMessage.UnknownSize);\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message\n * to all widgets. It assumes all widget nodes are attached to the\n * parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onBeforeAttach(msg: Message): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n\n /**\n * A message handler invoked on an `'after-attach'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message\n * to all widgets. It assumes all widget nodes are attached to the\n * parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onAfterAttach(msg: Message): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n\n /**\n * A message handler invoked on a `'before-detach'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message\n * to all widgets. It assumes all widget nodes are attached to the\n * parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onBeforeDetach(msg: Message): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message\n * to all widgets. It assumes all widget nodes are attached to the\n * parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onAfterDetach(msg: Message): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message to\n * all non-hidden widgets. It assumes all widget nodes are attached\n * to the parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onBeforeShow(msg: Message): void {\n for (const widget of this) {\n if (!widget.isHidden) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n }\n\n /**\n * A message handler invoked on an `'after-show'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message to\n * all non-hidden widgets. It assumes all widget nodes are attached\n * to the parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onAfterShow(msg: Message): void {\n for (const widget of this) {\n if (!widget.isHidden) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n }\n\n /**\n * A message handler invoked on a `'before-hide'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message to\n * all non-hidden widgets. It assumes all widget nodes are attached\n * to the parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onBeforeHide(msg: Message): void {\n for (const widget of this) {\n if (!widget.isHidden) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n }\n\n /**\n * A message handler invoked on an `'after-hide'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message to\n * all non-hidden widgets. It assumes all widget nodes are attached\n * to the parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onAfterHide(msg: Message): void {\n for (const widget of this) {\n if (!widget.isHidden) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n }\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n *\n * #### Notes\n * This will remove the child widget from the layout.\n *\n * Subclasses should **not** typically reimplement this method.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {\n this.removeWidget(msg.child);\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onFitRequest(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {}\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {}\n\n private _disposed = false;\n private _fitPolicy: Layout.FitPolicy;\n private _parent: Widget | null = null;\n}\n\n/**\n * The namespace for the `Layout` class statics.\n */\nexport namespace Layout {\n /**\n * A type alias for the layout fit policy.\n *\n * #### Notes\n * The fit policy controls the computed size constraints which are\n * applied to the parent widget by the layout.\n *\n * Some layout implementations may ignore the fit policy.\n */\n export type FitPolicy =\n | /**\n * No size constraint will be applied to the parent widget.\n */\n 'set-no-constraint'\n\n /**\n * The computed min size will be applied to the parent widget.\n */\n | 'set-min-size';\n\n /**\n * An options object for initializing a layout.\n */\n export interface IOptions {\n /**\n * The fit policy for the layout.\n *\n * The default is `'set-min-size'`.\n */\n fitPolicy?: FitPolicy;\n }\n\n /**\n * A type alias for the horizontal alignment of a widget.\n */\n export type HorizontalAlignment = 'left' | 'center' | 'right';\n\n /**\n * A type alias for the vertical alignment of a widget.\n */\n export type VerticalAlignment = 'top' | 'center' | 'bottom';\n\n /**\n * Get the horizontal alignment for a widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The horizontal alignment for the widget.\n *\n * #### Notes\n * If the layout width allocated to a widget is larger than its max\n * width, the horizontal alignment controls how the widget is placed\n * within the extra horizontal space.\n *\n * If the allocated width is less than the widget's max width, the\n * horizontal alignment has no effect.\n *\n * Some layout implementations may ignore horizontal alignment.\n */\n export function getHorizontalAlignment(widget: Widget): HorizontalAlignment {\n return Private.horizontalAlignmentProperty.get(widget);\n }\n\n /**\n * Set the horizontal alignment for a widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the horizontal alignment.\n *\n * #### Notes\n * If the layout width allocated to a widget is larger than its max\n * width, the horizontal alignment controls how the widget is placed\n * within the extra horizontal space.\n *\n * If the allocated width is less than the widget's max width, the\n * horizontal alignment has no effect.\n *\n * Some layout implementations may ignore horizontal alignment.\n *\n * Changing the horizontal alignment will post an `update-request`\n * message to widget's parent, provided the parent has a layout\n * installed.\n */\n export function setHorizontalAlignment(\n widget: Widget,\n value: HorizontalAlignment\n ): void {\n Private.horizontalAlignmentProperty.set(widget, value);\n }\n\n /**\n * Get the vertical alignment for a widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The vertical alignment for the widget.\n *\n * #### Notes\n * If the layout height allocated to a widget is larger than its max\n * height, the vertical alignment controls how the widget is placed\n * within the extra vertical space.\n *\n * If the allocated height is less than the widget's max height, the\n * vertical alignment has no effect.\n *\n * Some layout implementations may ignore vertical alignment.\n */\n export function getVerticalAlignment(widget: Widget): VerticalAlignment {\n return Private.verticalAlignmentProperty.get(widget);\n }\n\n /**\n * Set the vertical alignment for a widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the vertical alignment.\n *\n * #### Notes\n * If the layout height allocated to a widget is larger than its max\n * height, the vertical alignment controls how the widget is placed\n * within the extra vertical space.\n *\n * If the allocated height is less than the widget's max height, the\n * vertical alignment has no effect.\n *\n * Some layout implementations may ignore vertical alignment.\n *\n * Changing the horizontal alignment will post an `update-request`\n * message to widget's parent, provided the parent has a layout\n * installed.\n */\n export function setVerticalAlignment(\n widget: Widget,\n value: VerticalAlignment\n ): void {\n Private.verticalAlignmentProperty.set(widget, value);\n }\n}\n\n/**\n * An object which assists in the absolute layout of widgets.\n *\n * #### Notes\n * This class is useful when implementing a layout which arranges its\n * widgets using absolute positioning.\n *\n * This class is used by nearly all of the built-in lumino layouts.\n */\nexport class LayoutItem implements IDisposable {\n /**\n * Construct a new layout item.\n *\n * @param widget - The widget to be managed by the item.\n *\n * #### Notes\n * The widget will be set to absolute positioning.\n * The widget will use strict CSS containment.\n */\n constructor(widget: Widget) {\n this.widget = widget;\n this.widget.node.style.position = 'absolute';\n this.widget.node.style.contain = 'strict';\n }\n\n /**\n * Dispose of the the layout item.\n *\n * #### Notes\n * This will reset the positioning of the widget.\n */\n dispose(): void {\n // Do nothing if the item is already disposed.\n if (this._disposed) {\n return;\n }\n\n // Mark the item as disposed.\n this._disposed = true;\n\n // Reset the widget style.\n let style = this.widget.node.style;\n style.position = '';\n style.top = '';\n style.left = '';\n style.width = '';\n style.height = '';\n style.contain = '';\n }\n\n /**\n * The widget managed by the layout item.\n */\n readonly widget: Widget;\n\n /**\n * The computed minimum width of the widget.\n *\n * #### Notes\n * This value can be updated by calling the `fit` method.\n */\n get minWidth(): number {\n return this._minWidth;\n }\n\n /**\n * The computed minimum height of the widget.\n *\n * #### Notes\n * This value can be updated by calling the `fit` method.\n */\n get minHeight(): number {\n return this._minHeight;\n }\n\n /**\n * The computed maximum width of the widget.\n *\n * #### Notes\n * This value can be updated by calling the `fit` method.\n */\n get maxWidth(): number {\n return this._maxWidth;\n }\n\n /**\n * The computed maximum height of the widget.\n *\n * #### Notes\n * This value can be updated by calling the `fit` method.\n */\n get maxHeight(): number {\n return this._maxHeight;\n }\n\n /**\n * Whether the layout item is disposed.\n */\n get isDisposed(): boolean {\n return this._disposed;\n }\n\n /**\n * Whether the managed widget is hidden.\n */\n get isHidden(): boolean {\n return this.widget.isHidden;\n }\n\n /**\n * Whether the managed widget is visible.\n */\n get isVisible(): boolean {\n return this.widget.isVisible;\n }\n\n /**\n * Whether the managed widget is attached.\n */\n get isAttached(): boolean {\n return this.widget.isAttached;\n }\n\n /**\n * Update the computed size limits of the managed widget.\n */\n fit(): void {\n let limits = ElementExt.sizeLimits(this.widget.node);\n this._minWidth = limits.minWidth;\n this._minHeight = limits.minHeight;\n this._maxWidth = limits.maxWidth;\n this._maxHeight = limits.maxHeight;\n }\n\n /**\n * Update the position and size of the managed widget.\n *\n * @param left - The left edge position of the layout box.\n *\n * @param top - The top edge position of the layout box.\n *\n * @param width - The width of the layout box.\n *\n * @param height - The height of the layout box.\n */\n update(left: number, top: number, width: number, height: number): void {\n // Clamp the size to the computed size limits.\n let clampW = Math.max(this._minWidth, Math.min(width, this._maxWidth));\n let clampH = Math.max(this._minHeight, Math.min(height, this._maxHeight));\n\n // Adjust the left edge for the horizontal alignment, if needed.\n if (clampW < width) {\n switch (Layout.getHorizontalAlignment(this.widget)) {\n case 'left':\n break;\n case 'center':\n left += (width - clampW) / 2;\n break;\n case 'right':\n left += width - clampW;\n break;\n default:\n throw 'unreachable';\n }\n }\n\n // Adjust the top edge for the vertical alignment, if needed.\n if (clampH < height) {\n switch (Layout.getVerticalAlignment(this.widget)) {\n case 'top':\n break;\n case 'center':\n top += (height - clampH) / 2;\n break;\n case 'bottom':\n top += height - clampH;\n break;\n default:\n throw 'unreachable';\n }\n }\n\n // Set up the resize variables.\n let resized = false;\n let style = this.widget.node.style;\n\n // Update the top edge of the widget if needed.\n if (this._top !== top) {\n this._top = top;\n style.top = `${top}px`;\n }\n\n // Update the left edge of the widget if needed.\n if (this._left !== left) {\n this._left = left;\n style.left = `${left}px`;\n }\n\n // Update the width of the widget if needed.\n if (this._width !== clampW) {\n resized = true;\n this._width = clampW;\n style.width = `${clampW}px`;\n }\n\n // Update the height of the widget if needed.\n if (this._height !== clampH) {\n resized = true;\n this._height = clampH;\n style.height = `${clampH}px`;\n }\n\n // Send a resize message to the widget if needed.\n if (resized) {\n let msg = new Widget.ResizeMessage(clampW, clampH);\n MessageLoop.sendMessage(this.widget, msg);\n }\n }\n\n private _top = NaN;\n private _left = NaN;\n private _width = NaN;\n private _height = NaN;\n private _minWidth = 0;\n private _minHeight = 0;\n private _maxWidth = Infinity;\n private _maxHeight = Infinity;\n private _disposed = false;\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The attached property for a widget horizontal alignment.\n */\n export const horizontalAlignmentProperty = new AttachedProperty<\n Widget,\n Layout.HorizontalAlignment\n >({\n name: 'horizontalAlignment',\n create: () => 'center',\n changed: onAlignmentChanged\n });\n\n /**\n * The attached property for a widget vertical alignment.\n */\n export const verticalAlignmentProperty = new AttachedProperty<\n Widget,\n Layout.VerticalAlignment\n >({\n name: 'verticalAlignment',\n create: () => 'top',\n changed: onAlignmentChanged\n });\n\n /**\n * The change handler for the attached alignment properties.\n */\n function onAlignmentChanged(child: Widget): void {\n if (child.parent && child.parent.layout) {\n child.parent.update();\n }\n }\n}\n","/*\n * Copyright (c) Jupyter Development Team.\n * Distributed under the terms of the Modified BSD License.\n */\n\nexport namespace Utils {\n /**\n * Clamp a dimension value to an integer >= 0.\n */\n export function clampDimension(value: number): number {\n return Math.max(0, Math.floor(value));\n }\n}\n\nexport default Utils;\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { VirtualElement } from '@lumino/virtualdom';\n\n/**\n * An object which holds data related to an object's title.\n *\n * #### Notes\n * A title object is intended to hold the data necessary to display a\n * header for a particular object. A common example is the `TabPanel`,\n * which uses the widget title to populate the tab for a child widget.\n *\n * It is the responsibility of the owner to call the title disposal.\n */\nexport class Title implements IDisposable {\n /**\n * Construct a new title.\n *\n * @param options - The options for initializing the title.\n */\n constructor(options: Title.IOptions) {\n this.owner = options.owner;\n if (options.label !== undefined) {\n this._label = options.label;\n }\n if (options.mnemonic !== undefined) {\n this._mnemonic = options.mnemonic;\n }\n if (options.icon !== undefined) {\n this._icon = options.icon;\n }\n\n if (options.iconClass !== undefined) {\n this._iconClass = options.iconClass;\n }\n if (options.iconLabel !== undefined) {\n this._iconLabel = options.iconLabel;\n }\n if (options.caption !== undefined) {\n this._caption = options.caption;\n }\n if (options.className !== undefined) {\n this._className = options.className;\n }\n if (options.closable !== undefined) {\n this._closable = options.closable;\n }\n this._dataset = options.dataset || {};\n }\n\n /**\n * A signal emitted when the state of the title changes.\n */\n get changed(): ISignal {\n return this._changed;\n }\n\n /**\n * The object which owns the title.\n */\n readonly owner: T;\n\n /**\n * Get the label for the title.\n *\n * #### Notes\n * The default value is an empty string.\n */\n get label(): string {\n return this._label;\n }\n\n /**\n * Set the label for the title.\n */\n set label(value: string) {\n if (this._label === value) {\n return;\n }\n this._label = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the mnemonic index for the title.\n *\n * #### Notes\n * The default value is `-1`.\n */\n get mnemonic(): number {\n return this._mnemonic;\n }\n\n /**\n * Set the mnemonic index for the title.\n */\n set mnemonic(value: number) {\n if (this._mnemonic === value) {\n return;\n }\n this._mnemonic = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the icon renderer for the title.\n *\n * #### Notes\n * The default value is undefined.\n */\n get icon(): VirtualElement.IRenderer | undefined {\n return this._icon;\n }\n\n /**\n * Set the icon renderer for the title.\n *\n * #### Notes\n * A renderer is an object that supplies a render and unrender function.\n */\n set icon(value: VirtualElement.IRenderer | undefined) {\n if (this._icon === value) {\n return;\n }\n this._icon = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the icon class name for the title.\n *\n * #### Notes\n * The default value is an empty string.\n */\n get iconClass(): string {\n return this._iconClass;\n }\n\n /**\n * Set the icon class name for the title.\n *\n * #### Notes\n * Multiple class names can be separated with whitespace.\n */\n set iconClass(value: string) {\n if (this._iconClass === value) {\n return;\n }\n this._iconClass = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the icon label for the title.\n *\n * #### Notes\n * The default value is an empty string.\n */\n get iconLabel(): string {\n return this._iconLabel;\n }\n\n /**\n * Set the icon label for the title.\n *\n * #### Notes\n * Multiple class names can be separated with whitespace.\n */\n set iconLabel(value: string) {\n if (this._iconLabel === value) {\n return;\n }\n this._iconLabel = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the caption for the title.\n *\n * #### Notes\n * The default value is an empty string.\n */\n get caption(): string {\n return this._caption;\n }\n\n /**\n * Set the caption for the title.\n */\n set caption(value: string) {\n if (this._caption === value) {\n return;\n }\n this._caption = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the extra class name for the title.\n *\n * #### Notes\n * The default value is an empty string.\n */\n get className(): string {\n return this._className;\n }\n\n /**\n * Set the extra class name for the title.\n *\n * #### Notes\n * Multiple class names can be separated with whitespace.\n */\n set className(value: string) {\n if (this._className === value) {\n return;\n }\n this._className = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the closable state for the title.\n *\n * #### Notes\n * The default value is `false`.\n */\n get closable(): boolean {\n return this._closable;\n }\n\n /**\n * Set the closable state for the title.\n *\n * #### Notes\n * This controls the presence of a close icon when applicable.\n */\n set closable(value: boolean) {\n if (this._closable === value) {\n return;\n }\n this._closable = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the dataset for the title.\n *\n * #### Notes\n * The default value is an empty dataset.\n */\n get dataset(): Title.Dataset {\n return this._dataset;\n }\n\n /**\n * Set the dataset for the title.\n *\n * #### Notes\n * This controls the data attributes when applicable.\n */\n set dataset(value: Title.Dataset) {\n if (this._dataset === value) {\n return;\n }\n this._dataset = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Test whether the title has been disposed.\n */\n get isDisposed(): boolean {\n return this._isDisposed;\n }\n\n /**\n * Dispose of the resources held by the title.\n *\n * #### Notes\n * It is the responsibility of the owner to call the title disposal.\n */\n dispose(): void {\n if (this.isDisposed) {\n return;\n }\n this._isDisposed = true;\n\n Signal.clearData(this);\n }\n\n private _label = '';\n private _caption = '';\n private _mnemonic = -1;\n private _icon: VirtualElement.IRenderer | undefined = undefined;\n private _iconClass = '';\n private _iconLabel = '';\n private _className = '';\n private _closable = false;\n private _dataset: Title.Dataset;\n private _changed = new Signal(this);\n private _isDisposed = false;\n}\n\n/**\n * The namespace for the `Title` class statics.\n */\nexport namespace Title {\n /**\n * A type alias for a simple immutable string dataset.\n */\n export type Dataset = { readonly [key: string]: string };\n\n /**\n * An options object for initializing a title.\n */\n export interface IOptions {\n /**\n * The object which owns the title.\n */\n owner: T;\n\n /**\n * The label for the title.\n */\n label?: string;\n\n /**\n * The mnemonic index for the title.\n */\n mnemonic?: number;\n\n /**\n * The icon renderer for the title.\n */\n icon?: VirtualElement.IRenderer;\n\n /**\n * The icon class name for the title.\n */\n iconClass?: string;\n\n /**\n * The icon label for the title.\n */\n iconLabel?: string;\n\n /**\n * The caption for the title.\n */\n caption?: string;\n\n /**\n * The extra class name for the title.\n */\n className?: string;\n\n /**\n * The closable state for the title.\n */\n closable?: boolean;\n\n /**\n * The dataset for the title.\n */\n dataset?: Dataset;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { MessageLoop } from '@lumino/messaging';\n\nimport { Layout } from './layout';\n\nimport { Widget } from './widget';\n\n/**\n * A concrete layout implementation suitable for many use cases.\n *\n * #### Notes\n * This class is suitable as a base class for implementing a variety of\n * layouts, but can also be used directly with standard CSS to layout a\n * collection of widgets.\n */\nexport class PanelLayout extends Layout {\n /**\n * Dispose of the resources held by the layout.\n *\n * #### Notes\n * This will clear and dispose all widgets in the layout.\n *\n * All reimplementations should call the superclass method.\n *\n * This method is called automatically when the parent is disposed.\n */\n dispose(): void {\n while (this._widgets.length > 0) {\n this._widgets.pop()!.dispose();\n }\n super.dispose();\n }\n\n /**\n * A read-only array of the widgets in the layout.\n */\n get widgets(): ReadonlyArray {\n return this._widgets;\n }\n\n /**\n * Create an iterator over the widgets in the layout.\n *\n * @returns A new iterator over the widgets in the layout.\n */\n *[Symbol.iterator](): IterableIterator {\n yield* this._widgets;\n }\n\n /**\n * Add a widget to the end of the layout.\n *\n * @param widget - The widget to add to the layout.\n *\n * #### Notes\n * If the widget is already contained in the layout, it will be moved.\n */\n addWidget(widget: Widget): void {\n this.insertWidget(this._widgets.length, widget);\n }\n\n /**\n * Insert a widget into the layout at the specified index.\n *\n * @param index - The index at which to insert the widget.\n *\n * @param widget - The widget to insert into the layout.\n *\n * #### Notes\n * The index will be clamped to the bounds of the widgets.\n *\n * If the widget is already added to the layout, it will be moved.\n *\n * #### Undefined Behavior\n * An `index` which is non-integral.\n */\n insertWidget(index: number, widget: Widget): void {\n // Remove the widget from its current parent. This is a no-op\n // if the widget's parent is already the layout parent widget.\n widget.parent = this.parent;\n\n // Look up the current index of the widget.\n let i = this._widgets.indexOf(widget);\n\n // Clamp the insert index to the array bounds.\n let j = Math.max(0, Math.min(index, this._widgets.length));\n\n // If the widget is not in the array, insert it.\n if (i === -1) {\n // Insert the widget into the array.\n ArrayExt.insert(this._widgets, j, widget);\n\n // If the layout is parented, attach the widget to the DOM.\n if (this.parent) {\n this.attachWidget(j, widget);\n }\n\n // There is nothing more to do.\n return;\n }\n\n // Otherwise, the widget exists in the array and should be moved.\n\n // Adjust the index if the location is at the end of the array.\n if (j === this._widgets.length) {\n j--;\n }\n\n // Bail if there is no effective move.\n if (i === j) {\n return;\n }\n\n // Move the widget to the new location.\n ArrayExt.move(this._widgets, i, j);\n\n // If the layout is parented, move the widget in the DOM.\n if (this.parent) {\n this.moveWidget(i, j, widget);\n }\n }\n\n /**\n * Remove a widget from the layout.\n *\n * @param widget - The widget to remove from the layout.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method does *not* modify the widget's `parent`.\n */\n removeWidget(widget: Widget): void {\n this.removeWidgetAt(this._widgets.indexOf(widget));\n }\n\n /**\n * Remove the widget at a given index from the layout.\n *\n * @param index - The index of the widget to remove.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method does *not* modify the widget's `parent`.\n *\n * #### Undefined Behavior\n * An `index` which is non-integral.\n */\n removeWidgetAt(index: number): void {\n // Remove the widget from the array.\n let widget = ArrayExt.removeAt(this._widgets, index);\n\n // If the layout is parented, detach the widget from the DOM.\n if (widget && this.parent) {\n this.detachWidget(index, widget);\n }\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n super.init();\n let index = 0;\n for (const widget of this) {\n this.attachWidget(index++, widget);\n }\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param index - The current index of the widget in the layout.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This method is called automatically by the panel layout at the\n * appropriate time. It should not be called directly by user code.\n *\n * The default implementation adds the widgets's node to the parent's\n * node at the proper location, and sends the appropriate attach\n * messages to the widget if the parent is attached to the DOM.\n *\n * Subclasses may reimplement this method to control how the widget's\n * node is added to the parent's node.\n */\n protected attachWidget(index: number, widget: Widget): void {\n // Look up the next sibling reference node.\n let ref = this.parent!.node.children[index];\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Insert the widget's node before the sibling.\n this.parent!.node.insertBefore(widget.node, ref);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n }\n\n /**\n * Move a widget in the parent's DOM node.\n *\n * @param fromIndex - The previous index of the widget in the layout.\n *\n * @param toIndex - The current index of the widget in the layout.\n *\n * @param widget - The widget to move in the parent.\n *\n * #### Notes\n * This method is called automatically by the panel layout at the\n * appropriate time. It should not be called directly by user code.\n *\n * The default implementation moves the widget's node to the proper\n * location in the parent's node and sends the appropriate attach and\n * detach messages to the widget if the parent is attached to the DOM.\n *\n * Subclasses may reimplement this method to control how the widget's\n * node is moved in the parent's node.\n */\n protected moveWidget(\n fromIndex: number,\n toIndex: number,\n widget: Widget\n ): void {\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` and message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Look up the next sibling reference node.\n let ref = this.parent!.node.children[toIndex];\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Insert the widget's node before the sibling.\n this.parent!.node.insertBefore(widget.node, ref);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param index - The previous index of the widget in the layout.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This method is called automatically by the panel layout at the\n * appropriate time. It should not be called directly by user code.\n *\n * The default implementation removes the widget's node from the\n * parent's node, and sends the appropriate detach messages to the\n * widget if the parent is attached to the DOM.\n *\n * Subclasses may reimplement this method to control how the widget's\n * node is removed from the parent's node.\n */\n protected detachWidget(index: number, widget: Widget): void {\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n }\n\n private _widgets: Widget[] = [];\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { BoxEngine, BoxSizer } from './boxengine';\n\nimport { LayoutItem } from './layout';\n\nimport { PanelLayout } from './panellayout';\n\nimport { Utils } from './utils';\n\nimport { Widget } from './widget';\n\n/**\n * A layout which arranges its widgets into resizable sections.\n */\nexport class SplitLayout extends PanelLayout {\n /**\n * Construct a new split layout.\n *\n * @param options - The options for initializing the layout.\n */\n constructor(options: SplitLayout.IOptions) {\n super();\n this.renderer = options.renderer;\n if (options.orientation !== undefined) {\n this._orientation = options.orientation;\n }\n if (options.alignment !== undefined) {\n this._alignment = options.alignment;\n }\n if (options.spacing !== undefined) {\n this._spacing = Utils.clampDimension(options.spacing);\n }\n }\n\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n // Dispose of the layout items.\n for (const item of this._items) {\n item.dispose();\n }\n\n // Clear the layout state.\n this._box = null;\n this._items.length = 0;\n this._sizers.length = 0;\n this._handles.length = 0;\n\n // Dispose of the rest of the layout.\n super.dispose();\n }\n\n /**\n * The renderer used by the split layout.\n */\n readonly renderer: SplitLayout.IRenderer;\n\n /**\n * Get the layout orientation for the split layout.\n */\n get orientation(): SplitLayout.Orientation {\n return this._orientation;\n }\n\n /**\n * Set the layout orientation for the split layout.\n */\n set orientation(value: SplitLayout.Orientation) {\n if (this._orientation === value) {\n return;\n }\n this._orientation = value;\n if (!this.parent) {\n return;\n }\n this.parent.dataset['orientation'] = value;\n this.parent.fit();\n }\n\n /**\n * Get the content alignment for the split layout.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire split layout.\n */\n get alignment(): SplitLayout.Alignment {\n return this._alignment;\n }\n\n /**\n * Set the content alignment for the split layout.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire split layout.\n */\n set alignment(value: SplitLayout.Alignment) {\n if (this._alignment === value) {\n return;\n }\n this._alignment = value;\n if (!this.parent) {\n return;\n }\n this.parent.dataset['alignment'] = value;\n this.parent.update();\n }\n\n /**\n * Get the inter-element spacing for the split layout.\n */\n get spacing(): number {\n return this._spacing;\n }\n\n /**\n * Set the inter-element spacing for the split layout.\n */\n set spacing(value: number) {\n value = Utils.clampDimension(value);\n if (this._spacing === value) {\n return;\n }\n this._spacing = value;\n if (!this.parent) {\n return;\n }\n this.parent.fit();\n }\n\n /**\n * A read-only array of the split handles in the layout.\n */\n get handles(): ReadonlyArray {\n return this._handles;\n }\n\n /**\n * Get the absolute sizes of the widgets in the layout.\n *\n * @returns A new array of the absolute sizes of the widgets.\n *\n * This method **does not** measure the DOM nodes.\n */\n absoluteSizes(): number[] {\n return this._sizers.map(sizer => sizer.size);\n }\n\n /**\n * Get the relative sizes of the widgets in the layout.\n *\n * @returns A new array of the relative sizes of the widgets.\n *\n * #### Notes\n * The returned sizes reflect the sizes of the widgets normalized\n * relative to their siblings.\n *\n * This method **does not** measure the DOM nodes.\n */\n relativeSizes(): number[] {\n return Private.normalize(this._sizers.map(sizer => sizer.size));\n }\n\n /**\n * Set the relative sizes for the widgets in the layout.\n *\n * @param sizes - The relative sizes for the widgets in the panel.\n * @param update - Update the layout after setting relative sizes.\n * Default is True.\n *\n * #### Notes\n * Extra values are ignored, too few will yield an undefined layout.\n *\n * The actual geometry of the DOM nodes is updated asynchronously.\n */\n setRelativeSizes(sizes: number[], update = true): void {\n // Copy the sizes and pad with zeros as needed.\n let n = this._sizers.length;\n let temp = sizes.slice(0, n);\n while (temp.length < n) {\n temp.push(0);\n }\n\n // Normalize the padded sizes.\n let normed = Private.normalize(temp);\n\n // Apply the normalized sizes to the sizers.\n for (let i = 0; i < n; ++i) {\n let sizer = this._sizers[i];\n sizer.sizeHint = normed[i];\n sizer.size = normed[i];\n }\n\n // Set the flag indicating the sizes are normalized.\n this._hasNormedSizes = true;\n\n // Trigger an update of the parent widget.\n if (update && this.parent) {\n this.parent.update();\n }\n }\n\n /**\n * Move the offset position of a split handle.\n *\n * @param index - The index of the handle of the interest.\n *\n * @param position - The desired offset position of the handle.\n *\n * #### Notes\n * The position is relative to the offset parent.\n *\n * This will move the handle as close as possible to the desired\n * position. The sibling widgets will be adjusted as necessary.\n */\n moveHandle(index: number, position: number): void {\n // Bail if the index is invalid or the handle is hidden.\n let handle = this._handles[index];\n if (!handle || handle.classList.contains('lm-mod-hidden')) {\n return;\n }\n\n // Compute the desired delta movement for the handle.\n let delta: number;\n if (this._orientation === 'horizontal') {\n delta = position - handle.offsetLeft;\n } else {\n delta = position - handle.offsetTop;\n }\n\n // Bail if there is no handle movement.\n if (delta === 0) {\n return;\n }\n\n // Prevent widget resizing unless needed.\n for (let sizer of this._sizers) {\n if (sizer.size > 0) {\n sizer.sizeHint = sizer.size;\n }\n }\n\n // Adjust the sizers to reflect the handle movement.\n BoxEngine.adjust(this._sizers, index, delta);\n\n // Update the layout of the widgets.\n if (this.parent) {\n this.parent.update();\n }\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n this.parent!.dataset['orientation'] = this.orientation;\n this.parent!.dataset['alignment'] = this.alignment;\n super.init();\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param index - The current index of the widget in the layout.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected attachWidget(index: number, widget: Widget): void {\n // Create the item, handle, and sizer for the new widget.\n let item = new LayoutItem(widget);\n let handle = Private.createHandle(this.renderer);\n let average = Private.averageSize(this._sizers);\n let sizer = Private.createSizer(average);\n\n // Insert the item, handle, and sizer into the internal arrays.\n ArrayExt.insert(this._items, index, item);\n ArrayExt.insert(this._sizers, index, sizer);\n ArrayExt.insert(this._handles, index, handle);\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget and handle nodes to the parent.\n this.parent!.node.appendChild(widget.node);\n this.parent!.node.appendChild(handle);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * Move a widget in the parent's DOM node.\n *\n * @param fromIndex - The previous index of the widget in the layout.\n *\n * @param toIndex - The current index of the widget in the layout.\n *\n * @param widget - The widget to move in the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected moveWidget(\n fromIndex: number,\n toIndex: number,\n widget: Widget\n ): void {\n // Move the item, sizer, and handle for the widget.\n ArrayExt.move(this._items, fromIndex, toIndex);\n ArrayExt.move(this._sizers, fromIndex, toIndex);\n ArrayExt.move(this._handles, fromIndex, toIndex);\n\n // Post a fit request to the parent to show/hide last handle.\n this.parent!.fit();\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param index - The previous index of the widget in the layout.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected detachWidget(index: number, widget: Widget): void {\n // Remove the item, handle, and sizer for the widget.\n let item = ArrayExt.removeAt(this._items, index);\n let handle = ArrayExt.removeAt(this._handles, index);\n ArrayExt.removeAt(this._sizers, index);\n\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget and handle nodes from the parent.\n this.parent!.node.removeChild(widget.node);\n this.parent!.node.removeChild(handle!);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Dispose of the layout item.\n item!.dispose();\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n */\n protected onBeforeShow(msg: Message): void {\n super.onBeforeShow(msg);\n this.parent!.update();\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n super.onBeforeAttach(msg);\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n if (this.parent!.isVisible) {\n this._update(msg.width, msg.height);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.parent!.isVisible) {\n this._update(-1, -1);\n }\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n */\n protected onFitRequest(msg: Message): void {\n if (this.parent!.isAttached) {\n this._fit();\n }\n }\n\n /**\n * Update the item position.\n *\n * @param i Item index\n * @param isHorizontal Whether the layout is horizontal or not\n * @param left Left position in pixels\n * @param top Top position in pixels\n * @param height Item height\n * @param width Item width\n * @param size Item size\n */\n protected updateItemPosition(\n i: number,\n isHorizontal: boolean,\n left: number,\n top: number,\n height: number,\n width: number,\n size: number\n ): void {\n const item = this._items[i];\n if (item.isHidden) {\n return;\n }\n\n // Fetch the style for the handle.\n let handleStyle = this._handles[i].style;\n\n // Update the widget and handle, and advance the relevant edge.\n if (isHorizontal) {\n left += this.widgetOffset;\n item.update(left, top, size, height);\n left += size;\n handleStyle.top = `${top}px`;\n handleStyle.left = `${left}px`;\n handleStyle.width = `${this._spacing}px`;\n handleStyle.height = `${height}px`;\n } else {\n top += this.widgetOffset;\n item.update(left, top, width, size);\n top += size;\n handleStyle.top = `${top}px`;\n handleStyle.left = `${left}px`;\n handleStyle.width = `${width}px`;\n handleStyle.height = `${this._spacing}px`;\n }\n }\n\n /**\n * Fit the layout to the total size required by the widgets.\n */\n private _fit(): void {\n // Update the handles and track the visible widget count.\n let nVisible = 0;\n let lastHandleIndex = -1;\n for (let i = 0, n = this._items.length; i < n; ++i) {\n if (this._items[i].isHidden) {\n this._handles[i].classList.add('lm-mod-hidden');\n } else {\n this._handles[i].classList.remove('lm-mod-hidden');\n lastHandleIndex = i;\n nVisible++;\n }\n }\n\n // Hide the handle for the last visible widget.\n if (lastHandleIndex !== -1) {\n this._handles[lastHandleIndex].classList.add('lm-mod-hidden');\n }\n\n // Update the fixed space for the visible items.\n this._fixed =\n this._spacing * Math.max(0, nVisible - 1) +\n this.widgetOffset * this._items.length;\n\n // Setup the computed minimum size.\n let horz = this._orientation === 'horizontal';\n let minW = horz ? this._fixed : 0;\n let minH = horz ? 0 : this._fixed;\n\n // Update the sizers and computed size limits.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item and corresponding box sizer.\n let item = this._items[i];\n let sizer = this._sizers[i];\n\n // Prevent resizing unless necessary.\n if (sizer.size > 0) {\n sizer.sizeHint = sizer.size;\n }\n\n // If the item is hidden, it should consume zero size.\n if (item.isHidden) {\n sizer.minSize = 0;\n sizer.maxSize = 0;\n continue;\n }\n\n // Update the size limits for the item.\n item.fit();\n\n // Update the stretch factor.\n sizer.stretch = SplitLayout.getStretch(item.widget);\n\n // Update the sizer limits and computed min size.\n if (horz) {\n sizer.minSize = item.minWidth;\n sizer.maxSize = item.maxWidth;\n minW += item.minWidth;\n minH = Math.max(minH, item.minHeight);\n } else {\n sizer.minSize = item.minHeight;\n sizer.maxSize = item.maxHeight;\n minH += item.minHeight;\n minW = Math.max(minW, item.minWidth);\n }\n }\n\n // Update the box sizing and add it to the computed min size.\n let box = (this._box = ElementExt.boxSizing(this.parent!.node));\n minW += box.horizontalSum;\n minH += box.verticalSum;\n\n // Update the parent's min size constraints.\n let style = this.parent!.node.style;\n style.minWidth = `${minW}px`;\n style.minHeight = `${minH}px`;\n\n // Set the dirty flag to ensure only a single update occurs.\n this._dirty = true;\n\n // Notify the ancestor that it should fit immediately. This may\n // cause a resize of the parent, fulfilling the required update.\n if (this.parent!.parent) {\n MessageLoop.sendMessage(this.parent!.parent!, Widget.Msg.FitRequest);\n }\n\n // If the dirty flag is still set, the parent was not resized.\n // Trigger the required update on the parent widget immediately.\n if (this._dirty) {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n }\n }\n\n /**\n * Update the layout position and size of the widgets.\n *\n * The parent offset dimensions should be `-1` if unknown.\n */\n private _update(offsetWidth: number, offsetHeight: number): void {\n // Clear the dirty flag to indicate the update occurred.\n this._dirty = false;\n\n // Compute the visible item count.\n let nVisible = 0;\n for (let i = 0, n = this._items.length; i < n; ++i) {\n nVisible += +!this._items[i].isHidden;\n }\n\n // Bail early if there are no visible items to layout.\n if (nVisible === 0 && this.widgetOffset === 0) {\n return;\n }\n\n // Measure the parent if the offset dimensions are unknown.\n if (offsetWidth < 0) {\n offsetWidth = this.parent!.node.offsetWidth;\n }\n if (offsetHeight < 0) {\n offsetHeight = this.parent!.node.offsetHeight;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent!.node);\n }\n\n // Compute the actual layout bounds adjusted for border and padding.\n let top = this._box.paddingTop;\n let left = this._box.paddingLeft;\n let width = offsetWidth - this._box.horizontalSum;\n let height = offsetHeight - this._box.verticalSum;\n\n // Set up the variables for justification and alignment offset.\n let extra = 0;\n let offset = 0;\n let horz = this._orientation === 'horizontal';\n\n if (nVisible > 0) {\n // Compute the adjusted layout space.\n let space: number;\n if (horz) {\n // left += this.widgetOffset;\n space = Math.max(0, width - this._fixed);\n } else {\n // top += this.widgetOffset;\n space = Math.max(0, height - this._fixed);\n }\n\n // Scale the size hints if they are normalized.\n if (this._hasNormedSizes) {\n for (let sizer of this._sizers) {\n sizer.sizeHint *= space;\n }\n this._hasNormedSizes = false;\n }\n\n // Distribute the layout space to the box sizers.\n let delta = BoxEngine.calc(this._sizers, space);\n\n // Account for alignment if there is extra layout space.\n if (delta > 0) {\n switch (this._alignment) {\n case 'start':\n break;\n case 'center':\n extra = 0;\n offset = delta / 2;\n break;\n case 'end':\n extra = 0;\n offset = delta;\n break;\n case 'justify':\n extra = delta / nVisible;\n offset = 0;\n break;\n default:\n throw 'unreachable';\n }\n }\n }\n\n // Layout the items using the computed box sizes.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item.\n const item = this._items[i];\n\n // Fetch the computed size for the widget.\n const size = item.isHidden ? 0 : this._sizers[i].size + extra;\n\n this.updateItemPosition(\n i,\n horz,\n horz ? left + offset : left,\n horz ? top : top + offset,\n height,\n width,\n size\n );\n\n const fullOffset =\n this.widgetOffset +\n (this._handles[i].classList.contains('lm-mod-hidden')\n ? 0\n : this._spacing);\n\n if (horz) {\n left += size + fullOffset;\n } else {\n top += size + fullOffset;\n }\n }\n }\n\n protected widgetOffset = 0;\n private _fixed = 0;\n private _spacing = 4;\n private _dirty = false;\n private _hasNormedSizes = false;\n private _sizers: BoxSizer[] = [];\n private _items: LayoutItem[] = [];\n private _handles: HTMLDivElement[] = [];\n private _box: ElementExt.IBoxSizing | null = null;\n private _alignment: SplitLayout.Alignment = 'start';\n private _orientation: SplitLayout.Orientation = 'horizontal';\n}\n\n/**\n * The namespace for the `SplitLayout` class statics.\n */\nexport namespace SplitLayout {\n /**\n * A type alias for a split layout orientation.\n */\n export type Orientation = 'horizontal' | 'vertical';\n\n /**\n * A type alias for a split layout alignment.\n */\n export type Alignment = 'start' | 'center' | 'end' | 'justify';\n\n /**\n * An options object for initializing a split layout.\n */\n export interface IOptions {\n /**\n * The renderer to use for the split layout.\n */\n renderer: IRenderer;\n\n /**\n * The orientation of the layout.\n *\n * The default is `'horizontal'`.\n */\n orientation?: Orientation;\n\n /**\n * The content alignment of the layout.\n *\n * The default is `'start'`.\n */\n alignment?: Alignment;\n\n /**\n * The spacing between items in the layout.\n *\n * The default is `4`.\n */\n spacing?: number;\n }\n\n /**\n * A renderer for use with a split layout.\n */\n export interface IRenderer {\n /**\n * Create a new handle for use with a split layout.\n *\n * @returns A new handle element.\n */\n createHandle(): HTMLDivElement;\n }\n\n /**\n * Get the split layout stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The split layout stretch factor for the widget.\n */\n export function getStretch(widget: Widget): number {\n return Private.stretchProperty.get(widget);\n }\n\n /**\n * Set the split layout stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the stretch factor.\n */\n export function setStretch(widget: Widget, value: number): void {\n Private.stretchProperty.set(widget, value);\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The property descriptor for a widget stretch factor.\n */\n export const stretchProperty = new AttachedProperty({\n name: 'stretch',\n create: () => 0,\n coerce: (owner, value) => Math.max(0, Math.floor(value)),\n changed: onChildSizingChanged\n });\n\n /**\n * Create a new box sizer with the given size hint.\n */\n export function createSizer(size: number): BoxSizer {\n let sizer = new BoxSizer();\n sizer.sizeHint = Math.floor(size);\n return sizer;\n }\n\n /**\n * Create a new split handle node using the given renderer.\n */\n export function createHandle(\n renderer: SplitLayout.IRenderer\n ): HTMLDivElement {\n let handle = renderer.createHandle();\n handle.style.position = 'absolute';\n // Do not use size containment to allow the handle to fill the available space\n handle.style.contain = 'style';\n return handle;\n }\n\n /**\n * Compute the average size of an array of box sizers.\n */\n export function averageSize(sizers: BoxSizer[]): number {\n return sizers.reduce((v, s) => v + s.size, 0) / sizers.length || 0;\n }\n\n /**\n * Normalize an array of values.\n */\n export function normalize(values: number[]): number[] {\n let n = values.length;\n if (n === 0) {\n return [];\n }\n let sum = values.reduce((a, b) => a + Math.abs(b), 0);\n return sum === 0 ? values.map(v => 1 / n) : values.map(v => v / sum);\n }\n\n /**\n * The change handler for the attached sizing properties.\n */\n function onChildSizingChanged(child: Widget): void {\n if (child.parent && child.parent.layout instanceof SplitLayout) {\n child.parent.fit();\n }\n }\n}\n","/*\n * Copyright (c) Jupyter Development Team.\n * Distributed under the terms of the Modified BSD License.\n */\n\nimport { ArrayExt } from '@lumino/algorithm';\nimport { UUID } from '@lumino/coreutils';\nimport { SplitLayout } from './splitlayout';\nimport { Title } from './title';\nimport Utils from './utils';\nimport { Widget } from './widget';\n\n/**\n * A layout which arranges its widgets into collapsible resizable sections.\n */\nexport class AccordionLayout extends SplitLayout {\n /**\n * Construct a new accordion layout.\n *\n * @param options - The options for initializing the layout.\n *\n * #### Notes\n * The default orientation will be vertical.\n *\n * Titles must be rotated for horizontal accordion panel using CSS: see accordionpanel.css\n */\n constructor(options: AccordionLayout.IOptions) {\n super({ ...options, orientation: options.orientation || 'vertical' });\n this.titleSpace = options.titleSpace || 22;\n }\n\n /**\n * The section title height or width depending on the orientation.\n */\n get titleSpace(): number {\n return this.widgetOffset;\n }\n set titleSpace(value: number) {\n value = Utils.clampDimension(value);\n if (this.widgetOffset === value) {\n return;\n }\n this.widgetOffset = value;\n if (!this.parent) {\n return;\n }\n this.parent.fit();\n }\n\n /**\n * A read-only array of the section titles in the panel.\n */\n get titles(): ReadonlyArray {\n return this._titles;\n }\n\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n if (this.isDisposed) {\n return;\n }\n\n // Clear the layout state.\n this._titles.length = 0;\n\n // Dispose of the rest of the layout.\n super.dispose();\n }\n\n /**\n * The renderer used by the accordion layout.\n */\n readonly renderer: AccordionLayout.IRenderer;\n\n public updateTitle(index: number, widget: Widget): void {\n const oldTitle = this._titles[index];\n const expanded = oldTitle.classList.contains('lm-mod-expanded');\n const newTitle = Private.createTitle(this.renderer, widget.title, expanded);\n this._titles[index] = newTitle;\n\n // Add the title node to the parent before the widget.\n this.parent!.node.replaceChild(newTitle, oldTitle);\n }\n\n /**\n * Insert a widget into the layout at the specified index.\n *\n * @param index - The index at which to insert the widget.\n *\n * @param widget - The widget to insert into the layout.\n *\n * #### Notes\n * The index will be clamped to the bounds of the widgets.\n *\n * If the widget is already added to the layout, it will be moved.\n *\n * #### Undefined Behavior\n * An `index` which is non-integral.\n */\n insertWidget(index: number, widget: Widget): void {\n if (!widget.id) {\n widget.id = `id-${UUID.uuid4()}`;\n }\n super.insertWidget(index, widget);\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param index - The current index of the widget in the layout.\n *\n * @param widget - The widget to attach to the parent.\n */\n protected attachWidget(index: number, widget: Widget): void {\n const title = Private.createTitle(this.renderer, widget.title);\n\n ArrayExt.insert(this._titles, index, title);\n\n // Add the title node to the parent before the widget.\n this.parent!.node.appendChild(title);\n\n widget.node.setAttribute('role', 'region');\n widget.node.setAttribute('aria-labelledby', title.id);\n\n super.attachWidget(index, widget);\n }\n\n /**\n * Move a widget in the parent's DOM node.\n *\n * @param fromIndex - The previous index of the widget in the layout.\n *\n * @param toIndex - The current index of the widget in the layout.\n *\n * @param widget - The widget to move in the parent.\n */\n protected moveWidget(\n fromIndex: number,\n toIndex: number,\n widget: Widget\n ): void {\n ArrayExt.move(this._titles, fromIndex, toIndex);\n super.moveWidget(fromIndex, toIndex, widget);\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param index - The previous index of the widget in the layout.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected detachWidget(index: number, widget: Widget): void {\n const title = ArrayExt.removeAt(this._titles, index);\n\n this.parent!.node.removeChild(title!);\n\n super.detachWidget(index, widget);\n }\n\n /**\n * Update the item position.\n *\n * @param i Item index\n * @param isHorizontal Whether the layout is horizontal or not\n * @param left Left position in pixels\n * @param top Top position in pixels\n * @param height Item height\n * @param width Item width\n * @param size Item size\n */\n protected updateItemPosition(\n i: number,\n isHorizontal: boolean,\n left: number,\n top: number,\n height: number,\n width: number,\n size: number\n ): void {\n const titleStyle = this._titles[i].style;\n\n // Titles must be rotated for horizontal accordion panel using CSS: see accordionpanel.css\n titleStyle.top = `${top}px`;\n titleStyle.left = `${left}px`;\n titleStyle.height = `${this.widgetOffset}px`;\n if (isHorizontal) {\n titleStyle.width = `${height}px`;\n } else {\n titleStyle.width = `${width}px`;\n }\n\n super.updateItemPosition(i, isHorizontal, left, top, height, width, size);\n }\n\n private _titles: HTMLElement[] = [];\n}\n\nexport namespace AccordionLayout {\n /**\n * A type alias for a accordion layout orientation.\n */\n export type Orientation = SplitLayout.Orientation;\n\n /**\n * A type alias for a accordion layout alignment.\n */\n export type Alignment = SplitLayout.Alignment;\n\n /**\n * An options object for initializing a accordion layout.\n */\n export interface IOptions extends SplitLayout.IOptions {\n /**\n * The renderer to use for the accordion layout.\n */\n renderer: IRenderer;\n\n /**\n * The section title height or width depending on the orientation.\n *\n * The default is `22`.\n */\n titleSpace?: number;\n }\n\n /**\n * A renderer for use with an accordion layout.\n */\n export interface IRenderer extends SplitLayout.IRenderer {\n /**\n * Common class name for all accordion titles.\n */\n readonly titleClassName: string;\n\n /**\n * Render the element for a section title.\n *\n * @param title - The data to use for rendering the section title.\n *\n * @returns A element representing the section title.\n */\n createSectionTitle(title: Title): HTMLElement;\n }\n}\n\nnamespace Private {\n /**\n * Create the title HTML element.\n *\n * @param renderer Accordion renderer\n * @param data Widget title\n * @returns Title HTML element\n */\n export function createTitle(\n renderer: AccordionLayout.IRenderer,\n data: Title,\n expanded: boolean = true\n ): HTMLElement {\n const title = renderer.createSectionTitle(data);\n title.style.position = 'absolute';\n title.style.contain = 'strict';\n title.setAttribute('aria-label', `${data.label} Section`);\n title.setAttribute('aria-expanded', expanded ? 'true' : 'false');\n title.setAttribute('aria-controls', data.owner.id);\n if (expanded) {\n title.classList.add('lm-mod-expanded');\n }\n return title;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { PanelLayout } from './panellayout';\n\nimport { Widget } from './widget';\n\n/**\n * A simple and convenient panel widget class.\n *\n * #### Notes\n * This class is suitable as a base class for implementing a variety of\n * convenience panel widgets, but can also be used directly with CSS to\n * arrange a collection of widgets.\n *\n * This class provides a convenience wrapper around a {@link PanelLayout}.\n */\nexport class Panel extends Widget {\n /**\n * Construct a new panel.\n *\n * @param options - The options for initializing the panel.\n */\n constructor(options: Panel.IOptions = {}) {\n super();\n this.addClass('lm-Panel');\n this.layout = Private.createLayout(options);\n }\n\n /**\n * A read-only array of the widgets in the panel.\n */\n get widgets(): ReadonlyArray {\n return (this.layout as PanelLayout).widgets;\n }\n\n /**\n * Add a widget to the end of the panel.\n *\n * @param widget - The widget to add to the panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n */\n addWidget(widget: Widget): void {\n (this.layout as PanelLayout).addWidget(widget);\n }\n\n /**\n * Insert a widget at the specified index.\n *\n * @param index - The index at which to insert the widget.\n *\n * @param widget - The widget to insert into to the panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n */\n insertWidget(index: number, widget: Widget): void {\n (this.layout as PanelLayout).insertWidget(index, widget);\n }\n}\n\n/**\n * The namespace for the `Panel` class statics.\n */\nexport namespace Panel {\n /**\n * An options object for creating a panel.\n */\n export interface IOptions {\n /**\n * The panel layout to use for the panel.\n *\n * The default is a new `PanelLayout`.\n */\n layout?: PanelLayout;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Create a panel layout for the given panel options.\n */\n export function createLayout(options: Panel.IOptions): PanelLayout {\n return options.layout || new PanelLayout();\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { IDisposable } from '@lumino/disposable';\n\nimport { Drag } from '@lumino/dragdrop';\n\nimport { Message } from '@lumino/messaging';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { Panel } from './panel';\n\nimport { SplitLayout } from './splitlayout';\n\nimport { Widget } from './widget';\n\n/**\n * A panel which arranges its widgets into resizable sections.\n *\n * #### Notes\n * This class provides a convenience wrapper around a {@link SplitLayout}.\n */\nexport class SplitPanel extends Panel {\n /**\n * Construct a new split panel.\n *\n * @param options - The options for initializing the split panel.\n */\n constructor(options: SplitPanel.IOptions = {}) {\n super({ layout: Private.createLayout(options) });\n this.addClass('lm-SplitPanel');\n }\n\n /**\n * Dispose of the resources held by the panel.\n */\n dispose(): void {\n this._releaseMouse();\n super.dispose();\n }\n\n /**\n * Get the layout orientation for the split panel.\n */\n get orientation(): SplitPanel.Orientation {\n return (this.layout as SplitLayout).orientation;\n }\n\n /**\n * Set the layout orientation for the split panel.\n */\n set orientation(value: SplitPanel.Orientation) {\n (this.layout as SplitLayout).orientation = value;\n }\n\n /**\n * Get the content alignment for the split panel.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire split panel.\n */\n get alignment(): SplitPanel.Alignment {\n return (this.layout as SplitLayout).alignment;\n }\n\n /**\n * Set the content alignment for the split panel.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire split panel.\n */\n set alignment(value: SplitPanel.Alignment) {\n (this.layout as SplitLayout).alignment = value;\n }\n\n /**\n * Get the inter-element spacing for the split panel.\n */\n get spacing(): number {\n return (this.layout as SplitLayout).spacing;\n }\n\n /**\n * Set the inter-element spacing for the split panel.\n */\n set spacing(value: number) {\n (this.layout as SplitLayout).spacing = value;\n }\n\n /**\n * The renderer used by the split panel.\n */\n get renderer(): SplitPanel.IRenderer {\n return (this.layout as SplitLayout).renderer;\n }\n\n /**\n * A signal emitted when a split handle has moved.\n */\n get handleMoved(): ISignal {\n return this._handleMoved;\n }\n\n /**\n * A read-only array of the split handles in the panel.\n */\n get handles(): ReadonlyArray {\n return (this.layout as SplitLayout).handles;\n }\n\n /**\n * Get the relative sizes of the widgets in the panel.\n *\n * @returns A new array of the relative sizes of the widgets.\n *\n * #### Notes\n * The returned sizes reflect the sizes of the widgets normalized\n * relative to their siblings.\n *\n * This method **does not** measure the DOM nodes.\n */\n relativeSizes(): number[] {\n return (this.layout as SplitLayout).relativeSizes();\n }\n\n /**\n * Set the relative sizes for the widgets in the panel.\n *\n * @param sizes - The relative sizes for the widgets in the panel.\n * @param update - Update the layout after setting relative sizes.\n * Default is True.\n *\n * #### Notes\n * Extra values are ignored, too few will yield an undefined layout.\n *\n * The actual geometry of the DOM nodes is updated asynchronously.\n */\n setRelativeSizes(sizes: number[], update = true): void {\n (this.layout as SplitLayout).setRelativeSizes(sizes, update);\n }\n\n /**\n * Handle the DOM events for the split panel.\n *\n * @param event - The DOM event sent to the panel.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the panel's DOM node. It should\n * not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'pointerdown':\n this._evtPointerDown(event as PointerEvent);\n break;\n case 'pointermove':\n this._evtPointerMove(event as PointerEvent);\n break;\n case 'pointerup':\n this._evtPointerUp(event as PointerEvent);\n break;\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('pointerdown', this);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('pointerdown', this);\n this._releaseMouse();\n }\n\n /**\n * A message handler invoked on a `'child-added'` message.\n */\n protected onChildAdded(msg: Widget.ChildMessage): void {\n msg.child.addClass('lm-SplitPanel-child');\n this._releaseMouse();\n }\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {\n msg.child.removeClass('lm-SplitPanel-child');\n this._releaseMouse();\n }\n\n /**\n * Handle the `'keydown'` event for the split panel.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // Stop input events during drag.\n if (this._pressData) {\n event.preventDefault();\n event.stopPropagation();\n }\n\n // Release the mouse if `Escape` is pressed.\n if (event.keyCode === 27) {\n this._releaseMouse();\n }\n }\n\n /**\n * Handle the `'pointerdown'` event for the split panel.\n */\n private _evtPointerDown(event: PointerEvent): void {\n // Do nothing if the primary button is not pressed.\n if (event.button !== 0) {\n return;\n }\n\n // Find the handle which contains the target, if any.\n let layout = this.layout as SplitLayout;\n let index = ArrayExt.findFirstIndex(layout.handles, handle => {\n return handle.contains(event.target as HTMLElement);\n });\n\n // Bail early if the mouse press was not on a handle.\n if (index === -1) {\n return;\n }\n\n // Stop the event when a split handle is pressed.\n event.preventDefault();\n event.stopPropagation();\n\n // Add the extra document listeners.\n document.addEventListener('pointerup', this, true);\n document.addEventListener('pointermove', this, true);\n document.addEventListener('keydown', this, true);\n document.addEventListener('contextmenu', this, true);\n\n // Compute the offset delta for the handle press.\n let delta: number;\n let handle = layout.handles[index];\n let rect = handle.getBoundingClientRect();\n if (layout.orientation === 'horizontal') {\n delta = event.clientX - rect.left;\n } else {\n delta = event.clientY - rect.top;\n }\n\n // Override the cursor and store the press data.\n let style = window.getComputedStyle(handle);\n let override = Drag.overrideCursor(style.cursor!);\n this._pressData = { index, delta, override };\n }\n\n /**\n * Handle the `'pointermove'` event for the split panel.\n */\n private _evtPointerMove(event: PointerEvent): void {\n // Stop the event when dragging a split handle.\n event.preventDefault();\n event.stopPropagation();\n\n // Compute the desired offset position for the handle.\n let pos: number;\n let layout = this.layout as SplitLayout;\n let rect = this.node.getBoundingClientRect();\n if (layout.orientation === 'horizontal') {\n pos = event.clientX - rect.left - this._pressData!.delta;\n } else {\n pos = event.clientY - rect.top - this._pressData!.delta;\n }\n\n // Move the handle as close to the desired position as possible.\n layout.moveHandle(this._pressData!.index, pos);\n }\n\n /**\n * Handle the `'pointerup'` event for the split panel.\n */\n private _evtPointerUp(event: PointerEvent): void {\n // Do nothing if the primary button is not released.\n if (event.button !== 0) {\n return;\n }\n\n // Stop the event when releasing a handle.\n event.preventDefault();\n event.stopPropagation();\n\n // Finalize the mouse release.\n this._releaseMouse();\n }\n\n /**\n * Release the mouse grab for the split panel.\n */\n private _releaseMouse(): void {\n // Bail early if no drag is in progress.\n if (!this._pressData) {\n return;\n }\n\n // Clear the override cursor.\n this._pressData.override.dispose();\n this._pressData = null;\n\n // Emit the handle moved signal.\n this._handleMoved.emit();\n\n // Remove the extra document listeners.\n document.removeEventListener('keydown', this, true);\n document.removeEventListener('pointerup', this, true);\n document.removeEventListener('pointermove', this, true);\n document.removeEventListener('contextmenu', this, true);\n }\n\n private _handleMoved = new Signal(this);\n private _pressData: Private.IPressData | null = null;\n}\n\n/**\n * The namespace for the `SplitPanel` class statics.\n */\nexport namespace SplitPanel {\n /**\n * A type alias for a split panel orientation.\n */\n export type Orientation = SplitLayout.Orientation;\n\n /**\n * A type alias for a split panel alignment.\n */\n export type Alignment = SplitLayout.Alignment;\n\n /**\n * A type alias for a split panel renderer.\n */\n export type IRenderer = SplitLayout.IRenderer;\n\n /**\n * An options object for initializing a split panel.\n */\n export interface IOptions {\n /**\n * The renderer to use for the split panel.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n\n /**\n * The layout orientation of the panel.\n *\n * The default is `'horizontal'`.\n */\n orientation?: Orientation;\n\n /**\n * The content alignment of the panel.\n *\n * The default is `'start'`.\n */\n alignment?: Alignment;\n\n /**\n * The spacing between items in the panel.\n *\n * The default is `4`.\n */\n spacing?: number;\n\n /**\n * The split layout to use for the split panel.\n *\n * If this is provided, the other options are ignored.\n *\n * The default is a new `SplitLayout`.\n */\n layout?: SplitLayout;\n }\n\n /**\n * The default implementation of `IRenderer`.\n */\n export class Renderer implements IRenderer {\n /**\n * Create a new handle for use with a split panel.\n *\n * @returns A new handle element for a split panel.\n */\n createHandle(): HTMLDivElement {\n let handle = document.createElement('div');\n handle.className = 'lm-SplitPanel-handle';\n return handle;\n }\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n\n /**\n * Get the split panel stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The split panel stretch factor for the widget.\n */\n export function getStretch(widget: Widget): number {\n return SplitLayout.getStretch(widget);\n }\n\n /**\n * Set the split panel stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the stretch factor.\n */\n export function setStretch(widget: Widget, value: number): void {\n SplitLayout.setStretch(widget, value);\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * An object which holds mouse press data.\n */\n export interface IPressData {\n /**\n * The index of the pressed handle.\n */\n index: number;\n\n /**\n * The offset of the press in handle coordinates.\n */\n delta: number;\n\n /**\n * The disposable which will clear the override cursor.\n */\n override: IDisposable;\n }\n\n /**\n * Create a split layout for the given panel options.\n */\n export function createLayout(options: SplitPanel.IOptions): SplitLayout {\n return (\n options.layout ||\n new SplitLayout({\n renderer: options.renderer || SplitPanel.defaultRenderer,\n orientation: options.orientation,\n alignment: options.alignment,\n spacing: options.spacing\n })\n );\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n\nimport { ArrayExt } from '@lumino/algorithm';\nimport { Message } from '@lumino/messaging';\nimport { ISignal, Signal } from '@lumino/signaling';\nimport { AccordionLayout } from './accordionlayout';\nimport { SplitLayout } from './splitlayout';\nimport { SplitPanel } from './splitpanel';\nimport { Title } from './title';\nimport { Widget } from './widget';\n\n/**\n * A panel which arranges its widgets into resizable sections separated by a title widget.\n *\n * #### Notes\n * This class provides a convenience wrapper around {@link AccordionLayout}.\n */\nexport class AccordionPanel extends SplitPanel {\n /**\n * Construct a new accordion panel.\n *\n * @param options - The options for initializing the accordion panel.\n */\n constructor(options: AccordionPanel.IOptions = {}) {\n super({ ...options, layout: Private.createLayout(options) });\n this.addClass('lm-AccordionPanel');\n }\n\n /**\n * The renderer used by the accordion panel.\n */\n get renderer(): AccordionPanel.IRenderer {\n return (this.layout as AccordionLayout).renderer;\n }\n\n /**\n * The section title space.\n *\n * This is the height if the panel is vertical and the width if it is\n * horizontal.\n */\n get titleSpace(): number {\n return (this.layout as AccordionLayout).titleSpace;\n }\n set titleSpace(value: number) {\n (this.layout as AccordionLayout).titleSpace = value;\n }\n\n /**\n * A read-only array of the section titles in the panel.\n */\n get titles(): ReadonlyArray {\n return (this.layout as AccordionLayout).titles;\n }\n\n /**\n * A signal emitted when a widget of the AccordionPanel is collapsed or expanded.\n */\n get expansionToggled(): ISignal {\n return this._expansionToggled;\n }\n\n /**\n * Add a widget to the end of the panel.\n *\n * @param widget - The widget to add to the panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n */\n addWidget(widget: Widget): void {\n super.addWidget(widget);\n widget.title.changed.connect(this._onTitleChanged, this);\n }\n\n /**\n * Collapse the widget at position `index`.\n *\n * #### Notes\n * If no widget is found for `index`, this will bail.\n *\n * @param index Widget index\n */\n collapse(index: number): void {\n const widget = (this.layout as AccordionLayout).widgets[index];\n\n if (widget && !widget.isHidden) {\n this._toggleExpansion(index);\n }\n }\n\n /**\n * Expand the widget at position `index`.\n *\n * #### Notes\n * If no widget is found for `index`, this will bail.\n *\n * @param index Widget index\n */\n expand(index: number): void {\n const widget = (this.layout as AccordionLayout).widgets[index];\n\n if (widget && widget.isHidden) {\n this._toggleExpansion(index);\n }\n }\n\n /**\n * Insert a widget at the specified index.\n *\n * @param index - The index at which to insert the widget.\n *\n * @param widget - The widget to insert into to the panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n */\n insertWidget(index: number, widget: Widget): void {\n super.insertWidget(index, widget);\n widget.title.changed.connect(this._onTitleChanged, this);\n }\n\n /**\n * Handle the DOM events for the accordion panel.\n *\n * @param event - The DOM event sent to the panel.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the panel's DOM node. It should\n * not be called directly by user code.\n */\n handleEvent(event: Event): void {\n super.handleEvent(event);\n switch (event.type) {\n case 'click':\n this._evtClick(event as MouseEvent);\n break;\n case 'keydown':\n this._eventKeyDown(event as KeyboardEvent);\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('click', this);\n this.node.addEventListener('keydown', this);\n super.onBeforeAttach(msg);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n super.onAfterDetach(msg);\n this.node.removeEventListener('click', this);\n this.node.removeEventListener('keydown', this);\n }\n\n /**\n * Handle the `changed` signal of a title object.\n */\n private _onTitleChanged(sender: Title): void {\n const index = ArrayExt.findFirstIndex(this.widgets, widget => {\n return widget.contains(sender.owner);\n });\n\n if (index >= 0) {\n (this.layout as AccordionLayout).updateTitle(index, sender.owner);\n this.update();\n }\n }\n\n /**\n * Compute the size of widgets in this panel on the title click event.\n * On closing, the size of the widget is cached and we will try to expand\n * the last opened widget.\n * On opening, we will use the cached size if it is available to restore the\n * widget.\n * In both cases, if we can not compute the size of widgets, we will let\n * `SplitLayout` decide.\n *\n * @param index - The index of widget to be opened of closed\n *\n * @returns Relative size of widgets in this panel, if this size can\n * not be computed, return `undefined`\n */\n private _computeWidgetSize(index: number): number[] | undefined {\n const layout = this.layout as AccordionLayout;\n\n const widget = layout.widgets[index];\n if (!widget) {\n return undefined;\n }\n const isHidden = widget.isHidden;\n const widgetSizes = layout.absoluteSizes();\n const delta = (isHidden ? -1 : 1) * this.spacing;\n const totalSize = widgetSizes.reduce(\n (prev: number, curr: number) => prev + curr\n );\n\n let newSize = [...widgetSizes];\n\n if (!isHidden) {\n // Hide the widget\n const currentSize = widgetSizes[index];\n\n this._widgetSizesCache.set(widget, currentSize);\n newSize[index] = 0;\n\n const widgetToCollapse = newSize.map(sz => sz > 0).lastIndexOf(true);\n if (widgetToCollapse === -1) {\n // All widget are closed, let the `SplitLayout` compute widget sizes.\n return undefined;\n }\n\n newSize[widgetToCollapse] =\n widgetSizes[widgetToCollapse] + currentSize + delta;\n } else {\n // Show the widget\n const previousSize = this._widgetSizesCache.get(widget);\n if (!previousSize) {\n // Previous size is unavailable, let the `SplitLayout` compute widget sizes.\n return undefined;\n }\n newSize[index] += previousSize;\n\n const widgetToCollapse = newSize\n .map(sz => sz - previousSize > 0)\n .lastIndexOf(true);\n if (widgetToCollapse === -1) {\n // Can not reduce the size of one widget, reduce all opened widgets\n // proportionally with its size.\n newSize.forEach((_, idx) => {\n if (idx !== index) {\n newSize[idx] -=\n (widgetSizes[idx] / totalSize) * (previousSize - delta);\n }\n });\n } else {\n newSize[widgetToCollapse] -= previousSize - delta;\n }\n }\n return newSize.map(sz => sz / (totalSize + delta));\n }\n /**\n * Handle the `'click'` event for the accordion panel\n */\n private _evtClick(event: MouseEvent): void {\n const target = event.target as HTMLElement | null;\n\n if (target) {\n const index = ArrayExt.findFirstIndex(this.titles, title => {\n return title.contains(target);\n });\n\n if (index >= 0) {\n event.preventDefault();\n event.stopPropagation();\n this._toggleExpansion(index);\n }\n }\n }\n\n /**\n * Handle the `'keydown'` event for the accordion panel.\n */\n private _eventKeyDown(event: KeyboardEvent): void {\n if (event.defaultPrevented) {\n return;\n }\n\n const target = event.target as HTMLElement | null;\n let handled = false;\n if (target) {\n const index = ArrayExt.findFirstIndex(this.titles, title => {\n return title.contains(target);\n });\n\n if (index >= 0) {\n const keyCode = event.keyCode.toString();\n\n // If Space or Enter is pressed on title, emulate click event\n if (event.key.match(/Space|Enter/) || keyCode.match(/13|32/)) {\n target.click();\n handled = true;\n } else if (\n this.orientation === 'horizontal'\n ? event.key.match(/ArrowLeft|ArrowRight/) || keyCode.match(/37|39/)\n : event.key.match(/ArrowUp|ArrowDown/) || keyCode.match(/38|40/)\n ) {\n // If Up or Down (for vertical) / Left or Right (for horizontal) is pressed on title, loop on titles\n const direction =\n event.key.match(/ArrowLeft|ArrowUp/) || keyCode.match(/37|38/)\n ? -1\n : 1;\n const length = this.titles.length;\n const newIndex = (index + length + direction) % length;\n\n this.titles[newIndex].focus();\n handled = true;\n } else if (event.key === 'End' || keyCode === '35') {\n // If End is pressed on title, focus on the last title\n this.titles[this.titles.length - 1].focus();\n handled = true;\n } else if (event.key === 'Home' || keyCode === '36') {\n // If Home is pressed on title, focus on the first title\n this.titles[0].focus();\n handled = true;\n }\n }\n\n if (handled) {\n event.preventDefault();\n }\n }\n }\n\n private _toggleExpansion(index: number) {\n const title = this.titles[index];\n const widget = (this.layout as AccordionLayout).widgets[index];\n\n const newSize = this._computeWidgetSize(index);\n if (newSize) {\n this.setRelativeSizes(newSize, false);\n }\n\n if (widget.isHidden) {\n title.classList.add('lm-mod-expanded');\n title.setAttribute('aria-expanded', 'true');\n widget.show();\n } else {\n title.classList.remove('lm-mod-expanded');\n title.setAttribute('aria-expanded', 'false');\n widget.hide();\n }\n\n // Emit the expansion state signal.\n this._expansionToggled.emit(index);\n }\n\n private _widgetSizesCache: WeakMap = new WeakMap();\n private _expansionToggled = new Signal(this);\n}\n\n/**\n * The namespace for the `AccordionPanel` class statics.\n */\nexport namespace AccordionPanel {\n /**\n * A type alias for a accordion panel orientation.\n */\n export type Orientation = SplitLayout.Orientation;\n\n /**\n * A type alias for a accordion panel alignment.\n */\n export type Alignment = SplitLayout.Alignment;\n\n /**\n * A type alias for a accordion panel renderer.\n */\n export type IRenderer = AccordionLayout.IRenderer;\n\n /**\n * An options object for initializing a accordion panel.\n */\n export interface IOptions extends Partial {\n /**\n * The accordion layout to use for the accordion panel.\n *\n * If this is provided, the other options are ignored.\n *\n * The default is a new `AccordionLayout`.\n */\n layout?: AccordionLayout;\n }\n\n /**\n * The default implementation of `IRenderer`.\n */\n export class Renderer extends SplitPanel.Renderer implements IRenderer {\n constructor() {\n super();\n this._uuid = ++Renderer._nInstance;\n }\n /**\n * A selector which matches any title node in the accordion.\n */\n readonly titleClassName = 'lm-AccordionPanel-title';\n\n /**\n * Render the collapse indicator for a section title.\n *\n * @param data - The data to use for rendering the section title.\n *\n * @returns A element representing the collapse indicator.\n */\n createCollapseIcon(data: Title): HTMLElement {\n return document.createElement('span');\n }\n\n /**\n * Render the element for a section title.\n *\n * @param data - The data to use for rendering the section title.\n *\n * @returns A element representing the section title.\n */\n createSectionTitle(data: Title): HTMLElement {\n const handle = document.createElement('h3');\n handle.setAttribute('tabindex', '0');\n handle.id = this.createTitleKey(data);\n handle.className = this.titleClassName;\n for (const aData in data.dataset) {\n handle.dataset[aData] = data.dataset[aData];\n }\n\n const collapser = handle.appendChild(this.createCollapseIcon(data));\n collapser.className = 'lm-AccordionPanel-titleCollapser';\n\n const label = handle.appendChild(document.createElement('span'));\n label.className = 'lm-AccordionPanel-titleLabel';\n label.textContent = data.label;\n label.title = data.caption || data.label;\n\n return handle;\n }\n\n /**\n * Create a unique render key for the title.\n *\n * @param data - The data to use for the title.\n *\n * @returns The unique render key for the title.\n *\n * #### Notes\n * This method caches the key against the section title the first time\n * the key is generated.\n */\n createTitleKey(data: Title): string {\n let key = this._titleKeys.get(data);\n if (key === undefined) {\n key = `title-key-${this._uuid}-${this._titleID++}`;\n this._titleKeys.set(data, key);\n }\n return key;\n }\n\n private static _nInstance = 0;\n private readonly _uuid: number;\n private _titleID = 0;\n private _titleKeys = new WeakMap, string>();\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n}\n\nnamespace Private {\n /**\n * Create an accordion layout for the given panel options.\n *\n * @param options Panel options\n * @returns Panel layout\n */\n export function createLayout(\n options: AccordionPanel.IOptions\n ): AccordionLayout {\n return (\n options.layout ||\n new AccordionLayout({\n renderer: options.renderer || AccordionPanel.defaultRenderer,\n orientation: options.orientation,\n alignment: options.alignment,\n spacing: options.spacing,\n titleSpace: options.titleSpace\n })\n );\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { BoxEngine, BoxSizer } from './boxengine';\n\nimport { LayoutItem } from './layout';\n\nimport { PanelLayout } from './panellayout';\n\nimport Utils from './utils';\n\nimport { Widget } from './widget';\n\n/**\n * A layout which arranges its widgets in a single row or column.\n */\nexport class BoxLayout extends PanelLayout {\n /**\n * Construct a new box layout.\n *\n * @param options - The options for initializing the layout.\n */\n constructor(options: BoxLayout.IOptions = {}) {\n super();\n if (options.direction !== undefined) {\n this._direction = options.direction;\n }\n if (options.alignment !== undefined) {\n this._alignment = options.alignment;\n }\n if (options.spacing !== undefined) {\n this._spacing = Utils.clampDimension(options.spacing);\n }\n }\n\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n // Dispose of the layout items.\n for (const item of this._items) {\n item.dispose();\n }\n\n // Clear the layout state.\n this._box = null;\n this._items.length = 0;\n this._sizers.length = 0;\n\n // Dispose of the rest of the layout.\n super.dispose();\n }\n\n /**\n * Get the layout direction for the box layout.\n */\n get direction(): BoxLayout.Direction {\n return this._direction;\n }\n\n /**\n * Set the layout direction for the box layout.\n */\n set direction(value: BoxLayout.Direction) {\n if (this._direction === value) {\n return;\n }\n this._direction = value;\n if (!this.parent) {\n return;\n }\n this.parent.dataset['direction'] = value;\n this.parent.fit();\n }\n\n /**\n * Get the content alignment for the box layout.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire box layout.\n */\n get alignment(): BoxLayout.Alignment {\n return this._alignment;\n }\n\n /**\n * Set the content alignment for the box layout.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire box layout.\n */\n set alignment(value: BoxLayout.Alignment) {\n if (this._alignment === value) {\n return;\n }\n this._alignment = value;\n if (!this.parent) {\n return;\n }\n this.parent.dataset['alignment'] = value;\n this.parent.update();\n }\n\n /**\n * Get the inter-element spacing for the box layout.\n */\n get spacing(): number {\n return this._spacing;\n }\n\n /**\n * Set the inter-element spacing for the box layout.\n */\n set spacing(value: number) {\n value = Utils.clampDimension(value);\n if (this._spacing === value) {\n return;\n }\n this._spacing = value;\n if (!this.parent) {\n return;\n }\n this.parent.fit();\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n this.parent!.dataset['direction'] = this.direction;\n this.parent!.dataset['alignment'] = this.alignment;\n super.init();\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param index - The current index of the widget in the layout.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected attachWidget(index: number, widget: Widget): void {\n // Create and add a new layout item for the widget.\n ArrayExt.insert(this._items, index, new LayoutItem(widget));\n\n // Create and add a new sizer for the widget.\n ArrayExt.insert(this._sizers, index, new BoxSizer());\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget's node to the parent.\n this.parent!.node.appendChild(widget.node);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * Move a widget in the parent's DOM node.\n *\n * @param fromIndex - The previous index of the widget in the layout.\n *\n * @param toIndex - The current index of the widget in the layout.\n *\n * @param widget - The widget to move in the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected moveWidget(\n fromIndex: number,\n toIndex: number,\n widget: Widget\n ): void {\n // Move the layout item for the widget.\n ArrayExt.move(this._items, fromIndex, toIndex);\n\n // Move the sizer for the widget.\n ArrayExt.move(this._sizers, fromIndex, toIndex);\n\n // Post an update request for the parent widget.\n this.parent!.update();\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param index - The previous index of the widget in the layout.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected detachWidget(index: number, widget: Widget): void {\n // Remove the layout item for the widget.\n let item = ArrayExt.removeAt(this._items, index);\n\n // Remove the sizer for the widget.\n ArrayExt.removeAt(this._sizers, index);\n\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Dispose of the layout item.\n item!.dispose();\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n */\n protected onBeforeShow(msg: Message): void {\n super.onBeforeShow(msg);\n this.parent!.update();\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n super.onBeforeAttach(msg);\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n if (this.parent!.isVisible) {\n this._update(msg.width, msg.height);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.parent!.isVisible) {\n this._update(-1, -1);\n }\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n */\n protected onFitRequest(msg: Message): void {\n if (this.parent!.isAttached) {\n this._fit();\n }\n }\n\n /**\n * Fit the layout to the total size required by the widgets.\n */\n private _fit(): void {\n // Compute the visible item count.\n let nVisible = 0;\n for (let i = 0, n = this._items.length; i < n; ++i) {\n nVisible += +!this._items[i].isHidden;\n }\n\n // Update the fixed space for the visible items.\n this._fixed = this._spacing * Math.max(0, nVisible - 1);\n\n // Setup the computed minimum size.\n let horz = Private.isHorizontal(this._direction);\n let minW = horz ? this._fixed : 0;\n let minH = horz ? 0 : this._fixed;\n\n // Update the sizers and computed minimum size.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item and corresponding box sizer.\n let item = this._items[i];\n let sizer = this._sizers[i];\n\n // If the item is hidden, it should consume zero size.\n if (item.isHidden) {\n sizer.minSize = 0;\n sizer.maxSize = 0;\n continue;\n }\n\n // Update the size limits for the item.\n item.fit();\n\n // Update the size basis and stretch factor.\n sizer.sizeHint = BoxLayout.getSizeBasis(item.widget);\n sizer.stretch = BoxLayout.getStretch(item.widget);\n\n // Update the sizer limits and computed min size.\n if (horz) {\n sizer.minSize = item.minWidth;\n sizer.maxSize = item.maxWidth;\n minW += item.minWidth;\n minH = Math.max(minH, item.minHeight);\n } else {\n sizer.minSize = item.minHeight;\n sizer.maxSize = item.maxHeight;\n minH += item.minHeight;\n minW = Math.max(minW, item.minWidth);\n }\n }\n\n // Update the box sizing and add it to the computed min size.\n let box = (this._box = ElementExt.boxSizing(this.parent!.node));\n minW += box.horizontalSum;\n minH += box.verticalSum;\n\n // Update the parent's min size constraints.\n let style = this.parent!.node.style;\n style.minWidth = `${minW}px`;\n style.minHeight = `${minH}px`;\n\n // Set the dirty flag to ensure only a single update occurs.\n this._dirty = true;\n\n // Notify the ancestor that it should fit immediately. This may\n // cause a resize of the parent, fulfilling the required update.\n if (this.parent!.parent) {\n MessageLoop.sendMessage(this.parent!.parent!, Widget.Msg.FitRequest);\n }\n\n // If the dirty flag is still set, the parent was not resized.\n // Trigger the required update on the parent widget immediately.\n if (this._dirty) {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n }\n }\n\n /**\n * Update the layout position and size of the widgets.\n *\n * The parent offset dimensions should be `-1` if unknown.\n */\n private _update(offsetWidth: number, offsetHeight: number): void {\n // Clear the dirty flag to indicate the update occurred.\n this._dirty = false;\n\n // Compute the visible item count.\n let nVisible = 0;\n for (let i = 0, n = this._items.length; i < n; ++i) {\n nVisible += +!this._items[i].isHidden;\n }\n\n // Bail early if there are no visible items to layout.\n if (nVisible === 0) {\n return;\n }\n\n // Measure the parent if the offset dimensions are unknown.\n if (offsetWidth < 0) {\n offsetWidth = this.parent!.node.offsetWidth;\n }\n if (offsetHeight < 0) {\n offsetHeight = this.parent!.node.offsetHeight;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent!.node);\n }\n\n // Compute the layout area adjusted for border and padding.\n let top = this._box.paddingTop;\n let left = this._box.paddingLeft;\n let width = offsetWidth - this._box.horizontalSum;\n let height = offsetHeight - this._box.verticalSum;\n\n // Distribute the layout space and adjust the start position.\n let delta: number;\n switch (this._direction) {\n case 'left-to-right':\n delta = BoxEngine.calc(this._sizers, Math.max(0, width - this._fixed));\n break;\n case 'top-to-bottom':\n delta = BoxEngine.calc(this._sizers, Math.max(0, height - this._fixed));\n break;\n case 'right-to-left':\n delta = BoxEngine.calc(this._sizers, Math.max(0, width - this._fixed));\n left += width;\n break;\n case 'bottom-to-top':\n delta = BoxEngine.calc(this._sizers, Math.max(0, height - this._fixed));\n top += height;\n break;\n default:\n throw 'unreachable';\n }\n\n // Setup the variables for justification and alignment offset.\n let extra = 0;\n let offset = 0;\n\n // Account for alignment if there is extra layout space.\n if (delta > 0) {\n switch (this._alignment) {\n case 'start':\n break;\n case 'center':\n extra = 0;\n offset = delta / 2;\n break;\n case 'end':\n extra = 0;\n offset = delta;\n break;\n case 'justify':\n extra = delta / nVisible;\n offset = 0;\n break;\n default:\n throw 'unreachable';\n }\n }\n\n // Layout the items using the computed box sizes.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item.\n let item = this._items[i];\n\n // Ignore hidden items.\n if (item.isHidden) {\n continue;\n }\n\n // Fetch the computed size for the widget.\n let size = this._sizers[i].size;\n\n // Update the widget geometry and advance the relevant edge.\n switch (this._direction) {\n case 'left-to-right':\n item.update(left + offset, top, size + extra, height);\n left += size + extra + this._spacing;\n break;\n case 'top-to-bottom':\n item.update(left, top + offset, width, size + extra);\n top += size + extra + this._spacing;\n break;\n case 'right-to-left':\n item.update(left - offset - size - extra, top, size + extra, height);\n left -= size + extra + this._spacing;\n break;\n case 'bottom-to-top':\n item.update(left, top - offset - size - extra, width, size + extra);\n top -= size + extra + this._spacing;\n break;\n default:\n throw 'unreachable';\n }\n }\n }\n\n private _fixed = 0;\n private _spacing = 4;\n private _dirty = false;\n private _sizers: BoxSizer[] = [];\n private _items: LayoutItem[] = [];\n private _box: ElementExt.IBoxSizing | null = null;\n private _alignment: BoxLayout.Alignment = 'start';\n private _direction: BoxLayout.Direction = 'top-to-bottom';\n}\n\n/**\n * The namespace for the `BoxLayout` class statics.\n */\nexport namespace BoxLayout {\n /**\n * A type alias for a box layout direction.\n */\n export type Direction =\n | 'left-to-right'\n | 'right-to-left'\n | 'top-to-bottom'\n | 'bottom-to-top';\n\n /**\n * A type alias for a box layout alignment.\n */\n export type Alignment = 'start' | 'center' | 'end' | 'justify';\n\n /**\n * An options object for initializing a box layout.\n */\n export interface IOptions {\n /**\n * The direction of the layout.\n *\n * The default is `'top-to-bottom'`.\n */\n direction?: Direction;\n\n /**\n * The content alignment of the layout.\n *\n * The default is `'start'`.\n */\n alignment?: Alignment;\n\n /**\n * The spacing between items in the layout.\n *\n * The default is `4`.\n */\n spacing?: number;\n }\n\n /**\n * Get the box layout stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The box layout stretch factor for the widget.\n */\n export function getStretch(widget: Widget): number {\n return Private.stretchProperty.get(widget);\n }\n\n /**\n * Set the box layout stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the stretch factor.\n */\n export function setStretch(widget: Widget, value: number): void {\n Private.stretchProperty.set(widget, value);\n }\n\n /**\n * Get the box layout size basis for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The box layout size basis for the widget.\n */\n export function getSizeBasis(widget: Widget): number {\n return Private.sizeBasisProperty.get(widget);\n }\n\n /**\n * Set the box layout size basis for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the size basis.\n */\n export function setSizeBasis(widget: Widget, value: number): void {\n Private.sizeBasisProperty.set(widget, value);\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The property descriptor for a widget stretch factor.\n */\n export const stretchProperty = new AttachedProperty({\n name: 'stretch',\n create: () => 0,\n coerce: (owner, value) => Math.max(0, Math.floor(value)),\n changed: onChildSizingChanged\n });\n\n /**\n * The property descriptor for a widget size basis.\n */\n export const sizeBasisProperty = new AttachedProperty({\n name: 'sizeBasis',\n create: () => 0,\n coerce: (owner, value) => Math.max(0, Math.floor(value)),\n changed: onChildSizingChanged\n });\n\n /**\n * Test whether a direction has horizontal orientation.\n */\n export function isHorizontal(dir: BoxLayout.Direction): boolean {\n return dir === 'left-to-right' || dir === 'right-to-left';\n }\n\n /**\n * Clamp a spacing value to an integer >= 0.\n */\n export function clampSpacing(value: number): number {\n return Math.max(0, Math.floor(value));\n }\n\n /**\n * The change handler for the attached sizing properties.\n */\n function onChildSizingChanged(child: Widget): void {\n if (child.parent && child.parent.layout instanceof BoxLayout) {\n child.parent.fit();\n }\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { BoxLayout } from './boxlayout';\n\nimport { Panel } from './panel';\n\nimport { Widget } from './widget';\n\n/**\n * A panel which arranges its widgets in a single row or column.\n *\n * #### Notes\n * This class provides a convenience wrapper around a {@link BoxLayout}.\n */\nexport class BoxPanel extends Panel {\n /**\n * Construct a new box panel.\n *\n * @param options - The options for initializing the box panel.\n */\n constructor(options: BoxPanel.IOptions = {}) {\n super({ layout: Private.createLayout(options) });\n this.addClass('lm-BoxPanel');\n }\n\n /**\n * Get the layout direction for the box panel.\n */\n get direction(): BoxPanel.Direction {\n return (this.layout as BoxLayout).direction;\n }\n\n /**\n * Set the layout direction for the box panel.\n */\n set direction(value: BoxPanel.Direction) {\n (this.layout as BoxLayout).direction = value;\n }\n\n /**\n * Get the content alignment for the box panel.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire box layout.\n */\n get alignment(): BoxPanel.Alignment {\n return (this.layout as BoxLayout).alignment;\n }\n\n /**\n * Set the content alignment for the box panel.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire box layout.\n */\n set alignment(value: BoxPanel.Alignment) {\n (this.layout as BoxLayout).alignment = value;\n }\n\n /**\n * Get the inter-element spacing for the box panel.\n */\n get spacing(): number {\n return (this.layout as BoxLayout).spacing;\n }\n\n /**\n * Set the inter-element spacing for the box panel.\n */\n set spacing(value: number) {\n (this.layout as BoxLayout).spacing = value;\n }\n\n /**\n * A message handler invoked on a `'child-added'` message.\n */\n protected onChildAdded(msg: Widget.ChildMessage): void {\n msg.child.addClass('lm-BoxPanel-child');\n }\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {\n msg.child.removeClass('lm-BoxPanel-child');\n }\n}\n\n/**\n * The namespace for the `BoxPanel` class statics.\n */\nexport namespace BoxPanel {\n /**\n * A type alias for a box panel direction.\n */\n export type Direction = BoxLayout.Direction;\n\n /**\n * A type alias for a box panel alignment.\n */\n export type Alignment = BoxLayout.Alignment;\n\n /**\n * An options object for initializing a box panel.\n */\n export interface IOptions {\n /**\n * The layout direction of the panel.\n *\n * The default is `'top-to-bottom'`.\n */\n direction?: Direction;\n\n /**\n * The content alignment of the panel.\n *\n * The default is `'start'`.\n */\n alignment?: Alignment;\n\n /**\n * The spacing between items in the panel.\n *\n * The default is `4`.\n */\n spacing?: number;\n\n /**\n * The box layout to use for the box panel.\n *\n * If this is provided, the other options are ignored.\n *\n * The default is a new `BoxLayout`.\n */\n layout?: BoxLayout;\n }\n\n /**\n * Get the box panel stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The box panel stretch factor for the widget.\n */\n export function getStretch(widget: Widget): number {\n return BoxLayout.getStretch(widget);\n }\n\n /**\n * Set the box panel stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the stretch factor.\n */\n export function setStretch(widget: Widget, value: number): void {\n BoxLayout.setStretch(widget, value);\n }\n\n /**\n * Get the box panel size basis for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The box panel size basis for the widget.\n */\n export function getSizeBasis(widget: Widget): number {\n return BoxLayout.getSizeBasis(widget);\n }\n\n /**\n * Set the box panel size basis for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the size basis.\n */\n export function setSizeBasis(widget: Widget, value: number): void {\n BoxLayout.setSizeBasis(widget, value);\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Create a box layout for the given panel options.\n */\n export function createLayout(options: BoxPanel.IOptions): BoxLayout {\n return options.layout || new BoxLayout(options);\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt, StringExt } from '@lumino/algorithm';\n\nimport { JSONExt, ReadonlyJSONObject } from '@lumino/coreutils';\n\nimport { CommandRegistry } from '@lumino/commands';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message } from '@lumino/messaging';\n\nimport {\n ElementDataset,\n h,\n VirtualDOM,\n VirtualElement\n} from '@lumino/virtualdom';\n\nimport { Widget } from './widget';\n\n/**\n * A widget which displays command items as a searchable palette.\n */\nexport class CommandPalette extends Widget {\n /**\n * Construct a new command palette.\n *\n * @param options - The options for initializing the palette.\n */\n constructor(options: CommandPalette.IOptions) {\n super({ node: Private.createNode() });\n this.addClass('lm-CommandPalette');\n this.setFlag(Widget.Flag.DisallowLayout);\n this.commands = options.commands;\n this.renderer = options.renderer || CommandPalette.defaultRenderer;\n this.commands.commandChanged.connect(this._onGenericChange, this);\n this.commands.keyBindingChanged.connect(this._onGenericChange, this);\n }\n\n /**\n * Dispose of the resources held by the widget.\n */\n dispose(): void {\n this._items.length = 0;\n this._results = null;\n super.dispose();\n }\n\n /**\n * The command registry used by the command palette.\n */\n readonly commands: CommandRegistry;\n\n /**\n * The renderer used by the command palette.\n */\n readonly renderer: CommandPalette.IRenderer;\n\n /**\n * The command palette search node.\n *\n * #### Notes\n * This is the node which contains the search-related elements.\n */\n get searchNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-CommandPalette-search'\n )[0] as HTMLDivElement;\n }\n\n /**\n * The command palette input node.\n *\n * #### Notes\n * This is the actual input node for the search area.\n */\n get inputNode(): HTMLInputElement {\n return this.node.getElementsByClassName(\n 'lm-CommandPalette-input'\n )[0] as HTMLInputElement;\n }\n\n /**\n * The command palette content node.\n *\n * #### Notes\n * This is the node which holds the command item nodes.\n *\n * Modifying this node directly can lead to undefined behavior.\n */\n get contentNode(): HTMLUListElement {\n return this.node.getElementsByClassName(\n 'lm-CommandPalette-content'\n )[0] as HTMLUListElement;\n }\n\n /**\n * A read-only array of the command items in the palette.\n */\n get items(): ReadonlyArray {\n return this._items;\n }\n\n /**\n * Add a command item to the command palette.\n *\n * @param options - The options for creating the command item.\n *\n * @returns The command item added to the palette.\n */\n addItem(options: CommandPalette.IItemOptions): CommandPalette.IItem {\n // Create a new command item for the options.\n let item = Private.createItem(this.commands, options);\n\n // Add the item to the array.\n this._items.push(item);\n\n // Refresh the search results.\n this.refresh();\n\n // Return the item added to the palette.\n return item;\n }\n\n /**\n * Adds command items to the command palette.\n *\n * @param items - An array of options for creating each command item.\n *\n * @returns The command items added to the palette.\n */\n addItems(items: CommandPalette.IItemOptions[]): CommandPalette.IItem[] {\n const newItems = items.map(item => Private.createItem(this.commands, item));\n newItems.forEach(item => this._items.push(item));\n this.refresh();\n return newItems;\n }\n\n /**\n * Remove an item from the command palette.\n *\n * @param item - The item to remove from the palette.\n *\n * #### Notes\n * This is a no-op if the item is not in the palette.\n */\n removeItem(item: CommandPalette.IItem): void {\n this.removeItemAt(this._items.indexOf(item));\n }\n\n /**\n * Remove the item at a given index from the command palette.\n *\n * @param index - The index of the item to remove.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n removeItemAt(index: number): void {\n // Remove the item from the array.\n let item = ArrayExt.removeAt(this._items, index);\n\n // Bail if the index is out of range.\n if (!item) {\n return;\n }\n\n // Refresh the search results.\n this.refresh();\n }\n\n /**\n * Remove all items from the command palette.\n */\n clearItems(): void {\n // Bail if there is nothing to remove.\n if (this._items.length === 0) {\n return;\n }\n\n // Clear the array of items.\n this._items.length = 0;\n\n // Refresh the search results.\n this.refresh();\n }\n\n /**\n * Clear the search results and schedule an update.\n *\n * #### Notes\n * This should be called whenever the search results of the palette\n * should be updated.\n *\n * This is typically called automatically by the palette as needed,\n * but can be called manually if the input text is programatically\n * changed.\n *\n * The rendered results are updated asynchronously.\n */\n refresh(): void {\n this._results = null;\n if (this.inputNode.value !== '') {\n let clear = this.node.getElementsByClassName(\n 'lm-close-icon'\n )[0] as HTMLInputElement;\n clear.style.display = 'inherit';\n } else {\n let clear = this.node.getElementsByClassName(\n 'lm-close-icon'\n )[0] as HTMLInputElement;\n clear.style.display = 'none';\n }\n this.update();\n }\n\n /**\n * Handle the DOM events for the command palette.\n *\n * @param event - The DOM event sent to the command palette.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the command palette's DOM node.\n * It should not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'click':\n this._evtClick(event as MouseEvent);\n break;\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'input':\n this.refresh();\n break;\n case 'focus':\n case 'blur':\n this._toggleFocused();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('click', this);\n this.node.addEventListener('keydown', this);\n this.node.addEventListener('input', this);\n this.node.addEventListener('focus', this, true);\n this.node.addEventListener('blur', this, true);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('click', this);\n this.node.removeEventListener('keydown', this);\n this.node.removeEventListener('input', this);\n this.node.removeEventListener('focus', this, true);\n this.node.removeEventListener('blur', this, true);\n }\n\n /**\n * A message handler invoked on an `'after-show'` message.\n */\n protected onAfterShow(msg: Message): void {\n this.update();\n super.onAfterShow(msg);\n }\n\n /**\n * A message handler invoked on an `'activate-request'` message.\n */\n protected onActivateRequest(msg: Message): void {\n if (this.isAttached) {\n let input = this.inputNode;\n input.focus();\n input.select();\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.isHidden) {\n return;\n }\n\n // Fetch the current query text and content node.\n let query = this.inputNode.value;\n let contentNode = this.contentNode;\n\n // Ensure the search results are generated.\n let results = this._results;\n if (!results) {\n // Generate and store the new search results.\n results = this._results = Private.search(this._items, query);\n\n // Reset the active index.\n this._activeIndex = query\n ? ArrayExt.findFirstIndex(results, Private.canActivate)\n : -1;\n }\n\n // If there is no query and no results, clear the content.\n if (!query && results.length === 0) {\n VirtualDOM.render(null, contentNode);\n return;\n }\n\n // If the is a query but no results, render the empty message.\n if (query && results.length === 0) {\n let content = this.renderer.renderEmptyMessage({ query });\n VirtualDOM.render(content, contentNode);\n return;\n }\n\n // Create the render content for the search results.\n let renderer = this.renderer;\n let activeIndex = this._activeIndex;\n let content = new Array(results.length);\n for (let i = 0, n = results.length; i < n; ++i) {\n let result = results[i];\n if (result.type === 'header') {\n let indices = result.indices;\n let category = result.category;\n content[i] = renderer.renderHeader({ category, indices });\n } else {\n let item = result.item;\n let indices = result.indices;\n let active = i === activeIndex;\n content[i] = renderer.renderItem({ item, indices, active });\n }\n }\n\n // Render the search result content.\n VirtualDOM.render(content, contentNode);\n\n // Adjust the scroll position as needed.\n if (activeIndex < 0 || activeIndex >= results.length) {\n contentNode.scrollTop = 0;\n } else {\n let element = contentNode.children[activeIndex];\n ElementExt.scrollIntoViewIfNeeded(contentNode, element);\n }\n }\n\n /**\n * Handle the `'click'` event for the command palette.\n */\n private _evtClick(event: MouseEvent): void {\n // Bail if the click is not the left button.\n if (event.button !== 0) {\n return;\n }\n\n // Clear input if the target is clear button\n if ((event.target as HTMLElement).classList.contains('lm-close-icon')) {\n this.inputNode.value = '';\n this.refresh();\n return;\n }\n\n // Find the index of the item which was clicked.\n let index = ArrayExt.findFirstIndex(this.contentNode.children, node => {\n return node.contains(event.target as HTMLElement);\n });\n\n // Bail if the click was not on an item.\n if (index === -1) {\n return;\n }\n\n // Kill the event when a content item is clicked.\n event.preventDefault();\n event.stopPropagation();\n\n // Execute the item if possible.\n this._execute(index);\n }\n\n /**\n * Handle the `'keydown'` event for the command palette.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n if (event.altKey || event.ctrlKey || event.metaKey || event.shiftKey) {\n return;\n }\n switch (event.keyCode) {\n case 13: // Enter\n event.preventDefault();\n event.stopPropagation();\n this._execute(this._activeIndex);\n break;\n case 38: // Up Arrow\n event.preventDefault();\n event.stopPropagation();\n this._activatePreviousItem();\n break;\n case 40: // Down Arrow\n event.preventDefault();\n event.stopPropagation();\n this._activateNextItem();\n break;\n }\n }\n\n /**\n * Activate the next enabled command item.\n */\n private _activateNextItem(): void {\n // Bail if there are no search results.\n if (!this._results || this._results.length === 0) {\n return;\n }\n\n // Find the next enabled item index.\n let ai = this._activeIndex;\n let n = this._results.length;\n let start = ai < n - 1 ? ai + 1 : 0;\n let stop = start === 0 ? n - 1 : start - 1;\n this._activeIndex = ArrayExt.findFirstIndex(\n this._results,\n Private.canActivate,\n start,\n stop\n );\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * Activate the previous enabled command item.\n */\n private _activatePreviousItem(): void {\n // Bail if there are no search results.\n if (!this._results || this._results.length === 0) {\n return;\n }\n\n // Find the previous enabled item index.\n let ai = this._activeIndex;\n let n = this._results.length;\n let start = ai <= 0 ? n - 1 : ai - 1;\n let stop = start === n - 1 ? 0 : start + 1;\n this._activeIndex = ArrayExt.findLastIndex(\n this._results,\n Private.canActivate,\n start,\n stop\n );\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * Execute the command item at the given index, if possible.\n */\n private _execute(index: number): void {\n // Bail if there are no search results.\n if (!this._results) {\n return;\n }\n\n // Bail if the index is out of range.\n let part = this._results[index];\n if (!part) {\n return;\n }\n\n // Update the search text if the item is a header.\n if (part.type === 'header') {\n let input = this.inputNode;\n input.value = `${part.category.toLowerCase()} `;\n input.focus();\n this.refresh();\n return;\n }\n\n // Bail if item is not enabled.\n if (!part.item.isEnabled) {\n return;\n }\n\n // Execute the item.\n this.commands.execute(part.item.command, part.item.args);\n\n // Clear the query text.\n this.inputNode.value = '';\n\n // Refresh the search results.\n this.refresh();\n }\n\n /**\n * Toggle the focused modifier based on the input node focus state.\n */\n private _toggleFocused(): void {\n let focused = document.activeElement === this.inputNode;\n this.toggleClass('lm-mod-focused', focused);\n }\n\n /**\n * A signal handler for generic command changes.\n */\n private _onGenericChange(): void {\n this.refresh();\n }\n\n private _activeIndex = -1;\n private _items: CommandPalette.IItem[] = [];\n private _results: Private.SearchResult[] | null = null;\n}\n\n/**\n * The namespace for the `CommandPalette` class statics.\n */\nexport namespace CommandPalette {\n /**\n * An options object for creating a command palette.\n */\n export interface IOptions {\n /**\n * The command registry for use with the command palette.\n */\n commands: CommandRegistry;\n\n /**\n * A custom renderer for use with the command palette.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n }\n\n /**\n * An options object for creating a command item.\n */\n export interface IItemOptions {\n /**\n * The category for the item.\n */\n category: string;\n\n /**\n * The command to execute when the item is triggered.\n */\n command: string;\n\n /**\n * The arguments for the command.\n *\n * The default value is an empty object.\n */\n args?: ReadonlyJSONObject;\n\n /**\n * The rank for the command item.\n *\n * The rank is used as a tie-breaker when ordering command items\n * for display. Items are sorted in the following order:\n * 1. Text match (lower is better)\n * 2. Category (locale order)\n * 3. Rank (lower is better)\n * 4. Label (locale order)\n *\n * The default rank is `Infinity`.\n */\n rank?: number;\n }\n\n /**\n * An object which represents an item in a command palette.\n *\n * #### Notes\n * Item objects are created automatically by a command palette.\n */\n export interface IItem {\n /**\n * The command to execute when the item is triggered.\n */\n readonly command: string;\n\n /**\n * The arguments for the command.\n */\n readonly args: ReadonlyJSONObject;\n\n /**\n * The category for the command item.\n */\n readonly category: string;\n\n /**\n * The rank for the command item.\n */\n readonly rank: number;\n\n /**\n * The display label for the command item.\n */\n readonly label: string;\n\n /**\n * The display caption for the command item.\n */\n readonly caption: string;\n\n /**\n * The icon renderer for the command item.\n */\n readonly icon: VirtualElement.IRenderer | undefined;\n\n /**\n * The icon class for the command item.\n */\n readonly iconClass: string;\n\n /**\n * The icon label for the command item.\n */\n readonly iconLabel: string;\n\n /**\n * The extra class name for the command item.\n */\n readonly className: string;\n\n /**\n * The dataset for the command item.\n */\n readonly dataset: CommandRegistry.Dataset;\n\n /**\n * Whether the command item is enabled.\n */\n readonly isEnabled: boolean;\n\n /**\n * Whether the command item is toggled.\n */\n readonly isToggled: boolean;\n\n /**\n * Whether the command item is toggleable.\n */\n readonly isToggleable: boolean;\n\n /**\n * Whether the command item is visible.\n */\n readonly isVisible: boolean;\n\n /**\n * The key binding for the command item.\n */\n readonly keyBinding: CommandRegistry.IKeyBinding | null;\n }\n\n /**\n * The render data for a command palette header.\n */\n export interface IHeaderRenderData {\n /**\n * The category of the header.\n */\n readonly category: string;\n\n /**\n * The indices of the matched characters in the category.\n */\n readonly indices: ReadonlyArray | null;\n }\n\n /**\n * The render data for a command palette item.\n */\n export interface IItemRenderData {\n /**\n * The command palette item to render.\n */\n readonly item: IItem;\n\n /**\n * The indices of the matched characters in the label.\n */\n readonly indices: ReadonlyArray | null;\n\n /**\n * Whether the item is the active item.\n */\n readonly active: boolean;\n }\n\n /**\n * The render data for a command palette empty message.\n */\n export interface IEmptyMessageRenderData {\n /**\n * The query which failed to match any commands.\n */\n query: string;\n }\n\n /**\n * A renderer for use with a command palette.\n */\n export interface IRenderer {\n /**\n * Render the virtual element for a command palette header.\n *\n * @param data - The data to use for rendering the header.\n *\n * @returns A virtual element representing the header.\n */\n renderHeader(data: IHeaderRenderData): VirtualElement;\n\n /**\n * Render the virtual element for a command palette item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n *\n * #### Notes\n * The command palette will not render invisible items.\n */\n renderItem(data: IItemRenderData): VirtualElement;\n\n /**\n * Render the empty results message for a command palette.\n *\n * @param data - The data to use for rendering the message.\n *\n * @returns A virtual element representing the message.\n */\n renderEmptyMessage(data: IEmptyMessageRenderData): VirtualElement;\n }\n\n /**\n * The default implementation of `IRenderer`.\n */\n export class Renderer implements IRenderer {\n /**\n * Render the virtual element for a command palette header.\n *\n * @param data - The data to use for rendering the header.\n *\n * @returns A virtual element representing the header.\n */\n renderHeader(data: IHeaderRenderData): VirtualElement {\n let content = this.formatHeader(data);\n return h.li({ className: 'lm-CommandPalette-header' }, content);\n }\n\n /**\n * Render the virtual element for a command palette item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n */\n renderItem(data: IItemRenderData): VirtualElement {\n let className = this.createItemClass(data);\n let dataset = this.createItemDataset(data);\n if (data.item.isToggleable) {\n return h.li(\n {\n className,\n dataset,\n role: 'menuitemcheckbox',\n 'aria-checked': `${data.item.isToggled}`\n },\n this.renderItemIcon(data),\n this.renderItemContent(data),\n this.renderItemShortcut(data)\n );\n }\n return h.li(\n {\n className,\n dataset,\n role: 'menuitem'\n },\n this.renderItemIcon(data),\n this.renderItemContent(data),\n this.renderItemShortcut(data)\n );\n }\n\n /**\n * Render the empty results message for a command palette.\n *\n * @param data - The data to use for rendering the message.\n *\n * @returns A virtual element representing the message.\n */\n renderEmptyMessage(data: IEmptyMessageRenderData): VirtualElement {\n let content = this.formatEmptyMessage(data);\n return h.li({ className: 'lm-CommandPalette-emptyMessage' }, content);\n }\n\n /**\n * Render the icon for a command palette item.\n *\n * @param data - The data to use for rendering the icon.\n *\n * @returns A virtual element representing the icon.\n */\n renderItemIcon(data: IItemRenderData): VirtualElement {\n let className = this.createIconClass(data);\n\n // If data.item.icon is undefined, it will be ignored.\n return h.div({ className }, data.item.icon!, data.item.iconLabel);\n }\n\n /**\n * Render the content for a command palette item.\n *\n * @param data - The data to use for rendering the content.\n *\n * @returns A virtual element representing the content.\n */\n renderItemContent(data: IItemRenderData): VirtualElement {\n return h.div(\n { className: 'lm-CommandPalette-itemContent' },\n this.renderItemLabel(data),\n this.renderItemCaption(data)\n );\n }\n\n /**\n * Render the label for a command palette item.\n *\n * @param data - The data to use for rendering the label.\n *\n * @returns A virtual element representing the label.\n */\n renderItemLabel(data: IItemRenderData): VirtualElement {\n let content = this.formatItemLabel(data);\n return h.div({ className: 'lm-CommandPalette-itemLabel' }, content);\n }\n\n /**\n * Render the caption for a command palette item.\n *\n * @param data - The data to use for rendering the caption.\n *\n * @returns A virtual element representing the caption.\n */\n renderItemCaption(data: IItemRenderData): VirtualElement {\n let content = this.formatItemCaption(data);\n return h.div({ className: 'lm-CommandPalette-itemCaption' }, content);\n }\n\n /**\n * Render the shortcut for a command palette item.\n *\n * @param data - The data to use for rendering the shortcut.\n *\n * @returns A virtual element representing the shortcut.\n */\n renderItemShortcut(data: IItemRenderData): VirtualElement {\n let content = this.formatItemShortcut(data);\n return h.div({ className: 'lm-CommandPalette-itemShortcut' }, content);\n }\n\n /**\n * Create the class name for the command palette item.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the command palette item.\n */\n createItemClass(data: IItemRenderData): string {\n // Set up the initial class name.\n let name = 'lm-CommandPalette-item';\n\n // Add the boolean state classes.\n if (!data.item.isEnabled) {\n name += ' lm-mod-disabled';\n }\n if (data.item.isToggled) {\n name += ' lm-mod-toggled';\n }\n if (data.active) {\n name += ' lm-mod-active';\n }\n\n // Add the extra class.\n let extra = data.item.className;\n if (extra) {\n name += ` ${extra}`;\n }\n\n // Return the complete class name.\n return name;\n }\n\n /**\n * Create the dataset for the command palette item.\n *\n * @param data - The data to use for creating the dataset.\n *\n * @returns The dataset for the command palette item.\n */\n createItemDataset(data: IItemRenderData): ElementDataset {\n return { ...data.item.dataset, command: data.item.command };\n }\n\n /**\n * Create the class name for the command item icon.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the item icon.\n */\n createIconClass(data: IItemRenderData): string {\n let name = 'lm-CommandPalette-itemIcon';\n let extra = data.item.iconClass;\n return extra ? `${name} ${extra}` : name;\n }\n\n /**\n * Create the render content for the header node.\n *\n * @param data - The data to use for the header content.\n *\n * @returns The content to add to the header node.\n */\n formatHeader(data: IHeaderRenderData): h.Child {\n if (!data.indices || data.indices.length === 0) {\n return data.category;\n }\n return StringExt.highlight(data.category, data.indices, h.mark);\n }\n\n /**\n * Create the render content for the empty message node.\n *\n * @param data - The data to use for the empty message content.\n *\n * @returns The content to add to the empty message node.\n */\n formatEmptyMessage(data: IEmptyMessageRenderData): h.Child {\n return `No commands found that match '${data.query}'`;\n }\n\n /**\n * Create the render content for the item shortcut node.\n *\n * @param data - The data to use for the shortcut content.\n *\n * @returns The content to add to the shortcut node.\n */\n formatItemShortcut(data: IItemRenderData): h.Child {\n let kb = data.item.keyBinding;\n return kb ? CommandRegistry.formatKeystroke(kb.keys) : null;\n }\n\n /**\n * Create the render content for the item label node.\n *\n * @param data - The data to use for the label content.\n *\n * @returns The content to add to the label node.\n */\n formatItemLabel(data: IItemRenderData): h.Child {\n if (!data.indices || data.indices.length === 0) {\n return data.item.label;\n }\n return StringExt.highlight(data.item.label, data.indices, h.mark);\n }\n\n /**\n * Create the render content for the item caption node.\n *\n * @param data - The data to use for the caption content.\n *\n * @returns The content to add to the caption node.\n */\n formatItemCaption(data: IItemRenderData): h.Child {\n return data.item.caption;\n }\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Create the DOM node for a command palette.\n */\n export function createNode(): HTMLDivElement {\n let node = document.createElement('div');\n let search = document.createElement('div');\n let wrapper = document.createElement('div');\n let input = document.createElement('input');\n let content = document.createElement('ul');\n let clear = document.createElement('button');\n search.className = 'lm-CommandPalette-search';\n wrapper.className = 'lm-CommandPalette-wrapper';\n input.className = 'lm-CommandPalette-input';\n clear.className = 'lm-close-icon';\n\n content.className = 'lm-CommandPalette-content';\n content.setAttribute('role', 'menu');\n input.spellcheck = false;\n wrapper.appendChild(input);\n wrapper.appendChild(clear);\n search.appendChild(wrapper);\n node.appendChild(search);\n node.appendChild(content);\n return node;\n }\n\n /**\n * Create a new command item from a command registry and options.\n */\n export function createItem(\n commands: CommandRegistry,\n options: CommandPalette.IItemOptions\n ): CommandPalette.IItem {\n return new CommandItem(commands, options);\n }\n\n /**\n * A search result object for a header label.\n */\n export interface IHeaderResult {\n /**\n * The discriminated type of the object.\n */\n readonly type: 'header';\n\n /**\n * The category for the header.\n */\n readonly category: string;\n\n /**\n * The indices of the matched category characters.\n */\n readonly indices: ReadonlyArray | null;\n }\n\n /**\n * A search result object for a command item.\n */\n export interface IItemResult {\n /**\n * The discriminated type of the object.\n */\n readonly type: 'item';\n\n /**\n * The command item which was matched.\n */\n readonly item: CommandPalette.IItem;\n\n /**\n * The indices of the matched label characters.\n */\n readonly indices: ReadonlyArray | null;\n }\n\n /**\n * A type alias for a search result item.\n */\n export type SearchResult = IHeaderResult | IItemResult;\n\n /**\n * Search an array of command items for fuzzy matches.\n */\n export function search(\n items: CommandPalette.IItem[],\n query: string\n ): SearchResult[] {\n // Fuzzy match the items for the query.\n let scores = matchItems(items, query);\n\n // Sort the items based on their score.\n scores.sort(scoreCmp);\n\n // Create the results for the search.\n return createResults(scores);\n }\n\n /**\n * Test whether a result item can be activated.\n */\n export function canActivate(result: SearchResult): boolean {\n return result.type === 'item' && result.item.isEnabled;\n }\n\n /**\n * Normalize a category for a command item.\n */\n function normalizeCategory(category: string): string {\n return category.trim().replace(/\\s+/g, ' ');\n }\n\n /**\n * Normalize the query text for a fuzzy search.\n */\n function normalizeQuery(text: string): string {\n return text.replace(/\\s+/g, '').toLowerCase();\n }\n\n /**\n * An enum of the supported match types.\n */\n const enum MatchType {\n Label,\n Category,\n Split,\n Default\n }\n\n /**\n * A text match score with associated command item.\n */\n interface IScore {\n /**\n * The numerical type for the text match.\n */\n matchType: MatchType;\n\n /**\n * The numerical score for the text match.\n */\n score: number;\n\n /**\n * The indices of the matched category characters.\n */\n categoryIndices: number[] | null;\n\n /**\n * The indices of the matched label characters.\n */\n labelIndices: number[] | null;\n\n /**\n * The command item associated with the match.\n */\n item: CommandPalette.IItem;\n }\n\n /**\n * Perform a fuzzy match on an array of command items.\n */\n function matchItems(items: CommandPalette.IItem[], query: string): IScore[] {\n // Normalize the query text to lower case with no whitespace.\n query = normalizeQuery(query);\n\n // Create the array to hold the scores.\n let scores: IScore[] = [];\n\n // Iterate over the items and match against the query.\n for (let i = 0, n = items.length; i < n; ++i) {\n // Ignore items which are not visible.\n let item = items[i];\n if (!item.isVisible) {\n continue;\n }\n\n // If the query is empty, all items are matched by default.\n if (!query) {\n scores.push({\n matchType: MatchType.Default,\n categoryIndices: null,\n labelIndices: null,\n score: 0,\n item\n });\n continue;\n }\n\n // Run the fuzzy search for the item and query.\n let score = fuzzySearch(item, query);\n\n // Ignore the item if it is not a match.\n if (!score) {\n continue;\n }\n\n // Penalize disabled items.\n // TODO - push disabled items all the way down in sort cmp?\n if (!item.isEnabled) {\n score.score += 1000;\n }\n\n // Add the score to the results.\n scores.push(score);\n }\n\n // Return the final array of scores.\n return scores;\n }\n\n /**\n * Perform a fuzzy search on a single command item.\n */\n function fuzzySearch(\n item: CommandPalette.IItem,\n query: string\n ): IScore | null {\n // Create the source text to be searched.\n let category = item.category.toLowerCase();\n let label = item.label.toLowerCase();\n let source = `${category} ${label}`;\n\n // Set up the match score and indices array.\n let score = Infinity;\n let indices: number[] | null = null;\n\n // The regex for search word boundaries\n let rgx = /\\b\\w/g;\n\n // Search the source by word boundary.\n // eslint-disable-next-line no-constant-condition\n while (true) {\n // Find the next word boundary in the source.\n let rgxMatch = rgx.exec(source);\n\n // Break if there is no more source context.\n if (!rgxMatch) {\n break;\n }\n\n // Run the string match on the relevant substring.\n let match = StringExt.matchSumOfDeltas(source, query, rgxMatch.index);\n\n // Break if there is no match.\n if (!match) {\n break;\n }\n\n // Update the match if the score is better.\n if (match.score <= score) {\n score = match.score;\n indices = match.indices;\n }\n }\n\n // Bail if there was no match.\n if (!indices || score === Infinity) {\n return null;\n }\n\n // Compute the pivot index between category and label text.\n let pivot = category.length + 1;\n\n // Find the slice index to separate matched indices.\n let j = ArrayExt.lowerBound(indices, pivot, (a, b) => a - b);\n\n // Extract the matched category and label indices.\n let categoryIndices = indices.slice(0, j);\n let labelIndices = indices.slice(j);\n\n // Adjust the label indices for the pivot offset.\n for (let i = 0, n = labelIndices.length; i < n; ++i) {\n labelIndices[i] -= pivot;\n }\n\n // Handle a pure label match.\n if (categoryIndices.length === 0) {\n return {\n matchType: MatchType.Label,\n categoryIndices: null,\n labelIndices,\n score,\n item\n };\n }\n\n // Handle a pure category match.\n if (labelIndices.length === 0) {\n return {\n matchType: MatchType.Category,\n categoryIndices,\n labelIndices: null,\n score,\n item\n };\n }\n\n // Handle a split match.\n return {\n matchType: MatchType.Split,\n categoryIndices,\n labelIndices,\n score,\n item\n };\n }\n\n /**\n * A sort comparison function for a match score.\n */\n function scoreCmp(a: IScore, b: IScore): number {\n // First compare based on the match type\n let m1 = a.matchType - b.matchType;\n if (m1 !== 0) {\n return m1;\n }\n\n // Otherwise, compare based on the match score.\n let d1 = a.score - b.score;\n if (d1 !== 0) {\n return d1;\n }\n\n // Find the match index based on the match type.\n let i1 = 0;\n let i2 = 0;\n switch (a.matchType) {\n case MatchType.Label:\n i1 = a.labelIndices![0];\n i2 = b.labelIndices![0];\n break;\n case MatchType.Category:\n case MatchType.Split:\n i1 = a.categoryIndices![0];\n i2 = b.categoryIndices![0];\n break;\n }\n\n // Compare based on the match index.\n if (i1 !== i2) {\n return i1 - i2;\n }\n\n // Otherwise, compare by category.\n let d2 = a.item.category.localeCompare(b.item.category);\n if (d2 !== 0) {\n return d2;\n }\n\n // Otherwise, compare by rank.\n let r1 = a.item.rank;\n let r2 = b.item.rank;\n if (r1 !== r2) {\n return r1 < r2 ? -1 : 1; // Infinity safe\n }\n\n // Finally, compare by label.\n return a.item.label.localeCompare(b.item.label);\n }\n\n /**\n * Create the results from an array of sorted scores.\n */\n function createResults(scores: IScore[]): SearchResult[] {\n // Set up the search results array.\n let results: SearchResult[] = [];\n\n // Iterate over each score in the array.\n for (let i = 0, n = scores.length; i < n; ++i) {\n // Extract the current item and indices.\n let { item, categoryIndices, labelIndices } = scores[i];\n\n // Extract the category for the current item.\n let category = item.category;\n\n // Is this the same category as the preceding result?\n if (i === 0 || category !== scores[i - 1].item.category) {\n // Add the header result for the category.\n results.push({ type: 'header', category, indices: categoryIndices });\n }\n\n // Create the item result for the score.\n results.push({ type: 'item', item, indices: labelIndices });\n }\n\n // Return the final results.\n return results;\n }\n\n /**\n * A concrete implementation of `CommandPalette.IItem`.\n */\n class CommandItem implements CommandPalette.IItem {\n /**\n * Construct a new command item.\n */\n constructor(\n commands: CommandRegistry,\n options: CommandPalette.IItemOptions\n ) {\n this._commands = commands;\n this.category = normalizeCategory(options.category);\n this.command = options.command;\n this.args = options.args || JSONExt.emptyObject;\n this.rank = options.rank !== undefined ? options.rank : Infinity;\n }\n\n /**\n * The category for the command item.\n */\n readonly category: string;\n\n /**\n * The command to execute when the item is triggered.\n */\n readonly command: string;\n\n /**\n * The arguments for the command.\n */\n readonly args: ReadonlyJSONObject;\n\n /**\n * The rank for the command item.\n */\n readonly rank: number;\n\n /**\n * The display label for the command item.\n */\n get label(): string {\n return this._commands.label(this.command, this.args);\n }\n\n /**\n * The icon renderer for the command item.\n */\n get icon(): VirtualElement.IRenderer | undefined {\n return this._commands.icon(this.command, this.args);\n }\n\n /**\n * The icon class for the command item.\n */\n get iconClass(): string {\n return this._commands.iconClass(this.command, this.args);\n }\n\n /**\n * The icon label for the command item.\n */\n get iconLabel(): string {\n return this._commands.iconLabel(this.command, this.args);\n }\n\n /**\n * The display caption for the command item.\n */\n get caption(): string {\n return this._commands.caption(this.command, this.args);\n }\n\n /**\n * The extra class name for the command item.\n */\n get className(): string {\n return this._commands.className(this.command, this.args);\n }\n\n /**\n * The dataset for the command item.\n */\n get dataset(): CommandRegistry.Dataset {\n return this._commands.dataset(this.command, this.args);\n }\n\n /**\n * Whether the command item is enabled.\n */\n get isEnabled(): boolean {\n return this._commands.isEnabled(this.command, this.args);\n }\n\n /**\n * Whether the command item is toggled.\n */\n get isToggled(): boolean {\n return this._commands.isToggled(this.command, this.args);\n }\n\n /**\n * Whether the command item is toggleable.\n */\n get isToggleable(): boolean {\n return this._commands.isToggleable(this.command, this.args);\n }\n\n /**\n * Whether the command item is visible.\n */\n get isVisible(): boolean {\n return this._commands.isVisible(this.command, this.args);\n }\n\n /**\n * The key binding for the command item.\n */\n get keyBinding(): CommandRegistry.IKeyBinding | null {\n let { command, args } = this;\n return (\n ArrayExt.findLastValue(this._commands.keyBindings, kb => {\n return kb.command === command && JSONExt.deepEqual(kb.args, args);\n }) || null\n );\n }\n\n private _commands: CommandRegistry;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { CommandRegistry } from '@lumino/commands';\n\nimport { JSONExt, ReadonlyJSONObject } from '@lumino/coreutils';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { getKeyboardLayout } from '@lumino/keyboard';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport {\n ARIAAttrNames,\n ElementARIAAttrs,\n ElementDataset,\n h,\n VirtualDOM,\n VirtualElement\n} from '@lumino/virtualdom';\n\nimport { Widget } from './widget';\n\ninterface IWindowData {\n pageXOffset: number;\n pageYOffset: number;\n clientWidth: number;\n clientHeight: number;\n}\n\n/**\n * A widget which displays items as a canonical menu.\n */\nexport class Menu extends Widget {\n /**\n * Construct a new menu.\n *\n * @param options - The options for initializing the menu.\n */\n constructor(options: Menu.IOptions) {\n super({ node: Private.createNode() });\n this.addClass('lm-Menu');\n this.setFlag(Widget.Flag.DisallowLayout);\n this.commands = options.commands;\n this.renderer = options.renderer || Menu.defaultRenderer;\n }\n\n /**\n * Dispose of the resources held by the menu.\n */\n dispose(): void {\n this.close();\n this._items.length = 0;\n super.dispose();\n }\n\n /**\n * A signal emitted just before the menu is closed.\n *\n * #### Notes\n * This signal is emitted when the menu receives a `'close-request'`\n * message, just before it removes itself from the DOM.\n *\n * This signal is not emitted if the menu is already detached from\n * the DOM when it receives the `'close-request'` message.\n */\n get aboutToClose(): ISignal {\n return this._aboutToClose;\n }\n\n /**\n * A signal emitted when a new menu is requested by the user.\n *\n * #### Notes\n * This signal is emitted whenever the user presses the right or left\n * arrow keys, and a submenu cannot be opened or closed in response.\n *\n * This signal is useful when implementing menu bars in order to open\n * the next or previous menu in response to a user key press.\n *\n * This signal is only emitted for the root menu in a hierarchy.\n */\n get menuRequested(): ISignal {\n return this._menuRequested;\n }\n\n /**\n * The command registry used by the menu.\n */\n readonly commands: CommandRegistry;\n\n /**\n * The renderer used by the menu.\n */\n readonly renderer: Menu.IRenderer;\n\n /**\n * The parent menu of the menu.\n *\n * #### Notes\n * This is `null` unless the menu is an open submenu.\n */\n get parentMenu(): Menu | null {\n return this._parentMenu;\n }\n\n /**\n * The child menu of the menu.\n *\n * #### Notes\n * This is `null` unless the menu has an open submenu.\n */\n get childMenu(): Menu | null {\n return this._childMenu;\n }\n\n /**\n * The root menu of the menu hierarchy.\n */\n get rootMenu(): Menu {\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n let menu: Menu = this;\n while (menu._parentMenu) {\n menu = menu._parentMenu;\n }\n return menu;\n }\n\n /**\n * The leaf menu of the menu hierarchy.\n */\n get leafMenu(): Menu {\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n let menu: Menu = this;\n while (menu._childMenu) {\n menu = menu._childMenu;\n }\n return menu;\n }\n\n /**\n * The menu content node.\n *\n * #### Notes\n * This is the node which holds the menu item nodes.\n *\n * Modifying this node directly can lead to undefined behavior.\n */\n get contentNode(): HTMLUListElement {\n return this.node.getElementsByClassName(\n 'lm-Menu-content'\n )[0] as HTMLUListElement;\n }\n\n /**\n * Get the currently active menu item.\n */\n get activeItem(): Menu.IItem | null {\n return this._items[this._activeIndex] || null;\n }\n\n /**\n * Set the currently active menu item.\n *\n * #### Notes\n * If the item cannot be activated, the item will be set to `null`.\n */\n set activeItem(value: Menu.IItem | null) {\n this.activeIndex = value ? this._items.indexOf(value) : -1;\n }\n\n /**\n * Get the index of the currently active menu item.\n *\n * #### Notes\n * This will be `-1` if no menu item is active.\n */\n get activeIndex(): number {\n return this._activeIndex;\n }\n\n /**\n * Set the index of the currently active menu item.\n *\n * #### Notes\n * If the item cannot be activated, the index will be set to `-1`.\n */\n set activeIndex(value: number) {\n // Adjust the value for an out of range index.\n if (value < 0 || value >= this._items.length) {\n value = -1;\n }\n\n // Ensure the item can be activated.\n if (value !== -1 && !Private.canActivate(this._items[value])) {\n value = -1;\n }\n\n // Bail if the index will not change.\n if (this._activeIndex === value) {\n return;\n }\n\n // Update the active index.\n this._activeIndex = value;\n\n // Make active element in focus\n if (\n this._activeIndex >= 0 &&\n this.contentNode.childNodes[this._activeIndex]\n ) {\n (this.contentNode.childNodes[this._activeIndex] as HTMLElement).focus();\n }\n\n // schedule an update of the items.\n this.update();\n }\n\n /**\n * A read-only array of the menu items in the menu.\n */\n get items(): ReadonlyArray {\n return this._items;\n }\n\n /**\n * Activate the next selectable item in the menu.\n *\n * #### Notes\n * If no item is selectable, the index will be set to `-1`.\n */\n activateNextItem(): void {\n let n = this._items.length;\n let ai = this._activeIndex;\n let start = ai < n - 1 ? ai + 1 : 0;\n let stop = start === 0 ? n - 1 : start - 1;\n this.activeIndex = ArrayExt.findFirstIndex(\n this._items,\n Private.canActivate,\n start,\n stop\n );\n }\n\n /**\n * Activate the previous selectable item in the menu.\n *\n * #### Notes\n * If no item is selectable, the index will be set to `-1`.\n */\n activatePreviousItem(): void {\n let n = this._items.length;\n let ai = this._activeIndex;\n let start = ai <= 0 ? n - 1 : ai - 1;\n let stop = start === n - 1 ? 0 : start + 1;\n this.activeIndex = ArrayExt.findLastIndex(\n this._items,\n Private.canActivate,\n start,\n stop\n );\n }\n\n /**\n * Trigger the active menu item.\n *\n * #### Notes\n * If the active item is a submenu, it will be opened and the first\n * item will be activated.\n *\n * If the active item is a command, the command will be executed.\n *\n * If the menu is not attached, this is a no-op.\n *\n * If there is no active item, this is a no-op.\n */\n triggerActiveItem(): void {\n // Bail if the menu is not attached.\n if (!this.isAttached) {\n return;\n }\n\n // Bail if there is no active item.\n let item = this.activeItem;\n if (!item) {\n return;\n }\n\n // Cancel the pending timers.\n this._cancelOpenTimer();\n this._cancelCloseTimer();\n\n // If the item is a submenu, open it.\n if (item.type === 'submenu') {\n this._openChildMenu(true);\n return;\n }\n\n // Close the root menu before executing the command.\n this.rootMenu.close();\n\n // Execute the command for the item.\n let { command, args } = item;\n if (this.commands.isEnabled(command, args)) {\n this.commands.execute(command, args);\n } else {\n console.log(`Command '${command}' is disabled.`);\n }\n }\n\n /**\n * Add a menu item to the end of the menu.\n *\n * @param options - The options for creating the menu item.\n *\n * @returns The menu item added to the menu.\n */\n addItem(options: Menu.IItemOptions): Menu.IItem {\n return this.insertItem(this._items.length, options);\n }\n\n /**\n * Insert a menu item into the menu at the specified index.\n *\n * @param index - The index at which to insert the item.\n *\n * @param options - The options for creating the menu item.\n *\n * @returns The menu item added to the menu.\n *\n * #### Notes\n * The index will be clamped to the bounds of the items.\n */\n insertItem(index: number, options: Menu.IItemOptions): Menu.IItem {\n // Close the menu if it's attached.\n if (this.isAttached) {\n this.close();\n }\n\n // Reset the active index.\n this.activeIndex = -1;\n\n // Clamp the insert index to the array bounds.\n let i = Math.max(0, Math.min(index, this._items.length));\n\n // Create the item for the options.\n let item = Private.createItem(this, options);\n\n // Insert the item into the array.\n ArrayExt.insert(this._items, i, item);\n\n // Schedule an update of the items.\n this.update();\n\n // Return the item added to the menu.\n return item;\n }\n\n /**\n * Remove an item from the menu.\n *\n * @param item - The item to remove from the menu.\n *\n * #### Notes\n * This is a no-op if the item is not in the menu.\n */\n removeItem(item: Menu.IItem): void {\n this.removeItemAt(this._items.indexOf(item));\n }\n\n /**\n * Remove the item at a given index from the menu.\n *\n * @param index - The index of the item to remove.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n removeItemAt(index: number): void {\n // Close the menu if it's attached.\n if (this.isAttached) {\n this.close();\n }\n\n // Reset the active index.\n this.activeIndex = -1;\n\n // Remove the item from the array.\n let item = ArrayExt.removeAt(this._items, index);\n\n // Bail if the index is out of range.\n if (!item) {\n return;\n }\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * Remove all menu items from the menu.\n */\n clearItems(): void {\n // Close the menu if it's attached.\n if (this.isAttached) {\n this.close();\n }\n\n // Reset the active index.\n this.activeIndex = -1;\n\n // Bail if there is nothing to remove.\n if (this._items.length === 0) {\n return;\n }\n\n // Clear the items.\n this._items.length = 0;\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * Open the menu at the specified location.\n *\n * @param x - The client X coordinate of the menu location.\n *\n * @param y - The client Y coordinate of the menu location.\n *\n * @param options - The additional options for opening the menu.\n *\n * #### Notes\n * The menu will be opened at the given location unless it will not\n * fully fit on the screen. If it will not fit, it will be adjusted\n * to fit naturally on the screen.\n *\n * The menu will be attached under the `host` element in the DOM\n * (or `document.body` if `host` is `null`) and before the `ref`\n * element (or as the last child of `host` if `ref` is `null`).\n * The menu may be displayed outside of the `host` element\n * following the rules of CSS absolute positioning.\n *\n * This is a no-op if the menu is already attached to the DOM.\n */\n open(x: number, y: number, options: Menu.IOpenOptions = {}): void {\n // Bail early if the menu is already attached.\n if (this.isAttached) {\n return;\n }\n\n // Extract the menu options.\n let forceX = options.forceX || false;\n let forceY = options.forceY || false;\n const host = options.host ?? null;\n const ref = options.ref ?? null;\n\n // Open the menu as a root menu.\n Private.openRootMenu(this, x, y, forceX, forceY, host, ref);\n\n // Activate the menu to accept keyboard input.\n this.activate();\n }\n\n /**\n * Handle the DOM events for the menu.\n *\n * @param event - The DOM event sent to the menu.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the menu's DOM nodes. It should\n * not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'mouseup':\n this._evtMouseUp(event as MouseEvent);\n break;\n case 'mousemove':\n this._evtMouseMove(event as MouseEvent);\n break;\n case 'mouseenter':\n this._evtMouseEnter(event as MouseEvent);\n break;\n case 'mouseleave':\n this._evtMouseLeave(event as MouseEvent);\n break;\n case 'mousedown':\n this._evtMouseDown(event as MouseEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('keydown', this);\n this.node.addEventListener('mouseup', this);\n this.node.addEventListener('mousemove', this);\n this.node.addEventListener('mouseenter', this);\n this.node.addEventListener('mouseleave', this);\n this.node.addEventListener('contextmenu', this);\n document.addEventListener('mousedown', this, true);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('keydown', this);\n this.node.removeEventListener('mouseup', this);\n this.node.removeEventListener('mousemove', this);\n this.node.removeEventListener('mouseenter', this);\n this.node.removeEventListener('mouseleave', this);\n this.node.removeEventListener('contextmenu', this);\n document.removeEventListener('mousedown', this, true);\n }\n\n /**\n * A message handler invoked on an `'activate-request'` message.\n */\n protected onActivateRequest(msg: Message): void {\n if (this.isAttached) {\n this.node.focus();\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n let items = this._items;\n let renderer = this.renderer;\n let activeIndex = this._activeIndex;\n let collapsedFlags = Private.computeCollapsed(items);\n let content = new Array(items.length);\n for (let i = 0, n = items.length; i < n; ++i) {\n let item = items[i];\n let active = i === activeIndex;\n let collapsed = collapsedFlags[i];\n content[i] = renderer.renderItem({\n item,\n active,\n collapsed,\n onfocus: () => {\n this.activeIndex = i;\n }\n });\n }\n VirtualDOM.render(content, this.contentNode);\n }\n\n /**\n * A message handler invoked on a `'close-request'` message.\n */\n protected onCloseRequest(msg: Message): void {\n // Cancel the pending timers.\n this._cancelOpenTimer();\n this._cancelCloseTimer();\n\n // Reset the active index.\n this.activeIndex = -1;\n\n // Close any open child menu.\n let childMenu = this._childMenu;\n if (childMenu) {\n this._childIndex = -1;\n this._childMenu = null;\n childMenu._parentMenu = null;\n childMenu.close();\n }\n\n // Remove this menu from its parent and activate the parent.\n let parentMenu = this._parentMenu;\n if (parentMenu) {\n this._parentMenu = null;\n parentMenu._childIndex = -1;\n parentMenu._childMenu = null;\n parentMenu.activate();\n }\n\n // Emit the `aboutToClose` signal if the menu is attached.\n if (this.isAttached) {\n this._aboutToClose.emit(undefined);\n }\n\n // Finish closing the menu.\n super.onCloseRequest(msg);\n }\n\n /**\n * Handle the `'keydown'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the menu node.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // A menu handles all keydown events.\n event.preventDefault();\n event.stopPropagation();\n\n // Fetch the key code for the event.\n let kc = event.keyCode;\n\n // Enter\n if (kc === 13) {\n this.triggerActiveItem();\n return;\n }\n\n // Escape\n if (kc === 27) {\n this.close();\n return;\n }\n\n // Left Arrow\n if (kc === 37) {\n if (this._parentMenu) {\n this.close();\n } else {\n this._menuRequested.emit('previous');\n }\n return;\n }\n\n // Up Arrow\n if (kc === 38) {\n this.activatePreviousItem();\n return;\n }\n\n // Right Arrow\n if (kc === 39) {\n let item = this.activeItem;\n if (item && item.type === 'submenu') {\n this.triggerActiveItem();\n } else {\n this.rootMenu._menuRequested.emit('next');\n }\n return;\n }\n\n // Down Arrow\n if (kc === 40) {\n this.activateNextItem();\n return;\n }\n\n // Get the pressed key character.\n let key = getKeyboardLayout().keyForKeydownEvent(event);\n\n // Bail if the key is not valid.\n if (!key) {\n return;\n }\n\n // Search for the next best matching mnemonic item.\n let start = this._activeIndex + 1;\n let result = Private.findMnemonic(this._items, key, start);\n\n // Handle the requested mnemonic based on the search results.\n // If exactly one mnemonic is matched, that item is triggered.\n // Otherwise, the next mnemonic is activated if available,\n // followed by the auto mnemonic if available.\n if (result.index !== -1 && !result.multiple) {\n this.activeIndex = result.index;\n this.triggerActiveItem();\n } else if (result.index !== -1) {\n this.activeIndex = result.index;\n } else if (result.auto !== -1) {\n this.activeIndex = result.auto;\n }\n }\n\n /**\n * Handle the `'mouseup'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the menu node.\n */\n private _evtMouseUp(event: MouseEvent): void {\n if (event.button !== 0) {\n return;\n }\n event.preventDefault();\n event.stopPropagation();\n this.triggerActiveItem();\n }\n\n /**\n * Handle the `'mousemove'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the menu node.\n */\n private _evtMouseMove(event: MouseEvent): void {\n // Hit test the item nodes for the item under the mouse.\n let index = ArrayExt.findFirstIndex(this.contentNode.children, node => {\n return ElementExt.hitTest(node, event.clientX, event.clientY);\n });\n\n // Bail early if the mouse is already over the active index.\n if (index === this._activeIndex) {\n return;\n }\n\n // Update and coerce the active index.\n this.activeIndex = index;\n index = this.activeIndex;\n\n // If the index is the current child index, cancel the timers.\n if (index === this._childIndex) {\n this._cancelOpenTimer();\n this._cancelCloseTimer();\n return;\n }\n\n // If a child menu is currently open, start the close timer.\n if (this._childIndex !== -1) {\n this._startCloseTimer();\n }\n\n // Cancel the open timer to give a full delay for opening.\n this._cancelOpenTimer();\n\n // Bail if the active item is not a valid submenu item.\n let item = this.activeItem;\n if (!item || item.type !== 'submenu' || !item.submenu) {\n return;\n }\n\n // Start the open timer to open the active item submenu.\n this._startOpenTimer();\n }\n\n /**\n * Handle the `'mouseenter'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the menu node.\n */\n private _evtMouseEnter(event: MouseEvent): void {\n // Synchronize the active ancestor items.\n for (let menu = this._parentMenu; menu; menu = menu._parentMenu) {\n menu._cancelOpenTimer();\n menu._cancelCloseTimer();\n menu.activeIndex = menu._childIndex;\n }\n }\n\n /**\n * Handle the `'mouseleave'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the menu node.\n */\n private _evtMouseLeave(event: MouseEvent): void {\n // Cancel any pending submenu opening.\n this._cancelOpenTimer();\n\n // If there is no open child menu, just reset the active index.\n if (!this._childMenu) {\n this.activeIndex = -1;\n return;\n }\n\n // If the mouse is over the child menu, cancel the close timer.\n let { clientX, clientY } = event;\n if (ElementExt.hitTest(this._childMenu.node, clientX, clientY)) {\n this._cancelCloseTimer();\n return;\n }\n\n // Otherwise, reset the active index and start the close timer.\n this.activeIndex = -1;\n this._startCloseTimer();\n }\n\n /**\n * Handle the `'mousedown'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the document node.\n */\n private _evtMouseDown(event: MouseEvent): void {\n // Bail if the menu is not a root menu.\n if (this._parentMenu) {\n return;\n }\n\n // The mouse button which is pressed is irrelevant. If the press\n // is not on a menu, the entire hierarchy is closed and the event\n // is allowed to propagate. This allows other code to act on the\n // event, such as focusing the clicked element.\n if (Private.hitTestMenus(this, event.clientX, event.clientY)) {\n event.preventDefault();\n event.stopPropagation();\n } else {\n this.close();\n }\n }\n\n /**\n * Open the child menu at the active index immediately.\n *\n * If a different child menu is already open, it will be closed,\n * even if the active item is not a valid submenu.\n */\n private _openChildMenu(activateFirst = false): void {\n // If the item is not a valid submenu, close the child menu.\n let item = this.activeItem;\n if (!item || item.type !== 'submenu' || !item.submenu) {\n this._closeChildMenu();\n return;\n }\n\n // Do nothing if the child menu will not change.\n let submenu = item.submenu;\n if (submenu === this._childMenu) {\n return;\n }\n\n // Prior to any DOM modifications save window data\n Menu.saveWindowData();\n\n // Ensure the current child menu is closed.\n this._closeChildMenu();\n\n // Update the private child state.\n this._childMenu = submenu;\n this._childIndex = this._activeIndex;\n\n // Set the parent menu reference for the child.\n submenu._parentMenu = this;\n\n // Ensure the menu is updated and lookup the item node.\n MessageLoop.sendMessage(this, Widget.Msg.UpdateRequest);\n let itemNode = this.contentNode.children[this._activeIndex];\n\n // Open the submenu at the active node.\n Private.openSubmenu(submenu, itemNode as HTMLElement);\n\n // Activate the first item if desired.\n if (activateFirst) {\n submenu.activeIndex = -1;\n submenu.activateNextItem();\n }\n\n // Activate the child menu.\n submenu.activate();\n }\n\n /**\n * Close the child menu immediately.\n *\n * This is a no-op if a child menu is not open.\n */\n private _closeChildMenu(): void {\n if (this._childMenu) {\n this._childMenu.close();\n }\n }\n\n /**\n * Start the open timer, unless it is already pending.\n */\n private _startOpenTimer(): void {\n if (this._openTimerID === 0) {\n this._openTimerID = window.setTimeout(() => {\n this._openTimerID = 0;\n this._openChildMenu();\n }, Private.TIMER_DELAY);\n }\n }\n\n /**\n * Start the close timer, unless it is already pending.\n */\n private _startCloseTimer(): void {\n if (this._closeTimerID === 0) {\n this._closeTimerID = window.setTimeout(() => {\n this._closeTimerID = 0;\n this._closeChildMenu();\n }, Private.TIMER_DELAY);\n }\n }\n\n /**\n * Cancel the open timer, if the timer is pending.\n */\n private _cancelOpenTimer(): void {\n if (this._openTimerID !== 0) {\n clearTimeout(this._openTimerID);\n this._openTimerID = 0;\n }\n }\n\n /**\n * Cancel the close timer, if the timer is pending.\n */\n private _cancelCloseTimer(): void {\n if (this._closeTimerID !== 0) {\n clearTimeout(this._closeTimerID);\n this._closeTimerID = 0;\n }\n }\n\n /**\n * Save window data used for menu positioning in transient cache.\n *\n * In order to avoid layout trashing it is recommended to invoke this\n * method immediately prior to opening the menu and any DOM modifications\n * (like closing previously visible menu, or adding a class to menu widget).\n *\n * The transient cache will be released upon `open()` call.\n */\n static saveWindowData(): void {\n Private.saveWindowData();\n }\n\n private _childIndex = -1;\n private _activeIndex = -1;\n private _openTimerID = 0;\n private _closeTimerID = 0;\n private _items: Menu.IItem[] = [];\n private _childMenu: Menu | null = null;\n private _parentMenu: Menu | null = null;\n private _aboutToClose = new Signal(this);\n private _menuRequested = new Signal(this);\n}\n\n/**\n * The namespace for the `Menu` class statics.\n */\nexport namespace Menu {\n /**\n * An options object for creating a menu.\n */\n export interface IOptions {\n /**\n * The command registry for use with the menu.\n */\n commands: CommandRegistry;\n\n /**\n * A custom renderer for use with the menu.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n }\n\n /**\n * An options object for the `open` method on a menu.\n */\n export interface IOpenOptions {\n /**\n * Whether to force the X position of the menu.\n *\n * Setting to `true` will disable the logic which repositions the\n * X coordinate of the menu if it will not fit entirely on screen.\n *\n * The default is `false`.\n */\n forceX?: boolean;\n\n /**\n * Whether to force the Y position of the menu.\n *\n * Setting to `true` will disable the logic which repositions the\n * Y coordinate of the menu if it will not fit entirely on screen.\n *\n * The default is `false`.\n */\n forceY?: boolean;\n\n /**\n * The DOM node to use as the menu's host.\n *\n * If not specified then uses `document.body`.\n */\n host?: HTMLElement;\n\n /**\n * The child of `host` to use as the reference element.\n * If this is provided, the menu will be inserted before this\n * node in the host. The default is `null`, which will cause the\n * menu to be added as the last child of the host.\n */\n ref?: HTMLElement;\n }\n\n /**\n * A type alias for a menu item type.\n */\n export type ItemType = 'command' | 'submenu' | 'separator';\n\n /**\n * An options object for creating a menu item.\n */\n export interface IItemOptions {\n /**\n * The type of the menu item.\n *\n * The default value is `'command'`.\n */\n type?: ItemType;\n\n /**\n * The command to execute when the item is triggered.\n *\n * The default value is an empty string.\n */\n command?: string;\n\n /**\n * The arguments for the command.\n *\n * The default value is an empty object.\n */\n args?: ReadonlyJSONObject;\n\n /**\n * The submenu for a `'submenu'` type item.\n *\n * The default value is `null`.\n */\n submenu?: Menu | null;\n }\n\n /**\n * An object which represents a menu item.\n *\n * #### Notes\n * Item objects are created automatically by a menu.\n */\n export interface IItem {\n /**\n * The type of the menu item.\n */\n readonly type: ItemType;\n\n /**\n * The command to execute when the item is triggered.\n */\n readonly command: string;\n\n /**\n * The arguments for the command.\n */\n readonly args: ReadonlyJSONObject;\n\n /**\n * The submenu for a `'submenu'` type item.\n */\n readonly submenu: Menu | null;\n\n /**\n * The display label for the menu item.\n */\n readonly label: string;\n\n /**\n * The mnemonic index for the menu item.\n */\n readonly mnemonic: number;\n\n /**\n * The icon renderer for the menu item.\n */\n readonly icon: VirtualElement.IRenderer | undefined;\n\n /**\n * The icon class for the menu item.\n */\n readonly iconClass: string;\n\n /**\n * The icon label for the menu item.\n */\n readonly iconLabel: string;\n\n /**\n * The display caption for the menu item.\n */\n readonly caption: string;\n\n /**\n * The extra class name for the menu item.\n */\n readonly className: string;\n\n /**\n * The dataset for the menu item.\n */\n readonly dataset: CommandRegistry.Dataset;\n\n /**\n * Whether the menu item is enabled.\n */\n readonly isEnabled: boolean;\n\n /**\n * Whether the menu item is toggled.\n */\n readonly isToggled: boolean;\n\n /**\n * Whether the menu item is visible.\n */\n readonly isVisible: boolean;\n\n /**\n * The key binding for the menu item.\n */\n readonly keyBinding: CommandRegistry.IKeyBinding | null;\n }\n\n /**\n * An object which holds the data to render a menu item.\n */\n export interface IRenderData {\n /**\n * The item to be rendered.\n */\n readonly item: IItem;\n\n /**\n * Whether the item is the active item.\n */\n readonly active: boolean;\n\n /**\n * Whether the item should be collapsed.\n */\n readonly collapsed: boolean;\n\n /**\n * Handler for when element is in focus.\n */\n readonly onfocus?: () => void;\n }\n\n /**\n * A renderer for use with a menu.\n */\n export interface IRenderer {\n /**\n * Render the virtual element for a menu item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n */\n renderItem(data: IRenderData): VirtualElement;\n }\n\n /**\n * The default implementation of `IRenderer`.\n *\n * #### Notes\n * Subclasses are free to reimplement rendering methods as needed.\n */\n export class Renderer implements IRenderer {\n /**\n * Render the virtual element for a menu item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n */\n renderItem(data: IRenderData): VirtualElement {\n let className = this.createItemClass(data);\n let dataset = this.createItemDataset(data);\n let aria = this.createItemARIA(data);\n return h.li(\n {\n className,\n dataset,\n tabindex: '0',\n onfocus: data.onfocus,\n ...aria\n },\n this.renderIcon(data),\n this.renderLabel(data),\n this.renderShortcut(data),\n this.renderSubmenu(data)\n );\n }\n\n /**\n * Render the icon element for a menu item.\n *\n * @param data - The data to use for rendering the icon.\n *\n * @returns A virtual element representing the item icon.\n */\n renderIcon(data: IRenderData): VirtualElement {\n let className = this.createIconClass(data);\n\n // If data.item.icon is undefined, it will be ignored.\n return h.div({ className }, data.item.icon!, data.item.iconLabel);\n }\n\n /**\n * Render the label element for a menu item.\n *\n * @param data - The data to use for rendering the label.\n *\n * @returns A virtual element representing the item label.\n */\n renderLabel(data: IRenderData): VirtualElement {\n let content = this.formatLabel(data);\n return h.div({ className: 'lm-Menu-itemLabel' }, content);\n }\n\n /**\n * Render the shortcut element for a menu item.\n *\n * @param data - The data to use for rendering the shortcut.\n *\n * @returns A virtual element representing the item shortcut.\n */\n renderShortcut(data: IRenderData): VirtualElement {\n let content = this.formatShortcut(data);\n return h.div({ className: 'lm-Menu-itemShortcut' }, content);\n }\n\n /**\n * Render the submenu icon element for a menu item.\n *\n * @param data - The data to use for rendering the submenu icon.\n *\n * @returns A virtual element representing the submenu icon.\n */\n renderSubmenu(data: IRenderData): VirtualElement {\n return h.div({ className: 'lm-Menu-itemSubmenuIcon' });\n }\n\n /**\n * Create the class name for the menu item.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the menu item.\n */\n createItemClass(data: IRenderData): string {\n // Setup the initial class name.\n let name = 'lm-Menu-item';\n\n // Add the boolean state classes.\n if (!data.item.isEnabled) {\n name += ' lm-mod-disabled';\n }\n if (data.item.isToggled) {\n name += ' lm-mod-toggled';\n }\n if (!data.item.isVisible) {\n name += ' lm-mod-hidden';\n }\n if (data.active) {\n name += ' lm-mod-active';\n }\n if (data.collapsed) {\n name += ' lm-mod-collapsed';\n }\n\n // Add the extra class.\n let extra = data.item.className;\n if (extra) {\n name += ` ${extra}`;\n }\n\n // Return the complete class name.\n return name;\n }\n\n /**\n * Create the dataset for the menu item.\n *\n * @param data - The data to use for creating the dataset.\n *\n * @returns The dataset for the menu item.\n */\n createItemDataset(data: IRenderData): ElementDataset {\n let result: ElementDataset;\n let { type, command, dataset } = data.item;\n if (type === 'command') {\n result = { ...dataset, type, command };\n } else {\n result = { ...dataset, type };\n }\n return result;\n }\n\n /**\n * Create the class name for the menu item icon.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the item icon.\n */\n createIconClass(data: IRenderData): string {\n let name = 'lm-Menu-itemIcon';\n let extra = data.item.iconClass;\n return extra ? `${name} ${extra}` : name;\n }\n\n /**\n * Create the aria attributes for menu item.\n *\n * @param data - The data to use for the aria attributes.\n *\n * @returns The aria attributes object for the item.\n */\n createItemARIA(data: IRenderData): ElementARIAAttrs {\n let aria: { [T in ARIAAttrNames]?: string } = {};\n switch (data.item.type) {\n case 'separator':\n aria.role = 'presentation';\n break;\n case 'submenu':\n aria['aria-haspopup'] = 'true';\n if (!data.item.isEnabled) {\n aria['aria-disabled'] = 'true';\n }\n break;\n default:\n if (!data.item.isEnabled) {\n aria['aria-disabled'] = 'true';\n }\n aria.role = 'menuitem';\n }\n return aria;\n }\n\n /**\n * Create the render content for the label node.\n *\n * @param data - The data to use for the label content.\n *\n * @returns The content to add to the label node.\n */\n formatLabel(data: IRenderData): h.Child {\n // Fetch the label text and mnemonic index.\n let { label, mnemonic } = data.item;\n\n // If the index is out of range, do not modify the label.\n if (mnemonic < 0 || mnemonic >= label.length) {\n return label;\n }\n\n // Split the label into parts.\n let prefix = label.slice(0, mnemonic);\n let suffix = label.slice(mnemonic + 1);\n let char = label[mnemonic];\n\n // Wrap the mnemonic character in a span.\n let span = h.span({ className: 'lm-Menu-itemMnemonic' }, char);\n\n // Return the content parts.\n return [prefix, span, suffix];\n }\n\n /**\n * Create the render content for the shortcut node.\n *\n * @param data - The data to use for the shortcut content.\n *\n * @returns The content to add to the shortcut node.\n */\n formatShortcut(data: IRenderData): h.Child {\n let kb = data.item.keyBinding;\n return kb ? CommandRegistry.formatKeystroke(kb.keys) : null;\n }\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The ms delay for opening and closing a submenu.\n */\n export const TIMER_DELAY = 300;\n\n /**\n * The horizontal pixel overlap for an open submenu.\n */\n export const SUBMENU_OVERLAP = 3;\n\n let transientWindowDataCache: IWindowData | null = null;\n let transientCacheCounter: number = 0;\n\n function getWindowData(): IWindowData {\n // if transient cache is in use, take one from it\n if (transientCacheCounter > 0) {\n transientCacheCounter--;\n return transientWindowDataCache!;\n }\n return _getWindowData();\n }\n\n /**\n * Store window data in transient cache.\n *\n * The transient cache will be released upon `getWindowData()` call.\n * If this function is called multiple times, the cache will be\n * retained until as many calls to `getWindowData()` were made.\n *\n * Note: should be called before any DOM modifications.\n */\n export function saveWindowData(): void {\n transientWindowDataCache = _getWindowData();\n transientCacheCounter++;\n }\n\n /**\n * Create the DOM node for a menu.\n */\n export function createNode(): HTMLDivElement {\n let node = document.createElement('div');\n let content = document.createElement('ul');\n content.className = 'lm-Menu-content';\n node.appendChild(content);\n content.setAttribute('role', 'menu');\n node.tabIndex = 0;\n return node;\n }\n\n /**\n * Test whether a menu item can be activated.\n */\n export function canActivate(item: Menu.IItem): boolean {\n return item.type !== 'separator' && item.isEnabled && item.isVisible;\n }\n\n /**\n * Create a new menu item for an owner menu.\n */\n export function createItem(\n owner: Menu,\n options: Menu.IItemOptions\n ): Menu.IItem {\n return new MenuItem(owner.commands, options);\n }\n\n /**\n * Hit test a menu hierarchy starting at the given root.\n */\n export function hitTestMenus(menu: Menu, x: number, y: number): boolean {\n for (let temp: Menu | null = menu; temp; temp = temp.childMenu) {\n if (ElementExt.hitTest(temp.node, x, y)) {\n return true;\n }\n }\n return false;\n }\n\n /**\n * Compute which extra separator items should be collapsed.\n */\n export function computeCollapsed(\n items: ReadonlyArray\n ): boolean[] {\n // Allocate the return array and fill it with `false`.\n let result = new Array(items.length);\n ArrayExt.fill(result, false);\n\n // Collapse the leading separators.\n let k1 = 0;\n let n = items.length;\n for (; k1 < n; ++k1) {\n let item = items[k1];\n if (!item.isVisible) {\n continue;\n }\n if (item.type !== 'separator') {\n break;\n }\n result[k1] = true;\n }\n\n // Hide the trailing separators.\n let k2 = n - 1;\n for (; k2 >= 0; --k2) {\n let item = items[k2];\n if (!item.isVisible) {\n continue;\n }\n if (item.type !== 'separator') {\n break;\n }\n result[k2] = true;\n }\n\n // Hide the remaining consecutive separators.\n let hide = false;\n while (++k1 < k2) {\n let item = items[k1];\n if (!item.isVisible) {\n continue;\n }\n if (item.type !== 'separator') {\n hide = false;\n } else if (hide) {\n result[k1] = true;\n } else {\n hide = true;\n }\n }\n\n // Return the resulting flags.\n return result;\n }\n\n function _getWindowData(): IWindowData {\n return {\n pageXOffset: window.pageXOffset,\n pageYOffset: window.pageYOffset,\n clientWidth: document.documentElement.clientWidth,\n clientHeight: document.documentElement.clientHeight\n };\n }\n\n /**\n * Open a menu as a root menu at the target location.\n */\n export function openRootMenu(\n menu: Menu,\n x: number,\n y: number,\n forceX: boolean,\n forceY: boolean,\n host: HTMLElement | null,\n ref: HTMLElement | null\n ): void {\n // Get the current position and size of the main viewport.\n const windowData = getWindowData();\n let px = windowData.pageXOffset;\n let py = windowData.pageYOffset;\n let cw = windowData.clientWidth;\n let ch = windowData.clientHeight;\n\n // Ensure the menu is updated before attaching and measuring.\n MessageLoop.sendMessage(menu, Widget.Msg.UpdateRequest);\n\n // Compute the maximum allowed height for the menu.\n let maxHeight = ch - (forceY ? y : 0);\n\n // Fetch common variables.\n let node = menu.node;\n let style = node.style;\n\n // Clear the menu geometry and prepare it for measuring.\n style.opacity = '0';\n style.maxHeight = `${maxHeight}px`;\n\n // Attach the menu to the document.\n Widget.attach(menu, host || document.body, ref);\n\n // Measure the size of the menu.\n let { width, height } = node.getBoundingClientRect();\n\n // Adjust the X position of the menu to fit on-screen.\n if (!forceX && x + width > px + cw) {\n x = px + cw - width;\n }\n\n // Adjust the Y position of the menu to fit on-screen.\n if (!forceY && y + height > py + ch) {\n if (y > py + ch) {\n y = py + ch - height;\n } else {\n y = y - height;\n }\n }\n\n // Update the position of the menu to the computed position.\n style.transform = `translate(${Math.max(0, x)}px, ${Math.max(0, y)}px`;\n\n // Finally, make the menu visible on the screen.\n style.opacity = '1';\n }\n\n /**\n * Open a menu as a submenu using an item node for positioning.\n */\n export function openSubmenu(submenu: Menu, itemNode: HTMLElement): void {\n // Get the current position and size of the main viewport.\n const windowData = getWindowData();\n let px = windowData.pageXOffset;\n let py = windowData.pageYOffset;\n let cw = windowData.clientWidth;\n let ch = windowData.clientHeight;\n\n // Ensure the menu is updated before opening.\n MessageLoop.sendMessage(submenu, Widget.Msg.UpdateRequest);\n\n // Compute the maximum allowed height for the menu.\n let maxHeight = ch;\n\n // Fetch common variables.\n let node = submenu.node;\n let style = node.style;\n\n // Clear the menu geometry and prepare it for measuring.\n style.opacity = '0';\n style.maxHeight = `${maxHeight}px`;\n\n // Attach the menu to the document.\n Widget.attach(submenu, document.body);\n\n // Measure the size of the menu.\n let { width, height } = node.getBoundingClientRect();\n\n // Compute the box sizing for the menu.\n let box = ElementExt.boxSizing(submenu.node);\n\n // Get the bounding rect for the target item node.\n let itemRect = itemNode.getBoundingClientRect();\n\n // Compute the target X position.\n let x = itemRect.right - SUBMENU_OVERLAP;\n\n // Adjust the X position to fit on the screen.\n if (x + width > px + cw) {\n x = itemRect.left + SUBMENU_OVERLAP - width;\n }\n\n // Compute the target Y position.\n let y = itemRect.top - box.borderTop - box.paddingTop;\n\n // Adjust the Y position to fit on the screen.\n if (y + height > py + ch) {\n y = itemRect.bottom + box.borderBottom + box.paddingBottom - height;\n }\n\n // Update the position of the menu to the computed position.\n style.transform = `translate(${Math.max(0, x)}px, ${Math.max(0, y)}px`;\n\n // Finally, make the menu visible on the screen.\n style.opacity = '1';\n }\n\n /**\n * The results of a mnemonic search.\n */\n export interface IMnemonicResult {\n /**\n * The index of the first matching mnemonic item, or `-1`.\n */\n index: number;\n\n /**\n * Whether multiple mnemonic items matched.\n */\n multiple: boolean;\n\n /**\n * The index of the first auto matched non-mnemonic item.\n */\n auto: number;\n }\n\n /**\n * Find the best matching mnemonic item.\n *\n * The search starts at the given index and wraps around.\n */\n export function findMnemonic(\n items: ReadonlyArray,\n key: string,\n start: number\n ): IMnemonicResult {\n // Setup the result variables.\n let index = -1;\n let auto = -1;\n let multiple = false;\n\n // Normalize the key to upper case.\n let upperKey = key.toUpperCase();\n\n // Search the items from the given start index.\n for (let i = 0, n = items.length; i < n; ++i) {\n // Compute the wrapped index.\n let k = (i + start) % n;\n\n // Lookup the item\n let item = items[k];\n\n // Ignore items which cannot be activated.\n if (!canActivate(item)) {\n continue;\n }\n\n // Ignore items with an empty label.\n let label = item.label;\n if (label.length === 0) {\n continue;\n }\n\n // Lookup the mnemonic index for the label.\n let mn = item.mnemonic;\n\n // Handle a valid mnemonic index.\n if (mn >= 0 && mn < label.length) {\n if (label[mn].toUpperCase() === upperKey) {\n if (index === -1) {\n index = k;\n } else {\n multiple = true;\n }\n }\n continue;\n }\n\n // Finally, handle the auto index if possible.\n if (auto === -1 && label[0].toUpperCase() === upperKey) {\n auto = k;\n }\n }\n\n // Return the search results.\n return { index, multiple, auto };\n }\n\n /**\n * A concrete implementation of `Menu.IItem`.\n */\n class MenuItem implements Menu.IItem {\n /**\n * Construct a new menu item.\n */\n constructor(commands: CommandRegistry, options: Menu.IItemOptions) {\n this._commands = commands;\n this.type = options.type || 'command';\n this.command = options.command || '';\n this.args = options.args || JSONExt.emptyObject;\n this.submenu = options.submenu || null;\n }\n\n /**\n * The type of the menu item.\n */\n readonly type: Menu.ItemType;\n\n /**\n * The command to execute when the item is triggered.\n */\n readonly command: string;\n\n /**\n * The arguments for the command.\n */\n readonly args: ReadonlyJSONObject;\n\n /**\n * The submenu for a `'submenu'` type item.\n */\n readonly submenu: Menu | null;\n\n /**\n * The display label for the menu item.\n */\n get label(): string {\n if (this.type === 'command') {\n return this._commands.label(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.label;\n }\n return '';\n }\n\n /**\n * The mnemonic index for the menu item.\n */\n get mnemonic(): number {\n if (this.type === 'command') {\n return this._commands.mnemonic(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.mnemonic;\n }\n return -1;\n }\n\n /**\n * The icon renderer for the menu item.\n */\n get icon(): VirtualElement.IRenderer | undefined {\n if (this.type === 'command') {\n return this._commands.icon(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.icon;\n }\n return undefined;\n }\n\n /**\n * The icon class for the menu item.\n */\n get iconClass(): string {\n if (this.type === 'command') {\n return this._commands.iconClass(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.iconClass;\n }\n return '';\n }\n\n /**\n * The icon label for the menu item.\n */\n get iconLabel(): string {\n if (this.type === 'command') {\n return this._commands.iconLabel(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.iconLabel;\n }\n return '';\n }\n\n /**\n * The display caption for the menu item.\n */\n get caption(): string {\n if (this.type === 'command') {\n return this._commands.caption(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.caption;\n }\n return '';\n }\n\n /**\n * The extra class name for the menu item.\n */\n get className(): string {\n if (this.type === 'command') {\n return this._commands.className(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.className;\n }\n return '';\n }\n\n /**\n * The dataset for the menu item.\n */\n get dataset(): CommandRegistry.Dataset {\n if (this.type === 'command') {\n return this._commands.dataset(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.dataset;\n }\n return {};\n }\n\n /**\n * Whether the menu item is enabled.\n */\n get isEnabled(): boolean {\n if (this.type === 'command') {\n return this._commands.isEnabled(this.command, this.args);\n }\n if (this.type === 'submenu') {\n return this.submenu !== null;\n }\n return true;\n }\n\n /**\n * Whether the menu item is toggled.\n */\n get isToggled(): boolean {\n if (this.type === 'command') {\n return this._commands.isToggled(this.command, this.args);\n }\n return false;\n }\n\n /**\n * Whether the menu item is visible.\n */\n get isVisible(): boolean {\n if (this.type === 'command') {\n return this._commands.isVisible(this.command, this.args);\n }\n if (this.type === 'submenu') {\n return this.submenu !== null;\n }\n return true;\n }\n\n /**\n * The key binding for the menu item.\n */\n get keyBinding(): CommandRegistry.IKeyBinding | null {\n if (this.type === 'command') {\n let { command, args } = this;\n return (\n ArrayExt.findLastValue(this._commands.keyBindings, kb => {\n return kb.command === command && JSONExt.deepEqual(kb.args, args);\n }) || null\n );\n }\n return null;\n }\n\n private _commands: CommandRegistry;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { CommandRegistry } from '@lumino/commands';\n\nimport { DisposableDelegate, IDisposable } from '@lumino/disposable';\n\nimport { Selector } from '@lumino/domutils';\n\nimport { Menu } from './menu';\n\n/**\n * An object which implements a universal context menu.\n *\n * #### Notes\n * The items shown in the context menu are determined by CSS selector\n * matching against the DOM hierarchy at the site of the mouse click.\n * This is similar in concept to how keyboard shortcuts are matched\n * in the command registry.\n */\nexport class ContextMenu {\n /**\n * Construct a new context menu.\n *\n * @param options - The options for initializing the menu.\n */\n constructor(options: ContextMenu.IOptions) {\n const { groupByTarget, sortBySelector, ...others } = options;\n this.menu = new Menu(others);\n this._groupByTarget = groupByTarget !== false;\n this._sortBySelector = sortBySelector !== false;\n }\n\n /**\n * The menu widget which displays the matched context items.\n */\n readonly menu: Menu;\n\n /**\n * Add an item to the context menu.\n *\n * @param options - The options for creating the item.\n *\n * @returns A disposable which will remove the item from the menu.\n */\n addItem(options: ContextMenu.IItemOptions): IDisposable {\n // Create an item from the given options.\n let item = Private.createItem(options, this._idTick++);\n\n // Add the item to the internal array.\n this._items.push(item);\n\n // Return a disposable which will remove the item.\n return new DisposableDelegate(() => {\n ArrayExt.removeFirstOf(this._items, item);\n });\n }\n\n /**\n * Open the context menu in response to a `'contextmenu'` event.\n *\n * @param event - The `'contextmenu'` event of interest.\n *\n * @returns `true` if the menu was opened, or `false` if no items\n * matched the event and the menu was not opened.\n *\n * #### Notes\n * This method will populate the context menu with items which match\n * the propagation path of the event, then open the menu at the mouse\n * position indicated by the event.\n */\n open(event: MouseEvent): boolean {\n // Prior to any DOM modifications update the window data.\n Menu.saveWindowData();\n\n // Clear the current contents of the context menu.\n this.menu.clearItems();\n\n // Bail early if there are no items to match.\n if (this._items.length === 0) {\n return false;\n }\n\n // Find the matching items for the event.\n let items = Private.matchItems(\n this._items,\n event,\n this._groupByTarget,\n this._sortBySelector\n );\n\n // Bail if there are no matching items.\n if (!items || items.length === 0) {\n return false;\n }\n\n // Add the filtered items to the menu.\n for (const item of items) {\n this.menu.addItem(item);\n }\n\n // Open the context menu at the current mouse position.\n this.menu.open(event.clientX, event.clientY);\n\n // Indicate success.\n return true;\n }\n\n private _groupByTarget: boolean = true;\n private _idTick = 0;\n private _items: Private.IItem[] = [];\n private _sortBySelector: boolean = true;\n}\n\n/**\n * The namespace for the `ContextMenu` class statics.\n */\nexport namespace ContextMenu {\n /**\n * An options object for initializing a context menu.\n */\n export interface IOptions {\n /**\n * The command registry to use with the context menu.\n */\n commands: CommandRegistry;\n\n /**\n * A custom renderer for use with the context menu.\n */\n renderer?: Menu.IRenderer;\n\n /**\n * Whether to sort by selector and rank or only rank.\n *\n * Default true.\n */\n sortBySelector?: boolean;\n\n /**\n * Whether to group items following the DOM hierarchy.\n *\n * Default true.\n *\n * #### Note\n * If true, when the mouse event occurs on element `span` within `div.top`,\n * the items matching `div.top` will be shown before the ones matching `body`.\n */\n groupByTarget?: boolean;\n }\n\n /**\n * An options object for creating a context menu item.\n */\n export interface IItemOptions extends Menu.IItemOptions {\n /**\n * The CSS selector for the context menu item.\n *\n * The context menu item will only be displayed in the context menu\n * when the selector matches a node on the propagation path of the\n * contextmenu event. This allows the menu item to be restricted to\n * user-defined contexts.\n *\n * The selector must not contain commas.\n */\n selector: string;\n\n /**\n * The rank for the item.\n *\n * The rank is used as a tie-breaker when ordering context menu\n * items for display. Items are sorted in the following order:\n * 1. Depth in the DOM tree (deeper is better)\n * 2. Selector specificity (higher is better)\n * 3. Rank (lower is better)\n * 4. Insertion order\n *\n * The default rank is `Infinity`.\n */\n rank?: number;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * A normalized item for a context menu.\n */\n export interface IItem extends Menu.IItemOptions {\n /**\n * The selector for the item.\n */\n selector: string;\n\n /**\n * The rank for the item.\n */\n rank: number;\n\n /**\n * The tie-breaking id for the item.\n */\n id: number;\n }\n\n /**\n * Create a normalized context menu item from an options object.\n */\n export function createItem(\n options: ContextMenu.IItemOptions,\n id: number\n ): IItem {\n let selector = validateSelector(options.selector);\n let rank = options.rank !== undefined ? options.rank : Infinity;\n return { ...options, selector, rank, id };\n }\n\n /**\n * Find the items which match a context menu event.\n *\n * The results are sorted by DOM level, specificity, and rank.\n */\n export function matchItems(\n items: IItem[],\n event: MouseEvent,\n groupByTarget: boolean,\n sortBySelector: boolean\n ): IItem[] | null {\n // Look up the target of the event.\n let target = event.target as Element | null;\n\n // Bail if there is no target.\n if (!target) {\n return null;\n }\n\n // Look up the current target of the event.\n let currentTarget = event.currentTarget as Element | null;\n\n // Bail if there is no current target.\n if (!currentTarget) {\n return null;\n }\n\n // There are some third party libraries that cause the `target` to\n // be detached from the DOM before lumino can process the event.\n // If that happens, search for a new target node by point. If that\n // node is still dangling, bail.\n if (!currentTarget.contains(target)) {\n target = document.elementFromPoint(event.clientX, event.clientY);\n if (!target || !currentTarget.contains(target)) {\n return null;\n }\n }\n\n // Set up the result array.\n let result: IItem[] = [];\n\n // Copy the items array to allow in-place modification.\n let availableItems: Array = items.slice();\n\n // Walk up the DOM hierarchy searching for matches.\n while (target !== null) {\n // Set up the match array for this DOM level.\n let matches: IItem[] = [];\n\n // Search the remaining items for matches.\n for (let i = 0, n = availableItems.length; i < n; ++i) {\n // Fetch the item.\n let item = availableItems[i];\n\n // Skip items which are already consumed.\n if (!item) {\n continue;\n }\n\n // Skip items which do not match the element.\n if (!Selector.matches(target, item.selector)) {\n continue;\n }\n\n // Add the matched item to the result for this DOM level.\n matches.push(item);\n\n // Mark the item as consumed.\n availableItems[i] = null;\n }\n\n // Sort the matches for this level and add them to the results.\n if (matches.length !== 0) {\n if (groupByTarget) {\n matches.sort(sortBySelector ? itemCmp : itemCmpRank);\n }\n result.push(...matches);\n }\n\n // Stop searching at the limits of the DOM range.\n if (target === currentTarget) {\n break;\n }\n\n // Step to the parent DOM level.\n target = target.parentElement;\n }\n\n if (!groupByTarget) {\n result.sort(sortBySelector ? itemCmp : itemCmpRank);\n }\n\n // Return the matched and sorted results.\n return result;\n }\n\n /**\n * Validate the selector for a menu item.\n *\n * This returns the validated selector, or throws if the selector is\n * invalid or contains commas.\n */\n function validateSelector(selector: string): string {\n if (selector.indexOf(',') !== -1) {\n throw new Error(`Selector cannot contain commas: ${selector}`);\n }\n if (!Selector.isValid(selector)) {\n throw new Error(`Invalid selector: ${selector}`);\n }\n return selector;\n }\n\n /**\n * A sort comparison function for a context menu item by ranks.\n */\n function itemCmpRank(a: IItem, b: IItem): number {\n // Sort based on rank.\n let r1 = a.rank;\n let r2 = b.rank;\n if (r1 !== r2) {\n return r1 < r2 ? -1 : 1; // Infinity-safe\n }\n\n // When all else fails, sort by item id.\n return a.id - b.id;\n }\n\n /**\n * A sort comparison function for a context menu item by selectors and ranks.\n */\n function itemCmp(a: IItem, b: IItem): number {\n // Sort first based on selector specificity.\n let s1 = Selector.calculateSpecificity(a.selector);\n let s2 = Selector.calculateSpecificity(b.selector);\n if (s1 !== s2) {\n return s2 - s1;\n }\n\n // If specificities are equal\n return itemCmpRank(a, b);\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Drag } from '@lumino/dragdrop';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport {\n ElementARIAAttrs,\n ElementBaseAttrs,\n ElementDataset,\n ElementInlineStyle,\n h,\n VirtualDOM,\n VirtualElement\n} from '@lumino/virtualdom';\n\nimport { Title } from './title';\n\nimport { Widget } from './widget';\n\nconst ARROW_KEYS = [\n 'ArrowLeft',\n 'ArrowUp',\n 'ArrowRight',\n 'ArrowDown',\n 'Home',\n 'End'\n];\n\n/**\n * A widget which displays titles as a single row or column of tabs.\n *\n * #### Notes\n * If CSS transforms are used to rotate nodes for vertically oriented\n * text, then tab dragging will not work correctly. The `tabsMovable`\n * property should be set to `false` when rotating nodes from CSS.\n */\nexport class TabBar extends Widget {\n /**\n * Construct a new tab bar.\n *\n * @param options - The options for initializing the tab bar.\n */\n constructor(options: TabBar.IOptions = {}) {\n super({ node: Private.createNode() });\n this.addClass('lm-TabBar');\n this.contentNode.setAttribute('role', 'tablist');\n this.setFlag(Widget.Flag.DisallowLayout);\n this._document = options.document || document;\n this.tabsMovable = options.tabsMovable || false;\n this.titlesEditable = options.titlesEditable || false;\n this.allowDeselect = options.allowDeselect || false;\n this.addButtonEnabled = options.addButtonEnabled || false;\n this.insertBehavior = options.insertBehavior || 'select-tab-if-needed';\n this.name = options.name || '';\n this.orientation = options.orientation || 'horizontal';\n this.removeBehavior = options.removeBehavior || 'select-tab-after';\n this.renderer = options.renderer || TabBar.defaultRenderer;\n }\n\n /**\n * Dispose of the resources held by the widget.\n */\n dispose(): void {\n this._releaseMouse();\n this._titles.length = 0;\n this._previousTitle = null;\n super.dispose();\n }\n\n /**\n * A signal emitted when the current tab is changed.\n *\n * #### Notes\n * This signal is emitted when the currently selected tab is changed\n * either through user or programmatic interaction.\n *\n * Notably, this signal is not emitted when the index of the current\n * tab changes due to tabs being inserted, removed, or moved. It is\n * only emitted when the actual current tab node is changed.\n */\n get currentChanged(): ISignal> {\n return this._currentChanged;\n }\n\n /**\n * A signal emitted when a tab is moved by the user.\n *\n * #### Notes\n * This signal is emitted when a tab is moved by user interaction.\n *\n * This signal is not emitted when a tab is moved programmatically.\n */\n get tabMoved(): ISignal> {\n return this._tabMoved;\n }\n\n /**\n * A signal emitted when a tab is clicked by the user.\n *\n * #### Notes\n * If the clicked tab is not the current tab, the clicked tab will be\n * made current and the `currentChanged` signal will be emitted first.\n *\n * This signal is emitted even if the clicked tab is the current tab.\n */\n get tabActivateRequested(): ISignal<\n this,\n TabBar.ITabActivateRequestedArgs\n > {\n return this._tabActivateRequested;\n }\n\n /**\n * A signal emitted when the tab bar add button is clicked.\n */\n get addRequested(): ISignal {\n return this._addRequested;\n }\n\n /**\n * A signal emitted when a tab close icon is clicked.\n *\n * #### Notes\n * This signal is not emitted unless the tab title is `closable`.\n */\n get tabCloseRequested(): ISignal> {\n return this._tabCloseRequested;\n }\n\n /**\n * A signal emitted when a tab is dragged beyond the detach threshold.\n *\n * #### Notes\n * This signal is emitted when the user drags a tab with the mouse,\n * and mouse is dragged beyond the detach threshold.\n *\n * The consumer of the signal should call `releaseMouse` and remove\n * the tab in order to complete the detach.\n *\n * This signal is only emitted once per drag cycle.\n */\n get tabDetachRequested(): ISignal> {\n return this._tabDetachRequested;\n }\n\n /**\n * The renderer used by the tab bar.\n */\n readonly renderer: TabBar.IRenderer;\n\n /**\n * The document to use with the tab bar.\n *\n * The default is the global `document` instance.\n */\n get document(): Document | ShadowRoot {\n return this._document;\n }\n\n /**\n * Whether the tabs are movable by the user.\n *\n * #### Notes\n * Tabs can always be moved programmatically.\n */\n tabsMovable: boolean;\n\n /**\n * Whether the titles can be user-edited.\n *\n */\n get titlesEditable(): boolean {\n return this._titlesEditable;\n }\n\n /**\n * Set whether titles can be user edited.\n *\n */\n set titlesEditable(value: boolean) {\n this._titlesEditable = value;\n }\n\n /**\n * Whether a tab can be deselected by the user.\n *\n * #### Notes\n * Tabs can be always be deselected programmatically.\n */\n allowDeselect: boolean;\n\n /**\n * The selection behavior when inserting a tab.\n */\n insertBehavior: TabBar.InsertBehavior;\n\n /**\n * The selection behavior when removing a tab.\n */\n removeBehavior: TabBar.RemoveBehavior;\n\n /**\n * Get the currently selected title.\n *\n * #### Notes\n * This will be `null` if no tab is selected.\n */\n get currentTitle(): Title | null {\n return this._titles[this._currentIndex] || null;\n }\n\n /**\n * Set the currently selected title.\n *\n * #### Notes\n * If the title does not exist, the title will be set to `null`.\n */\n set currentTitle(value: Title | null) {\n this.currentIndex = value ? this._titles.indexOf(value) : -1;\n }\n\n /**\n * Get the index of the currently selected tab.\n *\n * #### Notes\n * This will be `-1` if no tab is selected.\n */\n get currentIndex(): number {\n return this._currentIndex;\n }\n\n /**\n * Set the index of the currently selected tab.\n *\n * #### Notes\n * If the value is out of range, the index will be set to `-1`.\n */\n set currentIndex(value: number) {\n // Adjust for an out of range index.\n if (value < 0 || value >= this._titles.length) {\n value = -1;\n }\n\n // Bail early if the index will not change.\n if (this._currentIndex === value) {\n return;\n }\n\n // Look up the previous index and title.\n let pi = this._currentIndex;\n let pt = this._titles[pi] || null;\n\n // Look up the current index and title.\n let ci = value;\n let ct = this._titles[ci] || null;\n\n // Update the current index and previous title.\n this._currentIndex = ci;\n this._previousTitle = pt;\n\n // Schedule an update of the tabs.\n this.update();\n\n // Emit the current changed signal.\n this._currentChanged.emit({\n previousIndex: pi,\n previousTitle: pt,\n currentIndex: ci,\n currentTitle: ct\n });\n }\n\n /**\n * Get the name of the tab bar.\n */\n get name(): string {\n return this._name;\n }\n\n /**\n * Set the name of the tab bar.\n */\n set name(value: string) {\n this._name = value;\n if (value) {\n this.contentNode.setAttribute('aria-label', value);\n } else {\n this.contentNode.removeAttribute('aria-label');\n }\n }\n\n /**\n * Get the orientation of the tab bar.\n *\n * #### Notes\n * This controls whether the tabs are arranged in a row or column.\n */\n get orientation(): TabBar.Orientation {\n return this._orientation;\n }\n\n /**\n * Set the orientation of the tab bar.\n *\n * #### Notes\n * This controls whether the tabs are arranged in a row or column.\n */\n set orientation(value: TabBar.Orientation) {\n // Do nothing if the orientation does not change.\n if (this._orientation === value) {\n return;\n }\n\n // Release the mouse before making any changes.\n this._releaseMouse();\n\n // Toggle the orientation values.\n this._orientation = value;\n this.dataset['orientation'] = value;\n this.contentNode.setAttribute('aria-orientation', value);\n }\n\n /**\n * Whether the add button is enabled.\n */\n get addButtonEnabled(): boolean {\n return this._addButtonEnabled;\n }\n\n /**\n * Set whether the add button is enabled.\n */\n set addButtonEnabled(value: boolean) {\n // Do nothing if the value does not change.\n if (this._addButtonEnabled === value) {\n return;\n }\n\n this._addButtonEnabled = value;\n if (value) {\n this.addButtonNode.classList.remove('lm-mod-hidden');\n } else {\n this.addButtonNode.classList.add('lm-mod-hidden');\n }\n }\n\n /**\n * A read-only array of the titles in the tab bar.\n */\n get titles(): ReadonlyArray> {\n return this._titles;\n }\n\n /**\n * The tab bar content node.\n *\n * #### Notes\n * This is the node which holds the tab nodes.\n *\n * Modifying this node directly can lead to undefined behavior.\n */\n get contentNode(): HTMLUListElement {\n return this.node.getElementsByClassName(\n 'lm-TabBar-content'\n )[0] as HTMLUListElement;\n }\n\n /**\n * The tab bar add button node.\n *\n * #### Notes\n * This is the node which holds the add button.\n *\n * Modifying this node directly can lead to undefined behavior.\n */\n get addButtonNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-TabBar-addButton'\n )[0] as HTMLDivElement;\n }\n\n /**\n * Add a tab to the end of the tab bar.\n *\n * @param value - The title which holds the data for the tab,\n * or an options object to convert to a title.\n *\n * @returns The title object added to the tab bar.\n *\n * #### Notes\n * If the title is already added to the tab bar, it will be moved.\n */\n addTab(value: Title | Title.IOptions): Title {\n return this.insertTab(this._titles.length, value);\n }\n\n /**\n * Insert a tab into the tab bar at the specified index.\n *\n * @param index - The index at which to insert the tab.\n *\n * @param value - The title which holds the data for the tab,\n * or an options object to convert to a title.\n *\n * @returns The title object added to the tab bar.\n *\n * #### Notes\n * The index will be clamped to the bounds of the tabs.\n *\n * If the title is already added to the tab bar, it will be moved.\n */\n insertTab(index: number, value: Title | Title.IOptions): Title {\n // Release the mouse before making any changes.\n this._releaseMouse();\n\n // Coerce the value to a title.\n let title = Private.asTitle(value);\n\n // Look up the index of the title.\n let i = this._titles.indexOf(title);\n\n // Clamp the insert index to the array bounds.\n let j = Math.max(0, Math.min(index, this._titles.length));\n\n // If the title is not in the array, insert it.\n if (i === -1) {\n // Insert the title into the array.\n ArrayExt.insert(this._titles, j, title);\n\n // Connect to the title changed signal.\n title.changed.connect(this._onTitleChanged, this);\n\n // Schedule an update of the tabs.\n this.update();\n\n // Adjust the current index for the insert.\n this._adjustCurrentForInsert(j, title);\n\n // Return the title added to the tab bar.\n return title;\n }\n\n // Otherwise, the title exists in the array and should be moved.\n\n // Adjust the index if the location is at the end of the array.\n if (j === this._titles.length) {\n j--;\n }\n\n // Bail if there is no effective move.\n if (i === j) {\n return title;\n }\n\n // Move the title to the new location.\n ArrayExt.move(this._titles, i, j);\n\n // Schedule an update of the tabs.\n this.update();\n\n // Adjust the current index for the move.\n this._adjustCurrentForMove(i, j);\n\n // Return the title added to the tab bar.\n return title;\n }\n\n /**\n * Remove a tab from the tab bar.\n *\n * @param title - The title for the tab to remove.\n *\n * #### Notes\n * This is a no-op if the title is not in the tab bar.\n */\n removeTab(title: Title): void {\n this.removeTabAt(this._titles.indexOf(title));\n }\n\n /**\n * Remove the tab at a given index from the tab bar.\n *\n * @param index - The index of the tab to remove.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n removeTabAt(index: number): void {\n // Release the mouse before making any changes.\n this._releaseMouse();\n\n // Remove the title from the array.\n let title = ArrayExt.removeAt(this._titles, index);\n\n // Bail if the index is out of range.\n if (!title) {\n return;\n }\n\n // Disconnect from the title changed signal.\n title.changed.disconnect(this._onTitleChanged, this);\n\n // Clear the previous title if it's being removed.\n if (title === this._previousTitle) {\n this._previousTitle = null;\n }\n\n // Schedule an update of the tabs.\n this.update();\n\n // Adjust the current index for the remove.\n this._adjustCurrentForRemove(index, title);\n }\n\n /**\n * Remove all tabs from the tab bar.\n */\n clearTabs(): void {\n // Bail if there is nothing to remove.\n if (this._titles.length === 0) {\n return;\n }\n\n // Release the mouse before making any changes.\n this._releaseMouse();\n\n // Disconnect from the title changed signals.\n for (let title of this._titles) {\n title.changed.disconnect(this._onTitleChanged, this);\n }\n\n // Get the current index and title.\n let pi = this.currentIndex;\n let pt = this.currentTitle;\n\n // Reset the current index and previous title.\n this._currentIndex = -1;\n this._previousTitle = null;\n\n // Clear the title array.\n this._titles.length = 0;\n\n // Schedule an update of the tabs.\n this.update();\n\n // If no tab was selected, there's nothing else to do.\n if (pi === -1) {\n return;\n }\n\n // Emit the current changed signal.\n this._currentChanged.emit({\n previousIndex: pi,\n previousTitle: pt,\n currentIndex: -1,\n currentTitle: null\n });\n }\n\n /**\n * Release the mouse and restore the non-dragged tab positions.\n *\n * #### Notes\n * This will cause the tab bar to stop handling mouse events and to\n * restore the tabs to their non-dragged positions.\n */\n releaseMouse(): void {\n this._releaseMouse();\n }\n\n /**\n * Handle the DOM events for the tab bar.\n *\n * @param event - The DOM event sent to the tab bar.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the tab bar's DOM node.\n *\n * This should not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'pointerdown':\n this._evtPointerDown(event as PointerEvent);\n break;\n case 'pointermove':\n this._evtPointerMove(event as PointerEvent);\n break;\n case 'pointerup':\n this._evtPointerUp(event as PointerEvent);\n break;\n case 'dblclick':\n this._evtDblClick(event as MouseEvent);\n break;\n case 'keydown':\n event.eventPhase === Event.CAPTURING_PHASE\n ? this._evtKeyDownCapturing(event as KeyboardEvent)\n : this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('pointerdown', this);\n this.node.addEventListener('dblclick', this);\n this.node.addEventListener('keydown', this);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('pointerdown', this);\n this.node.removeEventListener('dblclick', this);\n this.node.removeEventListener('keydown', this);\n this._releaseMouse();\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n let titles = this._titles;\n let renderer = this.renderer;\n let currentTitle = this.currentTitle;\n let content = new Array(titles.length);\n // Keep the tabindex=\"0\" attribute to the tab which handled it before the update.\n // If the add button handles it, no need to do anything. If no element of the tab\n // bar handles it, set it on the current or the first tab to ensure one element\n // handles it after update.\n const tabHandlingTabindex =\n this._getCurrentTabindex() ??\n (this._currentIndex > -1 ? this._currentIndex : 0);\n\n for (let i = 0, n = titles.length; i < n; ++i) {\n let title = titles[i];\n let current = title === currentTitle;\n let zIndex = current ? n : n - i - 1;\n let tabIndex = tabHandlingTabindex === i ? 0 : -1;\n content[i] = renderer.renderTab({ title, current, zIndex, tabIndex });\n }\n VirtualDOM.render(content, this.contentNode);\n }\n\n /**\n * Get the index of the tab which handles tabindex=\"0\".\n * If the add button handles tabindex=\"0\", -1 is returned.\n * If none of the previous handles tabindex=\"0\", null is returned.\n */\n private _getCurrentTabindex(): number | null {\n let index = null;\n const elemTabindex = this.contentNode.querySelector('li[tabindex=\"0\"]');\n if (elemTabindex) {\n index = [...this.contentNode.children].indexOf(elemTabindex);\n } else if (\n this._addButtonEnabled &&\n this.addButtonNode.getAttribute('tabindex') === '0'\n ) {\n index = -1;\n }\n return index;\n }\n\n /**\n * Handle the `'dblclick'` event for the tab bar.\n */\n private _evtDblClick(event: MouseEvent): void {\n // Do nothing if titles are not editable\n if (!this.titlesEditable) {\n return;\n }\n\n let tabs = this.contentNode.children;\n\n // Find the index of the targeted tab.\n let index = ArrayExt.findFirstIndex(tabs, tab => {\n return ElementExt.hitTest(tab, event.clientX, event.clientY);\n });\n\n // Do nothing if the press is not on a tab.\n if (index === -1) {\n return;\n }\n\n let title = this.titles[index];\n let label = tabs[index].querySelector('.lm-TabBar-tabLabel') as HTMLElement;\n if (label && label.contains(event.target as HTMLElement)) {\n let value = title.label || '';\n\n // Clear the label element\n let oldValue = label.innerHTML;\n label.innerHTML = '';\n\n let input = document.createElement('input');\n input.classList.add('lm-TabBar-tabInput');\n input.value = value;\n label.appendChild(input);\n\n let onblur = () => {\n input.removeEventListener('blur', onblur);\n label.innerHTML = oldValue;\n this.node.addEventListener('keydown', this);\n };\n\n input.addEventListener('dblclick', (event: Event) =>\n event.stopPropagation()\n );\n input.addEventListener('blur', onblur);\n input.addEventListener('keydown', (event: KeyboardEvent) => {\n if (event.key === 'Enter') {\n if (input.value !== '') {\n title.label = title.caption = input.value;\n }\n onblur();\n } else if (event.key === 'Escape') {\n onblur();\n }\n });\n this.node.removeEventListener('keydown', this);\n input.select();\n input.focus();\n\n if (label.children.length > 0) {\n (label.children[0] as HTMLElement).focus();\n }\n }\n }\n\n /**\n * Handle the `'keydown'` event for the tab bar at capturing phase.\n */\n private _evtKeyDownCapturing(event: KeyboardEvent): void {\n if (event.eventPhase !== Event.CAPTURING_PHASE) {\n return;\n }\n\n // Stop all input events during drag.\n event.preventDefault();\n event.stopPropagation();\n\n // Release the mouse if `Escape` is pressed.\n if (event.key === 'Escape') {\n this._releaseMouse();\n }\n }\n\n /**\n * Handle the `'keydown'` event for the tab bar at target phase.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // Allow for navigation using tab key\n if (event.key === 'Tab' || event.eventPhase === Event.CAPTURING_PHASE) {\n return;\n }\n\n // Check if Enter or Spacebar key has been pressed and open that tab\n if (\n event.key === 'Enter' ||\n event.key === 'Spacebar' ||\n event.key === ' '\n ) {\n // Get focus element that is in focus by the tab key\n const focusedElement = document.activeElement;\n\n // Test first if the focus is on the add button node\n if (\n this.addButtonEnabled &&\n this.addButtonNode.contains(focusedElement)\n ) {\n event.preventDefault();\n event.stopPropagation();\n this._addRequested.emit();\n } else {\n const index = ArrayExt.findFirstIndex(this.contentNode.children, tab =>\n tab.contains(focusedElement)\n );\n if (index >= 0) {\n event.preventDefault();\n event.stopPropagation();\n this.currentIndex = index;\n }\n }\n // Handle the arrow keys to switch tabs.\n } else if (ARROW_KEYS.includes(event.key)) {\n // Create a list of all focusable elements in the tab bar.\n const focusable: Element[] = [...this.contentNode.children];\n if (this.addButtonEnabled) {\n focusable.push(this.addButtonNode);\n }\n // If the tab bar contains only one element, nothing to do.\n if (focusable.length <= 1) {\n return;\n }\n event.preventDefault();\n event.stopPropagation();\n\n // Get the current focused element.\n let focusedIndex = focusable.indexOf(document.activeElement as Element);\n if (focusedIndex === -1) {\n focusedIndex = this._currentIndex;\n }\n\n // Find the next element to focus on.\n let nextFocused: Element | null | undefined;\n if (\n (event.key === 'ArrowRight' && this._orientation === 'horizontal') ||\n (event.key === 'ArrowDown' && this._orientation === 'vertical')\n ) {\n nextFocused = focusable[focusedIndex + 1] ?? focusable[0];\n } else if (\n (event.key === 'ArrowLeft' && this._orientation === 'horizontal') ||\n (event.key === 'ArrowUp' && this._orientation === 'vertical')\n ) {\n nextFocused =\n focusable[focusedIndex - 1] ?? focusable[focusable.length - 1];\n } else if (event.key === 'Home') {\n nextFocused = focusable[0];\n } else if (event.key === 'End') {\n nextFocused = focusable[focusable.length - 1];\n }\n\n // Change the focused element and the tabindex value.\n if (nextFocused) {\n focusable[focusedIndex]?.setAttribute('tabindex', '-1');\n nextFocused?.setAttribute('tabindex', '0');\n (nextFocused as HTMLElement).focus();\n }\n }\n }\n\n /**\n * Handle the `'pointerdown'` event for the tab bar.\n */\n private _evtPointerDown(event: PointerEvent | MouseEvent): void {\n // Do nothing if it's not a left or middle mouse press.\n if (event.button !== 0 && event.button !== 1) {\n return;\n }\n\n // Do nothing if a drag is in progress.\n if (this._dragData) {\n return;\n }\n\n // Do nothing if a title editable input was clicked.\n if (\n (event.target as HTMLElement).classList.contains('lm-TabBar-tabInput')\n ) {\n return;\n }\n\n // Check if the add button was clicked.\n let addButtonClicked =\n this.addButtonEnabled &&\n this.addButtonNode.contains(event.target as HTMLElement);\n\n // Lookup the tab nodes.\n let tabs = this.contentNode.children;\n\n // Find the index of the pressed tab.\n let index = ArrayExt.findFirstIndex(tabs, tab => {\n return ElementExt.hitTest(tab, event.clientX, event.clientY);\n });\n\n // Do nothing if the press is not on a tab or the add button.\n if (index === -1 && !addButtonClicked) {\n return;\n }\n\n // Pressing on a tab stops the event propagation.\n event.preventDefault();\n event.stopPropagation();\n\n // Initialize the non-measured parts of the drag data.\n this._dragData = {\n tab: tabs[index] as HTMLElement,\n index: index,\n pressX: event.clientX,\n pressY: event.clientY,\n tabPos: -1,\n tabSize: -1,\n tabPressPos: -1,\n targetIndex: -1,\n tabLayout: null,\n contentRect: null,\n override: null,\n dragActive: false,\n dragAborted: false,\n detachRequested: false\n };\n\n // Add the document pointer up listener.\n this.document.addEventListener('pointerup', this, true);\n\n // Do nothing else if the middle button or add button is clicked.\n if (event.button === 1 || addButtonClicked) {\n return;\n }\n\n // Do nothing else if the close icon is clicked.\n let icon = tabs[index].querySelector(this.renderer.closeIconSelector);\n if (icon && icon.contains(event.target as HTMLElement)) {\n return;\n }\n\n // Add the extra listeners if the tabs are movable.\n if (this.tabsMovable) {\n this.document.addEventListener('pointermove', this, true);\n this.document.addEventListener('keydown', this, true);\n this.document.addEventListener('contextmenu', this, true);\n }\n\n // Update the current index as appropriate.\n if (this.allowDeselect && this.currentIndex === index) {\n this.currentIndex = -1;\n } else {\n this.currentIndex = index;\n }\n\n // Do nothing else if there is no current tab.\n if (this.currentIndex === -1) {\n return;\n }\n\n // Emit the tab activate request signal.\n this._tabActivateRequested.emit({\n index: this.currentIndex,\n title: this.currentTitle!\n });\n }\n\n /**\n * Handle the `'pointermove'` event for the tab bar.\n */\n private _evtPointerMove(event: PointerEvent | MouseEvent): void {\n // Do nothing if no drag is in progress.\n let data = this._dragData;\n if (!data) {\n return;\n }\n\n // Suppress the event during a drag.\n event.preventDefault();\n event.stopPropagation();\n\n // Lookup the tab nodes.\n let tabs = this.contentNode.children;\n\n // Bail early if the drag threshold has not been met.\n if (!data.dragActive && !Private.dragExceeded(data, event)) {\n return;\n }\n\n // Activate the drag if necessary.\n if (!data.dragActive) {\n // Fill in the rest of the drag data measurements.\n let tabRect = data.tab.getBoundingClientRect();\n if (this._orientation === 'horizontal') {\n data.tabPos = data.tab.offsetLeft;\n data.tabSize = tabRect.width;\n data.tabPressPos = data.pressX - tabRect.left;\n } else {\n data.tabPos = data.tab.offsetTop;\n data.tabSize = tabRect.height;\n data.tabPressPos = data.pressY - tabRect.top;\n }\n data.tabPressOffset = {\n x: data.pressX - tabRect.left,\n y: data.pressY - tabRect.top\n };\n data.tabLayout = Private.snapTabLayout(tabs, this._orientation);\n data.contentRect = this.contentNode.getBoundingClientRect();\n data.override = Drag.overrideCursor('default');\n\n // Add the dragging style classes.\n data.tab.classList.add('lm-mod-dragging');\n this.addClass('lm-mod-dragging');\n\n // Mark the drag as active.\n data.dragActive = true;\n }\n\n // Emit the detach requested signal if the threshold is exceeded.\n if (!data.detachRequested && Private.detachExceeded(data, event)) {\n // Only emit the signal once per drag cycle.\n data.detachRequested = true;\n\n // Setup the arguments for the signal.\n let index = data.index;\n let clientX = event.clientX;\n let clientY = event.clientY;\n let tab = tabs[index] as HTMLElement;\n let title = this._titles[index];\n\n // Emit the tab detach requested signal.\n this._tabDetachRequested.emit({\n index,\n title,\n tab,\n clientX,\n clientY,\n offset: data.tabPressOffset\n });\n\n // Bail if the signal handler aborted the drag.\n if (data.dragAborted) {\n return;\n }\n }\n\n // Update the positions of the tabs.\n Private.layoutTabs(tabs, data, event, this._orientation);\n }\n\n /**\n * Handle the `'pointerup'` event for the document.\n */\n private _evtPointerUp(event: PointerEvent | MouseEvent): void {\n // Do nothing if it's not a left or middle mouse release.\n if (event.button !== 0 && event.button !== 1) {\n return;\n }\n\n // Do nothing if no drag is in progress.\n const data = this._dragData;\n if (!data) {\n return;\n }\n\n // Stop the event propagation.\n event.preventDefault();\n event.stopPropagation();\n\n // Remove the extra mouse event listeners.\n this.document.removeEventListener('pointermove', this, true);\n this.document.removeEventListener('pointerup', this, true);\n this.document.removeEventListener('keydown', this, true);\n this.document.removeEventListener('contextmenu', this, true);\n\n // Handle a release when the drag is not active.\n if (!data.dragActive) {\n // Clear the drag data.\n this._dragData = null;\n\n // Handle clicking the add button.\n let addButtonClicked =\n this.addButtonEnabled &&\n this.addButtonNode.contains(event.target as HTMLElement);\n if (addButtonClicked) {\n this._addRequested.emit(undefined);\n return;\n }\n\n // Lookup the tab nodes.\n let tabs = this.contentNode.children;\n\n // Find the index of the released tab.\n let index = ArrayExt.findFirstIndex(tabs, tab => {\n return ElementExt.hitTest(tab, event.clientX, event.clientY);\n });\n\n // Do nothing if the release is not on the original pressed tab.\n if (index !== data.index) {\n return;\n }\n\n // Ignore the release if the title is not closable.\n let title = this._titles[index];\n if (!title.closable) {\n return;\n }\n\n // Emit the close requested signal if the middle button is released.\n if (event.button === 1) {\n this._tabCloseRequested.emit({ index, title });\n return;\n }\n\n // Emit the close requested signal if the close icon was released.\n let icon = tabs[index].querySelector(this.renderer.closeIconSelector);\n if (icon && icon.contains(event.target as HTMLElement)) {\n this._tabCloseRequested.emit({ index, title });\n return;\n }\n\n // Otherwise, there is nothing left to do.\n return;\n }\n\n // Do nothing if the left button is not released.\n if (event.button !== 0) {\n return;\n }\n\n // Position the tab at its final resting position.\n Private.finalizeTabPosition(data, this._orientation);\n\n // Remove the dragging class from the tab so it can be transitioned.\n data.tab.classList.remove('lm-mod-dragging');\n\n // Parse the transition duration for releasing the tab.\n let duration = Private.parseTransitionDuration(data.tab);\n\n // Complete the release on a timer to allow the tab to transition.\n setTimeout(() => {\n // Do nothing if the drag has been aborted.\n if (data.dragAborted) {\n return;\n }\n\n // Clear the drag data reference.\n this._dragData = null;\n\n // Reset the positions of the tabs.\n Private.resetTabPositions(this.contentNode.children, this._orientation);\n\n // Clear the cursor grab.\n data.override!.dispose();\n\n // Remove the remaining dragging style.\n this.removeClass('lm-mod-dragging');\n\n // If the tab was not moved, there is nothing else to do.\n let i = data.index;\n let j = data.targetIndex;\n if (j === -1 || i === j) {\n return;\n }\n\n // Move the title to the new locations.\n ArrayExt.move(this._titles, i, j);\n\n // Adjust the current index for the move.\n this._adjustCurrentForMove(i, j);\n\n // Emit the tab moved signal.\n this._tabMoved.emit({\n fromIndex: i,\n toIndex: j,\n title: this._titles[j]\n });\n\n // Update the tabs immediately to prevent flicker.\n MessageLoop.sendMessage(this, Widget.Msg.UpdateRequest);\n }, duration);\n }\n\n /**\n * Release the mouse and restore the non-dragged tab positions.\n */\n private _releaseMouse(): void {\n // Do nothing if no drag is in progress.\n let data = this._dragData;\n if (!data) {\n return;\n }\n\n // Clear the drag data reference.\n this._dragData = null;\n\n // Remove the extra document event listeners.\n this.document.removeEventListener('pointermove', this, true);\n this.document.removeEventListener('pointerup', this, true);\n this.document.removeEventListener('keydown', this, true);\n this.document.removeEventListener('contextmenu', this, true);\n\n // Indicate the drag has been aborted. This allows the mouse\n // event handlers to return early when the drag is canceled.\n data.dragAborted = true;\n\n // If the drag is not active, there's nothing more to do.\n if (!data.dragActive) {\n return;\n }\n\n // Reset the tabs to their non-dragged positions.\n Private.resetTabPositions(this.contentNode.children, this._orientation);\n\n // Clear the cursor override.\n data.override!.dispose();\n\n // Clear the dragging style classes.\n data.tab.classList.remove('lm-mod-dragging');\n this.removeClass('lm-mod-dragging');\n }\n\n /**\n * Adjust the current index for a tab insert operation.\n *\n * This method accounts for the tab bar's insertion behavior when\n * adjusting the current index and emitting the changed signal.\n */\n private _adjustCurrentForInsert(i: number, title: Title): void {\n // Lookup commonly used variables.\n let ct = this.currentTitle;\n let ci = this._currentIndex;\n let bh = this.insertBehavior;\n\n // TODO: do we need to do an update to update the aria-selected attribute?\n\n // Handle the behavior where the new tab is always selected,\n // or the behavior where the new tab is selected if needed.\n if (bh === 'select-tab' || (bh === 'select-tab-if-needed' && ci === -1)) {\n this._currentIndex = i;\n this._previousTitle = ct;\n this._currentChanged.emit({\n previousIndex: ci,\n previousTitle: ct,\n currentIndex: i,\n currentTitle: title\n });\n return;\n }\n\n // Otherwise, silently adjust the current index if needed.\n if (ci >= i) {\n this._currentIndex++;\n }\n }\n\n /**\n * Adjust the current index for a tab move operation.\n *\n * This method will not cause the actual current tab to change.\n * It silently adjusts the index to account for the given move.\n */\n private _adjustCurrentForMove(i: number, j: number): void {\n if (this._currentIndex === i) {\n this._currentIndex = j;\n } else if (this._currentIndex < i && this._currentIndex >= j) {\n this._currentIndex++;\n } else if (this._currentIndex > i && this._currentIndex <= j) {\n this._currentIndex--;\n }\n }\n\n /**\n * Adjust the current index for a tab remove operation.\n *\n * This method accounts for the tab bar's remove behavior when\n * adjusting the current index and emitting the changed signal.\n */\n private _adjustCurrentForRemove(i: number, title: Title): void {\n // Lookup commonly used variables.\n let ci = this._currentIndex;\n let bh = this.removeBehavior;\n\n // Silently adjust the index if the current tab is not removed.\n if (ci !== i) {\n if (ci > i) {\n this._currentIndex--;\n }\n return;\n }\n\n // TODO: do we need to do an update to adjust the aria-selected value?\n\n // No tab gets selected if the tab bar is empty.\n if (this._titles.length === 0) {\n this._currentIndex = -1;\n this._currentChanged.emit({\n previousIndex: i,\n previousTitle: title,\n currentIndex: -1,\n currentTitle: null\n });\n return;\n }\n\n // Handle behavior where the next sibling tab is selected.\n if (bh === 'select-tab-after') {\n this._currentIndex = Math.min(i, this._titles.length - 1);\n this._currentChanged.emit({\n previousIndex: i,\n previousTitle: title,\n currentIndex: this._currentIndex,\n currentTitle: this.currentTitle\n });\n return;\n }\n\n // Handle behavior where the previous sibling tab is selected.\n if (bh === 'select-tab-before') {\n this._currentIndex = Math.max(0, i - 1);\n this._currentChanged.emit({\n previousIndex: i,\n previousTitle: title,\n currentIndex: this._currentIndex,\n currentTitle: this.currentTitle\n });\n return;\n }\n\n // Handle behavior where the previous history tab is selected.\n if (bh === 'select-previous-tab') {\n if (this._previousTitle) {\n this._currentIndex = this._titles.indexOf(this._previousTitle);\n this._previousTitle = null;\n } else {\n this._currentIndex = Math.min(i, this._titles.length - 1);\n }\n this._currentChanged.emit({\n previousIndex: i,\n previousTitle: title,\n currentIndex: this._currentIndex,\n currentTitle: this.currentTitle\n });\n return;\n }\n\n // Otherwise, no tab gets selected.\n this._currentIndex = -1;\n this._currentChanged.emit({\n previousIndex: i,\n previousTitle: title,\n currentIndex: -1,\n currentTitle: null\n });\n }\n\n /**\n * Handle the `changed` signal of a title object.\n */\n private _onTitleChanged(sender: Title): void {\n this.update();\n }\n\n private _name: string;\n private _currentIndex = -1;\n private _titles: Title[] = [];\n private _orientation: TabBar.Orientation;\n private _document: Document | ShadowRoot;\n private _titlesEditable: boolean = false;\n private _previousTitle: Title | null = null;\n private _dragData: Private.IDragData | null = null;\n private _addButtonEnabled: boolean = false;\n private _tabMoved = new Signal>(this);\n private _currentChanged = new Signal>(\n this\n );\n private _addRequested = new Signal(this);\n private _tabCloseRequested = new Signal<\n this,\n TabBar.ITabCloseRequestedArgs\n >(this);\n private _tabDetachRequested = new Signal<\n this,\n TabBar.ITabDetachRequestedArgs\n >(this);\n private _tabActivateRequested = new Signal<\n this,\n TabBar.ITabActivateRequestedArgs\n >(this);\n}\n\n/**\n * The namespace for the `TabBar` class statics.\n */\nexport namespace TabBar {\n /**\n * A type alias for a tab bar orientation.\n */\n export type Orientation =\n | /**\n * The tabs are arranged in a single row, left-to-right.\n *\n * The tab text orientation is horizontal.\n */\n 'horizontal'\n\n /**\n * The tabs are arranged in a single column, top-to-bottom.\n *\n * The tab text orientation is horizontal.\n */\n | 'vertical';\n\n /**\n * A type alias for the selection behavior on tab insert.\n */\n export type InsertBehavior =\n | /**\n * The selected tab will not be changed.\n */\n 'none'\n\n /**\n * The inserted tab will be selected.\n */\n | 'select-tab'\n\n /**\n * The inserted tab will be selected if the current tab is null.\n */\n | 'select-tab-if-needed';\n\n /**\n * A type alias for the selection behavior on tab remove.\n */\n export type RemoveBehavior =\n | /**\n * No tab will be selected.\n */\n 'none'\n\n /**\n * The tab after the removed tab will be selected if possible.\n */\n | 'select-tab-after'\n\n /**\n * The tab before the removed tab will be selected if possible.\n */\n | 'select-tab-before'\n\n /**\n * The previously selected tab will be selected if possible.\n */\n | 'select-previous-tab';\n\n /**\n * An options object for creating a tab bar.\n */\n export interface IOptions {\n /**\n * The document to use with the tab bar.\n *\n * The default is the global `document` instance.\n */\n\n document?: Document | ShadowRoot;\n\n /**\n * Name of the tab bar.\n *\n * This is used for accessibility reasons. The default is the empty string.\n */\n name?: string;\n\n /**\n * The layout orientation of the tab bar.\n *\n * The default is `horizontal`.\n */\n orientation?: TabBar.Orientation;\n\n /**\n * Whether the tabs are movable by the user.\n *\n * The default is `false`.\n */\n tabsMovable?: boolean;\n\n /**\n * Whether a tab can be deselected by the user.\n *\n * The default is `false`.\n */\n allowDeselect?: boolean;\n\n /**\n * Whether the titles can be directly edited by the user.\n *\n * The default is `false`.\n */\n titlesEditable?: boolean;\n\n /**\n * Whether the add button is enabled.\n *\n * The default is `false`.\n */\n addButtonEnabled?: boolean;\n\n /**\n * The selection behavior when inserting a tab.\n *\n * The default is `'select-tab-if-needed'`.\n */\n insertBehavior?: TabBar.InsertBehavior;\n\n /**\n * The selection behavior when removing a tab.\n *\n * The default is `'select-tab-after'`.\n */\n removeBehavior?: TabBar.RemoveBehavior;\n\n /**\n * A renderer to use with the tab bar.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n }\n\n /**\n * The arguments object for the `currentChanged` signal.\n */\n export interface ICurrentChangedArgs {\n /**\n * The previously selected index.\n */\n readonly previousIndex: number;\n\n /**\n * The previously selected title.\n */\n readonly previousTitle: Title | null;\n\n /**\n * The currently selected index.\n */\n readonly currentIndex: number;\n\n /**\n * The currently selected title.\n */\n readonly currentTitle: Title | null;\n }\n\n /**\n * The arguments object for the `tabMoved` signal.\n */\n export interface ITabMovedArgs {\n /**\n * The previous index of the tab.\n */\n readonly fromIndex: number;\n\n /**\n * The current index of the tab.\n */\n readonly toIndex: number;\n\n /**\n * The title for the tab.\n */\n readonly title: Title;\n }\n\n /**\n * The arguments object for the `tabActivateRequested` signal.\n */\n export interface ITabActivateRequestedArgs {\n /**\n * The index of the tab to activate.\n */\n readonly index: number;\n\n /**\n * The title for the tab.\n */\n readonly title: Title;\n }\n\n /**\n * The arguments object for the `tabCloseRequested` signal.\n */\n export interface ITabCloseRequestedArgs {\n /**\n * The index of the tab to close.\n */\n readonly index: number;\n\n /**\n * The title for the tab.\n */\n readonly title: Title;\n }\n\n /**\n * The arguments object for the `tabDetachRequested` signal.\n */\n export interface ITabDetachRequestedArgs {\n /**\n * The index of the tab to detach.\n */\n readonly index: number;\n\n /**\n * The title for the tab.\n */\n readonly title: Title;\n\n /**\n * The node representing the tab.\n */\n readonly tab: HTMLElement;\n\n /**\n * The current client X position of the mouse.\n */\n readonly clientX: number;\n\n /**\n * The current client Y position of the mouse.\n */\n readonly clientY: number;\n\n /**\n * The mouse position in the tab coordinate.\n */\n readonly offset?: { x: number; y: number };\n }\n\n /**\n * An object which holds the data to render a tab.\n */\n export interface IRenderData {\n /**\n * The title associated with the tab.\n */\n readonly title: Title;\n\n /**\n * Whether the tab is the current tab.\n */\n readonly current: boolean;\n\n /**\n * The z-index for the tab.\n */\n readonly zIndex: number;\n\n /**\n * The tabindex value for the tab.\n */\n readonly tabIndex?: number;\n }\n\n /**\n * A renderer for use with a tab bar.\n */\n export interface IRenderer {\n /**\n * A selector which matches the close icon node in a tab.\n */\n readonly closeIconSelector: string;\n\n /**\n * Render the virtual element for a tab.\n *\n * @param data - The data to use for rendering the tab.\n *\n * @returns A virtual element representing the tab.\n */\n renderTab(data: IRenderData): VirtualElement;\n }\n\n /**\n * The default implementation of `IRenderer`.\n *\n * #### Notes\n * Subclasses are free to reimplement rendering methods as needed.\n */\n export class Renderer implements IRenderer {\n constructor() {\n this._uuid = ++Renderer._nInstance;\n }\n /**\n * A selector which matches the close icon node in a tab.\n */\n readonly closeIconSelector = '.lm-TabBar-tabCloseIcon';\n\n /**\n * Render the virtual element for a tab.\n *\n * @param data - The data to use for rendering the tab.\n *\n * @returns A virtual element representing the tab.\n */\n renderTab(data: IRenderData): VirtualElement {\n let title = data.title.caption;\n let key = this.createTabKey(data);\n let id = key;\n let style = this.createTabStyle(data);\n let className = this.createTabClass(data);\n let dataset = this.createTabDataset(data);\n let aria = this.createTabARIA(data);\n if (data.title.closable) {\n return h.li(\n { id, key, className, title, style, dataset, ...aria },\n this.renderIcon(data),\n this.renderLabel(data),\n this.renderCloseIcon(data)\n );\n } else {\n return h.li(\n { id, key, className, title, style, dataset, ...aria },\n this.renderIcon(data),\n this.renderLabel(data)\n );\n }\n }\n\n /**\n * Render the icon element for a tab.\n *\n * @param data - The data to use for rendering the tab.\n *\n * @returns A virtual element representing the tab icon.\n */\n renderIcon(data: IRenderData): VirtualElement {\n const { title } = data;\n let className = this.createIconClass(data);\n\n // If title.icon is undefined, it will be ignored.\n return h.div({ className }, title.icon!, title.iconLabel);\n }\n\n /**\n * Render the label element for a tab.\n *\n * @param data - The data to use for rendering the tab.\n *\n * @returns A virtual element representing the tab label.\n */\n renderLabel(data: IRenderData): VirtualElement {\n return h.div({ className: 'lm-TabBar-tabLabel' }, data.title.label);\n }\n\n /**\n * Render the close icon element for a tab.\n *\n * @param data - The data to use for rendering the tab.\n *\n * @returns A virtual element representing the tab close icon.\n */\n renderCloseIcon(data: IRenderData): VirtualElement {\n return h.div({ className: 'lm-TabBar-tabCloseIcon' });\n }\n\n /**\n * Create a unique render key for the tab.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The unique render key for the tab.\n *\n * #### Notes\n * This method caches the key against the tab title the first time\n * the key is generated. This enables efficient rendering of moved\n * tabs and avoids subtle hover style artifacts.\n */\n createTabKey(data: IRenderData): string {\n let key = this._tabKeys.get(data.title);\n if (key === undefined) {\n key = `tab-key-${this._uuid}-${this._tabID++}`;\n this._tabKeys.set(data.title, key);\n }\n return key;\n }\n\n /**\n * Create the inline style object for a tab.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The inline style data for the tab.\n */\n createTabStyle(data: IRenderData): ElementInlineStyle {\n return { zIndex: `${data.zIndex}` };\n }\n\n /**\n * Create the class name for the tab.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The full class name for the tab.\n */\n createTabClass(data: IRenderData): string {\n let name = 'lm-TabBar-tab';\n if (data.title.className) {\n name += ` ${data.title.className}`;\n }\n if (data.title.closable) {\n name += ' lm-mod-closable';\n }\n if (data.current) {\n name += ' lm-mod-current';\n }\n return name;\n }\n\n /**\n * Create the dataset for a tab.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The dataset for the tab.\n */\n createTabDataset(data: IRenderData): ElementDataset {\n return data.title.dataset;\n }\n\n /**\n * Create the ARIA attributes for a tab.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The ARIA attributes for the tab.\n */\n createTabARIA(data: IRenderData): ElementARIAAttrs | ElementBaseAttrs {\n return {\n role: 'tab',\n 'aria-selected': data.current.toString(),\n tabindex: `${data.tabIndex ?? '-1'}`\n };\n }\n\n /**\n * Create the class name for the tab icon.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The full class name for the tab icon.\n */\n createIconClass(data: IRenderData): string {\n let name = 'lm-TabBar-tabIcon';\n let extra = data.title.iconClass;\n return extra ? `${name} ${extra}` : name;\n }\n\n private static _nInstance = 0;\n private readonly _uuid: number;\n private _tabID = 0;\n private _tabKeys = new WeakMap, string>();\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n\n /**\n * A selector which matches the add button node in the tab bar.\n */\n export const addButtonSelector = '.lm-TabBar-addButton';\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The start drag distance threshold.\n */\n export const DRAG_THRESHOLD = 5;\n\n /**\n * The detach distance threshold.\n */\n export const DETACH_THRESHOLD = 20;\n\n /**\n * A struct which holds the drag data for a tab bar.\n */\n export interface IDragData {\n /**\n * The tab node being dragged.\n */\n tab: HTMLElement;\n\n /**\n * The index of the tab being dragged.\n */\n index: number;\n\n /**\n * The mouse press client X position.\n */\n pressX: number;\n\n /**\n * The mouse press client Y position.\n */\n pressY: number;\n\n /**\n * The offset left/top of the tab being dragged.\n *\n * This will be `-1` if the drag is not active.\n */\n tabPos: number;\n\n /**\n * The offset width/height of the tab being dragged.\n *\n * This will be `-1` if the drag is not active.\n */\n tabSize: number;\n\n /**\n * The original mouse X/Y position in tab coordinates.\n *\n * This will be `-1` if the drag is not active.\n */\n tabPressPos: number;\n\n /**\n * The original mouse position in tab coordinates.\n *\n * This is undefined if the drag is not active.\n */\n tabPressOffset?: { x: number; y: number };\n\n /**\n * The tab target index upon mouse release.\n *\n * This will be `-1` if the drag is not active.\n */\n targetIndex: number;\n\n /**\n * The array of tab layout objects snapped at drag start.\n *\n * This will be `null` if the drag is not active.\n */\n tabLayout: ITabLayout[] | null;\n\n /**\n * The bounding client rect of the tab bar content node.\n *\n * This will be `null` if the drag is not active.\n */\n contentRect: DOMRect | null;\n\n /**\n * The disposable to clean up the cursor override.\n *\n * This will be `null` if the drag is not active.\n */\n override: IDisposable | null;\n\n /**\n * Whether the drag is currently active.\n */\n dragActive: boolean;\n\n /**\n * Whether the drag has been aborted.\n */\n dragAborted: boolean;\n\n /**\n * Whether a detach request as been made.\n */\n detachRequested: boolean;\n }\n\n /**\n * An object which holds layout data for a tab.\n */\n export interface ITabLayout {\n /**\n * The left/top margin value for the tab.\n */\n margin: number;\n\n /**\n * The offset left/top position of the tab.\n */\n pos: number;\n\n /**\n * The offset width/height of the tab.\n */\n size: number;\n }\n\n /**\n * Create the DOM node for a tab bar.\n */\n export function createNode(): HTMLDivElement {\n let node = document.createElement('div');\n let content = document.createElement('ul');\n content.setAttribute('role', 'tablist');\n content.className = 'lm-TabBar-content';\n node.appendChild(content);\n\n let add = document.createElement('div');\n add.className = 'lm-TabBar-addButton lm-mod-hidden';\n add.setAttribute('tabindex', '-1');\n add.setAttribute('role', 'button');\n node.appendChild(add);\n return node;\n }\n\n /**\n * Coerce a title or options into a real title.\n */\n export function asTitle(value: Title | Title.IOptions): Title {\n return value instanceof Title ? value : new Title(value);\n }\n\n /**\n * Parse the transition duration for a tab node.\n */\n export function parseTransitionDuration(tab: HTMLElement): number {\n let style = window.getComputedStyle(tab);\n return 1000 * (parseFloat(style.transitionDuration!) || 0);\n }\n\n /**\n * Get a snapshot of the current tab layout values.\n */\n export function snapTabLayout(\n tabs: HTMLCollection,\n orientation: TabBar.Orientation\n ): ITabLayout[] {\n let layout = new Array(tabs.length);\n for (let i = 0, n = tabs.length; i < n; ++i) {\n let node = tabs[i] as HTMLElement;\n let style = window.getComputedStyle(node);\n if (orientation === 'horizontal') {\n layout[i] = {\n pos: node.offsetLeft,\n size: node.offsetWidth,\n margin: parseFloat(style.marginLeft!) || 0\n };\n } else {\n layout[i] = {\n pos: node.offsetTop,\n size: node.offsetHeight,\n margin: parseFloat(style.marginTop!) || 0\n };\n }\n }\n return layout;\n }\n\n /**\n * Test if the event exceeds the drag threshold.\n */\n export function dragExceeded(data: IDragData, event: MouseEvent): boolean {\n let dx = Math.abs(event.clientX - data.pressX);\n let dy = Math.abs(event.clientY - data.pressY);\n return dx >= DRAG_THRESHOLD || dy >= DRAG_THRESHOLD;\n }\n\n /**\n * Test if the event exceeds the drag detach threshold.\n */\n export function detachExceeded(data: IDragData, event: MouseEvent): boolean {\n let rect = data.contentRect!;\n return (\n event.clientX < rect.left - DETACH_THRESHOLD ||\n event.clientX >= rect.right + DETACH_THRESHOLD ||\n event.clientY < rect.top - DETACH_THRESHOLD ||\n event.clientY >= rect.bottom + DETACH_THRESHOLD\n );\n }\n\n /**\n * Update the relative tab positions and computed target index.\n */\n export function layoutTabs(\n tabs: HTMLCollection,\n data: IDragData,\n event: MouseEvent,\n orientation: TabBar.Orientation\n ): void {\n // Compute the orientation-sensitive values.\n let pressPos: number;\n let localPos: number;\n let clientPos: number;\n let clientSize: number;\n if (orientation === 'horizontal') {\n pressPos = data.pressX;\n localPos = event.clientX - data.contentRect!.left;\n clientPos = event.clientX;\n clientSize = data.contentRect!.width;\n } else {\n pressPos = data.pressY;\n localPos = event.clientY - data.contentRect!.top;\n clientPos = event.clientY;\n clientSize = data.contentRect!.height;\n }\n\n // Compute the target data.\n let targetIndex = data.index;\n let targetPos = localPos - data.tabPressPos;\n let targetEnd = targetPos + data.tabSize;\n\n // Update the relative tab positions.\n for (let i = 0, n = tabs.length; i < n; ++i) {\n let pxPos: string;\n let layout = data.tabLayout![i];\n let threshold = layout.pos + (layout.size >> 1);\n if (i < data.index && targetPos < threshold) {\n pxPos = `${data.tabSize + data.tabLayout![i + 1].margin}px`;\n targetIndex = Math.min(targetIndex, i);\n } else if (i > data.index && targetEnd > threshold) {\n pxPos = `${-data.tabSize - layout.margin}px`;\n targetIndex = Math.max(targetIndex, i);\n } else if (i === data.index) {\n let ideal = clientPos - pressPos;\n let limit = clientSize - (data.tabPos + data.tabSize);\n pxPos = `${Math.max(-data.tabPos, Math.min(ideal, limit))}px`;\n } else {\n pxPos = '';\n }\n if (orientation === 'horizontal') {\n (tabs[i] as HTMLElement).style.left = pxPos;\n } else {\n (tabs[i] as HTMLElement).style.top = pxPos;\n }\n }\n\n // Update the computed target index.\n data.targetIndex = targetIndex;\n }\n\n /**\n * Position the drag tab at its final resting relative position.\n */\n export function finalizeTabPosition(\n data: IDragData,\n orientation: TabBar.Orientation\n ): void {\n // Compute the orientation-sensitive client size.\n let clientSize: number;\n if (orientation === 'horizontal') {\n clientSize = data.contentRect!.width;\n } else {\n clientSize = data.contentRect!.height;\n }\n\n // Compute the ideal final tab position.\n let ideal: number;\n if (data.targetIndex === data.index) {\n ideal = 0;\n } else if (data.targetIndex > data.index) {\n let tgt = data.tabLayout![data.targetIndex];\n ideal = tgt.pos + tgt.size - data.tabSize - data.tabPos;\n } else {\n let tgt = data.tabLayout![data.targetIndex];\n ideal = tgt.pos - data.tabPos;\n }\n\n // Compute the tab position limit.\n let limit = clientSize - (data.tabPos + data.tabSize);\n let final = Math.max(-data.tabPos, Math.min(ideal, limit));\n\n // Set the final orientation-sensitive position.\n if (orientation === 'horizontal') {\n data.tab.style.left = `${final}px`;\n } else {\n data.tab.style.top = `${final}px`;\n }\n }\n\n /**\n * Reset the relative positions of the given tabs.\n */\n export function resetTabPositions(\n tabs: HTMLCollection,\n orientation: TabBar.Orientation\n ): void {\n for (const tab of tabs) {\n if (orientation === 'horizontal') {\n (tab as HTMLElement).style.left = '';\n } else {\n (tab as HTMLElement).style.top = '';\n }\n }\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt, empty } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { BoxEngine, BoxSizer } from './boxengine';\n\nimport { Layout, LayoutItem } from './layout';\n\nimport { TabBar } from './tabbar';\n\nimport Utils from './utils';\n\nimport { Widget } from './widget';\n\n/**\n * A layout which provides a flexible docking arrangement.\n *\n * #### Notes\n * The consumer of this layout is responsible for handling all signals\n * from the generated tab bars and managing the visibility of widgets\n * and tab bars as needed.\n */\nexport class DockLayout extends Layout {\n /**\n * Construct a new dock layout.\n *\n * @param options - The options for initializing the layout.\n */\n constructor(options: DockLayout.IOptions) {\n super();\n this.renderer = options.renderer;\n if (options.spacing !== undefined) {\n this._spacing = Utils.clampDimension(options.spacing);\n }\n this._document = options.document || document;\n this._hiddenMode =\n options.hiddenMode !== undefined\n ? options.hiddenMode\n : Widget.HiddenMode.Display;\n }\n\n /**\n * Dispose of the resources held by the layout.\n *\n * #### Notes\n * This will clear and dispose all widgets in the layout.\n */\n dispose(): void {\n // Get an iterator over the widgets in the layout.\n let widgets = this[Symbol.iterator]();\n\n // Dispose of the layout items.\n this._items.forEach(item => {\n item.dispose();\n });\n\n // Clear the layout state before disposing the widgets.\n this._box = null;\n this._root = null;\n this._items.clear();\n\n // Dispose of the widgets contained in the old layout root.\n for (const widget of widgets) {\n widget.dispose();\n }\n\n // Dispose of the base class.\n super.dispose();\n }\n\n /**\n * The renderer used by the dock layout.\n */\n readonly renderer: DockLayout.IRenderer;\n\n /**\n * The method for hiding child widgets.\n *\n * #### Notes\n * If there is only one child widget, `Display` hiding mode will be used\n * regardless of this setting.\n */\n get hiddenMode(): Widget.HiddenMode {\n return this._hiddenMode;\n }\n set hiddenMode(v: Widget.HiddenMode) {\n if (this._hiddenMode === v) {\n return;\n }\n this._hiddenMode = v;\n for (const bar of this.tabBars()) {\n if (bar.titles.length > 1) {\n for (const title of bar.titles) {\n title.owner.hiddenMode = this._hiddenMode;\n }\n }\n }\n }\n\n /**\n * Get the inter-element spacing for the dock layout.\n */\n get spacing(): number {\n return this._spacing;\n }\n\n /**\n * Set the inter-element spacing for the dock layout.\n */\n set spacing(value: number) {\n value = Utils.clampDimension(value);\n if (this._spacing === value) {\n return;\n }\n this._spacing = value;\n if (!this.parent) {\n return;\n }\n this.parent.fit();\n }\n\n /**\n * Whether the dock layout is empty.\n */\n get isEmpty(): boolean {\n return this._root === null;\n }\n\n /**\n * Create an iterator over all widgets in the layout.\n *\n * @returns A new iterator over the widgets in the layout.\n *\n * #### Notes\n * This iterator includes the generated tab bars.\n */\n [Symbol.iterator](): IterableIterator {\n return this._root ? this._root.iterAllWidgets() : empty();\n }\n\n /**\n * Create an iterator over the user widgets in the layout.\n *\n * @returns A new iterator over the user widgets in the layout.\n *\n * #### Notes\n * This iterator does not include the generated tab bars.\n */\n widgets(): IterableIterator {\n return this._root ? this._root.iterUserWidgets() : empty();\n }\n\n /**\n * Create an iterator over the selected widgets in the layout.\n *\n * @returns A new iterator over the selected user widgets.\n *\n * #### Notes\n * This iterator yields the widgets corresponding to the current tab\n * of each tab bar in the layout.\n */\n selectedWidgets(): IterableIterator {\n return this._root ? this._root.iterSelectedWidgets() : empty();\n }\n\n /**\n * Create an iterator over the tab bars in the layout.\n *\n * @returns A new iterator over the tab bars in the layout.\n *\n * #### Notes\n * This iterator does not include the user widgets.\n */\n tabBars(): IterableIterator> {\n return this._root ? this._root.iterTabBars() : empty();\n }\n\n /**\n * Create an iterator over the handles in the layout.\n *\n * @returns A new iterator over the handles in the layout.\n */\n handles(): IterableIterator {\n return this._root ? this._root.iterHandles() : empty();\n }\n\n /**\n * Move a handle to the given offset position.\n *\n * @param handle - The handle to move.\n *\n * @param offsetX - The desired offset X position of the handle.\n *\n * @param offsetY - The desired offset Y position of the handle.\n *\n * #### Notes\n * If the given handle is not contained in the layout, this is no-op.\n *\n * The handle will be moved as close as possible to the desired\n * position without violating any of the layout constraints.\n *\n * Only one of the coordinates is used depending on the orientation\n * of the handle. This method accepts both coordinates to make it\n * easy to invoke from a mouse move event without needing to know\n * the handle orientation.\n */\n moveHandle(handle: HTMLDivElement, offsetX: number, offsetY: number): void {\n // Bail early if there is no root or if the handle is hidden.\n let hidden = handle.classList.contains('lm-mod-hidden');\n if (!this._root || hidden) {\n return;\n }\n\n // Lookup the split node for the handle.\n let data = this._root.findSplitNode(handle);\n if (!data) {\n return;\n }\n\n // Compute the desired delta movement for the handle.\n let delta: number;\n if (data.node.orientation === 'horizontal') {\n delta = offsetX - handle.offsetLeft;\n } else {\n delta = offsetY - handle.offsetTop;\n }\n\n // Bail if there is no handle movement.\n if (delta === 0) {\n return;\n }\n\n // Prevent sibling resizing unless needed.\n data.node.holdSizes();\n\n // Adjust the sizers to reflect the handle movement.\n BoxEngine.adjust(data.node.sizers, data.index, delta);\n\n // Update the layout of the widgets.\n if (this.parent) {\n this.parent.update();\n }\n }\n\n /**\n * Save the current configuration of the dock layout.\n *\n * @returns A new config object for the current layout state.\n *\n * #### Notes\n * The return value can be provided to the `restoreLayout` method\n * in order to restore the layout to its current configuration.\n */\n saveLayout(): DockLayout.ILayoutConfig {\n // Bail early if there is no root.\n if (!this._root) {\n return { main: null };\n }\n\n // Hold the current sizes in the layout tree.\n this._root.holdAllSizes();\n\n // Return the layout config.\n return { main: this._root.createConfig() };\n }\n\n /**\n * Restore the layout to a previously saved configuration.\n *\n * @param config - The layout configuration to restore.\n *\n * #### Notes\n * Widgets which currently belong to the layout but which are not\n * contained in the config will be unparented.\n */\n restoreLayout(config: DockLayout.ILayoutConfig): void {\n // Create the widget set for validating the config.\n let widgetSet = new Set();\n\n // Normalize the main area config and collect the widgets.\n let mainConfig: DockLayout.AreaConfig | null;\n if (config.main) {\n mainConfig = Private.normalizeAreaConfig(config.main, widgetSet);\n } else {\n mainConfig = null;\n }\n\n // Create iterators over the old content.\n let oldWidgets = this.widgets();\n let oldTabBars = this.tabBars();\n let oldHandles = this.handles();\n\n // Clear the root before removing the old content.\n this._root = null;\n\n // Unparent the old widgets which are not in the new config.\n for (const widget of oldWidgets) {\n if (!widgetSet.has(widget)) {\n widget.parent = null;\n }\n }\n\n // Dispose of the old tab bars.\n for (const tabBar of oldTabBars) {\n tabBar.dispose();\n }\n\n // Remove the old handles.\n for (const handle of oldHandles) {\n if (handle.parentNode) {\n handle.parentNode.removeChild(handle);\n }\n }\n\n // Reparent the new widgets to the current parent.\n for (const widget of widgetSet) {\n widget.parent = this.parent;\n }\n\n // Create the root node for the new config.\n if (mainConfig) {\n this._root = Private.realizeAreaConfig(\n mainConfig,\n {\n // Ignoring optional `document` argument as we must reuse `this._document`\n createTabBar: (document?: Document | ShadowRoot) =>\n this._createTabBar(),\n createHandle: () => this._createHandle()\n },\n this._document\n );\n } else {\n this._root = null;\n }\n\n // If there is no parent, there is nothing more to do.\n if (!this.parent) {\n return;\n }\n\n // Attach the new widgets to the parent.\n widgetSet.forEach(widget => {\n this.attachWidget(widget);\n });\n\n // Post a fit request to the parent.\n this.parent.fit();\n }\n\n /**\n * Add a widget to the dock layout.\n *\n * @param widget - The widget to add to the dock layout.\n *\n * @param options - The additional options for adding the widget.\n *\n * #### Notes\n * The widget will be moved if it is already contained in the layout.\n *\n * An error will be thrown if the reference widget is invalid.\n */\n addWidget(widget: Widget, options: DockLayout.IAddOptions = {}): void {\n // Parse the options.\n let ref = options.ref || null;\n let mode = options.mode || 'tab-after';\n\n // Find the tab node which holds the reference widget.\n let refNode: Private.TabLayoutNode | null = null;\n if (this._root && ref) {\n refNode = this._root.findTabNode(ref);\n }\n\n // Throw an error if the reference widget is invalid.\n if (ref && !refNode) {\n throw new Error('Reference widget is not in the layout.');\n }\n\n // Reparent the widget to the current layout parent.\n widget.parent = this.parent;\n\n // Insert the widget according to the insert mode.\n switch (mode) {\n case 'tab-after':\n this._insertTab(widget, ref, refNode, true);\n break;\n case 'tab-before':\n this._insertTab(widget, ref, refNode, false);\n break;\n case 'split-top':\n this._insertSplit(widget, ref, refNode, 'vertical', false);\n break;\n case 'split-left':\n this._insertSplit(widget, ref, refNode, 'horizontal', false);\n break;\n case 'split-right':\n this._insertSplit(widget, ref, refNode, 'horizontal', true);\n break;\n case 'split-bottom':\n this._insertSplit(widget, ref, refNode, 'vertical', true);\n break;\n case 'merge-top':\n this._insertSplit(widget, ref, refNode, 'vertical', false, true);\n break;\n case 'merge-left':\n this._insertSplit(widget, ref, refNode, 'horizontal', false, true);\n break;\n case 'merge-right':\n this._insertSplit(widget, ref, refNode, 'horizontal', true, true);\n break;\n case 'merge-bottom':\n this._insertSplit(widget, ref, refNode, 'vertical', true, true);\n break;\n }\n\n // Do nothing else if there is no parent widget.\n if (!this.parent) {\n return;\n }\n\n // Ensure the widget is attached to the parent widget.\n this.attachWidget(widget);\n\n // Post a fit request for the parent widget.\n this.parent.fit();\n }\n\n /**\n * Remove a widget from the layout.\n *\n * @param widget - The widget to remove from the layout.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method does *not* modify the widget's `parent`.\n */\n removeWidget(widget: Widget): void {\n // Remove the widget from its current layout location.\n this._removeWidget(widget);\n\n // Do nothing else if there is no parent widget.\n if (!this.parent) {\n return;\n }\n\n // Detach the widget from the parent widget.\n this.detachWidget(widget);\n\n // Post a fit request for the parent widget.\n this.parent.fit();\n }\n\n /**\n * Find the tab area which contains the given client position.\n *\n * @param clientX - The client X position of interest.\n *\n * @param clientY - The client Y position of interest.\n *\n * @returns The geometry of the tab area at the given position, or\n * `null` if there is no tab area at the given position.\n */\n hitTestTabAreas(\n clientX: number,\n clientY: number\n ): DockLayout.ITabAreaGeometry | null {\n // Bail early if hit testing cannot produce valid results.\n if (!this._root || !this.parent || !this.parent.isVisible) {\n return null;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent.node);\n }\n\n // Convert from client to local coordinates.\n let rect = this.parent.node.getBoundingClientRect();\n let x = clientX - rect.left - this._box.borderLeft;\n let y = clientY - rect.top - this._box.borderTop;\n\n // Find the tab layout node at the local position.\n let tabNode = this._root.hitTestTabNodes(x, y);\n\n // Bail if a tab layout node was not found.\n if (!tabNode) {\n return null;\n }\n\n // Extract the data from the tab node.\n let { tabBar, top, left, width, height } = tabNode;\n\n // Compute the right and bottom edges of the tab area.\n let borderWidth = this._box.borderLeft + this._box.borderRight;\n let borderHeight = this._box.borderTop + this._box.borderBottom;\n let right = rect.width - borderWidth - (left + width);\n let bottom = rect.height - borderHeight - (top + height);\n\n // Return the hit test results.\n return { tabBar, x, y, top, left, right, bottom, width, height };\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n // Perform superclass initialization.\n super.init();\n\n // Attach each widget to the parent.\n for (const widget of this) {\n this.attachWidget(widget);\n }\n\n // Attach each handle to the parent.\n for (const handle of this.handles()) {\n this.parent!.node.appendChild(handle);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * Attach the widget to the layout parent widget.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This is a no-op if the widget is already attached.\n */\n protected attachWidget(widget: Widget): void {\n // Do nothing if the widget is already attached.\n if (this.parent!.node === widget.node.parentNode) {\n return;\n }\n\n // Create the layout item for the widget.\n this._items.set(widget, new LayoutItem(widget));\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget's node to the parent.\n this.parent!.node.appendChild(widget.node);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n }\n\n /**\n * Detach the widget from the layout parent widget.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This is a no-op if the widget is not attached.\n */\n protected detachWidget(widget: Widget): void {\n // Do nothing if the widget is not attached.\n if (this.parent!.node !== widget.node.parentNode) {\n return;\n }\n\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Delete the layout item for the widget.\n let item = this._items.get(widget);\n if (item) {\n this._items.delete(widget);\n item.dispose();\n }\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n */\n protected onBeforeShow(msg: Message): void {\n super.onBeforeShow(msg);\n this.parent!.update();\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n super.onBeforeAttach(msg);\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n if (this.parent!.isVisible) {\n this._update(msg.width, msg.height);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.parent!.isVisible) {\n this._update(-1, -1);\n }\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n */\n protected onFitRequest(msg: Message): void {\n if (this.parent!.isAttached) {\n this._fit();\n }\n }\n\n /**\n * Remove the specified widget from the layout structure.\n *\n * #### Notes\n * This is a no-op if the widget is not in the layout tree.\n *\n * This does not detach the widget from the parent node.\n */\n private _removeWidget(widget: Widget): void {\n // Bail early if there is no layout root.\n if (!this._root) {\n return;\n }\n\n // Find the tab node which contains the given widget.\n let tabNode = this._root.findTabNode(widget);\n\n // Bail early if the tab node is not found.\n if (!tabNode) {\n return;\n }\n\n Private.removeAria(widget);\n\n // If there are multiple tabs, just remove the widget's tab.\n if (tabNode.tabBar.titles.length > 1) {\n tabNode.tabBar.removeTab(widget.title);\n if (\n this._hiddenMode === Widget.HiddenMode.Scale &&\n tabNode.tabBar.titles.length == 1\n ) {\n const existingWidget = tabNode.tabBar.titles[0].owner;\n existingWidget.hiddenMode = Widget.HiddenMode.Display;\n }\n return;\n }\n\n // Otherwise, the tab node needs to be removed...\n\n // Dispose the tab bar.\n tabNode.tabBar.dispose();\n\n // Handle the case where the tab node is the root.\n if (this._root === tabNode) {\n this._root = null;\n return;\n }\n\n // Otherwise, remove the tab node from its parent...\n\n // Prevent widget resizing unless needed.\n this._root.holdAllSizes();\n\n // Clear the parent reference on the tab node.\n let splitNode = tabNode.parent!;\n tabNode.parent = null;\n\n // Remove the tab node from its parent split node.\n let i = ArrayExt.removeFirstOf(splitNode.children, tabNode);\n let handle = ArrayExt.removeAt(splitNode.handles, i)!;\n ArrayExt.removeAt(splitNode.sizers, i);\n\n // Remove the handle from its parent DOM node.\n if (handle.parentNode) {\n handle.parentNode.removeChild(handle);\n }\n\n // If there are multiple children, just update the handles.\n if (splitNode.children.length > 1) {\n splitNode.syncHandles();\n return;\n }\n\n // Otherwise, the split node also needs to be removed...\n\n // Clear the parent reference on the split node.\n let maybeParent = splitNode.parent;\n splitNode.parent = null;\n\n // Lookup the remaining child node and handle.\n let childNode = splitNode.children[0];\n let childHandle = splitNode.handles[0];\n\n // Clear the split node data.\n splitNode.children.length = 0;\n splitNode.handles.length = 0;\n splitNode.sizers.length = 0;\n\n // Remove the child handle from its parent node.\n if (childHandle.parentNode) {\n childHandle.parentNode.removeChild(childHandle);\n }\n\n // Handle the case where the split node is the root.\n if (this._root === splitNode) {\n childNode.parent = null;\n this._root = childNode;\n return;\n }\n\n // Otherwise, move the child node to the parent node...\n let parentNode = maybeParent!;\n\n // Lookup the index of the split node.\n let j = parentNode.children.indexOf(splitNode);\n\n // Handle the case where the child node is a tab node.\n if (childNode instanceof Private.TabLayoutNode) {\n childNode.parent = parentNode;\n parentNode.children[j] = childNode;\n return;\n }\n\n // Remove the split data from the parent.\n let splitHandle = ArrayExt.removeAt(parentNode.handles, j)!;\n ArrayExt.removeAt(parentNode.children, j);\n ArrayExt.removeAt(parentNode.sizers, j);\n\n // Remove the handle from its parent node.\n if (splitHandle.parentNode) {\n splitHandle.parentNode.removeChild(splitHandle);\n }\n\n // The child node and the split parent node will have the same\n // orientation. Merge the grand-children with the parent node.\n for (let i = 0, n = childNode.children.length; i < n; ++i) {\n let gChild = childNode.children[i];\n let gHandle = childNode.handles[i];\n let gSizer = childNode.sizers[i];\n ArrayExt.insert(parentNode.children, j + i, gChild);\n ArrayExt.insert(parentNode.handles, j + i, gHandle);\n ArrayExt.insert(parentNode.sizers, j + i, gSizer);\n gChild.parent = parentNode;\n }\n\n // Clear the child node.\n childNode.children.length = 0;\n childNode.handles.length = 0;\n childNode.sizers.length = 0;\n childNode.parent = null;\n\n // Sync the handles on the parent node.\n parentNode.syncHandles();\n }\n\n /**\n * Create the tab layout node to hold the widget.\n */\n private _createTabNode(widget: Widget): Private.TabLayoutNode {\n let tabNode = new Private.TabLayoutNode(this._createTabBar());\n tabNode.tabBar.addTab(widget.title);\n Private.addAria(widget, tabNode.tabBar);\n return tabNode;\n }\n\n /**\n * Insert a widget next to an existing tab.\n *\n * #### Notes\n * This does not attach the widget to the parent widget.\n */\n private _insertTab(\n widget: Widget,\n ref: Widget | null,\n refNode: Private.TabLayoutNode | null,\n after: boolean\n ): void {\n // Do nothing if the tab is inserted next to itself.\n if (widget === ref) {\n return;\n }\n\n // Create the root if it does not exist.\n if (!this._root) {\n let tabNode = new Private.TabLayoutNode(this._createTabBar());\n tabNode.tabBar.addTab(widget.title);\n this._root = tabNode;\n Private.addAria(widget, tabNode.tabBar);\n return;\n }\n\n // Use the first tab node as the ref node if needed.\n if (!refNode) {\n refNode = this._root.findFirstTabNode()!;\n }\n\n // If the widget is not contained in the ref node, ensure it is\n // removed from the layout and hidden before being added again.\n if (refNode.tabBar.titles.indexOf(widget.title) === -1) {\n this._removeWidget(widget);\n widget.hide();\n }\n\n // Lookup the target index for inserting the tab.\n let index: number;\n if (ref) {\n index = refNode.tabBar.titles.indexOf(ref.title);\n } else {\n index = refNode.tabBar.currentIndex;\n }\n\n // Using transform create an additional layer in the pixel pipeline\n // to limit the number of layer, it is set only if there is more than one widget.\n if (this._hiddenMode === Widget.HiddenMode.Scale) {\n if (refNode.tabBar.titles.length === 0) {\n // Singular tab should use display mode to limit number of layers.\n widget.hiddenMode = Widget.HiddenMode.Display;\n } else if (refNode.tabBar.titles.length == 1) {\n // If we are adding a second tab, switch the existing tab back to scale.\n const existingWidget = refNode.tabBar.titles[0].owner;\n existingWidget.hiddenMode = Widget.HiddenMode.Scale;\n } else {\n // For the third and subsequent tabs no special action is needed.\n widget.hiddenMode = Widget.HiddenMode.Scale;\n }\n } else {\n // For all other modes just propagate the current mode.\n widget.hiddenMode = this._hiddenMode;\n }\n\n // Insert the widget's tab relative to the target index.\n refNode.tabBar.insertTab(index + (after ? 1 : 0), widget.title);\n Private.addAria(widget, refNode.tabBar);\n }\n\n /**\n * Insert a widget as a new split area.\n *\n * #### Notes\n * This does not attach the widget to the parent widget.\n */\n private _insertSplit(\n widget: Widget,\n ref: Widget | null,\n refNode: Private.TabLayoutNode | null,\n orientation: Private.Orientation,\n after: boolean,\n merge: boolean = false\n ): void {\n // Do nothing if there is no effective split.\n if (widget === ref && refNode && refNode.tabBar.titles.length === 1) {\n return;\n }\n\n // Ensure the widget is removed from the current layout.\n this._removeWidget(widget);\n\n // Set the root if it does not exist.\n if (!this._root) {\n this._root = this._createTabNode(widget);\n return;\n }\n\n // If the ref node parent is null, split the root.\n if (!refNode || !refNode.parent) {\n // Ensure the root is split with the correct orientation.\n let root = this._splitRoot(orientation);\n\n // Determine the insert index for the new tab node.\n let i = after ? root.children.length : 0;\n\n // Normalize the split node.\n root.normalizeSizes();\n\n // Create the sizer for new tab node.\n let sizer = Private.createSizer(refNode ? 1 : Private.GOLDEN_RATIO);\n\n // Insert the tab node sized to the golden ratio.\n let tabNode = this._createTabNode(widget);\n ArrayExt.insert(root.children, i, tabNode);\n ArrayExt.insert(root.sizers, i, sizer);\n ArrayExt.insert(root.handles, i, this._createHandle());\n tabNode.parent = root;\n\n // Re-normalize the split node to maintain the ratios.\n root.normalizeSizes();\n\n // Finally, synchronize the visibility of the handles.\n root.syncHandles();\n return;\n }\n\n // Lookup the split node for the ref widget.\n let splitNode = refNode.parent;\n\n // If the split node already had the correct orientation,\n // the widget can be inserted into the split node directly.\n if (splitNode.orientation === orientation) {\n // Find the index of the ref node.\n let i = splitNode.children.indexOf(refNode);\n\n // Conditionally reuse a tab layout found in the wanted position.\n if (merge) {\n let j = i + (after ? 1 : -1);\n let sibling = splitNode.children[j];\n if (sibling instanceof Private.TabLayoutNode) {\n this._insertTab(widget, null, sibling, true);\n ++sibling.tabBar.currentIndex;\n return;\n }\n }\n\n // Normalize the split node.\n splitNode.normalizeSizes();\n\n // Consume half the space for the insert location.\n let s = (splitNode.sizers[i].sizeHint /= 2);\n\n // Insert the tab node sized to the other half.\n let j = i + (after ? 1 : 0);\n let tabNode = this._createTabNode(widget);\n ArrayExt.insert(splitNode.children, j, tabNode);\n ArrayExt.insert(splitNode.sizers, j, Private.createSizer(s));\n ArrayExt.insert(splitNode.handles, j, this._createHandle());\n tabNode.parent = splitNode;\n\n // Finally, synchronize the visibility of the handles.\n splitNode.syncHandles();\n return;\n }\n\n // Remove the ref node from the split node.\n let i = ArrayExt.removeFirstOf(splitNode.children, refNode);\n\n // Create a new normalized split node for the children.\n let childNode = new Private.SplitLayoutNode(orientation);\n childNode.normalized = true;\n\n // Add the ref node sized to half the space.\n childNode.children.push(refNode);\n childNode.sizers.push(Private.createSizer(0.5));\n childNode.handles.push(this._createHandle());\n refNode.parent = childNode;\n\n // Add the tab node sized to the other half.\n let j = after ? 1 : 0;\n let tabNode = this._createTabNode(widget);\n ArrayExt.insert(childNode.children, j, tabNode);\n ArrayExt.insert(childNode.sizers, j, Private.createSizer(0.5));\n ArrayExt.insert(childNode.handles, j, this._createHandle());\n tabNode.parent = childNode;\n\n // Synchronize the visibility of the handles.\n childNode.syncHandles();\n\n // Finally, add the new child node to the original split node.\n ArrayExt.insert(splitNode.children, i, childNode);\n childNode.parent = splitNode;\n }\n\n /**\n * Ensure the root is a split node with the given orientation.\n */\n private _splitRoot(\n orientation: Private.Orientation\n ): Private.SplitLayoutNode {\n // Bail early if the root already meets the requirements.\n let oldRoot = this._root;\n if (oldRoot instanceof Private.SplitLayoutNode) {\n if (oldRoot.orientation === orientation) {\n return oldRoot;\n }\n }\n\n // Create a new root node with the specified orientation.\n let newRoot = (this._root = new Private.SplitLayoutNode(orientation));\n\n // Add the old root to the new root.\n if (oldRoot) {\n newRoot.children.push(oldRoot);\n newRoot.sizers.push(Private.createSizer(0));\n newRoot.handles.push(this._createHandle());\n oldRoot.parent = newRoot;\n }\n\n // Return the new root as a convenience.\n return newRoot;\n }\n\n /**\n * Fit the layout to the total size required by the widgets.\n */\n private _fit(): void {\n // Set up the computed minimum size.\n let minW = 0;\n let minH = 0;\n\n // Update the size limits for the layout tree.\n if (this._root) {\n let limits = this._root.fit(this._spacing, this._items);\n minW = limits.minWidth;\n minH = limits.minHeight;\n }\n\n // Update the box sizing and add it to the computed min size.\n let box = (this._box = ElementExt.boxSizing(this.parent!.node));\n minW += box.horizontalSum;\n minH += box.verticalSum;\n\n // Update the parent's min size constraints.\n let style = this.parent!.node.style;\n style.minWidth = `${minW}px`;\n style.minHeight = `${minH}px`;\n\n // Set the dirty flag to ensure only a single update occurs.\n this._dirty = true;\n\n // Notify the ancestor that it should fit immediately. This may\n // cause a resize of the parent, fulfilling the required update.\n if (this.parent!.parent) {\n MessageLoop.sendMessage(this.parent!.parent!, Widget.Msg.FitRequest);\n }\n\n // If the dirty flag is still set, the parent was not resized.\n // Trigger the required update on the parent widget immediately.\n if (this._dirty) {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n }\n }\n\n /**\n * Update the layout position and size of the widgets.\n *\n * The parent offset dimensions should be `-1` if unknown.\n */\n private _update(offsetWidth: number, offsetHeight: number): void {\n // Clear the dirty flag to indicate the update occurred.\n this._dirty = false;\n\n // Bail early if there is no root layout node.\n if (!this._root) {\n return;\n }\n\n // Measure the parent if the offset dimensions are unknown.\n if (offsetWidth < 0) {\n offsetWidth = this.parent!.node.offsetWidth;\n }\n if (offsetHeight < 0) {\n offsetHeight = this.parent!.node.offsetHeight;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent!.node);\n }\n\n // Compute the actual layout bounds adjusted for border and padding.\n let x = this._box.paddingTop;\n let y = this._box.paddingLeft;\n let width = offsetWidth - this._box.horizontalSum;\n let height = offsetHeight - this._box.verticalSum;\n\n // Update the geometry of the layout tree.\n this._root.update(x, y, width, height, this._spacing, this._items);\n }\n\n /**\n * Create a new tab bar for use by the dock layout.\n *\n * #### Notes\n * The tab bar will be attached to the parent if it exists.\n */\n private _createTabBar(): TabBar {\n // Create the tab bar using the renderer.\n let tabBar = this.renderer.createTabBar(this._document);\n\n // Enforce necessary tab bar behavior.\n tabBar.orientation = 'horizontal';\n\n // Attach the tab bar to the parent if possible.\n if (this.parent) {\n this.attachWidget(tabBar);\n }\n\n // Return the initialized tab bar.\n return tabBar;\n }\n\n /**\n * Create a new handle for the dock layout.\n *\n * #### Notes\n * The handle will be attached to the parent if it exists.\n */\n private _createHandle(): HTMLDivElement {\n // Create the handle using the renderer.\n let handle = this.renderer.createHandle();\n\n // Initialize the handle layout behavior.\n let style = handle.style;\n style.position = 'absolute';\n style.contain = 'strict';\n style.top = '0';\n style.left = '0';\n style.width = '0';\n style.height = '0';\n\n // Attach the handle to the parent if it exists.\n if (this.parent) {\n this.parent.node.appendChild(handle);\n }\n\n // Return the initialized handle.\n return handle;\n }\n\n private _spacing = 4;\n private _dirty = false;\n private _root: Private.LayoutNode | null = null;\n private _box: ElementExt.IBoxSizing | null = null;\n private _document: Document | ShadowRoot;\n private _hiddenMode: Widget.HiddenMode;\n private _items: Private.ItemMap = new Map();\n}\n\n/**\n * The namespace for the `DockLayout` class statics.\n */\nexport namespace DockLayout {\n /**\n * An options object for creating a dock layout.\n */\n export interface IOptions {\n /**\n * The document to use with the dock panel.\n *\n * The default is the global `document` instance.\n */\n document?: Document | ShadowRoot;\n\n /**\n * The method for hiding widgets.\n *\n * The default is `Widget.HiddenMode.Display`.\n */\n hiddenMode?: Widget.HiddenMode;\n\n /**\n * The renderer to use for the dock layout.\n */\n renderer: IRenderer;\n\n /**\n * The spacing between items in the layout.\n *\n * The default is `4`.\n */\n spacing?: number;\n }\n\n /**\n * A renderer for use with a dock layout.\n */\n export interface IRenderer {\n /**\n * Create a new tab bar for use with a dock layout.\n *\n * @returns A new tab bar for a dock layout.\n */\n createTabBar(document?: Document | ShadowRoot): TabBar;\n\n /**\n * Create a new handle node for use with a dock layout.\n *\n * @returns A new handle node for a dock layout.\n */\n createHandle(): HTMLDivElement;\n }\n\n /**\n * A type alias for the supported insertion modes.\n *\n * An insert mode is used to specify how a widget should be added\n * to the dock layout relative to a reference widget.\n */\n export type InsertMode =\n | /**\n * The area to the top of the reference widget.\n *\n * The widget will be inserted just above the reference widget.\n *\n * If the reference widget is null or invalid, the widget will be\n * inserted at the top edge of the dock layout.\n */\n 'split-top'\n\n /**\n * The area to the left of the reference widget.\n *\n * The widget will be inserted just left of the reference widget.\n *\n * If the reference widget is null or invalid, the widget will be\n * inserted at the left edge of the dock layout.\n */\n | 'split-left'\n\n /**\n * The area to the right of the reference widget.\n *\n * The widget will be inserted just right of the reference widget.\n *\n * If the reference widget is null or invalid, the widget will be\n * inserted at the right edge of the dock layout.\n */\n | 'split-right'\n\n /**\n * The area to the bottom of the reference widget.\n *\n * The widget will be inserted just below the reference widget.\n *\n * If the reference widget is null or invalid, the widget will be\n * inserted at the bottom edge of the dock layout.\n */\n | 'split-bottom'\n\n /**\n * Like `split-top` but if a tab layout exists above the reference widget,\n * it behaves like `tab-after` with reference to that instead.\n */\n | 'merge-top'\n\n /**\n * Like `split-left` but if a tab layout exists left of the reference widget,\n * it behaves like `tab-after` with reference to that instead.\n */\n | 'merge-left'\n\n /**\n * Like `split-right` but if a tab layout exists right of the reference widget,\n * it behaves like `tab-after` with reference to that instead.\n */\n | 'merge-right'\n\n /**\n * Like `split-bottom` but if a tab layout exists below the reference widget,\n * it behaves like `tab-after` with reference to that instead.\n */\n | 'merge-bottom'\n\n /**\n * The tab position before the reference widget.\n *\n * The widget will be added as a tab before the reference widget.\n *\n * If the reference widget is null or invalid, a sensible default\n * will be used.\n */\n | 'tab-before'\n\n /**\n * The tab position after the reference widget.\n *\n * The widget will be added as a tab after the reference widget.\n *\n * If the reference widget is null or invalid, a sensible default\n * will be used.\n */\n | 'tab-after';\n\n /**\n * An options object for adding a widget to the dock layout.\n */\n export interface IAddOptions {\n /**\n * The insertion mode for adding the widget.\n *\n * The default is `'tab-after'`.\n */\n mode?: InsertMode;\n\n /**\n * The reference widget for the insert location.\n *\n * The default is `null`.\n */\n ref?: Widget | null;\n }\n\n /**\n * A layout config object for a tab area.\n */\n export interface ITabAreaConfig {\n /**\n * The discriminated type of the config object.\n */\n type: 'tab-area';\n\n /**\n * The widgets contained in the tab area.\n */\n widgets: Widget[];\n\n /**\n * The index of the selected tab.\n */\n currentIndex: number;\n }\n\n /**\n * A layout config object for a split area.\n */\n export interface ISplitAreaConfig {\n /**\n * The discriminated type of the config object.\n */\n type: 'split-area';\n\n /**\n * The orientation of the split area.\n */\n orientation: 'horizontal' | 'vertical';\n\n /**\n * The children in the split area.\n */\n children: AreaConfig[];\n\n /**\n * The relative sizes of the children.\n */\n sizes: number[];\n }\n\n /**\n * A type alias for a general area config.\n */\n export type AreaConfig = ITabAreaConfig | ISplitAreaConfig;\n\n /**\n * A dock layout configuration object.\n */\n export interface ILayoutConfig {\n /**\n * The layout config for the main dock area.\n */\n main: AreaConfig | null;\n }\n\n /**\n * An object which represents the geometry of a tab area.\n */\n export interface ITabAreaGeometry {\n /**\n * The tab bar for the tab area.\n */\n tabBar: TabBar;\n\n /**\n * The local X position of the hit test in the dock area.\n *\n * #### Notes\n * This is the distance from the left edge of the layout parent\n * widget, to the local X coordinate of the hit test query.\n */\n x: number;\n\n /**\n * The local Y position of the hit test in the dock area.\n *\n * #### Notes\n * This is the distance from the top edge of the layout parent\n * widget, to the local Y coordinate of the hit test query.\n */\n y: number;\n\n /**\n * The local coordinate of the top edge of the tab area.\n *\n * #### Notes\n * This is the distance from the top edge of the layout parent\n * widget, to the top edge of the tab area.\n */\n top: number;\n\n /**\n * The local coordinate of the left edge of the tab area.\n *\n * #### Notes\n * This is the distance from the left edge of the layout parent\n * widget, to the left edge of the tab area.\n */\n left: number;\n\n /**\n * The local coordinate of the right edge of the tab area.\n *\n * #### Notes\n * This is the distance from the right edge of the layout parent\n * widget, to the right edge of the tab area.\n */\n right: number;\n\n /**\n * The local coordinate of the bottom edge of the tab area.\n *\n * #### Notes\n * This is the distance from the bottom edge of the layout parent\n * widget, to the bottom edge of the tab area.\n */\n bottom: number;\n\n /**\n * The width of the tab area.\n *\n * #### Notes\n * This is total width allocated for the tab area.\n */\n width: number;\n\n /**\n * The height of the tab area.\n *\n * #### Notes\n * This is total height allocated for the tab area.\n */\n height: number;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * A fraction used for sizing root panels; ~= `1 / golden_ratio`.\n */\n export const GOLDEN_RATIO = 0.618;\n\n /**\n * A type alias for a dock layout node.\n */\n export type LayoutNode = TabLayoutNode | SplitLayoutNode;\n\n /**\n * A type alias for the orientation of a split layout node.\n */\n export type Orientation = 'horizontal' | 'vertical';\n\n /**\n * A type alias for a layout item map.\n */\n export type ItemMap = Map;\n\n /**\n * Create a box sizer with an initial size hint.\n */\n export function createSizer(hint: number): BoxSizer {\n let sizer = new BoxSizer();\n sizer.sizeHint = hint;\n sizer.size = hint;\n return sizer;\n }\n\n /**\n * Normalize an area config object and collect the visited widgets.\n */\n export function normalizeAreaConfig(\n config: DockLayout.AreaConfig,\n widgetSet: Set\n ): DockLayout.AreaConfig | null {\n let result: DockLayout.AreaConfig | null;\n if (config.type === 'tab-area') {\n result = normalizeTabAreaConfig(config, widgetSet);\n } else {\n result = normalizeSplitAreaConfig(config, widgetSet);\n }\n return result;\n }\n\n /**\n * Convert a normalized area config into a layout tree.\n */\n export function realizeAreaConfig(\n config: DockLayout.AreaConfig,\n renderer: DockLayout.IRenderer,\n document: Document | ShadowRoot\n ): LayoutNode {\n let node: LayoutNode;\n if (config.type === 'tab-area') {\n node = realizeTabAreaConfig(config, renderer, document);\n } else {\n node = realizeSplitAreaConfig(config, renderer, document);\n }\n return node;\n }\n\n /**\n * A layout node which holds the data for a tabbed area.\n */\n export class TabLayoutNode {\n /**\n * Construct a new tab layout node.\n *\n * @param tabBar - The tab bar to use for the layout node.\n */\n constructor(tabBar: TabBar) {\n let tabSizer = new BoxSizer();\n let widgetSizer = new BoxSizer();\n tabSizer.stretch = 0;\n widgetSizer.stretch = 1;\n this.tabBar = tabBar;\n this.sizers = [tabSizer, widgetSizer];\n }\n\n /**\n * The parent of the layout node.\n */\n parent: SplitLayoutNode | null = null;\n\n /**\n * The tab bar for the layout node.\n */\n readonly tabBar: TabBar;\n\n /**\n * The sizers for the layout node.\n */\n readonly sizers: [BoxSizer, BoxSizer];\n\n /**\n * The most recent value for the `top` edge of the layout box.\n */\n get top(): number {\n return this._top;\n }\n\n /**\n * The most recent value for the `left` edge of the layout box.\n */\n get left(): number {\n return this._left;\n }\n\n /**\n * The most recent value for the `width` of the layout box.\n */\n get width(): number {\n return this._width;\n }\n\n /**\n * The most recent value for the `height` of the layout box.\n */\n get height(): number {\n return this._height;\n }\n\n /**\n * Create an iterator for all widgets in the layout tree.\n */\n *iterAllWidgets(): IterableIterator {\n yield this.tabBar;\n yield* this.iterUserWidgets();\n }\n\n /**\n * Create an iterator for the user widgets in the layout tree.\n */\n *iterUserWidgets(): IterableIterator {\n for (const title of this.tabBar.titles) {\n yield title.owner;\n }\n }\n\n /**\n * Create an iterator for the selected widgets in the layout tree.\n */\n *iterSelectedWidgets(): IterableIterator {\n let title = this.tabBar.currentTitle;\n if (title) {\n yield title.owner;\n }\n }\n\n /**\n * Create an iterator for the tab bars in the layout tree.\n */\n *iterTabBars(): IterableIterator> {\n yield this.tabBar;\n }\n\n /**\n * Create an iterator for the handles in the layout tree.\n */\n // eslint-disable-next-line require-yield\n *iterHandles(): IterableIterator {\n return;\n }\n\n /**\n * Find the tab layout node which contains the given widget.\n */\n findTabNode(widget: Widget): TabLayoutNode | null {\n return this.tabBar.titles.indexOf(widget.title) !== -1 ? this : null;\n }\n\n /**\n * Find the split layout node which contains the given handle.\n */\n findSplitNode(\n handle: HTMLDivElement\n ): { index: number; node: SplitLayoutNode } | null {\n return null;\n }\n\n /**\n * Find the first tab layout node in a layout tree.\n */\n findFirstTabNode(): TabLayoutNode | null {\n return this;\n }\n\n /**\n * Find the tab layout node which contains the local point.\n */\n hitTestTabNodes(x: number, y: number): TabLayoutNode | null {\n if (x < this._left || x >= this._left + this._width) {\n return null;\n }\n if (y < this._top || y >= this._top + this._height) {\n return null;\n }\n return this;\n }\n\n /**\n * Create a configuration object for the layout tree.\n */\n createConfig(): DockLayout.ITabAreaConfig {\n let widgets = this.tabBar.titles.map(title => title.owner);\n let currentIndex = this.tabBar.currentIndex;\n return { type: 'tab-area', widgets, currentIndex };\n }\n\n /**\n * Recursively hold all of the sizes in the layout tree.\n *\n * This ignores the sizers of tab layout nodes.\n */\n holdAllSizes(): void {\n return;\n }\n\n /**\n * Fit the layout tree.\n */\n fit(spacing: number, items: ItemMap): ElementExt.ISizeLimits {\n // Set up the limit variables.\n let minWidth = 0;\n let minHeight = 0;\n let maxWidth = Infinity;\n let maxHeight = Infinity;\n\n // Lookup the tab bar layout item.\n let tabBarItem = items.get(this.tabBar);\n\n // Lookup the widget layout item.\n let current = this.tabBar.currentTitle;\n let widgetItem = current ? items.get(current.owner) : undefined;\n\n // Lookup the tab bar and widget sizers.\n let [tabBarSizer, widgetSizer] = this.sizers;\n\n // Update the tab bar limits.\n if (tabBarItem) {\n tabBarItem.fit();\n }\n\n // Update the widget limits.\n if (widgetItem) {\n widgetItem.fit();\n }\n\n // Update the results and sizer for the tab bar.\n if (tabBarItem && !tabBarItem.isHidden) {\n minWidth = Math.max(minWidth, tabBarItem.minWidth);\n minHeight += tabBarItem.minHeight;\n tabBarSizer.minSize = tabBarItem.minHeight;\n tabBarSizer.maxSize = tabBarItem.maxHeight;\n } else {\n tabBarSizer.minSize = 0;\n tabBarSizer.maxSize = 0;\n }\n\n // Update the results and sizer for the current widget.\n if (widgetItem && !widgetItem.isHidden) {\n minWidth = Math.max(minWidth, widgetItem.minWidth);\n minHeight += widgetItem.minHeight;\n widgetSizer.minSize = widgetItem.minHeight;\n widgetSizer.maxSize = Infinity;\n } else {\n widgetSizer.minSize = 0;\n widgetSizer.maxSize = Infinity;\n }\n\n // Return the computed size limits for the layout node.\n return { minWidth, minHeight, maxWidth, maxHeight };\n }\n\n /**\n * Update the layout tree.\n */\n update(\n left: number,\n top: number,\n width: number,\n height: number,\n spacing: number,\n items: ItemMap\n ): void {\n // Update the layout box values.\n this._top = top;\n this._left = left;\n this._width = width;\n this._height = height;\n\n // Lookup the tab bar layout item.\n let tabBarItem = items.get(this.tabBar);\n\n // Lookup the widget layout item.\n let current = this.tabBar.currentTitle;\n let widgetItem = current ? items.get(current.owner) : undefined;\n\n // Distribute the layout space to the sizers.\n BoxEngine.calc(this.sizers, height);\n\n // Update the tab bar item using the computed size.\n if (tabBarItem && !tabBarItem.isHidden) {\n let size = this.sizers[0].size;\n tabBarItem.update(left, top, width, size);\n top += size;\n }\n\n // Layout the widget using the computed size.\n if (widgetItem && !widgetItem.isHidden) {\n let size = this.sizers[1].size;\n widgetItem.update(left, top, width, size);\n }\n }\n\n private _top = 0;\n private _left = 0;\n private _width = 0;\n private _height = 0;\n }\n\n /**\n * A layout node which holds the data for a split area.\n */\n export class SplitLayoutNode {\n /**\n * Construct a new split layout node.\n *\n * @param orientation - The orientation of the node.\n */\n constructor(orientation: Orientation) {\n this.orientation = orientation;\n }\n\n /**\n * The parent of the layout node.\n */\n parent: SplitLayoutNode | null = null;\n\n /**\n * Whether the sizers have been normalized.\n */\n normalized = false;\n\n /**\n * The orientation of the node.\n */\n readonly orientation: Orientation;\n\n /**\n * The child nodes for the split node.\n */\n readonly children: LayoutNode[] = [];\n\n /**\n * The box sizers for the layout children.\n */\n readonly sizers: BoxSizer[] = [];\n\n /**\n * The handles for the layout children.\n */\n readonly handles: HTMLDivElement[] = [];\n\n /**\n * Create an iterator for all widgets in the layout tree.\n */\n *iterAllWidgets(): IterableIterator {\n for (const child of this.children) {\n yield* child.iterAllWidgets();\n }\n }\n\n /**\n * Create an iterator for the user widgets in the layout tree.\n */\n *iterUserWidgets(): IterableIterator {\n for (const child of this.children) {\n yield* child.iterUserWidgets();\n }\n }\n\n /**\n * Create an iterator for the selected widgets in the layout tree.\n */\n *iterSelectedWidgets(): IterableIterator {\n for (const child of this.children) {\n yield* child.iterSelectedWidgets();\n }\n }\n\n /**\n * Create an iterator for the tab bars in the layout tree.\n */\n *iterTabBars(): IterableIterator> {\n for (const child of this.children) {\n yield* child.iterTabBars();\n }\n }\n\n /**\n * Create an iterator for the handles in the layout tree.\n */\n *iterHandles(): IterableIterator {\n yield* this.handles;\n for (const child of this.children) {\n yield* child.iterHandles();\n }\n }\n\n /**\n * Find the tab layout node which contains the given widget.\n */\n findTabNode(widget: Widget): TabLayoutNode | null {\n for (let i = 0, n = this.children.length; i < n; ++i) {\n let result = this.children[i].findTabNode(widget);\n if (result) {\n return result;\n }\n }\n return null;\n }\n\n /**\n * Find the split layout node which contains the given handle.\n */\n findSplitNode(\n handle: HTMLDivElement\n ): { index: number; node: SplitLayoutNode } | null {\n let index = this.handles.indexOf(handle);\n if (index !== -1) {\n return { index, node: this };\n }\n for (let i = 0, n = this.children.length; i < n; ++i) {\n let result = this.children[i].findSplitNode(handle);\n if (result) {\n return result;\n }\n }\n return null;\n }\n\n /**\n * Find the first tab layout node in a layout tree.\n */\n findFirstTabNode(): TabLayoutNode | null {\n if (this.children.length === 0) {\n return null;\n }\n return this.children[0].findFirstTabNode();\n }\n\n /**\n * Find the tab layout node which contains the local point.\n */\n hitTestTabNodes(x: number, y: number): TabLayoutNode | null {\n for (let i = 0, n = this.children.length; i < n; ++i) {\n let result = this.children[i].hitTestTabNodes(x, y);\n if (result) {\n return result;\n }\n }\n return null;\n }\n\n /**\n * Create a configuration object for the layout tree.\n */\n createConfig(): DockLayout.ISplitAreaConfig {\n let orientation = this.orientation;\n let sizes = this.createNormalizedSizes();\n let children = this.children.map(child => child.createConfig());\n return { type: 'split-area', orientation, children, sizes };\n }\n\n /**\n * Sync the visibility and orientation of the handles.\n */\n syncHandles(): void {\n this.handles.forEach((handle, i) => {\n handle.setAttribute('data-orientation', this.orientation);\n if (i === this.handles.length - 1) {\n handle.classList.add('lm-mod-hidden');\n } else {\n handle.classList.remove('lm-mod-hidden');\n }\n });\n }\n\n /**\n * Hold the current sizes of the box sizers.\n *\n * This sets the size hint of each sizer to its current size.\n */\n holdSizes(): void {\n for (const sizer of this.sizers) {\n sizer.sizeHint = sizer.size;\n }\n }\n\n /**\n * Recursively hold all of the sizes in the layout tree.\n *\n * This ignores the sizers of tab layout nodes.\n */\n holdAllSizes(): void {\n for (const child of this.children) {\n child.holdAllSizes();\n }\n this.holdSizes();\n }\n\n /**\n * Normalize the sizes of the split layout node.\n */\n normalizeSizes(): void {\n // Bail early if the sizers are empty.\n let n = this.sizers.length;\n if (n === 0) {\n return;\n }\n\n // Hold the current sizes of the sizers.\n this.holdSizes();\n\n // Compute the sum of the sizes.\n let sum = this.sizers.reduce((v, sizer) => v + sizer.sizeHint, 0);\n\n // Normalize the sizes based on the sum.\n if (sum === 0) {\n for (const sizer of this.sizers) {\n sizer.size = sizer.sizeHint = 1 / n;\n }\n } else {\n for (const sizer of this.sizers) {\n sizer.size = sizer.sizeHint /= sum;\n }\n }\n\n // Mark the sizes as normalized.\n this.normalized = true;\n }\n\n /**\n * Snap the normalized sizes of the split layout node.\n */\n createNormalizedSizes(): number[] {\n // Bail early if the sizers are empty.\n let n = this.sizers.length;\n if (n === 0) {\n return [];\n }\n\n // Grab the current sizes of the sizers.\n let sizes = this.sizers.map(sizer => sizer.size);\n\n // Compute the sum of the sizes.\n let sum = sizes.reduce((v, size) => v + size, 0);\n\n // Normalize the sizes based on the sum.\n if (sum === 0) {\n for (let i = sizes.length - 1; i > -1; i--) {\n sizes[i] = 1 / n;\n }\n } else {\n for (let i = sizes.length - 1; i > -1; i--) {\n sizes[i] /= sum;\n }\n }\n\n // Return the normalized sizes.\n return sizes;\n }\n\n /**\n * Fit the layout tree.\n */\n fit(spacing: number, items: ItemMap): ElementExt.ISizeLimits {\n // Compute the required fixed space.\n let horizontal = this.orientation === 'horizontal';\n let fixed = Math.max(0, this.children.length - 1) * spacing;\n\n // Set up the limit variables.\n let minWidth = horizontal ? fixed : 0;\n let minHeight = horizontal ? 0 : fixed;\n let maxWidth = Infinity;\n let maxHeight = Infinity;\n\n // Fit the children and update the limits.\n for (let i = 0, n = this.children.length; i < n; ++i) {\n let limits = this.children[i].fit(spacing, items);\n if (horizontal) {\n minHeight = Math.max(minHeight, limits.minHeight);\n minWidth += limits.minWidth;\n this.sizers[i].minSize = limits.minWidth;\n } else {\n minWidth = Math.max(minWidth, limits.minWidth);\n minHeight += limits.minHeight;\n this.sizers[i].minSize = limits.minHeight;\n }\n }\n\n // Return the computed limits for the layout node.\n return { minWidth, minHeight, maxWidth, maxHeight };\n }\n\n /**\n * Update the layout tree.\n */\n update(\n left: number,\n top: number,\n width: number,\n height: number,\n spacing: number,\n items: ItemMap\n ): void {\n // Compute the available layout space.\n let horizontal = this.orientation === 'horizontal';\n let fixed = Math.max(0, this.children.length - 1) * spacing;\n let space = Math.max(0, (horizontal ? width : height) - fixed);\n\n // De-normalize the sizes if needed.\n if (this.normalized) {\n for (const sizer of this.sizers) {\n sizer.sizeHint *= space;\n }\n this.normalized = false;\n }\n\n // Distribute the layout space to the sizers.\n BoxEngine.calc(this.sizers, space);\n\n // Update the geometry of the child nodes and handles.\n for (let i = 0, n = this.children.length; i < n; ++i) {\n let child = this.children[i];\n let size = this.sizers[i].size;\n let handleStyle = this.handles[i].style;\n if (horizontal) {\n child.update(left, top, size, height, spacing, items);\n left += size;\n handleStyle.top = `${top}px`;\n handleStyle.left = `${left}px`;\n handleStyle.width = `${spacing}px`;\n handleStyle.height = `${height}px`;\n left += spacing;\n } else {\n child.update(left, top, width, size, spacing, items);\n top += size;\n handleStyle.top = `${top}px`;\n handleStyle.left = `${left}px`;\n handleStyle.width = `${width}px`;\n handleStyle.height = `${spacing}px`;\n top += spacing;\n }\n }\n }\n }\n\n export function addAria(widget: Widget, tabBar: TabBar): void {\n widget.node.setAttribute('role', 'tabpanel');\n let renderer = tabBar.renderer;\n if (renderer instanceof TabBar.Renderer) {\n let tabId = renderer.createTabKey({\n title: widget.title,\n current: false,\n zIndex: 0\n });\n widget.node.setAttribute('aria-labelledby', tabId);\n }\n }\n\n export function removeAria(widget: Widget): void {\n widget.node.removeAttribute('role');\n widget.node.removeAttribute('aria-labelledby');\n }\n\n /**\n * Normalize a tab area config and collect the visited widgets.\n */\n function normalizeTabAreaConfig(\n config: DockLayout.ITabAreaConfig,\n widgetSet: Set\n ): DockLayout.ITabAreaConfig | null {\n // Bail early if there is no content.\n if (config.widgets.length === 0) {\n return null;\n }\n\n // Setup the filtered widgets array.\n let widgets: Widget[] = [];\n\n // Filter the config for unique widgets.\n for (const widget of config.widgets) {\n if (!widgetSet.has(widget)) {\n widgetSet.add(widget);\n widgets.push(widget);\n }\n }\n\n // Bail if there are no effective widgets.\n if (widgets.length === 0) {\n return null;\n }\n\n // Normalize the current index.\n let index = config.currentIndex;\n if (index !== -1 && (index < 0 || index >= widgets.length)) {\n index = 0;\n }\n\n // Return a normalized config object.\n return { type: 'tab-area', widgets, currentIndex: index };\n }\n\n /**\n * Normalize a split area config and collect the visited widgets.\n */\n function normalizeSplitAreaConfig(\n config: DockLayout.ISplitAreaConfig,\n widgetSet: Set\n ): DockLayout.AreaConfig | null {\n // Set up the result variables.\n let orientation = config.orientation;\n let children: DockLayout.AreaConfig[] = [];\n let sizes: number[] = [];\n\n // Normalize the config children.\n for (let i = 0, n = config.children.length; i < n; ++i) {\n // Normalize the child config.\n let child = normalizeAreaConfig(config.children[i], widgetSet);\n\n // Ignore an empty child.\n if (!child) {\n continue;\n }\n\n // Add the child or hoist its content as appropriate.\n if (child.type === 'tab-area' || child.orientation !== orientation) {\n children.push(child);\n sizes.push(Math.abs(config.sizes[i] || 0));\n } else {\n children.push(...child.children);\n sizes.push(...child.sizes);\n }\n }\n\n // Bail if there are no effective children.\n if (children.length === 0) {\n return null;\n }\n\n // If there is only one effective child, return that child.\n if (children.length === 1) {\n return children[0];\n }\n\n // Return a normalized config object.\n return { type: 'split-area', orientation, children, sizes };\n }\n\n /**\n * Convert a normalized tab area config into a layout tree.\n */\n function realizeTabAreaConfig(\n config: DockLayout.ITabAreaConfig,\n renderer: DockLayout.IRenderer,\n document: Document | ShadowRoot\n ): TabLayoutNode {\n // Create the tab bar for the layout node.\n let tabBar = renderer.createTabBar(document);\n\n // Hide each widget and add it to the tab bar.\n for (const widget of config.widgets) {\n widget.hide();\n tabBar.addTab(widget.title);\n Private.addAria(widget, tabBar);\n }\n\n // Set the current index of the tab bar.\n tabBar.currentIndex = config.currentIndex;\n\n // Return the new tab layout node.\n return new TabLayoutNode(tabBar);\n }\n\n /**\n * Convert a normalized split area config into a layout tree.\n */\n function realizeSplitAreaConfig(\n config: DockLayout.ISplitAreaConfig,\n renderer: DockLayout.IRenderer,\n document: Document | ShadowRoot\n ): SplitLayoutNode {\n // Create the split layout node.\n let node = new SplitLayoutNode(config.orientation);\n\n // Add each child to the layout node.\n config.children.forEach((child, i) => {\n // Create the child data for the layout node.\n let childNode = realizeAreaConfig(child, renderer, document);\n let sizer = createSizer(config.sizes[i]);\n let handle = renderer.createHandle();\n\n // Add the child data to the layout node.\n node.children.push(childNode);\n node.handles.push(handle);\n node.sizers.push(sizer);\n\n // Update the parent for the child node.\n childNode.parent = node;\n });\n\n // Synchronize the handle state for the layout node.\n node.syncHandles();\n\n // Normalize the sizes for the layout node.\n node.normalizeSizes();\n\n // Return the new layout node.\n return node;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { find } from '@lumino/algorithm';\n\nimport { MimeData } from '@lumino/coreutils';\n\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ElementExt, Platform } from '@lumino/domutils';\n\nimport { Drag } from '@lumino/dragdrop';\n\nimport { ConflatableMessage, Message, MessageLoop } from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { DockLayout } from './docklayout';\n\nimport { TabBar } from './tabbar';\n\nimport { Widget } from './widget';\n\n/**\n * A widget which provides a flexible docking area for widgets.\n */\nexport class DockPanel extends Widget {\n /**\n * Construct a new dock panel.\n *\n * @param options - The options for initializing the panel.\n */\n constructor(options: DockPanel.IOptions = {}) {\n super();\n this.addClass('lm-DockPanel');\n this._document = options.document || document;\n this._mode = options.mode || 'multiple-document';\n this._renderer = options.renderer || DockPanel.defaultRenderer;\n this._edges = options.edges || Private.DEFAULT_EDGES;\n if (options.tabsMovable !== undefined) {\n this._tabsMovable = options.tabsMovable;\n }\n if (options.tabsConstrained !== undefined) {\n this._tabsConstrained = options.tabsConstrained;\n }\n if (options.addButtonEnabled !== undefined) {\n this._addButtonEnabled = options.addButtonEnabled;\n }\n\n // Toggle the CSS mode attribute.\n this.dataset['mode'] = this._mode;\n\n // Create the delegate renderer for the layout.\n let renderer: DockPanel.IRenderer = {\n createTabBar: () => this._createTabBar(),\n createHandle: () => this._createHandle()\n };\n\n // Set up the dock layout for the panel.\n this.layout = new DockLayout({\n document: this._document,\n renderer,\n spacing: options.spacing,\n hiddenMode: options.hiddenMode\n });\n\n // Set up the overlay drop indicator.\n this.overlay = options.overlay || new DockPanel.Overlay();\n this.node.appendChild(this.overlay.node);\n }\n\n /**\n * Dispose of the resources held by the panel.\n */\n dispose(): void {\n // Ensure the mouse is released.\n this._releaseMouse();\n\n // Hide the overlay.\n this.overlay.hide(0);\n\n // Cancel a drag if one is in progress.\n if (this._drag) {\n this._drag.dispose();\n }\n\n // Dispose of the base class.\n super.dispose();\n }\n\n /**\n * The method for hiding widgets.\n */\n get hiddenMode(): Widget.HiddenMode {\n return (this.layout as DockLayout).hiddenMode;\n }\n\n /**\n * Set the method for hiding widgets.\n */\n set hiddenMode(v: Widget.HiddenMode) {\n (this.layout as DockLayout).hiddenMode = v;\n }\n\n /**\n * A signal emitted when the layout configuration is modified.\n *\n * #### Notes\n * This signal is emitted whenever the current layout configuration\n * may have changed.\n *\n * This signal is emitted asynchronously in a collapsed fashion, so\n * that multiple synchronous modifications results in only a single\n * emit of the signal.\n */\n get layoutModified(): ISignal {\n return this._layoutModified;\n }\n\n /**\n * A signal emitted when the add button on a tab bar is clicked.\n *\n */\n get addRequested(): ISignal> {\n return this._addRequested;\n }\n\n /**\n * The overlay used by the dock panel.\n */\n readonly overlay: DockPanel.IOverlay;\n\n /**\n * The renderer used by the dock panel.\n */\n get renderer(): DockPanel.IRenderer {\n return (this.layout as DockLayout).renderer;\n }\n\n /**\n * Get the spacing between the widgets.\n */\n get spacing(): number {\n return (this.layout as DockLayout).spacing;\n }\n\n /**\n * Set the spacing between the widgets.\n */\n set spacing(value: number) {\n (this.layout as DockLayout).spacing = value;\n }\n\n /**\n * Get the mode for the dock panel.\n */\n get mode(): DockPanel.Mode {\n return this._mode;\n }\n\n /**\n * Set the mode for the dock panel.\n *\n * #### Notes\n * Changing the mode is a destructive operation with respect to the\n * panel's layout configuration. If layout state must be preserved,\n * save the current layout config before changing the mode.\n */\n set mode(value: DockPanel.Mode) {\n // Bail early if the mode does not change.\n if (this._mode === value) {\n return;\n }\n\n // Update the internal mode.\n this._mode = value;\n\n // Toggle the CSS mode attribute.\n this.dataset['mode'] = value;\n\n // Get the layout for the panel.\n let layout = this.layout as DockLayout;\n\n // Configure the layout for the specified mode.\n switch (value) {\n case 'multiple-document':\n for (const tabBar of layout.tabBars()) {\n tabBar.show();\n }\n break;\n case 'single-document':\n layout.restoreLayout(Private.createSingleDocumentConfig(this));\n break;\n default:\n throw 'unreachable';\n }\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Whether the tabs can be dragged / moved at runtime.\n */\n get tabsMovable(): boolean {\n return this._tabsMovable;\n }\n\n /**\n * Enable / Disable draggable / movable tabs.\n */\n set tabsMovable(value: boolean) {\n this._tabsMovable = value;\n for (const tabBar of this.tabBars()) {\n tabBar.tabsMovable = value;\n }\n }\n\n /**\n * Whether the tabs are constrained to their source dock panel\n */\n get tabsConstrained(): boolean {\n return this._tabsConstrained;\n }\n\n /**\n * Constrain/Allow tabs to be dragged outside of this dock panel\n */\n set tabsConstrained(value: boolean) {\n this._tabsConstrained = value;\n }\n\n /**\n * Whether the add buttons for each tab bar are enabled.\n */\n get addButtonEnabled(): boolean {\n return this._addButtonEnabled;\n }\n\n /**\n * Set whether the add buttons for each tab bar are enabled.\n */\n set addButtonEnabled(value: boolean) {\n this._addButtonEnabled = value;\n for (const tabBar of this.tabBars()) {\n tabBar.addButtonEnabled = value;\n }\n }\n\n /**\n * Whether the dock panel is empty.\n */\n get isEmpty(): boolean {\n return (this.layout as DockLayout).isEmpty;\n }\n\n /**\n * Create an iterator over the user widgets in the panel.\n *\n * @returns A new iterator over the user widgets in the panel.\n *\n * #### Notes\n * This iterator does not include the generated tab bars.\n */\n *widgets(): IterableIterator {\n yield* (this.layout as DockLayout).widgets();\n }\n\n /**\n * Create an iterator over the selected widgets in the panel.\n *\n * @returns A new iterator over the selected user widgets.\n *\n * #### Notes\n * This iterator yields the widgets corresponding to the current tab\n * of each tab bar in the panel.\n */\n *selectedWidgets(): IterableIterator {\n yield* (this.layout as DockLayout).selectedWidgets();\n }\n\n /**\n * Create an iterator over the tab bars in the panel.\n *\n * @returns A new iterator over the tab bars in the panel.\n *\n * #### Notes\n * This iterator does not include the user widgets.\n */\n *tabBars(): IterableIterator> {\n yield* (this.layout as DockLayout).tabBars();\n }\n\n /**\n * Create an iterator over the handles in the panel.\n *\n * @returns A new iterator over the handles in the panel.\n */\n *handles(): IterableIterator {\n yield* (this.layout as DockLayout).handles();\n }\n\n /**\n * Select a specific widget in the dock panel.\n *\n * @param widget - The widget of interest.\n *\n * #### Notes\n * This will make the widget the current widget in its tab area.\n */\n selectWidget(widget: Widget): void {\n // Find the tab bar which contains the widget.\n let tabBar = find(this.tabBars(), bar => {\n return bar.titles.indexOf(widget.title) !== -1;\n });\n\n // Throw an error if no tab bar is found.\n if (!tabBar) {\n throw new Error('Widget is not contained in the dock panel.');\n }\n\n // Ensure the widget is the current widget.\n tabBar.currentTitle = widget.title;\n }\n\n /**\n * Activate a specified widget in the dock panel.\n *\n * @param widget - The widget of interest.\n *\n * #### Notes\n * This will select and activate the given widget.\n */\n activateWidget(widget: Widget): void {\n this.selectWidget(widget);\n widget.activate();\n }\n\n /**\n * Save the current layout configuration of the dock panel.\n *\n * @returns A new config object for the current layout state.\n *\n * #### Notes\n * The return value can be provided to the `restoreLayout` method\n * in order to restore the layout to its current configuration.\n */\n saveLayout(): DockPanel.ILayoutConfig {\n return (this.layout as DockLayout).saveLayout();\n }\n\n /**\n * Restore the layout to a previously saved configuration.\n *\n * @param config - The layout configuration to restore.\n *\n * #### Notes\n * Widgets which currently belong to the layout but which are not\n * contained in the config will be unparented.\n *\n * The dock panel automatically reverts to `'multiple-document'`\n * mode when a layout config is restored.\n */\n restoreLayout(config: DockPanel.ILayoutConfig): void {\n // Reset the mode.\n this._mode = 'multiple-document';\n\n // Restore the layout.\n (this.layout as DockLayout).restoreLayout(config);\n\n // Flush the message loop on IE and Edge to prevent flicker.\n if (Platform.IS_EDGE || Platform.IS_IE) {\n MessageLoop.flush();\n }\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Add a widget to the dock panel.\n *\n * @param widget - The widget to add to the dock panel.\n *\n * @param options - The additional options for adding the widget.\n *\n * #### Notes\n * If the panel is in single document mode, the options are ignored\n * and the widget is always added as tab in the hidden tab bar.\n */\n addWidget(widget: Widget, options: DockPanel.IAddOptions = {}): void {\n // Add the widget to the layout.\n if (this._mode === 'single-document') {\n (this.layout as DockLayout).addWidget(widget);\n } else {\n (this.layout as DockLayout).addWidget(widget, options);\n }\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Process a message sent to the widget.\n *\n * @param msg - The message sent to the widget.\n */\n processMessage(msg: Message): void {\n if (msg.type === 'layout-modified') {\n this._layoutModified.emit(undefined);\n } else {\n super.processMessage(msg);\n }\n }\n\n /**\n * Handle the DOM events for the dock panel.\n *\n * @param event - The DOM event sent to the panel.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the panel's DOM node. It should\n * not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'lm-dragenter':\n this._evtDragEnter(event as Drag.Event);\n break;\n case 'lm-dragleave':\n this._evtDragLeave(event as Drag.Event);\n break;\n case 'lm-dragover':\n this._evtDragOver(event as Drag.Event);\n break;\n case 'lm-drop':\n this._evtDrop(event as Drag.Event);\n break;\n case 'pointerdown':\n this._evtPointerDown(event as PointerEvent);\n break;\n case 'pointermove':\n this._evtPointerMove(event as PointerEvent);\n break;\n case 'pointerup':\n this._evtPointerUp(event as PointerEvent);\n break;\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('lm-dragenter', this);\n this.node.addEventListener('lm-dragleave', this);\n this.node.addEventListener('lm-dragover', this);\n this.node.addEventListener('lm-drop', this);\n this.node.addEventListener('pointerdown', this);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('lm-dragenter', this);\n this.node.removeEventListener('lm-dragleave', this);\n this.node.removeEventListener('lm-dragover', this);\n this.node.removeEventListener('lm-drop', this);\n this.node.removeEventListener('pointerdown', this);\n this._releaseMouse();\n }\n\n /**\n * A message handler invoked on a `'child-added'` message.\n */\n protected onChildAdded(msg: Widget.ChildMessage): void {\n // Ignore the generated tab bars.\n if (Private.isGeneratedTabBarProperty.get(msg.child)) {\n return;\n }\n\n // Add the widget class to the child.\n msg.child.addClass('lm-DockPanel-widget');\n }\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {\n // Ignore the generated tab bars.\n if (Private.isGeneratedTabBarProperty.get(msg.child)) {\n return;\n }\n\n // Remove the widget class from the child.\n msg.child.removeClass('lm-DockPanel-widget');\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Handle the `'lm-dragenter'` event for the dock panel.\n */\n private _evtDragEnter(event: Drag.Event): void {\n // If the factory mime type is present, mark the event as\n // handled in order to get the rest of the drag events.\n if (event.mimeData.hasData('application/vnd.lumino.widget-factory')) {\n event.preventDefault();\n event.stopPropagation();\n }\n }\n\n /**\n * Handle the `'lm-dragleave'` event for the dock panel.\n */\n private _evtDragLeave(event: Drag.Event): void {\n // Mark the event as handled.\n event.preventDefault();\n\n if (this._tabsConstrained && event.source !== this) return;\n\n event.stopPropagation();\n\n // The new target might be a descendant, so we might still handle the drop.\n // Hide asynchronously so that if a lm-dragover event bubbles up to us, the\n // hide is cancelled by the lm-dragover handler's show overlay logic.\n this.overlay.hide(1);\n }\n\n /**\n * Handle the `'lm-dragover'` event for the dock panel.\n */\n private _evtDragOver(event: Drag.Event): void {\n // Mark the event as handled.\n event.preventDefault();\n\n // Show the drop indicator overlay and update the drop\n // action based on the drop target zone under the mouse.\n if (\n (this._tabsConstrained && event.source !== this) ||\n this._showOverlay(event.clientX, event.clientY) === 'invalid'\n ) {\n event.dropAction = 'none';\n } else {\n event.stopPropagation();\n event.dropAction = event.proposedAction;\n }\n }\n\n /**\n * Handle the `'lm-drop'` event for the dock panel.\n */\n private _evtDrop(event: Drag.Event): void {\n // Mark the event as handled.\n event.preventDefault();\n\n // Hide the drop indicator overlay.\n this.overlay.hide(0);\n\n // Bail if the proposed action is to do nothing.\n if (event.proposedAction === 'none') {\n event.dropAction = 'none';\n return;\n }\n\n // Find the drop target under the mouse.\n let { clientX, clientY } = event;\n let { zone, target } = Private.findDropTarget(\n this,\n clientX,\n clientY,\n this._edges\n );\n\n // Bail if the drop zone is invalid.\n if (\n (this._tabsConstrained && event.source !== this) ||\n zone === 'invalid'\n ) {\n event.dropAction = 'none';\n return;\n }\n\n // Bail if the factory mime type has invalid data.\n let mimeData = event.mimeData;\n let factory = mimeData.getData('application/vnd.lumino.widget-factory');\n if (typeof factory !== 'function') {\n event.dropAction = 'none';\n return;\n }\n\n // Bail if the factory does not produce a widget.\n let widget = factory();\n if (!(widget instanceof Widget)) {\n event.dropAction = 'none';\n return;\n }\n\n // Bail if the widget is an ancestor of the dock panel.\n if (widget.contains(this)) {\n event.dropAction = 'none';\n return;\n }\n\n // Find the reference widget for the drop target.\n let ref = target ? Private.getDropRef(target.tabBar) : null;\n\n // Add the widget according to the indicated drop zone.\n switch (zone) {\n case 'root-all':\n this.addWidget(widget);\n break;\n case 'root-top':\n this.addWidget(widget, { mode: 'split-top' });\n break;\n case 'root-left':\n this.addWidget(widget, { mode: 'split-left' });\n break;\n case 'root-right':\n this.addWidget(widget, { mode: 'split-right' });\n break;\n case 'root-bottom':\n this.addWidget(widget, { mode: 'split-bottom' });\n break;\n case 'widget-all':\n this.addWidget(widget, { mode: 'tab-after', ref });\n break;\n case 'widget-top':\n this.addWidget(widget, { mode: 'split-top', ref });\n break;\n case 'widget-left':\n this.addWidget(widget, { mode: 'split-left', ref });\n break;\n case 'widget-right':\n this.addWidget(widget, { mode: 'split-right', ref });\n break;\n case 'widget-bottom':\n this.addWidget(widget, { mode: 'split-bottom', ref });\n break;\n case 'widget-tab':\n this.addWidget(widget, { mode: 'tab-after', ref });\n break;\n default:\n throw 'unreachable';\n }\n\n // Accept the proposed drop action.\n event.dropAction = event.proposedAction;\n\n // Stop propagation if we have not bailed so far.\n event.stopPropagation();\n\n // Activate the dropped widget.\n this.activateWidget(widget);\n }\n\n /**\n * Handle the `'keydown'` event for the dock panel.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // Stop input events during drag.\n event.preventDefault();\n event.stopPropagation();\n\n // Release the mouse if `Escape` is pressed.\n if (event.keyCode === 27) {\n // Finalize the mouse release.\n this._releaseMouse();\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n }\n\n /**\n * Handle the `'pointerdown'` event for the dock panel.\n */\n private _evtPointerDown(event: PointerEvent): void {\n // Do nothing if the left mouse button is not pressed.\n if (event.button !== 0) {\n return;\n }\n\n // Find the handle which contains the mouse target, if any.\n let layout = this.layout as DockLayout;\n let target = event.target as HTMLElement;\n let handle = find(layout.handles(), handle => handle.contains(target));\n if (!handle) {\n return;\n }\n\n // Stop the event when a handle is pressed.\n event.preventDefault();\n event.stopPropagation();\n\n // Add the extra document listeners.\n this._document.addEventListener('keydown', this, true);\n this._document.addEventListener('pointerup', this, true);\n this._document.addEventListener('pointermove', this, true);\n this._document.addEventListener('contextmenu', this, true);\n\n // Compute the offset deltas for the handle press.\n let rect = handle.getBoundingClientRect();\n let deltaX = event.clientX - rect.left;\n let deltaY = event.clientY - rect.top;\n\n // Override the cursor and store the press data.\n let style = window.getComputedStyle(handle);\n let override = Drag.overrideCursor(style.cursor!, this._document);\n this._pressData = { handle, deltaX, deltaY, override };\n }\n\n /**\n * Handle the `'pointermove'` event for the dock panel.\n */\n private _evtPointerMove(event: PointerEvent): void {\n // Bail early if no drag is in progress.\n if (!this._pressData) {\n return;\n }\n\n // Stop the event when dragging a handle.\n event.preventDefault();\n event.stopPropagation();\n\n // Compute the desired offset position for the handle.\n let rect = this.node.getBoundingClientRect();\n let xPos = event.clientX - rect.left - this._pressData.deltaX;\n let yPos = event.clientY - rect.top - this._pressData.deltaY;\n\n // Set the handle as close to the desired position as possible.\n let layout = this.layout as DockLayout;\n layout.moveHandle(this._pressData.handle, xPos, yPos);\n }\n\n /**\n * Handle the `'pointerup'` event for the dock panel.\n */\n private _evtPointerUp(event: PointerEvent): void {\n // Do nothing if the left mouse button is not released.\n if (event.button !== 0) {\n return;\n }\n\n // Stop the event when releasing a handle.\n event.preventDefault();\n event.stopPropagation();\n\n // Finalize the mouse release.\n this._releaseMouse();\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Release the mouse grab for the dock panel.\n */\n private _releaseMouse(): void {\n // Bail early if no drag is in progress.\n if (!this._pressData) {\n return;\n }\n\n // Clear the override cursor.\n this._pressData.override.dispose();\n this._pressData = null;\n\n // Remove the extra document listeners.\n this._document.removeEventListener('keydown', this, true);\n this._document.removeEventListener('pointerup', this, true);\n this._document.removeEventListener('pointermove', this, true);\n this._document.removeEventListener('contextmenu', this, true);\n }\n\n /**\n * Show the overlay indicator at the given client position.\n *\n * Returns the drop zone at the specified client position.\n *\n * #### Notes\n * If the position is not over a valid zone, the overlay is hidden.\n */\n private _showOverlay(clientX: number, clientY: number): Private.DropZone {\n // Find the dock target for the given client position.\n let { zone, target } = Private.findDropTarget(\n this,\n clientX,\n clientY,\n this._edges\n );\n\n // If the drop zone is invalid, hide the overlay and bail.\n if (zone === 'invalid') {\n this.overlay.hide(100);\n return zone;\n }\n\n // Setup the variables needed to compute the overlay geometry.\n let top: number;\n let left: number;\n let right: number;\n let bottom: number;\n let box = ElementExt.boxSizing(this.node); // TODO cache this?\n let rect = this.node.getBoundingClientRect();\n\n // Compute the overlay geometry based on the dock zone.\n switch (zone) {\n case 'root-all':\n top = box.paddingTop;\n left = box.paddingLeft;\n right = box.paddingRight;\n bottom = box.paddingBottom;\n break;\n case 'root-top':\n top = box.paddingTop;\n left = box.paddingLeft;\n right = box.paddingRight;\n bottom = rect.height * Private.GOLDEN_RATIO;\n break;\n case 'root-left':\n top = box.paddingTop;\n left = box.paddingLeft;\n right = rect.width * Private.GOLDEN_RATIO;\n bottom = box.paddingBottom;\n break;\n case 'root-right':\n top = box.paddingTop;\n left = rect.width * Private.GOLDEN_RATIO;\n right = box.paddingRight;\n bottom = box.paddingBottom;\n break;\n case 'root-bottom':\n top = rect.height * Private.GOLDEN_RATIO;\n left = box.paddingLeft;\n right = box.paddingRight;\n bottom = box.paddingBottom;\n break;\n case 'widget-all':\n top = target!.top;\n left = target!.left;\n right = target!.right;\n bottom = target!.bottom;\n break;\n case 'widget-top':\n top = target!.top;\n left = target!.left;\n right = target!.right;\n bottom = target!.bottom + target!.height / 2;\n break;\n case 'widget-left':\n top = target!.top;\n left = target!.left;\n right = target!.right + target!.width / 2;\n bottom = target!.bottom;\n break;\n case 'widget-right':\n top = target!.top;\n left = target!.left + target!.width / 2;\n right = target!.right;\n bottom = target!.bottom;\n break;\n case 'widget-bottom':\n top = target!.top + target!.height / 2;\n left = target!.left;\n right = target!.right;\n bottom = target!.bottom;\n break;\n case 'widget-tab': {\n const tabHeight = target!.tabBar.node.getBoundingClientRect().height;\n top = target!.top;\n left = target!.left;\n right = target!.right;\n bottom = target!.bottom + target!.height - tabHeight;\n break;\n }\n default:\n throw 'unreachable';\n }\n\n // Show the overlay with the computed geometry.\n this.overlay.show({ top, left, right, bottom });\n\n // Finally, return the computed drop zone.\n return zone;\n }\n\n /**\n * Create a new tab bar for use by the panel.\n */\n private _createTabBar(): TabBar {\n // Create the tab bar.\n let tabBar = this._renderer.createTabBar(this._document);\n\n // Set the generated tab bar property for the tab bar.\n Private.isGeneratedTabBarProperty.set(tabBar, true);\n\n // Hide the tab bar when in single document mode.\n if (this._mode === 'single-document') {\n tabBar.hide();\n }\n\n // Enforce necessary tab bar behavior.\n // TODO do we really want to enforce *all* of these?\n tabBar.tabsMovable = this._tabsMovable;\n tabBar.allowDeselect = false;\n tabBar.addButtonEnabled = this._addButtonEnabled;\n tabBar.removeBehavior = 'select-previous-tab';\n tabBar.insertBehavior = 'select-tab-if-needed';\n\n // Connect the signal handlers for the tab bar.\n tabBar.tabMoved.connect(this._onTabMoved, this);\n tabBar.currentChanged.connect(this._onCurrentChanged, this);\n tabBar.tabCloseRequested.connect(this._onTabCloseRequested, this);\n tabBar.tabDetachRequested.connect(this._onTabDetachRequested, this);\n tabBar.tabActivateRequested.connect(this._onTabActivateRequested, this);\n tabBar.addRequested.connect(this._onTabAddRequested, this);\n\n // Return the initialized tab bar.\n return tabBar;\n }\n\n /**\n * Create a new handle for use by the panel.\n */\n private _createHandle(): HTMLDivElement {\n return this._renderer.createHandle();\n }\n\n /**\n * Handle the `tabMoved` signal from a tab bar.\n */\n private _onTabMoved(): void {\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Handle the `currentChanged` signal from a tab bar.\n */\n private _onCurrentChanged(\n sender: TabBar,\n args: TabBar.ICurrentChangedArgs\n ): void {\n // Extract the previous and current title from the args.\n let { previousTitle, currentTitle } = args;\n\n // Hide the previous widget.\n if (previousTitle) {\n previousTitle.owner.hide();\n }\n\n // Show the current widget.\n if (currentTitle) {\n currentTitle.owner.show();\n }\n\n // Flush the message loop on IE and Edge to prevent flicker.\n if (Platform.IS_EDGE || Platform.IS_IE) {\n MessageLoop.flush();\n }\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Handle the `addRequested` signal from a tab bar.\n */\n private _onTabAddRequested(sender: TabBar): void {\n this._addRequested.emit(sender);\n }\n\n /**\n * Handle the `tabActivateRequested` signal from a tab bar.\n */\n private _onTabActivateRequested(\n sender: TabBar,\n args: TabBar.ITabActivateRequestedArgs\n ): void {\n args.title.owner.activate();\n }\n\n /**\n * Handle the `tabCloseRequested` signal from a tab bar.\n */\n private _onTabCloseRequested(\n sender: TabBar,\n args: TabBar.ITabCloseRequestedArgs\n ): void {\n args.title.owner.close();\n }\n\n /**\n * Handle the `tabDetachRequested` signal from a tab bar.\n */\n private _onTabDetachRequested(\n sender: TabBar,\n args: TabBar.ITabDetachRequestedArgs\n ): void {\n // Do nothing if a drag is already in progress.\n if (this._drag) {\n return;\n }\n\n // Release the tab bar's hold on the mouse.\n sender.releaseMouse();\n\n // Extract the data from the args.\n let { title, tab, clientX, clientY, offset } = args;\n\n // Setup the mime data for the drag operation.\n let mimeData = new MimeData();\n let factory = () => title.owner;\n mimeData.setData('application/vnd.lumino.widget-factory', factory);\n\n // Create the drag image for the drag operation.\n let dragImage = tab.cloneNode(true) as HTMLElement;\n if (offset) {\n dragImage.style.top = `-${offset.y}px`;\n dragImage.style.left = `-${offset.x}px`;\n }\n\n // Create the drag object to manage the drag-drop operation.\n this._drag = new Drag({\n document: this._document,\n mimeData,\n dragImage,\n proposedAction: 'move',\n supportedActions: 'move',\n source: this\n });\n\n // Hide the tab node in the original tab.\n tab.classList.add('lm-mod-hidden');\n let cleanup = () => {\n this._drag = null;\n tab.classList.remove('lm-mod-hidden');\n };\n\n // Start the drag operation and cleanup when done.\n this._drag.start(clientX, clientY).then(cleanup);\n }\n\n private _edges: DockPanel.IEdges;\n private _document: Document | ShadowRoot;\n private _mode: DockPanel.Mode;\n private _drag: Drag | null = null;\n private _renderer: DockPanel.IRenderer;\n private _tabsMovable: boolean = true;\n private _tabsConstrained: boolean = false;\n private _addButtonEnabled: boolean = false;\n private _pressData: Private.IPressData | null = null;\n private _layoutModified = new Signal(this);\n\n private _addRequested = new Signal>(this);\n}\n\n/**\n * The namespace for the `DockPanel` class statics.\n */\nexport namespace DockPanel {\n /**\n * An options object for creating a dock panel.\n */\n export interface IOptions {\n /**\n * The document to use with the dock panel.\n *\n * The default is the global `document` instance.\n */\n\n document?: Document | ShadowRoot;\n /**\n * The overlay to use with the dock panel.\n *\n * The default is a new `Overlay` instance.\n */\n overlay?: IOverlay;\n\n /**\n * The renderer to use for the dock panel.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n\n /**\n * The spacing between the items in the panel.\n *\n * The default is `4`.\n */\n spacing?: number;\n\n /**\n * The mode for the dock panel.\n *\n * The default is `'multiple-document'`.\n */\n mode?: DockPanel.Mode;\n\n /**\n * The sizes of the edge drop zones, in pixels.\n * If not given, default values will be used.\n */\n edges?: IEdges;\n\n /**\n * The method for hiding widgets.\n *\n * The default is `Widget.HiddenMode.Display`.\n */\n hiddenMode?: Widget.HiddenMode;\n\n /**\n * Allow tabs to be draggable / movable by user.\n *\n * The default is `'true'`.\n */\n tabsMovable?: boolean;\n\n /**\n * Constrain tabs to this dock panel\n *\n * The default is `'false'`.\n */\n tabsConstrained?: boolean;\n\n /**\n * Enable add buttons in each of the dock panel's tab bars.\n *\n * The default is `'false'`.\n */\n addButtonEnabled?: boolean;\n }\n\n /**\n * The sizes of the edge drop zones, in pixels.\n */\n export interface IEdges {\n /**\n * The size of the top edge drop zone.\n */\n top: number;\n\n /**\n * The size of the right edge drop zone.\n */\n right: number;\n\n /**\n * The size of the bottom edge drop zone.\n */\n bottom: number;\n\n /**\n * The size of the left edge drop zone.\n */\n left: number;\n }\n\n /**\n * A type alias for the supported dock panel modes.\n */\n export type Mode =\n | /**\n * The single document mode.\n *\n * In this mode, only a single widget is visible at a time, and that\n * widget fills the available layout space. No tab bars are visible.\n */\n 'single-document'\n\n /**\n * The multiple document mode.\n *\n * In this mode, multiple documents are displayed in separate tab\n * areas, and those areas can be individually resized by the user.\n */\n | 'multiple-document';\n\n /**\n * A type alias for a layout configuration object.\n */\n export type ILayoutConfig = DockLayout.ILayoutConfig;\n\n /**\n * A type alias for the supported insertion modes.\n */\n export type InsertMode = DockLayout.InsertMode;\n\n /**\n * A type alias for the add widget options.\n */\n export type IAddOptions = DockLayout.IAddOptions;\n\n /**\n * An object which holds the geometry for overlay positioning.\n */\n export interface IOverlayGeometry {\n /**\n * The distance between the overlay and parent top edges.\n */\n top: number;\n\n /**\n * The distance between the overlay and parent left edges.\n */\n left: number;\n\n /**\n * The distance between the overlay and parent right edges.\n */\n right: number;\n\n /**\n * The distance between the overlay and parent bottom edges.\n */\n bottom: number;\n }\n\n /**\n * An object which manages the overlay node for a dock panel.\n */\n export interface IOverlay {\n /**\n * The DOM node for the overlay.\n */\n readonly node: HTMLDivElement;\n\n /**\n * Show the overlay using the given overlay geometry.\n *\n * @param geo - The desired geometry for the overlay.\n *\n * #### Notes\n * The given geometry values assume the node will use absolute\n * positioning.\n *\n * This is called on every mouse move event during a drag in order\n * to update the position of the overlay. It should be efficient.\n */\n show(geo: IOverlayGeometry): void;\n\n /**\n * Hide the overlay node.\n *\n * @param delay - The delay (in ms) before hiding the overlay.\n * A delay value <= 0 should hide the overlay immediately.\n *\n * #### Notes\n * This is called whenever the overlay node should been hidden.\n */\n hide(delay: number): void;\n }\n\n /**\n * A concrete implementation of `IOverlay`.\n *\n * This is the default overlay implementation for a dock panel.\n */\n export class Overlay implements IOverlay {\n /**\n * Construct a new overlay.\n */\n constructor() {\n this.node = document.createElement('div');\n this.node.classList.add('lm-DockPanel-overlay');\n this.node.classList.add('lm-mod-hidden');\n this.node.style.position = 'absolute';\n this.node.style.contain = 'strict';\n }\n\n /**\n * The DOM node for the overlay.\n */\n readonly node: HTMLDivElement;\n\n /**\n * Show the overlay using the given overlay geometry.\n *\n * @param geo - The desired geometry for the overlay.\n */\n show(geo: IOverlayGeometry): void {\n // Update the position of the overlay.\n let style = this.node.style;\n style.top = `${geo.top}px`;\n style.left = `${geo.left}px`;\n style.right = `${geo.right}px`;\n style.bottom = `${geo.bottom}px`;\n\n // Clear any pending hide timer.\n clearTimeout(this._timer);\n this._timer = -1;\n\n // If the overlay is already visible, we're done.\n if (!this._hidden) {\n return;\n }\n\n // Clear the hidden flag.\n this._hidden = false;\n\n // Finally, show the overlay.\n this.node.classList.remove('lm-mod-hidden');\n }\n\n /**\n * Hide the overlay node.\n *\n * @param delay - The delay (in ms) before hiding the overlay.\n * A delay value <= 0 will hide the overlay immediately.\n */\n hide(delay: number): void {\n // Do nothing if the overlay is already hidden.\n if (this._hidden) {\n return;\n }\n\n // Hide immediately if the delay is <= 0.\n if (delay <= 0) {\n clearTimeout(this._timer);\n this._timer = -1;\n this._hidden = true;\n this.node.classList.add('lm-mod-hidden');\n return;\n }\n\n // Do nothing if a hide is already pending.\n if (this._timer !== -1) {\n return;\n }\n\n // Otherwise setup the hide timer.\n this._timer = window.setTimeout(() => {\n this._timer = -1;\n this._hidden = true;\n this.node.classList.add('lm-mod-hidden');\n }, delay);\n }\n\n private _timer = -1;\n private _hidden = true;\n }\n\n /**\n * A type alias for a dock panel renderer;\n */\n export type IRenderer = DockLayout.IRenderer;\n\n /**\n * The default implementation of `IRenderer`.\n */\n export class Renderer implements IRenderer {\n /**\n * Create a new tab bar for use with a dock panel.\n *\n * @returns A new tab bar for a dock panel.\n */\n createTabBar(document?: Document | ShadowRoot): TabBar {\n let bar = new TabBar({ document });\n bar.addClass('lm-DockPanel-tabBar');\n return bar;\n }\n\n /**\n * Create a new handle node for use with a dock panel.\n *\n * @returns A new handle node for a dock panel.\n */\n createHandle(): HTMLDivElement {\n let handle = document.createElement('div');\n handle.className = 'lm-DockPanel-handle';\n return handle;\n }\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * A fraction used for sizing root panels; ~= `1 / golden_ratio`.\n */\n export const GOLDEN_RATIO = 0.618;\n\n /**\n * The default sizes for the edge drop zones, in pixels.\n */\n export const DEFAULT_EDGES = {\n /**\n * The size of the top edge dock zone for the root panel, in pixels.\n * This is different from the others to distinguish between the top\n * tab bar and the top root zone.\n */\n top: 12,\n\n /**\n * The size of the edge dock zone for the root panel, in pixels.\n */\n right: 40,\n\n /**\n * The size of the edge dock zone for the root panel, in pixels.\n */\n bottom: 40,\n\n /**\n * The size of the edge dock zone for the root panel, in pixels.\n */\n left: 40\n };\n\n /**\n * A singleton `'layout-modified'` conflatable message.\n */\n export const LayoutModified = new ConflatableMessage('layout-modified');\n\n /**\n * An object which holds mouse press data.\n */\n export interface IPressData {\n /**\n * The handle which was pressed.\n */\n handle: HTMLDivElement;\n\n /**\n * The X offset of the press in handle coordinates.\n */\n deltaX: number;\n\n /**\n * The Y offset of the press in handle coordinates.\n */\n deltaY: number;\n\n /**\n * The disposable which will clear the override cursor.\n */\n override: IDisposable;\n }\n\n /**\n * A type alias for a drop zone.\n */\n export type DropZone =\n | /**\n * An invalid drop zone.\n */\n 'invalid'\n\n /**\n * The entirety of the root dock area.\n */\n | 'root-all'\n\n /**\n * The top portion of the root dock area.\n */\n | 'root-top'\n\n /**\n * The left portion of the root dock area.\n */\n | 'root-left'\n\n /**\n * The right portion of the root dock area.\n */\n | 'root-right'\n\n /**\n * The bottom portion of the root dock area.\n */\n | 'root-bottom'\n\n /**\n * The entirety of a tabbed widget area.\n */\n | 'widget-all'\n\n /**\n * The top portion of tabbed widget area.\n */\n | 'widget-top'\n\n /**\n * The left portion of tabbed widget area.\n */\n | 'widget-left'\n\n /**\n * The right portion of tabbed widget area.\n */\n | 'widget-right'\n\n /**\n * The bottom portion of tabbed widget area.\n */\n | 'widget-bottom'\n\n /**\n * The the bar of a tabbed widget area.\n */\n | 'widget-tab';\n\n /**\n * An object which holds the drop target zone and widget.\n */\n export interface IDropTarget {\n /**\n * The semantic zone for the mouse position.\n */\n zone: DropZone;\n\n /**\n * The tab area geometry for the drop zone, or `null`.\n */\n target: DockLayout.ITabAreaGeometry | null;\n }\n\n /**\n * An attached property used to track generated tab bars.\n */\n export const isGeneratedTabBarProperty = new AttachedProperty<\n Widget,\n boolean\n >({\n name: 'isGeneratedTabBar',\n create: () => false\n });\n\n /**\n * Create a single document config for the widgets in a dock panel.\n */\n export function createSingleDocumentConfig(\n panel: DockPanel\n ): DockPanel.ILayoutConfig {\n // Return an empty config if the panel is empty.\n if (panel.isEmpty) {\n return { main: null };\n }\n\n // Get a flat array of the widgets in the panel.\n let widgets = Array.from(panel.widgets());\n\n // Get the first selected widget in the panel.\n let selected = panel.selectedWidgets().next().value;\n\n // Compute the current index for the new config.\n let currentIndex = selected ? widgets.indexOf(selected) : -1;\n\n // Return the single document config.\n return { main: { type: 'tab-area', widgets, currentIndex } };\n }\n\n /**\n * Find the drop target at the given client position.\n */\n export function findDropTarget(\n panel: DockPanel,\n clientX: number,\n clientY: number,\n edges: DockPanel.IEdges\n ): IDropTarget {\n // Bail if the mouse is not over the dock panel.\n if (!ElementExt.hitTest(panel.node, clientX, clientY)) {\n return { zone: 'invalid', target: null };\n }\n\n // Look up the layout for the panel.\n let layout = panel.layout as DockLayout;\n\n // If the layout is empty, indicate the entire root drop zone.\n if (layout.isEmpty) {\n return { zone: 'root-all', target: null };\n }\n\n // Test the edge zones when in multiple document mode.\n if (panel.mode === 'multiple-document') {\n // Get the client rect for the dock panel.\n let panelRect = panel.node.getBoundingClientRect();\n\n // Compute the distance to each edge of the panel.\n let pl = clientX - panelRect.left + 1;\n let pt = clientY - panelRect.top + 1;\n let pr = panelRect.right - clientX;\n let pb = panelRect.bottom - clientY;\n\n // Find the minimum distance to an edge.\n let pd = Math.min(pt, pr, pb, pl);\n\n // Return a root zone if the mouse is within an edge.\n switch (pd) {\n case pt:\n if (pt < edges.top) {\n return { zone: 'root-top', target: null };\n }\n break;\n case pr:\n if (pr < edges.right) {\n return { zone: 'root-right', target: null };\n }\n break;\n case pb:\n if (pb < edges.bottom) {\n return { zone: 'root-bottom', target: null };\n }\n break;\n case pl:\n if (pl < edges.left) {\n return { zone: 'root-left', target: null };\n }\n break;\n default:\n throw 'unreachable';\n }\n }\n\n // Hit test the dock layout at the given client position.\n let target = layout.hitTestTabAreas(clientX, clientY);\n\n // Bail if no target area was found.\n if (!target) {\n return { zone: 'invalid', target: null };\n }\n\n // Return the whole tab area when in single document mode.\n if (panel.mode === 'single-document') {\n return { zone: 'widget-all', target };\n }\n\n // Compute the distance to each edge of the tab area.\n let al = target.x - target.left + 1;\n let at = target.y - target.top + 1;\n let ar = target.left + target.width - target.x;\n let ab = target.top + target.height - target.y;\n\n const tabHeight = target.tabBar.node.getBoundingClientRect().height;\n if (at < tabHeight) {\n return { zone: 'widget-tab', target };\n }\n\n // Get the X and Y edge sizes for the area.\n let rx = Math.round(target.width / 3);\n let ry = Math.round(target.height / 3);\n\n // If the mouse is not within an edge, indicate the entire area.\n if (al > rx && ar > rx && at > ry && ab > ry) {\n return { zone: 'widget-all', target };\n }\n\n // Scale the distances by the slenderness ratio.\n al /= rx;\n at /= ry;\n ar /= rx;\n ab /= ry;\n\n // Find the minimum distance to the area edge.\n let ad = Math.min(al, at, ar, ab);\n\n // Find the widget zone for the area edge.\n let zone: DropZone;\n switch (ad) {\n case al:\n zone = 'widget-left';\n break;\n case at:\n zone = 'widget-top';\n break;\n case ar:\n zone = 'widget-right';\n break;\n case ab:\n zone = 'widget-bottom';\n break;\n default:\n throw 'unreachable';\n }\n\n // Return the final drop target.\n return { zone, target };\n }\n\n /**\n * Get the drop reference widget for a tab bar.\n */\n export function getDropRef(tabBar: TabBar): Widget | null {\n if (tabBar.titles.length === 0) {\n return null;\n }\n if (tabBar.currentTitle) {\n return tabBar.currentTitle.owner;\n }\n return tabBar.titles[tabBar.titles.length - 1].owner;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { BoxEngine, BoxSizer } from './boxengine';\n\nimport { Layout, LayoutItem } from './layout';\n\nimport { Widget } from './widget';\n\n/**\n * A layout which arranges its widgets in a grid.\n */\nexport class GridLayout extends Layout {\n /**\n * Construct a new grid layout.\n *\n * @param options - The options for initializing the layout.\n */\n constructor(options: GridLayout.IOptions = {}) {\n super(options);\n if (options.rowCount !== undefined) {\n Private.reallocSizers(this._rowSizers, options.rowCount);\n }\n if (options.columnCount !== undefined) {\n Private.reallocSizers(this._columnSizers, options.columnCount);\n }\n if (options.rowSpacing !== undefined) {\n this._rowSpacing = Private.clampValue(options.rowSpacing);\n }\n if (options.columnSpacing !== undefined) {\n this._columnSpacing = Private.clampValue(options.columnSpacing);\n }\n }\n\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n // Dispose of the widgets and layout items.\n for (const item of this._items) {\n let widget = item.widget;\n item.dispose();\n widget.dispose();\n }\n\n // Clear the layout state.\n this._box = null;\n this._items.length = 0;\n this._rowStarts.length = 0;\n this._rowSizers.length = 0;\n this._columnStarts.length = 0;\n this._columnSizers.length = 0;\n\n // Dispose of the rest of the layout.\n super.dispose();\n }\n\n /**\n * Get the number of rows in the layout.\n */\n get rowCount(): number {\n return this._rowSizers.length;\n }\n\n /**\n * Set the number of rows in the layout.\n *\n * #### Notes\n * The minimum row count is `1`.\n */\n set rowCount(value: number) {\n // Do nothing if the row count does not change.\n if (value === this.rowCount) {\n return;\n }\n\n // Reallocate the row sizers.\n Private.reallocSizers(this._rowSizers, value);\n\n // Schedule a fit of the parent.\n if (this.parent) {\n this.parent.fit();\n }\n }\n\n /**\n * Get the number of columns in the layout.\n */\n get columnCount(): number {\n return this._columnSizers.length;\n }\n\n /**\n * Set the number of columns in the layout.\n *\n * #### Notes\n * The minimum column count is `1`.\n */\n set columnCount(value: number) {\n // Do nothing if the column count does not change.\n if (value === this.columnCount) {\n return;\n }\n\n // Reallocate the column sizers.\n Private.reallocSizers(this._columnSizers, value);\n\n // Schedule a fit of the parent.\n if (this.parent) {\n this.parent.fit();\n }\n }\n\n /**\n * Get the row spacing for the layout.\n */\n get rowSpacing(): number {\n return this._rowSpacing;\n }\n\n /**\n * Set the row spacing for the layout.\n */\n set rowSpacing(value: number) {\n // Clamp the spacing to the allowed range.\n value = Private.clampValue(value);\n\n // Bail if the spacing does not change\n if (this._rowSpacing === value) {\n return;\n }\n\n // Update the internal spacing.\n this._rowSpacing = value;\n\n // Schedule a fit of the parent.\n if (this.parent) {\n this.parent.fit();\n }\n }\n\n /**\n * Get the column spacing for the layout.\n */\n get columnSpacing(): number {\n return this._columnSpacing;\n }\n\n /**\n * Set the col spacing for the layout.\n */\n set columnSpacing(value: number) {\n // Clamp the spacing to the allowed range.\n value = Private.clampValue(value);\n\n // Bail if the spacing does not change\n if (this._columnSpacing === value) {\n return;\n }\n\n // Update the internal spacing.\n this._columnSpacing = value;\n\n // Schedule a fit of the parent.\n if (this.parent) {\n this.parent.fit();\n }\n }\n\n /**\n * Get the stretch factor for a specific row.\n *\n * @param index - The row index of interest.\n *\n * @returns The stretch factor for the row.\n *\n * #### Notes\n * This returns `-1` if the index is out of range.\n */\n rowStretch(index: number): number {\n let sizer = this._rowSizers[index];\n return sizer ? sizer.stretch : -1;\n }\n\n /**\n * Set the stretch factor for a specific row.\n *\n * @param index - The row index of interest.\n *\n * @param value - The stretch factor for the row.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n setRowStretch(index: number, value: number): void {\n // Look up the row sizer.\n let sizer = this._rowSizers[index];\n\n // Bail if the index is out of range.\n if (!sizer) {\n return;\n }\n\n // Clamp the value to the allowed range.\n value = Private.clampValue(value);\n\n // Bail if the stretch does not change.\n if (sizer.stretch === value) {\n return;\n }\n\n // Update the sizer stretch.\n sizer.stretch = value;\n\n // Schedule an update of the parent.\n if (this.parent) {\n this.parent.update();\n }\n }\n\n /**\n * Get the stretch factor for a specific column.\n *\n * @param index - The column index of interest.\n *\n * @returns The stretch factor for the column.\n *\n * #### Notes\n * This returns `-1` if the index is out of range.\n */\n columnStretch(index: number): number {\n let sizer = this._columnSizers[index];\n return sizer ? sizer.stretch : -1;\n }\n\n /**\n * Set the stretch factor for a specific column.\n *\n * @param index - The column index of interest.\n *\n * @param value - The stretch factor for the column.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n setColumnStretch(index: number, value: number): void {\n // Look up the column sizer.\n let sizer = this._columnSizers[index];\n\n // Bail if the index is out of range.\n if (!sizer) {\n return;\n }\n\n // Clamp the value to the allowed range.\n value = Private.clampValue(value);\n\n // Bail if the stretch does not change.\n if (sizer.stretch === value) {\n return;\n }\n\n // Update the sizer stretch.\n sizer.stretch = value;\n\n // Schedule an update of the parent.\n if (this.parent) {\n this.parent.update();\n }\n }\n\n /**\n * Create an iterator over the widgets in the layout.\n *\n * @returns A new iterator over the widgets in the layout.\n */\n *[Symbol.iterator](): IterableIterator {\n for (const item of this._items) {\n yield item.widget;\n }\n }\n\n /**\n * Add a widget to the grid layout.\n *\n * @param widget - The widget to add to the layout.\n *\n * #### Notes\n * If the widget is already contained in the layout, this is no-op.\n */\n addWidget(widget: Widget): void {\n // Look up the index for the widget.\n let i = ArrayExt.findFirstIndex(this._items, it => it.widget === widget);\n\n // Bail if the widget is already in the layout.\n if (i !== -1) {\n return;\n }\n\n // Add the widget to the layout.\n this._items.push(new LayoutItem(widget));\n\n // Attach the widget to the parent.\n if (this.parent) {\n this.attachWidget(widget);\n }\n }\n\n /**\n * Remove a widget from the grid layout.\n *\n * @param widget - The widget to remove from the layout.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method does *not* modify the widget's `parent`.\n */\n removeWidget(widget: Widget): void {\n // Look up the index for the widget.\n let i = ArrayExt.findFirstIndex(this._items, it => it.widget === widget);\n\n // Bail if the widget is not in the layout.\n if (i === -1) {\n return;\n }\n\n // Remove the widget from the layout.\n let item = ArrayExt.removeAt(this._items, i)!;\n\n // Detach the widget from the parent.\n if (this.parent) {\n this.detachWidget(widget);\n }\n\n // Dispose the layout item.\n item.dispose();\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n super.init();\n for (const widget of this) {\n this.attachWidget(widget);\n }\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param widget - The widget to attach to the parent.\n */\n protected attachWidget(widget: Widget): void {\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget's node to the parent.\n this.parent!.node.appendChild(widget.node);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param widget - The widget to detach from the parent.\n */\n protected detachWidget(widget: Widget): void {\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n */\n protected onBeforeShow(msg: Message): void {\n super.onBeforeShow(msg);\n this.parent!.update();\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n super.onBeforeAttach(msg);\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n if (this.parent!.isVisible) {\n this._update(msg.width, msg.height);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.parent!.isVisible) {\n this._update(-1, -1);\n }\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n */\n protected onFitRequest(msg: Message): void {\n if (this.parent!.isAttached) {\n this._fit();\n }\n }\n\n /**\n * Fit the layout to the total size required by the widgets.\n */\n private _fit(): void {\n // Reset the min sizes of the sizers.\n for (let i = 0, n = this.rowCount; i < n; ++i) {\n this._rowSizers[i].minSize = 0;\n }\n for (let i = 0, n = this.columnCount; i < n; ++i) {\n this._columnSizers[i].minSize = 0;\n }\n\n // Filter for the visible layout items.\n let items = this._items.filter(it => !it.isHidden);\n\n // Fit the layout items.\n for (let i = 0, n = items.length; i < n; ++i) {\n items[i].fit();\n }\n\n // Get the max row and column index.\n let maxRow = this.rowCount - 1;\n let maxCol = this.columnCount - 1;\n\n // Sort the items by row span.\n items.sort(Private.rowSpanCmp);\n\n // Update the min sizes of the row sizers.\n for (let i = 0, n = items.length; i < n; ++i) {\n // Fetch the item.\n let item = items[i];\n\n // Get the row bounds for the item.\n let config = GridLayout.getCellConfig(item.widget);\n let r1 = Math.min(config.row, maxRow);\n let r2 = Math.min(config.row + config.rowSpan - 1, maxRow);\n\n // Distribute the minimum height to the sizers as needed.\n Private.distributeMin(this._rowSizers, r1, r2, item.minHeight);\n }\n\n // Sort the items by column span.\n items.sort(Private.columnSpanCmp);\n\n // Update the min sizes of the column sizers.\n for (let i = 0, n = items.length; i < n; ++i) {\n // Fetch the item.\n let item = items[i];\n\n // Get the column bounds for the item.\n let config = GridLayout.getCellConfig(item.widget);\n let c1 = Math.min(config.column, maxCol);\n let c2 = Math.min(config.column + config.columnSpan - 1, maxCol);\n\n // Distribute the minimum width to the sizers as needed.\n Private.distributeMin(this._columnSizers, c1, c2, item.minWidth);\n }\n\n // If no size constraint is needed, just update the parent.\n if (this.fitPolicy === 'set-no-constraint') {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n return;\n }\n\n // Set up the computed min size.\n let minH = maxRow * this._rowSpacing;\n let minW = maxCol * this._columnSpacing;\n\n // Add the sizer minimums to the computed min size.\n for (let i = 0, n = this.rowCount; i < n; ++i) {\n minH += this._rowSizers[i].minSize;\n }\n for (let i = 0, n = this.columnCount; i < n; ++i) {\n minW += this._columnSizers[i].minSize;\n }\n\n // Update the box sizing and add it to the computed min size.\n let box = (this._box = ElementExt.boxSizing(this.parent!.node));\n minW += box.horizontalSum;\n minH += box.verticalSum;\n\n // Update the parent's min size constraints.\n let style = this.parent!.node.style;\n style.minWidth = `${minW}px`;\n style.minHeight = `${minH}px`;\n\n // Set the dirty flag to ensure only a single update occurs.\n this._dirty = true;\n\n // Notify the ancestor that it should fit immediately. This may\n // cause a resize of the parent, fulfilling the required update.\n if (this.parent!.parent) {\n MessageLoop.sendMessage(this.parent!.parent!, Widget.Msg.FitRequest);\n }\n\n // If the dirty flag is still set, the parent was not resized.\n // Trigger the required update on the parent widget immediately.\n if (this._dirty) {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n }\n }\n\n /**\n * Update the layout position and size of the widgets.\n *\n * The parent offset dimensions should be `-1` if unknown.\n */\n private _update(offsetWidth: number, offsetHeight: number): void {\n // Clear the dirty flag to indicate the update occurred.\n this._dirty = false;\n\n // Measure the parent if the offset dimensions are unknown.\n if (offsetWidth < 0) {\n offsetWidth = this.parent!.node.offsetWidth;\n }\n if (offsetHeight < 0) {\n offsetHeight = this.parent!.node.offsetHeight;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent!.node);\n }\n\n // Compute the layout area adjusted for border and padding.\n let top = this._box.paddingTop;\n let left = this._box.paddingLeft;\n let width = offsetWidth - this._box.horizontalSum;\n let height = offsetHeight - this._box.verticalSum;\n\n // Get the max row and column index.\n let maxRow = this.rowCount - 1;\n let maxCol = this.columnCount - 1;\n\n // Compute the total fixed row and column space.\n let fixedRowSpace = maxRow * this._rowSpacing;\n let fixedColSpace = maxCol * this._columnSpacing;\n\n // Distribute the available space to the box sizers.\n BoxEngine.calc(this._rowSizers, Math.max(0, height - fixedRowSpace));\n BoxEngine.calc(this._columnSizers, Math.max(0, width - fixedColSpace));\n\n // Update the row start positions.\n for (let i = 0, pos = top, n = this.rowCount; i < n; ++i) {\n this._rowStarts[i] = pos;\n pos += this._rowSizers[i].size + this._rowSpacing;\n }\n\n // Update the column start positions.\n for (let i = 0, pos = left, n = this.columnCount; i < n; ++i) {\n this._columnStarts[i] = pos;\n pos += this._columnSizers[i].size + this._columnSpacing;\n }\n\n // Update the geometry of the layout items.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item.\n let item = this._items[i];\n\n // Ignore hidden items.\n if (item.isHidden) {\n continue;\n }\n\n // Fetch the cell bounds for the widget.\n let config = GridLayout.getCellConfig(item.widget);\n let r1 = Math.min(config.row, maxRow);\n let c1 = Math.min(config.column, maxCol);\n let r2 = Math.min(config.row + config.rowSpan - 1, maxRow);\n let c2 = Math.min(config.column + config.columnSpan - 1, maxCol);\n\n // Compute the cell geometry.\n let x = this._columnStarts[c1];\n let y = this._rowStarts[r1];\n let w = this._columnStarts[c2] + this._columnSizers[c2].size - x;\n let h = this._rowStarts[r2] + this._rowSizers[r2].size - y;\n\n // Update the geometry of the layout item.\n item.update(x, y, w, h);\n }\n }\n\n private _dirty = false;\n private _rowSpacing = 4;\n private _columnSpacing = 4;\n private _items: LayoutItem[] = [];\n private _rowStarts: number[] = [];\n private _columnStarts: number[] = [];\n private _rowSizers: BoxSizer[] = [new BoxSizer()];\n private _columnSizers: BoxSizer[] = [new BoxSizer()];\n private _box: ElementExt.IBoxSizing | null = null;\n}\n\n/**\n * The namespace for the `GridLayout` class statics.\n */\nexport namespace GridLayout {\n /**\n * An options object for initializing a grid layout.\n */\n export interface IOptions extends Layout.IOptions {\n /**\n * The initial row count for the layout.\n *\n * The default is `1`.\n */\n rowCount?: number;\n\n /**\n * The initial column count for the layout.\n *\n * The default is `1`.\n */\n columnCount?: number;\n\n /**\n * The spacing between rows in the layout.\n *\n * The default is `4`.\n */\n rowSpacing?: number;\n\n /**\n * The spacing between columns in the layout.\n *\n * The default is `4`.\n */\n columnSpacing?: number;\n }\n\n /**\n * An object which holds the cell configuration for a widget.\n */\n export interface ICellConfig {\n /**\n * The row index for the widget.\n */\n readonly row: number;\n\n /**\n * The column index for the widget.\n */\n readonly column: number;\n\n /**\n * The row span for the widget.\n */\n readonly rowSpan: number;\n\n /**\n * The column span for the widget.\n */\n readonly columnSpan: number;\n }\n\n /**\n * Get the cell config for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The cell config for the widget.\n */\n export function getCellConfig(widget: Widget): ICellConfig {\n return Private.cellConfigProperty.get(widget);\n }\n\n /**\n * Set the cell config for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the cell config.\n */\n export function setCellConfig(\n widget: Widget,\n value: Partial\n ): void {\n Private.cellConfigProperty.set(widget, Private.normalizeConfig(value));\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The property descriptor for the widget cell config.\n */\n export const cellConfigProperty = new AttachedProperty<\n Widget,\n GridLayout.ICellConfig\n >({\n name: 'cellConfig',\n create: () => ({ row: 0, column: 0, rowSpan: 1, columnSpan: 1 }),\n changed: onChildCellConfigChanged\n });\n\n /**\n * Normalize a partial cell config object.\n */\n export function normalizeConfig(\n config: Partial\n ): GridLayout.ICellConfig {\n let row = Math.max(0, Math.floor(config.row || 0));\n let column = Math.max(0, Math.floor(config.column || 0));\n let rowSpan = Math.max(1, Math.floor(config.rowSpan || 0));\n let columnSpan = Math.max(1, Math.floor(config.columnSpan || 0));\n return { row, column, rowSpan, columnSpan };\n }\n\n /**\n * Clamp a value to an integer >= 0.\n */\n export function clampValue(value: number): number {\n return Math.max(0, Math.floor(value));\n }\n\n /**\n * A sort comparison function for row spans.\n */\n export function rowSpanCmp(a: LayoutItem, b: LayoutItem): number {\n let c1 = cellConfigProperty.get(a.widget);\n let c2 = cellConfigProperty.get(b.widget);\n return c1.rowSpan - c2.rowSpan;\n }\n\n /**\n * A sort comparison function for column spans.\n */\n export function columnSpanCmp(a: LayoutItem, b: LayoutItem): number {\n let c1 = cellConfigProperty.get(a.widget);\n let c2 = cellConfigProperty.get(b.widget);\n return c1.columnSpan - c2.columnSpan;\n }\n\n /**\n * Reallocate the box sizers for the given grid dimensions.\n */\n export function reallocSizers(sizers: BoxSizer[], count: number): void {\n // Coerce the count to the valid range.\n count = Math.max(1, Math.floor(count));\n\n // Add the missing sizers.\n while (sizers.length < count) {\n sizers.push(new BoxSizer());\n }\n\n // Remove the extra sizers.\n if (sizers.length > count) {\n sizers.length = count;\n }\n }\n\n /**\n * Distribute a min size constraint across a range of sizers.\n */\n export function distributeMin(\n sizers: BoxSizer[],\n i1: number,\n i2: number,\n minSize: number\n ): void {\n // Sanity check the indices.\n if (i2 < i1) {\n return;\n }\n\n // Handle the simple case of no cell span.\n if (i1 === i2) {\n let sizer = sizers[i1];\n sizer.minSize = Math.max(sizer.minSize, minSize);\n return;\n }\n\n // Compute the total current min size of the span.\n let totalMin = 0;\n for (let i = i1; i <= i2; ++i) {\n totalMin += sizers[i].minSize;\n }\n\n // Do nothing if the total is greater than the required.\n if (totalMin >= minSize) {\n return;\n }\n\n // Compute the portion of the space to allocate to each sizer.\n let portion = (minSize - totalMin) / (i2 - i1 + 1);\n\n // Add the portion to each sizer.\n for (let i = i1; i <= i2; ++i) {\n sizers[i].minSize += portion;\n }\n }\n\n /**\n * The change handler for the child cell config property.\n */\n function onChildCellConfigChanged(child: Widget): void {\n if (child.parent && child.parent.layout instanceof GridLayout) {\n child.parent.fit();\n }\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { getKeyboardLayout } from '@lumino/keyboard';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { CommandRegistry } from '@lumino/commands';\n\nimport {\n ElementARIAAttrs,\n ElementDataset,\n h,\n VirtualDOM,\n VirtualElement\n} from '@lumino/virtualdom';\n\nimport { Menu } from './menu';\n\nimport { Title } from './title';\n\nimport { Widget } from './widget';\n\n/**\n * A widget which displays menus as a canonical menu bar.\n */\nexport class MenuBar extends Widget {\n /**\n * Construct a new menu bar.\n *\n * @param options - The options for initializing the menu bar.\n */\n constructor(options: MenuBar.IOptions = {}) {\n super({ node: Private.createNode() });\n this.addClass('lm-MenuBar');\n this.setFlag(Widget.Flag.DisallowLayout);\n this.renderer = options.renderer || MenuBar.defaultRenderer;\n this._forceItemsPosition = options.forceItemsPosition || {\n forceX: true,\n forceY: true\n };\n this._overflowMenuOptions = options.overflowMenuOptions || {\n isVisible: true\n };\n }\n\n /**\n * Dispose of the resources held by the widget.\n */\n dispose(): void {\n this._closeChildMenu();\n this._menus.length = 0;\n super.dispose();\n }\n\n /**\n * The renderer used by the menu bar.\n */\n readonly renderer: MenuBar.IRenderer;\n\n /**\n * The child menu of the menu bar.\n *\n * #### Notes\n * This will be `null` if the menu bar does not have an open menu.\n */\n get childMenu(): Menu | null {\n return this._childMenu;\n }\n\n /**\n * The overflow index of the menu bar.\n */\n get overflowIndex(): number {\n return this._overflowIndex;\n }\n\n /**\n * The overflow menu of the menu bar.\n */\n get overflowMenu(): Menu | null {\n return this._overflowMenu;\n }\n\n /**\n * Get the menu bar content node.\n *\n * #### Notes\n * This is the node which holds the menu title nodes.\n *\n * Modifying this node directly can lead to undefined behavior.\n */\n get contentNode(): HTMLUListElement {\n return this.node.getElementsByClassName(\n 'lm-MenuBar-content'\n )[0] as HTMLUListElement;\n }\n\n /**\n * Get the currently active menu.\n */\n get activeMenu(): Menu | null {\n return this._menus[this._activeIndex] || null;\n }\n\n /**\n * Set the currently active menu.\n *\n * #### Notes\n * If the menu does not exist, the menu will be set to `null`.\n */\n set activeMenu(value: Menu | null) {\n this.activeIndex = value ? this._menus.indexOf(value) : -1;\n }\n\n /**\n * Get the index of the currently active menu.\n *\n * #### Notes\n * This will be `-1` if no menu is active.\n */\n get activeIndex(): number {\n return this._activeIndex;\n }\n\n /**\n * Set the index of the currently active menu.\n *\n * #### Notes\n * If the menu cannot be activated, the index will be set to `-1`.\n */\n set activeIndex(value: number) {\n // Adjust the value for an out of range index.\n if (value < 0 || value >= this._menus.length) {\n value = -1;\n }\n\n // An empty menu cannot be active\n if (value > -1 && this._menus[value].items.length === 0) {\n value = -1;\n }\n\n // Bail early if the index will not change.\n if (this._activeIndex === value) {\n return;\n }\n\n // Update the active index.\n this._activeIndex = value;\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * A read-only array of the menus in the menu bar.\n */\n get menus(): ReadonlyArray {\n return this._menus;\n }\n\n /**\n * Open the active menu and activate its first menu item.\n *\n * #### Notes\n * If there is no active menu, this is a no-op.\n */\n openActiveMenu(): void {\n // Bail early if there is no active item.\n if (this._activeIndex === -1) {\n return;\n }\n\n // Open the child menu.\n this._openChildMenu();\n\n // Activate the first item in the child menu.\n if (this._childMenu) {\n this._childMenu.activeIndex = -1;\n this._childMenu.activateNextItem();\n }\n }\n\n /**\n * Add a menu to the end of the menu bar.\n *\n * @param menu - The menu to add to the menu bar.\n *\n * #### Notes\n * If the menu is already added to the menu bar, it will be moved.\n */\n addMenu(menu: Menu, update: boolean = true): void {\n this.insertMenu(this._menus.length, menu, update);\n }\n\n /**\n * Insert a menu into the menu bar at the specified index.\n *\n * @param index - The index at which to insert the menu.\n *\n * @param menu - The menu to insert into the menu bar.\n *\n * #### Notes\n * The index will be clamped to the bounds of the menus.\n *\n * If the menu is already added to the menu bar, it will be moved.\n */\n insertMenu(index: number, menu: Menu, update: boolean = true): void {\n // Close the child menu before making changes.\n this._closeChildMenu();\n\n // Look up the index of the menu.\n let i = this._menus.indexOf(menu);\n\n // Clamp the insert index to the array bounds.\n let j = Math.max(0, Math.min(index, this._menus.length));\n\n // If the menu is not in the array, insert it.\n if (i === -1) {\n // Insert the menu into the array.\n ArrayExt.insert(this._menus, j, menu);\n\n // Add the styling class to the menu.\n menu.addClass('lm-MenuBar-menu');\n\n // Connect to the menu signals.\n menu.aboutToClose.connect(this._onMenuAboutToClose, this);\n menu.menuRequested.connect(this._onMenuMenuRequested, this);\n menu.title.changed.connect(this._onTitleChanged, this);\n\n // Schedule an update of the items.\n if (update) {\n this.update();\n }\n\n // There is nothing more to do.\n return;\n }\n\n // Otherwise, the menu exists in the array and should be moved.\n\n // Adjust the index if the location is at the end of the array.\n if (j === this._menus.length) {\n j--;\n }\n\n // Bail if there is no effective move.\n if (i === j) {\n return;\n }\n\n // Move the menu to the new locations.\n ArrayExt.move(this._menus, i, j);\n\n // Schedule an update of the items.\n if (update) {\n this.update();\n }\n }\n\n /**\n * Remove a menu from the menu bar.\n *\n * @param menu - The menu to remove from the menu bar.\n *\n * #### Notes\n * This is a no-op if the menu is not in the menu bar.\n */\n removeMenu(menu: Menu, update: boolean = true): void {\n this.removeMenuAt(this._menus.indexOf(menu), update);\n }\n\n /**\n * Remove the menu at a given index from the menu bar.\n *\n * @param index - The index of the menu to remove.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n removeMenuAt(index: number, update: boolean = true): void {\n // Close the child menu before making changes.\n this._closeChildMenu();\n\n // Remove the menu from the array.\n let menu = ArrayExt.removeAt(this._menus, index);\n\n // Bail if the index is out of range.\n if (!menu) {\n return;\n }\n\n // Disconnect from the menu signals.\n menu.aboutToClose.disconnect(this._onMenuAboutToClose, this);\n menu.menuRequested.disconnect(this._onMenuMenuRequested, this);\n menu.title.changed.disconnect(this._onTitleChanged, this);\n\n // Remove the styling class from the menu.\n menu.removeClass('lm-MenuBar-menu');\n\n // Schedule an update of the items.\n if (update) {\n this.update();\n }\n }\n\n /**\n * Remove all menus from the menu bar.\n */\n clearMenus(): void {\n // Bail if there is nothing to remove.\n if (this._menus.length === 0) {\n return;\n }\n\n // Close the child menu before making changes.\n this._closeChildMenu();\n\n // Disconnect from the menu signals and remove the styling class.\n for (let menu of this._menus) {\n menu.aboutToClose.disconnect(this._onMenuAboutToClose, this);\n menu.menuRequested.disconnect(this._onMenuMenuRequested, this);\n menu.title.changed.disconnect(this._onTitleChanged, this);\n menu.removeClass('lm-MenuBar-menu');\n }\n\n // Clear the menus array.\n this._menus.length = 0;\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * Handle the DOM events for the menu bar.\n *\n * @param event - The DOM event sent to the menu bar.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the menu bar's DOM nodes. It\n * should not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'mousedown':\n this._evtMouseDown(event as MouseEvent);\n break;\n case 'mousemove':\n this._evtMouseMove(event as MouseEvent);\n break;\n case 'focusout':\n this._evtFocusOut(event as FocusEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('keydown', this);\n this.node.addEventListener('mousedown', this);\n this.node.addEventListener('mousemove', this);\n this.node.addEventListener('focusout', this);\n this.node.addEventListener('contextmenu', this);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('keydown', this);\n this.node.removeEventListener('mousedown', this);\n this.node.removeEventListener('mousemove', this);\n this.node.removeEventListener('focusout', this);\n this.node.removeEventListener('contextmenu', this);\n this._closeChildMenu();\n }\n\n /**\n * A message handler invoked on an `'activate-request'` message.\n */\n protected onActivateRequest(msg: Message): void {\n if (this.isAttached) {\n this._focusItemAt(0);\n }\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n this.update();\n super.onResize(msg);\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n let menus = this._menus;\n let renderer = this.renderer;\n let activeIndex = this._activeIndex;\n let tabFocusIndex =\n this._tabFocusIndex >= 0 && this._tabFocusIndex < menus.length\n ? this._tabFocusIndex\n : 0;\n let length = this._overflowIndex > -1 ? this._overflowIndex : menus.length;\n let totalMenuSize = 0;\n let isVisible = false;\n\n // Check that the overflow menu doesn't count\n length = this._overflowMenu !== null ? length - 1 : length;\n let content = new Array(length);\n\n // Render visible menus\n for (let i = 0; i < length; ++i) {\n content[i] = renderer.renderItem({\n title: menus[i].title,\n active: i === activeIndex,\n tabbable: i === tabFocusIndex,\n disabled: menus[i].items.length === 0,\n onfocus: () => {\n this._tabFocusIndex = i;\n this.activeIndex = i;\n }\n });\n // Calculate size of current menu\n totalMenuSize += this._menuItemSizes[i];\n // Check if overflow menu is already rendered\n if (menus[i].title.label === this._overflowMenuOptions.title) {\n isVisible = true;\n length--;\n }\n }\n // Render overflow menu if needed and active\n if (this._overflowMenuOptions.isVisible) {\n if (this._overflowIndex > -1 && !isVisible) {\n // Create overflow menu\n if (this._overflowMenu === null) {\n const overflowMenuTitle = this._overflowMenuOptions.title ?? '...';\n this._overflowMenu = new Menu({ commands: new CommandRegistry() });\n this._overflowMenu.title.label = overflowMenuTitle;\n this._overflowMenu.title.mnemonic = 0;\n this.addMenu(this._overflowMenu, false);\n }\n // Move menus to overflow menu\n for (let i = menus.length - 2; i >= length; i--) {\n const submenu = this.menus[i];\n submenu.title.mnemonic = 0;\n this._overflowMenu.insertItem(0, {\n type: 'submenu',\n submenu: submenu\n });\n this.removeMenu(submenu, false);\n }\n content[length] = renderer.renderItem({\n title: this._overflowMenu.title,\n active: length === activeIndex && menus[length].items.length !== 0,\n tabbable: length === tabFocusIndex,\n disabled: menus[length].items.length === 0,\n onfocus: () => {\n this._tabFocusIndex = length;\n this.activeIndex = length;\n }\n });\n length++;\n } else if (this._overflowMenu !== null) {\n // Remove submenus from overflow menu\n let overflowMenuItems = this._overflowMenu.items;\n let screenSize = this.node.offsetWidth;\n let n = this._overflowMenu.items.length;\n for (let i = 0; i < n; ++i) {\n let index = menus.length - 1 - i;\n if (screenSize - totalMenuSize > this._menuItemSizes[index]) {\n let menu = overflowMenuItems[0].submenu as Menu;\n this._overflowMenu.removeItemAt(0);\n this.insertMenu(length, menu, false);\n content[length] = renderer.renderItem({\n title: menu.title,\n active: false,\n tabbable: length === tabFocusIndex,\n disabled: menus[length].items.length === 0,\n onfocus: () => {\n this._tabFocusIndex = length;\n this.activeIndex = length;\n }\n });\n length++;\n }\n }\n if (this._overflowMenu.items.length === 0) {\n this.removeMenu(this._overflowMenu, false);\n content.pop();\n this._overflowMenu = null;\n this._overflowIndex = -1;\n }\n }\n }\n VirtualDOM.render(content, this.contentNode);\n this._updateOverflowIndex();\n }\n\n /**\n * Calculate and update the current overflow index.\n */\n private _updateOverflowIndex(): void {\n if (!this._overflowMenuOptions.isVisible) {\n return;\n }\n\n // Get elements visible in the main menu bar\n const itemMenus = this.contentNode.childNodes;\n let screenSize = this.node.offsetWidth;\n let totalMenuSize = 0;\n let index = -1;\n let n = itemMenus.length;\n\n if (this._menuItemSizes.length == 0) {\n // Check if it is the first resize and get info about menu items sizes\n for (let i = 0; i < n; i++) {\n let item = itemMenus[i] as HTMLLIElement;\n // Add sizes to array\n totalMenuSize += item.offsetWidth;\n this._menuItemSizes.push(item.offsetWidth);\n if (totalMenuSize > screenSize && index === -1) {\n index = i;\n }\n }\n } else {\n // Calculate current menu size\n for (let i = 0; i < this._menuItemSizes.length; i++) {\n totalMenuSize += this._menuItemSizes[i];\n if (totalMenuSize > screenSize) {\n index = i;\n break;\n }\n }\n }\n this._overflowIndex = index;\n }\n\n /**\n * Handle the `'keydown'` event for the menu bar.\n *\n * #### Notes\n * All keys are trapped except the tab key that is ignored.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // Fetch the key code for the event.\n let kc = event.keyCode;\n\n // Reset the active index on tab, but do not trap the tab key.\n if (kc === 9) {\n this.activeIndex = -1;\n return;\n }\n\n // A menu bar handles all other keydown events.\n event.preventDefault();\n event.stopPropagation();\n\n // Enter, Space, Up Arrow, Down Arrow\n if (kc === 13 || kc === 32 || kc === 38 || kc === 40) {\n // The active index may have changed (for example, user hovers over an\n // item with the mouse), so be sure to use the focus index.\n this.activeIndex = this._tabFocusIndex;\n if (this.activeIndex !== this._tabFocusIndex) {\n // Bail if the setter refused to set activeIndex to tabFocusIndex\n // because it means that the item at tabFocusIndex cannot be opened (for\n // example, it has an empty menu)\n return;\n }\n this.openActiveMenu();\n return;\n }\n\n // Escape\n if (kc === 27) {\n this._closeChildMenu();\n this._focusItemAt(this.activeIndex);\n return;\n }\n\n // Left or Right Arrow\n if (kc === 37 || kc === 39) {\n let direction = kc === 37 ? -1 : 1;\n let start = this._tabFocusIndex + direction;\n let n = this._menus.length;\n for (let i = 0; i < n; i++) {\n let index = (n + start + direction * i) % n;\n if (this._menus[index].items.length) {\n this._focusItemAt(index);\n return;\n }\n }\n return;\n }\n\n // Get the pressed key character.\n let key = getKeyboardLayout().keyForKeydownEvent(event);\n\n // Bail if the key is not valid.\n if (!key) {\n return;\n }\n\n // Search for the next best matching mnemonic item.\n let start = this._activeIndex + 1;\n let result = Private.findMnemonic(this._menus, key, start);\n\n // Handle the requested mnemonic based on the search results.\n // If exactly one mnemonic is matched, that menu is opened.\n // Otherwise, the next mnemonic is activated if available,\n // followed by the auto mnemonic if available.\n if (result.index !== -1 && !result.multiple) {\n this.activeIndex = result.index;\n this.openActiveMenu();\n } else if (result.index !== -1) {\n this.activeIndex = result.index;\n this._focusItemAt(this.activeIndex);\n } else if (result.auto !== -1) {\n this.activeIndex = result.auto;\n this._focusItemAt(this.activeIndex);\n }\n }\n\n /**\n * Handle the `'mousedown'` event for the menu bar.\n */\n private _evtMouseDown(event: MouseEvent): void {\n // Bail if the mouse press was not on the menu bar. This can occur\n // when the document listener is installed for an active menu bar.\n if (!ElementExt.hitTest(this.node, event.clientX, event.clientY)) {\n return;\n }\n\n // Stop the propagation of the event. Immediate propagation is\n // also stopped so that an open menu does not handle the event.\n event.stopPropagation();\n event.stopImmediatePropagation();\n\n // Check if the mouse is over one of the menu items.\n let index = ArrayExt.findFirstIndex(this.contentNode.children, node => {\n return ElementExt.hitTest(node, event.clientX, event.clientY);\n });\n\n // If the press was not on an item, close the child menu.\n if (index === -1) {\n this._closeChildMenu();\n return;\n }\n\n // If the press was not the left mouse button, do nothing further.\n if (event.button !== 0) {\n return;\n }\n\n // Otherwise, toggle the open state of the child menu.\n if (this._childMenu) {\n this._closeChildMenu();\n this.activeIndex = index;\n } else {\n // If we don't call preventDefault() here, then the item in the menu\n // bar will take focus over the menu that is being opened.\n event.preventDefault();\n const position = this._positionForMenu(index);\n Menu.saveWindowData();\n // Begin DOM modifications.\n this.activeIndex = index;\n this._openChildMenu(position);\n }\n }\n\n /**\n * Handle the `'mousemove'` event for the menu bar.\n */\n private _evtMouseMove(event: MouseEvent): void {\n // Check if the mouse is over one of the menu items.\n let index = ArrayExt.findFirstIndex(this.contentNode.children, node => {\n return ElementExt.hitTest(node, event.clientX, event.clientY);\n });\n\n // Bail early if the active index will not change.\n if (index === this._activeIndex) {\n return;\n }\n\n // Bail early if a child menu is open and the mouse is not over\n // an item. This allows the child menu to be kept open when the\n // mouse is over the empty part of the menu bar.\n if (index === -1 && this._childMenu) {\n return;\n }\n\n // Get position for the new menu >before< updating active index.\n const position =\n index >= 0 && this._childMenu ? this._positionForMenu(index) : null;\n\n // Before any modification, update window data.\n Menu.saveWindowData();\n\n // Begin DOM modifications.\n\n // Update the active index to the hovered item.\n this.activeIndex = index;\n\n // Open the new menu if a menu is already open.\n if (position) {\n this._openChildMenu(position);\n }\n }\n\n /**\n * Find initial position for the menu based on menubar item position.\n *\n * NOTE: this should be called before updating active index to avoid\n * an additional layout and style invalidation as changing active\n * index modifies DOM.\n */\n private _positionForMenu(index: number): Private.IPosition {\n let itemNode = this.contentNode.children[index];\n let { left, bottom } = (itemNode as HTMLElement).getBoundingClientRect();\n return {\n top: bottom,\n left\n };\n }\n\n /**\n * Handle the `'focusout'` event for the menu bar.\n */\n private _evtFocusOut(event: FocusEvent): void {\n // Reset the active index if there is no open menu and the menubar is losing focus.\n if (!this._childMenu && !this.node.contains(event.relatedTarget as Node)) {\n this.activeIndex = -1;\n }\n }\n\n /**\n * Focus an item in the menu bar.\n *\n * #### Notes\n * Does not open the associated menu.\n */\n private _focusItemAt(index: number): void {\n const itemNode = this.contentNode.childNodes[index] as HTMLElement | void;\n if (itemNode) {\n itemNode.focus();\n }\n }\n\n /**\n * Open the child menu at the active index immediately.\n *\n * If a different child menu is already open, it will be closed,\n * even if there is no active menu.\n */\n private _openChildMenu(options: { left?: number; top?: number } = {}): void {\n // If there is no active menu, close the current menu.\n let newMenu = this.activeMenu;\n if (!newMenu) {\n this._closeChildMenu();\n return;\n }\n\n // Bail if there is no effective menu change.\n let oldMenu = this._childMenu;\n if (oldMenu === newMenu) {\n return;\n }\n\n // Swap the internal menu reference.\n this._childMenu = newMenu;\n\n // Close the current menu, or setup for the new menu.\n if (oldMenu) {\n oldMenu.close();\n } else {\n document.addEventListener('mousedown', this, true);\n }\n\n // Update the tab focus index and ensure the menu bar is updated.\n this._tabFocusIndex = this.activeIndex;\n MessageLoop.sendMessage(this, Widget.Msg.UpdateRequest);\n\n // Get the positioning data for the new menu.\n let { left, top } = options;\n if (typeof left === 'undefined' || typeof top === 'undefined') {\n ({ left, top } = this._positionForMenu(this._activeIndex));\n }\n // Begin DOM modifications\n\n if (!oldMenu) {\n // Continue setup for new menu\n this.addClass('lm-mod-active');\n }\n\n // Open the new menu at the computed location.\n if (newMenu.items.length > 0) {\n newMenu.open(left, top, this._forceItemsPosition);\n }\n }\n\n /**\n * Close the child menu immediately.\n *\n * This is a no-op if a child menu is not open.\n */\n private _closeChildMenu(): void {\n // Bail if no child menu is open.\n if (!this._childMenu) {\n return;\n }\n // Remove the active class from the menu bar.\n this.removeClass('lm-mod-active');\n\n // Remove the document listeners.\n document.removeEventListener('mousedown', this, true);\n\n // Clear the internal menu reference.\n let menu = this._childMenu;\n this._childMenu = null;\n\n // Close the menu.\n menu.close();\n\n // Reset the active index.\n this.activeIndex = -1;\n }\n\n /**\n * Handle the `aboutToClose` signal of a menu.\n */\n private _onMenuAboutToClose(sender: Menu): void {\n // Bail if the sender is not the child menu.\n if (sender !== this._childMenu) {\n return;\n }\n\n // Remove the active class from the menu bar.\n this.removeClass('lm-mod-active');\n\n // Remove the document listeners.\n document.removeEventListener('mousedown', this, true);\n\n // Clear the internal menu reference.\n this._childMenu = null;\n\n // Reset the active index.\n this.activeIndex = -1;\n }\n\n /**\n * Handle the `menuRequested` signal of a child menu.\n */\n private _onMenuMenuRequested(sender: Menu, args: 'next' | 'previous'): void {\n // Bail if the sender is not the child menu.\n if (sender !== this._childMenu) {\n return;\n }\n\n // Look up the active index and menu count.\n let i = this._activeIndex;\n let n = this._menus.length;\n\n // Active the next requested index.\n switch (args) {\n case 'next':\n this.activeIndex = i === n - 1 ? 0 : i + 1;\n break;\n case 'previous':\n this.activeIndex = i === 0 ? n - 1 : i - 1;\n break;\n }\n\n // Open the active menu.\n this.openActiveMenu();\n }\n\n /**\n * Handle the `changed` signal of a title object.\n */\n private _onTitleChanged(): void {\n this.update();\n }\n\n // Track the index of the item that is currently focused or hovered. -1 means nothing focused or hovered.\n private _activeIndex = -1;\n // Track which item can be focused using the TAB key. Unlike _activeIndex will\n // always point to a menuitem. Whenever you update this value, it's important\n // to follow it with an \"update-request\" message so that the `tabindex`\n // attribute on each menubar item gets properly updated.\n private _tabFocusIndex = 0;\n private _forceItemsPosition: Menu.IOpenOptions;\n private _overflowMenuOptions: IOverflowMenuOptions;\n private _menus: Menu[] = [];\n private _childMenu: Menu | null = null;\n private _overflowMenu: Menu | null = null;\n private _menuItemSizes: number[] = [];\n private _overflowIndex: number = -1;\n}\n\n/**\n * The namespace for the `MenuBar` class statics.\n */\nexport namespace MenuBar {\n /**\n * An options object for creating a menu bar.\n */\n export interface IOptions {\n /**\n * A custom renderer for creating menu bar content.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n /**\n * Whether to force the position of the menu. The MenuBar forces the\n * coordinates of its menus by default. With this option you can disable it.\n *\n * Setting to `false` will enable the logic which repositions the\n * coordinates of the menu if it will not fit entirely on screen.\n *\n * The default is `true`.\n */\n forceItemsPosition?: Menu.IOpenOptions;\n /**\n * Whether to add a overflow menu if there's overflow.\n *\n * Setting to `true` will enable the logic that creates an overflow menu\n * to show the menu items that don't fit entirely on the screen.\n *\n * The default is `true`.\n */\n overflowMenuOptions?: IOverflowMenuOptions;\n }\n\n /**\n * An object which holds the data to render a menu bar item.\n */\n export interface IRenderData {\n /**\n * The title to be rendered.\n */\n readonly title: Title;\n\n /**\n * Whether the item is the active item.\n */\n readonly active: boolean;\n\n /**\n * Whether the user can tab to the item.\n */\n readonly tabbable: boolean;\n\n /**\n * Whether the item is disabled.\n *\n * #### Notes\n * A disabled item cannot be active.\n * A disabled item cannot be focussed.\n */\n readonly disabled?: boolean;\n\n readonly onfocus?: (event: FocusEvent) => void;\n }\n\n /**\n * A renderer for use with a menu bar.\n */\n export interface IRenderer {\n /**\n * Render the virtual element for a menu bar item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n */\n renderItem(data: IRenderData): VirtualElement;\n }\n\n /**\n * The default implementation of `IRenderer`.\n *\n * #### Notes\n * Subclasses are free to reimplement rendering methods as needed.\n */\n export class Renderer implements IRenderer {\n /**\n * Render the virtual element for a menu bar item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n */\n renderItem(data: IRenderData): VirtualElement {\n let className = this.createItemClass(data);\n let dataset = this.createItemDataset(data);\n let aria = this.createItemARIA(data);\n return h.li(\n {\n className,\n dataset,\n ...(data.disabled ? {} : { tabindex: data.tabbable ? '0' : '-1' }),\n onfocus: data.onfocus,\n ...aria\n },\n this.renderIcon(data),\n this.renderLabel(data)\n );\n }\n\n /**\n * Render the icon element for a menu bar item.\n *\n * @param data - The data to use for rendering the icon.\n *\n * @returns A virtual element representing the item icon.\n */\n renderIcon(data: IRenderData): VirtualElement {\n let className = this.createIconClass(data);\n\n // If data.title.icon is undefined, it will be ignored.\n return h.div({ className }, data.title.icon!, data.title.iconLabel);\n }\n\n /**\n * Render the label element for a menu item.\n *\n * @param data - The data to use for rendering the label.\n *\n * @returns A virtual element representing the item label.\n */\n renderLabel(data: IRenderData): VirtualElement {\n let content = this.formatLabel(data);\n return h.div({ className: 'lm-MenuBar-itemLabel' }, content);\n }\n\n /**\n * Create the class name for the menu bar item.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the menu item.\n */\n createItemClass(data: IRenderData): string {\n let name = 'lm-MenuBar-item';\n if (data.title.className) {\n name += ` ${data.title.className}`;\n }\n if (data.active && !data.disabled) {\n name += ' lm-mod-active';\n }\n return name;\n }\n\n /**\n * Create the dataset for a menu bar item.\n *\n * @param data - The data to use for the item.\n *\n * @returns The dataset for the menu bar item.\n */\n createItemDataset(data: IRenderData): ElementDataset {\n return data.title.dataset;\n }\n\n /**\n * Create the aria attributes for menu bar item.\n *\n * @param data - The data to use for the aria attributes.\n *\n * @returns The aria attributes object for the item.\n */\n createItemARIA(data: IRenderData): ElementARIAAttrs {\n return {\n role: 'menuitem',\n 'aria-haspopup': 'true',\n 'aria-disabled': data.disabled ? 'true' : 'false'\n };\n }\n\n /**\n * Create the class name for the menu bar item icon.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the item icon.\n */\n createIconClass(data: IRenderData): string {\n let name = 'lm-MenuBar-itemIcon';\n let extra = data.title.iconClass;\n return extra ? `${name} ${extra}` : name;\n }\n\n /**\n * Create the render content for the label node.\n *\n * @param data - The data to use for the label content.\n *\n * @returns The content to add to the label node.\n */\n formatLabel(data: IRenderData): h.Child {\n // Fetch the label text and mnemonic index.\n let { label, mnemonic } = data.title;\n\n // If the index is out of range, do not modify the label.\n if (mnemonic < 0 || mnemonic >= label.length) {\n return label;\n }\n\n // Split the label into parts.\n let prefix = label.slice(0, mnemonic);\n let suffix = label.slice(mnemonic + 1);\n let char = label[mnemonic];\n\n // Wrap the mnemonic character in a span.\n let span = h.span({ className: 'lm-MenuBar-itemMnemonic' }, char);\n\n // Return the content parts.\n return [prefix, span, suffix];\n }\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n}\n\n/**\n * Options for overflow menu.\n */\nexport interface IOverflowMenuOptions {\n /**\n * Determines if a overflow menu appears when the menu items overflow.\n *\n * Defaults to `true`.\n */\n isVisible: boolean;\n /**\n * Determines the title of the overflow menu.\n *\n * Default: `...`.\n */\n title?: string;\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Create the DOM node for a menu bar.\n */\n export function createNode(): HTMLDivElement {\n let node = document.createElement('div');\n let content = document.createElement('ul');\n content.className = 'lm-MenuBar-content';\n node.appendChild(content);\n content.setAttribute('role', 'menubar');\n return node;\n }\n\n /**\n * Position for the menu relative to top-left screen corner.\n */\n export interface IPosition {\n /**\n * Pixels right from screen origin.\n */\n left: number;\n /**\n * Pixels down from screen origin.\n */\n top: number;\n }\n\n /**\n * The results of a mnemonic search.\n */\n export interface IMnemonicResult {\n /**\n * The index of the first matching mnemonic item, or `-1`.\n */\n index: number;\n\n /**\n * Whether multiple mnemonic items matched.\n */\n multiple: boolean;\n\n /**\n * The index of the first auto matched non-mnemonic item.\n */\n auto: number;\n }\n\n /**\n * Find the best matching mnemonic item.\n *\n * The search starts at the given index and wraps around.\n */\n export function findMnemonic(\n menus: ReadonlyArray,\n key: string,\n start: number\n ): IMnemonicResult {\n // Setup the result variables.\n let index = -1;\n let auto = -1;\n let multiple = false;\n\n // Normalize the key to upper case.\n let upperKey = key.toUpperCase();\n\n // Search the items from the given start index.\n for (let i = 0, n = menus.length; i < n; ++i) {\n // Compute the wrapped index.\n let k = (i + start) % n;\n\n // Look up the menu title.\n let title = menus[k].title;\n\n // Ignore titles with an empty label.\n if (title.label.length === 0) {\n continue;\n }\n\n // Look up the mnemonic index for the label.\n let mn = title.mnemonic;\n\n // Handle a valid mnemonic index.\n if (mn >= 0 && mn < title.label.length) {\n if (title.label[mn].toUpperCase() === upperKey) {\n if (index === -1) {\n index = k;\n } else {\n multiple = true;\n }\n }\n continue;\n }\n\n // Finally, handle the auto index if possible.\n if (auto === -1 && title.label[0].toUpperCase() === upperKey) {\n auto = k;\n }\n }\n\n // Return the search results.\n return { index, multiple, auto };\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Drag } from '@lumino/dragdrop';\n\nimport { Message } from '@lumino/messaging';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { Widget } from './widget';\n\n/**\n * A widget which implements a canonical scroll bar.\n */\nexport class ScrollBar extends Widget {\n /**\n * Construct a new scroll bar.\n *\n * @param options - The options for initializing the scroll bar.\n */\n constructor(options: ScrollBar.IOptions = {}) {\n super({ node: Private.createNode() });\n this.addClass('lm-ScrollBar');\n this.setFlag(Widget.Flag.DisallowLayout);\n\n // Set the orientation.\n this._orientation = options.orientation || 'vertical';\n this.dataset['orientation'] = this._orientation;\n\n // Parse the rest of the options.\n if (options.maximum !== undefined) {\n this._maximum = Math.max(0, options.maximum);\n }\n if (options.page !== undefined) {\n this._page = Math.max(0, options.page);\n }\n if (options.value !== undefined) {\n this._value = Math.max(0, Math.min(options.value, this._maximum));\n }\n }\n\n /**\n * A signal emitted when the user moves the scroll thumb.\n *\n * #### Notes\n * The payload is the current value of the scroll bar.\n */\n get thumbMoved(): ISignal {\n return this._thumbMoved;\n }\n\n /**\n * A signal emitted when the user clicks a step button.\n *\n * #### Notes\n * The payload is whether a decrease or increase is requested.\n */\n get stepRequested(): ISignal {\n return this._stepRequested;\n }\n\n /**\n * A signal emitted when the user clicks the scroll track.\n *\n * #### Notes\n * The payload is whether a decrease or increase is requested.\n */\n get pageRequested(): ISignal {\n return this._pageRequested;\n }\n\n /**\n * Get the orientation of the scroll bar.\n */\n get orientation(): ScrollBar.Orientation {\n return this._orientation;\n }\n\n /**\n * Set the orientation of the scroll bar.\n */\n set orientation(value: ScrollBar.Orientation) {\n // Do nothing if the orientation does not change.\n if (this._orientation === value) {\n return;\n }\n\n // Release the mouse before making changes.\n this._releaseMouse();\n\n // Update the internal orientation.\n this._orientation = value;\n this.dataset['orientation'] = value;\n\n // Schedule an update the scroll bar.\n this.update();\n }\n\n /**\n * Get the current value of the scroll bar.\n */\n get value(): number {\n return this._value;\n }\n\n /**\n * Set the current value of the scroll bar.\n *\n * #### Notes\n * The value will be clamped to the range `[0, maximum]`.\n */\n set value(value: number) {\n // Clamp the value to the allowable range.\n value = Math.max(0, Math.min(value, this._maximum));\n\n // Do nothing if the value does not change.\n if (this._value === value) {\n return;\n }\n\n // Update the internal value.\n this._value = value;\n\n // Schedule an update the scroll bar.\n this.update();\n }\n\n /**\n * Get the page size of the scroll bar.\n *\n * #### Notes\n * The page size is the amount of visible content in the scrolled\n * region, expressed in data units. It determines the size of the\n * scroll bar thumb.\n */\n get page(): number {\n return this._page;\n }\n\n /**\n * Set the page size of the scroll bar.\n *\n * #### Notes\n * The page size will be clamped to the range `[0, Infinity]`.\n */\n set page(value: number) {\n // Clamp the page size to the allowable range.\n value = Math.max(0, value);\n\n // Do nothing if the value does not change.\n if (this._page === value) {\n return;\n }\n\n // Update the internal page size.\n this._page = value;\n\n // Schedule an update the scroll bar.\n this.update();\n }\n\n /**\n * Get the maximum value of the scroll bar.\n */\n get maximum(): number {\n return this._maximum;\n }\n\n /**\n * Set the maximum value of the scroll bar.\n *\n * #### Notes\n * The max size will be clamped to the range `[0, Infinity]`.\n */\n set maximum(value: number) {\n // Clamp the value to the allowable range.\n value = Math.max(0, value);\n\n // Do nothing if the value does not change.\n if (this._maximum === value) {\n return;\n }\n\n // Update the internal values.\n this._maximum = value;\n\n // Clamp the current value to the new range.\n this._value = Math.min(this._value, value);\n\n // Schedule an update the scroll bar.\n this.update();\n }\n\n /**\n * The scroll bar decrement button node.\n *\n * #### Notes\n * Modifying this node directly can lead to undefined behavior.\n */\n get decrementNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-ScrollBar-button'\n )[0] as HTMLDivElement;\n }\n\n /**\n * The scroll bar increment button node.\n *\n * #### Notes\n * Modifying this node directly can lead to undefined behavior.\n */\n get incrementNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-ScrollBar-button'\n )[1] as HTMLDivElement;\n }\n\n /**\n * The scroll bar track node.\n *\n * #### Notes\n * Modifying this node directly can lead to undefined behavior.\n */\n get trackNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-ScrollBar-track'\n )[0] as HTMLDivElement;\n }\n\n /**\n * The scroll bar thumb node.\n *\n * #### Notes\n * Modifying this node directly can lead to undefined behavior.\n */\n get thumbNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-ScrollBar-thumb'\n )[0] as HTMLDivElement;\n }\n\n /**\n * Handle the DOM events for the scroll bar.\n *\n * @param event - The DOM event sent to the scroll bar.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the scroll bar's DOM node.\n *\n * This should not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'mousedown':\n this._evtMouseDown(event as MouseEvent);\n break;\n case 'mousemove':\n this._evtMouseMove(event as MouseEvent);\n break;\n case 'mouseup':\n this._evtMouseUp(event as MouseEvent);\n break;\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A method invoked on a 'before-attach' message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('mousedown', this);\n this.update();\n }\n\n /**\n * A method invoked on an 'after-detach' message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('mousedown', this);\n this._releaseMouse();\n }\n\n /**\n * A method invoked on an 'update-request' message.\n */\n protected onUpdateRequest(msg: Message): void {\n // Convert the value and page into percentages.\n let value = (this._value * 100) / this._maximum;\n let page = (this._page * 100) / (this._page + this._maximum);\n\n // Clamp the value and page to the relevant range.\n value = Math.max(0, Math.min(value, 100));\n page = Math.max(0, Math.min(page, 100));\n\n // Fetch the thumb style.\n let thumbStyle = this.thumbNode.style;\n\n // Update the thumb style for the current orientation.\n if (this._orientation === 'horizontal') {\n thumbStyle.top = '';\n thumbStyle.height = '';\n thumbStyle.left = `${value}%`;\n thumbStyle.width = `${page}%`;\n thumbStyle.transform = `translate(${-value}%, 0%)`;\n } else {\n thumbStyle.left = '';\n thumbStyle.width = '';\n thumbStyle.top = `${value}%`;\n thumbStyle.height = `${page}%`;\n thumbStyle.transform = `translate(0%, ${-value}%)`;\n }\n }\n\n /**\n * Handle the `'keydown'` event for the scroll bar.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // Stop all input events during drag.\n event.preventDefault();\n event.stopPropagation();\n\n // Ignore anything except the `Escape` key.\n if (event.keyCode !== 27) {\n return;\n }\n\n // Fetch the previous scroll value.\n let value = this._pressData ? this._pressData.value : -1;\n\n // Release the mouse.\n this._releaseMouse();\n\n // Restore the old scroll value if possible.\n if (value !== -1) {\n this._moveThumb(value);\n }\n }\n\n /**\n * Handle the `'mousedown'` event for the scroll bar.\n */\n private _evtMouseDown(event: MouseEvent): void {\n // Do nothing if it's not a left mouse press.\n if (event.button !== 0) {\n return;\n }\n\n // Send an activate request to the scroll bar. This can be\n // used by message hooks to activate something relevant.\n this.activate();\n\n // Do nothing if the mouse is already captured.\n if (this._pressData) {\n return;\n }\n\n // Find the pressed scroll bar part.\n let part = Private.findPart(this, event.target as HTMLElement);\n\n // Do nothing if the part is not of interest.\n if (!part) {\n return;\n }\n\n // Stop the event propagation.\n event.preventDefault();\n event.stopPropagation();\n\n // Override the mouse cursor.\n let override = Drag.overrideCursor('default');\n\n // Set up the press data.\n this._pressData = {\n part,\n override,\n delta: -1,\n value: -1,\n mouseX: event.clientX,\n mouseY: event.clientY\n };\n\n // Add the extra event listeners.\n document.addEventListener('mousemove', this, true);\n document.addEventListener('mouseup', this, true);\n document.addEventListener('keydown', this, true);\n document.addEventListener('contextmenu', this, true);\n\n // Handle a thumb press.\n if (part === 'thumb') {\n // Fetch the thumb node.\n let thumbNode = this.thumbNode;\n\n // Fetch the client rect for the thumb.\n let thumbRect = thumbNode.getBoundingClientRect();\n\n // Update the press data delta for the current orientation.\n if (this._orientation === 'horizontal') {\n this._pressData.delta = event.clientX - thumbRect.left;\n } else {\n this._pressData.delta = event.clientY - thumbRect.top;\n }\n\n // Add the active class to the thumb node.\n thumbNode.classList.add('lm-mod-active');\n\n // Store the current value in the press data.\n this._pressData.value = this._value;\n\n // Finished.\n return;\n }\n\n // Handle a track press.\n if (part === 'track') {\n // Fetch the client rect for the thumb.\n let thumbRect = this.thumbNode.getBoundingClientRect();\n\n // Determine the direction for the page request.\n let dir: 'decrement' | 'increment';\n if (this._orientation === 'horizontal') {\n dir = event.clientX < thumbRect.left ? 'decrement' : 'increment';\n } else {\n dir = event.clientY < thumbRect.top ? 'decrement' : 'increment';\n }\n\n // Start the repeat timer.\n this._repeatTimer = window.setTimeout(this._onRepeat, 350);\n\n // Emit the page requested signal.\n this._pageRequested.emit(dir);\n\n // Finished.\n return;\n }\n\n // Handle a decrement button press.\n if (part === 'decrement') {\n // Add the active class to the decrement node.\n this.decrementNode.classList.add('lm-mod-active');\n\n // Start the repeat timer.\n this._repeatTimer = window.setTimeout(this._onRepeat, 350);\n\n // Emit the step requested signal.\n this._stepRequested.emit('decrement');\n\n // Finished.\n return;\n }\n\n // Handle an increment button press.\n if (part === 'increment') {\n // Add the active class to the increment node.\n this.incrementNode.classList.add('lm-mod-active');\n\n // Start the repeat timer.\n this._repeatTimer = window.setTimeout(this._onRepeat, 350);\n\n // Emit the step requested signal.\n this._stepRequested.emit('increment');\n\n // Finished.\n return;\n }\n }\n\n /**\n * Handle the `'mousemove'` event for the scroll bar.\n */\n private _evtMouseMove(event: MouseEvent): void {\n // Do nothing if no drag is in progress.\n if (!this._pressData) {\n return;\n }\n\n // Stop the event propagation.\n event.preventDefault();\n event.stopPropagation();\n\n // Update the mouse position.\n this._pressData.mouseX = event.clientX;\n this._pressData.mouseY = event.clientY;\n\n // Bail if the thumb is not being dragged.\n if (this._pressData.part !== 'thumb') {\n return;\n }\n\n // Get the client rect for the thumb and track.\n let thumbRect = this.thumbNode.getBoundingClientRect();\n let trackRect = this.trackNode.getBoundingClientRect();\n\n // Fetch the scroll geometry based on the orientation.\n let trackPos: number;\n let trackSpan: number;\n if (this._orientation === 'horizontal') {\n trackPos = event.clientX - trackRect.left - this._pressData.delta;\n trackSpan = trackRect.width - thumbRect.width;\n } else {\n trackPos = event.clientY - trackRect.top - this._pressData.delta;\n trackSpan = trackRect.height - thumbRect.height;\n }\n\n // Compute the desired value from the scroll geometry.\n let value = trackSpan === 0 ? 0 : (trackPos * this._maximum) / trackSpan;\n\n // Move the thumb to the computed value.\n this._moveThumb(value);\n }\n\n /**\n * Handle the `'mouseup'` event for the scroll bar.\n */\n private _evtMouseUp(event: MouseEvent): void {\n // Do nothing if it's not a left mouse release.\n if (event.button !== 0) {\n return;\n }\n\n // Stop the event propagation.\n event.preventDefault();\n event.stopPropagation();\n\n // Release the mouse.\n this._releaseMouse();\n }\n\n /**\n * Release the mouse and restore the node states.\n */\n private _releaseMouse(): void {\n // Bail if there is no press data.\n if (!this._pressData) {\n return;\n }\n\n // Clear the repeat timer.\n clearTimeout(this._repeatTimer);\n this._repeatTimer = -1;\n\n // Clear the press data.\n this._pressData.override.dispose();\n this._pressData = null;\n\n // Remove the extra event listeners.\n document.removeEventListener('mousemove', this, true);\n document.removeEventListener('mouseup', this, true);\n document.removeEventListener('keydown', this, true);\n document.removeEventListener('contextmenu', this, true);\n\n // Remove the active classes from the nodes.\n this.thumbNode.classList.remove('lm-mod-active');\n this.decrementNode.classList.remove('lm-mod-active');\n this.incrementNode.classList.remove('lm-mod-active');\n }\n\n /**\n * Move the thumb to the specified position.\n */\n private _moveThumb(value: number): void {\n // Clamp the value to the allowed range.\n value = Math.max(0, Math.min(value, this._maximum));\n\n // Bail if the value does not change.\n if (this._value === value) {\n return;\n }\n\n // Update the internal value.\n this._value = value;\n\n // Schedule an update of the scroll bar.\n this.update();\n\n // Emit the thumb moved signal.\n this._thumbMoved.emit(value);\n }\n\n /**\n * A timeout callback for repeating the mouse press.\n */\n private _onRepeat = () => {\n // Clear the repeat timer id.\n this._repeatTimer = -1;\n\n // Bail if the mouse has been released.\n if (!this._pressData) {\n return;\n }\n\n // Look up the part that was pressed.\n let part = this._pressData.part;\n\n // Bail if the thumb was pressed.\n if (part === 'thumb') {\n return;\n }\n\n // Schedule the timer for another repeat.\n this._repeatTimer = window.setTimeout(this._onRepeat, 20);\n\n // Get the current mouse position.\n let mouseX = this._pressData.mouseX;\n let mouseY = this._pressData.mouseY;\n\n // Handle a decrement button repeat.\n if (part === 'decrement') {\n // Bail if the mouse is not over the button.\n if (!ElementExt.hitTest(this.decrementNode, mouseX, mouseY)) {\n return;\n }\n\n // Emit the step requested signal.\n this._stepRequested.emit('decrement');\n\n // Finished.\n return;\n }\n\n // Handle an increment button repeat.\n if (part === 'increment') {\n // Bail if the mouse is not over the button.\n if (!ElementExt.hitTest(this.incrementNode, mouseX, mouseY)) {\n return;\n }\n\n // Emit the step requested signal.\n this._stepRequested.emit('increment');\n\n // Finished.\n return;\n }\n\n // Handle a track repeat.\n if (part === 'track') {\n // Bail if the mouse is not over the track.\n if (!ElementExt.hitTest(this.trackNode, mouseX, mouseY)) {\n return;\n }\n\n // Fetch the thumb node.\n let thumbNode = this.thumbNode;\n\n // Bail if the mouse is over the thumb.\n if (ElementExt.hitTest(thumbNode, mouseX, mouseY)) {\n return;\n }\n\n // Fetch the client rect for the thumb.\n let thumbRect = thumbNode.getBoundingClientRect();\n\n // Determine the direction for the page request.\n let dir: 'decrement' | 'increment';\n if (this._orientation === 'horizontal') {\n dir = mouseX < thumbRect.left ? 'decrement' : 'increment';\n } else {\n dir = mouseY < thumbRect.top ? 'decrement' : 'increment';\n }\n\n // Emit the page requested signal.\n this._pageRequested.emit(dir);\n\n // Finished.\n return;\n }\n };\n\n private _value = 0;\n private _page = 10;\n private _maximum = 100;\n private _repeatTimer = -1;\n private _orientation: ScrollBar.Orientation;\n private _pressData: Private.IPressData | null = null;\n private _thumbMoved = new Signal(this);\n private _stepRequested = new Signal(this);\n private _pageRequested = new Signal(this);\n}\n\n/**\n * The namespace for the `ScrollBar` class statics.\n */\nexport namespace ScrollBar {\n /**\n * A type alias for a scroll bar orientation.\n */\n export type Orientation = 'horizontal' | 'vertical';\n\n /**\n * An options object for creating a scroll bar.\n */\n export interface IOptions {\n /**\n * The orientation of the scroll bar.\n *\n * The default is `'vertical'`.\n */\n orientation?: Orientation;\n\n /**\n * The value for the scroll bar.\n *\n * The default is `0`.\n */\n value?: number;\n\n /**\n * The page size for the scroll bar.\n *\n * The default is `10`.\n */\n page?: number;\n\n /**\n * The maximum value for the scroll bar.\n *\n * The default is `100`.\n */\n maximum?: number;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * A type alias for the parts of a scroll bar.\n */\n export type ScrollBarPart = 'thumb' | 'track' | 'decrement' | 'increment';\n\n /**\n * An object which holds mouse press data.\n */\n export interface IPressData {\n /**\n * The scroll bar part which was pressed.\n */\n part: ScrollBarPart;\n\n /**\n * The offset of the press in thumb coordinates, or -1.\n */\n delta: number;\n\n /**\n * The scroll value at the time the thumb was pressed, or -1.\n */\n value: number;\n\n /**\n * The disposable which will clear the override cursor.\n */\n override: IDisposable;\n\n /**\n * The current X position of the mouse.\n */\n mouseX: number;\n\n /**\n * The current Y position of the mouse.\n */\n mouseY: number;\n }\n\n /**\n * Create the DOM node for a scroll bar.\n */\n export function createNode(): HTMLElement {\n let node = document.createElement('div');\n let decrement = document.createElement('div');\n let increment = document.createElement('div');\n let track = document.createElement('div');\n let thumb = document.createElement('div');\n decrement.className = 'lm-ScrollBar-button';\n increment.className = 'lm-ScrollBar-button';\n decrement.dataset['action'] = 'decrement';\n increment.dataset['action'] = 'increment';\n track.className = 'lm-ScrollBar-track';\n thumb.className = 'lm-ScrollBar-thumb';\n track.appendChild(thumb);\n node.appendChild(decrement);\n node.appendChild(track);\n node.appendChild(increment);\n return node;\n }\n\n /**\n * Find the scroll bar part which contains the given target.\n */\n export function findPart(\n scrollBar: ScrollBar,\n target: HTMLElement\n ): ScrollBarPart | null {\n // Test the thumb.\n if (scrollBar.thumbNode.contains(target)) {\n return 'thumb';\n }\n\n // Test the track.\n if (scrollBar.trackNode.contains(target)) {\n return 'track';\n }\n\n // Test the decrement button.\n if (scrollBar.decrementNode.contains(target)) {\n return 'decrement';\n }\n\n // Test the increment button.\n if (scrollBar.incrementNode.contains(target)) {\n return 'increment';\n }\n\n // Indicate no match.\n return null;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { Panel } from './panel';\n\nimport { StackedLayout } from './stackedlayout';\n\nimport { Widget } from './widget';\n\n/**\n * A panel where visible widgets are stacked atop one another.\n *\n * #### Notes\n * This class provides a convenience wrapper around a {@link StackedLayout}.\n */\nexport class StackedPanel extends Panel {\n /**\n * Construct a new stacked panel.\n *\n * @param options - The options for initializing the panel.\n */\n constructor(options: StackedPanel.IOptions = {}) {\n super({ layout: Private.createLayout(options) });\n this.addClass('lm-StackedPanel');\n }\n\n /**\n * The method for hiding widgets.\n *\n * #### Notes\n * If there is only one child widget, `Display` hiding mode will be used\n * regardless of this setting.\n */\n get hiddenMode(): Widget.HiddenMode {\n return (this.layout as StackedLayout).hiddenMode;\n }\n\n /**\n * Set the method for hiding widgets.\n *\n * #### Notes\n * If there is only one child widget, `Display` hiding mode will be used\n * regardless of this setting.\n */\n set hiddenMode(v: Widget.HiddenMode) {\n (this.layout as StackedLayout).hiddenMode = v;\n }\n\n /**\n * A signal emitted when a widget is removed from a stacked panel.\n */\n get widgetRemoved(): ISignal {\n return this._widgetRemoved;\n }\n\n /**\n * A message handler invoked on a `'child-added'` message.\n */\n protected onChildAdded(msg: Widget.ChildMessage): void {\n msg.child.addClass('lm-StackedPanel-child');\n }\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {\n msg.child.removeClass('lm-StackedPanel-child');\n this._widgetRemoved.emit(msg.child);\n }\n\n private _widgetRemoved = new Signal(this);\n}\n\n/**\n * The namespace for the `StackedPanel` class statics.\n */\nexport namespace StackedPanel {\n /**\n * An options object for creating a stacked panel.\n */\n export interface IOptions {\n /**\n * The stacked layout to use for the stacked panel.\n *\n * The default is a new `StackedLayout`.\n */\n layout?: StackedLayout;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Create a stacked layout for the given panel options.\n */\n export function createLayout(options: StackedPanel.IOptions): StackedLayout {\n return options.layout || new StackedLayout();\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { Platform } from '@lumino/domutils';\n\nimport { MessageLoop } from '@lumino/messaging';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { BoxLayout } from './boxlayout';\n\nimport { StackedPanel } from './stackedpanel';\n\nimport { TabBar } from './tabbar';\n\nimport { Widget } from './widget';\n\n/**\n * A widget which combines a `TabBar` and a `StackedPanel`.\n *\n * #### Notes\n * This is a simple panel which handles the common case of a tab bar\n * placed next to a content area. The selected tab controls the widget\n * which is shown in the content area.\n *\n * For use cases which require more control than is provided by this\n * panel, the `TabBar` widget may be used independently.\n */\nexport class TabPanel extends Widget {\n /**\n * Construct a new tab panel.\n *\n * @param options - The options for initializing the tab panel.\n */\n constructor(options: TabPanel.IOptions = {}) {\n super();\n this.addClass('lm-TabPanel');\n\n // Create the tab bar and stacked panel.\n this.tabBar = new TabBar(options);\n this.tabBar.addClass('lm-TabPanel-tabBar');\n this.stackedPanel = new StackedPanel();\n this.stackedPanel.addClass('lm-TabPanel-stackedPanel');\n\n // Connect the tab bar signal handlers.\n this.tabBar.tabMoved.connect(this._onTabMoved, this);\n this.tabBar.currentChanged.connect(this._onCurrentChanged, this);\n this.tabBar.tabCloseRequested.connect(this._onTabCloseRequested, this);\n this.tabBar.tabActivateRequested.connect(\n this._onTabActivateRequested,\n this\n );\n this.tabBar.addRequested.connect(this._onTabAddRequested, this);\n\n // Connect the stacked panel signal handlers.\n this.stackedPanel.widgetRemoved.connect(this._onWidgetRemoved, this);\n\n // Get the data related to the placement.\n this._tabPlacement = options.tabPlacement || 'top';\n let direction = Private.directionFromPlacement(this._tabPlacement);\n let orientation = Private.orientationFromPlacement(this._tabPlacement);\n\n // Configure the tab bar for the placement.\n this.tabBar.orientation = orientation;\n this.tabBar.dataset['placement'] = this._tabPlacement;\n\n // Create the box layout.\n let layout = new BoxLayout({ direction, spacing: 0 });\n\n // Set the stretch factors for the child widgets.\n BoxLayout.setStretch(this.tabBar, 0);\n BoxLayout.setStretch(this.stackedPanel, 1);\n\n // Add the child widgets to the layout.\n layout.addWidget(this.tabBar);\n layout.addWidget(this.stackedPanel);\n\n // Install the layout on the tab panel.\n this.layout = layout;\n }\n\n /**\n * A signal emitted when the current tab is changed.\n *\n * #### Notes\n * This signal is emitted when the currently selected tab is changed\n * either through user or programmatic interaction.\n *\n * Notably, this signal is not emitted when the index of the current\n * tab changes due to tabs being inserted, removed, or moved. It is\n * only emitted when the actual current tab node is changed.\n */\n get currentChanged(): ISignal {\n return this._currentChanged;\n }\n\n /**\n * Get the index of the currently selected tab.\n *\n * #### Notes\n * This will be `-1` if no tab is selected.\n */\n get currentIndex(): number {\n return this.tabBar.currentIndex;\n }\n\n /**\n * Set the index of the currently selected tab.\n *\n * #### Notes\n * If the index is out of range, it will be set to `-1`.\n */\n set currentIndex(value: number) {\n this.tabBar.currentIndex = value;\n }\n\n /**\n * Get the currently selected widget.\n *\n * #### Notes\n * This will be `null` if there is no selected tab.\n */\n get currentWidget(): Widget | null {\n let title = this.tabBar.currentTitle;\n return title ? title.owner : null;\n }\n\n /**\n * Set the currently selected widget.\n *\n * #### Notes\n * If the widget is not in the panel, it will be set to `null`.\n */\n set currentWidget(value: Widget | null) {\n this.tabBar.currentTitle = value ? value.title : null;\n }\n\n /**\n * Get the whether the tabs are movable by the user.\n *\n * #### Notes\n * Tabs can always be moved programmatically.\n */\n get tabsMovable(): boolean {\n return this.tabBar.tabsMovable;\n }\n\n /**\n * Set the whether the tabs are movable by the user.\n *\n * #### Notes\n * Tabs can always be moved programmatically.\n */\n set tabsMovable(value: boolean) {\n this.tabBar.tabsMovable = value;\n }\n\n /**\n * Get the whether the add button is enabled.\n *\n */\n get addButtonEnabled(): boolean {\n return this.tabBar.addButtonEnabled;\n }\n\n /**\n * Set the whether the add button is enabled.\n *\n */\n set addButtonEnabled(value: boolean) {\n this.tabBar.addButtonEnabled = value;\n }\n\n /**\n * Get the tab placement for the tab panel.\n *\n * #### Notes\n * This controls the position of the tab bar relative to the content.\n */\n get tabPlacement(): TabPanel.TabPlacement {\n return this._tabPlacement;\n }\n\n /**\n * Set the tab placement for the tab panel.\n *\n * #### Notes\n * This controls the position of the tab bar relative to the content.\n */\n set tabPlacement(value: TabPanel.TabPlacement) {\n // Bail if the placement does not change.\n if (this._tabPlacement === value) {\n return;\n }\n\n // Update the internal value.\n this._tabPlacement = value;\n\n // Get the values related to the placement.\n let direction = Private.directionFromPlacement(value);\n let orientation = Private.orientationFromPlacement(value);\n\n // Configure the tab bar for the placement.\n this.tabBar.orientation = orientation;\n this.tabBar.dataset['placement'] = value;\n\n // Update the layout direction.\n (this.layout as BoxLayout).direction = direction;\n }\n\n /**\n * A signal emitted when the add button on a tab bar is clicked.\n *\n */\n get addRequested(): ISignal> {\n return this._addRequested;\n }\n\n /**\n * The tab bar used by the tab panel.\n *\n * #### Notes\n * Modifying the tab bar directly can lead to undefined behavior.\n */\n readonly tabBar: TabBar;\n\n /**\n * The stacked panel used by the tab panel.\n *\n * #### Notes\n * Modifying the panel directly can lead to undefined behavior.\n */\n readonly stackedPanel: StackedPanel;\n\n /**\n * A read-only array of the widgets in the panel.\n */\n get widgets(): ReadonlyArray {\n return this.stackedPanel.widgets;\n }\n\n /**\n * Add a widget to the end of the tab panel.\n *\n * @param widget - The widget to add to the tab panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n *\n * The widget's `title` is used to populate the tab.\n */\n addWidget(widget: Widget): void {\n this.insertWidget(this.widgets.length, widget);\n }\n\n /**\n * Insert a widget into the tab panel at a specified index.\n *\n * @param index - The index at which to insert the widget.\n *\n * @param widget - The widget to insert into to the tab panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n *\n * The widget's `title` is used to populate the tab.\n */\n insertWidget(index: number, widget: Widget): void {\n if (widget !== this.currentWidget) {\n widget.hide();\n }\n this.stackedPanel.insertWidget(index, widget);\n this.tabBar.insertTab(index, widget.title);\n\n widget.node.setAttribute('role', 'tabpanel');\n\n let renderer = this.tabBar.renderer;\n if (renderer instanceof TabBar.Renderer) {\n let tabId = renderer.createTabKey({\n title: widget.title,\n current: false,\n zIndex: 0\n });\n widget.node.setAttribute('aria-labelledby', tabId);\n }\n }\n\n /**\n * Handle the `currentChanged` signal from the tab bar.\n */\n private _onCurrentChanged(\n sender: TabBar,\n args: TabBar.ICurrentChangedArgs\n ): void {\n // Extract the previous and current title from the args.\n let { previousIndex, previousTitle, currentIndex, currentTitle } = args;\n\n // Extract the widgets from the titles.\n let previousWidget = previousTitle ? previousTitle.owner : null;\n let currentWidget = currentTitle ? currentTitle.owner : null;\n\n // Hide the previous widget.\n if (previousWidget) {\n previousWidget.hide();\n }\n\n // Show the current widget.\n if (currentWidget) {\n currentWidget.show();\n }\n\n // Emit the `currentChanged` signal for the tab panel.\n this._currentChanged.emit({\n previousIndex,\n previousWidget,\n currentIndex,\n currentWidget\n });\n\n // Flush the message loop on IE and Edge to prevent flicker.\n if (Platform.IS_EDGE || Platform.IS_IE) {\n MessageLoop.flush();\n }\n }\n\n /**\n * Handle the `tabAddRequested` signal from the tab bar.\n */\n private _onTabAddRequested(sender: TabBar, args: void): void {\n this._addRequested.emit(sender);\n }\n\n /**\n * Handle the `tabActivateRequested` signal from the tab bar.\n */\n private _onTabActivateRequested(\n sender: TabBar,\n args: TabBar.ITabActivateRequestedArgs\n ): void {\n args.title.owner.activate();\n }\n\n /**\n * Handle the `tabCloseRequested` signal from the tab bar.\n */\n private _onTabCloseRequested(\n sender: TabBar,\n args: TabBar.ITabCloseRequestedArgs\n ): void {\n args.title.owner.close();\n }\n\n /**\n * Handle the `tabMoved` signal from the tab bar.\n */\n private _onTabMoved(\n sender: TabBar,\n args: TabBar.ITabMovedArgs\n ): void {\n this.stackedPanel.insertWidget(args.toIndex, args.title.owner);\n }\n\n /**\n * Handle the `widgetRemoved` signal from the stacked panel.\n */\n private _onWidgetRemoved(sender: StackedPanel, widget: Widget): void {\n widget.node.removeAttribute('role');\n widget.node.removeAttribute('aria-labelledby');\n this.tabBar.removeTab(widget.title);\n }\n\n private _tabPlacement: TabPanel.TabPlacement;\n private _currentChanged = new Signal(\n this\n );\n\n private _addRequested = new Signal>(this);\n}\n\n/**\n * The namespace for the `TabPanel` class statics.\n */\nexport namespace TabPanel {\n /**\n * A type alias for tab placement in a tab bar.\n */\n export type TabPlacement =\n | /**\n * The tabs are placed as a row above the content.\n */\n 'top'\n\n /**\n * The tabs are placed as a column to the left of the content.\n */\n | 'left'\n\n /**\n * The tabs are placed as a column to the right of the content.\n */\n | 'right'\n\n /**\n * The tabs are placed as a row below the content.\n */\n | 'bottom';\n\n /**\n * An options object for initializing a tab panel.\n */\n export interface IOptions {\n /**\n * The document to use with the tab panel.\n *\n * The default is the global `document` instance.\n */\n document?: Document | ShadowRoot;\n\n /**\n * Whether the tabs are movable by the user.\n *\n * The default is `false`.\n */\n tabsMovable?: boolean;\n\n /**\n * Whether the button to add new tabs is enabled.\n *\n * The default is `false`.\n */\n addButtonEnabled?: boolean;\n\n /**\n * The placement of the tab bar relative to the content.\n *\n * The default is `'top'`.\n */\n tabPlacement?: TabPlacement;\n\n /**\n * The renderer for the panel's tab bar.\n *\n * The default is a shared renderer instance.\n */\n renderer?: TabBar.IRenderer;\n }\n\n /**\n * The arguments object for the `currentChanged` signal.\n */\n export interface ICurrentChangedArgs {\n /**\n * The previously selected index.\n */\n previousIndex: number;\n\n /**\n * The previously selected widget.\n */\n previousWidget: Widget | null;\n\n /**\n * The currently selected index.\n */\n currentIndex: number;\n\n /**\n * The currently selected widget.\n */\n currentWidget: Widget | null;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Convert a tab placement to tab bar orientation.\n */\n export function orientationFromPlacement(\n plc: TabPanel.TabPlacement\n ): TabBar.Orientation {\n return placementToOrientationMap[plc];\n }\n\n /**\n * Convert a tab placement to a box layout direction.\n */\n export function directionFromPlacement(\n plc: TabPanel.TabPlacement\n ): BoxLayout.Direction {\n return placementToDirectionMap[plc];\n }\n\n /**\n * A mapping of tab placement to tab bar orientation.\n */\n const placementToOrientationMap: { [key: string]: TabBar.Orientation } = {\n top: 'horizontal',\n left: 'vertical',\n right: 'vertical',\n bottom: 'horizontal'\n };\n\n /**\n * A mapping of tab placement to box layout direction.\n */\n const placementToDirectionMap: { [key: string]: BoxLayout.Direction } = {\n top: 'top-to-bottom',\n left: 'left-to-right',\n right: 'right-to-left',\n bottom: 'bottom-to-top'\n };\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { MessageLoop } from '@lumino/messaging';\n\nimport { Layout } from './layout';\n\nimport { Widget } from './widget';\n\n/**\n * A concrete layout implementation which holds a single widget.\n *\n * #### Notes\n * This class is useful for creating simple container widgets which\n * hold a single child. The child should be positioned with CSS.\n */\nexport class SingletonLayout extends Layout {\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n if (this._widget) {\n let widget = this._widget;\n this._widget = null;\n widget.dispose();\n }\n super.dispose();\n }\n\n /**\n * Get the child widget for the layout.\n */\n get widget(): Widget | null {\n return this._widget;\n }\n\n /**\n * Set the child widget for the layout.\n *\n * #### Notes\n * Setting the child widget will cause the old child widget to be\n * automatically disposed. If that is not desired, set the parent\n * of the old child to `null` before assigning a new child.\n */\n set widget(widget: Widget | null) {\n // Remove the widget from its current parent. This is a no-op\n // if the widget's parent is already the layout parent widget.\n if (widget) {\n widget.parent = this.parent;\n }\n\n // Bail early if the widget does not change.\n if (this._widget === widget) {\n return;\n }\n\n // Dispose of the old child widget.\n if (this._widget) {\n this._widget.dispose();\n }\n\n // Update the internal widget.\n this._widget = widget;\n\n // Attach the new child widget if needed.\n if (this.parent && widget) {\n this.attachWidget(widget);\n }\n }\n\n /**\n * Create an iterator over the widgets in the layout.\n *\n * @returns A new iterator over the widgets in the layout.\n */\n *[Symbol.iterator](): IterableIterator {\n if (this._widget) {\n yield this._widget;\n }\n }\n\n /**\n * Remove a widget from the layout.\n *\n * @param widget - The widget to remove from the layout.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method does *not* modify the widget's `parent`.\n */\n removeWidget(widget: Widget): void {\n // Bail early if the widget does not exist in the layout.\n if (this._widget !== widget) {\n return;\n }\n\n // Clear the internal widget.\n this._widget = null;\n\n // If the layout is parented, detach the widget from the DOM.\n if (this.parent) {\n this.detachWidget(widget);\n }\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n super.init();\n for (const widget of this) {\n this.attachWidget(widget);\n }\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This method is called automatically by the single layout at the\n * appropriate time. It should not be called directly by user code.\n *\n * The default implementation adds the widgets's node to the parent's\n * node at the proper location, and sends the appropriate attach\n * messages to the widget if the parent is attached to the DOM.\n *\n * Subclasses may reimplement this method to control how the widget's\n * node is added to the parent's node.\n */\n protected attachWidget(widget: Widget): void {\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget's node to the parent.\n this.parent!.node.appendChild(widget.node);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This method is called automatically by the single layout at the\n * appropriate time. It should not be called directly by user code.\n *\n * The default implementation removes the widget's node from the\n * parent's node, and sends the appropriate detach messages to the\n * widget if the parent is attached to the DOM.\n *\n * Subclasses may reimplement this method to control how the widget's\n * node is removed from the parent's node.\n */\n protected detachWidget(widget: Widget): void {\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n }\n\n private _widget: Widget | null = null;\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { Layout, LayoutItem } from './layout';\n\nimport { PanelLayout } from './panellayout';\n\nimport { Widget } from './widget';\n\n/**\n * A layout where visible widgets are stacked atop one another.\n *\n * #### Notes\n * The Z-order of the visible widgets follows their layout order.\n */\nexport class StackedLayout extends PanelLayout {\n constructor(options: StackedLayout.IOptions = {}) {\n super(options);\n this._hiddenMode =\n options.hiddenMode !== undefined\n ? options.hiddenMode\n : Widget.HiddenMode.Display;\n }\n\n /**\n * The method for hiding widgets.\n *\n * #### Notes\n * If there is only one child widget, `Display` hiding mode will be used\n * regardless of this setting.\n */\n get hiddenMode(): Widget.HiddenMode {\n return this._hiddenMode;\n }\n\n /**\n * Set the method for hiding widgets.\n *\n * #### Notes\n * If there is only one child widget, `Display` hiding mode will be used\n * regardless of this setting.\n */\n set hiddenMode(v: Widget.HiddenMode) {\n if (this._hiddenMode === v) {\n return;\n }\n this._hiddenMode = v;\n if (this.widgets.length > 1) {\n this.widgets.forEach(w => {\n w.hiddenMode = this._hiddenMode;\n });\n }\n }\n\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n // Dispose of the layout items.\n for (const item of this._items) {\n item.dispose();\n }\n\n // Clear the layout state.\n this._box = null;\n this._items.length = 0;\n\n // Dispose of the rest of the layout.\n super.dispose();\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param index - The current index of the widget in the layout.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected attachWidget(index: number, widget: Widget): void {\n // Using transform create an additional layer in the pixel pipeline\n // to limit the number of layer, it is set only if there is more than one widget.\n if (\n this._hiddenMode === Widget.HiddenMode.Scale &&\n this._items.length > 0\n ) {\n if (this._items.length === 1) {\n this.widgets[0].hiddenMode = Widget.HiddenMode.Scale;\n }\n widget.hiddenMode = Widget.HiddenMode.Scale;\n } else {\n widget.hiddenMode = Widget.HiddenMode.Display;\n }\n\n // Create and add a new layout item for the widget.\n ArrayExt.insert(this._items, index, new LayoutItem(widget));\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget's node to the parent.\n this.parent!.node.appendChild(widget.node);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * Move a widget in the parent's DOM node.\n *\n * @param fromIndex - The previous index of the widget in the layout.\n *\n * @param toIndex - The current index of the widget in the layout.\n *\n * @param widget - The widget to move in the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected moveWidget(\n fromIndex: number,\n toIndex: number,\n widget: Widget\n ): void {\n // Move the layout item for the widget.\n ArrayExt.move(this._items, fromIndex, toIndex);\n\n // Post an update request for the parent widget.\n this.parent!.update();\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param index - The previous index of the widget in the layout.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected detachWidget(index: number, widget: Widget): void {\n // Remove the layout item for the widget.\n let item = ArrayExt.removeAt(this._items, index);\n\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Reset the z-index for the widget.\n item!.widget.node.style.zIndex = '';\n\n // Reset the hidden mode for the widget.\n if (this._hiddenMode === Widget.HiddenMode.Scale) {\n widget.hiddenMode = Widget.HiddenMode.Display;\n\n // Reset the hidden mode for the first widget if necessary.\n if (this._items.length === 1) {\n this._items[0].widget.hiddenMode = Widget.HiddenMode.Display;\n }\n }\n\n // Dispose of the layout item.\n item!.dispose();\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n */\n protected onBeforeShow(msg: Message): void {\n super.onBeforeShow(msg);\n this.parent!.update();\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n super.onBeforeAttach(msg);\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n if (this.parent!.isVisible) {\n this._update(msg.width, msg.height);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.parent!.isVisible) {\n this._update(-1, -1);\n }\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n */\n protected onFitRequest(msg: Message): void {\n if (this.parent!.isAttached) {\n this._fit();\n }\n }\n\n /**\n * Fit the layout to the total size required by the widgets.\n */\n private _fit(): void {\n // Set up the computed minimum size.\n let minW = 0;\n let minH = 0;\n\n // Update the computed minimum size.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item.\n let item = this._items[i];\n\n // Ignore hidden items.\n if (item.isHidden) {\n continue;\n }\n\n // Update the size limits for the item.\n item.fit();\n\n // Update the computed minimum size.\n minW = Math.max(minW, item.minWidth);\n minH = Math.max(minH, item.minHeight);\n }\n\n // Update the box sizing and add it to the computed min size.\n let box = (this._box = ElementExt.boxSizing(this.parent!.node));\n minW += box.horizontalSum;\n minH += box.verticalSum;\n\n // Update the parent's min size constraints.\n let style = this.parent!.node.style;\n style.minWidth = `${minW}px`;\n style.minHeight = `${minH}px`;\n\n // Set the dirty flag to ensure only a single update occurs.\n this._dirty = true;\n\n // Notify the ancestor that it should fit immediately. This may\n // cause a resize of the parent, fulfilling the required update.\n if (this.parent!.parent) {\n MessageLoop.sendMessage(this.parent!.parent!, Widget.Msg.FitRequest);\n }\n\n // If the dirty flag is still set, the parent was not resized.\n // Trigger the required update on the parent widget immediately.\n if (this._dirty) {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n }\n }\n\n /**\n * Update the layout position and size of the widgets.\n *\n * The parent offset dimensions should be `-1` if unknown.\n */\n private _update(offsetWidth: number, offsetHeight: number): void {\n // Clear the dirty flag to indicate the update occurred.\n this._dirty = false;\n\n // Compute the visible item count.\n let nVisible = 0;\n for (let i = 0, n = this._items.length; i < n; ++i) {\n nVisible += +!this._items[i].isHidden;\n }\n\n // Bail early if there are no visible items to layout.\n if (nVisible === 0) {\n return;\n }\n\n // Measure the parent if the offset dimensions are unknown.\n if (offsetWidth < 0) {\n offsetWidth = this.parent!.node.offsetWidth;\n }\n if (offsetHeight < 0) {\n offsetHeight = this.parent!.node.offsetHeight;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent!.node);\n }\n\n // Compute the actual layout bounds adjusted for border and padding.\n let top = this._box.paddingTop;\n let left = this._box.paddingLeft;\n let width = offsetWidth - this._box.horizontalSum;\n let height = offsetHeight - this._box.verticalSum;\n\n // Update the widget stacking order and layout geometry.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item.\n let item = this._items[i];\n\n // Ignore hidden items.\n if (item.isHidden) {\n continue;\n }\n\n // Set the z-index for the widget.\n item.widget.node.style.zIndex = `${i}`;\n\n // Update the item geometry.\n item.update(left, top, width, height);\n }\n }\n\n private _dirty = false;\n private _items: LayoutItem[] = [];\n private _box: ElementExt.IBoxSizing | null = null;\n private _hiddenMode: Widget.HiddenMode;\n}\n\n/**\n * The namespace for the `StackedLayout` class statics.\n */\nexport namespace StackedLayout {\n /**\n * An options object for initializing a stacked layout.\n */\n export interface IOptions extends Layout.IOptions {\n /**\n * The method for hiding widgets.\n *\n * The default is `Widget.HiddenMode.Display`.\n */\n hiddenMode?: Widget.HiddenMode;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt, find, max } from '@lumino/algorithm';\n\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { Widget } from './widget';\n\n/**\n * A class which tracks focus among a set of widgets.\n *\n * This class is useful when code needs to keep track of the most\n * recently focused widget(s) among a set of related widgets.\n */\nexport class FocusTracker implements IDisposable {\n /**\n * Dispose of the resources held by the tracker.\n */\n dispose(): void {\n // Do nothing if the tracker is already disposed.\n if (this._counter < 0) {\n return;\n }\n\n // Mark the tracker as disposed.\n this._counter = -1;\n\n // Clear the connections for the tracker.\n Signal.clearData(this);\n\n // Remove all event listeners.\n for (const widget of this._widgets) {\n widget.node.removeEventListener('focus', this, true);\n widget.node.removeEventListener('blur', this, true);\n }\n\n // Clear the internal data structures.\n this._activeWidget = null;\n this._currentWidget = null;\n this._nodes.clear();\n this._numbers.clear();\n this._widgets.length = 0;\n }\n\n /**\n * A signal emitted when the current widget has changed.\n */\n get currentChanged(): ISignal> {\n return this._currentChanged;\n }\n\n /**\n * A signal emitted when the active widget has changed.\n */\n get activeChanged(): ISignal> {\n return this._activeChanged;\n }\n\n /**\n * A flag indicating whether the tracker is disposed.\n */\n get isDisposed(): boolean {\n return this._counter < 0;\n }\n\n /**\n * The current widget in the tracker.\n *\n * #### Notes\n * The current widget is the widget among the tracked widgets which\n * has the *descendant node* which has most recently been focused.\n *\n * The current widget will not be updated if the node loses focus. It\n * will only be updated when a different tracked widget gains focus.\n *\n * If the current widget is removed from the tracker, the previous\n * current widget will be restored.\n *\n * This behavior is intended to follow a user's conceptual model of\n * a semantically \"current\" widget, where the \"last thing of type X\"\n * to be interacted with is the \"current instance of X\", regardless\n * of whether that instance still has focus.\n */\n get currentWidget(): T | null {\n return this._currentWidget;\n }\n\n /**\n * The active widget in the tracker.\n *\n * #### Notes\n * The active widget is the widget among the tracked widgets which\n * has the *descendant node* which is currently focused.\n */\n get activeWidget(): T | null {\n return this._activeWidget;\n }\n\n /**\n * A read only array of the widgets being tracked.\n */\n get widgets(): ReadonlyArray {\n return this._widgets;\n }\n\n /**\n * Get the focus number for a particular widget in the tracker.\n *\n * @param widget - The widget of interest.\n *\n * @returns The focus number for the given widget, or `-1` if the\n * widget has not had focus since being added to the tracker, or\n * is not contained by the tracker.\n *\n * #### Notes\n * The focus number indicates the relative order in which the widgets\n * have gained focus. A widget with a larger number has gained focus\n * more recently than a widget with a smaller number.\n *\n * The `currentWidget` will always have the largest focus number.\n *\n * All widgets start with a focus number of `-1`, which indicates that\n * the widget has not been focused since being added to the tracker.\n */\n focusNumber(widget: T): number {\n let n = this._numbers.get(widget);\n return n === undefined ? -1 : n;\n }\n\n /**\n * Test whether the focus tracker contains a given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns `true` if the widget is tracked, `false` otherwise.\n */\n has(widget: T): boolean {\n return this._numbers.has(widget);\n }\n\n /**\n * Add a widget to the focus tracker.\n *\n * @param widget - The widget of interest.\n *\n * #### Notes\n * A widget will be automatically removed from the tracker if it\n * is disposed after being added.\n *\n * If the widget is already tracked, this is a no-op.\n */\n add(widget: T): void {\n // Do nothing if the widget is already tracked.\n if (this._numbers.has(widget)) {\n return;\n }\n\n // Test whether the widget has focus.\n let focused = widget.node.contains(document.activeElement);\n\n // Set up the initial focus number.\n let n = focused ? this._counter++ : -1;\n\n // Add the widget to the internal data structures.\n this._widgets.push(widget);\n this._numbers.set(widget, n);\n this._nodes.set(widget.node, widget);\n\n // Set up the event listeners. The capturing phase must be used\n // since the 'focus' and 'blur' events don't bubble and Firefox\n // doesn't support the 'focusin' or 'focusout' events.\n widget.node.addEventListener('focus', this, true);\n widget.node.addEventListener('blur', this, true);\n\n // Connect the disposed signal handler.\n widget.disposed.connect(this._onWidgetDisposed, this);\n\n // Set the current and active widgets if needed.\n if (focused) {\n this._setWidgets(widget, widget);\n }\n }\n\n /**\n * Remove a widget from the focus tracker.\n *\n * #### Notes\n * If the widget is the `currentWidget`, the previous current widget\n * will become the new `currentWidget`.\n *\n * A widget will be automatically removed from the tracker if it\n * is disposed after being added.\n *\n * If the widget is not tracked, this is a no-op.\n */\n remove(widget: T): void {\n // Bail early if the widget is not tracked.\n if (!this._numbers.has(widget)) {\n return;\n }\n\n // Disconnect the disposed signal handler.\n widget.disposed.disconnect(this._onWidgetDisposed, this);\n\n // Remove the event listeners.\n widget.node.removeEventListener('focus', this, true);\n widget.node.removeEventListener('blur', this, true);\n\n // Remove the widget from the internal data structures.\n ArrayExt.removeFirstOf(this._widgets, widget);\n this._nodes.delete(widget.node);\n this._numbers.delete(widget);\n\n // Bail early if the widget is not the current widget.\n if (this._currentWidget !== widget) {\n return;\n }\n\n // Filter the widgets for those which have had focus.\n let valid = this._widgets.filter(w => this._numbers.get(w) !== -1);\n\n // Get the valid widget with the max focus number.\n let previous =\n max(valid, (first, second) => {\n let a = this._numbers.get(first)!;\n let b = this._numbers.get(second)!;\n return a - b;\n }) || null;\n\n // Set the current and active widgets.\n this._setWidgets(previous, null);\n }\n\n /**\n * Handle the DOM events for the focus tracker.\n *\n * @param event - The DOM event sent to the panel.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the tracked nodes. It should\n * not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'focus':\n this._evtFocus(event as FocusEvent);\n break;\n case 'blur':\n this._evtBlur(event as FocusEvent);\n break;\n }\n }\n\n /**\n * Set the current and active widgets for the tracker.\n */\n private _setWidgets(current: T | null, active: T | null): void {\n // Swap the current widget.\n let oldCurrent = this._currentWidget;\n this._currentWidget = current;\n\n // Swap the active widget.\n let oldActive = this._activeWidget;\n this._activeWidget = active;\n\n // Emit the `currentChanged` signal if needed.\n if (oldCurrent !== current) {\n this._currentChanged.emit({ oldValue: oldCurrent, newValue: current });\n }\n\n // Emit the `activeChanged` signal if needed.\n if (oldActive !== active) {\n this._activeChanged.emit({ oldValue: oldActive, newValue: active });\n }\n }\n\n /**\n * Handle the `'focus'` event for a tracked widget.\n */\n private _evtFocus(event: FocusEvent): void {\n // Find the widget which gained focus, which is known to exist.\n let widget = this._nodes.get(event.currentTarget as HTMLElement)!;\n\n // Update the focus number if necessary.\n if (widget !== this._currentWidget) {\n this._numbers.set(widget, this._counter++);\n }\n\n // Set the current and active widgets.\n this._setWidgets(widget, widget);\n }\n\n /**\n * Handle the `'blur'` event for a tracked widget.\n */\n private _evtBlur(event: FocusEvent): void {\n // Find the widget which lost focus, which is known to exist.\n let widget = this._nodes.get(event.currentTarget as HTMLElement)!;\n\n // Get the node which being focused after this blur.\n let focusTarget = event.relatedTarget as HTMLElement;\n\n // If no other node is being focused, clear the active widget.\n if (!focusTarget) {\n this._setWidgets(this._currentWidget, null);\n return;\n }\n\n // Bail if the focus widget is not changing.\n if (widget.node.contains(focusTarget)) {\n return;\n }\n\n // If no tracked widget is being focused, clear the active widget.\n if (!find(this._widgets, w => w.node.contains(focusTarget))) {\n this._setWidgets(this._currentWidget, null);\n return;\n }\n }\n\n /**\n * Handle the `disposed` signal for a tracked widget.\n */\n private _onWidgetDisposed(sender: T): void {\n this.remove(sender);\n }\n\n private _counter = 0;\n private _widgets: T[] = [];\n private _activeWidget: T | null = null;\n private _currentWidget: T | null = null;\n private _numbers = new Map();\n private _nodes = new Map();\n private _activeChanged = new Signal>(this);\n private _currentChanged = new Signal>(\n this\n );\n}\n\n/**\n * The namespace for the `FocusTracker` class statics.\n */\nexport namespace FocusTracker {\n /**\n * An arguments object for the changed signals.\n */\n export interface IChangedArgs {\n /**\n * The old value for the widget.\n */\n oldValue: T | null;\n\n /**\n * The new value for the widget.\n */\n newValue: T | null;\n }\n}\n"],"mappings":"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"} +\ No newline at end of file ++{"version":3,"names":["BoxSizer","constructor","this","sizeHint","minSize","maxSize","Infinity","stretch","size","done","BoxEngine","Private","Utils","calc","sizers","space","count","length","totalMin","totalMax","totalSize","totalStretch","stretchCount","i","sizer","min","max","hint","Math","nearZero","notDoneCount","freeSpace","distSpace","distStretch","amt","adjust","index","delta","growLimit","shrinkLimit","n","grow","limit","shrink","growSizer","shrinkSizer","Title","options","_label","_caption","_mnemonic","_icon","undefined","_iconClass","_iconLabel","_className","_closable","_changed","Signal","_isDisposed","owner","label","mnemonic","icon","iconClass","iconLabel","caption","className","closable","_dataset","dataset","changed","value","emit","isDisposed","dispose","clearData","Widget","_flags","_layout","_parent","_disposed","_hiddenMode","HiddenMode","Display","node","createNode","addClass","setFlag","Flag","IsDisposed","parent","isAttached","detach","title","MessageLoop","AttachedProperty","disposed","testFlag","IsAttached","isHidden","IsHidden","isVisible","IsVisible","titleProperty","get","id","hiddenMode","_toggleHidden","Scale","style","willChange","contains","Error","msg","ChildMessage","sendMessage","Msg","ParentChanged","layout","DisallowLayout","children","widget","hasClass","name","classList","add","removeClass","remove","toggleClass","force","toggle","update","postMessage","UpdateRequest","fit","FitRequest","activate","ActivateRequest","close","CloseRequest","show","BeforeShow","clearFlag","AfterShow","hide","BeforeHide","AfterHide","setHidden","hidden","flag","processMessage","type","notifyLayout","onResize","onUpdateRequest","onFitRequest","onBeforeShow","onAfterShow","onBeforeHide","onAfterHide","onBeforeAttach","onAfterAttach","onBeforeDetach","onAfterDetach","onActivateRequest","onCloseRequest","onChildAdded","onChildRemoved","processParentMessage","transform","setAttribute","ContentVisibility","contentVisibility","zIndex","removeAttribute","Message","BeforeAttach","AfterAttach","BeforeDetach","AfterDetach","ConflatableMessage","child","super","ResizeMessage","width","height","UnknownSize","attach","host","ref","isConnected","insertBefore","parentNode","removeChild","create","document","createElement","tag","Layout","_fitPolicy","fitPolicy","init","minWidth","minHeight","maxWidth","maxHeight","onChildShown","onChildHidden","removeWidget","getHorizontalAlignment","horizontalAlignmentProperty","setHorizontalAlignment","set","getVerticalAlignment","verticalAlignmentProperty","setVerticalAlignment","LayoutItem","_top","NaN","_left","_width","_height","_minWidth","_minHeight","_maxWidth","_maxHeight","position","contain","top","left","limits","ElementExt","sizeLimits","clampW","clampH","resized","onAlignmentChanged","PanelLayout","_widgets","pop","widgets","Symbol","iterator","addWidget","insertWidget","indexOf","j","ArrayExt","insert","attachWidget","move","moveWidget","removeWidgetAt","removeAt","detachWidget","fromIndex","toIndex","clampDimension","floor","Utils$1","SplitLayout","widgetOffset","_fixed","_spacing","_dirty","_hasNormedSizes","_sizers","_items","_handles","_box","_alignment","_orientation","renderer","orientation","alignment","spacing","item","handles","absoluteSizes","map","relativeSizes","normalize","setRelativeSizes","sizes","temp","slice","push","normed","moveHandle","handle","offsetLeft","offsetTop","createHandle","average","averageSize","createSizer","appendChild","_update","_fit","updateItemPosition","isHorizontal","handleStyle","nVisible","lastHandleIndex","horz","minW","minH","getStretch","box","boxSizing","horizontalSum","verticalSum","offsetWidth","offsetHeight","paddingTop","paddingLeft","extra","offset","fullOffset","stretchProperty","setStretch","coerce","reduce","v","s","values","sum","a","b","abs","AccordionLayout","_titles","titleSpace","titles","updateTitle","oldTitle","expanded","newTitle","createTitle","replaceChild","UUID","uuid4","titleStyle","data","createSectionTitle","Panel","createLayout","SplitPanel","_handleMoved","_pressData","_releaseMouse","handleMoved","handleEvent","event","_evtPointerDown","_evtPointerMove","_evtPointerUp","_evtKeyDown","preventDefault","stopPropagation","addEventListener","removeEventListener","keyCode","button","findFirstIndex","target","rect","getBoundingClientRect","clientX","clientY","window","getComputedStyle","override","Drag","overrideCursor","cursor","pos","Renderer","defaultRenderer","AccordionPanel","_widgetSizesCache","WeakMap","_expansionToggled","expansionToggled","connect","_onTitleChanged","collapse","_toggleExpansion","expand","_evtClick","_eventKeyDown","sender","_computeWidgetSize","widgetSizes","prev","curr","newSize","previousSize","widgetToCollapse","sz","lastIndexOf","forEach","_","idx","currentSize","defaultPrevented","handled","toString","key","match","click","direction","newIndex","focus","titleClassName","_titleID","_titleKeys","_uuid","_nInstance","createCollapseIcon","createTitleKey","aData","textContent","BoxLayout","_direction","getSizeBasis","sizeBasisProperty","setSizeBasis","onChildSizingChanged","dir","clampSpacing","BoxPanel","CommandPalette","_activeIndex","_results","commands","commandChanged","_onGenericChange","keyBindingChanged","searchNode","getElementsByClassName","inputNode","contentNode","items","addItem","createItem","refresh","addItems","newItems","removeItem","removeItemAt","clearItems","display","_toggleFocused","input","select","query","results","search","canActivate","VirtualDOM","render","content","renderEmptyMessage","activeIndex","Array","result","indices","category","renderHeader","active","renderItem","scrollTop","element","scrollIntoViewIfNeeded","_execute","altKey","ctrlKey","metaKey","shiftKey","_activatePreviousItem","_activateNextItem","ai","start","stop","findLastIndex","part","toLowerCase","isEnabled","execute","command","args","focused","activeElement","formatHeader","h","li","createItemClass","createItemDataset","isToggleable","role","isToggled","renderItemIcon","renderItemContent","renderItemShortcut","formatEmptyMessage","createIconClass","div","renderItemLabel","renderItemCaption","formatItemLabel","formatItemCaption","formatItemShortcut","StringExt","highlight","mark","kb","keyBinding","CommandRegistry","formatKeystroke","keys","fuzzySearch","source","score","rgx","rgxMatch","exec","matchSumOfDeltas","pivot","lowerBound","categoryIndices","labelIndices","matchType","scoreCmp","m1","d1","i1","i2","d2","localeCompare","r1","rank","r2","wrapper","clear","spellcheck","CommandItem","scores","text","replace","matchItems","sort","createResults","_commands","trim","JSONExt","emptyObject","findLastValue","keyBindings","deepEqual","Menu","_childIndex","_openTimerID","_closeTimerID","_childMenu","_parentMenu","_aboutToClose","_menuRequested","aboutToClose","menuRequested","parentMenu","childMenu","rootMenu","menu","leafMenu","activeItem","childNodes","activateNextItem","activatePreviousItem","triggerActiveItem","_cancelOpenTimer","_cancelCloseTimer","_openChildMenu","console","log","insertItem","open","x","y","forceX","forceY","_a","_b","openRootMenu","_evtMouseUp","_evtMouseMove","_evtMouseEnter","_evtMouseLeave","_evtMouseDown","ownerDocument","collapsedFlags","computeCollapsed","collapsed","onfocus","kc","getKeyboardLayout","keyForKeydownEvent","findMnemonic","multiple","auto","hitTest","_startCloseTimer","submenu","_startOpenTimer","hitTestMenus","activateFirst","_closeChildMenu","saveWindowData","itemNode","openSubmenu","setTimeout","TIMER_DELAY","clearTimeout","static","aria","createItemARIA","tabindex","renderIcon","renderLabel","renderShortcut","renderSubmenu","formatLabel","formatShortcut","prefix","suffix","char","span","SUBMENU_OVERLAP","transientWindowDataCache","transientCacheCounter","getWindowData","_getWindowData","pageXOffset","pageYOffset","clientWidth","documentElement","clientHeight","tabIndex","MenuItem","fill","k1","k2","windowData","px","py","cw","ch","opacity","body","itemRect","right","borderTop","bottom","borderBottom","paddingBottom","upperKey","toUpperCase","k","mn","itemCmpRank","itemCmp","s1","Selector","calculateSpecificity","selector","s2","isValid","validateSelector","groupByTarget","sortBySelector","currentTarget","elementFromPoint","availableItems","matches","parentElement","ARROW_KEYS","TabBar","_currentIndex","_titlesEditable","_previousTitle","_dragData","_addButtonEnabled","_tabMoved","_currentChanged","_addRequested","_tabCloseRequested","_tabDetachRequested","_tabActivateRequested","_document","tabsMovable","titlesEditable","allowDeselect","addButtonEnabled","insertBehavior","removeBehavior","currentChanged","tabMoved","tabActivateRequested","addRequested","tabCloseRequested","tabDetachRequested","currentTitle","currentIndex","pi","pt","ci","ct","previousIndex","previousTitle","_name","addButtonNode","addTab","insertTab","asTitle","_adjustCurrentForInsert","_adjustCurrentForMove","removeTab","removeTabAt","disconnect","_adjustCurrentForRemove","clearTabs","releaseMouse","_evtDblClick","eventPhase","Event","CAPTURING_PHASE","_evtKeyDownCapturing","tabHandlingTabindex","_getCurrentTabindex","current","renderTab","elemTabindex","querySelector","getAttribute","tabs","tab","oldValue","innerHTML","onblur","focusedElement","includes","focusable","nextFocused","focusedIndex","_c","addButtonClicked","pressX","pressY","tabPos","tabSize","tabPressPos","targetIndex","tabLayout","contentRect","dragActive","dragAborted","detachRequested","closeIconSelector","dragExceeded","tabRect","tabPressOffset","snapTabLayout","detachExceeded","layoutTabs","finalizeTabPosition","duration","parseTransitionDuration","resetTabPositions","bh","_tabID","_tabKeys","createTabKey","createTabStyle","createTabClass","createTabDataset","createTabARIA","renderCloseIcon","addButtonSelector","DRAG_THRESHOLD","DETACH_THRESHOLD","parseFloat","transitionDuration","margin","marginLeft","marginTop","dx","dy","pressPos","localPos","clientPos","clientSize","targetPos","targetEnd","pxPos","threshold","ideal","tgt","final","DockLayout","_root","Map","bar","tabBars","isEmpty","iterAllWidgets","empty","iterUserWidgets","selectedWidgets","iterSelectedWidgets","iterTabBars","iterHandles","offsetX","offsetY","findSplitNode","holdSizes","saveLayout","holdAllSizes","main","createConfig","restoreLayout","config","mainConfig","widgetSet","Set","normalizeAreaConfig","oldWidgets","oldTabBars","oldHandles","has","tabBar","realizeAreaConfig","createTabBar","_createTabBar","_createHandle","mode","refNode","findTabNode","_insertTab","_insertSplit","_removeWidget","hitTestTabAreas","borderLeft","tabNode","hitTestTabNodes","borderWidth","borderRight","borderHeight","delete","removeAria","splitNode","removeFirstOf","syncHandles","maybeParent","childNode","childHandle","TabLayoutNode","splitHandle","gChild","gHandle","gSizer","_createTabNode","addAria","after","findFirstTabNode","merge","root","_splitRoot","normalizeSizes","GOLDEN_RATIO","sibling","SplitLayoutNode","normalized","oldRoot","newRoot","normalizeTabAreaConfig","normalizeSplitAreaConfig","realizeTabAreaConfig","realizeSplitAreaConfig","tabSizer","widgetSizer","tabBarItem","widgetItem","tabBarSizer","createNormalizedSizes","horizontal","fixed","tabId","DockPanel","_drag","_tabsMovable","_tabsConstrained","_layoutModified","_mode","_renderer","_edges","edges","DEFAULT_EDGES","tabsConstrained","overlay","Overlay","layoutModified","createSingleDocumentConfig","LayoutModified","selectWidget","find","activateWidget","Platform","IS_EDGE","IS_IE","flush","_evtDragEnter","_evtDragLeave","_evtDragOver","_evtDrop","isGeneratedTabBarProperty","mimeData","hasData","_showOverlay","dropAction","proposedAction","zone","findDropTarget","factory","getData","getDropRef","deltaX","deltaY","xPos","yPos","paddingRight","tabHeight","_onTabMoved","_onCurrentChanged","_onTabCloseRequested","_onTabDetachRequested","_onTabActivateRequested","_onTabAddRequested","MimeData","setData","dragImage","cloneNode","supportedActions","then","_timer","_hidden","geo","delay","panel","from","selected","next","panelRect","pl","pr","pb","al","at","ar","ab","rx","round","ry","GridLayout","_rowSpacing","_columnSpacing","_rowStarts","_columnStarts","_rowSizers","_columnSizers","rowCount","reallocSizers","columnCount","rowSpacing","clampValue","columnSpacing","rowStretch","setRowStretch","columnStretch","setColumnStretch","it","filter","maxRow","maxCol","rowSpanCmp","getCellConfig","row","rowSpan","distributeMin","columnSpanCmp","c1","column","c2","columnSpan","fixedRowSpace","fixedColSpace","w","cellConfigProperty","setCellConfig","normalizeConfig","portion","MenuBar","_tabFocusIndex","_menus","_overflowMenu","_menuItemSizes","_overflowIndex","_forceItemsPosition","forceItemsPosition","_overflowMenuOptions","overflowMenuOptions","overflowIndex","overflowMenu","activeMenu","menus","openActiveMenu","addMenu","insertMenu","_onMenuAboutToClose","_onMenuMenuRequested","removeMenu","removeMenuAt","clearMenus","_evtFocusOut","_focusItemAt","tabFocusIndex","totalMenuSize","tabbable","disabled","overflowMenuTitle","overflowMenuItems","screenSize","_updateOverflowIndex","itemMenus","stopImmediatePropagation","_positionForMenu","relatedTarget","newMenu","oldMenu","decrement","increment","track","thumb","findPart","scrollBar","thumbNode","trackNode","decrementNode","incrementNode","SingletonLayout","_widget","StackedLayout","StackedPanel","_widgetRemoved","widgetRemoved","orientationFromPlacement","plc","placementToOrientationMap","directionFromPlacement","placementToDirectionMap","_groupByTarget","_idTick","_sortBySelector","others","DisposableDelegate","_counter","_activeWidget","_currentWidget","_numbers","_nodes","_activeChanged","activeChanged","currentWidget","activeWidget","focusNumber","_onWidgetDisposed","_setWidgets","valid","previous","first","second","_evtFocus","_evtBlur","oldCurrent","oldActive","newValue","focusTarget","_onRepeat","_repeatTimer","mouseX","mouseY","thumbRect","_pageRequested","_stepRequested","_value","_page","_maximum","_thumbMoved","maximum","page","thumbMoved","stepRequested","pageRequested","thumbStyle","_moveThumb","trackPos","trackSpan","trackRect","stackedPanel","_onWidgetRemoved","_tabPlacement","tabPlacement","previousWidget"],"sources":["../src/boxengine.ts","../src/widget.ts","../src/layout.ts","../src/utils.ts","../src/title.ts","../src/panellayout.ts","../src/splitlayout.ts","../src/accordionlayout.ts","../src/panel.ts","../src/splitpanel.ts","../src/accordionpanel.ts","../src/boxlayout.ts","../src/boxpanel.ts","../src/commandpalette.ts","../src/menu.ts","../src/contextmenu.ts","../src/tabbar.ts","../src/docklayout.ts","../src/dockpanel.ts","../src/gridlayout.ts","../src/menubar.ts","../src/scrollbar.ts","../src/stackedpanel.ts","../src/tabpanel.ts","../src/singletonlayout.ts","../src/stackedlayout.ts","../src/focustracker.ts"],"sourcesContent":["// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\n\n/**\n * A sizer object for use with the box engine layout functions.\n *\n * #### Notes\n * A box sizer holds the geometry information for an object along an\n * arbitrary layout orientation.\n *\n * For best performance, this class should be treated as a raw data\n * struct. It should not typically be subclassed.\n */\nexport class BoxSizer {\n /**\n * The preferred size for the sizer.\n *\n * #### Notes\n * The sizer will be given this initial size subject to its size\n * bounds. The sizer will not deviate from this size unless such\n * deviation is required to fit into the available layout space.\n *\n * There is no limit to this value, but it will be clamped to the\n * bounds defined by {@link minSize} and {@link maxSize}.\n *\n * The default value is `0`.\n */\n sizeHint = 0;\n\n /**\n * The minimum size of the sizer.\n *\n * #### Notes\n * The sizer will never be sized less than this value, even if\n * it means the sizer will overflow the available layout space.\n *\n * It is assumed that this value lies in the range `[0, Infinity)`\n * and that it is `<=` to {@link maxSize}. Failure to adhere to this\n * constraint will yield undefined results.\n *\n * The default value is `0`.\n */\n minSize = 0;\n\n /**\n * The maximum size of the sizer.\n *\n * #### Notes\n * The sizer will never be sized greater than this value, even if\n * it means the sizer will underflow the available layout space.\n *\n * It is assumed that this value lies in the range `[0, Infinity]`\n * and that it is `>=` to {@link minSize}. Failure to adhere to this\n * constraint will yield undefined results.\n *\n * The default value is `Infinity`.\n */\n maxSize = Infinity;\n\n /**\n * The stretch factor for the sizer.\n *\n * #### Notes\n * This controls how much the sizer stretches relative to its sibling\n * sizers when layout space is distributed. A stretch factor of zero\n * is special and will cause the sizer to only be resized after all\n * other sizers with a stretch factor greater than zero have been\n * resized to their limits.\n *\n * It is assumed that this value is an integer that lies in the range\n * `[0, Infinity)`. Failure to adhere to this constraint will yield\n * undefined results.\n *\n * The default value is `1`.\n */\n stretch = 1;\n\n /**\n * The computed size of the sizer.\n *\n * #### Notes\n * This value is the output of a call to {@link BoxEngine.calc}. It represents\n * the computed size for the object along the layout orientation,\n * and will always lie in the range `[minSize, maxSize]`.\n *\n * This value is output only.\n *\n * Changing this value will have no effect.\n */\n size = 0;\n\n /**\n * An internal storage property for the layout algorithm.\n *\n * #### Notes\n * This value is used as temporary storage by the layout algorithm.\n *\n * Changing this value will have no effect.\n */\n done = false;\n}\n\n/**\n * The namespace for the box engine layout functions.\n */\nexport namespace BoxEngine {\n /**\n * Calculate the optimal layout sizes for a sequence of box sizers.\n *\n * This distributes the available layout space among the box sizers\n * according to the following algorithm:\n *\n * 1. Initialize the sizers's size to its size hint and compute the\n * sums for each of size hint, min size, and max size.\n *\n * 2. If the total size hint equals the available space, return.\n *\n * 3. If the available space is less than the total min size, set all\n * sizers to their min size and return.\n *\n * 4. If the available space is greater than the total max size, set\n * all sizers to their max size and return.\n *\n * 5. If the layout space is less than the total size hint, distribute\n * the negative delta as follows:\n *\n * a. Shrink each sizer with a stretch factor greater than zero by\n * an amount proportional to the negative space and the sum of\n * stretch factors. If the sizer reaches its min size, remove\n * it and its stretch factor from the computation.\n *\n * b. If after adjusting all stretch sizers there remains negative\n * space, distribute the space equally among the sizers with a\n * stretch factor of zero. If a sizer reaches its min size,\n * remove it from the computation.\n *\n * 6. If the layout space is greater than the total size hint,\n * distribute the positive delta as follows:\n *\n * a. Expand each sizer with a stretch factor greater than zero by\n * an amount proportional to the postive space and the sum of\n * stretch factors. If the sizer reaches its max size, remove\n * it and its stretch factor from the computation.\n *\n * b. If after adjusting all stretch sizers there remains positive\n * space, distribute the space equally among the sizers with a\n * stretch factor of zero. If a sizer reaches its max size,\n * remove it from the computation.\n *\n * 7. return\n *\n * @param sizers - The sizers for a particular layout line.\n *\n * @param space - The available layout space for the sizers.\n *\n * @returns The delta between the provided available space and the\n * actual consumed space. This value will be zero if the sizers\n * can be adjusted to fit, negative if the available space is too\n * small, and positive if the available space is too large.\n *\n * #### Notes\n * The {@link BoxSizer.size} of each sizer is updated with the computed size.\n *\n * This function can be called at any time to recompute the layout for\n * an existing sequence of sizers. The previously computed results will\n * have no effect on the new output. It is therefore not necessary to\n * create new sizer objects on each resize event.\n */\n export function calc(sizers: ArrayLike, space: number): number {\n // Bail early if there is nothing to do.\n let count = sizers.length;\n if (count === 0) {\n return space;\n }\n\n // Setup the size and stretch counters.\n let totalMin = 0;\n let totalMax = 0;\n let totalSize = 0;\n let totalStretch = 0;\n let stretchCount = 0;\n\n // Setup the sizers and compute the totals.\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n let min = sizer.minSize;\n let max = sizer.maxSize;\n let hint = sizer.sizeHint;\n sizer.done = false;\n sizer.size = Math.max(min, Math.min(hint, max));\n totalSize += sizer.size;\n totalMin += min;\n totalMax += max;\n if (sizer.stretch > 0) {\n totalStretch += sizer.stretch;\n stretchCount++;\n }\n }\n\n // If the space is equal to the total size, return early.\n if (space === totalSize) {\n return 0;\n }\n\n // If the space is less than the total min, minimize each sizer.\n if (space <= totalMin) {\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n sizer.size = sizer.minSize;\n }\n return space - totalMin;\n }\n\n // If the space is greater than the total max, maximize each sizer.\n if (space >= totalMax) {\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n sizer.size = sizer.maxSize;\n }\n return space - totalMax;\n }\n\n // The loops below perform sub-pixel precision sizing. A near zero\n // value is used for compares instead of zero to ensure that the\n // loop terminates when the subdivided space is reasonably small.\n let nearZero = 0.01;\n\n // A counter which is decremented each time a sizer is resized to\n // its limit. This ensures the loops terminate even if there is\n // space remaining to distribute.\n let notDoneCount = count;\n\n // Distribute negative delta space.\n if (space < totalSize) {\n // Shrink each stretchable sizer by an amount proportional to its\n // stretch factor. If a sizer reaches its min size it's marked as\n // done. The loop progresses in phases where each sizer is given\n // a chance to consume its fair share for the pass, regardless of\n // whether a sizer before it reached its limit. This continues\n // until the stretchable sizers or the free space is exhausted.\n let freeSpace = totalSize - space;\n while (stretchCount > 0 && freeSpace > nearZero) {\n let distSpace = freeSpace;\n let distStretch = totalStretch;\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n if (sizer.done || sizer.stretch === 0) {\n continue;\n }\n let amt = (sizer.stretch * distSpace) / distStretch;\n if (sizer.size - amt <= sizer.minSize) {\n freeSpace -= sizer.size - sizer.minSize;\n totalStretch -= sizer.stretch;\n sizer.size = sizer.minSize;\n sizer.done = true;\n notDoneCount--;\n stretchCount--;\n } else {\n freeSpace -= amt;\n sizer.size -= amt;\n }\n }\n }\n // Distribute any remaining space evenly among the non-stretchable\n // sizers. This progresses in phases in the same manner as above.\n while (notDoneCount > 0 && freeSpace > nearZero) {\n let amt = freeSpace / notDoneCount;\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n if (sizer.done) {\n continue;\n }\n if (sizer.size - amt <= sizer.minSize) {\n freeSpace -= sizer.size - sizer.minSize;\n sizer.size = sizer.minSize;\n sizer.done = true;\n notDoneCount--;\n } else {\n freeSpace -= amt;\n sizer.size -= amt;\n }\n }\n }\n }\n // Distribute positive delta space.\n else {\n // Expand each stretchable sizer by an amount proportional to its\n // stretch factor. If a sizer reaches its max size it's marked as\n // done. The loop progresses in phases where each sizer is given\n // a chance to consume its fair share for the pass, regardless of\n // whether a sizer before it reached its limit. This continues\n // until the stretchable sizers or the free space is exhausted.\n let freeSpace = space - totalSize;\n while (stretchCount > 0 && freeSpace > nearZero) {\n let distSpace = freeSpace;\n let distStretch = totalStretch;\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n if (sizer.done || sizer.stretch === 0) {\n continue;\n }\n let amt = (sizer.stretch * distSpace) / distStretch;\n if (sizer.size + amt >= sizer.maxSize) {\n freeSpace -= sizer.maxSize - sizer.size;\n totalStretch -= sizer.stretch;\n sizer.size = sizer.maxSize;\n sizer.done = true;\n notDoneCount--;\n stretchCount--;\n } else {\n freeSpace -= amt;\n sizer.size += amt;\n }\n }\n }\n // Distribute any remaining space evenly among the non-stretchable\n // sizers. This progresses in phases in the same manner as above.\n while (notDoneCount > 0 && freeSpace > nearZero) {\n let amt = freeSpace / notDoneCount;\n for (let i = 0; i < count; ++i) {\n let sizer = sizers[i];\n if (sizer.done) {\n continue;\n }\n if (sizer.size + amt >= sizer.maxSize) {\n freeSpace -= sizer.maxSize - sizer.size;\n sizer.size = sizer.maxSize;\n sizer.done = true;\n notDoneCount--;\n } else {\n freeSpace -= amt;\n sizer.size += amt;\n }\n }\n }\n }\n\n // Indicate that the consumed space equals the available space.\n return 0;\n }\n\n /**\n * Adjust a sizer by a delta and update its neighbors accordingly.\n *\n * @param sizers - The sizers which should be adjusted.\n *\n * @param index - The index of the sizer to grow.\n *\n * @param delta - The amount to adjust the sizer, positive or negative.\n *\n * #### Notes\n * This will adjust the indicated sizer by the specified amount, along\n * with the sizes of the appropriate neighbors, subject to the limits\n * specified by each of the sizers.\n *\n * This is useful when implementing box layouts where the boundaries\n * between the sizers are interactively adjustable by the user.\n */\n export function adjust(\n sizers: ArrayLike,\n index: number,\n delta: number\n ): void {\n // Bail early when there is nothing to do.\n if (sizers.length === 0 || delta === 0) {\n return;\n }\n\n // Dispatch to the proper implementation.\n if (delta > 0) {\n growSizer(sizers, index, delta);\n } else {\n shrinkSizer(sizers, index, -delta);\n }\n }\n\n /**\n * Grow a sizer by a positive delta and adjust neighbors.\n */\n function growSizer(\n sizers: ArrayLike,\n index: number,\n delta: number\n ): void {\n // Compute how much the items to the left can expand.\n let growLimit = 0;\n for (let i = 0; i <= index; ++i) {\n let sizer = sizers[i];\n growLimit += sizer.maxSize - sizer.size;\n }\n\n // Compute how much the items to the right can shrink.\n let shrinkLimit = 0;\n for (let i = index + 1, n = sizers.length; i < n; ++i) {\n let sizer = sizers[i];\n shrinkLimit += sizer.size - sizer.minSize;\n }\n\n // Clamp the delta adjustment to the limits.\n delta = Math.min(delta, growLimit, shrinkLimit);\n\n // Grow the sizers to the left by the delta.\n let grow = delta;\n for (let i = index; i >= 0 && grow > 0; --i) {\n let sizer = sizers[i];\n let limit = sizer.maxSize - sizer.size;\n if (limit >= grow) {\n sizer.sizeHint = sizer.size + grow;\n grow = 0;\n } else {\n sizer.sizeHint = sizer.size + limit;\n grow -= limit;\n }\n }\n\n // Shrink the sizers to the right by the delta.\n let shrink = delta;\n for (let i = index + 1, n = sizers.length; i < n && shrink > 0; ++i) {\n let sizer = sizers[i];\n let limit = sizer.size - sizer.minSize;\n if (limit >= shrink) {\n sizer.sizeHint = sizer.size - shrink;\n shrink = 0;\n } else {\n sizer.sizeHint = sizer.size - limit;\n shrink -= limit;\n }\n }\n }\n\n /**\n * Shrink a sizer by a positive delta and adjust neighbors.\n */\n function shrinkSizer(\n sizers: ArrayLike,\n index: number,\n delta: number\n ): void {\n // Compute how much the items to the right can expand.\n let growLimit = 0;\n for (let i = index + 1, n = sizers.length; i < n; ++i) {\n let sizer = sizers[i];\n growLimit += sizer.maxSize - sizer.size;\n }\n\n // Compute how much the items to the left can shrink.\n let shrinkLimit = 0;\n for (let i = 0; i <= index; ++i) {\n let sizer = sizers[i];\n shrinkLimit += sizer.size - sizer.minSize;\n }\n\n // Clamp the delta adjustment to the limits.\n delta = Math.min(delta, growLimit, shrinkLimit);\n\n // Grow the sizers to the right by the delta.\n let grow = delta;\n for (let i = index + 1, n = sizers.length; i < n && grow > 0; ++i) {\n let sizer = sizers[i];\n let limit = sizer.maxSize - sizer.size;\n if (limit >= grow) {\n sizer.sizeHint = sizer.size + grow;\n grow = 0;\n } else {\n sizer.sizeHint = sizer.size + limit;\n grow -= limit;\n }\n }\n\n // Shrink the sizers to the left by the delta.\n let shrink = delta;\n for (let i = index; i >= 0 && shrink > 0; --i) {\n let sizer = sizers[i];\n let limit = sizer.size - sizer.minSize;\n if (limit >= shrink) {\n sizer.sizeHint = sizer.size - shrink;\n shrink = 0;\n } else {\n sizer.sizeHint = sizer.size - limit;\n shrink -= limit;\n }\n }\n }\n}\n","/* eslint-disable @typescript-eslint/no-empty-function */\n// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { IObservableDisposable } from '@lumino/disposable';\n\nimport {\n ConflatableMessage,\n IMessageHandler,\n Message,\n MessageLoop\n} from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { Layout } from './layout';\n\nimport { Title } from './title';\n\n/**\n * The base class of the lumino widget hierarchy.\n *\n * #### Notes\n * This class will typically be subclassed in order to create a useful\n * widget. However, it can be used directly to host externally created\n * content.\n */\nexport class Widget implements IMessageHandler, IObservableDisposable {\n /**\n * Construct a new widget.\n *\n * @param options - The options for initializing the widget.\n */\n constructor(options: Widget.IOptions = {}) {\n this.node = Private.createNode(options);\n this.addClass('lm-Widget');\n }\n\n /**\n * Dispose of the widget and its descendant widgets.\n *\n * #### Notes\n * It is unsafe to use the widget after it has been disposed.\n *\n * All calls made to this method after the first are a no-op.\n */\n dispose(): void {\n // Do nothing if the widget is already disposed.\n if (this.isDisposed) {\n return;\n }\n\n // Set the disposed flag and emit the disposed signal.\n this.setFlag(Widget.Flag.IsDisposed);\n this._disposed.emit(undefined);\n\n // Remove or detach the widget if necessary.\n if (this.parent) {\n this.parent = null;\n } else if (this.isAttached) {\n Widget.detach(this);\n }\n\n // Dispose of the widget layout.\n if (this._layout) {\n this._layout.dispose();\n this._layout = null;\n }\n\n // Dispose the title\n this.title.dispose();\n\n // Clear the extra data associated with the widget.\n Signal.clearData(this);\n MessageLoop.clearData(this);\n AttachedProperty.clearData(this);\n }\n\n /**\n * A signal emitted when the widget is disposed.\n */\n get disposed(): ISignal {\n return this._disposed;\n }\n\n /**\n * Get the DOM node owned by the widget.\n */\n readonly node: HTMLElement;\n\n /**\n * Test whether the widget has been disposed.\n */\n get isDisposed(): boolean {\n return this.testFlag(Widget.Flag.IsDisposed);\n }\n\n /**\n * Test whether the widget's node is attached to the DOM.\n */\n get isAttached(): boolean {\n return this.testFlag(Widget.Flag.IsAttached);\n }\n\n /**\n * Test whether the widget is explicitly hidden.\n */\n get isHidden(): boolean {\n return this.testFlag(Widget.Flag.IsHidden);\n }\n\n /**\n * Test whether the widget is visible.\n *\n * #### Notes\n * A widget is visible when it is attached to the DOM, is not\n * explicitly hidden, and has no explicitly hidden ancestors.\n */\n get isVisible(): boolean {\n return this.testFlag(Widget.Flag.IsVisible);\n }\n\n /**\n * The title object for the widget.\n *\n * #### Notes\n * The title object is used by some container widgets when displaying\n * the widget alongside some title, such as a tab panel or side bar.\n *\n * Since not all widgets will use the title, it is created on demand.\n *\n * The `owner` property of the title is set to this widget.\n */\n get title(): Title {\n return Private.titleProperty.get(this);\n }\n\n /**\n * Get the id of the widget's DOM node.\n */\n get id(): string {\n return this.node.id;\n }\n\n /**\n * Set the id of the widget's DOM node.\n */\n set id(value: string) {\n this.node.id = value;\n }\n\n /**\n * The dataset for the widget's DOM node.\n */\n get dataset(): DOMStringMap {\n return this.node.dataset;\n }\n\n /**\n * Get the method for hiding the widget.\n */\n get hiddenMode(): Widget.HiddenMode {\n return this._hiddenMode;\n }\n\n /**\n * Set the method for hiding the widget.\n */\n set hiddenMode(value: Widget.HiddenMode) {\n if (this._hiddenMode === value) {\n return;\n }\n\n if (this.isHidden) {\n // Reset styles set by previous mode.\n this._toggleHidden(false);\n }\n\n if (value == Widget.HiddenMode.Scale) {\n this.node.style.willChange = 'transform';\n } else {\n this.node.style.willChange = 'auto';\n }\n\n this._hiddenMode = value;\n\n if (this.isHidden) {\n // Set styles for new mode.\n this._toggleHidden(true);\n }\n }\n\n /**\n * Get the parent of the widget.\n */\n get parent(): Widget | null {\n return this._parent;\n }\n\n /**\n * Set the parent of the widget.\n *\n * #### Notes\n * Children are typically added to a widget by using a layout, which\n * means user code will not normally set the parent widget directly.\n *\n * The widget will be automatically removed from its old parent.\n *\n * This is a no-op if there is no effective parent change.\n */\n set parent(value: Widget | null) {\n if (this._parent === value) {\n return;\n }\n if (value && this.contains(value)) {\n throw new Error('Invalid parent widget.');\n }\n if (this._parent && !this._parent.isDisposed) {\n let msg = new Widget.ChildMessage('child-removed', this);\n MessageLoop.sendMessage(this._parent, msg);\n }\n this._parent = value;\n if (this._parent && !this._parent.isDisposed) {\n let msg = new Widget.ChildMessage('child-added', this);\n MessageLoop.sendMessage(this._parent, msg);\n }\n if (!this.isDisposed) {\n MessageLoop.sendMessage(this, Widget.Msg.ParentChanged);\n }\n }\n\n /**\n * Get the layout for the widget.\n */\n get layout(): Layout | null {\n return this._layout;\n }\n\n /**\n * Set the layout for the widget.\n *\n * #### Notes\n * The layout is single-use only. It cannot be changed after the\n * first assignment.\n *\n * The layout is disposed automatically when the widget is disposed.\n */\n set layout(value: Layout | null) {\n if (this._layout === value) {\n return;\n }\n if (this.testFlag(Widget.Flag.DisallowLayout)) {\n throw new Error('Cannot set widget layout.');\n }\n if (this._layout) {\n throw new Error('Cannot change widget layout.');\n }\n if (value!.parent) {\n throw new Error('Cannot change layout parent.');\n }\n this._layout = value;\n value!.parent = this;\n }\n\n /**\n * Create an iterator over the widget's children.\n *\n * @returns A new iterator over the children of the widget.\n *\n * #### Notes\n * The widget must have a populated layout in order to have children.\n *\n * If a layout is not installed, the returned iterator will be empty.\n */\n *children(): IterableIterator {\n if (this._layout) {\n yield* this._layout;\n }\n }\n\n /**\n * Test whether a widget is a descendant of this widget.\n *\n * @param widget - The descendant widget of interest.\n *\n * @returns `true` if the widget is a descendant, `false` otherwise.\n */\n contains(widget: Widget): boolean {\n for (let value: Widget | null = widget; value; value = value._parent) {\n if (value === this) {\n return true;\n }\n }\n return false;\n }\n\n /**\n * Test whether the widget's DOM node has the given class name.\n *\n * @param name - The class name of interest.\n *\n * @returns `true` if the node has the class, `false` otherwise.\n */\n hasClass(name: string): boolean {\n return this.node.classList.contains(name);\n }\n\n /**\n * Add a class name to the widget's DOM node.\n *\n * @param name - The class name to add to the node.\n *\n * #### Notes\n * If the class name is already added to the node, this is a no-op.\n *\n * The class name must not contain whitespace.\n */\n addClass(name: string): void {\n this.node.classList.add(name);\n }\n\n /**\n * Remove a class name from the widget's DOM node.\n *\n * @param name - The class name to remove from the node.\n *\n * #### Notes\n * If the class name is not yet added to the node, this is a no-op.\n *\n * The class name must not contain whitespace.\n */\n removeClass(name: string): void {\n this.node.classList.remove(name);\n }\n\n /**\n * Toggle a class name on the widget's DOM node.\n *\n * @param name - The class name to toggle on the node.\n *\n * @param force - Whether to force add the class (`true`) or force\n * remove the class (`false`). If not provided, the presence of\n * the class will be toggled from its current state.\n *\n * @returns `true` if the class is now present, `false` otherwise.\n *\n * #### Notes\n * The class name must not contain whitespace.\n */\n toggleClass(name: string, force?: boolean): boolean {\n if (force === true) {\n this.node.classList.add(name);\n return true;\n }\n if (force === false) {\n this.node.classList.remove(name);\n return false;\n }\n return this.node.classList.toggle(name);\n }\n\n /**\n * Post an `'update-request'` message to the widget.\n *\n * #### Notes\n * This is a simple convenience method for posting the message.\n */\n update(): void {\n MessageLoop.postMessage(this, Widget.Msg.UpdateRequest);\n }\n\n /**\n * Post a `'fit-request'` message to the widget.\n *\n * #### Notes\n * This is a simple convenience method for posting the message.\n */\n fit(): void {\n MessageLoop.postMessage(this, Widget.Msg.FitRequest);\n }\n\n /**\n * Post an `'activate-request'` message to the widget.\n *\n * #### Notes\n * This is a simple convenience method for posting the message.\n */\n activate(): void {\n MessageLoop.postMessage(this, Widget.Msg.ActivateRequest);\n }\n\n /**\n * Send a `'close-request'` message to the widget.\n *\n * #### Notes\n * This is a simple convenience method for sending the message.\n */\n close(): void {\n MessageLoop.sendMessage(this, Widget.Msg.CloseRequest);\n }\n\n /**\n * Show the widget and make it visible to its parent widget.\n *\n * #### Notes\n * This causes the {@link isHidden} property to be `false`.\n *\n * If the widget is not explicitly hidden, this is a no-op.\n */\n show(): void {\n if (!this.testFlag(Widget.Flag.IsHidden)) {\n return;\n }\n if (this.isAttached && (!this.parent || this.parent.isVisible)) {\n MessageLoop.sendMessage(this, Widget.Msg.BeforeShow);\n }\n this.clearFlag(Widget.Flag.IsHidden);\n this._toggleHidden(false);\n\n if (this.isAttached && (!this.parent || this.parent.isVisible)) {\n MessageLoop.sendMessage(this, Widget.Msg.AfterShow);\n }\n if (this.parent) {\n let msg = new Widget.ChildMessage('child-shown', this);\n MessageLoop.sendMessage(this.parent, msg);\n }\n }\n\n /**\n * Hide the widget and make it hidden to its parent widget.\n *\n * #### Notes\n * This causes the {@link isHidden} property to be `true`.\n *\n * If the widget is explicitly hidden, this is a no-op.\n */\n hide(): void {\n if (this.testFlag(Widget.Flag.IsHidden)) {\n return;\n }\n if (this.isAttached && (!this.parent || this.parent.isVisible)) {\n MessageLoop.sendMessage(this, Widget.Msg.BeforeHide);\n }\n this.setFlag(Widget.Flag.IsHidden);\n this._toggleHidden(true);\n\n if (this.isAttached && (!this.parent || this.parent.isVisible)) {\n MessageLoop.sendMessage(this, Widget.Msg.AfterHide);\n }\n if (this.parent) {\n let msg = new Widget.ChildMessage('child-hidden', this);\n MessageLoop.sendMessage(this.parent, msg);\n }\n }\n\n /**\n * Show or hide the widget according to a boolean value.\n *\n * @param hidden - `true` to hide the widget, or `false` to show it.\n *\n * #### Notes\n * This is a convenience method for `hide()` and `show()`.\n */\n setHidden(hidden: boolean): void {\n if (hidden) {\n this.hide();\n } else {\n this.show();\n }\n }\n\n /**\n * Test whether the given widget flag is set.\n *\n * #### Notes\n * This will not typically be called directly by user code.\n */\n testFlag(flag: Widget.Flag): boolean {\n return (this._flags & flag) !== 0;\n }\n\n /**\n * Set the given widget flag.\n *\n * #### Notes\n * This will not typically be called directly by user code.\n */\n setFlag(flag: Widget.Flag): void {\n this._flags |= flag;\n }\n\n /**\n * Clear the given widget flag.\n *\n * #### Notes\n * This will not typically be called directly by user code.\n */\n clearFlag(flag: Widget.Flag): void {\n this._flags &= ~flag;\n }\n\n /**\n * Process a message sent to the widget.\n *\n * @param msg - The message sent to the widget.\n *\n * #### Notes\n * Subclasses may reimplement this method as needed.\n */\n processMessage(msg: Message): void {\n switch (msg.type) {\n case 'resize':\n this.notifyLayout(msg);\n this.onResize(msg as Widget.ResizeMessage);\n break;\n case 'update-request':\n this.notifyLayout(msg);\n this.onUpdateRequest(msg);\n break;\n case 'fit-request':\n this.notifyLayout(msg);\n this.onFitRequest(msg);\n break;\n case 'before-show':\n this.notifyLayout(msg);\n this.onBeforeShow(msg);\n break;\n case 'after-show':\n this.setFlag(Widget.Flag.IsVisible);\n this.notifyLayout(msg);\n this.onAfterShow(msg);\n break;\n case 'before-hide':\n this.notifyLayout(msg);\n this.onBeforeHide(msg);\n break;\n case 'after-hide':\n this.clearFlag(Widget.Flag.IsVisible);\n this.notifyLayout(msg);\n this.onAfterHide(msg);\n break;\n case 'before-attach':\n this.notifyLayout(msg);\n this.onBeforeAttach(msg);\n break;\n case 'after-attach':\n if (!this.isHidden && (!this.parent || this.parent.isVisible)) {\n this.setFlag(Widget.Flag.IsVisible);\n }\n this.setFlag(Widget.Flag.IsAttached);\n this.notifyLayout(msg);\n this.onAfterAttach(msg);\n break;\n case 'before-detach':\n this.notifyLayout(msg);\n this.onBeforeDetach(msg);\n break;\n case 'after-detach':\n this.clearFlag(Widget.Flag.IsVisible);\n this.clearFlag(Widget.Flag.IsAttached);\n this.notifyLayout(msg);\n this.onAfterDetach(msg);\n break;\n case 'activate-request':\n this.notifyLayout(msg);\n this.onActivateRequest(msg);\n break;\n case 'close-request':\n this.notifyLayout(msg);\n this.onCloseRequest(msg);\n break;\n case 'child-added':\n this.notifyLayout(msg);\n this.onChildAdded(msg as Widget.ChildMessage);\n break;\n case 'child-removed':\n this.notifyLayout(msg);\n this.onChildRemoved(msg as Widget.ChildMessage);\n break;\n default:\n this.notifyLayout(msg);\n break;\n }\n }\n\n /**\n * Invoke the message processing routine of the widget's layout.\n *\n * @param msg - The message to dispatch to the layout.\n *\n * #### Notes\n * This is a no-op if the widget does not have a layout.\n *\n * This will not typically be called directly by user code.\n */\n protected notifyLayout(msg: Message): void {\n if (this._layout) {\n this._layout.processParentMessage(msg);\n }\n }\n\n /**\n * A message handler invoked on a `'close-request'` message.\n *\n * #### Notes\n * The default implementation unparents or detaches the widget.\n */\n protected onCloseRequest(msg: Message): void {\n if (this.parent) {\n this.parent = null;\n } else if (this.isAttached) {\n Widget.detach(this);\n }\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onResize(msg: Widget.ResizeMessage): void {}\n\n /**\n * A message handler invoked on an `'update-request'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onUpdateRequest(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onFitRequest(msg: Message): void {}\n\n /**\n * A message handler invoked on an `'activate-request'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onActivateRequest(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'before-show'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onBeforeShow(msg: Message): void {}\n\n /**\n * A message handler invoked on an `'after-show'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onAfterShow(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'before-hide'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onBeforeHide(msg: Message): void {}\n\n /**\n * A message handler invoked on an `'after-hide'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onAfterHide(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onBeforeAttach(msg: Message): void {}\n\n /**\n * A message handler invoked on an `'after-attach'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onAfterAttach(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'before-detach'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onBeforeDetach(msg: Message): void {}\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onAfterDetach(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'child-added'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onChildAdded(msg: Widget.ChildMessage): void {}\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {}\n\n private _toggleHidden(hidden: boolean) {\n if (hidden) {\n switch (this._hiddenMode) {\n case Widget.HiddenMode.Display:\n this.addClass('lm-mod-hidden');\n break;\n case Widget.HiddenMode.Scale:\n this.node.style.transform = 'scale(0)';\n this.node.setAttribute('aria-hidden', 'true');\n break;\n case Widget.HiddenMode.ContentVisibility:\n // @ts-expect-error content-visibility unknown by DOM lib types\n this.node.style.contentVisibility = 'hidden';\n this.node.style.zIndex = '-1';\n break;\n }\n } else {\n switch (this._hiddenMode) {\n case Widget.HiddenMode.Display:\n this.removeClass('lm-mod-hidden');\n break;\n case Widget.HiddenMode.Scale:\n this.node.style.transform = '';\n this.node.removeAttribute('aria-hidden');\n break;\n case Widget.HiddenMode.ContentVisibility:\n // @ts-expect-error content-visibility unknown by DOM lib types\n this.node.style.contentVisibility = '';\n this.node.style.zIndex = '';\n break;\n }\n }\n }\n\n private _flags = 0;\n private _layout: Layout | null = null;\n private _parent: Widget | null = null;\n private _disposed = new Signal(this);\n private _hiddenMode: Widget.HiddenMode = Widget.HiddenMode.Display;\n}\n\n/**\n * The namespace for the `Widget` class statics.\n */\nexport namespace Widget {\n /**\n * An options object for initializing a widget.\n */\n export interface IOptions {\n /**\n * The optional node to use for the widget.\n *\n * If a node is provided, the widget will assume full ownership\n * and control of the node, as if it had created the node itself.\n *\n * The default is a new `
`.\n */\n node?: HTMLElement;\n\n /**\n * The optional element tag, used for constructing the widget's node.\n *\n * If a pre-constructed node is provided via the `node` arg, this\n * value is ignored.\n */\n tag?: keyof HTMLElementTagNameMap;\n }\n\n /**\n * The method for hiding the widget.\n *\n * The default is Display.\n *\n * Using `Scale` will often increase performance as most browsers will not\n * trigger style computation for the `transform` action. This should be used\n * sparingly and tested, since increasing the number of composition layers\n * may slow things down.\n *\n * To ensure the transformation does not trigger style recomputation, you\n * may need to set the widget CSS style `will-change: transform`. This\n * should be used only when needed as it may overwhelm the browser with a\n * high number of layers. See\n * https://developer.mozilla.org/en-US/docs/Web/CSS/will-change\n */\n export enum HiddenMode {\n /**\n * Set a `lm-mod-hidden` CSS class to hide the widget using `display:none`\n * CSS from the standard Lumino CSS.\n */\n Display = 0,\n\n /**\n * Hide the widget by setting the `transform` to `'scale(0)'`.\n */\n Scale,\n\n /**\n *Hide the widget by setting the `content-visibility` to `'hidden'`.\n */\n ContentVisibility\n }\n\n /**\n * An enum of widget bit flags.\n */\n export enum Flag {\n /**\n * The widget has been disposed.\n */\n IsDisposed = 0x1,\n\n /**\n * The widget is attached to the DOM.\n */\n IsAttached = 0x2,\n\n /**\n * The widget is hidden.\n */\n IsHidden = 0x4,\n\n /**\n * The widget is visible.\n */\n IsVisible = 0x8,\n\n /**\n * A layout cannot be set on the widget.\n */\n DisallowLayout = 0x10\n }\n\n /**\n * A collection of stateless messages related to widgets.\n */\n export namespace Msg {\n /**\n * A singleton `'before-show'` message.\n *\n * #### Notes\n * This message is sent to a widget before it becomes visible.\n *\n * This message is **not** sent when the widget is being attached.\n */\n export const BeforeShow = new Message('before-show');\n\n /**\n * A singleton `'after-show'` message.\n *\n * #### Notes\n * This message is sent to a widget after it becomes visible.\n *\n * This message is **not** sent when the widget is being attached.\n */\n export const AfterShow = new Message('after-show');\n\n /**\n * A singleton `'before-hide'` message.\n *\n * #### Notes\n * This message is sent to a widget before it becomes not-visible.\n *\n * This message is **not** sent when the widget is being detached.\n */\n export const BeforeHide = new Message('before-hide');\n\n /**\n * A singleton `'after-hide'` message.\n *\n * #### Notes\n * This message is sent to a widget after it becomes not-visible.\n *\n * This message is **not** sent when the widget is being detached.\n */\n export const AfterHide = new Message('after-hide');\n\n /**\n * A singleton `'before-attach'` message.\n *\n * #### Notes\n * This message is sent to a widget before it is attached.\n */\n export const BeforeAttach = new Message('before-attach');\n\n /**\n * A singleton `'after-attach'` message.\n *\n * #### Notes\n * This message is sent to a widget after it is attached.\n */\n export const AfterAttach = new Message('after-attach');\n\n /**\n * A singleton `'before-detach'` message.\n *\n * #### Notes\n * This message is sent to a widget before it is detached.\n */\n export const BeforeDetach = new Message('before-detach');\n\n /**\n * A singleton `'after-detach'` message.\n *\n * #### Notes\n * This message is sent to a widget after it is detached.\n */\n export const AfterDetach = new Message('after-detach');\n\n /**\n * A singleton `'parent-changed'` message.\n *\n * #### Notes\n * This message is sent to a widget when its parent has changed.\n */\n export const ParentChanged = new Message('parent-changed');\n\n /**\n * A singleton conflatable `'update-request'` message.\n *\n * #### Notes\n * This message can be dispatched to supporting widgets in order to\n * update their content based on the current widget state. Not all\n * widgets will respond to messages of this type.\n *\n * For widgets with a layout, this message will inform the layout to\n * update the position and size of its child widgets.\n */\n export const UpdateRequest = new ConflatableMessage('update-request');\n\n /**\n * A singleton conflatable `'fit-request'` message.\n *\n * #### Notes\n * For widgets with a layout, this message will inform the layout to\n * recalculate its size constraints to fit the space requirements of\n * its child widgets, and to update their position and size. Not all\n * layouts will respond to messages of this type.\n */\n export const FitRequest = new ConflatableMessage('fit-request');\n\n /**\n * A singleton conflatable `'activate-request'` message.\n *\n * #### Notes\n * This message should be dispatched to a widget when it should\n * perform the actions necessary to activate the widget, which\n * may include focusing its node or descendant node.\n */\n export const ActivateRequest = new ConflatableMessage('activate-request');\n\n /**\n * A singleton conflatable `'close-request'` message.\n *\n * #### Notes\n * This message should be dispatched to a widget when it should close\n * and remove itself from the widget hierarchy.\n */\n export const CloseRequest = new ConflatableMessage('close-request');\n }\n\n /**\n * A message class for child related messages.\n */\n export class ChildMessage extends Message {\n /**\n * Construct a new child message.\n *\n * @param type - The message type.\n *\n * @param child - The child widget for the message.\n */\n constructor(type: string, child: Widget) {\n super(type);\n this.child = child;\n }\n\n /**\n * The child widget for the message.\n */\n readonly child: Widget;\n }\n\n /**\n * A message class for `'resize'` messages.\n */\n export class ResizeMessage extends Message {\n /**\n * Construct a new resize message.\n *\n * @param width - The **offset width** of the widget, or `-1` if\n * the width is not known.\n *\n * @param height - The **offset height** of the widget, or `-1` if\n * the height is not known.\n */\n constructor(width: number, height: number) {\n super('resize');\n this.width = width;\n this.height = height;\n }\n\n /**\n * The offset width of the widget.\n *\n * #### Notes\n * This will be `-1` if the width is unknown.\n */\n readonly width: number;\n\n /**\n * The offset height of the widget.\n *\n * #### Notes\n * This will be `-1` if the height is unknown.\n */\n readonly height: number;\n }\n\n /**\n * The namespace for the `ResizeMessage` class statics.\n */\n export namespace ResizeMessage {\n /**\n * A singleton `'resize'` message with an unknown size.\n */\n export const UnknownSize = new ResizeMessage(-1, -1);\n }\n\n /**\n * Attach a widget to a host DOM node.\n *\n * @param widget - The widget of interest.\n *\n * @param host - The DOM node to use as the widget's host.\n *\n * @param ref - The child of `host` to use as the reference element.\n * If this is provided, the widget will be inserted before this\n * node in the host. The default is `null`, which will cause the\n * widget to be added as the last child of the host.\n *\n * #### Notes\n * This will throw an error if the widget is not a root widget, if\n * the widget is already attached, or if the host is not attached\n * to the DOM.\n */\n export function attach(\n widget: Widget,\n host: HTMLElement,\n ref: HTMLElement | null = null\n ): void {\n if (widget.parent) {\n throw new Error('Cannot attach a child widget.');\n }\n if (widget.isAttached || widget.node.isConnected) {\n throw new Error('Widget is already attached.');\n }\n if (!host.isConnected) {\n throw new Error('Host is not attached.');\n }\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n host.insertBefore(widget.node, ref);\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n\n /**\n * Detach the widget from its host DOM node.\n *\n * @param widget - The widget of interest.\n *\n * #### Notes\n * This will throw an error if the widget is not a root widget,\n * or if the widget is not attached to the DOM.\n */\n export function detach(widget: Widget): void {\n if (widget.parent) {\n throw new Error('Cannot detach a child widget.');\n }\n if (!widget.isAttached || !widget.node.isConnected) {\n throw new Error('Widget is not attached.');\n }\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n widget.node.parentNode!.removeChild(widget.node);\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * An attached property for the widget title object.\n */\n export const titleProperty = new AttachedProperty>({\n name: 'title',\n create: owner => new Title({ owner })\n });\n\n /**\n * Create a DOM node for the given widget options.\n */\n export function createNode(options: Widget.IOptions): HTMLElement {\n return options.node || document.createElement(options.tag || 'div');\n }\n}\n","/* eslint-disable @typescript-eslint/no-empty-function */\n// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { Signal } from '@lumino/signaling';\n\nimport { Widget } from './widget';\n\n/**\n * An abstract base class for creating lumino layouts.\n *\n * #### Notes\n * A layout is used to add widgets to a parent and to arrange those\n * widgets within the parent's DOM node.\n *\n * This class implements the base functionality which is required of\n * nearly all layouts. It must be subclassed in order to be useful.\n *\n * Notably, this class does not define a uniform interface for adding\n * widgets to the layout. A subclass should define that API in a way\n * which is meaningful for its intended use.\n */\nexport abstract class Layout implements Iterable, IDisposable {\n /**\n * Construct a new layout.\n *\n * @param options - The options for initializing the layout.\n */\n constructor(options: Layout.IOptions = {}) {\n this._fitPolicy = options.fitPolicy || 'set-min-size';\n }\n\n /**\n * Dispose of the resources held by the layout.\n *\n * #### Notes\n * This should be reimplemented to clear and dispose of the widgets.\n *\n * All reimplementations should call the superclass method.\n *\n * This method is called automatically when the parent is disposed.\n */\n dispose(): void {\n this._parent = null;\n this._disposed = true;\n Signal.clearData(this);\n AttachedProperty.clearData(this);\n }\n\n /**\n * Test whether the layout is disposed.\n */\n get isDisposed(): boolean {\n return this._disposed;\n }\n\n /**\n * Get the parent widget of the layout.\n */\n get parent(): Widget | null {\n return this._parent;\n }\n\n /**\n * Set the parent widget of the layout.\n *\n * #### Notes\n * This is set automatically when installing the layout on the parent\n * widget. The parent widget should not be set directly by user code.\n */\n set parent(value: Widget | null) {\n if (this._parent === value) {\n return;\n }\n if (this._parent) {\n throw new Error('Cannot change parent widget.');\n }\n if (value!.layout !== this) {\n throw new Error('Invalid parent widget.');\n }\n this._parent = value;\n this.init();\n }\n\n /**\n * Get the fit policy for the layout.\n *\n * #### Notes\n * The fit policy controls the computed size constraints which are\n * applied to the parent widget by the layout.\n *\n * Some layout implementations may ignore the fit policy.\n */\n get fitPolicy(): Layout.FitPolicy {\n return this._fitPolicy;\n }\n\n /**\n * Set the fit policy for the layout.\n *\n * #### Notes\n * The fit policy controls the computed size constraints which are\n * applied to the parent widget by the layout.\n *\n * Some layout implementations may ignore the fit policy.\n *\n * Changing the fit policy will clear the current size constraint\n * for the parent widget and then re-fit the parent.\n */\n set fitPolicy(value: Layout.FitPolicy) {\n // Bail if the policy does not change\n if (this._fitPolicy === value) {\n return;\n }\n\n // Update the internal policy.\n this._fitPolicy = value;\n\n // Clear the size constraints and schedule a fit of the parent.\n if (this._parent) {\n let style = this._parent.node.style;\n style.minWidth = '';\n style.minHeight = '';\n style.maxWidth = '';\n style.maxHeight = '';\n this._parent.fit();\n }\n }\n\n /**\n * Create an iterator over the widgets in the layout.\n *\n * @returns A new iterator over the widgets in the layout.\n *\n * #### Notes\n * This abstract method must be implemented by a subclass.\n */\n abstract [Symbol.iterator](): IterableIterator;\n\n /**\n * Remove a widget from the layout.\n *\n * @param widget - The widget to remove from the layout.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method should *not* modify the widget's `parent`.\n */\n abstract removeWidget(widget: Widget): void;\n\n /**\n * Process a message sent to the parent widget.\n *\n * @param msg - The message sent to the parent widget.\n *\n * #### Notes\n * This method is called by the parent widget to process a message.\n *\n * Subclasses may reimplement this method as needed.\n */\n processParentMessage(msg: Message): void {\n switch (msg.type) {\n case 'resize':\n this.onResize(msg as Widget.ResizeMessage);\n break;\n case 'update-request':\n this.onUpdateRequest(msg);\n break;\n case 'fit-request':\n this.onFitRequest(msg);\n break;\n case 'before-show':\n this.onBeforeShow(msg);\n break;\n case 'after-show':\n this.onAfterShow(msg);\n break;\n case 'before-hide':\n this.onBeforeHide(msg);\n break;\n case 'after-hide':\n this.onAfterHide(msg);\n break;\n case 'before-attach':\n this.onBeforeAttach(msg);\n break;\n case 'after-attach':\n this.onAfterAttach(msg);\n break;\n case 'before-detach':\n this.onBeforeDetach(msg);\n break;\n case 'after-detach':\n this.onAfterDetach(msg);\n break;\n case 'child-removed':\n this.onChildRemoved(msg as Widget.ChildMessage);\n break;\n case 'child-shown':\n this.onChildShown(msg as Widget.ChildMessage);\n break;\n case 'child-hidden':\n this.onChildHidden(msg as Widget.ChildMessage);\n break;\n }\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n *\n * #### Notes\n * This method is invoked immediately after the layout is installed\n * on the parent widget.\n *\n * The default implementation reparents all of the widgets to the\n * layout parent widget.\n *\n * Subclasses should reimplement this method and attach the child\n * widget nodes to the parent widget's node.\n */\n protected init(): void {\n for (const widget of this) {\n widget.parent = this.parent;\n }\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n *\n * #### Notes\n * The layout should ensure that its widgets are resized according\n * to the specified layout space, and that they are sent a `'resize'`\n * message if appropriate.\n *\n * The default implementation of this method sends an `UnknownSize`\n * resize message to all widgets.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, Widget.ResizeMessage.UnknownSize);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n *\n * #### Notes\n * The layout should ensure that its widgets are resized according\n * to the available layout space, and that they are sent a `'resize'`\n * message if appropriate.\n *\n * The default implementation of this method sends an `UnknownSize`\n * resize message to all widgets.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onUpdateRequest(msg: Message): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, Widget.ResizeMessage.UnknownSize);\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message\n * to all widgets. It assumes all widget nodes are attached to the\n * parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onBeforeAttach(msg: Message): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n\n /**\n * A message handler invoked on an `'after-attach'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message\n * to all widgets. It assumes all widget nodes are attached to the\n * parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onAfterAttach(msg: Message): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n\n /**\n * A message handler invoked on a `'before-detach'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message\n * to all widgets. It assumes all widget nodes are attached to the\n * parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onBeforeDetach(msg: Message): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message\n * to all widgets. It assumes all widget nodes are attached to the\n * parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onAfterDetach(msg: Message): void {\n for (const widget of this) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message to\n * all non-hidden widgets. It assumes all widget nodes are attached\n * to the parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onBeforeShow(msg: Message): void {\n for (const widget of this) {\n if (!widget.isHidden) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n }\n\n /**\n * A message handler invoked on an `'after-show'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message to\n * all non-hidden widgets. It assumes all widget nodes are attached\n * to the parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onAfterShow(msg: Message): void {\n for (const widget of this) {\n if (!widget.isHidden) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n }\n\n /**\n * A message handler invoked on a `'before-hide'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message to\n * all non-hidden widgets. It assumes all widget nodes are attached\n * to the parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onBeforeHide(msg: Message): void {\n for (const widget of this) {\n if (!widget.isHidden) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n }\n\n /**\n * A message handler invoked on an `'after-hide'` message.\n *\n * #### Notes\n * The default implementation of this method forwards the message to\n * all non-hidden widgets. It assumes all widget nodes are attached\n * to the parent widget node.\n *\n * This may be reimplemented by subclasses as needed.\n */\n protected onAfterHide(msg: Message): void {\n for (const widget of this) {\n if (!widget.isHidden) {\n MessageLoop.sendMessage(widget, msg);\n }\n }\n }\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n *\n * #### Notes\n * This will remove the child widget from the layout.\n *\n * Subclasses should **not** typically reimplement this method.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {\n this.removeWidget(msg.child);\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onFitRequest(msg: Message): void {}\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {}\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n *\n * #### Notes\n * The default implementation of this handler is a no-op.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {}\n\n private _disposed = false;\n private _fitPolicy: Layout.FitPolicy;\n private _parent: Widget | null = null;\n}\n\n/**\n * The namespace for the `Layout` class statics.\n */\nexport namespace Layout {\n /**\n * A type alias for the layout fit policy.\n *\n * #### Notes\n * The fit policy controls the computed size constraints which are\n * applied to the parent widget by the layout.\n *\n * Some layout implementations may ignore the fit policy.\n */\n export type FitPolicy =\n | /**\n * No size constraint will be applied to the parent widget.\n */\n 'set-no-constraint'\n\n /**\n * The computed min size will be applied to the parent widget.\n */\n | 'set-min-size';\n\n /**\n * An options object for initializing a layout.\n */\n export interface IOptions {\n /**\n * The fit policy for the layout.\n *\n * The default is `'set-min-size'`.\n */\n fitPolicy?: FitPolicy;\n }\n\n /**\n * A type alias for the horizontal alignment of a widget.\n */\n export type HorizontalAlignment = 'left' | 'center' | 'right';\n\n /**\n * A type alias for the vertical alignment of a widget.\n */\n export type VerticalAlignment = 'top' | 'center' | 'bottom';\n\n /**\n * Get the horizontal alignment for a widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The horizontal alignment for the widget.\n *\n * #### Notes\n * If the layout width allocated to a widget is larger than its max\n * width, the horizontal alignment controls how the widget is placed\n * within the extra horizontal space.\n *\n * If the allocated width is less than the widget's max width, the\n * horizontal alignment has no effect.\n *\n * Some layout implementations may ignore horizontal alignment.\n */\n export function getHorizontalAlignment(widget: Widget): HorizontalAlignment {\n return Private.horizontalAlignmentProperty.get(widget);\n }\n\n /**\n * Set the horizontal alignment for a widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the horizontal alignment.\n *\n * #### Notes\n * If the layout width allocated to a widget is larger than its max\n * width, the horizontal alignment controls how the widget is placed\n * within the extra horizontal space.\n *\n * If the allocated width is less than the widget's max width, the\n * horizontal alignment has no effect.\n *\n * Some layout implementations may ignore horizontal alignment.\n *\n * Changing the horizontal alignment will post an `update-request`\n * message to widget's parent, provided the parent has a layout\n * installed.\n */\n export function setHorizontalAlignment(\n widget: Widget,\n value: HorizontalAlignment\n ): void {\n Private.horizontalAlignmentProperty.set(widget, value);\n }\n\n /**\n * Get the vertical alignment for a widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The vertical alignment for the widget.\n *\n * #### Notes\n * If the layout height allocated to a widget is larger than its max\n * height, the vertical alignment controls how the widget is placed\n * within the extra vertical space.\n *\n * If the allocated height is less than the widget's max height, the\n * vertical alignment has no effect.\n *\n * Some layout implementations may ignore vertical alignment.\n */\n export function getVerticalAlignment(widget: Widget): VerticalAlignment {\n return Private.verticalAlignmentProperty.get(widget);\n }\n\n /**\n * Set the vertical alignment for a widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the vertical alignment.\n *\n * #### Notes\n * If the layout height allocated to a widget is larger than its max\n * height, the vertical alignment controls how the widget is placed\n * within the extra vertical space.\n *\n * If the allocated height is less than the widget's max height, the\n * vertical alignment has no effect.\n *\n * Some layout implementations may ignore vertical alignment.\n *\n * Changing the horizontal alignment will post an `update-request`\n * message to widget's parent, provided the parent has a layout\n * installed.\n */\n export function setVerticalAlignment(\n widget: Widget,\n value: VerticalAlignment\n ): void {\n Private.verticalAlignmentProperty.set(widget, value);\n }\n}\n\n/**\n * An object which assists in the absolute layout of widgets.\n *\n * #### Notes\n * This class is useful when implementing a layout which arranges its\n * widgets using absolute positioning.\n *\n * This class is used by nearly all of the built-in lumino layouts.\n */\nexport class LayoutItem implements IDisposable {\n /**\n * Construct a new layout item.\n *\n * @param widget - The widget to be managed by the item.\n *\n * #### Notes\n * The widget will be set to absolute positioning.\n * The widget will use strict CSS containment.\n */\n constructor(widget: Widget) {\n this.widget = widget;\n this.widget.node.style.position = 'absolute';\n this.widget.node.style.contain = 'strict';\n }\n\n /**\n * Dispose of the the layout item.\n *\n * #### Notes\n * This will reset the positioning of the widget.\n */\n dispose(): void {\n // Do nothing if the item is already disposed.\n if (this._disposed) {\n return;\n }\n\n // Mark the item as disposed.\n this._disposed = true;\n\n // Reset the widget style.\n let style = this.widget.node.style;\n style.position = '';\n style.top = '';\n style.left = '';\n style.width = '';\n style.height = '';\n style.contain = '';\n }\n\n /**\n * The widget managed by the layout item.\n */\n readonly widget: Widget;\n\n /**\n * The computed minimum width of the widget.\n *\n * #### Notes\n * This value can be updated by calling the `fit` method.\n */\n get minWidth(): number {\n return this._minWidth;\n }\n\n /**\n * The computed minimum height of the widget.\n *\n * #### Notes\n * This value can be updated by calling the `fit` method.\n */\n get minHeight(): number {\n return this._minHeight;\n }\n\n /**\n * The computed maximum width of the widget.\n *\n * #### Notes\n * This value can be updated by calling the `fit` method.\n */\n get maxWidth(): number {\n return this._maxWidth;\n }\n\n /**\n * The computed maximum height of the widget.\n *\n * #### Notes\n * This value can be updated by calling the `fit` method.\n */\n get maxHeight(): number {\n return this._maxHeight;\n }\n\n /**\n * Whether the layout item is disposed.\n */\n get isDisposed(): boolean {\n return this._disposed;\n }\n\n /**\n * Whether the managed widget is hidden.\n */\n get isHidden(): boolean {\n return this.widget.isHidden;\n }\n\n /**\n * Whether the managed widget is visible.\n */\n get isVisible(): boolean {\n return this.widget.isVisible;\n }\n\n /**\n * Whether the managed widget is attached.\n */\n get isAttached(): boolean {\n return this.widget.isAttached;\n }\n\n /**\n * Update the computed size limits of the managed widget.\n */\n fit(): void {\n let limits = ElementExt.sizeLimits(this.widget.node);\n this._minWidth = limits.minWidth;\n this._minHeight = limits.minHeight;\n this._maxWidth = limits.maxWidth;\n this._maxHeight = limits.maxHeight;\n }\n\n /**\n * Update the position and size of the managed widget.\n *\n * @param left - The left edge position of the layout box.\n *\n * @param top - The top edge position of the layout box.\n *\n * @param width - The width of the layout box.\n *\n * @param height - The height of the layout box.\n */\n update(left: number, top: number, width: number, height: number): void {\n // Clamp the size to the computed size limits.\n let clampW = Math.max(this._minWidth, Math.min(width, this._maxWidth));\n let clampH = Math.max(this._minHeight, Math.min(height, this._maxHeight));\n\n // Adjust the left edge for the horizontal alignment, if needed.\n if (clampW < width) {\n switch (Layout.getHorizontalAlignment(this.widget)) {\n case 'left':\n break;\n case 'center':\n left += (width - clampW) / 2;\n break;\n case 'right':\n left += width - clampW;\n break;\n default:\n throw 'unreachable';\n }\n }\n\n // Adjust the top edge for the vertical alignment, if needed.\n if (clampH < height) {\n switch (Layout.getVerticalAlignment(this.widget)) {\n case 'top':\n break;\n case 'center':\n top += (height - clampH) / 2;\n break;\n case 'bottom':\n top += height - clampH;\n break;\n default:\n throw 'unreachable';\n }\n }\n\n // Set up the resize variables.\n let resized = false;\n let style = this.widget.node.style;\n\n // Update the top edge of the widget if needed.\n if (this._top !== top) {\n this._top = top;\n style.top = `${top}px`;\n }\n\n // Update the left edge of the widget if needed.\n if (this._left !== left) {\n this._left = left;\n style.left = `${left}px`;\n }\n\n // Update the width of the widget if needed.\n if (this._width !== clampW) {\n resized = true;\n this._width = clampW;\n style.width = `${clampW}px`;\n }\n\n // Update the height of the widget if needed.\n if (this._height !== clampH) {\n resized = true;\n this._height = clampH;\n style.height = `${clampH}px`;\n }\n\n // Send a resize message to the widget if needed.\n if (resized) {\n let msg = new Widget.ResizeMessage(clampW, clampH);\n MessageLoop.sendMessage(this.widget, msg);\n }\n }\n\n private _top = NaN;\n private _left = NaN;\n private _width = NaN;\n private _height = NaN;\n private _minWidth = 0;\n private _minHeight = 0;\n private _maxWidth = Infinity;\n private _maxHeight = Infinity;\n private _disposed = false;\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The attached property for a widget horizontal alignment.\n */\n export const horizontalAlignmentProperty = new AttachedProperty<\n Widget,\n Layout.HorizontalAlignment\n >({\n name: 'horizontalAlignment',\n create: () => 'center',\n changed: onAlignmentChanged\n });\n\n /**\n * The attached property for a widget vertical alignment.\n */\n export const verticalAlignmentProperty = new AttachedProperty<\n Widget,\n Layout.VerticalAlignment\n >({\n name: 'verticalAlignment',\n create: () => 'top',\n changed: onAlignmentChanged\n });\n\n /**\n * The change handler for the attached alignment properties.\n */\n function onAlignmentChanged(child: Widget): void {\n if (child.parent && child.parent.layout) {\n child.parent.update();\n }\n }\n}\n","/*\n * Copyright (c) Jupyter Development Team.\n * Distributed under the terms of the Modified BSD License.\n */\n\nexport namespace Utils {\n /**\n * Clamp a dimension value to an integer >= 0.\n */\n export function clampDimension(value: number): number {\n return Math.max(0, Math.floor(value));\n }\n}\n\nexport default Utils;\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { VirtualElement } from '@lumino/virtualdom';\n\n/**\n * An object which holds data related to an object's title.\n *\n * #### Notes\n * A title object is intended to hold the data necessary to display a\n * header for a particular object. A common example is the `TabPanel`,\n * which uses the widget title to populate the tab for a child widget.\n *\n * It is the responsibility of the owner to call the title disposal.\n */\nexport class Title implements IDisposable {\n /**\n * Construct a new title.\n *\n * @param options - The options for initializing the title.\n */\n constructor(options: Title.IOptions) {\n this.owner = options.owner;\n if (options.label !== undefined) {\n this._label = options.label;\n }\n if (options.mnemonic !== undefined) {\n this._mnemonic = options.mnemonic;\n }\n if (options.icon !== undefined) {\n this._icon = options.icon;\n }\n\n if (options.iconClass !== undefined) {\n this._iconClass = options.iconClass;\n }\n if (options.iconLabel !== undefined) {\n this._iconLabel = options.iconLabel;\n }\n if (options.caption !== undefined) {\n this._caption = options.caption;\n }\n if (options.className !== undefined) {\n this._className = options.className;\n }\n if (options.closable !== undefined) {\n this._closable = options.closable;\n }\n this._dataset = options.dataset || {};\n }\n\n /**\n * A signal emitted when the state of the title changes.\n */\n get changed(): ISignal {\n return this._changed;\n }\n\n /**\n * The object which owns the title.\n */\n readonly owner: T;\n\n /**\n * Get the label for the title.\n *\n * #### Notes\n * The default value is an empty string.\n */\n get label(): string {\n return this._label;\n }\n\n /**\n * Set the label for the title.\n */\n set label(value: string) {\n if (this._label === value) {\n return;\n }\n this._label = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the mnemonic index for the title.\n *\n * #### Notes\n * The default value is `-1`.\n */\n get mnemonic(): number {\n return this._mnemonic;\n }\n\n /**\n * Set the mnemonic index for the title.\n */\n set mnemonic(value: number) {\n if (this._mnemonic === value) {\n return;\n }\n this._mnemonic = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the icon renderer for the title.\n *\n * #### Notes\n * The default value is undefined.\n */\n get icon(): VirtualElement.IRenderer | undefined {\n return this._icon;\n }\n\n /**\n * Set the icon renderer for the title.\n *\n * #### Notes\n * A renderer is an object that supplies a render and unrender function.\n */\n set icon(value: VirtualElement.IRenderer | undefined) {\n if (this._icon === value) {\n return;\n }\n this._icon = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the icon class name for the title.\n *\n * #### Notes\n * The default value is an empty string.\n */\n get iconClass(): string {\n return this._iconClass;\n }\n\n /**\n * Set the icon class name for the title.\n *\n * #### Notes\n * Multiple class names can be separated with whitespace.\n */\n set iconClass(value: string) {\n if (this._iconClass === value) {\n return;\n }\n this._iconClass = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the icon label for the title.\n *\n * #### Notes\n * The default value is an empty string.\n */\n get iconLabel(): string {\n return this._iconLabel;\n }\n\n /**\n * Set the icon label for the title.\n *\n * #### Notes\n * Multiple class names can be separated with whitespace.\n */\n set iconLabel(value: string) {\n if (this._iconLabel === value) {\n return;\n }\n this._iconLabel = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the caption for the title.\n *\n * #### Notes\n * The default value is an empty string.\n */\n get caption(): string {\n return this._caption;\n }\n\n /**\n * Set the caption for the title.\n */\n set caption(value: string) {\n if (this._caption === value) {\n return;\n }\n this._caption = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the extra class name for the title.\n *\n * #### Notes\n * The default value is an empty string.\n */\n get className(): string {\n return this._className;\n }\n\n /**\n * Set the extra class name for the title.\n *\n * #### Notes\n * Multiple class names can be separated with whitespace.\n */\n set className(value: string) {\n if (this._className === value) {\n return;\n }\n this._className = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the closable state for the title.\n *\n * #### Notes\n * The default value is `false`.\n */\n get closable(): boolean {\n return this._closable;\n }\n\n /**\n * Set the closable state for the title.\n *\n * #### Notes\n * This controls the presence of a close icon when applicable.\n */\n set closable(value: boolean) {\n if (this._closable === value) {\n return;\n }\n this._closable = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Get the dataset for the title.\n *\n * #### Notes\n * The default value is an empty dataset.\n */\n get dataset(): Title.Dataset {\n return this._dataset;\n }\n\n /**\n * Set the dataset for the title.\n *\n * #### Notes\n * This controls the data attributes when applicable.\n */\n set dataset(value: Title.Dataset) {\n if (this._dataset === value) {\n return;\n }\n this._dataset = value;\n this._changed.emit(undefined);\n }\n\n /**\n * Test whether the title has been disposed.\n */\n get isDisposed(): boolean {\n return this._isDisposed;\n }\n\n /**\n * Dispose of the resources held by the title.\n *\n * #### Notes\n * It is the responsibility of the owner to call the title disposal.\n */\n dispose(): void {\n if (this.isDisposed) {\n return;\n }\n this._isDisposed = true;\n\n Signal.clearData(this);\n }\n\n private _label = '';\n private _caption = '';\n private _mnemonic = -1;\n private _icon: VirtualElement.IRenderer | undefined = undefined;\n private _iconClass = '';\n private _iconLabel = '';\n private _className = '';\n private _closable = false;\n private _dataset: Title.Dataset;\n private _changed = new Signal(this);\n private _isDisposed = false;\n}\n\n/**\n * The namespace for the `Title` class statics.\n */\nexport namespace Title {\n /**\n * A type alias for a simple immutable string dataset.\n */\n export type Dataset = { readonly [key: string]: string };\n\n /**\n * An options object for initializing a title.\n */\n export interface IOptions {\n /**\n * The object which owns the title.\n */\n owner: T;\n\n /**\n * The label for the title.\n */\n label?: string;\n\n /**\n * The mnemonic index for the title.\n */\n mnemonic?: number;\n\n /**\n * The icon renderer for the title.\n */\n icon?: VirtualElement.IRenderer;\n\n /**\n * The icon class name for the title.\n */\n iconClass?: string;\n\n /**\n * The icon label for the title.\n */\n iconLabel?: string;\n\n /**\n * The caption for the title.\n */\n caption?: string;\n\n /**\n * The extra class name for the title.\n */\n className?: string;\n\n /**\n * The closable state for the title.\n */\n closable?: boolean;\n\n /**\n * The dataset for the title.\n */\n dataset?: Dataset;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { MessageLoop } from '@lumino/messaging';\n\nimport { Layout } from './layout';\n\nimport { Widget } from './widget';\n\n/**\n * A concrete layout implementation suitable for many use cases.\n *\n * #### Notes\n * This class is suitable as a base class for implementing a variety of\n * layouts, but can also be used directly with standard CSS to layout a\n * collection of widgets.\n */\nexport class PanelLayout extends Layout {\n /**\n * Dispose of the resources held by the layout.\n *\n * #### Notes\n * This will clear and dispose all widgets in the layout.\n *\n * All reimplementations should call the superclass method.\n *\n * This method is called automatically when the parent is disposed.\n */\n dispose(): void {\n while (this._widgets.length > 0) {\n this._widgets.pop()!.dispose();\n }\n super.dispose();\n }\n\n /**\n * A read-only array of the widgets in the layout.\n */\n get widgets(): ReadonlyArray {\n return this._widgets;\n }\n\n /**\n * Create an iterator over the widgets in the layout.\n *\n * @returns A new iterator over the widgets in the layout.\n */\n *[Symbol.iterator](): IterableIterator {\n yield* this._widgets;\n }\n\n /**\n * Add a widget to the end of the layout.\n *\n * @param widget - The widget to add to the layout.\n *\n * #### Notes\n * If the widget is already contained in the layout, it will be moved.\n */\n addWidget(widget: Widget): void {\n this.insertWidget(this._widgets.length, widget);\n }\n\n /**\n * Insert a widget into the layout at the specified index.\n *\n * @param index - The index at which to insert the widget.\n *\n * @param widget - The widget to insert into the layout.\n *\n * #### Notes\n * The index will be clamped to the bounds of the widgets.\n *\n * If the widget is already added to the layout, it will be moved.\n *\n * #### Undefined Behavior\n * An `index` which is non-integral.\n */\n insertWidget(index: number, widget: Widget): void {\n // Remove the widget from its current parent. This is a no-op\n // if the widget's parent is already the layout parent widget.\n widget.parent = this.parent;\n\n // Look up the current index of the widget.\n let i = this._widgets.indexOf(widget);\n\n // Clamp the insert index to the array bounds.\n let j = Math.max(0, Math.min(index, this._widgets.length));\n\n // If the widget is not in the array, insert it.\n if (i === -1) {\n // Insert the widget into the array.\n ArrayExt.insert(this._widgets, j, widget);\n\n // If the layout is parented, attach the widget to the DOM.\n if (this.parent) {\n this.attachWidget(j, widget);\n }\n\n // There is nothing more to do.\n return;\n }\n\n // Otherwise, the widget exists in the array and should be moved.\n\n // Adjust the index if the location is at the end of the array.\n if (j === this._widgets.length) {\n j--;\n }\n\n // Bail if there is no effective move.\n if (i === j) {\n return;\n }\n\n // Move the widget to the new location.\n ArrayExt.move(this._widgets, i, j);\n\n // If the layout is parented, move the widget in the DOM.\n if (this.parent) {\n this.moveWidget(i, j, widget);\n }\n }\n\n /**\n * Remove a widget from the layout.\n *\n * @param widget - The widget to remove from the layout.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method does *not* modify the widget's `parent`.\n */\n removeWidget(widget: Widget): void {\n this.removeWidgetAt(this._widgets.indexOf(widget));\n }\n\n /**\n * Remove the widget at a given index from the layout.\n *\n * @param index - The index of the widget to remove.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method does *not* modify the widget's `parent`.\n *\n * #### Undefined Behavior\n * An `index` which is non-integral.\n */\n removeWidgetAt(index: number): void {\n // Remove the widget from the array.\n let widget = ArrayExt.removeAt(this._widgets, index);\n\n // If the layout is parented, detach the widget from the DOM.\n if (widget && this.parent) {\n this.detachWidget(index, widget);\n }\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n super.init();\n let index = 0;\n for (const widget of this) {\n this.attachWidget(index++, widget);\n }\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param index - The current index of the widget in the layout.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This method is called automatically by the panel layout at the\n * appropriate time. It should not be called directly by user code.\n *\n * The default implementation adds the widgets's node to the parent's\n * node at the proper location, and sends the appropriate attach\n * messages to the widget if the parent is attached to the DOM.\n *\n * Subclasses may reimplement this method to control how the widget's\n * node is added to the parent's node.\n */\n protected attachWidget(index: number, widget: Widget): void {\n // Look up the next sibling reference node.\n let ref = this.parent!.node.children[index];\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Insert the widget's node before the sibling.\n this.parent!.node.insertBefore(widget.node, ref);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n }\n\n /**\n * Move a widget in the parent's DOM node.\n *\n * @param fromIndex - The previous index of the widget in the layout.\n *\n * @param toIndex - The current index of the widget in the layout.\n *\n * @param widget - The widget to move in the parent.\n *\n * #### Notes\n * This method is called automatically by the panel layout at the\n * appropriate time. It should not be called directly by user code.\n *\n * The default implementation moves the widget's node to the proper\n * location in the parent's node and sends the appropriate attach and\n * detach messages to the widget if the parent is attached to the DOM.\n *\n * Subclasses may reimplement this method to control how the widget's\n * node is moved in the parent's node.\n */\n protected moveWidget(\n fromIndex: number,\n toIndex: number,\n widget: Widget\n ): void {\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` and message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Look up the next sibling reference node.\n let ref = this.parent!.node.children[toIndex];\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Insert the widget's node before the sibling.\n this.parent!.node.insertBefore(widget.node, ref);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param index - The previous index of the widget in the layout.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This method is called automatically by the panel layout at the\n * appropriate time. It should not be called directly by user code.\n *\n * The default implementation removes the widget's node from the\n * parent's node, and sends the appropriate detach messages to the\n * widget if the parent is attached to the DOM.\n *\n * Subclasses may reimplement this method to control how the widget's\n * node is removed from the parent's node.\n */\n protected detachWidget(index: number, widget: Widget): void {\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n }\n\n private _widgets: Widget[] = [];\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { BoxEngine, BoxSizer } from './boxengine';\n\nimport { LayoutItem } from './layout';\n\nimport { PanelLayout } from './panellayout';\n\nimport { Utils } from './utils';\n\nimport { Widget } from './widget';\n\n/**\n * A layout which arranges its widgets into resizable sections.\n */\nexport class SplitLayout extends PanelLayout {\n /**\n * Construct a new split layout.\n *\n * @param options - The options for initializing the layout.\n */\n constructor(options: SplitLayout.IOptions) {\n super();\n this.renderer = options.renderer;\n if (options.orientation !== undefined) {\n this._orientation = options.orientation;\n }\n if (options.alignment !== undefined) {\n this._alignment = options.alignment;\n }\n if (options.spacing !== undefined) {\n this._spacing = Utils.clampDimension(options.spacing);\n }\n }\n\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n // Dispose of the layout items.\n for (const item of this._items) {\n item.dispose();\n }\n\n // Clear the layout state.\n this._box = null;\n this._items.length = 0;\n this._sizers.length = 0;\n this._handles.length = 0;\n\n // Dispose of the rest of the layout.\n super.dispose();\n }\n\n /**\n * The renderer used by the split layout.\n */\n readonly renderer: SplitLayout.IRenderer;\n\n /**\n * Get the layout orientation for the split layout.\n */\n get orientation(): SplitLayout.Orientation {\n return this._orientation;\n }\n\n /**\n * Set the layout orientation for the split layout.\n */\n set orientation(value: SplitLayout.Orientation) {\n if (this._orientation === value) {\n return;\n }\n this._orientation = value;\n if (!this.parent) {\n return;\n }\n this.parent.dataset['orientation'] = value;\n this.parent.fit();\n }\n\n /**\n * Get the content alignment for the split layout.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire split layout.\n */\n get alignment(): SplitLayout.Alignment {\n return this._alignment;\n }\n\n /**\n * Set the content alignment for the split layout.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire split layout.\n */\n set alignment(value: SplitLayout.Alignment) {\n if (this._alignment === value) {\n return;\n }\n this._alignment = value;\n if (!this.parent) {\n return;\n }\n this.parent.dataset['alignment'] = value;\n this.parent.update();\n }\n\n /**\n * Get the inter-element spacing for the split layout.\n */\n get spacing(): number {\n return this._spacing;\n }\n\n /**\n * Set the inter-element spacing for the split layout.\n */\n set spacing(value: number) {\n value = Utils.clampDimension(value);\n if (this._spacing === value) {\n return;\n }\n this._spacing = value;\n if (!this.parent) {\n return;\n }\n this.parent.fit();\n }\n\n /**\n * A read-only array of the split handles in the layout.\n */\n get handles(): ReadonlyArray {\n return this._handles;\n }\n\n /**\n * Get the absolute sizes of the widgets in the layout.\n *\n * @returns A new array of the absolute sizes of the widgets.\n *\n * This method **does not** measure the DOM nodes.\n */\n absoluteSizes(): number[] {\n return this._sizers.map(sizer => sizer.size);\n }\n\n /**\n * Get the relative sizes of the widgets in the layout.\n *\n * @returns A new array of the relative sizes of the widgets.\n *\n * #### Notes\n * The returned sizes reflect the sizes of the widgets normalized\n * relative to their siblings.\n *\n * This method **does not** measure the DOM nodes.\n */\n relativeSizes(): number[] {\n return Private.normalize(this._sizers.map(sizer => sizer.size));\n }\n\n /**\n * Set the relative sizes for the widgets in the layout.\n *\n * @param sizes - The relative sizes for the widgets in the panel.\n * @param update - Update the layout after setting relative sizes.\n * Default is True.\n *\n * #### Notes\n * Extra values are ignored, too few will yield an undefined layout.\n *\n * The actual geometry of the DOM nodes is updated asynchronously.\n */\n setRelativeSizes(sizes: number[], update = true): void {\n // Copy the sizes and pad with zeros as needed.\n let n = this._sizers.length;\n let temp = sizes.slice(0, n);\n while (temp.length < n) {\n temp.push(0);\n }\n\n // Normalize the padded sizes.\n let normed = Private.normalize(temp);\n\n // Apply the normalized sizes to the sizers.\n for (let i = 0; i < n; ++i) {\n let sizer = this._sizers[i];\n sizer.sizeHint = normed[i];\n sizer.size = normed[i];\n }\n\n // Set the flag indicating the sizes are normalized.\n this._hasNormedSizes = true;\n\n // Trigger an update of the parent widget.\n if (update && this.parent) {\n this.parent.update();\n }\n }\n\n /**\n * Move the offset position of a split handle.\n *\n * @param index - The index of the handle of the interest.\n *\n * @param position - The desired offset position of the handle.\n *\n * #### Notes\n * The position is relative to the offset parent.\n *\n * This will move the handle as close as possible to the desired\n * position. The sibling widgets will be adjusted as necessary.\n */\n moveHandle(index: number, position: number): void {\n // Bail if the index is invalid or the handle is hidden.\n let handle = this._handles[index];\n if (!handle || handle.classList.contains('lm-mod-hidden')) {\n return;\n }\n\n // Compute the desired delta movement for the handle.\n let delta: number;\n if (this._orientation === 'horizontal') {\n delta = position - handle.offsetLeft;\n } else {\n delta = position - handle.offsetTop;\n }\n\n // Bail if there is no handle movement.\n if (delta === 0) {\n return;\n }\n\n // Prevent widget resizing unless needed.\n for (let sizer of this._sizers) {\n if (sizer.size > 0) {\n sizer.sizeHint = sizer.size;\n }\n }\n\n // Adjust the sizers to reflect the handle movement.\n BoxEngine.adjust(this._sizers, index, delta);\n\n // Update the layout of the widgets.\n if (this.parent) {\n this.parent.update();\n }\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n this.parent!.dataset['orientation'] = this.orientation;\n this.parent!.dataset['alignment'] = this.alignment;\n super.init();\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param index - The current index of the widget in the layout.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected attachWidget(index: number, widget: Widget): void {\n // Create the item, handle, and sizer for the new widget.\n let item = new LayoutItem(widget);\n let handle = Private.createHandle(this.renderer);\n let average = Private.averageSize(this._sizers);\n let sizer = Private.createSizer(average);\n\n // Insert the item, handle, and sizer into the internal arrays.\n ArrayExt.insert(this._items, index, item);\n ArrayExt.insert(this._sizers, index, sizer);\n ArrayExt.insert(this._handles, index, handle);\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget and handle nodes to the parent.\n this.parent!.node.appendChild(widget.node);\n this.parent!.node.appendChild(handle);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * Move a widget in the parent's DOM node.\n *\n * @param fromIndex - The previous index of the widget in the layout.\n *\n * @param toIndex - The current index of the widget in the layout.\n *\n * @param widget - The widget to move in the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected moveWidget(\n fromIndex: number,\n toIndex: number,\n widget: Widget\n ): void {\n // Move the item, sizer, and handle for the widget.\n ArrayExt.move(this._items, fromIndex, toIndex);\n ArrayExt.move(this._sizers, fromIndex, toIndex);\n ArrayExt.move(this._handles, fromIndex, toIndex);\n\n // Post a fit request to the parent to show/hide last handle.\n this.parent!.fit();\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param index - The previous index of the widget in the layout.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected detachWidget(index: number, widget: Widget): void {\n // Remove the item, handle, and sizer for the widget.\n let item = ArrayExt.removeAt(this._items, index);\n let handle = ArrayExt.removeAt(this._handles, index);\n ArrayExt.removeAt(this._sizers, index);\n\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget and handle nodes from the parent.\n this.parent!.node.removeChild(widget.node);\n this.parent!.node.removeChild(handle!);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Dispose of the layout item.\n item!.dispose();\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n */\n protected onBeforeShow(msg: Message): void {\n super.onBeforeShow(msg);\n this.parent!.update();\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n super.onBeforeAttach(msg);\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n if (this.parent!.isVisible) {\n this._update(msg.width, msg.height);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.parent!.isVisible) {\n this._update(-1, -1);\n }\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n */\n protected onFitRequest(msg: Message): void {\n if (this.parent!.isAttached) {\n this._fit();\n }\n }\n\n /**\n * Update the item position.\n *\n * @param i Item index\n * @param isHorizontal Whether the layout is horizontal or not\n * @param left Left position in pixels\n * @param top Top position in pixels\n * @param height Item height\n * @param width Item width\n * @param size Item size\n */\n protected updateItemPosition(\n i: number,\n isHorizontal: boolean,\n left: number,\n top: number,\n height: number,\n width: number,\n size: number\n ): void {\n const item = this._items[i];\n if (item.isHidden) {\n return;\n }\n\n // Fetch the style for the handle.\n let handleStyle = this._handles[i].style;\n\n // Update the widget and handle, and advance the relevant edge.\n if (isHorizontal) {\n left += this.widgetOffset;\n item.update(left, top, size, height);\n left += size;\n handleStyle.top = `${top}px`;\n handleStyle.left = `${left}px`;\n handleStyle.width = `${this._spacing}px`;\n handleStyle.height = `${height}px`;\n } else {\n top += this.widgetOffset;\n item.update(left, top, width, size);\n top += size;\n handleStyle.top = `${top}px`;\n handleStyle.left = `${left}px`;\n handleStyle.width = `${width}px`;\n handleStyle.height = `${this._spacing}px`;\n }\n }\n\n /**\n * Fit the layout to the total size required by the widgets.\n */\n private _fit(): void {\n // Update the handles and track the visible widget count.\n let nVisible = 0;\n let lastHandleIndex = -1;\n for (let i = 0, n = this._items.length; i < n; ++i) {\n if (this._items[i].isHidden) {\n this._handles[i].classList.add('lm-mod-hidden');\n } else {\n this._handles[i].classList.remove('lm-mod-hidden');\n lastHandleIndex = i;\n nVisible++;\n }\n }\n\n // Hide the handle for the last visible widget.\n if (lastHandleIndex !== -1) {\n this._handles[lastHandleIndex].classList.add('lm-mod-hidden');\n }\n\n // Update the fixed space for the visible items.\n this._fixed =\n this._spacing * Math.max(0, nVisible - 1) +\n this.widgetOffset * this._items.length;\n\n // Setup the computed minimum size.\n let horz = this._orientation === 'horizontal';\n let minW = horz ? this._fixed : 0;\n let minH = horz ? 0 : this._fixed;\n\n // Update the sizers and computed size limits.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item and corresponding box sizer.\n let item = this._items[i];\n let sizer = this._sizers[i];\n\n // Prevent resizing unless necessary.\n if (sizer.size > 0) {\n sizer.sizeHint = sizer.size;\n }\n\n // If the item is hidden, it should consume zero size.\n if (item.isHidden) {\n sizer.minSize = 0;\n sizer.maxSize = 0;\n continue;\n }\n\n // Update the size limits for the item.\n item.fit();\n\n // Update the stretch factor.\n sizer.stretch = SplitLayout.getStretch(item.widget);\n\n // Update the sizer limits and computed min size.\n if (horz) {\n sizer.minSize = item.minWidth;\n sizer.maxSize = item.maxWidth;\n minW += item.minWidth;\n minH = Math.max(minH, item.minHeight);\n } else {\n sizer.minSize = item.minHeight;\n sizer.maxSize = item.maxHeight;\n minH += item.minHeight;\n minW = Math.max(minW, item.minWidth);\n }\n }\n\n // Update the box sizing and add it to the computed min size.\n let box = (this._box = ElementExt.boxSizing(this.parent!.node));\n minW += box.horizontalSum;\n minH += box.verticalSum;\n\n // Update the parent's min size constraints.\n let style = this.parent!.node.style;\n style.minWidth = `${minW}px`;\n style.minHeight = `${minH}px`;\n\n // Set the dirty flag to ensure only a single update occurs.\n this._dirty = true;\n\n // Notify the ancestor that it should fit immediately. This may\n // cause a resize of the parent, fulfilling the required update.\n if (this.parent!.parent) {\n MessageLoop.sendMessage(this.parent!.parent!, Widget.Msg.FitRequest);\n }\n\n // If the dirty flag is still set, the parent was not resized.\n // Trigger the required update on the parent widget immediately.\n if (this._dirty) {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n }\n }\n\n /**\n * Update the layout position and size of the widgets.\n *\n * The parent offset dimensions should be `-1` if unknown.\n */\n private _update(offsetWidth: number, offsetHeight: number): void {\n // Clear the dirty flag to indicate the update occurred.\n this._dirty = false;\n\n // Compute the visible item count.\n let nVisible = 0;\n for (let i = 0, n = this._items.length; i < n; ++i) {\n nVisible += +!this._items[i].isHidden;\n }\n\n // Bail early if there are no visible items to layout.\n if (nVisible === 0 && this.widgetOffset === 0) {\n return;\n }\n\n // Measure the parent if the offset dimensions are unknown.\n if (offsetWidth < 0) {\n offsetWidth = this.parent!.node.offsetWidth;\n }\n if (offsetHeight < 0) {\n offsetHeight = this.parent!.node.offsetHeight;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent!.node);\n }\n\n // Compute the actual layout bounds adjusted for border and padding.\n let top = this._box.paddingTop;\n let left = this._box.paddingLeft;\n let width = offsetWidth - this._box.horizontalSum;\n let height = offsetHeight - this._box.verticalSum;\n\n // Set up the variables for justification and alignment offset.\n let extra = 0;\n let offset = 0;\n let horz = this._orientation === 'horizontal';\n\n if (nVisible > 0) {\n // Compute the adjusted layout space.\n let space: number;\n if (horz) {\n // left += this.widgetOffset;\n space = Math.max(0, width - this._fixed);\n } else {\n // top += this.widgetOffset;\n space = Math.max(0, height - this._fixed);\n }\n\n // Scale the size hints if they are normalized.\n if (this._hasNormedSizes) {\n for (let sizer of this._sizers) {\n sizer.sizeHint *= space;\n }\n this._hasNormedSizes = false;\n }\n\n // Distribute the layout space to the box sizers.\n let delta = BoxEngine.calc(this._sizers, space);\n\n // Account for alignment if there is extra layout space.\n if (delta > 0) {\n switch (this._alignment) {\n case 'start':\n break;\n case 'center':\n extra = 0;\n offset = delta / 2;\n break;\n case 'end':\n extra = 0;\n offset = delta;\n break;\n case 'justify':\n extra = delta / nVisible;\n offset = 0;\n break;\n default:\n throw 'unreachable';\n }\n }\n }\n\n // Layout the items using the computed box sizes.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item.\n const item = this._items[i];\n\n // Fetch the computed size for the widget.\n const size = item.isHidden ? 0 : this._sizers[i].size + extra;\n\n this.updateItemPosition(\n i,\n horz,\n horz ? left + offset : left,\n horz ? top : top + offset,\n height,\n width,\n size\n );\n\n const fullOffset =\n this.widgetOffset +\n (this._handles[i].classList.contains('lm-mod-hidden')\n ? 0\n : this._spacing);\n\n if (horz) {\n left += size + fullOffset;\n } else {\n top += size + fullOffset;\n }\n }\n }\n\n protected widgetOffset = 0;\n private _fixed = 0;\n private _spacing = 4;\n private _dirty = false;\n private _hasNormedSizes = false;\n private _sizers: BoxSizer[] = [];\n private _items: LayoutItem[] = [];\n private _handles: HTMLDivElement[] = [];\n private _box: ElementExt.IBoxSizing | null = null;\n private _alignment: SplitLayout.Alignment = 'start';\n private _orientation: SplitLayout.Orientation = 'horizontal';\n}\n\n/**\n * The namespace for the `SplitLayout` class statics.\n */\nexport namespace SplitLayout {\n /**\n * A type alias for a split layout orientation.\n */\n export type Orientation = 'horizontal' | 'vertical';\n\n /**\n * A type alias for a split layout alignment.\n */\n export type Alignment = 'start' | 'center' | 'end' | 'justify';\n\n /**\n * An options object for initializing a split layout.\n */\n export interface IOptions {\n /**\n * The renderer to use for the split layout.\n */\n renderer: IRenderer;\n\n /**\n * The orientation of the layout.\n *\n * The default is `'horizontal'`.\n */\n orientation?: Orientation;\n\n /**\n * The content alignment of the layout.\n *\n * The default is `'start'`.\n */\n alignment?: Alignment;\n\n /**\n * The spacing between items in the layout.\n *\n * The default is `4`.\n */\n spacing?: number;\n }\n\n /**\n * A renderer for use with a split layout.\n */\n export interface IRenderer {\n /**\n * Create a new handle for use with a split layout.\n *\n * @returns A new handle element.\n */\n createHandle(): HTMLDivElement;\n }\n\n /**\n * Get the split layout stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The split layout stretch factor for the widget.\n */\n export function getStretch(widget: Widget): number {\n return Private.stretchProperty.get(widget);\n }\n\n /**\n * Set the split layout stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the stretch factor.\n */\n export function setStretch(widget: Widget, value: number): void {\n Private.stretchProperty.set(widget, value);\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The property descriptor for a widget stretch factor.\n */\n export const stretchProperty = new AttachedProperty({\n name: 'stretch',\n create: () => 0,\n coerce: (owner, value) => Math.max(0, Math.floor(value)),\n changed: onChildSizingChanged\n });\n\n /**\n * Create a new box sizer with the given size hint.\n */\n export function createSizer(size: number): BoxSizer {\n let sizer = new BoxSizer();\n sizer.sizeHint = Math.floor(size);\n return sizer;\n }\n\n /**\n * Create a new split handle node using the given renderer.\n */\n export function createHandle(\n renderer: SplitLayout.IRenderer\n ): HTMLDivElement {\n let handle = renderer.createHandle();\n handle.style.position = 'absolute';\n // Do not use size containment to allow the handle to fill the available space\n handle.style.contain = 'style';\n return handle;\n }\n\n /**\n * Compute the average size of an array of box sizers.\n */\n export function averageSize(sizers: BoxSizer[]): number {\n return sizers.reduce((v, s) => v + s.size, 0) / sizers.length || 0;\n }\n\n /**\n * Normalize an array of values.\n */\n export function normalize(values: number[]): number[] {\n let n = values.length;\n if (n === 0) {\n return [];\n }\n let sum = values.reduce((a, b) => a + Math.abs(b), 0);\n return sum === 0 ? values.map(v => 1 / n) : values.map(v => v / sum);\n }\n\n /**\n * The change handler for the attached sizing properties.\n */\n function onChildSizingChanged(child: Widget): void {\n if (child.parent && child.parent.layout instanceof SplitLayout) {\n child.parent.fit();\n }\n }\n}\n","/*\n * Copyright (c) Jupyter Development Team.\n * Distributed under the terms of the Modified BSD License.\n */\n\nimport { ArrayExt } from '@lumino/algorithm';\nimport { UUID } from '@lumino/coreutils';\nimport { SplitLayout } from './splitlayout';\nimport { Title } from './title';\nimport Utils from './utils';\nimport { Widget } from './widget';\n\n/**\n * A layout which arranges its widgets into collapsible resizable sections.\n */\nexport class AccordionLayout extends SplitLayout {\n /**\n * Construct a new accordion layout.\n *\n * @param options - The options for initializing the layout.\n *\n * #### Notes\n * The default orientation will be vertical.\n *\n * Titles must be rotated for horizontal accordion panel using CSS: see accordionpanel.css\n */\n constructor(options: AccordionLayout.IOptions) {\n super({ ...options, orientation: options.orientation || 'vertical' });\n this.titleSpace = options.titleSpace || 22;\n }\n\n /**\n * The section title height or width depending on the orientation.\n */\n get titleSpace(): number {\n return this.widgetOffset;\n }\n set titleSpace(value: number) {\n value = Utils.clampDimension(value);\n if (this.widgetOffset === value) {\n return;\n }\n this.widgetOffset = value;\n if (!this.parent) {\n return;\n }\n this.parent.fit();\n }\n\n /**\n * A read-only array of the section titles in the panel.\n */\n get titles(): ReadonlyArray {\n return this._titles;\n }\n\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n if (this.isDisposed) {\n return;\n }\n\n // Clear the layout state.\n this._titles.length = 0;\n\n // Dispose of the rest of the layout.\n super.dispose();\n }\n\n /**\n * The renderer used by the accordion layout.\n */\n readonly renderer: AccordionLayout.IRenderer;\n\n public updateTitle(index: number, widget: Widget): void {\n const oldTitle = this._titles[index];\n const expanded = oldTitle.classList.contains('lm-mod-expanded');\n const newTitle = Private.createTitle(this.renderer, widget.title, expanded);\n this._titles[index] = newTitle;\n\n // Add the title node to the parent before the widget.\n this.parent!.node.replaceChild(newTitle, oldTitle);\n }\n\n /**\n * Insert a widget into the layout at the specified index.\n *\n * @param index - The index at which to insert the widget.\n *\n * @param widget - The widget to insert into the layout.\n *\n * #### Notes\n * The index will be clamped to the bounds of the widgets.\n *\n * If the widget is already added to the layout, it will be moved.\n *\n * #### Undefined Behavior\n * An `index` which is non-integral.\n */\n insertWidget(index: number, widget: Widget): void {\n if (!widget.id) {\n widget.id = `id-${UUID.uuid4()}`;\n }\n super.insertWidget(index, widget);\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param index - The current index of the widget in the layout.\n *\n * @param widget - The widget to attach to the parent.\n */\n protected attachWidget(index: number, widget: Widget): void {\n const title = Private.createTitle(this.renderer, widget.title);\n\n ArrayExt.insert(this._titles, index, title);\n\n // Add the title node to the parent before the widget.\n this.parent!.node.appendChild(title);\n\n widget.node.setAttribute('role', 'region');\n widget.node.setAttribute('aria-labelledby', title.id);\n\n super.attachWidget(index, widget);\n }\n\n /**\n * Move a widget in the parent's DOM node.\n *\n * @param fromIndex - The previous index of the widget in the layout.\n *\n * @param toIndex - The current index of the widget in the layout.\n *\n * @param widget - The widget to move in the parent.\n */\n protected moveWidget(\n fromIndex: number,\n toIndex: number,\n widget: Widget\n ): void {\n ArrayExt.move(this._titles, fromIndex, toIndex);\n super.moveWidget(fromIndex, toIndex, widget);\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param index - The previous index of the widget in the layout.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected detachWidget(index: number, widget: Widget): void {\n const title = ArrayExt.removeAt(this._titles, index);\n\n this.parent!.node.removeChild(title!);\n\n super.detachWidget(index, widget);\n }\n\n /**\n * Update the item position.\n *\n * @param i Item index\n * @param isHorizontal Whether the layout is horizontal or not\n * @param left Left position in pixels\n * @param top Top position in pixels\n * @param height Item height\n * @param width Item width\n * @param size Item size\n */\n protected updateItemPosition(\n i: number,\n isHorizontal: boolean,\n left: number,\n top: number,\n height: number,\n width: number,\n size: number\n ): void {\n const titleStyle = this._titles[i].style;\n\n // Titles must be rotated for horizontal accordion panel using CSS: see accordionpanel.css\n titleStyle.top = `${top}px`;\n titleStyle.left = `${left}px`;\n titleStyle.height = `${this.widgetOffset}px`;\n if (isHorizontal) {\n titleStyle.width = `${height}px`;\n } else {\n titleStyle.width = `${width}px`;\n }\n\n super.updateItemPosition(i, isHorizontal, left, top, height, width, size);\n }\n\n private _titles: HTMLElement[] = [];\n}\n\nexport namespace AccordionLayout {\n /**\n * A type alias for a accordion layout orientation.\n */\n export type Orientation = SplitLayout.Orientation;\n\n /**\n * A type alias for a accordion layout alignment.\n */\n export type Alignment = SplitLayout.Alignment;\n\n /**\n * An options object for initializing a accordion layout.\n */\n export interface IOptions extends SplitLayout.IOptions {\n /**\n * The renderer to use for the accordion layout.\n */\n renderer: IRenderer;\n\n /**\n * The section title height or width depending on the orientation.\n *\n * The default is `22`.\n */\n titleSpace?: number;\n }\n\n /**\n * A renderer for use with an accordion layout.\n */\n export interface IRenderer extends SplitLayout.IRenderer {\n /**\n * Common class name for all accordion titles.\n */\n readonly titleClassName: string;\n\n /**\n * Render the element for a section title.\n *\n * @param title - The data to use for rendering the section title.\n *\n * @returns A element representing the section title.\n */\n createSectionTitle(title: Title): HTMLElement;\n }\n}\n\nnamespace Private {\n /**\n * Create the title HTML element.\n *\n * @param renderer Accordion renderer\n * @param data Widget title\n * @returns Title HTML element\n */\n export function createTitle(\n renderer: AccordionLayout.IRenderer,\n data: Title,\n expanded: boolean = true\n ): HTMLElement {\n const title = renderer.createSectionTitle(data);\n title.style.position = 'absolute';\n title.style.contain = 'strict';\n title.setAttribute('aria-label', `${data.label} Section`);\n title.setAttribute('aria-expanded', expanded ? 'true' : 'false');\n title.setAttribute('aria-controls', data.owner.id);\n if (expanded) {\n title.classList.add('lm-mod-expanded');\n }\n return title;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { PanelLayout } from './panellayout';\n\nimport { Widget } from './widget';\n\n/**\n * A simple and convenient panel widget class.\n *\n * #### Notes\n * This class is suitable as a base class for implementing a variety of\n * convenience panel widgets, but can also be used directly with CSS to\n * arrange a collection of widgets.\n *\n * This class provides a convenience wrapper around a {@link PanelLayout}.\n */\nexport class Panel extends Widget {\n /**\n * Construct a new panel.\n *\n * @param options - The options for initializing the panel.\n */\n constructor(options: Panel.IOptions = {}) {\n super();\n this.addClass('lm-Panel');\n this.layout = Private.createLayout(options);\n }\n\n /**\n * A read-only array of the widgets in the panel.\n */\n get widgets(): ReadonlyArray {\n return (this.layout as PanelLayout).widgets;\n }\n\n /**\n * Add a widget to the end of the panel.\n *\n * @param widget - The widget to add to the panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n */\n addWidget(widget: Widget): void {\n (this.layout as PanelLayout).addWidget(widget);\n }\n\n /**\n * Insert a widget at the specified index.\n *\n * @param index - The index at which to insert the widget.\n *\n * @param widget - The widget to insert into to the panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n */\n insertWidget(index: number, widget: Widget): void {\n (this.layout as PanelLayout).insertWidget(index, widget);\n }\n}\n\n/**\n * The namespace for the `Panel` class statics.\n */\nexport namespace Panel {\n /**\n * An options object for creating a panel.\n */\n export interface IOptions {\n /**\n * The panel layout to use for the panel.\n *\n * The default is a new `PanelLayout`.\n */\n layout?: PanelLayout;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Create a panel layout for the given panel options.\n */\n export function createLayout(options: Panel.IOptions): PanelLayout {\n return options.layout || new PanelLayout();\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { IDisposable } from '@lumino/disposable';\n\nimport { Drag } from '@lumino/dragdrop';\n\nimport { Message } from '@lumino/messaging';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { Panel } from './panel';\n\nimport { SplitLayout } from './splitlayout';\n\nimport { Widget } from './widget';\n\n/**\n * A panel which arranges its widgets into resizable sections.\n *\n * #### Notes\n * This class provides a convenience wrapper around a {@link SplitLayout}.\n */\nexport class SplitPanel extends Panel {\n /**\n * Construct a new split panel.\n *\n * @param options - The options for initializing the split panel.\n */\n constructor(options: SplitPanel.IOptions = {}) {\n super({ layout: Private.createLayout(options) });\n this.addClass('lm-SplitPanel');\n }\n\n /**\n * Dispose of the resources held by the panel.\n */\n dispose(): void {\n this._releaseMouse();\n super.dispose();\n }\n\n /**\n * Get the layout orientation for the split panel.\n */\n get orientation(): SplitPanel.Orientation {\n return (this.layout as SplitLayout).orientation;\n }\n\n /**\n * Set the layout orientation for the split panel.\n */\n set orientation(value: SplitPanel.Orientation) {\n (this.layout as SplitLayout).orientation = value;\n }\n\n /**\n * Get the content alignment for the split panel.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire split panel.\n */\n get alignment(): SplitPanel.Alignment {\n return (this.layout as SplitLayout).alignment;\n }\n\n /**\n * Set the content alignment for the split panel.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire split panel.\n */\n set alignment(value: SplitPanel.Alignment) {\n (this.layout as SplitLayout).alignment = value;\n }\n\n /**\n * Get the inter-element spacing for the split panel.\n */\n get spacing(): number {\n return (this.layout as SplitLayout).spacing;\n }\n\n /**\n * Set the inter-element spacing for the split panel.\n */\n set spacing(value: number) {\n (this.layout as SplitLayout).spacing = value;\n }\n\n /**\n * The renderer used by the split panel.\n */\n get renderer(): SplitPanel.IRenderer {\n return (this.layout as SplitLayout).renderer;\n }\n\n /**\n * A signal emitted when a split handle has moved.\n */\n get handleMoved(): ISignal {\n return this._handleMoved;\n }\n\n /**\n * A read-only array of the split handles in the panel.\n */\n get handles(): ReadonlyArray {\n return (this.layout as SplitLayout).handles;\n }\n\n /**\n * Get the relative sizes of the widgets in the panel.\n *\n * @returns A new array of the relative sizes of the widgets.\n *\n * #### Notes\n * The returned sizes reflect the sizes of the widgets normalized\n * relative to their siblings.\n *\n * This method **does not** measure the DOM nodes.\n */\n relativeSizes(): number[] {\n return (this.layout as SplitLayout).relativeSizes();\n }\n\n /**\n * Set the relative sizes for the widgets in the panel.\n *\n * @param sizes - The relative sizes for the widgets in the panel.\n * @param update - Update the layout after setting relative sizes.\n * Default is True.\n *\n * #### Notes\n * Extra values are ignored, too few will yield an undefined layout.\n *\n * The actual geometry of the DOM nodes is updated asynchronously.\n */\n setRelativeSizes(sizes: number[], update = true): void {\n (this.layout as SplitLayout).setRelativeSizes(sizes, update);\n }\n\n /**\n * Handle the DOM events for the split panel.\n *\n * @param event - The DOM event sent to the panel.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the panel's DOM node. It should\n * not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'pointerdown':\n this._evtPointerDown(event as PointerEvent);\n break;\n case 'pointermove':\n this._evtPointerMove(event as PointerEvent);\n break;\n case 'pointerup':\n this._evtPointerUp(event as PointerEvent);\n break;\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('pointerdown', this);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('pointerdown', this);\n this._releaseMouse();\n }\n\n /**\n * A message handler invoked on a `'child-added'` message.\n */\n protected onChildAdded(msg: Widget.ChildMessage): void {\n msg.child.addClass('lm-SplitPanel-child');\n this._releaseMouse();\n }\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {\n msg.child.removeClass('lm-SplitPanel-child');\n this._releaseMouse();\n }\n\n /**\n * Handle the `'keydown'` event for the split panel.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // Stop input events during drag.\n if (this._pressData) {\n event.preventDefault();\n event.stopPropagation();\n }\n\n // Release the mouse if `Escape` is pressed.\n if (event.keyCode === 27) {\n this._releaseMouse();\n }\n }\n\n /**\n * Handle the `'pointerdown'` event for the split panel.\n */\n private _evtPointerDown(event: PointerEvent): void {\n // Do nothing if the primary button is not pressed.\n if (event.button !== 0) {\n return;\n }\n\n // Find the handle which contains the target, if any.\n let layout = this.layout as SplitLayout;\n let index = ArrayExt.findFirstIndex(layout.handles, handle => {\n return handle.contains(event.target as HTMLElement);\n });\n\n // Bail early if the mouse press was not on a handle.\n if (index === -1) {\n return;\n }\n\n // Stop the event when a split handle is pressed.\n event.preventDefault();\n event.stopPropagation();\n\n // Add the extra document listeners.\n document.addEventListener('pointerup', this, true);\n document.addEventListener('pointermove', this, true);\n document.addEventListener('keydown', this, true);\n document.addEventListener('contextmenu', this, true);\n\n // Compute the offset delta for the handle press.\n let delta: number;\n let handle = layout.handles[index];\n let rect = handle.getBoundingClientRect();\n if (layout.orientation === 'horizontal') {\n delta = event.clientX - rect.left;\n } else {\n delta = event.clientY - rect.top;\n }\n\n // Override the cursor and store the press data.\n let style = window.getComputedStyle(handle);\n let override = Drag.overrideCursor(style.cursor!);\n this._pressData = { index, delta, override };\n }\n\n /**\n * Handle the `'pointermove'` event for the split panel.\n */\n private _evtPointerMove(event: PointerEvent): void {\n // Stop the event when dragging a split handle.\n event.preventDefault();\n event.stopPropagation();\n\n // Compute the desired offset position for the handle.\n let pos: number;\n let layout = this.layout as SplitLayout;\n let rect = this.node.getBoundingClientRect();\n if (layout.orientation === 'horizontal') {\n pos = event.clientX - rect.left - this._pressData!.delta;\n } else {\n pos = event.clientY - rect.top - this._pressData!.delta;\n }\n\n // Move the handle as close to the desired position as possible.\n layout.moveHandle(this._pressData!.index, pos);\n }\n\n /**\n * Handle the `'pointerup'` event for the split panel.\n */\n private _evtPointerUp(event: PointerEvent): void {\n // Do nothing if the primary button is not released.\n if (event.button !== 0) {\n return;\n }\n\n // Stop the event when releasing a handle.\n event.preventDefault();\n event.stopPropagation();\n\n // Finalize the mouse release.\n this._releaseMouse();\n }\n\n /**\n * Release the mouse grab for the split panel.\n */\n private _releaseMouse(): void {\n // Bail early if no drag is in progress.\n if (!this._pressData) {\n return;\n }\n\n // Clear the override cursor.\n this._pressData.override.dispose();\n this._pressData = null;\n\n // Emit the handle moved signal.\n this._handleMoved.emit();\n\n // Remove the extra document listeners.\n document.removeEventListener('keydown', this, true);\n document.removeEventListener('pointerup', this, true);\n document.removeEventListener('pointermove', this, true);\n document.removeEventListener('contextmenu', this, true);\n }\n\n private _handleMoved = new Signal(this);\n private _pressData: Private.IPressData | null = null;\n}\n\n/**\n * The namespace for the `SplitPanel` class statics.\n */\nexport namespace SplitPanel {\n /**\n * A type alias for a split panel orientation.\n */\n export type Orientation = SplitLayout.Orientation;\n\n /**\n * A type alias for a split panel alignment.\n */\n export type Alignment = SplitLayout.Alignment;\n\n /**\n * A type alias for a split panel renderer.\n */\n export type IRenderer = SplitLayout.IRenderer;\n\n /**\n * An options object for initializing a split panel.\n */\n export interface IOptions {\n /**\n * The renderer to use for the split panel.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n\n /**\n * The layout orientation of the panel.\n *\n * The default is `'horizontal'`.\n */\n orientation?: Orientation;\n\n /**\n * The content alignment of the panel.\n *\n * The default is `'start'`.\n */\n alignment?: Alignment;\n\n /**\n * The spacing between items in the panel.\n *\n * The default is `4`.\n */\n spacing?: number;\n\n /**\n * The split layout to use for the split panel.\n *\n * If this is provided, the other options are ignored.\n *\n * The default is a new `SplitLayout`.\n */\n layout?: SplitLayout;\n }\n\n /**\n * The default implementation of `IRenderer`.\n */\n export class Renderer implements IRenderer {\n /**\n * Create a new handle for use with a split panel.\n *\n * @returns A new handle element for a split panel.\n */\n createHandle(): HTMLDivElement {\n let handle = document.createElement('div');\n handle.className = 'lm-SplitPanel-handle';\n return handle;\n }\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n\n /**\n * Get the split panel stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The split panel stretch factor for the widget.\n */\n export function getStretch(widget: Widget): number {\n return SplitLayout.getStretch(widget);\n }\n\n /**\n * Set the split panel stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the stretch factor.\n */\n export function setStretch(widget: Widget, value: number): void {\n SplitLayout.setStretch(widget, value);\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * An object which holds mouse press data.\n */\n export interface IPressData {\n /**\n * The index of the pressed handle.\n */\n index: number;\n\n /**\n * The offset of the press in handle coordinates.\n */\n delta: number;\n\n /**\n * The disposable which will clear the override cursor.\n */\n override: IDisposable;\n }\n\n /**\n * Create a split layout for the given panel options.\n */\n export function createLayout(options: SplitPanel.IOptions): SplitLayout {\n return (\n options.layout ||\n new SplitLayout({\n renderer: options.renderer || SplitPanel.defaultRenderer,\n orientation: options.orientation,\n alignment: options.alignment,\n spacing: options.spacing\n })\n );\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n\nimport { ArrayExt } from '@lumino/algorithm';\nimport { Message } from '@lumino/messaging';\nimport { ISignal, Signal } from '@lumino/signaling';\nimport { AccordionLayout } from './accordionlayout';\nimport { SplitLayout } from './splitlayout';\nimport { SplitPanel } from './splitpanel';\nimport { Title } from './title';\nimport { Widget } from './widget';\n\n/**\n * A panel which arranges its widgets into resizable sections separated by a title widget.\n *\n * #### Notes\n * This class provides a convenience wrapper around {@link AccordionLayout}.\n */\nexport class AccordionPanel extends SplitPanel {\n /**\n * Construct a new accordion panel.\n *\n * @param options - The options for initializing the accordion panel.\n */\n constructor(options: AccordionPanel.IOptions = {}) {\n super({ ...options, layout: Private.createLayout(options) });\n this.addClass('lm-AccordionPanel');\n }\n\n /**\n * The renderer used by the accordion panel.\n */\n get renderer(): AccordionPanel.IRenderer {\n return (this.layout as AccordionLayout).renderer;\n }\n\n /**\n * The section title space.\n *\n * This is the height if the panel is vertical and the width if it is\n * horizontal.\n */\n get titleSpace(): number {\n return (this.layout as AccordionLayout).titleSpace;\n }\n set titleSpace(value: number) {\n (this.layout as AccordionLayout).titleSpace = value;\n }\n\n /**\n * A read-only array of the section titles in the panel.\n */\n get titles(): ReadonlyArray {\n return (this.layout as AccordionLayout).titles;\n }\n\n /**\n * A signal emitted when a widget of the AccordionPanel is collapsed or expanded.\n */\n get expansionToggled(): ISignal {\n return this._expansionToggled;\n }\n\n /**\n * Add a widget to the end of the panel.\n *\n * @param widget - The widget to add to the panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n */\n addWidget(widget: Widget): void {\n super.addWidget(widget);\n widget.title.changed.connect(this._onTitleChanged, this);\n }\n\n /**\n * Collapse the widget at position `index`.\n *\n * #### Notes\n * If no widget is found for `index`, this will bail.\n *\n * @param index Widget index\n */\n collapse(index: number): void {\n const widget = (this.layout as AccordionLayout).widgets[index];\n\n if (widget && !widget.isHidden) {\n this._toggleExpansion(index);\n }\n }\n\n /**\n * Expand the widget at position `index`.\n *\n * #### Notes\n * If no widget is found for `index`, this will bail.\n *\n * @param index Widget index\n */\n expand(index: number): void {\n const widget = (this.layout as AccordionLayout).widgets[index];\n\n if (widget && widget.isHidden) {\n this._toggleExpansion(index);\n }\n }\n\n /**\n * Insert a widget at the specified index.\n *\n * @param index - The index at which to insert the widget.\n *\n * @param widget - The widget to insert into to the panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n */\n insertWidget(index: number, widget: Widget): void {\n super.insertWidget(index, widget);\n widget.title.changed.connect(this._onTitleChanged, this);\n }\n\n /**\n * Handle the DOM events for the accordion panel.\n *\n * @param event - The DOM event sent to the panel.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the panel's DOM node. It should\n * not be called directly by user code.\n */\n handleEvent(event: Event): void {\n super.handleEvent(event);\n switch (event.type) {\n case 'click':\n this._evtClick(event as MouseEvent);\n break;\n case 'keydown':\n this._eventKeyDown(event as KeyboardEvent);\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('click', this);\n this.node.addEventListener('keydown', this);\n super.onBeforeAttach(msg);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n super.onAfterDetach(msg);\n this.node.removeEventListener('click', this);\n this.node.removeEventListener('keydown', this);\n }\n\n /**\n * Handle the `changed` signal of a title object.\n */\n private _onTitleChanged(sender: Title): void {\n const index = ArrayExt.findFirstIndex(this.widgets, widget => {\n return widget.contains(sender.owner);\n });\n\n if (index >= 0) {\n (this.layout as AccordionLayout).updateTitle(index, sender.owner);\n this.update();\n }\n }\n\n /**\n * Compute the size of widgets in this panel on the title click event.\n * On closing, the size of the widget is cached and we will try to expand\n * the last opened widget.\n * On opening, we will use the cached size if it is available to restore the\n * widget.\n * In both cases, if we can not compute the size of widgets, we will let\n * `SplitLayout` decide.\n *\n * @param index - The index of widget to be opened of closed\n *\n * @returns Relative size of widgets in this panel, if this size can\n * not be computed, return `undefined`\n */\n private _computeWidgetSize(index: number): number[] | undefined {\n const layout = this.layout as AccordionLayout;\n\n const widget = layout.widgets[index];\n if (!widget) {\n return undefined;\n }\n const isHidden = widget.isHidden;\n const widgetSizes = layout.absoluteSizes();\n const delta = (isHidden ? -1 : 1) * this.spacing;\n const totalSize = widgetSizes.reduce(\n (prev: number, curr: number) => prev + curr\n );\n\n let newSize = [...widgetSizes];\n\n if (!isHidden) {\n // Hide the widget\n const currentSize = widgetSizes[index];\n\n this._widgetSizesCache.set(widget, currentSize);\n newSize[index] = 0;\n\n const widgetToCollapse = newSize.map(sz => sz > 0).lastIndexOf(true);\n if (widgetToCollapse === -1) {\n // All widget are closed, let the `SplitLayout` compute widget sizes.\n return undefined;\n }\n\n newSize[widgetToCollapse] =\n widgetSizes[widgetToCollapse] + currentSize + delta;\n } else {\n // Show the widget\n const previousSize = this._widgetSizesCache.get(widget);\n if (!previousSize) {\n // Previous size is unavailable, let the `SplitLayout` compute widget sizes.\n return undefined;\n }\n newSize[index] += previousSize;\n\n const widgetToCollapse = newSize\n .map(sz => sz - previousSize > 0)\n .lastIndexOf(true);\n if (widgetToCollapse === -1) {\n // Can not reduce the size of one widget, reduce all opened widgets\n // proportionally with its size.\n newSize.forEach((_, idx) => {\n if (idx !== index) {\n newSize[idx] -=\n (widgetSizes[idx] / totalSize) * (previousSize - delta);\n }\n });\n } else {\n newSize[widgetToCollapse] -= previousSize - delta;\n }\n }\n return newSize.map(sz => sz / (totalSize + delta));\n }\n /**\n * Handle the `'click'` event for the accordion panel\n */\n private _evtClick(event: MouseEvent): void {\n const target = event.target as HTMLElement | null;\n\n if (target) {\n const index = ArrayExt.findFirstIndex(this.titles, title => {\n return title.contains(target);\n });\n\n if (index >= 0) {\n event.preventDefault();\n event.stopPropagation();\n this._toggleExpansion(index);\n }\n }\n }\n\n /**\n * Handle the `'keydown'` event for the accordion panel.\n */\n private _eventKeyDown(event: KeyboardEvent): void {\n if (event.defaultPrevented) {\n return;\n }\n\n const target = event.target as HTMLElement | null;\n let handled = false;\n if (target) {\n const index = ArrayExt.findFirstIndex(this.titles, title => {\n return title.contains(target);\n });\n\n if (index >= 0) {\n const keyCode = event.keyCode.toString();\n\n // If Space or Enter is pressed on title, emulate click event\n if (event.key.match(/Space|Enter/) || keyCode.match(/13|32/)) {\n target.click();\n handled = true;\n } else if (\n this.orientation === 'horizontal'\n ? event.key.match(/ArrowLeft|ArrowRight/) || keyCode.match(/37|39/)\n : event.key.match(/ArrowUp|ArrowDown/) || keyCode.match(/38|40/)\n ) {\n // If Up or Down (for vertical) / Left or Right (for horizontal) is pressed on title, loop on titles\n const direction =\n event.key.match(/ArrowLeft|ArrowUp/) || keyCode.match(/37|38/)\n ? -1\n : 1;\n const length = this.titles.length;\n const newIndex = (index + length + direction) % length;\n\n this.titles[newIndex].focus();\n handled = true;\n } else if (event.key === 'End' || keyCode === '35') {\n // If End is pressed on title, focus on the last title\n this.titles[this.titles.length - 1].focus();\n handled = true;\n } else if (event.key === 'Home' || keyCode === '36') {\n // If Home is pressed on title, focus on the first title\n this.titles[0].focus();\n handled = true;\n }\n }\n\n if (handled) {\n event.preventDefault();\n }\n }\n }\n\n private _toggleExpansion(index: number) {\n const title = this.titles[index];\n const widget = (this.layout as AccordionLayout).widgets[index];\n\n const newSize = this._computeWidgetSize(index);\n if (newSize) {\n this.setRelativeSizes(newSize, false);\n }\n\n if (widget.isHidden) {\n title.classList.add('lm-mod-expanded');\n title.setAttribute('aria-expanded', 'true');\n widget.show();\n } else {\n title.classList.remove('lm-mod-expanded');\n title.setAttribute('aria-expanded', 'false');\n widget.hide();\n }\n\n // Emit the expansion state signal.\n this._expansionToggled.emit(index);\n }\n\n private _widgetSizesCache: WeakMap = new WeakMap();\n private _expansionToggled = new Signal(this);\n}\n\n/**\n * The namespace for the `AccordionPanel` class statics.\n */\nexport namespace AccordionPanel {\n /**\n * A type alias for a accordion panel orientation.\n */\n export type Orientation = SplitLayout.Orientation;\n\n /**\n * A type alias for a accordion panel alignment.\n */\n export type Alignment = SplitLayout.Alignment;\n\n /**\n * A type alias for a accordion panel renderer.\n */\n export type IRenderer = AccordionLayout.IRenderer;\n\n /**\n * An options object for initializing a accordion panel.\n */\n export interface IOptions extends Partial {\n /**\n * The accordion layout to use for the accordion panel.\n *\n * If this is provided, the other options are ignored.\n *\n * The default is a new `AccordionLayout`.\n */\n layout?: AccordionLayout;\n }\n\n /**\n * The default implementation of `IRenderer`.\n */\n export class Renderer extends SplitPanel.Renderer implements IRenderer {\n constructor() {\n super();\n this._uuid = ++Renderer._nInstance;\n }\n /**\n * A selector which matches any title node in the accordion.\n */\n readonly titleClassName = 'lm-AccordionPanel-title';\n\n /**\n * Render the collapse indicator for a section title.\n *\n * @param data - The data to use for rendering the section title.\n *\n * @returns A element representing the collapse indicator.\n */\n createCollapseIcon(data: Title): HTMLElement {\n return document.createElement('span');\n }\n\n /**\n * Render the element for a section title.\n *\n * @param data - The data to use for rendering the section title.\n *\n * @returns A element representing the section title.\n */\n createSectionTitle(data: Title): HTMLElement {\n const handle = document.createElement('h3');\n handle.setAttribute('tabindex', '0');\n handle.id = this.createTitleKey(data);\n handle.className = this.titleClassName;\n for (const aData in data.dataset) {\n handle.dataset[aData] = data.dataset[aData];\n }\n\n const collapser = handle.appendChild(this.createCollapseIcon(data));\n collapser.className = 'lm-AccordionPanel-titleCollapser';\n\n const label = handle.appendChild(document.createElement('span'));\n label.className = 'lm-AccordionPanel-titleLabel';\n label.textContent = data.label;\n label.title = data.caption || data.label;\n\n return handle;\n }\n\n /**\n * Create a unique render key for the title.\n *\n * @param data - The data to use for the title.\n *\n * @returns The unique render key for the title.\n *\n * #### Notes\n * This method caches the key against the section title the first time\n * the key is generated.\n */\n createTitleKey(data: Title): string {\n let key = this._titleKeys.get(data);\n if (key === undefined) {\n key = `title-key-${this._uuid}-${this._titleID++}`;\n this._titleKeys.set(data, key);\n }\n return key;\n }\n\n private static _nInstance = 0;\n private readonly _uuid: number;\n private _titleID = 0;\n private _titleKeys = new WeakMap, string>();\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n}\n\nnamespace Private {\n /**\n * Create an accordion layout for the given panel options.\n *\n * @param options Panel options\n * @returns Panel layout\n */\n export function createLayout(\n options: AccordionPanel.IOptions\n ): AccordionLayout {\n return (\n options.layout ||\n new AccordionLayout({\n renderer: options.renderer || AccordionPanel.defaultRenderer,\n orientation: options.orientation,\n alignment: options.alignment,\n spacing: options.spacing,\n titleSpace: options.titleSpace\n })\n );\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { BoxEngine, BoxSizer } from './boxengine';\n\nimport { LayoutItem } from './layout';\n\nimport { PanelLayout } from './panellayout';\n\nimport Utils from './utils';\n\nimport { Widget } from './widget';\n\n/**\n * A layout which arranges its widgets in a single row or column.\n */\nexport class BoxLayout extends PanelLayout {\n /**\n * Construct a new box layout.\n *\n * @param options - The options for initializing the layout.\n */\n constructor(options: BoxLayout.IOptions = {}) {\n super();\n if (options.direction !== undefined) {\n this._direction = options.direction;\n }\n if (options.alignment !== undefined) {\n this._alignment = options.alignment;\n }\n if (options.spacing !== undefined) {\n this._spacing = Utils.clampDimension(options.spacing);\n }\n }\n\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n // Dispose of the layout items.\n for (const item of this._items) {\n item.dispose();\n }\n\n // Clear the layout state.\n this._box = null;\n this._items.length = 0;\n this._sizers.length = 0;\n\n // Dispose of the rest of the layout.\n super.dispose();\n }\n\n /**\n * Get the layout direction for the box layout.\n */\n get direction(): BoxLayout.Direction {\n return this._direction;\n }\n\n /**\n * Set the layout direction for the box layout.\n */\n set direction(value: BoxLayout.Direction) {\n if (this._direction === value) {\n return;\n }\n this._direction = value;\n if (!this.parent) {\n return;\n }\n this.parent.dataset['direction'] = value;\n this.parent.fit();\n }\n\n /**\n * Get the content alignment for the box layout.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire box layout.\n */\n get alignment(): BoxLayout.Alignment {\n return this._alignment;\n }\n\n /**\n * Set the content alignment for the box layout.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire box layout.\n */\n set alignment(value: BoxLayout.Alignment) {\n if (this._alignment === value) {\n return;\n }\n this._alignment = value;\n if (!this.parent) {\n return;\n }\n this.parent.dataset['alignment'] = value;\n this.parent.update();\n }\n\n /**\n * Get the inter-element spacing for the box layout.\n */\n get spacing(): number {\n return this._spacing;\n }\n\n /**\n * Set the inter-element spacing for the box layout.\n */\n set spacing(value: number) {\n value = Utils.clampDimension(value);\n if (this._spacing === value) {\n return;\n }\n this._spacing = value;\n if (!this.parent) {\n return;\n }\n this.parent.fit();\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n this.parent!.dataset['direction'] = this.direction;\n this.parent!.dataset['alignment'] = this.alignment;\n super.init();\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param index - The current index of the widget in the layout.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected attachWidget(index: number, widget: Widget): void {\n // Create and add a new layout item for the widget.\n ArrayExt.insert(this._items, index, new LayoutItem(widget));\n\n // Create and add a new sizer for the widget.\n ArrayExt.insert(this._sizers, index, new BoxSizer());\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget's node to the parent.\n this.parent!.node.appendChild(widget.node);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * Move a widget in the parent's DOM node.\n *\n * @param fromIndex - The previous index of the widget in the layout.\n *\n * @param toIndex - The current index of the widget in the layout.\n *\n * @param widget - The widget to move in the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected moveWidget(\n fromIndex: number,\n toIndex: number,\n widget: Widget\n ): void {\n // Move the layout item for the widget.\n ArrayExt.move(this._items, fromIndex, toIndex);\n\n // Move the sizer for the widget.\n ArrayExt.move(this._sizers, fromIndex, toIndex);\n\n // Post an update request for the parent widget.\n this.parent!.update();\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param index - The previous index of the widget in the layout.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected detachWidget(index: number, widget: Widget): void {\n // Remove the layout item for the widget.\n let item = ArrayExt.removeAt(this._items, index);\n\n // Remove the sizer for the widget.\n ArrayExt.removeAt(this._sizers, index);\n\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Dispose of the layout item.\n item!.dispose();\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n */\n protected onBeforeShow(msg: Message): void {\n super.onBeforeShow(msg);\n this.parent!.update();\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n super.onBeforeAttach(msg);\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n if (this.parent!.isVisible) {\n this._update(msg.width, msg.height);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.parent!.isVisible) {\n this._update(-1, -1);\n }\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n */\n protected onFitRequest(msg: Message): void {\n if (this.parent!.isAttached) {\n this._fit();\n }\n }\n\n /**\n * Fit the layout to the total size required by the widgets.\n */\n private _fit(): void {\n // Compute the visible item count.\n let nVisible = 0;\n for (let i = 0, n = this._items.length; i < n; ++i) {\n nVisible += +!this._items[i].isHidden;\n }\n\n // Update the fixed space for the visible items.\n this._fixed = this._spacing * Math.max(0, nVisible - 1);\n\n // Setup the computed minimum size.\n let horz = Private.isHorizontal(this._direction);\n let minW = horz ? this._fixed : 0;\n let minH = horz ? 0 : this._fixed;\n\n // Update the sizers and computed minimum size.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item and corresponding box sizer.\n let item = this._items[i];\n let sizer = this._sizers[i];\n\n // If the item is hidden, it should consume zero size.\n if (item.isHidden) {\n sizer.minSize = 0;\n sizer.maxSize = 0;\n continue;\n }\n\n // Update the size limits for the item.\n item.fit();\n\n // Update the size basis and stretch factor.\n sizer.sizeHint = BoxLayout.getSizeBasis(item.widget);\n sizer.stretch = BoxLayout.getStretch(item.widget);\n\n // Update the sizer limits and computed min size.\n if (horz) {\n sizer.minSize = item.minWidth;\n sizer.maxSize = item.maxWidth;\n minW += item.minWidth;\n minH = Math.max(minH, item.minHeight);\n } else {\n sizer.minSize = item.minHeight;\n sizer.maxSize = item.maxHeight;\n minH += item.minHeight;\n minW = Math.max(minW, item.minWidth);\n }\n }\n\n // Update the box sizing and add it to the computed min size.\n let box = (this._box = ElementExt.boxSizing(this.parent!.node));\n minW += box.horizontalSum;\n minH += box.verticalSum;\n\n // Update the parent's min size constraints.\n let style = this.parent!.node.style;\n style.minWidth = `${minW}px`;\n style.minHeight = `${minH}px`;\n\n // Set the dirty flag to ensure only a single update occurs.\n this._dirty = true;\n\n // Notify the ancestor that it should fit immediately. This may\n // cause a resize of the parent, fulfilling the required update.\n if (this.parent!.parent) {\n MessageLoop.sendMessage(this.parent!.parent!, Widget.Msg.FitRequest);\n }\n\n // If the dirty flag is still set, the parent was not resized.\n // Trigger the required update on the parent widget immediately.\n if (this._dirty) {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n }\n }\n\n /**\n * Update the layout position and size of the widgets.\n *\n * The parent offset dimensions should be `-1` if unknown.\n */\n private _update(offsetWidth: number, offsetHeight: number): void {\n // Clear the dirty flag to indicate the update occurred.\n this._dirty = false;\n\n // Compute the visible item count.\n let nVisible = 0;\n for (let i = 0, n = this._items.length; i < n; ++i) {\n nVisible += +!this._items[i].isHidden;\n }\n\n // Bail early if there are no visible items to layout.\n if (nVisible === 0) {\n return;\n }\n\n // Measure the parent if the offset dimensions are unknown.\n if (offsetWidth < 0) {\n offsetWidth = this.parent!.node.offsetWidth;\n }\n if (offsetHeight < 0) {\n offsetHeight = this.parent!.node.offsetHeight;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent!.node);\n }\n\n // Compute the layout area adjusted for border and padding.\n let top = this._box.paddingTop;\n let left = this._box.paddingLeft;\n let width = offsetWidth - this._box.horizontalSum;\n let height = offsetHeight - this._box.verticalSum;\n\n // Distribute the layout space and adjust the start position.\n let delta: number;\n switch (this._direction) {\n case 'left-to-right':\n delta = BoxEngine.calc(this._sizers, Math.max(0, width - this._fixed));\n break;\n case 'top-to-bottom':\n delta = BoxEngine.calc(this._sizers, Math.max(0, height - this._fixed));\n break;\n case 'right-to-left':\n delta = BoxEngine.calc(this._sizers, Math.max(0, width - this._fixed));\n left += width;\n break;\n case 'bottom-to-top':\n delta = BoxEngine.calc(this._sizers, Math.max(0, height - this._fixed));\n top += height;\n break;\n default:\n throw 'unreachable';\n }\n\n // Setup the variables for justification and alignment offset.\n let extra = 0;\n let offset = 0;\n\n // Account for alignment if there is extra layout space.\n if (delta > 0) {\n switch (this._alignment) {\n case 'start':\n break;\n case 'center':\n extra = 0;\n offset = delta / 2;\n break;\n case 'end':\n extra = 0;\n offset = delta;\n break;\n case 'justify':\n extra = delta / nVisible;\n offset = 0;\n break;\n default:\n throw 'unreachable';\n }\n }\n\n // Layout the items using the computed box sizes.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item.\n let item = this._items[i];\n\n // Ignore hidden items.\n if (item.isHidden) {\n continue;\n }\n\n // Fetch the computed size for the widget.\n let size = this._sizers[i].size;\n\n // Update the widget geometry and advance the relevant edge.\n switch (this._direction) {\n case 'left-to-right':\n item.update(left + offset, top, size + extra, height);\n left += size + extra + this._spacing;\n break;\n case 'top-to-bottom':\n item.update(left, top + offset, width, size + extra);\n top += size + extra + this._spacing;\n break;\n case 'right-to-left':\n item.update(left - offset - size - extra, top, size + extra, height);\n left -= size + extra + this._spacing;\n break;\n case 'bottom-to-top':\n item.update(left, top - offset - size - extra, width, size + extra);\n top -= size + extra + this._spacing;\n break;\n default:\n throw 'unreachable';\n }\n }\n }\n\n private _fixed = 0;\n private _spacing = 4;\n private _dirty = false;\n private _sizers: BoxSizer[] = [];\n private _items: LayoutItem[] = [];\n private _box: ElementExt.IBoxSizing | null = null;\n private _alignment: BoxLayout.Alignment = 'start';\n private _direction: BoxLayout.Direction = 'top-to-bottom';\n}\n\n/**\n * The namespace for the `BoxLayout` class statics.\n */\nexport namespace BoxLayout {\n /**\n * A type alias for a box layout direction.\n */\n export type Direction =\n | 'left-to-right'\n | 'right-to-left'\n | 'top-to-bottom'\n | 'bottom-to-top';\n\n /**\n * A type alias for a box layout alignment.\n */\n export type Alignment = 'start' | 'center' | 'end' | 'justify';\n\n /**\n * An options object for initializing a box layout.\n */\n export interface IOptions {\n /**\n * The direction of the layout.\n *\n * The default is `'top-to-bottom'`.\n */\n direction?: Direction;\n\n /**\n * The content alignment of the layout.\n *\n * The default is `'start'`.\n */\n alignment?: Alignment;\n\n /**\n * The spacing between items in the layout.\n *\n * The default is `4`.\n */\n spacing?: number;\n }\n\n /**\n * Get the box layout stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The box layout stretch factor for the widget.\n */\n export function getStretch(widget: Widget): number {\n return Private.stretchProperty.get(widget);\n }\n\n /**\n * Set the box layout stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the stretch factor.\n */\n export function setStretch(widget: Widget, value: number): void {\n Private.stretchProperty.set(widget, value);\n }\n\n /**\n * Get the box layout size basis for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The box layout size basis for the widget.\n */\n export function getSizeBasis(widget: Widget): number {\n return Private.sizeBasisProperty.get(widget);\n }\n\n /**\n * Set the box layout size basis for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the size basis.\n */\n export function setSizeBasis(widget: Widget, value: number): void {\n Private.sizeBasisProperty.set(widget, value);\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The property descriptor for a widget stretch factor.\n */\n export const stretchProperty = new AttachedProperty({\n name: 'stretch',\n create: () => 0,\n coerce: (owner, value) => Math.max(0, Math.floor(value)),\n changed: onChildSizingChanged\n });\n\n /**\n * The property descriptor for a widget size basis.\n */\n export const sizeBasisProperty = new AttachedProperty({\n name: 'sizeBasis',\n create: () => 0,\n coerce: (owner, value) => Math.max(0, Math.floor(value)),\n changed: onChildSizingChanged\n });\n\n /**\n * Test whether a direction has horizontal orientation.\n */\n export function isHorizontal(dir: BoxLayout.Direction): boolean {\n return dir === 'left-to-right' || dir === 'right-to-left';\n }\n\n /**\n * Clamp a spacing value to an integer >= 0.\n */\n export function clampSpacing(value: number): number {\n return Math.max(0, Math.floor(value));\n }\n\n /**\n * The change handler for the attached sizing properties.\n */\n function onChildSizingChanged(child: Widget): void {\n if (child.parent && child.parent.layout instanceof BoxLayout) {\n child.parent.fit();\n }\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { BoxLayout } from './boxlayout';\n\nimport { Panel } from './panel';\n\nimport { Widget } from './widget';\n\n/**\n * A panel which arranges its widgets in a single row or column.\n *\n * #### Notes\n * This class provides a convenience wrapper around a {@link BoxLayout}.\n */\nexport class BoxPanel extends Panel {\n /**\n * Construct a new box panel.\n *\n * @param options - The options for initializing the box panel.\n */\n constructor(options: BoxPanel.IOptions = {}) {\n super({ layout: Private.createLayout(options) });\n this.addClass('lm-BoxPanel');\n }\n\n /**\n * Get the layout direction for the box panel.\n */\n get direction(): BoxPanel.Direction {\n return (this.layout as BoxLayout).direction;\n }\n\n /**\n * Set the layout direction for the box panel.\n */\n set direction(value: BoxPanel.Direction) {\n (this.layout as BoxLayout).direction = value;\n }\n\n /**\n * Get the content alignment for the box panel.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire box layout.\n */\n get alignment(): BoxPanel.Alignment {\n return (this.layout as BoxLayout).alignment;\n }\n\n /**\n * Set the content alignment for the box panel.\n *\n * #### Notes\n * This is the alignment of the widgets in the layout direction.\n *\n * The alignment has no effect if the widgets can expand to fill the\n * entire box layout.\n */\n set alignment(value: BoxPanel.Alignment) {\n (this.layout as BoxLayout).alignment = value;\n }\n\n /**\n * Get the inter-element spacing for the box panel.\n */\n get spacing(): number {\n return (this.layout as BoxLayout).spacing;\n }\n\n /**\n * Set the inter-element spacing for the box panel.\n */\n set spacing(value: number) {\n (this.layout as BoxLayout).spacing = value;\n }\n\n /**\n * A message handler invoked on a `'child-added'` message.\n */\n protected onChildAdded(msg: Widget.ChildMessage): void {\n msg.child.addClass('lm-BoxPanel-child');\n }\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {\n msg.child.removeClass('lm-BoxPanel-child');\n }\n}\n\n/**\n * The namespace for the `BoxPanel` class statics.\n */\nexport namespace BoxPanel {\n /**\n * A type alias for a box panel direction.\n */\n export type Direction = BoxLayout.Direction;\n\n /**\n * A type alias for a box panel alignment.\n */\n export type Alignment = BoxLayout.Alignment;\n\n /**\n * An options object for initializing a box panel.\n */\n export interface IOptions {\n /**\n * The layout direction of the panel.\n *\n * The default is `'top-to-bottom'`.\n */\n direction?: Direction;\n\n /**\n * The content alignment of the panel.\n *\n * The default is `'start'`.\n */\n alignment?: Alignment;\n\n /**\n * The spacing between items in the panel.\n *\n * The default is `4`.\n */\n spacing?: number;\n\n /**\n * The box layout to use for the box panel.\n *\n * If this is provided, the other options are ignored.\n *\n * The default is a new `BoxLayout`.\n */\n layout?: BoxLayout;\n }\n\n /**\n * Get the box panel stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The box panel stretch factor for the widget.\n */\n export function getStretch(widget: Widget): number {\n return BoxLayout.getStretch(widget);\n }\n\n /**\n * Set the box panel stretch factor for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the stretch factor.\n */\n export function setStretch(widget: Widget, value: number): void {\n BoxLayout.setStretch(widget, value);\n }\n\n /**\n * Get the box panel size basis for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The box panel size basis for the widget.\n */\n export function getSizeBasis(widget: Widget): number {\n return BoxLayout.getSizeBasis(widget);\n }\n\n /**\n * Set the box panel size basis for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the size basis.\n */\n export function setSizeBasis(widget: Widget, value: number): void {\n BoxLayout.setSizeBasis(widget, value);\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Create a box layout for the given panel options.\n */\n export function createLayout(options: BoxPanel.IOptions): BoxLayout {\n return options.layout || new BoxLayout(options);\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt, StringExt } from '@lumino/algorithm';\n\nimport { JSONExt, ReadonlyJSONObject } from '@lumino/coreutils';\n\nimport { CommandRegistry } from '@lumino/commands';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message } from '@lumino/messaging';\n\nimport {\n ElementDataset,\n h,\n VirtualDOM,\n VirtualElement\n} from '@lumino/virtualdom';\n\nimport { Widget } from './widget';\n\n/**\n * A widget which displays command items as a searchable palette.\n */\nexport class CommandPalette extends Widget {\n /**\n * Construct a new command palette.\n *\n * @param options - The options for initializing the palette.\n */\n constructor(options: CommandPalette.IOptions) {\n super({ node: Private.createNode() });\n this.addClass('lm-CommandPalette');\n this.setFlag(Widget.Flag.DisallowLayout);\n this.commands = options.commands;\n this.renderer = options.renderer || CommandPalette.defaultRenderer;\n this.commands.commandChanged.connect(this._onGenericChange, this);\n this.commands.keyBindingChanged.connect(this._onGenericChange, this);\n }\n\n /**\n * Dispose of the resources held by the widget.\n */\n dispose(): void {\n this._items.length = 0;\n this._results = null;\n super.dispose();\n }\n\n /**\n * The command registry used by the command palette.\n */\n readonly commands: CommandRegistry;\n\n /**\n * The renderer used by the command palette.\n */\n readonly renderer: CommandPalette.IRenderer;\n\n /**\n * The command palette search node.\n *\n * #### Notes\n * This is the node which contains the search-related elements.\n */\n get searchNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-CommandPalette-search'\n )[0] as HTMLDivElement;\n }\n\n /**\n * The command palette input node.\n *\n * #### Notes\n * This is the actual input node for the search area.\n */\n get inputNode(): HTMLInputElement {\n return this.node.getElementsByClassName(\n 'lm-CommandPalette-input'\n )[0] as HTMLInputElement;\n }\n\n /**\n * The command palette content node.\n *\n * #### Notes\n * This is the node which holds the command item nodes.\n *\n * Modifying this node directly can lead to undefined behavior.\n */\n get contentNode(): HTMLUListElement {\n return this.node.getElementsByClassName(\n 'lm-CommandPalette-content'\n )[0] as HTMLUListElement;\n }\n\n /**\n * A read-only array of the command items in the palette.\n */\n get items(): ReadonlyArray {\n return this._items;\n }\n\n /**\n * Add a command item to the command palette.\n *\n * @param options - The options for creating the command item.\n *\n * @returns The command item added to the palette.\n */\n addItem(options: CommandPalette.IItemOptions): CommandPalette.IItem {\n // Create a new command item for the options.\n let item = Private.createItem(this.commands, options);\n\n // Add the item to the array.\n this._items.push(item);\n\n // Refresh the search results.\n this.refresh();\n\n // Return the item added to the palette.\n return item;\n }\n\n /**\n * Adds command items to the command palette.\n *\n * @param items - An array of options for creating each command item.\n *\n * @returns The command items added to the palette.\n */\n addItems(items: CommandPalette.IItemOptions[]): CommandPalette.IItem[] {\n const newItems = items.map(item => Private.createItem(this.commands, item));\n newItems.forEach(item => this._items.push(item));\n this.refresh();\n return newItems;\n }\n\n /**\n * Remove an item from the command palette.\n *\n * @param item - The item to remove from the palette.\n *\n * #### Notes\n * This is a no-op if the item is not in the palette.\n */\n removeItem(item: CommandPalette.IItem): void {\n this.removeItemAt(this._items.indexOf(item));\n }\n\n /**\n * Remove the item at a given index from the command palette.\n *\n * @param index - The index of the item to remove.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n removeItemAt(index: number): void {\n // Remove the item from the array.\n let item = ArrayExt.removeAt(this._items, index);\n\n // Bail if the index is out of range.\n if (!item) {\n return;\n }\n\n // Refresh the search results.\n this.refresh();\n }\n\n /**\n * Remove all items from the command palette.\n */\n clearItems(): void {\n // Bail if there is nothing to remove.\n if (this._items.length === 0) {\n return;\n }\n\n // Clear the array of items.\n this._items.length = 0;\n\n // Refresh the search results.\n this.refresh();\n }\n\n /**\n * Clear the search results and schedule an update.\n *\n * #### Notes\n * This should be called whenever the search results of the palette\n * should be updated.\n *\n * This is typically called automatically by the palette as needed,\n * but can be called manually if the input text is programatically\n * changed.\n *\n * The rendered results are updated asynchronously.\n */\n refresh(): void {\n this._results = null;\n if (this.inputNode.value !== '') {\n let clear = this.node.getElementsByClassName(\n 'lm-close-icon'\n )[0] as HTMLInputElement;\n clear.style.display = 'inherit';\n } else {\n let clear = this.node.getElementsByClassName(\n 'lm-close-icon'\n )[0] as HTMLInputElement;\n clear.style.display = 'none';\n }\n this.update();\n }\n\n /**\n * Handle the DOM events for the command palette.\n *\n * @param event - The DOM event sent to the command palette.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the command palette's DOM node.\n * It should not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'click':\n this._evtClick(event as MouseEvent);\n break;\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'input':\n this.refresh();\n break;\n case 'focus':\n case 'blur':\n this._toggleFocused();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('click', this);\n this.node.addEventListener('keydown', this);\n this.node.addEventListener('input', this);\n this.node.addEventListener('focus', this, true);\n this.node.addEventListener('blur', this, true);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('click', this);\n this.node.removeEventListener('keydown', this);\n this.node.removeEventListener('input', this);\n this.node.removeEventListener('focus', this, true);\n this.node.removeEventListener('blur', this, true);\n }\n\n /**\n * A message handler invoked on an `'after-show'` message.\n */\n protected onAfterShow(msg: Message): void {\n this.update();\n super.onAfterShow(msg);\n }\n\n /**\n * A message handler invoked on an `'activate-request'` message.\n */\n protected onActivateRequest(msg: Message): void {\n if (this.isAttached) {\n let input = this.inputNode;\n input.focus();\n input.select();\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.isHidden) {\n return;\n }\n\n // Fetch the current query text and content node.\n let query = this.inputNode.value;\n let contentNode = this.contentNode;\n\n // Ensure the search results are generated.\n let results = this._results;\n if (!results) {\n // Generate and store the new search results.\n results = this._results = Private.search(this._items, query);\n\n // Reset the active index.\n this._activeIndex = query\n ? ArrayExt.findFirstIndex(results, Private.canActivate)\n : -1;\n }\n\n // If there is no query and no results, clear the content.\n if (!query && results.length === 0) {\n VirtualDOM.render(null, contentNode);\n return;\n }\n\n // If the is a query but no results, render the empty message.\n if (query && results.length === 0) {\n let content = this.renderer.renderEmptyMessage({ query });\n VirtualDOM.render(content, contentNode);\n return;\n }\n\n // Create the render content for the search results.\n let renderer = this.renderer;\n let activeIndex = this._activeIndex;\n let content = new Array(results.length);\n for (let i = 0, n = results.length; i < n; ++i) {\n let result = results[i];\n if (result.type === 'header') {\n let indices = result.indices;\n let category = result.category;\n content[i] = renderer.renderHeader({ category, indices });\n } else {\n let item = result.item;\n let indices = result.indices;\n let active = i === activeIndex;\n content[i] = renderer.renderItem({ item, indices, active });\n }\n }\n\n // Render the search result content.\n VirtualDOM.render(content, contentNode);\n\n // Adjust the scroll position as needed.\n if (activeIndex < 0 || activeIndex >= results.length) {\n contentNode.scrollTop = 0;\n } else {\n let element = contentNode.children[activeIndex];\n ElementExt.scrollIntoViewIfNeeded(contentNode, element);\n }\n }\n\n /**\n * Handle the `'click'` event for the command palette.\n */\n private _evtClick(event: MouseEvent): void {\n // Bail if the click is not the left button.\n if (event.button !== 0) {\n return;\n }\n\n // Clear input if the target is clear button\n if ((event.target as HTMLElement).classList.contains('lm-close-icon')) {\n this.inputNode.value = '';\n this.refresh();\n return;\n }\n\n // Find the index of the item which was clicked.\n let index = ArrayExt.findFirstIndex(this.contentNode.children, node => {\n return node.contains(event.target as HTMLElement);\n });\n\n // Bail if the click was not on an item.\n if (index === -1) {\n return;\n }\n\n // Kill the event when a content item is clicked.\n event.preventDefault();\n event.stopPropagation();\n\n // Execute the item if possible.\n this._execute(index);\n }\n\n /**\n * Handle the `'keydown'` event for the command palette.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n if (event.altKey || event.ctrlKey || event.metaKey || event.shiftKey) {\n return;\n }\n switch (event.keyCode) {\n case 13: // Enter\n event.preventDefault();\n event.stopPropagation();\n this._execute(this._activeIndex);\n break;\n case 38: // Up Arrow\n event.preventDefault();\n event.stopPropagation();\n this._activatePreviousItem();\n break;\n case 40: // Down Arrow\n event.preventDefault();\n event.stopPropagation();\n this._activateNextItem();\n break;\n }\n }\n\n /**\n * Activate the next enabled command item.\n */\n private _activateNextItem(): void {\n // Bail if there are no search results.\n if (!this._results || this._results.length === 0) {\n return;\n }\n\n // Find the next enabled item index.\n let ai = this._activeIndex;\n let n = this._results.length;\n let start = ai < n - 1 ? ai + 1 : 0;\n let stop = start === 0 ? n - 1 : start - 1;\n this._activeIndex = ArrayExt.findFirstIndex(\n this._results,\n Private.canActivate,\n start,\n stop\n );\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * Activate the previous enabled command item.\n */\n private _activatePreviousItem(): void {\n // Bail if there are no search results.\n if (!this._results || this._results.length === 0) {\n return;\n }\n\n // Find the previous enabled item index.\n let ai = this._activeIndex;\n let n = this._results.length;\n let start = ai <= 0 ? n - 1 : ai - 1;\n let stop = start === n - 1 ? 0 : start + 1;\n this._activeIndex = ArrayExt.findLastIndex(\n this._results,\n Private.canActivate,\n start,\n stop\n );\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * Execute the command item at the given index, if possible.\n */\n private _execute(index: number): void {\n // Bail if there are no search results.\n if (!this._results) {\n return;\n }\n\n // Bail if the index is out of range.\n let part = this._results[index];\n if (!part) {\n return;\n }\n\n // Update the search text if the item is a header.\n if (part.type === 'header') {\n let input = this.inputNode;\n input.value = `${part.category.toLowerCase()} `;\n input.focus();\n this.refresh();\n return;\n }\n\n // Bail if item is not enabled.\n if (!part.item.isEnabled) {\n return;\n }\n\n // Execute the item.\n this.commands.execute(part.item.command, part.item.args);\n\n // Clear the query text.\n this.inputNode.value = '';\n\n // Refresh the search results.\n this.refresh();\n }\n\n /**\n * Toggle the focused modifier based on the input node focus state.\n */\n private _toggleFocused(): void {\n let focused = document.activeElement === this.inputNode;\n this.toggleClass('lm-mod-focused', focused);\n }\n\n /**\n * A signal handler for generic command changes.\n */\n private _onGenericChange(): void {\n this.refresh();\n }\n\n private _activeIndex = -1;\n private _items: CommandPalette.IItem[] = [];\n private _results: Private.SearchResult[] | null = null;\n}\n\n/**\n * The namespace for the `CommandPalette` class statics.\n */\nexport namespace CommandPalette {\n /**\n * An options object for creating a command palette.\n */\n export interface IOptions {\n /**\n * The command registry for use with the command palette.\n */\n commands: CommandRegistry;\n\n /**\n * A custom renderer for use with the command palette.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n }\n\n /**\n * An options object for creating a command item.\n */\n export interface IItemOptions {\n /**\n * The category for the item.\n */\n category: string;\n\n /**\n * The command to execute when the item is triggered.\n */\n command: string;\n\n /**\n * The arguments for the command.\n *\n * The default value is an empty object.\n */\n args?: ReadonlyJSONObject;\n\n /**\n * The rank for the command item.\n *\n * The rank is used as a tie-breaker when ordering command items\n * for display. Items are sorted in the following order:\n * 1. Text match (lower is better)\n * 2. Category (locale order)\n * 3. Rank (lower is better)\n * 4. Label (locale order)\n *\n * The default rank is `Infinity`.\n */\n rank?: number;\n }\n\n /**\n * An object which represents an item in a command palette.\n *\n * #### Notes\n * Item objects are created automatically by a command palette.\n */\n export interface IItem {\n /**\n * The command to execute when the item is triggered.\n */\n readonly command: string;\n\n /**\n * The arguments for the command.\n */\n readonly args: ReadonlyJSONObject;\n\n /**\n * The category for the command item.\n */\n readonly category: string;\n\n /**\n * The rank for the command item.\n */\n readonly rank: number;\n\n /**\n * The display label for the command item.\n */\n readonly label: string;\n\n /**\n * The display caption for the command item.\n */\n readonly caption: string;\n\n /**\n * The icon renderer for the command item.\n */\n readonly icon: VirtualElement.IRenderer | undefined;\n\n /**\n * The icon class for the command item.\n */\n readonly iconClass: string;\n\n /**\n * The icon label for the command item.\n */\n readonly iconLabel: string;\n\n /**\n * The extra class name for the command item.\n */\n readonly className: string;\n\n /**\n * The dataset for the command item.\n */\n readonly dataset: CommandRegistry.Dataset;\n\n /**\n * Whether the command item is enabled.\n */\n readonly isEnabled: boolean;\n\n /**\n * Whether the command item is toggled.\n */\n readonly isToggled: boolean;\n\n /**\n * Whether the command item is toggleable.\n */\n readonly isToggleable: boolean;\n\n /**\n * Whether the command item is visible.\n */\n readonly isVisible: boolean;\n\n /**\n * The key binding for the command item.\n */\n readonly keyBinding: CommandRegistry.IKeyBinding | null;\n }\n\n /**\n * The render data for a command palette header.\n */\n export interface IHeaderRenderData {\n /**\n * The category of the header.\n */\n readonly category: string;\n\n /**\n * The indices of the matched characters in the category.\n */\n readonly indices: ReadonlyArray | null;\n }\n\n /**\n * The render data for a command palette item.\n */\n export interface IItemRenderData {\n /**\n * The command palette item to render.\n */\n readonly item: IItem;\n\n /**\n * The indices of the matched characters in the label.\n */\n readonly indices: ReadonlyArray | null;\n\n /**\n * Whether the item is the active item.\n */\n readonly active: boolean;\n }\n\n /**\n * The render data for a command palette empty message.\n */\n export interface IEmptyMessageRenderData {\n /**\n * The query which failed to match any commands.\n */\n query: string;\n }\n\n /**\n * A renderer for use with a command palette.\n */\n export interface IRenderer {\n /**\n * Render the virtual element for a command palette header.\n *\n * @param data - The data to use for rendering the header.\n *\n * @returns A virtual element representing the header.\n */\n renderHeader(data: IHeaderRenderData): VirtualElement;\n\n /**\n * Render the virtual element for a command palette item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n *\n * #### Notes\n * The command palette will not render invisible items.\n */\n renderItem(data: IItemRenderData): VirtualElement;\n\n /**\n * Render the empty results message for a command palette.\n *\n * @param data - The data to use for rendering the message.\n *\n * @returns A virtual element representing the message.\n */\n renderEmptyMessage(data: IEmptyMessageRenderData): VirtualElement;\n }\n\n /**\n * The default implementation of `IRenderer`.\n */\n export class Renderer implements IRenderer {\n /**\n * Render the virtual element for a command palette header.\n *\n * @param data - The data to use for rendering the header.\n *\n * @returns A virtual element representing the header.\n */\n renderHeader(data: IHeaderRenderData): VirtualElement {\n let content = this.formatHeader(data);\n return h.li({ className: 'lm-CommandPalette-header' }, content);\n }\n\n /**\n * Render the virtual element for a command palette item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n */\n renderItem(data: IItemRenderData): VirtualElement {\n let className = this.createItemClass(data);\n let dataset = this.createItemDataset(data);\n if (data.item.isToggleable) {\n return h.li(\n {\n className,\n dataset,\n role: 'menuitemcheckbox',\n 'aria-checked': `${data.item.isToggled}`\n },\n this.renderItemIcon(data),\n this.renderItemContent(data),\n this.renderItemShortcut(data)\n );\n }\n return h.li(\n {\n className,\n dataset,\n role: 'menuitem'\n },\n this.renderItemIcon(data),\n this.renderItemContent(data),\n this.renderItemShortcut(data)\n );\n }\n\n /**\n * Render the empty results message for a command palette.\n *\n * @param data - The data to use for rendering the message.\n *\n * @returns A virtual element representing the message.\n */\n renderEmptyMessage(data: IEmptyMessageRenderData): VirtualElement {\n let content = this.formatEmptyMessage(data);\n return h.li({ className: 'lm-CommandPalette-emptyMessage' }, content);\n }\n\n /**\n * Render the icon for a command palette item.\n *\n * @param data - The data to use for rendering the icon.\n *\n * @returns A virtual element representing the icon.\n */\n renderItemIcon(data: IItemRenderData): VirtualElement {\n let className = this.createIconClass(data);\n\n // If data.item.icon is undefined, it will be ignored.\n return h.div({ className }, data.item.icon!, data.item.iconLabel);\n }\n\n /**\n * Render the content for a command palette item.\n *\n * @param data - The data to use for rendering the content.\n *\n * @returns A virtual element representing the content.\n */\n renderItemContent(data: IItemRenderData): VirtualElement {\n return h.div(\n { className: 'lm-CommandPalette-itemContent' },\n this.renderItemLabel(data),\n this.renderItemCaption(data)\n );\n }\n\n /**\n * Render the label for a command palette item.\n *\n * @param data - The data to use for rendering the label.\n *\n * @returns A virtual element representing the label.\n */\n renderItemLabel(data: IItemRenderData): VirtualElement {\n let content = this.formatItemLabel(data);\n return h.div({ className: 'lm-CommandPalette-itemLabel' }, content);\n }\n\n /**\n * Render the caption for a command palette item.\n *\n * @param data - The data to use for rendering the caption.\n *\n * @returns A virtual element representing the caption.\n */\n renderItemCaption(data: IItemRenderData): VirtualElement {\n let content = this.formatItemCaption(data);\n return h.div({ className: 'lm-CommandPalette-itemCaption' }, content);\n }\n\n /**\n * Render the shortcut for a command palette item.\n *\n * @param data - The data to use for rendering the shortcut.\n *\n * @returns A virtual element representing the shortcut.\n */\n renderItemShortcut(data: IItemRenderData): VirtualElement {\n let content = this.formatItemShortcut(data);\n return h.div({ className: 'lm-CommandPalette-itemShortcut' }, content);\n }\n\n /**\n * Create the class name for the command palette item.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the command palette item.\n */\n createItemClass(data: IItemRenderData): string {\n // Set up the initial class name.\n let name = 'lm-CommandPalette-item';\n\n // Add the boolean state classes.\n if (!data.item.isEnabled) {\n name += ' lm-mod-disabled';\n }\n if (data.item.isToggled) {\n name += ' lm-mod-toggled';\n }\n if (data.active) {\n name += ' lm-mod-active';\n }\n\n // Add the extra class.\n let extra = data.item.className;\n if (extra) {\n name += ` ${extra}`;\n }\n\n // Return the complete class name.\n return name;\n }\n\n /**\n * Create the dataset for the command palette item.\n *\n * @param data - The data to use for creating the dataset.\n *\n * @returns The dataset for the command palette item.\n */\n createItemDataset(data: IItemRenderData): ElementDataset {\n return { ...data.item.dataset, command: data.item.command };\n }\n\n /**\n * Create the class name for the command item icon.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the item icon.\n */\n createIconClass(data: IItemRenderData): string {\n let name = 'lm-CommandPalette-itemIcon';\n let extra = data.item.iconClass;\n return extra ? `${name} ${extra}` : name;\n }\n\n /**\n * Create the render content for the header node.\n *\n * @param data - The data to use for the header content.\n *\n * @returns The content to add to the header node.\n */\n formatHeader(data: IHeaderRenderData): h.Child {\n if (!data.indices || data.indices.length === 0) {\n return data.category;\n }\n return StringExt.highlight(data.category, data.indices, h.mark);\n }\n\n /**\n * Create the render content for the empty message node.\n *\n * @param data - The data to use for the empty message content.\n *\n * @returns The content to add to the empty message node.\n */\n formatEmptyMessage(data: IEmptyMessageRenderData): h.Child {\n return `No commands found that match '${data.query}'`;\n }\n\n /**\n * Create the render content for the item shortcut node.\n *\n * @param data - The data to use for the shortcut content.\n *\n * @returns The content to add to the shortcut node.\n */\n formatItemShortcut(data: IItemRenderData): h.Child {\n let kb = data.item.keyBinding;\n return kb ? CommandRegistry.formatKeystroke(kb.keys) : null;\n }\n\n /**\n * Create the render content for the item label node.\n *\n * @param data - The data to use for the label content.\n *\n * @returns The content to add to the label node.\n */\n formatItemLabel(data: IItemRenderData): h.Child {\n if (!data.indices || data.indices.length === 0) {\n return data.item.label;\n }\n return StringExt.highlight(data.item.label, data.indices, h.mark);\n }\n\n /**\n * Create the render content for the item caption node.\n *\n * @param data - The data to use for the caption content.\n *\n * @returns The content to add to the caption node.\n */\n formatItemCaption(data: IItemRenderData): h.Child {\n return data.item.caption;\n }\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Create the DOM node for a command palette.\n */\n export function createNode(): HTMLDivElement {\n let node = document.createElement('div');\n let search = document.createElement('div');\n let wrapper = document.createElement('div');\n let input = document.createElement('input');\n let content = document.createElement('ul');\n let clear = document.createElement('button');\n search.className = 'lm-CommandPalette-search';\n wrapper.className = 'lm-CommandPalette-wrapper';\n input.className = 'lm-CommandPalette-input';\n clear.className = 'lm-close-icon';\n\n content.className = 'lm-CommandPalette-content';\n content.setAttribute('role', 'menu');\n input.spellcheck = false;\n wrapper.appendChild(input);\n wrapper.appendChild(clear);\n search.appendChild(wrapper);\n node.appendChild(search);\n node.appendChild(content);\n return node;\n }\n\n /**\n * Create a new command item from a command registry and options.\n */\n export function createItem(\n commands: CommandRegistry,\n options: CommandPalette.IItemOptions\n ): CommandPalette.IItem {\n return new CommandItem(commands, options);\n }\n\n /**\n * A search result object for a header label.\n */\n export interface IHeaderResult {\n /**\n * The discriminated type of the object.\n */\n readonly type: 'header';\n\n /**\n * The category for the header.\n */\n readonly category: string;\n\n /**\n * The indices of the matched category characters.\n */\n readonly indices: ReadonlyArray | null;\n }\n\n /**\n * A search result object for a command item.\n */\n export interface IItemResult {\n /**\n * The discriminated type of the object.\n */\n readonly type: 'item';\n\n /**\n * The command item which was matched.\n */\n readonly item: CommandPalette.IItem;\n\n /**\n * The indices of the matched label characters.\n */\n readonly indices: ReadonlyArray | null;\n }\n\n /**\n * A type alias for a search result item.\n */\n export type SearchResult = IHeaderResult | IItemResult;\n\n /**\n * Search an array of command items for fuzzy matches.\n */\n export function search(\n items: CommandPalette.IItem[],\n query: string\n ): SearchResult[] {\n // Fuzzy match the items for the query.\n let scores = matchItems(items, query);\n\n // Sort the items based on their score.\n scores.sort(scoreCmp);\n\n // Create the results for the search.\n return createResults(scores);\n }\n\n /**\n * Test whether a result item can be activated.\n */\n export function canActivate(result: SearchResult): boolean {\n return result.type === 'item' && result.item.isEnabled;\n }\n\n /**\n * Normalize a category for a command item.\n */\n function normalizeCategory(category: string): string {\n return category.trim().replace(/\\s+/g, ' ');\n }\n\n /**\n * Normalize the query text for a fuzzy search.\n */\n function normalizeQuery(text: string): string {\n return text.replace(/\\s+/g, '').toLowerCase();\n }\n\n /**\n * An enum of the supported match types.\n */\n const enum MatchType {\n Label,\n Category,\n Split,\n Default\n }\n\n /**\n * A text match score with associated command item.\n */\n interface IScore {\n /**\n * The numerical type for the text match.\n */\n matchType: MatchType;\n\n /**\n * The numerical score for the text match.\n */\n score: number;\n\n /**\n * The indices of the matched category characters.\n */\n categoryIndices: number[] | null;\n\n /**\n * The indices of the matched label characters.\n */\n labelIndices: number[] | null;\n\n /**\n * The command item associated with the match.\n */\n item: CommandPalette.IItem;\n }\n\n /**\n * Perform a fuzzy match on an array of command items.\n */\n function matchItems(items: CommandPalette.IItem[], query: string): IScore[] {\n // Normalize the query text to lower case with no whitespace.\n query = normalizeQuery(query);\n\n // Create the array to hold the scores.\n let scores: IScore[] = [];\n\n // Iterate over the items and match against the query.\n for (let i = 0, n = items.length; i < n; ++i) {\n // Ignore items which are not visible.\n let item = items[i];\n if (!item.isVisible) {\n continue;\n }\n\n // If the query is empty, all items are matched by default.\n if (!query) {\n scores.push({\n matchType: MatchType.Default,\n categoryIndices: null,\n labelIndices: null,\n score: 0,\n item\n });\n continue;\n }\n\n // Run the fuzzy search for the item and query.\n let score = fuzzySearch(item, query);\n\n // Ignore the item if it is not a match.\n if (!score) {\n continue;\n }\n\n // Penalize disabled items.\n // TODO - push disabled items all the way down in sort cmp?\n if (!item.isEnabled) {\n score.score += 1000;\n }\n\n // Add the score to the results.\n scores.push(score);\n }\n\n // Return the final array of scores.\n return scores;\n }\n\n /**\n * Perform a fuzzy search on a single command item.\n */\n function fuzzySearch(\n item: CommandPalette.IItem,\n query: string\n ): IScore | null {\n // Create the source text to be searched.\n let category = item.category.toLowerCase();\n let label = item.label.toLowerCase();\n let source = `${category} ${label}`;\n\n // Set up the match score and indices array.\n let score = Infinity;\n let indices: number[] | null = null;\n\n // The regex for search word boundaries\n let rgx = /\\b\\w/g;\n\n // Search the source by word boundary.\n // eslint-disable-next-line no-constant-condition\n while (true) {\n // Find the next word boundary in the source.\n let rgxMatch = rgx.exec(source);\n\n // Break if there is no more source context.\n if (!rgxMatch) {\n break;\n }\n\n // Run the string match on the relevant substring.\n let match = StringExt.matchSumOfDeltas(source, query, rgxMatch.index);\n\n // Break if there is no match.\n if (!match) {\n break;\n }\n\n // Update the match if the score is better.\n if (match.score <= score) {\n score = match.score;\n indices = match.indices;\n }\n }\n\n // Bail if there was no match.\n if (!indices || score === Infinity) {\n return null;\n }\n\n // Compute the pivot index between category and label text.\n let pivot = category.length + 1;\n\n // Find the slice index to separate matched indices.\n let j = ArrayExt.lowerBound(indices, pivot, (a, b) => a - b);\n\n // Extract the matched category and label indices.\n let categoryIndices = indices.slice(0, j);\n let labelIndices = indices.slice(j);\n\n // Adjust the label indices for the pivot offset.\n for (let i = 0, n = labelIndices.length; i < n; ++i) {\n labelIndices[i] -= pivot;\n }\n\n // Handle a pure label match.\n if (categoryIndices.length === 0) {\n return {\n matchType: MatchType.Label,\n categoryIndices: null,\n labelIndices,\n score,\n item\n };\n }\n\n // Handle a pure category match.\n if (labelIndices.length === 0) {\n return {\n matchType: MatchType.Category,\n categoryIndices,\n labelIndices: null,\n score,\n item\n };\n }\n\n // Handle a split match.\n return {\n matchType: MatchType.Split,\n categoryIndices,\n labelIndices,\n score,\n item\n };\n }\n\n /**\n * A sort comparison function for a match score.\n */\n function scoreCmp(a: IScore, b: IScore): number {\n // First compare based on the match type\n let m1 = a.matchType - b.matchType;\n if (m1 !== 0) {\n return m1;\n }\n\n // Otherwise, compare based on the match score.\n let d1 = a.score - b.score;\n if (d1 !== 0) {\n return d1;\n }\n\n // Find the match index based on the match type.\n let i1 = 0;\n let i2 = 0;\n switch (a.matchType) {\n case MatchType.Label:\n i1 = a.labelIndices![0];\n i2 = b.labelIndices![0];\n break;\n case MatchType.Category:\n case MatchType.Split:\n i1 = a.categoryIndices![0];\n i2 = b.categoryIndices![0];\n break;\n }\n\n // Compare based on the match index.\n if (i1 !== i2) {\n return i1 - i2;\n }\n\n // Otherwise, compare by category.\n let d2 = a.item.category.localeCompare(b.item.category);\n if (d2 !== 0) {\n return d2;\n }\n\n // Otherwise, compare by rank.\n let r1 = a.item.rank;\n let r2 = b.item.rank;\n if (r1 !== r2) {\n return r1 < r2 ? -1 : 1; // Infinity safe\n }\n\n // Finally, compare by label.\n return a.item.label.localeCompare(b.item.label);\n }\n\n /**\n * Create the results from an array of sorted scores.\n */\n function createResults(scores: IScore[]): SearchResult[] {\n // Set up the search results array.\n let results: SearchResult[] = [];\n\n // Iterate over each score in the array.\n for (let i = 0, n = scores.length; i < n; ++i) {\n // Extract the current item and indices.\n let { item, categoryIndices, labelIndices } = scores[i];\n\n // Extract the category for the current item.\n let category = item.category;\n\n // Is this the same category as the preceding result?\n if (i === 0 || category !== scores[i - 1].item.category) {\n // Add the header result for the category.\n results.push({ type: 'header', category, indices: categoryIndices });\n }\n\n // Create the item result for the score.\n results.push({ type: 'item', item, indices: labelIndices });\n }\n\n // Return the final results.\n return results;\n }\n\n /**\n * A concrete implementation of `CommandPalette.IItem`.\n */\n class CommandItem implements CommandPalette.IItem {\n /**\n * Construct a new command item.\n */\n constructor(\n commands: CommandRegistry,\n options: CommandPalette.IItemOptions\n ) {\n this._commands = commands;\n this.category = normalizeCategory(options.category);\n this.command = options.command;\n this.args = options.args || JSONExt.emptyObject;\n this.rank = options.rank !== undefined ? options.rank : Infinity;\n }\n\n /**\n * The category for the command item.\n */\n readonly category: string;\n\n /**\n * The command to execute when the item is triggered.\n */\n readonly command: string;\n\n /**\n * The arguments for the command.\n */\n readonly args: ReadonlyJSONObject;\n\n /**\n * The rank for the command item.\n */\n readonly rank: number;\n\n /**\n * The display label for the command item.\n */\n get label(): string {\n return this._commands.label(this.command, this.args);\n }\n\n /**\n * The icon renderer for the command item.\n */\n get icon(): VirtualElement.IRenderer | undefined {\n return this._commands.icon(this.command, this.args);\n }\n\n /**\n * The icon class for the command item.\n */\n get iconClass(): string {\n return this._commands.iconClass(this.command, this.args);\n }\n\n /**\n * The icon label for the command item.\n */\n get iconLabel(): string {\n return this._commands.iconLabel(this.command, this.args);\n }\n\n /**\n * The display caption for the command item.\n */\n get caption(): string {\n return this._commands.caption(this.command, this.args);\n }\n\n /**\n * The extra class name for the command item.\n */\n get className(): string {\n return this._commands.className(this.command, this.args);\n }\n\n /**\n * The dataset for the command item.\n */\n get dataset(): CommandRegistry.Dataset {\n return this._commands.dataset(this.command, this.args);\n }\n\n /**\n * Whether the command item is enabled.\n */\n get isEnabled(): boolean {\n return this._commands.isEnabled(this.command, this.args);\n }\n\n /**\n * Whether the command item is toggled.\n */\n get isToggled(): boolean {\n return this._commands.isToggled(this.command, this.args);\n }\n\n /**\n * Whether the command item is toggleable.\n */\n get isToggleable(): boolean {\n return this._commands.isToggleable(this.command, this.args);\n }\n\n /**\n * Whether the command item is visible.\n */\n get isVisible(): boolean {\n return this._commands.isVisible(this.command, this.args);\n }\n\n /**\n * The key binding for the command item.\n */\n get keyBinding(): CommandRegistry.IKeyBinding | null {\n let { command, args } = this;\n return (\n ArrayExt.findLastValue(this._commands.keyBindings, kb => {\n return kb.command === command && JSONExt.deepEqual(kb.args, args);\n }) || null\n );\n }\n\n private _commands: CommandRegistry;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { CommandRegistry } from '@lumino/commands';\n\nimport { JSONExt, ReadonlyJSONObject } from '@lumino/coreutils';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { getKeyboardLayout } from '@lumino/keyboard';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport {\n ARIAAttrNames,\n ElementARIAAttrs,\n ElementDataset,\n h,\n VirtualDOM,\n VirtualElement\n} from '@lumino/virtualdom';\n\nimport { Widget } from './widget';\n\ninterface IWindowData {\n pageXOffset: number;\n pageYOffset: number;\n clientWidth: number;\n clientHeight: number;\n}\n\n/**\n * A widget which displays items as a canonical menu.\n */\nexport class Menu extends Widget {\n /**\n * Construct a new menu.\n *\n * @param options - The options for initializing the menu.\n */\n constructor(options: Menu.IOptions) {\n super({ node: Private.createNode() });\n this.addClass('lm-Menu');\n this.setFlag(Widget.Flag.DisallowLayout);\n this.commands = options.commands;\n this.renderer = options.renderer || Menu.defaultRenderer;\n }\n\n /**\n * Dispose of the resources held by the menu.\n */\n dispose(): void {\n this.close();\n this._items.length = 0;\n super.dispose();\n }\n\n /**\n * A signal emitted just before the menu is closed.\n *\n * #### Notes\n * This signal is emitted when the menu receives a `'close-request'`\n * message, just before it removes itself from the DOM.\n *\n * This signal is not emitted if the menu is already detached from\n * the DOM when it receives the `'close-request'` message.\n */\n get aboutToClose(): ISignal {\n return this._aboutToClose;\n }\n\n /**\n * A signal emitted when a new menu is requested by the user.\n *\n * #### Notes\n * This signal is emitted whenever the user presses the right or left\n * arrow keys, and a submenu cannot be opened or closed in response.\n *\n * This signal is useful when implementing menu bars in order to open\n * the next or previous menu in response to a user key press.\n *\n * This signal is only emitted for the root menu in a hierarchy.\n */\n get menuRequested(): ISignal {\n return this._menuRequested;\n }\n\n /**\n * The command registry used by the menu.\n */\n readonly commands: CommandRegistry;\n\n /**\n * The renderer used by the menu.\n */\n readonly renderer: Menu.IRenderer;\n\n /**\n * The parent menu of the menu.\n *\n * #### Notes\n * This is `null` unless the menu is an open submenu.\n */\n get parentMenu(): Menu | null {\n return this._parentMenu;\n }\n\n /**\n * The child menu of the menu.\n *\n * #### Notes\n * This is `null` unless the menu has an open submenu.\n */\n get childMenu(): Menu | null {\n return this._childMenu;\n }\n\n /**\n * The root menu of the menu hierarchy.\n */\n get rootMenu(): Menu {\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n let menu: Menu = this;\n while (menu._parentMenu) {\n menu = menu._parentMenu;\n }\n return menu;\n }\n\n /**\n * The leaf menu of the menu hierarchy.\n */\n get leafMenu(): Menu {\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n let menu: Menu = this;\n while (menu._childMenu) {\n menu = menu._childMenu;\n }\n return menu;\n }\n\n /**\n * The menu content node.\n *\n * #### Notes\n * This is the node which holds the menu item nodes.\n *\n * Modifying this node directly can lead to undefined behavior.\n */\n get contentNode(): HTMLUListElement {\n return this.node.getElementsByClassName(\n 'lm-Menu-content'\n )[0] as HTMLUListElement;\n }\n\n /**\n * Get the currently active menu item.\n */\n get activeItem(): Menu.IItem | null {\n return this._items[this._activeIndex] || null;\n }\n\n /**\n * Set the currently active menu item.\n *\n * #### Notes\n * If the item cannot be activated, the item will be set to `null`.\n */\n set activeItem(value: Menu.IItem | null) {\n this.activeIndex = value ? this._items.indexOf(value) : -1;\n }\n\n /**\n * Get the index of the currently active menu item.\n *\n * #### Notes\n * This will be `-1` if no menu item is active.\n */\n get activeIndex(): number {\n return this._activeIndex;\n }\n\n /**\n * Set the index of the currently active menu item.\n *\n * #### Notes\n * If the item cannot be activated, the index will be set to `-1`.\n */\n set activeIndex(value: number) {\n // Adjust the value for an out of range index.\n if (value < 0 || value >= this._items.length) {\n value = -1;\n }\n\n // Ensure the item can be activated.\n if (value !== -1 && !Private.canActivate(this._items[value])) {\n value = -1;\n }\n\n // Bail if the index will not change.\n if (this._activeIndex === value) {\n return;\n }\n\n // Update the active index.\n this._activeIndex = value;\n\n // Make active element in focus\n if (\n this._activeIndex >= 0 &&\n this.contentNode.childNodes[this._activeIndex]\n ) {\n (this.contentNode.childNodes[this._activeIndex] as HTMLElement).focus();\n }\n\n // schedule an update of the items.\n this.update();\n }\n\n /**\n * A read-only array of the menu items in the menu.\n */\n get items(): ReadonlyArray {\n return this._items;\n }\n\n /**\n * Activate the next selectable item in the menu.\n *\n * #### Notes\n * If no item is selectable, the index will be set to `-1`.\n */\n activateNextItem(): void {\n let n = this._items.length;\n let ai = this._activeIndex;\n let start = ai < n - 1 ? ai + 1 : 0;\n let stop = start === 0 ? n - 1 : start - 1;\n this.activeIndex = ArrayExt.findFirstIndex(\n this._items,\n Private.canActivate,\n start,\n stop\n );\n }\n\n /**\n * Activate the previous selectable item in the menu.\n *\n * #### Notes\n * If no item is selectable, the index will be set to `-1`.\n */\n activatePreviousItem(): void {\n let n = this._items.length;\n let ai = this._activeIndex;\n let start = ai <= 0 ? n - 1 : ai - 1;\n let stop = start === n - 1 ? 0 : start + 1;\n this.activeIndex = ArrayExt.findLastIndex(\n this._items,\n Private.canActivate,\n start,\n stop\n );\n }\n\n /**\n * Trigger the active menu item.\n *\n * #### Notes\n * If the active item is a submenu, it will be opened and the first\n * item will be activated.\n *\n * If the active item is a command, the command will be executed.\n *\n * If the menu is not attached, this is a no-op.\n *\n * If there is no active item, this is a no-op.\n */\n triggerActiveItem(): void {\n // Bail if the menu is not attached.\n if (!this.isAttached) {\n return;\n }\n\n // Bail if there is no active item.\n let item = this.activeItem;\n if (!item) {\n return;\n }\n\n // Cancel the pending timers.\n this._cancelOpenTimer();\n this._cancelCloseTimer();\n\n // If the item is a submenu, open it.\n if (item.type === 'submenu') {\n this._openChildMenu(true);\n return;\n }\n\n // Close the root menu before executing the command.\n this.rootMenu.close();\n\n // Execute the command for the item.\n let { command, args } = item;\n if (this.commands.isEnabled(command, args)) {\n this.commands.execute(command, args);\n } else {\n console.log(`Command '${command}' is disabled.`);\n }\n }\n\n /**\n * Add a menu item to the end of the menu.\n *\n * @param options - The options for creating the menu item.\n *\n * @returns The menu item added to the menu.\n */\n addItem(options: Menu.IItemOptions): Menu.IItem {\n return this.insertItem(this._items.length, options);\n }\n\n /**\n * Insert a menu item into the menu at the specified index.\n *\n * @param index - The index at which to insert the item.\n *\n * @param options - The options for creating the menu item.\n *\n * @returns The menu item added to the menu.\n *\n * #### Notes\n * The index will be clamped to the bounds of the items.\n */\n insertItem(index: number, options: Menu.IItemOptions): Menu.IItem {\n // Close the menu if it's attached.\n if (this.isAttached) {\n this.close();\n }\n\n // Reset the active index.\n this.activeIndex = -1;\n\n // Clamp the insert index to the array bounds.\n let i = Math.max(0, Math.min(index, this._items.length));\n\n // Create the item for the options.\n let item = Private.createItem(this, options);\n\n // Insert the item into the array.\n ArrayExt.insert(this._items, i, item);\n\n // Schedule an update of the items.\n this.update();\n\n // Return the item added to the menu.\n return item;\n }\n\n /**\n * Remove an item from the menu.\n *\n * @param item - The item to remove from the menu.\n *\n * #### Notes\n * This is a no-op if the item is not in the menu.\n */\n removeItem(item: Menu.IItem): void {\n this.removeItemAt(this._items.indexOf(item));\n }\n\n /**\n * Remove the item at a given index from the menu.\n *\n * @param index - The index of the item to remove.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n removeItemAt(index: number): void {\n // Close the menu if it's attached.\n if (this.isAttached) {\n this.close();\n }\n\n // Reset the active index.\n this.activeIndex = -1;\n\n // Remove the item from the array.\n let item = ArrayExt.removeAt(this._items, index);\n\n // Bail if the index is out of range.\n if (!item) {\n return;\n }\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * Remove all menu items from the menu.\n */\n clearItems(): void {\n // Close the menu if it's attached.\n if (this.isAttached) {\n this.close();\n }\n\n // Reset the active index.\n this.activeIndex = -1;\n\n // Bail if there is nothing to remove.\n if (this._items.length === 0) {\n return;\n }\n\n // Clear the items.\n this._items.length = 0;\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * Open the menu at the specified location.\n *\n * @param x - The client X coordinate of the menu location.\n *\n * @param y - The client Y coordinate of the menu location.\n *\n * @param options - The additional options for opening the menu.\n *\n * #### Notes\n * The menu will be opened at the given location unless it will not\n * fully fit on the screen. If it will not fit, it will be adjusted\n * to fit naturally on the screen.\n *\n * The menu will be attached under the `host` element in the DOM\n * (or `document.body` if `host` is `null`) and before the `ref`\n * element (or as the last child of `host` if `ref` is `null`).\n * The menu may be displayed outside of the `host` element\n * following the rules of CSS absolute positioning.\n *\n * This is a no-op if the menu is already attached to the DOM.\n */\n open(x: number, y: number, options: Menu.IOpenOptions = {}): void {\n // Bail early if the menu is already attached.\n if (this.isAttached) {\n return;\n }\n\n // Extract the menu options.\n let forceX = options.forceX || false;\n let forceY = options.forceY || false;\n const host = options.host ?? null;\n const ref = options.ref ?? null;\n\n // Open the menu as a root menu.\n Private.openRootMenu(this, x, y, forceX, forceY, host, ref);\n\n // Activate the menu to accept keyboard input.\n this.activate();\n }\n\n /**\n * Handle the DOM events for the menu.\n *\n * @param event - The DOM event sent to the menu.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the menu's DOM nodes. It should\n * not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'mouseup':\n this._evtMouseUp(event as MouseEvent);\n break;\n case 'mousemove':\n this._evtMouseMove(event as MouseEvent);\n break;\n case 'mouseenter':\n this._evtMouseEnter(event as MouseEvent);\n break;\n case 'mouseleave':\n this._evtMouseLeave(event as MouseEvent);\n break;\n case 'mousedown':\n this._evtMouseDown(event as MouseEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('keydown', this);\n this.node.addEventListener('mouseup', this);\n this.node.addEventListener('mousemove', this);\n this.node.addEventListener('mouseenter', this);\n this.node.addEventListener('mouseleave', this);\n this.node.addEventListener('contextmenu', this);\n this.node.ownerDocument.addEventListener('mousedown', this, true);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('keydown', this);\n this.node.removeEventListener('mouseup', this);\n this.node.removeEventListener('mousemove', this);\n this.node.removeEventListener('mouseenter', this);\n this.node.removeEventListener('mouseleave', this);\n this.node.removeEventListener('contextmenu', this);\n this.node.ownerDocument.removeEventListener('mousedown', this, true);\n }\n\n /**\n * A message handler invoked on an `'activate-request'` message.\n */\n protected onActivateRequest(msg: Message): void {\n if (this.isAttached) {\n this.node.focus();\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n let items = this._items;\n let renderer = this.renderer;\n let activeIndex = this._activeIndex;\n let collapsedFlags = Private.computeCollapsed(items);\n let content = new Array(items.length);\n for (let i = 0, n = items.length; i < n; ++i) {\n let item = items[i];\n let active = i === activeIndex;\n let collapsed = collapsedFlags[i];\n content[i] = renderer.renderItem({\n item,\n active,\n collapsed,\n onfocus: () => {\n this.activeIndex = i;\n }\n });\n }\n VirtualDOM.render(content, this.contentNode);\n }\n\n /**\n * A message handler invoked on a `'close-request'` message.\n */\n protected onCloseRequest(msg: Message): void {\n // Cancel the pending timers.\n this._cancelOpenTimer();\n this._cancelCloseTimer();\n\n // Reset the active index.\n this.activeIndex = -1;\n\n // Close any open child menu.\n let childMenu = this._childMenu;\n if (childMenu) {\n this._childIndex = -1;\n this._childMenu = null;\n childMenu._parentMenu = null;\n childMenu.close();\n }\n\n // Remove this menu from its parent and activate the parent.\n let parentMenu = this._parentMenu;\n if (parentMenu) {\n this._parentMenu = null;\n parentMenu._childIndex = -1;\n parentMenu._childMenu = null;\n parentMenu.activate();\n }\n\n // Emit the `aboutToClose` signal if the menu is attached.\n if (this.isAttached) {\n this._aboutToClose.emit(undefined);\n }\n\n // Finish closing the menu.\n super.onCloseRequest(msg);\n }\n\n /**\n * Handle the `'keydown'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the menu node.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // A menu handles all keydown events.\n event.preventDefault();\n event.stopPropagation();\n\n // Fetch the key code for the event.\n let kc = event.keyCode;\n\n // Enter\n if (kc === 13) {\n this.triggerActiveItem();\n return;\n }\n\n // Escape\n if (kc === 27) {\n this.close();\n return;\n }\n\n // Left Arrow\n if (kc === 37) {\n if (this._parentMenu) {\n this.close();\n } else {\n this._menuRequested.emit('previous');\n }\n return;\n }\n\n // Up Arrow\n if (kc === 38) {\n this.activatePreviousItem();\n return;\n }\n\n // Right Arrow\n if (kc === 39) {\n let item = this.activeItem;\n if (item && item.type === 'submenu') {\n this.triggerActiveItem();\n } else {\n this.rootMenu._menuRequested.emit('next');\n }\n return;\n }\n\n // Down Arrow\n if (kc === 40) {\n this.activateNextItem();\n return;\n }\n\n // Get the pressed key character.\n let key = getKeyboardLayout().keyForKeydownEvent(event);\n\n // Bail if the key is not valid.\n if (!key) {\n return;\n }\n\n // Search for the next best matching mnemonic item.\n let start = this._activeIndex + 1;\n let result = Private.findMnemonic(this._items, key, start);\n\n // Handle the requested mnemonic based on the search results.\n // If exactly one mnemonic is matched, that item is triggered.\n // Otherwise, the next mnemonic is activated if available,\n // followed by the auto mnemonic if available.\n if (result.index !== -1 && !result.multiple) {\n this.activeIndex = result.index;\n this.triggerActiveItem();\n } else if (result.index !== -1) {\n this.activeIndex = result.index;\n } else if (result.auto !== -1) {\n this.activeIndex = result.auto;\n }\n }\n\n /**\n * Handle the `'mouseup'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the menu node.\n */\n private _evtMouseUp(event: MouseEvent): void {\n if (event.button !== 0) {\n return;\n }\n event.preventDefault();\n event.stopPropagation();\n this.triggerActiveItem();\n }\n\n /**\n * Handle the `'mousemove'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the menu node.\n */\n private _evtMouseMove(event: MouseEvent): void {\n // Hit test the item nodes for the item under the mouse.\n let index = ArrayExt.findFirstIndex(this.contentNode.children, node => {\n return ElementExt.hitTest(node, event.clientX, event.clientY);\n });\n\n // Bail early if the mouse is already over the active index.\n if (index === this._activeIndex) {\n return;\n }\n\n // Update and coerce the active index.\n this.activeIndex = index;\n index = this.activeIndex;\n\n // If the index is the current child index, cancel the timers.\n if (index === this._childIndex) {\n this._cancelOpenTimer();\n this._cancelCloseTimer();\n return;\n }\n\n // If a child menu is currently open, start the close timer.\n if (this._childIndex !== -1) {\n this._startCloseTimer();\n }\n\n // Cancel the open timer to give a full delay for opening.\n this._cancelOpenTimer();\n\n // Bail if the active item is not a valid submenu item.\n let item = this.activeItem;\n if (!item || item.type !== 'submenu' || !item.submenu) {\n return;\n }\n\n // Start the open timer to open the active item submenu.\n this._startOpenTimer();\n }\n\n /**\n * Handle the `'mouseenter'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the menu node.\n */\n private _evtMouseEnter(event: MouseEvent): void {\n // Synchronize the active ancestor items.\n for (let menu = this._parentMenu; menu; menu = menu._parentMenu) {\n menu._cancelOpenTimer();\n menu._cancelCloseTimer();\n menu.activeIndex = menu._childIndex;\n }\n }\n\n /**\n * Handle the `'mouseleave'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the menu node.\n */\n private _evtMouseLeave(event: MouseEvent): void {\n // Cancel any pending submenu opening.\n this._cancelOpenTimer();\n\n // If there is no open child menu, just reset the active index.\n if (!this._childMenu) {\n this.activeIndex = -1;\n return;\n }\n\n // If the mouse is over the child menu, cancel the close timer.\n let { clientX, clientY } = event;\n if (ElementExt.hitTest(this._childMenu.node, clientX, clientY)) {\n this._cancelCloseTimer();\n return;\n }\n\n // Otherwise, reset the active index and start the close timer.\n this.activeIndex = -1;\n this._startCloseTimer();\n }\n\n /**\n * Handle the `'mousedown'` event for the menu.\n *\n * #### Notes\n * This listener is attached to the document node.\n */\n private _evtMouseDown(event: MouseEvent): void {\n // Bail if the menu is not a root menu.\n if (this._parentMenu) {\n return;\n }\n\n // The mouse button which is pressed is irrelevant. If the press\n // is not on a menu, the entire hierarchy is closed and the event\n // is allowed to propagate. This allows other code to act on the\n // event, such as focusing the clicked element.\n if (Private.hitTestMenus(this, event.clientX, event.clientY)) {\n event.preventDefault();\n event.stopPropagation();\n } else {\n this.close();\n }\n }\n\n /**\n * Open the child menu at the active index immediately.\n *\n * If a different child menu is already open, it will be closed,\n * even if the active item is not a valid submenu.\n */\n private _openChildMenu(activateFirst = false): void {\n // If the item is not a valid submenu, close the child menu.\n let item = this.activeItem;\n if (!item || item.type !== 'submenu' || !item.submenu) {\n this._closeChildMenu();\n return;\n }\n\n // Do nothing if the child menu will not change.\n let submenu = item.submenu;\n if (submenu === this._childMenu) {\n return;\n }\n\n // Prior to any DOM modifications save window data\n Menu.saveWindowData();\n\n // Ensure the current child menu is closed.\n this._closeChildMenu();\n\n // Update the private child state.\n this._childMenu = submenu;\n this._childIndex = this._activeIndex;\n\n // Set the parent menu reference for the child.\n submenu._parentMenu = this;\n\n // Ensure the menu is updated and lookup the item node.\n MessageLoop.sendMessage(this, Widget.Msg.UpdateRequest);\n let itemNode = this.contentNode.children[this._activeIndex];\n\n // Open the submenu at the active node.\n Private.openSubmenu(submenu, itemNode as HTMLElement);\n\n // Activate the first item if desired.\n if (activateFirst) {\n submenu.activeIndex = -1;\n submenu.activateNextItem();\n }\n\n // Activate the child menu.\n submenu.activate();\n }\n\n /**\n * Close the child menu immediately.\n *\n * This is a no-op if a child menu is not open.\n */\n private _closeChildMenu(): void {\n if (this._childMenu) {\n this._childMenu.close();\n }\n }\n\n /**\n * Start the open timer, unless it is already pending.\n */\n private _startOpenTimer(): void {\n if (this._openTimerID === 0) {\n this._openTimerID = window.setTimeout(() => {\n this._openTimerID = 0;\n this._openChildMenu();\n }, Private.TIMER_DELAY);\n }\n }\n\n /**\n * Start the close timer, unless it is already pending.\n */\n private _startCloseTimer(): void {\n if (this._closeTimerID === 0) {\n this._closeTimerID = window.setTimeout(() => {\n this._closeTimerID = 0;\n this._closeChildMenu();\n }, Private.TIMER_DELAY);\n }\n }\n\n /**\n * Cancel the open timer, if the timer is pending.\n */\n private _cancelOpenTimer(): void {\n if (this._openTimerID !== 0) {\n clearTimeout(this._openTimerID);\n this._openTimerID = 0;\n }\n }\n\n /**\n * Cancel the close timer, if the timer is pending.\n */\n private _cancelCloseTimer(): void {\n if (this._closeTimerID !== 0) {\n clearTimeout(this._closeTimerID);\n this._closeTimerID = 0;\n }\n }\n\n /**\n * Save window data used for menu positioning in transient cache.\n *\n * In order to avoid layout trashing it is recommended to invoke this\n * method immediately prior to opening the menu and any DOM modifications\n * (like closing previously visible menu, or adding a class to menu widget).\n *\n * The transient cache will be released upon `open()` call.\n */\n static saveWindowData(): void {\n Private.saveWindowData();\n }\n\n private _childIndex = -1;\n private _activeIndex = -1;\n private _openTimerID = 0;\n private _closeTimerID = 0;\n private _items: Menu.IItem[] = [];\n private _childMenu: Menu | null = null;\n private _parentMenu: Menu | null = null;\n private _aboutToClose = new Signal(this);\n private _menuRequested = new Signal(this);\n}\n\n/**\n * The namespace for the `Menu` class statics.\n */\nexport namespace Menu {\n /**\n * An options object for creating a menu.\n */\n export interface IOptions {\n /**\n * The command registry for use with the menu.\n */\n commands: CommandRegistry;\n\n /**\n * A custom renderer for use with the menu.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n }\n\n /**\n * An options object for the `open` method on a menu.\n */\n export interface IOpenOptions {\n /**\n * Whether to force the X position of the menu.\n *\n * Setting to `true` will disable the logic which repositions the\n * X coordinate of the menu if it will not fit entirely on screen.\n *\n * The default is `false`.\n */\n forceX?: boolean;\n\n /**\n * Whether to force the Y position of the menu.\n *\n * Setting to `true` will disable the logic which repositions the\n * Y coordinate of the menu if it will not fit entirely on screen.\n *\n * The default is `false`.\n */\n forceY?: boolean;\n\n /**\n * The DOM node to use as the menu's host.\n *\n * If not specified then uses `document.body`.\n */\n host?: HTMLElement;\n\n /**\n * The child of `host` to use as the reference element.\n * If this is provided, the menu will be inserted before this\n * node in the host. The default is `null`, which will cause the\n * menu to be added as the last child of the host.\n */\n ref?: HTMLElement;\n }\n\n /**\n * A type alias for a menu item type.\n */\n export type ItemType = 'command' | 'submenu' | 'separator';\n\n /**\n * An options object for creating a menu item.\n */\n export interface IItemOptions {\n /**\n * The type of the menu item.\n *\n * The default value is `'command'`.\n */\n type?: ItemType;\n\n /**\n * The command to execute when the item is triggered.\n *\n * The default value is an empty string.\n */\n command?: string;\n\n /**\n * The arguments for the command.\n *\n * The default value is an empty object.\n */\n args?: ReadonlyJSONObject;\n\n /**\n * The submenu for a `'submenu'` type item.\n *\n * The default value is `null`.\n */\n submenu?: Menu | null;\n }\n\n /**\n * An object which represents a menu item.\n *\n * #### Notes\n * Item objects are created automatically by a menu.\n */\n export interface IItem {\n /**\n * The type of the menu item.\n */\n readonly type: ItemType;\n\n /**\n * The command to execute when the item is triggered.\n */\n readonly command: string;\n\n /**\n * The arguments for the command.\n */\n readonly args: ReadonlyJSONObject;\n\n /**\n * The submenu for a `'submenu'` type item.\n */\n readonly submenu: Menu | null;\n\n /**\n * The display label for the menu item.\n */\n readonly label: string;\n\n /**\n * The mnemonic index for the menu item.\n */\n readonly mnemonic: number;\n\n /**\n * The icon renderer for the menu item.\n */\n readonly icon: VirtualElement.IRenderer | undefined;\n\n /**\n * The icon class for the menu item.\n */\n readonly iconClass: string;\n\n /**\n * The icon label for the menu item.\n */\n readonly iconLabel: string;\n\n /**\n * The display caption for the menu item.\n */\n readonly caption: string;\n\n /**\n * The extra class name for the menu item.\n */\n readonly className: string;\n\n /**\n * The dataset for the menu item.\n */\n readonly dataset: CommandRegistry.Dataset;\n\n /**\n * Whether the menu item is enabled.\n */\n readonly isEnabled: boolean;\n\n /**\n * Whether the menu item is toggled.\n */\n readonly isToggled: boolean;\n\n /**\n * Whether the menu item is visible.\n */\n readonly isVisible: boolean;\n\n /**\n * The key binding for the menu item.\n */\n readonly keyBinding: CommandRegistry.IKeyBinding | null;\n }\n\n /**\n * An object which holds the data to render a menu item.\n */\n export interface IRenderData {\n /**\n * The item to be rendered.\n */\n readonly item: IItem;\n\n /**\n * Whether the item is the active item.\n */\n readonly active: boolean;\n\n /**\n * Whether the item should be collapsed.\n */\n readonly collapsed: boolean;\n\n /**\n * Handler for when element is in focus.\n */\n readonly onfocus?: () => void;\n }\n\n /**\n * A renderer for use with a menu.\n */\n export interface IRenderer {\n /**\n * Render the virtual element for a menu item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n */\n renderItem(data: IRenderData): VirtualElement;\n }\n\n /**\n * The default implementation of `IRenderer`.\n *\n * #### Notes\n * Subclasses are free to reimplement rendering methods as needed.\n */\n export class Renderer implements IRenderer {\n /**\n * Render the virtual element for a menu item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n */\n renderItem(data: IRenderData): VirtualElement {\n let className = this.createItemClass(data);\n let dataset = this.createItemDataset(data);\n let aria = this.createItemARIA(data);\n return h.li(\n {\n className,\n dataset,\n tabindex: '0',\n onfocus: data.onfocus,\n ...aria\n },\n this.renderIcon(data),\n this.renderLabel(data),\n this.renderShortcut(data),\n this.renderSubmenu(data)\n );\n }\n\n /**\n * Render the icon element for a menu item.\n *\n * @param data - The data to use for rendering the icon.\n *\n * @returns A virtual element representing the item icon.\n */\n renderIcon(data: IRenderData): VirtualElement {\n let className = this.createIconClass(data);\n\n // If data.item.icon is undefined, it will be ignored.\n return h.div({ className }, data.item.icon!, data.item.iconLabel);\n }\n\n /**\n * Render the label element for a menu item.\n *\n * @param data - The data to use for rendering the label.\n *\n * @returns A virtual element representing the item label.\n */\n renderLabel(data: IRenderData): VirtualElement {\n let content = this.formatLabel(data);\n return h.div({ className: 'lm-Menu-itemLabel' }, content);\n }\n\n /**\n * Render the shortcut element for a menu item.\n *\n * @param data - The data to use for rendering the shortcut.\n *\n * @returns A virtual element representing the item shortcut.\n */\n renderShortcut(data: IRenderData): VirtualElement {\n let content = this.formatShortcut(data);\n return h.div({ className: 'lm-Menu-itemShortcut' }, content);\n }\n\n /**\n * Render the submenu icon element for a menu item.\n *\n * @param data - The data to use for rendering the submenu icon.\n *\n * @returns A virtual element representing the submenu icon.\n */\n renderSubmenu(data: IRenderData): VirtualElement {\n return h.div({ className: 'lm-Menu-itemSubmenuIcon' });\n }\n\n /**\n * Create the class name for the menu item.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the menu item.\n */\n createItemClass(data: IRenderData): string {\n // Setup the initial class name.\n let name = 'lm-Menu-item';\n\n // Add the boolean state classes.\n if (!data.item.isEnabled) {\n name += ' lm-mod-disabled';\n }\n if (data.item.isToggled) {\n name += ' lm-mod-toggled';\n }\n if (!data.item.isVisible) {\n name += ' lm-mod-hidden';\n }\n if (data.active) {\n name += ' lm-mod-active';\n }\n if (data.collapsed) {\n name += ' lm-mod-collapsed';\n }\n\n // Add the extra class.\n let extra = data.item.className;\n if (extra) {\n name += ` ${extra}`;\n }\n\n // Return the complete class name.\n return name;\n }\n\n /**\n * Create the dataset for the menu item.\n *\n * @param data - The data to use for creating the dataset.\n *\n * @returns The dataset for the menu item.\n */\n createItemDataset(data: IRenderData): ElementDataset {\n let result: ElementDataset;\n let { type, command, dataset } = data.item;\n if (type === 'command') {\n result = { ...dataset, type, command };\n } else {\n result = { ...dataset, type };\n }\n return result;\n }\n\n /**\n * Create the class name for the menu item icon.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the item icon.\n */\n createIconClass(data: IRenderData): string {\n let name = 'lm-Menu-itemIcon';\n let extra = data.item.iconClass;\n return extra ? `${name} ${extra}` : name;\n }\n\n /**\n * Create the aria attributes for menu item.\n *\n * @param data - The data to use for the aria attributes.\n *\n * @returns The aria attributes object for the item.\n */\n createItemARIA(data: IRenderData): ElementARIAAttrs {\n let aria: { [T in ARIAAttrNames]?: string } = {};\n switch (data.item.type) {\n case 'separator':\n aria.role = 'presentation';\n break;\n case 'submenu':\n aria['aria-haspopup'] = 'true';\n if (!data.item.isEnabled) {\n aria['aria-disabled'] = 'true';\n }\n break;\n default:\n if (!data.item.isEnabled) {\n aria['aria-disabled'] = 'true';\n }\n aria.role = 'menuitem';\n }\n return aria;\n }\n\n /**\n * Create the render content for the label node.\n *\n * @param data - The data to use for the label content.\n *\n * @returns The content to add to the label node.\n */\n formatLabel(data: IRenderData): h.Child {\n // Fetch the label text and mnemonic index.\n let { label, mnemonic } = data.item;\n\n // If the index is out of range, do not modify the label.\n if (mnemonic < 0 || mnemonic >= label.length) {\n return label;\n }\n\n // Split the label into parts.\n let prefix = label.slice(0, mnemonic);\n let suffix = label.slice(mnemonic + 1);\n let char = label[mnemonic];\n\n // Wrap the mnemonic character in a span.\n let span = h.span({ className: 'lm-Menu-itemMnemonic' }, char);\n\n // Return the content parts.\n return [prefix, span, suffix];\n }\n\n /**\n * Create the render content for the shortcut node.\n *\n * @param data - The data to use for the shortcut content.\n *\n * @returns The content to add to the shortcut node.\n */\n formatShortcut(data: IRenderData): h.Child {\n let kb = data.item.keyBinding;\n return kb ? CommandRegistry.formatKeystroke(kb.keys) : null;\n }\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The ms delay for opening and closing a submenu.\n */\n export const TIMER_DELAY = 300;\n\n /**\n * The horizontal pixel overlap for an open submenu.\n */\n export const SUBMENU_OVERLAP = 3;\n\n let transientWindowDataCache: IWindowData | null = null;\n let transientCacheCounter: number = 0;\n\n function getWindowData(): IWindowData {\n // if transient cache is in use, take one from it\n if (transientCacheCounter > 0) {\n transientCacheCounter--;\n return transientWindowDataCache!;\n }\n return _getWindowData();\n }\n\n /**\n * Store window data in transient cache.\n *\n * The transient cache will be released upon `getWindowData()` call.\n * If this function is called multiple times, the cache will be\n * retained until as many calls to `getWindowData()` were made.\n *\n * Note: should be called before any DOM modifications.\n */\n export function saveWindowData(): void {\n transientWindowDataCache = _getWindowData();\n transientCacheCounter++;\n }\n\n /**\n * Create the DOM node for a menu.\n */\n export function createNode(): HTMLDivElement {\n let node = document.createElement('div');\n let content = document.createElement('ul');\n content.className = 'lm-Menu-content';\n node.appendChild(content);\n content.setAttribute('role', 'menu');\n node.tabIndex = 0;\n return node;\n }\n\n /**\n * Test whether a menu item can be activated.\n */\n export function canActivate(item: Menu.IItem): boolean {\n return item.type !== 'separator' && item.isEnabled && item.isVisible;\n }\n\n /**\n * Create a new menu item for an owner menu.\n */\n export function createItem(\n owner: Menu,\n options: Menu.IItemOptions\n ): Menu.IItem {\n return new MenuItem(owner.commands, options);\n }\n\n /**\n * Hit test a menu hierarchy starting at the given root.\n */\n export function hitTestMenus(menu: Menu, x: number, y: number): boolean {\n for (let temp: Menu | null = menu; temp; temp = temp.childMenu) {\n if (ElementExt.hitTest(temp.node, x, y)) {\n return true;\n }\n }\n return false;\n }\n\n /**\n * Compute which extra separator items should be collapsed.\n */\n export function computeCollapsed(\n items: ReadonlyArray\n ): boolean[] {\n // Allocate the return array and fill it with `false`.\n let result = new Array(items.length);\n ArrayExt.fill(result, false);\n\n // Collapse the leading separators.\n let k1 = 0;\n let n = items.length;\n for (; k1 < n; ++k1) {\n let item = items[k1];\n if (!item.isVisible) {\n continue;\n }\n if (item.type !== 'separator') {\n break;\n }\n result[k1] = true;\n }\n\n // Hide the trailing separators.\n let k2 = n - 1;\n for (; k2 >= 0; --k2) {\n let item = items[k2];\n if (!item.isVisible) {\n continue;\n }\n if (item.type !== 'separator') {\n break;\n }\n result[k2] = true;\n }\n\n // Hide the remaining consecutive separators.\n let hide = false;\n while (++k1 < k2) {\n let item = items[k1];\n if (!item.isVisible) {\n continue;\n }\n if (item.type !== 'separator') {\n hide = false;\n } else if (hide) {\n result[k1] = true;\n } else {\n hide = true;\n }\n }\n\n // Return the resulting flags.\n return result;\n }\n\n function _getWindowData(): IWindowData {\n return {\n pageXOffset: window.pageXOffset,\n pageYOffset: window.pageYOffset,\n clientWidth: document.documentElement.clientWidth,\n clientHeight: document.documentElement.clientHeight\n };\n }\n\n /**\n * Open a menu as a root menu at the target location.\n */\n export function openRootMenu(\n menu: Menu,\n x: number,\n y: number,\n forceX: boolean,\n forceY: boolean,\n host: HTMLElement | null,\n ref: HTMLElement | null\n ): void {\n // Get the current position and size of the main viewport.\n const windowData = getWindowData();\n let px = windowData.pageXOffset;\n let py = windowData.pageYOffset;\n let cw = windowData.clientWidth;\n let ch = windowData.clientHeight;\n\n // Ensure the menu is updated before attaching and measuring.\n MessageLoop.sendMessage(menu, Widget.Msg.UpdateRequest);\n\n // Compute the maximum allowed height for the menu.\n let maxHeight = ch - (forceY ? y : 0);\n\n // Fetch common variables.\n let node = menu.node;\n let style = node.style;\n\n // Clear the menu geometry and prepare it for measuring.\n style.opacity = '0';\n style.maxHeight = `${maxHeight}px`;\n\n // Attach the menu to the document.\n Widget.attach(menu, host || document.body, ref);\n\n // Measure the size of the menu.\n let { width, height } = node.getBoundingClientRect();\n\n // Adjust the X position of the menu to fit on-screen.\n if (!forceX && x + width > px + cw) {\n x = px + cw - width;\n }\n\n // Adjust the Y position of the menu to fit on-screen.\n if (!forceY && y + height > py + ch) {\n if (y > py + ch) {\n y = py + ch - height;\n } else {\n y = y - height;\n }\n }\n\n // Update the position of the menu to the computed position.\n style.transform = `translate(${Math.max(0, x)}px, ${Math.max(0, y)}px`;\n\n // Finally, make the menu visible on the screen.\n style.opacity = '1';\n }\n\n /**\n * Open a menu as a submenu using an item node for positioning.\n */\n export function openSubmenu(submenu: Menu, itemNode: HTMLElement): void {\n // Get the current position and size of the main viewport.\n const windowData = getWindowData();\n let px = windowData.pageXOffset;\n let py = windowData.pageYOffset;\n let cw = windowData.clientWidth;\n let ch = windowData.clientHeight;\n\n // Ensure the menu is updated before opening.\n MessageLoop.sendMessage(submenu, Widget.Msg.UpdateRequest);\n\n // Compute the maximum allowed height for the menu.\n let maxHeight = ch;\n\n // Fetch common variables.\n let node = submenu.node;\n let style = node.style;\n\n // Clear the menu geometry and prepare it for measuring.\n style.opacity = '0';\n style.maxHeight = `${maxHeight}px`;\n\n // Attach the menu to the document.\n Widget.attach(submenu, itemNode.ownerDocument.body);\n\n // Measure the size of the menu.\n let { width, height } = node.getBoundingClientRect();\n\n // Compute the box sizing for the menu.\n let box = ElementExt.boxSizing(submenu.node);\n\n // Get the bounding rect for the target item node.\n let itemRect = itemNode.getBoundingClientRect();\n\n // Compute the target X position.\n let x = itemRect.right - SUBMENU_OVERLAP;\n\n // Adjust the X position to fit on the screen.\n if (x + width > px + cw) {\n x = itemRect.left + SUBMENU_OVERLAP - width;\n }\n\n // Compute the target Y position.\n let y = itemRect.top - box.borderTop - box.paddingTop;\n\n // Adjust the Y position to fit on the screen.\n if (y + height > py + ch) {\n y = itemRect.bottom + box.borderBottom + box.paddingBottom - height;\n }\n\n // Update the position of the menu to the computed position.\n style.transform = `translate(${Math.max(0, x)}px, ${Math.max(0, y)}px`;\n\n // Finally, make the menu visible on the screen.\n style.opacity = '1';\n }\n\n /**\n * The results of a mnemonic search.\n */\n export interface IMnemonicResult {\n /**\n * The index of the first matching mnemonic item, or `-1`.\n */\n index: number;\n\n /**\n * Whether multiple mnemonic items matched.\n */\n multiple: boolean;\n\n /**\n * The index of the first auto matched non-mnemonic item.\n */\n auto: number;\n }\n\n /**\n * Find the best matching mnemonic item.\n *\n * The search starts at the given index and wraps around.\n */\n export function findMnemonic(\n items: ReadonlyArray,\n key: string,\n start: number\n ): IMnemonicResult {\n // Setup the result variables.\n let index = -1;\n let auto = -1;\n let multiple = false;\n\n // Normalize the key to upper case.\n let upperKey = key.toUpperCase();\n\n // Search the items from the given start index.\n for (let i = 0, n = items.length; i < n; ++i) {\n // Compute the wrapped index.\n let k = (i + start) % n;\n\n // Lookup the item\n let item = items[k];\n\n // Ignore items which cannot be activated.\n if (!canActivate(item)) {\n continue;\n }\n\n // Ignore items with an empty label.\n let label = item.label;\n if (label.length === 0) {\n continue;\n }\n\n // Lookup the mnemonic index for the label.\n let mn = item.mnemonic;\n\n // Handle a valid mnemonic index.\n if (mn >= 0 && mn < label.length) {\n if (label[mn].toUpperCase() === upperKey) {\n if (index === -1) {\n index = k;\n } else {\n multiple = true;\n }\n }\n continue;\n }\n\n // Finally, handle the auto index if possible.\n if (auto === -1 && label[0].toUpperCase() === upperKey) {\n auto = k;\n }\n }\n\n // Return the search results.\n return { index, multiple, auto };\n }\n\n /**\n * A concrete implementation of `Menu.IItem`.\n */\n class MenuItem implements Menu.IItem {\n /**\n * Construct a new menu item.\n */\n constructor(commands: CommandRegistry, options: Menu.IItemOptions) {\n this._commands = commands;\n this.type = options.type || 'command';\n this.command = options.command || '';\n this.args = options.args || JSONExt.emptyObject;\n this.submenu = options.submenu || null;\n }\n\n /**\n * The type of the menu item.\n */\n readonly type: Menu.ItemType;\n\n /**\n * The command to execute when the item is triggered.\n */\n readonly command: string;\n\n /**\n * The arguments for the command.\n */\n readonly args: ReadonlyJSONObject;\n\n /**\n * The submenu for a `'submenu'` type item.\n */\n readonly submenu: Menu | null;\n\n /**\n * The display label for the menu item.\n */\n get label(): string {\n if (this.type === 'command') {\n return this._commands.label(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.label;\n }\n return '';\n }\n\n /**\n * The mnemonic index for the menu item.\n */\n get mnemonic(): number {\n if (this.type === 'command') {\n return this._commands.mnemonic(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.mnemonic;\n }\n return -1;\n }\n\n /**\n * The icon renderer for the menu item.\n */\n get icon(): VirtualElement.IRenderer | undefined {\n if (this.type === 'command') {\n return this._commands.icon(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.icon;\n }\n return undefined;\n }\n\n /**\n * The icon class for the menu item.\n */\n get iconClass(): string {\n if (this.type === 'command') {\n return this._commands.iconClass(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.iconClass;\n }\n return '';\n }\n\n /**\n * The icon label for the menu item.\n */\n get iconLabel(): string {\n if (this.type === 'command') {\n return this._commands.iconLabel(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.iconLabel;\n }\n return '';\n }\n\n /**\n * The display caption for the menu item.\n */\n get caption(): string {\n if (this.type === 'command') {\n return this._commands.caption(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.caption;\n }\n return '';\n }\n\n /**\n * The extra class name for the menu item.\n */\n get className(): string {\n if (this.type === 'command') {\n return this._commands.className(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.className;\n }\n return '';\n }\n\n /**\n * The dataset for the menu item.\n */\n get dataset(): CommandRegistry.Dataset {\n if (this.type === 'command') {\n return this._commands.dataset(this.command, this.args);\n }\n if (this.type === 'submenu' && this.submenu) {\n return this.submenu.title.dataset;\n }\n return {};\n }\n\n /**\n * Whether the menu item is enabled.\n */\n get isEnabled(): boolean {\n if (this.type === 'command') {\n return this._commands.isEnabled(this.command, this.args);\n }\n if (this.type === 'submenu') {\n return this.submenu !== null;\n }\n return true;\n }\n\n /**\n * Whether the menu item is toggled.\n */\n get isToggled(): boolean {\n if (this.type === 'command') {\n return this._commands.isToggled(this.command, this.args);\n }\n return false;\n }\n\n /**\n * Whether the menu item is visible.\n */\n get isVisible(): boolean {\n if (this.type === 'command') {\n return this._commands.isVisible(this.command, this.args);\n }\n if (this.type === 'submenu') {\n return this.submenu !== null;\n }\n return true;\n }\n\n /**\n * The key binding for the menu item.\n */\n get keyBinding(): CommandRegistry.IKeyBinding | null {\n if (this.type === 'command') {\n let { command, args } = this;\n return (\n ArrayExt.findLastValue(this._commands.keyBindings, kb => {\n return kb.command === command && JSONExt.deepEqual(kb.args, args);\n }) || null\n );\n }\n return null;\n }\n\n private _commands: CommandRegistry;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { CommandRegistry } from '@lumino/commands';\n\nimport { DisposableDelegate, IDisposable } from '@lumino/disposable';\n\nimport { Selector } from '@lumino/domutils';\n\nimport { Menu } from './menu';\n\n/**\n * An object which implements a universal context menu.\n *\n * #### Notes\n * The items shown in the context menu are determined by CSS selector\n * matching against the DOM hierarchy at the site of the mouse click.\n * This is similar in concept to how keyboard shortcuts are matched\n * in the command registry.\n */\nexport class ContextMenu {\n /**\n * Construct a new context menu.\n *\n * @param options - The options for initializing the menu.\n */\n constructor(options: ContextMenu.IOptions) {\n const { groupByTarget, sortBySelector, ...others } = options;\n this.menu = new Menu(others);\n this._groupByTarget = groupByTarget !== false;\n this._sortBySelector = sortBySelector !== false;\n }\n\n /**\n * The menu widget which displays the matched context items.\n */\n readonly menu: Menu;\n\n /**\n * Add an item to the context menu.\n *\n * @param options - The options for creating the item.\n *\n * @returns A disposable which will remove the item from the menu.\n */\n addItem(options: ContextMenu.IItemOptions): IDisposable {\n // Create an item from the given options.\n let item = Private.createItem(options, this._idTick++);\n\n // Add the item to the internal array.\n this._items.push(item);\n\n // Return a disposable which will remove the item.\n return new DisposableDelegate(() => {\n ArrayExt.removeFirstOf(this._items, item);\n });\n }\n\n /**\n * Open the context menu in response to a `'contextmenu'` event.\n *\n * @param event - The `'contextmenu'` event of interest.\n *\n * @returns `true` if the menu was opened, or `false` if no items\n * matched the event and the menu was not opened.\n *\n * #### Notes\n * This method will populate the context menu with items which match\n * the propagation path of the event, then open the menu at the mouse\n * position indicated by the event.\n */\n open(event: MouseEvent): boolean {\n // Prior to any DOM modifications update the window data.\n Menu.saveWindowData();\n\n // Clear the current contents of the context menu.\n this.menu.clearItems();\n\n // Bail early if there are no items to match.\n if (this._items.length === 0) {\n return false;\n }\n\n // Find the matching items for the event.\n let items = Private.matchItems(\n this._items,\n event,\n this._groupByTarget,\n this._sortBySelector\n );\n\n // Bail if there are no matching items.\n if (!items || items.length === 0) {\n return false;\n }\n\n // Add the filtered items to the menu.\n for (const item of items) {\n this.menu.addItem(item);\n }\n\n // Open the context menu at the current mouse position.\n this.menu.open(event.clientX, event.clientY);\n\n // Indicate success.\n return true;\n }\n\n private _groupByTarget: boolean = true;\n private _idTick = 0;\n private _items: Private.IItem[] = [];\n private _sortBySelector: boolean = true;\n}\n\n/**\n * The namespace for the `ContextMenu` class statics.\n */\nexport namespace ContextMenu {\n /**\n * An options object for initializing a context menu.\n */\n export interface IOptions {\n /**\n * The command registry to use with the context menu.\n */\n commands: CommandRegistry;\n\n /**\n * A custom renderer for use with the context menu.\n */\n renderer?: Menu.IRenderer;\n\n /**\n * Whether to sort by selector and rank or only rank.\n *\n * Default true.\n */\n sortBySelector?: boolean;\n\n /**\n * Whether to group items following the DOM hierarchy.\n *\n * Default true.\n *\n * #### Note\n * If true, when the mouse event occurs on element `span` within `div.top`,\n * the items matching `div.top` will be shown before the ones matching `body`.\n */\n groupByTarget?: boolean;\n }\n\n /**\n * An options object for creating a context menu item.\n */\n export interface IItemOptions extends Menu.IItemOptions {\n /**\n * The CSS selector for the context menu item.\n *\n * The context menu item will only be displayed in the context menu\n * when the selector matches a node on the propagation path of the\n * contextmenu event. This allows the menu item to be restricted to\n * user-defined contexts.\n *\n * The selector must not contain commas.\n */\n selector: string;\n\n /**\n * The rank for the item.\n *\n * The rank is used as a tie-breaker when ordering context menu\n * items for display. Items are sorted in the following order:\n * 1. Depth in the DOM tree (deeper is better)\n * 2. Selector specificity (higher is better)\n * 3. Rank (lower is better)\n * 4. Insertion order\n *\n * The default rank is `Infinity`.\n */\n rank?: number;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * A normalized item for a context menu.\n */\n export interface IItem extends Menu.IItemOptions {\n /**\n * The selector for the item.\n */\n selector: string;\n\n /**\n * The rank for the item.\n */\n rank: number;\n\n /**\n * The tie-breaking id for the item.\n */\n id: number;\n }\n\n /**\n * Create a normalized context menu item from an options object.\n */\n export function createItem(\n options: ContextMenu.IItemOptions,\n id: number\n ): IItem {\n let selector = validateSelector(options.selector);\n let rank = options.rank !== undefined ? options.rank : Infinity;\n return { ...options, selector, rank, id };\n }\n\n /**\n * Find the items which match a context menu event.\n *\n * The results are sorted by DOM level, specificity, and rank.\n */\n export function matchItems(\n items: IItem[],\n event: MouseEvent,\n groupByTarget: boolean,\n sortBySelector: boolean\n ): IItem[] | null {\n // Look up the target of the event.\n let target = event.target as Element | null;\n\n // Bail if there is no target.\n if (!target) {\n return null;\n }\n\n // Look up the current target of the event.\n let currentTarget = event.currentTarget as Element | null;\n\n // Bail if there is no current target.\n if (!currentTarget) {\n return null;\n }\n\n // There are some third party libraries that cause the `target` to\n // be detached from the DOM before lumino can process the event.\n // If that happens, search for a new target node by point. If that\n // node is still dangling, bail.\n if (!currentTarget.contains(target)) {\n target = document.elementFromPoint(event.clientX, event.clientY);\n if (!target || !currentTarget.contains(target)) {\n return null;\n }\n }\n\n // Set up the result array.\n let result: IItem[] = [];\n\n // Copy the items array to allow in-place modification.\n let availableItems: Array = items.slice();\n\n // Walk up the DOM hierarchy searching for matches.\n while (target !== null) {\n // Set up the match array for this DOM level.\n let matches: IItem[] = [];\n\n // Search the remaining items for matches.\n for (let i = 0, n = availableItems.length; i < n; ++i) {\n // Fetch the item.\n let item = availableItems[i];\n\n // Skip items which are already consumed.\n if (!item) {\n continue;\n }\n\n // Skip items which do not match the element.\n if (!Selector.matches(target, item.selector)) {\n continue;\n }\n\n // Add the matched item to the result for this DOM level.\n matches.push(item);\n\n // Mark the item as consumed.\n availableItems[i] = null;\n }\n\n // Sort the matches for this level and add them to the results.\n if (matches.length !== 0) {\n if (groupByTarget) {\n matches.sort(sortBySelector ? itemCmp : itemCmpRank);\n }\n result.push(...matches);\n }\n\n // Stop searching at the limits of the DOM range.\n if (target === currentTarget) {\n break;\n }\n\n // Step to the parent DOM level.\n target = target.parentElement;\n }\n\n if (!groupByTarget) {\n result.sort(sortBySelector ? itemCmp : itemCmpRank);\n }\n\n // Return the matched and sorted results.\n return result;\n }\n\n /**\n * Validate the selector for a menu item.\n *\n * This returns the validated selector, or throws if the selector is\n * invalid or contains commas.\n */\n function validateSelector(selector: string): string {\n if (selector.indexOf(',') !== -1) {\n throw new Error(`Selector cannot contain commas: ${selector}`);\n }\n if (!Selector.isValid(selector)) {\n throw new Error(`Invalid selector: ${selector}`);\n }\n return selector;\n }\n\n /**\n * A sort comparison function for a context menu item by ranks.\n */\n function itemCmpRank(a: IItem, b: IItem): number {\n // Sort based on rank.\n let r1 = a.rank;\n let r2 = b.rank;\n if (r1 !== r2) {\n return r1 < r2 ? -1 : 1; // Infinity-safe\n }\n\n // When all else fails, sort by item id.\n return a.id - b.id;\n }\n\n /**\n * A sort comparison function for a context menu item by selectors and ranks.\n */\n function itemCmp(a: IItem, b: IItem): number {\n // Sort first based on selector specificity.\n let s1 = Selector.calculateSpecificity(a.selector);\n let s2 = Selector.calculateSpecificity(b.selector);\n if (s1 !== s2) {\n return s2 - s1;\n }\n\n // If specificities are equal\n return itemCmpRank(a, b);\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Drag } from '@lumino/dragdrop';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport {\n ElementARIAAttrs,\n ElementBaseAttrs,\n ElementDataset,\n ElementInlineStyle,\n h,\n VirtualDOM,\n VirtualElement\n} from '@lumino/virtualdom';\n\nimport { Title } from './title';\n\nimport { Widget } from './widget';\n\nconst ARROW_KEYS = [\n 'ArrowLeft',\n 'ArrowUp',\n 'ArrowRight',\n 'ArrowDown',\n 'Home',\n 'End'\n];\n\n/**\n * A widget which displays titles as a single row or column of tabs.\n *\n * #### Notes\n * If CSS transforms are used to rotate nodes for vertically oriented\n * text, then tab dragging will not work correctly. The `tabsMovable`\n * property should be set to `false` when rotating nodes from CSS.\n */\nexport class TabBar extends Widget {\n /**\n * Construct a new tab bar.\n *\n * @param options - The options for initializing the tab bar.\n */\n constructor(options: TabBar.IOptions = {}) {\n super({ node: Private.createNode() });\n this.addClass('lm-TabBar');\n this.contentNode.setAttribute('role', 'tablist');\n this.setFlag(Widget.Flag.DisallowLayout);\n this._document = options.document || document;\n this.tabsMovable = options.tabsMovable || false;\n this.titlesEditable = options.titlesEditable || false;\n this.allowDeselect = options.allowDeselect || false;\n this.addButtonEnabled = options.addButtonEnabled || false;\n this.insertBehavior = options.insertBehavior || 'select-tab-if-needed';\n this.name = options.name || '';\n this.orientation = options.orientation || 'horizontal';\n this.removeBehavior = options.removeBehavior || 'select-tab-after';\n this.renderer = options.renderer || TabBar.defaultRenderer;\n }\n\n /**\n * Dispose of the resources held by the widget.\n */\n dispose(): void {\n this._releaseMouse();\n this._titles.length = 0;\n this._previousTitle = null;\n super.dispose();\n }\n\n /**\n * A signal emitted when the current tab is changed.\n *\n * #### Notes\n * This signal is emitted when the currently selected tab is changed\n * either through user or programmatic interaction.\n *\n * Notably, this signal is not emitted when the index of the current\n * tab changes due to tabs being inserted, removed, or moved. It is\n * only emitted when the actual current tab node is changed.\n */\n get currentChanged(): ISignal> {\n return this._currentChanged;\n }\n\n /**\n * A signal emitted when a tab is moved by the user.\n *\n * #### Notes\n * This signal is emitted when a tab is moved by user interaction.\n *\n * This signal is not emitted when a tab is moved programmatically.\n */\n get tabMoved(): ISignal> {\n return this._tabMoved;\n }\n\n /**\n * A signal emitted when a tab is clicked by the user.\n *\n * #### Notes\n * If the clicked tab is not the current tab, the clicked tab will be\n * made current and the `currentChanged` signal will be emitted first.\n *\n * This signal is emitted even if the clicked tab is the current tab.\n */\n get tabActivateRequested(): ISignal<\n this,\n TabBar.ITabActivateRequestedArgs\n > {\n return this._tabActivateRequested;\n }\n\n /**\n * A signal emitted when the tab bar add button is clicked.\n */\n get addRequested(): ISignal {\n return this._addRequested;\n }\n\n /**\n * A signal emitted when a tab close icon is clicked.\n *\n * #### Notes\n * This signal is not emitted unless the tab title is `closable`.\n */\n get tabCloseRequested(): ISignal> {\n return this._tabCloseRequested;\n }\n\n /**\n * A signal emitted when a tab is dragged beyond the detach threshold.\n *\n * #### Notes\n * This signal is emitted when the user drags a tab with the mouse,\n * and mouse is dragged beyond the detach threshold.\n *\n * The consumer of the signal should call `releaseMouse` and remove\n * the tab in order to complete the detach.\n *\n * This signal is only emitted once per drag cycle.\n */\n get tabDetachRequested(): ISignal> {\n return this._tabDetachRequested;\n }\n\n /**\n * The renderer used by the tab bar.\n */\n readonly renderer: TabBar.IRenderer;\n\n /**\n * The document to use with the tab bar.\n *\n * The default is the global `document` instance.\n */\n get document(): Document | ShadowRoot {\n return this._document;\n }\n\n /**\n * Whether the tabs are movable by the user.\n *\n * #### Notes\n * Tabs can always be moved programmatically.\n */\n tabsMovable: boolean;\n\n /**\n * Whether the titles can be user-edited.\n *\n */\n get titlesEditable(): boolean {\n return this._titlesEditable;\n }\n\n /**\n * Set whether titles can be user edited.\n *\n */\n set titlesEditable(value: boolean) {\n this._titlesEditable = value;\n }\n\n /**\n * Whether a tab can be deselected by the user.\n *\n * #### Notes\n * Tabs can be always be deselected programmatically.\n */\n allowDeselect: boolean;\n\n /**\n * The selection behavior when inserting a tab.\n */\n insertBehavior: TabBar.InsertBehavior;\n\n /**\n * The selection behavior when removing a tab.\n */\n removeBehavior: TabBar.RemoveBehavior;\n\n /**\n * Get the currently selected title.\n *\n * #### Notes\n * This will be `null` if no tab is selected.\n */\n get currentTitle(): Title | null {\n return this._titles[this._currentIndex] || null;\n }\n\n /**\n * Set the currently selected title.\n *\n * #### Notes\n * If the title does not exist, the title will be set to `null`.\n */\n set currentTitle(value: Title | null) {\n this.currentIndex = value ? this._titles.indexOf(value) : -1;\n }\n\n /**\n * Get the index of the currently selected tab.\n *\n * #### Notes\n * This will be `-1` if no tab is selected.\n */\n get currentIndex(): number {\n return this._currentIndex;\n }\n\n /**\n * Set the index of the currently selected tab.\n *\n * #### Notes\n * If the value is out of range, the index will be set to `-1`.\n */\n set currentIndex(value: number) {\n // Adjust for an out of range index.\n if (value < 0 || value >= this._titles.length) {\n value = -1;\n }\n\n // Bail early if the index will not change.\n if (this._currentIndex === value) {\n return;\n }\n\n // Look up the previous index and title.\n let pi = this._currentIndex;\n let pt = this._titles[pi] || null;\n\n // Look up the current index and title.\n let ci = value;\n let ct = this._titles[ci] || null;\n\n // Update the current index and previous title.\n this._currentIndex = ci;\n this._previousTitle = pt;\n\n // Schedule an update of the tabs.\n this.update();\n\n // Emit the current changed signal.\n this._currentChanged.emit({\n previousIndex: pi,\n previousTitle: pt,\n currentIndex: ci,\n currentTitle: ct\n });\n }\n\n /**\n * Get the name of the tab bar.\n */\n get name(): string {\n return this._name;\n }\n\n /**\n * Set the name of the tab bar.\n */\n set name(value: string) {\n this._name = value;\n if (value) {\n this.contentNode.setAttribute('aria-label', value);\n } else {\n this.contentNode.removeAttribute('aria-label');\n }\n }\n\n /**\n * Get the orientation of the tab bar.\n *\n * #### Notes\n * This controls whether the tabs are arranged in a row or column.\n */\n get orientation(): TabBar.Orientation {\n return this._orientation;\n }\n\n /**\n * Set the orientation of the tab bar.\n *\n * #### Notes\n * This controls whether the tabs are arranged in a row or column.\n */\n set orientation(value: TabBar.Orientation) {\n // Do nothing if the orientation does not change.\n if (this._orientation === value) {\n return;\n }\n\n // Release the mouse before making any changes.\n this._releaseMouse();\n\n // Toggle the orientation values.\n this._orientation = value;\n this.dataset['orientation'] = value;\n this.contentNode.setAttribute('aria-orientation', value);\n }\n\n /**\n * Whether the add button is enabled.\n */\n get addButtonEnabled(): boolean {\n return this._addButtonEnabled;\n }\n\n /**\n * Set whether the add button is enabled.\n */\n set addButtonEnabled(value: boolean) {\n // Do nothing if the value does not change.\n if (this._addButtonEnabled === value) {\n return;\n }\n\n this._addButtonEnabled = value;\n if (value) {\n this.addButtonNode.classList.remove('lm-mod-hidden');\n } else {\n this.addButtonNode.classList.add('lm-mod-hidden');\n }\n }\n\n /**\n * A read-only array of the titles in the tab bar.\n */\n get titles(): ReadonlyArray> {\n return this._titles;\n }\n\n /**\n * The tab bar content node.\n *\n * #### Notes\n * This is the node which holds the tab nodes.\n *\n * Modifying this node directly can lead to undefined behavior.\n */\n get contentNode(): HTMLUListElement {\n return this.node.getElementsByClassName(\n 'lm-TabBar-content'\n )[0] as HTMLUListElement;\n }\n\n /**\n * The tab bar add button node.\n *\n * #### Notes\n * This is the node which holds the add button.\n *\n * Modifying this node directly can lead to undefined behavior.\n */\n get addButtonNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-TabBar-addButton'\n )[0] as HTMLDivElement;\n }\n\n /**\n * Add a tab to the end of the tab bar.\n *\n * @param value - The title which holds the data for the tab,\n * or an options object to convert to a title.\n *\n * @returns The title object added to the tab bar.\n *\n * #### Notes\n * If the title is already added to the tab bar, it will be moved.\n */\n addTab(value: Title | Title.IOptions): Title {\n return this.insertTab(this._titles.length, value);\n }\n\n /**\n * Insert a tab into the tab bar at the specified index.\n *\n * @param index - The index at which to insert the tab.\n *\n * @param value - The title which holds the data for the tab,\n * or an options object to convert to a title.\n *\n * @returns The title object added to the tab bar.\n *\n * #### Notes\n * The index will be clamped to the bounds of the tabs.\n *\n * If the title is already added to the tab bar, it will be moved.\n */\n insertTab(index: number, value: Title | Title.IOptions): Title {\n // Release the mouse before making any changes.\n this._releaseMouse();\n\n // Coerce the value to a title.\n let title = Private.asTitle(value);\n\n // Look up the index of the title.\n let i = this._titles.indexOf(title);\n\n // Clamp the insert index to the array bounds.\n let j = Math.max(0, Math.min(index, this._titles.length));\n\n // If the title is not in the array, insert it.\n if (i === -1) {\n // Insert the title into the array.\n ArrayExt.insert(this._titles, j, title);\n\n // Connect to the title changed signal.\n title.changed.connect(this._onTitleChanged, this);\n\n // Schedule an update of the tabs.\n this.update();\n\n // Adjust the current index for the insert.\n this._adjustCurrentForInsert(j, title);\n\n // Return the title added to the tab bar.\n return title;\n }\n\n // Otherwise, the title exists in the array and should be moved.\n\n // Adjust the index if the location is at the end of the array.\n if (j === this._titles.length) {\n j--;\n }\n\n // Bail if there is no effective move.\n if (i === j) {\n return title;\n }\n\n // Move the title to the new location.\n ArrayExt.move(this._titles, i, j);\n\n // Schedule an update of the tabs.\n this.update();\n\n // Adjust the current index for the move.\n this._adjustCurrentForMove(i, j);\n\n // Return the title added to the tab bar.\n return title;\n }\n\n /**\n * Remove a tab from the tab bar.\n *\n * @param title - The title for the tab to remove.\n *\n * #### Notes\n * This is a no-op if the title is not in the tab bar.\n */\n removeTab(title: Title): void {\n this.removeTabAt(this._titles.indexOf(title));\n }\n\n /**\n * Remove the tab at a given index from the tab bar.\n *\n * @param index - The index of the tab to remove.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n removeTabAt(index: number): void {\n // Release the mouse before making any changes.\n this._releaseMouse();\n\n // Remove the title from the array.\n let title = ArrayExt.removeAt(this._titles, index);\n\n // Bail if the index is out of range.\n if (!title) {\n return;\n }\n\n // Disconnect from the title changed signal.\n title.changed.disconnect(this._onTitleChanged, this);\n\n // Clear the previous title if it's being removed.\n if (title === this._previousTitle) {\n this._previousTitle = null;\n }\n\n // Schedule an update of the tabs.\n this.update();\n\n // Adjust the current index for the remove.\n this._adjustCurrentForRemove(index, title);\n }\n\n /**\n * Remove all tabs from the tab bar.\n */\n clearTabs(): void {\n // Bail if there is nothing to remove.\n if (this._titles.length === 0) {\n return;\n }\n\n // Release the mouse before making any changes.\n this._releaseMouse();\n\n // Disconnect from the title changed signals.\n for (let title of this._titles) {\n title.changed.disconnect(this._onTitleChanged, this);\n }\n\n // Get the current index and title.\n let pi = this.currentIndex;\n let pt = this.currentTitle;\n\n // Reset the current index and previous title.\n this._currentIndex = -1;\n this._previousTitle = null;\n\n // Clear the title array.\n this._titles.length = 0;\n\n // Schedule an update of the tabs.\n this.update();\n\n // If no tab was selected, there's nothing else to do.\n if (pi === -1) {\n return;\n }\n\n // Emit the current changed signal.\n this._currentChanged.emit({\n previousIndex: pi,\n previousTitle: pt,\n currentIndex: -1,\n currentTitle: null\n });\n }\n\n /**\n * Release the mouse and restore the non-dragged tab positions.\n *\n * #### Notes\n * This will cause the tab bar to stop handling mouse events and to\n * restore the tabs to their non-dragged positions.\n */\n releaseMouse(): void {\n this._releaseMouse();\n }\n\n /**\n * Handle the DOM events for the tab bar.\n *\n * @param event - The DOM event sent to the tab bar.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the tab bar's DOM node.\n *\n * This should not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'pointerdown':\n this._evtPointerDown(event as PointerEvent);\n break;\n case 'pointermove':\n this._evtPointerMove(event as PointerEvent);\n break;\n case 'pointerup':\n this._evtPointerUp(event as PointerEvent);\n break;\n case 'dblclick':\n this._evtDblClick(event as MouseEvent);\n break;\n case 'keydown':\n event.eventPhase === Event.CAPTURING_PHASE\n ? this._evtKeyDownCapturing(event as KeyboardEvent)\n : this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('pointerdown', this);\n this.node.addEventListener('dblclick', this);\n this.node.addEventListener('keydown', this);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('pointerdown', this);\n this.node.removeEventListener('dblclick', this);\n this.node.removeEventListener('keydown', this);\n this._releaseMouse();\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n let titles = this._titles;\n let renderer = this.renderer;\n let currentTitle = this.currentTitle;\n let content = new Array(titles.length);\n // Keep the tabindex=\"0\" attribute to the tab which handled it before the update.\n // If the add button handles it, no need to do anything. If no element of the tab\n // bar handles it, set it on the current or the first tab to ensure one element\n // handles it after update.\n const tabHandlingTabindex =\n this._getCurrentTabindex() ??\n (this._currentIndex > -1 ? this._currentIndex : 0);\n\n for (let i = 0, n = titles.length; i < n; ++i) {\n let title = titles[i];\n let current = title === currentTitle;\n let zIndex = current ? n : n - i - 1;\n let tabIndex = tabHandlingTabindex === i ? 0 : -1;\n content[i] = renderer.renderTab({ title, current, zIndex, tabIndex });\n }\n VirtualDOM.render(content, this.contentNode);\n }\n\n /**\n * Get the index of the tab which handles tabindex=\"0\".\n * If the add button handles tabindex=\"0\", -1 is returned.\n * If none of the previous handles tabindex=\"0\", null is returned.\n */\n private _getCurrentTabindex(): number | null {\n let index = null;\n const elemTabindex = this.contentNode.querySelector('li[tabindex=\"0\"]');\n if (elemTabindex) {\n index = [...this.contentNode.children].indexOf(elemTabindex);\n } else if (\n this._addButtonEnabled &&\n this.addButtonNode.getAttribute('tabindex') === '0'\n ) {\n index = -1;\n }\n return index;\n }\n\n /**\n * Handle the `'dblclick'` event for the tab bar.\n */\n private _evtDblClick(event: MouseEvent): void {\n // Do nothing if titles are not editable\n if (!this.titlesEditable) {\n return;\n }\n\n let tabs = this.contentNode.children;\n\n // Find the index of the targeted tab.\n let index = ArrayExt.findFirstIndex(tabs, tab => {\n return ElementExt.hitTest(tab, event.clientX, event.clientY);\n });\n\n // Do nothing if the press is not on a tab.\n if (index === -1) {\n return;\n }\n\n let title = this.titles[index];\n let label = tabs[index].querySelector('.lm-TabBar-tabLabel') as HTMLElement;\n if (label && label.contains(event.target as HTMLElement)) {\n let value = title.label || '';\n\n // Clear the label element\n let oldValue = label.innerHTML;\n label.innerHTML = '';\n\n let input = document.createElement('input');\n input.classList.add('lm-TabBar-tabInput');\n input.value = value;\n label.appendChild(input);\n\n let onblur = () => {\n input.removeEventListener('blur', onblur);\n label.innerHTML = oldValue;\n this.node.addEventListener('keydown', this);\n };\n\n input.addEventListener('dblclick', (event: Event) =>\n event.stopPropagation()\n );\n input.addEventListener('blur', onblur);\n input.addEventListener('keydown', (event: KeyboardEvent) => {\n if (event.key === 'Enter') {\n if (input.value !== '') {\n title.label = title.caption = input.value;\n }\n onblur();\n } else if (event.key === 'Escape') {\n onblur();\n }\n });\n this.node.removeEventListener('keydown', this);\n input.select();\n input.focus();\n\n if (label.children.length > 0) {\n (label.children[0] as HTMLElement).focus();\n }\n }\n }\n\n /**\n * Handle the `'keydown'` event for the tab bar at capturing phase.\n */\n private _evtKeyDownCapturing(event: KeyboardEvent): void {\n if (event.eventPhase !== Event.CAPTURING_PHASE) {\n return;\n }\n\n // Stop all input events during drag.\n event.preventDefault();\n event.stopPropagation();\n\n // Release the mouse if `Escape` is pressed.\n if (event.key === 'Escape') {\n this._releaseMouse();\n }\n }\n\n /**\n * Handle the `'keydown'` event for the tab bar at target phase.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // Allow for navigation using tab key\n if (event.key === 'Tab' || event.eventPhase === Event.CAPTURING_PHASE) {\n return;\n }\n\n // Check if Enter or Spacebar key has been pressed and open that tab\n if (\n event.key === 'Enter' ||\n event.key === 'Spacebar' ||\n event.key === ' '\n ) {\n // Get focus element that is in focus by the tab key\n const focusedElement = document.activeElement;\n\n // Test first if the focus is on the add button node\n if (\n this.addButtonEnabled &&\n this.addButtonNode.contains(focusedElement)\n ) {\n event.preventDefault();\n event.stopPropagation();\n this._addRequested.emit();\n } else {\n const index = ArrayExt.findFirstIndex(this.contentNode.children, tab =>\n tab.contains(focusedElement)\n );\n if (index >= 0) {\n event.preventDefault();\n event.stopPropagation();\n this.currentIndex = index;\n }\n }\n // Handle the arrow keys to switch tabs.\n } else if (ARROW_KEYS.includes(event.key)) {\n // Create a list of all focusable elements in the tab bar.\n const focusable: Element[] = [...this.contentNode.children];\n if (this.addButtonEnabled) {\n focusable.push(this.addButtonNode);\n }\n // If the tab bar contains only one element, nothing to do.\n if (focusable.length <= 1) {\n return;\n }\n event.preventDefault();\n event.stopPropagation();\n\n // Get the current focused element.\n let focusedIndex = focusable.indexOf(document.activeElement as Element);\n if (focusedIndex === -1) {\n focusedIndex = this._currentIndex;\n }\n\n // Find the next element to focus on.\n let nextFocused: Element | null | undefined;\n if (\n (event.key === 'ArrowRight' && this._orientation === 'horizontal') ||\n (event.key === 'ArrowDown' && this._orientation === 'vertical')\n ) {\n nextFocused = focusable[focusedIndex + 1] ?? focusable[0];\n } else if (\n (event.key === 'ArrowLeft' && this._orientation === 'horizontal') ||\n (event.key === 'ArrowUp' && this._orientation === 'vertical')\n ) {\n nextFocused =\n focusable[focusedIndex - 1] ?? focusable[focusable.length - 1];\n } else if (event.key === 'Home') {\n nextFocused = focusable[0];\n } else if (event.key === 'End') {\n nextFocused = focusable[focusable.length - 1];\n }\n\n // Change the focused element and the tabindex value.\n if (nextFocused) {\n focusable[focusedIndex]?.setAttribute('tabindex', '-1');\n nextFocused?.setAttribute('tabindex', '0');\n (nextFocused as HTMLElement).focus();\n }\n }\n }\n\n /**\n * Handle the `'pointerdown'` event for the tab bar.\n */\n private _evtPointerDown(event: PointerEvent | MouseEvent): void {\n // Do nothing if it's not a left or middle mouse press.\n if (event.button !== 0 && event.button !== 1) {\n return;\n }\n\n // Do nothing if a drag is in progress.\n if (this._dragData) {\n return;\n }\n\n // Do nothing if a title editable input was clicked.\n if (\n (event.target as HTMLElement).classList.contains('lm-TabBar-tabInput')\n ) {\n return;\n }\n\n // Check if the add button was clicked.\n let addButtonClicked =\n this.addButtonEnabled &&\n this.addButtonNode.contains(event.target as HTMLElement);\n\n // Lookup the tab nodes.\n let tabs = this.contentNode.children;\n\n // Find the index of the pressed tab.\n let index = ArrayExt.findFirstIndex(tabs, tab => {\n return ElementExt.hitTest(tab, event.clientX, event.clientY);\n });\n\n // Do nothing if the press is not on a tab or the add button.\n if (index === -1 && !addButtonClicked) {\n return;\n }\n\n // Pressing on a tab stops the event propagation.\n event.preventDefault();\n event.stopPropagation();\n\n // Initialize the non-measured parts of the drag data.\n this._dragData = {\n tab: tabs[index] as HTMLElement,\n index: index,\n pressX: event.clientX,\n pressY: event.clientY,\n tabPos: -1,\n tabSize: -1,\n tabPressPos: -1,\n targetIndex: -1,\n tabLayout: null,\n contentRect: null,\n override: null,\n dragActive: false,\n dragAborted: false,\n detachRequested: false\n };\n\n // Add the document pointer up listener.\n this.document.addEventListener('pointerup', this, true);\n\n // Do nothing else if the middle button or add button is clicked.\n if (event.button === 1 || addButtonClicked) {\n return;\n }\n\n // Do nothing else if the close icon is clicked.\n let icon = tabs[index].querySelector(this.renderer.closeIconSelector);\n if (icon && icon.contains(event.target as HTMLElement)) {\n return;\n }\n\n // Add the extra listeners if the tabs are movable.\n if (this.tabsMovable) {\n this.document.addEventListener('pointermove', this, true);\n this.document.addEventListener('keydown', this, true);\n this.document.addEventListener('contextmenu', this, true);\n }\n\n // Update the current index as appropriate.\n if (this.allowDeselect && this.currentIndex === index) {\n this.currentIndex = -1;\n } else {\n this.currentIndex = index;\n }\n\n // Do nothing else if there is no current tab.\n if (this.currentIndex === -1) {\n return;\n }\n\n // Emit the tab activate request signal.\n this._tabActivateRequested.emit({\n index: this.currentIndex,\n title: this.currentTitle!\n });\n }\n\n /**\n * Handle the `'pointermove'` event for the tab bar.\n */\n private _evtPointerMove(event: PointerEvent | MouseEvent): void {\n // Do nothing if no drag is in progress.\n let data = this._dragData;\n if (!data) {\n return;\n }\n\n // Suppress the event during a drag.\n event.preventDefault();\n event.stopPropagation();\n\n // Lookup the tab nodes.\n let tabs = this.contentNode.children;\n\n // Bail early if the drag threshold has not been met.\n if (!data.dragActive && !Private.dragExceeded(data, event)) {\n return;\n }\n\n // Activate the drag if necessary.\n if (!data.dragActive) {\n // Fill in the rest of the drag data measurements.\n let tabRect = data.tab.getBoundingClientRect();\n if (this._orientation === 'horizontal') {\n data.tabPos = data.tab.offsetLeft;\n data.tabSize = tabRect.width;\n data.tabPressPos = data.pressX - tabRect.left;\n } else {\n data.tabPos = data.tab.offsetTop;\n data.tabSize = tabRect.height;\n data.tabPressPos = data.pressY - tabRect.top;\n }\n data.tabPressOffset = {\n x: data.pressX - tabRect.left,\n y: data.pressY - tabRect.top\n };\n data.tabLayout = Private.snapTabLayout(tabs, this._orientation);\n data.contentRect = this.contentNode.getBoundingClientRect();\n data.override = Drag.overrideCursor('default');\n\n // Add the dragging style classes.\n data.tab.classList.add('lm-mod-dragging');\n this.addClass('lm-mod-dragging');\n\n // Mark the drag as active.\n data.dragActive = true;\n }\n\n // Emit the detach requested signal if the threshold is exceeded.\n if (!data.detachRequested && Private.detachExceeded(data, event)) {\n // Only emit the signal once per drag cycle.\n data.detachRequested = true;\n\n // Setup the arguments for the signal.\n let index = data.index;\n let clientX = event.clientX;\n let clientY = event.clientY;\n let tab = tabs[index] as HTMLElement;\n let title = this._titles[index];\n\n // Emit the tab detach requested signal.\n this._tabDetachRequested.emit({\n index,\n title,\n tab,\n clientX,\n clientY,\n offset: data.tabPressOffset\n });\n\n // Bail if the signal handler aborted the drag.\n if (data.dragAborted) {\n return;\n }\n }\n\n // Update the positions of the tabs.\n Private.layoutTabs(tabs, data, event, this._orientation);\n }\n\n /**\n * Handle the `'pointerup'` event for the document.\n */\n private _evtPointerUp(event: PointerEvent | MouseEvent): void {\n // Do nothing if it's not a left or middle mouse release.\n if (event.button !== 0 && event.button !== 1) {\n return;\n }\n\n // Do nothing if no drag is in progress.\n const data = this._dragData;\n if (!data) {\n return;\n }\n\n // Stop the event propagation.\n event.preventDefault();\n event.stopPropagation();\n\n // Remove the extra mouse event listeners.\n this.document.removeEventListener('pointermove', this, true);\n this.document.removeEventListener('pointerup', this, true);\n this.document.removeEventListener('keydown', this, true);\n this.document.removeEventListener('contextmenu', this, true);\n\n // Handle a release when the drag is not active.\n if (!data.dragActive) {\n // Clear the drag data.\n this._dragData = null;\n\n // Handle clicking the add button.\n let addButtonClicked =\n this.addButtonEnabled &&\n this.addButtonNode.contains(event.target as HTMLElement);\n if (addButtonClicked) {\n this._addRequested.emit(undefined);\n return;\n }\n\n // Lookup the tab nodes.\n let tabs = this.contentNode.children;\n\n // Find the index of the released tab.\n let index = ArrayExt.findFirstIndex(tabs, tab => {\n return ElementExt.hitTest(tab, event.clientX, event.clientY);\n });\n\n // Do nothing if the release is not on the original pressed tab.\n if (index !== data.index) {\n return;\n }\n\n // Ignore the release if the title is not closable.\n let title = this._titles[index];\n if (!title.closable) {\n return;\n }\n\n // Emit the close requested signal if the middle button is released.\n if (event.button === 1) {\n this._tabCloseRequested.emit({ index, title });\n return;\n }\n\n // Emit the close requested signal if the close icon was released.\n let icon = tabs[index].querySelector(this.renderer.closeIconSelector);\n if (icon && icon.contains(event.target as HTMLElement)) {\n this._tabCloseRequested.emit({ index, title });\n return;\n }\n\n // Otherwise, there is nothing left to do.\n return;\n }\n\n // Do nothing if the left button is not released.\n if (event.button !== 0) {\n return;\n }\n\n // Position the tab at its final resting position.\n Private.finalizeTabPosition(data, this._orientation);\n\n // Remove the dragging class from the tab so it can be transitioned.\n data.tab.classList.remove('lm-mod-dragging');\n\n // Parse the transition duration for releasing the tab.\n let duration = Private.parseTransitionDuration(data.tab);\n\n // Complete the release on a timer to allow the tab to transition.\n setTimeout(() => {\n // Do nothing if the drag has been aborted.\n if (data.dragAborted) {\n return;\n }\n\n // Clear the drag data reference.\n this._dragData = null;\n\n // Reset the positions of the tabs.\n Private.resetTabPositions(this.contentNode.children, this._orientation);\n\n // Clear the cursor grab.\n data.override!.dispose();\n\n // Remove the remaining dragging style.\n this.removeClass('lm-mod-dragging');\n\n // If the tab was not moved, there is nothing else to do.\n let i = data.index;\n let j = data.targetIndex;\n if (j === -1 || i === j) {\n return;\n }\n\n // Move the title to the new locations.\n ArrayExt.move(this._titles, i, j);\n\n // Adjust the current index for the move.\n this._adjustCurrentForMove(i, j);\n\n // Emit the tab moved signal.\n this._tabMoved.emit({\n fromIndex: i,\n toIndex: j,\n title: this._titles[j]\n });\n\n // Update the tabs immediately to prevent flicker.\n MessageLoop.sendMessage(this, Widget.Msg.UpdateRequest);\n }, duration);\n }\n\n /**\n * Release the mouse and restore the non-dragged tab positions.\n */\n private _releaseMouse(): void {\n // Do nothing if no drag is in progress.\n let data = this._dragData;\n if (!data) {\n return;\n }\n\n // Clear the drag data reference.\n this._dragData = null;\n\n // Remove the extra document event listeners.\n this.document.removeEventListener('pointermove', this, true);\n this.document.removeEventListener('pointerup', this, true);\n this.document.removeEventListener('keydown', this, true);\n this.document.removeEventListener('contextmenu', this, true);\n\n // Indicate the drag has been aborted. This allows the mouse\n // event handlers to return early when the drag is canceled.\n data.dragAborted = true;\n\n // If the drag is not active, there's nothing more to do.\n if (!data.dragActive) {\n return;\n }\n\n // Reset the tabs to their non-dragged positions.\n Private.resetTabPositions(this.contentNode.children, this._orientation);\n\n // Clear the cursor override.\n data.override!.dispose();\n\n // Clear the dragging style classes.\n data.tab.classList.remove('lm-mod-dragging');\n this.removeClass('lm-mod-dragging');\n }\n\n /**\n * Adjust the current index for a tab insert operation.\n *\n * This method accounts for the tab bar's insertion behavior when\n * adjusting the current index and emitting the changed signal.\n */\n private _adjustCurrentForInsert(i: number, title: Title): void {\n // Lookup commonly used variables.\n let ct = this.currentTitle;\n let ci = this._currentIndex;\n let bh = this.insertBehavior;\n\n // TODO: do we need to do an update to update the aria-selected attribute?\n\n // Handle the behavior where the new tab is always selected,\n // or the behavior where the new tab is selected if needed.\n if (bh === 'select-tab' || (bh === 'select-tab-if-needed' && ci === -1)) {\n this._currentIndex = i;\n this._previousTitle = ct;\n this._currentChanged.emit({\n previousIndex: ci,\n previousTitle: ct,\n currentIndex: i,\n currentTitle: title\n });\n return;\n }\n\n // Otherwise, silently adjust the current index if needed.\n if (ci >= i) {\n this._currentIndex++;\n }\n }\n\n /**\n * Adjust the current index for a tab move operation.\n *\n * This method will not cause the actual current tab to change.\n * It silently adjusts the index to account for the given move.\n */\n private _adjustCurrentForMove(i: number, j: number): void {\n if (this._currentIndex === i) {\n this._currentIndex = j;\n } else if (this._currentIndex < i && this._currentIndex >= j) {\n this._currentIndex++;\n } else if (this._currentIndex > i && this._currentIndex <= j) {\n this._currentIndex--;\n }\n }\n\n /**\n * Adjust the current index for a tab remove operation.\n *\n * This method accounts for the tab bar's remove behavior when\n * adjusting the current index and emitting the changed signal.\n */\n private _adjustCurrentForRemove(i: number, title: Title): void {\n // Lookup commonly used variables.\n let ci = this._currentIndex;\n let bh = this.removeBehavior;\n\n // Silently adjust the index if the current tab is not removed.\n if (ci !== i) {\n if (ci > i) {\n this._currentIndex--;\n }\n return;\n }\n\n // TODO: do we need to do an update to adjust the aria-selected value?\n\n // No tab gets selected if the tab bar is empty.\n if (this._titles.length === 0) {\n this._currentIndex = -1;\n this._currentChanged.emit({\n previousIndex: i,\n previousTitle: title,\n currentIndex: -1,\n currentTitle: null\n });\n return;\n }\n\n // Handle behavior where the next sibling tab is selected.\n if (bh === 'select-tab-after') {\n this._currentIndex = Math.min(i, this._titles.length - 1);\n this._currentChanged.emit({\n previousIndex: i,\n previousTitle: title,\n currentIndex: this._currentIndex,\n currentTitle: this.currentTitle\n });\n return;\n }\n\n // Handle behavior where the previous sibling tab is selected.\n if (bh === 'select-tab-before') {\n this._currentIndex = Math.max(0, i - 1);\n this._currentChanged.emit({\n previousIndex: i,\n previousTitle: title,\n currentIndex: this._currentIndex,\n currentTitle: this.currentTitle\n });\n return;\n }\n\n // Handle behavior where the previous history tab is selected.\n if (bh === 'select-previous-tab') {\n if (this._previousTitle) {\n this._currentIndex = this._titles.indexOf(this._previousTitle);\n this._previousTitle = null;\n } else {\n this._currentIndex = Math.min(i, this._titles.length - 1);\n }\n this._currentChanged.emit({\n previousIndex: i,\n previousTitle: title,\n currentIndex: this._currentIndex,\n currentTitle: this.currentTitle\n });\n return;\n }\n\n // Otherwise, no tab gets selected.\n this._currentIndex = -1;\n this._currentChanged.emit({\n previousIndex: i,\n previousTitle: title,\n currentIndex: -1,\n currentTitle: null\n });\n }\n\n /**\n * Handle the `changed` signal of a title object.\n */\n private _onTitleChanged(sender: Title): void {\n this.update();\n }\n\n private _name: string;\n private _currentIndex = -1;\n private _titles: Title[] = [];\n private _orientation: TabBar.Orientation;\n private _document: Document | ShadowRoot;\n private _titlesEditable: boolean = false;\n private _previousTitle: Title | null = null;\n private _dragData: Private.IDragData | null = null;\n private _addButtonEnabled: boolean = false;\n private _tabMoved = new Signal>(this);\n private _currentChanged = new Signal>(\n this\n );\n private _addRequested = new Signal(this);\n private _tabCloseRequested = new Signal<\n this,\n TabBar.ITabCloseRequestedArgs\n >(this);\n private _tabDetachRequested = new Signal<\n this,\n TabBar.ITabDetachRequestedArgs\n >(this);\n private _tabActivateRequested = new Signal<\n this,\n TabBar.ITabActivateRequestedArgs\n >(this);\n}\n\n/**\n * The namespace for the `TabBar` class statics.\n */\nexport namespace TabBar {\n /**\n * A type alias for a tab bar orientation.\n */\n export type Orientation =\n | /**\n * The tabs are arranged in a single row, left-to-right.\n *\n * The tab text orientation is horizontal.\n */\n 'horizontal'\n\n /**\n * The tabs are arranged in a single column, top-to-bottom.\n *\n * The tab text orientation is horizontal.\n */\n | 'vertical';\n\n /**\n * A type alias for the selection behavior on tab insert.\n */\n export type InsertBehavior =\n | /**\n * The selected tab will not be changed.\n */\n 'none'\n\n /**\n * The inserted tab will be selected.\n */\n | 'select-tab'\n\n /**\n * The inserted tab will be selected if the current tab is null.\n */\n | 'select-tab-if-needed';\n\n /**\n * A type alias for the selection behavior on tab remove.\n */\n export type RemoveBehavior =\n | /**\n * No tab will be selected.\n */\n 'none'\n\n /**\n * The tab after the removed tab will be selected if possible.\n */\n | 'select-tab-after'\n\n /**\n * The tab before the removed tab will be selected if possible.\n */\n | 'select-tab-before'\n\n /**\n * The previously selected tab will be selected if possible.\n */\n | 'select-previous-tab';\n\n /**\n * An options object for creating a tab bar.\n */\n export interface IOptions {\n /**\n * The document to use with the tab bar.\n *\n * The default is the global `document` instance.\n */\n\n document?: Document | ShadowRoot;\n\n /**\n * Name of the tab bar.\n *\n * This is used for accessibility reasons. The default is the empty string.\n */\n name?: string;\n\n /**\n * The layout orientation of the tab bar.\n *\n * The default is `horizontal`.\n */\n orientation?: TabBar.Orientation;\n\n /**\n * Whether the tabs are movable by the user.\n *\n * The default is `false`.\n */\n tabsMovable?: boolean;\n\n /**\n * Whether a tab can be deselected by the user.\n *\n * The default is `false`.\n */\n allowDeselect?: boolean;\n\n /**\n * Whether the titles can be directly edited by the user.\n *\n * The default is `false`.\n */\n titlesEditable?: boolean;\n\n /**\n * Whether the add button is enabled.\n *\n * The default is `false`.\n */\n addButtonEnabled?: boolean;\n\n /**\n * The selection behavior when inserting a tab.\n *\n * The default is `'select-tab-if-needed'`.\n */\n insertBehavior?: TabBar.InsertBehavior;\n\n /**\n * The selection behavior when removing a tab.\n *\n * The default is `'select-tab-after'`.\n */\n removeBehavior?: TabBar.RemoveBehavior;\n\n /**\n * A renderer to use with the tab bar.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n }\n\n /**\n * The arguments object for the `currentChanged` signal.\n */\n export interface ICurrentChangedArgs {\n /**\n * The previously selected index.\n */\n readonly previousIndex: number;\n\n /**\n * The previously selected title.\n */\n readonly previousTitle: Title | null;\n\n /**\n * The currently selected index.\n */\n readonly currentIndex: number;\n\n /**\n * The currently selected title.\n */\n readonly currentTitle: Title | null;\n }\n\n /**\n * The arguments object for the `tabMoved` signal.\n */\n export interface ITabMovedArgs {\n /**\n * The previous index of the tab.\n */\n readonly fromIndex: number;\n\n /**\n * The current index of the tab.\n */\n readonly toIndex: number;\n\n /**\n * The title for the tab.\n */\n readonly title: Title;\n }\n\n /**\n * The arguments object for the `tabActivateRequested` signal.\n */\n export interface ITabActivateRequestedArgs {\n /**\n * The index of the tab to activate.\n */\n readonly index: number;\n\n /**\n * The title for the tab.\n */\n readonly title: Title;\n }\n\n /**\n * The arguments object for the `tabCloseRequested` signal.\n */\n export interface ITabCloseRequestedArgs {\n /**\n * The index of the tab to close.\n */\n readonly index: number;\n\n /**\n * The title for the tab.\n */\n readonly title: Title;\n }\n\n /**\n * The arguments object for the `tabDetachRequested` signal.\n */\n export interface ITabDetachRequestedArgs {\n /**\n * The index of the tab to detach.\n */\n readonly index: number;\n\n /**\n * The title for the tab.\n */\n readonly title: Title;\n\n /**\n * The node representing the tab.\n */\n readonly tab: HTMLElement;\n\n /**\n * The current client X position of the mouse.\n */\n readonly clientX: number;\n\n /**\n * The current client Y position of the mouse.\n */\n readonly clientY: number;\n\n /**\n * The mouse position in the tab coordinate.\n */\n readonly offset?: { x: number; y: number };\n }\n\n /**\n * An object which holds the data to render a tab.\n */\n export interface IRenderData {\n /**\n * The title associated with the tab.\n */\n readonly title: Title;\n\n /**\n * Whether the tab is the current tab.\n */\n readonly current: boolean;\n\n /**\n * The z-index for the tab.\n */\n readonly zIndex: number;\n\n /**\n * The tabindex value for the tab.\n */\n readonly tabIndex?: number;\n }\n\n /**\n * A renderer for use with a tab bar.\n */\n export interface IRenderer {\n /**\n * A selector which matches the close icon node in a tab.\n */\n readonly closeIconSelector: string;\n\n /**\n * Render the virtual element for a tab.\n *\n * @param data - The data to use for rendering the tab.\n *\n * @returns A virtual element representing the tab.\n */\n renderTab(data: IRenderData): VirtualElement;\n }\n\n /**\n * The default implementation of `IRenderer`.\n *\n * #### Notes\n * Subclasses are free to reimplement rendering methods as needed.\n */\n export class Renderer implements IRenderer {\n constructor() {\n this._uuid = ++Renderer._nInstance;\n }\n /**\n * A selector which matches the close icon node in a tab.\n */\n readonly closeIconSelector = '.lm-TabBar-tabCloseIcon';\n\n /**\n * Render the virtual element for a tab.\n *\n * @param data - The data to use for rendering the tab.\n *\n * @returns A virtual element representing the tab.\n */\n renderTab(data: IRenderData): VirtualElement {\n let title = data.title.caption;\n let key = this.createTabKey(data);\n let id = key;\n let style = this.createTabStyle(data);\n let className = this.createTabClass(data);\n let dataset = this.createTabDataset(data);\n let aria = this.createTabARIA(data);\n if (data.title.closable) {\n return h.li(\n { id, key, className, title, style, dataset, ...aria },\n this.renderIcon(data),\n this.renderLabel(data),\n this.renderCloseIcon(data)\n );\n } else {\n return h.li(\n { id, key, className, title, style, dataset, ...aria },\n this.renderIcon(data),\n this.renderLabel(data)\n );\n }\n }\n\n /**\n * Render the icon element for a tab.\n *\n * @param data - The data to use for rendering the tab.\n *\n * @returns A virtual element representing the tab icon.\n */\n renderIcon(data: IRenderData): VirtualElement {\n const { title } = data;\n let className = this.createIconClass(data);\n\n // If title.icon is undefined, it will be ignored.\n return h.div({ className }, title.icon!, title.iconLabel);\n }\n\n /**\n * Render the label element for a tab.\n *\n * @param data - The data to use for rendering the tab.\n *\n * @returns A virtual element representing the tab label.\n */\n renderLabel(data: IRenderData): VirtualElement {\n return h.div({ className: 'lm-TabBar-tabLabel' }, data.title.label);\n }\n\n /**\n * Render the close icon element for a tab.\n *\n * @param data - The data to use for rendering the tab.\n *\n * @returns A virtual element representing the tab close icon.\n */\n renderCloseIcon(data: IRenderData): VirtualElement {\n return h.div({ className: 'lm-TabBar-tabCloseIcon' });\n }\n\n /**\n * Create a unique render key for the tab.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The unique render key for the tab.\n *\n * #### Notes\n * This method caches the key against the tab title the first time\n * the key is generated. This enables efficient rendering of moved\n * tabs and avoids subtle hover style artifacts.\n */\n createTabKey(data: IRenderData): string {\n let key = this._tabKeys.get(data.title);\n if (key === undefined) {\n key = `tab-key-${this._uuid}-${this._tabID++}`;\n this._tabKeys.set(data.title, key);\n }\n return key;\n }\n\n /**\n * Create the inline style object for a tab.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The inline style data for the tab.\n */\n createTabStyle(data: IRenderData): ElementInlineStyle {\n return { zIndex: `${data.zIndex}` };\n }\n\n /**\n * Create the class name for the tab.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The full class name for the tab.\n */\n createTabClass(data: IRenderData): string {\n let name = 'lm-TabBar-tab';\n if (data.title.className) {\n name += ` ${data.title.className}`;\n }\n if (data.title.closable) {\n name += ' lm-mod-closable';\n }\n if (data.current) {\n name += ' lm-mod-current';\n }\n return name;\n }\n\n /**\n * Create the dataset for a tab.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The dataset for the tab.\n */\n createTabDataset(data: IRenderData): ElementDataset {\n return data.title.dataset;\n }\n\n /**\n * Create the ARIA attributes for a tab.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The ARIA attributes for the tab.\n */\n createTabARIA(data: IRenderData): ElementARIAAttrs | ElementBaseAttrs {\n return {\n role: 'tab',\n 'aria-selected': data.current.toString(),\n tabindex: `${data.tabIndex ?? '-1'}`\n };\n }\n\n /**\n * Create the class name for the tab icon.\n *\n * @param data - The data to use for the tab.\n *\n * @returns The full class name for the tab icon.\n */\n createIconClass(data: IRenderData): string {\n let name = 'lm-TabBar-tabIcon';\n let extra = data.title.iconClass;\n return extra ? `${name} ${extra}` : name;\n }\n\n private static _nInstance = 0;\n private readonly _uuid: number;\n private _tabID = 0;\n private _tabKeys = new WeakMap, string>();\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n\n /**\n * A selector which matches the add button node in the tab bar.\n */\n export const addButtonSelector = '.lm-TabBar-addButton';\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The start drag distance threshold.\n */\n export const DRAG_THRESHOLD = 5;\n\n /**\n * The detach distance threshold.\n */\n export const DETACH_THRESHOLD = 20;\n\n /**\n * A struct which holds the drag data for a tab bar.\n */\n export interface IDragData {\n /**\n * The tab node being dragged.\n */\n tab: HTMLElement;\n\n /**\n * The index of the tab being dragged.\n */\n index: number;\n\n /**\n * The mouse press client X position.\n */\n pressX: number;\n\n /**\n * The mouse press client Y position.\n */\n pressY: number;\n\n /**\n * The offset left/top of the tab being dragged.\n *\n * This will be `-1` if the drag is not active.\n */\n tabPos: number;\n\n /**\n * The offset width/height of the tab being dragged.\n *\n * This will be `-1` if the drag is not active.\n */\n tabSize: number;\n\n /**\n * The original mouse X/Y position in tab coordinates.\n *\n * This will be `-1` if the drag is not active.\n */\n tabPressPos: number;\n\n /**\n * The original mouse position in tab coordinates.\n *\n * This is undefined if the drag is not active.\n */\n tabPressOffset?: { x: number; y: number };\n\n /**\n * The tab target index upon mouse release.\n *\n * This will be `-1` if the drag is not active.\n */\n targetIndex: number;\n\n /**\n * The array of tab layout objects snapped at drag start.\n *\n * This will be `null` if the drag is not active.\n */\n tabLayout: ITabLayout[] | null;\n\n /**\n * The bounding client rect of the tab bar content node.\n *\n * This will be `null` if the drag is not active.\n */\n contentRect: DOMRect | null;\n\n /**\n * The disposable to clean up the cursor override.\n *\n * This will be `null` if the drag is not active.\n */\n override: IDisposable | null;\n\n /**\n * Whether the drag is currently active.\n */\n dragActive: boolean;\n\n /**\n * Whether the drag has been aborted.\n */\n dragAborted: boolean;\n\n /**\n * Whether a detach request as been made.\n */\n detachRequested: boolean;\n }\n\n /**\n * An object which holds layout data for a tab.\n */\n export interface ITabLayout {\n /**\n * The left/top margin value for the tab.\n */\n margin: number;\n\n /**\n * The offset left/top position of the tab.\n */\n pos: number;\n\n /**\n * The offset width/height of the tab.\n */\n size: number;\n }\n\n /**\n * Create the DOM node for a tab bar.\n */\n export function createNode(): HTMLDivElement {\n let node = document.createElement('div');\n let content = document.createElement('ul');\n content.setAttribute('role', 'tablist');\n content.className = 'lm-TabBar-content';\n node.appendChild(content);\n\n let add = document.createElement('div');\n add.className = 'lm-TabBar-addButton lm-mod-hidden';\n add.setAttribute('tabindex', '-1');\n add.setAttribute('role', 'button');\n node.appendChild(add);\n return node;\n }\n\n /**\n * Coerce a title or options into a real title.\n */\n export function asTitle(value: Title | Title.IOptions): Title {\n return value instanceof Title ? value : new Title(value);\n }\n\n /**\n * Parse the transition duration for a tab node.\n */\n export function parseTransitionDuration(tab: HTMLElement): number {\n let style = window.getComputedStyle(tab);\n return 1000 * (parseFloat(style.transitionDuration!) || 0);\n }\n\n /**\n * Get a snapshot of the current tab layout values.\n */\n export function snapTabLayout(\n tabs: HTMLCollection,\n orientation: TabBar.Orientation\n ): ITabLayout[] {\n let layout = new Array(tabs.length);\n for (let i = 0, n = tabs.length; i < n; ++i) {\n let node = tabs[i] as HTMLElement;\n let style = window.getComputedStyle(node);\n if (orientation === 'horizontal') {\n layout[i] = {\n pos: node.offsetLeft,\n size: node.offsetWidth,\n margin: parseFloat(style.marginLeft!) || 0\n };\n } else {\n layout[i] = {\n pos: node.offsetTop,\n size: node.offsetHeight,\n margin: parseFloat(style.marginTop!) || 0\n };\n }\n }\n return layout;\n }\n\n /**\n * Test if the event exceeds the drag threshold.\n */\n export function dragExceeded(data: IDragData, event: MouseEvent): boolean {\n let dx = Math.abs(event.clientX - data.pressX);\n let dy = Math.abs(event.clientY - data.pressY);\n return dx >= DRAG_THRESHOLD || dy >= DRAG_THRESHOLD;\n }\n\n /**\n * Test if the event exceeds the drag detach threshold.\n */\n export function detachExceeded(data: IDragData, event: MouseEvent): boolean {\n let rect = data.contentRect!;\n return (\n event.clientX < rect.left - DETACH_THRESHOLD ||\n event.clientX >= rect.right + DETACH_THRESHOLD ||\n event.clientY < rect.top - DETACH_THRESHOLD ||\n event.clientY >= rect.bottom + DETACH_THRESHOLD\n );\n }\n\n /**\n * Update the relative tab positions and computed target index.\n */\n export function layoutTabs(\n tabs: HTMLCollection,\n data: IDragData,\n event: MouseEvent,\n orientation: TabBar.Orientation\n ): void {\n // Compute the orientation-sensitive values.\n let pressPos: number;\n let localPos: number;\n let clientPos: number;\n let clientSize: number;\n if (orientation === 'horizontal') {\n pressPos = data.pressX;\n localPos = event.clientX - data.contentRect!.left;\n clientPos = event.clientX;\n clientSize = data.contentRect!.width;\n } else {\n pressPos = data.pressY;\n localPos = event.clientY - data.contentRect!.top;\n clientPos = event.clientY;\n clientSize = data.contentRect!.height;\n }\n\n // Compute the target data.\n let targetIndex = data.index;\n let targetPos = localPos - data.tabPressPos;\n let targetEnd = targetPos + data.tabSize;\n\n // Update the relative tab positions.\n for (let i = 0, n = tabs.length; i < n; ++i) {\n let pxPos: string;\n let layout = data.tabLayout![i];\n let threshold = layout.pos + (layout.size >> 1);\n if (i < data.index && targetPos < threshold) {\n pxPos = `${data.tabSize + data.tabLayout![i + 1].margin}px`;\n targetIndex = Math.min(targetIndex, i);\n } else if (i > data.index && targetEnd > threshold) {\n pxPos = `${-data.tabSize - layout.margin}px`;\n targetIndex = Math.max(targetIndex, i);\n } else if (i === data.index) {\n let ideal = clientPos - pressPos;\n let limit = clientSize - (data.tabPos + data.tabSize);\n pxPos = `${Math.max(-data.tabPos, Math.min(ideal, limit))}px`;\n } else {\n pxPos = '';\n }\n if (orientation === 'horizontal') {\n (tabs[i] as HTMLElement).style.left = pxPos;\n } else {\n (tabs[i] as HTMLElement).style.top = pxPos;\n }\n }\n\n // Update the computed target index.\n data.targetIndex = targetIndex;\n }\n\n /**\n * Position the drag tab at its final resting relative position.\n */\n export function finalizeTabPosition(\n data: IDragData,\n orientation: TabBar.Orientation\n ): void {\n // Compute the orientation-sensitive client size.\n let clientSize: number;\n if (orientation === 'horizontal') {\n clientSize = data.contentRect!.width;\n } else {\n clientSize = data.contentRect!.height;\n }\n\n // Compute the ideal final tab position.\n let ideal: number;\n if (data.targetIndex === data.index) {\n ideal = 0;\n } else if (data.targetIndex > data.index) {\n let tgt = data.tabLayout![data.targetIndex];\n ideal = tgt.pos + tgt.size - data.tabSize - data.tabPos;\n } else {\n let tgt = data.tabLayout![data.targetIndex];\n ideal = tgt.pos - data.tabPos;\n }\n\n // Compute the tab position limit.\n let limit = clientSize - (data.tabPos + data.tabSize);\n let final = Math.max(-data.tabPos, Math.min(ideal, limit));\n\n // Set the final orientation-sensitive position.\n if (orientation === 'horizontal') {\n data.tab.style.left = `${final}px`;\n } else {\n data.tab.style.top = `${final}px`;\n }\n }\n\n /**\n * Reset the relative positions of the given tabs.\n */\n export function resetTabPositions(\n tabs: HTMLCollection,\n orientation: TabBar.Orientation\n ): void {\n for (const tab of tabs) {\n if (orientation === 'horizontal') {\n (tab as HTMLElement).style.left = '';\n } else {\n (tab as HTMLElement).style.top = '';\n }\n }\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt, empty } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { BoxEngine, BoxSizer } from './boxengine';\n\nimport { Layout, LayoutItem } from './layout';\n\nimport { TabBar } from './tabbar';\n\nimport Utils from './utils';\n\nimport { Widget } from './widget';\n\n/**\n * A layout which provides a flexible docking arrangement.\n *\n * #### Notes\n * The consumer of this layout is responsible for handling all signals\n * from the generated tab bars and managing the visibility of widgets\n * and tab bars as needed.\n */\nexport class DockLayout extends Layout {\n /**\n * Construct a new dock layout.\n *\n * @param options - The options for initializing the layout.\n */\n constructor(options: DockLayout.IOptions) {\n super();\n this.renderer = options.renderer;\n if (options.spacing !== undefined) {\n this._spacing = Utils.clampDimension(options.spacing);\n }\n this._document = options.document || document;\n this._hiddenMode =\n options.hiddenMode !== undefined\n ? options.hiddenMode\n : Widget.HiddenMode.Display;\n }\n\n /**\n * Dispose of the resources held by the layout.\n *\n * #### Notes\n * This will clear and dispose all widgets in the layout.\n */\n dispose(): void {\n // Get an iterator over the widgets in the layout.\n let widgets = this[Symbol.iterator]();\n\n // Dispose of the layout items.\n this._items.forEach(item => {\n item.dispose();\n });\n\n // Clear the layout state before disposing the widgets.\n this._box = null;\n this._root = null;\n this._items.clear();\n\n // Dispose of the widgets contained in the old layout root.\n for (const widget of widgets) {\n widget.dispose();\n }\n\n // Dispose of the base class.\n super.dispose();\n }\n\n /**\n * The renderer used by the dock layout.\n */\n readonly renderer: DockLayout.IRenderer;\n\n /**\n * The method for hiding child widgets.\n *\n * #### Notes\n * If there is only one child widget, `Display` hiding mode will be used\n * regardless of this setting.\n */\n get hiddenMode(): Widget.HiddenMode {\n return this._hiddenMode;\n }\n set hiddenMode(v: Widget.HiddenMode) {\n if (this._hiddenMode === v) {\n return;\n }\n this._hiddenMode = v;\n for (const bar of this.tabBars()) {\n if (bar.titles.length > 1) {\n for (const title of bar.titles) {\n title.owner.hiddenMode = this._hiddenMode;\n }\n }\n }\n }\n\n /**\n * Get the inter-element spacing for the dock layout.\n */\n get spacing(): number {\n return this._spacing;\n }\n\n /**\n * Set the inter-element spacing for the dock layout.\n */\n set spacing(value: number) {\n value = Utils.clampDimension(value);\n if (this._spacing === value) {\n return;\n }\n this._spacing = value;\n if (!this.parent) {\n return;\n }\n this.parent.fit();\n }\n\n /**\n * Whether the dock layout is empty.\n */\n get isEmpty(): boolean {\n return this._root === null;\n }\n\n /**\n * Create an iterator over all widgets in the layout.\n *\n * @returns A new iterator over the widgets in the layout.\n *\n * #### Notes\n * This iterator includes the generated tab bars.\n */\n [Symbol.iterator](): IterableIterator {\n return this._root ? this._root.iterAllWidgets() : empty();\n }\n\n /**\n * Create an iterator over the user widgets in the layout.\n *\n * @returns A new iterator over the user widgets in the layout.\n *\n * #### Notes\n * This iterator does not include the generated tab bars.\n */\n widgets(): IterableIterator {\n return this._root ? this._root.iterUserWidgets() : empty();\n }\n\n /**\n * Create an iterator over the selected widgets in the layout.\n *\n * @returns A new iterator over the selected user widgets.\n *\n * #### Notes\n * This iterator yields the widgets corresponding to the current tab\n * of each tab bar in the layout.\n */\n selectedWidgets(): IterableIterator {\n return this._root ? this._root.iterSelectedWidgets() : empty();\n }\n\n /**\n * Create an iterator over the tab bars in the layout.\n *\n * @returns A new iterator over the tab bars in the layout.\n *\n * #### Notes\n * This iterator does not include the user widgets.\n */\n tabBars(): IterableIterator> {\n return this._root ? this._root.iterTabBars() : empty();\n }\n\n /**\n * Create an iterator over the handles in the layout.\n *\n * @returns A new iterator over the handles in the layout.\n */\n handles(): IterableIterator {\n return this._root ? this._root.iterHandles() : empty();\n }\n\n /**\n * Move a handle to the given offset position.\n *\n * @param handle - The handle to move.\n *\n * @param offsetX - The desired offset X position of the handle.\n *\n * @param offsetY - The desired offset Y position of the handle.\n *\n * #### Notes\n * If the given handle is not contained in the layout, this is no-op.\n *\n * The handle will be moved as close as possible to the desired\n * position without violating any of the layout constraints.\n *\n * Only one of the coordinates is used depending on the orientation\n * of the handle. This method accepts both coordinates to make it\n * easy to invoke from a mouse move event without needing to know\n * the handle orientation.\n */\n moveHandle(handle: HTMLDivElement, offsetX: number, offsetY: number): void {\n // Bail early if there is no root or if the handle is hidden.\n let hidden = handle.classList.contains('lm-mod-hidden');\n if (!this._root || hidden) {\n return;\n }\n\n // Lookup the split node for the handle.\n let data = this._root.findSplitNode(handle);\n if (!data) {\n return;\n }\n\n // Compute the desired delta movement for the handle.\n let delta: number;\n if (data.node.orientation === 'horizontal') {\n delta = offsetX - handle.offsetLeft;\n } else {\n delta = offsetY - handle.offsetTop;\n }\n\n // Bail if there is no handle movement.\n if (delta === 0) {\n return;\n }\n\n // Prevent sibling resizing unless needed.\n data.node.holdSizes();\n\n // Adjust the sizers to reflect the handle movement.\n BoxEngine.adjust(data.node.sizers, data.index, delta);\n\n // Update the layout of the widgets.\n if (this.parent) {\n this.parent.update();\n }\n }\n\n /**\n * Save the current configuration of the dock layout.\n *\n * @returns A new config object for the current layout state.\n *\n * #### Notes\n * The return value can be provided to the `restoreLayout` method\n * in order to restore the layout to its current configuration.\n */\n saveLayout(): DockLayout.ILayoutConfig {\n // Bail early if there is no root.\n if (!this._root) {\n return { main: null };\n }\n\n // Hold the current sizes in the layout tree.\n this._root.holdAllSizes();\n\n // Return the layout config.\n return { main: this._root.createConfig() };\n }\n\n /**\n * Restore the layout to a previously saved configuration.\n *\n * @param config - The layout configuration to restore.\n *\n * #### Notes\n * Widgets which currently belong to the layout but which are not\n * contained in the config will be unparented.\n */\n restoreLayout(config: DockLayout.ILayoutConfig): void {\n // Create the widget set for validating the config.\n let widgetSet = new Set();\n\n // Normalize the main area config and collect the widgets.\n let mainConfig: DockLayout.AreaConfig | null;\n if (config.main) {\n mainConfig = Private.normalizeAreaConfig(config.main, widgetSet);\n } else {\n mainConfig = null;\n }\n\n // Create iterators over the old content.\n let oldWidgets = this.widgets();\n let oldTabBars = this.tabBars();\n let oldHandles = this.handles();\n\n // Clear the root before removing the old content.\n this._root = null;\n\n // Unparent the old widgets which are not in the new config.\n for (const widget of oldWidgets) {\n if (!widgetSet.has(widget)) {\n widget.parent = null;\n }\n }\n\n // Dispose of the old tab bars.\n for (const tabBar of oldTabBars) {\n tabBar.dispose();\n }\n\n // Remove the old handles.\n for (const handle of oldHandles) {\n if (handle.parentNode) {\n handle.parentNode.removeChild(handle);\n }\n }\n\n // Reparent the new widgets to the current parent.\n for (const widget of widgetSet) {\n widget.parent = this.parent;\n }\n\n // Create the root node for the new config.\n if (mainConfig) {\n this._root = Private.realizeAreaConfig(\n mainConfig,\n {\n // Ignoring optional `document` argument as we must reuse `this._document`\n createTabBar: (document?: Document | ShadowRoot) =>\n this._createTabBar(),\n createHandle: () => this._createHandle()\n },\n this._document\n );\n } else {\n this._root = null;\n }\n\n // If there is no parent, there is nothing more to do.\n if (!this.parent) {\n return;\n }\n\n // Attach the new widgets to the parent.\n widgetSet.forEach(widget => {\n this.attachWidget(widget);\n });\n\n // Post a fit request to the parent.\n this.parent.fit();\n }\n\n /**\n * Add a widget to the dock layout.\n *\n * @param widget - The widget to add to the dock layout.\n *\n * @param options - The additional options for adding the widget.\n *\n * #### Notes\n * The widget will be moved if it is already contained in the layout.\n *\n * An error will be thrown if the reference widget is invalid.\n */\n addWidget(widget: Widget, options: DockLayout.IAddOptions = {}): void {\n // Parse the options.\n let ref = options.ref || null;\n let mode = options.mode || 'tab-after';\n\n // Find the tab node which holds the reference widget.\n let refNode: Private.TabLayoutNode | null = null;\n if (this._root && ref) {\n refNode = this._root.findTabNode(ref);\n }\n\n // Throw an error if the reference widget is invalid.\n if (ref && !refNode) {\n throw new Error('Reference widget is not in the layout.');\n }\n\n // Reparent the widget to the current layout parent.\n widget.parent = this.parent;\n\n // Insert the widget according to the insert mode.\n switch (mode) {\n case 'tab-after':\n this._insertTab(widget, ref, refNode, true);\n break;\n case 'tab-before':\n this._insertTab(widget, ref, refNode, false);\n break;\n case 'split-top':\n this._insertSplit(widget, ref, refNode, 'vertical', false);\n break;\n case 'split-left':\n this._insertSplit(widget, ref, refNode, 'horizontal', false);\n break;\n case 'split-right':\n this._insertSplit(widget, ref, refNode, 'horizontal', true);\n break;\n case 'split-bottom':\n this._insertSplit(widget, ref, refNode, 'vertical', true);\n break;\n case 'merge-top':\n this._insertSplit(widget, ref, refNode, 'vertical', false, true);\n break;\n case 'merge-left':\n this._insertSplit(widget, ref, refNode, 'horizontal', false, true);\n break;\n case 'merge-right':\n this._insertSplit(widget, ref, refNode, 'horizontal', true, true);\n break;\n case 'merge-bottom':\n this._insertSplit(widget, ref, refNode, 'vertical', true, true);\n break;\n }\n\n // Do nothing else if there is no parent widget.\n if (!this.parent) {\n return;\n }\n\n // Ensure the widget is attached to the parent widget.\n this.attachWidget(widget);\n\n // Post a fit request for the parent widget.\n this.parent.fit();\n }\n\n /**\n * Remove a widget from the layout.\n *\n * @param widget - The widget to remove from the layout.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method does *not* modify the widget's `parent`.\n */\n removeWidget(widget: Widget): void {\n // Remove the widget from its current layout location.\n this._removeWidget(widget);\n\n // Do nothing else if there is no parent widget.\n if (!this.parent) {\n return;\n }\n\n // Detach the widget from the parent widget.\n this.detachWidget(widget);\n\n // Post a fit request for the parent widget.\n this.parent.fit();\n }\n\n /**\n * Find the tab area which contains the given client position.\n *\n * @param clientX - The client X position of interest.\n *\n * @param clientY - The client Y position of interest.\n *\n * @returns The geometry of the tab area at the given position, or\n * `null` if there is no tab area at the given position.\n */\n hitTestTabAreas(\n clientX: number,\n clientY: number\n ): DockLayout.ITabAreaGeometry | null {\n // Bail early if hit testing cannot produce valid results.\n if (!this._root || !this.parent || !this.parent.isVisible) {\n return null;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent.node);\n }\n\n // Convert from client to local coordinates.\n let rect = this.parent.node.getBoundingClientRect();\n let x = clientX - rect.left - this._box.borderLeft;\n let y = clientY - rect.top - this._box.borderTop;\n\n // Find the tab layout node at the local position.\n let tabNode = this._root.hitTestTabNodes(x, y);\n\n // Bail if a tab layout node was not found.\n if (!tabNode) {\n return null;\n }\n\n // Extract the data from the tab node.\n let { tabBar, top, left, width, height } = tabNode;\n\n // Compute the right and bottom edges of the tab area.\n let borderWidth = this._box.borderLeft + this._box.borderRight;\n let borderHeight = this._box.borderTop + this._box.borderBottom;\n let right = rect.width - borderWidth - (left + width);\n let bottom = rect.height - borderHeight - (top + height);\n\n // Return the hit test results.\n return { tabBar, x, y, top, left, right, bottom, width, height };\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n // Perform superclass initialization.\n super.init();\n\n // Attach each widget to the parent.\n for (const widget of this) {\n this.attachWidget(widget);\n }\n\n // Attach each handle to the parent.\n for (const handle of this.handles()) {\n this.parent!.node.appendChild(handle);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * Attach the widget to the layout parent widget.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This is a no-op if the widget is already attached.\n */\n protected attachWidget(widget: Widget): void {\n // Do nothing if the widget is already attached.\n if (this.parent!.node === widget.node.parentNode) {\n return;\n }\n\n // Create the layout item for the widget.\n this._items.set(widget, new LayoutItem(widget));\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget's node to the parent.\n this.parent!.node.appendChild(widget.node);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n }\n\n /**\n * Detach the widget from the layout parent widget.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This is a no-op if the widget is not attached.\n */\n protected detachWidget(widget: Widget): void {\n // Do nothing if the widget is not attached.\n if (this.parent!.node !== widget.node.parentNode) {\n return;\n }\n\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Delete the layout item for the widget.\n let item = this._items.get(widget);\n if (item) {\n this._items.delete(widget);\n item.dispose();\n }\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n */\n protected onBeforeShow(msg: Message): void {\n super.onBeforeShow(msg);\n this.parent!.update();\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n super.onBeforeAttach(msg);\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n if (this.parent!.isVisible) {\n this._update(msg.width, msg.height);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.parent!.isVisible) {\n this._update(-1, -1);\n }\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n */\n protected onFitRequest(msg: Message): void {\n if (this.parent!.isAttached) {\n this._fit();\n }\n }\n\n /**\n * Remove the specified widget from the layout structure.\n *\n * #### Notes\n * This is a no-op if the widget is not in the layout tree.\n *\n * This does not detach the widget from the parent node.\n */\n private _removeWidget(widget: Widget): void {\n // Bail early if there is no layout root.\n if (!this._root) {\n return;\n }\n\n // Find the tab node which contains the given widget.\n let tabNode = this._root.findTabNode(widget);\n\n // Bail early if the tab node is not found.\n if (!tabNode) {\n return;\n }\n\n Private.removeAria(widget);\n\n // If there are multiple tabs, just remove the widget's tab.\n if (tabNode.tabBar.titles.length > 1) {\n tabNode.tabBar.removeTab(widget.title);\n if (\n this._hiddenMode === Widget.HiddenMode.Scale &&\n tabNode.tabBar.titles.length == 1\n ) {\n const existingWidget = tabNode.tabBar.titles[0].owner;\n existingWidget.hiddenMode = Widget.HiddenMode.Display;\n }\n return;\n }\n\n // Otherwise, the tab node needs to be removed...\n\n // Dispose the tab bar.\n tabNode.tabBar.dispose();\n\n // Handle the case where the tab node is the root.\n if (this._root === tabNode) {\n this._root = null;\n return;\n }\n\n // Otherwise, remove the tab node from its parent...\n\n // Prevent widget resizing unless needed.\n this._root.holdAllSizes();\n\n // Clear the parent reference on the tab node.\n let splitNode = tabNode.parent!;\n tabNode.parent = null;\n\n // Remove the tab node from its parent split node.\n let i = ArrayExt.removeFirstOf(splitNode.children, tabNode);\n let handle = ArrayExt.removeAt(splitNode.handles, i)!;\n ArrayExt.removeAt(splitNode.sizers, i);\n\n // Remove the handle from its parent DOM node.\n if (handle.parentNode) {\n handle.parentNode.removeChild(handle);\n }\n\n // If there are multiple children, just update the handles.\n if (splitNode.children.length > 1) {\n splitNode.syncHandles();\n return;\n }\n\n // Otherwise, the split node also needs to be removed...\n\n // Clear the parent reference on the split node.\n let maybeParent = splitNode.parent;\n splitNode.parent = null;\n\n // Lookup the remaining child node and handle.\n let childNode = splitNode.children[0];\n let childHandle = splitNode.handles[0];\n\n // Clear the split node data.\n splitNode.children.length = 0;\n splitNode.handles.length = 0;\n splitNode.sizers.length = 0;\n\n // Remove the child handle from its parent node.\n if (childHandle.parentNode) {\n childHandle.parentNode.removeChild(childHandle);\n }\n\n // Handle the case where the split node is the root.\n if (this._root === splitNode) {\n childNode.parent = null;\n this._root = childNode;\n return;\n }\n\n // Otherwise, move the child node to the parent node...\n let parentNode = maybeParent!;\n\n // Lookup the index of the split node.\n let j = parentNode.children.indexOf(splitNode);\n\n // Handle the case where the child node is a tab node.\n if (childNode instanceof Private.TabLayoutNode) {\n childNode.parent = parentNode;\n parentNode.children[j] = childNode;\n return;\n }\n\n // Remove the split data from the parent.\n let splitHandle = ArrayExt.removeAt(parentNode.handles, j)!;\n ArrayExt.removeAt(parentNode.children, j);\n ArrayExt.removeAt(parentNode.sizers, j);\n\n // Remove the handle from its parent node.\n if (splitHandle.parentNode) {\n splitHandle.parentNode.removeChild(splitHandle);\n }\n\n // The child node and the split parent node will have the same\n // orientation. Merge the grand-children with the parent node.\n for (let i = 0, n = childNode.children.length; i < n; ++i) {\n let gChild = childNode.children[i];\n let gHandle = childNode.handles[i];\n let gSizer = childNode.sizers[i];\n ArrayExt.insert(parentNode.children, j + i, gChild);\n ArrayExt.insert(parentNode.handles, j + i, gHandle);\n ArrayExt.insert(parentNode.sizers, j + i, gSizer);\n gChild.parent = parentNode;\n }\n\n // Clear the child node.\n childNode.children.length = 0;\n childNode.handles.length = 0;\n childNode.sizers.length = 0;\n childNode.parent = null;\n\n // Sync the handles on the parent node.\n parentNode.syncHandles();\n }\n\n /**\n * Create the tab layout node to hold the widget.\n */\n private _createTabNode(widget: Widget): Private.TabLayoutNode {\n let tabNode = new Private.TabLayoutNode(this._createTabBar());\n tabNode.tabBar.addTab(widget.title);\n Private.addAria(widget, tabNode.tabBar);\n return tabNode;\n }\n\n /**\n * Insert a widget next to an existing tab.\n *\n * #### Notes\n * This does not attach the widget to the parent widget.\n */\n private _insertTab(\n widget: Widget,\n ref: Widget | null,\n refNode: Private.TabLayoutNode | null,\n after: boolean\n ): void {\n // Do nothing if the tab is inserted next to itself.\n if (widget === ref) {\n return;\n }\n\n // Create the root if it does not exist.\n if (!this._root) {\n let tabNode = new Private.TabLayoutNode(this._createTabBar());\n tabNode.tabBar.addTab(widget.title);\n this._root = tabNode;\n Private.addAria(widget, tabNode.tabBar);\n return;\n }\n\n // Use the first tab node as the ref node if needed.\n if (!refNode) {\n refNode = this._root.findFirstTabNode()!;\n }\n\n // If the widget is not contained in the ref node, ensure it is\n // removed from the layout and hidden before being added again.\n if (refNode.tabBar.titles.indexOf(widget.title) === -1) {\n this._removeWidget(widget);\n widget.hide();\n }\n\n // Lookup the target index for inserting the tab.\n let index: number;\n if (ref) {\n index = refNode.tabBar.titles.indexOf(ref.title);\n } else {\n index = refNode.tabBar.currentIndex;\n }\n\n // Using transform create an additional layer in the pixel pipeline\n // to limit the number of layer, it is set only if there is more than one widget.\n if (this._hiddenMode === Widget.HiddenMode.Scale) {\n if (refNode.tabBar.titles.length === 0) {\n // Singular tab should use display mode to limit number of layers.\n widget.hiddenMode = Widget.HiddenMode.Display;\n } else if (refNode.tabBar.titles.length == 1) {\n // If we are adding a second tab, switch the existing tab back to scale.\n const existingWidget = refNode.tabBar.titles[0].owner;\n existingWidget.hiddenMode = Widget.HiddenMode.Scale;\n } else {\n // For the third and subsequent tabs no special action is needed.\n widget.hiddenMode = Widget.HiddenMode.Scale;\n }\n } else {\n // For all other modes just propagate the current mode.\n widget.hiddenMode = this._hiddenMode;\n }\n\n // Insert the widget's tab relative to the target index.\n refNode.tabBar.insertTab(index + (after ? 1 : 0), widget.title);\n Private.addAria(widget, refNode.tabBar);\n }\n\n /**\n * Insert a widget as a new split area.\n *\n * #### Notes\n * This does not attach the widget to the parent widget.\n */\n private _insertSplit(\n widget: Widget,\n ref: Widget | null,\n refNode: Private.TabLayoutNode | null,\n orientation: Private.Orientation,\n after: boolean,\n merge: boolean = false\n ): void {\n // Do nothing if there is no effective split.\n if (widget === ref && refNode && refNode.tabBar.titles.length === 1) {\n return;\n }\n\n // Ensure the widget is removed from the current layout.\n this._removeWidget(widget);\n\n // Set the root if it does not exist.\n if (!this._root) {\n this._root = this._createTabNode(widget);\n return;\n }\n\n // If the ref node parent is null, split the root.\n if (!refNode || !refNode.parent) {\n // Ensure the root is split with the correct orientation.\n let root = this._splitRoot(orientation);\n\n // Determine the insert index for the new tab node.\n let i = after ? root.children.length : 0;\n\n // Normalize the split node.\n root.normalizeSizes();\n\n // Create the sizer for new tab node.\n let sizer = Private.createSizer(refNode ? 1 : Private.GOLDEN_RATIO);\n\n // Insert the tab node sized to the golden ratio.\n let tabNode = this._createTabNode(widget);\n ArrayExt.insert(root.children, i, tabNode);\n ArrayExt.insert(root.sizers, i, sizer);\n ArrayExt.insert(root.handles, i, this._createHandle());\n tabNode.parent = root;\n\n // Re-normalize the split node to maintain the ratios.\n root.normalizeSizes();\n\n // Finally, synchronize the visibility of the handles.\n root.syncHandles();\n return;\n }\n\n // Lookup the split node for the ref widget.\n let splitNode = refNode.parent;\n\n // If the split node already had the correct orientation,\n // the widget can be inserted into the split node directly.\n if (splitNode.orientation === orientation) {\n // Find the index of the ref node.\n let i = splitNode.children.indexOf(refNode);\n\n // Conditionally reuse a tab layout found in the wanted position.\n if (merge) {\n let j = i + (after ? 1 : -1);\n let sibling = splitNode.children[j];\n if (sibling instanceof Private.TabLayoutNode) {\n this._insertTab(widget, null, sibling, true);\n ++sibling.tabBar.currentIndex;\n return;\n }\n }\n\n // Normalize the split node.\n splitNode.normalizeSizes();\n\n // Consume half the space for the insert location.\n let s = (splitNode.sizers[i].sizeHint /= 2);\n\n // Insert the tab node sized to the other half.\n let j = i + (after ? 1 : 0);\n let tabNode = this._createTabNode(widget);\n ArrayExt.insert(splitNode.children, j, tabNode);\n ArrayExt.insert(splitNode.sizers, j, Private.createSizer(s));\n ArrayExt.insert(splitNode.handles, j, this._createHandle());\n tabNode.parent = splitNode;\n\n // Finally, synchronize the visibility of the handles.\n splitNode.syncHandles();\n return;\n }\n\n // Remove the ref node from the split node.\n let i = ArrayExt.removeFirstOf(splitNode.children, refNode);\n\n // Create a new normalized split node for the children.\n let childNode = new Private.SplitLayoutNode(orientation);\n childNode.normalized = true;\n\n // Add the ref node sized to half the space.\n childNode.children.push(refNode);\n childNode.sizers.push(Private.createSizer(0.5));\n childNode.handles.push(this._createHandle());\n refNode.parent = childNode;\n\n // Add the tab node sized to the other half.\n let j = after ? 1 : 0;\n let tabNode = this._createTabNode(widget);\n ArrayExt.insert(childNode.children, j, tabNode);\n ArrayExt.insert(childNode.sizers, j, Private.createSizer(0.5));\n ArrayExt.insert(childNode.handles, j, this._createHandle());\n tabNode.parent = childNode;\n\n // Synchronize the visibility of the handles.\n childNode.syncHandles();\n\n // Finally, add the new child node to the original split node.\n ArrayExt.insert(splitNode.children, i, childNode);\n childNode.parent = splitNode;\n }\n\n /**\n * Ensure the root is a split node with the given orientation.\n */\n private _splitRoot(\n orientation: Private.Orientation\n ): Private.SplitLayoutNode {\n // Bail early if the root already meets the requirements.\n let oldRoot = this._root;\n if (oldRoot instanceof Private.SplitLayoutNode) {\n if (oldRoot.orientation === orientation) {\n return oldRoot;\n }\n }\n\n // Create a new root node with the specified orientation.\n let newRoot = (this._root = new Private.SplitLayoutNode(orientation));\n\n // Add the old root to the new root.\n if (oldRoot) {\n newRoot.children.push(oldRoot);\n newRoot.sizers.push(Private.createSizer(0));\n newRoot.handles.push(this._createHandle());\n oldRoot.parent = newRoot;\n }\n\n // Return the new root as a convenience.\n return newRoot;\n }\n\n /**\n * Fit the layout to the total size required by the widgets.\n */\n private _fit(): void {\n // Set up the computed minimum size.\n let minW = 0;\n let minH = 0;\n\n // Update the size limits for the layout tree.\n if (this._root) {\n let limits = this._root.fit(this._spacing, this._items);\n minW = limits.minWidth;\n minH = limits.minHeight;\n }\n\n // Update the box sizing and add it to the computed min size.\n let box = (this._box = ElementExt.boxSizing(this.parent!.node));\n minW += box.horizontalSum;\n minH += box.verticalSum;\n\n // Update the parent's min size constraints.\n let style = this.parent!.node.style;\n style.minWidth = `${minW}px`;\n style.minHeight = `${minH}px`;\n\n // Set the dirty flag to ensure only a single update occurs.\n this._dirty = true;\n\n // Notify the ancestor that it should fit immediately. This may\n // cause a resize of the parent, fulfilling the required update.\n if (this.parent!.parent) {\n MessageLoop.sendMessage(this.parent!.parent!, Widget.Msg.FitRequest);\n }\n\n // If the dirty flag is still set, the parent was not resized.\n // Trigger the required update on the parent widget immediately.\n if (this._dirty) {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n }\n }\n\n /**\n * Update the layout position and size of the widgets.\n *\n * The parent offset dimensions should be `-1` if unknown.\n */\n private _update(offsetWidth: number, offsetHeight: number): void {\n // Clear the dirty flag to indicate the update occurred.\n this._dirty = false;\n\n // Bail early if there is no root layout node.\n if (!this._root) {\n return;\n }\n\n // Measure the parent if the offset dimensions are unknown.\n if (offsetWidth < 0) {\n offsetWidth = this.parent!.node.offsetWidth;\n }\n if (offsetHeight < 0) {\n offsetHeight = this.parent!.node.offsetHeight;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent!.node);\n }\n\n // Compute the actual layout bounds adjusted for border and padding.\n let x = this._box.paddingTop;\n let y = this._box.paddingLeft;\n let width = offsetWidth - this._box.horizontalSum;\n let height = offsetHeight - this._box.verticalSum;\n\n // Update the geometry of the layout tree.\n this._root.update(x, y, width, height, this._spacing, this._items);\n }\n\n /**\n * Create a new tab bar for use by the dock layout.\n *\n * #### Notes\n * The tab bar will be attached to the parent if it exists.\n */\n private _createTabBar(): TabBar {\n // Create the tab bar using the renderer.\n let tabBar = this.renderer.createTabBar(this._document);\n\n // Enforce necessary tab bar behavior.\n tabBar.orientation = 'horizontal';\n\n // Attach the tab bar to the parent if possible.\n if (this.parent) {\n this.attachWidget(tabBar);\n }\n\n // Return the initialized tab bar.\n return tabBar;\n }\n\n /**\n * Create a new handle for the dock layout.\n *\n * #### Notes\n * The handle will be attached to the parent if it exists.\n */\n private _createHandle(): HTMLDivElement {\n // Create the handle using the renderer.\n let handle = this.renderer.createHandle();\n\n // Initialize the handle layout behavior.\n let style = handle.style;\n style.position = 'absolute';\n style.contain = 'strict';\n style.top = '0';\n style.left = '0';\n style.width = '0';\n style.height = '0';\n\n // Attach the handle to the parent if it exists.\n if (this.parent) {\n this.parent.node.appendChild(handle);\n }\n\n // Return the initialized handle.\n return handle;\n }\n\n private _spacing = 4;\n private _dirty = false;\n private _root: Private.LayoutNode | null = null;\n private _box: ElementExt.IBoxSizing | null = null;\n private _document: Document | ShadowRoot;\n private _hiddenMode: Widget.HiddenMode;\n private _items: Private.ItemMap = new Map();\n}\n\n/**\n * The namespace for the `DockLayout` class statics.\n */\nexport namespace DockLayout {\n /**\n * An options object for creating a dock layout.\n */\n export interface IOptions {\n /**\n * The document to use with the dock panel.\n *\n * The default is the global `document` instance.\n */\n document?: Document | ShadowRoot;\n\n /**\n * The method for hiding widgets.\n *\n * The default is `Widget.HiddenMode.Display`.\n */\n hiddenMode?: Widget.HiddenMode;\n\n /**\n * The renderer to use for the dock layout.\n */\n renderer: IRenderer;\n\n /**\n * The spacing between items in the layout.\n *\n * The default is `4`.\n */\n spacing?: number;\n }\n\n /**\n * A renderer for use with a dock layout.\n */\n export interface IRenderer {\n /**\n * Create a new tab bar for use with a dock layout.\n *\n * @returns A new tab bar for a dock layout.\n */\n createTabBar(document?: Document | ShadowRoot): TabBar;\n\n /**\n * Create a new handle node for use with a dock layout.\n *\n * @returns A new handle node for a dock layout.\n */\n createHandle(): HTMLDivElement;\n }\n\n /**\n * A type alias for the supported insertion modes.\n *\n * An insert mode is used to specify how a widget should be added\n * to the dock layout relative to a reference widget.\n */\n export type InsertMode =\n | /**\n * The area to the top of the reference widget.\n *\n * The widget will be inserted just above the reference widget.\n *\n * If the reference widget is null or invalid, the widget will be\n * inserted at the top edge of the dock layout.\n */\n 'split-top'\n\n /**\n * The area to the left of the reference widget.\n *\n * The widget will be inserted just left of the reference widget.\n *\n * If the reference widget is null or invalid, the widget will be\n * inserted at the left edge of the dock layout.\n */\n | 'split-left'\n\n /**\n * The area to the right of the reference widget.\n *\n * The widget will be inserted just right of the reference widget.\n *\n * If the reference widget is null or invalid, the widget will be\n * inserted at the right edge of the dock layout.\n */\n | 'split-right'\n\n /**\n * The area to the bottom of the reference widget.\n *\n * The widget will be inserted just below the reference widget.\n *\n * If the reference widget is null or invalid, the widget will be\n * inserted at the bottom edge of the dock layout.\n */\n | 'split-bottom'\n\n /**\n * Like `split-top` but if a tab layout exists above the reference widget,\n * it behaves like `tab-after` with reference to that instead.\n */\n | 'merge-top'\n\n /**\n * Like `split-left` but if a tab layout exists left of the reference widget,\n * it behaves like `tab-after` with reference to that instead.\n */\n | 'merge-left'\n\n /**\n * Like `split-right` but if a tab layout exists right of the reference widget,\n * it behaves like `tab-after` with reference to that instead.\n */\n | 'merge-right'\n\n /**\n * Like `split-bottom` but if a tab layout exists below the reference widget,\n * it behaves like `tab-after` with reference to that instead.\n */\n | 'merge-bottom'\n\n /**\n * The tab position before the reference widget.\n *\n * The widget will be added as a tab before the reference widget.\n *\n * If the reference widget is null or invalid, a sensible default\n * will be used.\n */\n | 'tab-before'\n\n /**\n * The tab position after the reference widget.\n *\n * The widget will be added as a tab after the reference widget.\n *\n * If the reference widget is null or invalid, a sensible default\n * will be used.\n */\n | 'tab-after';\n\n /**\n * An options object for adding a widget to the dock layout.\n */\n export interface IAddOptions {\n /**\n * The insertion mode for adding the widget.\n *\n * The default is `'tab-after'`.\n */\n mode?: InsertMode;\n\n /**\n * The reference widget for the insert location.\n *\n * The default is `null`.\n */\n ref?: Widget | null;\n }\n\n /**\n * A layout config object for a tab area.\n */\n export interface ITabAreaConfig {\n /**\n * The discriminated type of the config object.\n */\n type: 'tab-area';\n\n /**\n * The widgets contained in the tab area.\n */\n widgets: Widget[];\n\n /**\n * The index of the selected tab.\n */\n currentIndex: number;\n }\n\n /**\n * A layout config object for a split area.\n */\n export interface ISplitAreaConfig {\n /**\n * The discriminated type of the config object.\n */\n type: 'split-area';\n\n /**\n * The orientation of the split area.\n */\n orientation: 'horizontal' | 'vertical';\n\n /**\n * The children in the split area.\n */\n children: AreaConfig[];\n\n /**\n * The relative sizes of the children.\n */\n sizes: number[];\n }\n\n /**\n * A type alias for a general area config.\n */\n export type AreaConfig = ITabAreaConfig | ISplitAreaConfig;\n\n /**\n * A dock layout configuration object.\n */\n export interface ILayoutConfig {\n /**\n * The layout config for the main dock area.\n */\n main: AreaConfig | null;\n }\n\n /**\n * An object which represents the geometry of a tab area.\n */\n export interface ITabAreaGeometry {\n /**\n * The tab bar for the tab area.\n */\n tabBar: TabBar;\n\n /**\n * The local X position of the hit test in the dock area.\n *\n * #### Notes\n * This is the distance from the left edge of the layout parent\n * widget, to the local X coordinate of the hit test query.\n */\n x: number;\n\n /**\n * The local Y position of the hit test in the dock area.\n *\n * #### Notes\n * This is the distance from the top edge of the layout parent\n * widget, to the local Y coordinate of the hit test query.\n */\n y: number;\n\n /**\n * The local coordinate of the top edge of the tab area.\n *\n * #### Notes\n * This is the distance from the top edge of the layout parent\n * widget, to the top edge of the tab area.\n */\n top: number;\n\n /**\n * The local coordinate of the left edge of the tab area.\n *\n * #### Notes\n * This is the distance from the left edge of the layout parent\n * widget, to the left edge of the tab area.\n */\n left: number;\n\n /**\n * The local coordinate of the right edge of the tab area.\n *\n * #### Notes\n * This is the distance from the right edge of the layout parent\n * widget, to the right edge of the tab area.\n */\n right: number;\n\n /**\n * The local coordinate of the bottom edge of the tab area.\n *\n * #### Notes\n * This is the distance from the bottom edge of the layout parent\n * widget, to the bottom edge of the tab area.\n */\n bottom: number;\n\n /**\n * The width of the tab area.\n *\n * #### Notes\n * This is total width allocated for the tab area.\n */\n width: number;\n\n /**\n * The height of the tab area.\n *\n * #### Notes\n * This is total height allocated for the tab area.\n */\n height: number;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * A fraction used for sizing root panels; ~= `1 / golden_ratio`.\n */\n export const GOLDEN_RATIO = 0.618;\n\n /**\n * A type alias for a dock layout node.\n */\n export type LayoutNode = TabLayoutNode | SplitLayoutNode;\n\n /**\n * A type alias for the orientation of a split layout node.\n */\n export type Orientation = 'horizontal' | 'vertical';\n\n /**\n * A type alias for a layout item map.\n */\n export type ItemMap = Map;\n\n /**\n * Create a box sizer with an initial size hint.\n */\n export function createSizer(hint: number): BoxSizer {\n let sizer = new BoxSizer();\n sizer.sizeHint = hint;\n sizer.size = hint;\n return sizer;\n }\n\n /**\n * Normalize an area config object and collect the visited widgets.\n */\n export function normalizeAreaConfig(\n config: DockLayout.AreaConfig,\n widgetSet: Set\n ): DockLayout.AreaConfig | null {\n let result: DockLayout.AreaConfig | null;\n if (config.type === 'tab-area') {\n result = normalizeTabAreaConfig(config, widgetSet);\n } else {\n result = normalizeSplitAreaConfig(config, widgetSet);\n }\n return result;\n }\n\n /**\n * Convert a normalized area config into a layout tree.\n */\n export function realizeAreaConfig(\n config: DockLayout.AreaConfig,\n renderer: DockLayout.IRenderer,\n document: Document | ShadowRoot\n ): LayoutNode {\n let node: LayoutNode;\n if (config.type === 'tab-area') {\n node = realizeTabAreaConfig(config, renderer, document);\n } else {\n node = realizeSplitAreaConfig(config, renderer, document);\n }\n return node;\n }\n\n /**\n * A layout node which holds the data for a tabbed area.\n */\n export class TabLayoutNode {\n /**\n * Construct a new tab layout node.\n *\n * @param tabBar - The tab bar to use for the layout node.\n */\n constructor(tabBar: TabBar) {\n let tabSizer = new BoxSizer();\n let widgetSizer = new BoxSizer();\n tabSizer.stretch = 0;\n widgetSizer.stretch = 1;\n this.tabBar = tabBar;\n this.sizers = [tabSizer, widgetSizer];\n }\n\n /**\n * The parent of the layout node.\n */\n parent: SplitLayoutNode | null = null;\n\n /**\n * The tab bar for the layout node.\n */\n readonly tabBar: TabBar;\n\n /**\n * The sizers for the layout node.\n */\n readonly sizers: [BoxSizer, BoxSizer];\n\n /**\n * The most recent value for the `top` edge of the layout box.\n */\n get top(): number {\n return this._top;\n }\n\n /**\n * The most recent value for the `left` edge of the layout box.\n */\n get left(): number {\n return this._left;\n }\n\n /**\n * The most recent value for the `width` of the layout box.\n */\n get width(): number {\n return this._width;\n }\n\n /**\n * The most recent value for the `height` of the layout box.\n */\n get height(): number {\n return this._height;\n }\n\n /**\n * Create an iterator for all widgets in the layout tree.\n */\n *iterAllWidgets(): IterableIterator {\n yield this.tabBar;\n yield* this.iterUserWidgets();\n }\n\n /**\n * Create an iterator for the user widgets in the layout tree.\n */\n *iterUserWidgets(): IterableIterator {\n for (const title of this.tabBar.titles) {\n yield title.owner;\n }\n }\n\n /**\n * Create an iterator for the selected widgets in the layout tree.\n */\n *iterSelectedWidgets(): IterableIterator {\n let title = this.tabBar.currentTitle;\n if (title) {\n yield title.owner;\n }\n }\n\n /**\n * Create an iterator for the tab bars in the layout tree.\n */\n *iterTabBars(): IterableIterator> {\n yield this.tabBar;\n }\n\n /**\n * Create an iterator for the handles in the layout tree.\n */\n // eslint-disable-next-line require-yield\n *iterHandles(): IterableIterator {\n return;\n }\n\n /**\n * Find the tab layout node which contains the given widget.\n */\n findTabNode(widget: Widget): TabLayoutNode | null {\n return this.tabBar.titles.indexOf(widget.title) !== -1 ? this : null;\n }\n\n /**\n * Find the split layout node which contains the given handle.\n */\n findSplitNode(\n handle: HTMLDivElement\n ): { index: number; node: SplitLayoutNode } | null {\n return null;\n }\n\n /**\n * Find the first tab layout node in a layout tree.\n */\n findFirstTabNode(): TabLayoutNode | null {\n return this;\n }\n\n /**\n * Find the tab layout node which contains the local point.\n */\n hitTestTabNodes(x: number, y: number): TabLayoutNode | null {\n if (x < this._left || x >= this._left + this._width) {\n return null;\n }\n if (y < this._top || y >= this._top + this._height) {\n return null;\n }\n return this;\n }\n\n /**\n * Create a configuration object for the layout tree.\n */\n createConfig(): DockLayout.ITabAreaConfig {\n let widgets = this.tabBar.titles.map(title => title.owner);\n let currentIndex = this.tabBar.currentIndex;\n return { type: 'tab-area', widgets, currentIndex };\n }\n\n /**\n * Recursively hold all of the sizes in the layout tree.\n *\n * This ignores the sizers of tab layout nodes.\n */\n holdAllSizes(): void {\n return;\n }\n\n /**\n * Fit the layout tree.\n */\n fit(spacing: number, items: ItemMap): ElementExt.ISizeLimits {\n // Set up the limit variables.\n let minWidth = 0;\n let minHeight = 0;\n let maxWidth = Infinity;\n let maxHeight = Infinity;\n\n // Lookup the tab bar layout item.\n let tabBarItem = items.get(this.tabBar);\n\n // Lookup the widget layout item.\n let current = this.tabBar.currentTitle;\n let widgetItem = current ? items.get(current.owner) : undefined;\n\n // Lookup the tab bar and widget sizers.\n let [tabBarSizer, widgetSizer] = this.sizers;\n\n // Update the tab bar limits.\n if (tabBarItem) {\n tabBarItem.fit();\n }\n\n // Update the widget limits.\n if (widgetItem) {\n widgetItem.fit();\n }\n\n // Update the results and sizer for the tab bar.\n if (tabBarItem && !tabBarItem.isHidden) {\n minWidth = Math.max(minWidth, tabBarItem.minWidth);\n minHeight += tabBarItem.minHeight;\n tabBarSizer.minSize = tabBarItem.minHeight;\n tabBarSizer.maxSize = tabBarItem.maxHeight;\n } else {\n tabBarSizer.minSize = 0;\n tabBarSizer.maxSize = 0;\n }\n\n // Update the results and sizer for the current widget.\n if (widgetItem && !widgetItem.isHidden) {\n minWidth = Math.max(minWidth, widgetItem.minWidth);\n minHeight += widgetItem.minHeight;\n widgetSizer.minSize = widgetItem.minHeight;\n widgetSizer.maxSize = Infinity;\n } else {\n widgetSizer.minSize = 0;\n widgetSizer.maxSize = Infinity;\n }\n\n // Return the computed size limits for the layout node.\n return { minWidth, minHeight, maxWidth, maxHeight };\n }\n\n /**\n * Update the layout tree.\n */\n update(\n left: number,\n top: number,\n width: number,\n height: number,\n spacing: number,\n items: ItemMap\n ): void {\n // Update the layout box values.\n this._top = top;\n this._left = left;\n this._width = width;\n this._height = height;\n\n // Lookup the tab bar layout item.\n let tabBarItem = items.get(this.tabBar);\n\n // Lookup the widget layout item.\n let current = this.tabBar.currentTitle;\n let widgetItem = current ? items.get(current.owner) : undefined;\n\n // Distribute the layout space to the sizers.\n BoxEngine.calc(this.sizers, height);\n\n // Update the tab bar item using the computed size.\n if (tabBarItem && !tabBarItem.isHidden) {\n let size = this.sizers[0].size;\n tabBarItem.update(left, top, width, size);\n top += size;\n }\n\n // Layout the widget using the computed size.\n if (widgetItem && !widgetItem.isHidden) {\n let size = this.sizers[1].size;\n widgetItem.update(left, top, width, size);\n }\n }\n\n private _top = 0;\n private _left = 0;\n private _width = 0;\n private _height = 0;\n }\n\n /**\n * A layout node which holds the data for a split area.\n */\n export class SplitLayoutNode {\n /**\n * Construct a new split layout node.\n *\n * @param orientation - The orientation of the node.\n */\n constructor(orientation: Orientation) {\n this.orientation = orientation;\n }\n\n /**\n * The parent of the layout node.\n */\n parent: SplitLayoutNode | null = null;\n\n /**\n * Whether the sizers have been normalized.\n */\n normalized = false;\n\n /**\n * The orientation of the node.\n */\n readonly orientation: Orientation;\n\n /**\n * The child nodes for the split node.\n */\n readonly children: LayoutNode[] = [];\n\n /**\n * The box sizers for the layout children.\n */\n readonly sizers: BoxSizer[] = [];\n\n /**\n * The handles for the layout children.\n */\n readonly handles: HTMLDivElement[] = [];\n\n /**\n * Create an iterator for all widgets in the layout tree.\n */\n *iterAllWidgets(): IterableIterator {\n for (const child of this.children) {\n yield* child.iterAllWidgets();\n }\n }\n\n /**\n * Create an iterator for the user widgets in the layout tree.\n */\n *iterUserWidgets(): IterableIterator {\n for (const child of this.children) {\n yield* child.iterUserWidgets();\n }\n }\n\n /**\n * Create an iterator for the selected widgets in the layout tree.\n */\n *iterSelectedWidgets(): IterableIterator {\n for (const child of this.children) {\n yield* child.iterSelectedWidgets();\n }\n }\n\n /**\n * Create an iterator for the tab bars in the layout tree.\n */\n *iterTabBars(): IterableIterator> {\n for (const child of this.children) {\n yield* child.iterTabBars();\n }\n }\n\n /**\n * Create an iterator for the handles in the layout tree.\n */\n *iterHandles(): IterableIterator {\n yield* this.handles;\n for (const child of this.children) {\n yield* child.iterHandles();\n }\n }\n\n /**\n * Find the tab layout node which contains the given widget.\n */\n findTabNode(widget: Widget): TabLayoutNode | null {\n for (let i = 0, n = this.children.length; i < n; ++i) {\n let result = this.children[i].findTabNode(widget);\n if (result) {\n return result;\n }\n }\n return null;\n }\n\n /**\n * Find the split layout node which contains the given handle.\n */\n findSplitNode(\n handle: HTMLDivElement\n ): { index: number; node: SplitLayoutNode } | null {\n let index = this.handles.indexOf(handle);\n if (index !== -1) {\n return { index, node: this };\n }\n for (let i = 0, n = this.children.length; i < n; ++i) {\n let result = this.children[i].findSplitNode(handle);\n if (result) {\n return result;\n }\n }\n return null;\n }\n\n /**\n * Find the first tab layout node in a layout tree.\n */\n findFirstTabNode(): TabLayoutNode | null {\n if (this.children.length === 0) {\n return null;\n }\n return this.children[0].findFirstTabNode();\n }\n\n /**\n * Find the tab layout node which contains the local point.\n */\n hitTestTabNodes(x: number, y: number): TabLayoutNode | null {\n for (let i = 0, n = this.children.length; i < n; ++i) {\n let result = this.children[i].hitTestTabNodes(x, y);\n if (result) {\n return result;\n }\n }\n return null;\n }\n\n /**\n * Create a configuration object for the layout tree.\n */\n createConfig(): DockLayout.ISplitAreaConfig {\n let orientation = this.orientation;\n let sizes = this.createNormalizedSizes();\n let children = this.children.map(child => child.createConfig());\n return { type: 'split-area', orientation, children, sizes };\n }\n\n /**\n * Sync the visibility and orientation of the handles.\n */\n syncHandles(): void {\n this.handles.forEach((handle, i) => {\n handle.setAttribute('data-orientation', this.orientation);\n if (i === this.handles.length - 1) {\n handle.classList.add('lm-mod-hidden');\n } else {\n handle.classList.remove('lm-mod-hidden');\n }\n });\n }\n\n /**\n * Hold the current sizes of the box sizers.\n *\n * This sets the size hint of each sizer to its current size.\n */\n holdSizes(): void {\n for (const sizer of this.sizers) {\n sizer.sizeHint = sizer.size;\n }\n }\n\n /**\n * Recursively hold all of the sizes in the layout tree.\n *\n * This ignores the sizers of tab layout nodes.\n */\n holdAllSizes(): void {\n for (const child of this.children) {\n child.holdAllSizes();\n }\n this.holdSizes();\n }\n\n /**\n * Normalize the sizes of the split layout node.\n */\n normalizeSizes(): void {\n // Bail early if the sizers are empty.\n let n = this.sizers.length;\n if (n === 0) {\n return;\n }\n\n // Hold the current sizes of the sizers.\n this.holdSizes();\n\n // Compute the sum of the sizes.\n let sum = this.sizers.reduce((v, sizer) => v + sizer.sizeHint, 0);\n\n // Normalize the sizes based on the sum.\n if (sum === 0) {\n for (const sizer of this.sizers) {\n sizer.size = sizer.sizeHint = 1 / n;\n }\n } else {\n for (const sizer of this.sizers) {\n sizer.size = sizer.sizeHint /= sum;\n }\n }\n\n // Mark the sizes as normalized.\n this.normalized = true;\n }\n\n /**\n * Snap the normalized sizes of the split layout node.\n */\n createNormalizedSizes(): number[] {\n // Bail early if the sizers are empty.\n let n = this.sizers.length;\n if (n === 0) {\n return [];\n }\n\n // Grab the current sizes of the sizers.\n let sizes = this.sizers.map(sizer => sizer.size);\n\n // Compute the sum of the sizes.\n let sum = sizes.reduce((v, size) => v + size, 0);\n\n // Normalize the sizes based on the sum.\n if (sum === 0) {\n for (let i = sizes.length - 1; i > -1; i--) {\n sizes[i] = 1 / n;\n }\n } else {\n for (let i = sizes.length - 1; i > -1; i--) {\n sizes[i] /= sum;\n }\n }\n\n // Return the normalized sizes.\n return sizes;\n }\n\n /**\n * Fit the layout tree.\n */\n fit(spacing: number, items: ItemMap): ElementExt.ISizeLimits {\n // Compute the required fixed space.\n let horizontal = this.orientation === 'horizontal';\n let fixed = Math.max(0, this.children.length - 1) * spacing;\n\n // Set up the limit variables.\n let minWidth = horizontal ? fixed : 0;\n let minHeight = horizontal ? 0 : fixed;\n let maxWidth = Infinity;\n let maxHeight = Infinity;\n\n // Fit the children and update the limits.\n for (let i = 0, n = this.children.length; i < n; ++i) {\n let limits = this.children[i].fit(spacing, items);\n if (horizontal) {\n minHeight = Math.max(minHeight, limits.minHeight);\n minWidth += limits.minWidth;\n this.sizers[i].minSize = limits.minWidth;\n } else {\n minWidth = Math.max(minWidth, limits.minWidth);\n minHeight += limits.minHeight;\n this.sizers[i].minSize = limits.minHeight;\n }\n }\n\n // Return the computed limits for the layout node.\n return { minWidth, minHeight, maxWidth, maxHeight };\n }\n\n /**\n * Update the layout tree.\n */\n update(\n left: number,\n top: number,\n width: number,\n height: number,\n spacing: number,\n items: ItemMap\n ): void {\n // Compute the available layout space.\n let horizontal = this.orientation === 'horizontal';\n let fixed = Math.max(0, this.children.length - 1) * spacing;\n let space = Math.max(0, (horizontal ? width : height) - fixed);\n\n // De-normalize the sizes if needed.\n if (this.normalized) {\n for (const sizer of this.sizers) {\n sizer.sizeHint *= space;\n }\n this.normalized = false;\n }\n\n // Distribute the layout space to the sizers.\n BoxEngine.calc(this.sizers, space);\n\n // Update the geometry of the child nodes and handles.\n for (let i = 0, n = this.children.length; i < n; ++i) {\n let child = this.children[i];\n let size = this.sizers[i].size;\n let handleStyle = this.handles[i].style;\n if (horizontal) {\n child.update(left, top, size, height, spacing, items);\n left += size;\n handleStyle.top = `${top}px`;\n handleStyle.left = `${left}px`;\n handleStyle.width = `${spacing}px`;\n handleStyle.height = `${height}px`;\n left += spacing;\n } else {\n child.update(left, top, width, size, spacing, items);\n top += size;\n handleStyle.top = `${top}px`;\n handleStyle.left = `${left}px`;\n handleStyle.width = `${width}px`;\n handleStyle.height = `${spacing}px`;\n top += spacing;\n }\n }\n }\n }\n\n export function addAria(widget: Widget, tabBar: TabBar): void {\n widget.node.setAttribute('role', 'tabpanel');\n let renderer = tabBar.renderer;\n if (renderer instanceof TabBar.Renderer) {\n let tabId = renderer.createTabKey({\n title: widget.title,\n current: false,\n zIndex: 0\n });\n widget.node.setAttribute('aria-labelledby', tabId);\n }\n }\n\n export function removeAria(widget: Widget): void {\n widget.node.removeAttribute('role');\n widget.node.removeAttribute('aria-labelledby');\n }\n\n /**\n * Normalize a tab area config and collect the visited widgets.\n */\n function normalizeTabAreaConfig(\n config: DockLayout.ITabAreaConfig,\n widgetSet: Set\n ): DockLayout.ITabAreaConfig | null {\n // Bail early if there is no content.\n if (config.widgets.length === 0) {\n return null;\n }\n\n // Setup the filtered widgets array.\n let widgets: Widget[] = [];\n\n // Filter the config for unique widgets.\n for (const widget of config.widgets) {\n if (!widgetSet.has(widget)) {\n widgetSet.add(widget);\n widgets.push(widget);\n }\n }\n\n // Bail if there are no effective widgets.\n if (widgets.length === 0) {\n return null;\n }\n\n // Normalize the current index.\n let index = config.currentIndex;\n if (index !== -1 && (index < 0 || index >= widgets.length)) {\n index = 0;\n }\n\n // Return a normalized config object.\n return { type: 'tab-area', widgets, currentIndex: index };\n }\n\n /**\n * Normalize a split area config and collect the visited widgets.\n */\n function normalizeSplitAreaConfig(\n config: DockLayout.ISplitAreaConfig,\n widgetSet: Set\n ): DockLayout.AreaConfig | null {\n // Set up the result variables.\n let orientation = config.orientation;\n let children: DockLayout.AreaConfig[] = [];\n let sizes: number[] = [];\n\n // Normalize the config children.\n for (let i = 0, n = config.children.length; i < n; ++i) {\n // Normalize the child config.\n let child = normalizeAreaConfig(config.children[i], widgetSet);\n\n // Ignore an empty child.\n if (!child) {\n continue;\n }\n\n // Add the child or hoist its content as appropriate.\n if (child.type === 'tab-area' || child.orientation !== orientation) {\n children.push(child);\n sizes.push(Math.abs(config.sizes[i] || 0));\n } else {\n children.push(...child.children);\n sizes.push(...child.sizes);\n }\n }\n\n // Bail if there are no effective children.\n if (children.length === 0) {\n return null;\n }\n\n // If there is only one effective child, return that child.\n if (children.length === 1) {\n return children[0];\n }\n\n // Return a normalized config object.\n return { type: 'split-area', orientation, children, sizes };\n }\n\n /**\n * Convert a normalized tab area config into a layout tree.\n */\n function realizeTabAreaConfig(\n config: DockLayout.ITabAreaConfig,\n renderer: DockLayout.IRenderer,\n document: Document | ShadowRoot\n ): TabLayoutNode {\n // Create the tab bar for the layout node.\n let tabBar = renderer.createTabBar(document);\n\n // Hide each widget and add it to the tab bar.\n for (const widget of config.widgets) {\n widget.hide();\n tabBar.addTab(widget.title);\n Private.addAria(widget, tabBar);\n }\n\n // Set the current index of the tab bar.\n tabBar.currentIndex = config.currentIndex;\n\n // Return the new tab layout node.\n return new TabLayoutNode(tabBar);\n }\n\n /**\n * Convert a normalized split area config into a layout tree.\n */\n function realizeSplitAreaConfig(\n config: DockLayout.ISplitAreaConfig,\n renderer: DockLayout.IRenderer,\n document: Document | ShadowRoot\n ): SplitLayoutNode {\n // Create the split layout node.\n let node = new SplitLayoutNode(config.orientation);\n\n // Add each child to the layout node.\n config.children.forEach((child, i) => {\n // Create the child data for the layout node.\n let childNode = realizeAreaConfig(child, renderer, document);\n let sizer = createSizer(config.sizes[i]);\n let handle = renderer.createHandle();\n\n // Add the child data to the layout node.\n node.children.push(childNode);\n node.handles.push(handle);\n node.sizers.push(sizer);\n\n // Update the parent for the child node.\n childNode.parent = node;\n });\n\n // Synchronize the handle state for the layout node.\n node.syncHandles();\n\n // Normalize the sizes for the layout node.\n node.normalizeSizes();\n\n // Return the new layout node.\n return node;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { find } from '@lumino/algorithm';\n\nimport { MimeData } from '@lumino/coreutils';\n\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ElementExt, Platform } from '@lumino/domutils';\n\nimport { Drag } from '@lumino/dragdrop';\n\nimport { ConflatableMessage, Message, MessageLoop } from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { DockLayout } from './docklayout';\n\nimport { TabBar } from './tabbar';\n\nimport { Widget } from './widget';\n\n/**\n * A widget which provides a flexible docking area for widgets.\n */\nexport class DockPanel extends Widget {\n /**\n * Construct a new dock panel.\n *\n * @param options - The options for initializing the panel.\n */\n constructor(options: DockPanel.IOptions = {}) {\n super();\n this.addClass('lm-DockPanel');\n this._document = options.document || document;\n this._mode = options.mode || 'multiple-document';\n this._renderer = options.renderer || DockPanel.defaultRenderer;\n this._edges = options.edges || Private.DEFAULT_EDGES;\n if (options.tabsMovable !== undefined) {\n this._tabsMovable = options.tabsMovable;\n }\n if (options.tabsConstrained !== undefined) {\n this._tabsConstrained = options.tabsConstrained;\n }\n if (options.addButtonEnabled !== undefined) {\n this._addButtonEnabled = options.addButtonEnabled;\n }\n\n // Toggle the CSS mode attribute.\n this.dataset['mode'] = this._mode;\n\n // Create the delegate renderer for the layout.\n let renderer: DockPanel.IRenderer = {\n createTabBar: () => this._createTabBar(),\n createHandle: () => this._createHandle()\n };\n\n // Set up the dock layout for the panel.\n this.layout = new DockLayout({\n document: this._document,\n renderer,\n spacing: options.spacing,\n hiddenMode: options.hiddenMode\n });\n\n // Set up the overlay drop indicator.\n this.overlay = options.overlay || new DockPanel.Overlay();\n this.node.appendChild(this.overlay.node);\n }\n\n /**\n * Dispose of the resources held by the panel.\n */\n dispose(): void {\n // Ensure the mouse is released.\n this._releaseMouse();\n\n // Hide the overlay.\n this.overlay.hide(0);\n\n // Cancel a drag if one is in progress.\n if (this._drag) {\n this._drag.dispose();\n }\n\n // Dispose of the base class.\n super.dispose();\n }\n\n /**\n * The method for hiding widgets.\n */\n get hiddenMode(): Widget.HiddenMode {\n return (this.layout as DockLayout).hiddenMode;\n }\n\n /**\n * Set the method for hiding widgets.\n */\n set hiddenMode(v: Widget.HiddenMode) {\n (this.layout as DockLayout).hiddenMode = v;\n }\n\n /**\n * A signal emitted when the layout configuration is modified.\n *\n * #### Notes\n * This signal is emitted whenever the current layout configuration\n * may have changed.\n *\n * This signal is emitted asynchronously in a collapsed fashion, so\n * that multiple synchronous modifications results in only a single\n * emit of the signal.\n */\n get layoutModified(): ISignal {\n return this._layoutModified;\n }\n\n /**\n * A signal emitted when the add button on a tab bar is clicked.\n *\n */\n get addRequested(): ISignal> {\n return this._addRequested;\n }\n\n /**\n * The overlay used by the dock panel.\n */\n readonly overlay: DockPanel.IOverlay;\n\n /**\n * The renderer used by the dock panel.\n */\n get renderer(): DockPanel.IRenderer {\n return (this.layout as DockLayout).renderer;\n }\n\n /**\n * Get the spacing between the widgets.\n */\n get spacing(): number {\n return (this.layout as DockLayout).spacing;\n }\n\n /**\n * Set the spacing between the widgets.\n */\n set spacing(value: number) {\n (this.layout as DockLayout).spacing = value;\n }\n\n /**\n * Get the mode for the dock panel.\n */\n get mode(): DockPanel.Mode {\n return this._mode;\n }\n\n /**\n * Set the mode for the dock panel.\n *\n * #### Notes\n * Changing the mode is a destructive operation with respect to the\n * panel's layout configuration. If layout state must be preserved,\n * save the current layout config before changing the mode.\n */\n set mode(value: DockPanel.Mode) {\n // Bail early if the mode does not change.\n if (this._mode === value) {\n return;\n }\n\n // Update the internal mode.\n this._mode = value;\n\n // Toggle the CSS mode attribute.\n this.dataset['mode'] = value;\n\n // Get the layout for the panel.\n let layout = this.layout as DockLayout;\n\n // Configure the layout for the specified mode.\n switch (value) {\n case 'multiple-document':\n for (const tabBar of layout.tabBars()) {\n tabBar.show();\n }\n break;\n case 'single-document':\n layout.restoreLayout(Private.createSingleDocumentConfig(this));\n break;\n default:\n throw 'unreachable';\n }\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Whether the tabs can be dragged / moved at runtime.\n */\n get tabsMovable(): boolean {\n return this._tabsMovable;\n }\n\n /**\n * Enable / Disable draggable / movable tabs.\n */\n set tabsMovable(value: boolean) {\n this._tabsMovable = value;\n for (const tabBar of this.tabBars()) {\n tabBar.tabsMovable = value;\n }\n }\n\n /**\n * Whether the tabs are constrained to their source dock panel\n */\n get tabsConstrained(): boolean {\n return this._tabsConstrained;\n }\n\n /**\n * Constrain/Allow tabs to be dragged outside of this dock panel\n */\n set tabsConstrained(value: boolean) {\n this._tabsConstrained = value;\n }\n\n /**\n * Whether the add buttons for each tab bar are enabled.\n */\n get addButtonEnabled(): boolean {\n return this._addButtonEnabled;\n }\n\n /**\n * Set whether the add buttons for each tab bar are enabled.\n */\n set addButtonEnabled(value: boolean) {\n this._addButtonEnabled = value;\n for (const tabBar of this.tabBars()) {\n tabBar.addButtonEnabled = value;\n }\n }\n\n /**\n * Whether the dock panel is empty.\n */\n get isEmpty(): boolean {\n return (this.layout as DockLayout).isEmpty;\n }\n\n /**\n * Create an iterator over the user widgets in the panel.\n *\n * @returns A new iterator over the user widgets in the panel.\n *\n * #### Notes\n * This iterator does not include the generated tab bars.\n */\n *widgets(): IterableIterator {\n yield* (this.layout as DockLayout).widgets();\n }\n\n /**\n * Create an iterator over the selected widgets in the panel.\n *\n * @returns A new iterator over the selected user widgets.\n *\n * #### Notes\n * This iterator yields the widgets corresponding to the current tab\n * of each tab bar in the panel.\n */\n *selectedWidgets(): IterableIterator {\n yield* (this.layout as DockLayout).selectedWidgets();\n }\n\n /**\n * Create an iterator over the tab bars in the panel.\n *\n * @returns A new iterator over the tab bars in the panel.\n *\n * #### Notes\n * This iterator does not include the user widgets.\n */\n *tabBars(): IterableIterator> {\n yield* (this.layout as DockLayout).tabBars();\n }\n\n /**\n * Create an iterator over the handles in the panel.\n *\n * @returns A new iterator over the handles in the panel.\n */\n *handles(): IterableIterator {\n yield* (this.layout as DockLayout).handles();\n }\n\n /**\n * Select a specific widget in the dock panel.\n *\n * @param widget - The widget of interest.\n *\n * #### Notes\n * This will make the widget the current widget in its tab area.\n */\n selectWidget(widget: Widget): void {\n // Find the tab bar which contains the widget.\n let tabBar = find(this.tabBars(), bar => {\n return bar.titles.indexOf(widget.title) !== -1;\n });\n\n // Throw an error if no tab bar is found.\n if (!tabBar) {\n throw new Error('Widget is not contained in the dock panel.');\n }\n\n // Ensure the widget is the current widget.\n tabBar.currentTitle = widget.title;\n }\n\n /**\n * Activate a specified widget in the dock panel.\n *\n * @param widget - The widget of interest.\n *\n * #### Notes\n * This will select and activate the given widget.\n */\n activateWidget(widget: Widget): void {\n this.selectWidget(widget);\n widget.activate();\n }\n\n /**\n * Save the current layout configuration of the dock panel.\n *\n * @returns A new config object for the current layout state.\n *\n * #### Notes\n * The return value can be provided to the `restoreLayout` method\n * in order to restore the layout to its current configuration.\n */\n saveLayout(): DockPanel.ILayoutConfig {\n return (this.layout as DockLayout).saveLayout();\n }\n\n /**\n * Restore the layout to a previously saved configuration.\n *\n * @param config - The layout configuration to restore.\n *\n * #### Notes\n * Widgets which currently belong to the layout but which are not\n * contained in the config will be unparented.\n *\n * The dock panel automatically reverts to `'multiple-document'`\n * mode when a layout config is restored.\n */\n restoreLayout(config: DockPanel.ILayoutConfig): void {\n // Reset the mode.\n this._mode = 'multiple-document';\n\n // Restore the layout.\n (this.layout as DockLayout).restoreLayout(config);\n\n // Flush the message loop on IE and Edge to prevent flicker.\n if (Platform.IS_EDGE || Platform.IS_IE) {\n MessageLoop.flush();\n }\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Add a widget to the dock panel.\n *\n * @param widget - The widget to add to the dock panel.\n *\n * @param options - The additional options for adding the widget.\n *\n * #### Notes\n * If the panel is in single document mode, the options are ignored\n * and the widget is always added as tab in the hidden tab bar.\n */\n addWidget(widget: Widget, options: DockPanel.IAddOptions = {}): void {\n // Add the widget to the layout.\n if (this._mode === 'single-document') {\n (this.layout as DockLayout).addWidget(widget);\n } else {\n (this.layout as DockLayout).addWidget(widget, options);\n }\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Process a message sent to the widget.\n *\n * @param msg - The message sent to the widget.\n */\n processMessage(msg: Message): void {\n if (msg.type === 'layout-modified') {\n this._layoutModified.emit(undefined);\n } else {\n super.processMessage(msg);\n }\n }\n\n /**\n * Handle the DOM events for the dock panel.\n *\n * @param event - The DOM event sent to the panel.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the panel's DOM node. It should\n * not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'lm-dragenter':\n this._evtDragEnter(event as Drag.Event);\n break;\n case 'lm-dragleave':\n this._evtDragLeave(event as Drag.Event);\n break;\n case 'lm-dragover':\n this._evtDragOver(event as Drag.Event);\n break;\n case 'lm-drop':\n this._evtDrop(event as Drag.Event);\n break;\n case 'pointerdown':\n this._evtPointerDown(event as PointerEvent);\n break;\n case 'pointermove':\n this._evtPointerMove(event as PointerEvent);\n break;\n case 'pointerup':\n this._evtPointerUp(event as PointerEvent);\n break;\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('lm-dragenter', this);\n this.node.addEventListener('lm-dragleave', this);\n this.node.addEventListener('lm-dragover', this);\n this.node.addEventListener('lm-drop', this);\n this.node.addEventListener('pointerdown', this);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('lm-dragenter', this);\n this.node.removeEventListener('lm-dragleave', this);\n this.node.removeEventListener('lm-dragover', this);\n this.node.removeEventListener('lm-drop', this);\n this.node.removeEventListener('pointerdown', this);\n this._releaseMouse();\n }\n\n /**\n * A message handler invoked on a `'child-added'` message.\n */\n protected onChildAdded(msg: Widget.ChildMessage): void {\n // Ignore the generated tab bars.\n if (Private.isGeneratedTabBarProperty.get(msg.child)) {\n return;\n }\n\n // Add the widget class to the child.\n msg.child.addClass('lm-DockPanel-widget');\n }\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {\n // Ignore the generated tab bars.\n if (Private.isGeneratedTabBarProperty.get(msg.child)) {\n return;\n }\n\n // Remove the widget class from the child.\n msg.child.removeClass('lm-DockPanel-widget');\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Handle the `'lm-dragenter'` event for the dock panel.\n */\n private _evtDragEnter(event: Drag.Event): void {\n // If the factory mime type is present, mark the event as\n // handled in order to get the rest of the drag events.\n if (event.mimeData.hasData('application/vnd.lumino.widget-factory')) {\n event.preventDefault();\n event.stopPropagation();\n }\n }\n\n /**\n * Handle the `'lm-dragleave'` event for the dock panel.\n */\n private _evtDragLeave(event: Drag.Event): void {\n // Mark the event as handled.\n event.preventDefault();\n\n if (this._tabsConstrained && event.source !== this) return;\n\n event.stopPropagation();\n\n // The new target might be a descendant, so we might still handle the drop.\n // Hide asynchronously so that if a lm-dragover event bubbles up to us, the\n // hide is cancelled by the lm-dragover handler's show overlay logic.\n this.overlay.hide(1);\n }\n\n /**\n * Handle the `'lm-dragover'` event for the dock panel.\n */\n private _evtDragOver(event: Drag.Event): void {\n // Mark the event as handled.\n event.preventDefault();\n\n // Show the drop indicator overlay and update the drop\n // action based on the drop target zone under the mouse.\n if (\n (this._tabsConstrained && event.source !== this) ||\n this._showOverlay(event.clientX, event.clientY) === 'invalid'\n ) {\n event.dropAction = 'none';\n } else {\n event.stopPropagation();\n event.dropAction = event.proposedAction;\n }\n }\n\n /**\n * Handle the `'lm-drop'` event for the dock panel.\n */\n private _evtDrop(event: Drag.Event): void {\n // Mark the event as handled.\n event.preventDefault();\n\n // Hide the drop indicator overlay.\n this.overlay.hide(0);\n\n // Bail if the proposed action is to do nothing.\n if (event.proposedAction === 'none') {\n event.dropAction = 'none';\n return;\n }\n\n // Find the drop target under the mouse.\n let { clientX, clientY } = event;\n let { zone, target } = Private.findDropTarget(\n this,\n clientX,\n clientY,\n this._edges\n );\n\n // Bail if the drop zone is invalid.\n if (\n (this._tabsConstrained && event.source !== this) ||\n zone === 'invalid'\n ) {\n event.dropAction = 'none';\n return;\n }\n\n // Bail if the factory mime type has invalid data.\n let mimeData = event.mimeData;\n let factory = mimeData.getData('application/vnd.lumino.widget-factory');\n if (typeof factory !== 'function') {\n event.dropAction = 'none';\n return;\n }\n\n // Bail if the factory does not produce a widget.\n let widget = factory();\n if (!(widget instanceof Widget)) {\n event.dropAction = 'none';\n return;\n }\n\n // Bail if the widget is an ancestor of the dock panel.\n if (widget.contains(this)) {\n event.dropAction = 'none';\n return;\n }\n\n // Find the reference widget for the drop target.\n let ref = target ? Private.getDropRef(target.tabBar) : null;\n\n // Add the widget according to the indicated drop zone.\n switch (zone) {\n case 'root-all':\n this.addWidget(widget);\n break;\n case 'root-top':\n this.addWidget(widget, { mode: 'split-top' });\n break;\n case 'root-left':\n this.addWidget(widget, { mode: 'split-left' });\n break;\n case 'root-right':\n this.addWidget(widget, { mode: 'split-right' });\n break;\n case 'root-bottom':\n this.addWidget(widget, { mode: 'split-bottom' });\n break;\n case 'widget-all':\n this.addWidget(widget, { mode: 'tab-after', ref });\n break;\n case 'widget-top':\n this.addWidget(widget, { mode: 'split-top', ref });\n break;\n case 'widget-left':\n this.addWidget(widget, { mode: 'split-left', ref });\n break;\n case 'widget-right':\n this.addWidget(widget, { mode: 'split-right', ref });\n break;\n case 'widget-bottom':\n this.addWidget(widget, { mode: 'split-bottom', ref });\n break;\n case 'widget-tab':\n this.addWidget(widget, { mode: 'tab-after', ref });\n break;\n default:\n throw 'unreachable';\n }\n\n // Accept the proposed drop action.\n event.dropAction = event.proposedAction;\n\n // Stop propagation if we have not bailed so far.\n event.stopPropagation();\n\n // Activate the dropped widget.\n this.activateWidget(widget);\n }\n\n /**\n * Handle the `'keydown'` event for the dock panel.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // Stop input events during drag.\n event.preventDefault();\n event.stopPropagation();\n\n // Release the mouse if `Escape` is pressed.\n if (event.keyCode === 27) {\n // Finalize the mouse release.\n this._releaseMouse();\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n }\n\n /**\n * Handle the `'pointerdown'` event for the dock panel.\n */\n private _evtPointerDown(event: PointerEvent): void {\n // Do nothing if the left mouse button is not pressed.\n if (event.button !== 0) {\n return;\n }\n\n // Find the handle which contains the mouse target, if any.\n let layout = this.layout as DockLayout;\n let target = event.target as HTMLElement;\n let handle = find(layout.handles(), handle => handle.contains(target));\n if (!handle) {\n return;\n }\n\n // Stop the event when a handle is pressed.\n event.preventDefault();\n event.stopPropagation();\n\n // Add the extra document listeners.\n this._document.addEventListener('keydown', this, true);\n this._document.addEventListener('pointerup', this, true);\n this._document.addEventListener('pointermove', this, true);\n this._document.addEventListener('contextmenu', this, true);\n\n // Compute the offset deltas for the handle press.\n let rect = handle.getBoundingClientRect();\n let deltaX = event.clientX - rect.left;\n let deltaY = event.clientY - rect.top;\n\n // Override the cursor and store the press data.\n let style = window.getComputedStyle(handle);\n let override = Drag.overrideCursor(style.cursor!, this._document);\n this._pressData = { handle, deltaX, deltaY, override };\n }\n\n /**\n * Handle the `'pointermove'` event for the dock panel.\n */\n private _evtPointerMove(event: PointerEvent): void {\n // Bail early if no drag is in progress.\n if (!this._pressData) {\n return;\n }\n\n // Stop the event when dragging a handle.\n event.preventDefault();\n event.stopPropagation();\n\n // Compute the desired offset position for the handle.\n let rect = this.node.getBoundingClientRect();\n let xPos = event.clientX - rect.left - this._pressData.deltaX;\n let yPos = event.clientY - rect.top - this._pressData.deltaY;\n\n // Set the handle as close to the desired position as possible.\n let layout = this.layout as DockLayout;\n layout.moveHandle(this._pressData.handle, xPos, yPos);\n }\n\n /**\n * Handle the `'pointerup'` event for the dock panel.\n */\n private _evtPointerUp(event: PointerEvent): void {\n // Do nothing if the left mouse button is not released.\n if (event.button !== 0) {\n return;\n }\n\n // Stop the event when releasing a handle.\n event.preventDefault();\n event.stopPropagation();\n\n // Finalize the mouse release.\n this._releaseMouse();\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Release the mouse grab for the dock panel.\n */\n private _releaseMouse(): void {\n // Bail early if no drag is in progress.\n if (!this._pressData) {\n return;\n }\n\n // Clear the override cursor.\n this._pressData.override.dispose();\n this._pressData = null;\n\n // Remove the extra document listeners.\n this._document.removeEventListener('keydown', this, true);\n this._document.removeEventListener('pointerup', this, true);\n this._document.removeEventListener('pointermove', this, true);\n this._document.removeEventListener('contextmenu', this, true);\n }\n\n /**\n * Show the overlay indicator at the given client position.\n *\n * Returns the drop zone at the specified client position.\n *\n * #### Notes\n * If the position is not over a valid zone, the overlay is hidden.\n */\n private _showOverlay(clientX: number, clientY: number): Private.DropZone {\n // Find the dock target for the given client position.\n let { zone, target } = Private.findDropTarget(\n this,\n clientX,\n clientY,\n this._edges\n );\n\n // If the drop zone is invalid, hide the overlay and bail.\n if (zone === 'invalid') {\n this.overlay.hide(100);\n return zone;\n }\n\n // Setup the variables needed to compute the overlay geometry.\n let top: number;\n let left: number;\n let right: number;\n let bottom: number;\n let box = ElementExt.boxSizing(this.node); // TODO cache this?\n let rect = this.node.getBoundingClientRect();\n\n // Compute the overlay geometry based on the dock zone.\n switch (zone) {\n case 'root-all':\n top = box.paddingTop;\n left = box.paddingLeft;\n right = box.paddingRight;\n bottom = box.paddingBottom;\n break;\n case 'root-top':\n top = box.paddingTop;\n left = box.paddingLeft;\n right = box.paddingRight;\n bottom = rect.height * Private.GOLDEN_RATIO;\n break;\n case 'root-left':\n top = box.paddingTop;\n left = box.paddingLeft;\n right = rect.width * Private.GOLDEN_RATIO;\n bottom = box.paddingBottom;\n break;\n case 'root-right':\n top = box.paddingTop;\n left = rect.width * Private.GOLDEN_RATIO;\n right = box.paddingRight;\n bottom = box.paddingBottom;\n break;\n case 'root-bottom':\n top = rect.height * Private.GOLDEN_RATIO;\n left = box.paddingLeft;\n right = box.paddingRight;\n bottom = box.paddingBottom;\n break;\n case 'widget-all':\n top = target!.top;\n left = target!.left;\n right = target!.right;\n bottom = target!.bottom;\n break;\n case 'widget-top':\n top = target!.top;\n left = target!.left;\n right = target!.right;\n bottom = target!.bottom + target!.height / 2;\n break;\n case 'widget-left':\n top = target!.top;\n left = target!.left;\n right = target!.right + target!.width / 2;\n bottom = target!.bottom;\n break;\n case 'widget-right':\n top = target!.top;\n left = target!.left + target!.width / 2;\n right = target!.right;\n bottom = target!.bottom;\n break;\n case 'widget-bottom':\n top = target!.top + target!.height / 2;\n left = target!.left;\n right = target!.right;\n bottom = target!.bottom;\n break;\n case 'widget-tab': {\n const tabHeight = target!.tabBar.node.getBoundingClientRect().height;\n top = target!.top;\n left = target!.left;\n right = target!.right;\n bottom = target!.bottom + target!.height - tabHeight;\n break;\n }\n default:\n throw 'unreachable';\n }\n\n // Show the overlay with the computed geometry.\n this.overlay.show({ top, left, right, bottom });\n\n // Finally, return the computed drop zone.\n return zone;\n }\n\n /**\n * Create a new tab bar for use by the panel.\n */\n private _createTabBar(): TabBar {\n // Create the tab bar.\n let tabBar = this._renderer.createTabBar(this._document);\n\n // Set the generated tab bar property for the tab bar.\n Private.isGeneratedTabBarProperty.set(tabBar, true);\n\n // Hide the tab bar when in single document mode.\n if (this._mode === 'single-document') {\n tabBar.hide();\n }\n\n // Enforce necessary tab bar behavior.\n // TODO do we really want to enforce *all* of these?\n tabBar.tabsMovable = this._tabsMovable;\n tabBar.allowDeselect = false;\n tabBar.addButtonEnabled = this._addButtonEnabled;\n tabBar.removeBehavior = 'select-previous-tab';\n tabBar.insertBehavior = 'select-tab-if-needed';\n\n // Connect the signal handlers for the tab bar.\n tabBar.tabMoved.connect(this._onTabMoved, this);\n tabBar.currentChanged.connect(this._onCurrentChanged, this);\n tabBar.tabCloseRequested.connect(this._onTabCloseRequested, this);\n tabBar.tabDetachRequested.connect(this._onTabDetachRequested, this);\n tabBar.tabActivateRequested.connect(this._onTabActivateRequested, this);\n tabBar.addRequested.connect(this._onTabAddRequested, this);\n\n // Return the initialized tab bar.\n return tabBar;\n }\n\n /**\n * Create a new handle for use by the panel.\n */\n private _createHandle(): HTMLDivElement {\n return this._renderer.createHandle();\n }\n\n /**\n * Handle the `tabMoved` signal from a tab bar.\n */\n private _onTabMoved(): void {\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Handle the `currentChanged` signal from a tab bar.\n */\n private _onCurrentChanged(\n sender: TabBar,\n args: TabBar.ICurrentChangedArgs\n ): void {\n // Extract the previous and current title from the args.\n let { previousTitle, currentTitle } = args;\n\n // Hide the previous widget.\n if (previousTitle) {\n previousTitle.owner.hide();\n }\n\n // Show the current widget.\n if (currentTitle) {\n currentTitle.owner.show();\n }\n\n // Flush the message loop on IE and Edge to prevent flicker.\n if (Platform.IS_EDGE || Platform.IS_IE) {\n MessageLoop.flush();\n }\n\n // Schedule an emit of the layout modified signal.\n MessageLoop.postMessage(this, Private.LayoutModified);\n }\n\n /**\n * Handle the `addRequested` signal from a tab bar.\n */\n private _onTabAddRequested(sender: TabBar): void {\n this._addRequested.emit(sender);\n }\n\n /**\n * Handle the `tabActivateRequested` signal from a tab bar.\n */\n private _onTabActivateRequested(\n sender: TabBar,\n args: TabBar.ITabActivateRequestedArgs\n ): void {\n args.title.owner.activate();\n }\n\n /**\n * Handle the `tabCloseRequested` signal from a tab bar.\n */\n private _onTabCloseRequested(\n sender: TabBar,\n args: TabBar.ITabCloseRequestedArgs\n ): void {\n args.title.owner.close();\n }\n\n /**\n * Handle the `tabDetachRequested` signal from a tab bar.\n */\n private _onTabDetachRequested(\n sender: TabBar,\n args: TabBar.ITabDetachRequestedArgs\n ): void {\n // Do nothing if a drag is already in progress.\n if (this._drag) {\n return;\n }\n\n // Release the tab bar's hold on the mouse.\n sender.releaseMouse();\n\n // Extract the data from the args.\n let { title, tab, clientX, clientY, offset } = args;\n\n // Setup the mime data for the drag operation.\n let mimeData = new MimeData();\n let factory = () => title.owner;\n mimeData.setData('application/vnd.lumino.widget-factory', factory);\n\n // Create the drag image for the drag operation.\n let dragImage = tab.cloneNode(true) as HTMLElement;\n if (offset) {\n dragImage.style.top = `-${offset.y}px`;\n dragImage.style.left = `-${offset.x}px`;\n }\n\n // Create the drag object to manage the drag-drop operation.\n this._drag = new Drag({\n document: this._document,\n mimeData,\n dragImage,\n proposedAction: 'move',\n supportedActions: 'move',\n source: this\n });\n\n // Hide the tab node in the original tab.\n tab.classList.add('lm-mod-hidden');\n let cleanup = () => {\n this._drag = null;\n tab.classList.remove('lm-mod-hidden');\n };\n\n // Start the drag operation and cleanup when done.\n this._drag.start(clientX, clientY).then(cleanup);\n }\n\n private _edges: DockPanel.IEdges;\n private _document: Document | ShadowRoot;\n private _mode: DockPanel.Mode;\n private _drag: Drag | null = null;\n private _renderer: DockPanel.IRenderer;\n private _tabsMovable: boolean = true;\n private _tabsConstrained: boolean = false;\n private _addButtonEnabled: boolean = false;\n private _pressData: Private.IPressData | null = null;\n private _layoutModified = new Signal(this);\n\n private _addRequested = new Signal>(this);\n}\n\n/**\n * The namespace for the `DockPanel` class statics.\n */\nexport namespace DockPanel {\n /**\n * An options object for creating a dock panel.\n */\n export interface IOptions {\n /**\n * The document to use with the dock panel.\n *\n * The default is the global `document` instance.\n */\n\n document?: Document | ShadowRoot;\n /**\n * The overlay to use with the dock panel.\n *\n * The default is a new `Overlay` instance.\n */\n overlay?: IOverlay;\n\n /**\n * The renderer to use for the dock panel.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n\n /**\n * The spacing between the items in the panel.\n *\n * The default is `4`.\n */\n spacing?: number;\n\n /**\n * The mode for the dock panel.\n *\n * The default is `'multiple-document'`.\n */\n mode?: DockPanel.Mode;\n\n /**\n * The sizes of the edge drop zones, in pixels.\n * If not given, default values will be used.\n */\n edges?: IEdges;\n\n /**\n * The method for hiding widgets.\n *\n * The default is `Widget.HiddenMode.Display`.\n */\n hiddenMode?: Widget.HiddenMode;\n\n /**\n * Allow tabs to be draggable / movable by user.\n *\n * The default is `'true'`.\n */\n tabsMovable?: boolean;\n\n /**\n * Constrain tabs to this dock panel\n *\n * The default is `'false'`.\n */\n tabsConstrained?: boolean;\n\n /**\n * Enable add buttons in each of the dock panel's tab bars.\n *\n * The default is `'false'`.\n */\n addButtonEnabled?: boolean;\n }\n\n /**\n * The sizes of the edge drop zones, in pixels.\n */\n export interface IEdges {\n /**\n * The size of the top edge drop zone.\n */\n top: number;\n\n /**\n * The size of the right edge drop zone.\n */\n right: number;\n\n /**\n * The size of the bottom edge drop zone.\n */\n bottom: number;\n\n /**\n * The size of the left edge drop zone.\n */\n left: number;\n }\n\n /**\n * A type alias for the supported dock panel modes.\n */\n export type Mode =\n | /**\n * The single document mode.\n *\n * In this mode, only a single widget is visible at a time, and that\n * widget fills the available layout space. No tab bars are visible.\n */\n 'single-document'\n\n /**\n * The multiple document mode.\n *\n * In this mode, multiple documents are displayed in separate tab\n * areas, and those areas can be individually resized by the user.\n */\n | 'multiple-document';\n\n /**\n * A type alias for a layout configuration object.\n */\n export type ILayoutConfig = DockLayout.ILayoutConfig;\n\n /**\n * A type alias for the supported insertion modes.\n */\n export type InsertMode = DockLayout.InsertMode;\n\n /**\n * A type alias for the add widget options.\n */\n export type IAddOptions = DockLayout.IAddOptions;\n\n /**\n * An object which holds the geometry for overlay positioning.\n */\n export interface IOverlayGeometry {\n /**\n * The distance between the overlay and parent top edges.\n */\n top: number;\n\n /**\n * The distance between the overlay and parent left edges.\n */\n left: number;\n\n /**\n * The distance between the overlay and parent right edges.\n */\n right: number;\n\n /**\n * The distance between the overlay and parent bottom edges.\n */\n bottom: number;\n }\n\n /**\n * An object which manages the overlay node for a dock panel.\n */\n export interface IOverlay {\n /**\n * The DOM node for the overlay.\n */\n readonly node: HTMLDivElement;\n\n /**\n * Show the overlay using the given overlay geometry.\n *\n * @param geo - The desired geometry for the overlay.\n *\n * #### Notes\n * The given geometry values assume the node will use absolute\n * positioning.\n *\n * This is called on every mouse move event during a drag in order\n * to update the position of the overlay. It should be efficient.\n */\n show(geo: IOverlayGeometry): void;\n\n /**\n * Hide the overlay node.\n *\n * @param delay - The delay (in ms) before hiding the overlay.\n * A delay value <= 0 should hide the overlay immediately.\n *\n * #### Notes\n * This is called whenever the overlay node should been hidden.\n */\n hide(delay: number): void;\n }\n\n /**\n * A concrete implementation of `IOverlay`.\n *\n * This is the default overlay implementation for a dock panel.\n */\n export class Overlay implements IOverlay {\n /**\n * Construct a new overlay.\n */\n constructor() {\n this.node = document.createElement('div');\n this.node.classList.add('lm-DockPanel-overlay');\n this.node.classList.add('lm-mod-hidden');\n this.node.style.position = 'absolute';\n this.node.style.contain = 'strict';\n }\n\n /**\n * The DOM node for the overlay.\n */\n readonly node: HTMLDivElement;\n\n /**\n * Show the overlay using the given overlay geometry.\n *\n * @param geo - The desired geometry for the overlay.\n */\n show(geo: IOverlayGeometry): void {\n // Update the position of the overlay.\n let style = this.node.style;\n style.top = `${geo.top}px`;\n style.left = `${geo.left}px`;\n style.right = `${geo.right}px`;\n style.bottom = `${geo.bottom}px`;\n\n // Clear any pending hide timer.\n clearTimeout(this._timer);\n this._timer = -1;\n\n // If the overlay is already visible, we're done.\n if (!this._hidden) {\n return;\n }\n\n // Clear the hidden flag.\n this._hidden = false;\n\n // Finally, show the overlay.\n this.node.classList.remove('lm-mod-hidden');\n }\n\n /**\n * Hide the overlay node.\n *\n * @param delay - The delay (in ms) before hiding the overlay.\n * A delay value <= 0 will hide the overlay immediately.\n */\n hide(delay: number): void {\n // Do nothing if the overlay is already hidden.\n if (this._hidden) {\n return;\n }\n\n // Hide immediately if the delay is <= 0.\n if (delay <= 0) {\n clearTimeout(this._timer);\n this._timer = -1;\n this._hidden = true;\n this.node.classList.add('lm-mod-hidden');\n return;\n }\n\n // Do nothing if a hide is already pending.\n if (this._timer !== -1) {\n return;\n }\n\n // Otherwise setup the hide timer.\n this._timer = window.setTimeout(() => {\n this._timer = -1;\n this._hidden = true;\n this.node.classList.add('lm-mod-hidden');\n }, delay);\n }\n\n private _timer = -1;\n private _hidden = true;\n }\n\n /**\n * A type alias for a dock panel renderer;\n */\n export type IRenderer = DockLayout.IRenderer;\n\n /**\n * The default implementation of `IRenderer`.\n */\n export class Renderer implements IRenderer {\n /**\n * Create a new tab bar for use with a dock panel.\n *\n * @returns A new tab bar for a dock panel.\n */\n createTabBar(document?: Document | ShadowRoot): TabBar {\n let bar = new TabBar({ document });\n bar.addClass('lm-DockPanel-tabBar');\n return bar;\n }\n\n /**\n * Create a new handle node for use with a dock panel.\n *\n * @returns A new handle node for a dock panel.\n */\n createHandle(): HTMLDivElement {\n let handle = document.createElement('div');\n handle.className = 'lm-DockPanel-handle';\n return handle;\n }\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * A fraction used for sizing root panels; ~= `1 / golden_ratio`.\n */\n export const GOLDEN_RATIO = 0.618;\n\n /**\n * The default sizes for the edge drop zones, in pixels.\n */\n export const DEFAULT_EDGES = {\n /**\n * The size of the top edge dock zone for the root panel, in pixels.\n * This is different from the others to distinguish between the top\n * tab bar and the top root zone.\n */\n top: 12,\n\n /**\n * The size of the edge dock zone for the root panel, in pixels.\n */\n right: 40,\n\n /**\n * The size of the edge dock zone for the root panel, in pixels.\n */\n bottom: 40,\n\n /**\n * The size of the edge dock zone for the root panel, in pixels.\n */\n left: 40\n };\n\n /**\n * A singleton `'layout-modified'` conflatable message.\n */\n export const LayoutModified = new ConflatableMessage('layout-modified');\n\n /**\n * An object which holds mouse press data.\n */\n export interface IPressData {\n /**\n * The handle which was pressed.\n */\n handle: HTMLDivElement;\n\n /**\n * The X offset of the press in handle coordinates.\n */\n deltaX: number;\n\n /**\n * The Y offset of the press in handle coordinates.\n */\n deltaY: number;\n\n /**\n * The disposable which will clear the override cursor.\n */\n override: IDisposable;\n }\n\n /**\n * A type alias for a drop zone.\n */\n export type DropZone =\n | /**\n * An invalid drop zone.\n */\n 'invalid'\n\n /**\n * The entirety of the root dock area.\n */\n | 'root-all'\n\n /**\n * The top portion of the root dock area.\n */\n | 'root-top'\n\n /**\n * The left portion of the root dock area.\n */\n | 'root-left'\n\n /**\n * The right portion of the root dock area.\n */\n | 'root-right'\n\n /**\n * The bottom portion of the root dock area.\n */\n | 'root-bottom'\n\n /**\n * The entirety of a tabbed widget area.\n */\n | 'widget-all'\n\n /**\n * The top portion of tabbed widget area.\n */\n | 'widget-top'\n\n /**\n * The left portion of tabbed widget area.\n */\n | 'widget-left'\n\n /**\n * The right portion of tabbed widget area.\n */\n | 'widget-right'\n\n /**\n * The bottom portion of tabbed widget area.\n */\n | 'widget-bottom'\n\n /**\n * The the bar of a tabbed widget area.\n */\n | 'widget-tab';\n\n /**\n * An object which holds the drop target zone and widget.\n */\n export interface IDropTarget {\n /**\n * The semantic zone for the mouse position.\n */\n zone: DropZone;\n\n /**\n * The tab area geometry for the drop zone, or `null`.\n */\n target: DockLayout.ITabAreaGeometry | null;\n }\n\n /**\n * An attached property used to track generated tab bars.\n */\n export const isGeneratedTabBarProperty = new AttachedProperty<\n Widget,\n boolean\n >({\n name: 'isGeneratedTabBar',\n create: () => false\n });\n\n /**\n * Create a single document config for the widgets in a dock panel.\n */\n export function createSingleDocumentConfig(\n panel: DockPanel\n ): DockPanel.ILayoutConfig {\n // Return an empty config if the panel is empty.\n if (panel.isEmpty) {\n return { main: null };\n }\n\n // Get a flat array of the widgets in the panel.\n let widgets = Array.from(panel.widgets());\n\n // Get the first selected widget in the panel.\n let selected = panel.selectedWidgets().next().value;\n\n // Compute the current index for the new config.\n let currentIndex = selected ? widgets.indexOf(selected) : -1;\n\n // Return the single document config.\n return { main: { type: 'tab-area', widgets, currentIndex } };\n }\n\n /**\n * Find the drop target at the given client position.\n */\n export function findDropTarget(\n panel: DockPanel,\n clientX: number,\n clientY: number,\n edges: DockPanel.IEdges\n ): IDropTarget {\n // Bail if the mouse is not over the dock panel.\n if (!ElementExt.hitTest(panel.node, clientX, clientY)) {\n return { zone: 'invalid', target: null };\n }\n\n // Look up the layout for the panel.\n let layout = panel.layout as DockLayout;\n\n // If the layout is empty, indicate the entire root drop zone.\n if (layout.isEmpty) {\n return { zone: 'root-all', target: null };\n }\n\n // Test the edge zones when in multiple document mode.\n if (panel.mode === 'multiple-document') {\n // Get the client rect for the dock panel.\n let panelRect = panel.node.getBoundingClientRect();\n\n // Compute the distance to each edge of the panel.\n let pl = clientX - panelRect.left + 1;\n let pt = clientY - panelRect.top + 1;\n let pr = panelRect.right - clientX;\n let pb = panelRect.bottom - clientY;\n\n // Find the minimum distance to an edge.\n let pd = Math.min(pt, pr, pb, pl);\n\n // Return a root zone if the mouse is within an edge.\n switch (pd) {\n case pt:\n if (pt < edges.top) {\n return { zone: 'root-top', target: null };\n }\n break;\n case pr:\n if (pr < edges.right) {\n return { zone: 'root-right', target: null };\n }\n break;\n case pb:\n if (pb < edges.bottom) {\n return { zone: 'root-bottom', target: null };\n }\n break;\n case pl:\n if (pl < edges.left) {\n return { zone: 'root-left', target: null };\n }\n break;\n default:\n throw 'unreachable';\n }\n }\n\n // Hit test the dock layout at the given client position.\n let target = layout.hitTestTabAreas(clientX, clientY);\n\n // Bail if no target area was found.\n if (!target) {\n return { zone: 'invalid', target: null };\n }\n\n // Return the whole tab area when in single document mode.\n if (panel.mode === 'single-document') {\n return { zone: 'widget-all', target };\n }\n\n // Compute the distance to each edge of the tab area.\n let al = target.x - target.left + 1;\n let at = target.y - target.top + 1;\n let ar = target.left + target.width - target.x;\n let ab = target.top + target.height - target.y;\n\n const tabHeight = target.tabBar.node.getBoundingClientRect().height;\n if (at < tabHeight) {\n return { zone: 'widget-tab', target };\n }\n\n // Get the X and Y edge sizes for the area.\n let rx = Math.round(target.width / 3);\n let ry = Math.round(target.height / 3);\n\n // If the mouse is not within an edge, indicate the entire area.\n if (al > rx && ar > rx && at > ry && ab > ry) {\n return { zone: 'widget-all', target };\n }\n\n // Scale the distances by the slenderness ratio.\n al /= rx;\n at /= ry;\n ar /= rx;\n ab /= ry;\n\n // Find the minimum distance to the area edge.\n let ad = Math.min(al, at, ar, ab);\n\n // Find the widget zone for the area edge.\n let zone: DropZone;\n switch (ad) {\n case al:\n zone = 'widget-left';\n break;\n case at:\n zone = 'widget-top';\n break;\n case ar:\n zone = 'widget-right';\n break;\n case ab:\n zone = 'widget-bottom';\n break;\n default:\n throw 'unreachable';\n }\n\n // Return the final drop target.\n return { zone, target };\n }\n\n /**\n * Get the drop reference widget for a tab bar.\n */\n export function getDropRef(tabBar: TabBar): Widget | null {\n if (tabBar.titles.length === 0) {\n return null;\n }\n if (tabBar.currentTitle) {\n return tabBar.currentTitle.owner;\n }\n return tabBar.titles[tabBar.titles.length - 1].owner;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { AttachedProperty } from '@lumino/properties';\n\nimport { BoxEngine, BoxSizer } from './boxengine';\n\nimport { Layout, LayoutItem } from './layout';\n\nimport { Widget } from './widget';\n\n/**\n * A layout which arranges its widgets in a grid.\n */\nexport class GridLayout extends Layout {\n /**\n * Construct a new grid layout.\n *\n * @param options - The options for initializing the layout.\n */\n constructor(options: GridLayout.IOptions = {}) {\n super(options);\n if (options.rowCount !== undefined) {\n Private.reallocSizers(this._rowSizers, options.rowCount);\n }\n if (options.columnCount !== undefined) {\n Private.reallocSizers(this._columnSizers, options.columnCount);\n }\n if (options.rowSpacing !== undefined) {\n this._rowSpacing = Private.clampValue(options.rowSpacing);\n }\n if (options.columnSpacing !== undefined) {\n this._columnSpacing = Private.clampValue(options.columnSpacing);\n }\n }\n\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n // Dispose of the widgets and layout items.\n for (const item of this._items) {\n let widget = item.widget;\n item.dispose();\n widget.dispose();\n }\n\n // Clear the layout state.\n this._box = null;\n this._items.length = 0;\n this._rowStarts.length = 0;\n this._rowSizers.length = 0;\n this._columnStarts.length = 0;\n this._columnSizers.length = 0;\n\n // Dispose of the rest of the layout.\n super.dispose();\n }\n\n /**\n * Get the number of rows in the layout.\n */\n get rowCount(): number {\n return this._rowSizers.length;\n }\n\n /**\n * Set the number of rows in the layout.\n *\n * #### Notes\n * The minimum row count is `1`.\n */\n set rowCount(value: number) {\n // Do nothing if the row count does not change.\n if (value === this.rowCount) {\n return;\n }\n\n // Reallocate the row sizers.\n Private.reallocSizers(this._rowSizers, value);\n\n // Schedule a fit of the parent.\n if (this.parent) {\n this.parent.fit();\n }\n }\n\n /**\n * Get the number of columns in the layout.\n */\n get columnCount(): number {\n return this._columnSizers.length;\n }\n\n /**\n * Set the number of columns in the layout.\n *\n * #### Notes\n * The minimum column count is `1`.\n */\n set columnCount(value: number) {\n // Do nothing if the column count does not change.\n if (value === this.columnCount) {\n return;\n }\n\n // Reallocate the column sizers.\n Private.reallocSizers(this._columnSizers, value);\n\n // Schedule a fit of the parent.\n if (this.parent) {\n this.parent.fit();\n }\n }\n\n /**\n * Get the row spacing for the layout.\n */\n get rowSpacing(): number {\n return this._rowSpacing;\n }\n\n /**\n * Set the row spacing for the layout.\n */\n set rowSpacing(value: number) {\n // Clamp the spacing to the allowed range.\n value = Private.clampValue(value);\n\n // Bail if the spacing does not change\n if (this._rowSpacing === value) {\n return;\n }\n\n // Update the internal spacing.\n this._rowSpacing = value;\n\n // Schedule a fit of the parent.\n if (this.parent) {\n this.parent.fit();\n }\n }\n\n /**\n * Get the column spacing for the layout.\n */\n get columnSpacing(): number {\n return this._columnSpacing;\n }\n\n /**\n * Set the col spacing for the layout.\n */\n set columnSpacing(value: number) {\n // Clamp the spacing to the allowed range.\n value = Private.clampValue(value);\n\n // Bail if the spacing does not change\n if (this._columnSpacing === value) {\n return;\n }\n\n // Update the internal spacing.\n this._columnSpacing = value;\n\n // Schedule a fit of the parent.\n if (this.parent) {\n this.parent.fit();\n }\n }\n\n /**\n * Get the stretch factor for a specific row.\n *\n * @param index - The row index of interest.\n *\n * @returns The stretch factor for the row.\n *\n * #### Notes\n * This returns `-1` if the index is out of range.\n */\n rowStretch(index: number): number {\n let sizer = this._rowSizers[index];\n return sizer ? sizer.stretch : -1;\n }\n\n /**\n * Set the stretch factor for a specific row.\n *\n * @param index - The row index of interest.\n *\n * @param value - The stretch factor for the row.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n setRowStretch(index: number, value: number): void {\n // Look up the row sizer.\n let sizer = this._rowSizers[index];\n\n // Bail if the index is out of range.\n if (!sizer) {\n return;\n }\n\n // Clamp the value to the allowed range.\n value = Private.clampValue(value);\n\n // Bail if the stretch does not change.\n if (sizer.stretch === value) {\n return;\n }\n\n // Update the sizer stretch.\n sizer.stretch = value;\n\n // Schedule an update of the parent.\n if (this.parent) {\n this.parent.update();\n }\n }\n\n /**\n * Get the stretch factor for a specific column.\n *\n * @param index - The column index of interest.\n *\n * @returns The stretch factor for the column.\n *\n * #### Notes\n * This returns `-1` if the index is out of range.\n */\n columnStretch(index: number): number {\n let sizer = this._columnSizers[index];\n return sizer ? sizer.stretch : -1;\n }\n\n /**\n * Set the stretch factor for a specific column.\n *\n * @param index - The column index of interest.\n *\n * @param value - The stretch factor for the column.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n setColumnStretch(index: number, value: number): void {\n // Look up the column sizer.\n let sizer = this._columnSizers[index];\n\n // Bail if the index is out of range.\n if (!sizer) {\n return;\n }\n\n // Clamp the value to the allowed range.\n value = Private.clampValue(value);\n\n // Bail if the stretch does not change.\n if (sizer.stretch === value) {\n return;\n }\n\n // Update the sizer stretch.\n sizer.stretch = value;\n\n // Schedule an update of the parent.\n if (this.parent) {\n this.parent.update();\n }\n }\n\n /**\n * Create an iterator over the widgets in the layout.\n *\n * @returns A new iterator over the widgets in the layout.\n */\n *[Symbol.iterator](): IterableIterator {\n for (const item of this._items) {\n yield item.widget;\n }\n }\n\n /**\n * Add a widget to the grid layout.\n *\n * @param widget - The widget to add to the layout.\n *\n * #### Notes\n * If the widget is already contained in the layout, this is no-op.\n */\n addWidget(widget: Widget): void {\n // Look up the index for the widget.\n let i = ArrayExt.findFirstIndex(this._items, it => it.widget === widget);\n\n // Bail if the widget is already in the layout.\n if (i !== -1) {\n return;\n }\n\n // Add the widget to the layout.\n this._items.push(new LayoutItem(widget));\n\n // Attach the widget to the parent.\n if (this.parent) {\n this.attachWidget(widget);\n }\n }\n\n /**\n * Remove a widget from the grid layout.\n *\n * @param widget - The widget to remove from the layout.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method does *not* modify the widget's `parent`.\n */\n removeWidget(widget: Widget): void {\n // Look up the index for the widget.\n let i = ArrayExt.findFirstIndex(this._items, it => it.widget === widget);\n\n // Bail if the widget is not in the layout.\n if (i === -1) {\n return;\n }\n\n // Remove the widget from the layout.\n let item = ArrayExt.removeAt(this._items, i)!;\n\n // Detach the widget from the parent.\n if (this.parent) {\n this.detachWidget(widget);\n }\n\n // Dispose the layout item.\n item.dispose();\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n super.init();\n for (const widget of this) {\n this.attachWidget(widget);\n }\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param widget - The widget to attach to the parent.\n */\n protected attachWidget(widget: Widget): void {\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget's node to the parent.\n this.parent!.node.appendChild(widget.node);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param widget - The widget to detach from the parent.\n */\n protected detachWidget(widget: Widget): void {\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n */\n protected onBeforeShow(msg: Message): void {\n super.onBeforeShow(msg);\n this.parent!.update();\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n super.onBeforeAttach(msg);\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n if (this.parent!.isVisible) {\n this._update(msg.width, msg.height);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.parent!.isVisible) {\n this._update(-1, -1);\n }\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n */\n protected onFitRequest(msg: Message): void {\n if (this.parent!.isAttached) {\n this._fit();\n }\n }\n\n /**\n * Fit the layout to the total size required by the widgets.\n */\n private _fit(): void {\n // Reset the min sizes of the sizers.\n for (let i = 0, n = this.rowCount; i < n; ++i) {\n this._rowSizers[i].minSize = 0;\n }\n for (let i = 0, n = this.columnCount; i < n; ++i) {\n this._columnSizers[i].minSize = 0;\n }\n\n // Filter for the visible layout items.\n let items = this._items.filter(it => !it.isHidden);\n\n // Fit the layout items.\n for (let i = 0, n = items.length; i < n; ++i) {\n items[i].fit();\n }\n\n // Get the max row and column index.\n let maxRow = this.rowCount - 1;\n let maxCol = this.columnCount - 1;\n\n // Sort the items by row span.\n items.sort(Private.rowSpanCmp);\n\n // Update the min sizes of the row sizers.\n for (let i = 0, n = items.length; i < n; ++i) {\n // Fetch the item.\n let item = items[i];\n\n // Get the row bounds for the item.\n let config = GridLayout.getCellConfig(item.widget);\n let r1 = Math.min(config.row, maxRow);\n let r2 = Math.min(config.row + config.rowSpan - 1, maxRow);\n\n // Distribute the minimum height to the sizers as needed.\n Private.distributeMin(this._rowSizers, r1, r2, item.minHeight);\n }\n\n // Sort the items by column span.\n items.sort(Private.columnSpanCmp);\n\n // Update the min sizes of the column sizers.\n for (let i = 0, n = items.length; i < n; ++i) {\n // Fetch the item.\n let item = items[i];\n\n // Get the column bounds for the item.\n let config = GridLayout.getCellConfig(item.widget);\n let c1 = Math.min(config.column, maxCol);\n let c2 = Math.min(config.column + config.columnSpan - 1, maxCol);\n\n // Distribute the minimum width to the sizers as needed.\n Private.distributeMin(this._columnSizers, c1, c2, item.minWidth);\n }\n\n // If no size constraint is needed, just update the parent.\n if (this.fitPolicy === 'set-no-constraint') {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n return;\n }\n\n // Set up the computed min size.\n let minH = maxRow * this._rowSpacing;\n let minW = maxCol * this._columnSpacing;\n\n // Add the sizer minimums to the computed min size.\n for (let i = 0, n = this.rowCount; i < n; ++i) {\n minH += this._rowSizers[i].minSize;\n }\n for (let i = 0, n = this.columnCount; i < n; ++i) {\n minW += this._columnSizers[i].minSize;\n }\n\n // Update the box sizing and add it to the computed min size.\n let box = (this._box = ElementExt.boxSizing(this.parent!.node));\n minW += box.horizontalSum;\n minH += box.verticalSum;\n\n // Update the parent's min size constraints.\n let style = this.parent!.node.style;\n style.minWidth = `${minW}px`;\n style.minHeight = `${minH}px`;\n\n // Set the dirty flag to ensure only a single update occurs.\n this._dirty = true;\n\n // Notify the ancestor that it should fit immediately. This may\n // cause a resize of the parent, fulfilling the required update.\n if (this.parent!.parent) {\n MessageLoop.sendMessage(this.parent!.parent!, Widget.Msg.FitRequest);\n }\n\n // If the dirty flag is still set, the parent was not resized.\n // Trigger the required update on the parent widget immediately.\n if (this._dirty) {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n }\n }\n\n /**\n * Update the layout position and size of the widgets.\n *\n * The parent offset dimensions should be `-1` if unknown.\n */\n private _update(offsetWidth: number, offsetHeight: number): void {\n // Clear the dirty flag to indicate the update occurred.\n this._dirty = false;\n\n // Measure the parent if the offset dimensions are unknown.\n if (offsetWidth < 0) {\n offsetWidth = this.parent!.node.offsetWidth;\n }\n if (offsetHeight < 0) {\n offsetHeight = this.parent!.node.offsetHeight;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent!.node);\n }\n\n // Compute the layout area adjusted for border and padding.\n let top = this._box.paddingTop;\n let left = this._box.paddingLeft;\n let width = offsetWidth - this._box.horizontalSum;\n let height = offsetHeight - this._box.verticalSum;\n\n // Get the max row and column index.\n let maxRow = this.rowCount - 1;\n let maxCol = this.columnCount - 1;\n\n // Compute the total fixed row and column space.\n let fixedRowSpace = maxRow * this._rowSpacing;\n let fixedColSpace = maxCol * this._columnSpacing;\n\n // Distribute the available space to the box sizers.\n BoxEngine.calc(this._rowSizers, Math.max(0, height - fixedRowSpace));\n BoxEngine.calc(this._columnSizers, Math.max(0, width - fixedColSpace));\n\n // Update the row start positions.\n for (let i = 0, pos = top, n = this.rowCount; i < n; ++i) {\n this._rowStarts[i] = pos;\n pos += this._rowSizers[i].size + this._rowSpacing;\n }\n\n // Update the column start positions.\n for (let i = 0, pos = left, n = this.columnCount; i < n; ++i) {\n this._columnStarts[i] = pos;\n pos += this._columnSizers[i].size + this._columnSpacing;\n }\n\n // Update the geometry of the layout items.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item.\n let item = this._items[i];\n\n // Ignore hidden items.\n if (item.isHidden) {\n continue;\n }\n\n // Fetch the cell bounds for the widget.\n let config = GridLayout.getCellConfig(item.widget);\n let r1 = Math.min(config.row, maxRow);\n let c1 = Math.min(config.column, maxCol);\n let r2 = Math.min(config.row + config.rowSpan - 1, maxRow);\n let c2 = Math.min(config.column + config.columnSpan - 1, maxCol);\n\n // Compute the cell geometry.\n let x = this._columnStarts[c1];\n let y = this._rowStarts[r1];\n let w = this._columnStarts[c2] + this._columnSizers[c2].size - x;\n let h = this._rowStarts[r2] + this._rowSizers[r2].size - y;\n\n // Update the geometry of the layout item.\n item.update(x, y, w, h);\n }\n }\n\n private _dirty = false;\n private _rowSpacing = 4;\n private _columnSpacing = 4;\n private _items: LayoutItem[] = [];\n private _rowStarts: number[] = [];\n private _columnStarts: number[] = [];\n private _rowSizers: BoxSizer[] = [new BoxSizer()];\n private _columnSizers: BoxSizer[] = [new BoxSizer()];\n private _box: ElementExt.IBoxSizing | null = null;\n}\n\n/**\n * The namespace for the `GridLayout` class statics.\n */\nexport namespace GridLayout {\n /**\n * An options object for initializing a grid layout.\n */\n export interface IOptions extends Layout.IOptions {\n /**\n * The initial row count for the layout.\n *\n * The default is `1`.\n */\n rowCount?: number;\n\n /**\n * The initial column count for the layout.\n *\n * The default is `1`.\n */\n columnCount?: number;\n\n /**\n * The spacing between rows in the layout.\n *\n * The default is `4`.\n */\n rowSpacing?: number;\n\n /**\n * The spacing between columns in the layout.\n *\n * The default is `4`.\n */\n columnSpacing?: number;\n }\n\n /**\n * An object which holds the cell configuration for a widget.\n */\n export interface ICellConfig {\n /**\n * The row index for the widget.\n */\n readonly row: number;\n\n /**\n * The column index for the widget.\n */\n readonly column: number;\n\n /**\n * The row span for the widget.\n */\n readonly rowSpan: number;\n\n /**\n * The column span for the widget.\n */\n readonly columnSpan: number;\n }\n\n /**\n * Get the cell config for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns The cell config for the widget.\n */\n export function getCellConfig(widget: Widget): ICellConfig {\n return Private.cellConfigProperty.get(widget);\n }\n\n /**\n * Set the cell config for the given widget.\n *\n * @param widget - The widget of interest.\n *\n * @param value - The value for the cell config.\n */\n export function setCellConfig(\n widget: Widget,\n value: Partial\n ): void {\n Private.cellConfigProperty.set(widget, Private.normalizeConfig(value));\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * The property descriptor for the widget cell config.\n */\n export const cellConfigProperty = new AttachedProperty<\n Widget,\n GridLayout.ICellConfig\n >({\n name: 'cellConfig',\n create: () => ({ row: 0, column: 0, rowSpan: 1, columnSpan: 1 }),\n changed: onChildCellConfigChanged\n });\n\n /**\n * Normalize a partial cell config object.\n */\n export function normalizeConfig(\n config: Partial\n ): GridLayout.ICellConfig {\n let row = Math.max(0, Math.floor(config.row || 0));\n let column = Math.max(0, Math.floor(config.column || 0));\n let rowSpan = Math.max(1, Math.floor(config.rowSpan || 0));\n let columnSpan = Math.max(1, Math.floor(config.columnSpan || 0));\n return { row, column, rowSpan, columnSpan };\n }\n\n /**\n * Clamp a value to an integer >= 0.\n */\n export function clampValue(value: number): number {\n return Math.max(0, Math.floor(value));\n }\n\n /**\n * A sort comparison function for row spans.\n */\n export function rowSpanCmp(a: LayoutItem, b: LayoutItem): number {\n let c1 = cellConfigProperty.get(a.widget);\n let c2 = cellConfigProperty.get(b.widget);\n return c1.rowSpan - c2.rowSpan;\n }\n\n /**\n * A sort comparison function for column spans.\n */\n export function columnSpanCmp(a: LayoutItem, b: LayoutItem): number {\n let c1 = cellConfigProperty.get(a.widget);\n let c2 = cellConfigProperty.get(b.widget);\n return c1.columnSpan - c2.columnSpan;\n }\n\n /**\n * Reallocate the box sizers for the given grid dimensions.\n */\n export function reallocSizers(sizers: BoxSizer[], count: number): void {\n // Coerce the count to the valid range.\n count = Math.max(1, Math.floor(count));\n\n // Add the missing sizers.\n while (sizers.length < count) {\n sizers.push(new BoxSizer());\n }\n\n // Remove the extra sizers.\n if (sizers.length > count) {\n sizers.length = count;\n }\n }\n\n /**\n * Distribute a min size constraint across a range of sizers.\n */\n export function distributeMin(\n sizers: BoxSizer[],\n i1: number,\n i2: number,\n minSize: number\n ): void {\n // Sanity check the indices.\n if (i2 < i1) {\n return;\n }\n\n // Handle the simple case of no cell span.\n if (i1 === i2) {\n let sizer = sizers[i1];\n sizer.minSize = Math.max(sizer.minSize, minSize);\n return;\n }\n\n // Compute the total current min size of the span.\n let totalMin = 0;\n for (let i = i1; i <= i2; ++i) {\n totalMin += sizers[i].minSize;\n }\n\n // Do nothing if the total is greater than the required.\n if (totalMin >= minSize) {\n return;\n }\n\n // Compute the portion of the space to allocate to each sizer.\n let portion = (minSize - totalMin) / (i2 - i1 + 1);\n\n // Add the portion to each sizer.\n for (let i = i1; i <= i2; ++i) {\n sizers[i].minSize += portion;\n }\n }\n\n /**\n * The change handler for the child cell config property.\n */\n function onChildCellConfigChanged(child: Widget): void {\n if (child.parent && child.parent.layout instanceof GridLayout) {\n child.parent.fit();\n }\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { getKeyboardLayout } from '@lumino/keyboard';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { CommandRegistry } from '@lumino/commands';\n\nimport {\n ElementARIAAttrs,\n ElementDataset,\n h,\n VirtualDOM,\n VirtualElement\n} from '@lumino/virtualdom';\n\nimport { Menu } from './menu';\n\nimport { Title } from './title';\n\nimport { Widget } from './widget';\n\n/**\n * A widget which displays menus as a canonical menu bar.\n */\nexport class MenuBar extends Widget {\n /**\n * Construct a new menu bar.\n *\n * @param options - The options for initializing the menu bar.\n */\n constructor(options: MenuBar.IOptions = {}) {\n super({ node: Private.createNode() });\n this.addClass('lm-MenuBar');\n this.setFlag(Widget.Flag.DisallowLayout);\n this.renderer = options.renderer || MenuBar.defaultRenderer;\n this._forceItemsPosition = options.forceItemsPosition || {\n forceX: true,\n forceY: true\n };\n this._overflowMenuOptions = options.overflowMenuOptions || {\n isVisible: true\n };\n }\n\n /**\n * Dispose of the resources held by the widget.\n */\n dispose(): void {\n this._closeChildMenu();\n this._menus.length = 0;\n super.dispose();\n }\n\n /**\n * The renderer used by the menu bar.\n */\n readonly renderer: MenuBar.IRenderer;\n\n /**\n * The child menu of the menu bar.\n *\n * #### Notes\n * This will be `null` if the menu bar does not have an open menu.\n */\n get childMenu(): Menu | null {\n return this._childMenu;\n }\n\n /**\n * The overflow index of the menu bar.\n */\n get overflowIndex(): number {\n return this._overflowIndex;\n }\n\n /**\n * The overflow menu of the menu bar.\n */\n get overflowMenu(): Menu | null {\n return this._overflowMenu;\n }\n\n /**\n * Get the menu bar content node.\n *\n * #### Notes\n * This is the node which holds the menu title nodes.\n *\n * Modifying this node directly can lead to undefined behavior.\n */\n get contentNode(): HTMLUListElement {\n return this.node.getElementsByClassName(\n 'lm-MenuBar-content'\n )[0] as HTMLUListElement;\n }\n\n /**\n * Get the currently active menu.\n */\n get activeMenu(): Menu | null {\n return this._menus[this._activeIndex] || null;\n }\n\n /**\n * Set the currently active menu.\n *\n * #### Notes\n * If the menu does not exist, the menu will be set to `null`.\n */\n set activeMenu(value: Menu | null) {\n this.activeIndex = value ? this._menus.indexOf(value) : -1;\n }\n\n /**\n * Get the index of the currently active menu.\n *\n * #### Notes\n * This will be `-1` if no menu is active.\n */\n get activeIndex(): number {\n return this._activeIndex;\n }\n\n /**\n * Set the index of the currently active menu.\n *\n * #### Notes\n * If the menu cannot be activated, the index will be set to `-1`.\n */\n set activeIndex(value: number) {\n // Adjust the value for an out of range index.\n if (value < 0 || value >= this._menus.length) {\n value = -1;\n }\n\n // Bail early if the index will not change.\n if (this._activeIndex === value) {\n return;\n }\n\n // Update the active index.\n this._activeIndex = value;\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * A read-only array of the menus in the menu bar.\n */\n get menus(): ReadonlyArray {\n return this._menus;\n }\n\n /**\n * Open the active menu and activate its first menu item.\n *\n * #### Notes\n * If there is no active menu, this is a no-op.\n */\n openActiveMenu(): void {\n // Bail early if there is no active item.\n if (this._activeIndex === -1) {\n return;\n }\n\n // Open the child menu.\n this._openChildMenu();\n\n // Activate the first item in the child menu.\n if (this._childMenu) {\n this._childMenu.activeIndex = -1;\n this._childMenu.activateNextItem();\n }\n }\n\n /**\n * Add a menu to the end of the menu bar.\n *\n * @param menu - The menu to add to the menu bar.\n *\n * #### Notes\n * If the menu is already added to the menu bar, it will be moved.\n */\n addMenu(menu: Menu, update: boolean = true): void {\n this.insertMenu(this._menus.length, menu, update);\n }\n\n /**\n * Insert a menu into the menu bar at the specified index.\n *\n * @param index - The index at which to insert the menu.\n *\n * @param menu - The menu to insert into the menu bar.\n *\n * #### Notes\n * The index will be clamped to the bounds of the menus.\n *\n * If the menu is already added to the menu bar, it will be moved.\n */\n insertMenu(index: number, menu: Menu, update: boolean = true): void {\n // Close the child menu before making changes.\n this._closeChildMenu();\n\n // Look up the index of the menu.\n let i = this._menus.indexOf(menu);\n\n // Clamp the insert index to the array bounds.\n let j = Math.max(0, Math.min(index, this._menus.length));\n\n // If the menu is not in the array, insert it.\n if (i === -1) {\n // Insert the menu into the array.\n ArrayExt.insert(this._menus, j, menu);\n\n // Add the styling class to the menu.\n menu.addClass('lm-MenuBar-menu');\n\n // Connect to the menu signals.\n menu.aboutToClose.connect(this._onMenuAboutToClose, this);\n menu.menuRequested.connect(this._onMenuMenuRequested, this);\n menu.title.changed.connect(this._onTitleChanged, this);\n\n // Schedule an update of the items.\n if (update) {\n this.update();\n }\n\n // There is nothing more to do.\n return;\n }\n\n // Otherwise, the menu exists in the array and should be moved.\n\n // Adjust the index if the location is at the end of the array.\n if (j === this._menus.length) {\n j--;\n }\n\n // Bail if there is no effective move.\n if (i === j) {\n return;\n }\n\n // Move the menu to the new locations.\n ArrayExt.move(this._menus, i, j);\n\n // Schedule an update of the items.\n if (update) {\n this.update();\n }\n }\n\n /**\n * Remove a menu from the menu bar.\n *\n * @param menu - The menu to remove from the menu bar.\n *\n * #### Notes\n * This is a no-op if the menu is not in the menu bar.\n */\n removeMenu(menu: Menu, update: boolean = true): void {\n this.removeMenuAt(this._menus.indexOf(menu), update);\n }\n\n /**\n * Remove the menu at a given index from the menu bar.\n *\n * @param index - The index of the menu to remove.\n *\n * #### Notes\n * This is a no-op if the index is out of range.\n */\n removeMenuAt(index: number, update: boolean = true): void {\n // Close the child menu before making changes.\n this._closeChildMenu();\n\n // Remove the menu from the array.\n let menu = ArrayExt.removeAt(this._menus, index);\n\n // Bail if the index is out of range.\n if (!menu) {\n return;\n }\n\n // Disconnect from the menu signals.\n menu.aboutToClose.disconnect(this._onMenuAboutToClose, this);\n menu.menuRequested.disconnect(this._onMenuMenuRequested, this);\n menu.title.changed.disconnect(this._onTitleChanged, this);\n\n // Remove the styling class from the menu.\n menu.removeClass('lm-MenuBar-menu');\n\n // Schedule an update of the items.\n if (update) {\n this.update();\n }\n }\n\n /**\n * Remove all menus from the menu bar.\n */\n clearMenus(): void {\n // Bail if there is nothing to remove.\n if (this._menus.length === 0) {\n return;\n }\n\n // Close the child menu before making changes.\n this._closeChildMenu();\n\n // Disconnect from the menu signals and remove the styling class.\n for (let menu of this._menus) {\n menu.aboutToClose.disconnect(this._onMenuAboutToClose, this);\n menu.menuRequested.disconnect(this._onMenuMenuRequested, this);\n menu.title.changed.disconnect(this._onTitleChanged, this);\n menu.removeClass('lm-MenuBar-menu');\n }\n\n // Clear the menus array.\n this._menus.length = 0;\n\n // Schedule an update of the items.\n this.update();\n }\n\n /**\n * Handle the DOM events for the menu bar.\n *\n * @param event - The DOM event sent to the menu bar.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the menu bar's DOM nodes. It\n * should not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'mousedown':\n this._evtMouseDown(event as MouseEvent);\n break;\n case 'mousemove':\n this._evtMouseMove(event as MouseEvent);\n break;\n case 'focusout':\n this._evtFocusOut(event as FocusEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('keydown', this);\n this.node.addEventListener('mousedown', this);\n this.node.addEventListener('mousemove', this);\n this.node.addEventListener('focusout', this);\n this.node.addEventListener('contextmenu', this);\n }\n\n /**\n * A message handler invoked on an `'after-detach'` message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('keydown', this);\n this.node.removeEventListener('mousedown', this);\n this.node.removeEventListener('mousemove', this);\n this.node.removeEventListener('focusout', this);\n this.node.removeEventListener('contextmenu', this);\n this._closeChildMenu();\n }\n\n /**\n * A message handler invoked on an `'activate-request'` message.\n */\n protected onActivateRequest(msg: Message): void {\n if (this.isAttached) {\n this._focusItemAt(0);\n }\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n this.update();\n super.onResize(msg);\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n let menus = this._menus;\n let renderer = this.renderer;\n let activeIndex = this._activeIndex;\n let tabFocusIndex =\n this._tabFocusIndex >= 0 && this._tabFocusIndex < menus.length\n ? this._tabFocusIndex\n : 0;\n let length = this._overflowIndex > -1 ? this._overflowIndex : menus.length;\n let totalMenuSize = 0;\n let isVisible = false;\n\n // Check that the overflow menu doesn't count\n length = this._overflowMenu !== null ? length - 1 : length;\n let content = new Array(length);\n\n // Render visible menus\n for (let i = 0; i < length; ++i) {\n content[i] = renderer.renderItem({\n title: menus[i].title,\n active: i === activeIndex,\n tabbable: i === tabFocusIndex,\n disabled: menus[i].items.length === 0,\n onfocus: () => {\n this._tabFocusIndex = i;\n this.activeIndex = i;\n }\n });\n // Calculate size of current menu\n totalMenuSize += this._menuItemSizes[i];\n // Check if overflow menu is already rendered\n if (menus[i].title.label === this._overflowMenuOptions.title) {\n isVisible = true;\n length--;\n }\n }\n // Render overflow menu if needed and active\n if (this._overflowMenuOptions.isVisible) {\n if (this._overflowIndex > -1 && !isVisible) {\n // Create overflow menu\n if (this._overflowMenu === null) {\n const overflowMenuTitle = this._overflowMenuOptions.title ?? '...';\n this._overflowMenu = new Menu({ commands: new CommandRegistry() });\n this._overflowMenu.title.label = overflowMenuTitle;\n this._overflowMenu.title.mnemonic = 0;\n this.addMenu(this._overflowMenu, false);\n }\n // Move menus to overflow menu\n for (let i = menus.length - 2; i >= length; i--) {\n const submenu = this.menus[i];\n submenu.title.mnemonic = 0;\n this._overflowMenu.insertItem(0, {\n type: 'submenu',\n submenu: submenu\n });\n this.removeMenu(submenu, false);\n }\n content[length] = renderer.renderItem({\n title: this._overflowMenu.title,\n active: length === activeIndex && menus[length].items.length !== 0,\n tabbable: length === tabFocusIndex,\n disabled: menus[length].items.length === 0,\n onfocus: () => {\n this._tabFocusIndex = length;\n this.activeIndex = length;\n }\n });\n length++;\n } else if (this._overflowMenu !== null) {\n // Remove submenus from overflow menu\n let overflowMenuItems = this._overflowMenu.items;\n let screenSize = this.node.offsetWidth;\n let n = this._overflowMenu.items.length;\n for (let i = 0; i < n; ++i) {\n let index = menus.length - 1 - i;\n if (screenSize - totalMenuSize > this._menuItemSizes[index]) {\n let menu = overflowMenuItems[0].submenu as Menu;\n this._overflowMenu.removeItemAt(0);\n this.insertMenu(length, menu, false);\n content[length] = renderer.renderItem({\n title: menu.title,\n active: false,\n tabbable: length === tabFocusIndex,\n disabled: menus[length].items.length === 0,\n onfocus: () => {\n this._tabFocusIndex = length;\n this.activeIndex = length;\n }\n });\n length++;\n }\n }\n if (this._overflowMenu.items.length === 0) {\n this.removeMenu(this._overflowMenu, false);\n content.pop();\n this._overflowMenu = null;\n this._overflowIndex = -1;\n }\n }\n }\n VirtualDOM.render(content, this.contentNode);\n this._updateOverflowIndex();\n }\n\n /**\n * Calculate and update the current overflow index.\n */\n private _updateOverflowIndex(): void {\n if (!this._overflowMenuOptions.isVisible) {\n return;\n }\n\n // Get elements visible in the main menu bar\n const itemMenus = this.contentNode.childNodes;\n let screenSize = this.node.offsetWidth;\n let totalMenuSize = 0;\n let index = -1;\n let n = itemMenus.length;\n\n if (this._menuItemSizes.length == 0) {\n // Check if it is the first resize and get info about menu items sizes\n for (let i = 0; i < n; i++) {\n let item = itemMenus[i] as HTMLLIElement;\n // Add sizes to array\n totalMenuSize += item.offsetWidth;\n this._menuItemSizes.push(item.offsetWidth);\n if (totalMenuSize > screenSize && index === -1) {\n index = i;\n }\n }\n } else {\n // Calculate current menu size\n for (let i = 0; i < this._menuItemSizes.length; i++) {\n totalMenuSize += this._menuItemSizes[i];\n if (totalMenuSize > screenSize) {\n index = i;\n break;\n }\n }\n }\n this._overflowIndex = index;\n }\n\n /**\n * Handle the `'keydown'` event for the menu bar.\n *\n * #### Notes\n * All keys are trapped except the tab key that is ignored.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // Fetch the key code for the event.\n let kc = event.keyCode;\n\n // Reset the active index on tab, but do not trap the tab key.\n if (kc === 9) {\n this.activeIndex = -1;\n return;\n }\n\n // A menu bar handles all other keydown events.\n event.preventDefault();\n event.stopPropagation();\n\n // Enter, Space, Up Arrow, Down Arrow\n if (kc === 13 || kc === 32 || kc === 38 || kc === 40) {\n // The active index may have changed (for example, user hovers over an\n // item with the mouse), so be sure to use the focus index.\n this.activeIndex = this._tabFocusIndex;\n if (this.activeIndex !== this._tabFocusIndex) {\n // Bail if the setter refused to set activeIndex to tabFocusIndex\n // because it means that the item at tabFocusIndex cannot be opened (for\n // example, it has an empty menu)\n return;\n }\n this.openActiveMenu();\n return;\n }\n\n // Escape\n if (kc === 27) {\n this._closeChildMenu();\n this._focusItemAt(this.activeIndex);\n return;\n }\n\n // Left or Right Arrow\n if (kc === 37 || kc === 39) {\n let direction = kc === 37 ? -1 : 1;\n let start = this._tabFocusIndex + direction;\n let n = this._menus.length;\n for (let i = 0; i < n; i++) {\n let index = (n + start + direction * i) % n;\n if (this._menus[index].items.length) {\n this._focusItemAt(index);\n return;\n }\n }\n return;\n }\n\n // Get the pressed key character.\n let key = getKeyboardLayout().keyForKeydownEvent(event);\n\n // Bail if the key is not valid.\n if (!key) {\n return;\n }\n\n // Search for the next best matching mnemonic item.\n let start = this._activeIndex + 1;\n let result = Private.findMnemonic(this._menus, key, start);\n\n // Handle the requested mnemonic based on the search results.\n // If exactly one mnemonic is matched, that menu is opened.\n // Otherwise, the next mnemonic is activated if available,\n // followed by the auto mnemonic if available.\n if (result.index !== -1 && !result.multiple) {\n this.activeIndex = result.index;\n this.openActiveMenu();\n } else if (result.index !== -1) {\n this.activeIndex = result.index;\n this._focusItemAt(this.activeIndex);\n } else if (result.auto !== -1) {\n this.activeIndex = result.auto;\n this._focusItemAt(this.activeIndex);\n }\n }\n\n /**\n * Handle the `'mousedown'` event for the menu bar.\n */\n private _evtMouseDown(event: MouseEvent): void {\n // Bail if the mouse press was not on the menu bar. This can occur\n // when the document listener is installed for an active menu bar.\n if (!ElementExt.hitTest(this.node, event.clientX, event.clientY)) {\n return;\n }\n\n // Stop the propagation of the event. Immediate propagation is\n // also stopped so that an open menu does not handle the event.\n event.stopPropagation();\n event.stopImmediatePropagation();\n\n // Check if the mouse is over one of the menu items.\n let index = ArrayExt.findFirstIndex(this.contentNode.children, node => {\n return ElementExt.hitTest(node, event.clientX, event.clientY);\n });\n\n // If the press was not on an item, close the child menu.\n if (index === -1) {\n this._closeChildMenu();\n return;\n }\n\n // If the press was not the left mouse button, do nothing further.\n if (event.button !== 0) {\n return;\n }\n\n // Otherwise, toggle the open state of the child menu.\n if (this._childMenu) {\n this._closeChildMenu();\n this.activeIndex = index;\n } else {\n // If we don't call preventDefault() here, then the item in the menu\n // bar will take focus over the menu that is being opened.\n event.preventDefault();\n const position = this._positionForMenu(index);\n Menu.saveWindowData();\n // Begin DOM modifications.\n this.activeIndex = index;\n this._openChildMenu(position);\n }\n }\n\n /**\n * Handle the `'mousemove'` event for the menu bar.\n */\n private _evtMouseMove(event: MouseEvent): void {\n // Check if the mouse is over one of the menu items.\n let index = ArrayExt.findFirstIndex(this.contentNode.children, node => {\n return ElementExt.hitTest(node, event.clientX, event.clientY);\n });\n\n // Bail early if the active index will not change.\n if (index === this._activeIndex) {\n return;\n }\n\n // Bail early if a child menu is open and the mouse is not over\n // an item. This allows the child menu to be kept open when the\n // mouse is over the empty part of the menu bar.\n if (index === -1 && this._childMenu) {\n return;\n }\n\n // Get position for the new menu >before< updating active index.\n const position =\n index >= 0 && this._childMenu ? this._positionForMenu(index) : null;\n\n // Before any modification, update window data.\n Menu.saveWindowData();\n\n // Begin DOM modifications.\n\n // Update the active index to the hovered item.\n this.activeIndex = index;\n\n // Open the new menu if a menu is already open.\n if (position) {\n this._openChildMenu(position);\n }\n }\n\n /**\n * Find initial position for the menu based on menubar item position.\n *\n * NOTE: this should be called before updating active index to avoid\n * an additional layout and style invalidation as changing active\n * index modifies DOM.\n */\n private _positionForMenu(index: number): Private.IPosition {\n let itemNode = this.contentNode.children[index];\n let { left, bottom } = (itemNode as HTMLElement).getBoundingClientRect();\n return {\n top: bottom,\n left\n };\n }\n\n /**\n * Handle the `'focusout'` event for the menu bar.\n */\n private _evtFocusOut(event: FocusEvent): void {\n // Reset the active index if there is no open menu and the menubar is losing focus.\n if (!this._childMenu && !this.node.contains(event.relatedTarget as Node)) {\n this.activeIndex = -1;\n }\n }\n\n /**\n * Focus an item in the menu bar.\n *\n * #### Notes\n * Does not open the associated menu.\n */\n private _focusItemAt(index: number): void {\n const itemNode = this.contentNode.childNodes[index] as HTMLElement | void;\n if (itemNode) {\n itemNode.focus();\n }\n }\n\n /**\n * Open the child menu at the active index immediately.\n *\n * If a different child menu is already open, it will be closed,\n * even if there is no active menu.\n */\n private _openChildMenu(options: { left?: number; top?: number } = {}): void {\n // If there is no active menu, close the current menu.\n let newMenu = this.activeMenu;\n if (!newMenu) {\n this._closeChildMenu();\n return;\n }\n\n // Bail if there is no effective menu change.\n let oldMenu = this._childMenu;\n if (oldMenu === newMenu) {\n return;\n }\n\n // Swap the internal menu reference.\n this._childMenu = newMenu;\n\n // Close the current menu, or setup for the new menu.\n if (oldMenu) {\n oldMenu.close();\n } else {\n document.addEventListener('mousedown', this, true);\n }\n\n // Update the tab focus index and ensure the menu bar is updated.\n this._tabFocusIndex = this.activeIndex;\n MessageLoop.sendMessage(this, Widget.Msg.UpdateRequest);\n\n // Get the positioning data for the new menu.\n let { left, top } = options;\n if (typeof left === 'undefined' || typeof top === 'undefined') {\n ({ left, top } = this._positionForMenu(this._activeIndex));\n }\n // Begin DOM modifications\n\n if (!oldMenu) {\n // Continue setup for new menu\n this.addClass('lm-mod-active');\n }\n\n // Open the new menu at the computed location.\n if (newMenu.items.length > 0) {\n newMenu.open(left, top, this._forceItemsPosition);\n }\n }\n\n /**\n * Close the child menu immediately.\n *\n * This is a no-op if a child menu is not open.\n */\n private _closeChildMenu(): void {\n // Bail if no child menu is open.\n if (!this._childMenu) {\n return;\n }\n // Remove the active class from the menu bar.\n this.removeClass('lm-mod-active');\n\n // Remove the document listeners.\n document.removeEventListener('mousedown', this, true);\n\n // Clear the internal menu reference.\n let menu = this._childMenu;\n this._childMenu = null;\n\n // Close the menu.\n menu.close();\n\n // Reset the active index.\n this.activeIndex = -1;\n }\n\n /**\n * Handle the `aboutToClose` signal of a menu.\n */\n private _onMenuAboutToClose(sender: Menu): void {\n // Bail if the sender is not the child menu.\n if (sender !== this._childMenu) {\n return;\n }\n\n // Remove the active class from the menu bar.\n this.removeClass('lm-mod-active');\n\n // Remove the document listeners.\n document.removeEventListener('mousedown', this, true);\n\n // Clear the internal menu reference.\n this._childMenu = null;\n\n // Reset the active index.\n this.activeIndex = -1;\n }\n\n /**\n * Handle the `menuRequested` signal of a child menu.\n */\n private _onMenuMenuRequested(sender: Menu, args: 'next' | 'previous'): void {\n // Bail if the sender is not the child menu.\n if (sender !== this._childMenu) {\n return;\n }\n\n // Look up the active index and menu count.\n let i = this._activeIndex;\n let n = this._menus.length;\n\n // Active the next requested index.\n switch (args) {\n case 'next':\n this.activeIndex = i === n - 1 ? 0 : i + 1;\n break;\n case 'previous':\n this.activeIndex = i === 0 ? n - 1 : i - 1;\n break;\n }\n\n // Open the active menu.\n this.openActiveMenu();\n }\n\n /**\n * Handle the `changed` signal of a title object.\n */\n private _onTitleChanged(): void {\n this.update();\n }\n\n // Track the index of the item that is currently focused or hovered. -1 means nothing focused or hovered.\n private _activeIndex = -1;\n // Track which item can be focused using the TAB key. Unlike _activeIndex will\n // always point to a menuitem. Whenever you update this value, it's important\n // to follow it with an \"update-request\" message so that the `tabindex`\n // attribute on each menubar item gets properly updated.\n private _tabFocusIndex = 0;\n private _forceItemsPosition: Menu.IOpenOptions;\n private _overflowMenuOptions: IOverflowMenuOptions;\n private _menus: Menu[] = [];\n private _childMenu: Menu | null = null;\n private _overflowMenu: Menu | null = null;\n private _menuItemSizes: number[] = [];\n private _overflowIndex: number = -1;\n}\n\n/**\n * The namespace for the `MenuBar` class statics.\n */\nexport namespace MenuBar {\n /**\n * An options object for creating a menu bar.\n */\n export interface IOptions {\n /**\n * A custom renderer for creating menu bar content.\n *\n * The default is a shared renderer instance.\n */\n renderer?: IRenderer;\n /**\n * Whether to force the position of the menu. The MenuBar forces the\n * coordinates of its menus by default. With this option you can disable it.\n *\n * Setting to `false` will enable the logic which repositions the\n * coordinates of the menu if it will not fit entirely on screen.\n *\n * The default is `true`.\n */\n forceItemsPosition?: Menu.IOpenOptions;\n /**\n * Whether to add a overflow menu if there's overflow.\n *\n * Setting to `true` will enable the logic that creates an overflow menu\n * to show the menu items that don't fit entirely on the screen.\n *\n * The default is `true`.\n */\n overflowMenuOptions?: IOverflowMenuOptions;\n }\n\n /**\n * An object which holds the data to render a menu bar item.\n */\n export interface IRenderData {\n /**\n * The title to be rendered.\n */\n readonly title: Title;\n\n /**\n * Whether the item is the active item.\n */\n readonly active: boolean;\n\n /**\n * Whether the user can tab to the item.\n */\n readonly tabbable: boolean;\n\n /**\n * Whether the item is disabled.\n *\n * #### Notes\n * A disabled item cannot be active.\n * A disabled item cannot be focussed.\n */\n readonly disabled?: boolean;\n\n readonly onfocus?: (event: FocusEvent) => void;\n }\n\n /**\n * A renderer for use with a menu bar.\n */\n export interface IRenderer {\n /**\n * Render the virtual element for a menu bar item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n */\n renderItem(data: IRenderData): VirtualElement;\n }\n\n /**\n * The default implementation of `IRenderer`.\n *\n * #### Notes\n * Subclasses are free to reimplement rendering methods as needed.\n */\n export class Renderer implements IRenderer {\n /**\n * Render the virtual element for a menu bar item.\n *\n * @param data - The data to use for rendering the item.\n *\n * @returns A virtual element representing the item.\n */\n renderItem(data: IRenderData): VirtualElement {\n let className = this.createItemClass(data);\n let dataset = this.createItemDataset(data);\n let aria = this.createItemARIA(data);\n return h.li(\n {\n className,\n dataset,\n ...(data.disabled ? {} : { tabindex: data.tabbable ? '0' : '-1' }),\n onfocus: data.onfocus,\n ...aria\n },\n this.renderIcon(data),\n this.renderLabel(data)\n );\n }\n\n /**\n * Render the icon element for a menu bar item.\n *\n * @param data - The data to use for rendering the icon.\n *\n * @returns A virtual element representing the item icon.\n */\n renderIcon(data: IRenderData): VirtualElement {\n let className = this.createIconClass(data);\n\n // If data.title.icon is undefined, it will be ignored.\n return h.div({ className }, data.title.icon!, data.title.iconLabel);\n }\n\n /**\n * Render the label element for a menu item.\n *\n * @param data - The data to use for rendering the label.\n *\n * @returns A virtual element representing the item label.\n */\n renderLabel(data: IRenderData): VirtualElement {\n let content = this.formatLabel(data);\n return h.div({ className: 'lm-MenuBar-itemLabel' }, content);\n }\n\n /**\n * Create the class name for the menu bar item.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the menu item.\n */\n createItemClass(data: IRenderData): string {\n let name = 'lm-MenuBar-item';\n if (data.title.className) {\n name += ` ${data.title.className}`;\n }\n if (data.active && !data.disabled) {\n name += ' lm-mod-active';\n }\n return name;\n }\n\n /**\n * Create the dataset for a menu bar item.\n *\n * @param data - The data to use for the item.\n *\n * @returns The dataset for the menu bar item.\n */\n createItemDataset(data: IRenderData): ElementDataset {\n return data.title.dataset;\n }\n\n /**\n * Create the aria attributes for menu bar item.\n *\n * @param data - The data to use for the aria attributes.\n *\n * @returns The aria attributes object for the item.\n */\n createItemARIA(data: IRenderData): ElementARIAAttrs {\n return {\n role: 'menuitem',\n 'aria-haspopup': 'true',\n 'aria-disabled': data.disabled ? 'true' : 'false'\n };\n }\n\n /**\n * Create the class name for the menu bar item icon.\n *\n * @param data - The data to use for the class name.\n *\n * @returns The full class name for the item icon.\n */\n createIconClass(data: IRenderData): string {\n let name = 'lm-MenuBar-itemIcon';\n let extra = data.title.iconClass;\n return extra ? `${name} ${extra}` : name;\n }\n\n /**\n * Create the render content for the label node.\n *\n * @param data - The data to use for the label content.\n *\n * @returns The content to add to the label node.\n */\n formatLabel(data: IRenderData): h.Child {\n // Fetch the label text and mnemonic index.\n let { label, mnemonic } = data.title;\n\n // If the index is out of range, do not modify the label.\n if (mnemonic < 0 || mnemonic >= label.length) {\n return label;\n }\n\n // Split the label into parts.\n let prefix = label.slice(0, mnemonic);\n let suffix = label.slice(mnemonic + 1);\n let char = label[mnemonic];\n\n // Wrap the mnemonic character in a span.\n let span = h.span({ className: 'lm-MenuBar-itemMnemonic' }, char);\n\n // Return the content parts.\n return [prefix, span, suffix];\n }\n }\n\n /**\n * The default `Renderer` instance.\n */\n export const defaultRenderer = new Renderer();\n}\n\n/**\n * Options for overflow menu.\n */\nexport interface IOverflowMenuOptions {\n /**\n * Determines if a overflow menu appears when the menu items overflow.\n *\n * Defaults to `true`.\n */\n isVisible: boolean;\n /**\n * Determines the title of the overflow menu.\n *\n * Default: `...`.\n */\n title?: string;\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Create the DOM node for a menu bar.\n */\n export function createNode(): HTMLDivElement {\n let node = document.createElement('div');\n let content = document.createElement('ul');\n content.className = 'lm-MenuBar-content';\n node.appendChild(content);\n content.setAttribute('role', 'menubar');\n return node;\n }\n\n /**\n * Position for the menu relative to top-left screen corner.\n */\n export interface IPosition {\n /**\n * Pixels right from screen origin.\n */\n left: number;\n /**\n * Pixels down from screen origin.\n */\n top: number;\n }\n\n /**\n * The results of a mnemonic search.\n */\n export interface IMnemonicResult {\n /**\n * The index of the first matching mnemonic item, or `-1`.\n */\n index: number;\n\n /**\n * Whether multiple mnemonic items matched.\n */\n multiple: boolean;\n\n /**\n * The index of the first auto matched non-mnemonic item.\n */\n auto: number;\n }\n\n /**\n * Find the best matching mnemonic item.\n *\n * The search starts at the given index and wraps around.\n */\n export function findMnemonic(\n menus: ReadonlyArray,\n key: string,\n start: number\n ): IMnemonicResult {\n // Setup the result variables.\n let index = -1;\n let auto = -1;\n let multiple = false;\n\n // Normalize the key to upper case.\n let upperKey = key.toUpperCase();\n\n // Search the items from the given start index.\n for (let i = 0, n = menus.length; i < n; ++i) {\n // Compute the wrapped index.\n let k = (i + start) % n;\n\n // Look up the menu title.\n let title = menus[k].title;\n\n // Ignore titles with an empty label.\n if (title.label.length === 0) {\n continue;\n }\n\n // Look up the mnemonic index for the label.\n let mn = title.mnemonic;\n\n // Handle a valid mnemonic index.\n if (mn >= 0 && mn < title.label.length) {\n if (title.label[mn].toUpperCase() === upperKey) {\n if (index === -1) {\n index = k;\n } else {\n multiple = true;\n }\n }\n continue;\n }\n\n // Finally, handle the auto index if possible.\n if (auto === -1 && title.label[0].toUpperCase() === upperKey) {\n auto = k;\n }\n }\n\n // Return the search results.\n return { index, multiple, auto };\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Drag } from '@lumino/dragdrop';\n\nimport { Message } from '@lumino/messaging';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { Widget } from './widget';\n\n/**\n * A widget which implements a canonical scroll bar.\n */\nexport class ScrollBar extends Widget {\n /**\n * Construct a new scroll bar.\n *\n * @param options - The options for initializing the scroll bar.\n */\n constructor(options: ScrollBar.IOptions = {}) {\n super({ node: Private.createNode() });\n this.addClass('lm-ScrollBar');\n this.setFlag(Widget.Flag.DisallowLayout);\n\n // Set the orientation.\n this._orientation = options.orientation || 'vertical';\n this.dataset['orientation'] = this._orientation;\n\n // Parse the rest of the options.\n if (options.maximum !== undefined) {\n this._maximum = Math.max(0, options.maximum);\n }\n if (options.page !== undefined) {\n this._page = Math.max(0, options.page);\n }\n if (options.value !== undefined) {\n this._value = Math.max(0, Math.min(options.value, this._maximum));\n }\n }\n\n /**\n * A signal emitted when the user moves the scroll thumb.\n *\n * #### Notes\n * The payload is the current value of the scroll bar.\n */\n get thumbMoved(): ISignal {\n return this._thumbMoved;\n }\n\n /**\n * A signal emitted when the user clicks a step button.\n *\n * #### Notes\n * The payload is whether a decrease or increase is requested.\n */\n get stepRequested(): ISignal {\n return this._stepRequested;\n }\n\n /**\n * A signal emitted when the user clicks the scroll track.\n *\n * #### Notes\n * The payload is whether a decrease or increase is requested.\n */\n get pageRequested(): ISignal {\n return this._pageRequested;\n }\n\n /**\n * Get the orientation of the scroll bar.\n */\n get orientation(): ScrollBar.Orientation {\n return this._orientation;\n }\n\n /**\n * Set the orientation of the scroll bar.\n */\n set orientation(value: ScrollBar.Orientation) {\n // Do nothing if the orientation does not change.\n if (this._orientation === value) {\n return;\n }\n\n // Release the mouse before making changes.\n this._releaseMouse();\n\n // Update the internal orientation.\n this._orientation = value;\n this.dataset['orientation'] = value;\n\n // Schedule an update the scroll bar.\n this.update();\n }\n\n /**\n * Get the current value of the scroll bar.\n */\n get value(): number {\n return this._value;\n }\n\n /**\n * Set the current value of the scroll bar.\n *\n * #### Notes\n * The value will be clamped to the range `[0, maximum]`.\n */\n set value(value: number) {\n // Clamp the value to the allowable range.\n value = Math.max(0, Math.min(value, this._maximum));\n\n // Do nothing if the value does not change.\n if (this._value === value) {\n return;\n }\n\n // Update the internal value.\n this._value = value;\n\n // Schedule an update the scroll bar.\n this.update();\n }\n\n /**\n * Get the page size of the scroll bar.\n *\n * #### Notes\n * The page size is the amount of visible content in the scrolled\n * region, expressed in data units. It determines the size of the\n * scroll bar thumb.\n */\n get page(): number {\n return this._page;\n }\n\n /**\n * Set the page size of the scroll bar.\n *\n * #### Notes\n * The page size will be clamped to the range `[0, Infinity]`.\n */\n set page(value: number) {\n // Clamp the page size to the allowable range.\n value = Math.max(0, value);\n\n // Do nothing if the value does not change.\n if (this._page === value) {\n return;\n }\n\n // Update the internal page size.\n this._page = value;\n\n // Schedule an update the scroll bar.\n this.update();\n }\n\n /**\n * Get the maximum value of the scroll bar.\n */\n get maximum(): number {\n return this._maximum;\n }\n\n /**\n * Set the maximum value of the scroll bar.\n *\n * #### Notes\n * The max size will be clamped to the range `[0, Infinity]`.\n */\n set maximum(value: number) {\n // Clamp the value to the allowable range.\n value = Math.max(0, value);\n\n // Do nothing if the value does not change.\n if (this._maximum === value) {\n return;\n }\n\n // Update the internal values.\n this._maximum = value;\n\n // Clamp the current value to the new range.\n this._value = Math.min(this._value, value);\n\n // Schedule an update the scroll bar.\n this.update();\n }\n\n /**\n * The scroll bar decrement button node.\n *\n * #### Notes\n * Modifying this node directly can lead to undefined behavior.\n */\n get decrementNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-ScrollBar-button'\n )[0] as HTMLDivElement;\n }\n\n /**\n * The scroll bar increment button node.\n *\n * #### Notes\n * Modifying this node directly can lead to undefined behavior.\n */\n get incrementNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-ScrollBar-button'\n )[1] as HTMLDivElement;\n }\n\n /**\n * The scroll bar track node.\n *\n * #### Notes\n * Modifying this node directly can lead to undefined behavior.\n */\n get trackNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-ScrollBar-track'\n )[0] as HTMLDivElement;\n }\n\n /**\n * The scroll bar thumb node.\n *\n * #### Notes\n * Modifying this node directly can lead to undefined behavior.\n */\n get thumbNode(): HTMLDivElement {\n return this.node.getElementsByClassName(\n 'lm-ScrollBar-thumb'\n )[0] as HTMLDivElement;\n }\n\n /**\n * Handle the DOM events for the scroll bar.\n *\n * @param event - The DOM event sent to the scroll bar.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the scroll bar's DOM node.\n *\n * This should not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'mousedown':\n this._evtMouseDown(event as MouseEvent);\n break;\n case 'mousemove':\n this._evtMouseMove(event as MouseEvent);\n break;\n case 'mouseup':\n this._evtMouseUp(event as MouseEvent);\n break;\n case 'keydown':\n this._evtKeyDown(event as KeyboardEvent);\n break;\n case 'contextmenu':\n event.preventDefault();\n event.stopPropagation();\n break;\n }\n }\n\n /**\n * A method invoked on a 'before-attach' message.\n */\n protected onBeforeAttach(msg: Message): void {\n this.node.addEventListener('mousedown', this);\n this.update();\n }\n\n /**\n * A method invoked on an 'after-detach' message.\n */\n protected onAfterDetach(msg: Message): void {\n this.node.removeEventListener('mousedown', this);\n this._releaseMouse();\n }\n\n /**\n * A method invoked on an 'update-request' message.\n */\n protected onUpdateRequest(msg: Message): void {\n // Convert the value and page into percentages.\n let value = (this._value * 100) / this._maximum;\n let page = (this._page * 100) / (this._page + this._maximum);\n\n // Clamp the value and page to the relevant range.\n value = Math.max(0, Math.min(value, 100));\n page = Math.max(0, Math.min(page, 100));\n\n // Fetch the thumb style.\n let thumbStyle = this.thumbNode.style;\n\n // Update the thumb style for the current orientation.\n if (this._orientation === 'horizontal') {\n thumbStyle.top = '';\n thumbStyle.height = '';\n thumbStyle.left = `${value}%`;\n thumbStyle.width = `${page}%`;\n thumbStyle.transform = `translate(${-value}%, 0%)`;\n } else {\n thumbStyle.left = '';\n thumbStyle.width = '';\n thumbStyle.top = `${value}%`;\n thumbStyle.height = `${page}%`;\n thumbStyle.transform = `translate(0%, ${-value}%)`;\n }\n }\n\n /**\n * Handle the `'keydown'` event for the scroll bar.\n */\n private _evtKeyDown(event: KeyboardEvent): void {\n // Stop all input events during drag.\n event.preventDefault();\n event.stopPropagation();\n\n // Ignore anything except the `Escape` key.\n if (event.keyCode !== 27) {\n return;\n }\n\n // Fetch the previous scroll value.\n let value = this._pressData ? this._pressData.value : -1;\n\n // Release the mouse.\n this._releaseMouse();\n\n // Restore the old scroll value if possible.\n if (value !== -1) {\n this._moveThumb(value);\n }\n }\n\n /**\n * Handle the `'mousedown'` event for the scroll bar.\n */\n private _evtMouseDown(event: MouseEvent): void {\n // Do nothing if it's not a left mouse press.\n if (event.button !== 0) {\n return;\n }\n\n // Send an activate request to the scroll bar. This can be\n // used by message hooks to activate something relevant.\n this.activate();\n\n // Do nothing if the mouse is already captured.\n if (this._pressData) {\n return;\n }\n\n // Find the pressed scroll bar part.\n let part = Private.findPart(this, event.target as HTMLElement);\n\n // Do nothing if the part is not of interest.\n if (!part) {\n return;\n }\n\n // Stop the event propagation.\n event.preventDefault();\n event.stopPropagation();\n\n // Override the mouse cursor.\n let override = Drag.overrideCursor('default');\n\n // Set up the press data.\n this._pressData = {\n part,\n override,\n delta: -1,\n value: -1,\n mouseX: event.clientX,\n mouseY: event.clientY\n };\n\n // Add the extra event listeners.\n document.addEventListener('mousemove', this, true);\n document.addEventListener('mouseup', this, true);\n document.addEventListener('keydown', this, true);\n document.addEventListener('contextmenu', this, true);\n\n // Handle a thumb press.\n if (part === 'thumb') {\n // Fetch the thumb node.\n let thumbNode = this.thumbNode;\n\n // Fetch the client rect for the thumb.\n let thumbRect = thumbNode.getBoundingClientRect();\n\n // Update the press data delta for the current orientation.\n if (this._orientation === 'horizontal') {\n this._pressData.delta = event.clientX - thumbRect.left;\n } else {\n this._pressData.delta = event.clientY - thumbRect.top;\n }\n\n // Add the active class to the thumb node.\n thumbNode.classList.add('lm-mod-active');\n\n // Store the current value in the press data.\n this._pressData.value = this._value;\n\n // Finished.\n return;\n }\n\n // Handle a track press.\n if (part === 'track') {\n // Fetch the client rect for the thumb.\n let thumbRect = this.thumbNode.getBoundingClientRect();\n\n // Determine the direction for the page request.\n let dir: 'decrement' | 'increment';\n if (this._orientation === 'horizontal') {\n dir = event.clientX < thumbRect.left ? 'decrement' : 'increment';\n } else {\n dir = event.clientY < thumbRect.top ? 'decrement' : 'increment';\n }\n\n // Start the repeat timer.\n this._repeatTimer = window.setTimeout(this._onRepeat, 350);\n\n // Emit the page requested signal.\n this._pageRequested.emit(dir);\n\n // Finished.\n return;\n }\n\n // Handle a decrement button press.\n if (part === 'decrement') {\n // Add the active class to the decrement node.\n this.decrementNode.classList.add('lm-mod-active');\n\n // Start the repeat timer.\n this._repeatTimer = window.setTimeout(this._onRepeat, 350);\n\n // Emit the step requested signal.\n this._stepRequested.emit('decrement');\n\n // Finished.\n return;\n }\n\n // Handle an increment button press.\n if (part === 'increment') {\n // Add the active class to the increment node.\n this.incrementNode.classList.add('lm-mod-active');\n\n // Start the repeat timer.\n this._repeatTimer = window.setTimeout(this._onRepeat, 350);\n\n // Emit the step requested signal.\n this._stepRequested.emit('increment');\n\n // Finished.\n return;\n }\n }\n\n /**\n * Handle the `'mousemove'` event for the scroll bar.\n */\n private _evtMouseMove(event: MouseEvent): void {\n // Do nothing if no drag is in progress.\n if (!this._pressData) {\n return;\n }\n\n // Stop the event propagation.\n event.preventDefault();\n event.stopPropagation();\n\n // Update the mouse position.\n this._pressData.mouseX = event.clientX;\n this._pressData.mouseY = event.clientY;\n\n // Bail if the thumb is not being dragged.\n if (this._pressData.part !== 'thumb') {\n return;\n }\n\n // Get the client rect for the thumb and track.\n let thumbRect = this.thumbNode.getBoundingClientRect();\n let trackRect = this.trackNode.getBoundingClientRect();\n\n // Fetch the scroll geometry based on the orientation.\n let trackPos: number;\n let trackSpan: number;\n if (this._orientation === 'horizontal') {\n trackPos = event.clientX - trackRect.left - this._pressData.delta;\n trackSpan = trackRect.width - thumbRect.width;\n } else {\n trackPos = event.clientY - trackRect.top - this._pressData.delta;\n trackSpan = trackRect.height - thumbRect.height;\n }\n\n // Compute the desired value from the scroll geometry.\n let value = trackSpan === 0 ? 0 : (trackPos * this._maximum) / trackSpan;\n\n // Move the thumb to the computed value.\n this._moveThumb(value);\n }\n\n /**\n * Handle the `'mouseup'` event for the scroll bar.\n */\n private _evtMouseUp(event: MouseEvent): void {\n // Do nothing if it's not a left mouse release.\n if (event.button !== 0) {\n return;\n }\n\n // Stop the event propagation.\n event.preventDefault();\n event.stopPropagation();\n\n // Release the mouse.\n this._releaseMouse();\n }\n\n /**\n * Release the mouse and restore the node states.\n */\n private _releaseMouse(): void {\n // Bail if there is no press data.\n if (!this._pressData) {\n return;\n }\n\n // Clear the repeat timer.\n clearTimeout(this._repeatTimer);\n this._repeatTimer = -1;\n\n // Clear the press data.\n this._pressData.override.dispose();\n this._pressData = null;\n\n // Remove the extra event listeners.\n document.removeEventListener('mousemove', this, true);\n document.removeEventListener('mouseup', this, true);\n document.removeEventListener('keydown', this, true);\n document.removeEventListener('contextmenu', this, true);\n\n // Remove the active classes from the nodes.\n this.thumbNode.classList.remove('lm-mod-active');\n this.decrementNode.classList.remove('lm-mod-active');\n this.incrementNode.classList.remove('lm-mod-active');\n }\n\n /**\n * Move the thumb to the specified position.\n */\n private _moveThumb(value: number): void {\n // Clamp the value to the allowed range.\n value = Math.max(0, Math.min(value, this._maximum));\n\n // Bail if the value does not change.\n if (this._value === value) {\n return;\n }\n\n // Update the internal value.\n this._value = value;\n\n // Schedule an update of the scroll bar.\n this.update();\n\n // Emit the thumb moved signal.\n this._thumbMoved.emit(value);\n }\n\n /**\n * A timeout callback for repeating the mouse press.\n */\n private _onRepeat = () => {\n // Clear the repeat timer id.\n this._repeatTimer = -1;\n\n // Bail if the mouse has been released.\n if (!this._pressData) {\n return;\n }\n\n // Look up the part that was pressed.\n let part = this._pressData.part;\n\n // Bail if the thumb was pressed.\n if (part === 'thumb') {\n return;\n }\n\n // Schedule the timer for another repeat.\n this._repeatTimer = window.setTimeout(this._onRepeat, 20);\n\n // Get the current mouse position.\n let mouseX = this._pressData.mouseX;\n let mouseY = this._pressData.mouseY;\n\n // Handle a decrement button repeat.\n if (part === 'decrement') {\n // Bail if the mouse is not over the button.\n if (!ElementExt.hitTest(this.decrementNode, mouseX, mouseY)) {\n return;\n }\n\n // Emit the step requested signal.\n this._stepRequested.emit('decrement');\n\n // Finished.\n return;\n }\n\n // Handle an increment button repeat.\n if (part === 'increment') {\n // Bail if the mouse is not over the button.\n if (!ElementExt.hitTest(this.incrementNode, mouseX, mouseY)) {\n return;\n }\n\n // Emit the step requested signal.\n this._stepRequested.emit('increment');\n\n // Finished.\n return;\n }\n\n // Handle a track repeat.\n if (part === 'track') {\n // Bail if the mouse is not over the track.\n if (!ElementExt.hitTest(this.trackNode, mouseX, mouseY)) {\n return;\n }\n\n // Fetch the thumb node.\n let thumbNode = this.thumbNode;\n\n // Bail if the mouse is over the thumb.\n if (ElementExt.hitTest(thumbNode, mouseX, mouseY)) {\n return;\n }\n\n // Fetch the client rect for the thumb.\n let thumbRect = thumbNode.getBoundingClientRect();\n\n // Determine the direction for the page request.\n let dir: 'decrement' | 'increment';\n if (this._orientation === 'horizontal') {\n dir = mouseX < thumbRect.left ? 'decrement' : 'increment';\n } else {\n dir = mouseY < thumbRect.top ? 'decrement' : 'increment';\n }\n\n // Emit the page requested signal.\n this._pageRequested.emit(dir);\n\n // Finished.\n return;\n }\n };\n\n private _value = 0;\n private _page = 10;\n private _maximum = 100;\n private _repeatTimer = -1;\n private _orientation: ScrollBar.Orientation;\n private _pressData: Private.IPressData | null = null;\n private _thumbMoved = new Signal(this);\n private _stepRequested = new Signal(this);\n private _pageRequested = new Signal(this);\n}\n\n/**\n * The namespace for the `ScrollBar` class statics.\n */\nexport namespace ScrollBar {\n /**\n * A type alias for a scroll bar orientation.\n */\n export type Orientation = 'horizontal' | 'vertical';\n\n /**\n * An options object for creating a scroll bar.\n */\n export interface IOptions {\n /**\n * The orientation of the scroll bar.\n *\n * The default is `'vertical'`.\n */\n orientation?: Orientation;\n\n /**\n * The value for the scroll bar.\n *\n * The default is `0`.\n */\n value?: number;\n\n /**\n * The page size for the scroll bar.\n *\n * The default is `10`.\n */\n page?: number;\n\n /**\n * The maximum value for the scroll bar.\n *\n * The default is `100`.\n */\n maximum?: number;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * A type alias for the parts of a scroll bar.\n */\n export type ScrollBarPart = 'thumb' | 'track' | 'decrement' | 'increment';\n\n /**\n * An object which holds mouse press data.\n */\n export interface IPressData {\n /**\n * The scroll bar part which was pressed.\n */\n part: ScrollBarPart;\n\n /**\n * The offset of the press in thumb coordinates, or -1.\n */\n delta: number;\n\n /**\n * The scroll value at the time the thumb was pressed, or -1.\n */\n value: number;\n\n /**\n * The disposable which will clear the override cursor.\n */\n override: IDisposable;\n\n /**\n * The current X position of the mouse.\n */\n mouseX: number;\n\n /**\n * The current Y position of the mouse.\n */\n mouseY: number;\n }\n\n /**\n * Create the DOM node for a scroll bar.\n */\n export function createNode(): HTMLElement {\n let node = document.createElement('div');\n let decrement = document.createElement('div');\n let increment = document.createElement('div');\n let track = document.createElement('div');\n let thumb = document.createElement('div');\n decrement.className = 'lm-ScrollBar-button';\n increment.className = 'lm-ScrollBar-button';\n decrement.dataset['action'] = 'decrement';\n increment.dataset['action'] = 'increment';\n track.className = 'lm-ScrollBar-track';\n thumb.className = 'lm-ScrollBar-thumb';\n track.appendChild(thumb);\n node.appendChild(decrement);\n node.appendChild(track);\n node.appendChild(increment);\n return node;\n }\n\n /**\n * Find the scroll bar part which contains the given target.\n */\n export function findPart(\n scrollBar: ScrollBar,\n target: HTMLElement\n ): ScrollBarPart | null {\n // Test the thumb.\n if (scrollBar.thumbNode.contains(target)) {\n return 'thumb';\n }\n\n // Test the track.\n if (scrollBar.trackNode.contains(target)) {\n return 'track';\n }\n\n // Test the decrement button.\n if (scrollBar.decrementNode.contains(target)) {\n return 'decrement';\n }\n\n // Test the increment button.\n if (scrollBar.incrementNode.contains(target)) {\n return 'increment';\n }\n\n // Indicate no match.\n return null;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { Panel } from './panel';\n\nimport { StackedLayout } from './stackedlayout';\n\nimport { Widget } from './widget';\n\n/**\n * A panel where visible widgets are stacked atop one another.\n *\n * #### Notes\n * This class provides a convenience wrapper around a {@link StackedLayout}.\n */\nexport class StackedPanel extends Panel {\n /**\n * Construct a new stacked panel.\n *\n * @param options - The options for initializing the panel.\n */\n constructor(options: StackedPanel.IOptions = {}) {\n super({ layout: Private.createLayout(options) });\n this.addClass('lm-StackedPanel');\n }\n\n /**\n * The method for hiding widgets.\n *\n * #### Notes\n * If there is only one child widget, `Display` hiding mode will be used\n * regardless of this setting.\n */\n get hiddenMode(): Widget.HiddenMode {\n return (this.layout as StackedLayout).hiddenMode;\n }\n\n /**\n * Set the method for hiding widgets.\n *\n * #### Notes\n * If there is only one child widget, `Display` hiding mode will be used\n * regardless of this setting.\n */\n set hiddenMode(v: Widget.HiddenMode) {\n (this.layout as StackedLayout).hiddenMode = v;\n }\n\n /**\n * A signal emitted when a widget is removed from a stacked panel.\n */\n get widgetRemoved(): ISignal {\n return this._widgetRemoved;\n }\n\n /**\n * A message handler invoked on a `'child-added'` message.\n */\n protected onChildAdded(msg: Widget.ChildMessage): void {\n msg.child.addClass('lm-StackedPanel-child');\n }\n\n /**\n * A message handler invoked on a `'child-removed'` message.\n */\n protected onChildRemoved(msg: Widget.ChildMessage): void {\n msg.child.removeClass('lm-StackedPanel-child');\n this._widgetRemoved.emit(msg.child);\n }\n\n private _widgetRemoved = new Signal(this);\n}\n\n/**\n * The namespace for the `StackedPanel` class statics.\n */\nexport namespace StackedPanel {\n /**\n * An options object for creating a stacked panel.\n */\n export interface IOptions {\n /**\n * The stacked layout to use for the stacked panel.\n *\n * The default is a new `StackedLayout`.\n */\n layout?: StackedLayout;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Create a stacked layout for the given panel options.\n */\n export function createLayout(options: StackedPanel.IOptions): StackedLayout {\n return options.layout || new StackedLayout();\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { Platform } from '@lumino/domutils';\n\nimport { MessageLoop } from '@lumino/messaging';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { BoxLayout } from './boxlayout';\n\nimport { StackedPanel } from './stackedpanel';\n\nimport { TabBar } from './tabbar';\n\nimport { Widget } from './widget';\n\n/**\n * A widget which combines a `TabBar` and a `StackedPanel`.\n *\n * #### Notes\n * This is a simple panel which handles the common case of a tab bar\n * placed next to a content area. The selected tab controls the widget\n * which is shown in the content area.\n *\n * For use cases which require more control than is provided by this\n * panel, the `TabBar` widget may be used independently.\n */\nexport class TabPanel extends Widget {\n /**\n * Construct a new tab panel.\n *\n * @param options - The options for initializing the tab panel.\n */\n constructor(options: TabPanel.IOptions = {}) {\n super();\n this.addClass('lm-TabPanel');\n\n // Create the tab bar and stacked panel.\n this.tabBar = new TabBar(options);\n this.tabBar.addClass('lm-TabPanel-tabBar');\n this.stackedPanel = new StackedPanel();\n this.stackedPanel.addClass('lm-TabPanel-stackedPanel');\n\n // Connect the tab bar signal handlers.\n this.tabBar.tabMoved.connect(this._onTabMoved, this);\n this.tabBar.currentChanged.connect(this._onCurrentChanged, this);\n this.tabBar.tabCloseRequested.connect(this._onTabCloseRequested, this);\n this.tabBar.tabActivateRequested.connect(\n this._onTabActivateRequested,\n this\n );\n this.tabBar.addRequested.connect(this._onTabAddRequested, this);\n\n // Connect the stacked panel signal handlers.\n this.stackedPanel.widgetRemoved.connect(this._onWidgetRemoved, this);\n\n // Get the data related to the placement.\n this._tabPlacement = options.tabPlacement || 'top';\n let direction = Private.directionFromPlacement(this._tabPlacement);\n let orientation = Private.orientationFromPlacement(this._tabPlacement);\n\n // Configure the tab bar for the placement.\n this.tabBar.orientation = orientation;\n this.tabBar.dataset['placement'] = this._tabPlacement;\n\n // Create the box layout.\n let layout = new BoxLayout({ direction, spacing: 0 });\n\n // Set the stretch factors for the child widgets.\n BoxLayout.setStretch(this.tabBar, 0);\n BoxLayout.setStretch(this.stackedPanel, 1);\n\n // Add the child widgets to the layout.\n layout.addWidget(this.tabBar);\n layout.addWidget(this.stackedPanel);\n\n // Install the layout on the tab panel.\n this.layout = layout;\n }\n\n /**\n * A signal emitted when the current tab is changed.\n *\n * #### Notes\n * This signal is emitted when the currently selected tab is changed\n * either through user or programmatic interaction.\n *\n * Notably, this signal is not emitted when the index of the current\n * tab changes due to tabs being inserted, removed, or moved. It is\n * only emitted when the actual current tab node is changed.\n */\n get currentChanged(): ISignal {\n return this._currentChanged;\n }\n\n /**\n * Get the index of the currently selected tab.\n *\n * #### Notes\n * This will be `-1` if no tab is selected.\n */\n get currentIndex(): number {\n return this.tabBar.currentIndex;\n }\n\n /**\n * Set the index of the currently selected tab.\n *\n * #### Notes\n * If the index is out of range, it will be set to `-1`.\n */\n set currentIndex(value: number) {\n this.tabBar.currentIndex = value;\n }\n\n /**\n * Get the currently selected widget.\n *\n * #### Notes\n * This will be `null` if there is no selected tab.\n */\n get currentWidget(): Widget | null {\n let title = this.tabBar.currentTitle;\n return title ? title.owner : null;\n }\n\n /**\n * Set the currently selected widget.\n *\n * #### Notes\n * If the widget is not in the panel, it will be set to `null`.\n */\n set currentWidget(value: Widget | null) {\n this.tabBar.currentTitle = value ? value.title : null;\n }\n\n /**\n * Get the whether the tabs are movable by the user.\n *\n * #### Notes\n * Tabs can always be moved programmatically.\n */\n get tabsMovable(): boolean {\n return this.tabBar.tabsMovable;\n }\n\n /**\n * Set the whether the tabs are movable by the user.\n *\n * #### Notes\n * Tabs can always be moved programmatically.\n */\n set tabsMovable(value: boolean) {\n this.tabBar.tabsMovable = value;\n }\n\n /**\n * Get the whether the add button is enabled.\n *\n */\n get addButtonEnabled(): boolean {\n return this.tabBar.addButtonEnabled;\n }\n\n /**\n * Set the whether the add button is enabled.\n *\n */\n set addButtonEnabled(value: boolean) {\n this.tabBar.addButtonEnabled = value;\n }\n\n /**\n * Get the tab placement for the tab panel.\n *\n * #### Notes\n * This controls the position of the tab bar relative to the content.\n */\n get tabPlacement(): TabPanel.TabPlacement {\n return this._tabPlacement;\n }\n\n /**\n * Set the tab placement for the tab panel.\n *\n * #### Notes\n * This controls the position of the tab bar relative to the content.\n */\n set tabPlacement(value: TabPanel.TabPlacement) {\n // Bail if the placement does not change.\n if (this._tabPlacement === value) {\n return;\n }\n\n // Update the internal value.\n this._tabPlacement = value;\n\n // Get the values related to the placement.\n let direction = Private.directionFromPlacement(value);\n let orientation = Private.orientationFromPlacement(value);\n\n // Configure the tab bar for the placement.\n this.tabBar.orientation = orientation;\n this.tabBar.dataset['placement'] = value;\n\n // Update the layout direction.\n (this.layout as BoxLayout).direction = direction;\n }\n\n /**\n * A signal emitted when the add button on a tab bar is clicked.\n *\n */\n get addRequested(): ISignal> {\n return this._addRequested;\n }\n\n /**\n * The tab bar used by the tab panel.\n *\n * #### Notes\n * Modifying the tab bar directly can lead to undefined behavior.\n */\n readonly tabBar: TabBar;\n\n /**\n * The stacked panel used by the tab panel.\n *\n * #### Notes\n * Modifying the panel directly can lead to undefined behavior.\n */\n readonly stackedPanel: StackedPanel;\n\n /**\n * A read-only array of the widgets in the panel.\n */\n get widgets(): ReadonlyArray {\n return this.stackedPanel.widgets;\n }\n\n /**\n * Add a widget to the end of the tab panel.\n *\n * @param widget - The widget to add to the tab panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n *\n * The widget's `title` is used to populate the tab.\n */\n addWidget(widget: Widget): void {\n this.insertWidget(this.widgets.length, widget);\n }\n\n /**\n * Insert a widget into the tab panel at a specified index.\n *\n * @param index - The index at which to insert the widget.\n *\n * @param widget - The widget to insert into to the tab panel.\n *\n * #### Notes\n * If the widget is already contained in the panel, it will be moved.\n *\n * The widget's `title` is used to populate the tab.\n */\n insertWidget(index: number, widget: Widget): void {\n if (widget !== this.currentWidget) {\n widget.hide();\n }\n this.stackedPanel.insertWidget(index, widget);\n this.tabBar.insertTab(index, widget.title);\n\n widget.node.setAttribute('role', 'tabpanel');\n\n let renderer = this.tabBar.renderer;\n if (renderer instanceof TabBar.Renderer) {\n let tabId = renderer.createTabKey({\n title: widget.title,\n current: false,\n zIndex: 0\n });\n widget.node.setAttribute('aria-labelledby', tabId);\n }\n }\n\n /**\n * Handle the `currentChanged` signal from the tab bar.\n */\n private _onCurrentChanged(\n sender: TabBar,\n args: TabBar.ICurrentChangedArgs\n ): void {\n // Extract the previous and current title from the args.\n let { previousIndex, previousTitle, currentIndex, currentTitle } = args;\n\n // Extract the widgets from the titles.\n let previousWidget = previousTitle ? previousTitle.owner : null;\n let currentWidget = currentTitle ? currentTitle.owner : null;\n\n // Hide the previous widget.\n if (previousWidget) {\n previousWidget.hide();\n }\n\n // Show the current widget.\n if (currentWidget) {\n currentWidget.show();\n }\n\n // Emit the `currentChanged` signal for the tab panel.\n this._currentChanged.emit({\n previousIndex,\n previousWidget,\n currentIndex,\n currentWidget\n });\n\n // Flush the message loop on IE and Edge to prevent flicker.\n if (Platform.IS_EDGE || Platform.IS_IE) {\n MessageLoop.flush();\n }\n }\n\n /**\n * Handle the `tabAddRequested` signal from the tab bar.\n */\n private _onTabAddRequested(sender: TabBar, args: void): void {\n this._addRequested.emit(sender);\n }\n\n /**\n * Handle the `tabActivateRequested` signal from the tab bar.\n */\n private _onTabActivateRequested(\n sender: TabBar,\n args: TabBar.ITabActivateRequestedArgs\n ): void {\n args.title.owner.activate();\n }\n\n /**\n * Handle the `tabCloseRequested` signal from the tab bar.\n */\n private _onTabCloseRequested(\n sender: TabBar,\n args: TabBar.ITabCloseRequestedArgs\n ): void {\n args.title.owner.close();\n }\n\n /**\n * Handle the `tabMoved` signal from the tab bar.\n */\n private _onTabMoved(\n sender: TabBar,\n args: TabBar.ITabMovedArgs\n ): void {\n this.stackedPanel.insertWidget(args.toIndex, args.title.owner);\n }\n\n /**\n * Handle the `widgetRemoved` signal from the stacked panel.\n */\n private _onWidgetRemoved(sender: StackedPanel, widget: Widget): void {\n widget.node.removeAttribute('role');\n widget.node.removeAttribute('aria-labelledby');\n this.tabBar.removeTab(widget.title);\n }\n\n private _tabPlacement: TabPanel.TabPlacement;\n private _currentChanged = new Signal(\n this\n );\n\n private _addRequested = new Signal>(this);\n}\n\n/**\n * The namespace for the `TabPanel` class statics.\n */\nexport namespace TabPanel {\n /**\n * A type alias for tab placement in a tab bar.\n */\n export type TabPlacement =\n | /**\n * The tabs are placed as a row above the content.\n */\n 'top'\n\n /**\n * The tabs are placed as a column to the left of the content.\n */\n | 'left'\n\n /**\n * The tabs are placed as a column to the right of the content.\n */\n | 'right'\n\n /**\n * The tabs are placed as a row below the content.\n */\n | 'bottom';\n\n /**\n * An options object for initializing a tab panel.\n */\n export interface IOptions {\n /**\n * The document to use with the tab panel.\n *\n * The default is the global `document` instance.\n */\n document?: Document | ShadowRoot;\n\n /**\n * Whether the tabs are movable by the user.\n *\n * The default is `false`.\n */\n tabsMovable?: boolean;\n\n /**\n * Whether the button to add new tabs is enabled.\n *\n * The default is `false`.\n */\n addButtonEnabled?: boolean;\n\n /**\n * The placement of the tab bar relative to the content.\n *\n * The default is `'top'`.\n */\n tabPlacement?: TabPlacement;\n\n /**\n * The renderer for the panel's tab bar.\n *\n * The default is a shared renderer instance.\n */\n renderer?: TabBar.IRenderer;\n }\n\n /**\n * The arguments object for the `currentChanged` signal.\n */\n export interface ICurrentChangedArgs {\n /**\n * The previously selected index.\n */\n previousIndex: number;\n\n /**\n * The previously selected widget.\n */\n previousWidget: Widget | null;\n\n /**\n * The currently selected index.\n */\n currentIndex: number;\n\n /**\n * The currently selected widget.\n */\n currentWidget: Widget | null;\n }\n}\n\n/**\n * The namespace for the module implementation details.\n */\nnamespace Private {\n /**\n * Convert a tab placement to tab bar orientation.\n */\n export function orientationFromPlacement(\n plc: TabPanel.TabPlacement\n ): TabBar.Orientation {\n return placementToOrientationMap[plc];\n }\n\n /**\n * Convert a tab placement to a box layout direction.\n */\n export function directionFromPlacement(\n plc: TabPanel.TabPlacement\n ): BoxLayout.Direction {\n return placementToDirectionMap[plc];\n }\n\n /**\n * A mapping of tab placement to tab bar orientation.\n */\n const placementToOrientationMap: { [key: string]: TabBar.Orientation } = {\n top: 'horizontal',\n left: 'vertical',\n right: 'vertical',\n bottom: 'horizontal'\n };\n\n /**\n * A mapping of tab placement to box layout direction.\n */\n const placementToDirectionMap: { [key: string]: BoxLayout.Direction } = {\n top: 'top-to-bottom',\n left: 'left-to-right',\n right: 'right-to-left',\n bottom: 'bottom-to-top'\n };\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { MessageLoop } from '@lumino/messaging';\n\nimport { Layout } from './layout';\n\nimport { Widget } from './widget';\n\n/**\n * A concrete layout implementation which holds a single widget.\n *\n * #### Notes\n * This class is useful for creating simple container widgets which\n * hold a single child. The child should be positioned with CSS.\n */\nexport class SingletonLayout extends Layout {\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n if (this._widget) {\n let widget = this._widget;\n this._widget = null;\n widget.dispose();\n }\n super.dispose();\n }\n\n /**\n * Get the child widget for the layout.\n */\n get widget(): Widget | null {\n return this._widget;\n }\n\n /**\n * Set the child widget for the layout.\n *\n * #### Notes\n * Setting the child widget will cause the old child widget to be\n * automatically disposed. If that is not desired, set the parent\n * of the old child to `null` before assigning a new child.\n */\n set widget(widget: Widget | null) {\n // Remove the widget from its current parent. This is a no-op\n // if the widget's parent is already the layout parent widget.\n if (widget) {\n widget.parent = this.parent;\n }\n\n // Bail early if the widget does not change.\n if (this._widget === widget) {\n return;\n }\n\n // Dispose of the old child widget.\n if (this._widget) {\n this._widget.dispose();\n }\n\n // Update the internal widget.\n this._widget = widget;\n\n // Attach the new child widget if needed.\n if (this.parent && widget) {\n this.attachWidget(widget);\n }\n }\n\n /**\n * Create an iterator over the widgets in the layout.\n *\n * @returns A new iterator over the widgets in the layout.\n */\n *[Symbol.iterator](): IterableIterator {\n if (this._widget) {\n yield this._widget;\n }\n }\n\n /**\n * Remove a widget from the layout.\n *\n * @param widget - The widget to remove from the layout.\n *\n * #### Notes\n * A widget is automatically removed from the layout when its `parent`\n * is set to `null`. This method should only be invoked directly when\n * removing a widget from a layout which has yet to be installed on a\n * parent widget.\n *\n * This method does *not* modify the widget's `parent`.\n */\n removeWidget(widget: Widget): void {\n // Bail early if the widget does not exist in the layout.\n if (this._widget !== widget) {\n return;\n }\n\n // Clear the internal widget.\n this._widget = null;\n\n // If the layout is parented, detach the widget from the DOM.\n if (this.parent) {\n this.detachWidget(widget);\n }\n }\n\n /**\n * Perform layout initialization which requires the parent widget.\n */\n protected init(): void {\n super.init();\n for (const widget of this) {\n this.attachWidget(widget);\n }\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This method is called automatically by the single layout at the\n * appropriate time. It should not be called directly by user code.\n *\n * The default implementation adds the widgets's node to the parent's\n * node at the proper location, and sends the appropriate attach\n * messages to the widget if the parent is attached to the DOM.\n *\n * Subclasses may reimplement this method to control how the widget's\n * node is added to the parent's node.\n */\n protected attachWidget(widget: Widget): void {\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget's node to the parent.\n this.parent!.node.appendChild(widget.node);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This method is called automatically by the single layout at the\n * appropriate time. It should not be called directly by user code.\n *\n * The default implementation removes the widget's node from the\n * parent's node, and sends the appropriate detach messages to the\n * widget if the parent is attached to the DOM.\n *\n * Subclasses may reimplement this method to control how the widget's\n * node is removed from the parent's node.\n */\n protected detachWidget(widget: Widget): void {\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n }\n\n private _widget: Widget | null = null;\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt } from '@lumino/algorithm';\n\nimport { ElementExt } from '@lumino/domutils';\n\nimport { Message, MessageLoop } from '@lumino/messaging';\n\nimport { Layout, LayoutItem } from './layout';\n\nimport { PanelLayout } from './panellayout';\n\nimport { Widget } from './widget';\n\n/**\n * A layout where visible widgets are stacked atop one another.\n *\n * #### Notes\n * The Z-order of the visible widgets follows their layout order.\n */\nexport class StackedLayout extends PanelLayout {\n constructor(options: StackedLayout.IOptions = {}) {\n super(options);\n this._hiddenMode =\n options.hiddenMode !== undefined\n ? options.hiddenMode\n : Widget.HiddenMode.Display;\n }\n\n /**\n * The method for hiding widgets.\n *\n * #### Notes\n * If there is only one child widget, `Display` hiding mode will be used\n * regardless of this setting.\n */\n get hiddenMode(): Widget.HiddenMode {\n return this._hiddenMode;\n }\n\n /**\n * Set the method for hiding widgets.\n *\n * #### Notes\n * If there is only one child widget, `Display` hiding mode will be used\n * regardless of this setting.\n */\n set hiddenMode(v: Widget.HiddenMode) {\n if (this._hiddenMode === v) {\n return;\n }\n this._hiddenMode = v;\n if (this.widgets.length > 1) {\n this.widgets.forEach(w => {\n w.hiddenMode = this._hiddenMode;\n });\n }\n }\n\n /**\n * Dispose of the resources held by the layout.\n */\n dispose(): void {\n // Dispose of the layout items.\n for (const item of this._items) {\n item.dispose();\n }\n\n // Clear the layout state.\n this._box = null;\n this._items.length = 0;\n\n // Dispose of the rest of the layout.\n super.dispose();\n }\n\n /**\n * Attach a widget to the parent's DOM node.\n *\n * @param index - The current index of the widget in the layout.\n *\n * @param widget - The widget to attach to the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected attachWidget(index: number, widget: Widget): void {\n // Using transform create an additional layer in the pixel pipeline\n // to limit the number of layer, it is set only if there is more than one widget.\n if (\n this._hiddenMode === Widget.HiddenMode.Scale &&\n this._items.length > 0\n ) {\n if (this._items.length === 1) {\n this.widgets[0].hiddenMode = Widget.HiddenMode.Scale;\n }\n widget.hiddenMode = Widget.HiddenMode.Scale;\n } else {\n widget.hiddenMode = Widget.HiddenMode.Display;\n }\n\n // Create and add a new layout item for the widget.\n ArrayExt.insert(this._items, index, new LayoutItem(widget));\n\n // Send a `'before-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeAttach);\n }\n\n // Add the widget's node to the parent.\n this.parent!.node.appendChild(widget.node);\n\n // Send an `'after-attach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterAttach);\n }\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * Move a widget in the parent's DOM node.\n *\n * @param fromIndex - The previous index of the widget in the layout.\n *\n * @param toIndex - The current index of the widget in the layout.\n *\n * @param widget - The widget to move in the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected moveWidget(\n fromIndex: number,\n toIndex: number,\n widget: Widget\n ): void {\n // Move the layout item for the widget.\n ArrayExt.move(this._items, fromIndex, toIndex);\n\n // Post an update request for the parent widget.\n this.parent!.update();\n }\n\n /**\n * Detach a widget from the parent's DOM node.\n *\n * @param index - The previous index of the widget in the layout.\n *\n * @param widget - The widget to detach from the parent.\n *\n * #### Notes\n * This is a reimplementation of the superclass method.\n */\n protected detachWidget(index: number, widget: Widget): void {\n // Remove the layout item for the widget.\n let item = ArrayExt.removeAt(this._items, index);\n\n // Send a `'before-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.BeforeDetach);\n }\n\n // Remove the widget's node from the parent.\n this.parent!.node.removeChild(widget.node);\n\n // Send an `'after-detach'` message if the parent is attached.\n if (this.parent!.isAttached) {\n MessageLoop.sendMessage(widget, Widget.Msg.AfterDetach);\n }\n\n // Reset the z-index for the widget.\n item!.widget.node.style.zIndex = '';\n\n // Reset the hidden mode for the widget.\n if (this._hiddenMode === Widget.HiddenMode.Scale) {\n widget.hiddenMode = Widget.HiddenMode.Display;\n\n // Reset the hidden mode for the first widget if necessary.\n if (this._items.length === 1) {\n this._items[0].widget.hiddenMode = Widget.HiddenMode.Display;\n }\n }\n\n // Dispose of the layout item.\n item!.dispose();\n\n // Post a fit request for the parent widget.\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'before-show'` message.\n */\n protected onBeforeShow(msg: Message): void {\n super.onBeforeShow(msg);\n this.parent!.update();\n }\n\n /**\n * A message handler invoked on a `'before-attach'` message.\n */\n protected onBeforeAttach(msg: Message): void {\n super.onBeforeAttach(msg);\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-shown'` message.\n */\n protected onChildShown(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'child-hidden'` message.\n */\n protected onChildHidden(msg: Widget.ChildMessage): void {\n this.parent!.fit();\n }\n\n /**\n * A message handler invoked on a `'resize'` message.\n */\n protected onResize(msg: Widget.ResizeMessage): void {\n if (this.parent!.isVisible) {\n this._update(msg.width, msg.height);\n }\n }\n\n /**\n * A message handler invoked on an `'update-request'` message.\n */\n protected onUpdateRequest(msg: Message): void {\n if (this.parent!.isVisible) {\n this._update(-1, -1);\n }\n }\n\n /**\n * A message handler invoked on a `'fit-request'` message.\n */\n protected onFitRequest(msg: Message): void {\n if (this.parent!.isAttached) {\n this._fit();\n }\n }\n\n /**\n * Fit the layout to the total size required by the widgets.\n */\n private _fit(): void {\n // Set up the computed minimum size.\n let minW = 0;\n let minH = 0;\n\n // Update the computed minimum size.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item.\n let item = this._items[i];\n\n // Ignore hidden items.\n if (item.isHidden) {\n continue;\n }\n\n // Update the size limits for the item.\n item.fit();\n\n // Update the computed minimum size.\n minW = Math.max(minW, item.minWidth);\n minH = Math.max(minH, item.minHeight);\n }\n\n // Update the box sizing and add it to the computed min size.\n let box = (this._box = ElementExt.boxSizing(this.parent!.node));\n minW += box.horizontalSum;\n minH += box.verticalSum;\n\n // Update the parent's min size constraints.\n let style = this.parent!.node.style;\n style.minWidth = `${minW}px`;\n style.minHeight = `${minH}px`;\n\n // Set the dirty flag to ensure only a single update occurs.\n this._dirty = true;\n\n // Notify the ancestor that it should fit immediately. This may\n // cause a resize of the parent, fulfilling the required update.\n if (this.parent!.parent) {\n MessageLoop.sendMessage(this.parent!.parent!, Widget.Msg.FitRequest);\n }\n\n // If the dirty flag is still set, the parent was not resized.\n // Trigger the required update on the parent widget immediately.\n if (this._dirty) {\n MessageLoop.sendMessage(this.parent!, Widget.Msg.UpdateRequest);\n }\n }\n\n /**\n * Update the layout position and size of the widgets.\n *\n * The parent offset dimensions should be `-1` if unknown.\n */\n private _update(offsetWidth: number, offsetHeight: number): void {\n // Clear the dirty flag to indicate the update occurred.\n this._dirty = false;\n\n // Compute the visible item count.\n let nVisible = 0;\n for (let i = 0, n = this._items.length; i < n; ++i) {\n nVisible += +!this._items[i].isHidden;\n }\n\n // Bail early if there are no visible items to layout.\n if (nVisible === 0) {\n return;\n }\n\n // Measure the parent if the offset dimensions are unknown.\n if (offsetWidth < 0) {\n offsetWidth = this.parent!.node.offsetWidth;\n }\n if (offsetHeight < 0) {\n offsetHeight = this.parent!.node.offsetHeight;\n }\n\n // Ensure the parent box sizing data is computed.\n if (!this._box) {\n this._box = ElementExt.boxSizing(this.parent!.node);\n }\n\n // Compute the actual layout bounds adjusted for border and padding.\n let top = this._box.paddingTop;\n let left = this._box.paddingLeft;\n let width = offsetWidth - this._box.horizontalSum;\n let height = offsetHeight - this._box.verticalSum;\n\n // Update the widget stacking order and layout geometry.\n for (let i = 0, n = this._items.length; i < n; ++i) {\n // Fetch the item.\n let item = this._items[i];\n\n // Ignore hidden items.\n if (item.isHidden) {\n continue;\n }\n\n // Set the z-index for the widget.\n item.widget.node.style.zIndex = `${i}`;\n\n // Update the item geometry.\n item.update(left, top, width, height);\n }\n }\n\n private _dirty = false;\n private _items: LayoutItem[] = [];\n private _box: ElementExt.IBoxSizing | null = null;\n private _hiddenMode: Widget.HiddenMode;\n}\n\n/**\n * The namespace for the `StackedLayout` class statics.\n */\nexport namespace StackedLayout {\n /**\n * An options object for initializing a stacked layout.\n */\n export interface IOptions extends Layout.IOptions {\n /**\n * The method for hiding widgets.\n *\n * The default is `Widget.HiddenMode.Display`.\n */\n hiddenMode?: Widget.HiddenMode;\n }\n}\n","// Copyright (c) Jupyter Development Team.\n// Distributed under the terms of the Modified BSD License.\n/*-----------------------------------------------------------------------------\n| Copyright (c) 2014-2017, PhosphorJS Contributors\n|\n| Distributed under the terms of the BSD 3-Clause License.\n|\n| The full license is in the file LICENSE, distributed with this software.\n|----------------------------------------------------------------------------*/\nimport { ArrayExt, find, max } from '@lumino/algorithm';\n\nimport { IDisposable } from '@lumino/disposable';\n\nimport { ISignal, Signal } from '@lumino/signaling';\n\nimport { Widget } from './widget';\n\n/**\n * A class which tracks focus among a set of widgets.\n *\n * This class is useful when code needs to keep track of the most\n * recently focused widget(s) among a set of related widgets.\n */\nexport class FocusTracker implements IDisposable {\n /**\n * Dispose of the resources held by the tracker.\n */\n dispose(): void {\n // Do nothing if the tracker is already disposed.\n if (this._counter < 0) {\n return;\n }\n\n // Mark the tracker as disposed.\n this._counter = -1;\n\n // Clear the connections for the tracker.\n Signal.clearData(this);\n\n // Remove all event listeners.\n for (const widget of this._widgets) {\n widget.node.removeEventListener('focus', this, true);\n widget.node.removeEventListener('blur', this, true);\n }\n\n // Clear the internal data structures.\n this._activeWidget = null;\n this._currentWidget = null;\n this._nodes.clear();\n this._numbers.clear();\n this._widgets.length = 0;\n }\n\n /**\n * A signal emitted when the current widget has changed.\n */\n get currentChanged(): ISignal> {\n return this._currentChanged;\n }\n\n /**\n * A signal emitted when the active widget has changed.\n */\n get activeChanged(): ISignal> {\n return this._activeChanged;\n }\n\n /**\n * A flag indicating whether the tracker is disposed.\n */\n get isDisposed(): boolean {\n return this._counter < 0;\n }\n\n /**\n * The current widget in the tracker.\n *\n * #### Notes\n * The current widget is the widget among the tracked widgets which\n * has the *descendant node* which has most recently been focused.\n *\n * The current widget will not be updated if the node loses focus. It\n * will only be updated when a different tracked widget gains focus.\n *\n * If the current widget is removed from the tracker, the previous\n * current widget will be restored.\n *\n * This behavior is intended to follow a user's conceptual model of\n * a semantically \"current\" widget, where the \"last thing of type X\"\n * to be interacted with is the \"current instance of X\", regardless\n * of whether that instance still has focus.\n */\n get currentWidget(): T | null {\n return this._currentWidget;\n }\n\n /**\n * The active widget in the tracker.\n *\n * #### Notes\n * The active widget is the widget among the tracked widgets which\n * has the *descendant node* which is currently focused.\n */\n get activeWidget(): T | null {\n return this._activeWidget;\n }\n\n /**\n * A read only array of the widgets being tracked.\n */\n get widgets(): ReadonlyArray {\n return this._widgets;\n }\n\n /**\n * Get the focus number for a particular widget in the tracker.\n *\n * @param widget - The widget of interest.\n *\n * @returns The focus number for the given widget, or `-1` if the\n * widget has not had focus since being added to the tracker, or\n * is not contained by the tracker.\n *\n * #### Notes\n * The focus number indicates the relative order in which the widgets\n * have gained focus. A widget with a larger number has gained focus\n * more recently than a widget with a smaller number.\n *\n * The `currentWidget` will always have the largest focus number.\n *\n * All widgets start with a focus number of `-1`, which indicates that\n * the widget has not been focused since being added to the tracker.\n */\n focusNumber(widget: T): number {\n let n = this._numbers.get(widget);\n return n === undefined ? -1 : n;\n }\n\n /**\n * Test whether the focus tracker contains a given widget.\n *\n * @param widget - The widget of interest.\n *\n * @returns `true` if the widget is tracked, `false` otherwise.\n */\n has(widget: T): boolean {\n return this._numbers.has(widget);\n }\n\n /**\n * Add a widget to the focus tracker.\n *\n * @param widget - The widget of interest.\n *\n * #### Notes\n * A widget will be automatically removed from the tracker if it\n * is disposed after being added.\n *\n * If the widget is already tracked, this is a no-op.\n */\n add(widget: T): void {\n // Do nothing if the widget is already tracked.\n if (this._numbers.has(widget)) {\n return;\n }\n\n // Test whether the widget has focus.\n let focused = widget.node.contains(document.activeElement);\n\n // Set up the initial focus number.\n let n = focused ? this._counter++ : -1;\n\n // Add the widget to the internal data structures.\n this._widgets.push(widget);\n this._numbers.set(widget, n);\n this._nodes.set(widget.node, widget);\n\n // Set up the event listeners. The capturing phase must be used\n // since the 'focus' and 'blur' events don't bubble and Firefox\n // doesn't support the 'focusin' or 'focusout' events.\n widget.node.addEventListener('focus', this, true);\n widget.node.addEventListener('blur', this, true);\n\n // Connect the disposed signal handler.\n widget.disposed.connect(this._onWidgetDisposed, this);\n\n // Set the current and active widgets if needed.\n if (focused) {\n this._setWidgets(widget, widget);\n }\n }\n\n /**\n * Remove a widget from the focus tracker.\n *\n * #### Notes\n * If the widget is the `currentWidget`, the previous current widget\n * will become the new `currentWidget`.\n *\n * A widget will be automatically removed from the tracker if it\n * is disposed after being added.\n *\n * If the widget is not tracked, this is a no-op.\n */\n remove(widget: T): void {\n // Bail early if the widget is not tracked.\n if (!this._numbers.has(widget)) {\n return;\n }\n\n // Disconnect the disposed signal handler.\n widget.disposed.disconnect(this._onWidgetDisposed, this);\n\n // Remove the event listeners.\n widget.node.removeEventListener('focus', this, true);\n widget.node.removeEventListener('blur', this, true);\n\n // Remove the widget from the internal data structures.\n ArrayExt.removeFirstOf(this._widgets, widget);\n this._nodes.delete(widget.node);\n this._numbers.delete(widget);\n\n // Bail early if the widget is not the current widget.\n if (this._currentWidget !== widget) {\n return;\n }\n\n // Filter the widgets for those which have had focus.\n let valid = this._widgets.filter(w => this._numbers.get(w) !== -1);\n\n // Get the valid widget with the max focus number.\n let previous =\n max(valid, (first, second) => {\n let a = this._numbers.get(first)!;\n let b = this._numbers.get(second)!;\n return a - b;\n }) || null;\n\n // Set the current and active widgets.\n this._setWidgets(previous, null);\n }\n\n /**\n * Handle the DOM events for the focus tracker.\n *\n * @param event - The DOM event sent to the panel.\n *\n * #### Notes\n * This method implements the DOM `EventListener` interface and is\n * called in response to events on the tracked nodes. It should\n * not be called directly by user code.\n */\n handleEvent(event: Event): void {\n switch (event.type) {\n case 'focus':\n this._evtFocus(event as FocusEvent);\n break;\n case 'blur':\n this._evtBlur(event as FocusEvent);\n break;\n }\n }\n\n /**\n * Set the current and active widgets for the tracker.\n */\n private _setWidgets(current: T | null, active: T | null): void {\n // Swap the current widget.\n let oldCurrent = this._currentWidget;\n this._currentWidget = current;\n\n // Swap the active widget.\n let oldActive = this._activeWidget;\n this._activeWidget = active;\n\n // Emit the `currentChanged` signal if needed.\n if (oldCurrent !== current) {\n this._currentChanged.emit({ oldValue: oldCurrent, newValue: current });\n }\n\n // Emit the `activeChanged` signal if needed.\n if (oldActive !== active) {\n this._activeChanged.emit({ oldValue: oldActive, newValue: active });\n }\n }\n\n /**\n * Handle the `'focus'` event for a tracked widget.\n */\n private _evtFocus(event: FocusEvent): void {\n // Find the widget which gained focus, which is known to exist.\n let widget = this._nodes.get(event.currentTarget as HTMLElement)!;\n\n // Update the focus number if necessary.\n if (widget !== this._currentWidget) {\n this._numbers.set(widget, this._counter++);\n }\n\n // Set the current and active widgets.\n this._setWidgets(widget, widget);\n }\n\n /**\n * Handle the `'blur'` event for a tracked widget.\n */\n private _evtBlur(event: FocusEvent): void {\n // Find the widget which lost focus, which is known to exist.\n let widget = this._nodes.get(event.currentTarget as HTMLElement)!;\n\n // Get the node which being focused after this blur.\n let focusTarget = event.relatedTarget as HTMLElement;\n\n // If no other node is being focused, clear the active widget.\n if (!focusTarget) {\n this._setWidgets(this._currentWidget, null);\n return;\n }\n\n // Bail if the focus widget is not changing.\n if (widget.node.contains(focusTarget)) {\n return;\n }\n\n // If no tracked widget is being focused, clear the active widget.\n if (!find(this._widgets, w => w.node.contains(focusTarget))) {\n this._setWidgets(this._currentWidget, null);\n return;\n }\n }\n\n /**\n * Handle the `disposed` signal for a tracked widget.\n */\n private _onWidgetDisposed(sender: T): void {\n this.remove(sender);\n }\n\n private _counter = 0;\n private _widgets: T[] = [];\n private _activeWidget: T | null = null;\n private _currentWidget: T | null = null;\n private _numbers = new Map();\n private _nodes = new Map();\n private _activeChanged = new Signal>(this);\n private _currentChanged = new Signal>(\n this\n );\n}\n\n/**\n * The namespace for the `FocusTracker` class statics.\n */\nexport namespace FocusTracker {\n /**\n * An arguments object for the changed signals.\n */\n export interface IChangedArgs {\n /**\n * The old value for the widget.\n */\n oldValue: T | null;\n\n /**\n * The new value for the widget.\n */\n newValue: T | null;\n }\n}\n"],"mappings":"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"} +\ No newline at end of file +diff --git a/node_modules/@lumino/widgets/src/menu.ts b/node_modules/@lumino/widgets/src/menu.ts +index 80ca9e7..9874f25 100644 +--- a/node_modules/@lumino/widgets/src/menu.ts ++++ b/node_modules/@lumino/widgets/src/menu.ts +@@ -520,7 +520,7 @@ export class Menu extends Widget { + this.node.addEventListener('mouseenter', this); + this.node.addEventListener('mouseleave', this); + this.node.addEventListener('contextmenu', this); +- document.addEventListener('mousedown', this, true); ++ this.node.ownerDocument.addEventListener('mousedown', this, true); + } + + /** +@@ -533,7 +533,7 @@ export class Menu extends Widget { + this.node.removeEventListener('mouseenter', this); + this.node.removeEventListener('mouseleave', this); + this.node.removeEventListener('contextmenu', this); +- document.removeEventListener('mousedown', this, true); ++ this.node.ownerDocument.removeEventListener('mousedown', this, true); + } + + /** +@@ -1636,7 +1636,7 @@ namespace Private { + style.maxHeight = `${maxHeight}px`; + + // Attach the menu to the document. +- Widget.attach(submenu, document.body); ++ Widget.attach(submenu, itemNode.ownerDocument.body); + + // Measure the size of the menu. + let { width, height } = node.getBoundingClientRect(); +diff --git a/node_modules/@lumino/widgets/src/menubar.ts b/node_modules/@lumino/widgets/src/menubar.ts +index 9c7561a..ce51938 100644 +--- a/node_modules/@lumino/widgets/src/menubar.ts ++++ b/node_modules/@lumino/widgets/src/menubar.ts +@@ -145,11 +145,6 @@ export class MenuBar extends Widget { + value = -1; + } + +- // An empty menu cannot be active +- if (value > -1 && this._menus[value].items.length === 0) { +- value = -1; +- } +- + // Bail early if the index will not change. + if (this._activeIndex === value) { + return;