UNPKG

react-syntax-highlighter

Version:

syntax highlighting component for react with prismjs or highlightjs ast using inline styles

164 lines (163 loc) 7.7 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator")); var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator")); var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _react = _interopRequireDefault(require("react")); var _highlight = _interopRequireDefault(require("./highlight")); function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2["default"])(o), (0, _possibleConstructorReturn2["default"])(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2["default"])(t).constructor) : o.apply(t, e)); } function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } var _default = exports["default"] = function _default(options) { var _ReactAsyncHighlighter; var loader = options.loader, isLanguageRegistered = options.isLanguageRegistered, registerLanguage = options.registerLanguage, languageLoaders = options.languageLoaders, noAsyncLoadingLanguages = options.noAsyncLoadingLanguages; var ReactAsyncHighlighter = /*#__PURE__*/function (_React$PureComponent) { function ReactAsyncHighlighter() { (0, _classCallCheck2["default"])(this, ReactAsyncHighlighter); return _callSuper(this, ReactAsyncHighlighter, arguments); } (0, _inherits2["default"])(ReactAsyncHighlighter, _React$PureComponent); return (0, _createClass2["default"])(ReactAsyncHighlighter, [{ key: "componentDidUpdate", value: function componentDidUpdate() { if (!ReactAsyncHighlighter.isRegistered(this.props.language) && languageLoaders) { this.loadLanguage(); } } }, { key: "componentDidMount", value: function componentDidMount() { var _this = this; if (!ReactAsyncHighlighter.astGeneratorPromise) { ReactAsyncHighlighter.loadAstGenerator(); } if (!ReactAsyncHighlighter.astGenerator) { ReactAsyncHighlighter.astGeneratorPromise.then(function () { _this.forceUpdate(); }); } if (!ReactAsyncHighlighter.isRegistered(this.props.language) && languageLoaders) { this.loadLanguage(); } } }, { key: "loadLanguage", value: function loadLanguage() { var _this2 = this; var language = this.props.language; if (language === 'text') { return; } ReactAsyncHighlighter.loadLanguage(language).then(function () { return _this2.forceUpdate(); })["catch"](function () {}); } }, { key: "normalizeLanguage", value: function normalizeLanguage(language) { return ReactAsyncHighlighter.isSupportedLanguage(language) ? language : 'text'; } }, { key: "render", value: function render() { return /*#__PURE__*/_react["default"].createElement(ReactAsyncHighlighter.highlightInstance, (0, _extends2["default"])({}, this.props, { language: this.normalizeLanguage(this.props.language), astGenerator: ReactAsyncHighlighter.astGenerator })); } }], [{ key: "preload", value: function preload() { return ReactAsyncHighlighter.loadAstGenerator(); } }, { key: "loadLanguage", value: function () { var _loadLanguage = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee(language) { var languageLoader; return _regenerator["default"].wrap(function (_context) { while (1) switch (_context.prev = _context.next) { case 0: languageLoader = languageLoaders[language]; if (!(typeof languageLoader === 'function')) { _context.next = 1; break; } return _context.abrupt("return", languageLoader(ReactAsyncHighlighter.registerLanguage)); case 1: throw new Error("Language ".concat(language, " not supported")); case 2: case "end": return _context.stop(); } }, _callee); })); function loadLanguage(_x) { return _loadLanguage.apply(this, arguments); } return loadLanguage; }() }, { key: "isSupportedLanguage", value: function isSupportedLanguage(language) { return ReactAsyncHighlighter.isRegistered(language) || typeof languageLoaders[language] === 'function'; } }, { key: "loadAstGenerator", value: function loadAstGenerator() { ReactAsyncHighlighter.astGeneratorPromise = loader().then(function (astGenerator) { ReactAsyncHighlighter.astGenerator = astGenerator; if (registerLanguage) { ReactAsyncHighlighter.languages.forEach(function (language, name) { return registerLanguage(astGenerator, name, language); }); } }); return ReactAsyncHighlighter.astGeneratorPromise; } }]); }(_react["default"].PureComponent); _ReactAsyncHighlighter = ReactAsyncHighlighter; (0, _defineProperty2["default"])(ReactAsyncHighlighter, "astGenerator", null); (0, _defineProperty2["default"])(ReactAsyncHighlighter, "highlightInstance", (0, _highlight["default"])(null, {})); (0, _defineProperty2["default"])(ReactAsyncHighlighter, "astGeneratorPromise", null); (0, _defineProperty2["default"])(ReactAsyncHighlighter, "languages", new Map()); (0, _defineProperty2["default"])(ReactAsyncHighlighter, "supportedLanguages", options.supportedLanguages || Object.keys(languageLoaders || {})); (0, _defineProperty2["default"])(ReactAsyncHighlighter, "isRegistered", function (language) { if (noAsyncLoadingLanguages) { return true; } if (!registerLanguage) { throw new Error("Current syntax highlighter doesn't support registration of languages"); } if (!_ReactAsyncHighlighter.astGenerator) { // Ast generator not available yet, but language will be registered once it is. return _ReactAsyncHighlighter.languages.has(language); } return isLanguageRegistered(_ReactAsyncHighlighter.astGenerator, language); }); (0, _defineProperty2["default"])(ReactAsyncHighlighter, "registerLanguage", function (name, language) { if (!registerLanguage) { throw new Error("Current syntax highlighter doesn't support registration of languages"); } if (_ReactAsyncHighlighter.astGenerator) { return registerLanguage(_ReactAsyncHighlighter.astGenerator, name, language); } else { _ReactAsyncHighlighter.languages.set(name, language); } }); return ReactAsyncHighlighter; };