UNPKG

@finos/legend-data-cube

Version:
59 lines 2.17 kB
/** * Copyright (c) 2020-present, Goldman Sachs * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * This implementation wraps around DataCube state to expose a cleaner API to clients. * It also provides a typing-hack for core components to access advanced functionalities, * e.g. access to the internals of DataCube view state, grid client, etc., which should * not be exposed externally via the public interface. */ export class INTERNAL__DataCubeAPI { _dataCube; constructor(dataCube) { this._dataCube = dataCube; } _runTaskForEachView(runner) { // TODO: When we support multi-view (i.e. multiple instances of DataCubes) we would need // to traverse through and update the configurations of all of their grid clients runner(this._dataCube.view); } // ----------------------------- API ----------------------------- getProcessedSource() { return this._dataCube.view.getInitialSource(); } generateSpecification() { return this._dataCube.view.generateSpecification(); } updateName(name) { this._dataCube.view.updateName(name); } async applySpecification(specification) { await this._dataCube.view.applySpecification(specification); } retryFailedDataFetches() { this._runTaskForEachView((view) => { if (view.grid.isClientConfigured) { view.grid.client.retryServerSideLoads(); } }); } reload() { this._dataCube.reload(); } isCachingEnabled() { return this._dataCube.view.grid.isCachingEnabled; } } //# sourceMappingURL=DataCubeAPI.js.map