35 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			35 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| "use strict";
 | |
| Object.defineProperty(exports, "__esModule", { value: true });
 | |
| exports.noCase = void 0;
 | |
| var lower_case_1 = require("lower-case");
 | |
| // Support camel case ("camelCase" -> "camel Case" and "CAMELCase" -> "CAMEL Case").
 | |
| var DEFAULT_SPLIT_REGEXP = [/([a-z0-9])([A-Z])/g, /([A-Z])([A-Z][a-z])/g];
 | |
| // Remove all non-word characters.
 | |
| var DEFAULT_STRIP_REGEXP = /[^A-Z0-9]+/gi;
 | |
| /**
 | |
|  * Normalize the string into something other libraries can manipulate easier.
 | |
|  */
 | |
| function noCase(input, options) {
 | |
|     if (options === void 0) { options = {}; }
 | |
|     var _a = options.splitRegexp, splitRegexp = _a === void 0 ? DEFAULT_SPLIT_REGEXP : _a, _b = options.stripRegexp, stripRegexp = _b === void 0 ? DEFAULT_STRIP_REGEXP : _b, _c = options.transform, transform = _c === void 0 ? lower_case_1.lowerCase : _c, _d = options.delimiter, delimiter = _d === void 0 ? " " : _d;
 | |
|     var result = replace(replace(input, splitRegexp, "$1\0$2"), stripRegexp, "\0");
 | |
|     var start = 0;
 | |
|     var end = result.length;
 | |
|     // Trim the delimiter from around the output string.
 | |
|     while (result.charAt(start) === "\0")
 | |
|         start++;
 | |
|     while (result.charAt(end - 1) === "\0")
 | |
|         end--;
 | |
|     // Transform each token independently.
 | |
|     return result.slice(start, end).split("\0").map(transform).join(delimiter);
 | |
| }
 | |
| exports.noCase = noCase;
 | |
| /**
 | |
|  * Replace `re` in the input string with the replacement value.
 | |
|  */
 | |
| function replace(input, re, value) {
 | |
|     if (re instanceof RegExp)
 | |
|         return input.replace(re, value);
 | |
|     return re.reduce(function (input, re) { return input.replace(re, value); }, input);
 | |
| }
 | |
| //# sourceMappingURL=index.js.map
 |