@bigbinary/neeto-team-members-frontend 4.4.27 → 4.5.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (44) hide show
  1. package/app/javascript/src/translations/en.json +22 -1
  2. package/dist/Groups.js +1 -1
  3. package/dist/ManageMember.js +2 -2
  4. package/dist/MembersDropdown.js +1 -1
  5. package/dist/TeamMembers.js +172 -21
  6. package/dist/TeamMembers.js.map +1 -1
  7. package/dist/TeamsDropdown.js +1 -1
  8. package/dist/cjs/Groups.js +1 -1
  9. package/dist/cjs/ManageMember.js +2 -2
  10. package/dist/cjs/MembersDropdown.js +1 -1
  11. package/dist/cjs/TeamMembers.js +171 -20
  12. package/dist/cjs/TeamMembers.js.map +1 -1
  13. package/dist/cjs/TeamsDropdown.js +1 -1
  14. package/dist/cjs/constants.js +4 -1
  15. package/dist/cjs/constants.js.map +1 -1
  16. package/dist/cjs/hooks.js +1 -1
  17. package/dist/cjs/index.js +5 -3
  18. package/dist/cjs/index.js.map +1 -1
  19. package/dist/cjs/utils.js +1 -1
  20. package/dist/constants.js +6 -0
  21. package/dist/constants.js.map +1 -1
  22. package/dist/hooks.js +1 -1
  23. package/dist/{index-CKp_a6SU.js → index-C2ciZlLk.js} +4 -3
  24. package/dist/index-C2ciZlLk.js.map +1 -0
  25. package/dist/{index-D0Ev1DvT.js → index-Cpad1EmZ.js} +6 -5
  26. package/dist/index-Cpad1EmZ.js.map +1 -0
  27. package/dist/{index-yFl2aYDN.js → index-DPMt5r_V.js} +4 -3
  28. package/dist/index-DPMt5r_V.js.map +1 -0
  29. package/dist/{index-C_Q5GzdX.js → index-DX_qEZeG.js} +6 -5
  30. package/dist/index-DX_qEZeG.js.map +1 -0
  31. package/dist/index.js +5 -3
  32. package/dist/index.js.map +1 -1
  33. package/dist/{useTeamsApi-DReZnkbo.js → useTeamsApi-DLoZKPuX.js} +14 -3
  34. package/dist/useTeamsApi-DLoZKPuX.js.map +1 -0
  35. package/dist/{useTeamsApi-DMq-AW7A.js → useTeamsApi-DqizqY5S.js} +14 -2
  36. package/dist/useTeamsApi-DqizqY5S.js.map +1 -0
  37. package/dist/utils.js +1 -1
  38. package/package.json +9 -9
  39. package/dist/index-CKp_a6SU.js.map +0 -1
  40. package/dist/index-C_Q5GzdX.js.map +0 -1
  41. package/dist/index-D0Ev1DvT.js.map +0 -1
  42. package/dist/index-yFl2aYDN.js.map +0 -1
  43. package/dist/useTeamsApi-DMq-AW7A.js.map +0 -1
  44. package/dist/useTeamsApi-DReZnkbo.js.map +0 -1
@@ -21,10 +21,10 @@ var reactI18next = require('react-i18next');
21
21
  var reactRouterDom = require('react-router-dom');
22
22
  var withReactQuery = require('../withReactQuery-C7a_pGxf.js');
23
23
  var index$1 = require('../index-CWyeI4Kz.js');
24
- var useTeamsApi = require('../useTeamsApi-DMq-AW7A.js');
24
+ var useTeamsApi = require('../useTeamsApi-DqizqY5S.js');
25
25
  var _toConsumableArray = require('@babel/runtime/helpers/toConsumableArray');
26
26
  var utils = require('@bigbinary/neeto-filters-frontend/utils');
27
- var ManageMember = require('../index-yFl2aYDN.js');
27
+ var ManageMember = require('../index-DPMt5r_V.js');
28
28
  var injectCss = require('../inject-css-vQvjPR2x.js');
29
29
  var neetoCist = require('@bigbinary/neeto-cist');
30
30
  var Button = require('@bigbinary/neetoui/Button');
@@ -36,6 +36,10 @@ var Typography = require('@bigbinary/neetoui/Typography');
36
36
  var Right$1 = require('@bigbinary/neeto-icons/Right');
37
37
  var Search = require('@bigbinary/neeto-icons/Search');
38
38
  var Input = require('@bigbinary/neetoui/Input');
