UNPKG

@cisstech/nge

Version:

NG Essentials is a collection of libraries for Angular developers.

13 lines 11.2 kB
export class TreeFilter { constructor(term = '') { this.term = term; } } export class TreeState { constructor(active = '', expandedNodes = [], filter = new TreeFilter()) { this.active = active; this.expandedNodes = expandedNodes; this.filter = filter; } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree.model.js","sourceRoot":"","sources":["../../../../../../projects/nge/ui/tree/src/tree.model.ts"],"names":[],"mappings":"AA6SA,MAAM,OAAO,UAAU;IACrB,YAAmB,OAAO,EAAE;QAAT,SAAI,GAAJ,IAAI,CAAK;IAAG,CAAC;CACjC;AAED,MAAM,OAAO,SAAS;IACpB,YACS,SAAS,EAAE,EACX,gBAA0B,EAAE,EAC5B,SAAsB,IAAI,UAAU,EAAE;QAFtC,WAAM,GAAN,MAAM,CAAK;QACX,kBAAa,GAAb,aAAa,CAAe;QAC5B,WAAM,GAAN,MAAM,CAAgC;IAC5C,CAAC;CACL","sourcesContent":["/**\n * Representation of a node\n * T => data\n * string => id of a node\n * Element => dom element of a node\n * ITreeNodeHolder<T> internal representation\n */\nexport declare type INode<T> = T | string | Element | ITreeNodeHolder<T>\n\nexport interface ITreeState {\n  active: string\n  filter: ITreeFilter\n  expandedNodes: string[]\n}\n\nexport interface ITreeFilter {\n  term: string\n}\n\nexport interface ITreeEdition<T> {\n  node: T\n  text: string\n  creation?: boolean\n}\n\n/**\n * Keyboard event handlers\n */\nexport interface ITreeKeyAction<T> {\n  /**\n   * Original dom event (MouseEvent|KeyboardEvent).\n   * If `event.preventDefault()` is not called, the typed character will be added/removed\n   * to the current filter of the tree.\n   */\n  event: KeyboardEvent\n  /** The node on which the action is called. (`null` for contextmenu on the tree itself ) */\n  node?: T\n}\n\n/** Mouse event handlers */\nexport interface ITreeMouseAction<T> {\n  /** original dom event (MouseEvent|KeyboardEvent) */\n  event: MouseEvent\n  /** The node on which the action is called. (`null` for contextmenu on the tree itself ) */\n  node?: T\n}\n\n/** Maps mouse events, and key codes, to callbacks. */\nexport interface ITreeActionMapping<T> {\n  keys?: { [k: string]: (e: ITreeKeyAction<T>) => void }\n  mouse?: {\n    click?: (e: ITreeMouseAction<T>) => void\n    rightClick?: (e: ITreeMouseAction<T>) => void\n  }\n}\n\n/**\n * Tree api.\n */\nexport interface ITree<T> {\n  /**\n   * Gets the selected nodes.\n   */\n  selections(): T[]\n\n  /**\n   * Gets the current focused node.\n   */\n  focusedNode(): T | undefined\n\n  /**\n   * Gets a value indicating whether `node` is selected.\n   * @param node A reference to a node.\n   * @throws {ReferenceError} if node is null.\n   */\n  isSelected(node: INode<T>): boolean\n\n  /**\n   * Gets a value indicating whether `node` is the current focused node.\n   * @param node A reference to a node.\n   * @throws {ReferenceError} if node is null.\n   */\n  isFocused(node: INode<T>): boolean\n\n  /**\n   * Gets a value indicating whether `node` is expanded.\n   * @param node A reference to a node.\n   * @throws {ReferenceError} if node is null.\n   */\n  isExpanded(node: INode<T>): boolean\n\n  /**\n   * Sets `node` as the new focused node.\n   *\n   * Note:\n   * The ancestors the of node will be expanded and the tree will scroll into the node.\n   * @param node A reference to a node.\n   */\n  focus(node: INode<T>): void\n\n  /** Unfocus the current focused node */\n  unfocus(): void\n\n  /**\n   * Expands the passed `node` with all its parents.\n   *\n   * Note:\n   * This method will not select/focus the node.\n   *\n   * @param node A reference to a node.\n   * @throws {ReferenceError} if node is null.\n   */\n  expand(node: INode<T>): void\n\n  /**\n   * Expand the entire tree.\n   */\n  expandAll(): void\n\n  /**\n   * Collapses the given `node`.\n   *\n   * Note:\n   * This method will not select/focus the node.\n   *\n   * @param node A reference to a node.\n   * @throws {ReferenceError} if node is null.\n   */\n  collapse(node: INode<T>): void\n\n  /**\n   * Collapse the entire tree\n   */\n  collapseAll(): void\n\n  /**\n   * Toggles the expanded/collapse state of the given node.\n   *\n   * Note:\n   * This method will not select/focus the node.\n   *\n   * @param node A reference to a node.\n   * @throws {ReferenceError} if node is null.\n   */\n  toggle(node: INode<T>): void\n\n  /**\n   * Starts editing the given node.\n   * @param node A reference to a node.\n   * @param creation If true, an input will be displayed after the node to create a new child node.\n   * @throws {ReferenceError} if `node` is null.\n   */\n  startEdition(node: INode<T>, creation?: boolean): void\n\n  /**\n   * End the editing of the current node in a editing state.\n   */\n  endEdition(): void\n\n  /**\n   * Filter the tree using the given filter.\n   * @param filter The filter to apply.\n   */\n  search(filter: ITreeFilter): void\n\n  /**\n   * Saves the tree as an object to be restored later\n   * by calling `tree.restoreState()`.\n   */\n  saveState(): ITreeState\n\n  /**\n   * Restores the state of the tree from `state`.\n   * @param state the state.\n   */\n  restoreState(state: ITreeState): void\n}\n\n/**\n * Adapter class to map a generic type T to an ITreeHolder<T>\n * and attach event listeners to the tree instance.\n */\nexport interface ITreeAdapter<T> {\n  /**\n   * Unique identifier of the tree.\n   *\n   * This identifier is used to get a reference to the tree anywhere\n   * by using `TreeService` class.\n   */\n  id: string\n\n  /** Tree height (default 100%) */\n  treeHeight?: string\n\n  /** Item height (default 32) */\n  itemHeight?: number\n\n  /**\n   * Function called to get the id of a node.\n   */\n  idProvider: (node: T) => string\n\n  /**\n   * Function called to get test whether a node is expandable.\n   */\n  isExpandable: (node: T) => boolean\n\n  /**\n   * Function called to get the display name of a node.\n   */\n  nameProvider: (node: T) => string\n\n  /**\n   * Function called to get the children of a node.\n   */\n  childrenProvider: (node: T) => T[]\n\n  /**\n   * Function called to get the display tooltip of a node.\n   */\n  tooltipProvider?: (node: T) => string\n\n  /**\n   * If enabled, this option will filter the tree\n   * each time a keyboard key is pressed while the tree is focused.\n   *\n   * Note:\n   *\n   * The filter will be updated only if `preventDefault()` is not called\n   * on the original KeyboardEvent by any of the event handlers.\n   *\n   */\n  enableKeyboardFiltering?: boolean\n\n  /**\n   * Event called after a node is expanded in the tree.\n   * @param e informations about the event.\n   */\n  onDidExpand?: (e: T) => void\n\n  /**\n   * Event called after a node is expanded in the tree.\n   * @param e informations about the event.\n   */\n  onDidCollapse?: (e: T) => void\n\n  /**\n   * Event called after a node is edited in the tree.\n   * @param e informations about the event.\n   */\n  onDidEditName?: (e: ITreeEdition<T>) => void\n\n  /**\n   * Maps mouse events, and key codes, to callbacks.\n   */\n  actions?: ITreeActionMapping<T>\n\n  /** Should the tree keep the expands state when the nodes change? (default to `true`)*/\n  keepStateOnChangeNodes?: boolean\n}\n\n/** Internal representation of a node */\nexport interface ITreeNodeHolder<T> {\n  /** A unique key of this node. */\n  id: string\n\n  /** Reference to the original data. */\n  data: T\n\n  /** display name of the node */\n  name: string\n\n  /** Level in the tree (starts from 0). */\n  level: number\n\n  /** A value indicating whether the node is expandable */\n  expandable: boolean\n\n  /** Optional tooltip to show when the node is hovered */\n  tooltip?: string\n\n  padding: string\n\n  // TODO precalculate the following properties instead of calling functions inside template.\n\n  /** A value indicating whether the node is focused */\n  focused?: boolean\n\n  /** A value indicating whether the node is expanded */\n  expanded?: boolean\n\n  /** A value indicating whether the node is selected */\n  selected?: boolean\n\n  /** A value indicating whether the node is in creating state.  */\n  creating?: boolean\n\n  /** A value indicating whether the node is in renaming state.  */\n  renaming?: boolean\n}\n\nexport class TreeFilter implements ITreeFilter {\n  constructor(public term = '') {}\n}\n\nexport class TreeState implements ITreeState {\n  constructor(\n    public active = '',\n    public expandedNodes: string[] = [],\n    public filter: ITreeFilter = new TreeFilter()\n  ) {}\n}\n"]}