apisearch-ui
Version:
Javascript User Interface of Apisearch.
68 lines (67 loc) • 2.4 kB
JavaScript
;
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) {
extendStatics(d, b);
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
})();
exports.__esModule = true;
var preact_1 = require("preact");
var Highlight_1 = require("../../Highlight");
var Template_1 = require("../Template");
/**
* Item
*/
var Item = /** @class */ (function (_super) {
__extends(Item, _super);
function Item() {
return _super !== null && _super.apply(this, arguments) || this;
}
/**
* @param nextProps
* @param nextState
*/
Item.prototype.shouldComponentUpdate = function (nextProps, nextState) {
var shouldUpdate = this.props.data.uuid_composed !== nextProps.data.uuid_composed;
if (!shouldUpdate) {
this.highlight();
}
return shouldUpdate;
};
Item.prototype.componentDidMount = function () {
this.highlight();
};
Item.prototype.componentDidUpdate = function () {
this.highlight();
};
Item.prototype.highlight = function () {
var queryText = this.props.data.query_text;
if (this.props.data.highlights_enabled && queryText !== "") {
var element = document.getElementById("as-result-" + this.props.data.uuid_composed);
Highlight_1.highlightElement(element, queryText);
}
};
/**
* Render
*
* @return {any}
*/
Item.prototype.render = function () {
var _a;
var props = this.props;
var template = props.template;
var data = props.data;
var dictionary = (_a = props.dictionary) !== null && _a !== void 0 ? _a : {};
var id = "as-result-" + data.uuid_composed;
return preact_1.h(Template_1["default"], { template: template, data: data, id: id, className: "" + props.className, dictionary: dictionary });
};
return Item;
}(preact_1.Component));
exports["default"] = Item;