package.dist.esm.createIcon.js Maven / Gradle / Ivy
import { __rest } from "tslib";
import * as React from 'react';
let currentId = 0;
/**
* Factory to create Icon class components for consumers
*/
export function createIcon({ name, xOffset = 0, yOffset = 0, width, height, svgPath }) {
var _a;
return _a = class SVGIcon extends React.Component {
constructor() {
super(...arguments);
this.id = `icon-title-${currentId++}`;
}
render() {
const _b = this.props, { title, className } = _b, props = __rest(_b, ["title", "className"]);
const classes = className ? `pf-v5-svg ${className}` : 'pf-v5-svg';
const hasTitle = Boolean(title);
const viewBox = [xOffset, yOffset, width, height].join(' ');
return (React.createElement("svg", Object.assign({ className: classes, viewBox: viewBox, fill: "currentColor", "aria-labelledby": hasTitle ? this.id : null, "aria-hidden": hasTitle ? null : true, role: "img", width: "1em", height: "1em" }, props),
hasTitle && React.createElement("title", { id: this.id }, title),
React.createElement("path", { d: svgPath })));
}
},
_a.displayName = name,
_a;
}
//# sourceMappingURL=createIcon.js.map
© 2015 - 2025 Weber Informatics LLC | Privacy Policy