@local-civics/mgmt-ui 0.1.194 → 0.1.196

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/index.js CHANGED
@@ -183,8 +183,8 @@ function LinksGroup({ icon: Icon, href, label, initiallyOpened, links, active, n
183
183
  }
184
184
 
185
185
  var __defProp$d = Object.defineProperty;
186
- var __defProps$a = Object.defineProperties;
187
- var __getOwnPropDescs$a = Object.getOwnPropertyDescriptors;
186
+ var __defProps$9 = Object.defineProperties;
187
+ var __getOwnPropDescs$9 = Object.getOwnPropertyDescriptors;
188
188
  var __getOwnPropSymbols$d = Object.getOwnPropertySymbols;
189
189
  var __hasOwnProp$d = Object.prototype.hasOwnProperty;
190
190
  var __propIsEnum$d = Object.prototype.propertyIsEnumerable;
@@ -200,7 +200,7 @@ var __spreadValues$d = (a, b) => {
200
200
  }
201
201
  return a;
202
202
  };
203
- var __spreadProps$a = (a, b) => __defProps$a(a, __getOwnPropDescs$a(b));
203
+ var __spreadProps$9 = (a, b) => __defProps$9(a, __getOwnPropDescs$9(b));
204
204
  const useStyles$u = core.createStyles((theme, _params, getRef) => {
205
205
  const icon = getRef("icon");
206
206
  return {
@@ -232,7 +232,7 @@ const useStyles$u = core.createStyles((theme, _params, getRef) => {
232
232
  color: theme.colorScheme === "dark" ? theme.white : theme.black,
233
233
  borderBottom: `1px solid ${theme.colorScheme === "dark" ? theme.colors.dark[4] : theme.colors.gray[3]}`
234
234
  },
235
- link: __spreadProps$a(__spreadValues$d({}, theme.fn.focusStyles()), {
235
+ link: __spreadProps$9(__spreadValues$d({}, theme.fn.focusStyles()), {
236
236
  display: "flex",
237
237
  alignItems: "center",
238
238
  textDecoration: "none",
@@ -315,7 +315,7 @@ function Navbar(props) {
315
315
  }
316
316
  return /* @__PURE__ */ React__namespace.createElement(
317
317
  LinksGroup,
318
- __spreadProps$a(__spreadValues$d(__spreadValues$d({
318
+ __spreadProps$9(__spreadValues$d(__spreadValues$d({
319
319
  key: item.label,
320
320
  active: props.active
321
321
  }, item), context), {
@@ -657,8 +657,6 @@ function useSortableData(items, config = { key: "", direction: null }) {
657
657
  let direction = "asc";
658
658
  if (sortConfig.key === key && sortConfig.direction === "asc") {
659
659
  direction = "desc";
660
- } else if (sortConfig.key === key && sortConfig.direction === "desc") {
661
- direction = null;
662
660
  }
663
661
  setSortConfig({ key, direction });
664
662
  };
@@ -666,8 +664,8 @@ function useSortableData(items, config = { key: "", direction: null }) {
666
664
  }
667
665
 
668
666
  var __defProp$c = Object.defineProperty;
669
- var __defProps$9 = Object.defineProperties;
670
- var __getOwnPropDescs$9 = Object.getOwnPropertyDescriptors;
667
+ var __defProps$8 = Object.defineProperties;
668
+ var __getOwnPropDescs$8 = Object.getOwnPropertyDescriptors;
671
669
  var __getOwnPropSymbols$c = Object.getOwnPropertySymbols;
672
670
  var __hasOwnProp$c = Object.prototype.hasOwnProperty;
673
671
  var __propIsEnum$c = Object.prototype.propertyIsEnumerable;
@@ -683,10 +681,10 @@ var __spreadValues$c = (a, b) => {
683
681
  }
684
682
  return a;
685
683
  };
686
- var __spreadProps$9 = (a, b) => __defProps$9(a, __getOwnPropDescs$9(b));
684
+ var __spreadProps$8 = (a, b) => __defProps$8(a, __getOwnPropDescs$8(b));
687
685
  function Table$k(props) {
688
686
  const preparedItems = React__namespace.useMemo(() => {
689
- return props.items.map((item) => __spreadProps$9(__spreadValues$c({}, item), {
687
+ return props.items.map((item) => __spreadProps$8(__spreadValues$c({}, item), {
690
688
  status: item.isComplete ? 1 : 0
691
689
  }));
692
690
  }, [props.items]);
@@ -1138,8 +1136,8 @@ const SplitButton$4 = (props) => {
1138
1136
  };
1139
1137
 
1140
1138
  var __defProp$b = Object.defineProperty;
1141
- var __defProps$8 = Object.defineProperties;
1142
- var __getOwnPropDescs$8 = Object.getOwnPropertyDescriptors;
1139
+ var __defProps$7 = Object.defineProperties;
1140
+ var __getOwnPropDescs$7 = Object.getOwnPropertyDescriptors;
1143
1141
  var __getOwnPropSymbols$b = Object.getOwnPropertySymbols;
1144
1142
  var __hasOwnProp$b = Object.prototype.hasOwnProperty;
1145
1143
  var __propIsEnum$b = Object.prototype.propertyIsEnumerable;
@@ -1155,14 +1153,14 @@ var __spreadValues$b = (a, b) => {
1155
1153
  }
1156
1154
  return a;
1157
1155
  };
1158
- var __spreadProps$8 = (a, b) => __defProps$8(a, __getOwnPropDescs$8(b));
1156
+ var __spreadProps$7 = (a, b) => __defProps$7(a, __getOwnPropDescs$7(b));
1159
1157
  function Table$c(props) {
1160
- React__namespace.useMemo(() => {
1161
- return props.items.map((item) => __spreadProps$8(__spreadValues$b({}, item), {
1158
+ const preparedItems = React__namespace.useMemo(() => {
1159
+ return props.items.map((item) => __spreadProps$7(__spreadValues$b({}, item), {
1162
1160
  fullName: item.givenName && item.familyName ? `${item.givenName} ${item.familyName}`.toLowerCase() : item.email.toLowerCase()
1163
1161
  }));
1164
1162
  }, [props.items]);
1165
- const { items: sortedItems, requestSort, sortConfig } = useSortableData(props.items);
1163
+ const { items: sortedItems, requestSort, sortConfig } = useSortableData(preparedItems);
1166
1164
  if (props.items.length === 0) {
1167
1165
  return /* @__PURE__ */ React__namespace.createElement(
1168
1166
  PlaceholderBanner,
@@ -1256,8 +1254,8 @@ function Table$c(props) {
1256
1254
  }
1257
1255
 
1258
1256
  var __defProp$a = Object.defineProperty;
1259
- var __defProps$7 = Object.defineProperties;
1260
- var __getOwnPropDescs$7 = Object.getOwnPropertyDescriptors;
1257
+ var __defProps$6 = Object.defineProperties;
1258
+ var __getOwnPropDescs$6 = Object.getOwnPropertyDescriptors;
1261
1259
  var __getOwnPropSymbols$a = Object.getOwnPropertySymbols;
1262
1260
  var __hasOwnProp$a = Object.prototype.hasOwnProperty;
1263
1261
  var __propIsEnum$a = Object.prototype.propertyIsEnumerable;
@@ -1273,7 +1271,7 @@ var __spreadValues$a = (a, b) => {
1273
1271
  }
1274
1272
  return a;
1275
1273
  };
1276
- var __spreadProps$7 = (a, b) => __defProps$7(a, __getOwnPropDescs$7(b));
1274
+ var __spreadProps$6 = (a, b) => __defProps$6(a, __getOwnPropDescs$6(b));
1277
1275
  const useStyles$m = core.createStyles((theme) => ({
1278
1276
  title: {
1279
1277
  fontSize: 34,
@@ -1339,7 +1337,7 @@ const Class = (props) => {
1339
1337
  padding: "xl",
1340
1338
  size: "xl"
1341
1339
  },
1342
- /* @__PURE__ */ React__namespace.createElement(core.Stack, { spacing: "md" }, /* @__PURE__ */ React__namespace.createElement(DropzoneButton$1, __spreadProps$7(__spreadValues$a({}, props), { close: () => setOpened(false) })), /* @__PURE__ */ React__namespace.createElement(core.Divider, { label: "or", labelPosition: "center", my: "md", variant: "dashed" }), /* @__PURE__ */ React__namespace.createElement("form", { onSubmit: form$1.onSubmit(() => {
1340
+ /* @__PURE__ */ React__namespace.createElement(core.Stack, { spacing: "md" }, /* @__PURE__ */ React__namespace.createElement(DropzoneButton$1, __spreadProps$6(__spreadValues$a({}, props), { close: () => setOpened(false) })), /* @__PURE__ */ React__namespace.createElement(core.Divider, { label: "or", labelPosition: "center", my: "md", variant: "dashed" }), /* @__PURE__ */ React__namespace.createElement("form", { onSubmit: form$1.onSubmit(() => {
1343
1341
  const values = form$1.values;
1344
1342
  form$1.reset();
1345
1343
  setOpened(false);
@@ -2072,8 +2070,8 @@ function Stack$3(props) {
2072
2070
  }
2073
2071
 
2074
2072
  var __defProp$7 = Object.defineProperty;
2075
- var __defProps$6 = Object.defineProperties;
2076
- var __getOwnPropDescs$6 = Object.getOwnPropertyDescriptors;
2073
+ var __defProps$5 = Object.defineProperties;
2074
+ var __getOwnPropDescs$5 = Object.getOwnPropertyDescriptors;
2077
2075
  var __getOwnPropSymbols$7 = Object.getOwnPropertySymbols;
2078
2076
  var __hasOwnProp$7 = Object.prototype.hasOwnProperty;
2079
2077
  var __propIsEnum$7 = Object.prototype.propertyIsEnumerable;
@@ -2089,10 +2087,10 @@ var __spreadValues$7 = (a, b) => {
2089
2087
  }
2090
2088
  return a;
2091
2089
  };
2092
- var __spreadProps$6 = (a, b) => __defProps$6(a, __getOwnPropDescs$6(b));
2090
+ var __spreadProps$5 = (a, b) => __defProps$5(a, __getOwnPropDescs$5(b));
2093
2091
  function Table$6(props) {
2094
2092
  const preparedItems = React__namespace.useMemo(() => {
2095
- return props.items.map((item) => __spreadProps$6(__spreadValues$7({}, item), {
2093
+ return props.items.map((item) => __spreadProps$5(__spreadValues$7({}, item), {
2096
2094
  status: item.isComplete ? 2 : item.isStarted ? 1 : 0
2097
2095
  }));
2098
2096
  }, [props.items]);
@@ -2580,8 +2578,8 @@ function Table$4(props) {
2580
2578
  }
2581
2579
 
2582
2580
  var __defProp$6 = Object.defineProperty;
2583
- var __defProps$5 = Object.defineProperties;
2584
- var __getOwnPropDescs$5 = Object.getOwnPropertyDescriptors;
2581
+ var __defProps$4 = Object.defineProperties;
2582
+ var __getOwnPropDescs$4 = Object.getOwnPropertyDescriptors;
2585
2583
  var __getOwnPropSymbols$6 = Object.getOwnPropertySymbols;
2586
2584
  var __hasOwnProp$6 = Object.prototype.hasOwnProperty;
2587
2585
  var __propIsEnum$6 = Object.prototype.propertyIsEnumerable;
@@ -2597,7 +2595,7 @@ var __spreadValues$6 = (a, b) => {
2597
2595
  }
2598
2596
  return a;
2599
2597
  };
2600
- var __spreadProps$5 = (a, b) => __defProps$5(a, __getOwnPropDescs$5(b));
2598
+ var __spreadProps$4 = (a, b) => __defProps$4(a, __getOwnPropDescs$4(b));
2601
2599
  const useStyles$a = core.createStyles((theme) => ({
2602
2600
  title: {
2603
2601
  fontSize: 34,
@@ -2659,7 +2657,7 @@ const People = (props) => {
2659
2657
  padding: "xl",
2660
2658
  size: "xl"
2661
2659
  },
2662
- /* @__PURE__ */ React__namespace.createElement(core.Stack, { spacing: "md" }, /* @__PURE__ */ React__namespace.createElement(DropzoneButton, __spreadProps$5(__spreadValues$6({}, props), { close: () => setOpened(false) })), /* @__PURE__ */ React__namespace.createElement(core.Divider, { label: "or", labelPosition: "center", my: "md", variant: "dashed" }), /* @__PURE__ */ React__namespace.createElement("form", { onSubmit: form$1.onSubmit(() => {
2660
+ /* @__PURE__ */ React__namespace.createElement(core.Stack, { spacing: "md" }, /* @__PURE__ */ React__namespace.createElement(DropzoneButton, __spreadProps$4(__spreadValues$6({}, props), { close: () => setOpened(false) })), /* @__PURE__ */ React__namespace.createElement(core.Divider, { label: "or", labelPosition: "center", my: "md", variant: "dashed" }), /* @__PURE__ */ React__namespace.createElement("form", { onSubmit: form$1.onSubmit(() => {
2663
2661
  const values = form$1.values;
2664
2662
  form$1.reset();
2665
2663
  setOpened(false);
@@ -2947,8 +2945,8 @@ const TrialHome = (props) => {
2947
2945
  };
2948
2946
 
2949
2947
  var __defProp$4 = Object.defineProperty;
2950
- var __defProps$4 = Object.defineProperties;
2951
- var __getOwnPropDescs$4 = Object.getOwnPropertyDescriptors;
2948
+ var __defProps$3 = Object.defineProperties;
2949
+ var __getOwnPropDescs$3 = Object.getOwnPropertyDescriptors;
2952
2950
  var __getOwnPropSymbols$4 = Object.getOwnPropertySymbols;
2953
2951
  var __hasOwnProp$4 = Object.prototype.hasOwnProperty;
2954
2952
  var __propIsEnum$4 = Object.prototype.propertyIsEnumerable;
@@ -2964,7 +2962,7 @@ var __spreadValues$4 = (a, b) => {
2964
2962
  }
2965
2963
  return a;
2966
2964
  };
2967
- var __spreadProps$4 = (a, b) => __defProps$4(a, __getOwnPropDescs$4(b));
2965
+ var __spreadProps$3 = (a, b) => __defProps$3(a, __getOwnPropDescs$3(b));
2968
2966
  var __objRest = (source, exclude) => {
2969
2967
  var target = {};
2970
2968
  for (var prop in source)
@@ -3022,7 +3020,7 @@ function ImageCheckbox(_a) {
3022
3020
  const { classes, cx } = useStyles$7({ checked: value });
3023
3021
  return /* @__PURE__ */ React__namespace.createElement(
3024
3022
  core.UnstyledButton,
3025
- __spreadProps$4(__spreadValues$4({}, others), {
3023
+ __spreadProps$3(__spreadValues$4({}, others), {
3026
3024
  onClick: () => handleChange(!value),
3027
3025
  className: cx(classes.button, className)
3028
3026
  }),
@@ -3043,7 +3041,7 @@ function ImageCheckbox(_a) {
3043
3041
  function SelectGrid(props) {
3044
3042
  const items = props.items.map((item) => /* @__PURE__ */ React__namespace.createElement(
3045
3043
  ImageCheckbox,
3046
- __spreadProps$4(__spreadValues$4({}, item), {
3044
+ __spreadProps$3(__spreadValues$4({}, item), {
3047
3045
  key: item.title,
3048
3046
  onChange: (checked) => props.onChange(item.title, checked)
3049
3047
  })
@@ -3062,8 +3060,8 @@ function SelectGrid(props) {
3062
3060
  }
3063
3061
 
3064
3062
  var __defProp$3 = Object.defineProperty;
3065
- var __defProps$3 = Object.defineProperties;
3066
- var __getOwnPropDescs$3 = Object.getOwnPropertyDescriptors;
3063
+ var __defProps$2 = Object.defineProperties;
3064
+ var __getOwnPropDescs$2 = Object.getOwnPropertyDescriptors;
3067
3065
  var __getOwnPropSymbols$3 = Object.getOwnPropertySymbols;
3068
3066
  var __hasOwnProp$3 = Object.prototype.hasOwnProperty;
3069
3067
  var __propIsEnum$3 = Object.prototype.propertyIsEnumerable;
@@ -3079,7 +3077,7 @@ var __spreadValues$3 = (a, b) => {
3079
3077
  }
3080
3078
  return a;
3081
3079
  };
3082
- var __spreadProps$3 = (a, b) => __defProps$3(a, __getOwnPropDescs$3(b));
3080
+ var __spreadProps$2 = (a, b) => __defProps$2(a, __getOwnPropDescs$2(b));
3083
3081
  const useStyles$6 = core.createStyles((theme) => ({
3084
3082
  wrapper: {
3085
3083
  minHeight: "100%",
@@ -3189,7 +3187,7 @@ const TrialRegistration = (props) => {
3189
3187
  label: "School/Organization Name",
3190
3188
  placeholder: "What's the name of your school?",
3191
3189
  data: props.organizations.map((o) => {
3192
- return __spreadProps$3(__spreadValues$3({}, o), { value: o.displayName });
3190
+ return __spreadProps$2(__spreadValues$3({}, o), { value: o.displayName });
3193
3191
  }),
3194
3192
  onItemSubmit: (item) => setOrganization({ organizationId: item.organizationId, displayName: item.displayName }),
3195
3193
  onChange: (next) => {
@@ -3201,7 +3199,7 @@ const TrialRegistration = (props) => {
3201
3199
  SelectGrid,
3202
3200
  {
3203
3201
  items: OPTIONS,
3204
- onChange: (e, checked) => setInterests(__spreadProps$3(__spreadValues$3({}, interests), { [e]: checked }))
3202
+ onChange: (e, checked) => setInterests(__spreadProps$2(__spreadValues$3({}, interests), { [e]: checked }))
3205
3203
  }
3206
3204
  ), /* @__PURE__ */ React__namespace.createElement(core.Group, { position: "right", mt: "md" }, /* @__PURE__ */ React__namespace.createElement(
3207
3205
  core.Button,
@@ -3240,8 +3238,8 @@ const AdminProvider = (props) => {
3240
3238
  };
3241
3239
 
3242
3240
  var __defProp$2 = Object.defineProperty;
3243
- var __defProps$2 = Object.defineProperties;
3244
- var __getOwnPropDescs$2 = Object.getOwnPropertyDescriptors;
3241
+ var __defProps$1 = Object.defineProperties;
3242
+ var __getOwnPropDescs$1 = Object.getOwnPropertyDescriptors;
3245
3243
  var __getOwnPropSymbols$2 = Object.getOwnPropertySymbols;
3246
3244
  var __hasOwnProp$2 = Object.prototype.hasOwnProperty;
3247
3245
  var __propIsEnum$2 = Object.prototype.propertyIsEnumerable;
@@ -3257,7 +3255,7 @@ var __spreadValues$2 = (a, b) => {
3257
3255
  }
3258
3256
  return a;
3259
3257
  };
3260
- var __spreadProps$2 = (a, b) => __defProps$2(a, __getOwnPropDescs$2(b));
3258
+ var __spreadProps$1 = (a, b) => __defProps$1(a, __getOwnPropDescs$1(b));
3261
3259
  const useStyles$5 = core.createStyles((theme, props) => ({
3262
3260
  footer: {
3263
3261
  paddingTop: theme.spacing.md,
@@ -3353,7 +3351,7 @@ const App = (props) => {
3353
3351
  padding: "xs",
3354
3352
  navbar: props.navbar && /* @__PURE__ */ React__namespace.createElement(
3355
3353
  Navbar,
3356
- __spreadProps$2(__spreadValues$2({}, props.navbar.props), {
3354
+ __spreadProps$1(__spreadValues$2({}, props.navbar.props), {
3357
3355
  onSwitchAccounts: account.accounts && account.accounts.length > 1 ? () => account.setChangeModalOpen(true) : void 0
3358
3356
  })
3359
3357
  ),
@@ -3547,8 +3545,6 @@ function Stack$1(props) {
3547
3545
  }
3548
3546
 
3549
3547
  var __defProp$1 = Object.defineProperty;
3550
- var __defProps$1 = Object.defineProperties;
3551
- var __getOwnPropDescs$1 = Object.getOwnPropertyDescriptors;
3552
3548
  var __getOwnPropSymbols$1 = Object.getOwnPropertySymbols;
3553
3549
  var __hasOwnProp$1 = Object.prototype.hasOwnProperty;
3554
3550
  var __propIsEnum$1 = Object.prototype.propertyIsEnumerable;
@@ -3564,39 +3560,12 @@ var __spreadValues$1 = (a, b) => {
3564
3560
  }
3565
3561
  return a;
3566
3562
  };
3567
- var __spreadProps$1 = (a, b) => __defProps$1(a, __getOwnPropDescs$1(b));
3568
3563
  function Table$2(props) {
3569
3564
  const preparedItems = React__namespace.useMemo(() => {
3570
- console.group("Pathway Table Data Check");
3571
- console.log("Raw items from props:", props.items);
3572
- console.log("Categories available:", props.categories);
3573
- const mapped = props.items.map((item) => {
3574
- const flatItem = __spreadProps$1(__spreadValues$1({}, item), {
3575
- status: item.isComplete ? 1 : 0
3576
- });
3577
- if (item.categoryPoints) {
3578
- Object.keys(item.categoryPoints).forEach((catId) => {
3579
- flatItem[catId] = item.categoryPoints[catId];
3580
- });
3581
- }
3582
- return flatItem;
3583
- });
3584
- console.log("Transformed items (Flat):", mapped);
3585
- if (mapped.length > 0 && props.categories.length > 0) {
3586
- const firstStudent = mapped[0];
3587
- const firstCatId = props.categories[0].categoryId;
3588
- console.log(
3589
- `Matching Check: Does student have key [${firstCatId}]?`,
3590
- firstStudent.hasOwnProperty(firstCatId) ? "YES \u2705" : "NO \u274C",
3591
- "Value:",
3592
- firstStudent[firstCatId]
3593
- );
3594
- }
3595
- console.groupEnd();
3596
- return mapped;
3597
- }, [props.items, props.categories]);
3565
+ return (props.items || []).map((item) => __spreadValues$1(__spreadValues$1({}, item), item.categoryPoints));
3566
+ }, [props.items]);
3598
3567
  const { items: sortedItems, requestSort, sortConfig } = useSortableData(preparedItems);
3599
- if (props.items.length === 0) {
3568
+ if (props.loading && props.items.length === 0) {
3600
3569
  return /* @__PURE__ */ React__namespace.createElement(
3601
3570
  PlaceholderBanner,
3602
3571
  {
@@ -3634,7 +3603,7 @@ function Table$2(props) {
3634
3603
  render: (row) => /* @__PURE__ */ React__namespace.createElement(core.Group, { spacing: "sm", noWrap: true }, /* @__PURE__ */ React__namespace.createElement(core.Avatar, { size: 40, src: row.avatar, radius: 40 }), /* @__PURE__ */ React__namespace.createElement("div", null, /* @__PURE__ */ React__namespace.createElement(core.Text, { size: "sm", weight: 500 }, row.name), /* @__PURE__ */ React__namespace.createElement(core.Text, { size: "xs", color: "dimmed" }, row.email)))
3635
3604
  },
3636
3605
  {
3637
- accessor: "status",
3606
+ accessor: "isComplete",
3638
3607
  title: "Status",
3639
3608
  sortable: true,
3640
3609
  titleStyle: { whiteSpace: "nowrap" },
@@ -3679,6 +3648,8 @@ function Table$1(props) {
3679
3648
  mantineDatatable.DataTable,
3680
3649
  {
3681
3650
  verticalSpacing: "sm",
3651
+ withBorder: false,
3652
+ borderRadius: "sm",
3682
3653
  sx: { minWidth: 700 },
3683
3654
  highlightOnHover: true,
3684
3655
  striped: true,
@@ -3691,7 +3662,23 @@ function Table$1(props) {
3691
3662
  accessor: "badgeName",
3692
3663
  title: "Badge Name",
3693
3664
  sortable: true,
3694
- render: (row) => /* @__PURE__ */ React__namespace.createElement(core.Text, { component: reactRouterDom.Link, to: row.href, color: "blue" }, row.badgeName)
3665
+ render: (row) => /* @__PURE__ */ React__namespace.createElement(
3666
+ core.Text,
3667
+ {
3668
+ component: reactRouterDom.Link,
3669
+ to: row.href,
3670
+ sx: (theme) => ({
3671
+ color: theme.colorScheme === "dark" ? theme.white : theme.black,
3672
+ textDecoration: "none",
3673
+ fontWeight: 500,
3674
+ "&:hover": {
3675
+ textDecoration: "underline",
3676
+ color: theme.colors.blue[6]
3677
+ }
3678
+ })
3679
+ },
3680
+ row.badgeName
3681
+ )
3695
3682
  },
3696
3683
  {
3697
3684
  accessor: "percentageCompletion",