1 | const hostContext = (selector, el) => {
|
2 | return el.closest(selector) !== null;
|
3 | };
|
4 |
|
5 |
|
6 |
|
7 | const createColorClasses = (color, cssClassMap) => {
|
8 | return (typeof color === 'string' && color.length > 0) ? Object.assign({ 'ion-color': true, [`ion-color-${color}`]: true }, cssClassMap) : cssClassMap;
|
9 | };
|
10 | const getClassList = (classes) => {
|
11 | if (classes !== undefined) {
|
12 | const array = Array.isArray(classes) ? classes : classes.split(' ');
|
13 | return array
|
14 | .filter(c => c != null)
|
15 | .map(c => c.trim())
|
16 | .filter(c => c !== '');
|
17 | }
|
18 | return [];
|
19 | };
|
20 | const getClassMap = (classes) => {
|
21 | const map = {};
|
22 | getClassList(classes).forEach(c => map[c] = true);
|
23 | return map;
|
24 | };
|
25 | const SCHEME = /^[a-z][a-z0-9+\-.]*:/;
|
26 | const openURL = async (url, ev, direction, animation) => {
|
27 | if (url != null && url[0] !== '#' && !SCHEME.test(url)) {
|
28 | const router = document.querySelector('ion-router');
|
29 | if (router) {
|
30 | if (ev != null) {
|
31 | ev.preventDefault();
|
32 | }
|
33 | return router.push(url, direction, animation);
|
34 | }
|
35 | }
|
36 | return false;
|
37 | };
|
38 |
|
39 | export { createColorClasses as c, getClassMap as g, hostContext as h, openURL as o };
|