@teambit/sidebar 0.0.652 → 0.0.655

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.
@@ -4,6 +4,8 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
4
4
 
5
5
  require("core-js/modules/es.array.iterator.js");
6
6
 
7
+ require("core-js/modules/es.array.sort.js");
8
+
7
9
  Object.defineProperty(exports, "__esModule", {
8
10
  value: true
9
11
  });
@@ -87,15 +89,17 @@ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj &&
87
89
  * side bar component.
88
90
  */
89
91
  function SideBar(_ref) {
90
- var _drawers$;
91
-
92
92
  let {
93
93
  drawerSlot,
94
94
  itemSlot
95
95
  } = _ref,
96
96
  rest = (0, _objectWithoutProperties2().default)(_ref, ["drawerSlot", "itemSlot"]);
97
- const drawers = (0, _lodash().flatten)(drawerSlot.values());
98
- const [openDrawerList, onToggleDrawer] = (0, _react().useState)([(_drawers$ = drawers[0]) === null || _drawers$ === void 0 ? void 0 : _drawers$.id]);
97
+ const drawers = (0, _lodash().flatten)(drawerSlot.values()).filter(drawer => {
98
+ var _drawer$isHidden;
99
+
100
+ return !(drawer !== null && drawer !== void 0 && (_drawer$isHidden = drawer.isHidden) !== null && _drawer$isHidden !== void 0 && _drawer$isHidden.call(drawer));
101
+ }).sort(sortFn);
102
+ const [openDrawerList, onToggleDrawer] = (0, _react().useState)(drawers.map(drawer => drawer.id));
99
103
  const items = (0, _react().useMemo)(() => (0, _lodash().flatten)(itemSlot === null || itemSlot === void 0 ? void 0 : itemSlot.values()), [itemSlot]);
100
104
 
101
105
  const handleDrawerToggle = id => {
@@ -127,4 +131,13 @@ function SideBar(_ref) {
127
131
  }));
128
132
  }
129
133
 
