@doenet/doenetml 0.6.0-alpha1

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 (549) hide show
  1. package/.prettierrc +3 -0
  2. package/LICENSE +661 -0
  3. package/README.md +146 -0
  4. package/cypress/e2e/ActivityViewer/activityVariants.cy.js +1770 -0
  5. package/cypress/e2e/ActivityViewer/compiledActivity.cy.js +83 -0
  6. package/cypress/e2e/ActivityViewer/relationshipsAmongPages.cy.js +697 -0
  7. package/cypress/e2e/answerValidation/errorinnumbers.cy.js +2125 -0
  8. package/cypress/e2e/answerValidation/factoring.cy.js +1945 -0
  9. package/cypress/e2e/answerValidation/factoringOldAlgorithm.cy.js +892 -0
  10. package/cypress/e2e/answerValidation/functionanswers.cy.js +314 -0
  11. package/cypress/e2e/answerValidation/matchingpatterns.cy.js +287 -0
  12. package/cypress/e2e/answerValidation/matchpartial.cy.js +6711 -0
  13. package/cypress/e2e/answerValidation/pointlocation.cy.js +3989 -0
  14. package/cypress/e2e/answerValidation/symbolicequality.cy.js +1893 -0
  15. package/cypress/e2e/answerValidation/videoProgress.cy.js +210 -0
  16. package/cypress/e2e/assignNames/basiccopy.cy.js +2376 -0
  17. package/cypress/e2e/assignNames/collections.cy.js +9247 -0
  18. package/cypress/e2e/assignNames/selects.cy.js +105 -0
  19. package/cypress/e2e/assignNames/sequences.cy.js +1964 -0
  20. package/cypress/e2e/baseComponent/basecomponentproperties.cy.js +999 -0
  21. package/cypress/e2e/baseComponent/doenetMLtext.cy.js +427 -0
  22. package/cypress/e2e/chemistry/atom.cy.js +201 -0
  23. package/cypress/e2e/chemistry/ion.cy.js +608 -0
  24. package/cypress/e2e/chemistry/ioniccompound.cy.js +133 -0
  25. package/cypress/e2e/dynamicalsystem/cobwebpolyline.cy.js +2653 -0
  26. package/cypress/e2e/dynamicalsystem/equilibriumcurve.cy.js +311 -0
  27. package/cypress/e2e/dynamicalsystem/equilibriumline.cy.js +279 -0
  28. package/cypress/e2e/dynamicalsystem/equilibriumpoint.cy.js +283 -0
  29. package/cypress/e2e/dynamicalsystem/odesystem.cy.js +1834 -0
  30. package/cypress/e2e/equality/mathexpressions.cy.js +948 -0
  31. package/cypress/e2e/graphing/graphreferences.cy.js +978 -0
  32. package/cypress/e2e/graphing/graphreferences2.cy.js +615 -0
  33. package/cypress/e2e/linearAlgebra/eigenDecomposition.cy.js +401 -0
  34. package/cypress/e2e/tagSpecific/angle.cy.js +3898 -0
  35. package/cypress/e2e/tagSpecific/animatefromsequence.cy.js +2306 -0
  36. package/cypress/e2e/tagSpecific/answer.cy.js +31647 -0
  37. package/cypress/e2e/tagSpecific/bestfitline.cy.js +612 -0
  38. package/cypress/e2e/tagSpecific/blockquote.cy.js +30 -0
  39. package/cypress/e2e/tagSpecific/boolean.cy.js +742 -0
  40. package/cypress/e2e/tagSpecific/booleaninput.cy.js +1283 -0
  41. package/cypress/e2e/tagSpecific/booleanlist.cy.js +588 -0
  42. package/cypress/e2e/tagSpecific/booleanoperators.cy.js +596 -0
  43. package/cypress/e2e/tagSpecific/booleanoperatorsonmath.cy.js +498 -0
  44. package/cypress/e2e/tagSpecific/callaction.cy.js +2835 -0
  45. package/cypress/e2e/tagSpecific/choiceinput.cy.js +3205 -0
  46. package/cypress/e2e/tagSpecific/circle.cy.js +22036 -0
  47. package/cypress/e2e/tagSpecific/codeeditor.cy.js +1995 -0
  48. package/cypress/e2e/tagSpecific/collect.cy.js +5035 -0
  49. package/cypress/e2e/tagSpecific/componentsize.cy.js +502 -0
  50. package/cypress/e2e/tagSpecific/conditionalcontent.cy.js +3495 -0
  51. package/cypress/e2e/tagSpecific/contentBrowser.cy.js +335 -0
  52. package/cypress/e2e/tagSpecific/contentpicker.cy.js +261 -0
  53. package/cypress/e2e/tagSpecific/copy.cy.js +12627 -0
  54. package/cypress/e2e/tagSpecific/copy2.cy.js +5698 -0
  55. package/cypress/e2e/tagSpecific/curve.bezier.cy.js +12440 -0
  56. package/cypress/e2e/tagSpecific/curve.cy.js +1716 -0
  57. package/cypress/e2e/tagSpecific/curve.function.cy.js +1471 -0
  58. package/cypress/e2e/tagSpecific/curve.parametrized.cy.js +920 -0
  59. package/cypress/e2e/tagSpecific/document.cy.js +234 -0
  60. package/cypress/e2e/tagSpecific/endpoint.cy.js +197 -0
  61. package/cypress/e2e/tagSpecific/evaluate.cy.js +8895 -0
  62. package/cypress/e2e/tagSpecific/extract.cy.js +2282 -0
  63. package/cypress/e2e/tagSpecific/feedback.cy.js +2941 -0
  64. package/cypress/e2e/tagSpecific/function.cy.js +9450 -0
  65. package/cypress/e2e/tagSpecific/functioniterates.cy.js +1178 -0
  66. package/cypress/e2e/tagSpecific/functionoperators.cy.js +4047 -0
  67. package/cypress/e2e/tagSpecific/graph.cy.js +2491 -0
  68. package/cypress/e2e/tagSpecific/group.cy.js +683 -0
  69. package/cypress/e2e/tagSpecific/hint.cy.js +204 -0
  70. package/cypress/e2e/tagSpecific/image.cy.js +770 -0
  71. package/cypress/e2e/tagSpecific/integer.cy.js +206 -0
  72. package/cypress/e2e/tagSpecific/label.cy.js +800 -0
  73. package/cypress/e2e/tagSpecific/legend.cy.js +1001 -0
  74. package/cypress/e2e/tagSpecific/line.cy.js +12167 -0
  75. package/cypress/e2e/tagSpecific/linesegment.cy.js +4749 -0
  76. package/cypress/e2e/tagSpecific/lorem.cy.js +289 -0
  77. package/cypress/e2e/tagSpecific/map.cy.js +4476 -0
  78. package/cypress/e2e/tagSpecific/matchespattern.cy.js +693 -0
  79. package/cypress/e2e/tagSpecific/math.cy.js +10990 -0
  80. package/cypress/e2e/tagSpecific/mathdisplay.cy.js +2689 -0
  81. package/cypress/e2e/tagSpecific/mathinput.cy.js +15628 -0
  82. package/cypress/e2e/tagSpecific/mathinputgraph.cy.js +566 -0
  83. package/cypress/e2e/tagSpecific/mathlist.cy.js +4073 -0
  84. package/cypress/e2e/tagSpecific/mathoperators.cy.js +13851 -0
  85. package/cypress/e2e/tagSpecific/matrix.cy.js +8825 -0
  86. package/cypress/e2e/tagSpecific/matrixinput.cy.js +16277 -0
  87. package/cypress/e2e/tagSpecific/module.cy.js +1771 -0
  88. package/cypress/e2e/tagSpecific/number.cy.js +2221 -0
  89. package/cypress/e2e/tagSpecific/numberlist.cy.js +1285 -0
  90. package/cypress/e2e/tagSpecific/p.cy.js +72 -0
  91. package/cypress/e2e/tagSpecific/paginator.cy.js +2983 -0
  92. package/cypress/e2e/tagSpecific/parabola.cy.js +14331 -0
  93. package/cypress/e2e/tagSpecific/paragraphmarkup.cy.js +104 -0
  94. package/cypress/e2e/tagSpecific/periodicset.cy.js +1439 -0
  95. package/cypress/e2e/tagSpecific/piecewisefunction.cy.js +1055 -0
  96. package/cypress/e2e/tagSpecific/pluralize.cy.js +274 -0
  97. package/cypress/e2e/tagSpecific/point.cy.js +8895 -0
  98. package/cypress/e2e/tagSpecific/point2.cy.js +10259 -0
  99. package/cypress/e2e/tagSpecific/polygon.cy.js +5039 -0
  100. package/cypress/e2e/tagSpecific/polyline.cy.js +4704 -0
  101. package/cypress/e2e/tagSpecific/problem.cy.js +2768 -0
  102. package/cypress/e2e/tagSpecific/ray.cy.js +10770 -0
  103. package/cypress/e2e/tagSpecific/rectangle.cy.js +2143 -0
  104. package/cypress/e2e/tagSpecific/ref.cy.js +420 -0
  105. package/cypress/e2e/tagSpecific/regularPolygon.cy.js +1006 -0
  106. package/cypress/e2e/tagSpecific/regularPolygon2.cy.js +100 -0
  107. package/cypress/e2e/tagSpecific/regularPolygon3.cy.js +777 -0
  108. package/cypress/e2e/tagSpecific/samplerandomnumbers.cy.js +3619 -0
  109. package/cypress/e2e/tagSpecific/sectioning.cy.js +3530 -0
  110. package/cypress/e2e/tagSpecific/select.cy.js +5376 -0
  111. package/cypress/e2e/tagSpecific/selectfromsequence.cy.js +3846 -0
  112. package/cypress/e2e/tagSpecific/selectrandomnumbers.cy.js +2914 -0
  113. package/cypress/e2e/tagSpecific/sequence.cy.js +2093 -0
  114. package/cypress/e2e/tagSpecific/shuffle.cy.js +490 -0
  115. package/cypress/e2e/tagSpecific/sidebyside.cy.js +8057 -0
  116. package/cypress/e2e/tagSpecific/singlecharactercomponents.cy.js +72 -0
  117. package/cypress/e2e/tagSpecific/slider.cy.js +914 -0
  118. package/cypress/e2e/tagSpecific/solution.cy.js +109 -0
  119. package/cypress/e2e/tagSpecific/solveequations.cy.js +1026 -0
  120. package/cypress/e2e/tagSpecific/sort.cy.js +1685 -0
  121. package/cypress/e2e/tagSpecific/spreadsheet.cy.js +5971 -0
  122. package/cypress/e2e/tagSpecific/subsetofreals.cy.js +2725 -0
  123. package/cypress/e2e/tagSpecific/substitute.cy.js +2646 -0
  124. package/cypress/e2e/tagSpecific/tabular.cy.js +36 -0
  125. package/cypress/e2e/tagSpecific/text.cy.js +975 -0
  126. package/cypress/e2e/tagSpecific/textinput.cy.js +2177 -0
  127. package/cypress/e2e/tagSpecific/textlist.cy.js +369 -0
  128. package/cypress/e2e/tagSpecific/triangle.cy.js +1936 -0
  129. package/cypress/e2e/tagSpecific/triggerset.cy.js +2023 -0
  130. package/cypress/e2e/tagSpecific/updatevalue.cy.js +3288 -0
  131. package/cypress/e2e/tagSpecific/vector.cy.js +20183 -0
  132. package/cypress/e2e/tagSpecific/video.cy.js +612 -0
  133. package/cypress/e2e/tagSpecific/when.cy.js +202 -0
  134. package/cypress/e2e/variants/specifysinglevariant.cy.js +6726 -0
  135. package/cypress/e2e/variants/uniquevariants.cy.js +4846 -0
  136. package/cypress/fixtures/example.json +5 -0
  137. package/cypress/support/commands.js +32 -0
  138. package/cypress/support/e2e.js +31 -0
  139. package/cypress.config.js +18 -0
  140. package/docs/codeSnippet.jsx +11 -0
  141. package/docs/index.html +133 -0
  142. package/docs/index.jsx +138 -0
  143. package/docs/prism.css +3 -0
  144. package/index.html +14 -0
  145. package/index.js +21 -0
  146. package/media/answer_example.png +0 -0
  147. package/media/graph_example.png +0 -0
  148. package/media/graph_markup_example.png +0 -0
  149. package/package.json +83 -0
  150. package/public/favicon.ico +0 -0
  151. package/public/fonts/files/open-sans-v18-latin-700.woff +0 -0
  152. package/public/fonts/files/open-sans-v18-latin-700.woff2 +0 -0
  153. package/public/fonts/files/open-sans-v18-latin-700italic.woff +0 -0
  154. package/public/fonts/files/open-sans-v18-latin-700italic.woff2 +0 -0
  155. package/public/fonts/files/open-sans-v18-latin-italic.woff +0 -0
  156. package/public/fonts/files/open-sans-v18-latin-italic.woff2 +0 -0
  157. package/public/fonts/files/open-sans-v18-latin-light-italic.woff +0 -0
  158. package/public/fonts/files/open-sans-v18-latin-light-italic.woff2 +0 -0
  159. package/public/fonts/files/open-sans-v18-latin-light.woff +0 -0
  160. package/public/fonts/files/open-sans-v18-latin-light.woff2 +0 -0
  161. package/public/fonts/files/open-sans-v18-latin-regular.woff +0 -0
  162. package/public/fonts/files/open-sans-v18-latin-regular.woff2 +0 -0
  163. package/src/Core/ComponentTypes.js +426 -0
  164. package/src/Core/Core.js +11852 -0
  165. package/src/Core/CoreWorker.js +127 -0
  166. package/src/Core/Dependencies.js +8226 -0
  167. package/src/Core/Numerics.js +473 -0
  168. package/src/Core/ParameterStack.js +36 -0
  169. package/src/Core/ReadOnlyProxyHandler.js +41 -0
  170. package/src/Core/StateProxyHandler.js +88 -0
  171. package/src/Core/components/Aliases.js +67 -0
  172. package/src/Core/components/Angle.js +758 -0
  173. package/src/Core/components/AnimateFromSequence.js +922 -0
  174. package/src/Core/components/Answer.js +2087 -0
  175. package/src/Core/components/AsList.js +83 -0
  176. package/src/Core/components/AttractTo.js +245 -0
  177. package/src/Core/components/AttractToAngles.js +262 -0
  178. package/src/Core/components/AttractToConstraint.js +104 -0
  179. package/src/Core/components/AttractToGrid.js +315 -0
  180. package/src/Core/components/Award.js +906 -0
  181. package/src/Core/components/BestFitLine.js +318 -0
  182. package/src/Core/components/BezierControls.js +719 -0
  183. package/src/Core/components/BlockQuote.js +35 -0
  184. package/src/Core/components/Boolean.js +500 -0
  185. package/src/Core/components/BooleanInput.js +330 -0
  186. package/src/Core/components/BooleanList.js +396 -0
  187. package/src/Core/components/BooleanOperators.js +35 -0
  188. package/src/Core/components/BooleanOperatorsOfMath.js +148 -0
  189. package/src/Core/components/CallAction.js +261 -0
  190. package/src/Core/components/Caption.js +73 -0
  191. package/src/Core/components/Case.js +56 -0
  192. package/src/Core/components/Cell.js +439 -0
  193. package/src/Core/components/CellBlock.js +64 -0
  194. package/src/Core/components/Chart.js +795 -0
  195. package/src/Core/components/Choice.js +266 -0
  196. package/src/Core/components/ChoiceInput.js +1407 -0
  197. package/src/Core/components/Circle.js +2884 -0
  198. package/src/Core/components/CodeEditor.js +647 -0
  199. package/src/Core/components/CodeViewer.js +294 -0
  200. package/src/Core/components/CollaborateGroupSetup.js +46 -0
  201. package/src/Core/components/CollaborateGroups.js +119 -0
  202. package/src/Core/components/Collect.js +850 -0
  203. package/src/Core/components/Column.js +608 -0
  204. package/src/Core/components/ConditionalContent.js +468 -0
  205. package/src/Core/components/ConsiderAsResponses.js +49 -0
  206. package/src/Core/components/ConstrainTo.js +161 -0
  207. package/src/Core/components/ConstrainToAngles.js +244 -0
  208. package/src/Core/components/ConstrainToGraph.js +142 -0
  209. package/src/Core/components/ConstrainToGrid.js +175 -0
  210. package/src/Core/components/ConstraintUnion.js +119 -0
  211. package/src/Core/components/Constraints.js +497 -0
  212. package/src/Core/components/ContentBrowser.js +441 -0
  213. package/src/Core/components/ContentPicker.js +263 -0
  214. package/src/Core/components/ControlVectors.js +25 -0
  215. package/src/Core/components/Coords.js +63 -0
  216. package/src/Core/components/Copy.js +3412 -0
  217. package/src/Core/components/Curve.js +4130 -0
  218. package/src/Core/components/CustomAttribute.js +175 -0
  219. package/src/Core/components/DataFrame.js +357 -0
  220. package/src/Core/components/DiscreteSimulationResultList.js +342 -0
  221. package/src/Core/components/DiscreteSimulationResultPolyline.js +581 -0
  222. package/src/Core/components/Divisions.js +55 -0
  223. package/src/Core/components/Document.js +888 -0
  224. package/src/Core/components/Embed.js +65 -0
  225. package/src/Core/components/Endpoint.js +62 -0
  226. package/src/Core/components/Evaluate.js +321 -0
  227. package/src/Core/components/Extract.js +656 -0
  228. package/src/Core/components/Extrema.js +556 -0
  229. package/src/Core/components/Feedback.js +200 -0
  230. package/src/Core/components/FeedbackDefinitions.js +97 -0
  231. package/src/Core/components/Figure.js +148 -0
  232. package/src/Core/components/Footnote.js +73 -0
  233. package/src/Core/components/Function.js +5344 -0
  234. package/src/Core/components/FunctionIterates.js +306 -0
  235. package/src/Core/components/FunctionOperators.js +702 -0
  236. package/src/Core/components/Graph.js +1679 -0
  237. package/src/Core/components/Group.js +7 -0
  238. package/src/Core/components/HasSameFactoring.js +407 -0
  239. package/src/Core/components/Hint.js +241 -0
  240. package/src/Core/components/Image.js +524 -0
  241. package/src/Core/components/Indexing.js +79 -0
  242. package/src/Core/components/IntComma.js +64 -0
  243. package/src/Core/components/Integer.js +81 -0
  244. package/src/Core/components/Intersection.js +328 -0
  245. package/src/Core/components/Interval.js +29 -0
  246. package/src/Core/components/Label.js +492 -0
  247. package/src/Core/components/Latex.js +104 -0
  248. package/src/Core/components/Legend.js +329 -0
  249. package/src/Core/components/Line.js +2040 -0
  250. package/src/Core/components/LineSegment.js +882 -0
  251. package/src/Core/components/Lists.js +180 -0
  252. package/src/Core/components/Lorem.js +249 -0
  253. package/src/Core/components/MMeMen.js +377 -0
  254. package/src/Core/components/Map.js +873 -0
  255. package/src/Core/components/Markers.js +101 -0
  256. package/src/Core/components/MatchesPattern.js +339 -0
  257. package/src/Core/components/Math.js +2552 -0
  258. package/src/Core/components/MathInput.js +948 -0
  259. package/src/Core/components/MathList.js +828 -0
  260. package/src/Core/components/MathOperators.js +1286 -0
  261. package/src/Core/components/Matrix.js +497 -0
  262. package/src/Core/components/MatrixInput.js +3157 -0
  263. package/src/Core/components/MdMdnMrow.js +394 -0
  264. package/src/Core/components/Module.js +16 -0
  265. package/src/Core/components/Number.js +1031 -0
  266. package/src/Core/components/NumberList.js +550 -0
  267. package/src/Core/components/Option.js +24 -0
  268. package/src/Core/components/P.js +71 -0
  269. package/src/Core/components/Paginator.js +338 -0
  270. package/src/Core/components/Panel.js +126 -0
  271. package/src/Core/components/Parabola.js +1561 -0
  272. package/src/Core/components/ParagraphMarkup.js +59 -0
  273. package/src/Core/components/Pegboard.js +43 -0
  274. package/src/Core/components/PeriodicSet.js +291 -0
  275. package/src/Core/components/PiecewiseFunction.js +832 -0
  276. package/src/Core/components/Pluralize.js +198 -0
  277. package/src/Core/components/Point.js +1295 -0
  278. package/src/Core/components/Polygon.js +408 -0
  279. package/src/Core/components/Polyline.js +841 -0
  280. package/src/Core/components/RandomizedTextList.js +225 -0
  281. package/src/Core/components/Ray.js +1737 -0
  282. package/src/Core/components/Rectangle.js +1535 -0
  283. package/src/Core/components/Ref.js +350 -0
  284. package/src/Core/components/RegionBetweenCurveXAxis.js +124 -0
  285. package/src/Core/components/RegionHalfPlane.js +107 -0
  286. package/src/Core/components/RegularPolygon.js +2118 -0
  287. package/src/Core/components/RenderDoenetML.js +181 -0
  288. package/src/Core/components/Row.js +780 -0
  289. package/src/Core/components/SampleRandomNumbers.js +653 -0
  290. package/src/Core/components/Sectioning.js +303 -0
  291. package/src/Core/components/Select.js +947 -0
  292. package/src/Core/components/SelectFromSequence.js +1242 -0
  293. package/src/Core/components/SelectRandomNumbers.js +225 -0
  294. package/src/Core/components/Sequence.js +444 -0
  295. package/src/Core/components/Setup.js +53 -0
  296. package/src/Core/components/Shuffle.js +470 -0
  297. package/src/Core/components/SideBySide.js +2130 -0
  298. package/src/Core/components/SingleCharacterComponents.js +41 -0
  299. package/src/Core/components/Slider.js +819 -0
  300. package/src/Core/components/SolutionContainer.js +67 -0
  301. package/src/Core/components/Solutions.js +334 -0
  302. package/src/Core/components/SolveEquations.js +568 -0
  303. package/src/Core/components/Sort.js +398 -0
  304. package/src/Core/components/Sources.js +108 -0
  305. package/src/Core/components/Split.js +205 -0
  306. package/src/Core/components/Spreadsheet.js +1507 -0
  307. package/src/Core/components/StyleDefinitions.js +111 -0
  308. package/src/Core/components/SubsetOfReals.js +348 -0
  309. package/src/Core/components/SubsetOfRealsInput.js +1474 -0
  310. package/src/Core/components/Substitute.js +496 -0
  311. package/src/Core/components/SummaryStatistics.js +652 -0
  312. package/src/Core/components/Table.js +145 -0
  313. package/src/Core/components/Tabular.js +384 -0
  314. package/src/Core/components/Template.js +360 -0
  315. package/src/Core/components/Text.js +341 -0
  316. package/src/Core/components/TextInput.js +566 -0
  317. package/src/Core/components/TextList.js +442 -0
  318. package/src/Core/components/TextListFromString.js +137 -0
  319. package/src/Core/components/TextOperatorsOfMath.js +21 -0
  320. package/src/Core/components/Triangle.js +280 -0
  321. package/src/Core/components/TriggerSet.js +189 -0
  322. package/src/Core/components/TupleList.js +43 -0
  323. package/src/Core/components/UpdateValue.js +435 -0
  324. package/src/Core/components/VariantControl.js +36 -0
  325. package/src/Core/components/Vector.js +2478 -0
  326. package/src/Core/components/Verbatim.js +125 -0
  327. package/src/Core/components/Video.js +673 -0
  328. package/src/Core/components/When.js +198 -0
  329. package/src/Core/components/abstract/AngleListComponent.js +140 -0
  330. package/src/Core/components/abstract/BaseComponent.js +1496 -0
  331. package/src/Core/components/abstract/BlockComponent.js +5 -0
  332. package/src/Core/components/abstract/BooleanBaseOperator.js +88 -0
  333. package/src/Core/components/abstract/BooleanBaseOperatorOfMath.js +100 -0
  334. package/src/Core/components/abstract/BooleanBaseOperatorOneInput.js +44 -0
  335. package/src/Core/components/abstract/ComponentSize.js +789 -0
  336. package/src/Core/components/abstract/ComponentWithSelectableType.js +537 -0
  337. package/src/Core/components/abstract/CompositeComponent.js +142 -0
  338. package/src/Core/components/abstract/ConstraintComponent.js +19 -0
  339. package/src/Core/components/abstract/FunctionBaseOperator.js +680 -0
  340. package/src/Core/components/abstract/GraphicalComponent.js +56 -0
  341. package/src/Core/components/abstract/InlineComponent.js +5 -0
  342. package/src/Core/components/abstract/InlineRenderInlineChildren.js +63 -0
  343. package/src/Core/components/abstract/Input.js +192 -0
  344. package/src/Core/components/abstract/IntervalListComponent.js +218 -0
  345. package/src/Core/components/abstract/LineListComponent.js +114 -0
  346. package/src/Core/components/abstract/MathBaseOperator.js +631 -0
  347. package/src/Core/components/abstract/MathBaseOperatorOneInput.js +112 -0
  348. package/src/Core/components/abstract/PointListComponent.js +238 -0
  349. package/src/Core/components/abstract/SectioningComponent.js +1262 -0
  350. package/src/Core/components/abstract/SingleCharacterInline.js +23 -0
  351. package/src/Core/components/abstract/TextBaseOperatorOfMath.js +47 -0
  352. package/src/Core/components/abstract/TextOrInline.js +66 -0
  353. package/src/Core/components/abstract/VariableName.js +31 -0
  354. package/src/Core/components/abstract/VariableNameList.js +83 -0
  355. package/src/Core/components/abstract/VectorListComponent.js +235 -0
  356. package/src/Core/components/chemistry/Atom.js +910 -0
  357. package/src/Core/components/chemistry/ElectronConfiguration.js +36 -0
  358. package/src/Core/components/chemistry/Ion.js +684 -0
  359. package/src/Core/components/chemistry/IonicCompound.js +189 -0
  360. package/src/Core/components/chemistry/OrbitalDiagram.js +175 -0
  361. package/src/Core/components/chemistry/OrbitalDiagramInput.js +753 -0
  362. package/src/Core/components/chemistry/index.js +6 -0
  363. package/src/Core/components/commonsugar/breakstrings.js +627 -0
  364. package/src/Core/components/commonsugar/lists.js +177 -0
  365. package/src/Core/components/dynamicalSystems/CobwebPolyline.js +913 -0
  366. package/src/Core/components/dynamicalSystems/EquilibriumCurve.js +95 -0
  367. package/src/Core/components/dynamicalSystems/EquilibriumLine.js +93 -0
  368. package/src/Core/components/dynamicalSystems/EquilibriumPoint.js +93 -0
  369. package/src/Core/components/dynamicalSystems/ODESystem.js +943 -0
  370. package/src/Core/components/dynamicalSystems/index.js +5 -0
  371. package/src/Core/components/linearAlgebra/EigenDecomposition.js +294 -0
  372. package/src/Core/utils/array.js +30 -0
  373. package/src/Core/utils/booleanLogic.js +965 -0
  374. package/src/Core/utils/checkEquality.js +818 -0
  375. package/src/Core/utils/cid.js +29 -0
  376. package/src/Core/utils/componentInfoObjects.js +100 -0
  377. package/src/Core/utils/constraints.js +23 -0
  378. package/src/Core/utils/copy.js +572 -0
  379. package/src/Core/utils/deepFunctions.js +173 -0
  380. package/src/Core/utils/descendants.js +252 -0
  381. package/src/Core/utils/enumeration.js +234 -0
  382. package/src/Core/utils/feedback.js +84 -0
  383. package/src/Core/utils/function.js +1343 -0
  384. package/src/Core/utils/graphical.js +196 -0
  385. package/src/Core/utils/label.js +396 -0
  386. package/src/Core/utils/math.js +1056 -0
  387. package/src/Core/utils/naming.js +45 -0
  388. package/src/Core/utils/periodicSetEquality.js +403 -0
  389. package/src/Core/utils/randomNumbers.js +70 -0
  390. package/src/Core/utils/retrieveMedia.js +98 -0
  391. package/src/Core/utils/retrieveTextFile.js +140 -0
  392. package/src/Core/utils/returnAllPossibleVariants.js +73 -0
  393. package/src/Core/utils/rounding.js +316 -0
  394. package/src/Core/utils/sequence.js +754 -0
  395. package/src/Core/utils/serializedStateProcessing.js +4049 -0
  396. package/src/Core/utils/size.js +22 -0
  397. package/src/Core/utils/stateVariables.js +138 -0
  398. package/src/Core/utils/style.js +535 -0
  399. package/src/Core/utils/subset-of-reals.js +796 -0
  400. package/src/Core/utils/table.js +41 -0
  401. package/src/Core/utils/text.js +16 -0
  402. package/src/Core/utils/triggering.js +167 -0
  403. package/src/Core/utils/variants.js +477 -0
  404. package/src/DoenetML.css +308 -0
  405. package/src/DoenetML.jsx +201 -0
  406. package/src/Parser/doenet.grammar +90 -0
  407. package/src/Parser/doenet.js +33 -0
  408. package/src/Parser/doenet.terms.js +20 -0
  409. package/src/Parser/parser.js +266 -0
  410. package/src/Parser/tokens.js +129 -0
  411. package/src/Tools/CodeMirror.jsx +440 -0
  412. package/src/Tools/DarkmodeController.jsx +21 -0
  413. package/src/Tools/Footers/MathInputSelector.jsx +34 -0
  414. package/src/Tools/Footers/VirtualKeyboard.jsx +751 -0
  415. package/src/Tools/cypressTest/CypressTest.jsx +341 -0
  416. package/src/Tools/cypressTest/index.html +102 -0
  417. package/src/Tools/cypressTest/index.jsx +40 -0
  418. package/src/Viewer/ActivityViewer.jsx +1461 -0
  419. package/src/Viewer/PageViewer.jsx +1329 -0
  420. package/src/Viewer/renderers/alert.jsx +17 -0
  421. package/src/Viewer/renderers/angle.jsx +209 -0
  422. package/src/Viewer/renderers/answer.jsx +206 -0
  423. package/src/Viewer/renderers/asList.jsx +25 -0
  424. package/src/Viewer/renderers/blockQuote.jsx +41 -0
  425. package/src/Viewer/renderers/boolean.jsx +17 -0
  426. package/src/Viewer/renderers/booleanInput.css +105 -0
  427. package/src/Viewer/renderers/booleanInput.jsx +636 -0
  428. package/src/Viewer/renderers/button.jsx +369 -0
  429. package/src/Viewer/renderers/c.jsx +17 -0
  430. package/src/Viewer/renderers/callAction.jsx +18 -0
  431. package/src/Viewer/renderers/cell.jsx +59 -0
  432. package/src/Viewer/renderers/chart.jsx +83 -0
  433. package/src/Viewer/renderers/choiceInput.css +223 -0
  434. package/src/Viewer/renderers/choiceInput.jsx +535 -0
  435. package/src/Viewer/renderers/circle.jsx +990 -0
  436. package/src/Viewer/renderers/cobwebPolyline.jsx +442 -0
  437. package/src/Viewer/renderers/codeEditor.jsx +248 -0
  438. package/src/Viewer/renderers/codeViewer.jsx +105 -0
  439. package/src/Viewer/renderers/containerBlock.jsx +41 -0
  440. package/src/Viewer/renderers/containerInline.jsx +17 -0
  441. package/src/Viewer/renderers/contentBrowser.jsx +159 -0
  442. package/src/Viewer/renderers/contentPicker.jsx +160 -0
  443. package/src/Viewer/renderers/curve.jsx +1072 -0
  444. package/src/Viewer/renderers/ellipsis.jsx +17 -0
  445. package/src/Viewer/renderers/em.jsx +17 -0
  446. package/src/Viewer/renderers/embed.jsx +110 -0
  447. package/src/Viewer/renderers/feedback.jsx +74 -0
  448. package/src/Viewer/renderers/figure.jsx +131 -0
  449. package/src/Viewer/renderers/footnote.jsx +52 -0
  450. package/src/Viewer/renderers/graph.jsx +925 -0
  451. package/src/Viewer/renderers/hint.jsx +142 -0
  452. package/src/Viewer/renderers/image.jsx +581 -0
  453. package/src/Viewer/renderers/jsxgraph-distrib/jsxgraphcore.mjs +2 -0
  454. package/src/Viewer/renderers/jsxgraph-distrib/jsxgraphcore.mjs.map +1 -0
  455. package/src/Viewer/renderers/label.jsx +470 -0
  456. package/src/Viewer/renderers/legend.jsx +306 -0
  457. package/src/Viewer/renderers/line.jsx +511 -0
  458. package/src/Viewer/renderers/lineSegment.jsx +754 -0
  459. package/src/Viewer/renderers/list.jsx +111 -0
  460. package/src/Viewer/renderers/lq.jsx +12 -0
  461. package/src/Viewer/renderers/lsq.jsx +12 -0
  462. package/src/Viewer/renderers/math.jsx +582 -0
  463. package/src/Viewer/renderers/mathInput.css +10 -0
  464. package/src/Viewer/renderers/mathInput.jsx +425 -0
  465. package/src/Viewer/renderers/mathInputog.jsx +534 -0
  466. package/src/Viewer/renderers/mathList.jsx +39 -0
  467. package/src/Viewer/renderers/matrixInput.jsx +317 -0
  468. package/src/Viewer/renderers/mdash.jsx +12 -0
  469. package/src/Viewer/renderers/nbsp.jsx +12 -0
  470. package/src/Viewer/renderers/ndash.jsx +12 -0
  471. package/src/Viewer/renderers/number.jsx +454 -0
  472. package/src/Viewer/renderers/numberList.jsx +35 -0
  473. package/src/Viewer/renderers/orbitalDiagram.jsx +247 -0
  474. package/src/Viewer/renderers/orbitalDiagramInput.jsx +450 -0
  475. package/src/Viewer/renderers/p.jsx +38 -0
  476. package/src/Viewer/renderers/paginatorControls.jsx +41 -0
  477. package/src/Viewer/renderers/pegboard.jsx +239 -0
  478. package/src/Viewer/renderers/point.jsx +649 -0
  479. package/src/Viewer/renderers/polygon.jsx +612 -0
  480. package/src/Viewer/renderers/polyline.jsx +608 -0
  481. package/src/Viewer/renderers/pre.jsx +34 -0
  482. package/src/Viewer/renderers/q.jsx +17 -0
  483. package/src/Viewer/renderers/ray.jsx +410 -0
  484. package/src/Viewer/renderers/ref.jsx +149 -0
  485. package/src/Viewer/renderers/regionBetweenCurveXAxis.jsx +182 -0
  486. package/src/Viewer/renderers/renderDoenetML.jsx +56 -0
  487. package/src/Viewer/renderers/row.jsx +31 -0
  488. package/src/Viewer/renderers/rq.jsx +12 -0
  489. package/src/Viewer/renderers/rsq.jsx +12 -0
  490. package/src/Viewer/renderers/section.jsx +427 -0
  491. package/src/Viewer/renderers/sideBySide.jsx +80 -0
  492. package/src/Viewer/renderers/slider.jsx +800 -0
  493. package/src/Viewer/renderers/solution.jsx +134 -0
  494. package/src/Viewer/renderers/spreadsheet.jsx +83 -0
  495. package/src/Viewer/renderers/sq.jsx +17 -0
  496. package/src/Viewer/renderers/styles/global.css +14 -0
  497. package/src/Viewer/renderers/subsetOfRealsInput.jsx +392 -0
  498. package/src/Viewer/renderers/summaryStatistics.jsx +83 -0
  499. package/src/Viewer/renderers/table.jsx +78 -0
  500. package/src/Viewer/renderers/tabular.jsx +58 -0
  501. package/src/Viewer/renderers/tag.jsx +26 -0
  502. package/src/Viewer/renderers/text.jsx +439 -0
  503. package/src/Viewer/renderers/textInput.jsx +774 -0
  504. package/src/Viewer/renderers/textList.jsx +30 -0
  505. package/src/Viewer/renderers/triggerSet.jsx +52 -0
  506. package/src/Viewer/renderers/updateValue.jsx +30 -0
  507. package/src/Viewer/renderers/utils/css.js +13 -0
  508. package/src/Viewer/renderers/utils/graph.js +159 -0
  509. package/src/Viewer/renderers/utils/offGraphIndicators.js +91 -0
  510. package/src/Viewer/renderers/vector.jsx +678 -0
  511. package/src/Viewer/renderers/video.jsx +494 -0
  512. package/src/Viewer/useDoenetRenderer.jsx +128 -0
  513. package/src/main.jsx +16 -0
  514. package/src/media/fonts/files/open-sans-v18-latin-700.woff +0 -0
  515. package/src/media/fonts/files/open-sans-v18-latin-700.woff2 +0 -0
  516. package/src/media/fonts/files/open-sans-v18-latin-700italic.woff +0 -0
  517. package/src/media/fonts/files/open-sans-v18-latin-700italic.woff2 +0 -0
  518. package/src/media/fonts/files/open-sans-v18-latin-italic.woff +0 -0
  519. package/src/media/fonts/files/open-sans-v18-latin-italic.woff2 +0 -0
  520. package/src/media/fonts/files/open-sans-v18-latin-light-italic.woff +0 -0
  521. package/src/media/fonts/files/open-sans-v18-latin-light-italic.woff2 +0 -0
  522. package/src/media/fonts/files/open-sans-v18-latin-light.woff +0 -0
  523. package/src/media/fonts/files/open-sans-v18-latin-light.woff2 +0 -0
  524. package/src/media/fonts/files/open-sans-v18-latin-regular.woff +0 -0
  525. package/src/media/fonts/files/open-sans-v18-latin-regular.woff2 +0 -0
  526. package/src/test/testCode.doenet +26 -0
  527. package/src/test/testViewer.jsx +158 -0
  528. package/src/uiComponents/ActionButton.jsx +157 -0
  529. package/src/uiComponents/ActionButtonGroup.jsx +93 -0
  530. package/src/uiComponents/Button.jsx +160 -0
  531. package/src/uiComponents/ButtonGroup.jsx +56 -0
  532. package/src/uiComponents/ToggleButton.jsx +194 -0
  533. package/src/uiComponents/ToggleButtonGroup.jsx +77 -0
  534. package/src/utils/activityUtils.js +713 -0
  535. package/src/utils/array.js +17 -0
  536. package/src/utils/cid.js +34 -0
  537. package/src/utils/componentInfoObjects.js +89 -0
  538. package/src/utils/deepFunctions.js +165 -0
  539. package/src/utils/enumeration.js +226 -0
  540. package/src/utils/math.js +624 -0
  541. package/src/utils/naming.js +44 -0
  542. package/src/utils/retrieveTextFile.js +156 -0
  543. package/src/utils/returnAllPossibleVariants.js +81 -0
  544. package/src/utils/sequence.js +715 -0
  545. package/src/utils/serialize.js +29 -0
  546. package/src/utils/serializedStateProcessing.js +2587 -0
  547. package/src/utils/subset-of-reals.js +783 -0
  548. package/src/utils/url.js +19 -0
  549. package/vite.config.js +14 -0
