atom-nuclide
Version:
A unified developer experience for web and mobile development, built as a suite of features on top of Atom to provide hackability and the support of an active community.
54 lines (43 loc) • 2.25 kB
JavaScript
Object.defineProperty(exports, '__esModule', {
value: true
});
/*
* Copyright (c) 2015-present, Facebook, Inc.
* All rights reserved.
*
* This source code is licensed under the license found in the LICENSE file in
* the root directory of this source tree.
*/
function _asyncToGenerator(fn) { return function () { var gen = fn.apply(this, arguments); return new Promise(function (resolve, reject) { var callNext = step.bind(null, 'next'); var callThrow = step.bind(null, 'throw'); function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(callNext, callThrow); } } callNext(); }); }; }
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
var _commonsAtomRange2;
function _commonsAtomRange() {
return _commonsAtomRange2 = require('../../commons-atom/range');
}
var _UnescapedUnicodeDatatipComponent2;
function _UnescapedUnicodeDatatipComponent() {
return _UnescapedUnicodeDatatipComponent2 = _interopRequireDefault(require('./UnescapedUnicodeDatatipComponent'));
}
var _Unicode2;
function _Unicode() {
return _Unicode2 = require('./Unicode');
}
// Our "word" for the datatip is a contiguous alphanumeric string
// containing at least one Unicode escape: \uXXXX, \UXXXXXXXX, or
// \u{XXXX}.
//
// eslint-disable-next-line max-len
var WORD_REGEX = /[a-zA-Z0-9_-]*(?:\\u[0-9a-fA-F]{4}|\\U[0-9a-fA-F]{8}|\\u{[0-9a-fA-F]{1,8}})+(?:\\u[0-9a-fA-F]{4}|\\U[0-9a-fA-F]{8}|\\u{[0-9a-fA-F]{1,8}}|[a-zA-Z0-9_-])*/g;
exports.default = _asyncToGenerator(function* (editor, position) {
var extractedWord = (0, (_commonsAtomRange2 || _commonsAtomRange()).wordAtPosition)(editor, position, WORD_REGEX);
if (extractedWord == null) {
return null;
}
var extractedCodePoints = (0, (_Unicode2 || _Unicode()).extractCodePoints)(extractedWord.wordMatch[0]);
var codePoints = (0, (_Unicode2 || _Unicode()).decodeSurrogateCodePoints)(extractedCodePoints);
return {
component: (0, (_UnescapedUnicodeDatatipComponent2 || _UnescapedUnicodeDatatipComponent()).default)(codePoints),
range: extractedWord.range
};
});
module.exports = exports.default;