@flowtomic/ui 0.1.9 → 0.1.11

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 (99) hide show
  1. package/dist/blocks/developer-panel/page.js +1 -1
  2. package/dist/components/atoms/actions/badge/badge.d.ts +2 -2
  3. package/dist/components/atoms/actions/button/button.d.ts +2 -2
  4. package/dist/components/atoms/animation/encrypted-text/encrypted-text.js +1 -1
  5. package/dist/components/atoms/animation/sliding-number/sliding-number.d.ts.map +1 -1
  6. package/dist/components/atoms/animation/sliding-number/sliding-number.js +1 -1
  7. package/dist/components/atoms/data-display/qr-code/qr-code.d.ts +3 -3
  8. package/dist/components/atoms/data-display/qr-code/qr-code.d.ts.map +1 -1
  9. package/dist/components/atoms/data-display/qr-code/qr-code.js +4 -3
  10. package/dist/components/atoms/feedback/alert/alert.d.ts +1 -1
  11. package/dist/components/atoms/feedback/alert-dialog/alert-dialog.d.ts +2 -2
  12. package/dist/components/atoms/feedback/tooltip/tooltip.js +3 -3
  13. package/dist/components/atoms/forms/input/input.d.ts +2 -2
  14. package/dist/components/atoms/forms/toggle/toggle.d.ts +2 -2
  15. package/dist/components/atoms/index.d.ts +2 -0
  16. package/dist/components/atoms/index.d.ts.map +1 -1
  17. package/dist/components/atoms/index.js +1 -0
  18. package/dist/components/atoms/layout/sidebar/sidebar.d.ts +2 -2
  19. package/dist/components/atoms/navigation/command/command.d.ts +13 -13
  20. package/dist/components/atoms/widget-resize-handle/index.d.ts +3 -0
  21. package/dist/components/atoms/widget-resize-handle/index.d.ts.map +1 -0
  22. package/dist/components/atoms/widget-resize-handle/index.js +1 -0
  23. package/dist/components/atoms/widget-resize-handle/widget-resize-handle.d.ts +60 -0
  24. package/dist/components/atoms/widget-resize-handle/widget-resize-handle.d.ts.map +1 -0
  25. package/dist/components/atoms/widget-resize-handle/widget-resize-handle.js +75 -0
  26. package/dist/components/molecules/draggable-widget/draggable-widget.d.ts +73 -0
  27. package/dist/components/molecules/draggable-widget/draggable-widget.d.ts.map +1 -0
  28. package/dist/components/molecules/draggable-widget/draggable-widget.js +44 -0
  29. package/dist/components/molecules/draggable-widget/index.d.ts +3 -0
  30. package/dist/components/molecules/draggable-widget/index.d.ts.map +1 -0
  31. package/dist/components/molecules/draggable-widget/index.js +1 -0
  32. package/dist/components/molecules/edit-mode-toggle/edit-mode-toggle.d.ts +41 -0
  33. package/dist/components/molecules/edit-mode-toggle/edit-mode-toggle.d.ts.map +1 -0
  34. package/dist/components/molecules/edit-mode-toggle/edit-mode-toggle.js +26 -0
  35. package/dist/components/molecules/edit-mode-toggle/index.d.ts +3 -0
  36. package/dist/components/molecules/edit-mode-toggle/index.d.ts.map +1 -0
  37. package/dist/components/molecules/edit-mode-toggle/index.js +1 -0
  38. package/dist/components/molecules/forms/autocomplete/autocomplete-context.d.ts +1 -1
  39. package/dist/components/molecules/forms/autocomplete/autocomplete-context.d.ts.map +1 -1
  40. package/dist/components/molecules/forms/autocomplete/autocomplete-item.d.ts.map +1 -1
  41. package/dist/components/molecules/forms/autocomplete/autocomplete-section.d.ts.map +1 -1
  42. package/dist/components/molecules/forms/autocomplete/autocomplete.d.ts +1 -1
  43. package/dist/components/molecules/forms/autocomplete/autocomplete.d.ts.map +1 -1
  44. package/dist/components/molecules/forms/autocomplete/autocomplete.js +6 -6
  45. package/dist/components/molecules/forms/autocomplete/index.d.ts +2 -2
  46. package/dist/components/molecules/forms/autocomplete/index.d.ts.map +1 -1
  47. package/dist/components/molecules/forms/autocomplete/index.js +1 -1
  48. package/dist/components/molecules/forms/item/item.d.ts +2 -2
  49. package/dist/components/molecules/forms/text-editor/text-editor.d.ts.map +1 -1
  50. package/dist/components/molecules/forms/text-editor/text-editor.js +14 -13
  51. package/dist/components/molecules/index.d.ts +8 -2
  52. package/dist/components/molecules/index.d.ts.map +1 -1
  53. package/dist/components/molecules/index.js +4 -1
  54. package/dist/components/molecules/navigation/menu-dock/menu-dock.d.ts.map +1 -1
  55. package/dist/components/molecules/navigation/menu-dock/menu-dock.js +25 -28
  56. package/dist/components/molecules/widget-renderer/index.d.ts +3 -0
  57. package/dist/components/molecules/widget-renderer/index.d.ts.map +1 -0
  58. package/dist/components/molecules/widget-renderer/index.js +1 -0
  59. package/dist/components/molecules/widget-renderer/widget-renderer.d.ts +46 -0
  60. package/dist/components/molecules/widget-renderer/widget-renderer.d.ts.map +1 -0
  61. package/dist/components/molecules/widget-renderer/widget-renderer.js +37 -0
  62. package/dist/components/organisms/document-editor/document-editor.d.ts.map +1 -1
  63. package/dist/components/organisms/document-editor/document-editor.js +4 -4
  64. package/dist/components/organisms/document-editor/index.d.ts +1 -1
  65. package/dist/components/organisms/document-editor/index.d.ts.map +1 -1
  66. package/dist/components/organisms/draggable-dashboard-grid/draggable-dashboard-grid.d.ts +65 -0
  67. package/dist/components/organisms/draggable-dashboard-grid/draggable-dashboard-grid.d.ts.map +1 -0
  68. package/dist/components/organisms/draggable-dashboard-grid/draggable-dashboard-grid.js +124 -0
  69. package/dist/components/organisms/draggable-dashboard-grid/index.d.ts +3 -0
  70. package/dist/components/organisms/draggable-dashboard-grid/index.d.ts.map +1 -0
  71. package/dist/components/organisms/draggable-dashboard-grid/index.js +1 -0
  72. package/dist/components/organisms/form-layout/form-layout.d.ts +2 -2
  73. package/dist/components/organisms/form-layout/form-layout.d.ts.map +1 -1
  74. package/dist/components/organisms/form-layout/form-layout.js +11 -9
  75. package/dist/components/organisms/form-layout/index.d.ts +1 -1
  76. package/dist/components/organisms/form-layout/index.d.ts.map +1 -1
  77. package/dist/components/organisms/index.d.ts +6 -0
  78. package/dist/components/organisms/index.d.ts.map +1 -1
  79. package/dist/components/organisms/index.js +3 -0
  80. package/dist/components/organisms/model-selector/model-selector.d.ts +1 -1
  81. package/dist/components/organisms/widget-config-modal/index.d.ts +3 -0
  82. package/dist/components/organisms/widget-config-modal/index.d.ts.map +1 -0
  83. package/dist/components/organisms/widget-config-modal/index.js +1 -0
  84. package/dist/components/organisms/widget-config-modal/widget-config-modal.d.ts +57 -0
  85. package/dist/components/organisms/widget-config-modal/widget-config-modal.d.ts.map +1 -0
  86. package/dist/components/organisms/widget-config-modal/widget-config-modal.js +35 -0
  87. package/dist/components/organisms/widget-palette/index.d.ts +3 -0
  88. package/dist/components/organisms/widget-palette/index.d.ts.map +1 -0
  89. package/dist/components/organisms/widget-palette/index.js +1 -0
  90. package/dist/components/organisms/widget-palette/widget-palette.d.ts +71 -0
  91. package/dist/components/organisms/widget-palette/widget-palette.d.ts.map +1 -0
  92. package/dist/components/organisms/widget-palette/widget-palette.js +42 -0
  93. package/dist/index.d.ts +1 -0
  94. package/dist/index.d.ts.map +1 -1
  95. package/dist/index.js +513 -509
  96. package/dist/types/dashboard.d.ts +74 -0
  97. package/dist/types/dashboard.d.ts.map +1 -0
  98. package/dist/types/dashboard.js +7 -0
  99. package/package.json +4 -3
