@apia/tree 2.0.9 → 2.0.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/OOTree/OOTreeChildren.d.ts +14 -0
- package/dist/OOTree/OOTreeChildren.d.ts.map +1 -0
- package/dist/OOTree/OOTreeChildren.js +17 -0
- package/dist/OOTree/OOTreeChildren.js.map +1 -0
- package/dist/OOTree/OOTreeNode.d.ts +30 -0
- package/dist/OOTree/OOTreeNode.d.ts.map +1 -0
- package/dist/OOTree/OOTreeNode.js +133 -0
- package/dist/OOTree/OOTreeNode.js.map +1 -0
- package/dist/OOTree/index.d.ts +36 -0
- package/dist/OOTree/index.d.ts.map +1 -0
- package/dist/OOTree/index.js +126 -0
- package/dist/OOTree/index.js.map +1 -0
- package/dist/OOTree/types.d.ts +11 -0
- package/dist/OOTree/types.d.ts.map +1 -0
- package/dist/SearchLabel.js +30 -0
- package/dist/SearchLabel.js.map +1 -0
- package/dist/Tree.d.ts +7 -0
- package/dist/Tree.d.ts.map +1 -0
- package/dist/Tree.js +131 -0
- package/dist/Tree.js.map +1 -0
- package/dist/TreeContext.d.ts +13 -0
- package/dist/TreeContext.d.ts.map +1 -0
- package/dist/TreeContext.js +22 -0
- package/dist/TreeContext.js.map +1 -0
- package/dist/TreeDataController.d.ts +116 -0
- package/dist/TreeDataController.d.ts.map +1 -0
- package/dist/TreeDataController.js +611 -0
- package/dist/TreeDataController.js.map +1 -0
- package/dist/TreeItem.js +51 -0
- package/dist/TreeItem.js.map +1 -0
- package/dist/TreeItemChildren.js +20 -0
- package/dist/TreeItemChildren.js.map +1 -0
- package/dist/TreeItemLabel.js +72 -0
- package/dist/TreeItemLabel.js.map +1 -0
- package/dist/getDomProps.js +37 -0
- package/dist/getDomProps.js.map +1 -0
- package/dist/index.d.ts +7 -417
- package/dist/index.js +6 -1546
- package/dist/index.js.map +1 -1
- package/dist/renderers/DefaultIconRenderer.js +17 -0
- package/dist/renderers/DefaultIconRenderer.js.map +1 -0
- package/dist/renderers/DefaultLabelRenderer.js +9 -0
- package/dist/renderers/DefaultLabelRenderer.js.map +1 -0
- package/dist/renderers/Spacer.js +9 -0
- package/dist/renderers/Spacer.js.map +1 -0
- package/dist/types.d.ts +211 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/useTreeData.d.ts +25 -0
- package/dist/useTreeData.d.ts.map +1 -0
- package/dist/useTreeData.js +129 -0
- package/dist/useTreeData.js.map +1 -0
- package/dist/util.js +210 -0
- package/dist/util.js.map +1 -0
- package/package.json +3 -3
package/dist/index.d.ts
CHANGED
|
@@ -1,418 +1,8 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
onArrowUpOnFirstElement: boolean;
|
|
9
|
-
expandNode: NodeType;
|
|
10
|
-
mustFocus: TId;
|
|
11
|
-
stateUpdate: null;
|
|
12
|
-
}> {
|
|
13
|
-
name: string;
|
|
14
|
-
propsStore: PropsStore<NodeType>;
|
|
15
|
-
_configuration: RefObject<TTreeDataControllerConfig<NodeProps, NodeType>>;
|
|
16
|
-
get configuration(): {
|
|
17
|
-
current: TTreeDataControllerConfig<NodeProps, NodeType> | null;
|
|
18
|
-
};
|
|
19
|
-
hasApendedFirstChild: boolean;
|
|
20
|
-
/**
|
|
21
|
-
* Este array se usa para conocer los padres faltantes al momento de la
|
|
22
|
-
* construcción del árbol, de forma de optimizar el proceso
|
|
23
|
-
*/
|
|
24
|
-
missingParents: TId[];
|
|
25
|
-
nonEmittedUpdates: TId[];
|
|
26
|
-
get state(): TTreeDataControllerState;
|
|
27
|
-
stateKey: string;
|
|
28
|
-
get stateStore(): PropsStore<TTreeDataControllerState>;
|
|
29
|
-
constructor(name: string, configuration: RefObject<Partial<TTreeDataControllerConfig<NodeProps, NodeType>>>, propsStore?: PropsStore<NodeType>);
|
|
30
|
-
destructor(): void;
|
|
31
|
-
append(node: Omit<TModify<NodeType, {
|
|
32
|
-
children?: NodeType['children'];
|
|
33
|
-
parentId?: NodeType['parentId'];
|
|
34
|
-
}>, 'nodeProps' | 'actualParentId'> & Partial<Pick<NodeType, 'nodeProps'>>): void;
|
|
35
|
-
/**
|
|
36
|
-
* Cuando se quieren agregar muchos nodos, es conveniente llamar primero al
|
|
37
|
-
* método batchInit y luego de finalizar, al método batchFinish()
|
|
38
|
-
*/
|
|
39
|
-
batchInit(): void;
|
|
40
|
-
private getNodesRecursive;
|
|
41
|
-
/**
|
|
42
|
-
* Cuando se quieren agregar muchos nodos, es conveniente llamar primero al
|
|
43
|
-
* método batchInit y luego de finalizar, al método batchFinish()
|
|
44
|
-
*/
|
|
45
|
-
batchFinish(): void;
|
|
46
|
-
config(newConf: Partial<TTreeDataControllerConfig<NodeProps, NodeType>>): void;
|
|
47
|
-
deselectAll(): void;
|
|
48
|
-
forceEmitUpdate(): void;
|
|
49
|
-
getInitialState(): TTreeDataControllerState;
|
|
50
|
-
getNodesAsArray(): NodeType[];
|
|
51
|
-
/**
|
|
52
|
-
* Devuelve un array que contiene el id de todos los nodos pertenecientes al
|
|
53
|
-
* árbol
|
|
54
|
-
*/
|
|
55
|
-
getNodesIds(): string[];
|
|
56
|
-
getParentId(parentId: TId): TId;
|
|
57
|
-
/**
|
|
58
|
-
* Este método permite controlar el comportamiento con el teclado desde fuera
|
|
59
|
-
* del componente.
|
|
60
|
-
*/
|
|
61
|
-
handleKey(ev: React__default.KeyboardEvent): void;
|
|
62
|
-
isNode(node: NodeType | TDataNodeContainer<NodeProps> | TId): node is NodeType;
|
|
63
|
-
isNodeContainer(node: NodeType | TDataNodeContainer<NodeProps> | TId): node is TDataNodeContainer<NodeProps>;
|
|
64
|
-
includes(searchNode: NodeType): boolean;
|
|
65
|
-
initRoot(): void;
|
|
66
|
-
move(moveNode: TId, destinationNode: TId, afterOrBefore?: TRequireOnlyOne<{
|
|
67
|
-
after: NodeType | TId;
|
|
68
|
-
before: NodeType | TId;
|
|
69
|
-
position: number;
|
|
70
|
-
}>): void;
|
|
71
|
-
/**
|
|
72
|
-
* Borra el nodo del árbol, y dependiendo del parámetro removeChildren, borra
|
|
73
|
-
* también sus hijos.
|
|
74
|
-
*
|
|
75
|
-
* @param removeChildren - Si se pasa en false, los nodos hijos son movidos al root
|
|
76
|
-
*/
|
|
77
|
-
remove(removeNode: NodeType | TId, removeChildren?: boolean): void;
|
|
78
|
-
removeMultiple(nodes: TId[], removeChildren?: boolean): void;
|
|
79
|
-
previousNodes: TId[];
|
|
80
|
-
/**
|
|
81
|
-
* Borra todos los nodos del árbol.
|
|
82
|
-
*/
|
|
83
|
-
removeAll(): void;
|
|
84
|
-
selectAll(): void;
|
|
85
|
-
setExpandedNodes(nodes: TId[]): void;
|
|
86
|
-
setFocusedNode(key: TId, avoidSelection?: boolean): void;
|
|
87
|
-
setSelectedNodes(nodes: TId[], force?: boolean): void;
|
|
88
|
-
setSelectedNodesByClickEvent(ev: React__default.MouseEvent): void;
|
|
89
|
-
setState: (updateProps: Partial<TTreeDataControllerState>, conf?: TUpdateFieldConfiguration) => void;
|
|
90
|
-
useState: <T>(selector: (state: TTreeDataControllerState) => T) => T;
|
|
91
|
-
toggleNodeExpandedState(key: TId, shouldExpand?: boolean): void;
|
|
92
|
-
toggleNodeSelectedState(key: TId, isSelected?: boolean): void;
|
|
93
|
-
}
|
|
94
|
-
/**
|
|
95
|
-
* Este hook permite escuchar las props de un árbol, para ello es necesario
|
|
96
|
-
* pasar el handler.
|
|
97
|
-
*
|
|
98
|
-
* @param handler
|
|
99
|
-
* @param configuration
|
|
100
|
-
* @returns
|
|
101
|
-
*/
|
|
102
|
-
declare function useTreeSelector<NodeProps extends Record<string, unknown> = Record<string, unknown>, NodeType extends TDataNode<NodeProps> = TDataNode<NodeProps>, Selected = Record<string, unknown>, PropsType extends Record<string, unknown> = TTreeDataControllerState>(handler: TreeDataController<NodeProps, NodeType>, configuration?: TPropsConfiguration<Selected, PropsType>): Selected;
|
|
103
|
-
/**
|
|
104
|
-
* Este hook permite escuchar las props de un árbol, para ello es necesario
|
|
105
|
-
* pasar el handler.
|
|
106
|
-
*
|
|
107
|
-
* @param handler
|
|
108
|
-
* @param configuration
|
|
109
|
-
* @returns
|
|
110
|
-
*/
|
|
111
|
-
declare function useTreeSelectorByName<NodeProps extends Record<string, unknown> = Record<string, unknown>, NodeType extends TDataNode<NodeProps> = TDataNode<NodeProps>, Selected = Record<string, unknown>, PropsType extends Record<string, unknown> = TTreeDataControllerState>(treeName: string, configuration?: TPropsConfiguration<Selected, PropsType>): {
|
|
112
|
-
handler: TreeDataController<NodeProps, NodeType>;
|
|
113
|
-
selection: Selected;
|
|
114
|
-
};
|
|
115
|
-
|
|
116
|
-
type TId = string | number;
|
|
117
|
-
type TDataNodeContainer<NodeProps extends Record<string, unknown> = Record<string, unknown>> = Pick<TDataNode<NodeProps>, 'children' | 'id'>;
|
|
118
|
-
type TTreeDataControllerConfig<NodeProps extends Record<string, unknown> = Record<string, unknown>, NodeType extends TDataNode<NodeProps> = TDataNode<NodeProps>> = {
|
|
119
|
-
emitUpdates?: boolean;
|
|
120
|
-
} & Pick<TTreeProps<NodeProps, NodeType>, 'isMultiple' | 'onLoadData' | 'onExpand' | 'disableSelection' | 'selectionMode'>;
|
|
121
|
-
type TTreeDataControllerState = {
|
|
122
|
-
expandedNodes: TId[];
|
|
123
|
-
filteredNodes: TId[];
|
|
124
|
-
focusedNode: TId | null;
|
|
125
|
-
isLoading: boolean;
|
|
126
|
-
length: number;
|
|
127
|
-
selectedNodes: TId[];
|
|
128
|
-
};
|
|
129
|
-
type TTreeLabelRenderer<NodeProps extends Record<string, unknown> = Record<string, unknown>> = React__default.FunctionComponent<TDataNode<NodeProps> & {
|
|
130
|
-
level: number;
|
|
131
|
-
}>;
|
|
132
|
-
type TNodesExpandEvent<NodeProps extends Record<string, unknown> = Record<string, unknown>> = TDataNode<NodeProps>;
|
|
133
|
-
type TNodesSelectionEvent<NodeProps extends Record<string, unknown> = Record<string, unknown>> = TDataNode<NodeProps>[];
|
|
134
|
-
type TTreeProps<NodeProps extends Record<string, unknown> = Record<string, unknown>, NodeType extends TDataNode<NodeProps> = TDataNode<NodeProps>> = {
|
|
135
|
-
/**
|
|
136
|
-
* Debe ser un texto descriptivo, se usa para las personas no videntes
|
|
137
|
-
* principalmente.
|
|
138
|
-
*/
|
|
139
|
-
label: string;
|
|
140
|
-
name: string;
|
|
141
|
-
} & Partial<{
|
|
142
|
-
className: string;
|
|
143
|
-
/**
|
|
144
|
-
* Permite pasar un controller propio.
|
|
145
|
-
*/
|
|
146
|
-
controller?: TreeDataController<NodeProps, NodeType>;
|
|
147
|
-
disableSelection: boolean;
|
|
148
|
-
/**
|
|
149
|
-
* Si se pasa un filterString !== undefined => los nodos del árbol cuyo label
|
|
150
|
-
* no coincida serán ocultados, a menos que alguno de sus hijos si coincida.
|
|
151
|
-
*/
|
|
152
|
-
filterString: string;
|
|
153
|
-
/**
|
|
154
|
-
* Es posible alterar el comportamiento por defecto cada vez que el usuario
|
|
155
|
-
* selecciona un elemento de la lista mediante esta función, indicando al tree
|
|
156
|
-
* sobre qué elemento debe colocar el foco.
|
|
157
|
-
*
|
|
158
|
-
* Esta función debe tomar el liElement que recibe como parámetro y mediante
|
|
159
|
-
* querySelectors o el método que se considere correcto devolver la referencia
|
|
160
|
-
* al hijo sobre el cual se desea colocar el foco.
|
|
161
|
-
*
|
|
162
|
-
* @param liElement - Es el li que renderiza el nodo. Los hijos más importantes de este li son:
|
|
163
|
-
*
|
|
164
|
-
* - .tree__nodeItemLabel: Es el wrapper del botón de expandir, del ícono
|
|
165
|
-
* del nodo y del (custom?)Renderer. - ul[role="group"]: Es el wrapper de
|
|
166
|
-
* todos los hijos del nodo actual.*/
|
|
167
|
-
focusGetter: (liElement: HTMLElement) => HTMLElement;
|
|
168
|
-
/**
|
|
169
|
-
* Esta función es llamada cuando el árbol inicializó con la referencia al
|
|
170
|
-
* handler como parámetro.
|
|
171
|
-
*/
|
|
172
|
-
getHandler: (handler: TreeDataController<NodeProps, NodeType>) => unknown;
|
|
173
|
-
/**
|
|
174
|
-
* Permite ocultar todos los nodos de tipo folder que no tengan hijos.
|
|
175
|
-
*/
|
|
176
|
-
hideEmptyFolders: boolean;
|
|
177
|
-
/**
|
|
178
|
-
* Permite ocultar la etiqueta de búsqueda
|
|
179
|
-
*/
|
|
180
|
-
hideSearchLabel: boolean;
|
|
181
|
-
initialNodes: NodeType[];
|
|
182
|
-
/**
|
|
183
|
-
* Pone el mismo spinner que mientras está en modo batch.
|
|
184
|
-
*/
|
|
185
|
-
isLoading: boolean;
|
|
186
|
-
/**
|
|
187
|
-
* Habilita la selección múltiple, por defecto está deshabilitada.
|
|
188
|
-
*/
|
|
189
|
-
isMultiple: boolean;
|
|
190
|
-
/**
|
|
191
|
-
* Este callback es llamado cuando se presiona la flecha arriba en el primer
|
|
192
|
-
* elemento del árbol. Está pensado para mover el foco hacia el cuadro de
|
|
193
|
-
* búsqueda.
|
|
194
|
-
*/
|
|
195
|
-
onArrowUpOnFirstElement?: () => unknown;
|
|
196
|
-
onDeleteFilterString?: () => unknown;
|
|
197
|
-
onExpand: (ev: TNodesExpandEvent<NodeProps>) => unknown;
|
|
198
|
-
/**
|
|
199
|
-
* Esta función debe devolver una promesa. Cuando se expande un nodo que no
|
|
200
|
-
* tiene hijos, esta función es llamada y el nodo es puesto en estado de carga
|
|
201
|
-
* hasta que la promesa se resuelve.
|
|
202
|
-
*/
|
|
203
|
-
onLoadData: (node: NodeType) => Promise<void>;
|
|
204
|
-
/**
|
|
205
|
-
* Cada vez que se hace click sobre un nodo o se presiona enter estando
|
|
206
|
-
* éste en foco, se llama este callback informando de la acción.
|
|
207
|
-
*/
|
|
208
|
-
onNodeClick: (ev: React__default.KeyboardEvent | React__default.MouseEvent, node: NodeType) => unknown;
|
|
209
|
-
onSelect: (ev: TNodesSelectionEvent<NodeProps>) => unknown;
|
|
210
|
-
/**
|
|
211
|
-
* Si se pasa **onFocus**, el nodo será seleccionado al recibir foco (por
|
|
212
|
-
* ejemplo, al navegarlo con las flechas).
|
|
213
|
-
*
|
|
214
|
-
* Si se pasa **explicit**, solamente se
|
|
215
|
-
* hará seleccionará al hacerle click (o presionar enter o espacio).
|
|
216
|
-
*
|
|
217
|
-
* Si se pasa **explicitMultiple**, solamente se hará selección al hacer
|
|
218
|
-
* click o presionar enter o espacio, y además la selección múltiple solamente
|
|
219
|
-
* funcionará si las teclas Shift o Ctrl están presionadas.
|
|
220
|
-
*
|
|
221
|
-
* @default "onFocus"
|
|
222
|
-
*/
|
|
223
|
-
selectionMode: 'onFocus' | 'explicit' | 'explicitMultiple';
|
|
224
|
-
/**
|
|
225
|
-
* Si se pasa en false, los nodos padre solamente se podrán expandir/colapsar
|
|
226
|
-
* al hacer click en los íconos.
|
|
227
|
-
*/
|
|
228
|
-
toggleNodesOnLabelClick: boolean;
|
|
229
|
-
variant: string;
|
|
230
|
-
}>;
|
|
231
|
-
type TTreeIconRenderer<NodeProps extends Record<string, unknown> = Record<string, unknown>> = React__default.FunctionComponent<TDataNode<NodeProps>>;
|
|
232
|
-
type TDataNode<NodeProps extends Record<string, unknown> = Record<string, unknown>> = {
|
|
233
|
-
actualParentId?: TId;
|
|
234
|
-
children: TId[];
|
|
235
|
-
id: TId;
|
|
236
|
-
label: string;
|
|
237
|
-
/**
|
|
238
|
-
* Un objeto arbitrario con propiedades de nodo que no están relacionados a
|
|
239
|
-
* la estructura del árbol, sino de la estructura de información que
|
|
240
|
-
* representa.
|
|
241
|
-
*/
|
|
242
|
-
nodeProps: NodeProps;
|
|
243
|
-
parentId: TId;
|
|
244
|
-
} & Partial<{
|
|
245
|
-
/**
|
|
246
|
-
* Con esta prop se puede evitar que el nodo sea colapsado desde el label
|
|
247
|
-
*/
|
|
248
|
-
allowToggleExpandedFromLabel?: boolean;
|
|
249
|
-
className?: string;
|
|
250
|
-
color?: string;
|
|
251
|
-
/**
|
|
252
|
-
* Esta prop marca que ya se pidieron los datos mediante onLoadData para este
|
|
253
|
-
* nodo.
|
|
254
|
-
*/
|
|
255
|
-
hasLoaded: boolean;
|
|
256
|
-
/**
|
|
257
|
-
* El icon puede ser el nombre de uno de los elementos del mapa de íconos de
|
|
258
|
-
* Icon.tsx o un TTreeIconRenderer que permite utilizar un componente para
|
|
259
|
-
* renderizar el ícono.*/
|
|
260
|
-
icon: TIconName | TTreeIconRenderer<NodeProps>;
|
|
261
|
-
/**
|
|
262
|
-
* Este string se usa como height y width del ícono, de modo que se puede
|
|
263
|
-
* pasar cualquier expresión válida de ThemeUI.
|
|
264
|
-
*/
|
|
265
|
-
iconSize: string;
|
|
266
|
-
/**
|
|
267
|
-
* Cuando un nodo está deshabilitado, no se pondrá foco en él.
|
|
268
|
-
*/
|
|
269
|
-
isDisabled: boolean;
|
|
270
|
-
/**
|
|
271
|
-
* Indica si un nodo está o no expandido, en caso de que se establezca en
|
|
272
|
-
* true, el mismo será expandido. Esto puede ser útil para controlar el árbol
|
|
273
|
-
* desde fuera, en cuyo caso se deben modificar las propiedades mediante
|
|
274
|
-
* handler.propsStore.updateField(node.id, { newProps }).
|
|
275
|
-
*/
|
|
276
|
-
isExpanded: boolean;
|
|
277
|
-
/**
|
|
278
|
-
* Indica que el nodo no debe mostrarse ya que no coincide con los criterios
|
|
279
|
-
* de filtrado.
|
|
280
|
-
*/
|
|
281
|
-
isFiltered: boolean;
|
|
282
|
-
/**
|
|
283
|
-
* Indica si un nodo está en foco, es importante notar que alterar esta
|
|
284
|
-
* propiedad no va a alterar qué nodo del árbol está en foco ya que ese
|
|
285
|
-
* control lo hace internamente el árbol. En caso de querer modificar esto en
|
|
286
|
-
* forma externa, se deben usar los métodos correspondientes del handler.
|
|
287
|
-
*/
|
|
288
|
-
isFocused: boolean;
|
|
289
|
-
/**
|
|
290
|
-
* Esta prop se usa para decir que un nodo es un sub-árbol, aún cuando no
|
|
291
|
-
* tiene hijos. Esto es especialmente útil cuando se quiere hacer carga
|
|
292
|
-
* asíncrona de datos, ya que al expandirse, se llamará al método onLoadData
|
|
293
|
-
* del tree.
|
|
294
|
-
*/
|
|
295
|
-
isLeaf: boolean;
|
|
296
|
-
/**
|
|
297
|
-
* Se setea en true al momento de llamar a onLoadData y en false al finalizar
|
|
298
|
-
* la carga de datos.
|
|
299
|
-
*/
|
|
300
|
-
isLoading: boolean;
|
|
301
|
-
/**
|
|
302
|
-
* Por defecto todos los nodos son seleccionables, se debe pasar false
|
|
303
|
-
* explícitamente para deshabilitar la selección.
|
|
304
|
-
*/
|
|
305
|
-
isSelectable: boolean;
|
|
306
|
-
/**
|
|
307
|
-
* Indica si un nodo está o no seleccionado. Esto puede ser útil para
|
|
308
|
-
* controlar el árbol desde fuera, en cuyo caso se deben modificar las
|
|
309
|
-
* propiedades mediante handler.propsStore.updateField(node.id, { newProps }).
|
|
310
|
-
*/
|
|
311
|
-
isSelected: boolean;
|
|
312
|
-
/**
|
|
313
|
-
* Si se pasa un labelRenderer se utilizará en lugar de
|
|
314
|
-
* DefaultLabelRenderer.tsx. El labelRenderer es el responsable de hacer caso
|
|
315
|
-
* de los eventos de click para la selección del nodo.
|
|
316
|
-
*/
|
|
317
|
-
labelRenderer: TTreeLabelRenderer<NodeProps>;
|
|
318
|
-
title: string;
|
|
319
|
-
}>;
|
|
320
|
-
|
|
321
|
-
declare const _default: <NodeProps extends Record<string, unknown> = Record<string, unknown>, NodeType extends TDataNode<NodeProps> = TDataNode<NodeProps>>(props: TTreeProps<NodeProps, NodeType>) => React__default.JSX.Element;
|
|
322
|
-
|
|
323
|
-
type TTreeContext<NodeProps extends Record<string, unknown> = Record<string, unknown>, NodeType extends TDataNode<NodeProps> = TDataNode<NodeProps>> = {
|
|
324
|
-
forceUpdate: number;
|
|
325
|
-
name: string;
|
|
326
|
-
handler: TreeDataController<NodeProps, NodeType>;
|
|
327
|
-
treeProps: TTreeProps<NodeProps, NodeType>;
|
|
328
|
-
} & Pick<TTreeProps, 'focusGetter'>;
|
|
329
|
-
declare function useTreeContext<NodeProps extends Record<string, unknown> = Record<string, unknown>, NodeType extends TDataNode<NodeProps> = TDataNode<NodeProps>>(): TTreeContext<NodeProps, NodeType>;
|
|
330
|
-
|
|
331
|
-
interface IUseTreeData<NodeProps extends Record<string, unknown> = Record<string, unknown>, NodeType extends TDataNode<NodeProps> = TDataNode<NodeProps>> {
|
|
332
|
-
name: string;
|
|
333
|
-
treeProps: TTreeProps<NodeProps, NodeType>;
|
|
334
|
-
}
|
|
335
|
-
declare function useTreeData<NodeProps extends Record<string, unknown> = Record<string, unknown>, NodeType extends TDataNode<NodeProps> = TDataNode<NodeProps>>({ name, treeProps }: IUseTreeData<NodeProps, NodeType>): {
|
|
336
|
-
data: {
|
|
337
|
-
children: number[];
|
|
338
|
-
forceUpdate: number;
|
|
339
|
-
};
|
|
340
|
-
handler: TreeDataController<NodeProps, NodeType>;
|
|
341
|
-
keyHandler: {
|
|
342
|
-
id: string;
|
|
343
|
-
onKeyDown: (ev: React__default.KeyboardEvent) => void;
|
|
344
|
-
onMouseDown: (ev: React__default.MouseEvent) => void;
|
|
345
|
-
onClick: (ev: React__default.MouseEvent) => void;
|
|
346
|
-
ref: React__default.MutableRefObject<HTMLDivElement | null>;
|
|
347
|
-
};
|
|
348
|
-
};
|
|
349
|
-
|
|
350
|
-
type PrefixMapEntry = {
|
|
351
|
-
nodeId: TId;
|
|
352
|
-
prefix: string;
|
|
353
|
-
};
|
|
354
|
-
type TOOTreeNodeProps<NodeProps extends Record<string, unknown> = Record<string, unknown>> = Omit<TDataNode<NodeProps>, 'actualParentId' | 'parentId' | 'children' | 'hasLoaded'>;
|
|
355
|
-
type TSortOOTreeChildren<NodeProps extends Record<string, unknown> = Record<string, unknown>> = (a: TDataNode<NodeProps>, b: TDataNode<NodeProps>) => number;
|
|
356
|
-
|
|
357
|
-
declare function isOOTreeNode<NodeProps extends Record<string, unknown> = Record<string, unknown>>(element: OOTreeNode<NodeProps> | TDataNode<NodeProps>): element is OOTreeNode<NodeProps>;
|
|
358
|
-
declare class OOTreeNode<NodeProps extends Record<string, unknown> = Record<string, unknown>> {
|
|
359
|
-
#private;
|
|
360
|
-
protected tree: OOTree<NodeProps>;
|
|
361
|
-
protected parent: OOTreeNode<NodeProps> | TDataNode<NodeProps> | null;
|
|
362
|
-
protected props: TOOTreeNodeProps<NodeProps>;
|
|
363
|
-
id: string;
|
|
364
|
-
prefix: string;
|
|
365
|
-
constructor(tree: OOTree<NodeProps>, parent: OOTreeNode<NodeProps> | TDataNode<NodeProps> | null, props: TOOTreeNodeProps<NodeProps>);
|
|
366
|
-
attachToTree(): void;
|
|
367
|
-
append(props: TOOTreeNodeProps<NodeProps>): OOTreeNode<NodeProps>;
|
|
368
|
-
collapse(): void;
|
|
369
|
-
expand(): void;
|
|
370
|
-
focus(expand?: boolean): void;
|
|
371
|
-
getAll(): (() => OOTreeNode<NodeProps> | undefined)[];
|
|
372
|
-
getById(id: TId): OOTreeNode<NodeProps> | undefined;
|
|
373
|
-
getOriginalId(): string;
|
|
374
|
-
getParent(): OOTreeNode<NodeProps> | null;
|
|
375
|
-
getProps(): TDataNode<NodeProps>;
|
|
376
|
-
remove(): void;
|
|
377
|
-
sort(sortFunction: TSortOOTreeChildren<NodeProps>): void;
|
|
378
|
-
update(props: Partial<Omit<TOOTreeNodeProps<NodeProps>, 'id'>>): void;
|
|
379
|
-
}
|
|
380
|
-
|
|
381
|
-
declare class OOTreeChildren<NodeProps extends Record<string, unknown> = Record<string, unknown>> extends OOTreeNode<NodeProps> {
|
|
382
|
-
protected tree: OOTree<NodeProps, any>;
|
|
383
|
-
constructor(tree: OOTree<NodeProps, any>);
|
|
384
|
-
/**
|
|
385
|
-
* Se sobreescribe para evitar problemas
|
|
386
|
-
*/
|
|
387
|
-
expand(): void;
|
|
388
|
-
}
|
|
389
|
-
|
|
390
|
-
declare class OOTree<NodeProps extends Record<string, unknown> = Record<string, unknown>, Events extends Record<string, unknown> = Record<string, unknown>> extends EventEmitter<Events> {
|
|
391
|
-
#private;
|
|
392
|
-
props: TTreeProps<NodeProps>;
|
|
393
|
-
constructor(props: TTreeProps<NodeProps>);
|
|
394
|
-
getChildren: () => OOTreeChildren<NodeProps>;
|
|
395
|
-
getController: () => TreeDataController<NodeProps, TDataNode<NodeProps>>;
|
|
396
|
-
Component: (props: Partial<TTreeProps<NodeProps>>) => React.JSX.Element;
|
|
397
|
-
/**
|
|
398
|
-
* Data manipulation
|
|
399
|
-
*/
|
|
400
|
-
private prefixJoinCharacter;
|
|
401
|
-
private prefixWithIdJoinCharacter;
|
|
402
|
-
protected prefixesMap: Record<string, PrefixMapEntry>;
|
|
403
|
-
calculateDepth: (id: TId$1) => number;
|
|
404
|
-
/**
|
|
405
|
-
* Calcula el prefijo de un nodo que se está agregando al árbol evitando
|
|
406
|
-
* colisiones. Ese prefijo estará asociado a cada nodo y se utilizará para dar
|
|
407
|
-
* nombres únicos a sus hijos, no para el nodo en sí. Entonces, cada vez que
|
|
408
|
-
* se construye un nodo, se le asigna un prefijo considerando el prefijo de su
|
|
409
|
-
* padre, pero su nombre se hace a partir del prefijo del padre y su id.
|
|
410
|
-
*/
|
|
411
|
-
calculateNodePrefix: (id: TId$1, prefix?: string) => {
|
|
412
|
-
prefix: string;
|
|
413
|
-
id: string;
|
|
414
|
-
};
|
|
415
|
-
}
|
|
416
|
-
|
|
417
|
-
export { OOTree, OOTreeNode, type TDataNode, type TNodesSelectionEvent, type TTreeLabelRenderer, type TTreeProps, _default as Tree, TreeDataController, isOOTreeNode, useTreeContext, useTreeData, useTreeDataController, useTreeSelector, useTreeSelectorByName };
|
|
1
|
+
export { default as Tree } from './Tree.js';
|
|
2
|
+
export { useTreeContext } from './TreeContext.js';
|
|
3
|
+
export { default as TreeDataController, useTreeDataController, useTreeSelector, useTreeSelectorByName } from './TreeDataController.js';
|
|
4
|
+
export { default as useTreeData } from './useTreeData.js';
|
|
5
|
+
export { TDataNode, TTreeLabelRenderer, TTreeProps } from './types.js';
|
|
6
|
+
export { OOTree } from './OOTree/index.js';
|
|
7
|
+
export { OOTreeNode, isOOTreeNode } from './OOTree/OOTreeNode.js';
|
|
418
8
|
//# sourceMappingURL=index.d.ts.map
|