1 | ;
|
2 | /**
|
3 | * @license
|
4 | * Copyright Google LLC All Rights Reserved.
|
5 | *
|
6 | * Use of this source code is governed by an MIT-style license that can be
|
7 | * found in the LICENSE file at https://angular.io/license
|
8 | */
|
9 | Object.defineProperty(exports, "__esModule", { value: true });
|
10 | exports.levenshtein = exports.capitalize = exports.underscore = exports.classify = exports.camelize = exports.dasherize = exports.decamelize = void 0;
|
11 | const STRING_DASHERIZE_REGEXP = /[ _]/g;
|
12 | const STRING_DECAMELIZE_REGEXP = /([a-z\d])([A-Z])/g;
|
13 | const STRING_CAMELIZE_REGEXP = /(-|_|\.|\s)+(.)?/g;
|
14 | const STRING_UNDERSCORE_REGEXP_1 = /([a-z\d])([A-Z]+)/g;
|
15 | const STRING_UNDERSCORE_REGEXP_2 = /-|\s+/g;
|
16 | /**
|
17 | * Converts a camelized string into all lower case separated by underscores.
|
18 | *
|
19 | ```javascript
|
20 | decamelize('innerHTML'); // 'inner_html'
|
21 | decamelize('action_name'); // 'action_name'
|
22 | decamelize('css-class-name'); // 'css-class-name'
|
23 | decamelize('my favorite items'); // 'my favorite items'
|
24 | ```
|
25 |
|
26 | @method decamelize
|
27 | @param {String} str The string to decamelize.
|
28 | @return {String} the decamelized string.
|
29 | */
|
30 | function decamelize(str) {
|
31 | return str.replace(STRING_DECAMELIZE_REGEXP, '$1_$2').toLowerCase();
|
32 | }
|
33 | exports.decamelize = decamelize;
|
34 | /**
|
35 | Replaces underscores, spaces, or camelCase with dashes.
|
36 |
|
37 | ```javascript
|
38 | dasherize('innerHTML'); // 'inner-html'
|
39 | dasherize('action_name'); // 'action-name'
|
40 | dasherize('css-class-name'); // 'css-class-name'
|
41 | dasherize('my favorite items'); // 'my-favorite-items'
|
42 | ```
|
43 |
|
44 | @method dasherize
|
45 | @param {String} str The string to dasherize.
|
46 | @return {String} the dasherized string.
|
47 | */
|
48 | function dasherize(str) {
|
49 | return decamelize(str).replace(STRING_DASHERIZE_REGEXP, '-');
|
50 | }
|
51 | exports.dasherize = dasherize;
|
52 | /**
|
53 | Returns the lowerCamelCase form of a string.
|
54 |
|
55 | ```javascript
|
56 | camelize('innerHTML'); // 'innerHTML'
|
57 | camelize('action_name'); // 'actionName'
|
58 | camelize('css-class-name'); // 'cssClassName'
|
59 | camelize('my favorite items'); // 'myFavoriteItems'
|
60 | camelize('My Favorite Items'); // 'myFavoriteItems'
|
61 | ```
|
62 |
|
63 | @method camelize
|
64 | @param {String} str The string to camelize.
|
65 | @return {String} the camelized string.
|
66 | */
|
67 | function camelize(str) {
|
68 | return str
|
69 | .replace(STRING_CAMELIZE_REGEXP, (_match, _separator, chr) => {
|
70 | return chr ? chr.toUpperCase() : '';
|
71 | })
|
72 | .replace(/^([A-Z])/, (match) => match.toLowerCase());
|
73 | }
|
74 | exports.camelize = camelize;
|
75 | /**
|
76 | Returns the UpperCamelCase form of a string.
|
77 |
|
78 | @example
|
79 | ```javascript
|
80 | 'innerHTML'.classify(); // 'InnerHTML'
|
81 | 'action_name'.classify(); // 'ActionName'
|
82 | 'css-class-name'.classify(); // 'CssClassName'
|
83 | 'my favorite items'.classify(); // 'MyFavoriteItems'
|
84 | 'app.component'.classify(); // 'AppComponent'
|
85 | ```
|
86 | @method classify
|
87 | @param {String} str the string to classify
|
88 | @return {String} the classified string
|
89 | */
|
90 | function classify(str) {
|
91 | return str
|
92 | .split('.')
|
93 | .map((part) => capitalize(camelize(part)))
|
94 | .join('');
|
95 | }
|
96 | exports.classify = classify;
|
97 | /**
|
98 | More general than decamelize. Returns the lower_case_and_underscored
|
99 | form of a string.
|
100 |
|
101 | ```javascript
|
102 | 'innerHTML'.underscore(); // 'inner_html'
|
103 | 'action_name'.underscore(); // 'action_name'
|
104 | 'css-class-name'.underscore(); // 'css_class_name'
|
105 | 'my favorite items'.underscore(); // 'my_favorite_items'
|
106 | ```
|
107 |
|
108 | @method underscore
|
109 | @param {String} str The string to underscore.
|
110 | @return {String} the underscored string.
|
111 | */
|
112 | function underscore(str) {
|
113 | return str
|
114 | .replace(STRING_UNDERSCORE_REGEXP_1, '$1_$2')
|
115 | .replace(STRING_UNDERSCORE_REGEXP_2, '_')
|
116 | .toLowerCase();
|
117 | }
|
118 | exports.underscore = underscore;
|
119 | /**
|
120 | Returns the Capitalized form of a string
|
121 |
|
122 | ```javascript
|
123 | 'innerHTML'.capitalize() // 'InnerHTML'
|
124 | 'action_name'.capitalize() // 'Action_name'
|
125 | 'css-class-name'.capitalize() // 'Css-class-name'
|
126 | 'my favorite items'.capitalize() // 'My favorite items'
|
127 | ```
|
128 |
|
129 | @method capitalize
|
130 | @param {String} str The string to capitalize.
|
131 | @return {String} The capitalized string.
|
132 | */
|
133 | function capitalize(str) {
|
134 | return str.charAt(0).toUpperCase() + str.slice(1);
|
135 | }
|
136 | exports.capitalize = capitalize;
|
137 | /**
|
138 | * Calculate the levenshtein distance of two strings.
|
139 | * See https://en.wikipedia.org/wiki/Levenshtein_distance.
|
140 | * Based off https://gist.github.com/andrei-m/982927 (for using the faster dynamic programming
|
141 | * version).
|
142 | *
|
143 | * @param a String a.
|
144 | * @param b String b.
|
145 | * @returns A number that represents the distance between the two strings. The greater the number
|
146 | * the more distant the strings are from each others.
|
147 | */
|
148 | function levenshtein(a, b) {
|
149 | if (a.length == 0) {
|
150 | return b.length;
|
151 | }
|
152 | if (b.length == 0) {
|
153 | return a.length;
|
154 | }
|
155 | const matrix = [];
|
156 | // increment along the first column of each row
|
157 | for (let i = 0; i <= b.length; i++) {
|
158 | matrix[i] = [i];
|
159 | }
|
160 | // increment each column in the first row
|
161 | for (let j = 0; j <= a.length; j++) {
|
162 | matrix[0][j] = j;
|
163 | }
|
164 | // Fill in the rest of the matrix
|
165 | for (let i = 1; i <= b.length; i++) {
|
166 | for (let j = 1; j <= a.length; j++) {
|
167 | if (b.charAt(i - 1) == a.charAt(j - 1)) {
|
168 | matrix[i][j] = matrix[i - 1][j - 1];
|
169 | }
|
170 | else {
|
171 | matrix[i][j] = Math.min(matrix[i - 1][j - 1] + 1, // substitution
|
172 | matrix[i][j - 1] + 1, // insertion
|
173 | matrix[i - 1][j] + 1);
|
174 | }
|
175 | }
|
176 | }
|
177 | return matrix[b.length][a.length];
|
178 | }
|
179 | exports.levenshtein = levenshtein;
|
180 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"strings.js","sourceRoot":"","sources":["../../../../../../../../packages/angular_devkit/core/src/utils/strings.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nconst STRING_DASHERIZE_REGEXP = /[ _]/g;\nconst STRING_DECAMELIZE_REGEXP = /([a-z\\d])([A-Z])/g;\nconst STRING_CAMELIZE_REGEXP = /(-|_|\\.|\\s)+(.)?/g;\nconst STRING_UNDERSCORE_REGEXP_1 = /([a-z\\d])([A-Z]+)/g;\nconst STRING_UNDERSCORE_REGEXP_2 = /-|\\s+/g;\n\n/**\n * Converts a camelized string into all lower case separated by underscores.\n *\n ```javascript\n decamelize('innerHTML');         // 'inner_html'\n decamelize('action_name');       // 'action_name'\n decamelize('css-class-name');    // 'css-class-name'\n decamelize('my favorite items'); // 'my favorite items'\n ```\n\n @method decamelize\n @param {String} str The string to decamelize.\n @return {String} the decamelized string.\n */\nexport function decamelize(str: string): string {\n  return str.replace(STRING_DECAMELIZE_REGEXP, '$1_$2').toLowerCase();\n}\n\n/**\n Replaces underscores, spaces, or camelCase with dashes.\n\n ```javascript\n dasherize('innerHTML');         // 'inner-html'\n dasherize('action_name');       // 'action-name'\n dasherize('css-class-name');    // 'css-class-name'\n dasherize('my favorite items'); // 'my-favorite-items'\n ```\n\n @method dasherize\n @param {String} str The string to dasherize.\n @return {String} the dasherized string.\n */\nexport function dasherize(str: string): string {\n  return decamelize(str).replace(STRING_DASHERIZE_REGEXP, '-');\n}\n\n/**\n Returns the lowerCamelCase form of a string.\n\n ```javascript\n camelize('innerHTML');          // 'innerHTML'\n camelize('action_name');        // 'actionName'\n camelize('css-class-name');     // 'cssClassName'\n camelize('my favorite items');  // 'myFavoriteItems'\n camelize('My Favorite Items');  // 'myFavoriteItems'\n ```\n\n @method camelize\n @param {String} str The string to camelize.\n @return {String} the camelized string.\n */\nexport function camelize(str: string): string {\n  return str\n    .replace(STRING_CAMELIZE_REGEXP, (_match: string, _separator: string, chr: string) => {\n      return chr ? chr.toUpperCase() : '';\n    })\n    .replace(/^([A-Z])/, (match: string) => match.toLowerCase());\n}\n\n/**\n Returns the UpperCamelCase form of a string.\n\n @example\n ```javascript\n 'innerHTML'.classify();          // 'InnerHTML'\n 'action_name'.classify();        // 'ActionName'\n 'css-class-name'.classify();     // 'CssClassName'\n 'my favorite items'.classify();  // 'MyFavoriteItems'\n 'app.component'.classify();      // 'AppComponent'\n ```\n @method classify\n @param {String} str the string to classify\n @return {String} the classified string\n */\nexport function classify(str: string): string {\n  return str\n    .split('.')\n    .map((part) => capitalize(camelize(part)))\n    .join('');\n}\n\n/**\n More general than decamelize. Returns the lower_case_and_underscored\n form of a string.\n\n ```javascript\n 'innerHTML'.underscore();          // 'inner_html'\n 'action_name'.underscore();        // 'action_name'\n 'css-class-name'.underscore();     // 'css_class_name'\n 'my favorite items'.underscore();  // 'my_favorite_items'\n ```\n\n @method underscore\n @param {String} str The string to underscore.\n @return {String} the underscored string.\n */\nexport function underscore(str: string): string {\n  return str\n    .replace(STRING_UNDERSCORE_REGEXP_1, '$1_$2')\n    .replace(STRING_UNDERSCORE_REGEXP_2, '_')\n    .toLowerCase();\n}\n\n/**\n Returns the Capitalized form of a string\n\n ```javascript\n 'innerHTML'.capitalize()         // 'InnerHTML'\n 'action_name'.capitalize()       // 'Action_name'\n 'css-class-name'.capitalize()    // 'Css-class-name'\n 'my favorite items'.capitalize() // 'My favorite items'\n ```\n\n @method capitalize\n @param {String} str The string to capitalize.\n @return {String} The capitalized string.\n */\nexport function capitalize(str: string): string {\n  return str.charAt(0).toUpperCase() + str.slice(1);\n}\n\n/**\n * Calculate the levenshtein distance of two strings.\n * See https://en.wikipedia.org/wiki/Levenshtein_distance.\n * Based off https://gist.github.com/andrei-m/982927 (for using the faster dynamic programming\n * version).\n *\n * @param a String a.\n * @param b String b.\n * @returns A number that represents the distance between the two strings. The greater the number\n *   the more distant the strings are from each others.\n */\nexport function levenshtein(a: string, b: string): number {\n  if (a.length == 0) {\n    return b.length;\n  }\n  if (b.length == 0) {\n    return a.length;\n  }\n\n  const matrix: number[][] = [];\n\n  // increment along the first column of each row\n  for (let i = 0; i <= b.length; i++) {\n    matrix[i] = [i];\n  }\n\n  // increment each column in the first row\n  for (let j = 0; j <= a.length; j++) {\n    matrix[0][j] = j;\n  }\n\n  // Fill in the rest of the matrix\n  for (let i = 1; i <= b.length; i++) {\n    for (let j = 1; j <= a.length; j++) {\n      if (b.charAt(i - 1) == a.charAt(j - 1)) {\n        matrix[i][j] = matrix[i - 1][j - 1];\n      } else {\n        matrix[i][j] = Math.min(\n          matrix[i - 1][j - 1] + 1, // substitution\n          matrix[i][j - 1] + 1, // insertion\n          matrix[i - 1][j] + 1, // deletion\n        );\n      }\n    }\n  }\n\n  return matrix[b.length][a.length];\n}\n"]} |
\ | No newline at end of file |