@hisptz/react-ui
Version:
A collection of reusable complex DHIS2 react ui components.
71 lines (66 loc) • 4.76 kB
JavaScript
import { useDataQuery } from "@dhis2/app-runtime";
import i18n from "@dhis2/d2-i18n";
import PropTypes from "prop-types";
import React, { useEffect } from "react";
import Error from "../../../../Shared/Componets/Error/ErrorAPIResult";
import Loader from "../../../../Shared/Componets/Loaders/Loader";
import { lowerCaseAllWordsExceptFirstLetters } from "../../../../Utils/Functions/FormulaFunctions";
const query = {
detail: {
resource: "dataElements",
id: _ref => {
let {
id
} = _ref;
return id;
},
params: {
fields: ["id", "displayName", "domainType", "aggregationType", "zeroIsSignificant", "categoryCombo[id,displayName,categories[id,displayName,categoryOptions[id,displayName]]]"]
}
}
};
export default function AnalyticsDetails(_ref2) {
var _lowerCaseAllWordsExc, _result$categoryCombo, _result$categoryCombo2, _result$categoryCombo3, _result$categoryCombo4, _result$categoryCombo5, _result$categoryCombo6, _result$categoryCombo7;
let {
id
} = _ref2;
const {
loading,
error,
data,
refetch
} = useDataQuery(query, {
variables: {
id
}
});
useEffect(() => {
refetch({
id
});
}, [id]);
const result = data === null || data === void 0 ? void 0 : data.detail;
if (loading) {
return /*#__PURE__*/React.createElement(Loader, {
text: ""
});
}
if (error) {
return /*#__PURE__*/React.createElement(Error, {
error: error
});
}
return /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement("h3", null, i18n.t("Analytics Details"), " "), /*#__PURE__*/React.createElement("ul", null, /*#__PURE__*/React.createElement("li", null, i18n.t("Uses"), " ", /*#__PURE__*/React.createElement("b", null, i18n.t((result === null || result === void 0 ? void 0 : result.aggregationType) === "NONE" ? "NO" : (_lowerCaseAllWordsExc = lowerCaseAllWordsExceptFirstLetters(result === null || result === void 0 ? void 0 : result.aggregationType)) === null || _lowerCaseAllWordsExc === void 0 ? void 0 : _lowerCaseAllWordsExc.replace(/_/g, " ")), " "), " ", i18n.t("aggregation type through period and hierarchy"), " "), /*#__PURE__*/React.createElement("li", null, " ", result === null || result === void 0 ? void 0 : result.domainType, " ", i18n.t("data sources")), /*#__PURE__*/React.createElement("li", null, i18n.t(result !== null && result !== void 0 && result.zeroIsSignificant ? "It stores zero values" : "It does not store zero values")), /*#__PURE__*/React.createElement("li", null, i18n.t("Category Combo is"), " ", result === null || result === void 0 ? void 0 : (_result$categoryCombo = result.categoryCombo) === null || _result$categoryCombo === void 0 ? void 0 : _result$categoryCombo.displayName, " ", i18n.t("which has cross-tabulation between "), " ", result === null || result === void 0 ? void 0 : (_result$categoryCombo2 = result.categoryCombo) === null || _result$categoryCombo2 === void 0 ? void 0 : (_result$categoryCombo3 = _result$categoryCombo2.categories) === null || _result$categoryCombo3 === void 0 ? void 0 : _result$categoryCombo3.length, " ", i18n.t((result === null || result === void 0 ? void 0 : (_result$categoryCombo4 = result.categoryCombo) === null || _result$categoryCombo4 === void 0 ? void 0 : (_result$categoryCombo5 = _result$categoryCombo4.categories) === null || _result$categoryCombo5 === void 0 ? void 0 : _result$categoryCombo5.length) === 1 ? "category" : "categories"), " ", i18n.t("with following details"), /*#__PURE__*/React.createElement("ul", null, result === null || result === void 0 ? void 0 : (_result$categoryCombo6 = result.categoryCombo) === null || _result$categoryCombo6 === void 0 ? void 0 : (_result$categoryCombo7 = _result$categoryCombo6.categories) === null || _result$categoryCombo7 === void 0 ? void 0 : _result$categoryCombo7.map(cat => {
var _cat$categoryOptions, _cat$categoryOptions2;
return /*#__PURE__*/React.createElement("li", {
key: cat === null || cat === void 0 ? void 0 : cat.id
}, " ", cat === null || cat === void 0 ? void 0 : cat.displayName, i18n.t((cat === null || cat === void 0 ? void 0 : (_cat$categoryOptions = cat.categoryOptions) === null || _cat$categoryOptions === void 0 ? void 0 : _cat$categoryOptions.length) >= 0 ? "which also has the following options" : ""), /*#__PURE__*/React.createElement("ul", null, cat === null || cat === void 0 ? void 0 : (_cat$categoryOptions2 = cat.categoryOptions) === null || _cat$categoryOptions2 === void 0 ? void 0 : _cat$categoryOptions2.map(opt => {
return /*#__PURE__*/React.createElement("li", {
key: opt.id
}, " ", cat.displayName);
})));
})))));
}
AnalyticsDetails.propTypes = {
id: PropTypes.string.isRequired
};