@dressed/react 1.8.4 → 1.8.5-canary.2

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 (53) hide show
  1. package/README.md +7 -11
  2. package/dist/components/action-row.d.ts +2 -4
  3. package/dist/components/action-row.js.map +1 -1
  4. package/dist/components/button.d.ts +4 -4
  5. package/dist/components/button.js +3 -3
  6. package/dist/components/button.js.map +1 -1
  7. package/dist/components/checkbox.d.ts +7 -0
  8. package/dist/components/checkbox.js +14 -0
  9. package/dist/components/checkbox.js.map +1 -0
  10. package/dist/components/container.d.ts +2 -6
  11. package/dist/components/container.js.map +1 -1
  12. package/dist/components/file-upload.d.ts +1 -1
  13. package/dist/components/file-upload.js +3 -3
  14. package/dist/components/file-upload.js.map +1 -1
  15. package/dist/components/label.d.ts +2 -6
  16. package/dist/components/label.js.map +1 -1
  17. package/dist/components/media-gallery.d.ts +2 -5
  18. package/dist/components/media-gallery.js.map +1 -1
  19. package/dist/components/radio-group.d.ts +6 -0
  20. package/dist/components/radio-group.js +14 -0
  21. package/dist/components/radio-group.js.map +1 -0
  22. package/dist/components/section.d.ts +2 -3
  23. package/dist/components/section.js.map +1 -1
  24. package/dist/components/select-menu.d.ts +5 -7
  25. package/dist/components/select-menu.js +7 -7
  26. package/dist/components/select-menu.js.map +1 -1
  27. package/dist/components/separator.d.ts +1 -1
  28. package/dist/components/separator.js +3 -3
  29. package/dist/components/separator.js.map +1 -1
  30. package/dist/components/text-display.d.ts +2 -6
  31. package/dist/components/text-display.js.map +1 -1
  32. package/dist/components/text-input.d.ts +1 -1
  33. package/dist/components/text-input.js +3 -3
  34. package/dist/components/text-input.js.map +1 -1
  35. package/dist/index.d.ts +4 -0
  36. package/dist/index.js +4 -0
  37. package/dist/index.js.map +1 -1
  38. package/dist/react/renderer.js +16 -18
  39. package/dist/react/renderer.js.map +1 -1
  40. package/dist/rendering/callbacks.js +2 -2
  41. package/dist/rendering/callbacks.js.map +1 -1
  42. package/dist/rendering/index.d.ts +5 -0
  43. package/dist/rendering/index.js +7 -1
  44. package/dist/rendering/index.js.map +1 -1
  45. package/dist/rendering/interaction.d.ts +1 -1
  46. package/dist/rendering/interaction.js +2 -1
  47. package/dist/rendering/interaction.js.map +1 -1
  48. package/dist/rendering/message.d.ts +2 -2
  49. package/dist/rendering/message.js.map +1 -1
  50. package/dist/rendering/reconstruct.d.ts +4 -0
  51. package/dist/rendering/reconstruct.js +48 -0
  52. package/dist/rendering/reconstruct.js.map +1 -0
  53. package/package.json +10 -12
package/README.md CHANGED
@@ -7,7 +7,7 @@ If you manually call the render function yourself, you can use the old component
7
7
  ## 📦 Install
8
8
 
9
9
  ```sh
10
- bun add dressed react @dressed/react
10
+ bun add react @dressed/react
11
11
  ```
12
12
 
13
13
  ## 🚀 Usage
@@ -19,7 +19,6 @@ import { patchInteraction, ActionRow, Button } from "@dressed/react";
19
19
 
