forked from peterbe/minimalcss
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathutils.js
More file actions
46 lines (43 loc) · 1.32 KB
/
utils.js
File metadata and controls
46 lines (43 loc) · 1.32 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
/**
* Reduce a CSS selector to be without any pseudo class parts.
* For example, from `a:hover` return `a`. And from `input::-moz-focus-inner`
* to `input`.
* Also, more advanced ones like `a[href^="javascript:"]:after` to
* `a[href^="javascript:"]`.
* The last example works too if the input was `a[href^='javascript:']:after`
* instead (using ' instead of ").
*
* @param {string} selector
* @return {string}
*/
const reduceCSSSelector = selector => {
return selector.split(
/:(?=([^"'\\]*(\\.|["']([^"'\\]*\\.)*[^"'\\]*['"]))*[^"']*$)/g
)[0];
};
/**
* Remove the ' and/or " at the beginning and end of a string if it has it.
* @param {string} string
* @return {string}
*/
const unquoteString = string => {
const first = string.charAt(0);
const last = string.charAt(string.length - 1);
if (first === last && (first === '"' || first === "'")) {
return string.substring(1, string.length - 1);
}
return string;
};
/**
* Removes all sequences of two-or-more semicolons separated by zero-or-more
* whitespace, replacing each sequence with a single semicolon.
* @param {string} css
* @return {string}
*/
const removeSequentialSemis = css => {
while (/;\s*;/.test(css)) {
css = css.replace(/;\s*;/g, ';');
}
return css;
};
module.exports = { reduceCSSSelector, removeSequentialSemis, unquoteString };