/** * @license * Copyright 2021 Google LLC * SPDX-License-Identifier: Apache-2.0 */ /** * Calculates and reports workspace metrics. * * @class */ import type { IFlyout } from './interfaces/i_flyout.js'; import type { IMetricsManager } from './interfaces/i_metrics_manager.js'; import type { IToolbox } from './interfaces/i_toolbox.js'; import type { Metrics } from './utils/metrics.js'; import { Size } from './utils/size.js'; import * as toolboxUtils from './utils/toolbox.js'; import type { WorkspaceSvg } from './workspace_svg.js'; /** * The manager for all workspace metrics calculations. */ export declare class MetricsManager implements IMetricsManager { /** The workspace to calculate metrics for. */ protected readonly workspace_: WorkspaceSvg; /** @param workspace The workspace to calculate metrics for. */ constructor(workspace: WorkspaceSvg); /** * Gets the dimensions of the given workspace component, in pixel coordinates. * * @param elem The element to get the dimensions of, or null. It should be a * toolbox or flyout, and should implement getWidth() and getHeight(). * @returns An object containing width and height attributes, which will both * be zero if elem did not exist. */ protected getDimensionsPx_(elem: IToolbox | null | IFlyout): Size; /** * Gets the width and the height of the flyout in pixel * coordinates. By default, will get metrics for either a simple flyout (owned * directly by the workspace) or for the flyout owned by the toolbox. If you * pass `opt_own` as `true` then only metrics for the simple flyout will be * returned, and it will return 0 for the width and height if the workspace * has a category toolbox instead of a simple toolbox. * * @param opt_own Whether to only return the workspace's own flyout metrics. * @returns The width and height of the flyout. */ getFlyoutMetrics(opt_own?: boolean): ToolboxMetrics; /** * Gets the width, height and position of the toolbox on the workspace in * pixel coordinates. Returns 0 for the width and height if the workspace has * a simple toolbox instead of a category toolbox. To get the width and height * of a simple toolbox, see {@link (MetricsManager:class).getFlyoutMetrics}. * * @returns The object with the width, height and position of the toolbox. */ getToolboxMetrics(): ToolboxMetrics; /** * Gets the width and height of the workspace's parent SVG element in pixel * coordinates. This area includes the toolbox and the visible workspace area. * * @returns The width and height of the workspace's parent SVG element. */ getSvgMetrics(): Size; /** * Gets the absolute left and absolute top in pixel coordinates. * This is where the visible workspace starts in relation to the SVG * container. * * @returns The absolute metrics for the workspace. */ getAbsoluteMetrics(): AbsoluteMetrics; /** * Gets the metrics for the visible workspace in either pixel or workspace * coordinates. The visible workspace does not include the toolbox or flyout. * * @param opt_getWorkspaceCoordinates True to get the view metrics in * workspace coordinates, false to get them in pixel coordinates. * @returns The width, height, top and left of the viewport in either * workspace coordinates or pixel coordinates. */ getViewMetrics(opt_getWorkspaceCoordinates?: boolean): ContainerRegion; /** * Gets content metrics in either pixel or workspace coordinates. * The content area is a rectangle around all the top bounded elements on the * workspace (workspace comments and blocks). * * @param opt_getWorkspaceCoordinates True to get the content metrics in * workspace coordinates, false to get them in pixel coordinates. * @returns The metrics for the content container. */ getContentMetrics(opt_getWorkspaceCoordinates?: boolean): ContainerRegion; /** * Returns whether the scroll area has fixed edges. * * @returns Whether the scroll area has fixed edges. * @internal */ hasFixedEdges(): boolean; /** * Computes the fixed edges of the scroll area. * * @param opt_viewMetrics The view metrics if they have been previously * computed. Passing in null may cause the view metrics to be computed * again, if it is needed. * @returns The fixed edges of the scroll area. */ protected getComputedFixedEdges_(opt_viewMetrics?: ContainerRegion): FixedEdges; /** * Returns the content area with added padding. * * @param viewMetrics The view metrics. * @param contentMetrics The content metrics. * @returns The padded content area. */ protected getPaddedContent_(viewMetrics: ContainerRegion, contentMetrics: ContainerRegion): { top: number; bottom: number; left: number; right: number; }; /** * Returns the metrics for the scroll area of the workspace. * * @param opt_getWorkspaceCoordinates True to get the scroll metrics in * workspace coordinates, false to get them in pixel coordinates. * @param opt_viewMetrics The view metrics if they have been previously * computed. Passing in null may cause the view metrics to be computed * again, if it is needed. * @param opt_contentMetrics The content metrics if they have been previously * computed. Passing in null may cause the content metrics to be computed * again, if it is needed. * @returns The metrics for the scroll container. */ getScrollMetrics(opt_getWorkspaceCoordinates?: boolean, opt_viewMetrics?: ContainerRegion, opt_contentMetrics?: ContainerRegion): ContainerRegion; /** * Returns common metrics used by UI elements. * * @returns The UI metrics. */ getUiMetrics(): UiMetrics; /** * Returns an object with all the metrics required to size scrollbars for a * top level workspace. The following properties are computed: * Coordinate system: pixel coordinates, -left, -up, +right, +down * .viewHeight: Height of the visible portion of the workspace. * .viewWidth: Width of the visible portion of the workspace. * .contentHeight: Height of the content. * .contentWidth: Width of the content. * .scrollHeight: Height of the scroll area. * .scrollWidth: Width of the scroll area. * .svgHeight: Height of the Blockly div (the view + the toolbox, * simple or otherwise), * .svgWidth: Width of the Blockly div (the view + the toolbox, * simple or otherwise), * .viewTop: Top-edge of the visible portion of the workspace, relative to * the workspace origin. * .viewLeft: Left-edge of the visible portion of the workspace, relative to * the workspace origin. * .contentTop: Top-edge of the content, relative to the workspace origin. * .contentLeft: Left-edge of the content relative to the workspace origin. * .scrollTop: Top-edge of the scroll area, relative to the workspace origin. * .scrollLeft: Left-edge of the scroll area relative to the workspace origin. * .absoluteTop: Top-edge of the visible portion of the workspace, relative * to the blocklyDiv. * .absoluteLeft: Left-edge of the visible portion of the workspace, relative * to the blocklyDiv. * .toolboxWidth: Width of the toolbox, if it exists. Otherwise zero. * .toolboxHeight: Height of the toolbox, if it exists. Otherwise zero. * .flyoutWidth: Width of the flyout if it is always open. Otherwise zero. * .flyoutHeight: Height of the flyout if it is always open. Otherwise zero. * .toolboxPosition: Top, bottom, left or right. Use TOOLBOX_AT constants to * compare. * * @returns Contains size and position metrics of a top level workspace. */ getMetrics(): Metrics; } export declare namespace MetricsManager { /** * Describes the width, height and location of the toolbox on the main * workspace. */ interface ToolboxMetrics { width: number; height: number; position: toolboxUtils.Position; } /** Describes where the viewport starts in relation to the workspace SVG. */ interface AbsoluteMetrics { left: number; top: number; } /** * All the measurements needed to describe the size and location of a * container. */ interface ContainerRegion { height: number; width: number; top: number; left: number; } /** Describes fixed edges of the workspace. */ interface FixedEdges { top?: number; bottom?: number; left?: number; right?: number; } /** Common metrics used for UI elements. */ interface UiMetrics { viewMetrics: ContainerRegion; absoluteMetrics: AbsoluteMetrics; toolboxMetrics: ToolboxMetrics; } } export type ToolboxMetrics = MetricsManager.ToolboxMetrics; export type AbsoluteMetrics = MetricsManager.AbsoluteMetrics; export type ContainerRegion = MetricsManager.ContainerRegion; export type FixedEdges = MetricsManager.FixedEdges; export type UiMetrics = MetricsManager.UiMetrics; //# sourceMappingURL=metrics_manager.d.ts.map