match-sorter
Advanced tools
Comparing version 3.0.0 to 3.0.1
@@ -745,3 +745,3 @@ 'use strict'; | ||
* A number close to rankings.MATCHES represents a loose match. A number close | ||
* to rankings.MATCHES + 1 represents a loose match. | ||
* to rankings.MATCHES + 1 represents a tighter match. | ||
* @param {String} testString - the string to test against | ||
@@ -753,2 +753,3 @@ * @param {String} stringToRank - the string to rank | ||
function getClosenessRanking(testString, stringToRank) { | ||
var matchingInOrderCharCount = 0; | ||
var charNumber = 0; | ||
@@ -759,2 +760,3 @@ function findMatchingCharacter(matchChar, string, index) { | ||
if (stringChar === matchChar) { | ||
matchingInOrderCharCount += 1; | ||
return j + 1; | ||
@@ -765,3 +767,7 @@ } | ||
} | ||
function getRanking(spread) { | ||
var inOrderPercentage = matchingInOrderCharCount / stringToRank.length; | ||
return 1 + inOrderPercentage * (1 / spread); | ||
} | ||
var firstIndex = findMatchingCharacter(stringToRank[0], testString, 0); | ||
@@ -782,7 +788,3 @@ if (firstIndex < 0) { | ||
var spread = charNumber - firstIndex; | ||
return function (spread) { | ||
var matching = spread - stringToRank.length + 1; | ||
var ranking = rankings.MATCHES + 1 / matching; | ||
return ranking; | ||
}(spread); | ||
return getRanking(spread); | ||
} | ||
@@ -789,0 +791,0 @@ |
@@ -743,3 +743,3 @@ var characterMap = { | ||
* A number close to rankings.MATCHES represents a loose match. A number close | ||
* to rankings.MATCHES + 1 represents a loose match. | ||
* to rankings.MATCHES + 1 represents a tighter match. | ||
* @param {String} testString - the string to test against | ||
@@ -751,2 +751,3 @@ * @param {String} stringToRank - the string to rank | ||
function getClosenessRanking(testString, stringToRank) { | ||
var matchingInOrderCharCount = 0; | ||
var charNumber = 0; | ||
@@ -757,2 +758,3 @@ function findMatchingCharacter(matchChar, string, index) { | ||
if (stringChar === matchChar) { | ||
matchingInOrderCharCount += 1; | ||
return j + 1; | ||
@@ -763,3 +765,7 @@ } | ||
} | ||
function getRanking(spread) { | ||
var inOrderPercentage = matchingInOrderCharCount / stringToRank.length; | ||
return 1 + inOrderPercentage * (1 / spread); | ||
} | ||
var firstIndex = findMatchingCharacter(stringToRank[0], testString, 0); | ||
@@ -780,7 +786,3 @@ if (firstIndex < 0) { | ||
var spread = charNumber - firstIndex; | ||
return function (spread) { | ||
var matching = spread - stringToRank.length + 1; | ||
var ranking = rankings.MATCHES + 1 / matching; | ||
return ranking; | ||
}(spread); | ||
return getRanking(spread); | ||
} | ||
@@ -787,0 +789,0 @@ |
@@ -749,3 +749,3 @@ (function (global, factory) { | ||
* A number close to rankings.MATCHES represents a loose match. A number close | ||
* to rankings.MATCHES + 1 represents a loose match. | ||
* to rankings.MATCHES + 1 represents a tighter match. | ||
* @param {String} testString - the string to test against | ||
@@ -757,2 +757,3 @@ * @param {String} stringToRank - the string to rank | ||
function getClosenessRanking(testString, stringToRank) { | ||
var matchingInOrderCharCount = 0; | ||
var charNumber = 0; | ||
@@ -763,2 +764,3 @@ function findMatchingCharacter(matchChar, string, index) { | ||
if (stringChar === matchChar) { | ||
matchingInOrderCharCount += 1; | ||
return j + 1; | ||
@@ -769,3 +771,7 @@ } | ||
} | ||
function getRanking(spread) { | ||
var inOrderPercentage = matchingInOrderCharCount / stringToRank.length; | ||
return 1 + inOrderPercentage * (1 / spread); | ||
} | ||
var firstIndex = findMatchingCharacter(stringToRank[0], testString, 0); | ||
@@ -786,7 +792,3 @@ if (firstIndex < 0) { | ||
var spread = charNumber - firstIndex; | ||
return function (spread) { | ||
var matching = spread - stringToRank.length + 1; | ||
var ranking = rankings.MATCHES + 1 / matching; | ||
return ranking; | ||
}(spread); | ||
return getRanking(spread); | ||
} | ||
@@ -793,0 +795,0 @@ |
@@ -1,2 +0,2 @@ | ||
!function(e,n){"object"==typeof exports&&"undefined"!=typeof module?module.exports=n():"function"==typeof define&&define.amd?define(n):e.matchSorter=n()}(this,function(){"use strict";var e={"À":"A","Á":"A","Â":"A","Ã":"A","Ä":"A","Å":"A","Ấ":"A","Ắ":"A","Ẳ":"A","Ẵ":"A","Ặ":"A","Æ":"AE","Ầ":"A","Ằ":"A","Ȃ":"A","Ç":"C","Ḉ":"C","È":"E","É":"E","Ê":"E","Ë":"E","Ế":"E","Ḗ":"E","Ề":"E","Ḕ":"E","Ḝ":"E","Ȇ":"E","Ì":"I","Í":"I","Î":"I","Ï":"I","Ḯ":"I","Ȋ":"I","Ð":"D","Ñ":"N","Ò":"O","Ó":"O","Ô":"O","Õ":"O","Ö":"O","Ø":"O","Ố":"O","Ṍ":"O","Ṓ":"O","Ȏ":"O","Ù":"U","Ú":"U","Û":"U","Ü":"U","Ý":"Y","à":"a","á":"a","â":"a","ã":"a","ä":"a","å":"a","ấ":"a","ắ":"a","ẳ":"a","ẵ":"a","ặ":"a","æ":"ae","ầ":"a","ằ":"a","ȃ":"a","ç":"c","ḉ":"c","è":"e","é":"e","ê":"e","ë":"e","ế":"e","ḗ":"e","ề":"e","ḕ":"e","ḝ":"e","ȇ":"e","ì":"i","í":"i","î":"i","ï":"i","ḯ":"i","ȋ":"i","ð":"d","ñ":"n","ò":"o","ó":"o","ô":"o","õ":"o","ö":"o","ø":"o","ố":"o","ṍ":"o","ṓ":"o","ȏ":"o","ù":"u","ú":"u","û":"u","ü":"u","ý":"y","ÿ":"y","Ā":"A","ā":"a","Ă":"A","ă":"a","Ą":"A","ą":"a","Ć":"C","ć":"c","Ĉ":"C","ĉ":"c","Ċ":"C","ċ":"c","Č":"C","č":"c","C̆":"C","c̆":"c","Ď":"D","ď":"d","Đ":"D","đ":"d","Ē":"E","ē":"e","Ĕ":"E","ĕ":"e","Ė":"E","ė":"e","Ę":"E","ę":"e","Ě":"E","ě":"e","Ĝ":"G","Ǵ":"G","ĝ":"g","ǵ":"g","Ğ":"G","ğ":"g","Ġ":"G","ġ":"g","Ģ":"G","ģ":"g","Ĥ":"H","ĥ":"h","Ħ":"H","ħ":"h","Ḫ":"H","ḫ":"h","Ĩ":"I","ĩ":"i","Ī":"I","ī":"i","Ĭ":"I","ĭ":"i","Į":"I","į":"i","İ":"I","ı":"i","IJ":"IJ","ij":"ij","Ĵ":"J","ĵ":"j","Ķ":"K","ķ":"k","Ḱ":"K","ḱ":"k","K̆":"K","k̆":"k","Ĺ":"L","ĺ":"l","Ļ":"L","ļ":"l","Ľ":"L","ľ":"l","Ŀ":"L","ŀ":"l","Ł":"l","ł":"l","Ḿ":"M","ḿ":"m","M̆":"M","m̆":"m","Ń":"N","ń":"n","Ņ":"N","ņ":"n","Ň":"N","ň":"n","ʼn":"n","N̆":"N","n̆":"n","Ō":"O","ō":"o","Ŏ":"O","ŏ":"o","Ő":"O","ő":"o","Œ":"OE","œ":"oe","P̆":"P","p̆":"p","Ŕ":"R","ŕ":"r","Ŗ":"R","ŗ":"r","Ř":"R","ř":"r","R̆":"R","r̆":"r","Ȓ":"R","ȓ":"r","Ś":"S","ś":"s","Ŝ":"S","ŝ":"s","Ş":"S","Ș":"S","ș":"s","ş":"s","Š":"S","š":"s","Ţ":"T","ţ":"t","ț":"t","Ț":"T","Ť":"T","ť":"t","Ŧ":"T","ŧ":"t","T̆":"T","t̆":"t","Ũ":"U","ũ":"u","Ū":"U","ū":"u","Ŭ":"U","ŭ":"u","Ů":"U","ů":"u","Ű":"U","ű":"u","Ų":"U","ų":"u","Ȗ":"U","ȗ":"u","V̆":"V","v̆":"v","Ŵ":"W","ŵ":"w","Ẃ":"W","ẃ":"w","X̆":"X","x̆":"x","Ŷ":"Y","ŷ":"y","Ÿ":"Y","Y̆":"Y","y̆":"y","Ź":"Z","ź":"z","Ż":"Z","ż":"z","Ž":"Z","ž":"z","ſ":"s","ƒ":"f","Ơ":"O","ơ":"o","Ư":"U","ư":"u","Ǎ":"A","ǎ":"a","Ǐ":"I","ǐ":"i","Ǒ":"O","ǒ":"o","Ǔ":"U","ǔ":"u","Ǖ":"U","ǖ":"u","Ǘ":"U","ǘ":"u","Ǚ":"U","ǚ":"u","Ǜ":"U","ǜ":"u","Ứ":"U","ứ":"u","Ṹ":"U","ṹ":"u","Ǻ":"A","ǻ":"a","Ǽ":"AE","ǽ":"ae","Ǿ":"O","ǿ":"o","Þ":"TH","þ":"th","Ṕ":"P","ṕ":"p","Ṥ":"S","ṥ":"s","X́":"X","x́":"x","Ѓ":"Г","ѓ":"г","Ќ":"К","ќ":"к","A̋":"A","a̋":"a","E̋":"E","e̋":"e","I̋":"I","i̋":"i","Ǹ":"N","ǹ":"n","Ồ":"O","ồ":"o","Ṑ":"O","ṑ":"o","Ừ":"U","ừ":"u","Ẁ":"W","ẁ":"w","Ỳ":"Y","ỳ":"y","Ȁ":"A","ȁ":"a","Ȅ":"E","ȅ":"e","Ȉ":"I","ȉ":"i","Ȍ":"O","ȍ":"o","Ȑ":"R","ȑ":"r","Ȕ":"U","ȕ":"u","B̌":"B","b̌":"b","Č̣":"C","č̣":"c","Ê̌":"E","ê̌":"e","F̌":"F","f̌":"f","Ǧ":"G","ǧ":"g","Ȟ":"H","ȟ":"h","J̌":"J","ǰ":"j","Ǩ":"K","ǩ":"k","M̌":"M","m̌":"m","P̌":"P","p̌":"p","Q̌":"Q","q̌":"q","Ř̩":"R","ř̩":"r","Ṧ":"S","ṧ":"s","V̌":"V","v̌":"v","W̌":"W","w̌":"w","X̌":"X","x̌":"x","Y̌":"Y","y̌":"y","A̧":"A","a̧":"a","B̧":"B","b̧":"b","Ḑ":"D","ḑ":"d","Ȩ":"E","ȩ":"e","Ɛ̧":"E","ɛ̧":"e","Ḩ":"H","ḩ":"h","I̧":"I","i̧":"i","Ɨ̧":"I","ɨ̧":"i","M̧":"M","m̧":"m","O̧":"O","o̧":"o","Q̧":"Q","q̧":"q","U̧":"U","u̧":"u","X̧":"X","x̧":"x","Z̧":"Z","z̧":"z"},n=Object.keys(e).join("|"),r=new RegExp(n,"g"),t=new RegExp(n,""),o=function(n){return n.replace(r,function(n){return e[n]})},u=o,i=function(e){return!!e.match(t)},a=o;u.has=i,u.remove=a;var c="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},f=Object.assign||function(e){for(var n=1;n<arguments.length;n++){var r=arguments[n];for(var t in r)Object.prototype.hasOwnProperty.call(r,t)&&(e[t]=r[t])}return e},A={CASE_SENSITIVE_EQUAL:9,EQUAL:8,STARTS_WITH:7,WORD_STARTS_WITH:6,STRING_CASE:5,STRING_CASE_ACRONYM:4,CONTAINS:3,ACRONYM:2,MATCHES:1,NO_MATCH:0},s={CAMEL:.8,PASCAL:.6,KEBAB:.4,SNAKE:.2,NO_CASE:0};function E(e,n){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};if(!n)return e;var t=r.keys,o=r.threshold,u=void 0===o?A.MATCHES:o;return e.reduce(function(e,o,i){var a=function(e,n,r,t){if(!n)return{rank:d(e,r,t),keyIndex:-1,keyThreshold:t.threshold};return function(e,n){return n.reduce(function(n,r){var t=function(e,n){"object"===(void 0===n?"undefined":c(n))&&(n=n.key);var r=void 0;r="function"==typeof n?n(e):-1!==n.indexOf(".")?n.split(".").reduce(function(e,n){return e?e[n]:null},e):e[n];return null!=r?[].concat(r):null}(e,r);return t&&t.forEach(function(e){n.push({itemValue:e,attributes:function(e){"string"==typeof e&&(e={key:e});return f({maxRanking:1/0,minRanking:-1/0},e)}(r)})}),n},[])}(e,n).reduce(function(e,n,o){var u=e.rank,i=e.keyIndex,a=e.keyThreshold,c=n.itemValue,f=n.attributes,s=d(c,r,t),E=f.minRanking,l=f.maxRanking,O=f.threshold;return s<E&&s>=A.MATCHES?s=E:s>l&&(s=l),s>u&&(u=s,i=o,a=O),{rank:u,keyIndex:i,keyThreshold:a}},{rank:A.NO_MATCH,keyIndex:-1,keyThreshold:t.threshold})}(o,t,n,r),s=a.rank,E=a.keyIndex,l=a.keyThreshold;return s>=(void 0===l?u:l)&&e.push({item:o,rank:s,index:i,keyIndex:E}),e},[]).sort(l).map(function(e){return e.item})}function d(e,n,r){if(e=O(e,r),(n=O(n,r)).length>e.length)return A.NO_MATCH;if(e===n)return A.CASE_SENSITIVE_EQUAL;var t,o,u=function(e){var n=e.toLowerCase()!==e,r=e.indexOf("-")>=0,t=e.indexOf("_")>=0;if(!n&&!t&&r)return s.KEBAB;if(!n&&t&&!r)return s.SNAKE;if(n&&!r&&!t){var o=e[0].toUpperCase()===e[0];return o?s.PASCAL:s.CAMEL}return s.NO_CASE}(e),i=function(e,n,r){var t=e.toLowerCase().indexOf(n.toLowerCase());switch(r){case s.SNAKE:return"_"===e[t-1];case s.KEBAB:return"-"===e[t-1];case s.PASCAL:case s.CAMEL:return-1!==t&&e[t]===e[t].toUpperCase();default:return!1}}(e,n,u),a=function(e,n,r){var t=null;switch(r){case s.SNAKE:t="_";break;case s.KEBAB:t="-";break;case s.PASCAL:case s.CAMEL:t=/(?=[A-Z])/;break;default:t=null}var o=e.split(t);return n.toLowerCase().split("").reduce(function(e,n,r){var t=o[r];return e&&t&&t[0].toLowerCase()===n},!0)}(e,n,u);return(e=e.toLowerCase())===(n=n.toLowerCase())?A.EQUAL+u:0===e.indexOf(n)?A.STARTS_WITH+u:-1!==e.indexOf(" "+n)?A.WORD_STARTS_WITH+u:i?A.STRING_CASE+u:u>0&&a?A.STRING_CASE_ACRONYM+u:-1!==e.indexOf(n)?A.CONTAINS+u:1===n.length?A.NO_MATCH:-1!==(t=e,o="",t.split(" ").forEach(function(e){e.split("-").forEach(function(e){o+=e.substr(0,1)})}),o).indexOf(n)?A.ACRONYM+u:function(e,n){var r=0;function t(e,n,r){for(var t=r;t<n.length;t++){var o=n[t];if(o===e)return t+1}return-1}var o=t(n[0],e,0);if(o<0)return A.NO_MATCH;r=o;for(var u=1;u<n.length;u++){var i=n[u],a=(r=t(i,e,r))>-1;if(!a)return A.NO_MATCH}return function(e){var r=e-n.length+1,t=A.MATCHES+1/r;return t}(r-o)}(e,n)}function l(e,n){var r=e.rank,t=e.index,o=e.keyIndex,u=n.rank,i=n.index,a=n.keyIndex;return r===u?o===a?t<i?-1:1:o<a?-1:1:r>u?-1:1}function O(e,n){return e=""+e,n.keepDiacritics||(e=u(e)),e}E.rankings=A,E.caseRankings=s;var S=Object.freeze({default:E,rankings:A}),C=E;return Object.assign(C,Object.keys(S).reduce(function(e,n){return"default"!==n&&(e[n]=S[n]),e},{})),C}); | ||
!function(e,n){"object"==typeof exports&&"undefined"!=typeof module?module.exports=n():"function"==typeof define&&define.amd?define(n):e.matchSorter=n()}(this,function(){"use strict";var e={"À":"A","Á":"A","Â":"A","Ã":"A","Ä":"A","Å":"A","Ấ":"A","Ắ":"A","Ẳ":"A","Ẵ":"A","Ặ":"A","Æ":"AE","Ầ":"A","Ằ":"A","Ȃ":"A","Ç":"C","Ḉ":"C","È":"E","É":"E","Ê":"E","Ë":"E","Ế":"E","Ḗ":"E","Ề":"E","Ḕ":"E","Ḝ":"E","Ȇ":"E","Ì":"I","Í":"I","Î":"I","Ï":"I","Ḯ":"I","Ȋ":"I","Ð":"D","Ñ":"N","Ò":"O","Ó":"O","Ô":"O","Õ":"O","Ö":"O","Ø":"O","Ố":"O","Ṍ":"O","Ṓ":"O","Ȏ":"O","Ù":"U","Ú":"U","Û":"U","Ü":"U","Ý":"Y","à":"a","á":"a","â":"a","ã":"a","ä":"a","å":"a","ấ":"a","ắ":"a","ẳ":"a","ẵ":"a","ặ":"a","æ":"ae","ầ":"a","ằ":"a","ȃ":"a","ç":"c","ḉ":"c","è":"e","é":"e","ê":"e","ë":"e","ế":"e","ḗ":"e","ề":"e","ḕ":"e","ḝ":"e","ȇ":"e","ì":"i","í":"i","î":"i","ï":"i","ḯ":"i","ȋ":"i","ð":"d","ñ":"n","ò":"o","ó":"o","ô":"o","õ":"o","ö":"o","ø":"o","ố":"o","ṍ":"o","ṓ":"o","ȏ":"o","ù":"u","ú":"u","û":"u","ü":"u","ý":"y","ÿ":"y","Ā":"A","ā":"a","Ă":"A","ă":"a","Ą":"A","ą":"a","Ć":"C","ć":"c","Ĉ":"C","ĉ":"c","Ċ":"C","ċ":"c","Č":"C","č":"c","C̆":"C","c̆":"c","Ď":"D","ď":"d","Đ":"D","đ":"d","Ē":"E","ē":"e","Ĕ":"E","ĕ":"e","Ė":"E","ė":"e","Ę":"E","ę":"e","Ě":"E","ě":"e","Ĝ":"G","Ǵ":"G","ĝ":"g","ǵ":"g","Ğ":"G","ğ":"g","Ġ":"G","ġ":"g","Ģ":"G","ģ":"g","Ĥ":"H","ĥ":"h","Ħ":"H","ħ":"h","Ḫ":"H","ḫ":"h","Ĩ":"I","ĩ":"i","Ī":"I","ī":"i","Ĭ":"I","ĭ":"i","Į":"I","į":"i","İ":"I","ı":"i","IJ":"IJ","ij":"ij","Ĵ":"J","ĵ":"j","Ķ":"K","ķ":"k","Ḱ":"K","ḱ":"k","K̆":"K","k̆":"k","Ĺ":"L","ĺ":"l","Ļ":"L","ļ":"l","Ľ":"L","ľ":"l","Ŀ":"L","ŀ":"l","Ł":"l","ł":"l","Ḿ":"M","ḿ":"m","M̆":"M","m̆":"m","Ń":"N","ń":"n","Ņ":"N","ņ":"n","Ň":"N","ň":"n","ʼn":"n","N̆":"N","n̆":"n","Ō":"O","ō":"o","Ŏ":"O","ŏ":"o","Ő":"O","ő":"o","Œ":"OE","œ":"oe","P̆":"P","p̆":"p","Ŕ":"R","ŕ":"r","Ŗ":"R","ŗ":"r","Ř":"R","ř":"r","R̆":"R","r̆":"r","Ȓ":"R","ȓ":"r","Ś":"S","ś":"s","Ŝ":"S","ŝ":"s","Ş":"S","Ș":"S","ș":"s","ş":"s","Š":"S","š":"s","Ţ":"T","ţ":"t","ț":"t","Ț":"T","Ť":"T","ť":"t","Ŧ":"T","ŧ":"t","T̆":"T","t̆":"t","Ũ":"U","ũ":"u","Ū":"U","ū":"u","Ŭ":"U","ŭ":"u","Ů":"U","ů":"u","Ű":"U","ű":"u","Ų":"U","ų":"u","Ȗ":"U","ȗ":"u","V̆":"V","v̆":"v","Ŵ":"W","ŵ":"w","Ẃ":"W","ẃ":"w","X̆":"X","x̆":"x","Ŷ":"Y","ŷ":"y","Ÿ":"Y","Y̆":"Y","y̆":"y","Ź":"Z","ź":"z","Ż":"Z","ż":"z","Ž":"Z","ž":"z","ſ":"s","ƒ":"f","Ơ":"O","ơ":"o","Ư":"U","ư":"u","Ǎ":"A","ǎ":"a","Ǐ":"I","ǐ":"i","Ǒ":"O","ǒ":"o","Ǔ":"U","ǔ":"u","Ǖ":"U","ǖ":"u","Ǘ":"U","ǘ":"u","Ǚ":"U","ǚ":"u","Ǜ":"U","ǜ":"u","Ứ":"U","ứ":"u","Ṹ":"U","ṹ":"u","Ǻ":"A","ǻ":"a","Ǽ":"AE","ǽ":"ae","Ǿ":"O","ǿ":"o","Þ":"TH","þ":"th","Ṕ":"P","ṕ":"p","Ṥ":"S","ṥ":"s","X́":"X","x́":"x","Ѓ":"Г","ѓ":"г","Ќ":"К","ќ":"к","A̋":"A","a̋":"a","E̋":"E","e̋":"e","I̋":"I","i̋":"i","Ǹ":"N","ǹ":"n","Ồ":"O","ồ":"o","Ṑ":"O","ṑ":"o","Ừ":"U","ừ":"u","Ẁ":"W","ẁ":"w","Ỳ":"Y","ỳ":"y","Ȁ":"A","ȁ":"a","Ȅ":"E","ȅ":"e","Ȉ":"I","ȉ":"i","Ȍ":"O","ȍ":"o","Ȑ":"R","ȑ":"r","Ȕ":"U","ȕ":"u","B̌":"B","b̌":"b","Č̣":"C","č̣":"c","Ê̌":"E","ê̌":"e","F̌":"F","f̌":"f","Ǧ":"G","ǧ":"g","Ȟ":"H","ȟ":"h","J̌":"J","ǰ":"j","Ǩ":"K","ǩ":"k","M̌":"M","m̌":"m","P̌":"P","p̌":"p","Q̌":"Q","q̌":"q","Ř̩":"R","ř̩":"r","Ṧ":"S","ṧ":"s","V̌":"V","v̌":"v","W̌":"W","w̌":"w","X̌":"X","x̌":"x","Y̌":"Y","y̌":"y","A̧":"A","a̧":"a","B̧":"B","b̧":"b","Ḑ":"D","ḑ":"d","Ȩ":"E","ȩ":"e","Ɛ̧":"E","ɛ̧":"e","Ḩ":"H","ḩ":"h","I̧":"I","i̧":"i","Ɨ̧":"I","ɨ̧":"i","M̧":"M","m̧":"m","O̧":"O","o̧":"o","Q̧":"Q","q̧":"q","U̧":"U","u̧":"u","X̧":"X","x̧":"x","Z̧":"Z","z̧":"z"},n=Object.keys(e).join("|"),r=new RegExp(n,"g"),t=new RegExp(n,""),o=function(n){return n.replace(r,function(n){return e[n]})},u=o,i=function(e){return!!e.match(t)},a=o;u.has=i,u.remove=a;var c="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},f=Object.assign||function(e){for(var n=1;n<arguments.length;n++){var r=arguments[n];for(var t in r)Object.prototype.hasOwnProperty.call(r,t)&&(e[t]=r[t])}return e},A={CASE_SENSITIVE_EQUAL:9,EQUAL:8,STARTS_WITH:7,WORD_STARTS_WITH:6,STRING_CASE:5,STRING_CASE_ACRONYM:4,CONTAINS:3,ACRONYM:2,MATCHES:1,NO_MATCH:0},s={CAMEL:.8,PASCAL:.6,KEBAB:.4,SNAKE:.2,NO_CASE:0};function E(e,n){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};if(!n)return e;var t=r.keys,o=r.threshold,u=void 0===o?A.MATCHES:o;return e.reduce(function(e,o,i){var a=function(e,n,r,t){if(!n)return{rank:d(e,r,t),keyIndex:-1,keyThreshold:t.threshold};return function(e,n){return n.reduce(function(n,r){var t=function(e,n){"object"===(void 0===n?"undefined":c(n))&&(n=n.key);var r=void 0;r="function"==typeof n?n(e):-1!==n.indexOf(".")?n.split(".").reduce(function(e,n){return e?e[n]:null},e):e[n];return null!=r?[].concat(r):null}(e,r);return t&&t.forEach(function(e){n.push({itemValue:e,attributes:function(e){"string"==typeof e&&(e={key:e});return f({maxRanking:1/0,minRanking:-1/0},e)}(r)})}),n},[])}(e,n).reduce(function(e,n,o){var u=e.rank,i=e.keyIndex,a=e.keyThreshold,c=n.itemValue,f=n.attributes,s=d(c,r,t),E=f.minRanking,l=f.maxRanking,O=f.threshold;return s<E&&s>=A.MATCHES?s=E:s>l&&(s=l),s>u&&(u=s,i=o,a=O),{rank:u,keyIndex:i,keyThreshold:a}},{rank:A.NO_MATCH,keyIndex:-1,keyThreshold:t.threshold})}(o,t,n,r),s=a.rank,E=a.keyIndex,l=a.keyThreshold;return s>=(void 0===l?u:l)&&e.push({item:o,rank:s,index:i,keyIndex:E}),e},[]).sort(l).map(function(e){return e.item})}function d(e,n,r){if(e=O(e,r),(n=O(n,r)).length>e.length)return A.NO_MATCH;if(e===n)return A.CASE_SENSITIVE_EQUAL;var t,o,u=function(e){var n=e.toLowerCase()!==e,r=e.indexOf("-")>=0,t=e.indexOf("_")>=0;if(!n&&!t&&r)return s.KEBAB;if(!n&&t&&!r)return s.SNAKE;if(n&&!r&&!t){var o=e[0].toUpperCase()===e[0];return o?s.PASCAL:s.CAMEL}return s.NO_CASE}(e),i=function(e,n,r){var t=e.toLowerCase().indexOf(n.toLowerCase());switch(r){case s.SNAKE:return"_"===e[t-1];case s.KEBAB:return"-"===e[t-1];case s.PASCAL:case s.CAMEL:return-1!==t&&e[t]===e[t].toUpperCase();default:return!1}}(e,n,u),a=function(e,n,r){var t=null;switch(r){case s.SNAKE:t="_";break;case s.KEBAB:t="-";break;case s.PASCAL:case s.CAMEL:t=/(?=[A-Z])/;break;default:t=null}var o=e.split(t);return n.toLowerCase().split("").reduce(function(e,n,r){var t=o[r];return e&&t&&t[0].toLowerCase()===n},!0)}(e,n,u);return(e=e.toLowerCase())===(n=n.toLowerCase())?A.EQUAL+u:0===e.indexOf(n)?A.STARTS_WITH+u:-1!==e.indexOf(" "+n)?A.WORD_STARTS_WITH+u:i?A.STRING_CASE+u:u>0&&a?A.STRING_CASE_ACRONYM+u:-1!==e.indexOf(n)?A.CONTAINS+u:1===n.length?A.NO_MATCH:-1!==(t=e,o="",t.split(" ").forEach(function(e){e.split("-").forEach(function(e){o+=e.substr(0,1)})}),o).indexOf(n)?A.ACRONYM+u:function(e,n){var r=0,t=0;function o(e,n,t){for(var o=t;o<n.length;o++){var u=n[o];if(u===e)return r+=1,o+1}return-1}var u=o(n[0],e,0);if(u<0)return A.NO_MATCH;t=u;for(var i=1;i<n.length;i++){var a=n[i],c=(t=o(a,e,t))>-1;if(!c)return A.NO_MATCH}return function(e){return 1+r/n.length*(1/e)}(t-u)}(e,n)}function l(e,n){var r=e.rank,t=e.index,o=e.keyIndex,u=n.rank,i=n.index,a=n.keyIndex;return r===u?o===a?t<i?-1:1:o<a?-1:1:r>u?-1:1}function O(e,n){return e=""+e,n.keepDiacritics||(e=u(e)),e}E.rankings=A,E.caseRankings=s;var S=Object.freeze({default:E,rankings:A}),C=E;return Object.assign(C,Object.keys(S).reduce(function(e,n){return"default"!==n&&(e[n]=S[n]),e},{})),C}); | ||
//# sourceMappingURL=match-sorter.umd.min.js.map |
{ | ||
"name": "match-sorter", | ||
"version": "3.0.0", | ||
"version": "3.0.1", | ||
"description": "Simple, expected, and deterministic best-match sorting of an array in JavaScript", | ||
@@ -5,0 +5,0 @@ "main": "dist/match-sorter.cjs.js", |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
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
182171
3030
0