39
+ var Pane = require('@bigbinary/neetoui/Pane');
40
+ var Radio = require('@bigbinary/neetoui/Radio');
41
+ var Toastr = require('@bigbinary/neetoui/Toastr');
42
+ var constants$1 = require('./constants.js');
39
43
  var NeetoHeader = require('@bigbinary/neeto-molecules/Header');
40
44
  require('@tanstack/react-query');
41
45
  require('../queryClient-4vAFE3bx.js');
@@ -47,7 +51,6 @@ require('qs');
47
51
  require('classnames');
48
52
  require('@bigbinary/neeto-icons/Info');
49
53
  require('@bigbinary/neeto-icons/LeftArrow');
50
- require('@bigbinary/neetoui/Toastr');
51
54
  require('@bigbinary/neetoui/Callout');
52
55
  require('@bigbinary/neetoui/formik/ActionBlock');
53
56
  require('@bigbinary/neetoui/formik/Form');
@@ -58,15 +61,14 @@ require('../RolesRadioGroup-CGjcYVyV.js');
58
61
  require('@bigbinary/neetoui/Label');
59
62
  require('@bigbinary/neetoui/formik/Radio');
60
63
  require('yup');
61
- require('@bigbinary/neetoui/Pane');
62
64
  require('@bigbinary/neetoui/Modal');
63
65
  require('@bigbinary/neetoui/formik/MultiEmailInput');
64
66
  require('@bigbinary/neetoui/formik/Input');
65
67
  require('@bigbinary/neeto-molecules/MoreDropdown');
66
68
  require('@bigbinary/neetoui/Avatar');
67
69
 
