nativescript-web-adapter 0.1.1

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/dist/vue.cjs ADDED
@@ -0,0 +1,240 @@
1
+ 'use strict';
2
+
3
+ var vue = require('vue');
4
+
5
+ const Label = vue.defineComponent({
6
+ name: 'NSLabel',
7
+ props: {
8
+ text: { type: String, default: '' },
9
+ horizontalAlignment: { type: String, default: undefined }
10
+ },
11
+ emits: ['tap'],
12
+ setup(props, { slots, attrs, emit }) {
13
+ var _a;
14
+ const style = {};
15
+ if (props.horizontalAlignment) {
16
+ const map = { center: 'center', left: 'left', right: 'right' };
17
+ style.textAlign = (_a = map[String(props.horizontalAlignment).toLowerCase()]) !== null && _a !== void 0 ? _a : undefined;
18
+ }
19
+ const onClick = (e) => emit('tap', { eventName: 'tap', object: e.currentTarget });
20
+ return () => vue.h('span', { style, onClick, ...attrs }, slots.default ? slots.default() : props.text);
21
+ }
22
+ });
23
+
24
+ const Button = vue.defineComponent({
25
+ name: 'NSButton',
26
+ props: {
27
+ text: { type: String, default: '' },
28
+ horizontalAlignment: { type: String, default: undefined }
29
+ },
30
+ emits: ['tap'],
31
+ setup(props, { emit, slots, attrs }) {
32
+ var _a;
33
+ const onClick = (e) => emit('tap', { eventName: 'tap', object: e.currentTarget });
34
+ const style = {};
35
+ if (props.horizontalAlignment) {
36
+ const map = {
37
+ center: 'center',
38
+ left: 'start',
39
+ right: 'end',
40
+ stretch: 'stretch'
41
+ };
42
+ style.justifySelf = (_a = map[String(props.horizontalAlignment).toLowerCase()]) !== null && _a !== void 0 ? _a : undefined;
43
+ }
44
+ return () => vue.h('button', { onClick, style, ...attrs }, slots.default ? slots.default() : props.text);
45
+ }
46
+ });
47
+
48
+ const StackLayout = vue.defineComponent({
49
+ name: 'NSStackLayout',
50
+ emits: ['tap'],
51
+ setup(_, { slots, attrs, emit }) {
52
+ const onClick = (e) => emit('tap', { eventName: 'tap', object: e.currentTarget });
53
+ return () => { var _a; return vue.h('div', { style: { display: 'flex', flexDirection: 'column' }, onClick, ...attrs }, (_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots)); };
54
+ }
55
+ });
56
+
57
+ const FlexboxLayout = vue.defineComponent({
58
+ name: 'NSFlexboxLayout',
59
+ props: {
60
+ flexDirection: { type: String, default: 'row' },
61
+ justifyContent: { type: String, default: 'flex-start' },
62
+ alignItems: { type: String, default: 'stretch' }
63
+ },
64
+ emits: ['tap'],
65
+ setup(props, { slots, attrs, emit }) {
66
+ const onClick = (e) => emit('tap', { eventName: 'tap', object: e.currentTarget });
67
+ return () => { var _a; return vue.h('div', { style: { display: 'flex', flexDirection: props.flexDirection, justifyContent: props.justifyContent, alignItems: props.alignItems }, onClick, ...attrs }, (_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots)); };
68
+ }
69
+ });
70
+
71
+ function parseTracks(tracks) {
72
+ if (!tracks)
73
+ return undefined;
74
+ return tracks.split(',').map(s => s.trim()).map(t => {
75
+ if (t === '*' || t === 'auto')
76
+ return t === '*' ? '1fr' : 'auto';
77
+ if (/^\d+$/.test(t))
78
+ return `${t}px`;
79
+ return t;
80
+ }).join(' ');
81
+ }
82
+ const GridLayout = vue.defineComponent({
83
+ name: 'NSGridLayout',
84
+ props: {
85
+ rows: { type: String, default: undefined },
86
+ columns: { type: String, default: undefined }
87
+ },
88
+ emits: ['tap'],
89
+ setup(props, { slots, attrs, emit }) {
90
+ var _a, _b;
91
+ const containerStyle = {
92
+ display: 'grid',
93
+ // NS 默认一列:确保子项按行堆叠,而不是同一行多列并排
94
+ gridTemplateColumns: (_a = parseTracks(props.columns)) !== null && _a !== void 0 ? _a : '1fr',
95
+ // 行可选;若未指定,默认自适应内容
96
+ gridTemplateRows: (_b = parseTracks(props.rows)) !== null && _b !== void 0 ? _b : undefined,
97
+ // 以“按行”自动布局,默认逐行堆叠
98
+ gridAutoFlow: 'row',
99
+ width: '100%',
100
+ height: '100%'
101
+ };
102
+ const mapChild = (child) => {
103
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j;
104
+ if (!vue.isVNode(child))
105
+ return child;
106
+ const cprops = { ...(child.props || {}) };
107
+ const style = { ...(cprops.style || {}) };
108
+ // Row/Column placement: NativeScript uses 0-based indices; CSS Grid is 1-based
109
+ const row = (_a = cprops.row) !== null && _a !== void 0 ? _a : cprops['row'];
110
+ const col = (_c = (_b = cprops.col) !== null && _b !== void 0 ? _b : cprops['col']) !== null && _c !== void 0 ? _c : cprops.column;
111
+ if (row != null) {
112
+ const r = Number(row);
113
+ if (!isNaN(r))
114
+ style.gridRowStart = r + 1;
115
+ }
116
+ if (col != null) {
117
+ const c = Number(col);
118
+ if (!isNaN(c))
119
+ style.gridColumnStart = c + 1;
120
+ }
121
+ else {
122
+ // 未声明列时,强制放在第 1 列,避免隐式多列导致并排
123
+ style.gridColumnStart = 1;
124
+ }
125
+ // Horizontal alignment mapping
126
+ const ha = (_d = cprops.horizontalAlignment) !== null && _d !== void 0 ? _d : cprops['horizontalAlignment'];
127
+ if (ha) {
128
+ const map = {
129
+ center: 'center',
130
+ left: 'start',
131
+ right: 'end',
132
+ stretch: 'stretch'
133
+ };
134
+ style.justifySelf = (_e = map[String(ha).toLowerCase()]) !== null && _e !== void 0 ? _e : style.justifySelf;
135
+ }
136
+ // Vertical alignment mapping
137
+ const va = (_f = cprops.verticalAlignment) !== null && _f !== void 0 ? _f : cprops['verticalAlignment'];
138
+ if (va) {
139
+ const map = {
140
+ center: 'center',
141
+ top: 'start',
142
+ bottom: 'end',
143
+ stretch: 'stretch'
144
+ };
145
+ style.alignSelf = (_g = map[String(va).toLowerCase()]) !== null && _g !== void 0 ? _g : style.alignSelf;
146
+ }
147
+ // Row/Column span mapping
148
+ const rowSpan = (_h = cprops.rowSpan) !== null && _h !== void 0 ? _h : cprops['rowSpan'];
149
+ if (rowSpan != null) {
150
+ const rs = Number(rowSpan);
151
+ if (!isNaN(rs) && rs > 1)
152
+ style.gridRowEnd = `span ${rs}`;
153
+ }
154
+ const colSpan = (_j = cprops.colSpan) !== null && _j !== void 0 ? _j : cprops['colSpan'];
155
+ if (colSpan != null) {
156
+ const cs = Number(colSpan);
157
+ if (!isNaN(cs) && cs > 1)
158
+ style.gridColumnEnd = `span ${cs}`;
159
+ }
160
+ cprops.style = style;
161
+ return vue.h(child.type, cprops, child.children);
162
+ };
163
+ const onClick = (e) => emit('tap', { eventName: 'tap', object: e.currentTarget });
164
+ return () => {
165
+ var _a, _b;
166
+ const children = (_b = (_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots)) !== null && _b !== void 0 ? _b : [];
167
+ const mapped = children.map(mapChild);
168
+ return vue.h('div', { style: containerStyle, onClick, ...attrs }, mapped);
169
+ };
170
+ }
171
+ });
172
+
173
+ const Page = vue.defineComponent({
174
+ name: 'NSPage',
175
+ emits: ['tap'],
176
+ setup(_, { slots, attrs, emit }) {
177
+ const onClick = (e) => emit('tap', { eventName: 'tap', object: e.currentTarget });
178
+ return () => { var _a; return vue.h('main', { onClick, ...attrs }, (_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots)); };
179
+ }
180
+ });
181
+
182
+ const Frame = vue.defineComponent({
183
+ name: 'NSFrame',
184
+ setup(_, { slots, attrs }) {
185
+ return () => { var _a; return vue.h('div', { ...attrs }, (_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots)); };
186
+ }
187
+ });
188
+
189
+ const ActionBar = vue.defineComponent({
190
+ name: 'NSActionBar',
191
+ emits: ['tap'],
192
+ setup(_, { slots, attrs, emit }) {
193
+ const onClick = (e) => emit('tap', { eventName: 'tap', object: e.currentTarget });
194
+ return () => { var _a; return vue.h('header', { onClick, ...attrs }, (_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots)); };
195
+ }
196
+ });
197
+
198
+ const ImageCacheIt = vue.defineComponent({
199
+ name: 'ImageCacheIt',
200
+ props: {
201
+ src: { type: String, required: true },
202
+ stretch: { type: String, default: 'aspectFill' }
203
+ },
204
+ setup(props, { attrs }) {
205
+ const style = { width: '100%', display: 'block', objectPosition: 'center' };
206
+ if (props.stretch === 'aspectFill') {
207
+ style.objectFit = 'cover';
208
+ }
209
+ else if (props.stretch === 'aspectFit') {
210
+ style.objectFit = 'contain';
211
+ }
212
+ return () => vue.h('img', { src: props.src, style, ...attrs });
213
+ }
214
+ });
215
+
216
+ const NativeScriptWebPlugin = {
217
+ install(app) {
218
+ app.component('Label', Label);
219
+ app.component('Button', Button);
220
+ app.component('StackLayout', StackLayout);
221
+ app.component('FlexboxLayout', FlexboxLayout);
222
+ app.component('GridLayout', GridLayout);
223
+ app.component('Page', Page);
224
+ app.component('Frame', Frame);
225
+ app.component('ActionBar', ActionBar);
226
+ app.component('ImageCacheIt', ImageCacheIt);
227
+ }
228
+ };
229
+
230
+ exports.ActionBar = ActionBar;
231
+ exports.Button = Button;
232
+ exports.FlexboxLayout = FlexboxLayout;
233
+ exports.Frame = Frame;
234
+ exports.GridLayout = GridLayout;
235
+ exports.ImageCacheIt = ImageCacheIt;
236
+ exports.Label = Label;
237
+ exports.NativeScriptWebPlugin = NativeScriptWebPlugin;
238
+ exports.Page = Page;
239
+ exports.StackLayout = StackLayout;
240
+ //# sourceMappingURL=vue.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vue.cjs","sources":["../../src/vue/components/Label.ts","../../src/vue/components/Button.ts","../../src/vue/components/StackLayout.ts","../../src/vue/components/FlexboxLayout.ts","../../src/vue/components/GridLayout.ts","../../src/vue/components/Page.ts","../../src/vue/components/Frame.ts","../../src/vue/components/ActionBar.ts","../../src/vue/components/ImageCacheIt.ts","../../src/vue/index.ts"],"sourcesContent":["import { defineComponent, h } from 'vue';\n\nexport const Label = defineComponent({\n name: 'NSLabel',\n props: {\n text: { type: String, default: '' },\n horizontalAlignment: { type: String, default: undefined }\n },\n emits: ['tap'],\n setup(props, { slots, attrs, emit }) {\n const style: Record<string, any> = {};\n if (props.horizontalAlignment) {\n const map: Record<string, string> = { center: 'center', left: 'left', right: 'right' };\n style.textAlign = map[String(props.horizontalAlignment).toLowerCase()] ?? undefined;\n }\n const onClick = (e: MouseEvent) => emit('tap', { eventName: 'tap', object: e.currentTarget });\n return () => h('span', { style, onClick, ...attrs }, slots.default ? slots.default() : props.text);\n }\n});","import { defineComponent, h } from 'vue';\n\nexport const Button = defineComponent({\n name: 'NSButton',\n props: {\n text: { type: String, default: '' },\n horizontalAlignment: { type: String, default: undefined }\n },\n emits: ['tap'],\n setup(props, { emit, slots, attrs }) {\n const onClick = (e: MouseEvent) => emit('tap', { eventName: 'tap', object: e.currentTarget });\n const style: Record<string, any> = {};\n if (props.horizontalAlignment) {\n const map: Record<string, string> = {\n center: 'center',\n left: 'start',\n right: 'end',\n stretch: 'stretch'\n };\n style.justifySelf = map[String(props.horizontalAlignment).toLowerCase()] ?? undefined;\n }\n return () => h('button', { onClick, style, ...attrs }, slots.default ? slots.default() : props.text);\n }\n});","import { defineComponent, h } from 'vue';\n\nexport const StackLayout = defineComponent({\n name: 'NSStackLayout',\n emits: ['tap'],\n setup(_, { slots, attrs, emit }) {\n const onClick = (e: MouseEvent) => emit('tap', { eventName: 'tap', object: e.currentTarget });\n return () => h('div', { style: { display: 'flex', flexDirection: 'column' }, onClick, ...attrs }, slots.default?.());\n }\n});","import { defineComponent, h } from 'vue';\n\nexport const FlexboxLayout = defineComponent({\n name: 'NSFlexboxLayout',\n props: {\n flexDirection: { type: String, default: 'row' },\n justifyContent: { type: String, default: 'flex-start' },\n alignItems: { type: String, default: 'stretch' }\n },\n emits: ['tap'],\n setup(props, { slots, attrs, emit }) {\n const onClick = (e: MouseEvent) => emit('tap', { eventName: 'tap', object: e.currentTarget });\n return () => h('div', { style: { display: 'flex', flexDirection: props.flexDirection, justifyContent: props.justifyContent, alignItems: props.alignItems }, onClick, ...attrs }, slots.default?.());\n }\n});","import { defineComponent, h, VNode, isVNode } from 'vue';\n\nfunction parseTracks(tracks?: string) {\n if (!tracks) return undefined;\n return tracks.split(',').map(s => s.trim()).map(t => {\n if (t === '*' || t === 'auto') return t === '*' ? '1fr' : 'auto';\n if (/^\\d+$/.test(t)) return `${t}px`;\n return t;\n }).join(' ');\n}\n\nexport const GridLayout = defineComponent({\n name: 'NSGridLayout',\n props: {\n rows: { type: String, default: undefined },\n columns: { type: String, default: undefined }\n },\n emits: ['tap'],\n setup(props, { slots, attrs, emit }) {\n const containerStyle: Record<string, any> = {\n display: 'grid',\n // NS 默认一列:确保子项按行堆叠,而不是同一行多列并排\n gridTemplateColumns: parseTracks(props.columns) ?? '1fr',\n // 行可选;若未指定,默认自适应内容\n gridTemplateRows: parseTracks(props.rows) ?? undefined,\n // 以“按行”自动布局,默认逐行堆叠\n gridAutoFlow: 'row',\n width: '100%',\n height: '100%'\n };\n const mapChild = (child: VNode): VNode => {\n if (!isVNode(child)) return child as any;\n const cprops: any = { ...(child.props || {}) };\n const style: Record<string, any> = { ...(cprops.style || {}) };\n\n // Row/Column placement: NativeScript uses 0-based indices; CSS Grid is 1-based\n const row = cprops.row ?? cprops['row'];\n const col = cprops.col ?? cprops['col'] ?? cprops.column;\n if (row != null) {\n const r = Number(row);\n if (!isNaN(r)) style.gridRowStart = r + 1;\n }\n if (col != null) {\n const c = Number(col);\n if (!isNaN(c)) style.gridColumnStart = c + 1;\n } else {\n // 未声明列时,强制放在第 1 列,避免隐式多列导致并排\n style.gridColumnStart = 1;\n }\n\n // Horizontal alignment mapping\n const ha = cprops.horizontalAlignment ?? cprops['horizontalAlignment'];\n if (ha) {\n const map: Record<string, string> = {\n center: 'center',\n left: 'start',\n right: 'end',\n stretch: 'stretch'\n };\n style.justifySelf = map[String(ha).toLowerCase()] ?? style.justifySelf;\n }\n\n // Vertical alignment mapping\n const va = cprops.verticalAlignment ?? cprops['verticalAlignment'];\n if (va) {\n const map: Record<string, string> = {\n center: 'center',\n top: 'start',\n bottom: 'end',\n stretch: 'stretch'\n };\n style.alignSelf = map[String(va).toLowerCase()] ?? style.alignSelf;\n }\n\n // Row/Column span mapping\n const rowSpan = cprops.rowSpan ?? cprops['rowSpan'];\n if (rowSpan != null) {\n const rs = Number(rowSpan);\n if (!isNaN(rs) && rs > 1) style.gridRowEnd = `span ${rs}`;\n }\n const colSpan = cprops.colSpan ?? cprops['colSpan'];\n if (colSpan != null) {\n const cs = Number(colSpan);\n if (!isNaN(cs) && cs > 1) style.gridColumnEnd = `span ${cs}`;\n }\n\n cprops.style = style;\n return h(child.type as any, cprops, child.children as any);\n };\n\n const onClick = (e: MouseEvent) => emit('tap', { eventName: 'tap', object: e.currentTarget });\n return () => {\n const children = slots.default?.() ?? [];\n const mapped = children.map(mapChild);\n return h('div', { style: containerStyle, onClick, ...attrs }, mapped);\n };\n }\n});","import { defineComponent, h } from 'vue';\n\nexport const Page = defineComponent({\n name: 'NSPage',\n emits: ['tap'],\n setup(_, { slots, attrs, emit }) {\n const onClick = (e: MouseEvent) => emit('tap', { eventName: 'tap', object: e.currentTarget });\n return () => h('main', { onClick, ...attrs }, slots.default?.());\n }\n});","import { defineComponent, h } from 'vue';\n\nexport const Frame = defineComponent({\n name: 'NSFrame',\n setup(_, { slots, attrs }) {\n return () => h('div', { ...attrs }, slots.default?.());\n }\n});","import { defineComponent, h } from 'vue';\n\nexport const ActionBar = defineComponent({\n name: 'NSActionBar',\n emits: ['tap'],\n setup(_, { slots, attrs, emit }) {\n const onClick = (e: MouseEvent) => emit('tap', { eventName: 'tap', object: e.currentTarget });\n return () => h('header', { onClick, ...attrs }, slots.default?.());\n }\n});","import { defineComponent, h } from 'vue';\n\nexport const ImageCacheIt = defineComponent({\n name: 'ImageCacheIt',\n props: {\n src: { type: String, required: true },\n stretch: { type: String, default: 'aspectFill' }\n },\n setup(props, { attrs }) {\n const style: Record<string, any> = { width: '100%', display: 'block', objectPosition: 'center' };\n if (props.stretch === 'aspectFill') {\n style.objectFit = 'cover';\n } else if (props.stretch === 'aspectFit') {\n style.objectFit = 'contain';\n }\n return () => h('img', { src: props.src, style, ...attrs });\n }\n});","import type { App, Plugin } from 'vue';\nimport { Label } from './components/Label';\nimport { Button } from './components/Button';\nimport { StackLayout } from './components/StackLayout';\nimport { FlexboxLayout } from './components/FlexboxLayout';\nimport { GridLayout } from './components/GridLayout';\nimport { Page } from './components/Page';\nimport { Frame } from './components/Frame';\nimport { ActionBar } from './components/ActionBar';\nimport { ImageCacheIt } from './components/ImageCacheIt';\n\nexport const NativeScriptWebPlugin: Plugin = {\n install(app: App) {\n app.component('Label', Label);\n app.component('Button', Button);\n app.component('StackLayout', StackLayout);\n app.component('FlexboxLayout', FlexboxLayout);\n app.component('GridLayout', GridLayout);\n app.component('Page', Page);\n app.component('Frame', Frame);\n app.component('ActionBar', ActionBar);\n app.component('ImageCacheIt', ImageCacheIt);\n }\n};\n\nexport { Label, Button, StackLayout, FlexboxLayout, GridLayout, Page, Frame, ActionBar, ImageCacheIt };"],"names":["defineComponent","h","isVNode"],"mappings":"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"}
package/dist/vue.js ADDED
@@ -0,0 +1,229 @@
1
+ import { defineComponent, h, isVNode } from 'vue';
2
+
3
+ const Label = defineComponent({
4
+ name: 'NSLabel',
5
+ props: {
6
+ text: { type: String, default: '' },
7
+ horizontalAlignment: { type: String, default: undefined }
8
+ },
9
+ emits: ['tap'],
10
+ setup(props, { slots, attrs, emit }) {
11
+ var _a;
12
+ const style = {};
13
+ if (props.horizontalAlignment) {
14
+ const map = { center: 'center', left: 'left', right: 'right' };
15
+ style.textAlign = (_a = map[String(props.horizontalAlignment).toLowerCase()]) !== null && _a !== void 0 ? _a : undefined;
16
+ }
17
+ const onClick = (e) => emit('tap', { eventName: 'tap', object: e.currentTarget });
18
+ return () => h('span', { style, onClick, ...attrs }, slots.default ? slots.default() : props.text);
19
+ }
20
+ });
21
+
22
+ const Button = defineComponent({
23
+ name: 'NSButton',
24
+ props: {
25
+ text: { type: String, default: '' },
26
+ horizontalAlignment: { type: String, default: undefined }
27
+ },
28
+ emits: ['tap'],
29
+ setup(props, { emit, slots, attrs }) {
30
+ var _a;
31
+ const onClick = (e) => emit('tap', { eventName: 'tap', object: e.currentTarget });
32
+ const style = {};
33
+ if (props.horizontalAlignment) {
34
+ const map = {
35
+ center: 'center',
36
+ left: 'start',
37
+ right: 'end',
38
+ stretch: 'stretch'
39
+ };
40
+ style.justifySelf = (_a = map[String(props.horizontalAlignment).toLowerCase()]) !== null && _a !== void 0 ? _a : undefined;
41
+ }
42
+ return () => h('button', { onClick, style, ...attrs }, slots.default ? slots.default() : props.text);
43
+ }
44
+ });
45
+
46
+ const StackLayout = defineComponent({
47
+ name: 'NSStackLayout',
48
+ emits: ['tap'],
49
+ setup(_, { slots, attrs, emit }) {
50
+ const onClick = (e) => emit('tap', { eventName: 'tap', object: e.currentTarget });
51
+ return () => { var _a; return h('div', { style: { display: 'flex', flexDirection: 'column' }, onClick, ...attrs }, (_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots)); };
52
+ }
53
+ });
54
+
55
+ const FlexboxLayout = defineComponent({
56
+ name: 'NSFlexboxLayout',
57
+ props: {
58
+ flexDirection: { type: String, default: 'row' },
59
+ justifyContent: { type: String, default: 'flex-start' },
60
+ alignItems: { type: String, default: 'stretch' }
61
+ },
62
+ emits: ['tap'],
63
+ setup(props, { slots, attrs, emit }) {
64
+ const onClick = (e) => emit('tap', { eventName: 'tap', object: e.currentTarget });
65
+ return () => { var _a; return h('div', { style: { display: 'flex', flexDirection: props.flexDirection, justifyContent: props.justifyContent, alignItems: props.alignItems }, onClick, ...attrs }, (_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots)); };
66
+ }
67
+ });
68
+
69
+ function parseTracks(tracks) {
70
+ if (!tracks)
71
+ return undefined;
72
+ return tracks.split(',').map(s => s.trim()).map(t => {
73
+ if (t === '*' || t === 'auto')
74
+ return t === '*' ? '1fr' : 'auto';
75
+ if (/^\d+$/.test(t))
76
+ return `${t}px`;
77
+ return t;
78
+ }).join(' ');
79
+ }
80
+ const GridLayout = defineComponent({
81
+ name: 'NSGridLayout',
82
+ props: {
83
+ rows: { type: String, default: undefined },
84
+ columns: { type: String, default: undefined }
85
+ },
86
+ emits: ['tap'],
87
+ setup(props, { slots, attrs, emit }) {
88
+ var _a, _b;
89
+ const containerStyle = {
90
+ display: 'grid',
91
+ // NS 默认一列:确保子项按行堆叠,而不是同一行多列并排
92
+ gridTemplateColumns: (_a = parseTracks(props.columns)) !== null && _a !== void 0 ? _a : '1fr',
93
+ // 行可选;若未指定,默认自适应内容
94
+ gridTemplateRows: (_b = parseTracks(props.rows)) !== null && _b !== void 0 ? _b : undefined,
95
+ // 以“按行”自动布局,默认逐行堆叠
96
+ gridAutoFlow: 'row',
97
+ width: '100%',
98
+ height: '100%'
99
+ };
100
+ const mapChild = (child) => {
101
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j;
102
+ if (!isVNode(child))
103
+ return child;
104
+ const cprops = { ...(child.props || {}) };
105
+ const style = { ...(cprops.style || {}) };
106
+ // Row/Column placement: NativeScript uses 0-based indices; CSS Grid is 1-based
107
+ const row = (_a = cprops.row) !== null && _a !== void 0 ? _a : cprops['row'];
108
+ const col = (_c = (_b = cprops.col) !== null && _b !== void 0 ? _b : cprops['col']) !== null && _c !== void 0 ? _c : cprops.column;
109
+ if (row != null) {
110
+ const r = Number(row);
111
+ if (!isNaN(r))
112
+ style.gridRowStart = r + 1;
113
+ }
114
+ if (col != null) {
115
+ const c = Number(col);
116
+ if (!isNaN(c))
117
+ style.gridColumnStart = c + 1;
118
+ }
119
+ else {
120
+ // 未声明列时,强制放在第 1 列,避免隐式多列导致并排
121
+ style.gridColumnStart = 1;
122
+ }
123
+ // Horizontal alignment mapping
124
+ const ha = (_d = cprops.horizontalAlignment) !== null && _d !== void 0 ? _d : cprops['horizontalAlignment'];
125
+ if (ha) {
126
+ const map = {
127
+ center: 'center',
128
+ left: 'start',
129
+ right: 'end',
130
+ stretch: 'stretch'
131
+ };
132
+ style.justifySelf = (_e = map[String(ha).toLowerCase()]) !== null && _e !== void 0 ? _e : style.justifySelf;
133
+ }
134
+ // Vertical alignment mapping
135
+ const va = (_f = cprops.verticalAlignment) !== null && _f !== void 0 ? _f : cprops['verticalAlignment'];
136
+ if (va) {
137
+ const map = {
138
+ center: 'center',
139
+ top: 'start',
140
+ bottom: 'end',
141
+ stretch: 'stretch'
142
+ };
143
+ style.alignSelf = (_g = map[String(va).toLowerCase()]) !== null && _g !== void 0 ? _g : style.alignSelf;
144
+ }
145
+ // Row/Column span mapping
146
+ const rowSpan = (_h = cprops.rowSpan) !== null && _h !== void 0 ? _h : cprops['rowSpan'];
147
+ if (rowSpan != null) {
148
+ const rs = Number(rowSpan);
149
+ if (!isNaN(rs) && rs > 1)
150
+ style.gridRowEnd = `span ${rs}`;
151
+ }
152
+ const colSpan = (_j = cprops.colSpan) !== null && _j !== void 0 ? _j : cprops['colSpan'];
153
+ if (colSpan != null) {
154
+ const cs = Number(colSpan);
155
+ if (!isNaN(cs) && cs > 1)
156
+ style.gridColumnEnd = `span ${cs}`;
157
+ }
158
+ cprops.style = style;
159
+ return h(child.type, cprops, child.children);
160
+ };
161
+ const onClick = (e) => emit('tap', { eventName: 'tap', object: e.currentTarget });
162
+ return () => {
163
+ var _a, _b;
164
+ const children = (_b = (_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots)) !== null && _b !== void 0 ? _b : [];
165
+ const mapped = children.map(mapChild);
166
+ return h('div', { style: containerStyle, onClick, ...attrs }, mapped);
167
+ };
168
+ }
169
+ });
170
+
171
+ const Page = defineComponent({
172
+ name: 'NSPage',
173
+ emits: ['tap'],
174
+ setup(_, { slots, attrs, emit }) {
175
+ const onClick = (e) => emit('tap', { eventName: 'tap', object: e.currentTarget });
176
+ return () => { var _a; return h('main', { onClick, ...attrs }, (_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots)); };
177
+ }
178
+ });
179
+
180
+ const Frame = defineComponent({
181
+ name: 'NSFrame',
182
+ setup(_, { slots, attrs }) {
183
+ return () => { var _a; return h('div', { ...attrs }, (_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots)); };
184
+ }
185
+ });
186
+
187
+ const ActionBar = defineComponent({
188
+ name: 'NSActionBar',
189
+ emits: ['tap'],
190
+ setup(_, { slots, attrs, emit }) {
191
+ const onClick = (e) => emit('tap', { eventName: 'tap', object: e.currentTarget });
192
+ return () => { var _a; return h('header', { onClick, ...attrs }, (_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots)); };
193
+ }
194
+ });
195
+
196
+ const ImageCacheIt = defineComponent({
197
+ name: 'ImageCacheIt',
198
+ props: {
199
+ src: { type: String, required: true },
200
+ stretch: { type: String, default: 'aspectFill' }
201
+ },
202
+ setup(props, { attrs }) {
203
+ const style = { width: '100%', display: 'block', objectPosition: 'center' };
204
+ if (props.stretch === 'aspectFill') {
205
+ style.objectFit = 'cover';
206
+ }
207
+ else if (props.stretch === 'aspectFit') {
208
+ style.objectFit = 'contain';
209
+ }
210
+ return () => h('img', { src: props.src, style, ...attrs });
211
+ }
212
+ });
213
+
214
+ const NativeScriptWebPlugin = {
215
+ install(app) {
216
+ app.component('Label', Label);
217
+ app.component('Button', Button);
218
+ app.component('StackLayout', StackLayout);
219
+ app.component('FlexboxLayout', FlexboxLayout);
220
+ app.component('GridLayout', GridLayout);
221
+ app.component('Page', Page);
222
+ app.component('Frame', Frame);
223
+ app.component('ActionBar', ActionBar);
224
+ app.component('ImageCacheIt', ImageCacheIt);
225
+ }
226
+ };
227
+
228
+ export { ActionBar, Button, FlexboxLayout, Frame, GridLayout, ImageCacheIt, Label, NativeScriptWebPlugin, Page, StackLayout };
229
+ //# sourceMappingURL=vue.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vue.js","sources":["../../src/vue/components/Label.ts","../../src/vue/components/Button.ts","../../src/vue/components/StackLayout.ts","../../src/vue/components/FlexboxLayout.ts","../../src/vue/components/GridLayout.ts","../../src/vue/components/Page.ts","../../src/vue/components/Frame.ts","../../src/vue/components/ActionBar.ts","../../src/vue/components/ImageCacheIt.ts","../../src/vue/index.ts"],"sourcesContent":["import { defineComponent, h } from 'vue';\n\nexport const Label = defineComponent({\n name: 'NSLabel',\n props: {\n text: { type: String, default: '' },\n horizontalAlignment: { type: String, default: undefined }\n },\n emits: ['tap'],\n setup(props, { slots, attrs, emit }) {\n const style: Record<string, any> = {};\n if (props.horizontalAlignment) {\n const map: Record<string, string> = { center: 'center', left: 'left', right: 'right' };\n style.textAlign = map[String(props.horizontalAlignment).toLowerCase()] ?? undefined;\n }\n const onClick = (e: MouseEvent) => emit('tap', { eventName: 'tap', object: e.currentTarget });\n return () => h('span', { style, onClick, ...attrs }, slots.default ? slots.default() : props.text);\n }\n});","import { defineComponent, h } from 'vue';\n\nexport const Button = defineComponent({\n name: 'NSButton',\n props: {\n text: { type: String, default: '' },\n horizontalAlignment: { type: String, default: undefined }\n },\n emits: ['tap'],\n setup(props, { emit, slots, attrs }) {\n const onClick = (e: MouseEvent) => emit('tap', { eventName: 'tap', object: e.currentTarget });\n const style: Record<string, any> = {};\n if (props.horizontalAlignment) {\n const map: Record<string, string> = {\n center: 'center',\n left: 'start',\n right: 'end',\n stretch: 'stretch'\n };\n style.justifySelf = map[String(props.horizontalAlignment).toLowerCase()] ?? undefined;\n }\n return () => h('button', { onClick, style, ...attrs }, slots.default ? slots.default() : props.text);\n }\n});","import { defineComponent, h } from 'vue';\n\nexport const StackLayout = defineComponent({\n name: 'NSStackLayout',\n emits: ['tap'],\n setup(_, { slots, attrs, emit }) {\n const onClick = (e: MouseEvent) => emit('tap', { eventName: 'tap', object: e.currentTarget });\n return () => h('div', { style: { display: 'flex', flexDirection: 'column' }, onClick, ...attrs }, slots.default?.());\n }\n});","import { defineComponent, h } from 'vue';\n\nexport const FlexboxLayout = defineComponent({\n name: 'NSFlexboxLayout',\n props: {\n flexDirection: { type: String, default: 'row' },\n justifyContent: { type: String, default: 'flex-start' },\n alignItems: { type: String, default: 'stretch' }\n },\n emits: ['tap'],\n setup(props, { slots, attrs, emit }) {\n const onClick = (e: MouseEvent) => emit('tap', { eventName: 'tap', object: e.currentTarget });\n return () => h('div', { style: { display: 'flex', flexDirection: props.flexDirection, justifyContent: props.justifyContent, alignItems: props.alignItems }, onClick, ...attrs }, slots.default?.());\n }\n});","import { defineComponent, h, VNode, isVNode } from 'vue';\n\nfunction parseTracks(tracks?: string) {\n if (!tracks) return undefined;\n return tracks.split(',').map(s => s.trim()).map(t => {\n if (t === '*' || t === 'auto') return t === '*' ? '1fr' : 'auto';\n if (/^\\d+$/.test(t)) return `${t}px`;\n return t;\n }).join(' ');\n}\n\nexport const GridLayout = defineComponent({\n name: 'NSGridLayout',\n props: {\n rows: { type: String, default: undefined },\n columns: { type: String, default: undefined }\n },\n emits: ['tap'],\n setup(props, { slots, attrs, emit }) {\n const containerStyle: Record<string, any> = {\n display: 'grid',\n // NS 默认一列:确保子项按行堆叠,而不是同一行多列并排\n gridTemplateColumns: parseTracks(props.columns) ?? '1fr',\n // 行可选;若未指定,默认自适应内容\n gridTemplateRows: parseTracks(props.rows) ?? undefined,\n // 以“按行”自动布局,默认逐行堆叠\n gridAutoFlow: 'row',\n width: '100%',\n height: '100%'\n };\n const mapChild = (child: VNode): VNode => {\n if (!isVNode(child)) return child as any;\n const cprops: any = { ...(child.props || {}) };\n const style: Record<string, any> = { ...(cprops.style || {}) };\n\n // Row/Column placement: NativeScript uses 0-based indices; CSS Grid is 1-based\n const row = cprops.row ?? cprops['row'];\n const col = cprops.col ?? cprops['col'] ?? cprops.column;\n if (row != null) {\n const r = Number(row);\n if (!isNaN(r)) style.gridRowStart = r + 1;\n }\n if (col != null) {\n const c = Number(col);\n if (!isNaN(c)) style.gridColumnStart = c + 1;\n } else {\n // 未声明列时,强制放在第 1 列,避免隐式多列导致并排\n style.gridColumnStart = 1;\n }\n\n // Horizontal alignment mapping\n const ha = cprops.horizontalAlignment ?? cprops['horizontalAlignment'];\n if (ha) {\n const map: Record<string, string> = {\n center: 'center',\n left: 'start',\n right: 'end',\n stretch: 'stretch'\n };\n style.justifySelf = map[String(ha).toLowerCase()] ?? style.justifySelf;\n }\n\n // Vertical alignment mapping\n const va = cprops.verticalAlignment ?? cprops['verticalAlignment'];\n if (va) {\n const map: Record<string, string> = {\n center: 'center',\n top: 'start',\n bottom: 'end',\n stretch: 'stretch'\n };\n style.alignSelf = map[String(va).toLowerCase()] ?? style.alignSelf;\n }\n\n // Row/Column span mapping\n const rowSpan = cprops.rowSpan ?? cprops['rowSpan'];\n if (rowSpan != null) {\n const rs = Number(rowSpan);\n if (!isNaN(rs) && rs > 1) style.gridRowEnd = `span ${rs}`;\n }\n const colSpan = cprops.colSpan ?? cprops['colSpan'];\n if (colSpan != null) {\n const cs = Number(colSpan);\n if (!isNaN(cs) && cs > 1) style.gridColumnEnd = `span ${cs}`;\n }\n\n cprops.style = style;\n return h(child.type as any, cprops, child.children as any);\n };\n\n const onClick = (e: MouseEvent) => emit('tap', { eventName: 'tap', object: e.currentTarget });\n return () => {\n const children = slots.default?.() ?? [];\n const mapped = children.map(mapChild);\n return h('div', { style: containerStyle, onClick, ...attrs }, mapped);\n };\n }\n});","import { defineComponent, h } from 'vue';\n\nexport const Page = defineComponent({\n name: 'NSPage',\n emits: ['tap'],\n setup(_, { slots, attrs, emit }) {\n const onClick = (e: MouseEvent) => emit('tap', { eventName: 'tap', object: e.currentTarget });\n return () => h('main', { onClick, ...attrs }, slots.default?.());\n }\n});","import { defineComponent, h } from 'vue';\n\nexport const Frame = defineComponent({\n name: 'NSFrame',\n setup(_, { slots, attrs }) {\n return () => h('div', { ...attrs }, slots.default?.());\n }\n});","import { defineComponent, h } from 'vue';\n\nexport const ActionBar = defineComponent({\n name: 'NSActionBar',\n emits: ['tap'],\n setup(_, { slots, attrs, emit }) {\n const onClick = (e: MouseEvent) => emit('tap', { eventName: 'tap', object: e.currentTarget });\n return () => h('header', { onClick, ...attrs }, slots.default?.());\n }\n});","import { defineComponent, h } from 'vue';\n\nexport const ImageCacheIt = defineComponent({\n name: 'ImageCacheIt',\n props: {\n src: { type: String, required: true },\n stretch: { type: String, default: 'aspectFill' }\n },\n setup(props, { attrs }) {\n const style: Record<string, any> = { width: '100%', display: 'block', objectPosition: 'center' };\n if (props.stretch === 'aspectFill') {\n style.objectFit = 'cover';\n } else if (props.stretch === 'aspectFit') {\n style.objectFit = 'contain';\n }\n return () => h('img', { src: props.src, style, ...attrs });\n }\n});","import type { App, Plugin } from 'vue';\nimport { Label } from './components/Label';\nimport { Button } from './components/Button';\nimport { StackLayout } from './components/StackLayout';\nimport { FlexboxLayout } from './components/FlexboxLayout';\nimport { GridLayout } from './components/GridLayout';\nimport { Page } from './components/Page';\nimport { Frame } from './components/Frame';\nimport { ActionBar } from './components/ActionBar';\nimport { ImageCacheIt } from './components/ImageCacheIt';\n\nexport const NativeScriptWebPlugin: Plugin = {\n install(app: App) {\n app.component('Label', Label);\n app.component('Button', Button);\n app.component('StackLayout', StackLayout);\n app.component('FlexboxLayout', FlexboxLayout);\n app.component('GridLayout', GridLayout);\n app.component('Page', Page);\n app.component('Frame', Frame);\n app.component('ActionBar', ActionBar);\n app.component('ImageCacheIt', ImageCacheIt);\n }\n};\n\nexport { Label, Button, StackLayout, FlexboxLayout, GridLayout, Page, Frame, ActionBar, ImageCacheIt };"],"names":[],"mappings":"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"}
package/package.json ADDED
@@ -0,0 +1,59 @@
1
+ {
2
+ "name": "nativescript-web-adapter",
3
+ "version": "0.1.1",
4
+ "repository": {
5
+ "type": "git",
6
+ "url": "https://github.com/ponzS/NativeScript-for-web.git"
7
+ },
8
+ "bugs": {
9
+ "url": "https://github.com/ponzS/NativeScript-for-web/issues"
10
+ },
11
+ "homepage": "https://github.com/ponzS/NativeScript-for-web#readme",
12
+ "files": [
13
+ "dist",
14
+ "README.md"
15
+ ],
16
+ "description": "Web adapter for NativeScript UI components (Vue 3)",
17
+ "license": "MIT",
18
+ "type": "module",
19
+ "main": "dist/index.cjs",
20
+ "module": "dist/index.js",
21
+ "types": "dist/types/index.d.ts",
22
+ "exports": {
23
+ ".": {
24
+ "import": "./dist/index.js",
25
+ "require": "./dist/index.cjs",
26
+ "types": "./dist/types/index.d.ts"
27
+ },
28
+ "./vue": {
29
+ "import": "./dist/vue.js",
30
+ "require": "./dist/vue.cjs",
31
+ "types": "./dist/types/vue.d.ts"
32
+ },
33
+ "./core": {
34
+ "import": "./dist/core.js",
35
+ "require": "./dist/core.cjs",
36
+ "types": "./dist/types/core/index.d.ts"
37
+ }
38
+ },
39
+ "scripts": {
40
+ "build": "rimraf dist && rollup -c",
41
+ "types": "tsc -p tsconfig.json",
42
+ "test": "vitest run",
43
+ "dev": "vitest",
44
+ "prepare": "npm run build && npm run types",
45
+ "prepublishOnly": "npm run build && npm run types"
46
+ },
47
+ "peerDependencies": {
48
+ "vue": "^3.4.0"
49
+ },
50
+ "devDependencies": {
51
+ "@rollup/plugin-typescript": "^11.1.6",
52
+ "rimraf": "^6.0.1",
53
+ "rollup": "^4.22.0",
54
+ "rollup-plugin-dts": "^6.0.2",
55
+ "tslib": "^2.6.3",
56
+ "typescript": "~5.9.0",
57
+ "vitest": "^2.0.5"
58
+ }
59
+ }