UNPKG

devextreme

Version:

HTML5 JavaScript Component Suite for Responsive Web Development

233 lines (232 loc) • 7.3 kB
/** * DevExtreme (esm/ui/diagram/diagram.items_option.js) * Version: 21.1.4 * Build date: Mon Jun 21 2021 * * Copyright (c) 2012 - 2021 Developer Express Inc. ALL RIGHTS RESERVED * Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/ */ import { extend } from "../../core/utils/extend"; import { Component } from "../../core/component"; import DataHelperMixin from "../../data_helper"; var ItemsOptionBase = Component.inherit({}).include(DataHelperMixin); class ItemsOption extends ItemsOptionBase { constructor(diagramWidget) { super(); this._diagramWidget = diagramWidget; this._resetCache() } _dataSourceChangedHandler(newItems, e) { this._resetCache(); this._items = newItems.map(item => extend(true, {}, item)); this._dataSourceItems = newItems.slice(); if (e && e.changes) { var internalChanges = e.changes.filter(change => change.internalChange); var externalChanges = e.changes.filter(change => !change.internalChange); if (internalChanges.length) { this._reloadContentByChanges(internalChanges, false) } if (externalChanges.length) { this._reloadContentByChanges(externalChanges, true) } } else { this._diagramWidget._onDataSourceChanged() } } _dataSourceLoadingChangedHandler(isLoading) { if (isLoading && !this._dataSource.isLoaded()) { this._diagramWidget._showLoadingIndicator() } else { this._diagramWidget._hideLoadingIndicator() } } _prepareData(dataObj) { for (var key in dataObj) { if (!Object.prototype.hasOwnProperty.call(dataObj, key)) { continue } if (void 0 === dataObj[key]) { dataObj[key] = null } } return dataObj } insert(data, callback, errorCallback) { this._resetCache(); var store = this._getStore(); store.insert(this._prepareData(data)).done((data, key) => { store.push([{ type: "insert", key: key, data: data, internalChange: true }]); if (callback) { callback(data) } this._resetCache() }).fail(error => { if (errorCallback) { errorCallback(error) } this._resetCache() }) } update(key, data, callback, errorCallback) { var store = this._getStore(); var storeKey = this._getStoreKey(store, key, data); store.update(storeKey, this._prepareData(data)).done((data, key) => { store.push([{ type: "update", key: key, data: data, internalChange: true }]); if (callback) { callback(key, data) } }).fail(error => { if (errorCallback) { errorCallback(error) } }) } remove(key, data, callback, errorCallback) { this._resetCache(); var store = this._getStore(); var storeKey = this._getStoreKey(store, key, data); store.remove(storeKey).done(key => { store.push([{ type: "remove", key: key, internalChange: true }]); if (callback) { callback(key) } this._resetCache() }).fail(error => { if (errorCallback) { errorCallback(error) } this._resetCache() }) } findItem(itemKey) { if (!this._items) { return null } return this._getItemByKey(itemKey) } getItems() { return this._items } hasItems() { return !!this._items } _reloadContentByChanges(changes, isExternalChanges) { changes = changes.map(change => extend(change, { internalKey: this._getInternalKey(change.key) })); this._diagramWidget._reloadContentByChanges(changes, isExternalChanges) } _getItemByKey(key) { this._ensureCache(); var cache = this._cache; var index = this._getIndexByKey(key); return cache.items[index] } _getIndexByKey(key) { this._ensureCache(); var cache = this._cache; if ("object" === typeof key) { for (var i = 0, length = cache.keys.length; i < length; i++) { if (cache.keys[i] === key) { return i } } } else { var keySet = cache.keySet || cache.keys.reduce((accumulator, key, index) => { accumulator[key] = index; return accumulator }, {}); if (!cache.keySet) { cache.keySet = keySet } return keySet[key] } return -1 } _ensureCache() { var cache = this._cache; if (!cache.keys) { cache.keys = []; cache.items = []; this._fillCache(cache, this._items) } } _fillCache(cache, items) { if (!items || !items.length) { return } var keyExpr = this._getKeyExpr(); if (keyExpr) { items.forEach(item => { cache.keys.push(keyExpr(item)); cache.items.push(item) }) } var itemsExpr = this._getItemsExpr(); if (itemsExpr) { items.forEach(item => this._fillCache(cache, itemsExpr(item))) } var containerChildrenExpr = this._getContainerChildrenExpr(); if (containerChildrenExpr) { items.forEach(item => this._fillCache(cache, containerChildrenExpr(item))) } } _getKeyExpr() { throw "Not Implemented" } _getItemsExpr() {} _getContainerChildrenExpr() {} _initDataSource() { super._initDataSource(); this._dataSource && this._dataSource.paginate(false) } _dataSourceOptions() { return { paginate: false } } _getStore() { return this._dataSource && this._dataSource.store() } _getStoreKey(store, internalKey, data) { var storeKey = store.keyOf(data); if (storeKey === data) { var keyExpr = this._getKeyExpr(); this._dataSourceItems.forEach(item => { if (keyExpr(item) === internalKey) { storeKey = item } }) } return storeKey } _getInternalKey(storeKey) { if ("object" === typeof storeKey) { var keyExpr = this._getKeyExpr(); return keyExpr(storeKey) } return storeKey } _resetCache() { this._cache = {} } } export default ItemsOption;