diff options
| author | ruki <waruqi@gmail.com> | 2018-11-08 00:38:48 +0800 |
|---|---|---|
| committer | ruki <waruqi@gmail.com> | 2018-11-07 21:53:09 +0800 |
| commit | 26105034da4fcce7ac883c899d781f016559310d (patch) | |
| tree | c459a5dc4e3aa0972d9919033ece511ce76dd129 /node_modules/caniuse-api/dist/index.js | |
| parent | 2c77f00f1a7ecb6c8192f9c16d3b2001b254a107 (diff) | |
| download | xmake-docs-26105034da4fcce7ac883c899d781f016559310d.tar.gz xmake-docs-26105034da4fcce7ac883c899d781f016559310d.zip | |
switch to vuepress
Diffstat (limited to 'node_modules/caniuse-api/dist/index.js')
| -rw-r--r-- | node_modules/caniuse-api/dist/index.js | 99 |
1 files changed, 99 insertions, 0 deletions
diff --git a/node_modules/caniuse-api/dist/index.js b/node_modules/caniuse-api/dist/index.js new file mode 100644 index 00000000..8c0f4357 --- /dev/null +++ b/node_modules/caniuse-api/dist/index.js @@ -0,0 +1,99 @@ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +exports.getBrowserScope = exports.setBrowserScope = exports.getLatestStableBrowsers = exports.find = exports.isSupported = exports.getSupport = exports.features = undefined; + +var _lodash = require("lodash.memoize"); + +var _lodash2 = _interopRequireDefault(_lodash); + +var _browserslist = require("browserslist"); + +var _browserslist2 = _interopRequireDefault(_browserslist); + +var _utils = require("./utils"); + +var _data = require("caniuse-db/data.json"); + +var _data2 = _interopRequireDefault(_data); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +var features = _data2.default.data; +var featuresList = Object.keys(features); + +var browsers = void 0; +function setBrowserScope(browserList) { + browsers = (0, _utils.cleanBrowsersList)(browserList); +} + +function getBrowserScope() { + return browsers; +} + +var parse = (0, _lodash2.default)(_utils.parseCaniuseData, function (feature, browsers) { + return feature.title + browsers; +}); + +function getSupport(query) { + var feature = void 0; + try { + feature = features[query]; + } catch (e) { + var res = find(query); + if (res.length === 1) return getSupport(res[0]); + throw new ReferenceError("Please provide a proper feature name. Cannot find " + query); + } + return parse(feature, browsers); +} + +function isSupported(feature, browsers) { + var data = void 0; + try { + data = features[feature]; + } catch (e) { + var res = find(feature); + if (res.length === 1) { + data = features[res[0]]; + } else { + throw new ReferenceError("Please provide a proper feature name. Cannot find " + feature); + } + } + + return (0, _browserslist2.default)(browsers).map(function (browser) { + return browser.split(" "); + }).every(function (browser) { + return data.stats[browser[0]] && data.stats[browser[0]][browser[1]] === "y"; + }); +} + +function find(query) { + if (typeof query !== "string") { + throw new TypeError("The `query` parameter should be a string."); + } + + if (~featuresList.indexOf(query)) { + // exact match + return query; + } + + return featuresList.filter(function (file) { + return (0, _utils.contains)(file, query); + }); +} + +function getLatestStableBrowsers() { + return _browserslist2.default.queries.lastVersions.select(1); +} + +setBrowserScope(); + +exports.features = featuresList; +exports.getSupport = getSupport; +exports.isSupported = isSupported; +exports.find = find; +exports.getLatestStableBrowsers = getLatestStableBrowsers; +exports.setBrowserScope = setBrowserScope; +exports.getBrowserScope = getBrowserScope;
\ No newline at end of file |