@@ -0,0 +1,71 @@
1
+ /**
2
+ * WidgetPalette - Organism Component
3
+ *
4
+ * Sidebar com widgets disponíveis para adicionar ao dashboard.
5
+ * Componente genérico e totalmente configurável via props.
6
+ */
7
+ export interface WidgetPaletteItem {
8
+ /**
9
+ * ID único do widget
10
+ */
11
+ id: string;
12
+ /**
13
+ * Tipo do widget (string genérico)
14
+ */
15
+ type: string;
16
+ /**
17
+ * Nome do widget
18
+ */
19
+ name: string;
20
+ /**
21
+ * Descrição do widget
22
+ */
23
+ description: string;
24
+ /**
25
+ * Ícone do widget
26
+ */
27
+ icon: React.ComponentType<{
28
+ className?: string;
29
+ }>;
30
+ /**
31
+ * Tamanho padrão do widget (largura x altura)
32
+ */
33
+ defaultSize: {
34
+ w: number;
35
+ h: number;
36
+ };
37
+ }
38
+ export interface WidgetPaletteProps {
39
+ /**
40
+ * Se a paleta está aberta
41
+ */
42
+ isOpen: boolean;
43
+ /**
44
+ * Lista de widgets disponíveis (obrigatória)
45
+ */
46
+ widgets: WidgetPaletteItem[];
47
+ /**
48
+ * Callback para fechar a paleta
49
+ */
50
+ onClose?: () => void;
51
+ /**
52
+ * Título da paleta (opcional)
53
+ */
54
+ title?: string;
55
+ /**
56
+ * Descrição da paleta (opcional)
57
+ */
58
+ description?: string;
59
+ /**
60
+ * Classe CSS adicional
61
+ */
62
+ className?: string;
63
+ }
64
+ /**
65
+ * Paleta de widgets
66
+ *
67
+ * Componente genérico que exibe uma lista de widgets arrastáveis.
68
+ * Totalmente configurável via props, sem widgets hardcoded.
69
+ */
70
+ export declare function WidgetPalette({ isOpen, widgets, onClose, title, description, className, }: WidgetPaletteProps): import("react/jsx-runtime").JSX.Element | null;
71
+ //# sourceMappingURL=widget-palette.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"widget-palette.d.ts","sourceRoot":"","sources":["../../../../src/components/organisms/widget-palette/widget-palette.tsx"],"names":[],"mappings":"AAAA;;;;;GAKG;AAMH,MAAM,WAAW,iBAAiB;IAChC;;OAEG;IACH,EAAE,EAAE,MAAM,CAAC;IAEX;;OAEG;IACH,IAAI,EAAE,MAAM,CAAC;IAEb;;OAEG;IACH,IAAI,EAAE,MAAM,CAAC;IAEb;;OAEG;IACH,WAAW,EAAE,MAAM,CAAC;IAEpB;;OAEG;IACH,IAAI,EAAE,KAAK,CAAC,aAAa,CAAC;QAAE,SAAS,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAElD;;OAEG;IACH,WAAW,EAAE;QAAE,CAAC,EAAE,MAAM,CAAC;QAAC,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC;CACvC;AAED,MAAM,WAAW,kBAAkB;IACjC;;OAEG;IACH,MAAM,EAAE,OAAO,CAAC;IAEhB;;OAEG;IACH,OAAO,EAAE,iBAAiB,EAAE,CAAC;IAE7B;;OAEG;IACH,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IAErB;;OAEG;IACH,KAAK,CAAC,EAAE,MAAM,CAAC;IAEf;;OAEG;IACH,WAAW,CAAC,EAAE,MAAM,CAAC;IAErB;;OAEG;IACH,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAsDD;;;;;GAKG;AACH,wBAAgB,aAAa,CAAC,EAC5B,MAAM,EACN,OAAO,EACP,OAAO,EACP,KAA6B,EAC7B,WAA2D,EAC3D,SAAS,GACV,EAAE,kBAAkB,kDAkDpB"}
@@ -0,0 +1,42 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ /**
3
+ * WidgetPalette - Organism Component
4
+ *
5
+ * Sidebar com widgets disponíveis para adicionar ao dashboard.
6
+ * Componente genérico e totalmente configurável via props.
7
+ */
8
+ import { useDraggable } from "@dnd-kit/core";
9
+ import { X } from "lucide-react";
10
+ import { cn } from "@/lib/utils";
11
+ /**
12
+ * Item de widget arrastável da paleta
13
+ */
14
+ function DraggableWidgetItem({ widget }) {
15
+ const { attributes, listeners, setNodeRef, transform, isDragging } = useDraggable({
16
+ id: `palette-${widget.id}`,
17
+ data: {
18
+ type: "palette-widget",
19
+ widgetId: widget.id,
20
+ widgetType: widget.type,
21
+ defaultSize: widget.defaultSize,
22
+ },
23
+ });
24
+ const style = transform
25
+ ? {
26
+ transform: `translate3d(${transform.x}px, ${transform.y}px, 0)`,
27
+ }
28
+ : undefined;
29
+ const Icon = widget.icon;
30
+ return (_jsx("div", { ref: setNodeRef, style: style, ...listeners, ...attributes, className: cn("p-4 rounded-lg border-2 border-border bg-card", "cursor-grab active:cursor-grabbing", "hover:border-primary hover:shadow-md", "transition-all duration-200", isDragging && "opacity-50 z-50"), children: _jsxs("div", { className: "flex items-start gap-3", children: [_jsx("div", { className: "p-2 rounded-md bg-primary/10", children: _jsx(Icon, { className: "w-5 h-5 text-primary" }) }), _jsxs("div", { className: "flex-1 min-w-0", children: [_jsx("h4", { className: "font-semibold text-sm text-foreground mb-1", children: widget.name }), _jsx("p", { className: "text-xs text-muted-foreground line-clamp-2", children: widget.description }), _jsxs("div", { className: "mt-2 text-xs text-muted-foreground", children: [widget.defaultSize.w, " \u00D7 ", widget.defaultSize.h] })] })] }) }));
31
+ }
32
+ /**
33
+ * Paleta de widgets
34
+ *
35
+ * Componente genérico que exibe uma lista de widgets arrastáveis.
36
+ * Totalmente configurável via props, sem widgets hardcoded.
37
+ */
38
+ export function WidgetPalette({ isOpen, widgets, onClose, title = "Widgets Disponíveis", description = "Arraste widgets para adicionar ao dashboard", className, }) {
39
+ if (!isOpen)
40
+ return null;
41
+ return (_jsxs("div", { className: cn("fixed right-0 top-0 h-full w-80 bg-background border-l border-border", "shadow-lg z-40 transition-transform duration-300", "flex flex-col", className), children: [_jsxs("div", { className: "p-4 border-b border-border", children: [_jsxs("div", { className: "flex items-center justify-between", children: [_jsx("h3", { className: "text-lg font-semibold text-foreground", children: title }), onClose && (_jsx("button", { type: "button", onClick: onClose, className: "p-1 rounded-md hover:bg-accent transition-colors", "aria-label": "Fechar paleta", children: _jsx(X, { className: "w-5 h-5" }) }))] }), _jsx("p", { className: "text-sm text-muted-foreground mt-1", children: description })] }), _jsx("div", { className: "flex-1 overflow-y-auto p-4 space-y-3", children: widgets.length === 0 ? (_jsx("div", { className: "text-center py-8 text-sm text-muted-foreground", children: "Nenhum widget dispon\u00EDvel" })) : (widgets.map((widget) => _jsx(DraggableWidgetItem, { widget: widget }, widget.id))) }), _jsx("div", { className: "p-4 border-t border-border bg-muted/50", children: _jsxs("p", { className: "text-xs text-muted-foreground text-center", children: [widgets.length, " ", widgets.length === 1 ? "widget" : "widgets", " dispon\u00EDvel", widgets.length !== 1 ? "eis" : ""] }) })] }));
42
+ }
package/dist/index.d.ts CHANGED
@@ -13,4 +13,5 @@ export * from "./components/atoms";
13
13
  export * from "./components/molecules";
14
14
  export * from "./components/organisms";
15
15
  export { cn } from "./lib/utils";
16
+ export type { GridConfig, WidgetConfig, WidgetLayout } from "./types/dashboard";
16
17
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAGH,cAAc,oBAAoB,CAAC;AAGnC,cAAc,wBAAwB,CAAC;AAGvC,cAAc,wBAAwB,CAAC;AAGvC,OAAO,EAAE,EAAE,EAAE,MAAM,aAAa,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAGH,cAAc,oBAAoB,CAAC;AAGnC,cAAc,wBAAwB,CAAC;AAGvC,cAAc,wBAAwB,CAAC;AAEvC,OAAO,EAAE,EAAE,EAAE,MAAM,aAAa,CAAC;AAEjC,YAAY,EAAE,UAAU,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC"}