quasar
Version:
Build high-performance VueJS user interfaces (SPA, PWA, SSR, Mobile and Desktop) in record time
534 lines (489 loc) • 14.3 kB
JSON
{
"meta": {
"docsUrl": "https://v2.quasar.dev/vue-components/tree"
},
"props": {
"nodes": {
"type": "Array",
"tsType": "QTreeNode",
"desc": "The array of nodes that designates the tree structure",
"required": true,
"examples": [ "[ {...}, {...} ]" ],
"category": "content"
},
"node-key": {
"type": "String",
"desc": "The property name of each node object that holds a unique node id",
"required": true,
"examples": [ "key", "id" ],
"category": "content"
},
"label-key": {
"type": "String",
"desc": "The property name of each node object that holds the label of the node",
"default": "label",
"examples": [ "name", "description" ],
"category": "content"
},
"children-key": {
"type": "String",
"desc": "The property name of each node object that holds the list of children of the node",
"default": "children",
"examples": [ "roles", "relatives" ],
"category": "content"
},
"no-connectors": {
"type": "Boolean",
"desc": "Do not display the connector lines between nodes",
"category": "style"
},
"color": {
"extends": "color"
},
"control-color": {
"extends": "color",
"desc": "Color name for controls (like checkboxes) from the Quasar Color Palette",
"category": "style"
},
"text-color": {
"extends": "text-color"
},
"selected-color": {
"extends": "color",
"desc": "Color name for selected nodes (from the Quasar Color Palette)"
},
"dense": {
"extends": "dense",
"addedIn": "v2.2.4"
},
"dark": {
"extends": "dark"
},
"icon": {
"extends": "icon"
},
"tick-strategy": {
"type": "String",
"desc": "The type of strategy to use for the selection of the nodes",
"default": "none",
"values": [ "none", "strict", "leaf", "leaf-filtered" ],
"category": "behavior"
},
"ticked": {
"type": "Array",
"desc": "Keys of nodes that are ticked",
"sync": true,
"examples": [ "v-model:ticked=\"tickedKeys\"" ],
"category": "state"
},
"expanded": {
"type": "Array",
"desc": "Keys of nodes that are expanded",
"sync": true,
"examples": [ "v-model:expanded=\"expandedKeys\"" ],
"category": "state"
},
"selected": {
"type": "Any",
"desc": "Key of node currently selected",
"sync": true,
"examples": [ "v-model:selected=\"selectedKey\"" ],
"category": "state"
},
"no-selection-unset": {
"type": "Boolean",
"desc": "Do not allow un-selection when clicking currently selected node",
"category": "behavior",
"addedIn": "v2.4.10"
},
"default-expand-all": {
"type": "Boolean",
"desc": "Allow the tree to have all its branches expanded, when first rendered",
"category": "behavior"
},
"accordion": {
"type": "Boolean",
"desc": "Allows the tree to be set in accordion mode",
"category": "behavior"
},
"no-transition": {
"type": "Boolean",
"desc": "Turn off transition effects when expanding/collapsing nodes; Also enhances perf by a lot as a side-effect; Recommended for big trees",
"category": "behavior",
"addedIn": "v2.9.2"
},
"filter": {
"type": "String",
"desc": "The text value to be used for filtering nodes",
"examples": [ ":filter=\"searchText\"" ],
"category": "filter"
},
"filter-method": {
"type": "Function",
"desc": "The function to use to filter the tree nodes; For best performance, reference it from your scope and do not define it inline",
"default": "(see source code)",
"params": {
"node": {
"type": "Object",
"desc": "Node currently being filtered"
},
"filter": {
"type": "String",
"desc": "Filter text to match against"
}
},
"returns": {
"type": "Boolean",
"desc": "Matches or not"
},
"category": "filter"
},
"duration": {
"type": "Number",
"desc": "Toggle animation duration (in milliseconds)",
"default": 300,
"category": "style"
},
"no-nodes-label": {
"type": "String",
"desc": "Override default such label for when no nodes are available",
"examples": [ "No nodes to show!" ],
"category": "content"
},
"no-results-label": {
"type": "String",
"desc": "Override default such label for when no nodes are available due to filtering",
"examples": [ "No results" ],
"category": "content"
}
},
"slots": {
"default-header": {
"desc": "Slot to use for defining the header of a node",
"scope": {
"expanded": {
"type": "Boolean",
"desc": "Is node expanded? Can directly be assigned new Boolean value which changes expanded state",
"reactive": true
},
"ticked": {
"type": "Boolean",
"desc": "Is node ticked? Can directly be assigned new Boolean value which changes ticked state",
"reactive": true
},
"tree": {
"type": "Component",
"tsType": "QTree",
"desc": "QTree instance"
},
"node": {
"type": "Object",
"desc": "Node object"
},
"key": {
"type": "Any",
"desc": "Node's key"
},
"color": {
"type": "String",
"desc": "QTree instance 'color' supplied prop value",
"examples": [ "primary" ]
},
"dark": {
"type": "Boolean",
"desc": "QTree instance 'dark' supplied prop value"
}
}
},
"header-[name]": {
"desc": "Header template slot for describing node header; Used by nodes which have their 'header' prop set to '[name]', where '[name]' can be any string",
"scope": {
"expanded": {
"type": "Boolean",
"desc": "Is node expanded? Can directly be assigned new Boolean value which changes expanded state",
"reactive": true
},
"ticked": {
"type": "Boolean",
"desc": "Is node ticked? Can directly be assigned new Boolean value which changes ticked state",
"reactive": true
},
"tree": {
"type": "Component",
"tsType": "QTree",
"desc": "QTree instance"
},
"node": {
"type": "Object",
"desc": "Node object"
},
"key": {
"type": "Any",
"desc": "Node's key"
},
"color": {
"type": "String",
"desc": "QTree instance 'color' supplied prop value",
"examples": [ "primary" ]
},
"dark": {
"type": "Boolean",
"desc": "QTree instance 'dark' supplied prop value"
}
}
},
"default-body": {
"desc": "Slot to use for defining the body of a node",
"scope": {
"expanded": {
"type": "Boolean",
"desc": "Is node expanded? Can directly be assigned new Boolean value which changes expanded state",
"reactive": true
},
"ticked": {
"type": "Boolean",
"desc": "Is node ticked? Can directly be assigned new Boolean value which changes ticked state",
"reactive": true
},
"tree": {
"type": "Component",
"tsType": "QTree",
"desc": "QTree instance"
},
"node": {
"type": "Object",
"desc": "Node object"
},
"key": {
"type": "Any",
"desc": "Node's key"
},
"color": {
"type": "String",
"desc": "QTree instance 'color' supplied prop value",
"examples": [ "primary" ]
},
"dark": {
"type": "Boolean",
"desc": "QTree instance 'dark' supplied prop value"
}
}
},
"body-[name]": {
"desc": "Body template slot for describing node body; Used by nodes which have their 'body' prop set to '[name]', where '[name]' can be any string",
"scope": {
"expanded": {
"type": "Boolean",
"desc": "Is node expanded? Can directly be assigned new Boolean value which changes expanded state",
"reactive": true
},
"ticked": {
"type": "Boolean",
"desc": "Is node ticked? Can directly be assigned new Boolean value which changes ticked state",
"reactive": true
},
"tree": {
"type": "Component",
"tsType": "QTree",
"desc": "QTree instance"
},
"node": {
"type": "Object",
"desc": "Node object"
},
"key": {
"type": "Any",
"desc": "Node's key"
},
"color": {
"type": "String",
"desc": "QTree instance 'color' supplied prop value",
"examples": [ "primary" ]
},
"dark": {
"type": "Boolean",
"desc": "QTree instance 'dark' supplied prop value"
}
}
}
},
"events": {
"update:expanded": {
"desc": "Triggered when nodes are expanded or collapsed; Used by Vue on 'v-model:update' to update its value",
"params": {
"expanded": {
"type": "Array",
"desc": "The expanded node keys",
"examples": [ "[ 'Node 1', 'Node 2' ]" ]
}
}
},
"lazy-load": {
"desc": "Emitted when the lazy loading of nodes is finished",
"params": {
"details": {
"type": "Object",
"desc": "Lazy loading details",
"definition": {
"node": {
"type": "Object",
"required": true,
"desc": "The node to which the new nodes (the children) will be appended"
},
"key": {
"type": "String",
"required": true,
"desc": "The key of the node getting the newly loaded child nodes",
"examples": [ "New Node" ]
},
"done": {
"type": "Function",
"required": true,
"desc": "The callback to be carried out when the loading is successful",
"params": {
"children": {
"type": "Array",
"desc": "Array of nodes",
"default": "[]"
}
},
"returns": null
},
"fail": {
"type": "Function",
"required": true,
"desc": "The callback to be carried out should the loading fails",
"params": null,
"returns": null
}
}
}
}
},
"update:ticked": {
"desc": "Emitted when nodes are ticked/unticked via the checkbox; Used by Vue on 'v-model:ticked' to update its value",
"params": {
"target": {
"type": "Array",
"desc": "The ticked node keys",
"examples": [ "[ 'Node 1', 'Node 2' ]" ]
}
}
},
"update:selected": {
"desc": "Emitted when selected node changes; Used by Vue on 'v-model:selected' to update its value",
"params": {
"target": {
"type": "Any",
"desc": "The selected node key",
"examples": [ "Node 1" ]
}
}
},
"after-show": {
"extends": "after-show"
},
"after-hide": {
"extends": "after-hide"
}
},
"methods": {
"getNodeByKey": {
"desc": "Get the node with the given key",
"params": {
"key": {
"type": "Any",
"required": true,
"desc": "The key of a node",
"examples": [ "Node 1" ]
}
},
"returns": {
"type": "Object",
"desc": "Requested node"
}
},
"getTickedNodes": {
"desc": "Get array of nodes that are ticked",
"returns": {
"type": "Array",
"desc": "Ticked node objects"
}
},
"getExpandedNodes": {
"desc": "Get array of nodes that are expanded",
"returns": {
"type": "Array",
"desc": "Expanded node objects"
}
},
"isExpanded": {
"desc": "Determine if a node is expanded",
"params": {
"key": {
"type": "Any",
"required": true,
"desc": "The key of a node",
"examples": [ "Node 1" ]
}
},
"returns": {
"type": "Boolean",
"desc": "Is specified node expanded?"
}
},
"expandAll": {
"desc": "Use to expand all branches of the tree"
},
"collapseAll": {
"desc": "Use to collapse all branches of the tree"
},
"setExpanded": {
"desc": "Expands the tree at the point of the node with the key given",
"params": {
"key": {
"type": "Any",
"required": true,
"desc": "The key of a node",
"examples": [ "Node 1" ]
},
"state": {
"type": "Boolean",
"required": true,
"desc": "Set to 'true' to expand the branch of the tree, otherwise 'false' collapses it"
}
}
},
"isTicked": {
"desc": "Method to check if a node's checkbox is selected or not",
"params": {
"key": {
"type": "Any",
"required": true,
"desc": "The key of a node",
"examples": [ "Node 1" ]
}
},
"returns": {
"type": "Boolean",
"desc": "Is specified node ticked?"
}
},
"setTicked": {
"desc": "Method to set a node's checkbox programmatically",
"params": {
"keys": {
"type": "Array",
"required": true,
"desc": "The keys of nodes to tick/untick",
"examples": [ "[ 'Node 1', 'Node 2' ]" ]
},
"state": {
"type": "Boolean",
"required": true,
"desc": "Set to 'true' to tick the checkbox of nodes, otherwise 'false' unticks them"
}
}
}
}
}