20
20
  export default async function ping(interaction: CommandInteraction) {
21
21
  const patched = patchInteraction(interaction);
22
-
23
22
  await patched.reply(
24
23
  <>
25
24
  Pong!
@@ -34,22 +33,19 @@ export default async function ping(interaction: CommandInteraction) {
34
33
 
35
34
  If you don't want to manually patch every interaction, you can use middleware:
36
35
 
37
- ```ts
38
- // dressed.config.ts
36
+ ```ts title="dressed.config.ts"
39
37
  import { patchInteraction } from "@dressed/react";
40
- import type { ServerConfig } from "dressed/server";
38
+ import type { DressedConfig } from "dressed/server";
41
39
 
42
- const config: ServerConfig = {
40
+ export default {
43
41
  build: { extensions: ["tsx", "ts"] },
44
42
  middleware: {
45
43
  commands: (i) => [patchInteraction(i)],
46
44
  components: (i, a) => [patchInteraction(i), a],
47
45
  },
48
- };
49
-
50
- export default config;
46
+ } satisfies DressedConfig;
51
47
  ```
52
48
 
53
49
  > [!IMPORTANT]
54
- > In order for Dressed to bundle your tsx/jsx files, the extension must be added to the build config's extensions array\
55
- > e.g. `dressed build -E tsx,ts`
50
+ > In order for Dressed to bundle your tsx/jsx files, a glob containing them must be added to the build config's include array\
51
+ > e.g. `dressed build -I '**/*.{ts,tsx}'`
@@ -1,7 +1,5 @@
1
1
  import type { APIActionRowComponent, APIComponentInActionRow } from "discord-api-types/v10";
2
- import { type ReactElement, type ReactNode } from "react";
2
+ import { type PropsWithChildren, type ReactElement } from "react";
3
3
  import { type ComponentNode } from "../react/renderer.ts";
4
- export declare function ActionRow({ children, }: {
5
- children: ReactNode;
6
- }): ReactElement<APIActionRowComponent<APIComponentInActionRow>>;
4
+ export declare function ActionRow({ children, }: PropsWithChildren): ReactElement<APIActionRowComponent<APIComponentInActionRow>>;
7
5
  export declare function parseActionRow<T extends APIActionRowComponent<APIComponentInActionRow>>(props: T, children: ComponentNode[]): Promise<T>;
@@ -1 +1 @@
1
- {"version":3,"file":"action-row.js","sourceRoot":"","sources":["../../src/components/action-row.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,IAAI,gBAAgB,EAAE,MAAM,SAAS,CAAC;AACxD,OAAO,EAAE,aAAa,EAAqC,MAAM,OAAO,CAAC;AACzE,OAAO,EAAsB,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAErE,MAAM,UAAU,SAAS,CAAC,EACxB,QAAQ,GAGT;IACC,MAAM,KAAK,GAAG,gBAAgB,EAAE,CAAC;IACjC,OAAO,aAAa,CAAC,cAAc,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC;AACxD,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,cAAc,CAClC,KAAQ,EACR,QAAyB;IAEzB,OAAO,EAAE,GAAG,KAAK,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC;AAC9E,CAAC"}
1
+ {"version":3,"file":"action-row.js","sourceRoot":"","sources":["../../src/components/action-row.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,IAAI,gBAAgB,EAAE,MAAM,SAAS,CAAC;AACxD,OAAO,EAAE,aAAa,EAA6C,MAAM,OAAO,CAAC;AACjF,OAAO,EAAsB,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAErE,MAAM,UAAU,SAAS,CAAC,EACxB,QAAQ,GACU;IAClB,MAAM,KAAK,GAAG,gBAAgB,EAAE,CAAC;IACjC,OAAO,aAAa,CAAC,cAAc,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC;AACxD,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,cAAc,CAClC,KAAQ,EACR,QAAyB;IAEzB,OAAO,EAAE,GAAG,KAAK,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC;AAC9E,CAAC"}
@@ -13,9 +13,9 @@ interface ButtonWithOnClick extends Omit<ButtonWithCustomId, "custom_id"> {
13
13
  /** An additional handler identity defined in the callback setup which will run if the `onClick` is no longer registered */
14
14
  fallback?: string;
15
15
  }
16
- export declare function Button(props: ButtonWithCustomId): ReactElement<APIButtonComponentWithCustomId>;
17
- export declare function Button(props: ButtonWithOnClick): ReactElement<APIButtonComponentWithCustomId>;
18
- export declare function Button(props: Omit<APIButtonComponentWithSKUId, "type" | "style">): ReactElement<APIButtonComponentWithSKUId>;
19
- export declare function Button(props: Omit<APIButtonComponentWithURL, "type" | "style">): ReactElement<APIButtonComponentWithURL>;
16
+ export declare function Button(config: ButtonWithCustomId): ReactElement<APIButtonComponentWithCustomId>;
17
+ export declare function Button(config: ButtonWithOnClick): ReactElement<APIButtonComponentWithCustomId>;
18
+ export declare function Button(config: Omit<APIButtonComponentWithSKUId, "type" | "style">): ReactElement<APIButtonComponentWithSKUId>;
19
+ export declare function Button(config: Omit<APIButtonComponentWithURL, "type" | "style">): ReactElement<APIButtonComponentWithURL>;
20
20
  export declare function parseButton<T extends APIButtonComponent & (Pick<ButtonWithOnClick, "onClick" | "fallback"> | object)>(nodeId: string, props: T): Promise<T>;
21
21
  export {};
@@ -1,9 +1,9 @@
1
1
  import { Button as DressedComponent } from "dressed";
2
2
  import { createElement } from "react";
3
3
  import { registerHandler } from "../rendering/callbacks.js";
4
- export function Button(props) {
5
- const component = DressedComponent(props);
6
- return createElement("dressed-node", component);
4
+ export function Button(config) {
5
+ const props = DressedComponent(config);
6
+ return createElement("dressed-node", props);
7
7
  }
8
8
  export async function parseButton(nodeId, props) {
9
9
  return {
@@ -1 +1 @@
1
- {"version":3,"file":"button.js","sourceRoot":"","sources":["../../src/components/button.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,MAAM,IAAI,gBAAgB,EAAE,MAAM,SAAS,CAAC;AACrD,OAAO,EAAE,aAAa,EAAqB,MAAM,OAAO,CAAC;AACzD,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AA0B5D,MAAM,UAAU,MAAM,CACpB,KAIqD;IAErD,MAAM,SAAS,GAAG,gBAAgB,CAAC,KAAc,CAAC,CAAC;IACnD,OAAO,aAAa,CAAC,cAAc,EAAE,SAAS,CAAC,CAAC;AAClD,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,WAAW,CAE/B,MAAc,EAAE,KAAQ;IACxB,OAAO;QACL,GAAG,KAAK;QACR,GAAG,CAAC,SAAS,IAAI,KAAK,CAAC,CAAC,CAAC,eAAe,CAAC,MAAM,EAAE,KAAK,CAAC,OAAgB,EAAE,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;KACtG,CAAC;AACJ,CAAC"}
1
+ {"version":3,"file":"button.js","sourceRoot":"","sources":["../../src/components/button.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,MAAM,IAAI,gBAAgB,EAAE,MAAM,SAAS,CAAC;AACrD,OAAO,EAAE,aAAa,EAAqB,MAAM,OAAO,CAAC;AACzD,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AA0B5D,MAAM,UAAU,MAAM,CACpB,MAIqD;IAErD,MAAM,KAAK,GAAG,gBAAgB,CAAC,MAAe,CAAC,CAAC;IAChD,OAAO,aAAa,CAAC,cAAc,EAAE,KAAK,CAAC,CAAC;AAC9C,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,WAAW,CAE/B,MAAc,EAAE,KAAQ;IACxB,OAAO;QACL,GAAG,KAAK;QACR,GAAG,CAAC,SAAS,IAAI,KAAK,CAAC,CAAC,CAAC,eAAe,CAAC,MAAM,EAAE,KAAK,CAAC,OAAgB,EAAE,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;KACtG,CAAC;AACJ,CAAC"}
@@ -0,0 +1,7 @@
1
+ import type { APICheckboxComponent, APICheckboxGroupComponent, APICheckboxGroupOption } from "discord-api-types/v10";
2
+ import { type PropsWithChildren, type ReactElement } from "react";
3
+ import type { ComponentNode } from "../react/renderer.ts";
4
+ export declare function Checkbox(config: Omit<APICheckboxComponent, "type">): ReactElement<APICheckboxComponent>;
5
+ export declare function Checkbox(config: APICheckboxGroupOption): ReactElement<APICheckboxGroupOption>;
6
+ export declare function CheckboxGroup({ children, ...rest }: PropsWithChildren<Omit<APICheckboxGroupComponent, "options" | "type">>): ReactElement<APICheckboxGroupComponent>;
7
+ export declare function parseCheckboxGroup<T extends APICheckboxGroupComponent>(props: T, children: ComponentNode[]): Promise<T>;
@@ -0,0 +1,14 @@
1
+ import { Checkbox as DressedComponent, CheckboxGroup as DressedGroupComponent } from "dressed";
2
+ import { createElement } from "react";
3
+ export function Checkbox(config) {
4
+ const props = "label" in config ? DressedComponent(config.label, config.value, config) : DressedComponent(config);
5
+ return createElement("dressed-node", props);
6
+ }
7
+ export function CheckboxGroup({ children, ...rest }) {
8
+ const props = DressedGroupComponent(rest);
9
+ return createElement("dressed-node", props, children);
10
+ }
11
+ export async function parseCheckboxGroup(props, children) {
12
+ return { ...props, options: children.map((c) => c.props) };
13
+ }
14
+ //# sourceMappingURL=checkbox.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"checkbox.js","sourceRoot":"","sources":["../../src/components/checkbox.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,IAAI,gBAAgB,EAAE,aAAa,IAAI,qBAAqB,EAAE,MAAM,SAAS,CAAC;AAC/F,OAAO,EAAE,aAAa,EAA6C,MAAM,OAAO,CAAC;AAOjF,MAAM,UAAU,QAAQ,CACtB,MAAmE;IAEnE,MAAM,KAAK,GAAG,OAAO,IAAI,MAAM,CAAC,CAAC,CAAC,gBAAgB,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;IAClH,OAAO,aAAa,CAAC,cAAc,EAAE,KAAc,CAAC,CAAC;AACvD,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,EAC5B,QAAQ,EACR,GAAG,IAAI,EACgE;IACvE,MAAM,KAAK,GAAG,qBAAqB,CAAC,IAAa,CAAC,CAAC;IACnD,OAAO,aAAa,CAAC,cAAc,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC;AACxD,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,kBAAkB,CACtC,KAAQ,EACR,QAAyB;IAEzB,OAAO,EAAE,GAAG,KAAK,EAAE,OAAO,EAAE,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC;AAC7D,CAAC"}
@@ -1,9 +1,5 @@
1
1
  import type { APIContainerComponent } from "discord-api-types/v10";
2
- import { type ReactElement, type ReactNode } from "react";
2
+ import { type PropsWithChildren, type ReactElement } from "react";
3
3
  import { type ComponentNode } from "../react/renderer.ts";
4
- interface ContainerProps extends Omit<APIContainerComponent, "components" | "type"> {
5
- children: ReactNode;
6
- }
7
- export declare function Container({ children, ...rest }: ContainerProps): ReactElement<APIContainerComponent>;
4
+ export declare function Container({ children, ...rest }: PropsWithChildren<Omit<APIContainerComponent, "components" | "type">>): ReactElement<APIContainerComponent>;
8
5
  export declare function parseContainer<T extends APIContainerComponent>(props: T, children: ComponentNode[]): Promise<T>;
9
- export {};
@@ -1 +1 @@
1
- {"version":3,"file":"container.js","sourceRoot":"","sources":["../../src/components/container.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,IAAI,gBAAgB,EAAE,MAAM,SAAS,CAAC;AACxD,OAAO,EAAE,aAAa,EAAqC,MAAM,OAAO,CAAC;AACzE,OAAO,EAAsB,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAMrE,MAAM,UAAU,SAAS,CAAC,EAAE,QAAQ,EAAE,GAAG,IAAI,EAAkB;IAC7D,MAAM,KAAK,GAAG,gBAAgB,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;IACzC,OAAO,aAAa,CAAC,cAAc,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC;AACxD,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,cAAc,CAAkC,KAAQ,EAAE,QAAyB;IACvG,OAAO,EAAE,GAAG,KAAK,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC;AAC9E,CAAC"}
1
+ {"version":3,"file":"container.js","sourceRoot":"","sources":["../../src/components/container.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,IAAI,gBAAgB,EAAE,MAAM,SAAS,CAAC;AACxD,OAAO,EAAE,aAAa,EAA6C,MAAM,OAAO,CAAC;AACjF,OAAO,EAAsB,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAErE,MAAM,UAAU,SAAS,CAAC,EACxB,QAAQ,EACR,GAAG,IAAI,EAC+D;IACtE,MAAM,KAAK,GAAG,gBAAgB,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;IACzC,OAAO,aAAa,CAAC,cAAc,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC;AACxD,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,cAAc,CAAkC,KAAQ,EAAE,QAAyB;IACvG,OAAO,EAAE,GAAG,KAAK,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC;AAC9E,CAAC"}
@@ -1,3 +1,3 @@
1
1
  import type { APIFileUploadComponent } from "discord-api-types/v10";
2
2
  import { type ReactElement } from "react";
3
- export declare function FileUpload(props: Omit<APIFileUploadComponent, "type">): ReactElement<APIFileUploadComponent>;
3
+ export declare function FileUpload(config: Omit<APIFileUploadComponent, "type">): ReactElement<APIFileUploadComponent>;
@@ -1,7 +1,7 @@
1
1
  import { FileUpload as DressedComponent } from "dressed";
2
2
  import { createElement } from "react";
3
- export function FileUpload(props) {
4
- const component = DressedComponent(props);
5
- return createElement("dressed-node", component);
3
+ export function FileUpload(config) {
4
+ const props = DressedComponent(config);
5
+ return createElement("dressed-node", props);
6
6
  }
7
7
  //# sourceMappingURL=file-upload.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"file-upload.js","sourceRoot":"","sources":["../../src/components/file-upload.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,IAAI,gBAAgB,EAAE,MAAM,SAAS,CAAC;AACzD,OAAO,EAAE,aAAa,EAAqB,MAAM,OAAO,CAAC;AAEzD,MAAM,UAAU,UAAU,CAAC,KAA2C;IACpE,MAAM,SAAS,GAAG,gBAAgB,CAAC,KAAK,CAAC,CAAC;IAC1C,OAAO,aAAa,CAAC,cAAc,EAAE,SAAS,CAAC,CAAC;AAClD,CAAC"}
1
+ {"version":3,"file":"file-upload.js","sourceRoot":"","sources":["../../src/components/file-upload.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,IAAI,gBAAgB,EAAE,MAAM,SAAS,CAAC;AACzD,OAAO,EAAE,aAAa,EAAqB,MAAM,OAAO,CAAC;AAEzD,MAAM,UAAU,UAAU,CAAC,MAA4C;IACrE,MAAM,KAAK,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAC;IACvC,OAAO,aAAa,CAAC,cAAc,EAAE,KAAK,CAAC,CAAC;AAC9C,CAAC"}
@@ -1,9 +1,5 @@
1
1
  import type { APILabelComponent } from "discord-api-types/v10";
2
- import { type ReactElement, type ReactNode } from "react";
2
+ import { type PropsWithChildren, type ReactElement } from "react";
3
3
  import { type ComponentNode } from "../react/renderer.ts";
4
- interface LabelProps extends Omit<APILabelComponent, "component" | "type"> {
5
- children: ReactNode;
6
- }
7
- export declare function Label({ label, description, children, ...rest }: LabelProps): ReactElement<APILabelComponent>;
4
+ export declare function Label({ label, description, children, ...rest }: PropsWithChildren<Omit<APILabelComponent, "component" | "type">>): ReactElement<APILabelComponent>;
8
5
  export declare function parseLabel<T extends APILabelComponent>(props: T, children: ComponentNode[]): Promise<T>;
9
- export {};
@@ -1 +1 @@
1
- {"version":3,"file":"label.js","sourceRoot":"","sources":["../../src/components/label.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,IAAI,gBAAgB,EAAE,MAAM,SAAS,CAAC;AACpD,OAAO,EAAE,aAAa,EAAqC,MAAM,OAAO,CAAC;AACzE,OAAO,EAAsB,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAMrE,MAAM,UAAU,KAAK,CAAC,EAAE,KAAK,EAAE,WAAW,EAAE,QAAQ,EAAE,GAAG,IAAI,EAAc;IACzE,MAAM,KAAK,GAAG,gBAAgB,CAAC,KAAK,EAAE,IAAa,EAAE,WAAW,EAAE,IAAI,CAAC,CAAC;IACxE,OAAO,aAAa,CAAC,cAAc,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC;AACxD,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,UAAU,CAA8B,KAAQ,EAAE,QAAyB;IAC/F,OAAO;QACL,GAAG,KAAK;QACR,SAAS,EAAE,CAAC,MAAM,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;KAC3D,CAAC;AACJ,CAAC"}
1
+ {"version":3,"file":"label.js","sourceRoot":"","sources":["../../src/components/label.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,IAAI,gBAAgB,EAAE,MAAM,SAAS,CAAC;AACpD,OAAO,EAAE,aAAa,EAA6C,MAAM,OAAO,CAAC;AACjF,OAAO,EAAsB,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAErE,MAAM,UAAU,KAAK,CAAC,EACpB,KAAK,EACL,WAAW,EACX,QAAQ,EACR,GAAG,IAAI,EAC0D;IACjE,MAAM,KAAK,GAAG,gBAAgB,CAAC,KAAK,EAAE,IAAa,EAAE,WAAW,EAAE,IAAI,CAAC,CAAC;IACxE,OAAO,aAAa,CAAC,cAAc,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC;AACxD,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,UAAU,CAA8B,KAAQ,EAAE,QAAyB;IAC/F,OAAO;QACL,GAAG,KAAK;QACR,SAAS,EAAE,CAAC,MAAM,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;KAC3D,CAAC;AACJ,CAAC"}
@@ -1,10 +1,7 @@
1
1
  import type { APIMediaGalleryComponent, APIMediaGalleryItem } from "discord-api-types/v10";
2
- import { type ReactNode } from "react";
2
+ import { type PropsWithChildren } from "react";
3
3
  import type { Node } from "../react/node.ts";
4
- interface MediaGalleryProps extends Omit<APIMediaGalleryComponent, "items" | "type"> {
5
- children: ReactNode;
6
- }
7
- export declare function MediaGallery({ children, ...rest }: MediaGalleryProps): import("react").ReactElement<APIMediaGalleryComponent, string | import("react").JSXElementConstructor<any>>;
4
+ export declare function MediaGallery({ children, ...rest }: PropsWithChildren<Omit<APIMediaGalleryComponent, "items" | "type">>): import("react").ReactElement<APIMediaGalleryComponent, string | import("react").JSXElementConstructor<any>>;
8
5
  interface ItemProps extends Omit<APIMediaGalleryItem, "media" | "type"> {
9
6
  media: APIMediaGalleryItem["media"] | string;
10
7
  }
@@ -1 +1 @@
1
- {"version":3,"file":"media-gallery.js","sourceRoot":"","sources":["../../src/components/media-gallery.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,IAAI,gBAAgB,EAAE,gBAAgB,IAAI,WAAW,EAAE,MAAM,SAAS,CAAC;AAC5F,OAAO,EAAE,aAAa,EAAkB,MAAM,OAAO,CAAC;AAOtD,MAAM,UAAU,YAAY,CAAC,EAAE,QAAQ,EAAE,GAAG,IAAI,EAAqB;IACnE,MAAM,KAAK,GAAG,gBAAgB,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;IACzC,OAAO,aAAa,CAAC,cAAc,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC;AACxD,CAAC;AAMD,MAAM,UAAU,gBAAgB,CAAC,EAAE,KAAK,EAAE,GAAG,IAAI,EAAa;IAC5D,MAAM,KAAK,GAAG,WAAW,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;IACvC,OAAO,aAAa,CAAC,cAAc,EAAE,KAAK,CAAC,CAAC;AAC9C,CAAC;AAED,MAAM,UAAU,iBAAiB,CAC/B,KAAQ,EACR,QAAqC;IAErC,OAAO,EAAE,GAAG,KAAK,EAAE,KAAK,EAAE,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC;AAC3D,CAAC"}
1
+ {"version":3,"file":"media-gallery.js","sourceRoot":"","sources":["../../src/components/media-gallery.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,IAAI,gBAAgB,EAAE,gBAAgB,IAAI,WAAW,EAAE,MAAM,SAAS,CAAC;AAC5F,OAAO,EAAE,aAAa,EAA0B,MAAM,OAAO,CAAC;AAG9D,MAAM,UAAU,YAAY,CAAC,EAC3B,QAAQ,EACR,GAAG,IAAI,EAC6D;IACpE,MAAM,KAAK,GAAG,gBAAgB,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;IACzC,OAAO,aAAa,CAAC,cAAc,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC;AACxD,CAAC;AAMD,MAAM,UAAU,gBAAgB,CAAC,EAAE,KAAK,EAAE,GAAG,IAAI,EAAa;IAC5D,MAAM,KAAK,GAAG,WAAW,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;IACvC,OAAO,aAAa,CAAC,cAAc,EAAE,KAAK,CAAC,CAAC;AAC9C,CAAC;AAED,MAAM,UAAU,iBAAiB,CAC/B,KAAQ,EACR,QAAqC;IAErC,OAAO,EAAE,GAAG,KAAK,EAAE,KAAK,EAAE,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC;AAC3D,CAAC"}
@@ -0,0 +1,6 @@
1
+ import type { APIRadioGroupComponent, APIRadioGroupOption } from "discord-api-types/v10";
2
+ import { type PropsWithChildren, type ReactElement } from "react";
3
+ import type { ComponentNode } from "../react/renderer.ts";
4
+ export declare function RadioGroup({ children, ...rest }: PropsWithChildren<Omit<APIRadioGroupComponent, "options" | "type">>): ReactElement<APIRadioGroupComponent>;
5
+ export declare function RadioGroupOption({ label, value, ...rest }: APIRadioGroupOption): ReactElement<APIRadioGroupOption>;
6
+ export declare function parseRadioGroup<T extends APIRadioGroupComponent>(props: T, children: ComponentNode[]): Promise<T>;
@@ -0,0 +1,14 @@
1
+ import { RadioGroup as DressedComponent, RadioGroupOption as DressedOption } from "dressed";
2
+ import { createElement } from "react";
3
+ export function RadioGroup({ children, ...rest }) {
4
+ const props = DressedComponent(rest);
5
+ return createElement("dressed-node", props, children);
6
+ }
7
+ export function RadioGroupOption({ label, value, ...rest }) {
8
+ const props = DressedOption(label, value, rest);
9
+ return createElement("dressed-node", props);
10
+ }
11
+ export async function parseRadioGroup(props, children) {
12
+ return { ...props, options: children.map((c) => c.props) };
13
+ }
14
+ //# sourceMappingURL=radio-group.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"radio-group.js","sourceRoot":"","sources":["../../src/components/radio-group.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,IAAI,gBAAgB,EAAE,gBAAgB,IAAI,aAAa,EAAE,MAAM,SAAS,CAAC;AAC5F,OAAO,EAAE,aAAa,EAA6C,MAAM,OAAO,CAAC;AAGjF,MAAM,UAAU,UAAU,CAAC,EACzB,QAAQ,EACR,GAAG,IAAI,EAC6D;IACpE,MAAM,KAAK,GAAG,gBAAgB,CAAC,IAAa,CAAC,CAAC;IAC9C,OAAO,aAAa,CAAC,cAAc,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC;AACxD,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,IAAI,EAAuB;IAC7E,MAAM,KAAK,GAAG,aAAa,CAAC,KAAK,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;IAChD,OAAO,aAAa,CAAC,cAAc,EAAE,KAAK,CAAC,CAAC;AAC9C,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,eAAe,CACnC,KAAQ,EACR,QAAyB;IAEzB,OAAO,EAAE,GAAG,KAAK,EAAE,OAAO,EAAE,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC;AAC7D,CAAC"}
@@ -1,10 +1,9 @@
1
1
  import type { APISectionComponent } from "discord-api-types/v10";
2
- import { type ReactElement, type ReactNode } from "react";
2
+ import { type PropsWithChildren, type ReactElement, type ReactNode } from "react";
3
3
  import { type ComponentNode } from "../react/renderer.ts";
4
4
  interface SectionProps extends Omit<APISectionComponent, "accessory" | "components" | "type"> {
5
- children: ReactNode;
6
5
  accessory: ReactNode;
7
6
  }
8
- export declare function Section({ children, accessory, ...rest }: SectionProps): ReactElement<APISectionComponent>;
7
+ export declare function Section({ children, accessory, ...rest }: PropsWithChildren<SectionProps>): ReactElement<APISectionComponent>;
9
8
  export declare function parseSection<T extends APISectionComponent>(props: T, children: ComponentNode[]): Promise<T>;
10
9
  export {};
@@ -1 +1 @@
1
- {"version":3,"file":"section.js","sourceRoot":"","sources":["../../src/components/section.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,IAAI,gBAAgB,EAAE,MAAM,SAAS,CAAC;AACtD,OAAO,EAAE,aAAa,EAAqC,MAAM,OAAO,CAAC;AACzE,OAAO,EAAsB,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAOrE,MAAM,UAAU,OAAO,CAAC,EAAE,QAAQ,EAAE,SAAS,EAAE,GAAG,IAAI,EAAgB;IACpE,MAAM,KAAK,GAAG,gBAAgB,CAAC,EAAE,EAAE,IAAa,EAAE,IAAI,CAAC,CAAC;IACxD,OAAO,aAAa,CAAC,cAAc,EAAE,KAAK,EAAE,SAAS,EAAE,QAAQ,CAAC,CAAC;AACnE,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,YAAY,CAAgC,KAAQ,EAAE,QAAyB;IACnG,MAAM,CAAC,SAAS,EAAE,GAAG,UAAU,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC;IAC9E,OAAO,EAAE,GAAG,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,CAAC;AAC7C,CAAC"}
1
+ {"version":3,"file":"section.js","sourceRoot":"","sources":["../../src/components/section.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,IAAI,gBAAgB,EAAE,MAAM,SAAS,CAAC;AACtD,OAAO,EAAE,aAAa,EAA6D,MAAM,OAAO,CAAC;AACjG,OAAO,EAAsB,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAMrE,MAAM,UAAU,OAAO,CAAC,EACtB,QAAQ,EACR,SAAS,EACT,GAAG,IAAI,EACyB;IAChC,MAAM,KAAK,GAAG,gBAAgB,CAAC,EAAE,EAAE,IAAa,EAAE,IAAI,CAAC,CAAC;IACxD,OAAO,aAAa,CAAC,cAAc,EAAE,KAAK,EAAE,SAAS,EAAE,QAAQ,CAAC,CAAC;AACnE,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,YAAY,CAAgC,KAAQ,EAAE,QAAyB;IACnG,MAAM,CAAC,SAAS,EAAE,GAAG,UAAU,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC;IAC9E,OAAO,EAAE,GAAG,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,CAAC;AAC7C,CAAC"}
@@ -1,5 +1,5 @@
1
1
  import { type APISelectMenuComponent, type APISelectMenuOption, ComponentType } from "discord-api-types/v10";
2
- import { type ReactElement, type ReactNode } from "react";
2
+ import { type PropsWithChildren, type ReactElement } from "react";
3
3
  import type { Node } from "../react/node.ts";
4
4
  import type { MessageComponentInteraction } from "../rendering/interaction.ts";
5
5
  type SelectType = "Channel" | "Mentionable" | "Role" | "String" | "User";
@@ -10,9 +10,7 @@ type SelectMap = {
10
10
  };
11
11
  type SelectMenuWithCustomId<K extends SelectType> = Omit<SelectMap[`${K}Select`], "type" | "options"> & {
12
12
  type: K;
13
- } & (K extends "String" ? {
14
- children: ReactNode;
15
- } : object);
13
+ } & (K extends "String" ? PropsWithChildren : object);
16
14
  type SelectMenuWithOnClick<K extends SelectType> = Omit<SelectMenuWithCustomId<K>, "custom_id"> & {
17
15
  /**
18
16
  * Create a temporary handler callback, will not work in a serverless environment
@@ -22,12 +20,12 @@ type SelectMenuWithOnClick<K extends SelectType> = Omit<SelectMenuWithCustomId<K
22
20
  /** An additional handler identity defined in the callback setup which will run if the `onSubmit` is no longer registered */
23
21
  fallback?: string;
24
22
  };
25
- export declare function SelectMenu<K extends SelectType>(props: SelectMenuWithCustomId<K> & {
23
+ export declare function SelectMenu<K extends SelectType>(config: SelectMenuWithCustomId<K> & {
26
24
  type: K;
27
25
  }): ReactElement<SelectMap[`${K}Select`]>;
28
- export declare function SelectMenu<K extends SelectType>(props: SelectMenuWithOnClick<K> & {
26
+ export declare function SelectMenu<K extends SelectType>(config: SelectMenuWithOnClick<K> & {
29
27
  type: K;
30
28
  }): ReactElement<SelectMap[`${K}Select`]>;
31
- export declare function SelectMenuOption(props: APISelectMenuOption): ReactElement<APISelectMenuOption>;
29
+ export declare function SelectMenuOption({ label, value, ...rest }: APISelectMenuOption): ReactElement<APISelectMenuOption>;
32
30
  export declare function parseSelectMenu<T extends APISelectMenuComponent & (Pick<SelectMenuWithOnClick<SelectType>, "onSubmit" | "fallback"> | object)>(nodeId: string, props: T, children: Node<APISelectMenuOption>[]): T;
33
31
  export {};
@@ -2,14 +2,14 @@ import { ComponentType } from "discord-api-types/v10";
2
2
  import { SelectMenu as DressedComponent, SelectMenuOption as DressedOption } from "dressed";
3
3
  import { createElement } from "react";
4
4
  import { registerHandler } from "../rendering/callbacks.js";
5
- export function SelectMenu(props) {
6
- const { children, ...rest } = props;
7
- const component = DressedComponent(rest);
8
- return createElement("dressed-node", component, children);
5
+ export function SelectMenu(config) {
6
+ const { children, ...rest } = config;
7
+ const props = DressedComponent(rest);
8
+ return createElement("dressed-node", props, children);
9
9
  }
10
- export function SelectMenuOption(props) {
11
- const component = DressedOption(props.label, props.value, props);
12
- return createElement("dressed-node", component);
10
+ export function SelectMenuOption({ label, value, ...rest }) {
11
+ const props = DressedOption(label, value, rest);
12
+ return createElement("dressed-node", props);
13
13
  }
14
14
  export function parseSelectMenu(nodeId, props, children) {
15
15
  if (props.type === ComponentType.StringSelect) {
@@ -1 +1 @@
1
- {"version":3,"file":"select-menu.js","sourceRoot":"","sources":["../../src/components/select-menu.ts"],"names":[],"mappings":"AAAA,OAAO,EAAyD,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAC7G,OAAO,EAAE,UAAU,IAAI,gBAAgB,EAAE,gBAAgB,IAAI,aAAa,EAAE,MAAM,SAAS,CAAC;AAC5F,OAAO,EAAE,aAAa,EAAqC,MAAM,OAAO,CAAC;AAEzE,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AA8B5D,MAAM,UAAU,UAAU,CACxB,KAA2D;IAE3D,MAAM,EAAE,QAAQ,EAAE,GAAG,IAAI,EAAE,GAAG,KAAgC,CAAC;IAC/D,MAAM,SAAS,GAAG,gBAAgB,CAAC,IAAa,CAAC,CAAC;IAClD,OAAO,aAAa,CAAC,cAAc,EAAE,SAAkB,EAAE,QAAqB,CAAC,CAAC;AAClF,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,KAA0B;IACzD,MAAM,SAAS,GAAG,aAAa,CAAC,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IACjE,OAAO,aAAa,CAAC,cAAc,EAAE,SAAS,CAAC,CAAC;AAClD,CAAC;AAED,MAAM,UAAU,eAAe,CAE7B,MAAc,EAAE,KAAQ,EAAE,QAAqC;IAC/D,IAAI,KAAK,CAAC,IAAI,KAAK,aAAa,CAAC,YAAY,EAAE,CAAC;QAC9C,KAAK,CAAC,OAAO,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;IAC/C,CAAC;IACD,OAAO;QACL,GAAG,KAAK;QACR,GAAG,CAAC,UAAU,IAAI,KAAK,CAAC,CAAC,CAAC,eAAe,CAAC,MAAM,EAAE,KAAK,CAAC,QAAiB,EAAE,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;KACxG,CAAC;AACJ,CAAC"}
1
+ {"version":3,"file":"select-menu.js","sourceRoot":"","sources":["../../src/components/select-menu.ts"],"names":[],"mappings":"AAAA,OAAO,EAAyD,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAC7G,OAAO,EAAE,UAAU,IAAI,gBAAgB,EAAE,gBAAgB,IAAI,aAAa,EAAE,MAAM,SAAS,CAAC;AAC5F,OAAO,EAAE,aAAa,EAA6D,MAAM,OAAO,CAAC;AAEjG,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AA8B5D,MAAM,UAAU,UAAU,CACxB,MAA4D;IAE5D,MAAM,EAAE,QAAQ,EAAE,GAAG,IAAI,EAAE,GAAG,MAAiC,CAAC;IAChE,MAAM,KAAK,GAAG,gBAAgB,CAAC,IAAa,CAAC,CAAC;IAC9C,OAAO,aAAa,CAAC,cAAc,EAAE,KAAc,EAAE,QAAqB,CAAC,CAAC;AAC9E,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,IAAI,EAAuB;IAC7E,MAAM,KAAK,GAAG,aAAa,CAAC,KAAK,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;IAChD,OAAO,aAAa,CAAC,cAAc,EAAE,KAAK,CAAC,CAAC;AAC9C,CAAC;AAED,MAAM,UAAU,eAAe,CAE7B,MAAc,EAAE,KAAQ,EAAE,QAAqC;IAC/D,IAAI,KAAK,CAAC,IAAI,KAAK,aAAa,CAAC,YAAY,EAAE,CAAC;QAC9C,KAAK,CAAC,OAAO,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;IAC/C,CAAC;IACD,OAAO;QACL,GAAG,KAAK;QACR,GAAG,CAAC,UAAU,IAAI,KAAK,CAAC,CAAC,CAAC,eAAe,CAAC,MAAM,EAAE,KAAK,CAAC,QAAiB,EAAE,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;KACxG,CAAC;AACJ,CAAC"}
@@ -3,5 +3,5 @@ import { type ReactElement } from "react";
3
3
  interface SeparatorProps extends Omit<APISeparatorComponent, "type" | "spacing"> {
4
4
  spacing?: keyof typeof SeparatorSpacingSize;
5
5
  }
6
- export declare function Separator({ spacing, ...props }: SeparatorProps): ReactElement<APISeparatorComponent>;
6
+ export declare function Separator(config: SeparatorProps): ReactElement<APISeparatorComponent>;
7
7
  export {};
@@ -1,7 +1,7 @@
1
1
  import { Separator as DressedComponent } from "dressed";
2
2
  import { createElement } from "react";
3
- export function Separator({ spacing, ...props }) {
4
- const component = DressedComponent({ spacing, ...props });
5
- return createElement("dressed-node", component);
3
+ export function Separator(config) {
4
+ const props = DressedComponent(config);
5
+ return createElement("dressed-node", props);
6
6
  }
7
7
  //# sourceMappingURL=separator.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"separator.js","sourceRoot":"","sources":["../../src/components/separator.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,IAAI,gBAAgB,EAAE,MAAM,SAAS,CAAC;AACxD,OAAO,EAAE,aAAa,EAAqB,MAAM,OAAO,CAAC;AAMzD,MAAM,UAAU,SAAS,CAAC,EAAE,OAAO,EAAE,GAAG,KAAK,EAAkB;IAC7D,MAAM,SAAS,GAAG,gBAAgB,CAAC,EAAE,OAAO,EAAE,GAAG,KAAK,EAAE,CAAC,CAAC;IAC1D,OAAO,aAAa,CAAC,cAAc,EAAE,SAAS,CAAC,CAAC;AAClD,CAAC"}
1
+ {"version":3,"file":"separator.js","sourceRoot":"","sources":["../../src/components/separator.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,IAAI,gBAAgB,EAAE,MAAM,SAAS,CAAC;AACxD,OAAO,EAAE,aAAa,EAAqB,MAAM,OAAO,CAAC;AAMzD,MAAM,UAAU,SAAS,CAAC,MAAsB;IAC9C,MAAM,KAAK,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAC;IACvC,OAAO,aAAa,CAAC,cAAc,EAAE,KAAK,CAAC,CAAC;AAC9C,CAAC"}
@@ -1,8 +1,4 @@
1
1
  import type { APITextDisplayComponent } from "discord-api-types/v10";
2
- import { type ReactElement, type ReactNode } from "react";
3
- interface TextDisplayProps extends Omit<APITextDisplayComponent, "content" | "type"> {
4
- children: ReactNode;
5
- }
6
- export declare function TextDisplay({ children, ...rest }: TextDisplayProps): ReactElement<APITextDisplayComponent>;
2
+ import { type PropsWithChildren, type ReactElement } from "react";
3
+ export declare function TextDisplay({ children, ...rest }: PropsWithChildren<Omit<APITextDisplayComponent, "content" | "type">>): ReactElement<APITextDisplayComponent>;
7
4
  export declare function parseTextDisplay<T extends APITextDisplayComponent>(props: T, children: string): T;
8
- export {};
@@ -1 +1 @@
1
- {"version":3,"file":"text-display.js","sourceRoot":"","sources":["../../src/components/text-display.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,IAAI,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAC1D,OAAO,EAAE,aAAa,EAAqC,MAAM,OAAO,CAAC;AAMzE,MAAM,UAAU,WAAW,CAAC,EAAE,QAAQ,EAAE,GAAG,IAAI,EAAoB;IACjE,MAAM,KAAK,GAAG,gBAAgB,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;IACzC,OAAO,aAAa,CAAC,cAAc,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC;AACxD,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAoC,KAAQ,EAAE,QAAgB;IAC5F,OAAO,EAAE,GAAG,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAC;AACzC,CAAC"}
1
+ {"version":3,"file":"text-display.js","sourceRoot":"","sources":["../../src/components/text-display.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,IAAI,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAC1D,OAAO,EAAE,aAAa,EAA6C,MAAM,OAAO,CAAC;AAEjF,MAAM,UAAU,WAAW,CAAC,EAC1B,QAAQ,EACR,GAAG,IAAI,EAC8D;IACrE,MAAM,KAAK,GAAG,gBAAgB,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;IACzC,OAAO,aAAa,CAAC,cAAc,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC;AACxD,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAoC,KAAQ,EAAE,QAAgB;IAC5F,OAAO,EAAE,GAAG,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAC;AACzC,CAAC"}
@@ -3,5 +3,5 @@ import { type ReactElement } from "react";
3
3
  interface TextInputProps extends Omit<APITextInputComponent, "type" | "style"> {
4
4
  style?: keyof typeof TextInputStyle;
5
5
  }
6
- export declare function TextInput({ style, ...props }: TextInputProps): ReactElement<APITextInputComponent>;
6
+ export declare function TextInput(config: TextInputProps): ReactElement<APITextInputComponent>;
7
7
  export {};
@@ -1,7 +1,7 @@
1
1
  import { TextInput as DressedComponent } from "dressed";
2
2
  import { createElement } from "react";
3
- export function TextInput({ style, ...props }) {
4
- const component = DressedComponent({ style, ...props });
5
- return createElement("dressed-node", component);
3
+ export function TextInput(config) {
4
+ const props = DressedComponent(config);
5
+ return createElement("dressed-node", props);
6
6
  }
7
7
  //# sourceMappingURL=text-input.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"text-input.js","sourceRoot":"","sources":["../../src/components/text-input.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,IAAI,gBAAgB,EAAE,MAAM,SAAS,CAAC;AACxD,OAAO,EAAE,aAAa,EAAqB,MAAM,OAAO,CAAC;AAMzD,MAAM,UAAU,SAAS,CAAC,EAAE,KAAK,EAAE,GAAG,KAAK,EAAkB;IAC3D,MAAM,SAAS,GAAG,gBAAgB,CAAC,EAAE,KAAK,EAAE,GAAG,KAAK,EAAE,CAAC,CAAC;IACxD,OAAO,aAAa,CAAC,cAAc,EAAE,SAAS,CAAC,CAAC;AAClD,CAAC"}
1
+ {"version":3,"file":"text-input.js","sourceRoot":"","sources":["../../src/components/text-input.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,IAAI,gBAAgB,EAAE,MAAM,SAAS,CAAC;AACxD,OAAO,EAAE,aAAa,EAAqB,MAAM,OAAO,CAAC;AAMzD,MAAM,UAAU,SAAS,CAAC,MAAsB;IAC9C,MAAM,KAAK,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAC;IACvC,OAAO,aAAa,CAAC,cAAc,EAAE,KAAK,CAAC,CAAC;AAC9C,CAAC"}
package/dist/index.d.ts CHANGED
@@ -1,9 +1,12 @@
1
1
  export { ActionRow } from "./components/action-row.ts";
2
2
  export { Button } from "./components/button.ts";
3
+ export { Checkbox, CheckboxGroup } from "./components/checkbox.ts";
3
4
  export { Container } from "./components/container.ts";
4
5
  export { File } from "./components/file.ts";
6
+ export { FileUpload } from "./components/file-upload.ts";
5
7
  export { Label } from "./components/label.ts";
6
8
  export { MediaGallery, MediaGalleryItem } from "./components/media-gallery.ts";
9
+ export { RadioGroup, RadioGroupOption } from "./components/radio-group.ts";
7
10
  export { Section } from "./components/section.ts";
8
11
  export { SelectMenu, SelectMenuOption } from "./components/select-menu.ts";
9
12
  export { Separator } from "./components/separator.ts";
@@ -14,3 +17,4 @@ export * from "./react/reconciler.ts";
14
17
  export * from "./rendering/index.ts";
15
18
  export * from "./rendering/interaction.ts";
16
19
  export * from "./rendering/message.ts";
20
+ export * from "./rendering/reconstruct.ts";
package/dist/index.js CHANGED
@@ -1,10 +1,13 @@
1
1
  // Components
2
2
  export { ActionRow } from "./components/action-row.js";
3
3
  export { Button } from "./components/button.js";
4
+ export { Checkbox, CheckboxGroup } from "./components/checkbox.js";
4
5
  export { Container } from "./components/container.js";
5
6
  export { File } from "./components/file.js";
7
+ export { FileUpload } from "./components/file-upload.js";
6
8
  export { Label } from "./components/label.js";
7
9
  export { MediaGallery, MediaGalleryItem } from "./components/media-gallery.js";
10
+ export { RadioGroup, RadioGroupOption } from "./components/radio-group.js";
8
11
  export { Section } from "./components/section.js";
9
12
  export { SelectMenu, SelectMenuOption } from "./components/select-menu.js";
10
13
  export { Separator } from "./components/separator.js";
@@ -16,4 +19,5 @@ export * from "./react/reconciler.js";
16
19
  export * from "./rendering/index.js";
17
20
  export * from "./rendering/interaction.js";
18
21
  export * from "./rendering/message.js";
22
+ export * from "./rendering/reconstruct.js";
19
23
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,aAAa;AACb,OAAO,EAAE,SAAS,EAAE,MAAM,4BAA4B,CAAC;AACvD,OAAO,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAChD,OAAO,EAAE,SAAS,EAAE,MAAM,2BAA2B,CAAC;AACtD,OAAO,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAC;AAC5C,OAAO,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAC9C,OAAO,EAAE,YAAY,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AAC/E,OAAO,EAAE,OAAO,EAAE,MAAM,yBAAyB,CAAC;AAClD,OAAO,EAAE,UAAU,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAC;AAC3E,OAAO,EAAE,SAAS,EAAE,MAAM,2BAA2B,CAAC;AACtD,OAAO,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAC;AAC3D,OAAO,EAAE,SAAS,EAAE,MAAM,4BAA4B,CAAC;AACvD,OAAO,EAAE,SAAS,EAAE,MAAM,2BAA2B,CAAC;AAEtD,YAAY;AACZ,cAAc,uBAAuB,CAAC;AACtC,cAAc,sBAAsB,CAAC;AACrC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,wBAAwB,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,aAAa;AACb,OAAO,EAAE,SAAS,EAAE,MAAM,4BAA4B,CAAC;AACvD,OAAO,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAChD,OAAO,EAAE,QAAQ,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AACnE,OAAO,EAAE,SAAS,EAAE,MAAM,2BAA2B,CAAC;AACtD,OAAO,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAC;AAC5C,OAAO,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AACzD,OAAO,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAC9C,OAAO,EAAE,YAAY,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AAC/E,OAAO,EAAE,UAAU,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAC;AAC3E,OAAO,EAAE,OAAO,EAAE,MAAM,yBAAyB,CAAC;AAClD,OAAO,EAAE,UAAU,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAC;AAC3E,OAAO,EAAE,SAAS,EAAE,MAAM,2BAA2B,CAAC;AACtD,OAAO,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAC;AAC3D,OAAO,EAAE,SAAS,EAAE,MAAM,4BAA4B,CAAC;AACvD,OAAO,EAAE,SAAS,EAAE,MAAM,2BAA2B,CAAC;AAEtD,YAAY;AACZ,cAAc,uBAAuB,CAAC;AACtC,cAAc,sBAAsB,CAAC;AACrC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,wBAAwB,CAAC;AACvC,cAAc,4BAA4B,CAAC"}
@@ -3,9 +3,11 @@ import { ComponentType, } from "discord-api-types/v10";
3
3
  import { TextDisplay } from "dressed";
4
4
  import { parseActionRow } from "../components/action-row.js";
5
5
  import { parseButton } from "../components/button.js";
6
+ import { parseCheckboxGroup } from "../components/checkbox.js";
6
7
  import { parseContainer } from "../components/container.js";
7
8
  import { parseLabel } from "../components/label.js";
8
9
  import { parseMediaGallery } from "../components/media-gallery.js";
10
+ import { parseRadioGroup } from "../components/radio-group.js";
9
11
  import { parseSection } from "../components/section.js";
10
12
  import { parseSelectMenu } from "../components/select-menu.js";
11
13
  import { parseTextDisplay } from "../components/text-display.js";
@@ -51,41 +53,37 @@ export function createRenderer(callback) {
51
53
  }
52
54
  export async function parseNode(node) {
53
55
  switch (node.props.type) {
54
- case ComponentType.ActionRow: {
56
+ case ComponentType.ActionRow:
55
57
  return parseActionRow(node.props, node.children);
56
- }
57
- case ComponentType.Button: {
58
+ case ComponentType.Button:
58
59
  return parseButton(node.id, node.props);
59
- }
60
60
  case ComponentType.StringSelect:
61
61
  case ComponentType.UserSelect:
62
62
  case ComponentType.RoleSelect:
63
63
  case ComponentType.MentionableSelect:
64
- case ComponentType.ChannelSelect: {
64
+ case ComponentType.ChannelSelect:
65
65
  return parseSelectMenu(node.id, node.props, node.children);
66
- }
67
66
  case ComponentType.TextInput:
68
67
  case ComponentType.Thumbnail:
69
68
  case ComponentType.File:
70
69
  case ComponentType.Separator:
71
- case ComponentType.FileUpload: {
70
+ case ComponentType.FileUpload:
71
+ case ComponentType.Checkbox:
72
72
  return node.props;
73
- }
74
- case ComponentType.Section: {
73
+ case ComponentType.Section:
75
74
  return parseSection(node.props, node.children);
76
- }
77
- case ComponentType.TextDisplay: {
75
+ case ComponentType.TextDisplay:
78
76
  return parseTextDisplay(node.props, node.text());
79
- }
80
- case ComponentType.MediaGallery: {
77
+ case ComponentType.MediaGallery:
81
78
  return parseMediaGallery(node.props, node.children);
82
- }
83
- case ComponentType.Container: {
79
+ case ComponentType.Container:
84
80
  return parseContainer(node.props, node.children);
85
- }
86
- case ComponentType.Label: {
81
+ case ComponentType.Label:
87
82
  return parseLabel(node.props, node.children);
88
- }
83
+ case ComponentType.RadioGroup:
84
+ return parseRadioGroup(node.props, node.children);
85
+ case ComponentType.CheckboxGroup:
86
+ return parseCheckboxGroup(node.props, node.children);
89
87
  default: {
90
88
  if (typeof node.props === "string") {
91
89
  return TextDisplay(node.text());
@@ -1 +1 @@
1
- {"version":3,"file":"renderer.js","sourceRoot":"","sources":["../../src/react/renderer.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"renderer.js","sourceRoot":"","sources":["../../src/react/renderer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AACzC,OAAO,EAKL,aAAa,GACd,MAAM,uBAAuB,CAAC;AAC/B,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AACtC,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AACtD,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;AAC/D,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAC5D,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACpD,OAAO,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;AACnE,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAC/D,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AACxD,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAC/D,OAAO,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AAEjE,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAShD,SAAS,cAAc,CAAI,KAAgB;IACzC,MAAM,MAAM,GAAG,EAAE,CAAC;IAClB,IAAI,OAAO,GAAG,EAAE,CAAC;IAEjB,SAAS,QAAQ;QACf,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;YACnB,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC;YACrC,OAAO,GAAG,EAAE,CAAC;QACf,CAAC;IACH,CAAC;IAED,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;QACzB,IAAI,OAAO,IAAI,CAAC,KAAK,KAAK,QAAQ,EAAE,CAAC;YACnC,OAAO,IAAI,IAAI,CAAC,KAAK,CAAC;QACxB,CAAC;aAAM,CAAC;YACN,QAAQ,EAAE,CAAC;YACX,MAAM,CAAC,IAAI,CAAC,EAAE,GAAG,IAAI,EAAE,QAAQ,EAAE,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;QACpE,CAAC;IACH,CAAC;IAED,QAAQ,EAAE,CAAC;IACX,OAAO,MAAM,CAAC;AAChB,CAAC;AAID,MAAM,UAAU,cAAc,CAAC,QAA0B;IACvD,IAAI,QAAQ,GAAG,EAAE,CAAC;IAClB,MAAM,QAAQ,GAAa;QACzB,KAAK,EAAE,EAAE;QACT,KAAK,CAAC,MAAM;YACV,MAAM,UAAU,GAAG,EAAE,CAAC;YACtB,KAAK,MAAM,IAAI,IAAI,cAAc,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC;gBAClD,UAAU,CAAC,IAAI,CAAC,MAAM,SAAS,CAAC,IAAqB,CAAC,CAAC,CAAC;YAC1D,CAAC;YACD,MAAM,IAAI,GAAG,UAAU,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YACnF,IAAI,IAAI,KAAK,QAAQ;gBAAE,OAAO;YAC9B,QAAQ,GAAG,IAAI,CAAC;YAChB,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAG,UAAU,CAAC,CAAC;QACzB,CAAC;KACF,CAAC;IAEF,OAAO,QAAQ,CAAC;AAClB,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,SAAS,CAAC,IAAmB;IACjD,QAAQ,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;QACxB,KAAK,aAAa,CAAC,SAAS;YAC1B,OAAO,cAAc,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;QACnD,KAAK,aAAa,CAAC,MAAM;YACvB,OAAO,WAAW,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1C,KAAK,aAAa,CAAC,YAAY,CAAC;QAChC,KAAK,aAAa,CAAC,UAAU,CAAC;QAC9B,KAAK,aAAa,CAAC,UAAU,CAAC;QAC9B,KAAK,aAAa,CAAC,iBAAiB,CAAC;QACrC,KAAK,aAAa,CAAC,aAAa;YAC9B,OAAO,eAAe,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,QAAuC,CAAC,CAAC;QAC5F,KAAK,aAAa,CAAC,SAAS,CAAC;QAC7B,KAAK,aAAa,CAAC,SAAS,CAAC;QAC7B,KAAK,aAAa,CAAC,IAAI,CAAC;QACxB,KAAK,aAAa,CAAC,SAAS,CAAC;QAC7B,KAAK,aAAa,CAAC,UAAU,CAAC;QAC9B,KAAK,aAAa,CAAC,QAAQ;YACzB,OAAO,IAAI,CAAC,KAAK,CAAC;QACpB,KAAK,aAAa,CAAC,OAAO;YACxB,OAAO,YAAY,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;QACjD,KAAK,aAAa,CAAC,WAAW;YAC5B,OAAO,gBAAgB,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;QACnD,KAAK,aAAa,CAAC,YAAY;YAC7B,OAAO,iBAAiB,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,QAAuC,CAAC,CAAC;QACrF,KAAK,aAAa,CAAC,SAAS;YAC1B,OAAO,cAAc,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;QACnD,KAAK,aAAa,CAAC,KAAK;YACtB,OAAO,UAAU,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC/C,KAAK,aAAa,CAAC,UAAU;YAC3B,OAAO,eAAe,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;QACpD,KAAK,aAAa,CAAC,aAAa;YAC9B,OAAO,kBAAkB,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;QACvD,OAAO,CAAC,CAAC,CAAC;YACR,IAAI,OAAO,IAAI,CAAC,KAAK,KAAK,QAAQ,EAAE,CAAC;gBACnC,OAAO,WAAW,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;YAClC,CAAC;YACD,MAAM,IAAI,KAAK,CAAC,cAAc,CAAC,CAAC;QAClC,CAAC;IACH,CAAC;AACH,CAAC"}
@@ -22,9 +22,9 @@ export function createCallbackHandler(fallbacks = {}) {
22
22
  });
23
23
  }
24
24
  export function registerHandler(id, handler, fallback) {
25
- var _a;
25
+ var _a, _b, _c;
26
26
  clearTimeout((_a = handlers.get(id)) === null || _a === void 0 ? void 0 : _a.$handlerCleaner);
27
- handlers.set(id, Object.assign(handler, { $handlerCleaner: setTimeout(() => handlers.delete(id), 6e4 * 30).unref() }));
27
+ handlers.set(id, Object.assign(handler, { $handlerCleaner: (_c = (_b = setTimeout(() => handlers.delete(id), 6e4 * 30)).unref) === null || _c === void 0 ? void 0 : _c.call(_b) }));
28
28
  const fbText = fallback ? `-${fallback}` : "";
29
29
  return { custom_id: `@dressed/react-handler-${id}${fbText}` };
30
30
  }
@@ -1 +1 @@
1
- {"version":3,"file":"callbacks.js","sourceRoot":"","sources":["../../src/rendering/callbacks.ts"],"names":[],"mappings":"AAAA,OAAO,EAAiE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AAInH,MAAM,CAAC,MAAM,QAAQ,GAAG,IAAI,GAAG,EAA0D,CAAC;AAE1F,wEAAwE;AACxE,MAAM,CAAC,MAAM,OAAO,GAAG,+CAA+C,CAAC;AAEvE,4DAA4D;AAC5D,mEAAmE;AACnE,MAAM,UAAU,qBAAqB,CAAyC,YAAe,EAAO;IAClG,KAAK,MAAM,GAAG,IAAI,SAAS;QAAE,QAAQ,CAAC,GAAG,CAAC,GAAG,EAAE,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC;IAC/D,OAAO,MAAM,CAAC,MAAM,CAClB,KAAK,EACH,WAAiE,EACjE,IAA8C,EAC9C,EAAE;;QACF,MAAM,OAAO,GAAG,MAAA,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,mCAAI,QAAQ,CAAC,GAAG,CAAC,MAAA,IAAI,CAAC,QAAQ,mCAAI,SAAS,CAAC,CAAC;QACzF,mBAAmB;QACnB,WAAW,GAAG,WAAW,CAAC,QAAQ,KAAK,MAAM,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,gBAAgB,CAAC,WAAW,CAAC,CAAC;QAClH,IAAI,CAAC,OAAO;YAAE,MAAM,IAAI,KAAK,CAAC,yDAAyD,CAAC,CAAC;QACzF,MAAM,OAAO,CAAC,WAAoB,CAAC,CAAC;QACpC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,MAAM;YAAE,WAAW,CAAC,WAAW,EAAE,CAAC;IAC7D,CAAC,EACD;QACE,SAAS,EAAE,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAEtE;KACF,CACF,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,EAAU,EAAE,OAAgB,EAAE,QAAiB;;IAC7E,YAAY,CAAC,MAAA,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC,0CAAE,eAAe,CAAC,CAAC;IAChD,QAAQ,CAAC,GAAG,CACV,EAAE,EACF,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,EAAE,eAAe,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CACrG,CAAC;IACF,MAAM,MAAM,GAAG,QAAQ,CAAC,CAAC,CAAC,IAAI,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;IAC9C,OAAO,EAAE,SAAS,EAAE,0BAA0B,EAAE,GAAG,MAAM,EAAE,EAAE,CAAC;AAChE,CAAC"}
1
+ {"version":3,"file":"callbacks.js","sourceRoot":"","sources":["../../src/rendering/callbacks.ts"],"names":[],"mappings":"AAAA,OAAO,EAAiE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AAInH,MAAM,CAAC,MAAM,QAAQ,GAAG,IAAI,GAAG,EAA0D,CAAC;AAE1F,wEAAwE;AACxE,MAAM,CAAC,MAAM,OAAO,GAAG,+CAA+C,CAAC;AAEvE,4DAA4D;AAC5D,mEAAmE;AACnE,MAAM,UAAU,qBAAqB,CAAyC,YAAe,EAAO;IAClG,KAAK,MAAM,GAAG,IAAI,SAAS;QAAE,QAAQ,CAAC,GAAG,CAAC,GAAG,EAAE,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC;IAC/D,OAAO,MAAM,CAAC,MAAM,CAClB,KAAK,EACH,WAAiE,EACjE,IAA8C,EAC9C,EAAE;;QACF,MAAM,OAAO,GAAG,MAAA,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,mCAAI,QAAQ,CAAC,GAAG,CAAC,MAAA,IAAI,CAAC,QAAQ,mCAAI,SAAS,CAAC,CAAC;QACzF,mBAAmB;QACnB,WAAW,GAAG,WAAW,CAAC,QAAQ,KAAK,MAAM,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,gBAAgB,CAAC,WAAW,CAAC,CAAC;QAClH,IAAI,CAAC,OAAO;YAAE,MAAM,IAAI,KAAK,CAAC,yDAAyD,CAAC,CAAC;QACzF,MAAM,OAAO,CAAC,WAAoB,CAAC,CAAC;QACpC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,MAAM;YAAE,WAAW,CAAC,WAAW,EAAE,CAAC;IAC7D,CAAC,EACD;QACE,SAAS,EAAE,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAEtE;KACF,CACF,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,EAAU,EAAE,OAAgB,EAAE,QAAiB;;IAC7E,YAAY,CAAC,MAAA,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC,0CAAE,eAAe,CAAC,CAAC;IAChD,QAAQ,CAAC,GAAG,CACV,EAAE,EACF,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,EAAE,eAAe,EAAE,MAAA,MAAA,UAAU,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC,EAAC,KAAK,kDAAI,EAAE,CAAC,CACvG,CAAC;IACF,MAAM,MAAM,GAAG,QAAQ,CAAC,CAAC,CAAC,IAAI,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;IAC9C,OAAO,EAAE,SAAS,EAAE,0BAA0B,EAAE,GAAG,MAAM,EAAE,EAAE,CAAC;AAChE,CAAC"}
@@ -1,5 +1,10 @@
1
1
  import type { ReactNode } from "react";
2
2
  import { type RendererCallback } from "../react/renderer.ts";
3
+ /**
4
+ * Renders a component tree.
5
+ * @param children The components to render
6
+ * @param callback A function called each time the React process updates the components
7
+ */
3
8
  export declare function render(children: ReactNode, callback: RendererCallback): {
4
9
  renderer: import("../react/renderer.ts").Renderer;
5
10
  container: any;
@@ -1,8 +1,14 @@
1
+ import { logger } from "dressed/utils";
1
2
  import { reconciler } from "../react/reconciler.js";
2
3
  import { createRenderer } from "../react/renderer.js";
4
+ /**
5
+ * Renders a component tree.
6
+ * @param children The components to render
7
+ * @param callback A function called each time the React process updates the components
8
+ */
3
9
  export function render(children, callback) {
4
10
  const renderer = createRenderer(callback);
5
- const container = reconciler.createContainer(renderer, 0, null, false, null, "dressed", (error) => console.error(error), () => { }, () => { }, () => { }, null);
11
+ const container = reconciler.createContainer(renderer, 0, null, false, null, "dressed", logger.error, () => { }, () => { }, () => { });
6
12
  if (container !== null)
7
13
  reconciler.updateContainer(children, container);
8
14
  return { renderer, container };
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/rendering/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACpD,OAAO,EAAE,cAAc,EAAyB,MAAM,sBAAsB,CAAC;AAE7E,MAAM,UAAU,MAAM,CAAC,QAAmB,EAAE,QAA0B;IACpE,MAAM,QAAQ,GAAG,cAAc,CAAC,QAAQ,CAAC,CAAC;IAE1C,MAAM,SAAS,GAAG,UAAU,CAAC,eAAe,CAC1C,QAAQ,EACR,CAAC,EACD,IAAI,EACJ,KAAK,EACL,IAAI,EACJ,SAAS,EACT,CAAC,KAAY,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,EACtC,GAAG,EAAE,GAAE,CAAC,EACR,GAAG,EAAE,GAAE,CAAC,EACR,GAAG,EAAE,GAAE,CAAC,EACR,IAAI,CACL,CAAC;IAEF,IAAI,SAAS,KAAK,IAAI;QAAE,UAAU,CAAC,eAAe,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;IAExE,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;AACjC,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/rendering/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvC,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACpD,OAAO,EAAE,cAAc,EAAyB,MAAM,sBAAsB,CAAC;AAE7E;;;;GAIG;AACH,MAAM,UAAU,MAAM,CAAC,QAAmB,EAAE,QAA0B;IACpE,MAAM,QAAQ,GAAG,cAAc,CAAC,QAAQ,CAAC,CAAC;IAE1C,MAAM,SAAS,GAAG,UAAU,CAAC,eAAe,CAC1C,QAAQ,EACR,CAAC,EACD,IAAI,EACJ,KAAK,EACL,IAAI,EACJ,SAAS,EACT,MAAM,CAAC,KAAK,EACZ,GAAG,EAAE,GAAE,CAAC,EACR,GAAG,EAAE,GAAE,CAAC,EACR,GAAG,EAAE,GAAE,CAAC,CACT,CAAC;IAEF,IAAI,SAAS,KAAK,IAAI;QAAE,UAAU,CAAC,eAAe,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;IAExE,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;AACjC,CAAC"}
@@ -7,7 +7,7 @@ type ReactivatedInteraction<T> = OverrideMethodParams<T, {
7
7
  [K in "reply" | "editReply" | "update" | "followUp" | "showModal"]: [
8
8
  components: ReactNode,
9
9
  ...(Parameters<T[K]> extends readonly [...infer P] ? [
10
- data?: Omit<Exclude<P[0], string>, "content" | "components">,
10
+ data?: Omit<Exclude<P[0], string>, "content" | "components" | "embeds">,
11
11
  $req?: P[1] & {
12
12
  /**
13
13
  * Do not set the contents of your response to `null` after 15 minutes (when Discord deletes the original interaction) in order to conserve resources.
@@ -30,6 +30,7 @@ export function patchInteraction(interaction, parent) {
30
30
  return editWebhookMessage(interaction.application_id, interaction.token, followUpId, data, undefined, $req);
31
31
  }
32
32
  return new Promise((resolve) => {
33
+ var _a, _b;
33
34
  const { container } = render(parent ? createElement(parent, null, components) : components, async (c) => {
34
35
  if (c.length === 0 || Date.now() > createdAt + 6e4 * 15)
35
36
  return;
@@ -53,7 +54,7 @@ export function patchInteraction(interaction, parent) {
53
54
  resolve(Object.assign(res !== null && res !== void 0 ? res : {}, { $container: container }));
54
55
  });
55
56
  if (!($req === null || $req === void 0 ? void 0 : $req.persistContainer)) {
56
- setTimeout(() => reconciler.updateContainer(null, container), createdAt + 6e4 * 15 - Date.now()).unref();
57
+ (_b = (_a = setTimeout(() => reconciler.updateContainer(null, container), createdAt + 6e4 * 15 - Date.now())).unref) === null || _b === void 0 ? void 0 : _b.call(_a);
57
58
  }
58
59
  });
59
60
  };
@@ -1 +1 @@
1
- {"version":3,"file":"interaction.js","sourceRoot":"","sources":["../../src/rendering/interaction.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"interaction.js","sourceRoot":"","sources":["../../src/rendering/interaction.ts"],"names":[],"mappings":"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"}
@@ -17,9 +17,9 @@ export type WithContainer<T> = T & {
17
17
  * Renders the provided children and posts a message to a guild text or DM channel with the `IsComponentsV2` flag.
18
18
  * @example createMessage(channelId, <Button label="Foo" />)
19
19
  */
20
- export declare function createMessage(channelId: Snowflake, components: ReactNode, data?: Omit<Exclude<Parameters<typeof dressedCreateMessage>[1], string>, "content" | "components">, $req?: CallConfig): Promise<WithContainer<APIMessage>>;
20
+ export declare function createMessage(channelId: Snowflake, components: ReactNode, data?: Omit<Exclude<Parameters<typeof dressedCreateMessage>[1], string>, "content" | "components" | "embeds">, $req?: CallConfig): Promise<WithContainer<APIMessage>>;
21
21
  /**
22
22
  * Renders the provided children and edits a previously sent message.
23
23
  * @example editMessage(channelId, messageId, <Button label="Bar" />)
24
24
  */
25
- export declare function editMessage(channelId: Snowflake, messageId: Snowflake, components: ReactNode, data?: Omit<Exclude<Parameters<typeof dressedEditMessage>[2], string>, "content" | "components">, $req?: CallConfig): Promise<WithContainer<APIMessage>>;
25
+ export declare function editMessage(channelId: Snowflake, messageId: Snowflake, components: ReactNode, data?: Omit<Exclude<Parameters<typeof dressedEditMessage>[2], string>, "content" | "components" | "embeds">, $req?: CallConfig): Promise<WithContainer<APIMessage>>;
@@ -1 +1 @@
1
- {"version":3,"file":"message.js","sourceRoot":"","sources":["../../src/rendering/message.ts"],"names":[],"mappings":"AAAA,OAAO,EAAmB,YAAY,EAAkB,MAAM,uBAAuB,CAAC;AACtF,OAAO,EAAE,aAAa,IAAI,oBAAoB,EAAE,WAAW,IAAI,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAInG,OAAO,EAAE,MAAM,EAAE,MAAM,YAAY,CAAC;AAapC;;;GAGG;AACH,MAAM,UAAU,aAAa,CAC3B,SAAoB,EACpB,UAAqB,EACrB,OAAoG,EAAE,EACtG,IAAiB;;IAEjB,IAAI,CAAC,KAAK,GAAG,CAAC,MAAA,IAAI,CAAC,KAAK,mCAAI,CAAC,CAAC,GAAG,YAAY,CAAC,cAAc,CAAC;IAE7D,IAAI,SAAiC,CAAC;IACtC,IAAI,WAAW,GAAG,KAAK,CAAC;IAExB,SAAS,IAAI;QACX,IAAI,CAAC,SAAS;YAAE,OAAO;QACvB,OAAO,kBAAkB,CAAC,SAAS,EAAE,SAAS,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;IAC9D,CAAC;IAED,OAAO,IAAI,OAAO,CAA4B,CAAC,OAAO,EAAE,EAAE;QACxD,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC,UAAU,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;YACnD,IAAI,CAAC,CAAC,MAAM,KAAK,CAAC;gBAAE,OAAO;YAC3B,mBAAmB;YACnB,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;YACpB,IAAI,SAAS;gBAAE,OAAO,IAAI,EAAE,CAAC;YAC7B,IAAI,SAAS,KAAK,CAAC,EAAE,CAAC;gBACpB,WAAW,GAAG,IAAI,CAAC;gBACnB,OAAO;YACT,CAAC;YACD,SAAS,GAAG,CAAC,CAAC;YACd,MAAM,OAAO,GAAG,MAAM,oBAAoB,CAAC,SAAS,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;YAClE,SAAS,GAAG,OAAO,CAAC,EAAE,CAAC;YACvB,IAAI,WAAW;gBAAE,IAAI,EAAE,CAAC;YACxB,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,EAAE,UAAU,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC;QAC7D,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,WAAW,CACzB,SAAoB,EACpB,SAAoB,EACpB,UAAqB,EACrB,OAAkG,EAAE,EACpG,IAAiB;;IAEjB,IAAI,CAAC,KAAK,GAAG,CAAC,MAAA,IAAI,CAAC,KAAK,mCAAI,CAAC,CAAC,GAAG,YAAY,CAAC,cAAc,CAAC;IAE7D,OAAO,IAAI,OAAO,CAA4B,CAAC,OAAO,EAAE,EAAE;QACxD,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC,UAAU,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;YACnD,IAAI,CAAC,CAAC,MAAM,KAAK,CAAC;gBAAE,OAAO;YAC3B,mBAAmB;YACnB,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;YACpB,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,kBAAkB,CAAC,SAAS,EAAE,SAAS,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,EAAE,UAAU,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC;QAChH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC"}
1
+ {"version":3,"file":"message.js","sourceRoot":"","sources":["../../src/rendering/message.ts"],"names":[],"mappings":"AAAA,OAAO,EAAmB,YAAY,EAAkB,MAAM,uBAAuB,CAAC;AACtF,OAAO,EAAE,aAAa,IAAI,oBAAoB,EAAE,WAAW,IAAI,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAInG,OAAO,EAAE,MAAM,EAAE,MAAM,YAAY,CAAC;AAapC;;;GAGG;AACH,MAAM,UAAU,aAAa,CAC3B,SAAoB,EACpB,UAAqB,EACrB,OAA+G,EAAE,EACjH,IAAiB;;IAEjB,IAAI,CAAC,KAAK,GAAG,CAAC,MAAA,IAAI,CAAC,KAAK,mCAAI,CAAC,CAAC,GAAG,YAAY,CAAC,cAAc,CAAC;IAE7D,IAAI,SAAiC,CAAC;IACtC,IAAI,WAAW,GAAG,KAAK,CAAC;IAExB,SAAS,IAAI;QACX,IAAI,CAAC,SAAS;YAAE,OAAO;QACvB,OAAO,kBAAkB,CAAC,SAAS,EAAE,SAAS,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;IAC9D,CAAC;IAED,OAAO,IAAI,OAAO,CAA4B,CAAC,OAAO,EAAE,EAAE;QACxD,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC,UAAU,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;YACnD,IAAI,CAAC,CAAC,MAAM,KAAK,CAAC;gBAAE,OAAO;YAC3B,mBAAmB;YACnB,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;YACpB,IAAI,SAAS;gBAAE,OAAO,IAAI,EAAE,CAAC;YAC7B,IAAI,SAAS,KAAK,CAAC,EAAE,CAAC;gBACpB,WAAW,GAAG,IAAI,CAAC;gBACnB,OAAO;YACT,CAAC;YACD,SAAS,GAAG,CAAC,CAAC;YACd,MAAM,OAAO,GAAG,MAAM,oBAAoB,CAAC,SAAS,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;YAClE,SAAS,GAAG,OAAO,CAAC,EAAE,CAAC;YACvB,IAAI,WAAW;gBAAE,IAAI,EAAE,CAAC;YACxB,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,EAAE,UAAU,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC;QAC7D,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,WAAW,CACzB,SAAoB,EACpB,SAAoB,EACpB,UAAqB,EACrB,OAA6G,EAAE,EAC/G,IAAiB;;IAEjB,IAAI,CAAC,KAAK,GAAG,CAAC,MAAA,IAAI,CAAC,KAAK,mCAAI,CAAC,CAAC,GAAG,YAAY,CAAC,cAAc,CAAC;IAE7D,OAAO,IAAI,OAAO,CAA4B,CAAC,OAAO,EAAE,EAAE;QACxD,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC,UAAU,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;YACnD,IAAI,CAAC,CAAC,MAAM,KAAK,CAAC;gBAAE,OAAO;YAC3B,mBAAmB;YACnB,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;YACpB,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,kBAAkB,CAAC,SAAS,EAAE,SAAS,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,EAAE,UAAU,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC;QAChH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,4 @@
1
+ import { type APIMessageComponent, type APIModalComponent } from "discord-api-types/v10";
2
+ import { type ReactElement } from "react";
3
+ /** Turns the JSON form of components into React elements to be rendered */
4
+ export declare function reconstructElementTree(components: (APIMessageComponent | APIModalComponent)[]): ReactElement[];
@@ -0,0 +1,48 @@
1
+ import { ComponentType } from "discord-api-types/v10";
2
+ import { createElement } from "react";
3
+ /** Turns the JSON form of components into React elements to be rendered */
4
+ export function reconstructElementTree(components) {
5
+ return components.map((component) => {
6
+ let args;
7
+ switch (component.type) {
8
+ case ComponentType.ActionRow:
9
+ case ComponentType.Container:
10
+ args = [component, reconstructElementTree(component.components)];
11
+ break;
12
+ case ComponentType.Button:
13
+ case ComponentType.StringSelect:
14
+ case ComponentType.TextInput:
15
+ case ComponentType.UserSelect:
16
+ case ComponentType.RoleSelect:
17
+ case ComponentType.MentionableSelect:
18
+ case ComponentType.ChannelSelect:
19
+ case ComponentType.Thumbnail:
20
+ case ComponentType.File:
21
+ case ComponentType.Separator:
22
+ case ComponentType.FileUpload:
23
+ case ComponentType.Checkbox:
24
+ args = [component];
25
+ break;
26
+ case ComponentType.Section:
27
+ args = [component, reconstructElementTree([component.accessory]), reconstructElementTree(component.components)];
28
+ break;
29
+ case ComponentType.TextDisplay:
30
+ args = [component, component.content];
31
+ break;
32
+ case ComponentType.MediaGallery:
33
+ args = [component, component.items.map((i) => createElement("dressed-node", i))];
34
+ break;
35
+ case ComponentType.Label:
36
+ args = [component, reconstructElementTree([component.component])];
37
+ break;
38
+ case ComponentType.RadioGroup:
39
+ case ComponentType.CheckboxGroup:
40
+ args = [component, component.options.map((o) => createElement("dressed-node", o))];
41
+ break;
42
+ default:
43
+ args = [null];
44
+ }
45
+ return createElement("dressed-node", ...args);
46
+ });
47
+ }
48
+ //# sourceMappingURL=reconstruct.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"reconstruct.js","sourceRoot":"","sources":["../../src/rendering/reconstruct.ts"],"names":[],"mappings":"AAAA,OAAO,EAAoD,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACxG,OAAO,EAAE,aAAa,EAAqC,MAAM,OAAO,CAAC;AAEzE,2EAA2E;AAC3E,MAAM,UAAU,sBAAsB,CAAC,UAAuD;IAC5F,OAAO,UAAU,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE;QAClC,IAAI,IAAqC,CAAC;QAE1C,QAAQ,SAAS,CAAC,IAAI,EAAE,CAAC;YACvB,KAAK,aAAa,CAAC,SAAS,CAAC;YAC7B,KAAK,aAAa,CAAC,SAAS;gBAC1B,IAAI,GAAG,CAAC,SAAS,EAAE,sBAAsB,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC;gBACjE,MAAM;YACR,KAAK,aAAa,CAAC,MAAM,CAAC;YAC1B,KAAK,aAAa,CAAC,YAAY,CAAC;YAChC,KAAK,aAAa,CAAC,SAAS,CAAC;YAC7B,KAAK,aAAa,CAAC,UAAU,CAAC;YAC9B,KAAK,aAAa,CAAC,UAAU,CAAC;YAC9B,KAAK,aAAa,CAAC,iBAAiB,CAAC;YACrC,KAAK,aAAa,CAAC,aAAa,CAAC;YACjC,KAAK,aAAa,CAAC,SAAS,CAAC;YAC7B,KAAK,aAAa,CAAC,IAAI,CAAC;YACxB,KAAK,aAAa,CAAC,SAAS,CAAC;YAC7B,KAAK,aAAa,CAAC,UAAU,CAAC;YAC9B,KAAK,aAAa,CAAC,QAAQ;gBACzB,IAAI,GAAG,CAAC,SAAS,CAAC,CAAC;gBACnB,MAAM;YACR,KAAK,aAAa,CAAC,OAAO;gBACxB,IAAI,GAAG,CAAC,SAAS,EAAE,sBAAsB,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,EAAE,sBAAsB,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC;gBAChH,MAAM;YACR,KAAK,aAAa,CAAC,WAAW;gBAC5B,IAAI,GAAG,CAAC,SAAS,EAAE,SAAS,CAAC,OAAO,CAAC,CAAC;gBACtC,MAAM;YACR,KAAK,aAAa,CAAC,YAAY;gBAC7B,IAAI,GAAG,CAAC,SAAS,EAAE,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,aAAa,CAAC,cAAc,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;gBACjF,MAAM;YACR,KAAK,aAAa,CAAC,KAAK;gBACtB,IAAI,GAAG,CAAC,SAAS,EAAE,sBAAsB,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;gBAClE,MAAM;YACR,KAAK,aAAa,CAAC,UAAU,CAAC;YAC9B,KAAK,aAAa,CAAC,aAAa;gBAC9B,IAAI,GAAG,CAAC,SAAS,EAAE,SAAS,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,aAAa,CAAC,cAAc,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;gBACnF,MAAM;YACR;gBACE,IAAI,GAAG,CAAC,IAAI,CAAC,CAAC;QAClB,CAAC;QAED,OAAO,aAAa,CAAC,cAAc,EAAE,GAAG,IAAI,CAAC,CAAC;IAChD,CAAC,CAAC,CAAC;AACL,CAAC"}
package/package.json CHANGED
@@ -1,14 +1,20 @@
1
1
  {
2
2
  "name": "@dressed/react",
3
- "version": "1.8.4",
3
+ "version": "1.8.5-canary.2",
4
4
  "repository": {
5
5
  "type": "git",
6
6
  "url": "git+https://github.com/Inbestigator/dressed.git",
7
7
  "directory": "packages/dressed-react"
8
8
  },
9
+ "dependencies": {
10
+ "@types/react": "^19.2.14",
11
+ "@types/react-reconciler": "^0.33.0",
12
+ "discord-api-types": "^0.38.39",
13
+ "react-reconciler": "npm:@dressed/react-reconciler"
14
+ },
9
15
  "peerDependencies": {
10
- "dressed": "^1.10.1",
11
- "react": "^19.2.3"
16
+ "dressed": "^2.0.0-canary.2",
17
+ "react": "^19.2.4"
12
18
  },
13
19
  "exports": {
14
20
  ".": "./dist/index.js",
@@ -32,13 +38,5 @@
32
38
  "dry-publish": "bun publish --dry-run"
33
39
  },
34
40
  "type": "module",
35
- "types": "./dist/index.d.ts",
36
- "dependencies": {
37
- "discord-api-types": "^0.38.37",
38
- "react-reconciler": "npm:@dressed/react-reconciler"
39
- },
40
- "devDependencies": {
41
- "@types/react": "^19.2.8",
42
- "@types/react-reconciler": "^0.32.3"
43
- }
41
+ "types": "./dist/index.d.ts"
44
42
  }