discord-html-transcripts-v2 3.3.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.
Files changed (87) hide show
  1. package/LICENSE +201 -0
  2. package/README.md +136 -0
  3. package/dist/downloader/images.d.ts +36 -0
  4. package/dist/downloader/images.js +114 -0
  5. package/dist/downloader/images.js.map +1 -0
  6. package/dist/generator/index.d.ts +18 -0
  7. package/dist/generator/index.js +78 -0
  8. package/dist/generator/index.js.map +1 -0
  9. package/dist/generator/renderers/attachment.d.ts +22 -0
  10. package/dist/generator/renderers/attachment.js +49 -0
  11. package/dist/generator/renderers/attachment.js.map +1 -0
  12. package/dist/generator/renderers/components/Button.d.ts +10 -0
  13. package/dist/generator/renderers/components/Button.js +24 -0
  14. package/dist/generator/renderers/components/Button.js.map +1 -0
  15. package/dist/generator/renderers/components/Container.d.ts +6 -0
  16. package/dist/generator/renderers/components/Container.js +26 -0
  17. package/dist/generator/renderers/components/Container.js.map +1 -0
  18. package/dist/generator/renderers/components/Media Gallery.d.ts +6 -0
  19. package/dist/generator/renderers/components/Media Gallery.js +40 -0
  20. package/dist/generator/renderers/components/Media Gallery.js.map +1 -0
  21. package/dist/generator/renderers/components/Select Menu.d.ts +9 -0
  22. package/dist/generator/renderers/components/Select Menu.js +41 -0
  23. package/dist/generator/renderers/components/Select Menu.js.map +1 -0
  24. package/dist/generator/renderers/components/Spacing.d.ts +7 -0
  25. package/dist/generator/renderers/components/Spacing.js +18 -0
  26. package/dist/generator/renderers/components/Spacing.js.map +1 -0
  27. package/dist/generator/renderers/components/Thumbnail.d.ts +5 -0
  28. package/dist/generator/renderers/components/Thumbnail.js +16 -0
  29. package/dist/generator/renderers/components/Thumbnail.js.map +1 -0
  30. package/dist/generator/renderers/components/section/Section.d.ts +9 -0
  31. package/dist/generator/renderers/components/section/Section.js +21 -0
  32. package/dist/generator/renderers/components/section/Section.js.map +1 -0
  33. package/dist/generator/renderers/components/section/SectionAccessory.d.ts +6 -0
  34. package/dist/generator/renderers/components/section/SectionAccessory.js +21 -0
  35. package/dist/generator/renderers/components/section/SectionAccessory.js.map +1 -0
  36. package/dist/generator/renderers/components/section/SectionContent.d.ts +6 -0
  37. package/dist/generator/renderers/components/section/SectionContent.js +17 -0
  38. package/dist/generator/renderers/components/section/SectionContent.js.map +1 -0
  39. package/dist/generator/renderers/components/styles.d.ts +21 -0
  40. package/dist/generator/renderers/components/styles.js +114 -0
  41. package/dist/generator/renderers/components/styles.js.map +1 -0
  42. package/dist/generator/renderers/components/utils.d.ts +42 -0
  43. package/dist/generator/renderers/components/utils.js +101 -0
  44. package/dist/generator/renderers/components/utils.js.map +1 -0
  45. package/dist/generator/renderers/components.d.ts +12 -0
  46. package/dist/generator/renderers/components.js +63 -0
  47. package/dist/generator/renderers/components.js.map +1 -0
  48. package/dist/generator/renderers/content.d.ts +32 -0
  49. package/dist/generator/renderers/content.js +180 -0
  50. package/dist/generator/renderers/content.js.map +1 -0
  51. package/dist/generator/renderers/embed.d.ts +12 -0
  52. package/dist/generator/renderers/embed.js +53 -0
  53. package/dist/generator/renderers/embed.js.map +1 -0
  54. package/dist/generator/renderers/message.d.ts +7 -0
  55. package/dist/generator/renderers/message.js +69 -0
  56. package/dist/generator/renderers/message.js.map +1 -0
  57. package/dist/generator/renderers/reply.d.ts +7 -0
  58. package/dist/generator/renderers/reply.js +58 -0
  59. package/dist/generator/renderers/reply.js.map +1 -0
  60. package/dist/generator/renderers/systemMessage.d.ts +13 -0
  61. package/dist/generator/renderers/systemMessage.js +133 -0
  62. package/dist/generator/renderers/systemMessage.js.map +1 -0
  63. package/dist/generator/transcript.d.ts +10 -0
  64. package/dist/generator/transcript.js +89 -0
  65. package/dist/generator/transcript.js.map +1 -0
  66. package/dist/index.d.ts +25 -0
  67. package/dist/index.js +137 -0
  68. package/dist/index.js.map +1 -0
  69. package/dist/static/client.d.ts +2 -0
  70. package/dist/static/client.js +30 -0
  71. package/dist/static/client.js.map +1 -0
  72. package/dist/types.d.ts +63 -0
  73. package/dist/types.js +10 -0
  74. package/dist/types.js.map +1 -0
  75. package/dist/utils/buildProfiles.d.ts +11 -0
  76. package/dist/utils/buildProfiles.js +42 -0
  77. package/dist/utils/buildProfiles.js.map +1 -0
  78. package/dist/utils/embeds.d.ts +2 -0
  79. package/dist/utils/embeds.js +17 -0
  80. package/dist/utils/embeds.js.map +1 -0
  81. package/dist/utils/extend.d.ts +8 -0
  82. package/dist/utils/extend.js +8 -0
  83. package/dist/utils/extend.js.map +1 -0
  84. package/dist/utils/utils.d.ts +9 -0
  85. package/dist/utils/utils.js +44 -0
  86. package/dist/utils/utils.js.map +1 -0
  87. package/package.json +87 -0
