UNPKG

1.24 kBJavaScriptView Raw
1const hostContext = (selector, el) => {
2 return el.closest(selector) !== null;
3};
4/**
5 * Create the mode and color classes for the component based on the classes passed in
6 */
7const createColorClasses = (color, cssClassMap) => {
8 return (typeof color === 'string' && color.length > 0) ? Object.assign({ 'ion-color': true, [`ion-color-${color}`]: true }, cssClassMap) : cssClassMap;
9};
10const 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};
20const getClassMap = (classes) => {
21 const map = {};
22 getClassList(classes).forEach(c => map[c] = true);
23 return map;
24};
25const SCHEME = /^[a-z][a-z0-9+\-.]*:/;
26const 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
39export { createColorClasses as c, getClassMap as g, hostContext as h, openURL as o };