@@ -0,0 +1,2282 @@
1
+ import { cesc, cesc2 } from "../../../../src/utils/url";
2
+
3
+ function nInDOM(n) {
4
+ if (n < 0) {
5
+ return `−${Math.abs(n)}`;
6
+ } else {
7
+ return String(n);
8
+ }
9
+ }
10
+
11
+ describe("Extract Tag Tests", function () {
12
+ beforeEach(() => {
13
+ cy.clearIndexedDB();
14
+ cy.visit("/src/Tools/cypressTest/");
15
+ });
16
+
17
+ it("extract copies properties", () => {
18
+ cy.window().then(async (win) => {
19
+ win.postMessage(
20
+ {
21
+ doenetML: `
22
+ <text>a</text>
23
+ <extract prop="latex" assignNames="e1"><math modifyIndirectly="false">x</math></extract>
24
+ <extract prop="latex" assignNames="e2"><math modifyIndirectly="true">x</math></extract>
25
+ `,
26
+ },
27
+ "*",
28
+ );
29
+ });
30
+
31
+ cy.get(cesc("#\\/_text1")).should("have.text", "a"); // to wait until loaded
32
+
33
+ cy.log(`check properties`);
34
+ cy.window().then(async (win) => {
35
+ let stateVariables = await win.returnAllStateVariables1();
36
+ expect(stateVariables["/_math1"].stateValues.modifyIndirectly).eq(false);
37
+ expect(stateVariables["/_math2"].stateValues.modifyIndirectly).eq(true);
38
+ expect(stateVariables["/e1"].stateValues.modifyIndirectly).eq(false);
39
+ expect(stateVariables["/e2"].stateValues.modifyIndirectly).eq(true);
40
+ });
41
+ });
42
+
43
+ it("extract can overwrite basecomponent properties", () => {
44
+ cy.window().then(async (win) => {
45
+ win.postMessage(
46
+ {
47
+ doenetML: `
48
+ <text>a</text>
49
+ <extract modifyIndirectly="true" prop="latex" assignNames="e1"><math modifyIndirectly="false">x</math></extract>
50
+ <extract modifyIndirectly="false" prop="latex" assignNames="e2"><math modifyIndirectly="true">x</math></extract>
51
+ `,
52
+ },
53
+ "*",
54
+ );
55
+ });
56
+
57
+ cy.get(cesc("#\\/_text1")).should("have.text", "a"); // to wait until loaded
58
+
59
+ cy.log(`check properties`);
60
+ cy.window().then(async (win) => {
61
+ let stateVariables = await win.returnAllStateVariables1();
62
+ expect(stateVariables["/_math1"].stateValues.modifyIndirectly).eq(false);
63
+ expect(stateVariables["/_math2"].stateValues.modifyIndirectly).eq(true);
64
+ expect(stateVariables["/e1"].stateValues.modifyIndirectly).eq(true);
65
+ expect(stateVariables["/e2"].stateValues.modifyIndirectly).eq(false);
66
+ });
67
+ });
68
+
69
+ it("extract multiple tags", () => {
70
+ cy.window().then(async (win) => {
71
+ win.postMessage(
72
+ {
73
+ doenetML: `
74
+ <text>a</text>
75
+ <extract prop="y" assignNames="e1 e2 e3">
76
+ <point>(1,2)</point>
77
+ <point>(3,4)</point>
78
+ <point>(5,6)</point>
79
+ </extract>
80
+ `,
81
+ },
82
+ "*",
83
+ );
84
+ });
85
+
86
+ cy.get(cesc("#\\/_text1")).should("have.text", "a"); // to wait until loaded
87
+
88
+ cy.get(cesc("#\\/e1"))
89
+ .find(".mjx-mrow")
90
+ .eq(0)
91
+ .invoke("text")
92
+ .then((text) => {
93
+ expect(text.trim()).equal("2");
94
+ });
95
+ cy.get(cesc("#\\/e2"))
96
+ .find(".mjx-mrow")
97
+ .eq(0)
98
+ .invoke("text")
99
+ .then((text) => {
100
+ expect(text.trim()).equal("4");
101
+ });
102
+ cy.get(cesc("#\\/e3"))
103
+ .find(".mjx-mrow")
104
+ .eq(0)
105
+ .invoke("text")
106
+ .then((text) => {
107
+ expect(text.trim()).equal("6");
108
+ });
109
+
110
+ cy.log(`check properties`);
111
+ cy.window().then(async (win) => {
112
+ let stateVariables = await win.returnAllStateVariables1();
113
+ expect(stateVariables["/e1"].stateValues.value).eq(2);
114
+ expect(stateVariables["/e2"].stateValues.value).eq(4);
115
+ expect(stateVariables["/e3"].stateValues.value).eq(6);
116
+ });
117
+ });
118
+
119
+ it("extract still updatable", () => {
120
+ cy.window().then(async (win) => {
121
+ win.postMessage(
122
+ {
123
+ doenetML: `
124
+ <text>a</text>
125
+ <graph>
126
+ <copy assignNames="copy" target="original" />
127
+ <point name="transformed">
128
+ (<copy prop="y" target="copy2" />,
129
+ <extract prop="x1"><copy name="copy2" target="copy" /></extract>)
130
+ </point>
131
+ </graph>
132
+
133
+ <graph>
134
+ <point name="original">(1,2)</point>
135
+ </graph>
136
+ `,
137
+ },
138
+ "*",
139
+ );
140
+ });
141
+
142
+ cy.get(cesc("#\\/_text1")).should("have.text", "a"); // to wait until loaded
143
+
144
+ cy.log(`initial position`);
145
+ cy.window().then(async (win) => {
146
+ let stateVariables = await win.returnAllStateVariables1();
147
+ expect(stateVariables["/original"].stateValues.xs[0]).eq(1);
148
+ expect(stateVariables["/original"].stateValues.xs[1]).eq(2);
149
+ expect(stateVariables["/copy"].stateValues.xs[0]).eq(1);
150
+ expect(stateVariables["/copy"].stateValues.xs[1]).eq(2);
151
+ expect(stateVariables["/transformed"].stateValues.xs[0]).eq(2);
152
+ expect(stateVariables["/transformed"].stateValues.xs[1]).eq(1);
153
+ });
154
+
155
+ cy.log(`move original point`);
156
+ cy.window().then(async (win) => {
157
+ await win.callAction1({
158
+ actionName: "movePoint",
159
+ componentName: "/original",
160
+ args: { x: -3, y: 5 },
161
+ });
162
+ let stateVariables = await win.returnAllStateVariables1();
163
+ expect(stateVariables["/original"].stateValues.xs[0]).eq(-3);
164
+ expect(stateVariables["/original"].stateValues.xs[1]).eq(5);
165
+ expect(stateVariables["/copy"].stateValues.xs[0]).eq(-3);
166
+ expect(stateVariables["/copy"].stateValues.xs[1]).eq(5);
167
+ expect(stateVariables["/transformed"].stateValues.xs[0]).eq(5);
168
+ expect(stateVariables["/transformed"].stateValues.xs[1]).eq(-3);
169
+ });
170
+
171
+ cy.log(`move copy point`);
172
+ cy.window().then(async (win) => {
173
+ await win.callAction1({
174
+ actionName: "movePoint",
175
+ componentName: "/copy",
176
+ args: { x: 6, y: -9 },
177
+ });
178
+ let stateVariables = await win.returnAllStateVariables1();
179
+ expect(stateVariables["/original"].stateValues.xs[0]).eq(6);
180
+ expect(stateVariables["/original"].stateValues.xs[1]).eq(-9);
181
+ expect(stateVariables["/copy"].stateValues.xs[0]).eq(6);
182
+ expect(stateVariables["/copy"].stateValues.xs[1]).eq(-9);
183
+ expect(stateVariables["/transformed"].stateValues.xs[0]).eq(-9);
184
+ expect(stateVariables["/transformed"].stateValues.xs[1]).eq(6);
185
+ });
186
+
187
+ cy.log(`move transformed point`);
188
+ cy.window().then(async (win) => {
189
+ await win.callAction1({
190
+ actionName: "movePoint",
191
+ componentName: "/transformed",
192
+ args: { x: -1, y: -7 },
193
+ });
194
+ let stateVariables = await win.returnAllStateVariables1();
195
+ expect(stateVariables["/original"].stateValues.xs[0]).eq(-7);
196
+ expect(stateVariables["/original"].stateValues.xs[1]).eq(-1);
197
+ expect(stateVariables["/copy"].stateValues.xs[0]).eq(-7);
198
+ expect(stateVariables["/copy"].stateValues.xs[1]).eq(-1);
199
+ expect(stateVariables["/transformed"].stateValues.xs[0]).eq(-1);
200
+ expect(stateVariables["/transformed"].stateValues.xs[1]).eq(-7);
201
+ });
202
+ });
203
+
204
+ it("copy prop of extract", () => {
205
+ cy.window().then(async (win) => {
206
+ win.postMessage(
207
+ {
208
+ doenetML: `
209
+ <text>a</text>
210
+ <extract prop="center">
211
+ <circle through="$_point1 $_point2" />
212
+ </extract>
213
+
214
+ <copy assignNames="x1" prop="x" target="_extract1" />,
215
+ <copy assignNames="y1" prop="y" target="_extract1" />
216
+
217
+ <graph>
218
+ <point>(1,2)</point>
219
+ <point>(5,6)</point>
220
+ <copy assignNames="copiedextract" target="_extract1" />
221
+ </graph>
222
+
223
+ <copy assignNames="x2" prop="x" target="copiedextract" />,
224
+ <copy assignNames="y2" prop="y" target="copiedextract" />
225
+ `,
226
+ },
227
+ "*",
228
+ );
229
+ });
230
+
231
+ cy.get(cesc("#\\/_text1")).should("have.text", "a"); // to wait until loaded
232
+
233
+ cy.window().then(async (win) => {
234
+ let stateVariables = await win.returnAllStateVariables1();
235
+ expect(stateVariables["/x1"].stateValues.value).eq(3);
236
+ expect(stateVariables["/y1"].stateValues.value).eq(4);
237
+ expect(stateVariables["/x2"].stateValues.value).eq(3);
238
+ expect(stateVariables["/y2"].stateValues.value).eq(4);
239
+ });
240
+
241
+ cy.log("move extracted center");
242
+ cy.window().then(async (win) => {
243
+ await win.callAction1({
244
+ actionName: "movePoint",
245
+ componentName: "/copiedextract",
246
+ args: { x: -2, y: -5 },
247
+ });
248
+ let stateVariables = await win.returnAllStateVariables1();
249
+ expect(stateVariables["/x1"].stateValues.value).closeTo(-2, 1e-12);
250
+ expect(stateVariables["/y1"].stateValues.value).closeTo(-5, 1e-12);
251
+ expect(stateVariables["/x2"].stateValues.value).closeTo(-2, 1e-12);
252
+ expect(stateVariables["/y2"].stateValues.value).closeTo(-5, 1e-12);
253
+ expect(stateVariables["/_point1"].stateValues.xs[0]).closeTo(-4, 1e-12);
254
+ expect(stateVariables["/_point1"].stateValues.xs[1]).closeTo(-7, 1e-12);
255
+ expect(stateVariables["/_point2"].stateValues.xs[0]).closeTo(0, 1e-12);
256
+ expect(stateVariables["/_point2"].stateValues.xs[1]).closeTo(-3, 1e-12);
257
+ });
258
+
259
+ cy.log("move points 1 and 2");
260
+ cy.window().then(async (win) => {
261
+ await win.callAction1({
262
+ actionName: "movePoint",
263
+ componentName: "/_point1",
264
+ args: { x: 8, y: -1 },
265
+ });
266
+ await win.callAction1({
267
+ actionName: "movePoint",
268
+ componentName: "/_point2",
269
+ args: { x: -6, y: -7 },
270
+ });
271
+ let stateVariables = await win.returnAllStateVariables1();
272
+ expect(stateVariables["/x1"].stateValues.value).closeTo(1, 1e-12);
273
+ expect(stateVariables["/y1"].stateValues.value).closeTo(-4, 1e-12);
274
+ expect(stateVariables["/x2"].stateValues.value).closeTo(1, 1e-12);
275
+ expect(stateVariables["/y2"].stateValues.value).closeTo(-4, 1e-12);
276
+ });
277
+ });
278
+
279
+ it("extract from sequence", () => {
280
+ cy.window().then(async (win) => {
281
+ win.postMessage(
282
+ {
283
+ doenetML: `
284
+ <text>a</text>
285
+ <mathinput name="n"/>
286
+
287
+ <p><aslist>
288
+ <extract prop="text">
289
+ <sequence length="$n" />
290
+ </extract>
291
+ </aslist></p>
292
+
293
+ <p><aslist><copy target="_extract1" /></aslist></p>
294
+
295
+ <p><copy target="_aslist2" /></p>
296
+ `,
297
+ },
298
+ "*",
299
+ );
300
+ });
301
+
302
+ cy.get(cesc("#\\/_text1")).should("have.text", "a"); // to wait until loaded
303
+
304
+ cy.get(cesc("#\\/_p1")).should("have.text", "");
305
+ cy.get(cesc("#\\/_p2")).should("have.text", "");
306
+ cy.get(cesc("#\\/_p3")).should("have.text", "");
307
+
308
+ cy.window().then(async (win) => {
309
+ let stateVariables = await win.returnAllStateVariables1();
310
+ expect(
311
+ stateVariables["/_aslist1"].activeChildren.map((x) => x.componentType),
312
+ ).eqls([]);
313
+ expect(
314
+ stateVariables["/_aslist2"].activeChildren.map((x) => x.componentType),
315
+ ).eqls([]);
316
+ expect(
317
+ stateVariables[
318
+ stateVariables["/_p3"].activeChildren[0].componentName
319
+ ].activeChildren.map((x) => x.componentType),
320
+ ).eqls([]);
321
+ expect(
322
+ stateVariables["/_aslist1"].activeChildren.map(
323
+ (x) => stateVariables[x.componentName].stateValues.value,
324
+ ),
325
+ ).eqls([]);
326
+ expect(
327
+ stateVariables["/_aslist2"].activeChildren.map(
328
+ (x) => stateVariables[x.componentName].stateValues.value,
329
+ ),
330
+ ).eqls([]);
331
+ expect(
332
+ stateVariables[
333
+ stateVariables["/_p3"].activeChildren[0].componentName
334
+ ].activeChildren.map(
335
+ (x) => stateVariables[x.componentName].stateValues.value,
336
+ ),
337
+ ).eqls([]);
338
+ });
339
+
340
+ cy.log("set to 3");
341
+ cy.get(cesc("#\\/n") + " textarea").type(`3{enter}`, { force: true });
342
+ cy.get(cesc("#\\/_p1")).should("have.text", "1, 2, 3");
343
+ cy.get(cesc("#\\/_p2")).should("have.text", "1, 2, 3");
344
+ cy.get(cesc("#\\/_p3")).should("have.text", "1, 2, 3");
345
+
346
+ cy.window().then(async (win) => {
347
+ let stateVariables = await win.returnAllStateVariables1();
348
+ expect(
349
+ stateVariables["/_aslist1"].activeChildren.map((x) => x.componentType),
350
+ ).eqls(["text", "text", "text"]);
351
+ expect(
352
+ stateVariables["/_aslist2"].activeChildren.map((x) => x.componentType),
353
+ ).eqls(["text", "text", "text"]);
354
+ expect(
355
+ stateVariables[
356
+ stateVariables["/_p3"].activeChildren[0].componentName
357
+ ].activeChildren.map((x) => x.componentType),
358
+ ).eqls(["text", "text", "text"]);
359
+ expect(
360
+ stateVariables["/_aslist1"].activeChildren.map(
361
+ (x) => stateVariables[x.componentName].stateValues.value,
362
+ ),
363
+ ).eqls(["1", "2", "3"]);
364
+ expect(
365
+ stateVariables["/_aslist2"].activeChildren.map(
366
+ (x) => stateVariables[x.componentName].stateValues.value,
367
+ ),
368
+ ).eqls(["1", "2", "3"]);
369
+ expect(
370
+ stateVariables[
371
+ stateVariables["/_p3"].activeChildren[0].componentName
372
+ ].activeChildren.map(
373
+ (x) => stateVariables[x.componentName].stateValues.value,
374
+ ),
375
+ ).eqls(["1", "2", "3"]);
376
+ });
377
+
378
+ cy.log("increase to 4");
379
+ cy.get(cesc("#\\/n") + " textarea").type(`{end}{backspace}4{enter}`, {
380
+ force: true,
381
+ });
382
+ cy.get(cesc("#\\/_p1")).should("have.text", "1, 2, 3, 4");
383
+ cy.get(cesc("#\\/_p2")).should("have.text", "1, 2, 3, 4");
384
+ cy.get(cesc("#\\/_p3")).should("have.text", "1, 2, 3, 4");
385
+
386
+ cy.window().then(async (win) => {
387
+ let stateVariables = await win.returnAllStateVariables1();
388
+ expect(
389
+ stateVariables["/_aslist1"].activeChildren.map((x) => x.componentType),
390
+ ).eqls(["text", "text", "text", "text"]);
391
+ expect(
392
+ stateVariables["/_aslist2"].activeChildren.map((x) => x.componentType),
393
+ ).eqls(["text", "text", "text", "text"]);
394
+ expect(
395
+ stateVariables[
396
+ stateVariables["/_p3"].activeChildren[0].componentName
397
+ ].activeChildren.map((x) => x.componentType),
398
+ ).eqls(["text", "text", "text", "text"]);
399
+ expect(
400
+ stateVariables["/_aslist1"].activeChildren.map(
401
+ (x) => stateVariables[x.componentName].stateValues.value,
402
+ ),
403
+ ).eqls(["1", "2", "3", "4"]);
404
+ expect(
405
+ stateVariables["/_aslist2"].activeChildren.map(
406
+ (x) => stateVariables[x.componentName].stateValues.value,
407
+ ),
408
+ ).eqls(["1", "2", "3", "4"]);
409
+ expect(
410
+ stateVariables[
411
+ stateVariables["/_p3"].activeChildren[0].componentName
412
+ ].activeChildren.map(
413
+ (x) => stateVariables[x.componentName].stateValues.value,
414
+ ),
415
+ ).eqls(["1", "2", "3", "4"]);
416
+ });
417
+
418
+ cy.log("decrease to 2");
419
+ cy.get(cesc("#\\/n") + " textarea").type(`{end}{backspace}2{enter}`, {
420
+ force: true,
421
+ });
422
+ cy.get(cesc("#\\/_p1")).should("have.text", "1, 2");
423
+ cy.get(cesc("#\\/_p2")).should("have.text", "1, 2");
424
+ cy.get(cesc("#\\/_p3")).should("have.text", "1, 2");
425
+
426
+ cy.window().then(async (win) => {
427
+ let stateVariables = await win.returnAllStateVariables1();
428
+ expect(
429
+ stateVariables["/_aslist1"].activeChildren.map((x) => x.componentType),
430
+ ).eqls(["text", "text"]);
431
+ expect(
432
+ stateVariables["/_aslist2"].activeChildren.map((x) => x.componentType),
433
+ ).eqls(["text", "text"]);
434
+ expect(
435
+ stateVariables[
436
+ stateVariables["/_p3"].activeChildren[0].componentName
437
+ ].activeChildren.map((x) => x.componentType),
438
+ ).eqls(["text", "text"]);
439
+ expect(
440
+ stateVariables["/_aslist1"].activeChildren.map(
441
+ (x) => stateVariables[x.componentName].stateValues.value,
442
+ ),
443
+ ).eqls(["1", "2"]);
444
+ expect(
445
+ stateVariables["/_aslist2"].activeChildren.map(
446
+ (x) => stateVariables[x.componentName].stateValues.value,
447
+ ),
448
+ ).eqls(["1", "2"]);
449
+ expect(
450
+ stateVariables[
451
+ stateVariables["/_p3"].activeChildren[0].componentName
452
+ ].activeChildren.map(
453
+ (x) => stateVariables[x.componentName].stateValues.value,
454
+ ),
455
+ ).eqls(["1", "2"]);
456
+ });
457
+
458
+ cy.log("increase to 5");
459
+ cy.get(cesc("#\\/n") + " textarea").type(`{end}{backspace}5{enter}`, {
460
+ force: true,
461
+ });
462
+ cy.get(cesc("#\\/_p1")).should("have.text", "1, 2, 3, 4, 5");
463
+ cy.get(cesc("#\\/_p2")).should("have.text", "1, 2, 3, 4, 5");
464
+ cy.get(cesc("#\\/_p3")).should("have.text", "1, 2, 3, 4, 5");
465
+
466
+ cy.window().then(async (win) => {
467
+ let stateVariables = await win.returnAllStateVariables1();
468
+ expect(
469
+ stateVariables["/_aslist1"].activeChildren.map((x) => x.componentType),
470
+ ).eqls(["text", "text", "text", "text", "text"]);
471
+ expect(
472
+ stateVariables["/_aslist2"].activeChildren.map((x) => x.componentType),
473
+ ).eqls(["text", "text", "text", "text", "text"]);
474
+ expect(
475
+ stateVariables[
476
+ stateVariables["/_p3"].activeChildren[0].componentName
477
+ ].activeChildren.map((x) => x.componentType),
478
+ ).eqls(["text", "text", "text", "text", "text"]);
479
+ expect(
480
+ stateVariables["/_aslist1"].activeChildren.map(
481
+ (x) => stateVariables[x.componentName].stateValues.value,
482
+ ),
483
+ ).eqls(["1", "2", "3", "4", "5"]);
484
+ expect(
485
+ stateVariables["/_aslist2"].activeChildren.map(
486
+ (x) => stateVariables[x.componentName].stateValues.value,
487
+ ),
488
+ ).eqls(["1", "2", "3", "4", "5"]);
489
+ expect(
490
+ stateVariables[
491
+ stateVariables["/_p3"].activeChildren[0].componentName
492
+ ].activeChildren.map(
493
+ (x) => stateVariables[x.componentName].stateValues.value,
494
+ ),
495
+ ).eqls(["1", "2", "3", "4", "5"]);
496
+ });
497
+ });
498
+
499
+ it("extract from map", () => {
500
+ cy.window().then(async (win) => {
501
+ win.postMessage(
502
+ {
503
+ doenetML: `
504
+ <text>a</text>
505
+ <mathinput name="n" />
506
+ <mathinput name="m" />
507
+
508
+ <p><aslist>
509
+ <extract prop="x">
510
+ <map>
511
+ <template newnamespace><point>($a+<copy prop="value" target="../m" />,0)</point></template>
512
+ <sources alias="a">
513
+ <sequence length="$n" />
514
+ </sources>
515
+ </map>
516
+ </extract>
517
+ </aslist></p>
518
+
519
+ <p><aslist><copy target="_extract1" /></aslist></p>
520
+
521
+ <p><copy target="_aslist2" /></p>
522
+
523
+ <p><copy prop="value" target="n" assignNames="n2" />
524
+ <copy prop="value" target="m" assignNames="m2" /></p>
525
+ `,
526
+ },
527
+ "*",
528
+ );
529
+ });
530
+
531
+ cy.get(cesc("#\\/_text1")).should("have.text", "a"); // to wait until loaded
532
+
533
+ cy.get(cesc("#\\/_p1")).should("have.text", "");
534
+ cy.get(cesc("#\\/_p2")).should("have.text", "");
535
+ cy.get(cesc("#\\/_p3")).should("have.text", "");
536
+
537
+ cy.window().then(async (win) => {
538
+ let stateVariables = await win.returnAllStateVariables1();
539
+ expect(
540
+ stateVariables["/_aslist1"].activeChildren.map((x) => x.componentType),
541
+ ).eqls([]);
542
+ expect(
543
+ stateVariables["/_aslist2"].activeChildren.map((x) => x.componentType),
544
+ ).eqls([]);
545
+ expect(
546
+ stateVariables[
547
+ stateVariables["/_p3"].activeChildren[0].componentName
548
+ ].activeChildren.map((x) => x.componentType),
549
+ ).eqls([]);
550
+ expect(
551
+ stateVariables["/_aslist1"].activeChildren.map(
552
+ (x) => stateVariables[x.componentName].stateValues.value,
553
+ ),
554
+ ).eqls([]);
555
+ expect(
556
+ stateVariables["/_aslist2"].activeChildren.map(
557
+ (x) => stateVariables[x.componentName].stateValues.value,
558
+ ),
559
+ ).eqls([]);
560
+ expect(
561
+ stateVariables[
562
+ stateVariables["/_p3"].activeChildren[0].componentName
563
+ ].activeChildren.map(
564
+ (x) => stateVariables[x.componentName].stateValues.value,
565
+ ),
566
+ ).eqls([]);
567
+ });
568
+
569
+ cy.log("set n to 3");
570
+ cy.get(cesc("#\\/n") + " textarea").type(`3{enter}`, { force: true });
571
+ cy.get(cesc("#\\/n2")).should("contain.text", "3");
572
+ cy.window().then(async (win) => {
573
+ let stateVariables = await win.returnAllStateVariables1();
574
+ let aslist1 = stateVariables["/_p1"].activeChildren[0];
575
+ let aslist2 = stateVariables["/_p2"].activeChildren[0];
576
+ let aslist3 = stateVariables["/_p3"].activeChildren[0];
577
+ for (let i = 0; i < 3; i++) {
578
+ cy.get(
579
+ cesc2(
580
+ `#${
581
+ stateVariables[aslist1.componentName].activeChildren[i]
582
+ .componentName
583
+ }`,
584
+ ),
585
+ )
586
+ .find(".mjx-mrow")
587
+ .eq(0)
588
+ .invoke("text")
589
+ .then((text) => {
590
+ expect(text.trim()).equal(`${i + 1}+_`);
591
+ });
592
+ cy.get(
593
+ cesc2(
594
+ `#${
595
+ stateVariables[aslist2.componentName].activeChildren[i]
596
+ .componentName
597
+ }`,
598
+ ),
599
+ )
600
+ .find(".mjx-mrow")
601
+ .eq(0)
602
+ .invoke("text")
603
+ .then((text) => {
604
+ expect(text.trim()).equal(`${i + 1}+_`);
605
+ });
606
+ cy.get(
607
+ cesc2(
608
+ `#${
609
+ stateVariables[aslist3.componentName].activeChildren[i]
610
+ .componentName
611
+ }`,
612
+ ),
613
+ )
614
+ .find(".mjx-mrow")
615
+ .eq(0)
616
+ .invoke("text")
617
+ .then((text) => {
618
+ expect(text.trim()).equal(`${i + 1}+_`);
619
+ });
620
+ }
621
+
622
+ // Note: put in another .then so test execute in order they appear here
623
+ // (so easier to find test results)
624
+ cy.window().then(async (win) => {
625
+ let stateVariables = await win.returnAllStateVariables1();
626
+ expect(
627
+ stateVariables["/_aslist1"].activeChildren.map(
628
+ (x) => x.componentType,
629
+ ),
630
+ ).eqls(["math", "math", "math"]);
631
+ expect(
632
+ stateVariables["/_aslist2"].activeChildren.map(
633
+ (x) => x.componentType,
634
+ ),
635
+ ).eqls(["math", "math", "math"]);
636
+ expect(
637
+ stateVariables[
638
+ stateVariables["/_p3"].activeChildren[0].componentName
639
+ ].activeChildren.map((x) => x.componentType),
640
+ ).eqls(["math", "math", "math"]);
641
+ expect(
642
+ stateVariables["/_aslist1"].activeChildren.map(
643
+ (x) => stateVariables[x.componentName].stateValues.value,
644
+ ),
645
+ ).eqls([
646
+ ["+", 1, "_"],
647
+ ["+", 2, "_"],
648
+ ["+", 3, "_"],
649
+ ]);
650
+ expect(
651
+ stateVariables["/_aslist2"].activeChildren.map(
652
+ (x) => stateVariables[x.componentName].stateValues.value,
653
+ ),
654
+ ).eqls([
655
+ ["+", 1, "_"],
656
+ ["+", 2, "_"],
657
+ ["+", 3, "_"],
658
+ ]);
659
+ expect(
660
+ stateVariables[
661
+ stateVariables["/_p3"].activeChildren[0].componentName
662
+ ].activeChildren.map(
663
+ (x) => stateVariables[x.componentName].stateValues.value,
664
+ ),
665
+ ).eqls([
666
+ ["+", 1, "_"],
667
+ ["+", 2, "_"],
668
+ ["+", 3, "_"],
669
+ ]);
670
+ });
671
+ });
672
+
673
+ cy.log("set m to 7");
674
+ cy.get(cesc("#\\/m") + " textarea").type(`7{enter}`, { force: true });
675
+ cy.get(cesc("#\\/m2")).should("contain.text", "7");
676
+ cy.window().then(async (win) => {
677
+ let stateVariables = await win.returnAllStateVariables1();
678
+ let aslist1 = stateVariables["/_p1"].activeChildren[0];
679
+ let aslist2 = stateVariables["/_p2"].activeChildren[0];
680
+ let aslist3 = stateVariables["/_p3"].activeChildren[0];
681
+ for (let i = 0; i < 3; i++) {
682
+ cy.get(
683
+ cesc2(
684
+ `#${
685
+ stateVariables[aslist1.componentName].activeChildren[i]
686
+ .componentName
687
+ }`,
688
+ ),
689
+ )
690
+ .find(".mjx-mrow")
691
+ .eq(0)
692
+ .invoke("text")
693
+ .then((text) => {
694
+ expect(text.trim()).equal(`${i + 8}`);
695
+ });
696
+ cy.get(
697
+ cesc2(
698
+ `#${
699
+ stateVariables[aslist2.componentName].activeChildren[i]
700
+ .componentName
701
+ }`,
702
+ ),
703
+ )
704
+ .find(".mjx-mrow")
705
+ .eq(0)
706
+ .invoke("text")
707
+ .then((text) => {
708
+ expect(text.trim()).equal(`${i + 8}`);
709
+ });
710
+ cy.get(
711
+ cesc2(
712
+ `#${
713
+ stateVariables[aslist3.componentName].activeChildren[i]
714
+ .componentName
715
+ }`,
716
+ ),
717
+ )
718
+ .find(".mjx-mrow")
719
+ .eq(0)
720
+ .invoke("text")
721
+ .then((text) => {
722
+ expect(text.trim()).equal(`${i + 8}`);
723
+ });
724
+ }
725
+
726
+ // Note: put in another .then so test execute in order they appear here
727
+ // (so easier to find test results)
728
+ cy.window().then(async (win) => {
729
+ let stateVariables = await win.returnAllStateVariables1();
730
+ expect(
731
+ stateVariables["/_aslist1"].activeChildren.map(
732
+ (x) => x.componentType,
733
+ ),
734
+ ).eqls(["math", "math", "math"]);
735
+ expect(
736
+ stateVariables["/_aslist2"].activeChildren.map(
737
+ (x) => x.componentType,
738
+ ),
739
+ ).eqls(["math", "math", "math"]);
740
+ expect(
741
+ stateVariables[
742
+ stateVariables["/_p3"].activeChildren[0].componentName
743
+ ].activeChildren.map((x) => x.componentType),
744
+ ).eqls(["math", "math", "math"]);
745
+ expect(
746
+ stateVariables["/_aslist1"].activeChildren.map(
747
+ (x) => stateVariables[x.componentName].stateValues.value,
748
+ ),
749
+ ).eqls([8, 9, 10]);
750
+ expect(
751
+ stateVariables["/_aslist2"].activeChildren.map(
752
+ (x) => stateVariables[x.componentName].stateValues.value,
753
+ ),
754
+ ).eqls([8, 9, 10]);
755
+ expect(
756
+ stateVariables[
757
+ stateVariables["/_p3"].activeChildren[0].componentName
758
+ ].activeChildren.map(
759
+ (x) => stateVariables[x.componentName].stateValues.value,
760
+ ),
761
+ ).eqls([8, 9, 10]);
762
+ });
763
+ });
764
+
765
+ cy.log("increase n to 4");
766
+ cy.get(cesc("#\\/n") + " textarea").type(`{end}{backspace}4{enter}`, {
767
+ force: true,
768
+ });
769
+ cy.get(cesc("#\\/n2")).should("contain.text", "4");
770
+ cy.window().then(async (win) => {
771
+ let stateVariables = await win.returnAllStateVariables1();
772
+ let aslist1 = stateVariables["/_p1"].activeChildren[0];
773
+ let aslist2 = stateVariables["/_p2"].activeChildren[0];
774
+ let aslist3 = stateVariables["/_p3"].activeChildren[0];
775
+ for (let i = 0; i < 4; i++) {
776
+ cy.get(
777
+ cesc2(
778
+ `#${
779
+ stateVariables[aslist1.componentName].activeChildren[i]
780
+ .componentName
781
+ }`,
782
+ ),
783
+ )
784
+ .find(".mjx-mrow")
785
+ .eq(0)
786
+ .invoke("text")
787
+ .then((text) => {
788
+ expect(text.trim()).equal(`${i + 8}`);
789
+ });
790
+ cy.get(
791
+ cesc2(
792
+ `#${
793
+ stateVariables[aslist2.componentName].activeChildren[i]
794
+ .componentName
795
+ }`,
796
+ ),
797
+ )
798
+ .find(".mjx-mrow")
799
+ .eq(0)
800
+ .invoke("text")
801
+ .then((text) => {
802
+ expect(text.trim()).equal(`${i + 8}`);
803
+ });
804
+ cy.get(
805
+ cesc2(
806
+ `#${
807
+ stateVariables[aslist3.componentName].activeChildren[i]
808
+ .componentName
809
+ }`,
810
+ ),
811
+ )
812
+ .find(".mjx-mrow")
813
+ .eq(0)
814
+ .invoke("text")
815
+ .then((text) => {
816
+ expect(text.trim()).equal(`${i + 8}`);
817
+ });
818
+ }
819
+
820
+ // Note: put in another .then so test execute in order they appear here
821
+ // (so easier to find test results)
822
+ cy.window().then(async (win) => {
823
+ let stateVariables = await win.returnAllStateVariables1();
824
+ expect(
825
+ stateVariables["/_aslist1"].activeChildren.map(
826
+ (x) => x.componentType,
827
+ ),
828
+ ).eqls(["math", "math", "math", "math"]);
829
+ expect(
830
+ stateVariables["/_aslist2"].activeChildren.map(
831
+ (x) => x.componentType,
832
+ ),
833
+ ).eqls(["math", "math", "math", "math"]);
834
+ expect(
835
+ stateVariables[
836
+ stateVariables["/_p3"].activeChildren[0].componentName
837
+ ].activeChildren.map((x) => x.componentType),
838
+ ).eqls(["math", "math", "math", "math"]);
839
+ expect(
840
+ stateVariables["/_aslist1"].activeChildren.map(
841
+ (x) => stateVariables[x.componentName].stateValues.value,
842
+ ),
843
+ ).eqls([8, 9, 10, 11]);
844
+ expect(
845
+ stateVariables["/_aslist2"].activeChildren.map(
846
+ (x) => stateVariables[x.componentName].stateValues.value,
847
+ ),
848
+ ).eqls([8, 9, 10, 11]);
849
+ expect(
850
+ stateVariables[
851
+ stateVariables["/_p3"].activeChildren[0].componentName
852
+ ].activeChildren.map(
853
+ (x) => stateVariables[x.componentName].stateValues.value,
854
+ ),
855
+ ).eqls([8, 9, 10, 11]);
856
+ });
857
+ });
858
+
859
+ cy.log("change m to q");
860
+ cy.get(cesc("#\\/m") + " textarea").type(`{end}{backspace}q{enter}`, {
861
+ force: true,
862
+ });
863
+ cy.get(cesc("#\\/m2")).should("contain.text", "q");
864
+ cy.window().then(async (win) => {
865
+ let stateVariables = await win.returnAllStateVariables1();
866
+ let aslist1 = stateVariables["/_p1"].activeChildren[0];
867
+ let aslist2 = stateVariables["/_p2"].activeChildren[0];
868
+ let aslist3 = stateVariables["/_p3"].activeChildren[0];
869
+ for (let i = 0; i < 4; i++) {
870
+ cy.get(
871
+ cesc2(
872
+ `#${
873
+ stateVariables[aslist1.componentName].activeChildren[i]
874
+ .componentName
875
+ }`,
876
+ ),
877
+ )
878
+ .find(".mjx-mrow")
879
+ .eq(0)
880
+ .invoke("text")
881
+ .then((text) => {
882
+ expect(text.trim()).equal(`q+${i + 1}`);
883
+ });
884
+ cy.get(
885
+ cesc2(
886
+ `#${
887
+ stateVariables[aslist2.componentName].activeChildren[i]
888
+ .componentName
889
+ }`,
890
+ ),
891
+ )
892
+ .find(".mjx-mrow")
893
+ .eq(0)
894
+ .invoke("text")
895
+ .then((text) => {
896
+ expect(text.trim()).equal(`q+${i + 1}`);
897
+ });
898
+ cy.get(
899
+ cesc2(
900
+ `#${
901
+ stateVariables[aslist3.componentName].activeChildren[i]
902
+ .componentName
903
+ }`,
904
+ ),
905
+ )
906
+ .find(".mjx-mrow")
907
+ .eq(0)
908
+ .invoke("text")
909
+ .then((text) => {
910
+ expect(text.trim()).equal(`q+${i + 1}`);
911
+ });
912
+ }
913
+
914
+ // Note: put in another .then so test execute in order they appear here
915
+ // (so easier to find test results)
916
+ cy.window().then(async (win) => {
917
+ let stateVariables = await win.returnAllStateVariables1();
918
+ expect(
919
+ stateVariables["/_aslist1"].activeChildren.map(
920
+ (x) => x.componentType,
921
+ ),
922
+ ).eqls(["math", "math", "math", "math"]);
923
+ expect(
924
+ stateVariables["/_aslist2"].activeChildren.map(
925
+ (x) => x.componentType,
926
+ ),
927
+ ).eqls(["math", "math", "math", "math"]);
928
+ expect(
929
+ stateVariables[
930
+ stateVariables["/_p3"].activeChildren[0].componentName
931
+ ].activeChildren.map((x) => x.componentType),
932
+ ).eqls(["math", "math", "math", "math"]);
933
+ expect(
934
+ stateVariables["/_aslist1"].activeChildren.map(
935
+ (x) => stateVariables[x.componentName].stateValues.value,
936
+ ),
937
+ ).eqls([
938
+ ["+", "q", 1],
939
+ ["+", "q", 2],
940
+ ["+", "q", 3],
941
+ ["+", "q", 4],
942
+ ]);
943
+ expect(
944
+ stateVariables["/_aslist2"].activeChildren.map(
945
+ (x) => stateVariables[x.componentName].stateValues.value,
946
+ ),
947
+ ).eqls([
948
+ ["+", "q", 1],
949
+ ["+", "q", 2],
950
+ ["+", "q", 3],
951
+ ["+", "q", 4],
952
+ ]);
953
+ expect(
954
+ stateVariables[
955
+ stateVariables["/_p3"].activeChildren[0].componentName
956
+ ].activeChildren.map(
957
+ (x) => stateVariables[x.componentName].stateValues.value,
958
+ ),
959
+ ).eqls([
960
+ ["+", "q", 1],
961
+ ["+", "q", 2],
962
+ ["+", "q", 3],
963
+ ["+", "q", 4],
964
+ ]);
965
+ });
966
+ });
967
+
968
+ cy.log("decrease n to 2");
969
+ cy.get(cesc("#\\/n") + " textarea").type(`{end}{backspace}2{enter}`, {
970
+ force: true,
971
+ });
972
+ cy.get(cesc("#\\/n2")).should("contain.text", "2");
973
+ cy.window().then(async (win) => {
974
+ let stateVariables = await win.returnAllStateVariables1();
975
+ let aslist1 = stateVariables["/_p1"].activeChildren[0];
976
+ let aslist2 = stateVariables["/_p2"].activeChildren[0];
977
+ let aslist3 = stateVariables["/_p3"].activeChildren[0];
978
+ for (let i = 0; i < 2; i++) {
979
+ cy.get(
980
+ cesc2(
981
+ `#${
982
+ stateVariables[aslist1.componentName].activeChildren[i]
983
+ .componentName
984
+ }`,
985
+ ),
986
+ )
987
+ .find(".mjx-mrow")
988
+ .eq(0)
989
+ .invoke("text")
990
+ .then((text) => {
991
+ expect(text.trim()).equal(`q+${i + 1}`);
992
+ });
993
+ cy.get(
994
+ cesc2(
995
+ `#${
996
+ stateVariables[aslist2.componentName].activeChildren[i]
997
+ .componentName
998
+ }`,
999
+ ),
1000
+ )
1001
+ .find(".mjx-mrow")
1002
+ .eq(0)
1003
+ .invoke("text")
1004
+ .then((text) => {
1005
+ expect(text.trim()).equal(`q+${i + 1}`);
1006
+ });
1007
+ cy.get(
1008
+ cesc2(
1009
+ `#${
1010
+ stateVariables[aslist3.componentName].activeChildren[i]
1011
+ .componentName
1012
+ }`,
1013
+ ),
1014
+ )
1015
+ .find(".mjx-mrow")
1016
+ .eq(0)
1017
+ .invoke("text")
1018
+ .then((text) => {
1019
+ expect(text.trim()).equal(`q+${i + 1}`);
1020
+ });
1021
+ }
1022
+
1023
+ // Note: put in another .then so test execute in order they appear here
1024
+ // (so easier to find test results)
1025
+ cy.window().then(async (win) => {
1026
+ let stateVariables = await win.returnAllStateVariables1();
1027
+ expect(
1028
+ stateVariables["/_aslist1"].activeChildren.map(
1029
+ (x) => x.componentType,
1030
+ ),
1031
+ ).eqls(["math", "math"]);
1032
+ expect(
1033
+ stateVariables["/_aslist2"].activeChildren.map(
1034
+ (x) => x.componentType,
1035
+ ),
1036
+ ).eqls(["math", "math"]);
1037
+ expect(
1038
+ stateVariables[
1039
+ stateVariables["/_p3"].activeChildren[0].componentName
1040
+ ].activeChildren.map((x) => x.componentType),
1041
+ ).eqls(["math", "math"]);
1042
+ expect(
1043
+ stateVariables["/_aslist1"].activeChildren.map(
1044
+ (x) => stateVariables[x.componentName].stateValues.value,
1045
+ ),
1046
+ ).eqls([
1047
+ ["+", "q", 1],
1048
+ ["+", "q", 2],
1049
+ ]);
1050
+ expect(
1051
+ stateVariables["/_aslist2"].activeChildren.map(
1052
+ (x) => stateVariables[x.componentName].stateValues.value,
1053
+ ),
1054
+ ).eqls([
1055
+ ["+", "q", 1],
1056
+ ["+", "q", 2],
1057
+ ]);
1058
+ expect(
1059
+ stateVariables[
1060
+ stateVariables["/_p3"].activeChildren[0].componentName
1061
+ ].activeChildren.map(
1062
+ (x) => stateVariables[x.componentName].stateValues.value,
1063
+ ),
1064
+ ).eqls([
1065
+ ["+", "q", 1],
1066
+ ["+", "q", 2],
1067
+ ]);
1068
+ });
1069
+ });
1070
+
1071
+ cy.log("set m to -1");
1072
+ cy.get(cesc("#\\/m") + " textarea").type(`{end}{backspace}-1{enter}`, {
1073
+ force: true,
1074
+ });
1075
+ cy.get(cesc("#\\/m2")).should("contain.text", "−1");
1076
+ cy.window().then(async (win) => {
1077
+ let stateVariables = await win.returnAllStateVariables1();
1078
+ let aslist1 = stateVariables["/_p1"].activeChildren[0];
1079
+ let aslist2 = stateVariables["/_p2"].activeChildren[0];
1080
+ let aslist3 = stateVariables["/_p3"].activeChildren[0];
1081
+ for (let i = 0; i < 2; i++) {
1082
+ cy.get(
1083
+ cesc2(
1084
+ `#${
1085
+ stateVariables[aslist1.componentName].activeChildren[i]
1086
+ .componentName
1087
+ }`,
1088
+ ),
1089
+ )
1090
+ .find(".mjx-mrow")
1091
+ .eq(0)
1092
+ .invoke("text")
1093
+ .then((text) => {
1094
+ expect(text.trim()).equal(`${i}`);
1095
+ });
1096
+ cy.get(
1097
+ cesc2(
1098
+ `#${
1099
+ stateVariables[aslist2.componentName].activeChildren[i]
1100
+ .componentName
1101
+ }`,
1102
+ ),
1103
+ )
1104
+ .find(".mjx-mrow")
1105
+ .eq(0)
1106
+ .invoke("text")
1107
+ .then((text) => {
1108
+ expect(text.trim()).equal(`${i}`);
1109
+ });
1110
+ cy.get(
1111
+ cesc2(
1112
+ `#${
1113
+ stateVariables[aslist3.componentName].activeChildren[i]
1114
+ .componentName
1115
+ }`,
1116
+ ),
1117
+ )
1118
+ .find(".mjx-mrow")
1119
+ .eq(0)
1120
+ .invoke("text")
1121
+ .then((text) => {
1122
+ expect(text.trim()).equal(`${i}`);
1123
+ });
1124
+ }
1125
+
1126
+ // Note: put in another .then so test execute in order they appear here
1127
+ // (so easier to find test results)
1128
+ cy.window().then(async (win) => {
1129
+ let stateVariables = await win.returnAllStateVariables1();
1130
+ expect(
1131
+ stateVariables["/_aslist1"].activeChildren.map(
1132
+ (x) => x.componentType,
1133
+ ),
1134
+ ).eqls(["math", "math"]);
1135
+ expect(
1136
+ stateVariables["/_aslist2"].activeChildren.map(
1137
+ (x) => x.componentType,
1138
+ ),
1139
+ ).eqls(["math", "math"]);
1140
+ expect(
1141
+ stateVariables[
1142
+ stateVariables["/_p3"].activeChildren[0].componentName
1143
+ ].activeChildren.map((x) => x.componentType),
1144
+ ).eqls(["math", "math"]);
1145
+ expect(
1146
+ stateVariables["/_aslist1"].activeChildren.map(
1147
+ (x) => stateVariables[x.componentName].stateValues.value,
1148
+ ),
1149
+ ).eqls([0, 1]);
1150
+ expect(
1151
+ stateVariables["/_aslist2"].activeChildren.map(
1152
+ (x) => stateVariables[x.componentName].stateValues.value,
1153
+ ),
1154
+ ).eqls([0, 1]);
1155
+ expect(
1156
+ stateVariables[
1157
+ stateVariables["/_p3"].activeChildren[0].componentName
1158
+ ].activeChildren.map(
1159
+ (x) => stateVariables[x.componentName].stateValues.value,
1160
+ ),
1161
+ ).eqls([0, 1]);
1162
+ });
1163
+ });
1164
+
1165
+ cy.log("increase n to 5");
1166
+ cy.get(cesc("#\\/n") + " textarea").type(`{end}{backspace}5{enter}`, {
1167
+ force: true,
1168
+ });
1169
+ cy.get(cesc("#\\/n2")).should("contain.text", "5");
1170
+ cy.window().then(async (win) => {
1171
+ let stateVariables = await win.returnAllStateVariables1();
1172
+ let aslist1 = stateVariables["/_p1"].activeChildren[0];
1173
+ let aslist2 = stateVariables["/_p2"].activeChildren[0];
1174
+ let aslist3 = stateVariables["/_p3"].activeChildren[0];
1175
+ for (let i = 0; i < 5; i++) {
1176
+ cy.get(
1177
+ cesc2(
1178
+ `#${
1179
+ stateVariables[aslist1.componentName].activeChildren[i]
1180
+ .componentName
1181
+ }`,
1182
+ ),
1183
+ )
1184
+ .find(".mjx-mrow")
1185
+ .eq(0)
1186
+ .invoke("text")
1187
+ .then((text) => {
1188
+ expect(text.trim()).equal(`${i}`);
1189
+ });
1190
+ cy.get(
1191
+ cesc2(
1192
+ `#${
1193
+ stateVariables[aslist2.componentName].activeChildren[i]
1194
+ .componentName
1195
+ }`,
1196
+ ),
1197
+ )
1198
+ .find(".mjx-mrow")
1199
+ .eq(0)
1200
+ .invoke("text")
1201
+ .then((text) => {
1202
+ expect(text.trim()).equal(`${i}`);
1203
+ });
1204
+ cy.get(
1205
+ cesc2(
1206
+ `#${
1207
+ stateVariables[aslist3.componentName].activeChildren[i]
1208
+ .componentName
1209
+ }`,
1210
+ ),
1211
+ )
1212
+ .find(".mjx-mrow")
1213
+ .eq(0)
1214
+ .invoke("text")
1215
+ .then((text) => {
1216
+ expect(text.trim()).equal(`${i}`);
1217
+ });
1218
+ }
1219
+
1220
+ // Note: put in another .then so test execute in order they appear here
1221
+ // (so easier to find test results)
1222
+ cy.window().then(async (win) => {
1223
+ let stateVariables = await win.returnAllStateVariables1();
1224
+ expect(
1225
+ stateVariables["/_aslist1"].activeChildren.map(
1226
+ (x) => x.componentType,
1227
+ ),
1228
+ ).eqls(["math", "math", "math", "math", "math"]);
1229
+ expect(
1230
+ stateVariables["/_aslist2"].activeChildren.map(
1231
+ (x) => x.componentType,
1232
+ ),
1233
+ ).eqls(["math", "math", "math", "math", "math"]);
1234
+ expect(
1235
+ stateVariables[
1236
+ stateVariables["/_p3"].activeChildren[0].componentName
1237
+ ].activeChildren.map((x) => x.componentType),
1238
+ ).eqls(["math", "math", "math", "math", "math"]);
1239
+ expect(
1240
+ stateVariables["/_aslist1"].activeChildren.map(
1241
+ (x) => stateVariables[x.componentName].stateValues.value,
1242
+ ),
1243
+ ).eqls([0, 1, 2, 3, 4]);
1244
+ expect(
1245
+ stateVariables["/_aslist2"].activeChildren.map(
1246
+ (x) => stateVariables[x.componentName].stateValues.value,
1247
+ ),
1248
+ ).eqls([0, 1, 2, 3, 4]);
1249
+ expect(
1250
+ stateVariables[
1251
+ stateVariables["/_p3"].activeChildren[0].componentName
1252
+ ].activeChildren.map(
1253
+ (x) => stateVariables[x.componentName].stateValues.value,
1254
+ ),
1255
+ ).eqls([0, 1, 2, 3, 4]);
1256
+ });
1257
+ });
1258
+ });
1259
+
1260
+ // not sure if this is desired, but it is current behavior
1261
+ it("extract ignores hide", () => {
1262
+ cy.window().then(async (win) => {
1263
+ win.postMessage(
1264
+ {
1265
+ doenetML: `
1266
+ <text>a</text>
1267
+ <p>See hidden text: <extract prop="value"><text name="hidden" hide>secret</text></extract></p>
1268
+
1269
+ `,
1270
+ },
1271
+ "*",
1272
+ );
1273
+ });
1274
+
1275
+ // to wait for page to load
1276
+ cy.get(cesc("#\\/_text1")).should("have.text", "a");
1277
+
1278
+ cy.get(cesc("#\\/_p1")).should("have.text", "See hidden text: secret");
1279
+ });
1280
+
1281
+ it("extracts hide dynamically", () => {
1282
+ cy.window().then(async (win) => {
1283
+ win.postMessage(
1284
+ {
1285
+ doenetML: `
1286
+ <text>a</text>
1287
+
1288
+ <booleaninput name='h1' prefill="false" >
1289
+ <label>Hide first extract</label>
1290
+ </booleaninput>
1291
+ <booleaninput name='h2' prefill="true" >
1292
+ <label>Hide second extract</label>
1293
+ </booleaninput>
1294
+
1295
+ <p name="e1">extract 1: <extract hide="$h1" prop="value" ><text>hello</text></extract></p>
1296
+ <p name="e2">extract 2: <extract hide="$h2" prop="value" ><text>hello</text></extract></p>
1297
+ `,
1298
+ },
1299
+ "*",
1300
+ );
1301
+ });
1302
+
1303
+ cy.get(cesc("#\\/_text1")).should("have.text", "a"); // to wait for page to load
1304
+
1305
+ cy.get(cesc("#\\/e1")).should("have.text", "extract 1: hello");
1306
+ cy.get(cesc("#\\/e2")).should("have.text", "extract 2: ");
1307
+
1308
+ cy.get(cesc("#\\/h1")).click();
1309
+ cy.get(cesc("#\\/h2")).click();
1310
+
1311
+ cy.get(cesc("#\\/e1")).should("have.text", "extract 1: ");
1312
+ cy.get(cesc("#\\/e2")).should("have.text", "extract 2: hello");
1313
+
1314
+ cy.get(cesc("#\\/h1")).click();
1315
+ cy.get(cesc("#\\/h2")).click();
1316
+
1317
+ cy.get(cesc("#\\/e1")).should("have.text", "extract 1: hello");
1318
+ cy.get(cesc("#\\/e2")).should("have.text", "extract 2: ");
1319
+ });
1320
+
1321
+ it("extract componentIndex", () => {
1322
+ cy.window().then(async (win) => {
1323
+ win.postMessage(
1324
+ {
1325
+ doenetML: `
1326
+ <text>a</text>
1327
+
1328
+ <p>n: <mathinput name="n" /></p>
1329
+
1330
+ <graph name="g1">
1331
+ <point name="A">(1,2)</point>
1332
+ <point name="B">(3,4)</point>
1333
+ </graph>
1334
+
1335
+ <aslist name="al"><extract prop="x" componentIndex="$n" assignNames="Ax Bx">
1336
+ <collect name="col" componentTypes="point" target="g1" />
1337
+ </extract></aslist>
1338
+
1339
+ <copy target="al" name="al2" newNamespace />
1340
+
1341
+ `,
1342
+ },
1343
+ "*",
1344
+ );
1345
+ });
1346
+
1347
+ cy.get(cesc("#\\/_text1")).should("have.text", "a"); // to wait for page to load
1348
+
1349
+ let x1 = 1,
1350
+ y1 = 2,
1351
+ x2 = 3,
1352
+ y2 = 4;
1353
+
1354
+ cy.get(cesc("#\\/Ax") + " .mjx-mrow").should("not.exist");
1355
+ cy.get(cesc("#\\/al2\\/Ax") + " .mjx-mrow").should("not.exist");
1356
+ cy.get(cesc("#\\/Bx") + " .mjx-mrow").should("not.exist");
1357
+ cy.get(cesc("#\\/al2\\/Bx") + " .mjx-mrow").should("not.exist");
1358
+
1359
+ cy.window().then(async (win) => {
1360
+ let stateVariables = await win.returnAllStateVariables1();
1361
+ expect(stateVariables["/A"].stateValues.xs).eqls([x1, y1]);
1362
+ expect(stateVariables["/Ax"]).eq(undefined);
1363
+ expect(stateVariables["/al2/Ax"]).eq(undefined);
1364
+ expect(stateVariables["/Bx"]).eq(undefined);
1365
+ expect(stateVariables["/al2/Bx"]).eq(undefined);
1366
+ });
1367
+
1368
+ cy.log("restrict collection to first component");
1369
+
1370
+ cy.get(cesc("#\\/n") + " textarea").type("1{enter}", { force: true });
1371
+
1372
+ cy.get(cesc("#\\/Bx") + " .mjx-mrow").should("not.exist");
1373
+ cy.get(cesc("#\\/al2\\/Bx") + " .mjx-mrow").should("not.exist");
1374
+ cy.get(cesc("#\\/Ax") + " .mjx-mrow").should("contain.text", nInDOM(x1));
1375
+ cy.get(cesc("#\\/al2\\/Ax") + " .mjx-mrow").should(
1376
+ "contain.text",
1377
+ nInDOM(x1),
1378
+ );
1379
+
1380
+ cy.window().then(async (win) => {
1381
+ let stateVariables = await win.returnAllStateVariables1();
1382
+ expect(stateVariables["/A"].stateValues.xs).eqls([x1, y1]);
1383
+ expect(stateVariables["/B"].stateValues.xs).eqls([x2, y2]);
1384
+ expect(stateVariables["/Ax"].stateValues.value).eq(x1);
1385
+ expect(stateVariables["/al2/Ax"].stateValues.value).eq(x1);
1386
+ expect(stateVariables["/Bx"]).eq(undefined);
1387
+ expect(stateVariables["/al2/Bx"]).eq(undefined);
1388
+ });
1389
+
1390
+ cy.log("move point");
1391
+ cy.window().then(async (win) => {
1392
+ (x1 = 9), (y1 = -5);
1393
+ await win.callAction1({
1394
+ actionName: "movePoint",
1395
+ componentName: "/A",
1396
+ args: { x: x1, y: y1 },
1397
+ });
1398
+
1399
+ cy.get(cesc("#\\/Bx") + " .mjx-mrow").should("not.exist");
1400
+ cy.get(cesc("#\\/al2\\/Bx") + " .mjx-mrow").should("not.exist");
1401
+ cy.get(cesc("#\\/Ax") + " .mjx-mrow").should("contain.text", nInDOM(x1));
1402
+ cy.get(cesc("#\\/al2\\/Ax") + " .mjx-mrow").should(
1403
+ "contain.text",
1404
+ nInDOM(x1),
1405
+ );
1406
+
1407
+ cy.window().then(async (win) => {
1408
+ let stateVariables = await win.returnAllStateVariables1();
1409
+ expect(stateVariables["/A"].stateValues.xs).eqls([x1, y1]);
1410
+ expect(stateVariables["/B"].stateValues.xs).eqls([x2, y2]);
1411
+ expect(stateVariables["/Ax"].stateValues.value).eq(x1);
1412
+ expect(stateVariables["/al2/Ax"].stateValues.value).eq(x1);
1413
+ expect(stateVariables["/Bx"]).eq(undefined);
1414
+ expect(stateVariables["/al2/Bx"]).eq(undefined);
1415
+ });
1416
+ });
1417
+
1418
+ cy.log("restrict collection to second component");
1419
+
1420
+ cy.get(cesc("#\\/n") + " textarea").type("{end}{backspace}2{enter}", {
1421
+ force: true,
1422
+ });
1423
+
1424
+ cy.window().then(async (win) => {
1425
+ cy.get(cesc("#\\/Bx") + " .mjx-mrow").should("not.exist");
1426
+ cy.get(cesc("#\\/al2\\/Bx") + " .mjx-mrow").should("not.exist");
1427
+ cy.get(cesc("#\\/Ax") + " .mjx-mrow").should("contain.text", nInDOM(x2));
1428
+ cy.get(cesc("#\\/al2\\/Ax") + " .mjx-mrow").should(
1429
+ "contain.text",
1430
+ nInDOM(x2),
1431
+ );
1432
+
1433
+ cy.window().then(async (win) => {
1434
+ let stateVariables = await win.returnAllStateVariables1();
1435
+ expect(stateVariables["/A"].stateValues.xs).eqls([x1, y1]);
1436
+ expect(stateVariables["/B"].stateValues.xs).eqls([x2, y2]);
1437
+ expect(stateVariables["/Ax"].stateValues.value).eq(x2);
1438
+ expect(stateVariables["/al2/Ax"].stateValues.value).eq(x2);
1439
+ expect(stateVariables["/Bx"]).eq(undefined);
1440
+ expect(stateVariables["/al2/Bx"]).eq(undefined);
1441
+ });
1442
+ });
1443
+
1444
+ cy.log("move point");
1445
+ cy.window().then(async (win) => {
1446
+ (x2 = 0), (y2 = 8);
1447
+ await win.callAction1({
1448
+ actionName: "movePoint",
1449
+ componentName: "/B",
1450
+ args: { x: x2, y: y2 },
1451
+ });
1452
+
1453
+ cy.get(cesc("#\\/Bx") + " .mjx-mrow").should("not.exist");
1454
+ cy.get(cesc("#\\/al2\\/Bx") + " .mjx-mrow").should("not.exist");
1455
+ cy.get(cesc("#\\/Ax") + " .mjx-mrow").should("contain.text", nInDOM(x2));
1456
+ cy.get(cesc("#\\/al2\\/Ax") + " .mjx-mrow").should(
1457
+ "contain.text",
1458
+ nInDOM(x2),
1459
+ );
1460
+
1461
+ cy.window().then(async (win) => {
1462
+ let stateVariables = await win.returnAllStateVariables1();
1463
+ expect(stateVariables["/A"].stateValues.xs).eqls([x1, y1]);
1464
+ expect(stateVariables["/B"].stateValues.xs).eqls([x2, y2]);
1465
+ expect(stateVariables["/Ax"].stateValues.value).eq(x2);
1466
+ expect(stateVariables["/al2/Ax"].stateValues.value).eq(x2);
1467
+ expect(stateVariables["/Bx"]).eq(undefined);
1468
+ expect(stateVariables["/al2/Bx"]).eq(undefined);
1469
+ });
1470
+ });
1471
+ });
1472
+
1473
+ it("copy propIndex and componentIndex", () => {
1474
+ cy.window().then(async (win) => {
1475
+ win.postMessage(
1476
+ {
1477
+ doenetML: `
1478
+ <text>a</text>
1479
+
1480
+ <p>m: <mathinput name="m" /></p>
1481
+ <p>n: <mathinput name="n" /></p>
1482
+
1483
+ <graph name="g1">
1484
+ <point name="A">(1,2)</point>
1485
+ <point name="B">(3,4)</point>
1486
+ </graph>
1487
+
1488
+
1489
+ <p><aslist name="al"><extract prop="xs" componentIndex="$m" propIndex="$n" assignNames="n1 n2 n3 n4">
1490
+ <collect name="col" componentTypes="point" target="g1" assignNames="A1 B1" />
1491
+ </extract></aslist></p>
1492
+
1493
+ <p><copy target="al" name="al2" newNamespace /></p>
1494
+
1495
+ `,
1496
+ },
1497
+ "*",
1498
+ );
1499
+ });
1500
+
1501
+ cy.get(cesc("#\\/_text1")).should("have.text", "a"); // to wait for page to load
1502
+
1503
+ let x1 = 1,
1504
+ y1 = 2,
1505
+ x2 = 3,
1506
+ y2 = 4;
1507
+
1508
+ cy.get(cesc("#\\/n1") + " .mjx-mrow").should("not.exist");
1509
+ cy.get(cesc("#\\/n2") + " .mjx-mrow").should("not.exist");
1510
+ cy.get(cesc("#\\/n3") + " .mjx-mrow").should("not.exist");
1511
+ cy.get(cesc("#\\/n4") + " .mjx-mrow").should("not.exist");
1512
+ cy.get(cesc("#\\/al2\\/n1") + " .mjx-mrow").should("not.exist");
1513
+ cy.get(cesc("#\\/al2\\/n2") + " .mjx-mrow").should("not.exist");
1514
+ cy.get(cesc("#\\/al2\\/n3") + " .mjx-mrow").should("not.exist");
1515
+ cy.get(cesc("#\\/al2\\/n4") + " .mjx-mrow").should("not.exist");
1516
+
1517
+ cy.window().then(async (win) => {
1518
+ let stateVariables = await win.returnAllStateVariables1();
1519
+ expect(stateVariables["/A"].stateValues.xs).eqls([x1, y1]);
1520
+ expect(stateVariables["/B"].stateValues.xs).eqls([x2, y2]);
1521
+ expect(stateVariables["/n1"]).eq(undefined);
1522
+ expect(stateVariables["/n2"]).eq(undefined);
1523
+ expect(stateVariables["/n3"]).eq(undefined);
1524
+ expect(stateVariables["/n4"]).eq(undefined);
1525
+ expect(stateVariables["/al2/n1"]).eq(undefined);
1526
+ expect(stateVariables["/al2/n2"]).eq(undefined);
1527
+ expect(stateVariables["/al2/n3"]).eq(undefined);
1528
+ expect(stateVariables["/al2/n4"]).eq(undefined);
1529
+ });
1530
+
1531
+ cy.log("set propIndex to 1");
1532
+
1533
+ cy.get(cesc("#\\/n") + " textarea").type("1{enter}", { force: true });
1534
+
1535
+ cy.get(cesc("#\\/n1") + " .mjx-mrow").should("not.exist");
1536
+ cy.get(cesc("#\\/n2") + " .mjx-mrow").should("not.exist");
1537
+ cy.get(cesc("#\\/n3") + " .mjx-mrow").should("not.exist");
1538
+ cy.get(cesc("#\\/n4") + " .mjx-mrow").should("not.exist");
1539
+ cy.get(cesc("#\\/al2\\/n1") + " .mjx-mrow").should("not.exist");
1540
+ cy.get(cesc("#\\/al2\\/n2") + " .mjx-mrow").should("not.exist");
1541
+ cy.get(cesc("#\\/al2\\/n3") + " .mjx-mrow").should("not.exist");
1542
+ cy.get(cesc("#\\/al2\\/n4") + " .mjx-mrow").should("not.exist");
1543
+
1544
+ cy.window().then(async (win) => {
1545
+ let stateVariables = await win.returnAllStateVariables1();
1546
+ expect(stateVariables["/A"].stateValues.xs).eqls([x1, y1]);
1547
+ expect(stateVariables["/B"].stateValues.xs).eqls([x2, y2]);
1548
+ expect(stateVariables["/n1"]).eq(undefined);
1549
+ expect(stateVariables["/n2"]).eq(undefined);
1550
+ expect(stateVariables["/n3"]).eq(undefined);
1551
+ expect(stateVariables["/n4"]).eq(undefined);
1552
+ expect(stateVariables["/al2/n1"]).eq(undefined);
1553
+ expect(stateVariables["/al2/n2"]).eq(undefined);
1554
+ expect(stateVariables["/al2/n3"]).eq(undefined);
1555
+ expect(stateVariables["/al2/n4"]).eq(undefined);
1556
+ });
1557
+
1558
+ cy.log("move point 1");
1559
+ cy.window().then(async (win) => {
1560
+ (x1 = 9), (y1 = -5);
1561
+ await win.callAction1({
1562
+ actionName: "movePoint",
1563
+ componentName: "/A",
1564
+ args: { x: x1, y: y1 },
1565
+ });
1566
+
1567
+ cy.get(cesc("#\\/n1") + " .mjx-mrow").should("not.exist");
1568
+ cy.get(cesc("#\\/n2") + " .mjx-mrow").should("not.exist");
1569
+ cy.get(cesc("#\\/n3") + " .mjx-mrow").should("not.exist");
1570
+ cy.get(cesc("#\\/n4") + " .mjx-mrow").should("not.exist");
1571
+ cy.get(cesc("#\\/al2\\/n1") + " .mjx-mrow").should("not.exist");
1572
+ cy.get(cesc("#\\/al2\\/n2") + " .mjx-mrow").should("not.exist");
1573
+ cy.get(cesc("#\\/al2\\/n3") + " .mjx-mrow").should("not.exist");
1574
+ cy.get(cesc("#\\/al2\\/n4") + " .mjx-mrow").should("not.exist");
1575
+
1576
+ cy.window().then(async (win) => {
1577
+ let stateVariables = await win.returnAllStateVariables1();
1578
+ expect(stateVariables["/A"].stateValues.xs).eqls([x1, y1]);
1579
+ expect(stateVariables["/B"].stateValues.xs).eqls([x2, y2]);
1580
+ expect(stateVariables["/n1"]).eq(undefined);
1581
+ expect(stateVariables["/n2"]).eq(undefined);
1582
+ expect(stateVariables["/n3"]).eq(undefined);
1583
+ expect(stateVariables["/n4"]).eq(undefined);
1584
+ expect(stateVariables["/al2/n1"]).eq(undefined);
1585
+ expect(stateVariables["/al2/n2"]).eq(undefined);
1586
+ expect(stateVariables["/al2/n3"]).eq(undefined);
1587
+ expect(stateVariables["/al2/n4"]).eq(undefined);
1588
+ });
1589
+ });
1590
+
1591
+ cy.log("set componentIndex to 2");
1592
+
1593
+ cy.get(cesc("#\\/m") + " textarea").type("2{enter}", { force: true });
1594
+
1595
+ cy.window().then(async (win) => {
1596
+ cy.get(cesc("#\\/n1") + " .mjx-mrow").should("contain.text", nInDOM(x2));
1597
+ cy.get(cesc("#\\/n2") + " .mjx-mrow").should("not.exist");
1598
+ cy.get(cesc("#\\/n3") + " .mjx-mrow").should("not.exist");
1599
+ cy.get(cesc("#\\/n4") + " .mjx-mrow").should("not.exist");
1600
+ cy.get(cesc("#\\/al2\\/n1") + " .mjx-mrow").should(
1601
+ "contain.text",
1602
+ nInDOM(x2),
1603
+ );
1604
+ cy.get(cesc("#\\/al2\\/n2") + " .mjx-mrow").should("not.exist");
1605
+ cy.get(cesc("#\\/al2\\/n3") + " .mjx-mrow").should("not.exist");
1606
+ cy.get(cesc("#\\/al2\\/n4") + " .mjx-mrow").should("not.exist");
1607
+
1608
+ cy.window().then(async (win) => {
1609
+ let stateVariables = await win.returnAllStateVariables1();
1610
+ expect(stateVariables["/A"].stateValues.xs).eqls([x1, y1]);
1611
+ expect(stateVariables["/B"].stateValues.xs).eqls([x2, y2]);
1612
+ expect(stateVariables["/n1"].stateValues.value).eq(x2);
1613
+ expect(stateVariables["/n2"]).eq(undefined);
1614
+ expect(stateVariables["/n3"]).eq(undefined);
1615
+ expect(stateVariables["/n4"]).eq(undefined);
1616
+ expect(stateVariables["/al2/n1"].stateValues.value).eq(x2);
1617
+ expect(stateVariables["/al2/n2"]).eq(undefined);
1618
+ expect(stateVariables["/al2/n3"]).eq(undefined);
1619
+ expect(stateVariables["/al2/n4"]).eq(undefined);
1620
+ });
1621
+ });
1622
+
1623
+ cy.log("move point2");
1624
+ cy.window().then(async (win) => {
1625
+ (x2 = 0), (y2 = 8);
1626
+ await win.callAction1({
1627
+ actionName: "movePoint",
1628
+ componentName: "/B",
1629
+ args: { x: x2, y: y2 },
1630
+ });
1631
+
1632
+ cy.get(cesc("#\\/n1") + " .mjx-mrow").should("contain.text", nInDOM(x2));
1633
+ cy.get(cesc("#\\/n2") + " .mjx-mrow").should("not.exist");
1634
+ cy.get(cesc("#\\/n3") + " .mjx-mrow").should("not.exist");
1635
+ cy.get(cesc("#\\/n4") + " .mjx-mrow").should("not.exist");
1636
+ cy.get(cesc("#\\/al2\\/n1") + " .mjx-mrow").should(
1637
+ "contain.text",
1638
+ nInDOM(x2),
1639
+ );
1640
+ cy.get(cesc("#\\/al2\\/n2") + " .mjx-mrow").should("not.exist");
1641
+ cy.get(cesc("#\\/al2\\/n3") + " .mjx-mrow").should("not.exist");
1642
+ cy.get(cesc("#\\/al2\\/n4") + " .mjx-mrow").should("not.exist");
1643
+
1644
+ cy.window().then(async (win) => {
1645
+ let stateVariables = await win.returnAllStateVariables1();
1646
+ expect(stateVariables["/A"].stateValues.xs).eqls([x1, y1]);
1647
+ expect(stateVariables["/B"].stateValues.xs).eqls([x2, y2]);
1648
+ expect(stateVariables["/n1"].stateValues.value).eq(x2);
1649
+ expect(stateVariables["/n2"]).eq(undefined);
1650
+ expect(stateVariables["/n3"]).eq(undefined);
1651
+ expect(stateVariables["/n4"]).eq(undefined);
1652
+ expect(stateVariables["/al2/n1"].stateValues.value).eq(x2);
1653
+ expect(stateVariables["/al2/n2"]).eq(undefined);
1654
+ expect(stateVariables["/al2/n3"]).eq(undefined);
1655
+ expect(stateVariables["/al2/n4"]).eq(undefined);
1656
+ });
1657
+ });
1658
+
1659
+ cy.log("set propIndex to 2");
1660
+ cy.get(cesc("#\\/n") + " textarea").type("{end}{backspace}2{enter}", {
1661
+ force: true,
1662
+ });
1663
+
1664
+ cy.window().then(async (win) => {
1665
+ cy.get(cesc("#\\/n1") + " .mjx-mrow").should("contain.text", nInDOM(y2));
1666
+ cy.get(cesc("#\\/n2") + " .mjx-mrow").should("not.exist");
1667
+ cy.get(cesc("#\\/n3") + " .mjx-mrow").should("not.exist");
1668
+ cy.get(cesc("#\\/n4") + " .mjx-mrow").should("not.exist");
1669
+ cy.get(cesc("#\\/al2\\/n1") + " .mjx-mrow").should(
1670
+ "contain.text",
1671
+ nInDOM(y2),
1672
+ );
1673
+ cy.get(cesc("#\\/al2\\/n2") + " .mjx-mrow").should("not.exist");
1674
+ cy.get(cesc("#\\/al2\\/n3") + " .mjx-mrow").should("not.exist");
1675
+ cy.get(cesc("#\\/al2\\/n4") + " .mjx-mrow").should("not.exist");
1676
+
1677
+ cy.window().then(async (win) => {
1678
+ let stateVariables = await win.returnAllStateVariables1();
1679
+ expect(stateVariables["/A"].stateValues.xs).eqls([x1, y1]);
1680
+ expect(stateVariables["/B"].stateValues.xs).eqls([x2, y2]);
1681
+ expect(stateVariables["/n1"].stateValues.value).eq(y2);
1682
+ expect(stateVariables["/n2"]).eq(undefined);
1683
+ expect(stateVariables["/n3"]).eq(undefined);
1684
+ expect(stateVariables["/n4"]).eq(undefined);
1685
+ expect(stateVariables["/al2/n1"].stateValues.value).eq(y2);
1686
+ expect(stateVariables["/al2/n2"]).eq(undefined);
1687
+ expect(stateVariables["/al2/n3"]).eq(undefined);
1688
+ expect(stateVariables["/al2/n4"]).eq(undefined);
1689
+ });
1690
+ });
1691
+
1692
+ cy.log("set componentIndex to 1");
1693
+ cy.get(cesc("#\\/m") + " textarea").type("{end}{backspace}1{enter}", {
1694
+ force: true,
1695
+ });
1696
+
1697
+ cy.window().then(async (win) => {
1698
+ cy.get(cesc("#\\/n1") + " .mjx-mrow").should("contain.text", nInDOM(y1));
1699
+ cy.get(cesc("#\\/n2") + " .mjx-mrow").should("not.exist");
1700
+ cy.get(cesc("#\\/n3") + " .mjx-mrow").should("not.exist");
1701
+ cy.get(cesc("#\\/n4") + " .mjx-mrow").should("not.exist");
1702
+ cy.get(cesc("#\\/al2\\/n1") + " .mjx-mrow").should(
1703
+ "contain.text",
1704
+ nInDOM(y1),
1705
+ );
1706
+ cy.get(cesc("#\\/al2\\/n2") + " .mjx-mrow").should("not.exist");
1707
+ cy.get(cesc("#\\/al2\\/n3") + " .mjx-mrow").should("not.exist");
1708
+ cy.get(cesc("#\\/al2\\/n4") + " .mjx-mrow").should("not.exist");
1709
+
1710
+ cy.window().then(async (win) => {
1711
+ let stateVariables = await win.returnAllStateVariables1();
1712
+ expect(stateVariables["/A"].stateValues.xs).eqls([x1, y1]);
1713
+ expect(stateVariables["/B"].stateValues.xs).eqls([x2, y2]);
1714
+ expect(stateVariables["/n1"].stateValues.value).eq(y1);
1715
+ expect(stateVariables["/n2"]).eq(undefined);
1716
+ expect(stateVariables["/n3"]).eq(undefined);
1717
+ expect(stateVariables["/n4"]).eq(undefined);
1718
+ expect(stateVariables["/al2/n1"].stateValues.value).eq(y1);
1719
+ expect(stateVariables["/al2/n2"]).eq(undefined);
1720
+ expect(stateVariables["/al2/n3"]).eq(undefined);
1721
+ expect(stateVariables["/al2/n4"]).eq(undefined);
1722
+ });
1723
+ });
1724
+
1725
+ cy.log("set propIndex to 3");
1726
+ cy.get(cesc("#\\/n") + " textarea").type("{end}{backspace}3{enter}", {
1727
+ force: true,
1728
+ });
1729
+
1730
+ cy.window().then(async (win) => {
1731
+ cy.get(cesc("#\\/n1") + " .mjx-mrow").should("not.exist");
1732
+ cy.get(cesc("#\\/n2") + " .mjx-mrow").should("not.exist");
1733
+ cy.get(cesc("#\\/n3") + " .mjx-mrow").should("not.exist");
1734
+ cy.get(cesc("#\\/n4") + " .mjx-mrow").should("not.exist");
1735
+ cy.get(cesc("#\\/al2\\/n1") + " .mjx-mrow").should("not.exist");
1736
+ cy.get(cesc("#\\/al2\\/n2") + " .mjx-mrow").should("not.exist");
1737
+ cy.get(cesc("#\\/al2\\/n3") + " .mjx-mrow").should("not.exist");
1738
+ cy.get(cesc("#\\/al2\\/n4") + " .mjx-mrow").should("not.exist");
1739
+
1740
+ cy.window().then(async (win) => {
1741
+ let stateVariables = await win.returnAllStateVariables1();
1742
+ expect(stateVariables["/A"].stateValues.xs).eqls([x1, y1]);
1743
+ expect(stateVariables["/B"].stateValues.xs).eqls([x2, y2]);
1744
+ expect(stateVariables["/n1"]).eq(undefined);
1745
+ expect(stateVariables["/n2"]).eq(undefined);
1746
+ expect(stateVariables["/n3"]).eq(undefined);
1747
+ expect(stateVariables["/n4"]).eq(undefined);
1748
+ expect(stateVariables["/al2/n1"]).eq(undefined);
1749
+ expect(stateVariables["/al2/n2"]).eq(undefined);
1750
+ expect(stateVariables["/al2/n3"]).eq(undefined);
1751
+ expect(stateVariables["/al2/n4"]).eq(undefined);
1752
+ });
1753
+ });
1754
+
1755
+ cy.log("set propIndex to 1");
1756
+ cy.get(cesc("#\\/n") + " textarea").type("{end}{backspace}1{enter}", {
1757
+ force: true,
1758
+ });
1759
+
1760
+ cy.window().then(async (win) => {
1761
+ cy.get(cesc("#\\/n1") + " .mjx-mrow").should("contain.text", nInDOM(x1));
1762
+ cy.get(cesc("#\\/n2") + " .mjx-mrow").should("not.exist");
1763
+ cy.get(cesc("#\\/n3") + " .mjx-mrow").should("not.exist");
1764
+ cy.get(cesc("#\\/n4") + " .mjx-mrow").should("not.exist");
1765
+ cy.get(cesc("#\\/al2\\/n1") + " .mjx-mrow").should(
1766
+ "contain.text",
1767
+ nInDOM(x1),
1768
+ );
1769
+ cy.get(cesc("#\\/al2\\/n2") + " .mjx-mrow").should("not.exist");
1770
+ cy.get(cesc("#\\/al2\\/n3") + " .mjx-mrow").should("not.exist");
1771
+ cy.get(cesc("#\\/al2\\/n4") + " .mjx-mrow").should("not.exist");
1772
+
1773
+ cy.window().then(async (win) => {
1774
+ let stateVariables = await win.returnAllStateVariables1();
1775
+ expect(stateVariables["/A"].stateValues.xs).eqls([x1, y1]);
1776
+ expect(stateVariables["/B"].stateValues.xs).eqls([x2, y2]);
1777
+ expect(stateVariables["/n1"].stateValues.value).eq(x1);
1778
+ expect(stateVariables["/n2"]).eq(undefined);
1779
+ expect(stateVariables["/n3"]).eq(undefined);
1780
+ expect(stateVariables["/n4"]).eq(undefined);
1781
+ expect(stateVariables["/al2/n1"].stateValues.value).eq(x1);
1782
+ expect(stateVariables["/al2/n2"]).eq(undefined);
1783
+ expect(stateVariables["/al2/n3"]).eq(undefined);
1784
+ expect(stateVariables["/al2/n4"]).eq(undefined);
1785
+ });
1786
+ });
1787
+
1788
+ cy.log("set componentIndex to 3");
1789
+ cy.get(cesc("#\\/m") + " textarea").type("{end}{backspace}3{enter}", {
1790
+ force: true,
1791
+ });
1792
+
1793
+ cy.window().then(async (win) => {
1794
+ cy.get(cesc("#\\/n1") + " .mjx-mrow").should("not.exist");
1795
+ cy.get(cesc("#\\/n2") + " .mjx-mrow").should("not.exist");
1796
+ cy.get(cesc("#\\/n3") + " .mjx-mrow").should("not.exist");
1797
+ cy.get(cesc("#\\/n4") + " .mjx-mrow").should("not.exist");
1798
+ cy.get(cesc("#\\/al2\\/n1") + " .mjx-mrow").should("not.exist");
1799
+ cy.get(cesc("#\\/al2\\/n2") + " .mjx-mrow").should("not.exist");
1800
+ cy.get(cesc("#\\/al2\\/n3") + " .mjx-mrow").should("not.exist");
1801
+ cy.get(cesc("#\\/al2\\/n4") + " .mjx-mrow").should("not.exist");
1802
+
1803
+ cy.window().then(async (win) => {
1804
+ let stateVariables = await win.returnAllStateVariables1();
1805
+ expect(stateVariables["/A"].stateValues.xs).eqls([x1, y1]);
1806
+ expect(stateVariables["/B"].stateValues.xs).eqls([x2, y2]);
1807
+ expect(stateVariables["/n1"]).eq(undefined);
1808
+ expect(stateVariables["/n2"]).eq(undefined);
1809
+ expect(stateVariables["/n3"]).eq(undefined);
1810
+ expect(stateVariables["/n4"]).eq(undefined);
1811
+ expect(stateVariables["/al2/n1"]).eq(undefined);
1812
+ expect(stateVariables["/al2/n2"]).eq(undefined);
1813
+ expect(stateVariables["/al2/n3"]).eq(undefined);
1814
+ expect(stateVariables["/al2/n4"]).eq(undefined);
1815
+ });
1816
+ });
1817
+
1818
+ cy.log("set componentIndex to 2");
1819
+ cy.get(cesc("#\\/m") + " textarea").type("{end}{backspace}2{enter}", {
1820
+ force: true,
1821
+ });
1822
+
1823
+ cy.window().then(async (win) => {
1824
+ cy.get(cesc("#\\/n1") + " .mjx-mrow").should("contain.text", nInDOM(x2));
1825
+ cy.get(cesc("#\\/n2") + " .mjx-mrow").should("not.exist");
1826
+ cy.get(cesc("#\\/n3") + " .mjx-mrow").should("not.exist");
1827
+ cy.get(cesc("#\\/n4") + " .mjx-mrow").should("not.exist");
1828
+ cy.get(cesc("#\\/al2\\/n1") + " .mjx-mrow").should(
1829
+ "contain.text",
1830
+ nInDOM(x2),
1831
+ );
1832
+ cy.get(cesc("#\\/al2\\/n2") + " .mjx-mrow").should("not.exist");
1833
+ cy.get(cesc("#\\/al2\\/n3") + " .mjx-mrow").should("not.exist");
1834
+ cy.get(cesc("#\\/al2\\/n4") + " .mjx-mrow").should("not.exist");
1835
+
1836
+ cy.window().then(async (win) => {
1837
+ let stateVariables = await win.returnAllStateVariables1();
1838
+ expect(stateVariables["/A"].stateValues.xs).eqls([x1, y1]);
1839
+ expect(stateVariables["/B"].stateValues.xs).eqls([x2, y2]);
1840
+ expect(stateVariables["/n1"].stateValues.value).eq(x2);
1841
+ expect(stateVariables["/n2"]).eq(undefined);
1842
+ expect(stateVariables["/n3"]).eq(undefined);
1843
+ expect(stateVariables["/n4"]).eq(undefined);
1844
+ expect(stateVariables["/al2/n1"].stateValues.value).eq(x2);
1845
+ expect(stateVariables["/al2/n2"]).eq(undefined);
1846
+ expect(stateVariables["/al2/n3"]).eq(undefined);
1847
+ expect(stateVariables["/al2/n4"]).eq(undefined);
1848
+ });
1849
+ });
1850
+
1851
+ cy.log("clear propIndex");
1852
+ cy.get(cesc("#\\/n") + " textarea").type("{end}{backspace}{enter}", {
1853
+ force: true,
1854
+ });
1855
+
1856
+ cy.get(cesc("#\\/n1") + " .mjx-mrow").should("not.exist");
1857
+ cy.get(cesc("#\\/n2") + " .mjx-mrow").should("not.exist");
1858
+ cy.get(cesc("#\\/n3") + " .mjx-mrow").should("not.exist");
1859
+ cy.get(cesc("#\\/n4") + " .mjx-mrow").should("not.exist");
1860
+ cy.get(cesc("#\\/al2\\/n1") + " .mjx-mrow").should("not.exist");
1861
+ cy.get(cesc("#\\/al2\\/n2") + " .mjx-mrow").should("not.exist");
1862
+ cy.get(cesc("#\\/al2\\/n3") + " .mjx-mrow").should("not.exist");
1863
+ cy.get(cesc("#\\/al2\\/n4") + " .mjx-mrow").should("not.exist");
1864
+
1865
+ cy.window().then(async (win) => {
1866
+ let stateVariables = await win.returnAllStateVariables1();
1867
+ expect(stateVariables["/A"].stateValues.xs).eqls([x1, y1]);
1868
+ expect(stateVariables["/B"].stateValues.xs).eqls([x2, y2]);
1869
+ expect(stateVariables["/n1"]).eq(undefined);
1870
+ expect(stateVariables["/n2"]).eq(undefined);
1871
+ expect(stateVariables["/n3"]).eq(undefined);
1872
+ expect(stateVariables["/n4"]).eq(undefined);
1873
+ expect(stateVariables["/al2/n1"]).eq(undefined);
1874
+ expect(stateVariables["/al2/n2"]).eq(undefined);
1875
+ expect(stateVariables["/al2/n3"]).eq(undefined);
1876
+ expect(stateVariables["/al2/n4"]).eq(undefined);
1877
+ });
1878
+ });
1879
+
1880
+ it("copy multidimensional propIndex", () => {
1881
+ cy.window().then(async (win) => {
1882
+ win.postMessage(
1883
+ {
1884
+ doenetML: `
1885
+ <text>a</text>
1886
+
1887
+ <p>m: <mathinput name="m" /></p>
1888
+ <p>n: <mathinput name="n" /></p>
1889
+
1890
+ <graph name="g1">
1891
+ <polygon vertices="(1,2) (3,4) (-5,6)" name="pg" />
1892
+ </graph>
1893
+
1894
+
1895
+ <p name="p1"><extract prop="vertices" propIndex="$m $n" assignNames="n1 n2">
1896
+ $pg
1897
+ </extract></p>
1898
+
1899
+ <p copySource="p1" name="p2" newNamespace />
1900
+
1901
+ `,
1902
+ },
1903
+ "*",
1904
+ );
1905
+ });
1906
+
1907
+ cy.get(cesc("#\\/_text1")).should("have.text", "a"); // to wait for page to load
1908
+
1909
+ let x1 = 1,
1910
+ y1 = 2,
1911
+ x2 = 3,
1912
+ y2 = 4,
1913
+ x3 = -5,
1914
+ y3 = 6;
1915
+
1916
+ cy.get(cesc("#\\/n1") + " .mjx-mrow").should("not.exist");
1917
+ cy.get(cesc("#\\/n2") + " .mjx-mrow").should("not.exist");
1918
+ cy.get(cesc("#\\/p2\\/n1") + " .mjx-mrow").should("not.exist");
1919
+ cy.get(cesc("#\\/p2\\/n2") + " .mjx-mrow").should("not.exist");
1920
+
1921
+ cy.window().then(async (win) => {
1922
+ let stateVariables = await win.returnAllStateVariables1();
1923
+ expect(stateVariables["/pg"].stateValues.vertices).eqls([
1924
+ [x1, y1],
1925
+ [x2, y2],
1926
+ [x3, y3],
1927
+ ]);
1928
+ expect(stateVariables["/n1"]).eq(undefined);
1929
+ expect(stateVariables["/n2"]).eq(undefined);
1930
+ expect(stateVariables["/p2/n1"]).eq(undefined);
1931
+ expect(stateVariables["/p2/n2"]).eq(undefined);
1932
+ });
1933
+
1934
+ cy.log("set second propIndex to 1");
1935
+
1936
+ cy.get(cesc("#\\/n") + " textarea").type("1{enter}", { force: true });
1937
+
1938
+ cy.get(cesc("#\\/n1") + " .mjx-mrow").should("not.exist");
1939
+ cy.get(cesc("#\\/n2") + " .mjx-mrow").should("not.exist");
1940
+ cy.get(cesc("#\\/p2\\/n1") + " .mjx-mrow").should("not.exist");
1941
+ cy.get(cesc("#\\/p2\\/n2") + " .mjx-mrow").should("not.exist");
1942
+
1943
+ cy.window().then(async (win) => {
1944
+ let stateVariables = await win.returnAllStateVariables1();
1945
+ expect(stateVariables["/pg"].stateValues.vertices).eqls([
1946
+ [x1, y1],
1947
+ [x2, y2],
1948
+ [x3, y3],
1949
+ ]);
1950
+ expect(stateVariables["/n1"]).eq(undefined);
1951
+ expect(stateVariables["/n2"]).eq(undefined);
1952
+ expect(stateVariables["/p2/n1"]).eq(undefined);
1953
+ expect(stateVariables["/p2/n2"]).eq(undefined);
1954
+ });
1955
+
1956
+ cy.log("move first point");
1957
+ cy.window().then(async (win) => {
1958
+ (x1 = 9), (y1 = -5);
1959
+ await win.callAction1({
1960
+ actionName: "movePolygon",
1961
+ componentName: "/pg",
1962
+ args: {
1963
+ pointCoords: { 0: [x1, y1] },
1964
+ },
1965
+ });
1966
+
1967
+ cy.get(cesc("#\\/n1") + " .mjx-mrow").should("not.exist");
1968
+ cy.get(cesc("#\\/n2") + " .mjx-mrow").should("not.exist");
1969
+ cy.get(cesc("#\\/p2\\/n1") + " .mjx-mrow").should("not.exist");
1970
+ cy.get(cesc("#\\/p2\\/n2") + " .mjx-mrow").should("not.exist");
1971
+
1972
+ cy.window().then(async (win) => {
1973
+ let stateVariables = await win.returnAllStateVariables1();
1974
+ expect(stateVariables["/pg"].stateValues.vertices).eqls([
1975
+ [x1, y1],
1976
+ [x2, y2],
1977
+ [x3, y3],
1978
+ ]);
1979
+ expect(stateVariables["/n1"]).eq(undefined);
1980
+ expect(stateVariables["/n2"]).eq(undefined);
1981
+ expect(stateVariables["/p2/n1"]).eq(undefined);
1982
+ expect(stateVariables["/p2/n2"]).eq(undefined);
1983
+ });
1984
+ });
1985
+
1986
+ cy.log("set first propIndex to 2");
1987
+
1988
+ cy.get(cesc("#\\/m") + " textarea").type("2{enter}", { force: true });
1989
+
1990
+ cy.window().then(async (win) => {
1991
+ cy.get(cesc("#\\/n1") + " .mjx-mrow").should("contain.text", nInDOM(x2));
1992
+ cy.get(cesc("#\\/n2") + " .mjx-mrow").should("not.exist");
1993
+ cy.get(cesc("#\\/p2\\/n1") + " .mjx-mrow").should(
1994
+ "contain.text",
1995
+ nInDOM(x2),
1996
+ );
1997
+ cy.get(cesc("#\\/p2\\/n2") + " .mjx-mrow").should("not.exist");
1998
+
1999
+ cy.window().then(async (win) => {
2000
+ let stateVariables = await win.returnAllStateVariables1();
2001
+ expect(stateVariables["/pg"].stateValues.vertices).eqls([
2002
+ [x1, y1],
2003
+ [x2, y2],
2004
+ [x3, y3],
2005
+ ]);
2006
+ expect(stateVariables["/n1"].stateValues.value).eq(x2);
2007
+ expect(stateVariables["/n2"]).eq(undefined);
2008
+ expect(stateVariables["/p2/n1"].stateValues.value).eq(x2);
2009
+ expect(stateVariables["/p2/n2"]).eq(undefined);
2010
+ });
2011
+ });
2012
+
2013
+ cy.log("move second point");
2014
+ cy.window().then(async (win) => {
2015
+ (x2 = 0), (y2 = 8);
2016
+ await win.callAction1({
2017
+ actionName: "movePolygon",
2018
+ componentName: "/pg",
2019
+ args: {
2020
+ pointCoords: { 1: [x2, y2] },
2021
+ },
2022
+ });
2023
+
2024
+ cy.get(cesc("#\\/n1") + " .mjx-mrow").should("contain.text", nInDOM(x2));
2025
+ cy.get(cesc("#\\/n2") + " .mjx-mrow").should("not.exist");
2026
+ cy.get(cesc("#\\/p2\\/n1") + " .mjx-mrow").should(
2027
+ "contain.text",
2028
+ nInDOM(x2),
2029
+ );
2030
+ cy.get(cesc("#\\/p2\\/n2") + " .mjx-mrow").should("not.exist");
2031
+
2032
+ cy.window().then(async (win) => {
2033
+ let stateVariables = await win.returnAllStateVariables1();
2034
+ expect(stateVariables["/pg"].stateValues.vertices).eqls([
2035
+ [x1, y1],
2036
+ [x2, y2],
2037
+ [x3, y3],
2038
+ ]);
2039
+ expect(stateVariables["/n1"].stateValues.value).eq(x2);
2040
+ expect(stateVariables["/n2"]).eq(undefined);
2041
+ expect(stateVariables["/p2/n1"].stateValues.value).eq(x2);
2042
+ expect(stateVariables["/p2/n2"]).eq(undefined);
2043
+ });
2044
+ });
2045
+
2046
+ cy.log("set second propIndex to 2");
2047
+ cy.get(cesc("#\\/n") + " textarea").type("{end}{backspace}2{enter}", {
2048
+ force: true,
2049
+ });
2050
+
2051
+ cy.window().then(async (win) => {
2052
+ cy.get(cesc("#\\/n1") + " .mjx-mrow").should("contain.text", nInDOM(y2));
2053
+ cy.get(cesc("#\\/n2") + " .mjx-mrow").should("not.exist");
2054
+ cy.get(cesc("#\\/p2\\/n1") + " .mjx-mrow").should(
2055
+ "contain.text",
2056
+ nInDOM(y2),
2057
+ );
2058
+ cy.get(cesc("#\\/p2\\/n2") + " .mjx-mrow").should("not.exist");
2059
+
2060
+ cy.window().then(async (win) => {
2061
+ let stateVariables = await win.returnAllStateVariables1();
2062
+ expect(stateVariables["/pg"].stateValues.vertices).eqls([
2063
+ [x1, y1],
2064
+ [x2, y2],
2065
+ [x3, y3],
2066
+ ]);
2067
+ expect(stateVariables["/n1"].stateValues.value).eq(y2);
2068
+ expect(stateVariables["/n2"]).eq(undefined);
2069
+ expect(stateVariables["/p2/n1"].stateValues.value).eq(y2);
2070
+ expect(stateVariables["/p2/n2"]).eq(undefined);
2071
+ });
2072
+ });
2073
+
2074
+ cy.log("set first propIndex to 1");
2075
+ cy.get(cesc("#\\/m") + " textarea").type("{end}{backspace}1{enter}", {
2076
+ force: true,
2077
+ });
2078
+
2079
+ cy.window().then(async (win) => {
2080
+ cy.get(cesc("#\\/n1") + " .mjx-mrow").should("contain.text", nInDOM(y1));
2081
+ cy.get(cesc("#\\/n2") + " .mjx-mrow").should("not.exist");
2082
+ cy.get(cesc("#\\/p2\\/n1") + " .mjx-mrow").should(
2083
+ "contain.text",
2084
+ nInDOM(y1),
2085
+ );
2086
+ cy.get(cesc("#\\/p2\\/n2") + " .mjx-mrow").should("not.exist");
2087
+
2088
+ cy.window().then(async (win) => {
2089
+ let stateVariables = await win.returnAllStateVariables1();
2090
+ expect(stateVariables["/pg"].stateValues.vertices).eqls([
2091
+ [x1, y1],
2092
+ [x2, y2],
2093
+ [x3, y3],
2094
+ ]);
2095
+ expect(stateVariables["/n1"].stateValues.value).eq(y1);
2096
+ expect(stateVariables["/n2"]).eq(undefined);
2097
+ expect(stateVariables["/p2/n1"].stateValues.value).eq(y1);
2098
+ expect(stateVariables["/p2/n2"]).eq(undefined);
2099
+ });
2100
+ });
2101
+
2102
+ cy.log("set second propIndex to 3");
2103
+ cy.get(cesc("#\\/n") + " textarea").type("{end}{backspace}3{enter}", {
2104
+ force: true,
2105
+ });
2106
+
2107
+ cy.window().then(async (win) => {
2108
+ cy.get(cesc("#\\/n1") + " .mjx-mrow").should("not.exist");
2109
+ cy.get(cesc("#\\/n2") + " .mjx-mrow").should("not.exist");
2110
+ cy.get(cesc("#\\/p2\\/n1") + " .mjx-mrow").should("not.exist");
2111
+ cy.get(cesc("#\\/p2\\/n2") + " .mjx-mrow").should("not.exist");
2112
+
2113
+ cy.window().then(async (win) => {
2114
+ let stateVariables = await win.returnAllStateVariables1();
2115
+ expect(stateVariables["/pg"].stateValues.vertices).eqls([
2116
+ [x1, y1],
2117
+ [x2, y2],
2118
+ [x3, y3],
2119
+ ]);
2120
+ expect(stateVariables["/n1"]).eq(undefined);
2121
+ expect(stateVariables["/n2"]).eq(undefined);
2122
+ expect(stateVariables["/p2/n1"]).eq(undefined);
2123
+ expect(stateVariables["/p2/n2"]).eq(undefined);
2124
+ });
2125
+ });
2126
+
2127
+ cy.log("set second propIndex to 1");
2128
+ cy.get(cesc("#\\/n") + " textarea").type("{end}{backspace}1{enter}", {
2129
+ force: true,
2130
+ });
2131
+
2132
+ cy.window().then(async (win) => {
2133
+ cy.get(cesc("#\\/n1") + " .mjx-mrow").should("contain.text", nInDOM(x1));
2134
+ cy.get(cesc("#\\/n2") + " .mjx-mrow").should("not.exist");
2135
+ cy.get(cesc("#\\/p2\\/n1") + " .mjx-mrow").should(
2136
+ "contain.text",
2137
+ nInDOM(x1),
2138
+ );
2139
+ cy.get(cesc("#\\/p2\\/n2") + " .mjx-mrow").should("not.exist");
2140
+
2141
+ cy.window().then(async (win) => {
2142
+ let stateVariables = await win.returnAllStateVariables1();
2143
+ expect(stateVariables["/pg"].stateValues.vertices).eqls([
2144
+ [x1, y1],
2145
+ [x2, y2],
2146
+ [x3, y3],
2147
+ ]);
2148
+ expect(stateVariables["/n1"].stateValues.value).eq(x1);
2149
+ expect(stateVariables["/n2"]).eq(undefined);
2150
+ expect(stateVariables["/p2/n1"].stateValues.value).eq(x1);
2151
+ expect(stateVariables["/p2/n2"]).eq(undefined);
2152
+ });
2153
+ });
2154
+
2155
+ cy.log("set first propindex to 4");
2156
+ cy.get(cesc("#\\/m") + " textarea").type("{end}{backspace}4{enter}", {
2157
+ force: true,
2158
+ });
2159
+
2160
+ cy.window().then(async (win) => {
2161
+ cy.get(cesc("#\\/n1") + " .mjx-mrow").should("not.exist");
2162
+ cy.get(cesc("#\\/n2") + " .mjx-mrow").should("not.exist");
2163
+ cy.get(cesc("#\\/p2\\/n1") + " .mjx-mrow").should("not.exist");
2164
+ cy.get(cesc("#\\/p2\\/n2") + " .mjx-mrow").should("not.exist");
2165
+
2166
+ cy.window().then(async (win) => {
2167
+ let stateVariables = await win.returnAllStateVariables1();
2168
+ expect(stateVariables["/pg"].stateValues.vertices).eqls([
2169
+ [x1, y1],
2170
+ [x2, y2],
2171
+ [x3, y3],
2172
+ ]);
2173
+ expect(stateVariables["/n1"]).eq(undefined);
2174
+ expect(stateVariables["/n2"]).eq(undefined);
2175
+ expect(stateVariables["/p2/n1"]).eq(undefined);
2176
+ expect(stateVariables["/p2/n2"]).eq(undefined);
2177
+ });
2178
+ });
2179
+
2180
+ cy.log("set first propIndex to 3");
2181
+ cy.get(cesc("#\\/m") + " textarea").type("{end}{backspace}3{enter}", {
2182
+ force: true,
2183
+ });
2184
+
2185
+ cy.window().then(async (win) => {
2186
+ cy.get(cesc("#\\/n1") + " .mjx-mrow").should("contain.text", nInDOM(x3));
2187
+ cy.get(cesc("#\\/n2") + " .mjx-mrow").should("not.exist");
2188
+ cy.get(cesc("#\\/p2\\/n1") + " .mjx-mrow").should(
2189
+ "contain.text",
2190
+ nInDOM(x3),
2191
+ );
2192
+ cy.get(cesc("#\\/p2\\/n2") + " .mjx-mrow").should("not.exist");
2193
+
2194
+ cy.window().then(async (win) => {
2195
+ let stateVariables = await win.returnAllStateVariables1();
2196
+ expect(stateVariables["/pg"].stateValues.vertices).eqls([
2197
+ [x1, y1],
2198
+ [x2, y2],
2199
+ [x3, y3],
2200
+ ]);
2201
+ expect(stateVariables["/n1"].stateValues.value).eq(x3);
2202
+ expect(stateVariables["/n2"]).eq(undefined);
2203
+ expect(stateVariables["/p2/n1"].stateValues.value).eq(x3);
2204
+ expect(stateVariables["/p2/n2"]).eq(undefined);
2205
+ });
2206
+ });
2207
+
2208
+ cy.log("clear second propIndex");
2209
+ cy.get(cesc("#\\/n") + " textarea").type("{end}{backspace}{enter}", {
2210
+ force: true,
2211
+ });
2212
+
2213
+ cy.get(cesc("#\\/n1") + " .mjx-mrow").should("not.exist");
2214
+ cy.get(cesc("#\\/n2") + " .mjx-mrow").should("not.exist");
2215
+ cy.get(cesc("#\\/p2\\/n1") + " .mjx-mrow").should("not.exist");
2216
+ cy.get(cesc("#\\/p2\\/n2") + " .mjx-mrow").should("not.exist");
2217
+
2218
+ cy.window().then(async (win) => {
2219
+ let stateVariables = await win.returnAllStateVariables1();
2220
+ expect(stateVariables["/pg"].stateValues.vertices).eqls([
2221
+ [x1, y1],
2222
+ [x2, y2],
2223
+ [x3, y3],
2224
+ ]);
2225
+ expect(stateVariables["/n1"]).eq(undefined);
2226
+ expect(stateVariables["/n2"]).eq(undefined);
2227
+ expect(stateVariables["/p2/n1"]).eq(undefined);
2228
+ expect(stateVariables["/p2/n2"]).eq(undefined);
2229
+ });
2230
+ });
2231
+
2232
+ it("extract is case insensitive", () => {
2233
+ cy.window().then(async (win) => {
2234
+ win.postMessage(
2235
+ {
2236
+ doenetML: `
2237
+ <text>a</text>
2238
+ <extract prop="LaTeX" assignNames="e1"><math>x</math></extract>
2239
+ <extract prop="LATEX" assignNames="e2"><math>y</math></extract>
2240
+ `,
2241
+ },
2242
+ "*",
2243
+ );
2244
+ });
2245
+
2246
+ cy.get(cesc("#\\/_text1")).should("have.text", "a"); // to wait until loaded
2247
+
2248
+ cy.log(`check properties`);
2249
+ cy.window().then(async (win) => {
2250
+ let stateVariables = await win.returnAllStateVariables1();
2251
+ expect(stateVariables["/e1"].stateValues.value).eq("x");
2252
+ expect(stateVariables["/e2"].stateValues.value).eq("y");
2253
+ });
2254
+ });
2255
+
2256
+ it("createComponentOfType adapts result", () => {
2257
+ cy.window().then(async (win) => {
2258
+ win.postMessage(
2259
+ {
2260
+ doenetML: `
2261
+ <text>a</text>
2262
+ <extract prop="x" assignNames="e1"><vector>(1/2,2/3)</vector></extract>
2263
+ <extract prop="x" assignNames="e2" createComponentOfType="number"><vector>(3/4,4/5)</vector></extract>
2264
+ `,
2265
+ },
2266
+ "*",
2267
+ );
2268
+ });
2269
+
2270
+ cy.get(cesc("#\\/_text1")).should("have.text", "a"); // to wait until loaded
2271
+
2272
+ cy.get(cesc("#\\/e1") + " .mjx-mrow").should("contain.text", "12");
2273
+ cy.get(cesc("#\\/e2")).should("have.text", "0.75");
2274
+
2275
+ cy.log(`check properties`);
2276
+ cy.window().then(async (win) => {
2277
+ let stateVariables = await win.returnAllStateVariables1();
2278
+ expect(stateVariables["/e1"].stateValues.value).eqls(["/", 1, 2]);
2279
+ expect(stateVariables["/e2"].stateValues.value).eq(0.75);
2280
+ });
2281
+ });
2282
+ });