134
+ function sortFn(first, second) {
135
+ var _first$order, _second$order;
136
+
137
+ // 0 - equal
138
+ // <0 - first < second
139
+ // >0 - first > second
140
+ return ((_first$order = first.order) !== null && _first$order !== void 0 ? _first$order : 0) - ((_second$order = second.order) !== null && _second$order !== void 0 ? _second$order : 0);
141
+ }
142
+
130
143
  //# sourceMappingURL=side-bar.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["side-bar.tsx"],"names":["SideBar","drawerSlot","itemSlot","rest","drawers","values","openDrawerList","onToggleDrawer","id","items","handleDrawerToggle","isDrawerOpen","includes","list","filter","drawer","concat","styles","sidebar","map","name","widget","Context"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;;AAAA;AAAA;AAAA;;AAAA;AAAA;;AACA;AAAA;;AAAA;AAAA;AAAA;;AAAA;AAAA;;AACA;AAAA;;AAAA;AAAA;AAAA;;AAAA;AAAA;;AACA;AAAA;;AAAA;AAAA;AAAA;;AAAA;AAAA;;AAEA;AAAA;;AAAA;AAAA;AAAA;;AAAA;AAAA;;;;;;AAaA;AACA;AACA;AACO,SAASA,OAAT,OAAkE;AAAA;;AAAA,MAAjD;AAAEC,IAAAA,UAAF;AAAcC,IAAAA;AAAd,GAAiD;AAAA,MAAtBC,IAAsB;AACvE,QAAMC,OAAO,GAAG,uBAAQH,UAAU,CAACI,MAAX,EAAR,CAAhB;AACA,QAAM,CAACC,cAAD,EAAiBC,cAAjB,IAAmC,uBAAiC,cAACH,OAAO,CAAC,CAAD,CAAR,8CAAC,UAAYI,EAAb,CAAjC,CAAzC;AACA,QAAMC,KAAK,GAAG,sBAAQ,MAAM,uBAAQP,QAAR,aAAQA,QAAR,uBAAQA,QAAQ,CAAEG,MAAV,EAAR,CAAd,EAA2C,CAACH,QAAD,CAA3C,CAAd;;AAEA,QAAMQ,kBAAkB,GAAIF,EAAD,IAAgB;AACzC,UAAMG,YAAY,GAAGL,cAAc,CAACM,QAAf,CAAwBJ,EAAxB,CAArB;;AACA,QAAIG,YAAJ,EAAkB;AAChBJ,MAAAA,cAAc,CAAEM,IAAD,IAAUA,IAAI,CAACC,MAAL,CAAaC,MAAD,IAAYA,MAAM,KAAKP,EAAnC,CAAX,CAAd;AACA;AACD;;AACDD,IAAAA,cAAc,CAAEM,IAAD,IAAUA,IAAI,CAACG,MAAL,CAAYR,EAAZ,CAAX,CAAd;AACD,GAPD;;AASA,sBACE,mEAASL,IAAT;AAAe,IAAA,SAAS,EAAEc,yBAAOC;AAAjC,mBACE,+BAAC,mCAAD;AAAa,IAAA,KAAK,EAAET;AAApB,IADF,EAEGL,OAAO,CAACe,GAAR,CAAaJ,MAAD,IAAY;AACvB,QAAI,CAACA,MAAD,IAAW,CAACA,MAAM,CAACK,IAAvB,EAA6B,OAAO,IAAP,CADN,CAEvB;;AACA,wBACE,+BAAC,8BAAD;AACE,MAAA,MAAM,EAAEd,cAAc,CAACM,QAAf,CAAwBG,MAAM,CAACP,EAA/B,CADV;AAEE,MAAA,QAAQ,EAAE,MAAME,kBAAkB,CAACK,MAAM,CAACP,EAAR,CAFpC;AAGE,MAAA,GAAG,EAAEO,MAAM,CAACP,EAHd;AAIE,MAAA,IAAI,EAAEO,MAAM,CAACK,IAJf;AAKE,MAAA,MAAM,EAAEL,MAAM,CAACM,MALjB;AAME,MAAA,OAAO,EAAEN,MAAM,CAACO;AANlB,oBAQE,+BAAC,MAAD,CAAQ,MAAR,OARF,CADF;AAYD,GAfA,CAFH,CADF;AAqBD","sourcesContent":["import React, { useState, useMemo } from 'react';\nimport { flatten } from 'lodash';\nimport { MenuSection } from '@teambit/design.ui.surfaces.menu.section';\nimport { DrawerUI } from '@teambit/ui-foundation.ui.tree.drawer';\nimport { DrawerSlot, SidebarItemSlot } from '../../sidebar.ui.runtime';\nimport styles from './side-bar.module.scss';\n\nexport type SideBarProps = {\n /**\n * slot of registered drawers.\n */\n drawerSlot: DrawerSlot;\n /**\n * slot of registered items to the main section at the top.\n */\n itemSlot?: SidebarItemSlot;\n} & React.HTMLAttributes<HTMLDivElement>;\n\n/**\n * side bar component.\n */\nexport function SideBar({ drawerSlot, itemSlot, ...rest }: SideBarProps) {\n const drawers = flatten(drawerSlot.values());\n const [openDrawerList, onToggleDrawer] = useState<(string | undefined)[]>([drawers[0]?.id]);\n const items = useMemo(() => flatten(itemSlot?.values()), [itemSlot]);\n\n const handleDrawerToggle = (id: string) => {\n const isDrawerOpen = openDrawerList.includes(id);\n if (isDrawerOpen) {\n onToggleDrawer((list) => list.filter((drawer) => drawer !== id));\n return;\n }\n onToggleDrawer((list) => list.concat(id));\n };\n\n return (\n <div {...rest} className={styles.sidebar}>\n <MenuSection items={items} />\n {drawers.map((drawer) => {\n if (!drawer || !drawer.name) return null;\n // consider passing collapse all as a prop so each drawer collapses itself\n return (\n <DrawerUI\n isOpen={openDrawerList.includes(drawer.id)}\n onToggle={() => handleDrawerToggle(drawer.id)}\n key={drawer.id}\n name={drawer.name}\n Widget={drawer.widget}\n Context={drawer.Context}\n >\n <drawer.render />\n </DrawerUI>\n );\n })}\n </div>\n );\n}\n"]}
