neo.mjs 9.7.0 → 9.8.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/ServiceWorker.mjs +2 -2
- package/apps/portal/index.html +1 -1
- package/apps/portal/resources/data/blog.json +12 -0
- package/apps/portal/resources/data/examples_dist_esm.json +136 -0
- package/apps/portal/view/examples/TabContainer.mjs +11 -2
- package/apps/portal/view/examples/TabContainerController.mjs +1 -1
- package/apps/portal/view/home/FooterContainer.mjs +1 -1
- package/package.json +1 -1
- package/src/DefaultConfig.mjs +2 -2
- package/src/main/DomAccess.mjs +1 -1
package/ServiceWorker.mjs
CHANGED
package/apps/portal/index.html
CHANGED
@@ -1,4 +1,16 @@
|
|
1
1
|
[{
|
2
|
+
"author" : "Tobias Uhlig",
|
3
|
+
"authorImage" : "author_TobiasUhlig.jpeg",
|
4
|
+
"date" : "Jun 02, 2025",
|
5
|
+
"id" : 64,
|
6
|
+
"image" : "json-blueprints.png",
|
7
|
+
"name" : "How JSON Blueprints & Shared Workers Power Next-Gen AI Interfaces",
|
8
|
+
"provider" : "Medium",
|
9
|
+
"publisher" : "",
|
10
|
+
"selectedInto": [],
|
11
|
+
"type" : "Blog Post",
|
12
|
+
"url" : "https://tobiasuhlig.medium.com/the-ui-revolution-how-json-blueprints-shared-workers-power-next-gen-ai-interfaces-60a2bf0fc1dc?source=friends_link&sk=1b0b306285e23bb12f31271dd87bebe5"
|
13
|
+
}, {
|
2
14
|
"author" : "Tobias Uhlig",
|
3
15
|
"authorImage" : "author_TobiasUhlig.jpeg",
|
4
16
|
"date" : "Feb 12, 2025",
|
@@ -0,0 +1,136 @@
|
|
1
|
+
[{
|
2
|
+
"id" : 21,
|
3
|
+
"environments": ["Desktop", "Mobile"],
|
4
|
+
"image" : "devmode/bigData.png",
|
5
|
+
"name" : "Buffered Data Grid with 5M cells",
|
6
|
+
"sourceUrl" : "examples/grid/bigData",
|
7
|
+
"url" : "dist/esm/examples/grid/bigData/index.html"
|
8
|
+
}, {
|
9
|
+
"id" : 20,
|
10
|
+
"image" : "devmode/sharedcovid.png",
|
11
|
+
"name" : "Multi Window Covid App",
|
12
|
+
"sharedWorkers": true,
|
13
|
+
"sourceUrl" : "apps/sharedcovid",
|
14
|
+
"url" : "dist/esm/apps/sharedcovid/index.html#mainview=table"
|
15
|
+
}, {
|
16
|
+
"id" : 19,
|
17
|
+
"image" : "devmode/calendar-preview.png",
|
18
|
+
"name" : "Calendar",
|
19
|
+
"sourceUrl": "src/calendar",
|
20
|
+
"url" : "dist/esm/examples/calendar/basic/index.html"
|
21
|
+
}, {
|
22
|
+
"id" : 18,
|
23
|
+
"image" : "devmode/helix.png",
|
24
|
+
"name" : "component.Helix",
|
25
|
+
"sourceUrl": "examples/component/helix",
|
26
|
+
"url" : "dist/esm/examples/component/helix/index.html"
|
27
|
+
}, {
|
28
|
+
"id" : 17,
|
29
|
+
"image" : "devmode/mwCoronaGallery.png",
|
30
|
+
"name" : "Multi Window Covid Gallery",
|
31
|
+
"sharedWorkers": true,
|
32
|
+
"sourceUrl" : "examples/component/multiWindowCoronaGallery",
|
33
|
+
"url" : "dist/esm/examples/component/multiWindowCoronaGallery/index.html"
|
34
|
+
}, {
|
35
|
+
"id" : 16,
|
36
|
+
"image" : "devmode/multi_window_dd.png",
|
37
|
+
"name" : "Multi-Window Drag&Drop",
|
38
|
+
"sharedWorkers": true,
|
39
|
+
"sourceUrl" : "apps/shareddialog",
|
40
|
+
"url" : "dist/esm/apps/shareddialog/index.html"
|
41
|
+
}, {
|
42
|
+
"id" : 15,
|
43
|
+
"image" : "devmode/tabContainer.png",
|
44
|
+
"name" : "tab.Container",
|
45
|
+
"sourceUrl": "examples/tab/container",
|
46
|
+
"url" : "dist/esm/examples/tab/container/index.html"
|
47
|
+
}, {
|
48
|
+
"id" : 14,
|
49
|
+
"image" : "devmode/model-component-example.png",
|
50
|
+
"name" : "State Provider Example",
|
51
|
+
"sourceUrl": "examples/stateProvider/advanced",
|
52
|
+
"url" : "dist/esm/examples/stateProvider/advanced/index.html"
|
53
|
+
}, {
|
54
|
+
"id" : 13,
|
55
|
+
"image" : "devmode/dragdrop.png",
|
56
|
+
"name" : "Dialog drag&drop",
|
57
|
+
"sourceUrl": "examples/dialog",
|
58
|
+
"url" : "dist/esm/examples/dialog/"
|
59
|
+
}, {
|
60
|
+
"id" : 12,
|
61
|
+
"image" : "dist_prod/colorsApp.png",
|
62
|
+
"name" : "Colors Dashboard",
|
63
|
+
"sharedWorkers": true,
|
64
|
+
"sourceUrl" : "apps/colors",
|
65
|
+
"url" : "dist/esm/apps/colors/index.html"
|
66
|
+
}, {
|
67
|
+
"id" : 11,
|
68
|
+
"image" : "devmode/covidDashboard.png",
|
69
|
+
"name" : "Covid Dashboard",
|
70
|
+
"sourceUrl": "apps/covid",
|
71
|
+
"url" : "dist/esm/apps/covid/index.html#mainview=table"
|
72
|
+
}, {
|
73
|
+
"id" : 10,
|
74
|
+
"image" : "devmode/coronaHelix.png",
|
75
|
+
"name" : "COVID-19 Helix",
|
76
|
+
"sourceUrl": "examples/component/coronaHelix",
|
77
|
+
"url" : "dist/esm/examples/component/coronaHelix/index.html"
|
78
|
+
}, {
|
79
|
+
"id" : 9,
|
80
|
+
"image" : "devmode/coronaGallery.png",
|
81
|
+
"name" : "COVID-19 Gallery",
|
82
|
+
"sourceUrl": "examples/component/coronaGallery",
|
83
|
+
"url" : "dist/esm/examples/component/coronaGallery/index.html"
|
84
|
+
}, {
|
85
|
+
"id" : 8,
|
86
|
+
"image" : "devmode/gallery.png",
|
87
|
+
"name" : "component.Gallery",
|
88
|
+
"sourceUrl": "examples/component/gallery",
|
89
|
+
"url" : "dist/esm/examples/component/gallery/index.html"
|
90
|
+
}, {
|
91
|
+
"id" : 7,
|
92
|
+
"image" : "devmode/tableFiltering.png",
|
93
|
+
"name" : "Table Filtering",
|
94
|
+
"sourceUrl": "examples/tableFiltering",
|
95
|
+
"url" : "dist/esm/examples/tableFiltering/"
|
96
|
+
}, {
|
97
|
+
"id" : 6,
|
98
|
+
"image" : "devmode/dateSelector.png",
|
99
|
+
"name" : "component.DateSelector",
|
100
|
+
"sourceUrl": "examples/component/dateSelector",
|
101
|
+
"url" : "dist/esm/examples/component/dateSelector/index.html"
|
102
|
+
}, {
|
103
|
+
"id" : 5,
|
104
|
+
"image" : "devmode/dateField.png",
|
105
|
+
"name" : "form.field.Date",
|
106
|
+
"sourceUrl": "examples/form/field/date",
|
107
|
+
"url" : "dist/esm/examples/form/field/date/index.html"
|
108
|
+
}, {
|
109
|
+
"id" : 4,
|
110
|
+
"image" : "devmode/selectField.png",
|
111
|
+
"name" : "form.field.ComboBox",
|
112
|
+
"sourceUrl": "examples/form/field/combobox",
|
113
|
+
"url" : "dist/esm/examples/form/field/combobox/index.html"
|
114
|
+
}, {
|
115
|
+
"id" : 3,
|
116
|
+
"environments" : ["Desktop", "Mobile"],
|
117
|
+
"image" : "dist_prod/portalApp.png",
|
118
|
+
"name" : "Portal App",
|
119
|
+
"sharedWorkers": true,
|
120
|
+
"sourceUrl" : "apps/portal",
|
121
|
+
"url" : "dist/esm/apps/portal/index.html"
|
122
|
+
}, {
|
123
|
+
"hidden" : true,
|
124
|
+
"id" : 2,
|
125
|
+
"image" : "devmode/realworldApp.png",
|
126
|
+
"name" : "RealWorld App",
|
127
|
+
"sourceUrl": "apps/realworld",
|
128
|
+
"url" : "dist/esm/apps/realworld/index.html"
|
129
|
+
}, {
|
130
|
+
"hidden" : true,
|
131
|
+
"id" : 1,
|
132
|
+
"image" : "devmode/realworldApp2.png",
|
133
|
+
"name" : "RealWorld App v2</br>(in progress)",
|
134
|
+
"sourceUrl": "apps/realworld2",
|
135
|
+
"url" : "dist/esm/apps/realworld2/index.html#/gallery"
|
136
|
+
}]
|
@@ -47,17 +47,26 @@ class TabContainer extends Container {
|
|
47
47
|
header : {
|
48
48
|
iconCls: 'fa fa-chess-knight',
|
49
49
|
route : '/examples/devmode',
|
50
|
-
text : '
|
50
|
+
text : 'Dev Mode'
|
51
51
|
}
|
52
52
|
}, {
|
53
53
|
environment: 'dist/development',
|
54
54
|
reference : 'examples-dist-dev-list',
|
55
55
|
store : {module: ExampleStore, url: '../../apps/portal/resources/data/examples_dist_dev.json'},
|
56
56
|
header : {
|
57
|
-
iconCls: 'fa fa-chess-
|
57
|
+
iconCls: 'fa fa-chess-bishop',
|
58
58
|
route : '/examples/dist_dev',
|
59
59
|
text : 'dist/dev'
|
60
60
|
}
|
61
|
+
}, {
|
62
|
+
environment: 'dist/production',
|
63
|
+
reference : 'examples-dist-esm-list',
|
64
|
+
store : {module: ExampleStore, url: '../../apps/portal/resources/data/examples_dist_esm.json'},
|
65
|
+
header : {
|
66
|
+
iconCls: 'fa fa-chess-queen',
|
67
|
+
route : '/examples/dist_esm',
|
68
|
+
text : 'dist/esm'
|
69
|
+
}
|
61
70
|
}, {
|
62
71
|
environment: 'dist/production',
|
63
72
|
reference : 'examples-dist-prod-list',
|
@@ -25,7 +25,7 @@ class TabContainerController extends Component {
|
|
25
25
|
* We need to store the current positions, since drag&drop resorting of tabs is enabled
|
26
26
|
* @member {String[]} tabItems
|
27
27
|
*/
|
28
|
-
tabItems = ['devmode', 'dist_dev', 'dist_prod']
|
28
|
+
tabItems = ['devmode', 'dist_dev', 'dist_esm', 'dist_prod']
|
29
29
|
|
30
30
|
/**
|
31
31
|
*
|
package/package.json
CHANGED
package/src/DefaultConfig.mjs
CHANGED
@@ -264,12 +264,12 @@ const DefaultConfig = {
|
|
264
264
|
useVdomWorker: true,
|
265
265
|
/**
|
266
266
|
* buildScripts/injectPackageVersion.mjs will update this value
|
267
|
-
* @default '9.
|
267
|
+
* @default '9.8.0'
|
268
268
|
* @memberOf! module:Neo
|
269
269
|
* @name config.version
|
270
270
|
* @type String
|
271
271
|
*/
|
272
|
-
version: '9.
|
272
|
+
version: '9.8.0'
|
273
273
|
};
|
274
274
|
|
275
275
|
Object.assign(DefaultConfig, {
|
package/src/main/DomAccess.mjs
CHANGED
@@ -1130,7 +1130,7 @@ class DomAccess extends Base {
|
|
1130
1130
|
topFocusTrap = subject.$topFocusTrap = document.createElement('div');
|
1131
1131
|
bottomFocusTrap = subject.$bottomFocusTrap = document.createElement('div');
|
1132
1132
|
|
1133
|
-
// The two focus
|
1133
|
+
// The two focus trapping elements must be invisible but tabbable.
|
1134
1134
|
topFocusTrap.className = bottomFocusTrap.className = 'neo-focus-trap';
|
1135
1135
|
topFocusTrap.setAttribute('tabIndex', 0);
|
1136
1136
|
bottomFocusTrap.setAttribute('tabIndex', 0);
|