react-pivottable-plus 1.0.0

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.
@@ -0,0 +1,381 @@
1
+ "use strict";
2
+
3
+ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.RadixUI = RadixUI;
8
+ var _react = _interopRequireWildcard(require("react"));
9
+ var _usePivot2 = require("../hooks/usePivot");
10
+ var Select = _interopRequireWildcard(require("@radix-ui/react-select"));
11
+ var Popover = _interopRequireWildcard(require("@radix-ui/react-popover"));
12
+ var _lucideReact = require("lucide-react");
13
+ var _sortablejs = _interopRequireDefault(require("sortablejs"));
14
+ var _PivotTable = _interopRequireDefault(require("../PivotTable"));
15
+ var _Utilities = require("../Utilities");
16
+ var _clsx = _interopRequireDefault(require("clsx"));
17
+ var _tailwindMerge = require("tailwind-merge");
18
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; }
19
+ function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, "default": e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); }
20
+ function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
21
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
22
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
23
+ function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
24
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
25
+ function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
26
+ function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); }
27
+ function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
28
+ function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
29
+ function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); }
30
+ function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); }
31
+ function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
32
+ function cn() {
33
+ for (var _len = arguments.length, inputs = new Array(_len), _key = 0; _key < _len; _key++) {
34
+ inputs[_key] = arguments[_key];
35
+ }
36
+ return (0, _tailwindMerge.twMerge)((0, _clsx["default"])(inputs));
37
+ }
38
+ var DnDContainer = function DnDContainer(_ref) {
39
+ var list = _ref.list,
40
+ setList = _ref.setList,
41
+ className = _ref.className,
42
+ children = _ref.children;
43
+ var el = (0, _react.useRef)(null);
44
+ var setListRef = (0, _react.useRef)(setList);
45
+ var listRef = (0, _react.useRef)(list);
46
+ (0, _react.useEffect)(function () {
47
+ setListRef.current = setList;
48
+ }, [setList]);
49
+ (0, _react.useEffect)(function () {
50
+ listRef.current = list;
51
+ if (el.current && el.current.sortable) {
52
+ el.current.sortable._currentList = list;
53
+ }
54
+ }, [list]);
55
+ (0, _react.useEffect)(function () {
56
+ var sortable = _sortablejs["default"].create(el.current, {
57
+ group: 'shared',
58
+ ghostClass: 'opacity-50',
59
+ animation: 150,
60
+ onEnd: function onEnd(evt) {
61
+ var from = evt.from,
62
+ to = evt.to,
63
+ oldIndex = evt.oldIndex,
64
+ newIndex = evt.newIndex,
65
+ item = evt.item;
66
+ var itemId = item.getAttribute('data-id');
67
+
68
+ // ── REVERSIÓN SÍNCRONA DEL DOM ──
69
+ if (from !== to || oldIndex !== newIndex) {
70
+ item.remove();
71
+ var nextEl = from.children[oldIndex];
72
+ if (nextEl) {
73
+ from.insertBefore(item, nextEl);
74
+ } else {
75
+ from.appendChild(item);
76
+ }
77
+ }
78
+ if (from === to) {
79
+ // ── Reordenamiento interno ──
80
+ var newOrder = _toConsumableArray(listRef.current);
81
+ newOrder.splice(oldIndex, 1);
82
+ newOrder.splice(newIndex, 0, itemId);
83
+ if (setListRef.current) {
84
+ setListRef.current(newOrder);
85
+ }
86
+ } else {
87
+ // ── Movimiento entre listas ──
88
+ var fromSortable = from.sortable;
89
+ var toSortable = to.sortable;
90
+ if (fromSortable !== null && fromSortable !== void 0 && fromSortable._setList && toSortable !== null && toSortable !== void 0 && toSortable._setList) {
91
+ var sourceItems = fromSortable._currentList.filter(function (id) {
92
+ return id !== itemId;
93
+ });
94
+ var targetItems = _toConsumableArray(toSortable._currentList);
95
+ targetItems.splice(newIndex, 0, itemId);
96
+ fromSortable._setList(sourceItems);
97
+ toSortable._setList(targetItems);
98
+ }
99
+ }
100
+ }
101
+ });
102
+ el.current.sortable = sortable;
103
+ sortable._setList = function (newOrder) {
104
+ if (setListRef.current) {
105
+ setListRef.current(newOrder);
106
+ }
107
+ };
108
+ sortable._currentList = listRef.current;
109
+ return function () {
110
+ return sortable.destroy();
111
+ };
112
+ }, []);
113
+ return /*#__PURE__*/_react["default"].createElement("div", {
114
+ className: className
115
+ }, /*#__PURE__*/_react["default"].createElement("ul", {
116
+ ref: el,
117
+ style: {
118
+ listStyleType: 'none',
119
+ padding: 0,
120
+ margin: 0,
121
+ minHeight: '1.5rem',
122
+ width: '100%',
123
+ display: 'flex',
124
+ flexWrap: 'wrap',
125
+ gap: '8px'
126
+ }
127
+ }, _react["default"].Children.map(children, function (child) {
128
+ return /*#__PURE__*/_react["default"].createElement("li", {
129
+ key: child.key,
130
+ "data-id": child.props['data-id']
131
+ }, child);
132
+ })));
133
+ };
134
+ var RadixSelect = function RadixSelect(_ref2) {
135
+ var label = _ref2.label,
136
+ value = _ref2.value,
137
+ values = _ref2.values,
138
+ onChange = _ref2.onChange;
139
+ return /*#__PURE__*/_react["default"].createElement("div", {
140
+ className: "flex flex-col gap-1.5 min-w-[180px]"
141
+ }, /*#__PURE__*/_react["default"].createElement("label", {
142
+ className: "text-[10px] font-black text-slate-400 uppercase tracking-widest"
143
+ }, label), /*#__PURE__*/_react["default"].createElement(Select.Root, {
144
+ value: value,
145
+ onValueChange: onChange
146
+ }, /*#__PURE__*/_react["default"].createElement(Select.Trigger, {
147
+ className: "flex items-center justify-between w-full px-4 py-2 text-sm bg-white border border-slate-200 rounded-xl hover:border-blue-400 focus:ring-4 focus:ring-blue-500/10 outline-none transition-all shadow-sm"
148
+ }, /*#__PURE__*/_react["default"].createElement(Select.Value, null), /*#__PURE__*/_react["default"].createElement(Select.Icon, null, /*#__PURE__*/_react["default"].createElement(_lucideReact.ChevronDown, {
149
+ size: 14,
150
+ className: "text-slate-400"
151
+ }))), /*#__PURE__*/_react["default"].createElement(Select.Portal, null, /*#__PURE__*/_react["default"].createElement(Select.Content, {
152
+ className: "overflow-hidden bg-white rounded-2xl shadow-2xl border border-slate-100 z-[1000] animate-in fade-in zoom-in-95 duration-100"
153
+ }, /*#__PURE__*/_react["default"].createElement(Select.Viewport, {
154
+ className: "p-2"
155
+ }, values.map(function (v) {
156
+ return /*#__PURE__*/_react["default"].createElement(Select.Item, {
157
+ key: v,
158
+ value: v,
159
+ className: "flex items-center gap-2 px-8 py-2.5 text-sm text-slate-700 rounded-lg cursor-default select-none hover:bg-blue-50 focus:bg-blue-50 outline-none relative transition-colors"
160
+ }, /*#__PURE__*/_react["default"].createElement(Select.ItemText, null, v), /*#__PURE__*/_react["default"].createElement(Select.ItemIndicator, {
161
+ className: "absolute left-2 flex items-center justify-center"
162
+ }, /*#__PURE__*/_react["default"].createElement(_lucideReact.Check, {
163
+ size: 14,
164
+ className: "text-blue-600"
165
+ })));
166
+ }))))));
167
+ };
168
+ function RadixUI(props) {
169
+ var _usePivot = (0, _usePivot2.usePivot)(props),
170
+ pivotProps = _usePivot.props,
171
+ pivotState = _usePivot.state,
172
+ actions = _usePivot.actions;
173
+ var aggregatorName = pivotProps.aggregatorName;
174
+ var rendererName = pivotProps.rendererName;
175
+ var pivotData = new _Utilities.PivotData(_objectSpread(_objectSpread({}, pivotProps), {}, {
176
+ data: pivotState.materializedInput
177
+ }));
178
+ var totalPivotRows = pivotData.getRowKeys().length;
179
+ var totalRecords = pivotState.materializedInput.length;
180
+ var totalPages = Math.ceil(totalPivotRows / (pivotProps.pageSize || 20));
181
+ var unusedList = Object.keys(pivotState.attrValues).filter(function (e) {
182
+ return e && e.trim() !== '' && !pivotProps.rows.includes(e) && !pivotProps.cols.includes(e);
183
+ }).sort((0, _Utilities.sortAs)(pivotState.unusedOrder || []));
184
+ var colList = pivotProps.cols.filter(function (e) {
185
+ return e && e.trim() !== '';
186
+ });
187
+ var rowList = pivotProps.rows.filter(function (e) {
188
+ return e && e.trim() !== '';
189
+ });
190
+ var renderAttribute = function renderAttribute(attr) {
191
+ return /*#__PURE__*/_react["default"].createElement("div", {
192
+ key: attr,
193
+ className: "inline-flex items-center gap-2 bg-white border border-slate-200 rounded-xl px-3 py-1.5 text-[13px] font-semibold text-slate-700 shadow-sm cursor-grab hover:bg-slate-50 transition-colors group",
194
+ "data-id": attr
195
+ }, /*#__PURE__*/_react["default"].createElement(_lucideReact.GripVertical, {
196
+ size: 14,
197
+ className: "text-slate-300 group-hover:text-slate-400 transition-colors"
198
+ }), /*#__PURE__*/_react["default"].createElement("span", null, attr), /*#__PURE__*/_react["default"].createElement(Popover.Root, null, /*#__PURE__*/_react["default"].createElement(Popover.Trigger, {
199
+ asChild: true
200
+ }, /*#__PURE__*/_react["default"].createElement("button", {
201
+ className: cn("text-slate-400 hover:text-slate-600 focus:outline-none ml-1 flex items-center justify-center p-0.5 rounded-sm transition-colors", pivotProps.valueFilter[attr] && "text-blue-600")
202
+ }, /*#__PURE__*/_react["default"].createElement(_lucideReact.Filter, {
203
+ size: 14
204
+ }))), /*#__PURE__*/_react["default"].createElement(Popover.Portal, null, /*#__PURE__*/_react["default"].createElement(Popover.Content, {
205
+ className: "w-72 p-6 bg-white rounded-3xl shadow-2xl border border-slate-100 z-[1000] outline-none"
206
+ }, /*#__PURE__*/_react["default"].createElement("h4", {
207
+ className: "font-black text-slate-900 text-xs uppercase tracking-widest mb-4"
208
+ }, "Filtrar: ", attr), /*#__PURE__*/_react["default"].createElement("div", {
209
+ className: "max-h-60 overflow-y-auto space-y-2 mb-4 pr-2 custom-scrollbar"
210
+ }, Object.keys(pivotState.attrValues[attr] || {}).map(function (v) {
211
+ return /*#__PURE__*/_react["default"].createElement("div", {
212
+ key: v,
213
+ className: "flex items-center gap-3 text-sm py-1.5 px-2 hover:bg-slate-50 rounded-lg transition-colors cursor-pointer"
214
+ }, /*#__PURE__*/_react["default"].createElement("input", {
215
+ type: "checkbox",
216
+ checked: !(v in (pivotProps.valueFilter[attr] || {})),
217
+ onChange: function onChange() {
218
+ return actions.toggleFilter(attr, v);
219
+ },
220
+ className: "rounded-md border-slate-300 text-blue-600 focus:ring-blue-500 w-4 h-4"
221
+ }), /*#__PURE__*/_react["default"].createElement("span", {
222
+ className: "text-slate-600 font-medium"
223
+ }, v === 'null' ? /*#__PURE__*/_react["default"].createElement("em", null, "null") : v));
224
+ })), /*#__PURE__*/_react["default"].createElement(Popover.Arrow, {
225
+ className: "fill-white"
226
+ })))));
227
+ };
228
+ return /*#__PURE__*/_react["default"].createElement("div", {
229
+ className: "flex flex-col bg-white border border-slate-200 rounded-lg overflow-hidden font-sans text-slate-800 text-sm shadow-sm"
230
+ }, /*#__PURE__*/_react["default"].createElement("div", {
231
+ className: "flex w-full border-b border-slate-200 min-h-[4rem]"
232
+ }, /*#__PURE__*/_react["default"].createElement("div", {
233
+ className: "w-[300px] p-4 border-r border-slate-200 bg-white flex flex-col justify-start flex-shrink-0"
234
+ }, /*#__PURE__*/_react["default"].createElement(RadixSelect, {
235
+ label: "Visualizaci\xF3n",
236
+ value: rendererName,
237
+ values: Object.keys(pivotProps.renderers),
238
+ onChange: function onChange(v) {
239
+ return actions.updateProp('rendererName', v);
240
+ }
241
+ })), /*#__PURE__*/_react["default"].createElement("div", {
242
+ className: "flex-1 p-4 bg-slate-50/80"
243
+ }, /*#__PURE__*/_react["default"].createElement(DnDContainer, {
244
+ list: unusedList,
245
+ setList: function setList(newOrder) {
246
+ actions.setUnusedOrder(newOrder);
247
+ },
248
+ className: "flex flex-wrap gap-2 w-full min-h-[1.5rem]"
249
+ }, unusedList.map(renderAttribute)))), /*#__PURE__*/_react["default"].createElement("div", {
250
+ className: "flex w-full border-b border-slate-200 min-h-[4rem]"
251
+ }, /*#__PURE__*/_react["default"].createElement("div", {
252
+ className: "w-[300px] p-4 border-r border-slate-200 bg-slate-50/30 flex-shrink-0 flex items-start"
253
+ }, /*#__PURE__*/_react["default"].createElement("div", {
254
+ className: "flex flex-col gap-2 w-full"
255
+ }, /*#__PURE__*/_react["default"].createElement("div", {
256
+ className: "flex items-center gap-2"
257
+ }, /*#__PURE__*/_react["default"].createElement("div", {
258
+ className: "flex-1"
259
+ }, /*#__PURE__*/_react["default"].createElement(RadixSelect, {
260
+ label: "Agregador",
261
+ value: aggregatorName,
262
+ values: Object.keys(pivotProps.aggregators),
263
+ onChange: function onChange(v) {
264
+ return actions.updateProp('aggregatorName', v);
265
+ }
266
+ })), /*#__PURE__*/_react["default"].createElement("div", {
267
+ className: "flex items-center text-slate-600 gap-1.5 text-base leading-none"
268
+ }, /*#__PURE__*/_react["default"].createElement("span", {
269
+ className: "cursor-pointer hover:text-slate-900 transition-colors"
270
+ }, "\u2195"), /*#__PURE__*/_react["default"].createElement("span", {
271
+ className: "cursor-pointer hover:text-slate-900 transition-colors"
272
+ }, "\u2194"))), pivotProps.aggregators[aggregatorName]([])().numInputs > 0 && /*#__PURE__*/_react["default"].createElement(RadixSelect, {
273
+ label: "Atributo de Valor",
274
+ value: pivotProps.vals[0] || '',
275
+ values: Object.keys(pivotState.attrValues),
276
+ onChange: function onChange(v) {
277
+ return actions.updateProp('vals', [v]);
278
+ }
279
+ }))), /*#__PURE__*/_react["default"].createElement("div", {
280
+ className: "flex-1 p-4 bg-white"
281
+ }, /*#__PURE__*/_react["default"].createElement(DnDContainer, {
282
+ list: colList,
283
+ setList: function setList(newOrder) {
284
+ actions.updateProp('cols', newOrder);
285
+ },
286
+ className: "flex flex-wrap gap-2 w-full min-h-[1.5rem]"
287
+ }, colList.map(renderAttribute)))), /*#__PURE__*/_react["default"].createElement("div", {
288
+ className: "flex w-full min-h-[400px]"
289
+ }, /*#__PURE__*/_react["default"].createElement("div", {
290
+ className: "w-[300px] p-4 border-r border-slate-200 bg-white flex-shrink-0"
291
+ }, /*#__PURE__*/_react["default"].createElement(DnDContainer, {
292
+ list: rowList,
293
+ setList: function setList(newOrder) {
294
+ actions.updateProp('rows', newOrder);
295
+ },
296
+ className: "flex flex-col gap-2 w-full min-h-[1.5rem]"
297
+ }, rowList.map(renderAttribute))), /*#__PURE__*/_react["default"].createElement("div", {
298
+ className: "flex-1 w-full p-4 bg-slate-50/30 overflow-auto"
299
+ }, /*#__PURE__*/_react["default"].createElement(_PivotTable["default"], _extends({}, pivotProps, {
300
+ data: pivotState.materializedInput
301
+ })))), pivotProps.pagination && /*#__PURE__*/_react["default"].createElement("div", {
302
+ className: "flex items-center justify-between px-6 py-3 border-t border-slate-200 bg-white text-slate-600"
303
+ }, /*#__PURE__*/_react["default"].createElement("div", {
304
+ className: "text-[13px] font-medium"
305
+ }, "Registros: ", /*#__PURE__*/_react["default"].createElement("span", {
306
+ className: "text-slate-900"
307
+ }, totalRecords), " | Filas: ", /*#__PURE__*/_react["default"].createElement("span", {
308
+ className: "text-slate-900"
309
+ }, totalPivotRows)), /*#__PURE__*/_react["default"].createElement("div", {
310
+ className: "flex items-center gap-6"
311
+ }, /*#__PURE__*/_react["default"].createElement("div", {
312
+ className: "flex items-center gap-1.5"
313
+ }, /*#__PURE__*/_react["default"].createElement("button", {
314
+ className: "p-1 rounded-md hover:bg-slate-100 disabled:opacity-30 disabled:cursor-not-allowed transition-colors",
315
+ disabled: pivotProps.page <= 1,
316
+ onClick: function onClick() {
317
+ return actions.updateProp('page', 1);
318
+ }
319
+ }, /*#__PURE__*/_react["default"].createElement(_lucideReact.ChevronsLeft, {
320
+ size: 18
321
+ })), /*#__PURE__*/_react["default"].createElement("button", {
322
+ className: "p-1 rounded-md hover:bg-slate-100 disabled:opacity-30 disabled:cursor-not-allowed transition-colors",
323
+ disabled: pivotProps.page <= 1,
324
+ onClick: function onClick() {
325
+ return actions.updateProp('page', pivotProps.page - 1);
326
+ }
327
+ }, /*#__PURE__*/_react["default"].createElement(_lucideReact.ChevronLeft, {
328
+ size: 18
329
+ })), /*#__PURE__*/_react["default"].createElement("div", {
330
+ className: "flex items-center gap-2 mx-1"
331
+ }, /*#__PURE__*/_react["default"].createElement("span", {
332
+ className: "text-[13px] font-medium"
333
+ }, "P\xE1gina"), /*#__PURE__*/_react["default"].createElement("input", {
334
+ type: "number",
335
+ className: "w-12 h-8 text-center border border-slate-300 rounded-md text-[13px] font-semibold text-slate-900 focus:border-indigo-500 focus:ring-1 focus:ring-indigo-500 outline-none",
336
+ value: pivotProps.page,
337
+ min: 1,
338
+ max: totalPages,
339
+ onChange: function onChange(e) {
340
+ var val = parseInt(e.target.value, 10);
341
+ if (val > 0 && val <= totalPages) {
342
+ actions.updateProp('page', val);
343
+ }
344
+ }
345
+ }), /*#__PURE__*/_react["default"].createElement("span", {
346
+ className: "text-[13px] font-medium text-slate-400"
347
+ }, "de ", totalPages)), /*#__PURE__*/_react["default"].createElement("button", {
348
+ className: "p-1 rounded-md hover:bg-slate-100 disabled:opacity-30 disabled:cursor-not-allowed transition-colors",
349
+ disabled: pivotProps.page >= totalPages,
350
+ onClick: function onClick() {
351
+ return actions.updateProp('page', pivotProps.page + 1);
352
+ }
353
+ }, /*#__PURE__*/_react["default"].createElement(_lucideReact.ChevronRight, {
354
+ size: 18
355
+ })), /*#__PURE__*/_react["default"].createElement("button", {
356
+ className: "p-1 rounded-md hover:bg-slate-100 disabled:opacity-30 disabled:cursor-not-allowed transition-colors",
357
+ disabled: pivotProps.page >= totalPages,
358
+ onClick: function onClick() {
359
+ return actions.updateProp('page', totalPages);
360
+ }
361
+ }, /*#__PURE__*/_react["default"].createElement(_lucideReact.ChevronsRight, {
362
+ size: 18
363
+ }))), /*#__PURE__*/_react["default"].createElement("div", {
364
+ className: "flex items-center gap-2 border-l border-slate-200 pl-6"
365
+ }, /*#__PURE__*/_react["default"].createElement("span", {
366
+ className: "text-[13px] font-medium text-slate-400"
367
+ }, "Mostrar"), /*#__PURE__*/_react["default"].createElement("select", {
368
+ className: "text-[13px] font-semibold border border-slate-300 rounded-md px-2 py-1 focus:border-indigo-500 focus:ring-1 focus:ring-indigo-500 outline-none hover:border-slate-400 bg-white text-slate-900",
369
+ value: pivotProps.pageSize,
370
+ onChange: function onChange(e) {
371
+ actions.updateProp('pageSize', parseInt(e.target.value, 10));
372
+ actions.updateProp('page', 1);
373
+ }
374
+ }, [10, 20, 50, 100].map(function (n) {
375
+ return /*#__PURE__*/_react["default"].createElement("option", {
376
+ key: n,
377
+ value: n
378
+ }, n);
379
+ }))))));
380
+ }
381
+ //# sourceMappingURL=RadixUI.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RadixUI.js","names":["_react","_interopRequireWildcard","require","_usePivot2","Select","Popover","_lucideReact","_sortablejs","_interopRequireDefault","_PivotTable","_Utilities","_clsx","_tailwindMerge","e","__esModule","t","WeakMap","r","n","o","i","f","__proto__","_typeof","has","get","set","_t","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","_extends","assign","bind","arguments","length","apply","ownKeys","keys","getOwnPropertySymbols","filter","enumerable","push","_objectSpread","forEach","_defineProperty","getOwnPropertyDescriptors","defineProperties","_toPropertyKey","value","configurable","writable","_toPrimitive","Symbol","toPrimitive","TypeError","String","Number","_toConsumableArray","_arrayWithoutHoles","_iterableToArray","_unsupportedIterableToArray","_nonIterableSpread","a","_arrayLikeToArray","toString","slice","constructor","name","Array","from","test","iterator","isArray","cn","_len","inputs","_key","twMerge","clsx","DnDContainer","_ref","list","setList","className","children","el","useRef","setListRef","listRef","useEffect","current","sortable","_currentList","Sortable","create","group","ghostClass","animation","onEnd","evt","to","oldIndex","newIndex","item","itemId","getAttribute","remove","nextEl","insertBefore","appendChild","newOrder","splice","fromSortable","toSortable","_setList","sourceItems","id","targetItems","destroy","createElement","ref","style","listStyleType","padding","margin","minHeight","width","display","flexWrap","gap","React","Children","map","child","key","props","RadixSelect","_ref2","label","values","onChange","Root","onValueChange","Trigger","Value","Icon","ChevronDown","size","Portal","Content","Viewport","v","Item","ItemText","ItemIndicator","Check","RadixUI","_usePivot","usePivot","pivotProps","pivotState","state","actions","aggregatorName","rendererName","pivotData","PivotData","data","materializedInput","totalPivotRows","getRowKeys","totalRecords","totalPages","Math","ceil","pageSize","unusedList","attrValues","trim","rows","includes","cols","sort","sortAs","unusedOrder","colList","rowList","renderAttribute","attr","GripVertical","asChild","valueFilter","Filter","type","checked","toggleFilter","Arrow","renderers","updateProp","setUnusedOrder","aggregators","numInputs","vals","pagination","disabled","page","onClick","ChevronsLeft","ChevronLeft","min","max","val","parseInt","target","ChevronRight","ChevronsRight"],"sources":["../src/renderers/RadixUI.jsx"],"sourcesContent":["import React, { useState, useRef, useEffect } from 'react';\r\nimport { usePivot } from '../hooks/usePivot';\r\nimport * as Select from '@radix-ui/react-select';\r\nimport * as Popover from '@radix-ui/react-popover';\r\nimport { ChevronDown, Filter, GripVertical, Check, Settings2, ChevronLeft, ChevronRight, ChevronsLeft, ChevronsRight } from 'lucide-react';\r\nimport Sortable from 'sortablejs';\r\nimport PivotTable from '../PivotTable';\r\nimport { PivotData, sortAs } from '../Utilities';\r\nimport clsx from 'clsx';\r\nimport { twMerge } from 'tailwind-merge';\r\n\r\nfunction cn(...inputs) {\r\n return twMerge(clsx(inputs));\r\n}\r\n\r\nconst DnDContainer = ({ list, setList, className, children }) => {\r\n const el = useRef(null);\r\n const setListRef = useRef(setList);\r\n const listRef = useRef(list);\r\n \r\n useEffect(() => {\r\n setListRef.current = setList;\r\n }, [setList]);\r\n\r\n useEffect(() => {\r\n listRef.current = list;\r\n if (el.current && el.current.sortable) {\r\n el.current.sortable._currentList = list;\r\n }\r\n }, [list]);\r\n\r\n useEffect(() => {\r\n const sortable = Sortable.create(el.current, {\r\n group: 'shared',\r\n ghostClass: 'opacity-50',\r\n animation: 150,\r\n onEnd: (evt) => {\r\n const { from, to, oldIndex, newIndex, item } = evt;\r\n const itemId = item.getAttribute('data-id');\r\n\r\n // ── REVERSIÓN SÍNCRONA DEL DOM ──\r\n if (from !== to || oldIndex !== newIndex) {\r\n item.remove();\r\n const nextEl = from.children[oldIndex];\r\n if (nextEl) {\r\n from.insertBefore(item, nextEl);\r\n } else {\r\n from.appendChild(item);\r\n }\r\n }\r\n\r\n if (from === to) {\r\n // ── Reordenamiento interno ──\r\n const newOrder = [...listRef.current];\r\n newOrder.splice(oldIndex, 1);\r\n newOrder.splice(newIndex, 0, itemId);\r\n \r\n if (setListRef.current) {\r\n setListRef.current(newOrder);\r\n }\r\n } else {\r\n // ── Movimiento entre listas ──\r\n const fromSortable = from.sortable;\r\n const toSortable = to.sortable;\r\n\r\n if (fromSortable?._setList && toSortable?._setList) {\r\n const sourceItems = fromSortable._currentList.filter(id => id !== itemId);\r\n const targetItems = [...toSortable._currentList];\r\n targetItems.splice(newIndex, 0, itemId);\r\n\r\n fromSortable._setList(sourceItems);\r\n toSortable._setList(targetItems);\r\n }\r\n }\r\n },\r\n });\r\n\r\n el.current.sortable = sortable;\r\n sortable._setList = (newOrder) => {\r\n if (setListRef.current) {\r\n setListRef.current(newOrder);\r\n }\r\n };\r\n sortable._currentList = listRef.current;\r\n\r\n return () => sortable.destroy();\r\n }, []);\r\n\r\n return (\r\n <div className={className}>\r\n <ul \r\n ref={el} \r\n style={{ \r\n listStyleType: 'none', \r\n padding: 0, \r\n margin: 0, \r\n minHeight: '1.5rem', \r\n width: '100%',\r\n display: 'flex',\r\n flexWrap: 'wrap',\r\n gap: '8px'\r\n }}\r\n >\r\n {React.Children.map(children, child => (\r\n <li key={child.key} data-id={child.props['data-id']}>\r\n {child}\r\n </li>\r\n ))}\r\n </ul>\r\n </div>\r\n );\r\n};\r\n\r\nconst RadixSelect = ({ label, value, values, onChange }) => (\r\n <div className=\"flex flex-col gap-1.5 min-w-[180px]\">\r\n <label className=\"text-[10px] font-black text-slate-400 uppercase tracking-widest\">{label}</label>\r\n <Select.Root value={value} onValueChange={onChange}>\r\n <Select.Trigger className=\"flex items-center justify-between w-full px-4 py-2 text-sm bg-white border border-slate-200 rounded-xl hover:border-blue-400 focus:ring-4 focus:ring-blue-500/10 outline-none transition-all shadow-sm\">\r\n <Select.Value />\r\n <Select.Icon><ChevronDown size={14} className=\"text-slate-400\" /></Select.Icon>\r\n </Select.Trigger>\r\n <Select.Portal>\r\n <Select.Content className=\"overflow-hidden bg-white rounded-2xl shadow-2xl border border-slate-100 z-[1000] animate-in fade-in zoom-in-95 duration-100\">\r\n <Select.Viewport className=\"p-2\">\r\n {values.map(v => (\r\n <Select.Item key={v} value={v} className=\"flex items-center gap-2 px-8 py-2.5 text-sm text-slate-700 rounded-lg cursor-default select-none hover:bg-blue-50 focus:bg-blue-50 outline-none relative transition-colors\">\r\n <Select.ItemText>{v}</Select.ItemText>\r\n <Select.ItemIndicator className=\"absolute left-2 flex items-center justify-center\"><Check size={14} className=\"text-blue-600\" /></Select.ItemIndicator>\r\n </Select.Item>\r\n ))}\r\n </Select.Viewport>\r\n </Select.Content>\r\n </Select.Portal>\r\n </Select.Root>\r\n </div>\r\n);\r\n\r\nexport function RadixUI(props) {\r\n const { props: pivotProps, state: pivotState, actions } = usePivot(props);\r\n\r\n const aggregatorName = pivotProps.aggregatorName;\r\n const rendererName = pivotProps.rendererName;\r\n\r\n const pivotData = new PivotData({\r\n ...pivotProps,\r\n data: pivotState.materializedInput,\r\n });\r\n const totalPivotRows = pivotData.getRowKeys().length;\r\n const totalRecords = pivotState.materializedInput.length;\r\n const totalPages = Math.ceil(totalPivotRows / (pivotProps.pageSize || 20));\r\n\r\n const unusedList = Object.keys(pivotState.attrValues)\r\n .filter(e => e && e.trim() !== '' && !pivotProps.rows.includes(e) && !pivotProps.cols.includes(e))\r\n .sort(sortAs(pivotState.unusedOrder || []));\r\n\r\n const colList = pivotProps.cols.filter(e => e && e.trim() !== '');\r\n const rowList = pivotProps.rows.filter(e => e && e.trim() !== '');\r\n\r\n const renderAttribute = (attr) => (\r\n <div\r\n key={attr}\r\n className=\"inline-flex items-center gap-2 bg-white border border-slate-200 rounded-xl px-3 py-1.5 text-[13px] font-semibold text-slate-700 shadow-sm cursor-grab hover:bg-slate-50 transition-colors group\"\r\n data-id={attr}\r\n >\r\n <GripVertical size={14} className=\"text-slate-300 group-hover:text-slate-400 transition-colors\" />\r\n <span>{attr}</span>\r\n\r\n <Popover.Root>\r\n <Popover.Trigger asChild>\r\n <button className={cn(\"text-slate-400 hover:text-slate-600 focus:outline-none ml-1 flex items-center justify-center p-0.5 rounded-sm transition-colors\", pivotProps.valueFilter[attr] && \"text-blue-600\")}>\r\n <Filter size={14} />\r\n </button>\r\n </Popover.Trigger>\r\n <Popover.Portal>\r\n <Popover.Content className=\"w-72 p-6 bg-white rounded-3xl shadow-2xl border border-slate-100 z-[1000] outline-none\">\r\n <h4 className=\"font-black text-slate-900 text-xs uppercase tracking-widest mb-4\">Filtrar: {attr}</h4>\r\n <div className=\"max-h-60 overflow-y-auto space-y-2 mb-4 pr-2 custom-scrollbar\">\r\n {Object.keys(pivotState.attrValues[attr] || {}).map(v => (\r\n <div key={v} className=\"flex items-center gap-3 text-sm py-1.5 px-2 hover:bg-slate-50 rounded-lg transition-colors cursor-pointer\">\r\n <input type=\"checkbox\" checked={!(v in (pivotProps.valueFilter[attr] || {}))} onChange={() => actions.toggleFilter(attr, v)} className=\"rounded-md border-slate-300 text-blue-600 focus:ring-blue-500 w-4 h-4\" />\r\n <span className=\"text-slate-600 font-medium\">{v === 'null' ? <em>null</em> : v}</span>\r\n </div>\r\n ))}\r\n </div>\r\n <Popover.Arrow className=\"fill-white\" />\r\n </Popover.Content>\r\n </Popover.Portal>\r\n </Popover.Root>\r\n </div>\r\n );\r\n\r\n return (\r\n <div className=\"flex flex-col bg-white border border-slate-200 rounded-lg overflow-hidden font-sans text-slate-800 text-sm shadow-sm\">\r\n {/* Row 1: Renderer Dropdown & Unused Attributes */}\r\n <div className=\"flex w-full border-b border-slate-200 min-h-[4rem]\">\r\n {/* Renderer */}\r\n <div className=\"w-[300px] p-4 border-r border-slate-200 bg-white flex flex-col justify-start flex-shrink-0\">\r\n <RadixSelect\r\n label=\"Visualización\"\r\n value={rendererName}\r\n values={Object.keys(pivotProps.renderers)}\r\n onChange={(v) => actions.updateProp('rendererName', v)}\r\n />\r\n </div>\r\n\r\n {/* Unused Attrs */}\r\n <div className=\"flex-1 p-4 bg-slate-50/80\">\r\n <DnDContainer\r\n list={unusedList}\r\n setList={(newOrder) => {\r\n actions.setUnusedOrder(newOrder);\r\n }}\r\n className=\"flex flex-wrap gap-2 w-full min-h-[1.5rem]\"\r\n >\r\n {unusedList.map(renderAttribute)}\r\n </DnDContainer>\r\n </div>\r\n </div>\r\n\r\n {/* Row 2: Aggregators & Column Attributes */}\r\n <div className=\"flex w-full border-b border-slate-200 min-h-[4rem]\">\r\n {/* Aggregators */}\r\n <div className=\"w-[300px] p-4 border-r border-slate-200 bg-slate-50/30 flex-shrink-0 flex items-start\">\r\n <div className=\"flex flex-col gap-2 w-full\">\r\n <div className=\"flex items-center gap-2\">\r\n <div className=\"flex-1\">\r\n <RadixSelect\r\n label=\"Agregador\"\r\n value={aggregatorName}\r\n values={Object.keys(pivotProps.aggregators)}\r\n onChange={(v) => actions.updateProp('aggregatorName', v)}\r\n />\r\n </div>\r\n\r\n <div className=\"flex items-center text-slate-600 gap-1.5 text-base leading-none\">\r\n <span className=\"cursor-pointer hover:text-slate-900 transition-colors\">↕</span>\r\n <span className=\"cursor-pointer hover:text-slate-900 transition-colors\">↔</span>\r\n </div>\r\n </div>\r\n\r\n {pivotProps.aggregators[aggregatorName]([])().numInputs > 0 && (\r\n <RadixSelect\r\n label=\"Atributo de Valor\"\r\n value={pivotProps.vals[0] || ''}\r\n values={Object.keys(pivotState.attrValues)}\r\n onChange={(v) => actions.updateProp('vals', [v])}\r\n />\r\n )}\r\n </div>\r\n </div>\r\n\r\n {/* Col Attrs */}\r\n <div className=\"flex-1 p-4 bg-white\">\r\n <DnDContainer\r\n list={colList}\r\n setList={(newOrder) => {\r\n actions.updateProp('cols', newOrder);\r\n }}\r\n className=\"flex flex-wrap gap-2 w-full min-h-[1.5rem]\"\r\n >\r\n {colList.map(renderAttribute)}\r\n </DnDContainer>\r\n </div>\r\n </div>\r\n\r\n {/* Row 3: Row Attributes & Table Data */}\r\n <div className=\"flex w-full min-h-[400px]\">\r\n {/* Row Attrs */}\r\n <div className=\"w-[300px] p-4 border-r border-slate-200 bg-white flex-shrink-0\">\r\n <DnDContainer\r\n list={rowList}\r\n setList={(newOrder) => {\r\n actions.updateProp('rows', newOrder);\r\n }}\r\n className=\"flex flex-col gap-2 w-full min-h-[1.5rem]\"\r\n >\r\n {rowList.map(renderAttribute)}\r\n </DnDContainer>\r\n </div>\r\n\r\n {/* Table Output */}\r\n <div className=\"flex-1 w-full p-4 bg-slate-50/30 overflow-auto\">\r\n <PivotTable {...pivotProps} data={pivotState.materializedInput} />\r\n </div>\r\n </div>\r\n\r\n {/* Footer: Totals and Pagination */}\r\n {pivotProps.pagination && (\r\n <div className=\"flex items-center justify-between px-6 py-3 border-t border-slate-200 bg-white text-slate-600\">\r\n <div className=\"text-[13px] font-medium\">\r\n Registros: <span className=\"text-slate-900\">{totalRecords}</span> | Filas: <span className=\"text-slate-900\">{totalPivotRows}</span>\r\n </div>\r\n\r\n <div className=\"flex items-center gap-6\">\r\n <div className=\"flex items-center gap-1.5\">\r\n <button\r\n className=\"p-1 rounded-md hover:bg-slate-100 disabled:opacity-30 disabled:cursor-not-allowed transition-colors\"\r\n disabled={pivotProps.page <= 1}\r\n onClick={() => actions.updateProp('page', 1)}\r\n >\r\n <ChevronsLeft size={18} />\r\n </button>\r\n <button\r\n className=\"p-1 rounded-md hover:bg-slate-100 disabled:opacity-30 disabled:cursor-not-allowed transition-colors\"\r\n disabled={pivotProps.page <= 1}\r\n onClick={() => actions.updateProp('page', pivotProps.page - 1)}\r\n >\r\n <ChevronLeft size={18} />\r\n </button>\r\n\r\n <div className=\"flex items-center gap-2 mx-1\">\r\n <span className=\"text-[13px] font-medium\">Página</span>\r\n <input\r\n type=\"number\"\r\n className=\"w-12 h-8 text-center border border-slate-300 rounded-md text-[13px] font-semibold text-slate-900 focus:border-indigo-500 focus:ring-1 focus:ring-indigo-500 outline-none\"\r\n value={pivotProps.page}\r\n min={1}\r\n max={totalPages}\r\n onChange={(e) => {\r\n const val = parseInt(e.target.value, 10);\r\n if (val > 0 && val <= totalPages) {\r\n actions.updateProp('page', val);\r\n }\r\n }}\r\n />\r\n <span className=\"text-[13px] font-medium text-slate-400\">de {totalPages}</span>\r\n </div>\r\n\r\n <button\r\n className=\"p-1 rounded-md hover:bg-slate-100 disabled:opacity-30 disabled:cursor-not-allowed transition-colors\"\r\n disabled={pivotProps.page >= totalPages}\r\n onClick={() => actions.updateProp('page', pivotProps.page + 1)}\r\n >\r\n <ChevronRight size={18} />\r\n </button>\r\n <button\r\n className=\"p-1 rounded-md hover:bg-slate-100 disabled:opacity-30 disabled:cursor-not-allowed transition-colors\"\r\n disabled={pivotProps.page >= totalPages}\r\n onClick={() => actions.updateProp('page', totalPages)}\r\n >\r\n <ChevronsRight size={18} />\r\n </button>\r\n </div>\r\n\r\n <div className=\"flex items-center gap-2 border-l border-slate-200 pl-6\">\r\n <span className=\"text-[13px] font-medium text-slate-400\">Mostrar</span>\r\n <select\r\n className=\"text-[13px] font-semibold border border-slate-300 rounded-md px-2 py-1 focus:border-indigo-500 focus:ring-1 focus:ring-indigo-500 outline-none hover:border-slate-400 bg-white text-slate-900\"\r\n value={pivotProps.pageSize}\r\n onChange={(e) => {\r\n actions.updateProp('pageSize', parseInt(e.target.value, 10));\r\n actions.updateProp('page', 1);\r\n }}\r\n >\r\n {[10, 20, 50, 100].map(n => (\r\n <option key={n} value={n}>\r\n {n}\r\n </option>\r\n ))}\r\n </select>\r\n </div>\r\n </div>\r\n </div>\r\n )}\r\n </div>\r\n );\r\n}\r\n"],"mappings":"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","ignoreList":[]}