@@ -0,0 +1,49 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.Attachments = Attachments;
7
+ exports.Attachment = Attachment;
8
+ const discord_components_react_1 = require("@derockdev/discord-components-react");
9
+ const react_1 = __importDefault(require("react"));
10
+ const utils_1 = require("../../utils/utils");
11
+ /**
12
+ * Renders all attachments for a message
13
+ * @param message
14
+ * @param context
15
+ * @returns
16
+ */
17
+ async function Attachments(props) {
18
+ if (props.message.attachments.size === 0)
19
+ return react_1.default.createElement(react_1.default.Fragment, null);
20
+ return (react_1.default.createElement(discord_components_react_1.DiscordAttachments, { slot: "attachments" }, props.message.attachments.map((attachment, id) => (react_1.default.createElement(Attachment, { attachment: attachment, message: props.message, context: props.context, key: id })))));
21
+ }
22
+ // "audio" | "video" | "image" | "file"
23
+ function getAttachmentType(attachment) {
24
+ var _a, _b, _c;
25
+ const type = (_c = (_b = (_a = attachment.contentType) === null || _a === void 0 ? void 0 : _a.split('/')) === null || _b === void 0 ? void 0 : _b[0]) !== null && _c !== void 0 ? _c : 'unknown';
26
+ if (['audio', 'video', 'image'].includes(type))
27
+ return type;
28
+ return 'file';
29
+ }
30
+ /**
31
+ * Renders one Discord Attachment
32
+ * @param props - the attachment and rendering context
33
+ */
34
+ async function Attachment({ attachment, context, message, }) {
35
+ let url = attachment.url;
36
+ const name = attachment.name;
37
+ const width = attachment.width;
38
+ const height = attachment.height;
39
+ const type = getAttachmentType(attachment);
40
+ // if the attachment is an image, download it to a data url
41
+ if (type === 'image') {
42
+ const downloaded = await context.callbacks.resolveImageSrc(attachment.toJSON(), message.toJSON());
43
+ if (downloaded !== null) {
44
+ url = downloaded !== null && downloaded !== void 0 ? downloaded : url;
45
+ }
46
+ }
47
+ return (react_1.default.createElement(discord_components_react_1.DiscordAttachment, { type: type, size: (0, utils_1.formatBytes)(attachment.size), key: attachment.id, slot: "attachment", url: url, alt: name !== null && name !== void 0 ? name : undefined, width: width !== null && width !== void 0 ? width : undefined, height: height !== null && height !== void 0 ? height : undefined }));
48
+ }
49
+ //# sourceMappingURL=attachment.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"attachment.js","sourceRoot":"","sources":["../../../src/generator/renderers/attachment.tsx"],"names":[],"mappings":";;;;;AAaA,kCAUC;AAaD,gCAwCC;AA5ED,kFAA4F;AAC5F,kDAA0B;AAI1B,6CAAgD;AAEhD;;;;;GAKG;AACI,KAAK,UAAU,WAAW,CAAC,KAA0D;IAC1F,IAAI,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,KAAK,CAAC;QAAE,OAAO,6DAAK,CAAC;IAEvD,OAAO,CACL,8BAAC,6CAAkB,IAAC,IAAI,EAAC,aAAa,IACnC,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE,EAAE,EAAE,CAAC,CACjD,8BAAC,UAAU,IAAC,UAAU,EAAE,UAAU,EAAE,OAAO,EAAE,KAAK,CAAC,OAAO,EAAE,OAAO,EAAE,KAAK,CAAC,OAAO,EAAE,GAAG,EAAE,EAAE,GAAI,CAChG,CAAC,CACiB,CACtB,CAAC;AACJ,CAAC;AAED,uCAAuC;AACvC,SAAS,iBAAiB,CAAC,UAA0B;;IACnD,MAAM,IAAI,GAAG,MAAA,MAAA,MAAA,UAAU,CAAC,WAAW,0CAAE,KAAK,CAAC,GAAG,CAAC,0CAAG,CAAC,CAAC,mCAAI,SAAS,CAAC;IAClE,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC;QAAE,OAAO,IAAuB,CAAC;IAC/E,OAAO,MAAM,CAAC;AAChB,CAAC;AAED;;;GAGG;AACI,KAAK,UAAU,UAAU,CAAC,EAC/B,UAAU,EACV,OAAO,EACP,OAAO,GAKR;IACC,IAAI,GAAG,GAAG,UAAU,CAAC,GAAG,CAAC;IACzB,MAAM,IAAI,GAAG,UAAU,CAAC,IAAI,CAAC;IAC7B,MAAM,KAAK,GAAG,UAAU,CAAC,KAAK,CAAC;IAC/B,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC;IAEjC,MAAM,IAAI,GAAG,iBAAiB,CAAC,UAAU,CAAC,CAAC;IAE3C,2DAA2D;IAC3D,IAAI,IAAI,KAAK,OAAO,EAAE,CAAC;QACrB,MAAM,UAAU,GAAG,MAAM,OAAO,CAAC,SAAS,CAAC,eAAe,CACxD,UAAU,CAAC,MAAM,EAAmB,EACpC,OAAO,CAAC,MAAM,EAAgB,CAC/B,CAAC;QAEF,IAAI,UAAU,KAAK,IAAI,EAAE,CAAC;YACxB,GAAG,GAAG,UAAU,aAAV,UAAU,cAAV,UAAU,GAAI,GAAG,CAAC;QAC1B,CAAC;IACH,CAAC;IAED,OAAO,CACL,8BAAC,4CAAiB,IAChB,IAAI,EAAE,IAAI,EACV,IAAI,EAAE,IAAA,mBAAW,EAAC,UAAU,CAAC,IAAI,CAAC,EAClC,GAAG,EAAE,UAAU,CAAC,EAAE,EAClB,IAAI,EAAC,YAAY,EACjB,GAAG,EAAE,GAAG,EACR,GAAG,EAAE,IAAI,aAAJ,IAAI,cAAJ,IAAI,GAAI,SAAS,EACtB,KAAK,EAAE,KAAK,aAAL,KAAK,cAAL,KAAK,GAAI,SAAS,EACzB,MAAM,EAAE,MAAM,aAAN,MAAM,cAAN,MAAM,GAAI,SAAS,GAC3B,CACH,CAAC;AACJ,CAAC"}
@@ -0,0 +1,10 @@
1
+ import React from 'react';
2
+ interface DiscordButtonProps {
3
+ type: string;
4
+ url?: string;
5
+ emoji?: string;
6
+ children: React.ReactNode;
7
+ disabled?: boolean;
8
+ }
9
+ export declare function DiscordButton({ type, url, emoji, children, disabled }: DiscordButtonProps): React.JSX.Element;
10
+ export default DiscordButton;
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.DiscordButton = DiscordButton;
7
+ const react_1 = __importDefault(require("react"));
8
+ function DiscordButton({ type, url, emoji, children, disabled = false }) {
9
+ const className = `discord-button discord-button-${type}${disabled ? ' discord-button-disabled' : ''}`;
10
+ const content = (react_1.default.createElement(react_1.default.Fragment, null,
11
+ emoji && (react_1.default.createElement("span", { style: { display: 'flex', alignItems: 'center' } },
12
+ react_1.default.createElement("img", { src: emoji, alt: "emoji", style: { width: '16px', height: '16px', marginRight: '8px' } }))),
13
+ react_1.default.createElement("span", { style: { display: 'flex', alignItems: 'center' } }, children),
14
+ url && !disabled && (react_1.default.createElement("span", { style: { marginLeft: '8px', display: 'flex', alignItems: 'center' } },
15
+ react_1.default.createElement("svg", { role: "img", xmlns: "http://www.w3.org/2000/svg", width: "16", height: "16", fill: "none", viewBox: "0 0 24 24" },
16
+ react_1.default.createElement("path", { fill: "currentColor", d: "M15 2a1 1 0 0 1 1-1h6a1 1 0 0 1 1 1v6a1 1 0 1 1-2 0V4.41l-4.3 4.3a1 1 0 1 1-1.4-1.42L19.58 3H16a1 1 0 0 1-1-1Z" }),
17
+ react_1.default.createElement("path", { fill: "currentColor", d: "M5 2a3 3 0 0 0-3 3v14a3 3 0 0 0 3 3h14a3 3 0 0 0 3-3v-6a1 1 0 1 0-2 0v6a1 1 0 0 1-1 1H5a1 1 0 0 1-1-1V5a1 1 0 0 1 1-1h6a1 1 0 1 0 0-2H5Z" }))))));
18
+ if (url && !disabled) {
19
+ return (react_1.default.createElement("a", { href: url, target: "_blank", rel: "noreferrer", className: className }, content));
20
+ }
21
+ return (react_1.default.createElement("span", { "aria-disabled": disabled, className: className }, content));
22
+ }
23
+ exports.default = DiscordButton;
24
+ //# sourceMappingURL=Button.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Button.js","sourceRoot":"","sources":["../../../../src/generator/renderers/components/Button.tsx"],"names":[],"mappings":";;;;;AAUA,sCAwCC;AAlDD,kDAA0B;AAU1B,SAAgB,aAAa,CAAC,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,GAAG,KAAK,EAAsB;IAChG,MAAM,SAAS,GAAG,iCAAiC,IAAI,GAAG,QAAQ,CAAC,CAAC,CAAC,0BAA0B,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC;IACvG,MAAM,OAAO,GAAG,CACd;QACG,KAAK,IAAI,CACR,wCAAM,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE;YACpD,uCAAK,GAAG,EAAE,KAAK,EAAE,GAAG,EAAC,OAAO,EAAC,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,KAAK,EAAE,GAAI,CACxF,CACR;QACD,wCAAM,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,IAAG,QAAQ,CAAQ;QACxE,GAAG,IAAI,CAAC,QAAQ,IAAI,CACnB,wCAAM,KAAK,EAAE,EAAE,UAAU,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE;YACvE,uCAAK,IAAI,EAAC,KAAK,EAAC,KAAK,EAAC,4BAA4B,EAAC,KAAK,EAAC,IAAI,EAAC,MAAM,EAAC,IAAI,EAAC,IAAI,EAAC,MAAM,EAAC,OAAO,EAAC,WAAW;gBACvG,wCACE,IAAI,EAAC,cAAc,EACnB,CAAC,EAAC,gHAAgH,GAClH;gBACF,wCACE,IAAI,EAAC,cAAc,EACnB,CAAC,EAAC,0IAA0I,GAC5I,CACE,CACD,CACR,CACA,CACJ,CAAC;IAEF,IAAI,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;QACrB,OAAO,CACL,qCAAG,IAAI,EAAE,GAAG,EAAE,MAAM,EAAC,QAAQ,EAAC,GAAG,EAAC,YAAY,EAAC,SAAS,EAAE,SAAS,IAChE,OAAO,CACN,CACL,CAAC;IACJ,CAAC;IAED,OAAO,CACL,yDAAqB,QAAQ,EAAE,SAAS,EAAE,SAAS,IAChD,OAAO,CACH,CACR,CAAC;AACJ,CAAC;AAED,kBAAe,aAAa,CAAC"}
@@ -0,0 +1,6 @@
1
+ import React from 'react';
2
+ declare function DiscordContainer({ children, accentColor }: {
3
+ children: React.ReactNode;
4
+ accentColor?: number;
5
+ }): React.JSX.Element;
6
+ export default DiscordContainer;
@@ -0,0 +1,26 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const react_1 = __importDefault(require("react"));
7
+ function DiscordContainer({ children, accentColor }) {
8
+ const accent = typeof accentColor === 'number' ? `#${accentColor.toString(16).padStart(6, '0')}` : '#5865f2';
9
+ return (react_1.default.createElement("div", { style: {
10
+ display: 'flex',
11
+ width: '100%',
12
+ maxWidth: '520px',
13
+ flexDirection: 'column',
14
+ backgroundColor: '#3f4248',
15
+ padding: '14px 14px 12px',
16
+ border: '1px solid #4f5359',
17
+ borderLeft: `4px solid ${accent}`,
18
+ marginTop: '2px',
19
+ marginBottom: '2px',
20
+ borderRadius: '8px',
21
+ gap: '8px',
22
+ boxSizing: 'border-box',
23
+ } }, children));
24
+ }
25
+ exports.default = DiscordContainer;
26
+ //# sourceMappingURL=Container.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Container.js","sourceRoot":"","sources":["../../../../src/generator/renderers/components/Container.tsx"],"names":[],"mappings":";;;;;AAAA,kDAA0B;AAE1B,SAAS,gBAAgB,CAAC,EAAE,QAAQ,EAAE,WAAW,EAAuD;IACtG,MAAM,MAAM,GAAG,OAAO,WAAW,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,WAAW,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;IAE7G,OAAO,CACL,uCACE,KAAK,EAAE;YACL,OAAO,EAAE,MAAM;YACf,KAAK,EAAE,MAAM;YACb,QAAQ,EAAE,OAAO;YACjB,aAAa,EAAE,QAAQ;YACvB,eAAe,EAAE,SAAS;YAC1B,OAAO,EAAE,gBAAgB;YACzB,MAAM,EAAE,mBAAmB;YAC3B,UAAU,EAAE,aAAa,MAAM,EAAE;YACjC,SAAS,EAAE,KAAK;YAChB,YAAY,EAAE,KAAK;YACnB,YAAY,EAAE,KAAK;YACnB,GAAG,EAAE,KAAK;YACV,SAAS,EAAE,YAAY;SACxB,IAEA,QAAQ,CACL,CACP,CAAC;AACJ,CAAC;AAED,kBAAe,gBAAgB,CAAC"}
@@ -0,0 +1,6 @@
1
+ import React from 'react';
2
+ import type { MediaGalleryComponent } from 'discord.js';
3
+ declare function DiscordMediaGallery({ component }: {
4
+ component: MediaGalleryComponent;
5
+ }): React.JSX.Element | null;
6
+ export default DiscordMediaGallery;
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const react_1 = __importDefault(require("react"));
7
+ const utils_1 = require("./utils");
8
+ function DiscordMediaGallery({ component }) {
9
+ if (!component.items || component.items.length === 0) {
10
+ return null;
11
+ }
12
+ const count = component.items.length;
13
+ const imagesToShow = component.items.slice(0, 10);
14
+ const hasMore = component.items.length > 10;
15
+ return (react_1.default.createElement("div", { style: (0, utils_1.getGalleryLayout)(count) }, imagesToShow.map((media, idx) => (react_1.default.createElement("div", { key: idx, style: (0, utils_1.getImageStyle)(idx, count) },
16
+ react_1.default.createElement("img", { src: media.media.url, alt: media.description || 'Media content', style: {
17
+ width: '100%',
18
+ height: '100%',
19
+ objectFit: 'cover',
20
+ display: 'block',
21
+ } }),
22
+ hasMore && idx === imagesToShow.length - 1 && (react_1.default.createElement("div", { style: {
23
+ position: 'absolute',
24
+ top: 0,
25
+ left: 0,
26
+ width: '100%',
27
+ height: '100%',
28
+ display: 'flex',
29
+ alignItems: 'center',
30
+ justifyContent: 'center',
31
+ backgroundColor: 'rgba(0, 0, 0, 0.7)',
32
+ color: 'white',
33
+ fontSize: '20px',
34
+ fontWeight: 'bold',
35
+ } },
36
+ "+",
37
+ component.items.length - 10)))))));
38
+ }
39
+ exports.default = DiscordMediaGallery;
40
+ //# sourceMappingURL=Media%20Gallery.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Media Gallery.js","sourceRoot":"","sources":["../../../../src/generator/renderers/components/Media Gallery.tsx"],"names":[],"mappings":";;;;;AAAA,kDAA0B;AAE1B,mCAA0D;AAE1D,SAAS,mBAAmB,CAAC,EAAE,SAAS,EAAwC;IAC9E,IAAI,CAAC,SAAS,CAAC,KAAK,IAAI,SAAS,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACrD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,KAAK,GAAG,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC;IACrC,MAAM,YAAY,GAAG,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IAClD,MAAM,OAAO,GAAG,SAAS,CAAC,KAAK,CAAC,MAAM,GAAG,EAAE,CAAC;IAE5C,OAAO,CACL,uCAAK,KAAK,EAAE,IAAA,wBAAgB,EAAC,KAAK,CAAC,IAChC,YAAY,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE,CAAC,CAChC,uCAAK,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,IAAA,qBAAa,EAAC,GAAG,EAAE,KAAK,CAAC;QAC7C,uCACE,GAAG,EAAE,KAAK,CAAC,KAAK,CAAC,GAAG,EACpB,GAAG,EAAE,KAAK,CAAC,WAAW,IAAI,eAAe,EACzC,KAAK,EAAE;gBACL,KAAK,EAAE,MAAM;gBACb,MAAM,EAAE,MAAM;gBACd,SAAS,EAAE,OAAO;gBAClB,OAAO,EAAE,OAAO;aACjB,GACD;QACD,OAAO,IAAI,GAAG,KAAK,YAAY,CAAC,MAAM,GAAG,CAAC,IAAI,CAC7C,uCACE,KAAK,EAAE;gBACL,QAAQ,EAAE,UAAU;gBACpB,GAAG,EAAE,CAAC;gBACN,IAAI,EAAE,CAAC;gBACP,KAAK,EAAE,MAAM;gBACb,MAAM,EAAE,MAAM;gBACd,OAAO,EAAE,MAAM;gBACf,UAAU,EAAE,QAAQ;gBACpB,cAAc,EAAE,QAAQ;gBACxB,eAAe,EAAE,oBAAoB;gBACrC,KAAK,EAAE,OAAO;gBACd,QAAQ,EAAE,MAAM;gBAChB,UAAU,EAAE,MAAM;aACnB;;YAEC,SAAS,CAAC,KAAK,CAAC,MAAM,GAAG,EAAE,CACzB,CACP,CACG,CACP,CAAC,CACE,CACP,CAAC;AACJ,CAAC;AAED,kBAAe,mBAAmB,CAAC"}
@@ -0,0 +1,9 @@
1
+ import React from 'react';
2
+ import { type MessageActionRowComponent, ComponentType } from 'discord.js';
3
+ declare function DiscordSelectMenu({ component, disabled, }: {
4
+ component: Exclude<MessageActionRowComponent, {
5
+ type: ComponentType.Button;
6
+ }>;
7
+ disabled?: boolean;
8
+ }): React.JSX.Element;
9
+ export default DiscordSelectMenu;
@@ -0,0 +1,41 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const react_1 = __importDefault(require("react"));
7
+ const discord_js_1 = require("discord.js");
8
+ const utils_1 = require("../../../utils/utils");
9
+ const utils_2 = require("./utils");
10
+ function DiscordSelectMenu({ component, disabled = false, }) {
11
+ const isStringSelect = component.type === discord_js_1.ComponentType.StringSelect;
12
+ const placeholder = component.placeholder || (0, utils_2.getSelectTypeLabel)(component.type);
13
+ return (react_1.default.createElement("div", { className: `discord-select-menu${disabled ? ' discord-select-menu-disabled' : ''}` },
14
+ react_1.default.createElement("div", { style: { overflow: 'hidden', textOverflow: 'ellipsis', whiteSpace: 'nowrap' } }, placeholder),
15
+ react_1.default.createElement("div", { style: { display: 'flex', alignItems: 'center', marginLeft: '8px' } },
16
+ react_1.default.createElement("svg", { width: "24", height: "24", viewBox: "0 0 24 24" },
17
+ react_1.default.createElement("path", { fill: "currentColor", d: "M7 10L12 15L17 10H7Z" }))),
18
+ isStringSelect && component.options && component.options.length > 0 && (react_1.default.createElement("div", { style: {
19
+ display: 'none',
20
+ position: 'absolute',
21
+ top: '44px',
22
+ left: '0',
23
+ width: '100%',
24
+ backgroundColor: '#2b2d31',
25
+ borderRadius: '4px',
26
+ zIndex: 10,
27
+ border: '1px solid #1e1f22',
28
+ maxHeight: '320px',
29
+ overflowY: 'auto',
30
+ } }, component.options.map((option, idx) => (react_1.default.createElement("div", { key: idx, style: {
31
+ padding: '8px 12px',
32
+ cursor: 'pointer',
33
+ display: 'flex',
34
+ alignItems: 'center',
35
+ borderBottom: idx < component.options.length - 1 ? '1px solid #1e1f22' : 'none',
36
+ } },
37
+ option.emoji && react_1.default.createElement("span", { style: { marginRight: '8px' } }, (0, utils_1.parseDiscordEmoji)(option.emoji)),
38
+ react_1.default.createElement("span", null, option.label))))))));
39
+ }
40
+ exports.default = DiscordSelectMenu;
41
+ //# sourceMappingURL=Select%20Menu.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Select Menu.js","sourceRoot":"","sources":["../../../../src/generator/renderers/components/Select Menu.tsx"],"names":[],"mappings":";;;;;AAAA,kDAA0B;AAC1B,2CAA2E;AAC3E,gDAAyD;AACzD,mCAA6C;AAE7C,SAAS,iBAAiB,CAAC,EACzB,SAAS,EACT,QAAQ,GAAG,KAAK,GAIjB;IACC,MAAM,cAAc,GAAG,SAAS,CAAC,IAAI,KAAK,0BAAa,CAAC,YAAY,CAAC;IACrE,MAAM,WAAW,GAAG,SAAS,CAAC,WAAW,IAAI,IAAA,0BAAkB,EAAC,SAAS,CAAC,IAAI,CAAC,CAAC;IAEhF,OAAO,CACL,uCAAK,SAAS,EAAE,sBAAsB,QAAQ,CAAC,CAAC,CAAC,+BAA+B,CAAC,CAAC,CAAC,EAAE,EAAE;QACrF,uCAAK,KAAK,EAAE,EAAE,QAAQ,EAAE,QAAQ,EAAE,YAAY,EAAE,UAAU,EAAE,UAAU,EAAE,QAAQ,EAAE,IAAG,WAAW,CAAO;QACvG,uCAAK,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,UAAU,EAAE,KAAK,EAAE;YACtE,uCAAK,KAAK,EAAC,IAAI,EAAC,MAAM,EAAC,IAAI,EAAC,OAAO,EAAC,WAAW;gBAC7C,wCAAM,IAAI,EAAC,cAAc,EAAC,CAAC,EAAC,sBAAsB,GAAG,CACjD,CACF;QACL,cAAc,IAAI,SAAS,CAAC,OAAO,IAAI,SAAS,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,IAAI,CACtE,uCACE,KAAK,EAAE;gBACL,OAAO,EAAE,MAAM;gBACf,QAAQ,EAAE,UAAU;gBACpB,GAAG,EAAE,MAAM;gBACX,IAAI,EAAE,GAAG;gBACT,KAAK,EAAE,MAAM;gBACb,eAAe,EAAE,SAAS;gBAC1B,YAAY,EAAE,KAAK;gBACnB,MAAM,EAAE,EAAE;gBACV,MAAM,EAAE,mBAAmB;gBAC3B,SAAS,EAAE,OAAO;gBAClB,SAAS,EAAE,MAAM;aAClB,IAEA,SAAS,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,GAAG,EAAE,EAAE,CAAC,CACtC,uCACE,GAAG,EAAE,GAAG,EACR,KAAK,EAAE;gBACL,OAAO,EAAE,UAAU;gBACnB,MAAM,EAAE,SAAS;gBACjB,OAAO,EAAE,MAAM;gBACf,UAAU,EAAE,QAAQ;gBACpB,YAAY,EAAE,GAAG,GAAG,SAAS,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,MAAM;aAChF;YAEA,MAAM,CAAC,KAAK,IAAI,wCAAM,KAAK,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,IAAG,IAAA,yBAAiB,EAAC,MAAM,CAAC,KAAK,CAAC,CAAQ;YAC9F,4CAAO,MAAM,CAAC,KAAK,CAAQ,CACvB,CACP,CAAC,CACE,CACP,CACG,CACP,CAAC;AACJ,CAAC;AAED,kBAAe,iBAAiB,CAAC"}
@@ -0,0 +1,7 @@
1
+ import React from 'react';
2
+ import { SeparatorSpacingSize } from 'discord.js';
3
+ declare function DiscordSeparator({ divider, spacing }: {
4
+ divider: boolean;
5
+ spacing: SeparatorSpacingSize;
6
+ }): React.JSX.Element;
7
+ export default DiscordSeparator;
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const react_1 = __importDefault(require("react"));
7
+ const discord_js_1 = require("discord.js");
8
+ function DiscordSeparator({ divider, spacing }) {
9
+ const marginY = spacing === discord_js_1.SeparatorSpacingSize.Large ? '10px' : spacing === discord_js_1.SeparatorSpacingSize.Small ? '6px' : '2px';
10
+ return (react_1.default.createElement("div", { style: {
11
+ width: '100%',
12
+ height: divider ? '1px' : '0px',
13
+ backgroundColor: divider ? '#4f5359' : 'transparent',
14
+ margin: `${marginY} 0`,
15
+ } }));
16
+ }
17
+ exports.default = DiscordSeparator;
18
+ //# sourceMappingURL=Spacing.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Spacing.js","sourceRoot":"","sources":["../../../../src/generator/renderers/components/Spacing.tsx"],"names":[],"mappings":";;;;;AAAA,kDAA0B;AAC1B,2CAAkD;AAElD,SAAS,gBAAgB,CAAC,EAAE,OAAO,EAAE,OAAO,EAAuD;IACjG,MAAM,OAAO,GACX,OAAO,KAAK,iCAAoB,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,KAAK,iCAAoB,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC;IAE3G,OAAO,CACL,uCACE,KAAK,EAAE;YACL,KAAK,EAAE,MAAM;YACb,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK;YAC/B,eAAe,EAAE,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,aAAa;YACpD,MAAM,EAAE,GAAG,OAAO,IAAI;SACvB,GACD,CACH,CAAC;AACJ,CAAC;AAED,kBAAe,gBAAgB,CAAC"}
@@ -0,0 +1,5 @@
1
+ import React from 'react';
2
+ declare function DiscordThumbnail({ url }: {
3
+ url: string;
4
+ }): React.JSX.Element;
5
+ export default DiscordThumbnail;
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const react_1 = __importDefault(require("react"));
7
+ function DiscordThumbnail({ url }) {
8
+ return (react_1.default.createElement("img", { src: url, alt: "Thumbnail", style: {
9
+ width: '85px',
10
+ height: '85px',
11
+ objectFit: 'cover',
12
+ borderRadius: '8px',
13
+ } }));
14
+ }
15
+ exports.default = DiscordThumbnail;
16
+ //# sourceMappingURL=Thumbnail.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Thumbnail.js","sourceRoot":"","sources":["../../../../src/generator/renderers/components/Thumbnail.tsx"],"names":[],"mappings":";;;;;AAAA,kDAA0B;AAE1B,SAAS,gBAAgB,CAAC,EAAE,GAAG,EAAmB;IAChD,OAAO,CACL,uCACE,GAAG,EAAE,GAAG,EACR,GAAG,EAAC,WAAW,EACf,KAAK,EAAE;YACL,KAAK,EAAE,MAAM;YACb,MAAM,EAAE,MAAM;YACd,SAAS,EAAE,OAAO;YAClB,YAAY,EAAE,KAAK;SACpB,GACD,CACH,CAAC;AACJ,CAAC;AAED,kBAAe,gBAAgB,CAAC"}
@@ -0,0 +1,9 @@
1
+ import React from 'react';
2
+ import type { ButtonComponent, ThumbnailComponent } from 'discord.js';
3
+ interface DiscordSectionProps {
4
+ children: React.ReactNode;
5
+ accessory?: ButtonComponent | ThumbnailComponent;
6
+ id: number;
7
+ }
8
+ declare function DiscordSection({ children, accessory, id }: DiscordSectionProps): React.JSX.Element;
9
+ export default DiscordSection;
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const react_1 = __importDefault(require("react"));
7
+ const components_1 = require("../../components");
8
+ const SectionContent_1 = __importDefault(require("./SectionContent"));
9
+ const SectionAccessory_1 = __importDefault(require("./SectionAccessory"));
10
+ function DiscordSection({ children, accessory, id }) {
11
+ return (react_1.default.createElement("div", { style: {
12
+ display: 'flex',
13
+ flexDirection: 'row',
14
+ width: '100%',
15
+ maxWidth: '500px',
16
+ } },
17
+ react_1.default.createElement(SectionContent_1.default, null, children),
18
+ react_1.default.createElement(SectionAccessory_1.default, null, accessory && react_1.default.createElement(components_1.Component, { component: accessory, id: id }))));
19
+ }
20
+ exports.default = DiscordSection;
21
+ //# sourceMappingURL=Section.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Section.js","sourceRoot":"","sources":["../../../../../src/generator/renderers/components/section/Section.tsx"],"names":[],"mappings":";;;;;AAAA,kDAA0B;AAE1B,iDAA6C;AAC7C,sEAA8C;AAC9C,0EAAkD;AAQlD,SAAS,cAAc,CAAC,EAAE,QAAQ,EAAE,SAAS,EAAE,EAAE,EAAuB;IACtE,OAAO,CACL,uCACE,KAAK,EAAE;YACL,OAAO,EAAE,MAAM;YACf,aAAa,EAAE,KAAK;YACpB,KAAK,EAAE,MAAM;YACb,QAAQ,EAAE,OAAO;SAClB;QAED,8BAAC,wBAAc,QAAE,QAAQ,CAAkB;QAC3C,8BAAC,0BAAgB,QAAE,SAAS,IAAI,8BAAC,sBAAS,IAAC,SAAS,EAAE,SAAS,EAAE,EAAE,EAAE,EAAE,GAAI,CAAoB,CAC3F,CACP,CAAC;AACJ,CAAC;AAED,kBAAe,cAAc,CAAC"}
@@ -0,0 +1,6 @@
1
+ import React from 'react';
2
+ interface SectionAccessoryProps {
3
+ children?: React.ReactNode;
4
+ }
5
+ declare function SectionAccessory({ children }: SectionAccessoryProps): React.JSX.Element | null;
6
+ export default SectionAccessory;
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const react_1 = __importDefault(require("react"));
7
+ function SectionAccessory({ children }) {
8
+ if (!children)
9
+ return null;
10
+ return (react_1.default.createElement("div", { style: {
11
+ display: 'flex',
12
+ width: 'auto',
13
+ minWidth: '84px',
14
+ justifyContent: 'flex-end',
15
+ alignItems: 'flex-start',
16
+ marginLeft: '12px',
17
+ flexShrink: 0,
18
+ } }, children));
19
+ }
20
+ exports.default = SectionAccessory;
21
+ //# sourceMappingURL=SectionAccessory.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SectionAccessory.js","sourceRoot":"","sources":["../../../../../src/generator/renderers/components/section/SectionAccessory.tsx"],"names":[],"mappings":";;;;;AAAA,kDAA0B;AAM1B,SAAS,gBAAgB,CAAC,EAAE,QAAQ,EAAyB;IAC3D,IAAI,CAAC,QAAQ;QAAE,OAAO,IAAI,CAAC;IAE3B,OAAO,CACL,uCACE,KAAK,EAAE;YACL,OAAO,EAAE,MAAM;YACf,KAAK,EAAE,MAAM;YACb,QAAQ,EAAE,MAAM;YAChB,cAAc,EAAE,UAAU;YAC1B,UAAU,EAAE,YAAY;YACxB,UAAU,EAAE,MAAM;YAClB,UAAU,EAAE,CAAC;SACd,IAEA,QAAQ,CACL,CACP,CAAC;AACJ,CAAC;AAED,kBAAe,gBAAgB,CAAC"}
@@ -0,0 +1,6 @@
1
+ import React from 'react';
2
+ interface SectionContentProps {
3
+ children: React.ReactNode;
4
+ }
5
+ declare function SectionContent({ children }: SectionContentProps): React.JSX.Element;
6
+ export default SectionContent;
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const react_1 = __importDefault(require("react"));
7
+ function SectionContent({ children }) {
8
+ return (react_1.default.createElement("div", { style: {
9
+ display: 'flex',
10
+ flexDirection: 'column',
11
+ width: '100%',
12
+ minWidth: 0,
13
+ gap: '6px',
14
+ } }, children));
15
+ }
16
+ exports.default = SectionContent;
17
+ //# sourceMappingURL=SectionContent.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SectionContent.js","sourceRoot":"","sources":["../../../../../src/generator/renderers/components/section/SectionContent.tsx"],"names":[],"mappings":";;;;;AAAA,kDAA0B;AAM1B,SAAS,cAAc,CAAC,EAAE,QAAQ,EAAuB;IACvD,OAAO,CACL,uCACE,KAAK,EAAE;YACL,OAAO,EAAE,MAAM;YACf,aAAa,EAAE,QAAQ;YACvB,KAAK,EAAE,MAAM;YACb,QAAQ,EAAE,CAAC;YACX,GAAG,EAAE,KAAK;SACX,IAEA,QAAQ,CACL,CACP,CAAC;AACJ,CAAC;AAED,kBAAe,cAAc,CAAC"}
@@ -0,0 +1,21 @@
1
+ export declare const containerStyle: {
2
+ display: "grid";
3
+ gap: string;
4
+ width: string;
5
+ maxWidth: string;
6
+ borderRadius: string;
7
+ overflow: "hidden";
8
+ };
9
+ export declare const baseImageStyle: {
10
+ overflow: "hidden";
11
+ position: "relative";
12
+ background: string;
13
+ };
14
+ export declare const ButtonStyleMapping: {
15
+ readonly 1: "primary";
16
+ readonly 2: "secondary";
17
+ readonly 3: "success";
18
+ readonly 4: "destructive";
19
+ readonly 5: "secondary";
20
+ };
21
+ export declare const globalStyles = "\n .discord-container {\n display: grid;\n gap: 4px;\n width: 100%;\n max-width: 500px;\n border-radius: 8px;\n overflow: hidden;\n }\n\n .discord-base-image {\n overflow: hidden;\n position: relative;\n background: #2b2d31;\n }\n\n .discord-button {\n color: #ffffff !important;\n padding: 2px 16px;\n border-radius: 8px;\n text-decoration: none !important;\n display: inline-flex;\n align-items: center;\n justify-content: center;\n font-size: 14px;\n font-weight: 500;\n height: 32px;\n min-height: 32px;\n min-width: 60px;\n cursor: pointer;\n font-family: Whitney, \"Helvetica Neue\", Helvetica, Arial, sans-serif;\n text-align: center;\n box-sizing: border-box;\n border: none;\n outline: none;\n transition: background-color 0.2s ease;\n }\n\n .discord-button-primary {\n background-color: hsl(234.935 calc(1*85.556%) 64.706% /1);\n }\n\n .discord-button-secondary {\n background-color: hsl(240 calc(1*4%) 60.784% /0.12156862745098039);\n }\n\n .discord-button-success {\n background-color: hsl(145.97 calc(1*100%) 26.275% /1);\n }\n\n .discord-button-destructive {\n background-color: hsl(355.636 calc(1*64.706%) 50% /1);\n }\n\n .discord-button-disabled {\n opacity: 0.5;\n cursor: not-allowed;\n pointer-events: none;\n }\n\n .discord-select-menu {\n margin-top: 2px;\n margin-bottom: 2px;\n position: relative;\n width: 100%;\n max-width: 500px;\n height: 40px;\n background-color: #2b2d31;\n border-radius: 4px;\n color: #b5bac1;\n cursor: pointer;\n font-family: Whitney, \"Helvetica Neue\", Helvetica, Arial, sans-serif;\n font-size: 14px;\n display: flex;\n align-items: center;\n padding: 0 8px;\n justify-content: space-between;\n box-sizing: border-box;\n border: 1px solid #1e1f22;\n }\n\n .discord-select-menu-disabled {\n opacity: 0.6;\n cursor: not-allowed;\n }\n";
@@ -0,0 +1,114 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.globalStyles = exports.ButtonStyleMapping = exports.baseImageStyle = exports.containerStyle = void 0;
4
+ const discord_js_1 = require("discord.js");
5
+ // Container styles
6
+ exports.containerStyle = {
7
+ display: 'grid',
8
+ gap: '4px',
9
+ width: '100%',
10
+ maxWidth: '500px',
11
+ borderRadius: '8px',
12
+ overflow: 'hidden',
13
+ };
14
+ // Base image style
15
+ exports.baseImageStyle = {
16
+ overflow: 'hidden',
17
+ position: 'relative',
18
+ background: '#2b2d31',
19
+ };
20
+ // Button style mapping
21
+ exports.ButtonStyleMapping = {
22
+ [discord_js_1.ButtonStyle.Primary]: 'primary',
23
+ [discord_js_1.ButtonStyle.Secondary]: 'secondary',
24
+ [discord_js_1.ButtonStyle.Success]: 'success',
25
+ [discord_js_1.ButtonStyle.Danger]: 'destructive',
26
+ [discord_js_1.ButtonStyle.Link]: 'secondary',
27
+ };
28
+ exports.globalStyles = `
29
+ .discord-container {
30
+ display: grid;
31
+ gap: 4px;
32
+ width: 100%;
33
+ max-width: 500px;
34
+ border-radius: 8px;
35
+ overflow: hidden;
36
+ }
37
+
38
+ .discord-base-image {
39
+ overflow: hidden;
40
+ position: relative;
41
+ background: #2b2d31;
42
+ }
43
+
44
+ .discord-button {
45
+ color: #ffffff !important;
46
+ padding: 2px 16px;
47
+ border-radius: 8px;
48
+ text-decoration: none !important;
49
+ display: inline-flex;
50
+ align-items: center;
51
+ justify-content: center;
52
+ font-size: 14px;
53
+ font-weight: 500;
54
+ height: 32px;
55
+ min-height: 32px;
56
+ min-width: 60px;
57
+ cursor: pointer;
58
+ font-family: Whitney, "Helvetica Neue", Helvetica, Arial, sans-serif;
59
+ text-align: center;
60
+ box-sizing: border-box;
61
+ border: none;
62
+ outline: none;
63
+ transition: background-color 0.2s ease;
64
+ }
65
+
66
+ .discord-button-primary {
67
+ background-color: hsl(234.935 calc(1*85.556%) 64.706% /1);
68
+ }
69
+
70
+ .discord-button-secondary {
71
+ background-color: hsl(240 calc(1*4%) 60.784% /0.12156862745098039);
72
+ }
73
+
74
+ .discord-button-success {
75
+ background-color: hsl(145.97 calc(1*100%) 26.275% /1);
76
+ }
77
+
78
+ .discord-button-destructive {
79
+ background-color: hsl(355.636 calc(1*64.706%) 50% /1);
80
+ }
81
+
82
+ .discord-button-disabled {
83
+ opacity: 0.5;
84
+ cursor: not-allowed;
85
+ pointer-events: none;
86
+ }
87
+
88
+ .discord-select-menu {
89
+ margin-top: 2px;
90
+ margin-bottom: 2px;
91
+ position: relative;
92
+ width: 100%;
93
+ max-width: 500px;
94
+ height: 40px;
95
+ background-color: #2b2d31;
96
+ border-radius: 4px;
97
+ color: #b5bac1;
98
+ cursor: pointer;
99
+ font-family: Whitney, "Helvetica Neue", Helvetica, Arial, sans-serif;
100
+ font-size: 14px;
101
+ display: flex;
102
+ align-items: center;
103
+ padding: 0 8px;
104
+ justify-content: space-between;
105
+ box-sizing: border-box;
106
+ border: 1px solid #1e1f22;
107
+ }
108
+
109
+ .discord-select-menu-disabled {
110
+ opacity: 0.6;
111
+ cursor: not-allowed;
112
+ }
113
+ `;
114
+ //# sourceMappingURL=styles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"styles.js","sourceRoot":"","sources":["../../../../src/generator/renderers/components/styles.ts"],"names":[],"mappings":";;;AACA,2CAAyC;AAEzC,mBAAmB;AACN,QAAA,cAAc,GAAG;IAC5B,OAAO,EAAE,MAAM;IACf,GAAG,EAAE,KAAK;IACV,KAAK,EAAE,MAAM;IACb,QAAQ,EAAE,OAAO;IACjB,YAAY,EAAE,KAAK;IACnB,QAAQ,EAAE,QAAQ;CACK,CAAC;AAE1B,mBAAmB;AACN,QAAA,cAAc,GAAG;IAC5B,QAAQ,EAAE,QAAQ;IAClB,QAAQ,EAAE,UAAU;IACpB,UAAU,EAAE,SAAS;CACE,CAAC;AAE1B,uBAAuB;AACV,QAAA,kBAAkB,GAAG;IAChC,CAAC,wBAAW,CAAC,OAAO,CAAC,EAAE,SAAS;IAChC,CAAC,wBAAW,CAAC,SAAS,CAAC,EAAE,WAAW;IACpC,CAAC,wBAAW,CAAC,OAAO,CAAC,EAAE,SAAS;IAChC,CAAC,wBAAW,CAAC,MAAM,CAAC,EAAE,aAAa;IACnC,CAAC,wBAAW,CAAC,IAAI,CAAC,EAAE,WAAW;CACvB,CAAC;AAEE,QAAA,YAAY,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAqF3B,CAAC"}
@@ -0,0 +1,42 @@
1
+ import { ComponentType } from 'discord.js';
2
+ export declare function getSelectTypeLabel(type: ComponentType): string;
3
+ /**
4
+ * Gets the grid layout for media galleries based on count
5
+ */
6
+ export declare function getGalleryLayout(count: number): {
7
+ gridTemplateColumns: string;
8
+ gridTemplateRows: string;
9
+ maxWidth: string;
10
+ display: "grid";
11
+ gap: string;
12
+ width: string;
13
+ borderRadius: string;
14
+ overflow: "hidden";
15
+ };
16
+ /**
17
+ * Gets the style for an individual image based on its position and total count
18
+ */
19
+ export declare function getImageStyle(idx: number, count: number): {
20
+ overflow: "hidden";
21
+ position: "relative";
22
+ background: string;
23
+ } | {
24
+ aspectRatio: string;
25
+ borderRadius: string;
26
+ overflow: "hidden";
27
+ position: "relative";
28
+ background: string;
29
+ } | {
30
+ gridRow: string;
31
+ gridColumn: string;
32
+ aspectRatio: string;
33
+ overflow: "hidden";
34
+ position: "relative";
35
+ background: string;
36
+ } | {
37
+ gridRow: string;
38
+ gridColumn: string;
39
+ overflow: "hidden";
40
+ position: "relative";
41
+ background: string;
42
+ };