devextreme
Version:
HTML5 JavaScript Component Suite for Responsive Web Development
105 lines (104 loc) • 3.22 kB
JavaScript
/**
* DevExtreme (esm/renovation/ui/grids/data_grid/data_grid_views.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 _extends from "@babel/runtime/helpers/esm/extends";
import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
var _excluded = ["instance", "showBorders"];
import {
createComponentVNode
} from "inferno";
import {
InfernoEffect,
InfernoComponent
} from "@devextreme/vdom";
import {
GridBaseViews
} from "../grid_base/grid_base_views";
import {
gridViewModule
} from "../../../../ui/grid_core/ui.grid_core.grid_view";
import {
DataGridProps
} from "./common/data_grid_props";
import {
deferRender
} from "../../../../core/utils/common";
var {
VIEW_NAMES: VIEW_NAMES
} = gridViewModule;
var DATA_GRID_CLASS = "dx-datagrid";
var DATA_GRID_ROLE_NAME = "grid";
export var viewFunction = _ref => {
var {
props: {
showBorders: showBorders
},
views: views
} = _ref;
return createComponentVNode(2, GridBaseViews, {
views: views,
className: DATA_GRID_CLASS,
showBorders: showBorders,
role: DATA_GRID_ROLE_NAME
})
};
var DataGridPropsType = {
showBorders: DataGridProps.showBorders
};
export class DataGridViews extends InfernoComponent {
constructor(props) {
super(props);
this.state = {};
this.update = this.update.bind(this)
}
createEffects() {
return [new InfernoEffect(this.update, [this.props.instance])]
}
updateEffects() {
var _this$_effects$;
null === (_this$_effects$ = this._effects[0]) || void 0 === _this$_effects$ ? void 0 : _this$_effects$.update([this.props.instance])
}
update() {
var gridInstance = this.props.instance;
if (!gridInstance) {
return
}
var dataController = gridInstance.getController("data");
var resizingController = gridInstance.getController("resizing");
deferRender(() => {
resizingController.resize();
if (dataController.isLoaded()) {
resizingController.fireContentReadyAction()
}
})
}
get views() {
if (!this.props.instance) {
return []
}
var views = VIEW_NAMES.map(viewName => this.props.instance.getView(viewName)).filter(view => view);
return views.map(view => ({
name: view.name,
view: view
}))
}
get restAttributes() {
var _this$props = this.props,
restProps = _objectWithoutPropertiesLoose(_this$props, _excluded);
return restProps
}
render() {
var props = this.props;
return viewFunction({
props: _extends({}, props),
views: this.views,
restAttributes: this.restAttributes
})
}
}
DataGridViews.defaultProps = _extends({}, DataGridPropsType);