nativecorejs 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +22 -0
- package/dist/components/builtinRegistry.d.ts +2 -0
- package/dist/components/builtinRegistry.js +72 -0
- package/dist/components/index.d.ts +59 -0
- package/dist/components/index.js +59 -0
- package/dist/components/loading-spinner.d.ts +5 -0
- package/dist/components/loading-spinner.js +48 -0
- package/dist/components/nc-a.d.ts +45 -0
- package/dist/components/nc-a.js +290 -0
- package/dist/components/nc-accordion.d.ts +36 -0
- package/dist/components/nc-accordion.js +186 -0
- package/dist/components/nc-alert.d.ts +11 -0
- package/dist/components/nc-alert.js +127 -0
- package/dist/components/nc-animation.d.ts +117 -0
- package/dist/components/nc-animation.js +1053 -0
- package/dist/components/nc-autocomplete.d.ts +41 -0
- package/dist/components/nc-autocomplete.js +275 -0
- package/dist/components/nc-avatar-group.d.ts +7 -0
- package/dist/components/nc-avatar-group.js +85 -0
- package/dist/components/nc-avatar.d.ts +9 -0
- package/dist/components/nc-avatar.js +127 -0
- package/dist/components/nc-badge.d.ts +7 -0
- package/dist/components/nc-badge.js +63 -0
- package/dist/components/nc-bottom-nav.d.ts +53 -0
- package/dist/components/nc-bottom-nav.js +198 -0
- package/dist/components/nc-breadcrumb.d.ts +10 -0
- package/dist/components/nc-breadcrumb.js +71 -0
- package/dist/components/nc-button.d.ts +38 -0
- package/dist/components/nc-button.js +293 -0
- package/dist/components/nc-card.d.ts +11 -0
- package/dist/components/nc-card.js +74 -0
- package/dist/components/nc-checkbox.d.ts +16 -0
- package/dist/components/nc-checkbox.js +194 -0
- package/dist/components/nc-chip.d.ts +8 -0
- package/dist/components/nc-chip.js +89 -0
- package/dist/components/nc-code.d.ts +37 -0
- package/dist/components/nc-code.js +315 -0
- package/dist/components/nc-collapsible.d.ts +33 -0
- package/dist/components/nc-collapsible.js +148 -0
- package/dist/components/nc-color-picker.d.ts +33 -0
- package/dist/components/nc-color-picker.js +265 -0
- package/dist/components/nc-copy-button.d.ts +10 -0
- package/dist/components/nc-copy-button.js +94 -0
- package/dist/components/nc-date-picker.d.ts +41 -0
- package/dist/components/nc-date-picker.js +443 -0
- package/dist/components/nc-div.d.ts +53 -0
- package/dist/components/nc-div.js +270 -0
- package/dist/components/nc-divider.d.ts +7 -0
- package/dist/components/nc-divider.js +57 -0
- package/dist/components/nc-drawer.d.ts +40 -0
- package/dist/components/nc-drawer.js +217 -0
- package/dist/components/nc-dropdown.d.ts +41 -0
- package/dist/components/nc-dropdown.js +170 -0
- package/dist/components/nc-empty-state.d.ts +5 -0
- package/dist/components/nc-empty-state.js +76 -0
- package/dist/components/nc-file-upload.d.ts +40 -0
- package/dist/components/nc-file-upload.js +336 -0
- package/dist/components/nc-form.d.ts +70 -0
- package/dist/components/nc-form.js +273 -0
- package/dist/components/nc-image.d.ts +10 -0
- package/dist/components/nc-image.js +139 -0
- package/dist/components/nc-input.d.ts +25 -0
- package/dist/components/nc-input.js +302 -0
- package/dist/components/nc-kbd.d.ts +5 -0
- package/dist/components/nc-kbd.js +34 -0
- package/dist/components/nc-menu-item.d.ts +43 -0
- package/dist/components/nc-menu-item.js +182 -0
- package/dist/components/nc-menu.d.ts +76 -0
- package/dist/components/nc-menu.js +360 -0
- package/dist/components/nc-modal.d.ts +51 -0
- package/dist/components/nc-modal.js +231 -0
- package/dist/components/nc-nav-item.d.ts +35 -0
- package/dist/components/nc-nav-item.js +142 -0
- package/dist/components/nc-number-input.d.ts +22 -0
- package/dist/components/nc-number-input.js +270 -0
- package/dist/components/nc-otp-input.d.ts +41 -0
- package/dist/components/nc-otp-input.js +227 -0
- package/dist/components/nc-pagination.d.ts +28 -0
- package/dist/components/nc-pagination.js +171 -0
- package/dist/components/nc-popover.d.ts +58 -0
- package/dist/components/nc-popover.js +301 -0
- package/dist/components/nc-progress-circular.d.ts +7 -0
- package/dist/components/nc-progress-circular.js +67 -0
- package/dist/components/nc-progress.d.ts +7 -0
- package/dist/components/nc-progress.js +109 -0
- package/dist/components/nc-radio.d.ts +13 -0
- package/dist/components/nc-radio.js +169 -0
- package/dist/components/nc-rating.d.ts +19 -0
- package/dist/components/nc-rating.js +187 -0
- package/dist/components/nc-rich-text.d.ts +43 -0
- package/dist/components/nc-rich-text.js +310 -0
- package/dist/components/nc-scroll-top.d.ts +28 -0
- package/dist/components/nc-scroll-top.js +103 -0
- package/dist/components/nc-select.d.ts +51 -0
- package/dist/components/nc-select.js +425 -0
- package/dist/components/nc-skeleton.d.ts +7 -0
- package/dist/components/nc-skeleton.js +90 -0
- package/dist/components/nc-slider.d.ts +41 -0
- package/dist/components/nc-slider.js +268 -0
- package/dist/components/nc-snackbar.d.ts +51 -0
- package/dist/components/nc-snackbar.js +200 -0
- package/dist/components/nc-splash.d.ts +25 -0
- package/dist/components/nc-splash.js +296 -0
- package/dist/components/nc-stepper.d.ts +50 -0
- package/dist/components/nc-stepper.js +236 -0
- package/dist/components/nc-switch.d.ts +14 -0
- package/dist/components/nc-switch.js +194 -0
- package/dist/components/nc-tab-item.d.ts +39 -0
- package/dist/components/nc-tab-item.js +127 -0
- package/dist/components/nc-table.d.ts +44 -0
- package/dist/components/nc-table.js +265 -0
- package/dist/components/nc-tabs.d.ts +79 -0
- package/dist/components/nc-tabs.js +519 -0
- package/dist/components/nc-tag-input.d.ts +49 -0
- package/dist/components/nc-tag-input.js +268 -0
- package/dist/components/nc-textarea.d.ts +15 -0
- package/dist/components/nc-textarea.js +164 -0
- package/dist/components/nc-time-picker.d.ts +51 -0
- package/dist/components/nc-time-picker.js +452 -0
- package/dist/components/nc-timeline.d.ts +53 -0
- package/dist/components/nc-timeline.js +171 -0
- package/dist/components/nc-tooltip.d.ts +27 -0
- package/dist/components/nc-tooltip.js +135 -0
- package/dist/core/component.d.ts +33 -0
- package/dist/core/component.js +208 -0
- package/dist/core/gpu-animation.d.ts +141 -0
- package/dist/core/gpu-animation.js +474 -0
- package/dist/core/lazyComponents.d.ts +13 -0
- package/dist/core/lazyComponents.js +73 -0
- package/dist/core/router.d.ts +55 -0
- package/dist/core/router.js +424 -0
- package/dist/core/state.d.ts +18 -0
- package/dist/core/state.js +153 -0
- package/dist/index.d.ts +14 -0
- package/dist/index.js +11 -0
- package/dist/utils/cacheBuster.d.ts +9 -0
- package/dist/utils/cacheBuster.js +12 -0
- package/dist/utils/dom.d.ts +16 -0
- package/dist/utils/dom.js +70 -0
- package/dist/utils/events.d.ts +20 -0
- package/dist/utils/events.js +80 -0
- package/dist/utils/templates.d.ts +2 -0
- package/dist/utils/templates.js +2 -0
- package/package.json +53 -0
- package/src/styles/base.css +40 -0
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
export const dom = {
|
|
2
|
+
query: (selector) => document.querySelector(selector),
|
|
3
|
+
queryAll: (selector) => document.querySelectorAll(selector),
|
|
4
|
+
$: (selector) => document.querySelector(selector),
|
|
5
|
+
$$: (selector) => document.querySelectorAll(selector),
|
|
6
|
+
within: (parent, selector) => {
|
|
7
|
+
const element = typeof parent === 'string' ? document.querySelector(parent) : parent;
|
|
8
|
+
return element ? element.querySelector(selector) : null;
|
|
9
|
+
},
|
|
10
|
+
withinAll: (parent, selector) => {
|
|
11
|
+
const element = typeof parent === 'string' ? document.querySelector(parent) : parent;
|
|
12
|
+
return element ? element.querySelectorAll(selector) : [];
|
|
13
|
+
},
|
|
14
|
+
create: (tag, attrs, ...children) => {
|
|
15
|
+
const element = document.createElement(tag);
|
|
16
|
+
if (attrs) {
|
|
17
|
+
for (const [key, value] of Object.entries(attrs)) {
|
|
18
|
+
element.setAttribute(key, value);
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
for (const child of children) {
|
|
22
|
+
if (typeof child === 'string') {
|
|
23
|
+
element.appendChild(document.createTextNode(child));
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
element.appendChild(child);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
return element;
|
|
30
|
+
},
|
|
31
|
+
addClass: (element, ...classes) => {
|
|
32
|
+
const target = typeof element === 'string' ? document.querySelector(element) : element;
|
|
33
|
+
if (target)
|
|
34
|
+
target.classList.add(...classes);
|
|
35
|
+
},
|
|
36
|
+
removeClass: (element, ...classes) => {
|
|
37
|
+
const target = typeof element === 'string' ? document.querySelector(element) : element;
|
|
38
|
+
if (target)
|
|
39
|
+
target.classList.remove(...classes);
|
|
40
|
+
},
|
|
41
|
+
toggleClass: (element, className, force) => {
|
|
42
|
+
const target = typeof element === 'string' ? document.querySelector(element) : element;
|
|
43
|
+
if (target)
|
|
44
|
+
target.classList.toggle(className, force);
|
|
45
|
+
},
|
|
46
|
+
show: (element) => {
|
|
47
|
+
const target = typeof element === 'string' ? document.querySelector(element) : element;
|
|
48
|
+
if (target)
|
|
49
|
+
target.style.removeProperty('display');
|
|
50
|
+
},
|
|
51
|
+
hide: (element) => {
|
|
52
|
+
const target = typeof element === 'string' ? document.querySelector(element) : element;
|
|
53
|
+
if (target)
|
|
54
|
+
target.style.display = 'none';
|
|
55
|
+
},
|
|
56
|
+
listen: (selectorOrElement, eventName, handler, options) => {
|
|
57
|
+
const element = typeof selectorOrElement === 'string'
|
|
58
|
+
? document.querySelector(selectorOrElement)
|
|
59
|
+
: selectorOrElement;
|
|
60
|
+
if (element) {
|
|
61
|
+
element.addEventListener(eventName, handler, options);
|
|
62
|
+
return () => element.removeEventListener(eventName, handler, options);
|
|
63
|
+
}
|
|
64
|
+
return () => { };
|
|
65
|
+
}
|
|
66
|
+
};
|
|
67
|
+
if (typeof window !== 'undefined') {
|
|
68
|
+
window.dom = dom;
|
|
69
|
+
}
|
|
70
|
+
export default dom;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
export declare function on<T = Event>(selector: string, eventName: string, handler: (event: T) => void): () => void;
|
|
2
|
+
export declare function bindEvents(bindings: Record<string, Record<string, (event: any) => void>>): () => void;
|
|
3
|
+
export declare const onClick: (selector: string, handler: (event: Event) => void) => () => void;
|
|
4
|
+
export declare const onChange: (selector: string, handler: (event: Event) => void) => () => void;
|
|
5
|
+
export declare const onInput: (selector: string, handler: (event: Event) => void) => () => void;
|
|
6
|
+
export declare const onSubmit: (selector: string, handler: (event: Event) => void) => () => void;
|
|
7
|
+
export declare function delegate<T = Event>(containerSelector: string, eventName: string, targetSelector: string, handler: (event: T, target: Element) => void): () => void;
|
|
8
|
+
export declare function trackEvents(): {
|
|
9
|
+
on<T = Event>(selector: string, eventName: string, handler: (event: T) => void): void;
|
|
10
|
+
onClick(selector: string, handler: (event: Event) => void): void;
|
|
11
|
+
onChange(selector: string, handler: (event: Event) => void): void;
|
|
12
|
+
onInput(selector: string, handler: (event: Event) => void): void;
|
|
13
|
+
onSubmit(selector: string, handler: (event: Event) => void): void;
|
|
14
|
+
delegate<T = Event>(containerSelector: string, eventName: string, targetSelector: string, handler: (event: T, target: Element) => void): void;
|
|
15
|
+
cleanup(): void;
|
|
16
|
+
};
|
|
17
|
+
export declare function trackSubscriptions(): {
|
|
18
|
+
watch(unsubscribe: () => void): void;
|
|
19
|
+
cleanup(): void;
|
|
20
|
+
};
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
export function on(selector, eventName, handler) {
|
|
2
|
+
const elements = document.querySelectorAll(selector);
|
|
3
|
+
elements.forEach(el => {
|
|
4
|
+
el.addEventListener(eventName, handler);
|
|
5
|
+
});
|
|
6
|
+
return () => {
|
|
7
|
+
elements.forEach(el => {
|
|
8
|
+
el.removeEventListener(eventName, handler);
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
}
|
|
12
|
+
export function bindEvents(bindings) {
|
|
13
|
+
const cleanups = [];
|
|
14
|
+
for (const [eventName, handlers] of Object.entries(bindings)) {
|
|
15
|
+
for (const [selector, handler] of Object.entries(handlers)) {
|
|
16
|
+
cleanups.push(on(selector, eventName, handler));
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
return () => {
|
|
20
|
+
cleanups.forEach(cleanup => cleanup());
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
export const onClick = (selector, handler) => on(selector, 'click', handler);
|
|
24
|
+
export const onChange = (selector, handler) => on(selector, 'change', handler);
|
|
25
|
+
export const onInput = (selector, handler) => on(selector, 'input', handler);
|
|
26
|
+
export const onSubmit = (selector, handler) => on(selector, 'submit', handler);
|
|
27
|
+
export function delegate(containerSelector, eventName, targetSelector, handler) {
|
|
28
|
+
const container = document.querySelector(containerSelector);
|
|
29
|
+
if (!container)
|
|
30
|
+
return () => { };
|
|
31
|
+
const delegateHandler = (event) => {
|
|
32
|
+
const target = event.target.closest(targetSelector);
|
|
33
|
+
if (target && container.contains(target)) {
|
|
34
|
+
handler(event, target);
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
container.addEventListener(eventName, delegateHandler);
|
|
38
|
+
return () => {
|
|
39
|
+
container.removeEventListener(eventName, delegateHandler);
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
export function trackEvents() {
|
|
43
|
+
const cleanupFunctions = [];
|
|
44
|
+
return {
|
|
45
|
+
on(selector, eventName, handler) {
|
|
46
|
+
cleanupFunctions.push(on(selector, eventName, handler));
|
|
47
|
+
},
|
|
48
|
+
onClick(selector, handler) {
|
|
49
|
+
cleanupFunctions.push(onClick(selector, handler));
|
|
50
|
+
},
|
|
51
|
+
onChange(selector, handler) {
|
|
52
|
+
cleanupFunctions.push(onChange(selector, handler));
|
|
53
|
+
},
|
|
54
|
+
onInput(selector, handler) {
|
|
55
|
+
cleanupFunctions.push(onInput(selector, handler));
|
|
56
|
+
},
|
|
57
|
+
onSubmit(selector, handler) {
|
|
58
|
+
cleanupFunctions.push(onSubmit(selector, handler));
|
|
59
|
+
},
|
|
60
|
+
delegate(containerSelector, eventName, targetSelector, handler) {
|
|
61
|
+
cleanupFunctions.push(delegate(containerSelector, eventName, targetSelector, handler));
|
|
62
|
+
},
|
|
63
|
+
cleanup() {
|
|
64
|
+
cleanupFunctions.forEach(cleanup => cleanup());
|
|
65
|
+
cleanupFunctions.length = 0;
|
|
66
|
+
}
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
export function trackSubscriptions() {
|
|
70
|
+
const unsubscribers = [];
|
|
71
|
+
return {
|
|
72
|
+
watch(unsubscribe) {
|
|
73
|
+
unsubscribers.push(unsubscribe);
|
|
74
|
+
},
|
|
75
|
+
cleanup() {
|
|
76
|
+
unsubscribers.forEach(fn => fn());
|
|
77
|
+
unsubscribers.length = 0;
|
|
78
|
+
}
|
|
79
|
+
};
|
|
80
|
+
}
|
package/package.json
ADDED
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "nativecorejs",
|
|
3
|
+
"version": "0.1.0",
|
|
4
|
+
"description": "NativeCore framework runtime primitives and utilities",
|
|
5
|
+
"keywords": [
|
|
6
|
+
"nativecore",
|
|
7
|
+
"nativecorejs",
|
|
8
|
+
"web-components",
|
|
9
|
+
"signals",
|
|
10
|
+
"spa"
|
|
11
|
+
],
|
|
12
|
+
"homepage": "https://github.com/davidtv2008/nativecorejs#readme",
|
|
13
|
+
"bugs": {
|
|
14
|
+
"url": "https://github.com/davidtv2008/nativecorejs/issues"
|
|
15
|
+
},
|
|
16
|
+
"repository": {
|
|
17
|
+
"type": "git",
|
|
18
|
+
"url": "git+https://github.com/davidtv2008/nativecorejs.git"
|
|
19
|
+
},
|
|
20
|
+
"type": "module",
|
|
21
|
+
"main": "./dist/index.js",
|
|
22
|
+
"types": "./dist/index.d.ts",
|
|
23
|
+
"exports": {
|
|
24
|
+
".": {
|
|
25
|
+
"types": "./dist/index.d.ts",
|
|
26
|
+
"import": "./dist/index.js"
|
|
27
|
+
},
|
|
28
|
+
"./components": {
|
|
29
|
+
"types": "./dist/components/index.d.ts",
|
|
30
|
+
"import": "./dist/components/index.js"
|
|
31
|
+
},
|
|
32
|
+
"./styles/base.css": "./src/styles/base.css"
|
|
33
|
+
},
|
|
34
|
+
"files": [
|
|
35
|
+
"dist",
|
|
36
|
+
"src/styles"
|
|
37
|
+
],
|
|
38
|
+
"scripts": {
|
|
39
|
+
"build": "tsc -p tsconfig.json",
|
|
40
|
+
"dev": "tsc -p tsconfig.json --watch",
|
|
41
|
+
"prepublishOnly": "npm run build"
|
|
42
|
+
},
|
|
43
|
+
"publishConfig": {
|
|
44
|
+
"access": "public"
|
|
45
|
+
},
|
|
46
|
+
"engines": {
|
|
47
|
+
"node": ">=18"
|
|
48
|
+
},
|
|
49
|
+
"license": "MIT",
|
|
50
|
+
"devDependencies": {
|
|
51
|
+
"typescript": "^5.6.3"
|
|
52
|
+
}
|
|
53
|
+
}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
/* NativeCore base framework styles */
|
|
2
|
+
|
|
3
|
+
* {
|
|
4
|
+
scrollbar-width: thin;
|
|
5
|
+
scrollbar-color: rgba(0, 0, 0, 0.3) transparent;
|
|
6
|
+
box-sizing: border-box;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
*::-webkit-scrollbar {
|
|
10
|
+
width: 10px;
|
|
11
|
+
height: 10px;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
*::-webkit-scrollbar-track {
|
|
15
|
+
background: transparent;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
*::-webkit-scrollbar-thumb {
|
|
19
|
+
background: rgba(0, 0, 0, 0.3);
|
|
20
|
+
border-radius: 5px;
|
|
21
|
+
transition: background 0.2s ease;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
*::-webkit-scrollbar-thumb:hover {
|
|
25
|
+
background: rgba(0, 0, 0, 0.5);
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
@media (prefers-color-scheme: dark) {
|
|
29
|
+
* {
|
|
30
|
+
scrollbar-color: rgba(255, 255, 255, 0.2) transparent;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
*::-webkit-scrollbar-thumb {
|
|
34
|
+
background: rgba(255, 255, 255, 0.2);
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
*::-webkit-scrollbar-thumb:hover {
|
|
38
|
+
background: rgba(255, 255, 255, 0.3);
|
|
39
|
+
}
|
|
40
|
+
}
|