@eccenca/gui-elements
Version:
GUI elements based on other libraries, usable in React application, written in Typescript.
55 lines • 3.22 kB
JavaScript
;
var __rest = (this && this.__rest) || function (s, e) {
var t = {};
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
t[p] = s[p];
if (s != null && typeof Object.getOwnPropertySymbols === "function")
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
t[p[i]] = s[p[i]];
}
return t;
};
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.ConfidenceValue = ConfidenceValue;
const react_1 = __importDefault(require("react"));
const color_1 = __importDefault(require("color"));
const constants_1 = require("../../configuration/constants");
const ProgressBar_1 = require("./../../components/ProgressBar");
const Tag_1 = require("./../../components/Tag");
const toPercent = (n) => {
const formatted = (n * 100).toFixed(2);
const maybeRemovedFraction = formatted.replace(/(\.0+$)|(0+$)/, "");
return `${maybeRemovedFraction}%`;
};
function ConfidenceValue(_a) {
var { className, value, minValue = -1, maxValue = 1, centerValue = 0, barColor, barStart = "side", spaceUsage = "static", tagProps, progressBarProps } = _a, otherProps = __rest(_a, ["className", "value", "minValue", "maxValue", "centerValue", "barColor", "barStart", "spaceUsage", "tagProps", "progressBarProps"]);
const barValue = value === centerValue
? 0
: value < centerValue
? value / (minValue - centerValue)
: value / (maxValue - centerValue);
let color = (0, color_1.default)("#000000");
if (barColor) {
try {
color = (0, color_1.default)(barColor);
}
catch (ex) {
console.warn("Received invalid color for confidence bar: " + barColor);
}
}
return (react_1.default.createElement("span", Object.assign({ className: `${constants_1.CLASSPREFIX}-confidencevalue` +
` ${constants_1.CLASSPREFIX}-confidencevalue--${barStart}` +
` ${constants_1.CLASSPREFIX}-confidencevalue--${spaceUsage}space` +
(value < centerValue
? ` ${constants_1.CLASSPREFIX}-confidencevalue--negative`
: ` ${constants_1.CLASSPREFIX}-confidencevalue--positive`) +
(className ? ` ${className}` : "") }, otherProps),
react_1.default.createElement(Tag_1.Tag, Object.assign({ className: `${constants_1.CLASSPREFIX}-confidencevalue__value` }, tagProps), toPercent(value)),
react_1.default.createElement("div", { className: `${constants_1.CLASSPREFIX}-confidencevalue__bar-colorwrapper`, style: barColor ? { color: color.rgb().toString() } : {} },
react_1.default.createElement(ProgressBar_1.ProgressBar, Object.assign({ className: `${constants_1.CLASSPREFIX}-confidencevalue__bar`, value: barValue, intent: barColor ? undefined : value < centerValue ? "danger" : "success", stripes: false, animate: false }, progressBarProps)))));
}
//# sourceMappingURL=ConfidenceValue.js.map