UNPKG

react-dadata

Version:

React-компонент для подсказок адресов, организаций и банков с помощью сервиса DaData.ru

38 lines (37 loc) 1.94 kB
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 (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; }; return extendStatics(d, b); }; return function (d, b) { if (typeof b !== "function" && b !== null) throw new TypeError("Class extends value " + String(b) + " is not a constructor or null"); extendStatics(d, b); function __() { this.constructor = d; } d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); import highlightWords from 'highlight-words'; import React, { PureComponent } from 'react'; var HighlightWords = /** @class */ (function (_super) { __extends(HighlightWords, _super); function HighlightWords() { return _super !== null && _super.apply(this, arguments) || this; } HighlightWords.prototype.render = function () { var _a = this.props, text = _a.text, words = _a.words, highlightClassName = _a.highlightClassName, _b = _a.tagName, tagName = _b === void 0 ? 'span' : _b; var query = typeof words === 'string' ? words : words.join(' '); var chunks = highlightWords({ text: text, query: query }); return (React.createElement("span", { "aria-label": text }, chunks.map(function (chunk) { if (!chunk.match) { return (React.createElement("span", { key: chunk.key, "aria-hidden": true }, chunk.text)); } var Component = tagName; return (React.createElement(Component, { key: chunk.key, className: highlightClassName, "aria-hidden": true }, chunk.text)); }))); }; return HighlightWords; }(PureComponent)); export { HighlightWords };