-
Notifications
You must be signed in to change notification settings - Fork 34
Ancestry Extension
The store Ancestry extension adds an additional set of functions to both the Hierarchy and Object stores to explore the hierarchy and order of those stores.
* [Store Root versus Tree root](##store-root-versus-tree-root) * [Loading the Ancestry Extension](#loading-the-ancestry-extension) * [Ancestry Functions](#ancestry-functions) * [Sample Application](#sample-application)Throughout the documentation references are made to both the tree root as well as the store root. It is important to know that they are NOT the same thing. Store root item(s) identify so called top-level objects in the store, there can be as little as zero top-level objects (empty store) or as many as the number of store objects. A top-level store object is an object that does not have a parent object.
In reality, stores implementing the cbtree/store/api/Store
or dojo/store/api/Store
API do not have distinct root objects. In essence those stores are containers of
'items' were each item is a JavaScript Object. This also applies to the cbtree
hierarchy and Object stores however, they are able to derive the object
hierarchy using the store property parentProperty
and classify the objects as either:
- Top-level store objects.
- Non top-level store objects.
As stated before, top-level store objects are objects that do not have a parent reference, for example:
{ name:"Abe", lastName:"Simpson" }
{ name:"Abe", lastName:"Simpson", parent:null }
{ name:"Abe", lastName:"Simpson", parent:[] }
Non top-level store objects are objects that do have a parent reference and therefore are descendants (or children) of its parent(s):
{ name:"Homer", lastName:"Simpson", parent:["Abe"] }
{ name:"Bart", lastName:"Simpson", parent:["Homer", "Marge"] }
In any case, the following statement must always be true:
If object B is a descendant of object A, than object A is an ancestor of object B.
Please see the Data Hierachy section for more details on how to organize your data.
The tree root is a DOM element that may or may not be associated with a store object. The tree root is established by executing the root query of the store model and, depending on the type of store model, may represent an actual store object or a fabricated root object. See the Tree Store Model and Forest Store Model for more details.
However, in case the tree root is associated with an actual store object it still does not have to be a top-level store object. Again, it all depends on the root query.
Ancestry is implemented as an extension to the cbtree Natural, Hierarchy and Object stores and as such must to be loaded as a separate module. The following sample shows how to load the Ancestry extension. The Ancestry extension is located at cbtree/store/extensions/Ancestry
require(["cbtree/store/Hierarchy",
"cbtree/store/extensions/Ancestry"] // Load Ancestry extension
function( Hierarchy, Ancestry ) {
...
var myStore = new Hierarchy( { ... } );
}
);
If you instantiate your store declarative you MUST load the Ancestry extension
programmatically, this because it has no constructor and therefore can not be
instantiated by dojo/parser
. Note that, although in this case not strictly
required, we also list the hierarchy store as a dependency.
require(["dojo/parser", // dojo parser
"cbtree/store/Hierarchy", // The Hierarchy store
"cbtree/store/extensions/Ancestry" // The Ancestry extensions
]);
...
<body class="claro">
<div data-dojo-id="myStore" data-dojo-type="cbtree/store/Hierarchy" data-dojo-props=" ... "></div>
...
</body>
item: Object | Id
Store object or id to evaluate
idOnly: Boolean
Optional, If set to true only the ancestor ids are returned. The default is
false
.
returns: Object[] | void
If the item exists, an array of store object or ids otherwise undefined. If an empty array is returned (length=0) it indicates that item has no parents and therefore is considered a top-level item.
> Get all descendants (children, grandchildren, great-grandchildren, and so forth) > of a given item.
item: Object | Id
Store object or id to evaluate
idOnly: Boolean
Optional, If set to true only the descendant ids are returned. The default is
false
.
returns: Object[] | void
If the item exists, an array of store object or ids otherwise undefined. If an empty array is returned (length=0) it indicates that item has no parents and therefore is considered a top-level item.
> Returns the virtual path(s) of an item. Each path segment represents the > identifier of an ancestor with the exception of the last segment which is > the item identifier.
item: Object | Id
The item whose path(s) are to be returned. Item is either an object or an identifier.
separator: String
Optional, specifies the character to use for separating the path segments. Default is the forward slash (/).
returns: PathList
A PathList. If the item does not exist undefined is returned.
> Get the siblings of an item.
item: Object | Id
Store object or id to evaluate
idOnly: Boolean
Optional, If set to true only the sibling ids are returned. The default is
false
.
returns: Object[] | void
If the item exists, an array of store object or ids otherwise undefined. If an empty array is returned (length=0) it indicates that item has no siblings.
> Returns true if the object identified by argument `ancestor` is an ancestor > of the object identified by argument `item`.
ancestor: Object | Id
The ancestor Object or id
item: Object | Id
Child object or id to evaluate
returns: Boolean
true if ancestor is an ancestor of item otherwise false.
> Evaluate if objectA appears before objectB in the natural order of store objects.
itemA: Object | Id
The first Object or id
itemB: Object | Id
The second Object or id
returns: Boolean
true if itemA appears before itemB otherwise false.
> Evaluate if an item is a child (or immediate descendant) of a given parent.
item: Object | Id
Child object or id to evaluate
parent: Object | Id
The parent Object or id
returns: Boolean
true if the object is a child otherwise false.
> Evaluate if an item is a descendant of a given parent.
item: Object | Id
Child object or id to evaluate
ancestor: Object | Id
The ancestor Object or id
returns: Boolean
true if the child object is a descendant otherwise false.
> Returns true if the object identified by argument 'item' is the sibling of > the object identified by argument 'sibling'.
item: Object | Id
Store object or id to evaluate
sibling: Object | Id
The sibling Object or id
returns: Boolean
The following is demo application `cbtree/demos/store/tree30.html`.true if item is a sibling otherwise false.
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>The Store Hierarchy and Ancestry</title>
<style type="text/css">
@import "../../../dijit/themes/claro/claro.css";
@import "../../themes/claro/claro.css";
</style>
<script type="text/javascript">
var dojoConfig = {
baseUrl: "../../../",
packages: [
{ name: "dojo", location: "dojo" },
{ name: "dijit", location: "dijit" },
{ name: "cbtree",location: "cbtree" }
]
};
</script>
<script type="text/javascript" src="../../../dojo/dojo.js"></script>
<script type="text/javascript">
require([
"dojo/ready",
"cbtree/Tree", // Checkbox tree
"cbtree/model/TreeStoreModel", // Object Store Tree Model
"cbtree/store/Hierarchy", // The Hierarchy store
"cbtree/store/extensions/Ancestry" // Load the Ancestry extension
], function ( ready, Tree, TreeStoreModel, Hierarchy, Ancestry) {
var store = new Hierarchy( { url: "../../store/json/Simpsons.json", idProperty:"name"});
var model = new TreeStoreModel( { store: store,
query: {name: "Root"},
rootLabel: "The Family",
});
function checkBoxClicked( item, nodeWidget, event ) {
var descendants = store.getDescendants(item);
var ancestors = store.getAncestors(item, true);
var siblings = store.getSiblings(item);
var isDecendant = store.isDescendantOf(item,"Abe");
var isAncestor = store.isAncestorOf("Abe", item);
var paths = store.getPaths( item );
if (paths.length) {
var intersect = paths.intersect();
var contains = paths.contains( /Abe/);
var segments = paths.segments();
}
}
ready(function(){
var tree = new Tree( { model: model, id: "FamilyTree" }, "CheckboxTree" );
tree.on( "checkBoxClick", checkBoxClicked);
tree.startup();
});
});
</script>
</head>
<body class="claro">
<h1 class="DemoTitle">Store Hierarchy and Ancestry</h1>
<div id="CheckboxTree">
</div>
</body>
</html>
```