UNPKG

@hisptz/react-ui

Version:

A collection of reusable complex DHIS2 react ui components.

71 lines (66 loc) 4.76 kB
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 };