| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117 | import { __extends } from "tslib";import { AbstractMatch } from './abstract-match';/** * @class Autolinker.match.Mention * @extends Autolinker.match.AbstractMatch * * Represents a Mention match found in an input string which should be Autolinked. * * See this class's superclass ({@link Autolinker.match.Match}) for more details. */var MentionMatch = /** @class */ (function (_super) {    __extends(MentionMatch, _super);    /**     * @method constructor     * @param {Object} cfg The configuration properties for the Match     *   instance, specified in an Object (map).     */    function MentionMatch(cfg) {        var _this = _super.call(this, cfg) || this;        /**         * @public         * @property {'mention'} type         *         * A string name for the type of match that this class represents. Can be         * used in a TypeScript discriminating union to type-narrow from the         * `Match` type.         */        _this.type = 'mention';        /**         * @cfg {String} serviceName         *         * The service to point mention matches to. See {@link Autolinker#mention}         * for available values.         */        _this.serviceName = 'twitter'; // default value just to get the above doc comment in the ES5 output and documentation generator        /**         * @cfg {String} mention (required)         *         * The Mention that was matched, without the '@' character.         */        _this.mention = ''; // default value just to get the above doc comment in the ES5 output and documentation generator        _this.mention = cfg.mention;        _this.serviceName = cfg.serviceName;        return _this;    }    /**     * Returns a string name for the type of match that this class represents.     * For the case of MentionMatch, returns 'mention'.     *     * @return {String}     */    MentionMatch.prototype.getType = function () {        return 'mention';    };    /**     * Returns the mention, without the '@' character.     *     * @return {String}     */    MentionMatch.prototype.getMention = function () {        return this.mention;    };    /**     * Returns the configured {@link #serviceName} to point the mention to.     * Ex: 'instagram', 'twitter', 'soundcloud'.     *     * @return {String}     */    MentionMatch.prototype.getServiceName = function () {        return this.serviceName;    };    /**     * Returns the anchor href that should be generated for the match.     *     * @return {String}     */    MentionMatch.prototype.getAnchorHref = function () {        switch (this.serviceName) {            case 'twitter':                return 'https://twitter.com/' + this.mention;            case 'instagram':                return 'https://instagram.com/' + this.mention;            case 'soundcloud':                return 'https://soundcloud.com/' + this.mention;            case 'tiktok':                return 'https://www.tiktok.com/@' + this.mention;            default:                // Shouldn't happen because Autolinker's constructor should block any invalid values, but just in case.                throw new Error('Unknown service name to point mention to: ' + this.serviceName);        }    };    /**     * Returns the anchor text that should be generated for the match.     *     * @return {String}     */    MentionMatch.prototype.getAnchorText = function () {        return '@' + this.mention;    };    /**     * Returns the CSS class suffixes that should be used on a tag built with     * the match. See {@link Autolinker.match.Match#getCssClassSuffixes} for     * details.     *     * @return {String[]}     */    MentionMatch.prototype.getCssClassSuffixes = function () {        var cssClassSuffixes = _super.prototype.getCssClassSuffixes.call(this), serviceName = this.getServiceName();        if (serviceName) {            cssClassSuffixes.push(serviceName);        }        return cssClassSuffixes;    };    return MentionMatch;}(AbstractMatch));export { MentionMatch };//# sourceMappingURL=mention-match.js.map
 |