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