@cuemath/leap 2.8.53-as1 → 2.8.53-as3

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 (40) hide show
  1. package/dist/assets/line-icons/icons/puzzle-icon.js +51 -0
  2. package/dist/assets/line-icons/icons/puzzle-icon.js.map +1 -0
  3. package/dist/assets/line-icons/icons/tile.js +54 -0
  4. package/dist/assets/line-icons/icons/tile.js.map +1 -0
  5. package/dist/features/cue-canvas/sidebar/puzzles/api/get-puzzles.js +13 -0
  6. package/dist/features/cue-canvas/sidebar/puzzles/api/get-puzzles.js.map +1 -0
  7. package/dist/features/cue-canvas/sidebar/puzzles/filter-selection-menu.js +60 -0
  8. package/dist/features/cue-canvas/sidebar/puzzles/filter-selection-menu.js.map +1 -0
  9. package/dist/features/cue-canvas/sidebar/puzzles/filters-section.js +44 -0
  10. package/dist/features/cue-canvas/sidebar/puzzles/filters-section.js.map +1 -0
  11. package/dist/features/cue-canvas/sidebar/puzzles/filters.js +107 -0
  12. package/dist/features/cue-canvas/sidebar/puzzles/filters.js.map +1 -0
  13. package/dist/features/cue-canvas/sidebar/puzzles/hooks/use-fetch-cue-canvas-activity.js +51 -0
  14. package/dist/features/cue-canvas/sidebar/puzzles/hooks/use-fetch-cue-canvas-activity.js.map +1 -0
  15. package/dist/features/cue-canvas/sidebar/puzzles/launch-puzzle.js +84 -0
  16. package/dist/features/cue-canvas/sidebar/puzzles/launch-puzzle.js.map +1 -0
  17. package/dist/features/cue-canvas/sidebar/puzzles/puzzle-menu-header.js +36 -0
  18. package/dist/features/cue-canvas/sidebar/puzzles/puzzle-menu-header.js.map +1 -0
  19. package/dist/features/cue-canvas/sidebar/puzzles/puzzle-menu.js +133 -0
  20. package/dist/features/cue-canvas/sidebar/puzzles/puzzle-menu.js.map +1 -0
  21. package/dist/features/cue-canvas/sidebar/puzzles/puzzles-styled.js +96 -0
  22. package/dist/features/cue-canvas/sidebar/puzzles/puzzles-styled.js.map +1 -0
  23. package/dist/features/cue-canvas/sidebar/puzzles/puzzles.js +29 -0
  24. package/dist/features/cue-canvas/sidebar/puzzles/puzzles.js.map +1 -0
  25. package/dist/features/cue-canvas/sidebar/puzzles/utils.js +124 -0
  26. package/dist/features/cue-canvas/sidebar/puzzles/utils.js.map +1 -0
  27. package/dist/features/cue-canvas/sidebar/sidebar.js +16 -0
  28. package/dist/features/cue-canvas/sidebar/sidebar.js.map +1 -0
  29. package/dist/features/cue-canvas/sidebar/tiles/tile.js +16 -0
  30. package/dist/features/cue-canvas/sidebar/tiles/tile.js.map +1 -0
  31. package/dist/features/hooks/use-debounce.js +16 -0
  32. package/dist/features/hooks/use-debounce.js.map +1 -0
  33. package/dist/features/whiteboard/whiteboard.js +48 -0
  34. package/dist/features/whiteboard/whiteboard.js.map +1 -0
  35. package/dist/features/whiteboard/whiteboard.styled.js +35 -0
  36. package/dist/features/whiteboard/whiteboard.styled.js.map +1 -0
  37. package/dist/index.d.ts +11 -0
  38. package/dist/index.js +304 -302
  39. package/dist/index.js.map +1 -1
  40. package/package.json +1 -1