68
- function ownKeys$5(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; }
69
- function _objectSpread$5(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$5(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$5(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
70
+ function ownKeys$6(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; }
71
+ function _objectSpread$6(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$6(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$6(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
70
72
  var useFilters = function useFilters(_ref) {
71
73
  var _config$filterColumns;
72
74
  var config = _ref.config;
@@ -85,7 +87,7 @@ var useFilters = function useFilters(_ref) {
85
87
  emailSearchTerm = _useState2[0],
86
88
  setEmailSearchTerm = _useState2[1];
87
89
  var defaultNeetoFilters = utils.buildFiltersFromURL([].concat(_toConsumableArray((_config$filterColumns = config === null || config === void 0 ? void 0 : config.filterColumns) !== null && _config$filterColumns !== void 0 ? _config$filterColumns : ManageMember.defaultNeetoFiltersColumns()), [searchKeywordProps]));
88
- var _useState3 = require$$0.useState(_objectSpread$5(_objectSpread$5(_objectSpread$5({}, ManageMember.DEFAULT_FILTER_VALUES), config === null || config === void 0 ? void 0 : config.defaultFilterValues), {}, {
90
+ var _useState3 = require$$0.useState(_objectSpread$6(_objectSpread$6(_objectSpread$6({}, ManageMember.DEFAULT_FILTER_VALUES), config === null || config === void 0 ? void 0 : config.defaultFilterValues), {}, {
89
91
  neetoFilters: defaultNeetoFilters
90
92
  })),
91
93
  _useState4 = _slicedToArray(_useState3, 2),
@@ -134,8 +136,8 @@ var useFilters = function useFilters(_ref) {
134
136
  };
135
137
  };
136
138
 
137
- function ownKeys$4(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; }
138
- function _objectSpread$4(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$4(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$4(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
139
+ function ownKeys$5(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; }
140
+ function _objectSpread$5(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$5(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$5(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
139
141
  var useTeams = function useTeams(_ref) {
140
142
  var config = _ref.config,
141
143
  filters = _ref.filters,
@@ -211,7 +213,7 @@ var useTeams = function useTeams(_ref) {
211
213
  emails: ramda.pluck("email", rowData),
212
214
  keys: keys
213
215
  };
214
- setSelectedRows(_objectSpread$4({}, rows));
216
+ setSelectedRows(_objectSpread$5({}, rows));
215
217
  config === null || config === void 0 || (_config$table = config.table) === null || _config$table === void 0 || (_config$table$onRowSe = _config$table.onRowSelect) === null || _config$table$onRowSe === void 0 || _config$table$onRowSe.call(_config$table, {
216
218
  rows: rows,
217
219
  resetSelectedRows: resetSelectedRows,
@@ -241,8 +243,8 @@ injectCss.n(css,{});
241
243
  var FIXED_COLUMNS = ["name", "actions"];
242
244
  var MANAGE_ROLES_BUTTON_LABEL = i18next.t("neetoTeamMembers.labels.manageRole", constants.PLURAL);
243
245
 
244
- function ownKeys$3(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; }
245
- function _objectSpread$3(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$3(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$3(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
246
+ function ownKeys$4(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; }
247
+ function _objectSpread$4(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$4(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$4(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
246
248
  var Header$2 = function Header(_ref) {
247
249
  var isCreatePermissionGranted = _ref.isCreatePermissionGranted,
248
250
  otherActionBlock = _ref.otherActionBlock,
@@ -254,7 +256,7 @@ var Header$2 = function Header(_ref) {
254
256
  var isRolesButtonVisible = !!rolesButtonProps;
255
257
  var isOtherActionBlockVisible = !!otherActionBlock;
256
258
  return /*#__PURE__*/jsxRuntime.jsxs(jsxRuntime.Fragment, {
257
- children: [isOtherActionBlockVisible && otherActionBlock(), isRolesButtonVisible ? /*#__PURE__*/jsxRuntime.jsx(Button, _objectSpread$3({
259
+ children: [isOtherActionBlockVisible && otherActionBlock(), isRolesButtonVisible ? /*#__PURE__*/jsxRuntime.jsx(Button, _objectSpread$4({
258
260
  "data-cy": "ntm-manage-roles-button",
259
261
  label: MANAGE_ROLES_BUTTON_LABEL,
260
262
  style: "secondary"
@@ -395,8 +397,8 @@ var RolesDropdown = function RolesDropdown(_ref) {
395
397
  });
396
398
  };
397
399
 
398
- function ownKeys$2(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; }
399
- function _objectSpread$2(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$2(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$2(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
400
+ function ownKeys$3(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; }
401
+ function _objectSpread$3(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$3(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$3(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
400
402
  var Menu = Dropdown.Menu,
401
403
  MenuItem = Dropdown.MenuItem;
402
404
  var Left = function Left(_ref) {
@@ -542,7 +544,7 @@ var Left = function Left(_ref) {
542
544
  title: selectedAlert === null || selectedAlert === void 0 ? void 0 : selectedAlert.title,
543
545
  message: /*#__PURE__*/jsxRuntime.jsx(reactI18next.Trans, {
544
546
  i18nKey: selectedAlert === null || selectedAlert === void 0 ? void 0 : selectedAlert.message,
545
- values: _objectSpread$2(_objectSpread$2({}, selectedMembersCountValues), {}, {
547
+ values: _objectSpread$3(_objectSpread$3({}, selectedMembersCountValues), {}, {
546
548
  person: selectedRows.displayNames[0],
547
549
  role: bulkUpdateRole
548
550
  })
@@ -559,9 +561,10 @@ var Right = reactUtils.withT(function (_ref3) {
559
561
  columns = _ref3.columns,
560
562
  filterColumns = _ref3.filterColumns,
561
563
  handleNeetoFilterChange = _ref3.handleNeetoFilterChange,
562
- setIsFiltersPaneOpen = _ref3.setIsFiltersPaneOpen,
563
564
  isFiltersPaneOpen = _ref3.isFiltersPaneOpen,
564
- searchKeywordProps = _ref3.searchKeywordProps;
565
+ searchKeywordProps = _ref3.searchKeywordProps,
566
+ setIsDownloadPaneOpen = _ref3.setIsDownloadPaneOpen,
567
+ setIsFiltersPaneOpen = _ref3.setIsFiltersPaneOpen;
565
568
  return /*#__PURE__*/jsxRuntime.jsx(SubHeader$1.RightBlock, {
566
569
  columnsButtonProps: {
567
570
  columnData: columns,
@@ -572,6 +575,12 @@ var Right = reactUtils.withT(function (_ref3) {
572
575
  placeholder: t("neetoTeamMembers.columns.search")
573
576
  }
574
577
  },
578
+ downloadButtonProps: {
579
+ isVisible: true,
580
+ onClick: function onClick() {
581
+ return setIsDownloadPaneOpen(true);
582
+ }
583
+ },
575
584
  filterProps: {
576
585
  columns: filterColumns,
577
586
  isOpen: isFiltersPaneOpen,
@@ -586,6 +595,134 @@ var SubHeader = {
586
595
  Right: Right
587
596
  };
588
597
 
598
+ var EXPORT_TYPES = {
599
+ PDF: "pdf",
600
+ CSV: "csv",
601
+ EXCEL: "xlsx"
602
+ };
603
+ var DEFAULT_EXPORT_OPTIONS = {
604
+ exportType: EXPORT_TYPES.EXCEL
605
+ };
606
+ var EXPORT_OPTIONS = [{
607
+ type: EXPORT_TYPES.EXCEL,
608
+ individualExportLabel: i18next.t("neetoTeamMembers.labels.downloads.xlsx"),
609
+ bulkExportLabel: i18next.t("neetoTeamMembers.labels.downloadAs", {
610
+ format: i18next.t("neetoTeamMembers.labels.downloads.xlsx")
611
+ }),
612
+ dataCy: "download-as-excel-radio-item"
613
+ }, {
614
+ type: EXPORT_TYPES.CSV,
615
+ individualExportLabel: i18next.t("neetoTeamMembers.labels.downloads.csv"),
616
+ bulkExportLabel: i18next.t("neetoTeamMembers.labels.downloadAs", {
617
+ format: i18next.t("neetoTeamMembers.labels.downloads.csv")
618
+ }),
619
+ dataCy: "download-as-csv-radio-item"
620
+ }, {
621
+ type: EXPORT_TYPES.PDF,
622
+ individualExportLabel: i18next.t("neetoTeamMembers.labels.downloads.pdf"),
623
+ bulkExportLabel: i18next.t("neetoTeamMembers.labels.downloadAs", {
624
+ format: i18next.t("neetoTeamMembers.labels.downloads.pdf")
625
+ }),
626
+ dataCy: "download-as-pdf-radio-item"
627
+ }];
628
+
629
+ function ownKeys$2(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; }
630
+ function _objectSpread$2(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$2(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$2(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
631
+ var ExportPane = function ExportPane(_ref) {
632
+ var isOpen = _ref.isOpen,
633
+ onClose = _ref.onClose,
634
+ appliedFilters = _ref.appliedFilters,
635
+ hasBulkSelectedAllRows = _ref.hasBulkSelectedAllRows,
636
+ selectedMemberIds = _ref.selectedMemberIds,
637
+ selectedRowsCount = _ref.selectedRowsCount;
638
+ var _useState = require$$0.useState(DEFAULT_EXPORT_OPTIONS),
639
+ _useState2 = _slicedToArray(_useState, 2),
640
+ exportOptions = _useState2[0],
641
+ setExportOptions = _useState2[1];
642
+ var _useTranslation = reactI18next.useTranslation(),
643
+ t = _useTranslation.t;
644
+ var setExportOption = function setExportOption(exportOptions) {
645
+ return setExportOptions(ramda.mergeLeft(exportOptions));
646
+ };
647
+ var exportType = exportOptions.exportType;
648
+ var getParams = function getParams() {
649
+ return _objectSpread$2(_objectSpread$2({}, exportOptions), {}, {
650
+ filters: appliedFilters || undefined,
651
+ considerAllMembers: hasBulkSelectedAllRows,
652
+ memberIds: hasBulkSelectedAllRows ? undefined : selectedMemberIds
653
+ });
654
+ };
655
+ var _useExportMembers = useTeamsApi.useExportMembers({
656
+ onSuccess: function onSuccess() {
657
+ onClose();
658
+ setExportOptions(DEFAULT_EXPORT_OPTIONS);
659
+ Toastr.success(/*#__PURE__*/jsxRuntime.jsx(reactI18next.Trans, {
660
+ i18nKey: "toastr.success.downloadMembers",
661
+ values: {
662
+ email: initializers.globalProps.user.email
663
+ }
664
+ }));
665
+ utils$1.captureAnalyticsEvent(constants$1.EVENTS.TEAM_MEMBERS_DOWNLOADED, _objectSpread$2({}, exportOptions));
666
+ },
667
+ onError: function onError(error) {
668
+ return Toastr.error(error);
669
+ }
670
+ }),
671
+ exportMembers = _useExportMembers.mutate;
672
+ var description = neetoCist.isNotEmpty(selectedMemberIds) || hasBulkSelectedAllRows ? t("neetoTeamMembers.downloadPane.description.selectedMembers", {
673
+ count: selectedRowsCount
674
+ }) : t("neetoTeamMembers.downloadPane.description.allMembers");
675
+ return /*#__PURE__*/jsxRuntime.jsxs(Pane, {
676
+ isOpen: isOpen,
677
+ onClose: onClose,
678
+ children: [/*#__PURE__*/jsxRuntime.jsx(Pane.Header, {
679
+ children: /*#__PURE__*/jsxRuntime.jsx(Typography, {
680
+ "data-cy": "export-member-heading",
681
+ style: "h2",
682
+ children: t("neetoTeamMembers.downloadPane.title")
683
+ })
684
+ }), /*#__PURE__*/jsxRuntime.jsx(Pane.Body, {
685
+ children: /*#__PURE__*/jsxRuntime.jsx(Radio, {
686
+ stacked: true,
687
+ className: "flex-grow-0 space-y-4",
688
+ label: description,
689
+ children: EXPORT_OPTIONS.map(function (_ref2) {
690
+ var type = _ref2.type,
691
+ bulkExportLabel = _ref2.bulkExportLabel,
692
+ dataCy = _ref2.dataCy;
693
+ return /*#__PURE__*/jsxRuntime.jsx(Radio.Item, {
694
+ checked: exportType === type,
695
+ "data-cy": dataCy,
696
+ label: bulkExportLabel,
697
+ onChange: function onChange() {
698
+ return setExportOption({
699
+ exportType: type
700
+ });
701
+ }
702
+ }, type);
703
+ })
704
+ })
705
+ }), /*#__PURE__*/jsxRuntime.jsxs(Pane.Footer, {
706
+ className: "gap-x-2",
707
+ children: [/*#__PURE__*/jsxRuntime.jsx(Button, {
708
+ "data-cy": "export-submit-button",
709
+ label: t("neetoTeamMembers.buttons.download"),
710
+ onClick: function onClick() {
711
+ return exportMembers({
712
+ "export": getParams()
713
+ });
714
+ }
715
+ }), /*#__PURE__*/jsxRuntime.jsx(Button, {
716
+ className: "mr-2",
717
+ "data-cy": "export-cancel-button",
718
+ label: t("neetoTeamMembers.buttons.cancel"),
719
+ style: "text",
720
+ onClick: onClose
721
+ })]
722
+ })]
723
+ });
724
+ };
725
+
589
726
  function ownKeys$1(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; }
590
727
  function _objectSpread$1(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$1(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$1(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
591
728
  var Header = function Header(_ref) {
@@ -627,8 +764,12 @@ var TeamMembers = function TeamMembers(_ref) {
627
764
  setIsFiltersPaneOpen = _useState2[1];
628
765
  var _useState3 = require$$0.useState(false),
629
766
  _useState4 = _slicedToArray(_useState3, 2),
630
- hasBulkSelectedAllRows = _useState4[0],
631
- setHasBulkSelectedAllRows = _useState4[1];
767
+ isDownloadPaneOpen = _useState4[0],
768
+ setIsDownloadPaneOpen = _useState4[1];
769
+ var _useState5 = require$$0.useState(false),
770
+ _useState6 = _slicedToArray(_useState5, 2),
771
+ hasBulkSelectedAllRows = _useState6[0],
772
+ setHasBulkSelectedAllRows = _useState6[1];
632
773
  require$$0.useEffect(function () {
633
774
  handleMemberFilterChange();
634
775
  }, []);
@@ -763,6 +904,7 @@ var TeamMembers = function TeamMembers(_ref) {
763
904
  handleNeetoFilterChange: handleNeetoFilterChange,
764
905
  isFiltersPaneOpen: isFiltersPaneOpen,
765
906
  searchKeywordProps: searchKeywordProps,
907
+ setIsDownloadPaneOpen: setIsDownloadPaneOpen,
766
908
  setIsFiltersPaneOpen: setIsFiltersPaneOpen
767
909
  })
768
910
  }), /*#__PURE__*/jsxRuntime.jsx(FiltersBar, {
@@ -771,6 +913,15 @@ var TeamMembers = function TeamMembers(_ref) {
771
913
  keyword: searchKeywordProps,
772
914
  setIsPaneOpen: setIsFiltersPaneOpen,
773
915
  onChange: handleNeetoFilterChange
916
+ }), /*#__PURE__*/jsxRuntime.jsx(ExportPane, {
917
+ hasBulkSelectedAllRows: hasBulkSelectedAllRows,
918
+ selectedRowsCount: selectedRowsCount,
919
+ appliedFilters: filters,
920
+ isOpen: isDownloadPaneOpen,
921
+ selectedMemberIds: selectedRows.keys,
922
+ onClose: function onClose() {
923
+ return setIsDownloadPaneOpen(false);
924
+ }
774
925
  }), /*#__PURE__*/jsxRuntime.jsx(TableWrapper, {
775
926
  hasPagination: (team === null || team === void 0 ? void 0 : team.membersCount) > filters.pageSize,
776
927
  children: (team === null || team === void 0 ? void 0 : team.membersCount) !== 0 ? /*#__PURE__*/jsxRuntime.jsx(Table, {