array-string-at
Advanced tools
Comparing version 1.0.0 to 1.1.0
@@ -5,2 +5,10 @@ # Changelog | ||
## [1.1.0][] - 2021-09-13 | ||
### Added | ||
- TypeScript types | ||
- Test case for `Infinity` | ||
- Support for `TypedArray` | ||
## [1.0.0][] - 2021-06-06 | ||
@@ -14,1 +22,3 @@ | ||
[1.0.0]: https://github.com/niksy/array-string-at/tree/v1.0.0 | ||
[unreleased]: https://github.com/niksy/array-string-at/compare/v1.1.0...HEAD | ||
[1.1.0]: https://github.com/niksy/array-string-at/tree/v1.1.0 |
@@ -5,17 +5,64 @@ 'use strict'; | ||
/* eslint-disable no-undefined */ | ||
var isTypedarray = isTypedArray; | ||
isTypedArray.strict = isStrictTypedArray; | ||
isTypedArray.loose = isLooseTypedArray; | ||
var toString = Object.prototype.toString; | ||
var names = { | ||
'[object Int8Array]': true | ||
, '[object Int16Array]': true | ||
, '[object Int32Array]': true | ||
, '[object Uint8Array]': true | ||
, '[object Uint8ClampedArray]': true | ||
, '[object Uint16Array]': true | ||
, '[object Uint32Array]': true | ||
, '[object Float32Array]': true | ||
, '[object Float64Array]': true | ||
}; | ||
function isTypedArray(arr) { | ||
return ( | ||
isStrictTypedArray(arr) | ||
|| isLooseTypedArray(arr) | ||
) | ||
} | ||
function isStrictTypedArray(arr) { | ||
return ( | ||
arr instanceof Int8Array | ||
|| arr instanceof Int16Array | ||
|| arr instanceof Int32Array | ||
|| arr instanceof Uint8Array | ||
|| arr instanceof Uint8ClampedArray | ||
|| arr instanceof Uint16Array | ||
|| arr instanceof Uint32Array | ||
|| arr instanceof Float32Array | ||
|| arr instanceof Float64Array | ||
) | ||
} | ||
function isLooseTypedArray(arr) { | ||
return names[toString.call(arr)] | ||
} | ||
/* globals unknown */ | ||
/** | ||
* @param {string|Array} item | ||
* @param {number} _index | ||
* @typedef {Int8Array | Int16Array | Int32Array | Uint8Array | Uint8ClampedArray | Uint16Array | Uint32Array | Float32Array | Float64Array} TypedArray | ||
*/ | ||
/** | ||
* Returns value at specified index. Supports relative indexing from the end when passed a negative index. Uses native implementation if available. | ||
* | ||
* @returns {*} | ||
* @throws {TypeError} | ||
* @param {string|Array<unknown>|TypedArray} item | ||
* @param {number} [index] | ||
*/ | ||
function ponyfill(item, _index) { | ||
if (typeof item !== 'string' && !Array.isArray(item)) { | ||
function ponyfill(item, index) { | ||
var _index; | ||
if (typeof item !== 'string' && !Array.isArray(item) && !isTypedarray.loose(item)) { | ||
throw new TypeError('Expected a string or array-like item.'); | ||
} | ||
var index = Math.trunc(_index) || 0; | ||
index = Math.trunc((_index = index) !== null && _index !== void 0 ? _index : 0) || 0; | ||
@@ -32,14 +79,18 @@ if (index < 0) { | ||
} | ||
var preferNative = function preferNative(item, index) { | ||
if (typeof item === 'string' && typeof String.prototype.at !== 'undefined' || Array.isArray(item) && Array.prototype.at !== 'undefined') { | ||
return item.at(index); | ||
} | ||
/* istanbul ignore next */ | ||
/** | ||
* Returns value at specified index. Supports relative indexing from the end when passed a negative index. Uses native implementation if available. | ||
* | ||
* @param {string|Array<unknown>|TypedArray} item Item to search. | ||
* @param {number} [index] Relative index. | ||
*/ | ||
return ponyfill(item, index); | ||
}; | ||
function preferNative(item, index) { | ||
var _item$at, _item$at2; | ||
exports.default = ponyfill; | ||
return (_item$at = item === null || item === void 0 ? void 0 : (_item$at2 = item.at) === null || _item$at2 === void 0 ? void 0 : _item$at2.call(item, index !== null && index !== void 0 ? index : 0)) !== null && _item$at !== void 0 ? _item$at : ponyfill(item, index); | ||
} | ||
exports['default'] = ponyfill; | ||
exports.preferNative = preferNative; | ||
//# sourceMappingURL=index.js.map |
@@ -1,16 +0,63 @@ | ||
/* eslint-disable no-undefined */ | ||
var isTypedarray = isTypedArray; | ||
isTypedArray.strict = isStrictTypedArray; | ||
isTypedArray.loose = isLooseTypedArray; | ||
var toString = Object.prototype.toString; | ||
var names = { | ||
'[object Int8Array]': true | ||
, '[object Int16Array]': true | ||
, '[object Int32Array]': true | ||
, '[object Uint8Array]': true | ||
, '[object Uint8ClampedArray]': true | ||
, '[object Uint16Array]': true | ||
, '[object Uint32Array]': true | ||
, '[object Float32Array]': true | ||
, '[object Float64Array]': true | ||
}; | ||
function isTypedArray(arr) { | ||
return ( | ||
isStrictTypedArray(arr) | ||
|| isLooseTypedArray(arr) | ||
) | ||
} | ||
function isStrictTypedArray(arr) { | ||
return ( | ||
arr instanceof Int8Array | ||
|| arr instanceof Int16Array | ||
|| arr instanceof Int32Array | ||
|| arr instanceof Uint8Array | ||
|| arr instanceof Uint8ClampedArray | ||
|| arr instanceof Uint16Array | ||
|| arr instanceof Uint32Array | ||
|| arr instanceof Float32Array | ||
|| arr instanceof Float64Array | ||
) | ||
} | ||
function isLooseTypedArray(arr) { | ||
return names[toString.call(arr)] | ||
} | ||
/* globals unknown */ | ||
/** | ||
* @param {string|Array} item | ||
* @param {number} _index | ||
* @typedef {Int8Array | Int16Array | Int32Array | Uint8Array | Uint8ClampedArray | Uint16Array | Uint32Array | Float32Array | Float64Array} TypedArray | ||
*/ | ||
/** | ||
* Returns value at specified index. Supports relative indexing from the end when passed a negative index. Uses native implementation if available. | ||
* | ||
* @returns {*} | ||
* @throws {TypeError} | ||
* @param {string|Array<unknown>|TypedArray} item | ||
* @param {number} [index] | ||
*/ | ||
function ponyfill(item, _index) { | ||
if (typeof item !== 'string' && !Array.isArray(item)) { | ||
function ponyfill(item, index) { | ||
var _index; | ||
if (typeof item !== 'string' && !Array.isArray(item) && !isTypedarray.loose(item)) { | ||
throw new TypeError('Expected a string or array-like item.'); | ||
} | ||
var index = Math.trunc(_index) || 0; | ||
index = Math.trunc((_index = index) !== null && _index !== void 0 ? _index : 0) || 0; | ||
@@ -27,14 +74,17 @@ if (index < 0) { | ||
} | ||
var preferNative = function preferNative(item, index) { | ||
if (typeof item === 'string' && typeof String.prototype.at !== 'undefined' || Array.isArray(item) && Array.prototype.at !== 'undefined') { | ||
return item.at(index); | ||
} | ||
/* istanbul ignore next */ | ||
/** | ||
* Returns value at specified index. Supports relative indexing from the end when passed a negative index. Uses native implementation if available. | ||
* | ||
* @param {string|Array<unknown>|TypedArray} item Item to search. | ||
* @param {number} [index] Relative index. | ||
*/ | ||
return ponyfill(item, index); | ||
}; | ||
function preferNative(item, index) { | ||
var _item$at, _item$at2; | ||
export default ponyfill; | ||
export { preferNative }; | ||
return (_item$at = item === null || item === void 0 ? void 0 : (_item$at2 = item.at) === null || _item$at2 === void 0 ? void 0 : _item$at2.call(item, index !== null && index !== void 0 ? index : 0)) !== null && _item$at !== void 0 ? _item$at : ponyfill(item, index); | ||
} | ||
export { ponyfill as default, preferNative }; | ||
//# sourceMappingURL=index.js.map |
{ | ||
"name": "array-string-at", | ||
"version": "1.0.0", | ||
"version": "1.1.0", | ||
"description": "Array/string `.at()` ponyfill.", | ||
@@ -17,2 +17,3 @@ "license": "MIT", | ||
"module": "esm/index.js", | ||
"types": "esm/index.d.ts", | ||
"directories": { | ||
@@ -32,3 +33,3 @@ "test": "test" | ||
"module-check": "node -e 'require(\"array-string-at\");' && node --input-type=module -e 'import \"array-string-at\";'", | ||
"prepublishOnly": "npm run build && npm run module-check", | ||
"prepublishOnly": "npm run build && npm run lint:types && npm run module-check", | ||
"postpublish": "GITHUB_TOKEN=$GITHUB_RELEASE_TOKEN github-release-from-changelog", | ||
@@ -39,4 +40,9 @@ "release": "np --no-release-draft", | ||
"test:automated:watch": "npm run test:automated -- --auto-watch --no-single-run", | ||
"version": "if [[ $(git rev-parse --abbrev-ref HEAD) == 'master' ]]; then version-changelog CHANGELOG.md && changelog-verify CHANGELOG.md && git add CHANGELOG.md; else echo; fi" | ||
"version": "if [ $(git rev-parse --abbrev-ref HEAD) == 'master' ]; then version-changelog CHANGELOG.md && changelog-verify CHANGELOG.md && git add CHANGELOG.md; else echo; fi", | ||
"lint:types": "tsc" | ||
}, | ||
"dependencies": { | ||
"@types/is-typedarray": "^1.0.0", | ||
"is-typedarray": "^1.0.0" | ||
}, | ||
"devDependencies": { | ||
@@ -51,16 +57,20 @@ "@babel/cli": "^7.2.3", | ||
"@rollup/plugin-node-resolve": "^9.0.0", | ||
"@types/karma-fixture": "^0.2.5", | ||
"@types/mocha": "^8.2.3", | ||
"@types/node": "^16.3.0", | ||
"changelog-verify": "^1.1.2", | ||
"core-js": "^2.6.5", | ||
"eslint": "^7.11.0", | ||
"eslint-config-niksy": "^9.0.0", | ||
"eslint-config-prettier": "^6.14.0", | ||
"eslint-plugin-extend": "^0.1.1", | ||
"eslint-plugin-import": "^2.22.1", | ||
"eslint-plugin-jsdoc": "^30.7.3", | ||
"cpy": "^8.1.2", | ||
"eslint": "^7.31.0", | ||
"eslint-config-niksy": "^10.0.0", | ||
"eslint-config-prettier": "^8.3.0", | ||
"eslint-plugin-import": "^2.23.4", | ||
"eslint-plugin-jsdoc": "^33.3.0", | ||
"eslint-plugin-mocha": "^8.0.0", | ||
"eslint-plugin-node": "^11.1.0", | ||
"eslint-plugin-prettier": "^3.0.1", | ||
"eslint-plugin-promise": "^4.1.1", | ||
"eslint-plugin-unicorn": "^23.0.0", | ||
"eslint-plugin-prettier": "^3.4.0", | ||
"eslint-plugin-promise": "^5.1.0", | ||
"eslint-plugin-unicorn": "^31.0.0", | ||
"esm": "^3.0.51", | ||
"execa": "^5.1.1", | ||
"github-release-from-changelog": "^2.1.1", | ||
@@ -71,3 +81,3 @@ "husky": "^4.3.0", | ||
"karma-chrome-launcher": "^3.1.0", | ||
"karma-coverage-istanbul-reporter": "^3.0.3", | ||
"karma-coverage": "^2.0.3", | ||
"karma-fixture": "^0.2.6", | ||
@@ -87,2 +97,3 @@ "karma-html2js-preprocessor": "^1.1.0", | ||
"rollup-plugin-node-globals": "^1.4.0", | ||
"typescript": "^4.3.5", | ||
"version-changelog": "^3.1.1" | ||
@@ -89,0 +100,0 @@ }, |
# array-string-at | ||
[![Build Status][ci-img]][ci] | ||
[![BrowserStack Status][browserstack-img]][browserstack] | ||
[![Browser testing by BrowserStack][browserstack-img]][browserstack] | ||
@@ -62,3 +62,3 @@ [Array/string `.at()`](https://github.com/tc39/proposal-relative-indexing-method) | ||
Type: `string|Array` | ||
Type: `string|Array<unknown>|TypedArray` | ||
@@ -97,4 +97,4 @@ Item to search. | ||
[browserstack]: https://www.browserstack.com/ | ||
[browserstack-img]: https://www.browserstack.com/automate/badge.svg?badge_key=RUJVZTdFUy9NenNXaTdMYU54aDlnKy9TOFNhNTl4ZlBPNitVVXh1ZWpBVT0tLUpFWk9iWkxRdDV5eUJiWVg3Qm1QTnc9PQ==--e7a7b6fb5fd32b1dd45755978da5c71ab1dbaca0 | ||
[browserstack-img]: https://img.shields.io/badge/browser%20testing-BrowserStack-informational?logo= | ||
<!-- prettier-ignore-end --> |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
26584
14
187
2
48
1
+ Added@types/is-typedarray@^1.0.0
+ Addedis-typedarray@^1.0.0
+ Added@types/is-typedarray@1.0.2(transitive)
+ Added@types/node@22.10.2(transitive)
+ Addedis-typedarray@1.0.0(transitive)
+ Addedundici-types@6.20.0(transitive)