@raona/components
Version:
React components used at Raona to work with SPFx
73 lines (72 loc) • 4.1 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 (b.hasOwnProperty(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 __());
};
})();
var __assign = (this && this.__assign) || function () {
__assign = Object.assign || function(t) {
for (var s, i = 1, n = arguments.length; i < n; i++) {
s = arguments[i];
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
t[p] = s[p];
}
return t;
};
return __assign.apply(this, arguments);
};
Object.defineProperty(exports, "__esModule", { value: true });
var React = require("react");
var react_1 = require("react");
// import { CardEntity, CardStyles, EventBodyStyles } from '../../entities';
var stylesConstants_1 = require("./stylesConstants");
var getTimeAgo_1 = require("@raona/sp/dist/utils/getTimeAgo");
function getHashtagsFromTweetContent(content) {
var expression = /(\#[\u00C0-\u017F-0-9a-zA-Z]+\w)/g; // #word (con dieresis, numeros y letras)
var arrayWords = content.match(expression);
return arrayWords ? arrayWords : [];
}
var RSSCard = /** @class */ (function (_super) {
__extends(RSSCard, _super);
function RSSCard() {
return _super !== null && _super.apply(this, arguments) || this;
}
RSSCard.prototype.componentDidMount = function () {
console.log('debugando with npm Link');
};
RSSCard.prototype.render = function () {
var _a = this.props, item = _a.item, rssStyles = _a.rssStyles;
var hashtags = item.content ? getHashtagsFromTweetContent(item.content) : ['No Content, no Hashtags!!'];
var styles = rssStyles ? __assign({}, rssStyles) : __assign({}, stylesConstants_1.rssConstantStyles); // Default Style for this component
return (React.createElement("div", { className: styles.card },
React.createElement("div", { className: styles.wrapper, onClick: function () { window.open(item.redirectUrl, '_blank'); } },
React.createElement("div", { className: styles.header.header },
React.createElement("div", { className: styles.header.image, style: { backgroundImage: "url(\"" + item.imageUrl + "\")" } })),
React.createElement("div", { className: styles.body },
React.createElement("div", { className: styles.content.content },
React.createElement("div", { className: styles.content.meta },
React.createElement("span", { className: styles.content.title }, item.title),
React.createElement("span", { className: styles.content.network },
"@",
item.username),
React.createElement("span", { className: styles.content.date }, getTimeAgo_1.getTimeAgo(item.date))),
React.createElement("div", { className: styles.content.text },
React.createElement("span", null, item.content)),
React.createElement("div", { className: styles.hashtags.hashtags }, hashtags.length > 0
? hashtags.map(function (h) { return React.createElement("span", { className: styles.hashtags.hashtag },
" ",
h,
" "); })
: React.createElement("span", { className: styles.hashtags.hashtag }, " #Cellnex ")))))));
};
return RSSCard;
}(react_1.Component));
exports.RSSCard = RSSCard;
;