@gooddata/react-components
Version:
GoodData.UI - A powerful JavaScript library for building analytical applications
108 lines • 6.07 kB
JavaScript
;
var __extends = (this && this.__extends) || (function () {
var extendStatics = function (d, b) {
extendStatics = Object.setPrototypeOf ||
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
return extendStatics(d, b);
};
return function (d, b) {
extendStatics(d, b);
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
})();
var __assign = (this && this.__assign) || function () {
__assign = Object.assign || function(t) {
for (var s, i = 1, n = arguments.length; i < n; i++) {
s = arguments[i];
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
t[p] = s[p];
}
return t;
};
return __assign.apply(this, arguments);
};
Object.defineProperty(exports, "__esModule", { value: true });
// (C) 2019-2020 GoodData Corporation
var React = require("react");
var react_dom_1 = require("react-dom");
var cloneDeep = require("lodash/cloneDeep");
var get = require("lodash/get");
var set = require("lodash/set");
var tail = require("lodash/tail");
var isEmpty = require("lodash/isEmpty");
var BucketNames = require("../../../../constants/bucketNames");
var bucketConfig_1 = require("../../../utils/bucketConfig");
var PluggableBaseChart_1 = require("../baseChart/PluggableBaseChart");
var TreeMapConfigurationPanel_1 = require("../../configurationPanels/TreeMapConfigurationPanel");
var bucket_1 = require("../../../constants/bucket");
var supportedProperties_1 = require("../../../constants/supportedProperties");
var uiConfig_1 = require("../../../constants/uiConfig");
var bucketHelper_1 = require("../../../utils/bucketHelper");
var treemapUiConfigHelper_1 = require("../../../utils/uiConfigHelpers/treemapUiConfigHelper");
var sort_1 = require("../../../utils/sort");
var propertiesHelper_1 = require("../../../utils/propertiesHelper");
var visualizationTypes_1 = require("../../../../constants/visualizationTypes");
var PluggableTreemap = /** @class */ (function (_super) {
__extends(PluggableTreemap, _super);
function PluggableTreemap(props) {
var _this = _super.call(this, props) || this;
_this.type = visualizationTypes_1.VisualizationTypes.TREEMAP;
_this.supportedPropertiesList = supportedProperties_1.TREEMAP_SUPPORTED_PROPERTIES;
_this.initializeProperties(props.visualizationProperties);
return _this;
}
PluggableTreemap.prototype.getExtendedReferencePoint = function (referencePoint) {
var clonedReferencePoint = cloneDeep(referencePoint);
var newReferencePoint = __assign({}, clonedReferencePoint, { uiConfig: cloneDeep(uiConfig_1.DEFAULT_TREEMAP_UICONFIG) });
newReferencePoint = bucketHelper_1.removeAllArithmeticMeasuresFromDerived(newReferencePoint);
newReferencePoint = bucketHelper_1.removeAllDerivedMeasures(newReferencePoint);
var buckets = get(clonedReferencePoint, bucket_1.BUCKETS, []);
var measures = bucketHelper_1.getMeasureItems(buckets);
var stacks = bucketHelper_1.getStackItems(buckets);
var nonStackAttributes = bucketHelper_1.getAttributeItemsWithoutStacks(buckets);
var view = nonStackAttributes.slice(0, 1);
if (nonStackAttributes.length > 0) {
set(newReferencePoint, uiConfig_1.UICONFIG, cloneDeep(uiConfig_1.TREEMAP_UICONFIG_WITH_ONE_MEASURE));
measures = bucketHelper_1.getMeasureItems(bucketHelper_1.limitNumberOfMeasuresInBuckets(buckets, 1));
}
else if (measures.length > 1) {
set(newReferencePoint, uiConfig_1.UICONFIG, cloneDeep(uiConfig_1.TREEMAP_UICONFIG_WITH_MULTIPLE_MEASURES));
}
if (nonStackAttributes.length > 1 && isEmpty(stacks)) {
// first attribute is taken, find next available non-date attribute
var attributesWithoutFirst = tail(nonStackAttributes);
var nonDate = attributesWithoutFirst.filter(function (attribute) { return !bucketHelper_1.isDateBucketItem(attribute); });
stacks = nonDate.slice(0, 1);
}
set(newReferencePoint, bucket_1.BUCKETS, [
{
localIdentifier: BucketNames.MEASURES,
items: measures,
},
{
localIdentifier: BucketNames.VIEW,
items: view,
},
{
localIdentifier: BucketNames.SEGMENT,
items: stacks,
},
]);
newReferencePoint = treemapUiConfigHelper_1.setTreemapUiConfig(newReferencePoint, this.intl, this.type);
newReferencePoint = bucketConfig_1.configurePercent(newReferencePoint, false);
newReferencePoint = bucketConfig_1.configureOverTimeComparison(newReferencePoint, !!this.featureFlags.enableWeekFilters);
newReferencePoint = propertiesHelper_1.getReferencePointWithSupportedProperties(newReferencePoint, this.supportedPropertiesList);
newReferencePoint = sort_1.removeSort(newReferencePoint);
return Promise.resolve(bucketHelper_1.sanitizeFilters(newReferencePoint));
};
PluggableTreemap.prototype.renderConfigurationPanel = function () {
if (document.querySelector(this.configPanelElement)) {
react_dom_1.render(React.createElement(TreeMapConfigurationPanel_1.default, { locale: this.locale, references: this.references, properties: this.visualizationProperties, propertiesMeta: this.propertiesMeta, mdObject: this.mdObject, colors: this.colors, pushData: this.handlePushData, type: this.type, isError: this.isError, isLoading: this.isLoading, featureFlags: this.featureFlags }), document.querySelector(this.configPanelElement));
}
};
return PluggableTreemap;
}(PluggableBaseChart_1.PluggableBaseChart));
exports.PluggableTreemap = PluggableTreemap;
//# sourceMappingURL=PluggableTreemap.js.map