1
+ {"version":3,"sources":["side-bar.tsx"],"names":["SideBar","drawerSlot","itemSlot","rest","drawers","values","filter","drawer","isHidden","sort","sortFn","openDrawerList","onToggleDrawer","map","id","items","handleDrawerToggle","isDrawerOpen","includes","list","concat","styles","sidebar","name","widget","Context","first","second","order"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;;AAAA;AAAA;AAAA;;AAAA;AAAA;;AACA;AAAA;;AAAA;AAAA;AAAA;;AAAA;AAAA;;AACA;AAAA;;AAAA;AAAA;AAAA;;AAAA;AAAA;;AACA;AAAA;;AAAA;AAAA;AAAA;;AAAA;AAAA;;AAEA;AAAA;;AAAA;AAAA;AAAA;;AAAA;AAAA;;;;;;AAaA;AACA;AACA;AACO,SAASA,OAAT,OAAkE;AAAA,MAAjD;AAAEC,IAAAA,UAAF;AAAcC,IAAAA;AAAd,GAAiD;AAAA,MAAtBC,IAAsB;AACvE,QAAMC,OAAO,GAAG,uBAAQH,UAAU,CAACI,MAAX,EAAR,EACbC,MADa,CACLC,MAAD;AAAA;;AAAA,WAAY,EAACA,MAAD,aAACA,MAAD,mCAACA,MAAM,CAAEC,QAAT,6CAAC,sBAAAD,MAAM,CAAP,CAAZ;AAAA,GADM,EAEbE,IAFa,CAERC,MAFQ,CAAhB;AAIA,QAAM,CAACC,cAAD,EAAiBC,cAAjB,IAAmC,uBAAiCR,OAAO,CAACS,GAAR,CAAaN,MAAD,IAAYA,MAAM,CAACO,EAA/B,CAAjC,CAAzC;AACA,QAAMC,KAAK,GAAG,sBAAQ,MAAM,uBAAQb,QAAR,aAAQA,QAAR,uBAAQA,QAAQ,CAAEG,MAAV,EAAR,CAAd,EAA2C,CAACH,QAAD,CAA3C,CAAd;;AAEA,QAAMc,kBAAkB,GAAIF,EAAD,IAAgB;AACzC,UAAMG,YAAY,GAAGN,cAAc,CAACO,QAAf,CAAwBJ,EAAxB,CAArB;;AACA,QAAIG,YAAJ,EAAkB;AAChBL,MAAAA,cAAc,CAAEO,IAAD,IAAUA,IAAI,CAACb,MAAL,CAAaC,MAAD,IAAYA,MAAM,KAAKO,EAAnC,CAAX,CAAd;AACA;AACD;;AACDF,IAAAA,cAAc,CAAEO,IAAD,IAAUA,IAAI,CAACC,MAAL,CAAYN,EAAZ,CAAX,CAAd;AACD,GAPD;;AASA,sBACE,mEAASX,IAAT;AAAe,IAAA,SAAS,EAAEkB,yBAAOC;AAAjC,mBACE,+BAAC,mCAAD;AAAa,IAAA,KAAK,EAAEP;AAApB,IADF,EAEGX,OAAO,CAACS,GAAR,CAAaN,MAAD,IAAY;AACvB,QAAI,CAACA,MAAD,IAAW,CAACA,MAAM,CAACgB,IAAvB,EAA6B,OAAO,IAAP,CADN,CAEvB;;AACA,wBACE,+BAAC,8BAAD;AACE,MAAA,MAAM,EAAEZ,cAAc,CAACO,QAAf,CAAwBX,MAAM,CAACO,EAA/B,CADV;AAEE,MAAA,QAAQ,EAAE,MAAME,kBAAkB,CAACT,MAAM,CAACO,EAAR,CAFpC;AAGE,MAAA,GAAG,EAAEP,MAAM,CAACO,EAHd;AAIE,MAAA,IAAI,EAAEP,MAAM,CAACgB,IAJf;AAKE,MAAA,MAAM,EAAEhB,MAAM,CAACiB,MALjB;AAME,MAAA,OAAO,EAAEjB,MAAM,CAACkB;AANlB,oBAQE,+BAAC,MAAD,CAAQ,MAAR,OARF,CADF;AAYD,GAfA,CAFH,CADF;AAqBD;;AACD,SAASf,MAAT,CAAgBgB,KAAhB,EAAmCC,MAAnC,EAAuD;AAAA;;AACrD;AACA;AACA;AAEA,SAAO,iBAACD,KAAK,CAACE,KAAP,uDAAgB,CAAhB,sBAAsBD,MAAM,CAACC,KAA7B,yDAAsC,CAAtC,CAAP;AACD","sourcesContent":["import React, { useState, useMemo } from 'react';\nimport { flatten } from 'lodash';\nimport { MenuSection } from '@teambit/design.ui.surfaces.menu.section';\nimport { DrawerType, DrawerUI } from '@teambit/ui-foundation.ui.tree.drawer';\nimport { DrawerSlot, SidebarItemSlot } from '../../sidebar.ui.runtime';\nimport styles from './side-bar.module.scss';\n\nexport type SideBarProps = {\n /**\n * slot of registered drawers.\n */\n drawerSlot: DrawerSlot;\n /**\n * slot of registered items to the main section at the top.\n */\n itemSlot?: SidebarItemSlot;\n} & React.HTMLAttributes<HTMLDivElement>;\n\n/**\n * side bar component.\n */\nexport function SideBar({ drawerSlot, itemSlot, ...rest }: SideBarProps) {\n const drawers = flatten(drawerSlot.values())\n .filter((drawer) => !drawer?.isHidden?.())\n .sort(sortFn);\n\n const [openDrawerList, onToggleDrawer] = useState<(string | undefined)[]>(drawers.map((drawer) => drawer.id));\n const items = useMemo(() => flatten(itemSlot?.values()), [itemSlot]);\n\n const handleDrawerToggle = (id: string) => {\n const isDrawerOpen = openDrawerList.includes(id);\n if (isDrawerOpen) {\n onToggleDrawer((list) => list.filter((drawer) => drawer !== id));\n return;\n }\n onToggleDrawer((list) => list.concat(id));\n };\n\n return (\n <div {...rest} className={styles.sidebar}>\n <MenuSection items={items} />\n {drawers.map((drawer) => {\n if (!drawer || !drawer.name) return null;\n // consider passing collapse all as a prop so each drawer collapses itself\n return (\n <DrawerUI\n isOpen={openDrawerList.includes(drawer.id)}\n onToggle={() => handleDrawerToggle(drawer.id)}\n key={drawer.id}\n name={drawer.name}\n Widget={drawer.widget}\n Context={drawer.Context}\n >\n <drawer.render />\n </DrawerUI>\n );\n })}\n </div>\n );\n}\nfunction sortFn(first: DrawerType, second: DrawerType) {\n // 0 - equal\n // <0 - first < second\n // >0 - first > second\n\n return (first.order ?? 0) - (second.order ?? 0);\n}\n"]}
package/package.json CHANGED
@@ -1,12 +1,12 @@
1
1
  {
2
2
  "name": "@teambit/sidebar",
3
- "version": "0.0.652",
3
+ "version": "0.0.655",
4
4
  "homepage": "https://bit.dev/teambit/ui-foundation/sidebar",
5
5
  "main": "dist/index.js",
6
6
  "componentId": {
7
7
  "scope": "teambit.ui-foundation",
8
8
  "name": "sidebar",
9
- "version": "0.0.652"
9
+ "version": "0.0.655"
10
10
  },
11
11
  "dependencies": {
12
12
  "@teambit/harmony": "0.2.11",
@@ -17,9 +17,9 @@
17
17
  "@teambit/base-ui.routing.nav-link": "1.0.0",
18
18
  "@teambit/documenter.ui.separator": "4.1.1",
19
19
  "@teambit/evangelist.elements.icon": "1.0.2",
20
- "@teambit/component": "0.0.652",
21
- "@teambit/ui-foundation.ui.tree.drawer": "0.0.490",
22
- "@teambit/ui": "0.0.652",
20
+ "@teambit/component": "0.0.655",
21
+ "@teambit/ui-foundation.ui.tree.drawer": "0.0.491",
22
+ "@teambit/ui": "0.0.655",
23
23
  "@teambit/design.ui.surfaces.menu.section": "0.0.347"
24
24
  },
25
25
  "devDependencies": {
@@ -33,7 +33,7 @@
33
33
  "@types/node": "12.20.4"
34
34
  },
35
35
  "peerDependencies": {
36
- "@teambit/legacy": "1.0.223",
36
+ "@teambit/legacy": "1.0.225",
37
37
  "react-dom": "^16.8.0 || ^17.0.0",
38
38
  "react": "^16.8.0 || ^17.0.0"
39
39
  },
@@ -61,7 +61,7 @@
61
61
  "react": "-"
62
62
  },
63
63
  "peerDependencies": {
64
- "@teambit/legacy": "1.0.223",
64
+ "@teambit/legacy": "1.0.225",
65
65
  "react-dom": "^16.8.0 || ^17.0.0",
66
66
  "react": "^16.8.0 || ^17.0.0"
67
67
  }
@@ -1,7 +1,7 @@
1
1
  import React, { useState, useMemo } from 'react';
2
2
  import { flatten } from 'lodash';
3
3
  import { MenuSection } from '@teambit/design.ui.surfaces.menu.section';
4
- import { DrawerUI } from '@teambit/ui-foundation.ui.tree.drawer';
4
+ import { DrawerType, DrawerUI } from '@teambit/ui-foundation.ui.tree.drawer';
5
5
  import { DrawerSlot, SidebarItemSlot } from '../../sidebar.ui.runtime';
6
6
  import styles from './side-bar.module.scss';
7
7
 
@@ -20,8 +20,11 @@ export type SideBarProps = {
20
20
  * side bar component.
21
21
  */
22
22
  export function SideBar({ drawerSlot, itemSlot, ...rest }: SideBarProps) {
23
- const drawers = flatten(drawerSlot.values());
24
- const [openDrawerList, onToggleDrawer] = useState<(string | undefined)[]>([drawers[0]?.id]);
23
+ const drawers = flatten(drawerSlot.values())
24
+ .filter((drawer) => !drawer?.isHidden?.())
25
+ .sort(sortFn);
26
+
27
+ const [openDrawerList, onToggleDrawer] = useState<(string | undefined)[]>(drawers.map((drawer) => drawer.id));
25
28
  const items = useMemo(() => flatten(itemSlot?.values()), [itemSlot]);
26
29
 
27
30
  const handleDrawerToggle = (id: string) => {
@@ -55,3 +58,10 @@ export function SideBar({ drawerSlot, itemSlot, ...rest }: SideBarProps) {
55
58
  </div>
56
59
  );
57
60
  }
61
+ function sortFn(first: DrawerType, second: DrawerType) {
62
+ // 0 - equal
63
+ // <0 - first < second
64
+ // >0 - first > second
65
+
66
+ return (first.order ?? 0) - (second.order ?? 0);
67
+ }