@fugood/bricks-project 2.23.7 → 2.23.9-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/compile/index.ts +72 -25
- package/package.json +2 -2
- package/skills/bricks-design/LICENSE.txt +180 -0
- package/skills/bricks-design/SKILL.md +66 -0
- package/types/automation.ts +1 -1
- package/types/bricks/Camera.ts +10 -5
- package/types/bricks/Chart.ts +5 -2
- package/types/bricks/GenerativeMedia.ts +20 -7
- package/types/bricks/Icon.ts +3 -2
- package/types/bricks/Image.ts +2 -1
- package/types/bricks/Items.ts +19 -8
- package/types/bricks/Lottie.ts +9 -4
- package/types/bricks/Maps.ts +10 -5
- package/types/bricks/QrCode.ts +1 -0
- package/types/bricks/Rect.ts +1 -0
- package/types/bricks/RichText.ts +3 -2
- package/types/bricks/Rive.ts +17 -10
- package/types/bricks/Slideshow.ts +12 -5
- package/types/bricks/Svg.ts +1 -0
- package/types/bricks/Text.ts +1 -0
- package/types/bricks/TextInput.ts +8 -5
- package/types/bricks/Video.ts +3 -2
- package/types/bricks/VideoStreaming.ts +1 -0
- package/types/bricks/WebRtcStream.ts +1 -0
- package/types/bricks/WebView.ts +6 -5
- package/types/common.ts +10 -8
- package/types/generators/AlarmClock.ts +7 -4
- package/types/generators/Assistant.ts +9 -6
- package/types/generators/BleCentral.ts +14 -5
- package/types/generators/BlePeripheral.ts +1 -0
- package/types/generators/CanvasMap.ts +2 -1
- package/types/generators/CastlesPay.ts +7 -2
- package/types/generators/DataBank.ts +8 -3
- package/types/generators/File.ts +41 -14
- package/types/generators/GraphQl.ts +6 -3
- package/types/generators/Http.ts +3 -2
- package/types/generators/HttpServer.ts +11 -6
- package/types/generators/Information.ts +2 -1
- package/types/generators/Intent.ts +3 -2
- package/types/generators/Iterator.ts +5 -4
- package/types/generators/Keyboard.ts +4 -3
- package/types/generators/LlmAnthropicCompat.ts +11 -4
- package/types/generators/LlmAppleBuiltin.ts +8 -3
- package/types/generators/LlmGgml.ts +12 -5
- package/types/generators/LlmMediaTekNeuroPilot.ts +11 -4
- package/types/generators/LlmMlx.ts +11 -4
- package/types/generators/LlmOnnx.ts +11 -4
- package/types/generators/LlmOpenAiCompat.ts +11 -4
- package/types/generators/LlmQualcommAiEngine.ts +9 -4
- package/types/generators/Mcp.ts +40 -17
- package/types/generators/McpServer.ts +17 -8
- package/types/generators/MediaFlow.ts +8 -3
- package/types/generators/MqttBroker.ts +16 -7
- package/types/generators/MqttClient.ts +5 -4
- package/types/generators/Question.ts +2 -1
- package/types/generators/RealtimeTranscription.ts +22 -7
- package/types/generators/RerankerGgml.ts +5 -2
- package/types/generators/SerialPort.ts +7 -2
- package/types/generators/SoundPlayer.ts +4 -1
- package/types/generators/SoundRecorder.ts +3 -2
- package/types/generators/SpeechToTextGgml.ts +8 -3
- package/types/generators/SpeechToTextOnnx.ts +5 -2
- package/types/generators/SpeechToTextPlatform.ts +7 -2
- package/types/generators/SqLite.ts +5 -2
- package/types/generators/Step.ts +2 -1
- package/types/generators/SttAppleBuiltin.ts +5 -2
- package/types/generators/Tcp.ts +5 -4
- package/types/generators/TcpServer.ts +10 -7
- package/types/generators/TextToSpeechAppleBuiltin.ts +5 -2
- package/types/generators/TextToSpeechGgml.ts +5 -2
- package/types/generators/TextToSpeechOnnx.ts +5 -2
- package/types/generators/TextToSpeechOpenAiLike.ts +5 -2
- package/types/generators/ThermalPrinter.ts +2 -1
- package/types/generators/Tick.ts +3 -2
- package/types/generators/Udp.ts +3 -2
- package/types/generators/VadGgml.ts +8 -3
- package/types/generators/VadOnnx.ts +6 -3
- package/types/generators/VadTraditional.ts +8 -3
- package/types/generators/VectorStore.ts +4 -3
- package/types/generators/Watchdog.ts +3 -2
- package/types/generators/WebCrawler.ts +3 -2
- package/types/generators/WebRtc.ts +8 -3
- package/types/generators/WebSocket.ts +2 -1
- package/types/subspace.ts +1 -0
- package/utils/event-props.ts +833 -1059
package/types/bricks/Items.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
/* Auto generated by build script
|
|
2
2
|
*
|
|
3
|
-
*
|
|
3
|
+
* Data-driven list/grid. Maps items array to brick templates via propertyMapping, with pagination and detail mode support
|
|
4
4
|
*/
|
|
5
5
|
import type { SwitchCondInnerStateCurrentCanvas, SwitchCondData, SwitchDef } from '../switch'
|
|
6
6
|
import type { Data, DataLink } from '../data'
|
|
@@ -15,6 +15,7 @@ import type {
|
|
|
15
15
|
EventProperty,
|
|
16
16
|
} from '../common'
|
|
17
17
|
import type { BrickBasicProperty, BrickBasicEvents, BrickBasicEventsForItem } from '../brick-base'
|
|
18
|
+
import type { TemplateEventPropsMap } from '../../utils/event-props'
|
|
18
19
|
|
|
19
20
|
/* prev page */
|
|
20
21
|
export type BrickItemsActionPrevPage = Action & {
|
|
@@ -400,17 +401,27 @@ Default property:
|
|
|
400
401
|
| DataLink
|
|
401
402
|
events?: BrickBasicEventsForItem & {
|
|
402
403
|
/* Event on page render finished */
|
|
403
|
-
onPageRender?: Array<
|
|
404
|
+
onPageRender?: Array<
|
|
405
|
+
EventActionForItem<string & keyof TemplateEventPropsMap['Items']['onPageRender']>
|
|
406
|
+
>
|
|
404
407
|
/* Event on page change. */
|
|
405
|
-
onPageChange?: Array<
|
|
408
|
+
onPageChange?: Array<
|
|
409
|
+
EventActionForItem<string & keyof TemplateEventPropsMap['Items']['onPageChange']>
|
|
410
|
+
>
|
|
406
411
|
/* Event on page index out of bound. */
|
|
407
|
-
onPageOutOfBound?: Array<
|
|
412
|
+
onPageOutOfBound?: Array<
|
|
413
|
+
EventActionForItem<string & keyof TemplateEventPropsMap['Items']['onPageOutOfBound']>
|
|
414
|
+
>
|
|
408
415
|
/* Event on into `detail` mode */
|
|
409
|
-
onIntoDetailMode?: Array<
|
|
416
|
+
onIntoDetailMode?: Array<
|
|
417
|
+
EventActionForItem<string & keyof TemplateEventPropsMap['Items']['onIntoDetailMode']>
|
|
418
|
+
>
|
|
410
419
|
/* Event on into `list` mode. */
|
|
411
|
-
onIntoListMode?: Array<
|
|
420
|
+
onIntoListMode?: Array<
|
|
421
|
+
EventActionForItem<string & keyof TemplateEventPropsMap['Items']['onIntoListMode']>
|
|
422
|
+
>
|
|
412
423
|
/* Event on render error */
|
|
413
|
-
onError?: Array<EventActionForItem
|
|
424
|
+
onError?: Array<EventActionForItem<string & keyof TemplateEventPropsMap['Items']['onError']>>
|
|
414
425
|
}
|
|
415
426
|
outlets?: {
|
|
416
427
|
/* Catched error message */
|
|
@@ -436,7 +447,7 @@ Default property:
|
|
|
436
447
|
}
|
|
437
448
|
}
|
|
438
449
|
|
|
439
|
-
/*
|
|
450
|
+
/* Data-driven list/grid. Maps items array to brick templates via propertyMapping, with pagination and detail mode support */
|
|
440
451
|
export type BrickItems = Brick &
|
|
441
452
|
BrickItemsDef & {
|
|
442
453
|
templateKey: 'BRICK_ITEMS'
|
package/types/bricks/Lottie.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
/* Auto generated by build script
|
|
2
2
|
*
|
|
3
|
-
* Lottie
|
|
3
|
+
* Lottie animation player supporting .json and .dotlottie formats. Supports speed, loop, frame range control, color/text filters, and hardware rendering
|
|
4
4
|
*/
|
|
5
5
|
import type { SwitchCondInnerStateCurrentCanvas, SwitchCondData, SwitchDef } from '../switch'
|
|
6
6
|
import type { Data, DataLink } from '../data'
|
|
@@ -15,6 +15,7 @@ import type {
|
|
|
15
15
|
EventProperty,
|
|
16
16
|
} from '../common'
|
|
17
17
|
import type { BrickBasicProperty, BrickBasicEvents, BrickBasicEventsForItem } from '../brick-base'
|
|
18
|
+
import type { TemplateEventPropsMap } from '../../utils/event-props'
|
|
18
19
|
|
|
19
20
|
/* Play animation */
|
|
20
21
|
export type BrickLottieActionPlay = ActionWithParams & {
|
|
@@ -115,9 +116,13 @@ Default property:
|
|
|
115
116
|
/* Event of the brick blur (Use TV Device with controller) */
|
|
116
117
|
onBlur?: Array<EventAction>
|
|
117
118
|
/* Event of the animation finished */
|
|
118
|
-
onAnimationFinish?: Array<
|
|
119
|
+
onAnimationFinish?: Array<
|
|
120
|
+
EventAction<string & keyof TemplateEventPropsMap['Lottie']['onAnimationFinish']>
|
|
121
|
+
>
|
|
119
122
|
/* Event of the uri on load failed */
|
|
120
|
-
onAnimationFailure?: Array<
|
|
123
|
+
onAnimationFailure?: Array<
|
|
124
|
+
EventAction<string & keyof TemplateEventPropsMap['Lottie']['onAnimationFailure']>
|
|
125
|
+
>
|
|
121
126
|
/* Event of the animation on loop */
|
|
122
127
|
onAnimationLoop?: Array<EventAction>
|
|
123
128
|
}
|
|
@@ -140,7 +145,7 @@ Default property:
|
|
|
140
145
|
}
|
|
141
146
|
}
|
|
142
147
|
|
|
143
|
-
/* Lottie
|
|
148
|
+
/* Lottie animation player supporting .json and .dotlottie formats. Supports speed, loop, frame range control, color/text filters, and hardware rendering */
|
|
144
149
|
export type BrickLottie = Brick &
|
|
145
150
|
BrickLottieDef & {
|
|
146
151
|
templateKey: 'BRICK_LOTTIE'
|
package/types/bricks/Maps.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
/* Auto generated by build script
|
|
2
2
|
*
|
|
3
|
-
* Interactive map
|
|
3
|
+
* Interactive map with markers, paths, and location tracking. Supports Google Maps (iOS/Android/Desktop/Web) and Apple Maps (iOS/tvOS)
|
|
4
4
|
*/
|
|
5
5
|
import type { SwitchCondInnerStateCurrentCanvas, SwitchCondData, SwitchDef } from '../switch'
|
|
6
6
|
import type { Data, DataLink } from '../data'
|
|
@@ -15,6 +15,7 @@ import type {
|
|
|
15
15
|
EventProperty,
|
|
16
16
|
} from '../common'
|
|
17
17
|
import type { BrickBasicProperty, BrickBasicEvents, BrickBasicEventsForItem } from '../brick-base'
|
|
18
|
+
import type { TemplateEventPropsMap } from '../../utils/event-props'
|
|
18
19
|
|
|
19
20
|
/* Zoom in the map */
|
|
20
21
|
export type BrickMapsActionZoomIn = Action & {
|
|
@@ -206,11 +207,15 @@ Default property:
|
|
|
206
207
|
/* Event of the brick blur (Use TV Device with controller) */
|
|
207
208
|
onBlur?: Array<EventAction>
|
|
208
209
|
/* Event when a marker is pressed */
|
|
209
|
-
onMarkerPress?: Array<
|
|
210
|
+
onMarkerPress?: Array<
|
|
211
|
+
EventAction<string & keyof TemplateEventPropsMap['Maps']['onMarkerPress']>
|
|
212
|
+
>
|
|
210
213
|
/* Event when the map is pressed */
|
|
211
|
-
onMapPress?: Array<EventAction
|
|
214
|
+
onMapPress?: Array<EventAction<string & keyof TemplateEventPropsMap['Maps']['onMapPress']>>
|
|
212
215
|
/* Event when the map region changes */
|
|
213
|
-
onRegionChange?: Array<
|
|
216
|
+
onRegionChange?: Array<
|
|
217
|
+
EventAction<string & keyof TemplateEventPropsMap['Maps']['onRegionChange']>
|
|
218
|
+
>
|
|
214
219
|
/* Event when the map is ready */
|
|
215
220
|
onReady?: Array<EventAction>
|
|
216
221
|
}
|
|
@@ -234,7 +239,7 @@ Default property:
|
|
|
234
239
|
}
|
|
235
240
|
}
|
|
236
241
|
|
|
237
|
-
/* Interactive map
|
|
242
|
+
/* Interactive map with markers, paths, and location tracking. Supports Google Maps (iOS/Android/Desktop/Web) and Apple Maps (iOS/tvOS) */
|
|
238
243
|
export type BrickMaps = Brick &
|
|
239
244
|
BrickMapsDef & {
|
|
240
245
|
templateKey: 'BRICK_MAPS'
|
package/types/bricks/QrCode.ts
CHANGED
|
@@ -15,6 +15,7 @@ import type {
|
|
|
15
15
|
EventProperty,
|
|
16
16
|
} from '../common'
|
|
17
17
|
import type { BrickBasicProperty, BrickBasicEvents, BrickBasicEventsForItem } from '../brick-base'
|
|
18
|
+
import type { TemplateEventPropsMap } from '../../utils/event-props'
|
|
18
19
|
|
|
19
20
|
interface BrickQrcodeDef {
|
|
20
21
|
/*
|
package/types/bricks/Rect.ts
CHANGED
|
@@ -15,6 +15,7 @@ import type {
|
|
|
15
15
|
EventProperty,
|
|
16
16
|
} from '../common'
|
|
17
17
|
import type { BrickBasicProperty, BrickBasicEvents, BrickBasicEventsForItem } from '../brick-base'
|
|
18
|
+
import type { TemplateEventPropsMap } from '../../utils/event-props'
|
|
18
19
|
|
|
19
20
|
interface BrickRectDef {
|
|
20
21
|
/*
|
package/types/bricks/RichText.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
/* Auto generated by build script
|
|
2
2
|
*
|
|
3
|
-
* Rich text
|
|
3
|
+
* Rich text with HTML content rendering, multiple fonts, colors, heading levels (h1-h6), and inline images
|
|
4
4
|
*/
|
|
5
5
|
import type { SwitchCondInnerStateCurrentCanvas, SwitchCondData, SwitchDef } from '../switch'
|
|
6
6
|
import type { Data, DataLink } from '../data'
|
|
@@ -15,6 +15,7 @@ import type {
|
|
|
15
15
|
EventProperty,
|
|
16
16
|
} from '../common'
|
|
17
17
|
import type { BrickBasicProperty, BrickBasicEvents, BrickBasicEventsForItem } from '../brick-base'
|
|
18
|
+
import type { TemplateEventPropsMap } from '../../utils/event-props'
|
|
18
19
|
|
|
19
20
|
interface BrickRichTextDef {
|
|
20
21
|
/*
|
|
@@ -104,7 +105,7 @@ Default property:
|
|
|
104
105
|
}
|
|
105
106
|
}
|
|
106
107
|
|
|
107
|
-
/* Rich text
|
|
108
|
+
/* Rich text with HTML content rendering, multiple fonts, colors, heading levels (h1-h6), and inline images */
|
|
108
109
|
export type BrickRichText = Brick &
|
|
109
110
|
BrickRichTextDef & {
|
|
110
111
|
templateKey: 'BRICK_RICH_TEXT'
|
package/types/bricks/Rive.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
/* Auto generated by build script
|
|
2
2
|
*
|
|
3
|
-
* Rive
|
|
3
|
+
* Render Rive (.riv) animations with state machine input control, text run updates, and artboard selection
|
|
4
4
|
*/
|
|
5
5
|
import type { SwitchCondInnerStateCurrentCanvas, SwitchCondData, SwitchDef } from '../switch'
|
|
6
6
|
import type { Data, DataLink } from '../data'
|
|
@@ -15,6 +15,7 @@ import type {
|
|
|
15
15
|
EventProperty,
|
|
16
16
|
} from '../common'
|
|
17
17
|
import type { BrickBasicProperty, BrickBasicEvents, BrickBasicEventsForItem } from '../brick-base'
|
|
18
|
+
import type { TemplateEventPropsMap } from '../../utils/event-props'
|
|
18
19
|
|
|
19
20
|
/* Play animation */
|
|
20
21
|
export type BrickRiveActionPlay = ActionWithParams & {
|
|
@@ -162,21 +163,27 @@ Default property:
|
|
|
162
163
|
}
|
|
163
164
|
events?: BrickBasicEvents & {
|
|
164
165
|
/* Event of animation play */
|
|
165
|
-
onPlay?: Array<EventAction
|
|
166
|
+
onPlay?: Array<EventAction<string & keyof TemplateEventPropsMap['Rive']['onPlay']>>
|
|
166
167
|
/* Event of animation pause */
|
|
167
|
-
onPause?: Array<EventAction
|
|
168
|
+
onPause?: Array<EventAction<string & keyof TemplateEventPropsMap['Rive']['onPause']>>
|
|
168
169
|
/* Event of animation stop */
|
|
169
|
-
onStop?: Array<EventAction
|
|
170
|
+
onStop?: Array<EventAction<string & keyof TemplateEventPropsMap['Rive']['onStop']>>
|
|
170
171
|
/* Event of animation loop end */
|
|
171
|
-
onLoopEnd?: Array<EventAction
|
|
172
|
+
onLoopEnd?: Array<EventAction<string & keyof TemplateEventPropsMap['Rive']['onLoopEnd']>>
|
|
172
173
|
/* Event of state changed */
|
|
173
|
-
onStateChanged?: Array<
|
|
174
|
+
onStateChanged?: Array<
|
|
175
|
+
EventAction<string & keyof TemplateEventPropsMap['Rive']['onStateChanged']>
|
|
176
|
+
>
|
|
174
177
|
/* Event of error */
|
|
175
|
-
onError?: Array<EventAction
|
|
178
|
+
onError?: Array<EventAction<string & keyof TemplateEventPropsMap['Rive']['onError']>>
|
|
176
179
|
/* Event of Rive general event received */
|
|
177
|
-
onRiveGeneralEvent?: Array<
|
|
180
|
+
onRiveGeneralEvent?: Array<
|
|
181
|
+
EventAction<string & keyof TemplateEventPropsMap['Rive']['onRiveGeneralEvent']>
|
|
182
|
+
>
|
|
178
183
|
/* Event of Rive open-url event received */
|
|
179
|
-
onRiveOpenUrlEvent?: Array<
|
|
184
|
+
onRiveOpenUrlEvent?: Array<
|
|
185
|
+
EventAction<string & keyof TemplateEventPropsMap['Rive']['onRiveOpenUrlEvent']>
|
|
186
|
+
>
|
|
180
187
|
}
|
|
181
188
|
animation?: AnimationBasicEvents & {
|
|
182
189
|
onPlay?: Animation
|
|
@@ -190,7 +197,7 @@ Default property:
|
|
|
190
197
|
}
|
|
191
198
|
}
|
|
192
199
|
|
|
193
|
-
/* Rive
|
|
200
|
+
/* Render Rive (.riv) animations with state machine input control, text run updates, and artboard selection */
|
|
194
201
|
export type BrickRive = Brick &
|
|
195
202
|
BrickRiveDef & {
|
|
196
203
|
templateKey: 'BRICK_RIVE'
|
|
@@ -15,6 +15,7 @@ import type {
|
|
|
15
15
|
EventProperty,
|
|
16
16
|
} from '../common'
|
|
17
17
|
import type { BrickBasicProperty, BrickBasicEvents, BrickBasicEventsForItem } from '../brick-base'
|
|
18
|
+
import type { TemplateEventPropsMap } from '../../utils/event-props'
|
|
18
19
|
|
|
19
20
|
/* Jump to a specific index in the slideshow */
|
|
20
21
|
export type BrickSlideshowActionJumpToIndex = ActionWithParams & {
|
|
@@ -149,17 +150,23 @@ Default property:
|
|
|
149
150
|
}
|
|
150
151
|
events?: BrickBasicEvents & {
|
|
151
152
|
/* Event of the next slideshow on change start */
|
|
152
|
-
changeStart?: Array<
|
|
153
|
+
changeStart?: Array<
|
|
154
|
+
EventAction<string & keyof TemplateEventPropsMap['Slideshow']['changeStart']>
|
|
155
|
+
>
|
|
153
156
|
/* Event of the next slideshow on change end */
|
|
154
|
-
changeEnd?: Array<EventAction
|
|
157
|
+
changeEnd?: Array<EventAction<string & keyof TemplateEventPropsMap['Slideshow']['changeEnd']>>
|
|
155
158
|
/* Event on paths change */
|
|
156
|
-
contentChange?: Array<
|
|
159
|
+
contentChange?: Array<
|
|
160
|
+
EventAction<string & keyof TemplateEventPropsMap['Slideshow']['contentChange']>
|
|
161
|
+
>
|
|
157
162
|
/* Event on plays of paths are end */
|
|
158
|
-
roundEnd?: Array<EventAction
|
|
163
|
+
roundEnd?: Array<EventAction<string & keyof TemplateEventPropsMap['Slideshow']['roundEnd']>>
|
|
159
164
|
/* Event of the slideshow on load */
|
|
160
165
|
mediaOnLoad?: Array<EventAction>
|
|
161
166
|
/* Event of the slideshow media loading error */
|
|
162
|
-
mediaOnError?: Array<
|
|
167
|
+
mediaOnError?: Array<
|
|
168
|
+
EventAction<string & keyof TemplateEventPropsMap['Slideshow']['mediaOnError']>
|
|
169
|
+
>
|
|
163
170
|
}
|
|
164
171
|
animation?: AnimationBasicEvents & {
|
|
165
172
|
changeStart?: Animation
|
package/types/bricks/Svg.ts
CHANGED
|
@@ -15,6 +15,7 @@ import type {
|
|
|
15
15
|
EventProperty,
|
|
16
16
|
} from '../common'
|
|
17
17
|
import type { BrickBasicProperty, BrickBasicEvents, BrickBasicEventsForItem } from '../brick-base'
|
|
18
|
+
import type { TemplateEventPropsMap } from '../../utils/event-props'
|
|
18
19
|
|
|
19
20
|
interface BrickSvgDef {
|
|
20
21
|
/*
|
package/types/bricks/Text.ts
CHANGED
|
@@ -15,6 +15,7 @@ import type {
|
|
|
15
15
|
EventProperty,
|
|
16
16
|
} from '../common'
|
|
17
17
|
import type { BrickBasicProperty, BrickBasicEvents, BrickBasicEventsForItem } from '../brick-base'
|
|
18
|
+
import type { TemplateEventPropsMap } from '../../utils/event-props'
|
|
18
19
|
|
|
19
20
|
interface BrickTextDef {
|
|
20
21
|
/*
|
|
@@ -15,6 +15,7 @@ import type {
|
|
|
15
15
|
EventProperty,
|
|
16
16
|
} from '../common'
|
|
17
17
|
import type { BrickBasicProperty, BrickBasicEvents, BrickBasicEventsForItem } from '../brick-base'
|
|
18
|
+
import type { TemplateEventPropsMap } from '../../utils/event-props'
|
|
18
19
|
|
|
19
20
|
/* Focus TextInput */
|
|
20
21
|
export type BrickTextInputActionFocus = Action & {
|
|
@@ -175,15 +176,17 @@ Default property:
|
|
|
175
176
|
/* Event of the TextInput is empty */
|
|
176
177
|
onEmpty?: Array<EventAction>
|
|
177
178
|
/* Event of the TextInput value change */
|
|
178
|
-
onChange?: Array<EventAction
|
|
179
|
+
onChange?: Array<EventAction<string & keyof TemplateEventPropsMap['TextInput']['onChange']>>
|
|
179
180
|
/* Event of the TextInput submit */
|
|
180
|
-
onSubmit?: Array<EventAction
|
|
181
|
+
onSubmit?: Array<EventAction<string & keyof TemplateEventPropsMap['TextInput']['onSubmit']>>
|
|
181
182
|
/* Event of the TextInput match regex (check every value change) */
|
|
182
|
-
onMatch?: Array<EventAction
|
|
183
|
+
onMatch?: Array<EventAction<string & keyof TemplateEventPropsMap['TextInput']['onMatch']>>
|
|
183
184
|
/* Event of the TextInput not match regex (check every value change) */
|
|
184
|
-
onNotMatch?: Array<EventAction
|
|
185
|
+
onNotMatch?: Array<EventAction<string & keyof TemplateEventPropsMap['TextInput']['onNotMatch']>>
|
|
185
186
|
/* Event of the TextInput not match regex (check every submit) */
|
|
186
|
-
onResultNotMatch?: Array<
|
|
187
|
+
onResultNotMatch?: Array<
|
|
188
|
+
EventAction<string & keyof TemplateEventPropsMap['TextInput']['onResultNotMatch']>
|
|
189
|
+
>
|
|
187
190
|
/* Event of the TextInput reach max length or match regex */
|
|
188
191
|
onFullFill?: Array<EventAction>
|
|
189
192
|
}
|
package/types/bricks/Video.ts
CHANGED
|
@@ -15,6 +15,7 @@ import type {
|
|
|
15
15
|
EventProperty,
|
|
16
16
|
} from '../common'
|
|
17
17
|
import type { BrickBasicProperty, BrickBasicEvents, BrickBasicEventsForItem } from '../brick-base'
|
|
18
|
+
import type { TemplateEventPropsMap } from '../../utils/event-props'
|
|
18
19
|
|
|
19
20
|
/* Play the video */
|
|
20
21
|
export type BrickVideoActionPlay = Action & {
|
|
@@ -120,7 +121,7 @@ Default property:
|
|
|
120
121
|
/* Event of the brick blur (Use TV Device with controller) */
|
|
121
122
|
onBlur?: Array<EventAction>
|
|
122
123
|
/* Event of the next video on change start */
|
|
123
|
-
nextVideo?: Array<EventAction
|
|
124
|
+
nextVideo?: Array<EventAction<string & keyof TemplateEventPropsMap['Video']['nextVideo']>>
|
|
124
125
|
/* Event on plays of path are totally end */
|
|
125
126
|
roundEnd?: Array<EventAction>
|
|
126
127
|
/* Event on video load */
|
|
@@ -128,7 +129,7 @@ Default property:
|
|
|
128
129
|
/* Event of the video playing error */
|
|
129
130
|
onError?: Array<EventAction>
|
|
130
131
|
/* Event of the video progress interval */
|
|
131
|
-
onProgress?: Array<EventAction
|
|
132
|
+
onProgress?: Array<EventAction<string & keyof TemplateEventPropsMap['Video']['onProgress']>>
|
|
132
133
|
}
|
|
133
134
|
outlets?: {
|
|
134
135
|
/* Brick is pressing */
|
|
@@ -15,6 +15,7 @@ import type {
|
|
|
15
15
|
EventProperty,
|
|
16
16
|
} from '../common'
|
|
17
17
|
import type { BrickBasicProperty, BrickBasicEvents, BrickBasicEventsForItem } from '../brick-base'
|
|
18
|
+
import type { TemplateEventPropsMap } from '../../utils/event-props'
|
|
18
19
|
|
|
19
20
|
interface BrickVideoStreamingDef {
|
|
20
21
|
/*
|
|
@@ -15,6 +15,7 @@ import type {
|
|
|
15
15
|
EventProperty,
|
|
16
16
|
} from '../common'
|
|
17
17
|
import type { BrickBasicProperty, BrickBasicEvents, BrickBasicEventsForItem } from '../brick-base'
|
|
18
|
+
import type { TemplateEventPropsMap } from '../../utils/event-props'
|
|
18
19
|
|
|
19
20
|
interface BrickWebRTCStreamDef {
|
|
20
21
|
/*
|
package/types/bricks/WebView.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
/* Auto generated by build script
|
|
2
2
|
*
|
|
3
|
-
*
|
|
3
|
+
* Embedded web browser with JS injection, DOM query selectors, content cropping, navigation control, and permission management
|
|
4
4
|
*/
|
|
5
5
|
import type { SwitchCondInnerStateCurrentCanvas, SwitchCondData, SwitchDef } from '../switch'
|
|
6
6
|
import type { Data, DataLink } from '../data'
|
|
@@ -15,6 +15,7 @@ import type {
|
|
|
15
15
|
EventProperty,
|
|
16
16
|
} from '../common'
|
|
17
17
|
import type { BrickBasicProperty, BrickBasicEvents, BrickBasicEventsForItem } from '../brick-base'
|
|
18
|
+
import type { TemplateEventPropsMap } from '../../utils/event-props'
|
|
18
19
|
|
|
19
20
|
/* Run Javascript on the WebView */
|
|
20
21
|
export type BrickWebViewActionInjectJavascript = ActionWithParams & {
|
|
@@ -125,11 +126,11 @@ Default property:
|
|
|
125
126
|
}
|
|
126
127
|
events?: BrickBasicEvents & {
|
|
127
128
|
/* Event of the WebView on load */
|
|
128
|
-
onLoad?: Array<EventAction
|
|
129
|
+
onLoad?: Array<EventAction<string & keyof TemplateEventPropsMap['Webview']['onLoad']>>
|
|
129
130
|
/* Event when the WebView load fails */
|
|
130
|
-
onError?: Array<EventAction
|
|
131
|
+
onError?: Array<EventAction<string & keyof TemplateEventPropsMap['Webview']['onError']>>
|
|
131
132
|
/* Event of the webview on message by `window.ReactNativeWebView.postMessage` on you're injected javascript code */
|
|
132
|
-
onMessage?: Array<EventAction
|
|
133
|
+
onMessage?: Array<EventAction<string & keyof TemplateEventPropsMap['Webview']['onMessage']>>
|
|
133
134
|
}
|
|
134
135
|
outlets?: {
|
|
135
136
|
/* The result of the query selector action */
|
|
@@ -144,7 +145,7 @@ Default property:
|
|
|
144
145
|
}
|
|
145
146
|
}
|
|
146
147
|
|
|
147
|
-
/*
|
|
148
|
+
/* Embedded web browser with JS injection, DOM query selectors, content cropping, navigation control, and permission management */
|
|
148
149
|
export type BrickWebView = Brick &
|
|
149
150
|
BrickWebViewDef & {
|
|
150
151
|
templateKey: 'BRICK_WEBVIEW'
|
package/types/common.ts
CHANGED
|
@@ -47,34 +47,36 @@ export type Action = {
|
|
|
47
47
|
name?: string
|
|
48
48
|
}
|
|
49
49
|
|
|
50
|
-
//
|
|
50
|
+
// For standalone action types where specific event properties are not known
|
|
51
51
|
export type EventProperty = string
|
|
52
52
|
|
|
53
|
-
export type ActionWithParams = Action & {
|
|
53
|
+
export type ActionWithParams<EP extends string = string> = Action & {
|
|
54
54
|
params?: Array<{
|
|
55
55
|
input: string
|
|
56
|
-
value?: any |
|
|
56
|
+
value?: any | EP
|
|
57
57
|
mapping?: string
|
|
58
58
|
}>
|
|
59
59
|
}
|
|
60
60
|
|
|
61
|
-
export type ActionWithDataParams = Action & {
|
|
61
|
+
export type ActionWithDataParams<EP extends string = string> = Action & {
|
|
62
62
|
dataParams?: Array<{
|
|
63
63
|
input: () => Data
|
|
64
|
-
value?: any |
|
|
64
|
+
value?: any | EP
|
|
65
65
|
mapping?: string
|
|
66
66
|
}>
|
|
67
67
|
}
|
|
68
68
|
|
|
69
69
|
export type ItemBrickID = string
|
|
70
70
|
|
|
71
|
-
|
|
71
|
+
// EP carries available event property keys for this event context
|
|
72
|
+
// Use: EventAction<string & keyof TemplateEventPropsMap['Name']['event']>
|
|
73
|
+
export type EventAction<EP extends string = string> = {
|
|
72
74
|
handler: 'system' | (() => Brick | Generator) | SubspaceID | ItemBrickID
|
|
73
|
-
action: ActionWithParams | ActionWithDataParams
|
|
75
|
+
action: ActionWithParams<EP> | ActionWithDataParams<EP>
|
|
74
76
|
waitAsync?: boolean
|
|
75
77
|
}
|
|
76
78
|
|
|
77
|
-
export type EventActionForItem = {
|
|
79
|
+
export type EventActionForItem<EP extends string = string> = {
|
|
78
80
|
handler:
|
|
79
81
|
| 'system'
|
|
80
82
|
| (() => Brick | Generator | { brickId: string; templateKey: string })
|
|
@@ -13,6 +13,7 @@ import type {
|
|
|
13
13
|
Action,
|
|
14
14
|
EventProperty,
|
|
15
15
|
} from '../common'
|
|
16
|
+
import type { TemplateEventPropsMap } from '../../utils/event-props'
|
|
16
17
|
|
|
17
18
|
/* Start the alarm clock */
|
|
18
19
|
export type GeneratorAlarmClockActionStart = Action & {
|
|
@@ -64,13 +65,15 @@ Default property:
|
|
|
64
65
|
}
|
|
65
66
|
events?: {
|
|
66
67
|
/* Event for cron rule is not invalid */
|
|
67
|
-
onRuleInvalid?: Array<
|
|
68
|
+
onRuleInvalid?: Array<
|
|
69
|
+
EventAction<string & keyof TemplateEventPropsMap['AlarmClock']['onRuleInvalid']>
|
|
70
|
+
>
|
|
68
71
|
/* Event for alarm clock start */
|
|
69
|
-
onStart?: Array<EventAction
|
|
72
|
+
onStart?: Array<EventAction<string & keyof TemplateEventPropsMap['AlarmClock']['onStart']>>
|
|
70
73
|
/* Event for alarm clock trig */
|
|
71
|
-
onTrig?: Array<EventAction
|
|
74
|
+
onTrig?: Array<EventAction<string & keyof TemplateEventPropsMap['AlarmClock']['onTrig']>>
|
|
72
75
|
/* Event for alarm clock stop */
|
|
73
|
-
onEnd?: Array<EventAction
|
|
76
|
+
onEnd?: Array<EventAction<string & keyof TemplateEventPropsMap['AlarmClock']['onEnd']>>
|
|
74
77
|
}
|
|
75
78
|
outlets?: {
|
|
76
79
|
/* Current time of each alarm clock trig */
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
/* Auto generated by build script
|
|
2
2
|
*
|
|
3
|
-
* AI
|
|
3
|
+
* Conversational AI agent orchestrating LLM (GGML/MLX/OpenAI/QNN/ONNX/Anthropic/NeuroPilot), STT, TTS, MCP tool-use, and file search (RAG) with auto-summary
|
|
4
4
|
*/
|
|
5
5
|
import type { SwitchCondInnerStateCurrentCanvas, SwitchCondData, SwitchDef } from '../switch'
|
|
6
6
|
import type { Data, DataLink } from '../data'
|
|
@@ -13,6 +13,7 @@ import type {
|
|
|
13
13
|
Action,
|
|
14
14
|
EventProperty,
|
|
15
15
|
} from '../common'
|
|
16
|
+
import type { TemplateEventPropsMap } from '../../utils/event-props'
|
|
16
17
|
|
|
17
18
|
/* Add a message to the assistant */
|
|
18
19
|
export type GeneratorAssistantActionAddMessage = ActionWithParams & {
|
|
@@ -513,17 +514,19 @@ Default property:
|
|
|
513
514
|
}
|
|
514
515
|
events?: {
|
|
515
516
|
/* Error event */
|
|
516
|
-
onError?: Array<EventAction
|
|
517
|
+
onError?: Array<EventAction<string & keyof TemplateEventPropsMap['Assistant']['onError']>>
|
|
517
518
|
/* Log event */
|
|
518
|
-
onLogs?: Array<EventAction
|
|
519
|
+
onLogs?: Array<EventAction<string & keyof TemplateEventPropsMap['Assistant']['onLogs']>>
|
|
519
520
|
/* Messages update event */
|
|
520
|
-
onMessagesUpdate?: Array<
|
|
521
|
+
onMessagesUpdate?: Array<
|
|
522
|
+
EventAction<string & keyof TemplateEventPropsMap['Assistant']['onMessagesUpdate']>
|
|
523
|
+
>
|
|
521
524
|
/* Heatup finished event */
|
|
522
525
|
onHeatupFinished?: Array<EventAction>
|
|
523
526
|
/* Generating event (triggered when assistant starts generating response) */
|
|
524
527
|
onGenerating?: Array<EventAction>
|
|
525
528
|
/* Finished event (triggered when assistant finishes generating response) */
|
|
526
|
-
onFinished?: Array<EventAction
|
|
529
|
+
onFinished?: Array<EventAction<string & keyof TemplateEventPropsMap['Assistant']['onFinished']>>
|
|
527
530
|
}
|
|
528
531
|
outlets?: {
|
|
529
532
|
/* Whether the assistant is heating up */
|
|
@@ -588,7 +591,7 @@ Default property:
|
|
|
588
591
|
}
|
|
589
592
|
}
|
|
590
593
|
|
|
591
|
-
/* AI
|
|
594
|
+
/* Conversational AI agent orchestrating LLM (GGML/MLX/OpenAI/QNN/ONNX/Anthropic/NeuroPilot), STT, TTS, MCP tool-use, and file search (RAG) with auto-summary */
|
|
592
595
|
export type GeneratorAssistant = Generator &
|
|
593
596
|
GeneratorAssistantDef & {
|
|
594
597
|
templateKey: 'GENERATOR_ASSISTANT'
|
|
@@ -13,6 +13,7 @@ import type {
|
|
|
13
13
|
Action,
|
|
14
14
|
EventProperty,
|
|
15
15
|
} from '../common'
|
|
16
|
+
import type { TemplateEventPropsMap } from '../../utils/event-props'
|
|
16
17
|
|
|
17
18
|
/* Start scan */
|
|
18
19
|
export type GeneratorBleCentralActionStartScan = Action & {
|
|
@@ -181,21 +182,29 @@ Default property:
|
|
|
181
182
|
/* Event for state change */
|
|
182
183
|
onStateChange?: Array<EventAction>
|
|
183
184
|
/* Event for error occurred */
|
|
184
|
-
onError?: Array<EventAction
|
|
185
|
+
onError?: Array<EventAction<string & keyof TemplateEventPropsMap['BleCentral']['onError']>>
|
|
185
186
|
/* Event for start scan */
|
|
186
187
|
onStartScan?: Array<EventAction>
|
|
187
188
|
/* Event for stop scan */
|
|
188
189
|
onStopScan?: Array<EventAction>
|
|
189
190
|
/* Event for discover device */
|
|
190
|
-
onDiscoverDevice?: Array<
|
|
191
|
+
onDiscoverDevice?: Array<
|
|
192
|
+
EventAction<string & keyof TemplateEventPropsMap['BleCentral']['onDiscoverDevice']>
|
|
193
|
+
>
|
|
191
194
|
/* Event for device connected */
|
|
192
|
-
onConnectDevice?: Array<
|
|
195
|
+
onConnectDevice?: Array<
|
|
196
|
+
EventAction<string & keyof TemplateEventPropsMap['BleCentral']['onConnectDevice']>
|
|
197
|
+
>
|
|
193
198
|
/* Event for device disconnected */
|
|
194
199
|
onDisconnectDevice?: Array<EventAction>
|
|
195
200
|
/* Event for receive on read */
|
|
196
|
-
onReadReceive?: Array<
|
|
201
|
+
onReadReceive?: Array<
|
|
202
|
+
EventAction<string & keyof TemplateEventPropsMap['BleCentral']['onReadReceive']>
|
|
203
|
+
>
|
|
197
204
|
/* Event for receive on monitor */
|
|
198
|
-
onMonitorReceive?: Array<
|
|
205
|
+
onMonitorReceive?: Array<
|
|
206
|
+
EventAction<string & keyof TemplateEventPropsMap['BleCentral']['onMonitorReceive']>
|
|
207
|
+
>
|
|
199
208
|
}
|
|
200
209
|
outlets?: {
|
|
201
210
|
/* Is scaning */
|
|
@@ -13,6 +13,7 @@ import type {
|
|
|
13
13
|
Action,
|
|
14
14
|
EventProperty,
|
|
15
15
|
} from '../common'
|
|
16
|
+
import type { TemplateEventPropsMap } from '../../utils/event-props'
|
|
16
17
|
|
|
17
18
|
interface GeneratorCanvasMapDef {
|
|
18
19
|
/*
|
|
@@ -38,7 +39,7 @@ Default property:
|
|
|
38
39
|
}
|
|
39
40
|
events?: {
|
|
40
41
|
/* Event triggered when a rule matches and canvas navigation occurs */
|
|
41
|
-
onNavigate?: Array<EventAction
|
|
42
|
+
onNavigate?: Array<EventAction<string & keyof TemplateEventPropsMap['CanvasMap']['onNavigate']>>
|
|
42
43
|
}
|
|
43
44
|
outlets?: {
|
|
44
45
|
/* Last matched trigger rule that caused canvas navigation */
|
|
@@ -13,6 +13,7 @@ import type {
|
|
|
13
13
|
Action,
|
|
14
14
|
EventProperty,
|
|
15
15
|
} from '../common'
|
|
16
|
+
import type { TemplateEventPropsMap } from '../../utils/event-props'
|
|
16
17
|
|
|
17
18
|
/* Sale */
|
|
18
19
|
export type GeneratorCastlesPayActionSale = ActionWithParams & {
|
|
@@ -47,9 +48,13 @@ Default property:
|
|
|
47
48
|
property?: {}
|
|
48
49
|
events?: {
|
|
49
50
|
/* Action Success */
|
|
50
|
-
onActionSuccess?: Array<
|
|
51
|
+
onActionSuccess?: Array<
|
|
52
|
+
EventAction<string & keyof TemplateEventPropsMap['CastlesPay']['onActionSuccess']>
|
|
53
|
+
>
|
|
51
54
|
/* Action Error */
|
|
52
|
-
onActionError?: Array<
|
|
55
|
+
onActionError?: Array<
|
|
56
|
+
EventAction<string & keyof TemplateEventPropsMap['CastlesPay']['onActionError']>
|
|
57
|
+
>
|
|
53
58
|
}
|
|
54
59
|
outlets?: {
|
|
55
60
|
/* Last Transaction Result */
|