@@ -0,0 +1,51 @@
1
+ import { jsxs as l, jsx as r } from "react/jsx-runtime";
2
+ const e = (c) => /* @__PURE__ */ l(
3
+ "svg",
4
+ {
5
+ width: "20",
6
+ height: "20",
7
+ viewBox: "0 0 20 20",
8
+ fill: "none",
9
+ xmlns: "http://www.w3.org/2000/svg",
10
+ ...c,
11
+ children: [
12
+ /* @__PURE__ */ r(
13
+ "path",
14
+ {
15
+ d: "M4.84375 5.78632L4.84375 4.37218C4.84375 3.98865 5.15466 3.67773 5.53819 3.67773H7.11038",
16
+ stroke: "currentColor",
17
+ strokeWidth: "1.39167"
18
+ }
19
+ ),
20
+ /* @__PURE__ */ r(
21
+ "path",
22
+ {
23
+ d: "M14.6472 16.5289L17.3453 4.68253C17.4304 4.30858 17.1963 3.93638 16.8224 3.85121L10.0307 2.30435C9.67373 2.22305 9.31497 2.43282 9.21075 2.78377L8.31911 5.78642",
24
+ stroke: "currentColor",
25
+ strokeWidth: "1.39167"
26
+ }
27
+ ),
28
+ /* @__PURE__ */ r(
29
+ "rect",
30
+ {
31
+ x: "3.33325",
32
+ y: "7.59961",
33
+ width: "9.0665",
34
+ height: "9.0665",
35
+ rx: "0.694444",
36
+ fill: "#F6F6F6",
37
+ stroke: "currentColor",
38
+ strokeWidth: "1.39167"
39
+ }
40
+ ),
41
+ /* @__PURE__ */ r("circle", { cx: "6.29508", cy: "10.563", r: "0.695833", fill: "black" }),
42
+ /* @__PURE__ */ r("circle", { cx: "6.29508", cy: "13.7359", r: "0.695833", fill: "black" }),
43
+ /* @__PURE__ */ r("circle", { cx: "9.4689", cy: "10.563", r: "0.695833", fill: "black" }),
44
+ /* @__PURE__ */ r("circle", { cx: "9.4689", cy: "13.7359", r: "0.695833", fill: "black" })
45
+ ]
46
+ }
47
+ );
48
+ export {
49
+ e as default
50
+ };
51
+ //# sourceMappingURL=puzzle-icon.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"puzzle-icon.js","sources":["../../../../src/assets/line-icons/icons/puzzle-icon.tsx"],"sourcesContent":["const PuzzleIcon: React.FC<React.SVGProps<SVGSVGElement>> = props => (\n <svg\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n {...props}\n >\n <path\n d=\"M4.84375 5.78632L4.84375 4.37218C4.84375 3.98865 5.15466 3.67773 5.53819 3.67773H7.11038\"\n stroke=\"currentColor\"\n strokeWidth=\"1.39167\"\n />\n <path\n d=\"M14.6472 16.5289L17.3453 4.68253C17.4304 4.30858 17.1963 3.93638 16.8224 3.85121L10.0307 2.30435C9.67373 2.22305 9.31497 2.43282 9.21075 2.78377L8.31911 5.78642\"\n stroke=\"currentColor\"\n strokeWidth=\"1.39167\"\n />\n <rect\n x=\"3.33325\"\n y=\"7.59961\"\n width=\"9.0665\"\n height=\"9.0665\"\n rx=\"0.694444\"\n fill=\"#F6F6F6\"\n stroke=\"currentColor\"\n strokeWidth=\"1.39167\"\n />\n <circle cx=\"6.29508\" cy=\"10.563\" r=\"0.695833\" fill=\"black\" />\n <circle cx=\"6.29508\" cy=\"13.7359\" r=\"0.695833\" fill=\"black\" />\n <circle cx=\"9.4689\" cy=\"10.563\" r=\"0.695833\" fill=\"black\" />\n <circle cx=\"9.4689\" cy=\"13.7359\" r=\"0.695833\" fill=\"black\" />\n </svg>\n);\n\nexport default PuzzleIcon;\n"],"names":["PuzzleIcon","props","jsxs","jsx"],"mappings":";AAAA,MAAMA,IAAsD,CAC1DC,MAAA,gBAAAC;AAAA,EAAC;AAAA,EAAA;AAAA,IACC,OAAM;AAAA,IACN,QAAO;AAAA,IACP,SAAQ;AAAA,IACR,MAAK;AAAA,IACL,OAAM;AAAA,IACL,GAAGD;AAAA,IAEJ,UAAA;AAAA,MAAA,gBAAAE;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,GAAE;AAAA,UACF,QAAO;AAAA,UACP,aAAY;AAAA,QAAA;AAAA,MACd;AAAA,MACA,gBAAAA;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,GAAE;AAAA,UACF,QAAO;AAAA,UACP,aAAY;AAAA,QAAA;AAAA,MACd;AAAA,MACA,gBAAAA;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,GAAE;AAAA,UACF,GAAE;AAAA,UACF,OAAM;AAAA,UACN,QAAO;AAAA,UACP,IAAG;AAAA,UACH,MAAK;AAAA,UACL,QAAO;AAAA,UACP,aAAY;AAAA,QAAA;AAAA,MACd;AAAA,MACA,gBAAAA,EAAC,YAAO,IAAG,WAAU,IAAG,UAAS,GAAE,YAAW,MAAK,QAAQ,CAAA;AAAA,MAC3D,gBAAAA,EAAC,YAAO,IAAG,WAAU,IAAG,WAAU,GAAE,YAAW,MAAK,QAAQ,CAAA;AAAA,MAC5D,gBAAAA,EAAC,YAAO,IAAG,UAAS,IAAG,UAAS,GAAE,YAAW,MAAK,QAAQ,CAAA;AAAA,MAC1D,gBAAAA,EAAC,YAAO,IAAG,UAAS,IAAG,WAAU,GAAE,YAAW,MAAK,QAAQ,CAAA;AAAA,IAAA;AAAA,EAAA;AAC7D;"}
@@ -0,0 +1,54 @@
1
+ import { jsxs as i, jsx as t } from "react/jsx-runtime";
2
+ const o = (e) => /* @__PURE__ */ i(
3
+ "svg",
4
+ {
5
+ className: "tile-icon",
6
+ width: "32",
7
+ height: "32",
8
+ viewBox: "0 0 32 32",
9
+ fill: "none",
10
+ xmlns: "http://www.w3.org/2000/svg",
11
+ ...e,
12
+ children: [
13
+ /* @__PURE__ */ t("rect", { x: "0.5", y: "0.5", width: "31", height: "31", rx: "15.5", fill: "white" }),
14
+ /* @__PURE__ */ t("rect", { x: "0.5", y: "0.5", width: "31", height: "31", rx: "15.5", stroke: "white" }),
15
+ /* @__PURE__ */ t(
16
+ "rect",
17
+ {
18
+ x: "8.5",
19
+ y: "16",
20
+ width: "5.83333",
21
+ height: "6.66667",
22
+ rx: "0.833333",
23
+ stroke: "#2B2B2B",
24
+ strokeWidth: "1.39167",
25
+ strokeLinejoin: "round"
26
+ }
27
+ ),
28
+ /* @__PURE__ */ t(
29
+ "circle",
30
+ {
31
+ cx: "20.1667",
32
+ cy: "19.2542",
33
+ r: "3.33333",
34
+ stroke: "#2B2B2B",
35
+ strokeWidth: "1.39167",
36
+ strokeLinejoin: "round"
37
+ }
38
+ ),
39
+ /* @__PURE__ */ t(
40
+ "path",
41
+ {
42
+ d: "M18.8222 13.6583H11.7094C10.9896 13.6583 10.6084 12.8073 11.0875 12.2702L14.644 8.28391C14.9753 7.91249 15.5563 7.9125 15.8876 8.28391L19.444 12.2702C19.9232 12.8073 19.542 13.6583 18.8222 13.6583Z",
43
+ stroke: "#2B2B2B",
44
+ strokeWidth: "1.39167",
45
+ strokeLinejoin: "round"
46
+ }
47
+ )
48
+ ]
49
+ }
50
+ );
51
+ export {
52
+ o as default
53
+ };
54
+ //# sourceMappingURL=tile.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tile.js","sources":["../../../../src/assets/line-icons/icons/tile.tsx"],"sourcesContent":["const TileIcon: React.FC<React.SVGProps<SVGSVGElement>> = props => (\n <svg\n className=\"tile-icon\"\n width=\"32\"\n height=\"32\"\n viewBox=\"0 0 32 32\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n {...props}\n >\n <rect x=\"0.5\" y=\"0.5\" width=\"31\" height=\"31\" rx=\"15.5\" fill=\"white\" />\n <rect x=\"0.5\" y=\"0.5\" width=\"31\" height=\"31\" rx=\"15.5\" stroke=\"white\" />\n <rect\n x=\"8.5\"\n y=\"16\"\n width=\"5.83333\"\n height=\"6.66667\"\n rx=\"0.833333\"\n stroke=\"#2B2B2B\"\n strokeWidth=\"1.39167\"\n strokeLinejoin=\"round\"\n />\n <circle\n cx=\"20.1667\"\n cy=\"19.2542\"\n r=\"3.33333\"\n stroke=\"#2B2B2B\"\n strokeWidth=\"1.39167\"\n strokeLinejoin=\"round\"\n />\n <path\n d=\"M18.8222 13.6583H11.7094C10.9896 13.6583 10.6084 12.8073 11.0875 12.2702L14.644 8.28391C14.9753 7.91249 15.5563 7.9125 15.8876 8.28391L19.444 12.2702C19.9232 12.8073 19.542 13.6583 18.8222 13.6583Z\"\n stroke=\"#2B2B2B\"\n strokeWidth=\"1.39167\"\n strokeLinejoin=\"round\"\n />\n </svg>\n);\n\nexport default TileIcon;\n"],"names":["TileIcon","props","jsxs","jsx"],"mappings":";AAAA,MAAMA,IAAoD,CACxDC,MAAA,gBAAAC;AAAA,EAAC;AAAA,EAAA;AAAA,IACC,WAAU;AAAA,IACV,OAAM;AAAA,IACN,QAAO;AAAA,IACP,SAAQ;AAAA,IACR,MAAK;AAAA,IACL,OAAM;AAAA,IACL,GAAGD;AAAA,IAEJ,UAAA;AAAA,MAAA,gBAAAE,EAAC,QAAK,EAAA,GAAE,OAAM,GAAE,OAAM,OAAM,MAAK,QAAO,MAAK,IAAG,QAAO,MAAK,SAAQ;AAAA,MACnE,gBAAAA,EAAA,QAAA,EAAK,GAAE,OAAM,GAAE,OAAM,OAAM,MAAK,QAAO,MAAK,IAAG,QAAO,QAAO,SAAQ;AAAA,MACtE,gBAAAA;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,GAAE;AAAA,UACF,GAAE;AAAA,UACF,OAAM;AAAA,UACN,QAAO;AAAA,UACP,IAAG;AAAA,UACH,QAAO;AAAA,UACP,aAAY;AAAA,UACZ,gBAAe;AAAA,QAAA;AAAA,MACjB;AAAA,MACA,gBAAAA;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,IAAG;AAAA,UACH,IAAG;AAAA,UACH,GAAE;AAAA,UACF,QAAO;AAAA,UACP,aAAY;AAAA,UACZ,gBAAe;AAAA,QAAA;AAAA,MACjB;AAAA,MACA,gBAAAA;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,GAAE;AAAA,UACF,QAAO;AAAA,UACP,aAAY;AAAA,UACZ,gBAAe;AAAA,QAAA;AAAA,MACjB;AAAA,IAAA;AAAA,EAAA;AACF;"}
@@ -0,0 +1,13 @@
1
+ import { createGetAPI as e } from "@cuemath/rest-api";
2
+ import { BASE_URL_V3 as r, BASE_URL_V2 as c } from "../../../../../constants/api.js";
3
+ import { stringify as o } from "../../../../../helpers/query-string.js";
4
+ const { get: g } = e({
5
+ getURL: (t, i) => `${r}/curriculum/cueboard-activities/?${o(i)}`
6
+ }), { useGet: _ } = e({
7
+ getURL: (t) => `${c}/curriculum/wb-activities/${t}`
8
+ });
9
+ export {
10
+ g as getPuzzles,
11
+ _ as useGetActivity
12
+ };
13
+ //# sourceMappingURL=get-puzzles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-puzzles.js","sources":["../../../../../../src/features/cue-canvas/sidebar/puzzles/api/get-puzzles.ts"],"sourcesContent":["import { createGetAPI } from '@cuemath/rest-api';\n\nimport { BASE_URL_V2, BASE_URL_V3 } from '../../../../../constants/api';\nimport { stringify } from '../../../../../helpers/query-string';\n\nexport interface IFilterOption {\n applied: boolean;\n code: string;\n name: string;\n}\n\nexport interface IFilterData {\n activity_tiles: IFilterOption[];\n activity_topics: IFilterOption[];\n activity_types: IFilterOption[];\n grades: IFilterOption[];\n search: string;\n}\n\nexport interface IPuzzlesResultData {\n activity_tiles: string[];\n activity_topics: string[];\n activity_types: string[];\n activity_url: string;\n created_on: string;\n created_on_ts: number;\n grades: string[];\n id: string;\n is_live: boolean;\n name: string;\n node_id: string;\n updated_on: string;\n updated_on_ts: number;\n}\nexport interface IPuzzlesResponses {\n filters: IFilterData;\n results: IPuzzlesResultData[];\n}\nexport interface IGetPuzzles {\n activity_tiles?: string[];\n activity_topics?: string[];\n activity_types?: string[];\n grades?: string[];\n search?: string;\n}\n\nexport interface ActivityMetadata {\n code: string;\n description: string | null;\n id: string;\n is_live: boolean;\n name: string;\n priority: number | null;\n type: 'ACTIVITY_TILE' | 'ACTIVITY_TOPIC' | 'ACTIVITY_TYPE' | string;\n}\n\nexport interface IActivityGrade {\n code: string;\n description: string;\n id: string;\n is_live: boolean;\n name: string;\n priority: number;\n type: 'GRADE';\n}\n\nexport interface ActivityData {\n activity_tiles: ActivityMetadata[];\n activity_topics: ActivityMetadata[];\n activity_types: ActivityMetadata[];\n grades: IActivityGrade[];\n worksheet: Worksheet;\n}\n\ninterface Worksheet {\n code: string;\n complete_in: number | null;\n course_type: string;\n description: string | null;\n desmos_calculator_enabled: boolean;\n id: string;\n instructions_ref: string | null;\n is_lesson_v3_enabled: boolean;\n is_live: boolean;\n is_subjective: boolean;\n is_turing: boolean;\n learnosity_activity_ref: string | null;\n name: string;\n points_available: number;\n project_name: string;\n sheet_time: number | null;\n student_instructions_ref: string | null;\n target_accuracy: number;\n thumbnail_url: string | null;\n total_questions: number | null;\n visible_in_mpr: boolean;\n worksheet_type: string;\n}\n\nconst { get: getPuzzles } = createGetAPI<IPuzzlesResponses, IGetPuzzles>({\n getURL: (_, query) => `${BASE_URL_V3}/curriculum/cueboard-activities/?${stringify(query)}`,\n});\n\nconst { useGet: useGetActivity } = createGetAPI<ActivityData>({\n getURL: nodeId => `${BASE_URL_V2}/curriculum/wb-activities/${nodeId}`,\n});\n\nexport { getPuzzles, useGetActivity };\n"],"names":["getPuzzles","createGetAPI","_","query","BASE_URL_V3","stringify","useGetActivity","nodeId","BASE_URL_V2"],"mappings":";;;AAmGA,MAAM,EAAE,KAAKA,EAAW,IAAIC,EAA6C;AAAA,EACvE,QAAQ,CAACC,GAAGC,MAAU,GAAGC,CAAW,oCAAoCC,EAAUF,CAAK,CAAC;AAC1F,CAAC,GAEK,EAAE,QAAQG,EAAe,IAAIL,EAA2B;AAAA,EAC5D,QAAQ,CAAAM,MAAU,GAAGC,CAAW,6BAA6BD,CAAM;AACrE,CAAC;"}
@@ -0,0 +1,60 @@
1
+ import { jsxs as l, jsx as e } from "react/jsx-runtime";
2
+ import { memo as h, useState as u, useCallback as m } from "react";
3
+ import b from "../../../../assets/line-icons/icons/back.js";
4
+ import C from "../../../../assets/line-icons/icons/cross.js";
5
+ import s from "../../../ui/buttons/clickable/clickable.js";
6
+ import x from "../../../ui/buttons/text-button/text-button.js";
7
+ import k from "../../../ui/inputs/checkbox-input-list/checkbox-input-list.js";
8
+ import i from "../../../ui/layout/flex-view.js";
9
+ import d from "../../../ui/text/text.js";
10
+ import { MenuContainer as g, CheckboxWrapper as I } from "./puzzles-styled.js";
11
+ const T = ({
12
+ closeAllPopups: t,
13
+ menuItems: c,
14
+ onFiltersChange: a,
15
+ type: n
16
+ }) => {
17
+ const [o, p] = u(
18
+ c.filter((r) => r.applied).map((r) => r.name)
19
+ ), f = m((r) => {
20
+ p(r);
21
+ }, []), $ = m(() => {
22
+ a({
23
+ [n]: o
24
+ }), t();
25
+ }, [a, t, o, n]);
26
+ return /* @__PURE__ */ l(g, { children: [
27
+ /* @__PURE__ */ l(i, { $justifyContent: "space-between", $flexDirection: "row", $gutterX: 1, $gapX: 0.5, children: [
28
+ /* @__PURE__ */ l(i, { $flexDirection: "row", $alignItems: "center", $flexColumnGapX: 1, children: [
29
+ /* @__PURE__ */ e(s, { onClick: t, label: "back", children: /* @__PURE__ */ e(b, { color: "WHITE" }) }),
30
+ /* @__PURE__ */ l(d, { $color: "WHITE", $renderAs: "eyebrow2", children: [
31
+ "Select ",
32
+ n === "grades" ? n : n.split("_")[1],
33
+ o.length > 0 && /* @__PURE__ */ e("span", { children: ` (${o.length})` })
34
+ ] })
35
+ ] }),
36
+ /* @__PURE__ */ l(i, { $flexDirection: "row", $alignItems: "center", $flexColumnGapX: 1, children: [
37
+ /* @__PURE__ */ e(x, { color: "WHITE", label: "Apply", onClick: $ }),
38
+ /* @__PURE__ */ e(s, { onClick: t, label: "close filter menu", children: /* @__PURE__ */ e(C, { color: "WHITE" }) })
39
+ ] })
40
+ ] }),
41
+ /* @__PURE__ */ e(I, { $gutterX: 1, $gapX: 1, children: /* @__PURE__ */ e(
42
+ k,
43
+ {
44
+ size: "medium",
45
+ renderAs: "black-dark",
46
+ numColumns: 3,
47
+ options: c.map((r) => ({
48
+ id: r.name,
49
+ label: /* @__PURE__ */ e(d, { $renderAs: "ub3-bold", $color: "WHITE", $inline: !0, children: r.name })
50
+ })),
51
+ value: o,
52
+ onChange: f
53
+ }
54
+ ) })
55
+ ] });
56
+ }, A = h(T);
57
+ export {
58
+ A as default
59
+ };
60
+ //# sourceMappingURL=filter-selection-menu.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"filter-selection-menu.js","sources":["../../../../../src/features/cue-canvas/sidebar/puzzles/filter-selection-menu.tsx"],"sourcesContent":["import type { IFilterOption } from './api/get-puzzles';\nimport type { FilterSelectionMenuProps } from './puzzles-type';\n\nimport { memo, useCallback, useState } from 'react';\n\nimport BackIcon from '../../../../assets/line-icons/icons/back';\nimport CrossIcon from '../../../../assets/line-icons/icons/cross';\nimport Clickable from '../../../ui/buttons/clickable/clickable';\nimport TextButton from '../../../ui/buttons/text-button/text-button';\nimport CheckboxInputList from '../../../ui/inputs/checkbox-input-list/checkbox-input-list';\nimport FlexView from '../../../ui/layout/flex-view';\nimport Text from '../../../ui/text/text';\nimport * as Styled from './puzzles-styled';\n\nconst FilterSelectionMenu: React.FC<FilterSelectionMenuProps> = ({\n closeAllPopups,\n menuItems,\n onFiltersChange,\n type,\n}) => {\n const [selectedOptions, setSelectedOptions] = useState<string[]>(\n menuItems.filter((ele: IFilterOption) => ele.applied).map((ele: IFilterOption) => ele.name),\n );\n\n const handleFilterChange = useCallback((selectedCodes: string[]) => {\n setSelectedOptions(selectedCodes);\n }, []);\n\n const handleApplyFilters = useCallback(() => {\n onFiltersChange({\n [type]: selectedOptions,\n });\n\n closeAllPopups();\n }, [onFiltersChange, closeAllPopups, selectedOptions, type]);\n\n return (\n <Styled.MenuContainer>\n <FlexView $justifyContent=\"space-between\" $flexDirection=\"row\" $gutterX={1} $gapX={0.5}>\n <FlexView $flexDirection=\"row\" $alignItems=\"center\" $flexColumnGapX={1}>\n <Clickable onClick={closeAllPopups} label=\"back\">\n <BackIcon color=\"WHITE\" />\n </Clickable>\n <Text $color=\"WHITE\" $renderAs=\"eyebrow2\">\n Select {type === 'grades' ? type : type.split('_')[1]}\n {selectedOptions.length > 0 && <span>{` (${selectedOptions.length})`}</span>}\n </Text>\n </FlexView>\n <FlexView $flexDirection=\"row\" $alignItems=\"center\" $flexColumnGapX={1}>\n <TextButton color=\"WHITE\" label=\"Apply\" onClick={handleApplyFilters} />\n <Clickable onClick={closeAllPopups} label=\"close filter menu\">\n <CrossIcon color=\"WHITE\" />\n </Clickable>\n </FlexView>\n </FlexView>\n <Styled.CheckboxWrapper $gutterX={1} $gapX={1}>\n <CheckboxInputList\n size=\"medium\"\n renderAs=\"black-dark\"\n numColumns={3}\n options={menuItems.map(ele => ({\n id: ele.name,\n label: (\n <Text $renderAs=\"ub3-bold\" $color=\"WHITE\" $inline>\n {ele.name}\n </Text>\n ),\n }))}\n value={selectedOptions}\n onChange={handleFilterChange}\n />\n </Styled.CheckboxWrapper>\n </Styled.MenuContainer>\n );\n};\n\nexport default memo(FilterSelectionMenu);\n"],"names":["FilterSelectionMenu","closeAllPopups","menuItems","onFiltersChange","type","selectedOptions","setSelectedOptions","useState","ele","handleFilterChange","useCallback","selectedCodes","handleApplyFilters","jsxs","Styled.MenuContainer","FlexView","jsx","Clickable","BackIcon","Text","TextButton","CrossIcon","Styled.CheckboxWrapper","CheckboxInputList","FilterSelectionMenu$1","memo"],"mappings":";;;;;;;;;;AAcA,MAAMA,IAA0D,CAAC;AAAA,EAC/D,gBAAAC;AAAA,EACA,WAAAC;AAAA,EACA,iBAAAC;AAAA,EACA,MAAAC;AACF,MAAM;AACE,QAAA,CAACC,GAAiBC,CAAkB,IAAIC;AAAA,IAC5CL,EAAU,OAAO,CAACM,MAAuBA,EAAI,OAAO,EAAE,IAAI,CAACA,MAAuBA,EAAI,IAAI;AAAA,EAAA,GAGtFC,IAAqBC,EAAY,CAACC,MAA4B;AAClE,IAAAL,EAAmBK,CAAa;AAAA,EAClC,GAAG,CAAE,CAAA,GAECC,IAAqBF,EAAY,MAAM;AAC3B,IAAAP,EAAA;AAAA,MACd,CAACC,CAAI,GAAGC;AAAA,IAAA,CACT,GAEcJ;KACd,CAACE,GAAiBF,GAAgBI,GAAiBD,CAAI,CAAC;AAGzD,SAAA,gBAAAS,EAACC,GAAA,EACC,UAAA;AAAA,IAAC,gBAAAD,EAAAE,GAAA,EAAS,iBAAgB,iBAAgB,gBAAe,OAAM,UAAU,GAAG,OAAO,KACjF,UAAA;AAAA,MAAA,gBAAAF,EAACE,KAAS,gBAAe,OAAM,aAAY,UAAS,iBAAiB,GACnE,UAAA;AAAA,QAAC,gBAAAC,EAAAC,GAAA,EAAU,SAAShB,GAAgB,OAAM,QACxC,UAAC,gBAAAe,EAAAE,GAAA,EAAS,OAAM,QAAA,CAAQ,EAC1B,CAAA;AAAA,QACC,gBAAAL,EAAAM,GAAA,EAAK,QAAO,SAAQ,WAAU,YAAW,UAAA;AAAA,UAAA;AAAA,UAChCf,MAAS,WAAWA,IAAOA,EAAK,MAAM,GAAG,EAAE,CAAC;AAAA,UACnDC,EAAgB,SAAS,KAAK,gBAAAW,EAAC,UAAM,UAAK,KAAAX,EAAgB,MAAM,IAAI,CAAA;AAAA,QAAA,GACvE;AAAA,MAAA,GACF;AAAA,wBACCU,GAAS,EAAA,gBAAe,OAAM,aAAY,UAAS,iBAAiB,GACnE,UAAA;AAAA,QAAA,gBAAAC,EAACI,KAAW,OAAM,SAAQ,OAAM,SAAQ,SAASR,GAAoB;AAAA,QACrE,gBAAAI,EAACC,GAAU,EAAA,SAAShB,GAAgB,OAAM,qBACxC,UAAC,gBAAAe,EAAAK,GAAA,EAAU,OAAM,QAAA,CAAQ,EAC3B,CAAA;AAAA,MAAA,GACF;AAAA,IAAA,GACF;AAAA,sBACCC,GAAA,EAAuB,UAAU,GAAG,OAAO,GAC1C,UAAA,gBAAAN;AAAA,MAACO;AAAA,MAAA;AAAA,QACC,MAAK;AAAA,QACL,UAAS;AAAA,QACT,YAAY;AAAA,QACZ,SAASrB,EAAU,IAAI,CAAQM,OAAA;AAAA,UAC7B,IAAIA,EAAI;AAAA,UACR,OACG,gBAAAQ,EAAAG,GAAA,EAAK,WAAU,YAAW,QAAO,SAAQ,SAAO,IAC9C,UAAAX,EAAI,KACP,CAAA;AAAA,QAAA,EAEF;AAAA,QACF,OAAOH;AAAA,QACP,UAAUI;AAAA,MAAA;AAAA,IAAA,GAEd;AAAA,EACF,EAAA,CAAA;AAEJ,GAEee,IAAAC,EAAKzB,CAAmB;"}
@@ -0,0 +1,44 @@
1
+ import { jsxs as l, Fragment as s, jsx as r } from "react/jsx-runtime";
2
+ import { memo as a } from "react";
3
+ import d from "../../../ui/buttons/text-button/text-button.js";
4
+ import p from "../../../ui/inputs/checkbox-input-list/checkbox-input-list.js";
5
+ import u from "../../../ui/layout/flex-view.js";
6
+ import t from "../../../ui/text/text.js";
7
+ const $ = ({
8
+ title: n,
9
+ items: e,
10
+ selectedItems: i,
11
+ onChange: m,
12
+ openSelector: c
13
+ }) => /* @__PURE__ */ l(s, { children: [
14
+ /* @__PURE__ */ r(t, { $renderAs: "eyebrow2", $color: "WHITE", children: n }),
15
+ /* @__PURE__ */ l(u, { $gutterX: 0.5, $gapX: 0.5, $flexRowGapX: 0.25, children: [
16
+ e.length > 0 && /* @__PURE__ */ r(
17
+ p,
18
+ {
19
+ size: "medium",
20
+ renderAs: "black-dark",
21
+ numColumns: 1,
22
+ options: e.slice(0, 3).map((o) => ({
23
+ id: o,
24
+ label: /* @__PURE__ */ r(t, { $renderAs: "ub3-bold", $color: "WHITE", $inline: !0, children: o })
25
+ })),
26
+ value: i,
27
+ onChange: m
28
+ }
29
+ ),
30
+ e.length > 3 && /* @__PURE__ */ r(
31
+ d,
32
+ {
33
+ size: "small",
34
+ color: "GREY_2",
35
+ onClick: c,
36
+ label: `${e.length - 3}+ more`
37
+ }
38
+ )
39
+ ] })
40
+ ] }), F = a($);
41
+ export {
42
+ F as default
43
+ };
44
+ //# sourceMappingURL=filters-section.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"filters-section.js","sources":["../../../../../src/features/cue-canvas/sidebar/puzzles/filters-section.tsx"],"sourcesContent":["import type { IFilterSectionProps } from './puzzles-type';\n\nimport React, { memo } from 'react';\n\nimport TextButton from '../../../ui/buttons/text-button/text-button';\nimport CheckboxInputList from '../../../ui/inputs/checkbox-input-list/checkbox-input-list';\nimport FlexView from '../../../ui/layout/flex-view';\nimport Text from '../../../ui/text/text';\n\nconst FilterSection: React.FC<IFilterSectionProps> = ({\n title,\n items,\n selectedItems,\n onChange,\n openSelector,\n}) => {\n return (\n <>\n <Text $renderAs=\"eyebrow2\" $color=\"WHITE\">\n {title}\n </Text>\n <FlexView $gutterX={0.5} $gapX={0.5} $flexRowGapX={0.25}>\n {items.length > 0 && (\n <CheckboxInputList\n size=\"medium\"\n renderAs=\"black-dark\"\n numColumns={1}\n options={items.slice(0, 3).map(ele => ({\n id: ele,\n label: (\n <Text $renderAs=\"ub3-bold\" $color=\"WHITE\" $inline>\n {ele}\n </Text>\n ),\n }))}\n value={selectedItems}\n onChange={onChange}\n />\n )}\n {items.length > 3 && (\n <TextButton\n size=\"small\"\n color=\"GREY_2\"\n onClick={openSelector}\n label={`${items.length - 3}+ more`}\n />\n )}\n </FlexView>\n </>\n );\n};\n\nexport default memo(FilterSection);\n"],"names":["FilterSection","title","items","selectedItems","onChange","openSelector","jsxs","Fragment","jsx","Text","FlexView","CheckboxInputList","ele","TextButton","FilterSection$1","memo"],"mappings":";;;;;;AASA,MAAMA,IAA+C,CAAC;AAAA,EACpD,OAAAC;AAAA,EACA,OAAAC;AAAA,EACA,eAAAC;AAAA,EACA,UAAAC;AAAA,EACA,cAAAC;AACF,MAGM,gBAAAC,EAAAC,GAAA,EAAA,UAAA;AAAA,EAAA,gBAAAC,EAACC,GAAK,EAAA,WAAU,YAAW,QAAO,SAC/B,UACHR,GAAA;AAAA,oBACCS,GAAS,EAAA,UAAU,KAAK,OAAO,KAAK,cAAc,MAChD,UAAA;AAAA,IAAAR,EAAM,SAAS,KACd,gBAAAM;AAAA,MAACG;AAAA,MAAA;AAAA,QACC,MAAK;AAAA,QACL,UAAS;AAAA,QACT,YAAY;AAAA,QACZ,SAAST,EAAM,MAAM,GAAG,CAAC,EAAE,IAAI,CAAQU,OAAA;AAAA,UACrC,IAAIA;AAAA,UACJ,yBACGH,GAAK,EAAA,WAAU,YAAW,QAAO,SAAQ,SAAO,IAC9C,UACHG,EAAA,CAAA;AAAA,QAAA,EAEF;AAAA,QACF,OAAOT;AAAA,QACP,UAAAC;AAAA,MAAA;AAAA,IACF;AAAA,IAEDF,EAAM,SAAS,KACd,gBAAAM;AAAA,MAACK;AAAA,MAAA;AAAA,QACC,MAAK;AAAA,QACL,OAAM;AAAA,QACN,SAASR;AAAA,QACT,OAAO,GAAGH,EAAM,SAAS,CAAC;AAAA,MAAA;AAAA,IAC5B;AAAA,EAAA,GAEJ;AACF,EAAA,CAAA,GAIWY,IAAAC,EAAKf,CAAa;"}
@@ -0,0 +1,107 @@
1
+ import { jsxs as h, Fragment as B, jsx as o } from "react/jsx-runtime";
2
+ import { memo as L, useState as T, useMemo as u, useCallback as r, useEffect as g } from "react";
3
+ import I from "../../../ui/buttons/text-button/text-button.js";
4
+ import A from "../../../ui/layout/flex-view.js";
5
+ import M from "../../../ui/tab/tab.js";
6
+ import b from "../../../ui/text/text.js";
7
+ import w from "./filters-section.js";
8
+ import { SelectedGrades as R } from "./puzzles-styled.js";
9
+ import { GRADE_DISPLAY_NAMES as Y } from "./utils.js";
10
+ const l = (n) => n.filter((t) => t.applied).map((t) => t.name), $ = (n) => n.map((t) => t.name), q = (n) => {
11
+ const { handleFiltersChange: t, filterGrades: f, filterTypes: i, filterTiles: c, filterTopics: a, togglePopup: s } = n, [d, x] = T(l(f)), [F, y] = T(l(c)), [G, S] = T(l(a)), [p, E] = T(l(i)), P = u(() => $(i), [i]), W = u(() => $(c), [c]), D = u(() => $(a), [a]), H = r(
12
+ (e) => {
13
+ const m = p.includes(e) ? p.filter((X) => X !== e) : [...p, e];
14
+ E(m), t({
15
+ activity_types: m
16
+ });
17
+ },
18
+ [t, p]
19
+ ), _ = r(
20
+ (e) => {
21
+ y(e), t({
22
+ activity_tiles: e
23
+ });
24
+ },
25
+ [t]
26
+ ), k = r(
27
+ (e) => {
28
+ S(e), t({
29
+ activity_topics: e
30
+ });
31
+ },
32
+ [t]
33
+ ), C = r(() => {
34
+ s("grades");
35
+ }, [s]), j = r(() => {
36
+ s("tiles");
37
+ }, [s]), v = r(() => {
38
+ s("topics");
39
+ }, [s]);
40
+ return g(() => {
41
+ x(l(f));
42
+ }, [f]), g(() => {
43
+ y(l(c));
44
+ }, [c]), g(() => {
45
+ S(l(a));
46
+ }, [a]), g(() => {
47
+ E(l(i));
48
+ }, [i]), /* @__PURE__ */ h(B, { children: [
49
+ /* @__PURE__ */ o(b, { $renderAs: "eyebrow2", $color: "WHITE", children: "GRADE" }),
50
+ /* @__PURE__ */ h(
51
+ A,
52
+ {
53
+ $flexDirection: "row",
54
+ $justifyContent: "space-between",
55
+ $alignItems: "center",
56
+ $gutterX: 0.5,
57
+ $gapX: 0.25,
58
+ $marginBottomX: 0.5,
59
+ children: [
60
+ d.length ? /* @__PURE__ */ o(R, { $renderAs: "eyebrow2", $color: "WHITE", children: d.map((e, m) => /* @__PURE__ */ h("span", { children: [
61
+ Y[e],
62
+ m < d.length - 1 ? ", " : ""
63
+ ] }, e)) }) : /* @__PURE__ */ o(I, { color: "WHITE", onClick: C, label: "Select Grade" }),
64
+ d.length > 0 && /* @__PURE__ */ o(I, { color: "WHITE", onClick: C, label: "Edit" })
65
+ ]
66
+ }
67
+ ),
68
+ /* @__PURE__ */ o(b, { $renderAs: "eyebrow2", $color: "WHITE", children: "TYPE" }),
69
+ /* @__PURE__ */ o(A, { $flexDirection: "row", $flexWrap: !0, children: P.map((e) => /* @__PURE__ */ o(
70
+ M,
71
+ {
72
+ $width: "fit-content",
73
+ $renderAs: "secondary",
74
+ label: e,
75
+ $selected: p.includes(e),
76
+ shape: "square",
77
+ $size: "small",
78
+ onClick: () => H(e)
79
+ },
80
+ e
81
+ )) }),
82
+ /* @__PURE__ */ o(
83
+ w,
84
+ {
85
+ title: "TOPIC",
86
+ items: D,
87
+ selectedItems: G,
88
+ onChange: k,
89
+ openSelector: v
90
+ }
91
+ ),
92
+ /* @__PURE__ */ o(
93
+ w,
94
+ {
95
+ title: "TILE",
96
+ items: W,
97
+ onChange: _,
98
+ selectedItems: F,
99
+ openSelector: j
100
+ }
101
+ )
102
+ ] });
103
+ }, ee = L(q);
104
+ export {
105
+ ee as default
106
+ };
107
+ //# sourceMappingURL=filters.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"filters.js","sources":["../../../../../src/features/cue-canvas/sidebar/puzzles/filters.tsx"],"sourcesContent":["import type { IFilterOption } from './api/get-puzzles';\nimport type { FiltersProps } from './puzzles-type';\n\nimport React, { memo, useCallback, useEffect, useMemo, useState } from 'react';\n\nimport TextButton from '../../../ui/buttons/text-button/text-button';\nimport FlexView from '../../../ui/layout/flex-view';\nimport TabComponent from '../../../ui/tab/tab';\nimport Text from '../../../ui/text/text';\nimport FilterSection from './filters-section';\nimport * as Styled from './puzzles-styled';\nimport { GRADE_DISPLAY_NAMES } from './utils';\n\nconst getAppliedFilters = (filters: IFilterOption[]): string[] => {\n return filters.filter(item => item.applied).map(item => item.name);\n};\n\nconst getAllFilters = (filters: IFilterOption[]): string[] => {\n return filters.map(item => item.name);\n};\n\nconst Filters: React.FC<FiltersProps> = props => {\n const { handleFiltersChange, filterGrades, filterTypes, filterTiles, filterTopics, togglePopup } =\n props;\n const [selectedGrades, setSelectedGrade] = useState<string[]>(getAppliedFilters(filterGrades));\n const [selectedTiles, setSelectedTiles] = useState<string[]>(getAppliedFilters(filterTiles));\n const [selectedTopics, setSelectedTopics] = useState<string[]>(getAppliedFilters(filterTopics));\n const [selectedTypes, setSelectedTypes] = useState<string[]>(getAppliedFilters(filterTypes));\n\n const allTypes = useMemo(() => getAllFilters(filterTypes), [filterTypes]);\n const allTiles = useMemo(() => getAllFilters(filterTiles), [filterTiles]);\n const allTopics = useMemo(() => getAllFilters(filterTopics), [filterTopics]);\n\n const handleTypeChange = useCallback(\n (ele: string) => {\n const newSelectedTypes = selectedTypes.includes(ele)\n ? selectedTypes.filter(type => type !== ele)\n : [...selectedTypes, ele];\n\n setSelectedTypes(newSelectedTypes);\n handleFiltersChange({\n activity_types: newSelectedTypes,\n });\n },\n [handleFiltersChange, selectedTypes],\n );\n\n const handleTileChange = useCallback(\n (selectedCodes: string[]) => {\n setSelectedTiles(selectedCodes);\n handleFiltersChange({\n activity_tiles: selectedCodes,\n });\n },\n [handleFiltersChange],\n );\n\n const handleTopicChange = useCallback(\n (selectedCodes: string[]) => {\n setSelectedTopics(selectedCodes);\n handleFiltersChange({\n activity_topics: selectedCodes,\n });\n },\n [handleFiltersChange],\n );\n\n const toggleGradePopup = useCallback(() => {\n togglePopup('grades');\n }, [togglePopup]);\n\n const toggleTilesPopup = useCallback(() => {\n togglePopup('tiles');\n }, [togglePopup]);\n\n const toggleTopicsPopup = useCallback(() => {\n togglePopup('topics');\n }, [togglePopup]);\n\n useEffect(() => {\n setSelectedGrade(getAppliedFilters(filterGrades));\n }, [filterGrades]);\n\n useEffect(() => {\n setSelectedTiles(getAppliedFilters(filterTiles));\n }, [filterTiles]);\n\n useEffect(() => {\n setSelectedTopics(getAppliedFilters(filterTopics));\n }, [filterTopics]);\n\n useEffect(() => {\n setSelectedTypes(getAppliedFilters(filterTypes));\n }, [filterTypes]);\n\n return (\n <>\n <Text $renderAs=\"eyebrow2\" $color=\"WHITE\">\n GRADE\n </Text>\n <FlexView\n $flexDirection=\"row\"\n $justifyContent=\"space-between\"\n $alignItems=\"center\"\n $gutterX={0.5}\n $gapX={0.25}\n $marginBottomX={0.5}\n >\n {selectedGrades.length ? (\n <Styled.SelectedGrades $renderAs=\"eyebrow2\" $color=\"WHITE\">\n {selectedGrades.map((grade, index) => (\n <span key={grade}>\n {GRADE_DISPLAY_NAMES[grade]}\n {index < selectedGrades.length - 1 ? ', ' : ''}\n </span>\n ))}\n </Styled.SelectedGrades>\n ) : (\n <TextButton color=\"WHITE\" onClick={toggleGradePopup} label=\"Select Grade\" />\n )}\n {selectedGrades.length > 0 && (\n <TextButton color=\"WHITE\" onClick={toggleGradePopup} label=\"Edit\" />\n )}\n </FlexView>\n <Text $renderAs=\"eyebrow2\" $color=\"WHITE\">\n TYPE\n </Text>\n <FlexView $flexDirection=\"row\" $flexWrap>\n {allTypes.map((ele: string) => (\n <TabComponent\n key={ele}\n $width=\"fit-content\"\n $renderAs=\"secondary\"\n label={ele}\n $selected={selectedTypes.includes(ele)}\n shape=\"square\"\n $size=\"small\"\n onClick={() => handleTypeChange(ele)}\n />\n ))}\n </FlexView>\n <FilterSection\n title=\"TOPIC\"\n items={allTopics}\n selectedItems={selectedTopics}\n onChange={handleTopicChange}\n openSelector={toggleTopicsPopup}\n />\n <FilterSection\n title=\"TILE\"\n items={allTiles}\n onChange={handleTileChange}\n selectedItems={selectedTiles}\n openSelector={toggleTilesPopup}\n />\n </>\n );\n};\n\nexport default memo(Filters);\n"],"names":["getAppliedFilters","filters","item","getAllFilters","Filters","props","handleFiltersChange","filterGrades","filterTypes","filterTiles","filterTopics","togglePopup","selectedGrades","setSelectedGrade","useState","selectedTiles","setSelectedTiles","selectedTopics","setSelectedTopics","selectedTypes","setSelectedTypes","allTypes","useMemo","allTiles","allTopics","handleTypeChange","useCallback","ele","newSelectedTypes","type","handleTileChange","selectedCodes","handleTopicChange","toggleGradePopup","toggleTilesPopup","toggleTopicsPopup","useEffect","jsxs","Fragment","jsx","Text","FlexView","Styled.SelectedGrades","grade","index","GRADE_DISPLAY_NAMES","TextButton","TabComponent","FilterSection","Filters$1","memo"],"mappings":"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"}
@@ -0,0 +1,51 @@
1
+ import { useState as n, useRef as _, useCallback as d, useEffect as p } from "react";
2
+ import { getPuzzles as g } from "../api/get-puzzles.js";
3
+ import { checkIfFilterChanges as h } from "../utils.js";
4
+ const P = (o) => {
5
+ const [a, f] = n(
6
+ o ? { grades: [o] } : {}
7
+ ), [m, r] = n(!1), [s, y] = n(), i = _(null), u = d(async () => {
8
+ r(!0), i.current && i.current.abort();
9
+ const v = new AbortController();
10
+ i.current = v, h(a, s == null ? void 0 : s.filters) ? await g({
11
+ id: "",
12
+ query: a,
13
+ meta: void 0,
14
+ abortSignal: i.current.signal
15
+ }).then((l) => {
16
+ if (l) {
17
+ const {
18
+ __CODE__: c
19
+ // isProcessingFailed
20
+ } = l;
21
+ if (!(c >= 400 && c < 500)) {
22
+ if (c !== 500) {
23
+ const { data: e } = l || {};
24
+ e && (f({
25
+ activity_types: e.filters.activity_types.filter((t) => t.applied).map((t) => t.name),
26
+ search: e.filters.search,
27
+ grades: e.filters.grades.filter((t) => t.applied).map((t) => t.name),
28
+ activity_tiles: e.filters.activity_tiles.filter((t) => t.applied).map((t) => t.name),
29
+ activity_topics: e.filters.activity_topics.filter((t) => t.applied).map((t) => t.name)
30
+ }), y(e), r(!1));
31
+ }
32
+ }
33
+ }
34
+ }).catch(() => {
35
+ r(!1);
36
+ }) : r(!1);
37
+ }, [a, s]);
38
+ return p(() => {
39
+ u();
40
+ }, [u]), p(() => () => {
41
+ i.current && i.current.abort();
42
+ }, []), {
43
+ isPuzzlesProcessing: m,
44
+ puzzlesData: s,
45
+ setActivityFilters: f
46
+ };
47
+ };
48
+ export {
49
+ P as default
50
+ };
51
+ //# sourceMappingURL=use-fetch-cue-canvas-activity.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-fetch-cue-canvas-activity.js","sources":["../../../../../../src/features/cue-canvas/sidebar/puzzles/hooks/use-fetch-cue-canvas-activity.ts"],"sourcesContent":["import type { IFilterOption, IGetPuzzles } from '../api/get-puzzles';\n\nimport { useCallback, useEffect, useRef, useState } from 'react';\n\nimport { getPuzzles, type IPuzzlesResponses } from '../api/get-puzzles';\nimport { checkIfFilterChanges } from '../utils';\n\nconst useFetchCueCanvasActivity = (studentGrade?: string) => {\n const [activityFilters, setActivityFilters] = useState<IGetPuzzles>(\n studentGrade ? { grades: [studentGrade] } : {},\n );\n const [isPuzzlesProcessing, setIsPuzzlesProcessing] = useState(false);\n const [puzzlesData, setPuzzlesData] = useState<IPuzzlesResponses | undefined>();\n const abortControllerRef = useRef<AbortController | null>(null);\n\n const fetchResource = useCallback(async () => {\n setIsPuzzlesProcessing(true);\n\n if (abortControllerRef.current) {\n abortControllerRef.current.abort();\n }\n\n const controller = new AbortController();\n\n abortControllerRef.current = controller;\n if (checkIfFilterChanges(activityFilters, puzzlesData?.filters)) {\n await getPuzzles({\n id: '',\n query: activityFilters,\n meta: undefined,\n abortSignal: abortControllerRef.current.signal,\n })\n .then(res => {\n if (res) {\n const {\n __CODE__,\n // isProcessingFailed\n } = res;\n\n if (__CODE__ >= 400 && __CODE__ < 500) {\n // onError(__ERROR__?.message ?? 'Error while fetching the resource');\n } else if (__CODE__ === 500) {\n // setIsPuzzlesFailed(isProcessingFailed);\n // setError('Internal server error, Please try again');\n } else {\n const { data } = res || {};\n\n if (data) {\n setActivityFilters({\n activity_types: data.filters.activity_types\n .filter((type: IFilterOption) => type.applied)\n .map((type: IFilterOption) => type.name),\n search: data.filters.search,\n grades: data.filters.grades\n .filter((grade: IFilterOption) => grade.applied)\n .map((grade: IFilterOption) => grade.name),\n activity_tiles: data.filters.activity_tiles\n .filter((grade: IFilterOption) => grade.applied)\n .map((tile: IFilterOption) => tile.name),\n activity_topics: data.filters.activity_topics\n .filter((grade: IFilterOption) => grade.applied)\n .map((topic: IFilterOption) => topic.name),\n });\n setPuzzlesData(data);\n setIsPuzzlesProcessing(false);\n }\n }\n }\n })\n .catch(() => {\n setIsPuzzlesProcessing(false);\n // setIsPuzzlesFailed(true);\n });\n } else {\n setIsPuzzlesProcessing(false);\n }\n }, [activityFilters, puzzlesData]);\n\n useEffect(() => {\n fetchResource();\n }, [fetchResource]);\n\n useEffect(() => {\n return () => {\n if (abortControllerRef.current) {\n abortControllerRef.current.abort();\n }\n };\n }, []);\n\n return {\n isPuzzlesProcessing,\n puzzlesData,\n setActivityFilters,\n };\n};\n\nexport default useFetchCueCanvasActivity;\n"],"names":["useFetchCueCanvasActivity","studentGrade","activityFilters","setActivityFilters","useState","isPuzzlesProcessing","setIsPuzzlesProcessing","puzzlesData","setPuzzlesData","abortControllerRef","useRef","fetchResource","useCallback","controller","checkIfFilterChanges","getPuzzles","res","__CODE__","data","type","grade","tile","topic","useEffect"],"mappings":";;;AAOM,MAAAA,IAA4B,CAACC,MAA0B;AACrD,QAAA,CAACC,GAAiBC,CAAkB,IAAIC;AAAA,IAC5CH,IAAe,EAAE,QAAQ,CAACA,CAAY,MAAM,CAAC;AAAA,EAAA,GAEzC,CAACI,GAAqBC,CAAsB,IAAIF,EAAS,EAAK,GAC9D,CAACG,GAAaC,CAAc,IAAIJ,EAAwC,GACxEK,IAAqBC,EAA+B,IAAI,GAExDC,IAAgBC,EAAY,YAAY;AAC5C,IAAAN,EAAuB,EAAI,GAEvBG,EAAmB,WACrBA,EAAmB,QAAQ;AAGvB,UAAAI,IAAa,IAAI;AAEvB,IAAAJ,EAAmB,UAAUI,GACzBC,EAAqBZ,GAAiBK,KAAA,gBAAAA,EAAa,OAAO,IAC5D,MAAMQ,EAAW;AAAA,MACf,IAAI;AAAA,MACJ,OAAOb;AAAA,MACP,MAAM;AAAA,MACN,aAAaO,EAAmB,QAAQ;AAAA,IAAA,CACzC,EACE,KAAK,CAAOO,MAAA;AACX,UAAIA,GAAK;AACD,cAAA;AAAA,UACJ,UAAAC;AAAA;AAAA,QAEE,IAAAD;AAEA,YAAA,EAAAC,KAAY,OAAOA,IAAW;AAElC,cAAWA,MAAa,KAGjB;AACL,kBAAM,EAAE,MAAAC,EAAA,IAASF,KAAO;AAExB,YAAIE,MACiBf,EAAA;AAAA,cACjB,gBAAgBe,EAAK,QAAQ,eAC1B,OAAO,CAACC,MAAwBA,EAAK,OAAO,EAC5C,IAAI,CAACA,MAAwBA,EAAK,IAAI;AAAA,cACzC,QAAQD,EAAK,QAAQ;AAAA,cACrB,QAAQA,EAAK,QAAQ,OAClB,OAAO,CAACE,MAAyBA,EAAM,OAAO,EAC9C,IAAI,CAACA,MAAyBA,EAAM,IAAI;AAAA,cAC3C,gBAAgBF,EAAK,QAAQ,eAC1B,OAAO,CAACE,MAAyBA,EAAM,OAAO,EAC9C,IAAI,CAACC,MAAwBA,EAAK,IAAI;AAAA,cACzC,iBAAiBH,EAAK,QAAQ,gBAC3B,OAAO,CAACE,MAAyBA,EAAM,OAAO,EAC9C,IAAI,CAACE,MAAyBA,EAAM,IAAI;AAAA,YAAA,CAC5C,GACDd,EAAeU,CAAI,GACnBZ,EAAuB,EAAK;AAAA,UAEhC;AAAA;AAAA,MACF;AAAA,IAAA,CACD,EACA,MAAM,MAAM;AACX,MAAAA,EAAuB,EAAK;AAAA,IAAA,CAE7B,IAEHA,EAAuB,EAAK;AAAA,EAC9B,GACC,CAACJ,GAAiBK,CAAW,CAAC;AAEjC,SAAAgB,EAAU,MAAM;AACA,IAAAZ;EAAA,GACb,CAACA,CAAa,CAAC,GAElBY,EAAU,MACD,MAAM;AACX,IAAId,EAAmB,WACrBA,EAAmB,QAAQ;EAC7B,GAED,CAAE,CAAA,GAEE;AAAA,IACL,qBAAAJ;AAAA,IACA,aAAAE;AAAA,IACA,oBAAAJ;AAAA,EAAA;AAEJ;"}
@@ -0,0 +1,84 @@
1
+ import { jsxs as e, jsx as t } from "react/jsx-runtime";
2
+ import { memo as L, useEffect as z, useCallback as G } from "react";
3
+ import O from "styled-components";
4
+ import { ILLUSTRATIONS as E } from "../../../../assets/illustrations/illustrations.js";
5
+ import R from "../../../../assets/line-icons/icons/back.js";
6
+ import S from "../../../../assets/line-icons/icons/cross.js";
7
+ import W from "../../../ui/buttons/button/button.js";
8
+ import { Loader as P } from "../../../ui/buttons/button/button-styled.js";
9
+ import h from "../../../ui/buttons/clickable/clickable.js";
10
+ import r from "../../../ui/layout/flex-view.js";
11
+ import b from "../../../ui/text/text.js";
12
+ import { useCueCanvasActions as B } from "../../hooks/use-cue-canvas-actions.js";
13
+ import { useGetActivity as H } from "./api/get-puzzles.js";
14
+ import { MenuContainer as v } from "./puzzles-styled.js";
15
+ import { serializeData as J, getTags as o } from "./utils.js";
16
+ const M = O.iframe`
17
+ width: 100%;
18
+ height: 100%;
19
+ `, ct = L((w) => {
20
+ const { launchPuzzleData: A, onMenuVisibilityChange: s, toggleMenu: l } = w, { node_id: m } = A || {}, { activeInstance: i } = B(), {
21
+ get: f,
22
+ data: p,
23
+ isProcessed: C
24
+ } = H();
25
+ z(() => {
26
+ f(m);
27
+ }, [f, m]);
28
+ const {
29
+ activity_tiles: d,
30
+ activity_topics: u,
31
+ activity_types: g,
32
+ grades: $,
33
+ worksheet: T
34
+ } = p || {}, { instructions_ref: y, learnosity_activity_ref: n } = T || {}, x = G(async () => {
35
+ const c = n && await (await fetch(n)).json(), j = {
36
+ ...J(c)
37
+ };
38
+ l(), i == null || i.replaceCanvas(j);
39
+ }, [i, n, l]);
40
+ if (!p || !C)
41
+ return /* @__PURE__ */ e(v, { $justifyContent: "center", $alignItems: "center", children: [
42
+ /* @__PURE__ */ t(P, { src: E.LOADER, alt: "Loader", $size: "small" }),
43
+ ";"
44
+ ] });
45
+ const I = $ ? o($, "grades") : [], D = u ? o(u) : [], X = g ? o(g) : [], k = d ? o(d) : [], _ = [...D, ...I, ...X, ...k];
46
+ return /* @__PURE__ */ e(v, { children: [
47
+ /* @__PURE__ */ e(
48
+ r,
49
+ {
50
+ $justifyContent: "space-between",
51
+ $alignItems: "center",
52
+ $flexDirection: "row",
53
+ $gutterX: 1,
54
+ $gapX: 0.5,
55
+ children: [
56
+ /* @__PURE__ */ t(h, { onClick: s, label: "back", children: /* @__PURE__ */ t(R, { color: "WHITE" }) }),
57
+ /* @__PURE__ */ e(r, { $flexDirection: "row", $alignItems: "center", $flexColumnGapX: 1, children: [
58
+ /* @__PURE__ */ t(
59
+ W,
60
+ {
61
+ size: "small",
62
+ renderAs: "primary",
63
+ widthX: 12,
64
+ label: "Launch",
65
+ onClick: x
66
+ }
67
+ ),
68
+ /* @__PURE__ */ t(h, { onClick: s, label: "close filter menu", children: /* @__PURE__ */ t(S, { color: "WHITE" }) })
69
+ ] })
70
+ ]
71
+ }
72
+ ),
73
+ /* @__PURE__ */ e(r, { $flexDirection: "row", $flexColumnGapX: 1, $gapX: 1, $gutterX: 1, children: [
74
+ /* @__PURE__ */ t(b, { $renderAs: "ab1", $color: "GREY_2", children: "Tags:" }),
75
+ /* @__PURE__ */ t(r, { $flexDirection: "row", $flexColumnGapX: 1, $flexRowGapX: 0.5, $flexWrap: !0, children: _.map((c, a) => /* @__PURE__ */ t(r, { $background: "WHITE", $borderRadius: 16, $gapX: 0.25, $gutterX: 1, children: /* @__PURE__ */ t(b, { $renderAs: "ub2", children: c }, a) }, a)) })
76
+ ] }),
77
+ y && /* @__PURE__ */ t(M, { id: "launch_activity_iframe", src: y })
78
+ ] });
79
+ });
80
+ export {
81
+ M as Iframe,
82
+ ct as default
83
+ };
84
+ //# sourceMappingURL=launch-puzzle.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"launch-puzzle.js","sources":["../../../../../src/features/cue-canvas/sidebar/puzzles/launch-puzzle.tsx"],"sourcesContent":["import type { IPuzzlesResultData } from './api/get-puzzles';\nimport type { FC } from 'react';\n\nimport { memo, useCallback, useEffect } from 'react';\nimport styled from 'styled-components';\n\nimport { ILLUSTRATIONS } from '../../../../assets/illustrations/illustrations';\nimport BackIcon from '../../../../assets/line-icons/icons/back';\nimport CrossIcon from '../../../../assets/line-icons/icons/cross';\nimport Button from '../../../ui/buttons/button/button';\nimport { Loader } from '../../../ui/buttons/button/button-styled';\nimport Clickable from '../../../ui/buttons/clickable/clickable';\nimport FlexView from '../../../ui/layout/flex-view';\nimport Text from '../../../ui/text/text';\nimport { useCueCanvasActions } from '../../hooks/use-cue-canvas-actions';\nimport { useGetActivity } from './api/get-puzzles';\nimport * as Styled from './puzzles-styled';\nimport { getTags, serializeData } from './utils';\n\nexport const Iframe = styled.iframe`\n width: 100%;\n height: 100%;\n`;\n\ninterface ILaunchPuzzleProps {\n launchPuzzleData: IPuzzlesResultData;\n onMenuVisibilityChange: () => void;\n toggleMenu: () => void;\n}\n\nconst LaunchPuzzle: FC<ILaunchPuzzleProps> = memo(props => {\n const { launchPuzzleData, onMenuVisibilityChange, toggleMenu } = props;\n const { node_id: nodeId } = launchPuzzleData || {};\n const { activeInstance: cueCanvas } = useCueCanvasActions();\n\n const {\n get: getWbActivity,\n data: wbActivityData,\n isProcessed: wbActivityDataProcessed,\n } = useGetActivity();\n\n useEffect(() => {\n getWbActivity(nodeId);\n }, [getWbActivity, nodeId]);\n const {\n activity_tiles: activityTiles,\n activity_topics: activityTopics,\n activity_types: activityTypes,\n grades: grades,\n worksheet,\n } = wbActivityData || {};\n const { instructions_ref: iframeSrc, learnosity_activity_ref: learnnosityActivityRef } =\n worksheet || {};\n\n const onLaunchActivityClick = useCallback(async () => {\n const jsonOBJ = learnnosityActivityRef && (await (await fetch(learnnosityActivityRef)).json());\n\n const newJSONObj = serializeData(jsonOBJ);\n const actionData = {\n ...newJSONObj,\n };\n\n toggleMenu();\n\n cueCanvas?.replaceCanvas(actionData);\n }, [cueCanvas, learnnosityActivityRef, toggleMenu]);\n\n if (!wbActivityData || !wbActivityDataProcessed) {\n return (\n <Styled.MenuContainer $justifyContent=\"center\" $alignItems=\"center\">\n <Loader src={ILLUSTRATIONS.LOADER} alt=\"Loader\" $size=\"small\" />;\n </Styled.MenuContainer>\n );\n }\n\n const getGradesArr = grades ? getTags(grades, 'grades') : [];\n const getTopicsArr = activityTopics ? getTags(activityTopics) : [];\n const getTypesArr = activityTypes ? getTags(activityTypes) : [];\n const getTilesArr = activityTiles ? getTags(activityTiles) : [];\n\n const tagData: string[] = [...getTopicsArr, ...getGradesArr, ...getTypesArr, ...getTilesArr];\n\n return (\n <Styled.MenuContainer>\n <FlexView\n $justifyContent=\"space-between\"\n $alignItems=\"center\"\n $flexDirection=\"row\"\n $gutterX={1}\n $gapX={0.5}\n >\n <Clickable onClick={onMenuVisibilityChange} label=\"back\">\n <BackIcon color=\"WHITE\" />\n </Clickable>\n <FlexView $flexDirection=\"row\" $alignItems=\"center\" $flexColumnGapX={1}>\n <Button\n size=\"small\"\n renderAs=\"primary\"\n widthX={12}\n label=\"Launch\"\n onClick={onLaunchActivityClick}\n />\n <Clickable onClick={onMenuVisibilityChange} label=\"close filter menu\">\n <CrossIcon color=\"WHITE\" />\n </Clickable>\n </FlexView>\n </FlexView>\n <FlexView $flexDirection=\"row\" $flexColumnGapX={1} $gapX={1} $gutterX={1}>\n <Text $renderAs=\"ab1\" $color=\"GREY_2\">\n Tags:\n </Text>\n <FlexView $flexDirection=\"row\" $flexColumnGapX={1} $flexRowGapX={0.5} $flexWrap>\n {tagData.map((tag, index) => (\n <FlexView $background=\"WHITE\" $borderRadius={16} $gapX={0.25} $gutterX={1} key={index}>\n <Text $renderAs=\"ub2\" key={index}>\n {tag}\n </Text>\n </FlexView>\n ))}\n </FlexView>\n </FlexView>\n {iframeSrc && <Iframe id=\"launch_activity_iframe\" src={iframeSrc} />}\n </Styled.MenuContainer>\n );\n});\n\nexport default LaunchPuzzle;\n"],"names":["Iframe","styled","LaunchPuzzle","memo","props","launchPuzzleData","onMenuVisibilityChange","toggleMenu","nodeId","cueCanvas","useCueCanvasActions","getWbActivity","wbActivityData","wbActivityDataProcessed","useGetActivity","useEffect","activityTiles","activityTopics","activityTypes","grades","worksheet","iframeSrc","learnnosityActivityRef","onLaunchActivityClick","useCallback","jsonOBJ","actionData","serializeData","Styled.MenuContainer","jsx","Loader","ILLUSTRATIONS","getGradesArr","getTags","getTopicsArr","getTypesArr","getTilesArr","tagData","jsxs","FlexView","Clickable","BackIcon","Button","CrossIcon","Text","tag","index"],"mappings":"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"}
@@ -0,0 +1,36 @@
1
+ import { jsxs as o, jsx as e } from "react/jsx-runtime";
2
+ import { memo as i } from "react";
3
+ import n from "../../../../assets/line-icons/icons/cross.js";
4
+ import c from "../../../../assets/line-icons/icons/puzzle-icon.js";
5
+ import m from "../../../ui/buttons/clickable/clickable.js";
6
+ import s from "../../../ui/buttons/text-button/text-button.js";
7
+ import r from "../../../ui/layout/flex-view.js";
8
+ import a from "../../../ui/text/text.js";
9
+ const f = ({
10
+ toggleMenu: t,
11
+ onReset: l
12
+ }) => /* @__PURE__ */ o(
13
+ r,
14
+ {
15
+ $flexDirection: "row",
16
+ $justifyContent: "space-between",
17
+ $alignItems: "center",
18
+ $gutterX: 1,
19
+ $gapX: 0.5,
20
+ $heightX: 3,
21
+ children: [
22
+ /* @__PURE__ */ o(r, { $flexDirection: "row", $alignItems: "center", $flexColumnGapX: 0.5, children: [
23
+ /* @__PURE__ */ e(c, { color: "WHITE" }),
24
+ /* @__PURE__ */ e(a, { $color: "WHITE", $renderAs: "body2", children: "ACTIVITIES" })
25
+ ] }),
26
+ /* @__PURE__ */ o(r, { $flexDirection: "row", $alignItems: "center", $flexColumnGapX: 1, children: [
27
+ /* @__PURE__ */ e(s, { color: "WHITE", label: "Reset", onClick: l }),
28
+ /* @__PURE__ */ e(m, { onClick: t, label: "close activities menu", children: /* @__PURE__ */ e(n, { color: "WHITE" }) })
29
+ ] })
30
+ ]
31
+ }
32
+ ), h = i(f);
33
+ export {
34
+ h as default
35
+ };
36
+ //# sourceMappingURL=puzzle-menu-header.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"puzzle-menu-header.js","sources":["../../../../../src/features/cue-canvas/sidebar/puzzles/puzzle-menu-header.tsx"],"sourcesContent":["import { memo } from 'react';\n\nimport CrossIcon from '../../../../assets/line-icons/icons/cross';\nimport PuzzleIcon from '../../../../assets/line-icons/icons/puzzle-icon';\nimport Clickable from '../../../ui/buttons/clickable/clickable';\nimport TextButton from '../../../ui/buttons/text-button/text-button';\nimport FlexView from '../../../ui/layout/flex-view';\nimport Text from '../../../ui/text/text';\n\nconst MenuHeader: React.FC<{ toggleMenu: () => void; onReset?: () => void }> = ({\n toggleMenu,\n onReset,\n}) => (\n <FlexView\n $flexDirection=\"row\"\n $justifyContent=\"space-between\"\n $alignItems=\"center\"\n $gutterX={1}\n $gapX={0.5}\n $heightX={3}\n >\n <FlexView $flexDirection=\"row\" $alignItems=\"center\" $flexColumnGapX={0.5}>\n <PuzzleIcon color=\"WHITE\" />\n <Text $color=\"WHITE\" $renderAs=\"body2\">\n ACTIVITIES\n </Text>\n </FlexView>\n <FlexView $flexDirection=\"row\" $alignItems=\"center\" $flexColumnGapX={1}>\n <TextButton color=\"WHITE\" label=\"Reset\" onClick={onReset} />\n <Clickable onClick={toggleMenu} label=\"close activities menu\">\n <CrossIcon color=\"WHITE\" />\n </Clickable>\n </FlexView>\n </FlexView>\n);\n\nexport default memo(MenuHeader);\n"],"names":["MenuHeader","toggleMenu","onReset","jsxs","FlexView","jsx","PuzzleIcon","Text","TextButton","Clickable","CrossIcon","PuzzleMenuHeader","memo"],"mappings":";;;;;;;;AASA,MAAMA,IAAyE,CAAC;AAAA,EAC9E,YAAAC;AAAA,EACA,SAAAC;AACF,MACE,gBAAAC;AAAA,EAACC;AAAA,EAAA;AAAA,IACC,gBAAe;AAAA,IACf,iBAAgB;AAAA,IAChB,aAAY;AAAA,IACZ,UAAU;AAAA,IACV,OAAO;AAAA,IACP,UAAU;AAAA,IAEV,UAAA;AAAA,MAAA,gBAAAD,EAACC,KAAS,gBAAe,OAAM,aAAY,UAAS,iBAAiB,KACnE,UAAA;AAAA,QAAC,gBAAAC,EAAAC,GAAA,EAAW,OAAM,QAAQ,CAAA;AAAA,0BACzBC,GAAK,EAAA,QAAO,SAAQ,WAAU,SAAQ,UAEvC,cAAA;AAAA,MAAA,GACF;AAAA,wBACCH,GAAS,EAAA,gBAAe,OAAM,aAAY,UAAS,iBAAiB,GACnE,UAAA;AAAA,QAAA,gBAAAC,EAACG,KAAW,OAAM,SAAQ,OAAM,SAAQ,SAASN,GAAS;AAAA,QAC1D,gBAAAG,EAACI,GAAU,EAAA,SAASR,GAAY,OAAM,yBACpC,UAAC,gBAAAI,EAAAK,GAAA,EAAU,OAAM,QAAA,CAAQ,EAC3B,CAAA;AAAA,MAAA,GACF;AAAA,IAAA;AAAA,EAAA;AACF,GAGaC,IAAAC,EAAKZ,CAAU;"}