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.
Files changed (145) hide show
  1. package/README.md +22 -0
  2. package/dist/components/builtinRegistry.d.ts +2 -0
  3. package/dist/components/builtinRegistry.js +72 -0
  4. package/dist/components/index.d.ts +59 -0
  5. package/dist/components/index.js +59 -0
  6. package/dist/components/loading-spinner.d.ts +5 -0
  7. package/dist/components/loading-spinner.js +48 -0
  8. package/dist/components/nc-a.d.ts +45 -0
  9. package/dist/components/nc-a.js +290 -0
  10. package/dist/components/nc-accordion.d.ts +36 -0
  11. package/dist/components/nc-accordion.js +186 -0
  12. package/dist/components/nc-alert.d.ts +11 -0
  13. package/dist/components/nc-alert.js +127 -0
  14. package/dist/components/nc-animation.d.ts +117 -0
  15. package/dist/components/nc-animation.js +1053 -0
  16. package/dist/components/nc-autocomplete.d.ts +41 -0
  17. package/dist/components/nc-autocomplete.js +275 -0
  18. package/dist/components/nc-avatar-group.d.ts +7 -0
  19. package/dist/components/nc-avatar-group.js +85 -0
  20. package/dist/components/nc-avatar.d.ts +9 -0
  21. package/dist/components/nc-avatar.js +127 -0
  22. package/dist/components/nc-badge.d.ts +7 -0
  23. package/dist/components/nc-badge.js +63 -0
  24. package/dist/components/nc-bottom-nav.d.ts +53 -0
  25. package/dist/components/nc-bottom-nav.js +198 -0
  26. package/dist/components/nc-breadcrumb.d.ts +10 -0
  27. package/dist/components/nc-breadcrumb.js +71 -0
  28. package/dist/components/nc-button.d.ts +38 -0
  29. package/dist/components/nc-button.js +293 -0
  30. package/dist/components/nc-card.d.ts +11 -0
  31. package/dist/components/nc-card.js +74 -0
  32. package/dist/components/nc-checkbox.d.ts +16 -0
  33. package/dist/components/nc-checkbox.js +194 -0
  34. package/dist/components/nc-chip.d.ts +8 -0
  35. package/dist/components/nc-chip.js +89 -0
  36. package/dist/components/nc-code.d.ts +37 -0
  37. package/dist/components/nc-code.js +315 -0
  38. package/dist/components/nc-collapsible.d.ts +33 -0
  39. package/dist/components/nc-collapsible.js +148 -0
  40. package/dist/components/nc-color-picker.d.ts +33 -0
  41. package/dist/components/nc-color-picker.js +265 -0
  42. package/dist/components/nc-copy-button.d.ts +10 -0
  43. package/dist/components/nc-copy-button.js +94 -0
  44. package/dist/components/nc-date-picker.d.ts +41 -0
  45. package/dist/components/nc-date-picker.js +443 -0
  46. package/dist/components/nc-div.d.ts +53 -0
  47. package/dist/components/nc-div.js +270 -0
  48. package/dist/components/nc-divider.d.ts +7 -0
  49. package/dist/components/nc-divider.js +57 -0
  50. package/dist/components/nc-drawer.d.ts +40 -0
  51. package/dist/components/nc-drawer.js +217 -0
  52. package/dist/components/nc-dropdown.d.ts +41 -0
  53. package/dist/components/nc-dropdown.js +170 -0
  54. package/dist/components/nc-empty-state.d.ts +5 -0
  55. package/dist/components/nc-empty-state.js +76 -0
  56. package/dist/components/nc-file-upload.d.ts +40 -0
  57. package/dist/components/nc-file-upload.js +336 -0
  58. package/dist/components/nc-form.d.ts +70 -0
  59. package/dist/components/nc-form.js +273 -0
  60. package/dist/components/nc-image.d.ts +10 -0
  61. package/dist/components/nc-image.js +139 -0
  62. package/dist/components/nc-input.d.ts +25 -0
  63. package/dist/components/nc-input.js +302 -0
  64. package/dist/components/nc-kbd.d.ts +5 -0
  65. package/dist/components/nc-kbd.js +34 -0
  66. package/dist/components/nc-menu-item.d.ts +43 -0
  67. package/dist/components/nc-menu-item.js +182 -0
  68. package/dist/components/nc-menu.d.ts +76 -0
  69. package/dist/components/nc-menu.js +360 -0
  70. package/dist/components/nc-modal.d.ts +51 -0
  71. package/dist/components/nc-modal.js +231 -0
  72. package/dist/components/nc-nav-item.d.ts +35 -0
  73. package/dist/components/nc-nav-item.js +142 -0
  74. package/dist/components/nc-number-input.d.ts +22 -0
  75. package/dist/components/nc-number-input.js +270 -0
  76. package/dist/components/nc-otp-input.d.ts +41 -0
  77. package/dist/components/nc-otp-input.js +227 -0
  78. package/dist/components/nc-pagination.d.ts +28 -0
  79. package/dist/components/nc-pagination.js +171 -0
  80. package/dist/components/nc-popover.d.ts +58 -0
  81. package/dist/components/nc-popover.js +301 -0
  82. package/dist/components/nc-progress-circular.d.ts +7 -0
  83. package/dist/components/nc-progress-circular.js +67 -0
  84. package/dist/components/nc-progress.d.ts +7 -0
  85. package/dist/components/nc-progress.js +109 -0
  86. package/dist/components/nc-radio.d.ts +13 -0
  87. package/dist/components/nc-radio.js +169 -0
  88. package/dist/components/nc-rating.d.ts +19 -0
  89. package/dist/components/nc-rating.js +187 -0
  90. package/dist/components/nc-rich-text.d.ts +43 -0
  91. package/dist/components/nc-rich-text.js +310 -0
  92. package/dist/components/nc-scroll-top.d.ts +28 -0
  93. package/dist/components/nc-scroll-top.js +103 -0
  94. package/dist/components/nc-select.d.ts +51 -0
  95. package/dist/components/nc-select.js +425 -0
  96. package/dist/components/nc-skeleton.d.ts +7 -0
  97. package/dist/components/nc-skeleton.js +90 -0
  98. package/dist/components/nc-slider.d.ts +41 -0
  99. package/dist/components/nc-slider.js +268 -0
  100. package/dist/components/nc-snackbar.d.ts +51 -0
  101. package/dist/components/nc-snackbar.js +200 -0
  102. package/dist/components/nc-splash.d.ts +25 -0
  103. package/dist/components/nc-splash.js +296 -0
  104. package/dist/components/nc-stepper.d.ts +50 -0
  105. package/dist/components/nc-stepper.js +236 -0
  106. package/dist/components/nc-switch.d.ts +14 -0
  107. package/dist/components/nc-switch.js +194 -0
  108. package/dist/components/nc-tab-item.d.ts +39 -0
  109. package/dist/components/nc-tab-item.js +127 -0
  110. package/dist/components/nc-table.d.ts +44 -0
  111. package/dist/components/nc-table.js +265 -0
  112. package/dist/components/nc-tabs.d.ts +79 -0
  113. package/dist/components/nc-tabs.js +519 -0
  114. package/dist/components/nc-tag-input.d.ts +49 -0
  115. package/dist/components/nc-tag-input.js +268 -0
  116. package/dist/components/nc-textarea.d.ts +15 -0
  117. package/dist/components/nc-textarea.js +164 -0
  118. package/dist/components/nc-time-picker.d.ts +51 -0
  119. package/dist/components/nc-time-picker.js +452 -0
  120. package/dist/components/nc-timeline.d.ts +53 -0
  121. package/dist/components/nc-timeline.js +171 -0
  122. package/dist/components/nc-tooltip.d.ts +27 -0
  123. package/dist/components/nc-tooltip.js +135 -0
  124. package/dist/core/component.d.ts +33 -0
  125. package/dist/core/component.js +208 -0
  126. package/dist/core/gpu-animation.d.ts +141 -0
  127. package/dist/core/gpu-animation.js +474 -0
  128. package/dist/core/lazyComponents.d.ts +13 -0
  129. package/dist/core/lazyComponents.js +73 -0
  130. package/dist/core/router.d.ts +55 -0
  131. package/dist/core/router.js +424 -0
  132. package/dist/core/state.d.ts +18 -0
  133. package/dist/core/state.js +153 -0
  134. package/dist/index.d.ts +14 -0
  135. package/dist/index.js +11 -0
  136. package/dist/utils/cacheBuster.d.ts +9 -0
  137. package/dist/utils/cacheBuster.js +12 -0
  138. package/dist/utils/dom.d.ts +16 -0
  139. package/dist/utils/dom.js +70 -0
  140. package/dist/utils/events.d.ts +20 -0
  141. package/dist/utils/events.js +80 -0
  142. package/dist/utils/templates.d.ts +2 -0
  143. package/dist/utils/templates.js +2 -0
  144. package/package.json +53 -0
  145. 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
+ }
@@ -0,0 +1,2 @@
1
+ export declare const html: (strings: TemplateStringsArray, ...values: any[]) => string;
2
+ export declare const css: (strings: TemplateStringsArray, ...values: any[]) => string;
@@ -0,0 +1,2 @@
1
+ export const html = (strings, ...values) => String.raw({ raw: strings }, ...values);
2
+ export const css = (strings, ...values) => String.raw({ raw: strings }, ...values);
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
+ }