@magmamath/students-features 1.8.0 → 1.8.1-rc.0
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/commonjs/features/fluency/components/FluencySolving.js +2 -2
- package/dist/commonjs/features/fluency/components/FluencySolving.js.map +1 -1
- package/dist/commonjs/features/fluency/components/fluency-solving/components/DebugBoxIndicator.js +48 -0
- package/dist/commonjs/features/fluency/components/fluency-solving/components/DebugBoxIndicator.js.map +1 -0
- package/dist/commonjs/features/fluency/components/fluency-solving/components/EquationContent.js +9 -8
- package/dist/commonjs/features/fluency/components/fluency-solving/components/EquationContent.js.map +1 -1
- package/dist/commonjs/features/fluency/components/fluency-solving/components/FluencyCardDeck.js +3 -1
- package/dist/commonjs/features/fluency/components/fluency-solving/components/FluencyCardDeck.js.map +1 -1
- package/dist/commonjs/features/fluency/components/fluency-solving/components/FluencyEquationCard.js +63 -10
- package/dist/commonjs/features/fluency/components/fluency-solving/components/FluencyEquationCard.js.map +1 -1
- package/dist/commonjs/features/fluency/components/fluency-solving/components/FluencySolvingHeader.js +10 -0
- package/dist/commonjs/features/fluency/components/fluency-solving/components/FluencySolvingHeader.js.map +1 -1
- package/dist/commonjs/features/fluency/components/fluency-solving/components/FluencySolvingProgress.js +0 -2
- package/dist/commonjs/features/fluency/components/fluency-solving/components/FluencySolvingProgress.js.map +1 -1
- package/dist/commonjs/features/fluency/index.js +12 -0
- package/dist/commonjs/features/fluency/index.js.map +1 -1
- package/dist/commonjs/features/fluency/visual-scaffolding/adapter.js +36 -0
- package/dist/commonjs/features/fluency/visual-scaffolding/adapter.js.map +1 -0
- package/dist/commonjs/features/fluency/visual-scaffolding/components/DiscreteCounterGrid.js +232 -0
- package/dist/commonjs/features/fluency/visual-scaffolding/components/DiscreteCounterGrid.js.map +1 -0
- package/dist/commonjs/features/fluency/visual-scaffolding/components/Dot.js +51 -0
- package/dist/commonjs/features/fluency/visual-scaffolding/components/Dot.js.map +1 -0
- package/dist/commonjs/features/fluency/visual-scaffolding/components/DynamicNumberLine.js +104 -0
- package/dist/commonjs/features/fluency/visual-scaffolding/components/DynamicNumberLine.js.map +1 -0
- package/dist/commonjs/features/fluency/visual-scaffolding/components/FactVisual.js +75 -0
- package/dist/commonjs/features/fluency/visual-scaffolding/components/FactVisual.js.map +1 -0
- package/dist/commonjs/features/fluency/visual-scaffolding/components/QuotativeBars.js +91 -0
- package/dist/commonjs/features/fluency/visual-scaffolding/components/QuotativeBars.js.map +1 -0
- package/dist/commonjs/features/fluency/visual-scaffolding/components/RelationalBlock.js +279 -0
- package/dist/commonjs/features/fluency/visual-scaffolding/components/RelationalBlock.js.map +1 -0
- package/dist/commonjs/features/fluency/visual-scaffolding/components/visualColors.js +44 -0
- package/dist/commonjs/features/fluency/visual-scaffolding/components/visualColors.js.map +1 -0
- package/dist/commonjs/features/fluency/visual-scaffolding/index.js +73 -0
- package/dist/commonjs/features/fluency/visual-scaffolding/index.js.map +1 -0
- package/dist/commonjs/features/fluency/visual-scaffolding/renderFact.js +276 -0
- package/dist/commonjs/features/fluency/visual-scaffolding/renderFact.js.map +1 -0
- package/dist/commonjs/features/fluency/visual-scaffolding/types.js +2 -0
- package/dist/commonjs/features/fluency/visual-scaffolding/types.js.map +1 -0
- package/dist/commonjs/features/fluency-teacher/assets/{DivisionIcon.js → SortDefaultIcon.js} +8 -11
- package/dist/commonjs/features/fluency-teacher/assets/SortDefaultIcon.js.map +1 -0
- package/dist/commonjs/features/fluency-teacher/components/FluencyTeacher.js +3 -4
- package/dist/commonjs/features/fluency-teacher/components/FluencyTeacher.js.map +1 -1
- package/dist/commonjs/features/fluency-teacher/components/drawer/DrawerHeader.js +43 -48
- package/dist/commonjs/features/fluency-teacher/components/drawer/DrawerHeader.js.map +1 -1
- package/dist/commonjs/features/fluency-teacher/components/drawer/DrawerMasteryLegend.js +80 -0
- package/dist/commonjs/features/fluency-teacher/components/drawer/DrawerMasteryLegend.js.map +1 -0
- package/dist/commonjs/features/fluency-teacher/components/drawer/DrawerMatrixes.js +28 -11
- package/dist/commonjs/features/fluency-teacher/components/drawer/DrawerMatrixes.js.map +1 -1
- package/dist/commonjs/features/fluency-teacher/components/drawer/DrawerOperatorBox.js +44 -27
- package/dist/commonjs/features/fluency-teacher/components/drawer/DrawerOperatorBox.js.map +1 -1
- package/dist/commonjs/features/fluency-teacher/components/drawer/DrawerOperatorStatCard.js +40 -47
- package/dist/commonjs/features/fluency-teacher/components/drawer/DrawerOperatorStatCard.js.map +1 -1
- package/dist/commonjs/features/fluency-teacher/components/drawer/DrawerStats.js +24 -14
- package/dist/commonjs/features/fluency-teacher/components/drawer/DrawerStats.js.map +1 -1
- package/dist/commonjs/features/fluency-teacher/components/drawer/FluencyTeacherDrawer.js +6 -6
- package/dist/commonjs/features/fluency-teacher/components/drawer/FluencyTeacherDrawer.js.map +1 -1
- package/dist/commonjs/features/fluency-teacher/components/matrix/DrawerMatrix.js.map +1 -1
- package/dist/commonjs/features/fluency-teacher/components/matrix/MatrixCell.js +16 -2
- package/dist/commonjs/features/fluency-teacher/components/matrix/MatrixCell.js.map +1 -1
- package/dist/commonjs/features/fluency-teacher/components/matrix/MatrixRow.js +2 -1
- package/dist/commonjs/features/fluency-teacher/components/matrix/MatrixRow.js.map +1 -1
- package/dist/commonjs/features/fluency-teacher/components/table/AllPupilsTableRow.js +41 -15
- package/dist/commonjs/features/fluency-teacher/components/table/AllPupilsTableRow.js.map +1 -1
- package/dist/commonjs/features/fluency-teacher/components/table/AverageSortButton.js +62 -6
- package/dist/commonjs/features/fluency-teacher/components/table/AverageSortButton.js.map +1 -1
- package/dist/commonjs/features/fluency-teacher/components/table/FluencyTeacherStudentsTable.js +40 -42
- package/dist/commonjs/features/fluency-teacher/components/table/FluencyTeacherStudentsTable.js.map +1 -1
- package/dist/commonjs/features/fluency-teacher/components/table/OperatorBadge.js +16 -25
- package/dist/commonjs/features/fluency-teacher/components/table/OperatorBadge.js.map +1 -1
- package/dist/commonjs/features/fluency-teacher/components/table/TableColumnSortButton.js +40 -30
- package/dist/commonjs/features/fluency-teacher/components/table/TableColumnSortButton.js.map +1 -1
- package/dist/commonjs/features/fluency-teacher/components/table/TableRow.js +72 -59
- package/dist/commonjs/features/fluency-teacher/components/table/TableRow.js.map +1 -1
- package/dist/commonjs/features/fluency-teacher/components/table/TableRowAverageProgress.js +71 -0
- package/dist/commonjs/features/fluency-teacher/components/table/TableRowAverageProgress.js.map +1 -0
- package/dist/commonjs/features/fluency-teacher/context/TeacherFluencyContext.js.map +1 -1
- package/dist/commonjs/features/fluency-teacher/fluencyTeacher.constants.js +38 -103
- package/dist/commonjs/features/fluency-teacher/fluencyTeacher.constants.js.map +1 -1
- package/dist/commonjs/features/fluency-teacher/fluencyTeacher.helpers.js +10 -52
- package/dist/commonjs/features/fluency-teacher/fluencyTeacher.helpers.js.map +1 -1
- package/dist/commonjs/features/fluency-teacher/hooks/useDrawerGrid.js +2 -3
- package/dist/commonjs/features/fluency-teacher/hooks/useDrawerGrid.js.map +1 -1
- package/dist/commonjs/features/fluency-teacher/hooks/useDrawerMatrix.js.map +1 -1
- package/dist/commonjs/features/fluency-teacher/model/TeacherFluencyFiltersModel.js +1 -2
- package/dist/commonjs/features/fluency-teacher/model/TeacherFluencyFiltersModel.js.map +1 -1
- package/dist/commonjs/features/fluency-teacher/model/TeacherFluencyModel.js +0 -9
- package/dist/commonjs/features/fluency-teacher/model/TeacherFluencyModel.js.map +1 -1
- package/dist/module/features/fluency/components/FluencySolving.js +2 -2
- package/dist/module/features/fluency/components/FluencySolving.js.map +1 -1
- package/dist/module/features/fluency/components/fluency-solving/components/DebugBoxIndicator.js +43 -0
- package/dist/module/features/fluency/components/fluency-solving/components/DebugBoxIndicator.js.map +1 -0
- package/dist/module/features/fluency/components/fluency-solving/components/EquationContent.js +9 -8
- package/dist/module/features/fluency/components/fluency-solving/components/EquationContent.js.map +1 -1
- package/dist/module/features/fluency/components/fluency-solving/components/FluencyCardDeck.js +3 -1
- package/dist/module/features/fluency/components/fluency-solving/components/FluencyCardDeck.js.map +1 -1
- package/dist/module/features/fluency/components/fluency-solving/components/FluencyEquationCard.js +64 -11
- package/dist/module/features/fluency/components/fluency-solving/components/FluencyEquationCard.js.map +1 -1
- package/dist/module/features/fluency/components/fluency-solving/components/FluencySolvingHeader.js +10 -0
- package/dist/module/features/fluency/components/fluency-solving/components/FluencySolvingHeader.js.map +1 -1
- package/dist/module/features/fluency/components/fluency-solving/components/FluencySolvingProgress.js +0 -2
- package/dist/module/features/fluency/components/fluency-solving/components/FluencySolvingProgress.js.map +1 -1
- package/dist/module/features/fluency/index.js +1 -0
- package/dist/module/features/fluency/index.js.map +1 -1
- package/dist/module/features/fluency/visual-scaffolding/adapter.js +31 -0
- package/dist/module/features/fluency/visual-scaffolding/adapter.js.map +1 -0
- package/dist/module/features/fluency/visual-scaffolding/components/DiscreteCounterGrid.js +225 -0
- package/dist/module/features/fluency/visual-scaffolding/components/DiscreteCounterGrid.js.map +1 -0
- package/dist/module/features/fluency/visual-scaffolding/components/Dot.js +45 -0
- package/dist/module/features/fluency/visual-scaffolding/components/Dot.js.map +1 -0
- package/dist/module/features/fluency/visual-scaffolding/components/DynamicNumberLine.js +96 -0
- package/dist/module/features/fluency/visual-scaffolding/components/DynamicNumberLine.js.map +1 -0
- package/dist/module/features/fluency/visual-scaffolding/components/FactVisual.js +69 -0
- package/dist/module/features/fluency/visual-scaffolding/components/FactVisual.js.map +1 -0
- package/dist/module/features/fluency/visual-scaffolding/components/QuotativeBars.js +83 -0
- package/dist/module/features/fluency/visual-scaffolding/components/QuotativeBars.js.map +1 -0
- package/dist/module/features/fluency/visual-scaffolding/components/RelationalBlock.js +272 -0
- package/dist/module/features/fluency/visual-scaffolding/components/RelationalBlock.js.map +1 -0
- package/dist/module/features/fluency/visual-scaffolding/components/visualColors.js +41 -0
- package/dist/module/features/fluency/visual-scaffolding/components/visualColors.js.map +1 -0
- package/dist/module/features/fluency/visual-scaffolding/index.js +8 -0
- package/dist/module/features/fluency/visual-scaffolding/index.js.map +1 -0
- package/dist/module/features/fluency/visual-scaffolding/renderFact.js +269 -0
- package/dist/module/features/fluency/visual-scaffolding/renderFact.js.map +1 -0
- package/dist/module/features/fluency/visual-scaffolding/types.js +2 -0
- package/dist/module/features/fluency/visual-scaffolding/types.js.map +1 -0
- package/dist/module/features/fluency-teacher/assets/SortDefaultIcon.js +23 -0
- package/dist/module/features/fluency-teacher/assets/SortDefaultIcon.js.map +1 -0
- package/dist/module/features/fluency-teacher/components/FluencyTeacher.js +3 -4
- package/dist/module/features/fluency-teacher/components/FluencyTeacher.js.map +1 -1
- package/dist/module/features/fluency-teacher/components/drawer/DrawerHeader.js +44 -49
- package/dist/module/features/fluency-teacher/components/drawer/DrawerHeader.js.map +1 -1
- package/dist/module/features/fluency-teacher/components/drawer/DrawerMasteryLegend.js +74 -0
- package/dist/module/features/fluency-teacher/components/drawer/DrawerMasteryLegend.js.map +1 -0
- package/dist/module/features/fluency-teacher/components/drawer/DrawerMatrixes.js +31 -14
- package/dist/module/features/fluency-teacher/components/drawer/DrawerMatrixes.js.map +1 -1
- package/dist/module/features/fluency-teacher/components/drawer/DrawerOperatorBox.js +45 -28
- package/dist/module/features/fluency-teacher/components/drawer/DrawerOperatorBox.js.map +1 -1
- package/dist/module/features/fluency-teacher/components/drawer/DrawerOperatorStatCard.js +41 -48
- package/dist/module/features/fluency-teacher/components/drawer/DrawerOperatorStatCard.js.map +1 -1
- package/dist/module/features/fluency-teacher/components/drawer/DrawerStats.js +27 -17
- package/dist/module/features/fluency-teacher/components/drawer/DrawerStats.js.map +1 -1
- package/dist/module/features/fluency-teacher/components/drawer/FluencyTeacherDrawer.js +6 -6
- package/dist/module/features/fluency-teacher/components/drawer/FluencyTeacherDrawer.js.map +1 -1
- package/dist/module/features/fluency-teacher/components/matrix/DrawerMatrix.js.map +1 -1
- package/dist/module/features/fluency-teacher/components/matrix/MatrixCell.js +17 -3
- package/dist/module/features/fluency-teacher/components/matrix/MatrixCell.js.map +1 -1
- package/dist/module/features/fluency-teacher/components/matrix/MatrixRow.js +2 -1
- package/dist/module/features/fluency-teacher/components/matrix/MatrixRow.js.map +1 -1
- package/dist/module/features/fluency-teacher/components/table/AllPupilsTableRow.js +42 -16
- package/dist/module/features/fluency-teacher/components/table/AllPupilsTableRow.js.map +1 -1
- package/dist/module/features/fluency-teacher/components/table/AverageSortButton.js +63 -7
- package/dist/module/features/fluency-teacher/components/table/AverageSortButton.js.map +1 -1
- package/dist/module/features/fluency-teacher/components/table/FluencyTeacherStudentsTable.js +42 -44
- package/dist/module/features/fluency-teacher/components/table/FluencyTeacherStudentsTable.js.map +1 -1
- package/dist/module/features/fluency-teacher/components/table/OperatorBadge.js +16 -25
- package/dist/module/features/fluency-teacher/components/table/OperatorBadge.js.map +1 -1
- package/dist/module/features/fluency-teacher/components/table/TableColumnSortButton.js +42 -32
- package/dist/module/features/fluency-teacher/components/table/TableColumnSortButton.js.map +1 -1
- package/dist/module/features/fluency-teacher/components/table/TableRow.js +75 -62
- package/dist/module/features/fluency-teacher/components/table/TableRow.js.map +1 -1
- package/dist/module/features/fluency-teacher/components/table/TableRowAverageProgress.js +65 -0
- package/dist/module/features/fluency-teacher/components/table/TableRowAverageProgress.js.map +1 -0
- package/dist/module/features/fluency-teacher/context/TeacherFluencyContext.js.map +1 -1
- package/dist/module/features/fluency-teacher/fluencyTeacher.constants.js +37 -102
- package/dist/module/features/fluency-teacher/fluencyTeacher.constants.js.map +1 -1
- package/dist/module/features/fluency-teacher/fluencyTeacher.helpers.js +8 -43
- package/dist/module/features/fluency-teacher/fluencyTeacher.helpers.js.map +1 -1
- package/dist/module/features/fluency-teacher/hooks/useDrawerGrid.js +2 -3
- package/dist/module/features/fluency-teacher/hooks/useDrawerGrid.js.map +1 -1
- package/dist/module/features/fluency-teacher/hooks/useDrawerMatrix.js.map +1 -1
- package/dist/module/features/fluency-teacher/model/TeacherFluencyFiltersModel.js +1 -2
- package/dist/module/features/fluency-teacher/model/TeacherFluencyFiltersModel.js.map +1 -1
- package/dist/module/features/fluency-teacher/model/TeacherFluencyModel.js +0 -9
- package/dist/module/features/fluency-teacher/model/TeacherFluencyModel.js.map +1 -1
- package/dist/typescript/commonjs/features/fluency/components/fluency-solving/components/DebugBoxIndicator.d.ts +3 -0
- package/dist/typescript/commonjs/features/fluency/components/fluency-solving/components/DebugBoxIndicator.d.ts.map +1 -0
- package/dist/typescript/commonjs/features/fluency/components/fluency-solving/components/EquationContent.d.ts.map +1 -1
- package/dist/typescript/commonjs/features/fluency/components/fluency-solving/components/FluencyCardDeck.d.ts.map +1 -1
- package/dist/typescript/commonjs/features/fluency/components/fluency-solving/components/FluencyEquationCard.d.ts +2 -1
- package/dist/typescript/commonjs/features/fluency/components/fluency-solving/components/FluencyEquationCard.d.ts.map +1 -1
- package/dist/typescript/commonjs/features/fluency/components/fluency-solving/components/FluencySolvingHeader.d.ts.map +1 -1
- package/dist/typescript/commonjs/features/fluency/index.d.ts +1 -0
- package/dist/typescript/commonjs/features/fluency/index.d.ts.map +1 -1
- package/dist/typescript/commonjs/features/fluency/visual-scaffolding/__tests__/renderFact.test.d.ts +2 -0
- package/dist/typescript/commonjs/features/fluency/visual-scaffolding/__tests__/renderFact.test.d.ts.map +1 -0
- package/dist/typescript/commonjs/features/fluency/visual-scaffolding/adapter.d.ts +4 -0
- package/dist/typescript/commonjs/features/fluency/visual-scaffolding/adapter.d.ts.map +1 -0
- package/dist/typescript/commonjs/features/fluency/visual-scaffolding/components/DiscreteCounterGrid.d.ts +10 -0
- package/dist/typescript/commonjs/features/fluency/visual-scaffolding/components/DiscreteCounterGrid.d.ts.map +1 -0
- package/dist/typescript/commonjs/features/fluency/visual-scaffolding/components/Dot.d.ts +10 -0
- package/dist/typescript/commonjs/features/fluency/visual-scaffolding/components/Dot.d.ts.map +1 -0
- package/dist/typescript/commonjs/features/fluency/visual-scaffolding/components/DynamicNumberLine.d.ts +10 -0
- package/dist/typescript/commonjs/features/fluency/visual-scaffolding/components/DynamicNumberLine.d.ts.map +1 -0
- package/dist/typescript/commonjs/features/fluency/visual-scaffolding/components/FactVisual.d.ts +10 -0
- package/dist/typescript/commonjs/features/fluency/visual-scaffolding/components/FactVisual.d.ts.map +1 -0
- package/dist/typescript/commonjs/features/fluency/visual-scaffolding/components/QuotativeBars.d.ts +10 -0
- package/dist/typescript/commonjs/features/fluency/visual-scaffolding/components/QuotativeBars.d.ts.map +1 -0
- package/dist/typescript/commonjs/features/fluency/visual-scaffolding/components/RelationalBlock.d.ts +10 -0
- package/dist/typescript/commonjs/features/fluency/visual-scaffolding/components/RelationalBlock.d.ts.map +1 -0
- package/dist/typescript/commonjs/features/fluency/visual-scaffolding/components/visualColors.d.ts +16 -0
- package/dist/typescript/commonjs/features/fluency/visual-scaffolding/components/visualColors.d.ts.map +1 -0
- package/dist/typescript/commonjs/features/fluency/visual-scaffolding/index.d.ts +6 -0
- package/dist/typescript/commonjs/features/fluency/visual-scaffolding/index.d.ts.map +1 -0
- package/dist/typescript/commonjs/features/fluency/visual-scaffolding/renderFact.d.ts +23 -0
- package/dist/typescript/commonjs/features/fluency/visual-scaffolding/renderFact.d.ts.map +1 -0
- package/dist/typescript/commonjs/features/fluency/visual-scaffolding/types.d.ts +103 -0
- package/dist/typescript/commonjs/features/fluency/visual-scaffolding/types.d.ts.map +1 -0
- package/dist/typescript/commonjs/features/fluency-teacher/assets/SortDefaultIcon.d.ts +4 -0
- package/dist/typescript/commonjs/features/fluency-teacher/assets/SortDefaultIcon.d.ts.map +1 -0
- package/dist/typescript/commonjs/features/fluency-teacher/components/drawer/DrawerHeader.d.ts.map +1 -1
- package/dist/typescript/commonjs/features/fluency-teacher/components/drawer/DrawerMasteryLegend.d.ts +3 -0
- package/dist/typescript/commonjs/features/fluency-teacher/components/drawer/DrawerMasteryLegend.d.ts.map +1 -0
- package/dist/typescript/commonjs/features/fluency-teacher/components/drawer/DrawerMatrixes.d.ts.map +1 -1
- package/dist/typescript/commonjs/features/fluency-teacher/components/drawer/DrawerOperatorBox.d.ts +4 -1
- package/dist/typescript/commonjs/features/fluency-teacher/components/drawer/DrawerOperatorBox.d.ts.map +1 -1
- package/dist/typescript/commonjs/features/fluency-teacher/components/drawer/DrawerOperatorStatCard.d.ts +4 -6
- package/dist/typescript/commonjs/features/fluency-teacher/components/drawer/DrawerOperatorStatCard.d.ts.map +1 -1
- package/dist/typescript/commonjs/features/fluency-teacher/components/drawer/DrawerStats.d.ts.map +1 -1
- package/dist/typescript/commonjs/features/fluency-teacher/components/drawer/FluencyTeacherDrawer.d.ts.map +1 -1
- package/dist/typescript/commonjs/features/fluency-teacher/components/matrix/DrawerMatrix.d.ts +2 -3
- package/dist/typescript/commonjs/features/fluency-teacher/components/matrix/DrawerMatrix.d.ts.map +1 -1
- package/dist/typescript/commonjs/features/fluency-teacher/components/matrix/MatrixCell.d.ts +5 -6
- package/dist/typescript/commonjs/features/fluency-teacher/components/matrix/MatrixCell.d.ts.map +1 -1
- package/dist/typescript/commonjs/features/fluency-teacher/components/matrix/MatrixHeaderRow.d.ts +1 -2
- package/dist/typescript/commonjs/features/fluency-teacher/components/matrix/MatrixHeaderRow.d.ts.map +1 -1
- package/dist/typescript/commonjs/features/fluency-teacher/components/matrix/MatrixRow.d.ts +3 -5
- package/dist/typescript/commonjs/features/fluency-teacher/components/matrix/MatrixRow.d.ts.map +1 -1
- package/dist/typescript/commonjs/features/fluency-teacher/components/table/AllPupilsTableRow.d.ts.map +1 -1
- package/dist/typescript/commonjs/features/fluency-teacher/components/table/AverageSortButton.d.ts +1 -2
- package/dist/typescript/commonjs/features/fluency-teacher/components/table/AverageSortButton.d.ts.map +1 -1
- package/dist/typescript/commonjs/features/fluency-teacher/components/table/FluencyTeacherStudentsTable.d.ts.map +1 -1
- package/dist/typescript/commonjs/features/fluency-teacher/components/table/OperatorBadge.d.ts +4 -5
- package/dist/typescript/commonjs/features/fluency-teacher/components/table/OperatorBadge.d.ts.map +1 -1
- package/dist/typescript/commonjs/features/fluency-teacher/components/table/TableColumnSortButton.d.ts +6 -7
- package/dist/typescript/commonjs/features/fluency-teacher/components/table/TableColumnSortButton.d.ts.map +1 -1
- package/dist/typescript/commonjs/features/fluency-teacher/components/table/TableRow.d.ts +3 -4
- package/dist/typescript/commonjs/features/fluency-teacher/components/table/TableRow.d.ts.map +1 -1
- package/dist/typescript/commonjs/features/fluency-teacher/components/table/TableRowAverageProgress.d.ts +7 -0
- package/dist/typescript/commonjs/features/fluency-teacher/components/table/TableRowAverageProgress.d.ts.map +1 -0
- package/dist/typescript/commonjs/features/fluency-teacher/context/TeacherFluencyContext.d.ts +0 -1
- package/dist/typescript/commonjs/features/fluency-teacher/context/TeacherFluencyContext.d.ts.map +1 -1
- package/dist/typescript/commonjs/features/fluency-teacher/fluencyTeacher.constants.d.ts +3 -16
- package/dist/typescript/commonjs/features/fluency-teacher/fluencyTeacher.constants.d.ts.map +1 -1
- package/dist/typescript/commonjs/features/fluency-teacher/fluencyTeacher.helpers.d.ts +4 -11
- package/dist/typescript/commonjs/features/fluency-teacher/fluencyTeacher.helpers.d.ts.map +1 -1
- package/dist/typescript/commonjs/features/fluency-teacher/fluencyTeacher.types.d.ts +6 -35
- package/dist/typescript/commonjs/features/fluency-teacher/fluencyTeacher.types.d.ts.map +1 -1
- package/dist/typescript/commonjs/features/fluency-teacher/hooks/useDrawerGrid.d.ts +12 -1
- package/dist/typescript/commonjs/features/fluency-teacher/hooks/useDrawerGrid.d.ts.map +1 -1
- package/dist/typescript/commonjs/features/fluency-teacher/hooks/useDrawerMatrix.d.ts +3 -3
- package/dist/typescript/commonjs/features/fluency-teacher/hooks/useDrawerMatrix.d.ts.map +1 -1
- package/dist/typescript/commonjs/features/fluency-teacher/model/TeacherFluencyFiltersModel.d.ts +0 -1
- package/dist/typescript/commonjs/features/fluency-teacher/model/TeacherFluencyFiltersModel.d.ts.map +1 -1
- package/dist/typescript/commonjs/features/fluency-teacher/model/TeacherFluencyModel.d.ts.map +1 -1
- package/dist/typescript/module/features/fluency/components/fluency-solving/components/DebugBoxIndicator.d.ts +3 -0
- package/dist/typescript/module/features/fluency/components/fluency-solving/components/DebugBoxIndicator.d.ts.map +1 -0
- package/dist/typescript/module/features/fluency/components/fluency-solving/components/EquationContent.d.ts.map +1 -1
- package/dist/typescript/module/features/fluency/components/fluency-solving/components/FluencyCardDeck.d.ts.map +1 -1
- package/dist/typescript/module/features/fluency/components/fluency-solving/components/FluencyEquationCard.d.ts +2 -1
- package/dist/typescript/module/features/fluency/components/fluency-solving/components/FluencyEquationCard.d.ts.map +1 -1
- package/dist/typescript/module/features/fluency/components/fluency-solving/components/FluencySolvingHeader.d.ts.map +1 -1
- package/dist/typescript/module/features/fluency/index.d.ts +1 -0
- package/dist/typescript/module/features/fluency/index.d.ts.map +1 -1
- package/dist/typescript/module/features/fluency/visual-scaffolding/__tests__/renderFact.test.d.ts +2 -0
- package/dist/typescript/module/features/fluency/visual-scaffolding/__tests__/renderFact.test.d.ts.map +1 -0
- package/dist/typescript/module/features/fluency/visual-scaffolding/adapter.d.ts +4 -0
- package/dist/typescript/module/features/fluency/visual-scaffolding/adapter.d.ts.map +1 -0
- package/dist/typescript/module/features/fluency/visual-scaffolding/components/DiscreteCounterGrid.d.ts +10 -0
- package/dist/typescript/module/features/fluency/visual-scaffolding/components/DiscreteCounterGrid.d.ts.map +1 -0
- package/dist/typescript/module/features/fluency/visual-scaffolding/components/Dot.d.ts +10 -0
- package/dist/typescript/module/features/fluency/visual-scaffolding/components/Dot.d.ts.map +1 -0
- package/dist/typescript/module/features/fluency/visual-scaffolding/components/DynamicNumberLine.d.ts +10 -0
- package/dist/typescript/module/features/fluency/visual-scaffolding/components/DynamicNumberLine.d.ts.map +1 -0
- package/dist/typescript/module/features/fluency/visual-scaffolding/components/FactVisual.d.ts +10 -0
- package/dist/typescript/module/features/fluency/visual-scaffolding/components/FactVisual.d.ts.map +1 -0
- package/dist/typescript/module/features/fluency/visual-scaffolding/components/QuotativeBars.d.ts +10 -0
- package/dist/typescript/module/features/fluency/visual-scaffolding/components/QuotativeBars.d.ts.map +1 -0
- package/dist/typescript/module/features/fluency/visual-scaffolding/components/RelationalBlock.d.ts +10 -0
- package/dist/typescript/module/features/fluency/visual-scaffolding/components/RelationalBlock.d.ts.map +1 -0
- package/dist/typescript/module/features/fluency/visual-scaffolding/components/visualColors.d.ts +16 -0
- package/dist/typescript/module/features/fluency/visual-scaffolding/components/visualColors.d.ts.map +1 -0
- package/dist/typescript/module/features/fluency/visual-scaffolding/index.d.ts +6 -0
- package/dist/typescript/module/features/fluency/visual-scaffolding/index.d.ts.map +1 -0
- package/dist/typescript/module/features/fluency/visual-scaffolding/renderFact.d.ts +23 -0
- package/dist/typescript/module/features/fluency/visual-scaffolding/renderFact.d.ts.map +1 -0
- package/dist/typescript/module/features/fluency/visual-scaffolding/types.d.ts +103 -0
- package/dist/typescript/module/features/fluency/visual-scaffolding/types.d.ts.map +1 -0
- package/dist/typescript/module/features/fluency-teacher/assets/SortDefaultIcon.d.ts +4 -0
- package/dist/typescript/module/features/fluency-teacher/assets/SortDefaultIcon.d.ts.map +1 -0
- package/dist/typescript/module/features/fluency-teacher/components/drawer/DrawerHeader.d.ts.map +1 -1
- package/dist/typescript/module/features/fluency-teacher/components/drawer/DrawerMasteryLegend.d.ts +3 -0
- package/dist/typescript/module/features/fluency-teacher/components/drawer/DrawerMasteryLegend.d.ts.map +1 -0
- package/dist/typescript/module/features/fluency-teacher/components/drawer/DrawerMatrixes.d.ts.map +1 -1
- package/dist/typescript/module/features/fluency-teacher/components/drawer/DrawerOperatorBox.d.ts +4 -1
- package/dist/typescript/module/features/fluency-teacher/components/drawer/DrawerOperatorBox.d.ts.map +1 -1
- package/dist/typescript/module/features/fluency-teacher/components/drawer/DrawerOperatorStatCard.d.ts +4 -6
- package/dist/typescript/module/features/fluency-teacher/components/drawer/DrawerOperatorStatCard.d.ts.map +1 -1
- package/dist/typescript/module/features/fluency-teacher/components/drawer/DrawerStats.d.ts.map +1 -1
- package/dist/typescript/module/features/fluency-teacher/components/drawer/FluencyTeacherDrawer.d.ts.map +1 -1
- package/dist/typescript/module/features/fluency-teacher/components/matrix/DrawerMatrix.d.ts +2 -3
- package/dist/typescript/module/features/fluency-teacher/components/matrix/DrawerMatrix.d.ts.map +1 -1
- package/dist/typescript/module/features/fluency-teacher/components/matrix/MatrixCell.d.ts +5 -6
- package/dist/typescript/module/features/fluency-teacher/components/matrix/MatrixCell.d.ts.map +1 -1
- package/dist/typescript/module/features/fluency-teacher/components/matrix/MatrixHeaderRow.d.ts +1 -2
- package/dist/typescript/module/features/fluency-teacher/components/matrix/MatrixHeaderRow.d.ts.map +1 -1
- package/dist/typescript/module/features/fluency-teacher/components/matrix/MatrixRow.d.ts +3 -5
- package/dist/typescript/module/features/fluency-teacher/components/matrix/MatrixRow.d.ts.map +1 -1
- package/dist/typescript/module/features/fluency-teacher/components/table/AllPupilsTableRow.d.ts.map +1 -1
- package/dist/typescript/module/features/fluency-teacher/components/table/AverageSortButton.d.ts +1 -2
- package/dist/typescript/module/features/fluency-teacher/components/table/AverageSortButton.d.ts.map +1 -1
- package/dist/typescript/module/features/fluency-teacher/components/table/FluencyTeacherStudentsTable.d.ts.map +1 -1
- package/dist/typescript/module/features/fluency-teacher/components/table/OperatorBadge.d.ts +4 -5
- package/dist/typescript/module/features/fluency-teacher/components/table/OperatorBadge.d.ts.map +1 -1
- package/dist/typescript/module/features/fluency-teacher/components/table/TableColumnSortButton.d.ts +6 -7
- package/dist/typescript/module/features/fluency-teacher/components/table/TableColumnSortButton.d.ts.map +1 -1
- package/dist/typescript/module/features/fluency-teacher/components/table/TableRow.d.ts +3 -4
- package/dist/typescript/module/features/fluency-teacher/components/table/TableRow.d.ts.map +1 -1
- package/dist/typescript/module/features/fluency-teacher/components/table/TableRowAverageProgress.d.ts +7 -0
- package/dist/typescript/module/features/fluency-teacher/components/table/TableRowAverageProgress.d.ts.map +1 -0
- package/dist/typescript/module/features/fluency-teacher/context/TeacherFluencyContext.d.ts +0 -1
- package/dist/typescript/module/features/fluency-teacher/context/TeacherFluencyContext.d.ts.map +1 -1
- package/dist/typescript/module/features/fluency-teacher/fluencyTeacher.constants.d.ts +3 -16
- package/dist/typescript/module/features/fluency-teacher/fluencyTeacher.constants.d.ts.map +1 -1
- package/dist/typescript/module/features/fluency-teacher/fluencyTeacher.helpers.d.ts +4 -11
- package/dist/typescript/module/features/fluency-teacher/fluencyTeacher.helpers.d.ts.map +1 -1
- package/dist/typescript/module/features/fluency-teacher/fluencyTeacher.types.d.ts +6 -35
- package/dist/typescript/module/features/fluency-teacher/fluencyTeacher.types.d.ts.map +1 -1
- package/dist/typescript/module/features/fluency-teacher/hooks/useDrawerGrid.d.ts +12 -1
- package/dist/typescript/module/features/fluency-teacher/hooks/useDrawerGrid.d.ts.map +1 -1
- package/dist/typescript/module/features/fluency-teacher/hooks/useDrawerMatrix.d.ts +3 -3
- package/dist/typescript/module/features/fluency-teacher/hooks/useDrawerMatrix.d.ts.map +1 -1
- package/dist/typescript/module/features/fluency-teacher/model/TeacherFluencyFiltersModel.d.ts +0 -1
- package/dist/typescript/module/features/fluency-teacher/model/TeacherFluencyFiltersModel.d.ts.map +1 -1
- package/dist/typescript/module/features/fluency-teacher/model/TeacherFluencyModel.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/features/fluency/components/FluencySolving.tsx +2 -2
- package/src/features/fluency/components/fluency-solving/components/DebugBoxIndicator.tsx +40 -0
- package/src/features/fluency/components/fluency-solving/components/EquationContent.tsx +12 -8
- package/src/features/fluency/components/fluency-solving/components/FluencyCardDeck.tsx +6 -1
- package/src/features/fluency/components/fluency-solving/components/FluencyEquationCard.tsx +63 -11
- package/src/features/fluency/components/fluency-solving/components/FluencySolvingHeader.tsx +9 -0
- package/src/features/fluency/components/fluency-solving/components/FluencySolvingProgress.tsx +0 -2
- package/src/features/fluency/index.ts +1 -0
- package/src/features/fluency/visual-scaffolding/__tests__/__snapshots__/renderFact.test.ts.snap +64 -0
- package/src/features/fluency/visual-scaffolding/__tests__/renderFact.test.ts +192 -0
- package/src/features/fluency/visual-scaffolding/adapter.ts +33 -0
- package/src/features/fluency/visual-scaffolding/components/DiscreteCounterGrid.tsx +222 -0
- package/src/features/fluency/visual-scaffolding/components/Dot.tsx +36 -0
- package/src/features/fluency/visual-scaffolding/components/DynamicNumberLine.tsx +98 -0
- package/src/features/fluency/visual-scaffolding/components/FactVisual.tsx +61 -0
- package/src/features/fluency/visual-scaffolding/components/QuotativeBars.tsx +92 -0
- package/src/features/fluency/visual-scaffolding/components/RelationalBlock.tsx +225 -0
- package/src/features/fluency/visual-scaffolding/components/visualColors.ts +45 -0
- package/src/features/fluency/visual-scaffolding/index.ts +5 -0
- package/src/features/fluency/visual-scaffolding/renderFact.ts +219 -0
- package/src/features/fluency/visual-scaffolding/types.ts +108 -0
- package/src/features/fluency-teacher/assets/SortDefaultIcon.tsx +10 -0
- package/src/features/fluency-teacher/components/FluencyTeacher.tsx +3 -3
- package/src/features/fluency-teacher/components/drawer/DrawerHeader.tsx +35 -37
- package/src/features/fluency-teacher/components/drawer/DrawerMasteryLegend.tsx +63 -0
- package/src/features/fluency-teacher/components/drawer/DrawerMatrixes.tsx +32 -13
- package/src/features/fluency-teacher/components/drawer/DrawerOperatorBox.tsx +40 -20
- package/src/features/fluency-teacher/components/drawer/DrawerOperatorStatCard.tsx +35 -35
- package/src/features/fluency-teacher/components/drawer/DrawerStats.tsx +28 -16
- package/src/features/fluency-teacher/components/drawer/FluencyTeacherDrawer.tsx +5 -4
- package/src/features/fluency-teacher/components/matrix/DrawerMatrix.tsx +2 -3
- package/src/features/fluency-teacher/components/matrix/MatrixCell.tsx +16 -7
- package/src/features/fluency-teacher/components/matrix/MatrixHeaderRow.tsx +1 -1
- package/src/features/fluency-teacher/components/matrix/MatrixRow.tsx +4 -4
- package/src/features/fluency-teacher/components/table/AllPupilsTableRow.tsx +40 -13
- package/src/features/fluency-teacher/components/table/AverageSortButton.tsx +62 -8
- package/src/features/fluency-teacher/components/table/FluencyTeacherStudentsTable.tsx +35 -49
- package/src/features/fluency-teacher/components/table/OperatorBadge.tsx +11 -18
- package/src/features/fluency-teacher/components/table/TableColumnSortButton.tsx +49 -28
- package/src/features/fluency-teacher/components/table/TableRow.tsx +64 -65
- package/src/features/fluency-teacher/components/table/TableRowAverageProgress.tsx +65 -0
- package/src/features/fluency-teacher/context/TeacherFluencyContext.ts +0 -1
- package/src/features/fluency-teacher/fluencyTeacher.constants.ts +40 -138
- package/src/features/fluency-teacher/fluencyTeacher.helpers.ts +10 -82
- package/src/features/fluency-teacher/fluencyTeacher.types.ts +6 -39
- package/src/features/fluency-teacher/hooks/useDrawerGrid.ts +7 -4
- package/src/features/fluency-teacher/hooks/useDrawerMatrix.ts +3 -4
- package/src/features/fluency-teacher/model/TeacherFluencyFiltersModel.ts +5 -8
- package/src/features/fluency-teacher/model/TeacherFluencyModel.ts +0 -8
- package/dist/commonjs/features/fluency-teacher/assets/DivisionIcon.js.map +0 -1
- package/dist/commonjs/features/fluency-teacher/components/matrix/MatrixLegend.js +0 -83
- package/dist/commonjs/features/fluency-teacher/components/matrix/MatrixLegend.js.map +0 -1
- package/dist/commonjs/features/fluency-teacher/components/table/AverageCell.js +0 -55
- package/dist/commonjs/features/fluency-teacher/components/table/AverageCell.js.map +0 -1
- package/dist/commonjs/features/fluency-teacher/components/table/SortOrderCarets.js +0 -40
- package/dist/commonjs/features/fluency-teacher/components/table/SortOrderCarets.js.map +0 -1
- package/dist/commonjs/features/fluency-teacher/components/table/tableCell.styles.js +0 -45
- package/dist/commonjs/features/fluency-teacher/components/table/tableCell.styles.js.map +0 -1
- package/dist/module/features/fluency-teacher/assets/DivisionIcon.js +0 -26
- package/dist/module/features/fluency-teacher/assets/DivisionIcon.js.map +0 -1
- package/dist/module/features/fluency-teacher/components/matrix/MatrixLegend.js +0 -77
- package/dist/module/features/fluency-teacher/components/matrix/MatrixLegend.js.map +0 -1
- package/dist/module/features/fluency-teacher/components/table/AverageCell.js +0 -49
- package/dist/module/features/fluency-teacher/components/table/AverageCell.js.map +0 -1
- package/dist/module/features/fluency-teacher/components/table/SortOrderCarets.js +0 -34
- package/dist/module/features/fluency-teacher/components/table/SortOrderCarets.js.map +0 -1
- package/dist/module/features/fluency-teacher/components/table/tableCell.styles.js +0 -42
- package/dist/module/features/fluency-teacher/components/table/tableCell.styles.js.map +0 -1
- package/dist/typescript/commonjs/features/fluency-teacher/assets/DivisionIcon.d.ts +0 -4
- package/dist/typescript/commonjs/features/fluency-teacher/assets/DivisionIcon.d.ts.map +0 -1
- package/dist/typescript/commonjs/features/fluency-teacher/components/matrix/MatrixLegend.d.ts +0 -10
- package/dist/typescript/commonjs/features/fluency-teacher/components/matrix/MatrixLegend.d.ts.map +0 -1
- package/dist/typescript/commonjs/features/fluency-teacher/components/table/AverageCell.d.ts +0 -9
- package/dist/typescript/commonjs/features/fluency-teacher/components/table/AverageCell.d.ts.map +0 -1
- package/dist/typescript/commonjs/features/fluency-teacher/components/table/SortOrderCarets.d.ts +0 -9
- package/dist/typescript/commonjs/features/fluency-teacher/components/table/SortOrderCarets.d.ts.map +0 -1
- package/dist/typescript/commonjs/features/fluency-teacher/components/table/tableCell.styles.d.ts +0 -35
- package/dist/typescript/commonjs/features/fluency-teacher/components/table/tableCell.styles.d.ts.map +0 -1
- package/dist/typescript/module/features/fluency-teacher/assets/DivisionIcon.d.ts +0 -4
- package/dist/typescript/module/features/fluency-teacher/assets/DivisionIcon.d.ts.map +0 -1
- package/dist/typescript/module/features/fluency-teacher/components/matrix/MatrixLegend.d.ts +0 -10
- package/dist/typescript/module/features/fluency-teacher/components/matrix/MatrixLegend.d.ts.map +0 -1
- package/dist/typescript/module/features/fluency-teacher/components/table/AverageCell.d.ts +0 -9
- package/dist/typescript/module/features/fluency-teacher/components/table/AverageCell.d.ts.map +0 -1
- package/dist/typescript/module/features/fluency-teacher/components/table/SortOrderCarets.d.ts +0 -9
- package/dist/typescript/module/features/fluency-teacher/components/table/SortOrderCarets.d.ts.map +0 -1
- package/dist/typescript/module/features/fluency-teacher/components/table/tableCell.styles.d.ts +0 -35
- package/dist/typescript/module/features/fluency-teacher/components/table/tableCell.styles.d.ts.map +0 -1
- package/src/features/fluency-teacher/assets/DivisionIcon.tsx +0 -20
- package/src/features/fluency-teacher/components/matrix/MatrixLegend.tsx +0 -81
- package/src/features/fluency-teacher/components/table/AverageCell.tsx +0 -45
- package/src/features/fluency-teacher/components/table/SortOrderCarets.tsx +0 -37
- package/src/features/fluency-teacher/components/table/tableCell.styles.ts +0 -39
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["FluencyMode","MODE_TO_OPERATION","ADDITION","SUBTRACTION","MULTIPLICATION","DIVISION","clampBox","box","clamped","Math","max","min","round","toFactPresentation","fact","left","right","numbers","operation","mode"],"sourceRoot":"../../../../../src","sources":["features/fluency/visual-scaffolding/adapter.ts"],"mappings":";;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAASA,WAAW,QAAQ,gCAA6B;AAIzD,MAAMC,iBAAiD,GAAG;EACxD,CAACD,WAAW,CAACE,QAAQ,GAAG,UAAU;EAClC,CAACF,WAAW,CAACG,WAAW,GAAG,aAAa;EACxC,CAACH,WAAW,CAACI,cAAc,GAAG,gBAAgB;EAC9C,CAACJ,WAAW,CAACK,QAAQ,GAAG;AAC1B,CAAC;AAED,MAAMC,QAAQ,GAAIC,GAAW,IAA8B;EACzD,MAAMC,OAAO,GAAGC,IAAI,CAACC,GAAG,CAAC,CAAC,EAAED,IAAI,CAACE,GAAG,CAAC,CAAC,EAAEF,IAAI,CAACG,KAAK,CAACL,GAAG,CAAC,CAAC,CAAC;EACzD,OAAOC,OAAO;AAChB,CAAC;AAED,OAAO,SAASK,kBAAkBA,CAACC,IAAiB,EAAoB;EACtE,MAAM,CAACC,IAAI,EAAEC,KAAK,CAAC,GAAGF,IAAI,CAACG,OAAO;EAClC,OAAO;IACLC,SAAS,EAAEjB,iBAAiB,CAACa,IAAI,CAACK,IAAI,CAAC;IACvCJ,IAAI;IACJC,KAAK;IACLT,GAAG,EAAED,QAAQ,CAACQ,IAAI,CAACP,GAAG;EACxB,CAAC;AACH","ignoreList":[]}
|
|
@@ -0,0 +1,225 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import React, { useState } from 'react';
|
|
4
|
+
import { View, StyleSheet } from 'react-native';
|
|
5
|
+
import { COLORS, SPACING, BORDER_RADIUS } from '@magmamath/react-native-ui';
|
|
6
|
+
import { Dot } from "./Dot.js";
|
|
7
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
8
|
+
const CELL_SIZE = 24;
|
|
9
|
+
const CELL_GAP = 4;
|
|
10
|
+
const FRAME_COLUMNS = 5;
|
|
11
|
+
const TOKEN_SIZE = 14;
|
|
12
|
+
const GROUP_COLUMNS = 5;
|
|
13
|
+
const GROUP_PADDING = SPACING[200];
|
|
14
|
+
const GROUP_BORDER = 2;
|
|
15
|
+
// Wide enough to fit GROUP_COLUMNS dots per row (incl. padding + border, border-box),
|
|
16
|
+
// so a group of five fills one row like the ten-frame instead of wrapping at four.
|
|
17
|
+
const GROUP_MAX_WIDTH = GROUP_COLUMNS * (TOKEN_SIZE + CELL_GAP) + 2 * GROUP_PADDING + 2 * GROUP_BORDER;
|
|
18
|
+
// Max groups per row; groups are split into balanced rows (10 → 5+5, 20 → 5×4).
|
|
19
|
+
const GROUPS_PER_ROW_MAX = 5;
|
|
20
|
+
|
|
21
|
+
// Budget the grid is allowed to occupy in the visual zone; bigger facts (e.g.
|
|
22
|
+
// 9 × 9 → many groups) are scaled down uniformly to fit rather than overflowing.
|
|
23
|
+
const FIT_W = 500;
|
|
24
|
+
const FIT_H = 92;
|
|
25
|
+
// L1 — renders absolute, discrete quantities to build a conceptual baseline.
|
|
26
|
+
export const DiscreteCounterGrid = ({
|
|
27
|
+
spec,
|
|
28
|
+
colors
|
|
29
|
+
}) => {
|
|
30
|
+
const {
|
|
31
|
+
layout
|
|
32
|
+
} = spec;
|
|
33
|
+
const [size, setSize] = useState(null);
|
|
34
|
+
const measure = event => {
|
|
35
|
+
const {
|
|
36
|
+
width,
|
|
37
|
+
height
|
|
38
|
+
} = event.nativeEvent.layout;
|
|
39
|
+
setSize(prev => prev?.width === width && prev?.height === height ? prev : {
|
|
40
|
+
width,
|
|
41
|
+
height
|
|
42
|
+
});
|
|
43
|
+
};
|
|
44
|
+
|
|
45
|
+
// Shrink only when the natural size exceeds the budget; otherwise render 1:1.
|
|
46
|
+
const scale = size && size.width > 0 && size.height > 0 ? Math.min(1, FIT_W / size.width, FIT_H / size.height) : 1;
|
|
47
|
+
const content = (() => {
|
|
48
|
+
switch (layout.type) {
|
|
49
|
+
case 'tenframes':
|
|
50
|
+
{
|
|
51
|
+
// Pour `a` tone-A tokens then `b` tone-B tokens into the frame, filling it
|
|
52
|
+
// up; a second frame appears only once the sum spills past ten.
|
|
53
|
+
const total = layout.a + layout.b;
|
|
54
|
+
const frameCount = total > layout.capacity ? 2 : 1;
|
|
55
|
+
const cells = Array.from({
|
|
56
|
+
length: layout.capacity * frameCount
|
|
57
|
+
}, (_, i) => {
|
|
58
|
+
if (i < layout.a) return 'a';
|
|
59
|
+
if (i < total) return 'b';
|
|
60
|
+
return null;
|
|
61
|
+
});
|
|
62
|
+
return /*#__PURE__*/_jsx(View, {
|
|
63
|
+
style: styles.frameRow,
|
|
64
|
+
children: Array.from({
|
|
65
|
+
length: frameCount
|
|
66
|
+
}, (_, f) => /*#__PURE__*/_jsx(TenFrame, {
|
|
67
|
+
tones: cells.slice(f * layout.capacity, (f + 1) * layout.capacity),
|
|
68
|
+
colors: colors
|
|
69
|
+
}, f))
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
case 'tenframes_takeaway':
|
|
73
|
+
{
|
|
74
|
+
// Fill `total` tokens (striking the last `removed`); a second frame shows
|
|
75
|
+
// only when the minuend spills past ten, matching the addition frames.
|
|
76
|
+
const frameCount = layout.total > layout.capacity ? 2 : 1;
|
|
77
|
+
const cells = Array.from({
|
|
78
|
+
length: layout.capacity * frameCount
|
|
79
|
+
}, (_, i) => {
|
|
80
|
+
if (i >= layout.total) return null;
|
|
81
|
+
return i >= layout.total - layout.removed ? 'gone' : 'a';
|
|
82
|
+
});
|
|
83
|
+
return /*#__PURE__*/_jsx(View, {
|
|
84
|
+
style: styles.frameRow,
|
|
85
|
+
children: Array.from({
|
|
86
|
+
length: frameCount
|
|
87
|
+
}, (_, f) => /*#__PURE__*/_jsx(TenFrame, {
|
|
88
|
+
tones: cells.slice(f * layout.capacity, (f + 1) * layout.capacity),
|
|
89
|
+
colors: colors
|
|
90
|
+
}, f))
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
case 'array':
|
|
94
|
+
return /*#__PURE__*/_jsx(View, {
|
|
95
|
+
style: styles.array,
|
|
96
|
+
children: Array.from({
|
|
97
|
+
length: layout.rows
|
|
98
|
+
}, (_, r) => /*#__PURE__*/_jsx(View, {
|
|
99
|
+
style: styles.arrayRow,
|
|
100
|
+
children: Array.from({
|
|
101
|
+
length: layout.cols
|
|
102
|
+
}, (_, c) => /*#__PURE__*/_jsx(Dot, {
|
|
103
|
+
color: colors.accent,
|
|
104
|
+
size: TOKEN_SIZE
|
|
105
|
+
}, c))
|
|
106
|
+
}, r))
|
|
107
|
+
});
|
|
108
|
+
case 'groups':
|
|
109
|
+
{
|
|
110
|
+
const rowCount = Math.max(1, Math.ceil(layout.groupCount / GROUPS_PER_ROW_MAX));
|
|
111
|
+
const perRow = Math.ceil(layout.groupCount / rowCount);
|
|
112
|
+
return /*#__PURE__*/_jsx(View, {
|
|
113
|
+
style: styles.groupGrid,
|
|
114
|
+
children: Array.from({
|
|
115
|
+
length: rowCount
|
|
116
|
+
}, (_, r) => /*#__PURE__*/_jsx(View, {
|
|
117
|
+
style: styles.groupRow,
|
|
118
|
+
children: Array.from({
|
|
119
|
+
length: Math.min(perRow, layout.groupCount - r * perRow)
|
|
120
|
+
}, (_, g) => /*#__PURE__*/_jsx(View, {
|
|
121
|
+
style: [styles.group, {
|
|
122
|
+
borderColor: colors.mid
|
|
123
|
+
}],
|
|
124
|
+
children: Array.from({
|
|
125
|
+
length: layout.perGroup
|
|
126
|
+
}, (_, d) => /*#__PURE__*/_jsx(Dot, {
|
|
127
|
+
color: colors.accent,
|
|
128
|
+
size: TOKEN_SIZE
|
|
129
|
+
}, d))
|
|
130
|
+
}, g))
|
|
131
|
+
}, r))
|
|
132
|
+
});
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
})();
|
|
136
|
+
return /*#__PURE__*/_jsx(View, {
|
|
137
|
+
onLayout: measure,
|
|
138
|
+
style: [styles.fit, {
|
|
139
|
+
transform: [{
|
|
140
|
+
scale
|
|
141
|
+
}]
|
|
142
|
+
}],
|
|
143
|
+
children: content
|
|
144
|
+
});
|
|
145
|
+
};
|
|
146
|
+
const TONE_COLOR = (tone, colors) => tone === 'a' ? colors.accent : colors.mid;
|
|
147
|
+
const TenFrame = ({
|
|
148
|
+
tones,
|
|
149
|
+
colors
|
|
150
|
+
}) => {
|
|
151
|
+
return /*#__PURE__*/_jsx(View, {
|
|
152
|
+
style: styles.frame,
|
|
153
|
+
children: tones.map((tone, i) => /*#__PURE__*/_jsxs(View, {
|
|
154
|
+
style: styles.cell,
|
|
155
|
+
children: [tone === 'gone' && /*#__PURE__*/_jsx(Dot, {
|
|
156
|
+
color: colors.accent,
|
|
157
|
+
strike: true,
|
|
158
|
+
size: TOKEN_SIZE
|
|
159
|
+
}), (tone === 'a' || tone === 'b') && /*#__PURE__*/_jsx(Dot, {
|
|
160
|
+
color: TONE_COLOR(tone, colors),
|
|
161
|
+
size: TOKEN_SIZE
|
|
162
|
+
})]
|
|
163
|
+
}, i))
|
|
164
|
+
});
|
|
165
|
+
};
|
|
166
|
+
const styles = StyleSheet.create({
|
|
167
|
+
// Measures its natural size; transform-scales down to the budget if it overflows.
|
|
168
|
+
fit: {
|
|
169
|
+
alignItems: 'center'
|
|
170
|
+
},
|
|
171
|
+
groupGrid: {
|
|
172
|
+
gap: SPACING[200],
|
|
173
|
+
alignItems: 'center'
|
|
174
|
+
},
|
|
175
|
+
frameRow: {
|
|
176
|
+
flexDirection: 'row',
|
|
177
|
+
gap: SPACING[300],
|
|
178
|
+
alignItems: 'center',
|
|
179
|
+
flexWrap: 'wrap',
|
|
180
|
+
justifyContent: 'center'
|
|
181
|
+
},
|
|
182
|
+
frame: {
|
|
183
|
+
width: FRAME_COLUMNS * CELL_SIZE + (FRAME_COLUMNS - 1) * CELL_GAP,
|
|
184
|
+
flexDirection: 'row',
|
|
185
|
+
flexWrap: 'wrap',
|
|
186
|
+
gap: CELL_GAP
|
|
187
|
+
},
|
|
188
|
+
cell: {
|
|
189
|
+
width: CELL_SIZE,
|
|
190
|
+
height: CELL_SIZE,
|
|
191
|
+
borderRadius: 4,
|
|
192
|
+
borderWidth: 1.5,
|
|
193
|
+
borderColor: COLORS.NEUTRAL_5,
|
|
194
|
+
alignItems: 'center',
|
|
195
|
+
justifyContent: 'center'
|
|
196
|
+
},
|
|
197
|
+
array: {
|
|
198
|
+
gap: CELL_GAP + 2,
|
|
199
|
+
alignItems: 'center'
|
|
200
|
+
},
|
|
201
|
+
arrayRow: {
|
|
202
|
+
flexDirection: 'row',
|
|
203
|
+
gap: CELL_GAP + 2
|
|
204
|
+
},
|
|
205
|
+
groupRow: {
|
|
206
|
+
flexDirection: 'row',
|
|
207
|
+
flexWrap: 'wrap',
|
|
208
|
+
gap: SPACING[200],
|
|
209
|
+
justifyContent: 'center',
|
|
210
|
+
alignItems: 'center'
|
|
211
|
+
},
|
|
212
|
+
group: {
|
|
213
|
+
flexDirection: 'row',
|
|
214
|
+
flexWrap: 'wrap',
|
|
215
|
+
// Shrink to fit the dots it holds (a single dot gets a small box); cap at
|
|
216
|
+
// five columns so larger groups wrap instead of stretching.
|
|
217
|
+
maxWidth: GROUP_MAX_WIDTH,
|
|
218
|
+
gap: CELL_GAP,
|
|
219
|
+
padding: GROUP_PADDING,
|
|
220
|
+
borderWidth: GROUP_BORDER,
|
|
221
|
+
borderRadius: BORDER_RADIUS[200],
|
|
222
|
+
backgroundColor: COLORS.NEUTRAL_2
|
|
223
|
+
}
|
|
224
|
+
});
|
|
225
|
+
//# sourceMappingURL=DiscreteCounterGrid.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["React","useState","View","StyleSheet","COLORS","SPACING","BORDER_RADIUS","Dot","jsx","_jsx","jsxs","_jsxs","CELL_SIZE","CELL_GAP","FRAME_COLUMNS","TOKEN_SIZE","GROUP_COLUMNS","GROUP_PADDING","GROUP_BORDER","GROUP_MAX_WIDTH","GROUPS_PER_ROW_MAX","FIT_W","FIT_H","DiscreteCounterGrid","spec","colors","layout","size","setSize","measure","event","width","height","nativeEvent","prev","scale","Math","min","content","type","total","a","b","frameCount","capacity","cells","Array","from","length","_","i","style","styles","frameRow","children","f","TenFrame","tones","slice","removed","array","rows","r","arrayRow","cols","c","color","accent","rowCount","max","ceil","groupCount","perRow","groupGrid","groupRow","g","group","borderColor","mid","perGroup","d","onLayout","fit","transform","TONE_COLOR","tone","frame","map","cell","strike","create","alignItems","gap","flexDirection","flexWrap","justifyContent","borderRadius","borderWidth","NEUTRAL_5","maxWidth","padding","backgroundColor","NEUTRAL_2"],"sourceRoot":"../../../../../../src","sources":["features/fluency/visual-scaffolding/components/DiscreteCounterGrid.tsx"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import React from 'react';
|
|
4
|
+
import { View, StyleSheet } from 'react-native';
|
|
5
|
+
import { COLORS } from '@magmamath/react-native-ui';
|
|
6
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
7
|
+
export const DOT_SIZE = 12;
|
|
8
|
+
// Shared quantity primitive: a filled circle.
|
|
9
|
+
export const Dot = ({
|
|
10
|
+
color,
|
|
11
|
+
strike = false,
|
|
12
|
+
size = DOT_SIZE
|
|
13
|
+
}) => {
|
|
14
|
+
const circle = {
|
|
15
|
+
width: size,
|
|
16
|
+
height: size,
|
|
17
|
+
borderRadius: size / 2
|
|
18
|
+
};
|
|
19
|
+
return /*#__PURE__*/_jsx(View, {
|
|
20
|
+
style: [circle, {
|
|
21
|
+
backgroundColor: color
|
|
22
|
+
}],
|
|
23
|
+
children: strike && /*#__PURE__*/_jsx(View, {
|
|
24
|
+
style: styles.strike
|
|
25
|
+
})
|
|
26
|
+
});
|
|
27
|
+
};
|
|
28
|
+
const styles = StyleSheet.create({
|
|
29
|
+
strike: {
|
|
30
|
+
position: 'absolute',
|
|
31
|
+
top: '50%',
|
|
32
|
+
left: '-15%',
|
|
33
|
+
width: '130%',
|
|
34
|
+
height: 2,
|
|
35
|
+
marginTop: -1,
|
|
36
|
+
// pull up half the height so the bar is centered, not top-aligned
|
|
37
|
+
borderRadius: 1,
|
|
38
|
+
// round the stroke ends
|
|
39
|
+
backgroundColor: COLORS.NEUTRAL_10,
|
|
40
|
+
transform: [{
|
|
41
|
+
rotate: '-45deg'
|
|
42
|
+
}]
|
|
43
|
+
}
|
|
44
|
+
});
|
|
45
|
+
//# sourceMappingURL=Dot.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["React","View","StyleSheet","COLORS","jsx","_jsx","DOT_SIZE","Dot","color","strike","size","circle","width","height","borderRadius","style","backgroundColor","children","styles","create","position","top","left","marginTop","NEUTRAL_10","transform","rotate"],"sourceRoot":"../../../../../../src","sources":["features/fluency/visual-scaffolding/components/Dot.tsx"],"mappings":";;AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,IAAI,EAAEC,UAAU,QAAQ,cAAc;AAC/C,SAASC,MAAM,QAAQ,4BAA4B;AAAA,SAAAC,GAAA,IAAAC,IAAA;AAEnD,OAAO,MAAMC,QAAQ,GAAG,EAAE;AAS1B;AACA,OAAO,MAAMC,GAAG,GAAGA,CAAC;EAAEC,KAAK;EAAEC,MAAM,GAAG,KAAK;EAAEC,IAAI,GAAGJ;AAAmB,CAAC,KAAK;EAC3E,MAAMK,MAAM,GAAG;IAAEC,KAAK,EAAEF,IAAI;IAAEG,MAAM,EAAEH,IAAI;IAAEI,YAAY,EAAEJ,IAAI,GAAG;EAAE,CAAC;EACpE,oBACEL,IAAA,CAACJ,IAAI;IAACc,KAAK,EAAE,CAACJ,MAAM,EAAE;MAAEK,eAAe,EAAER;IAAM,CAAC,CAAE;IAAAS,QAAA,EAC/CR,MAAM,iBAAIJ,IAAA,CAACJ,IAAI;MAACc,KAAK,EAAEG,MAAM,CAACT;IAAO,CAAE;EAAC,CACrC,CAAC;AAEX,CAAC;AAED,MAAMS,MAAM,GAAGhB,UAAU,CAACiB,MAAM,CAAC;EAC/BV,MAAM,EAAE;IACNW,QAAQ,EAAE,UAAU;IACpBC,GAAG,EAAE,KAAK;IACVC,IAAI,EAAE,MAAM;IACZV,KAAK,EAAE,MAAM;IACbC,MAAM,EAAE,CAAC;IACTU,SAAS,EAAE,CAAC,CAAC;IAAE;IACfT,YAAY,EAAE,CAAC;IAAE;IACjBE,eAAe,EAAEb,MAAM,CAACqB,UAAU;IAClCC,SAAS,EAAE,CAAC;MAAEC,MAAM,EAAE;IAAS,CAAC;EAClC;AACF,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import React from 'react';
|
|
4
|
+
import { View, StyleSheet } from 'react-native';
|
|
5
|
+
import Svg, { Line, Path, Circle, Text as SvgText } from 'react-native-svg';
|
|
6
|
+
import { COLORS, FONT_FAMILY } from '@magmamath/react-native-ui';
|
|
7
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
8
|
+
const VB_W = 560;
|
|
9
|
+
const VB_H = 110;
|
|
10
|
+
const PAD_X = 22;
|
|
11
|
+
const BASE_Y = 74;
|
|
12
|
+
const ARC_H = 56;
|
|
13
|
+
// L3 — addition jumps forward, subtraction backward; both bridge through every
|
|
14
|
+
// ten (jumps land on each multiple of 10 crossed). Multiplication skip-counts.
|
|
15
|
+
export const DynamicNumberLine = ({
|
|
16
|
+
spec,
|
|
17
|
+
colors
|
|
18
|
+
}) => {
|
|
19
|
+
const span = spec.hi - spec.lo;
|
|
20
|
+
const denom = span === 0 ? 1 : span;
|
|
21
|
+
const x = v => PAD_X + (v - spec.lo) / denom * (VB_W - 2 * PAD_X);
|
|
22
|
+
return /*#__PURE__*/_jsx(View, {
|
|
23
|
+
style: styles.wrapper,
|
|
24
|
+
children: /*#__PURE__*/_jsxs(Svg, {
|
|
25
|
+
width: "100%",
|
|
26
|
+
height: "100%",
|
|
27
|
+
viewBox: `0 0 ${VB_W} ${VB_H}`,
|
|
28
|
+
preserveAspectRatio: "xMidYMid meet",
|
|
29
|
+
children: [/*#__PURE__*/_jsx(Line, {
|
|
30
|
+
x1: PAD_X - 14,
|
|
31
|
+
y1: BASE_Y,
|
|
32
|
+
x2: VB_W - PAD_X + 14,
|
|
33
|
+
y2: BASE_Y,
|
|
34
|
+
stroke: COLORS.NEUTRAL_5,
|
|
35
|
+
strokeWidth: 3,
|
|
36
|
+
strokeLinecap: "round"
|
|
37
|
+
}), spec.ticks.map(value => /*#__PURE__*/_jsxs(React.Fragment, {
|
|
38
|
+
children: [/*#__PURE__*/_jsx(Line, {
|
|
39
|
+
x1: x(value),
|
|
40
|
+
y1: BASE_Y - 6,
|
|
41
|
+
x2: x(value),
|
|
42
|
+
y2: BASE_Y + 6,
|
|
43
|
+
stroke: COLORS.NEUTRAL_6,
|
|
44
|
+
strokeWidth: 3
|
|
45
|
+
}), /*#__PURE__*/_jsx(SvgText, {
|
|
46
|
+
x: x(value),
|
|
47
|
+
y: BASE_Y + 25,
|
|
48
|
+
fontSize: 20,
|
|
49
|
+
fontWeight: "700",
|
|
50
|
+
fontFamily: FONT_FAMILY.buenosAires,
|
|
51
|
+
fill: COLORS.NEUTRAL_8,
|
|
52
|
+
textAnchor: "middle",
|
|
53
|
+
children: value === spec.hiddenTick ? '?' : value
|
|
54
|
+
})]
|
|
55
|
+
}, `t${value}`)), spec.jumps.map((jump, i) => {
|
|
56
|
+
const midX = (x(jump.from) + x(jump.to)) / 2;
|
|
57
|
+
return /*#__PURE__*/_jsxs(React.Fragment, {
|
|
58
|
+
children: [/*#__PURE__*/_jsx(Path, {
|
|
59
|
+
d: `M ${x(jump.from)} ${BASE_Y - 4} Q ${midX} ${BASE_Y - ARC_H - 12} ${x(jump.to)} ${BASE_Y - 4}`,
|
|
60
|
+
stroke: colors.accent,
|
|
61
|
+
strokeWidth: 4,
|
|
62
|
+
fill: "none"
|
|
63
|
+
}), /*#__PURE__*/_jsx(Circle, {
|
|
64
|
+
cx: x(jump.to),
|
|
65
|
+
cy: BASE_Y,
|
|
66
|
+
r: 6.5,
|
|
67
|
+
fill: colors.accent
|
|
68
|
+
}), /*#__PURE__*/_jsx(SvgText, {
|
|
69
|
+
x: midX,
|
|
70
|
+
y: BASE_Y - ARC_H - 1,
|
|
71
|
+
fontSize: 20,
|
|
72
|
+
fontWeight: "800",
|
|
73
|
+
fontFamily: FONT_FAMILY.buenosAires,
|
|
74
|
+
fill: colors.dark,
|
|
75
|
+
textAnchor: "middle",
|
|
76
|
+
children: jump.label
|
|
77
|
+
})]
|
|
78
|
+
}, `j${i}`);
|
|
79
|
+
}), spec.jumps.length > 0 && /*#__PURE__*/_jsx(Circle, {
|
|
80
|
+
cx: x(spec.jumps[0].from),
|
|
81
|
+
cy: BASE_Y,
|
|
82
|
+
r: 6.5,
|
|
83
|
+
fill: colors.accent
|
|
84
|
+
})]
|
|
85
|
+
})
|
|
86
|
+
});
|
|
87
|
+
};
|
|
88
|
+
const styles = StyleSheet.create({
|
|
89
|
+
wrapper: {
|
|
90
|
+
width: '100%',
|
|
91
|
+
maxWidth: VB_W,
|
|
92
|
+
aspectRatio: VB_W / VB_H,
|
|
93
|
+
alignSelf: 'center'
|
|
94
|
+
}
|
|
95
|
+
});
|
|
96
|
+
//# sourceMappingURL=DynamicNumberLine.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["React","View","StyleSheet","Svg","Line","Path","Circle","Text","SvgText","COLORS","FONT_FAMILY","jsx","_jsx","jsxs","_jsxs","VB_W","VB_H","PAD_X","BASE_Y","ARC_H","DynamicNumberLine","spec","colors","span","hi","lo","denom","x","v","style","styles","wrapper","children","width","height","viewBox","preserveAspectRatio","x1","y1","x2","y2","stroke","NEUTRAL_5","strokeWidth","strokeLinecap","ticks","map","value","Fragment","NEUTRAL_6","y","fontSize","fontWeight","fontFamily","buenosAires","fill","NEUTRAL_8","textAnchor","hiddenTick","jumps","jump","i","midX","from","to","d","accent","cx","cy","r","dark","label","length","create","maxWidth","aspectRatio","alignSelf"],"sourceRoot":"../../../../../../src","sources":["features/fluency/visual-scaffolding/components/DynamicNumberLine.tsx"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import React from 'react';
|
|
4
|
+
import { View, StyleSheet } from 'react-native';
|
|
5
|
+
import { DiscreteCounterGrid } from "./DiscreteCounterGrid.js";
|
|
6
|
+
import { RelationalBlock } from "./RelationalBlock.js";
|
|
7
|
+
import { DynamicNumberLine } from "./DynamicNumberLine.js";
|
|
8
|
+
import { QuotativeBars } from "./QuotativeBars.js";
|
|
9
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
10
|
+
// Text alternative for the decorative-supportive visual.
|
|
11
|
+
const labelFor = spec => {
|
|
12
|
+
switch (spec.kind) {
|
|
13
|
+
case 'grid':
|
|
14
|
+
case 'relational':
|
|
15
|
+
case 'line':
|
|
16
|
+
case 'bars':
|
|
17
|
+
return `${spec.left} ${spec.operation} ${spec.right}`;
|
|
18
|
+
case 'none':
|
|
19
|
+
return '';
|
|
20
|
+
}
|
|
21
|
+
};
|
|
22
|
+
const renderVisual = (spec, colors) => {
|
|
23
|
+
switch (spec.kind) {
|
|
24
|
+
case 'grid':
|
|
25
|
+
return /*#__PURE__*/_jsx(DiscreteCounterGrid, {
|
|
26
|
+
spec: spec,
|
|
27
|
+
colors: colors
|
|
28
|
+
});
|
|
29
|
+
case 'relational':
|
|
30
|
+
return /*#__PURE__*/_jsx(RelationalBlock, {
|
|
31
|
+
spec: spec,
|
|
32
|
+
colors: colors
|
|
33
|
+
});
|
|
34
|
+
case 'line':
|
|
35
|
+
return /*#__PURE__*/_jsx(DynamicNumberLine, {
|
|
36
|
+
spec: spec,
|
|
37
|
+
colors: colors
|
|
38
|
+
});
|
|
39
|
+
case 'bars':
|
|
40
|
+
return /*#__PURE__*/_jsx(QuotativeBars, {
|
|
41
|
+
spec: spec,
|
|
42
|
+
colors: colors
|
|
43
|
+
});
|
|
44
|
+
case 'none':
|
|
45
|
+
return null;
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
|
|
49
|
+
// Renders the scaffold for the current spec. Whether a visual shows at all is
|
|
50
|
+
// decided by the card (none at L4/L5); this component just draws it.
|
|
51
|
+
export const FactVisual = ({
|
|
52
|
+
spec,
|
|
53
|
+
colors
|
|
54
|
+
}) => {
|
|
55
|
+
if (spec.kind === 'none') return null;
|
|
56
|
+
return /*#__PURE__*/_jsx(View, {
|
|
57
|
+
style: styles.container,
|
|
58
|
+
accessible: true,
|
|
59
|
+
accessibilityLabel: labelFor(spec),
|
|
60
|
+
children: renderVisual(spec, colors)
|
|
61
|
+
});
|
|
62
|
+
};
|
|
63
|
+
const styles = StyleSheet.create({
|
|
64
|
+
container: {
|
|
65
|
+
alignItems: 'center',
|
|
66
|
+
justifyContent: 'center'
|
|
67
|
+
}
|
|
68
|
+
});
|
|
69
|
+
//# sourceMappingURL=FactVisual.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["React","View","StyleSheet","DiscreteCounterGrid","RelationalBlock","DynamicNumberLine","QuotativeBars","jsx","_jsx","labelFor","spec","kind","left","operation","right","renderVisual","colors","FactVisual","style","styles","container","accessible","accessibilityLabel","children","create","alignItems","justifyContent"],"sourceRoot":"../../../../../../src","sources":["features/fluency/visual-scaffolding/components/FactVisual.tsx"],"mappings":";;AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,IAAI,EAAEC,UAAU,QAAQ,cAAc;AAG/C,SAASC,mBAAmB,QAAQ,0BAAuB;AAC3D,SAASC,eAAe,QAAQ,sBAAmB;AACnD,SAASC,iBAAiB,QAAQ,wBAAqB;AACvD,SAASC,aAAa,QAAQ,oBAAiB;AAAA,SAAAC,GAAA,IAAAC,IAAA;AAQ/C;AACA,MAAMC,QAAQ,GAAIC,IAAgB,IAAa;EAC7C,QAAQA,IAAI,CAACC,IAAI;IACf,KAAK,MAAM;IACX,KAAK,YAAY;IACjB,KAAK,MAAM;IACX,KAAK,MAAM;MACT,OAAO,GAAGD,IAAI,CAACE,IAAI,IAAIF,IAAI,CAACG,SAAS,IAAIH,IAAI,CAACI,KAAK,EAAE;IACvD,KAAK,MAAM;MACT,OAAO,EAAE;EACb;AACF,CAAC;AAED,MAAMC,YAAY,GAAGA,CAACL,IAAgB,EAAEM,MAAoB,KAAK;EAC/D,QAAQN,IAAI,CAACC,IAAI;IACf,KAAK,MAAM;MACT,oBAAOH,IAAA,CAACL,mBAAmB;QAACO,IAAI,EAAEA,IAAK;QAACM,MAAM,EAAEA;MAAO,CAAE,CAAC;IAC5D,KAAK,YAAY;MACf,oBAAOR,IAAA,CAACJ,eAAe;QAACM,IAAI,EAAEA,IAAK;QAACM,MAAM,EAAEA;MAAO,CAAE,CAAC;IACxD,KAAK,MAAM;MACT,oBAAOR,IAAA,CAACH,iBAAiB;QAACK,IAAI,EAAEA,IAAK;QAACM,MAAM,EAAEA;MAAO,CAAE,CAAC;IAC1D,KAAK,MAAM;MACT,oBAAOR,IAAA,CAACF,aAAa;QAACI,IAAI,EAAEA,IAAK;QAACM,MAAM,EAAEA;MAAO,CAAE,CAAC;IACtD,KAAK,MAAM;MACT,OAAO,IAAI;EACf;AACF,CAAC;;AAED;AACA;AACA,OAAO,MAAMC,UAAU,GAAGA,CAAC;EAAEP,IAAI;EAAEM;AAAwB,CAAC,KAAK;EAC/D,IAAIN,IAAI,CAACC,IAAI,KAAK,MAAM,EAAE,OAAO,IAAI;EAErC,oBACEH,IAAA,CAACP,IAAI;IAACiB,KAAK,EAAEC,MAAM,CAACC,SAAU;IAACC,UAAU;IAACC,kBAAkB,EAAEb,QAAQ,CAACC,IAAI,CAAE;IAAAa,QAAA,EAC1ER,YAAY,CAACL,IAAI,EAAEM,MAAM;EAAC,CACvB,CAAC;AAEX,CAAC;AAED,MAAMG,MAAM,GAAGjB,UAAU,CAACsB,MAAM,CAAC;EAC/BJ,SAAS,EAAE;IACTK,UAAU,EAAE,QAAQ;IACpBC,cAAc,EAAE;EAClB;AACF,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import React from 'react';
|
|
4
|
+
import { View, StyleSheet } from 'react-native';
|
|
5
|
+
import Svg, { Rect, Path, Text as SvgText } from 'react-native-svg';
|
|
6
|
+
import { COLORS, FONT_FAMILY } from '@magmamath/react-native-ui';
|
|
7
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
8
|
+
const VB_W = 480;
|
|
9
|
+
const VB_H = 98;
|
|
10
|
+
const PAD_X = 24;
|
|
11
|
+
const BAR_Y = 12;
|
|
12
|
+
const BAR_H = 46;
|
|
13
|
+
const BRACKET_Y = BAR_Y + BAR_H + 8;
|
|
14
|
+
// L2 (division) — quotative model: the dividend bar is cut into equal groups of
|
|
15
|
+
// the divisor; counting the groups gives the quotient (the answer).
|
|
16
|
+
export const QuotativeBars = ({
|
|
17
|
+
spec,
|
|
18
|
+
colors
|
|
19
|
+
}) => {
|
|
20
|
+
const segments = Math.max(1, spec.segmentCount);
|
|
21
|
+
const barW = VB_W - 2 * PAD_X;
|
|
22
|
+
const segW = barW / segments;
|
|
23
|
+
return /*#__PURE__*/_jsx(View, {
|
|
24
|
+
style: styles.wrapper,
|
|
25
|
+
children: /*#__PURE__*/_jsxs(Svg, {
|
|
26
|
+
width: "100%",
|
|
27
|
+
height: "100%",
|
|
28
|
+
viewBox: `0 0 ${VB_W} ${VB_H}`,
|
|
29
|
+
preserveAspectRatio: "xMidYMid meet",
|
|
30
|
+
children: [Array.from({
|
|
31
|
+
length: segments
|
|
32
|
+
}, (_, i) => {
|
|
33
|
+
const x = PAD_X + i * segW;
|
|
34
|
+
return /*#__PURE__*/_jsxs(React.Fragment, {
|
|
35
|
+
children: [/*#__PURE__*/_jsx(Rect, {
|
|
36
|
+
x: x,
|
|
37
|
+
y: BAR_Y,
|
|
38
|
+
width: segW,
|
|
39
|
+
height: BAR_H,
|
|
40
|
+
rx: 6,
|
|
41
|
+
fill: i % 2 === 0 ? colors.bg : colors.mid,
|
|
42
|
+
stroke: colors.accent,
|
|
43
|
+
strokeWidth: 2.5
|
|
44
|
+
}), /*#__PURE__*/_jsx(SvgText, {
|
|
45
|
+
x: x + segW / 2,
|
|
46
|
+
y: BAR_Y + BAR_H / 2 + 7,
|
|
47
|
+
fontSize: 20,
|
|
48
|
+
fontWeight: "700",
|
|
49
|
+
fontFamily: FONT_FAMILY.buenosAires,
|
|
50
|
+
fill: colors.dark,
|
|
51
|
+
textAnchor: "middle",
|
|
52
|
+
children: spec.segment
|
|
53
|
+
})]
|
|
54
|
+
}, i);
|
|
55
|
+
}), /*#__PURE__*/_jsx(Path, {
|
|
56
|
+
d: `M ${PAD_X} ${BRACKET_Y} L ${PAD_X} ${BRACKET_Y + 6} L ${VB_W - PAD_X} ${BRACKET_Y + 6} L ${VB_W - PAD_X} ${BRACKET_Y}`,
|
|
57
|
+
fill: "none",
|
|
58
|
+
stroke: COLORS.NEUTRAL_6,
|
|
59
|
+
strokeWidth: 2.5,
|
|
60
|
+
strokeLinecap: "round",
|
|
61
|
+
strokeLinejoin: "round"
|
|
62
|
+
}), /*#__PURE__*/_jsx(SvgText, {
|
|
63
|
+
x: VB_W / 2,
|
|
64
|
+
y: BRACKET_Y + 20,
|
|
65
|
+
fontSize: 15,
|
|
66
|
+
fontWeight: "700",
|
|
67
|
+
fontFamily: FONT_FAMILY.buenosAires,
|
|
68
|
+
fill: COLORS.NEUTRAL_8,
|
|
69
|
+
textAnchor: "middle",
|
|
70
|
+
children: spec.total
|
|
71
|
+
})]
|
|
72
|
+
})
|
|
73
|
+
});
|
|
74
|
+
};
|
|
75
|
+
const styles = StyleSheet.create({
|
|
76
|
+
wrapper: {
|
|
77
|
+
width: '100%',
|
|
78
|
+
maxWidth: VB_W,
|
|
79
|
+
aspectRatio: VB_W / VB_H,
|
|
80
|
+
alignSelf: 'center'
|
|
81
|
+
}
|
|
82
|
+
});
|
|
83
|
+
//# sourceMappingURL=QuotativeBars.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["React","View","StyleSheet","Svg","Rect","Path","Text","SvgText","COLORS","FONT_FAMILY","jsx","_jsx","jsxs","_jsxs","VB_W","VB_H","PAD_X","BAR_Y","BAR_H","BRACKET_Y","QuotativeBars","spec","colors","segments","Math","max","segmentCount","barW","segW","style","styles","wrapper","children","width","height","viewBox","preserveAspectRatio","Array","from","length","_","i","x","Fragment","y","rx","fill","bg","mid","stroke","accent","strokeWidth","fontSize","fontWeight","fontFamily","buenosAires","dark","textAnchor","segment","d","NEUTRAL_6","strokeLinecap","strokeLinejoin","NEUTRAL_8","total","create","maxWidth","aspectRatio","alignSelf"],"sourceRoot":"../../../../../../src","sources":["features/fluency/visual-scaffolding/components/QuotativeBars.tsx"],"mappings":"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","ignoreList":[]}
|