@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.
@@ -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-OdNt_XE3.js';
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: 16, height: 20, fill: "none", children: /* @__PURE__ */ jsxRuntimeExports.jsx(
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: "m13.744 15.03.75.007-.75-.007ZM1.334 4.25a.75.75 0 1 0 0 1.5v-1.5Zm13.333 1.5a.75.75 0 0 0 0-1.5v1.5ZM7.083 8.334a.75.75 0 1 0-1.5 0h1.5ZM5.583 15a.75.75 0 0 0 1.5 0h-1.5Zm4.834-6.666a.75.75 0 0 0-1.5 0h1.5ZM8.917 15a.75.75 0 0 0 1.5 0h-1.5Zm4.916-10-.75-.006-.09 10.03.75.006.75.007.09-10.03-.75-.007Zm-3.422 13.334v-.75H5.5v1.5h4.91v-.75ZM2.167 5h-.75v10h1.5V5h-.75Zm-.834 0v.75h.834v-1.5h-.834V5Zm.834 0v.75h2.5v-1.5h-2.5V5Zm2.5 0v.75h6.666v-1.5H4.667V5Zm6.666 0v.75h2.5v-1.5h-2.5V5Zm2.5 0v.75h.834v-1.5h-.834V5Zm-9.166-.37h.75c0-1.142 1.07-2.213 2.583-2.213v-1.5c-2.17 0-4.083 1.582-4.083 3.713h.75ZM8 1.667v.75c1.512 0 2.583 1.071 2.583 2.213h1.5C12.083 2.499 10.17.917 8 .917v.75ZM4.667 4.63h-.75V5h1.5v-.37h-.75Zm6.666 0h-.75V5h1.5v-.37h-.75ZM5.5 18.334v-.75A2.583 2.583 0 0 1 2.917 15h-1.5A4.083 4.083 0 0 0 5.5 19.084v-.75Zm8.244-3.304-.75-.007a2.583 2.583 0 0 1-2.583 2.56v1.5a4.083 4.083 0 0 0 4.083-4.046l-.75-.007Zm-7.41-6.696h-.75V15h1.5V8.334h-.75Zm3.333 0h-.75V15h1.5V8.334h-.75Z"
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: breadcrumbItems }),
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
- breadCrumb,
5355
+ menu,
5322
5356
  groupHeadingButtonItems,
5323
5357
  handleClickGroupHeadingButtonItem
5324
5358
  } = props;
5325
5359
  return /* @__PURE__ */ jsxRuntimeExports.jsxs(
5326
5360
  Heading,
5327
5361
  {
5328
- breadcrumbItems: breadCrumb,
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
- let dataBreakcrum;
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
- breadCrumb: generateBreadcrumb,
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.1';
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(menu);
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 activeMenu = useMemo$1(
12191
- () => menu.find(
12192
- (item) => item?.subMenu?.map(
12193
- (sub) => sub.href === activeMainMenu || sub.href === pathUrl
12194
- )
12195
- ),
12196
- [menu, activeMainMenu, pathUrl]
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
- (item) => item.name.toLowerCase().startsWith(searchSidebar.toLowerCase())
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
- }, [menu, searchSidebar]);
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 ? "https://i.ibb.co/XrQYLt6C/logo.png" : openSubCollapse ? "" : "https://i.ibb.co/0phgNKb7/Type-Collapse-menu.png",
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
- "ul",
12246
- {
12247
- role: "list",
12248
- className: twMerge(
12249
- "-mx-2 space-y-1 relative h-[60vh] overflow-y-auto scrollbar-hidden"
12250
- ),
12251
- children: newMenu.map((item) => {
12252
- const isActive = openSubCollapse || [activeMainMenu, pathUrl].includes(item.href) || collapse;
12253
- const isActiveUrl = item.href === activeMainMenu || item.href === pathUrl;
12254
- return /* @__PURE__ */ jsxRuntimeExports.jsxs(
12255
- "li",
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
- "div",
12243
+ "span",
12300
12244
  {
12301
12245
  className: twMerge(
12302
- "relative group rounded-bl-full rounded-tl-full hover:text-black",
12303
- !collapse && "hover:bg-[#FFFFFF]"
12304
- ),
12305
- children: /* @__PURE__ */ jsxRuntimeExports.jsxs(
12306
- "a",
12307
- {
12308
- onClick: () => {
12309
- handleActiveMain(item.href);
12310
- setCollapse(false);
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
- item.name
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: collapse && bm.label })
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] z-10 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"
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 top-0 p-3.5 space-y-4 space-x-4 z-50"
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-full h-auto object-contain",
12390
- src: "https://i.ibb.co/XrQYLt6C/logo.png",
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: activeMenu && /* @__PURE__ */ jsxRuntimeExports.jsx(
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: activeMenu?.subMenu?.map((sub) => /* @__PURE__ */ jsxRuntimeExports.jsxs("li", { children: [
12410
- /* @__PURE__ */ jsxRuntimeExports.jsxs(
12411
- "a",
12412
- {
12413
- onClick: () => {
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: () => router(sub2.href),
12393
+ onClick: () => {
12394
+ handleOpenSubmenu(sub?.name);
12395
+ },
12436
12396
  className: twMerge(
12437
- sub2.href === pathUrl ? "bg-[#EEEEF0] text-black" : "",
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
- sub2.icon,
12442
- sub2.name
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
- sub2.name
12446
- ))
12447
- }
12448
- )
12449
- ] }, sub.name))
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-30" : "",
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