[483] | 1 | define(["dojo/_base/declare"], function(declare){ |
---|
| 2 | |
---|
| 3 | return declare("dijit.tree.model", null, { |
---|
| 4 | // summary: |
---|
| 5 | // Contract for any data provider object for the tree. |
---|
| 6 | // description: |
---|
| 7 | // Tree passes in values to the constructor to specify the callbacks. |
---|
| 8 | // "item" is typically a dojo/data/Item but it's just a black box so |
---|
| 9 | // it could be anything. |
---|
| 10 | // |
---|
| 11 | // This (like `dojo/data/api/Read`) is just documentation, and not meant to be used. |
---|
| 12 | |
---|
| 13 | destroy: function(){ |
---|
| 14 | // summary: |
---|
| 15 | // Destroys this object, releasing connections to the store |
---|
| 16 | // tags: |
---|
| 17 | // extension |
---|
| 18 | }, |
---|
| 19 | |
---|
| 20 | // ======================================================================= |
---|
| 21 | // Methods for traversing hierarchy |
---|
| 22 | |
---|
| 23 | getRoot: function(onItem){ |
---|
| 24 | // summary: |
---|
| 25 | // Calls onItem with the root item for the tree, possibly a fabricated item. |
---|
| 26 | // Throws exception on error. |
---|
| 27 | // tags: |
---|
| 28 | // extension |
---|
| 29 | }, |
---|
| 30 | |
---|
| 31 | mayHaveChildren: function(item){ |
---|
| 32 | // summary: |
---|
| 33 | // Tells if an item has or may have children. Implementing logic here |
---|
| 34 | // avoids showing +/- expando icon for nodes that we know don't have children. |
---|
| 35 | // (For efficiency reasons we may not want to check if an element actually |
---|
| 36 | // has children until user clicks the expando node) |
---|
| 37 | // item: dojo/data/Item |
---|
| 38 | // tags: |
---|
| 39 | // extension |
---|
| 40 | }, |
---|
| 41 | |
---|
| 42 | getChildren: function(parentItem, onComplete){ |
---|
| 43 | // summary: |
---|
| 44 | // Calls onComplete() with array of child items of given parent item, all loaded. |
---|
| 45 | // Throws exception on error. |
---|
| 46 | // parentItem: dojo/data/Item |
---|
| 47 | // onComplete: function(items) |
---|
| 48 | // tags: |
---|
| 49 | // extension |
---|
| 50 | }, |
---|
| 51 | |
---|
| 52 | // ======================================================================= |
---|
| 53 | // Inspecting items |
---|
| 54 | |
---|
| 55 | isItem: function(something){ |
---|
| 56 | // summary: |
---|
| 57 | // Returns true if *something* is an item and came from this model instance. |
---|
| 58 | // Returns false if *something* is a literal, an item from another model instance, |
---|
| 59 | // or is any object other than an item. |
---|
| 60 | // tags: |
---|
| 61 | // extension |
---|
| 62 | }, |
---|
| 63 | |
---|
| 64 | getIdentity: function(item){ |
---|
| 65 | // summary: |
---|
| 66 | // Returns identity for an item |
---|
| 67 | // tags: |
---|
| 68 | // extension |
---|
| 69 | }, |
---|
| 70 | |
---|
| 71 | getLabel: function(item){ |
---|
| 72 | // summary: |
---|
| 73 | // Get the label for an item |
---|
| 74 | // tags: |
---|
| 75 | // extension |
---|
| 76 | }, |
---|
| 77 | |
---|
| 78 | // ======================================================================= |
---|
| 79 | // Write interface |
---|
| 80 | |
---|
| 81 | newItem: function(args, parent, insertIndex, before){ |
---|
| 82 | // summary: |
---|
| 83 | // Creates a new item. See `dojo/data/api/Write` for details on args. |
---|
| 84 | // args: dijit/tree/dndSource.__Item |
---|
| 85 | // parent: Item |
---|
| 86 | // insertIndex: int? |
---|
| 87 | // Allows to insert the new item as the n'th child of `parent`. |
---|
| 88 | // before: Item? |
---|
| 89 | // Insert the new item as the previous sibling of this item. `before` must be a child of `parent`. |
---|
| 90 | // tags: |
---|
| 91 | // extension |
---|
| 92 | }, |
---|
| 93 | |
---|
| 94 | pasteItem: function(childItem, oldParentItem, newParentItem, bCopy, insertIndex, before){ |
---|
| 95 | // summary: |
---|
| 96 | // Move or copy an item from one parent item to another. |
---|
| 97 | // Used in drag & drop. |
---|
| 98 | // If oldParentItem is specified and bCopy is false, childItem is removed from oldParentItem. |
---|
| 99 | // If newParentItem is specified, childItem is attached to newParentItem. |
---|
| 100 | // childItem: Item |
---|
| 101 | // oldParentItem: Item |
---|
| 102 | // newParentItem: Item |
---|
| 103 | // bCopy: Boolean |
---|
| 104 | // insertIndex: int? |
---|
| 105 | // Allows to insert the new item as the n'th child of `parent`. |
---|
| 106 | // before: Item? |
---|
| 107 | // Insert the new item as the previous sibling of this item. `before` must be a child of `parent`. |
---|
| 108 | // tags: |
---|
| 109 | // extension |
---|
| 110 | }, |
---|
| 111 | |
---|
| 112 | // ======================================================================= |
---|
| 113 | // Callbacks |
---|
| 114 | |
---|
| 115 | onChange: function(item){ |
---|
| 116 | // summary: |
---|
| 117 | // Callback whenever an item has changed, so that Tree |
---|
| 118 | // can update the label, icon, etc. Note that changes |
---|
| 119 | // to an item's children or parent(s) will trigger an |
---|
| 120 | // onChildrenChange() so you can ignore those changes here. |
---|
| 121 | // item: dojo/data/Item |
---|
| 122 | // tags: |
---|
| 123 | // callback |
---|
| 124 | }, |
---|
| 125 | |
---|
| 126 | onChildrenChange: function(parent, newChildrenList){ |
---|
| 127 | // summary: |
---|
| 128 | // Callback to do notifications about new, updated, or deleted items. |
---|
| 129 | // parent: dojo/data/Item |
---|
| 130 | // newChildrenList: dojo/data/Item[] |
---|
| 131 | // tags: |
---|
| 132 | // callback |
---|
| 133 | } |
---|
| 134 | }); |
---|
| 135 | }); |
---|