@pnkx-lib/ui 1.9.85 → 1.9.87
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/style.css +2 -2
- package/es/chunks/{AntdIcon-OdNt_XE3.js → AntdIcon-CfjDMPv2.js} +9 -16
- package/es/chunks/{Switch-BpQVmWXF.js → Switch-BRvdbb0u.js} +1 -1
- package/es/chunks/{index-BmfEnmGs.js → index-3YgUpR-Y.js} +219 -228
- package/es/fields/index.js +2 -2
- package/es/index.js +3 -3
- package/es/ui/index.js +2 -2
- package/package.json +5 -3
- package/types/fields.d.ts +13 -13
- package/types/index.d.ts +81 -80
- package/types/ui.d.ts +69 -68
@@ -1,4 +1,4 @@
|
|
1
|
-
import { j as jsxRuntimeExports, c as Icon, _ as _extends, e as _typeof, P as PnkxField, C as CheckboxField, t as twMerge, u as useForm, d as classNames, l as lodashExports, f as _arrayLikeToArray, h as _unsupportedIterableToArray, w as warningOnce, i as _createClass, k as _classCallCheck, m as _defineProperty, n as _slicedToArray, o as warning$1, p as canUseDom, q as _objectSpread2, r as updateCSS, s as removeCSS, v as _arrayWithHoles, x as _nonIterableRest, y as resetWarned$1, F as FastColor, z as generate, A as presetPrimaryColors, B as presetPalettes, G as _inherits, H as _createSuper, J as _assertThisInitialized, K as _objectWithoutProperties, M as IconContext, I as Input } from './AntdIcon-
|
1
|
+
import { j as jsxRuntimeExports, c as Icon, _ as _extends, e as _typeof, P as PnkxField, C as CheckboxField, t as twMerge, u as useForm, d as classNames, l as lodashExports, f as _arrayLikeToArray, h as _unsupportedIterableToArray, w as warningOnce, i as _createClass, k as _classCallCheck, m as _defineProperty, n as _slicedToArray, o as warning$1, p as canUseDom, q as _objectSpread2, r as updateCSS, s as removeCSS, v as _arrayWithHoles, x as _nonIterableRest, y as resetWarned$1, F as FastColor, z as generate, A as presetPrimaryColors, B as presetPalettes, G as _inherits, H as _createSuper, J as _assertThisInitialized, K as _objectWithoutProperties, M as IconContext, I as Input } from './AntdIcon-CfjDMPv2.js';
|
2
2
|
import { Button as Button$1, Cascader, Modal as Modal$1, Badge as Badge$1, Breadcrumb as Breadcrumb$1, Tooltip as Tooltip$1, Divider as Divider$2, Table as Table$1, Tabs as Tabs$1, Space as Space$1, Card, Skeleton as Skeleton$1, Popover as Popover$1, Col as Col$1, Row as Row$1, Dropdown as Dropdown$1, Flex as Flex$1, Splitter as Splitter$1, Menu as Menu$1, Pagination as Pagination$1, Steps as Steps$1, Tag as Tag$1, Alert as Alert$1, Spin as Spin$1, Drawer as Drawer$1, Popconfirm as Popconfirm$1, QRCode as QRCode$1, Result as Result$1, Rate as Rate$1, Segmented as Segmented$1, Statistic as Statistic$1, Timeline as Timeline$1, Tour as Tour$1, Tree as Tree$1, Typography, Watermark as Watermark$1, Anchor as Anchor$1, Affix, AutoComplete as AutoComplete$1, Input as Input$1, Collapse, ColorPicker, Empty as Empty$2, Image as Image$1 } from 'antd';
|
3
3
|
import * as React from 'react';
|
4
4
|
import React__default, { version as version$1, isValidElement, useLayoutEffect as useLayoutEffect$1, useEffect, useRef, useMemo as useMemo$1, useCallback, useState, createContext, memo, useReducer, useContext, Component } from 'react';
|
@@ -5008,12 +5008,12 @@ const ActivateIcon = ({ stroke, fill }) => /* @__PURE__ */ jsxRuntimeExports.jsx
|
|
5008
5008
|
}
|
5009
5009
|
) });
|
5010
5010
|
|
5011
|
-
const DeleteIcon = ({ stroke, fill = "#DD4338" }) => /* @__PURE__ */ jsxRuntimeExports.jsx("svg", { xmlns: "http://www.w3.org/2000/svg", width:
|
5011
|
+
const DeleteIcon = ({ stroke, fill = "#DD4338" }) => /* @__PURE__ */ jsxRuntimeExports.jsx("svg", { xmlns: "http://www.w3.org/2000/svg", width: 23, height: 24, fill: "none", children: /* @__PURE__ */ jsxRuntimeExports.jsx(
|
5012
5012
|
"path",
|
5013
5013
|
{
|
5014
5014
|
fill,
|
5015
5015
|
stroke,
|
5016
|
-
d: "
|
5016
|
+
d: "m18.219 17.634.75.006-.75-.006ZM4.319 5.65a.75.75 0 1 0 0 1.5v-1.5Zm14.934 1.5a.75.75 0 0 0 0-1.5v1.5Zm-8.584 2.984a.75.75 0 1 0-1.5 0h1.5ZM9.17 17.6a.75.75 0 0 0 1.5 0h-1.5Zm5.234-7.466a.75.75 0 1 0-1.5 0h1.5Zm-1.5 7.466a.75.75 0 0 0 1.5 0h-1.5Zm5.416-11.2-.75-.006-.1 11.233.75.007.75.006.1-11.233-.75-.007Zm-3.833 14.934v-.75h-5.5v1.5h5.5v-.75ZM5.253 6.4h-.75v11.2h1.5V6.4h-.75Zm-.934 0v.75h.934v-1.5h-.934v.75Zm.934 0v.75h2.8v-1.5h-2.8v.75Zm2.8 0v.75h7.466v-1.5H8.053v.75Zm7.466 0v.75h2.8v-1.5h-2.8v.75Zm2.8 0v.75h.934v-1.5h-.934v.75ZM8.053 5.985h.75c0-1.338 1.25-2.568 2.983-2.568v-1.5c-2.39 0-4.483 1.74-4.483 4.068h.75Zm3.733-3.318v.75c1.733 0 2.983 1.23 2.983 2.568h1.5c0-2.327-2.092-4.068-4.483-4.068v.75ZM8.053 5.985h-.75V6.4h1.5v-.415h-.75Zm7.466 0h-.75V6.4h1.5v-.415h-.75ZM8.986 21.334v-.75A2.983 2.983 0 0 1 6.003 17.6h-1.5a4.483 4.483 0 0 0 4.483 4.484v-.75Zm9.233-3.7-.75-.007a2.983 2.983 0 0 1-2.983 2.957v1.5a4.483 4.483 0 0 0 4.483-4.444l-.75-.006Zm-8.3-7.5h-.75V17.6h1.5v-7.466h-.75Zm3.734 0h-.75V17.6h1.5v-7.466h-.75Z"
|
5017
5017
|
}
|
5018
5018
|
) });
|
5019
5019
|
|
@@ -5262,14 +5262,48 @@ const Breadcrumb = (props) => {
|
|
5262
5262
|
};
|
5263
5263
|
|
5264
5264
|
const Heading = (props) => {
|
5265
|
-
const {
|
5266
|
-
rightContent,
|
5267
|
-
children,
|
5268
|
-
noBreadcum,
|
5269
|
-
classNameWrapHeading,
|
5270
|
-
breadcrumbItems
|
5271
|
-
} = props;
|
5265
|
+
const { rightContent, children, noBreadcum, classNameWrapHeading, menu } = props;
|
5272
5266
|
//! State
|
5267
|
+
const location = useLocation();
|
5268
|
+
const pathUrl = location.pathname;
|
5269
|
+
const dataBreadcrumb = [];
|
5270
|
+
menu.forEach((itemMenu) => {
|
5271
|
+
if (!itemMenu.isShow) return;
|
5272
|
+
itemMenu.modules.forEach(
|
5273
|
+
(module) => {
|
5274
|
+
const modulePath = module.path?.replace(/\/$/, "");
|
5275
|
+
if (pathUrl === modulePath) {
|
5276
|
+
dataBreadcrumb.push({
|
5277
|
+
title: module.name,
|
5278
|
+
href: module.path
|
5279
|
+
});
|
5280
|
+
return;
|
5281
|
+
}
|
5282
|
+
module.subMenu?.forEach(
|
5283
|
+
(sub) => {
|
5284
|
+
const subPath = modulePath + sub.path;
|
5285
|
+
if (pathUrl === subPath) {
|
5286
|
+
dataBreadcrumb.push(
|
5287
|
+
{ title: module.name, href: module.path },
|
5288
|
+
{ title: sub.name, href: sub.path }
|
5289
|
+
);
|
5290
|
+
return;
|
5291
|
+
}
|
5292
|
+
sub.children?.forEach((child) => {
|
5293
|
+
const fullPath = subPath + child.path;
|
5294
|
+
if (pathUrl === fullPath) {
|
5295
|
+
dataBreadcrumb.push(
|
5296
|
+
{ title: module.name, href: module.path },
|
5297
|
+
{ title: sub.name, href: sub.path },
|
5298
|
+
{ title: child.name, href: child.path }
|
5299
|
+
);
|
5300
|
+
}
|
5301
|
+
});
|
5302
|
+
}
|
5303
|
+
);
|
5304
|
+
}
|
5305
|
+
);
|
5306
|
+
});
|
5273
5307
|
//! Function
|
5274
5308
|
//! Render
|
5275
5309
|
return /* @__PURE__ */ jsxRuntimeExports.jsxs(jsxRuntimeExports.Fragment, { children: [
|
@@ -5281,7 +5315,7 @@ const Heading = (props) => {
|
|
5281
5315
|
classNameWrapHeading
|
5282
5316
|
),
|
5283
5317
|
children: [
|
5284
|
-
!noBreadcum && /* @__PURE__ */ jsxRuntimeExports.jsx(Breadcrumb, { items:
|
5318
|
+
!noBreadcum && /* @__PURE__ */ jsxRuntimeExports.jsx(Breadcrumb, { items: dataBreadcrumb }),
|
5285
5319
|
rightContent
|
5286
5320
|
]
|
5287
5321
|
}
|
@@ -5318,14 +5352,14 @@ const HeadingTable = (props) => {
|
|
5318
5352
|
showSetting,
|
5319
5353
|
renderHeadingSearch,
|
5320
5354
|
rightHeadingContent,
|
5321
|
-
|
5355
|
+
menu,
|
5322
5356
|
groupHeadingButtonItems,
|
5323
5357
|
handleClickGroupHeadingButtonItem
|
5324
5358
|
} = props;
|
5325
5359
|
return /* @__PURE__ */ jsxRuntimeExports.jsxs(
|
5326
5360
|
Heading,
|
5327
5361
|
{
|
5328
|
-
|
5362
|
+
menu,
|
5329
5363
|
classNameWrapHeading: "justify-between",
|
5330
5364
|
rightContent: rightHeadingContent && rightHeadingContent,
|
5331
5365
|
children: [
|
@@ -5608,7 +5642,7 @@ const BulkAction = ({
|
|
5608
5642
|
index
|
5609
5643
|
) })
|
5610
5644
|
) }),
|
5611
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(
|
5645
|
+
open && /* @__PURE__ */ jsxRuntimeExports.jsx(
|
5612
5646
|
ConfirmModal,
|
5613
5647
|
{
|
5614
5648
|
title: notifyContent?.title,
|
@@ -5646,78 +5680,8 @@ const Table = ({
|
|
5646
5680
|
showIndexColumn = true,
|
5647
5681
|
...rest
|
5648
5682
|
}) => {
|
5649
|
-
//! State
|
5650
|
-
const location = useLocation();
|
5651
|
-
const pathUrl = location.pathname;
|
5652
5683
|
const status = filters?.status;
|
5653
|
-
|
5654
|
-
for (const item of menu) {
|
5655
|
-
if (!item.subMenu) continue;
|
5656
|
-
for (const sub of item?.subMenu) {
|
5657
|
-
if (!sub.children) continue;
|
5658
|
-
for (const childrenSub of sub?.children) {
|
5659
|
-
const isItemActive = pathUrl === item.href;
|
5660
|
-
const isSubActive = pathUrl === sub.href;
|
5661
|
-
const isChildrenActive = pathUrl === childrenSub.href;
|
5662
|
-
if (isChildrenActive) {
|
5663
|
-
dataBreakcrum = {
|
5664
|
-
name: item.name,
|
5665
|
-
href: item.href,
|
5666
|
-
subMenu: {
|
5667
|
-
name: sub.name,
|
5668
|
-
href: sub.href,
|
5669
|
-
childrenSub: {
|
5670
|
-
name: childrenSub.name,
|
5671
|
-
href: childrenSub.href
|
5672
|
-
}
|
5673
|
-
}
|
5674
|
-
};
|
5675
|
-
break;
|
5676
|
-
}
|
5677
|
-
if (isSubActive) {
|
5678
|
-
dataBreakcrum = {
|
5679
|
-
name: item.name,
|
5680
|
-
href: item.href,
|
5681
|
-
subMenu: {
|
5682
|
-
name: sub.name,
|
5683
|
-
href: sub.href,
|
5684
|
-
childrenSub: null
|
5685
|
-
}
|
5686
|
-
};
|
5687
|
-
break;
|
5688
|
-
}
|
5689
|
-
if (isItemActive) {
|
5690
|
-
dataBreakcrum = {
|
5691
|
-
name: item.name,
|
5692
|
-
href: item.href,
|
5693
|
-
subMenu: null
|
5694
|
-
};
|
5695
|
-
break;
|
5696
|
-
}
|
5697
|
-
}
|
5698
|
-
if (dataBreakcrum) break;
|
5699
|
-
}
|
5700
|
-
if (dataBreakcrum) break;
|
5701
|
-
}
|
5702
|
-
const generateBreadcrumb = [];
|
5703
|
-
if (dataBreakcrum) {
|
5704
|
-
generateBreadcrumb.push({
|
5705
|
-
title: dataBreakcrum.name,
|
5706
|
-
href: dataBreakcrum.href
|
5707
|
-
});
|
5708
|
-
if (dataBreakcrum.subMenu) {
|
5709
|
-
generateBreadcrumb.push({
|
5710
|
-
title: dataBreakcrum.subMenu.name,
|
5711
|
-
href: dataBreakcrum.subMenu.href
|
5712
|
-
});
|
5713
|
-
if (dataBreakcrum.subMenu.childrenSub) {
|
5714
|
-
generateBreadcrumb.push({
|
5715
|
-
title: dataBreakcrum.subMenu.childrenSub.name,
|
5716
|
-
href: dataBreakcrum.subMenu.childrenSub.href
|
5717
|
-
});
|
5718
|
-
}
|
5719
|
-
}
|
5720
|
-
}
|
5684
|
+
//! State
|
5721
5685
|
const [data, setData] = useState([]);
|
5722
5686
|
const [openSetting, setOpenStting] = useState(false);
|
5723
5687
|
const paginationConfig = {
|
@@ -5780,7 +5744,7 @@ const Table = ({
|
|
5780
5744
|
renderHeadingSearch,
|
5781
5745
|
setOpenStting,
|
5782
5746
|
showSetting,
|
5783
|
-
|
5747
|
+
menu,
|
5784
5748
|
groupHeadingButtonItems,
|
5785
5749
|
handleClickGroupHeadingButtonItem
|
5786
5750
|
}
|
@@ -9578,7 +9542,7 @@ function genStyleUtils(config) {
|
|
9578
9542
|
};
|
9579
9543
|
}
|
9580
9544
|
|
9581
|
-
const version = '5.25.
|
9545
|
+
const version = '5.25.0';
|
9582
9546
|
|
9583
9547
|
function isStableColor(color) {
|
9584
9548
|
return color >= 0 && color <= 255;
|
@@ -12094,6 +12058,10 @@ function useDebounce(value, delay) {
|
|
12094
12058
|
return debouncedValue;
|
12095
12059
|
}
|
12096
12060
|
|
12061
|
+
const logoHeader = "";
|
12062
|
+
|
12063
|
+
const logoHeaderText = "";
|
12064
|
+
|
12097
12065
|
const userInfo = {
|
12098
12066
|
avatar: "https://img.freepik.com/premium-vector/character-avatar-isolated_729149-194801.jpg?semt=ais_hybrid&w=740",
|
12099
12067
|
name: "username",
|
@@ -12172,7 +12140,7 @@ const bottomMenu = [
|
|
12172
12140
|
show: true
|
12173
12141
|
}
|
12174
12142
|
];
|
12175
|
-
const Sidebar = ({ children, menu
|
12143
|
+
const Sidebar = ({ children, menu }) => {
|
12176
12144
|
const router = useNavigate();
|
12177
12145
|
const location = useLocation();
|
12178
12146
|
const pathUrl = location.pathname;
|
@@ -12181,20 +12149,29 @@ const Sidebar = ({ children, menu = [] }) => {
|
|
12181
12149
|
const [collapse, setCollapse] = useState(false);
|
12182
12150
|
const [openSubCollapse, setOpenSubCollapse] = useState(false);
|
12183
12151
|
const [valueSearch, setValueSearch] = useState("");
|
12184
|
-
const [newMenu, setNewMenu] = useState(
|
12152
|
+
const [newMenu, setNewMenu] = useState(
|
12153
|
+
menu?.filter((route) => route.isShow)?.flatMap((route) => route.modules)
|
12154
|
+
);
|
12185
12155
|
const searchSidebar = useDebounce(valueSearch, 300);
|
12186
12156
|
const toast = useToast({
|
12187
12157
|
message: "Thông báo",
|
12188
12158
|
description: "Tính năng đang được phát triển"
|
12189
12159
|
});
|
12190
|
-
const
|
12191
|
-
() =>
|
12192
|
-
(
|
12193
|
-
(
|
12194
|
-
|
12195
|
-
|
12196
|
-
|
12197
|
-
|
12160
|
+
const activeSubmenu = useMemo$1(() => {
|
12161
|
+
return newMenu.flatMap((menuItem) => {
|
12162
|
+
if (pathUrl.startsWith(menuItem.path)) {
|
12163
|
+
return (menuItem.subMenu || []).map(
|
12164
|
+
(item) => ({
|
12165
|
+
name: item.name,
|
12166
|
+
path: item.path,
|
12167
|
+
icon: item.icon,
|
12168
|
+
children: item.children
|
12169
|
+
})
|
12170
|
+
);
|
12171
|
+
}
|
12172
|
+
return [];
|
12173
|
+
});
|
12174
|
+
}, [newMenu, pathUrl]);
|
12198
12175
|
const handleActiveMain = (path) => {
|
12199
12176
|
setActiveMainMenu(path);
|
12200
12177
|
router(path);
|
@@ -12203,11 +12180,19 @@ const Sidebar = ({ children, menu = [] }) => {
|
|
12203
12180
|
setOpenSubmenu((prev) => prev === itemName ? null : itemName);
|
12204
12181
|
};
|
12205
12182
|
useEffect(() => {
|
12206
|
-
const filteredMenu = menu.filter(
|
12207
|
-
|
12208
|
-
|
12183
|
+
const filteredMenu = menu.filter((item) => item.isShow).flatMap((menu2) => {
|
12184
|
+
return menu2.modules.filter((subMenu) => {
|
12185
|
+
return subMenu.name.toLowerCase().includes(searchSidebar.toLowerCase());
|
12186
|
+
});
|
12187
|
+
});
|
12209
12188
|
setNewMenu(filteredMenu);
|
12210
|
-
}, [
|
12189
|
+
}, [searchSidebar]);
|
12190
|
+
const handleClick = (sub, path) => {
|
12191
|
+
if (!sub?.path || !activeMainMenu) return;
|
12192
|
+
const segments = [activeMainMenu, sub.path, path || ""].map((s) => s.replace(/^\/|\/$/g, "")).filter(Boolean);
|
12193
|
+
const pathRouter = "/" + segments.join("/");
|
12194
|
+
router(pathRouter);
|
12195
|
+
};
|
12211
12196
|
return /* @__PURE__ */ jsxRuntimeExports.jsxs("div", { className: "flex relative h-screen", children: [
|
12212
12197
|
/* @__PURE__ */ jsxRuntimeExports.jsxs(
|
12213
12198
|
"div",
|
@@ -12227,7 +12212,7 @@ const Sidebar = ({ children, menu = [] }) => {
|
|
12227
12212
|
"img",
|
12228
12213
|
{
|
12229
12214
|
className: "h-8 w-auto",
|
12230
|
-
src: collapse ?
|
12215
|
+
src: collapse ? logoHeaderText : openSubCollapse ? "" : logoHeader,
|
12231
12216
|
alt: ""
|
12232
12217
|
}
|
12233
12218
|
) }),
|
@@ -12241,96 +12226,89 @@ const Sidebar = ({ children, menu = [] }) => {
|
|
12241
12226
|
}
|
12242
12227
|
) }) }),
|
12243
12228
|
/* @__PURE__ */ jsxRuntimeExports.jsxs("nav", { className: twMerge("flex flex-1 flex-col px-2"), children: [
|
12244
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(
|
12245
|
-
|
12246
|
-
|
12247
|
-
|
12248
|
-
|
12249
|
-
"
|
12250
|
-
|
12251
|
-
|
12252
|
-
|
12253
|
-
|
12254
|
-
|
12255
|
-
|
12256
|
-
|
12257
|
-
className: twMerge(
|
12258
|
-
"relative cursor-pointer",
|
12259
|
-
isActive ? "ml-2" : "ml-0"
|
12260
|
-
),
|
12261
|
-
children: [
|
12262
|
-
(activeMainMenu === item.href || item.href === pathUrl) && /* @__PURE__ */ jsxRuntimeExports.jsxs(jsxRuntimeExports.Fragment, { children: [
|
12263
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(
|
12264
|
-
"span",
|
12265
|
-
{
|
12266
|
-
className: twMerge(
|
12267
|
-
"absolute top-[-40px] right-0 w-10 h-10 rounded-full"
|
12268
|
-
)
|
12269
|
-
}
|
12270
|
-
),
|
12271
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(
|
12272
|
-
"span",
|
12273
|
-
{
|
12274
|
-
className: twMerge(
|
12275
|
-
"absolute bottom-[-40px] right-0 w-10 h-10 rounded-full"
|
12276
|
-
)
|
12277
|
-
}
|
12278
|
-
)
|
12279
|
-
] }),
|
12280
|
-
(activeMainMenu === item.href || item.href === pathUrl) && !collapse && /* @__PURE__ */ jsxRuntimeExports.jsxs(jsxRuntimeExports.Fragment, { children: [
|
12281
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(
|
12282
|
-
"span",
|
12283
|
-
{
|
12284
|
-
className: twMerge(
|
12285
|
-
"absolute top-[-40px] right-0 w-10 h-10 rounded-full shadow-[24px_24px_0_white]"
|
12286
|
-
)
|
12287
|
-
}
|
12288
|
-
),
|
12289
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx(
|
12290
|
-
"span",
|
12291
|
-
{
|
12292
|
-
className: twMerge(
|
12293
|
-
"absolute bottom-[-40px] right-0 w-10 h-10 rounded-full shadow-[24px_-24px_0_white]"
|
12294
|
-
)
|
12295
|
-
}
|
12296
|
-
)
|
12297
|
-
] }),
|
12229
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx("ul", { role: "list", className: twMerge("-mx-2 space-y-1 relative"), children: newMenu.flatMap(
|
12230
|
+
(item) => {
|
12231
|
+
const isActive = [activeMainMenu, pathUrl].includes(item.path);
|
12232
|
+
const isActiveUrl = item.path === activeMainMenu || item.path === pathUrl;
|
12233
|
+
return /* @__PURE__ */ jsxRuntimeExports.jsx("div", { children: /* @__PURE__ */ jsxRuntimeExports.jsxs(
|
12234
|
+
"li",
|
12235
|
+
{
|
12236
|
+
className: twMerge(
|
12237
|
+
"relative cursor-pointer",
|
12238
|
+
isActive ? "ml-2" : "ml-0"
|
12239
|
+
),
|
12240
|
+
children: [
|
12241
|
+
(activeMainMenu === item.path || item.path === pathUrl) && /* @__PURE__ */ jsxRuntimeExports.jsxs(jsxRuntimeExports.Fragment, { children: [
|
12298
12242
|
/* @__PURE__ */ jsxRuntimeExports.jsx(
|
12299
|
-
"
|
12243
|
+
"span",
|
12300
12244
|
{
|
12301
12245
|
className: twMerge(
|
12302
|
-
"
|
12303
|
-
|
12304
|
-
|
12305
|
-
|
12306
|
-
|
12307
|
-
|
12308
|
-
|
12309
|
-
|
12310
|
-
|
12311
|
-
setOpenSubCollapse(true);
|
12312
|
-
},
|
12313
|
-
className: twMerge(
|
12314
|
-
isActiveUrl ? "bg-[#FFFFFF] text-black hover:text-black" : "text-[#FFFFFF] hover:bg-[#FFFFFF] hover:text-black",
|
12315
|
-
"py-2 rounded-md mt-2 text-sm whitespace-nowrap leading-6 font-semibold relative z-10",
|
12316
|
-
collapse ? "pl-4 mr-2 " : "rounded-bl-full rounded-tl-full justify-center",
|
12317
|
-
"flex items-center whitespace-nowrap gap-2"
|
12318
|
-
),
|
12319
|
-
children: [
|
12320
|
-
item.icon,
|
12321
|
-
collapse && item.name
|
12322
|
-
]
|
12323
|
-
}
|
12246
|
+
"absolute top-[-40px] right-0 w-10 h-10 rounded-full"
|
12247
|
+
)
|
12248
|
+
}
|
12249
|
+
),
|
12250
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx(
|
12251
|
+
"span",
|
12252
|
+
{
|
12253
|
+
className: twMerge(
|
12254
|
+
"absolute bottom-[-40px] right-0 w-10 h-10 rounded-full"
|
12324
12255
|
)
|
12325
12256
|
}
|
12326
12257
|
)
|
12327
|
-
]
|
12328
|
-
|
12329
|
-
|
12330
|
-
|
12331
|
-
|
12258
|
+
] }),
|
12259
|
+
(activeMainMenu === item.path || item.path === pathUrl) && !collapse && /* @__PURE__ */ jsxRuntimeExports.jsxs(jsxRuntimeExports.Fragment, { children: [
|
12260
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx(
|
12261
|
+
"span",
|
12262
|
+
{
|
12263
|
+
className: twMerge(
|
12264
|
+
"absolute top-[-40px] right-0 w-10 h-10 rounded-full shadow-[24px_24px_0_white]"
|
12265
|
+
)
|
12266
|
+
}
|
12267
|
+
),
|
12268
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx(
|
12269
|
+
"span",
|
12270
|
+
{
|
12271
|
+
className: twMerge(
|
12272
|
+
"absolute bottom-[-40px] right-0 w-10 h-10 rounded-full shadow-[24px_-24px_0_white]"
|
12273
|
+
)
|
12274
|
+
}
|
12275
|
+
)
|
12276
|
+
] }),
|
12277
|
+
/* @__PURE__ */ jsxRuntimeExports.jsx(
|
12278
|
+
"div",
|
12279
|
+
{
|
12280
|
+
className: twMerge(
|
12281
|
+
"relative group rounded-bl-full rounded-tl-full hover:text-black",
|
12282
|
+
!collapse && "hover:bg-[#FFFFFF]"
|
12283
|
+
),
|
12284
|
+
children: /* @__PURE__ */ jsxRuntimeExports.jsxs(
|
12285
|
+
"a",
|
12286
|
+
{
|
12287
|
+
onClick: () => {
|
12288
|
+
handleActiveMain(item.path);
|
12289
|
+
setCollapse(false);
|
12290
|
+
setOpenSubCollapse(true);
|
12291
|
+
},
|
12292
|
+
className: twMerge(
|
12293
|
+
isActiveUrl ? "bg-[#FFFFFF] text-black hover:text-black" : "text-[#FFFFFF] hover:bg-[#FFFFFF] hover:text-black",
|
12294
|
+
"py-2 rounded-md mt-2 text-sm whitespace-nowrap leading-6 font-semibold relative z-10",
|
12295
|
+
collapse ? "pl-4 mr-2" : "rounded-bl-full rounded-tl-full justify-center",
|
12296
|
+
"flex items-center whitespace-nowrap gap-2"
|
12297
|
+
),
|
12298
|
+
children: [
|
12299
|
+
item.icon,
|
12300
|
+
collapse && item.name
|
12301
|
+
]
|
12302
|
+
}
|
12303
|
+
)
|
12304
|
+
}
|
12305
|
+
)
|
12306
|
+
]
|
12307
|
+
},
|
12308
|
+
item.name
|
12309
|
+
) });
|
12332
12310
|
}
|
12333
|
-
),
|
12311
|
+
) }),
|
12334
12312
|
/* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: twMerge("mt-auto pb-4"), children: /* @__PURE__ */ jsxRuntimeExports.jsx("ul", { children: bottomMenu.map(
|
12335
12313
|
(bm) => bm.show && /* @__PURE__ */ jsxRuntimeExports.jsx(
|
12336
12314
|
"li",
|
@@ -12346,7 +12324,7 @@ const Sidebar = ({ children, menu = [] }) => {
|
|
12346
12324
|
),
|
12347
12325
|
children: [
|
12348
12326
|
/* @__PURE__ */ jsxRuntimeExports.jsx("div", { className: "flex max-w-8 min-w-8 min-h-6 justify-center hover:text-black", children: bm.icon }),
|
12349
|
-
/* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: "text-sm hover:text-black", children:
|
12327
|
+
collapse && /* @__PURE__ */ jsxRuntimeExports.jsx("span", { className: "text-sm hover:text-black", children: bm.label })
|
12350
12328
|
]
|
12351
12329
|
}
|
12352
12330
|
)
|
@@ -12363,7 +12341,7 @@ const Sidebar = ({ children, menu = [] }) => {
|
|
12363
12341
|
{
|
12364
12342
|
onClick: () => setOpenSubCollapse(false),
|
12365
12343
|
className: twMerge(
|
12366
|
-
"absolute top-1/19 transform -translate-y-1/2 cursor-pointer bg-[#FFFFFF]
|
12344
|
+
"absolute top-1/19 transform -translate-y-1/2 z-[100] cursor-pointer bg-[#FFFFFF] text-[#3078BD] rounded-full w-10 h-10 flex items-center justify-center shadow transition-all duration-300 left-44 sm:left-40 md:left-48 lg:left-85"
|
12367
12345
|
),
|
12368
12346
|
children: /* @__PURE__ */ jsxRuntimeExports.jsx(RefIcon$9, { className: twMerge("w-4 h-4") })
|
12369
12347
|
}
|
@@ -12381,13 +12359,13 @@ const Sidebar = ({ children, menu = [] }) => {
|
|
12381
12359
|
"div",
|
12382
12360
|
{
|
12383
12361
|
className: twMerge(
|
12384
|
-
"absolute
|
12362
|
+
"absolute top-0 p-3.5 space-y-4 space-x-4 z-50"
|
12385
12363
|
),
|
12386
12364
|
children: /* @__PURE__ */ jsxRuntimeExports.jsx(
|
12387
12365
|
"img",
|
12388
12366
|
{
|
12389
|
-
className: "w-
|
12390
|
-
src:
|
12367
|
+
className: "w-[15%] h-auto object-contain",
|
12368
|
+
src: logoHeaderText,
|
12391
12369
|
alt: "Logo"
|
12392
12370
|
}
|
12393
12371
|
)
|
@@ -12399,54 +12377,67 @@ const Sidebar = ({ children, menu = [] }) => {
|
|
12399
12377
|
className: twMerge(
|
12400
12378
|
"flex flex-1 transition-all mt-16 duration-300 flex-col"
|
12401
12379
|
),
|
12402
|
-
children:
|
12380
|
+
children: /* @__PURE__ */ jsxRuntimeExports.jsx(
|
12403
12381
|
"ul",
|
12404
12382
|
{
|
12405
12383
|
role: "list",
|
12406
12384
|
className: twMerge(
|
12407
12385
|
"-mx-2 space-y-1 cursor-pointer mt-4 ml-[3rem]"
|
12408
12386
|
),
|
12409
|
-
children:
|
12410
|
-
|
12411
|
-
"
|
12412
|
-
|
12413
|
-
|
12414
|
-
handleOpenSubmenu(sub.name);
|
12415
|
-
router(sub.href);
|
12416
|
-
},
|
12417
|
-
className: twMerge(
|
12418
|
-
sub.href === pathUrl ? "bg-[#EEEEF0] text-black" : "text-gray-700 hover:bg-[#EEEEF0]",
|
12419
|
-
"group flex gap-x-3 rounded-md p-2 mr-8 text-sm leading-6 transition-all duration-300 font-semibold items-center"
|
12420
|
-
),
|
12421
|
-
children: [
|
12422
|
-
sub.icon,
|
12423
|
-
sub.name,
|
12424
|
-
openSubmenu === sub.name ? /* @__PURE__ */ jsxRuntimeExports.jsx(RefIcon, { className: twMerge("w-4 h-4 ml-auto") }) : /* @__PURE__ */ jsxRuntimeExports.jsx(RefIcon$7, { className: twMerge("w-4 h-4 ml-auto") })
|
12425
|
-
]
|
12426
|
-
}
|
12427
|
-
),
|
12428
|
-
openSubmenu === sub.name && sub.children && /* @__PURE__ */ jsxRuntimeExports.jsx(
|
12429
|
-
"ul",
|
12430
|
-
{
|
12431
|
-
className: twMerge("pl-2 transition-all duration-300 "),
|
12432
|
-
children: sub.children.map((sub2) => /* @__PURE__ */ jsxRuntimeExports.jsxs(
|
12433
|
-
"li",
|
12387
|
+
children: activeSubmenu?.map(
|
12388
|
+
(sub) => {
|
12389
|
+
return /* @__PURE__ */ jsxRuntimeExports.jsxs("li", { children: [
|
12390
|
+
/* @__PURE__ */ jsxRuntimeExports.jsxs(
|
12391
|
+
"a",
|
12434
12392
|
{
|
12435
|
-
onClick: () =>
|
12393
|
+
onClick: () => {
|
12394
|
+
handleOpenSubmenu(sub?.name);
|
12395
|
+
},
|
12436
12396
|
className: twMerge(
|
12437
|
-
|
12438
|
-
"text-xs hover:bg-[#EEEEF0] mr-8 transition-all duration-300 mt-2 rounded-md py-2 flex items-center gap-2 p-2"
|
12397
|
+
"group flex gap-x-3 rounded-md p-2 text-gray-700 hover:bg-[#EEEEF0] mr-8 text-sm leading-6 transition-all duration-300 font-semibold items-center"
|
12439
12398
|
),
|
12440
12399
|
children: [
|
12441
|
-
|
12442
|
-
|
12400
|
+
sub?.icon,
|
12401
|
+
sub?.name,
|
12402
|
+
openSubmenu === sub?.name ? /* @__PURE__ */ jsxRuntimeExports.jsx(RefIcon, { className: twMerge("w-4 h-4 ml-auto") }) : /* @__PURE__ */ jsxRuntimeExports.jsx(
|
12403
|
+
RefIcon$7,
|
12404
|
+
{
|
12405
|
+
className: twMerge("w-4 h-4 ml-auto")
|
12406
|
+
}
|
12407
|
+
)
|
12443
12408
|
]
|
12444
|
-
}
|
12445
|
-
|
12446
|
-
)
|
12447
|
-
|
12448
|
-
|
12449
|
-
|
12409
|
+
}
|
12410
|
+
),
|
12411
|
+
openSubmenu === sub?.name && Array.isArray(sub?.children) && /* @__PURE__ */ jsxRuntimeExports.jsx(
|
12412
|
+
"ul",
|
12413
|
+
{
|
12414
|
+
className: twMerge(
|
12415
|
+
"pl-2 transition-all duration-300"
|
12416
|
+
),
|
12417
|
+
children: sub?.children.map(
|
12418
|
+
(item) => {
|
12419
|
+
return /* @__PURE__ */ jsxRuntimeExports.jsxs(
|
12420
|
+
"li",
|
12421
|
+
{
|
12422
|
+
onClick: () => handleClick(sub, item.path),
|
12423
|
+
className: twMerge(
|
12424
|
+
pathUrl.startsWith(item.path) ? "bg-[#EEEEF0] text-black" : "",
|
12425
|
+
"text-xs hover:bg-[#EEEEF0] mr-8 transition-all duration-300 mt-2 rounded-md py-2 flex items-center gap-2 p-2"
|
12426
|
+
),
|
12427
|
+
children: [
|
12428
|
+
item.icon,
|
12429
|
+
item.name
|
12430
|
+
]
|
12431
|
+
},
|
12432
|
+
item.path
|
12433
|
+
);
|
12434
|
+
}
|
12435
|
+
)
|
12436
|
+
}
|
12437
|
+
)
|
12438
|
+
] }, sub?.name);
|
12439
|
+
}
|
12440
|
+
)
|
12450
12441
|
}
|
12451
12442
|
)
|
12452
12443
|
}
|
@@ -12458,7 +12449,7 @@ const Sidebar = ({ children, menu = [] }) => {
|
|
12458
12449
|
"div",
|
12459
12450
|
{
|
12460
12451
|
className: twMerge(
|
12461
|
-
collapse && openSubCollapse ? "ml-
|
12452
|
+
collapse && openSubCollapse ? "ml-35" : "ml-5",
|
12462
12453
|
"flex-1 p-4 h-full overflow-y-auto scrollbar-none"
|
12463
12454
|
),
|
12464
12455
|
children
|