@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,2023 @@
1
+ import { cesc } from "../../../../src/utils/url";
2
+
3
+ describe("TriggerSet Tag Tests", function () {
4
+ beforeEach(() => {
5
+ cy.clearIndexedDB();
6
+ cy.visit("/src/Tools/cypressTest/");
7
+ });
8
+
9
+ it("triggerSet", () => {
10
+ cy.window().then(async (win) => {
11
+ win.postMessage(
12
+ {
13
+ doenetML: `
14
+ <text>a</text>
15
+ <p>Boolean to swap: <boolean name="b" /></p>
16
+ <p>Say hello: <text name="hello"></text></p>
17
+ <p>Count: <number name="n">1</number></p>
18
+
19
+ <graph name="g">
20
+ <point name="P">(1,2)</point>
21
+ </graph>
22
+
23
+ <p name="nums"><aslist><sampleRandomNumbers name="s" numSamples="5" type="discreteUniform" from="1" to="6" /></aslist></p>
24
+
25
+ <triggerSet name="tset">
26
+ <label>perform updates and actions</label>
27
+ <updateValue name="flip" target="b" newValue="not$b" type="boolean" />
28
+ <updateValue name="addHello" target="hello" newValue="$hello hello" type="text" />
29
+ <updateValue name="addOne" target="n" newValue="$n+1" type="number" />
30
+ <callAction target="s" actionName="resample" name="rs" >
31
+ <label>roll dice and add point</label>
32
+ </callAction>
33
+ <callAction name="addPoint" target="g" actionName="addChildren" >
34
+ <label>add point</label>
35
+ <point>(3,4)</point>
36
+ </callAction>
37
+ </triggerSet>
38
+ `,
39
+ },
40
+ "*",
41
+ );
42
+ });
43
+ cy.get(cesc("#\\/_text1")).should("have.text", "a"); //wait for page to load
44
+
45
+ cy.get(cesc("#\\/flip")).should("not.exist");
46
+ cy.get(cesc("#\\/addHello")).should("not.exist");
47
+ cy.get(cesc("#\\/addOne")).should("not.exist");
48
+ cy.get(cesc("#\\/rs")).should("not.exist");
49
+ cy.get(cesc("#\\/addPoint")).should("not.exist");
50
+
51
+ cy.window().then(async (win) => {
52
+ let stateVariables = await win.returnAllStateVariables1();
53
+ let numbers;
54
+ let g = stateVariables["/g"];
55
+
56
+ expect(g.activeChildren.length).eq(1);
57
+
58
+ cy.get(cesc("#\\/nums"))
59
+ .invoke("text")
60
+ .then((text) => {
61
+ numbers = text.split(",").map(Number);
62
+ expect(numbers.length).eq(5);
63
+ for (let num of numbers) {
64
+ expect(Number.isInteger(num)).be.true;
65
+ expect(num).gte(1);
66
+ expect(num).lte(6);
67
+ }
68
+ });
69
+
70
+ cy.get(cesc("#\\/b")).should("have.text", "false");
71
+ cy.get(cesc("#\\/hello")).should("have.text", "");
72
+ cy.get(cesc("#\\/n")).should("have.text", "1");
73
+
74
+ cy.get(cesc("#\\/tset_button")).click();
75
+ cy.waitUntil(() =>
76
+ cy.window().then(async (win) => {
77
+ let stateVariables = await win.returnAllStateVariables1();
78
+ let g = stateVariables["/g"];
79
+ return g.activeChildren.length === 2;
80
+ }),
81
+ );
82
+
83
+ cy.get(cesc("#\\/nums"))
84
+ .invoke("text")
85
+ .then((text) => {
86
+ let numbers2 = text.split(",").map(Number);
87
+ expect(numbers2).not.eqls(numbers);
88
+ numbers = numbers2;
89
+ });
90
+
91
+ cy.get(cesc("#\\/b")).should("have.text", "true");
92
+ cy.get(cesc("#\\/hello")).should("have.text", " hello");
93
+ cy.get(cesc("#\\/n")).should("have.text", "2");
94
+
95
+ cy.get(cesc("#\\/tset_button")).click();
96
+ cy.waitUntil(() =>
97
+ cy.window().then(async (win) => {
98
+ let stateVariables = await win.returnAllStateVariables1();
99
+ let g = stateVariables["/g"];
100
+ return g.activeChildren.length === 3;
101
+ }),
102
+ );
103
+
104
+ cy.get(cesc("#\\/nums"))
105
+ .invoke("text")
106
+ .then((text) => {
107
+ let numbers2 = text.split(",").map(Number);
108
+ expect(numbers2).not.eqls(numbers);
109
+ numbers = numbers2;
110
+ });
111
+
112
+ cy.get(cesc("#\\/b")).should("have.text", "false");
113
+ cy.get(cesc("#\\/hello")).should("have.text", " hello hello");
114
+ cy.get(cesc("#\\/n")).should("have.text", "3");
115
+
116
+ cy.get(cesc("#\\/tset_button")).click();
117
+ cy.waitUntil(() =>
118
+ cy.window().then(async (win) => {
119
+ let stateVariables = await win.returnAllStateVariables1();
120
+ let g = stateVariables["/g"];
121
+ return g.activeChildren.length === 4;
122
+ }),
123
+ );
124
+
125
+ cy.get(cesc("#\\/nums"))
126
+ .invoke("text")
127
+ .then((text) => {
128
+ let numbers2 = text.split(",").map(Number);
129
+ expect(numbers2).not.eqls(numbers);
130
+ numbers = numbers2;
131
+ });
132
+
133
+ cy.get(cesc("#\\/b")).should("have.text", "true");
134
+ cy.get(cesc("#\\/hello")).should("have.text", " hello hello hello");
135
+ cy.get(cesc("#\\/n")).should("have.text", "4");
136
+ });
137
+ });
138
+
139
+ it("triggerSet and chain to updatevalue and call action", () => {
140
+ cy.window().then(async (win) => {
141
+ win.postMessage(
142
+ {
143
+ doenetML: `
144
+ <text>a</text>
145
+ <p>Boolean to swap: <boolean name="b" /></p>
146
+ <p>Say hello: <text name="hello"></text></p>
147
+ <p>Count: <number name="n">1</number></p>
148
+
149
+ <graph name="g">
150
+ <point name="P">(1,2)</point>
151
+ </graph>
152
+
153
+ <p name="nums"><aslist><sampleRandomNumbers name="s" numSamples="5" type="discreteUniform" from="1" to="6" /></aslist></p>
154
+
155
+ <triggerSet name="tset">
156
+ <label>perform updates and actions</label>
157
+ <updateValue name="flip" target="b" newValue="not$b" type="boolean" />
158
+ <updateValue name="addHello" target="hello" newValue="$hello hello" type="text" />
159
+ <callAction target="s" actionName="resample" name="rs" >
160
+ <label>roll dice and add point</label>
161
+ </callAction>
162
+ </triggerSet>
163
+
164
+ <updateValue name="addOne" target="n" newValue="$n+1" type="number" triggerWith="tset" />
165
+ <callAction name="addPoint" target="g" actionName="addChildren" triggerWith="tset" >
166
+ <label>add point</label>
167
+ <point>(3,4)</point>
168
+ </callAction>
169
+ `,
170
+ },
171
+ "*",
172
+ );
173
+ });
174
+ cy.get(cesc("#\\/_text1")).should("have.text", "a"); //wait for page to load
175
+
176
+ cy.get(cesc("#\\/flip")).should("not.exist");
177
+ cy.get(cesc("#\\/addHello")).should("not.exist");
178
+ cy.get(cesc("#\\/addOne")).should("not.exist");
179
+ cy.get(cesc("#\\/rs")).should("not.exist");
180
+ cy.get(cesc("#\\/addPoint")).should("not.exist");
181
+
182
+ cy.window().then(async (win) => {
183
+ let stateVariables = await win.returnAllStateVariables1();
184
+ let numbers;
185
+ let g = stateVariables["/g"];
186
+
187
+ expect(g.activeChildren.length).eq(1);
188
+
189
+ cy.get(cesc("#\\/nums"))
190
+ .invoke("text")
191
+ .then((text) => {
192
+ numbers = text.split(",").map(Number);
193
+ expect(numbers.length).eq(5);
194
+ for (let num of numbers) {
195
+ expect(Number.isInteger(num)).be.true;
196
+ expect(num).gte(1);
197
+ expect(num).lte(6);
198
+ }
199
+ });
200
+
201
+ cy.get(cesc("#\\/b")).should("have.text", "false");
202
+ cy.get(cesc("#\\/hello")).should("have.text", "");
203
+ cy.get(cesc("#\\/n")).should("have.text", "1");
204
+
205
+ cy.get(cesc("#\\/tset_button")).click();
206
+ cy.waitUntil(() =>
207
+ cy.window().then(async (win) => {
208
+ let stateVariables = await win.returnAllStateVariables1();
209
+ let g = stateVariables["/g"];
210
+ return g.activeChildren.length === 2;
211
+ }),
212
+ );
213
+
214
+ cy.get(cesc("#\\/nums"))
215
+ .invoke("text")
216
+ .then((text) => {
217
+ let numbers2 = text.split(",").map(Number);
218
+ expect(numbers2).not.eqls(numbers);
219
+ numbers = numbers2;
220
+ });
221
+
222
+ cy.get(cesc("#\\/b")).should("have.text", "true");
223
+ cy.get(cesc("#\\/hello")).should("have.text", " hello");
224
+ cy.get(cesc("#\\/n")).should("have.text", "2");
225
+
226
+ cy.get(cesc("#\\/tset_button")).click();
227
+ cy.waitUntil(() =>
228
+ cy.window().then(async (win) => {
229
+ let stateVariables = await win.returnAllStateVariables1();
230
+ let g = stateVariables["/g"];
231
+ return g.activeChildren.length === 3;
232
+ }),
233
+ );
234
+
235
+ cy.get(cesc("#\\/nums"))
236
+ .invoke("text")
237
+ .then((text) => {
238
+ let numbers2 = text.split(",").map(Number);
239
+ expect(numbers2).not.eqls(numbers);
240
+ numbers = numbers2;
241
+ });
242
+
243
+ cy.get(cesc("#\\/b")).should("have.text", "false");
244
+ cy.get(cesc("#\\/hello")).should("have.text", " hello hello");
245
+ cy.get(cesc("#\\/n")).should("have.text", "3");
246
+
247
+ cy.get(cesc("#\\/tset_button")).click();
248
+ cy.waitUntil(() =>
249
+ cy.window().then(async (win) => {
250
+ let stateVariables = await win.returnAllStateVariables1();
251
+ let g = stateVariables["/g"];
252
+ return g.activeChildren.length === 4;
253
+ }),
254
+ );
255
+
256
+ cy.get(cesc("#\\/nums"))
257
+ .invoke("text")
258
+ .then((text) => {
259
+ let numbers2 = text.split(",").map(Number);
260
+ expect(numbers2).not.eqls(numbers);
261
+ numbers = numbers2;
262
+ });
263
+
264
+ cy.get(cesc("#\\/b")).should("have.text", "true");
265
+ cy.get(cesc("#\\/hello")).should("have.text", " hello hello hello");
266
+ cy.get(cesc("#\\/n")).should("have.text", "4");
267
+ });
268
+ });
269
+
270
+ it("triggerSet and chain to triggerset", () => {
271
+ cy.window().then(async (win) => {
272
+ win.postMessage(
273
+ {
274
+ doenetML: `
275
+ <text>a</text>
276
+ <p>Boolean to swap: <boolean name="b" /></p>
277
+ <p>Say hello: <text name="hello"></text></p>
278
+ <p>Count: <number name="n">1</number></p>
279
+
280
+ <graph name="g">
281
+ <point name="P">(1,2)</point>
282
+ </graph>
283
+
284
+ <p name="nums"><aslist><sampleRandomNumbers name="s" numSamples="5" type="discreteUniform" from="1" to="6" /></aslist></p>
285
+
286
+ <triggerSet name="tset">
287
+ <label>perform updates and actions</label>
288
+ <updateValue name="flip" target="b" newValue="not$b" type="boolean" />
289
+ <updateValue target="hello" newValue="$hello hello" type="text" />
290
+ <callAction target="s" actionName="resample" name="rs" >
291
+ <label>roll dice and add point</label>
292
+ </callAction>
293
+ </triggerSet>
294
+
295
+ <triggerSet triggerWith="tset" >
296
+ <label>perform updates</label>
297
+ <updateValue target="n" newValue="$n+1" type="number" />
298
+ <callAction name="addPoint" target="g" actionName="addChildren" >
299
+ <label>add point</label>
300
+ <point>(3,4)</point>
301
+ </callAction>
302
+ </triggerSet>
303
+
304
+ `,
305
+ },
306
+ "*",
307
+ );
308
+ });
309
+ cy.get(cesc("#\\/_text1")).should("have.text", "a"); //wait for page to load
310
+
311
+ cy.get(cesc("#\\/flip")).should("not.exist");
312
+ cy.get(cesc("#\\/addHello")).should("not.exist");
313
+ cy.get(cesc("#\\/addOne")).should("not.exist");
314
+ cy.get(cesc("#\\/rs")).should("not.exist");
315
+ cy.get(cesc("#\\/addPoint")).should("not.exist");
316
+
317
+ cy.window().then(async (win) => {
318
+ let stateVariables = await win.returnAllStateVariables1();
319
+ let numbers;
320
+ let g = stateVariables["/g"];
321
+
322
+ expect(g.activeChildren.length).eq(1);
323
+
324
+ cy.get(cesc("#\\/nums"))
325
+ .invoke("text")
326
+ .then((text) => {
327
+ numbers = text.split(",").map(Number);
328
+ expect(numbers.length).eq(5);
329
+ for (let num of numbers) {
330
+ expect(Number.isInteger(num)).be.true;
331
+ expect(num).gte(1);
332
+ expect(num).lte(6);
333
+ }
334
+ });
335
+
336
+ cy.get(cesc("#\\/b")).should("have.text", "false");
337
+ cy.get(cesc("#\\/hello")).should("have.text", "");
338
+ cy.get(cesc("#\\/n")).should("have.text", "1");
339
+
340
+ cy.get(cesc("#\\/tset_button")).click();
341
+ cy.waitUntil(() =>
342
+ cy.window().then(async (win) => {
343
+ let stateVariables = await win.returnAllStateVariables1();
344
+ let g = stateVariables["/g"];
345
+ return g.activeChildren.length === 2;
346
+ }),
347
+ );
348
+
349
+ cy.get(cesc("#\\/nums"))
350
+ .invoke("text")
351
+ .then((text) => {
352
+ let numbers2 = text.split(",").map(Number);
353
+ expect(numbers2).not.eqls(numbers);
354
+ numbers = numbers2;
355
+ });
356
+
357
+ cy.get(cesc("#\\/b")).should("have.text", "true");
358
+ cy.get(cesc("#\\/hello")).should("have.text", " hello");
359
+ cy.get(cesc("#\\/n")).should("have.text", "2");
360
+
361
+ cy.get(cesc("#\\/tset_button")).click();
362
+ cy.waitUntil(() =>
363
+ cy.window().then(async (win) => {
364
+ let stateVariables = await win.returnAllStateVariables1();
365
+ let g = stateVariables["/g"];
366
+ return g.activeChildren.length === 3;
367
+ }),
368
+ );
369
+
370
+ cy.get(cesc("#\\/nums"))
371
+ .invoke("text")
372
+ .then((text) => {
373
+ let numbers2 = text.split(",").map(Number);
374
+ expect(numbers2).not.eqls(numbers);
375
+ numbers = numbers2;
376
+ });
377
+
378
+ cy.get(cesc("#\\/b")).should("have.text", "false");
379
+ cy.get(cesc("#\\/hello")).should("have.text", " hello hello");
380
+ cy.get(cesc("#\\/n")).should("have.text", "3");
381
+
382
+ cy.get(cesc("#\\/tset_button")).click();
383
+ cy.waitUntil(() =>
384
+ cy.window().then(async (win) => {
385
+ let stateVariables = await win.returnAllStateVariables1();
386
+ let g = stateVariables["/g"];
387
+ return g.activeChildren.length === 4;
388
+ }),
389
+ );
390
+
391
+ cy.get(cesc("#\\/nums"))
392
+ .invoke("text")
393
+ .then((text) => {
394
+ let numbers2 = text.split(",").map(Number);
395
+ expect(numbers2).not.eqls(numbers);
396
+ numbers = numbers2;
397
+ });
398
+
399
+ cy.get(cesc("#\\/b")).should("have.text", "true");
400
+ cy.get(cesc("#\\/hello")).should("have.text", " hello hello hello");
401
+ cy.get(cesc("#\\/n")).should("have.text", "4");
402
+ });
403
+ });
404
+
405
+ it("triggerSet and chain multiple sources to triggerset", () => {
406
+ cy.window().then(async (win) => {
407
+ win.postMessage(
408
+ {
409
+ doenetML: `
410
+ <text>a</text>
411
+ <p>Boolean to swap: <boolean name="b" /></p>
412
+ <p>Say hello: <text name="hello"></text></p>
413
+ <p>Count: <number name="n">1</number></p>
414
+ <p>Count 2: <number name="n2">1</number></p>
415
+
416
+ <graph name="g">
417
+ <point name="P">(1,2)</point>
418
+ </graph>
419
+
420
+ <p name="nums"><aslist><sampleRandomNumbers name="s" numSamples="5" type="discreteUniform" from="1" to="6" /></aslist></p>
421
+
422
+ <triggerSet name="tset">
423
+ <label>perform updates and actions</label>
424
+ <updateValue name="flip" target="b" newValue="not$b" type="boolean" />
425
+ <updateValue target="hello" newValue="$hello hello" type="text" />
426
+ <callAction target="s" actionName="resample" name="rs" >
427
+ <label>roll dice and add point</label>
428
+ </callAction>
429
+ </triggerSet>
430
+
431
+ <triggerSet triggerWith="tset in" >
432
+ <label>perform updates</label>
433
+ <updateValue target="n" newValue="$n+1" type="number" />
434
+ <callAction name="addPoint" target="g" actionName="addChildren" >
435
+ <label>add point</label>
436
+ <point>(3,4)</point>
437
+ </callAction>
438
+ </triggerSet>
439
+
440
+ <updateValue name="in" target="n2" newValue="$n2+1" type="number" >
441
+ <label>update number and others</label>
442
+ </updateValue>
443
+
444
+ `,
445
+ },
446
+ "*",
447
+ );
448
+ });
449
+ cy.get(cesc("#\\/_text1")).should("have.text", "a"); //wait for page to load
450
+
451
+ cy.get(cesc("#\\/flip")).should("not.exist");
452
+ cy.get(cesc("#\\/addHello")).should("not.exist");
453
+ cy.get(cesc("#\\/addOne")).should("not.exist");
454
+ cy.get(cesc("#\\/rs")).should("not.exist");
455
+ cy.get(cesc("#\\/addPoint")).should("not.exist");
456
+
457
+ cy.window().then(async (win) => {
458
+ let stateVariables = await win.returnAllStateVariables1();
459
+ let numbers;
460
+ let g = stateVariables["/g"];
461
+
462
+ expect(g.activeChildren.length).eq(1);
463
+
464
+ cy.get(cesc("#\\/nums"))
465
+ .invoke("text")
466
+ .then((text) => {
467
+ numbers = text.split(",").map(Number);
468
+ expect(numbers.length).eq(5);
469
+ for (let num of numbers) {
470
+ expect(Number.isInteger(num)).be.true;
471
+ expect(num).gte(1);
472
+ expect(num).lte(6);
473
+ }
474
+ });
475
+
476
+ cy.get(cesc("#\\/b")).should("have.text", "false");
477
+ cy.get(cesc("#\\/hello")).should("have.text", "");
478
+ cy.get(cesc("#\\/n")).should("have.text", "1");
479
+ cy.get(cesc("#\\/n2")).should("have.text", "1");
480
+
481
+ cy.get(cesc("#\\/tset_button")).click();
482
+ cy.waitUntil(() =>
483
+ cy.window().then(async (win) => {
484
+ let stateVariables = await win.returnAllStateVariables1();
485
+ let g = stateVariables["/g"];
486
+ return g.activeChildren.length === 2;
487
+ }),
488
+ );
489
+
490
+ cy.get(cesc("#\\/nums"))
491
+ .invoke("text")
492
+ .then((text) => {
493
+ let numbers2 = text.split(",").map(Number);
494
+ expect(numbers2).not.eqls(numbers);
495
+ numbers = numbers2;
496
+ });
497
+
498
+ cy.get(cesc("#\\/b")).should("have.text", "true");
499
+ cy.get(cesc("#\\/hello")).should("have.text", " hello");
500
+ cy.get(cesc("#\\/n")).should("have.text", "2");
501
+ cy.get(cesc("#\\/n2")).should("have.text", "1");
502
+
503
+ cy.get(cesc("#\\/in_button")).click();
504
+ cy.waitUntil(() =>
505
+ cy.window().then(async (win) => {
506
+ let stateVariables = await win.returnAllStateVariables1();
507
+ let g = stateVariables["/g"];
508
+ return g.activeChildren.length === 3;
509
+ }),
510
+ );
511
+
512
+ cy.get(cesc("#\\/b")).should("have.text", "true");
513
+ cy.get(cesc("#\\/hello")).should("have.text", " hello");
514
+ cy.get(cesc("#\\/n")).should("have.text", "3");
515
+ cy.get(cesc("#\\/n2")).should("have.text", "2");
516
+ });
517
+ });
518
+
519
+ it("triggerSet based on trigger", () => {
520
+ cy.window().then(async (win) => {
521
+ win.postMessage(
522
+ {
523
+ doenetML: `
524
+ <text>a</text>
525
+ <graph>
526
+ <point name="P">(-1,2)</point>
527
+ </graph>
528
+ <math name="x">x</math>
529
+ <math name="y">y</math>
530
+
531
+ <triggerSet triggerWhen="$(P.x)>0 and $(P.y)>0" >
532
+ <updateValue name="trip" target="x" newValue="3$x" simplify />
533
+ <updateValue name="quad" target="y" newValue="4$y" simplify />
534
+ </triggerSet>
535
+ `,
536
+ },
537
+ "*",
538
+ );
539
+ });
540
+ cy.get(cesc("#\\/_text1")).should("have.text", "a"); //wait for page to load
541
+
542
+ cy.get(cesc("#\\/x"))
543
+ .find(".mjx-mrow")
544
+ .eq(0)
545
+ .invoke("text")
546
+ .then((text) => {
547
+ expect(text.trim()).equal("x");
548
+ });
549
+ cy.get(cesc("#\\/y"))
550
+ .find(".mjx-mrow")
551
+ .eq(0)
552
+ .invoke("text")
553
+ .then((text) => {
554
+ expect(text.trim()).equal("y");
555
+ });
556
+
557
+ cy.get(cesc("#\\/trip")).should("not.exist");
558
+ cy.get(cesc("#\\/quad")).should("not.exist");
559
+
560
+ cy.window().then(async (win) => {
561
+ await win.callAction1({
562
+ actionName: "movePoint",
563
+ componentName: "/P",
564
+ args: { x: -1, y: -7 },
565
+ });
566
+ cy.get(cesc("#\\/x"))
567
+ .find(".mjx-mrow")
568
+ .eq(0)
569
+ .invoke("text")
570
+ .then((text) => {
571
+ expect(text.trim()).equal("x");
572
+ });
573
+ cy.get(cesc("#\\/y"))
574
+ .find(".mjx-mrow")
575
+ .eq(0)
576
+ .invoke("text")
577
+ .then((text) => {
578
+ expect(text.trim()).equal("y");
579
+ });
580
+ });
581
+
582
+ cy.window().then(async (win) => {
583
+ await win.callAction1({
584
+ actionName: "movePoint",
585
+ componentName: "/P",
586
+ args: { x: 3, y: -4 },
587
+ });
588
+ cy.get(cesc("#\\/x"))
589
+ .find(".mjx-mrow")
590
+ .eq(0)
591
+ .invoke("text")
592
+ .then((text) => {
593
+ expect(text.trim()).equal("x");
594
+ });
595
+ cy.get(cesc("#\\/y"))
596
+ .find(".mjx-mrow")
597
+ .eq(0)
598
+ .invoke("text")
599
+ .then((text) => {
600
+ expect(text.trim()).equal("y");
601
+ });
602
+ });
603
+
604
+ cy.window().then(async (win) => {
605
+ await win.callAction1({
606
+ actionName: "movePoint",
607
+ componentName: "/P",
608
+ args: { x: 1, y: 7 },
609
+ });
610
+ cy.get(cesc("#\\/x")).should("contain.text", "3x");
611
+ cy.get(cesc("#\\/x"))
612
+ .find(".mjx-mrow")
613
+ .eq(0)
614
+ .invoke("text")
615
+ .then((text) => {
616
+ expect(text.trim()).equal("3x");
617
+ });
618
+ cy.get(cesc("#\\/y"))
619
+ .find(".mjx-mrow")
620
+ .eq(0)
621
+ .invoke("text")
622
+ .then((text) => {
623
+ expect(text.trim()).equal("4y");
624
+ });
625
+ });
626
+
627
+ cy.window().then(async (win) => {
628
+ await win.callAction1({
629
+ actionName: "movePoint",
630
+ componentName: "/P",
631
+ args: { x: 5, y: 9 },
632
+ });
633
+ cy.get(cesc("#\\/x"))
634
+ .find(".mjx-mrow")
635
+ .eq(0)
636
+ .invoke("text")
637
+ .then((text) => {
638
+ expect(text.trim()).equal("3x");
639
+ });
640
+ cy.get(cesc("#\\/y"))
641
+ .find(".mjx-mrow")
642
+ .eq(0)
643
+ .invoke("text")
644
+ .then((text) => {
645
+ expect(text.trim()).equal("4y");
646
+ });
647
+ });
648
+
649
+ cy.window().then(async (win) => {
650
+ await win.callAction1({
651
+ actionName: "movePoint",
652
+ componentName: "/P",
653
+ args: { x: -3, y: 4 },
654
+ });
655
+ cy.get(cesc("#\\/x"))
656
+ .find(".mjx-mrow")
657
+ .eq(0)
658
+ .invoke("text")
659
+ .then((text) => {
660
+ expect(text.trim()).equal("3x");
661
+ });
662
+ cy.get(cesc("#\\/y"))
663
+ .find(".mjx-mrow")
664
+ .eq(0)
665
+ .invoke("text")
666
+ .then((text) => {
667
+ expect(text.trim()).equal("4y");
668
+ });
669
+ });
670
+
671
+ cy.window().then(async (win) => {
672
+ await win.callAction1({
673
+ actionName: "movePoint",
674
+ componentName: "/P",
675
+ args: { x: -6, y: 5 },
676
+ });
677
+ cy.get(cesc("#\\/x"))
678
+ .find(".mjx-mrow")
679
+ .eq(0)
680
+ .invoke("text")
681
+ .then((text) => {
682
+ expect(text.trim()).equal("3x");
683
+ });
684
+ cy.get(cesc("#\\/y"))
685
+ .find(".mjx-mrow")
686
+ .eq(0)
687
+ .invoke("text")
688
+ .then((text) => {
689
+ expect(text.trim()).equal("4y");
690
+ });
691
+ });
692
+
693
+ cy.window().then(async (win) => {
694
+ await win.callAction1({
695
+ actionName: "movePoint",
696
+ componentName: "/P",
697
+ args: { x: 4, y: 2 },
698
+ });
699
+ cy.get(cesc("#\\/x")).should("contain.text", "9x");
700
+ cy.get(cesc("#\\/x"))
701
+ .find(".mjx-mrow")
702
+ .eq(0)
703
+ .invoke("text")
704
+ .then((text) => {
705
+ expect(text.trim()).equal("9x");
706
+ });
707
+ cy.get(cesc("#\\/y"))
708
+ .find(".mjx-mrow")
709
+ .eq(0)
710
+ .invoke("text")
711
+ .then((text) => {
712
+ expect(text.trim()).equal("16y");
713
+ });
714
+ });
715
+
716
+ cy.window().then(async (win) => {
717
+ await win.callAction1({
718
+ actionName: "movePoint",
719
+ componentName: "/P",
720
+ args: { x: 9, y: 7 },
721
+ });
722
+ cy.get(cesc("#\\/x"))
723
+ .find(".mjx-mrow")
724
+ .eq(0)
725
+ .invoke("text")
726
+ .then((text) => {
727
+ expect(text.trim()).equal("9x");
728
+ });
729
+ cy.get(cesc("#\\/y"))
730
+ .find(".mjx-mrow")
731
+ .eq(0)
732
+ .invoke("text")
733
+ .then((text) => {
734
+ expect(text.trim()).equal("16y");
735
+ });
736
+ });
737
+ });
738
+
739
+ it("triggerSet triggered when click", () => {
740
+ cy.window().then(async (win) => {
741
+ win.postMessage(
742
+ {
743
+ doenetML: `
744
+ <text>a</text>
745
+ <graph>
746
+ <point name="P">(-1,2)</point>
747
+ </graph>
748
+ <math name="x">x</math>
749
+ <math name="y">y</math>
750
+
751
+ <triggerSet triggerWhenObjectsClicked="P" >
752
+ <updateValue name="trip" target="x" newValue="3$x" simplify />
753
+ <updateValue name="quad" target="y" newValue="4$y" simplify />
754
+ </triggerSet>
755
+ `,
756
+ },
757
+ "*",
758
+ );
759
+ });
760
+ cy.get(cesc("#\\/_text1")).should("have.text", "a"); //wait for page to load
761
+
762
+ cy.get(cesc("#\\/x"))
763
+ .find(".mjx-mrow")
764
+ .eq(0)
765
+ .invoke("text")
766
+ .then((text) => {
767
+ expect(text.trim()).equal("x");
768
+ });
769
+ cy.get(cesc("#\\/y"))
770
+ .find(".mjx-mrow")
771
+ .eq(0)
772
+ .invoke("text")
773
+ .then((text) => {
774
+ expect(text.trim()).equal("y");
775
+ });
776
+
777
+ cy.get(cesc("#\\/trip")).should("not.exist");
778
+ cy.get(cesc("#\\/quad")).should("not.exist");
779
+
780
+ cy.window().then(async (win) => {
781
+ await win.callAction1({
782
+ actionName: "movePoint",
783
+ componentName: "/P",
784
+ args: { x: -1, y: -7 },
785
+ });
786
+ cy.get(cesc("#\\/x"))
787
+ .find(".mjx-mrow")
788
+ .eq(0)
789
+ .invoke("text")
790
+ .then((text) => {
791
+ expect(text.trim()).equal("x");
792
+ });
793
+ cy.get(cesc("#\\/y"))
794
+ .find(".mjx-mrow")
795
+ .eq(0)
796
+ .invoke("text")
797
+ .then((text) => {
798
+ expect(text.trim()).equal("y");
799
+ });
800
+ });
801
+
802
+ cy.window().then(async (win) => {
803
+ await win.callAction1({
804
+ actionName: "pointClicked",
805
+ componentName: "/P",
806
+ args: { name: "/P" },
807
+ });
808
+ cy.get(cesc("#\\/x")).should("contain.text", "3x");
809
+ cy.get(cesc("#\\/x"))
810
+ .find(".mjx-mrow")
811
+ .eq(0)
812
+ .invoke("text")
813
+ .then((text) => {
814
+ expect(text.trim()).equal("3x");
815
+ });
816
+ cy.get(cesc("#\\/y"))
817
+ .find(".mjx-mrow")
818
+ .eq(0)
819
+ .invoke("text")
820
+ .then((text) => {
821
+ expect(text.trim()).equal("4y");
822
+ });
823
+ });
824
+
825
+ cy.window().then(async (win) => {
826
+ await win.callAction1({
827
+ actionName: "movePoint",
828
+ componentName: "/P",
829
+ args: { x: 5, y: 9 },
830
+ });
831
+ cy.get(cesc("#\\/x"))
832
+ .find(".mjx-mrow")
833
+ .eq(0)
834
+ .invoke("text")
835
+ .then((text) => {
836
+ expect(text.trim()).equal("3x");
837
+ });
838
+ cy.get(cesc("#\\/y"))
839
+ .find(".mjx-mrow")
840
+ .eq(0)
841
+ .invoke("text")
842
+ .then((text) => {
843
+ expect(text.trim()).equal("4y");
844
+ });
845
+ });
846
+
847
+ cy.window().then(async (win) => {
848
+ await win.callAction1({
849
+ actionName: "pointClicked",
850
+ componentName: "/P",
851
+ args: { name: "/P" },
852
+ });
853
+ cy.get(cesc("#\\/x")).should("contain.text", "9x");
854
+ cy.get(cesc("#\\/x"))
855
+ .find(".mjx-mrow")
856
+ .eq(0)
857
+ .invoke("text")
858
+ .then((text) => {
859
+ expect(text.trim()).equal("9x");
860
+ });
861
+ cy.get(cesc("#\\/y"))
862
+ .find(".mjx-mrow")
863
+ .eq(0)
864
+ .invoke("text")
865
+ .then((text) => {
866
+ expect(text.trim()).equal("16y");
867
+ });
868
+ });
869
+
870
+ cy.window().then(async (win) => {
871
+ await win.callAction1({
872
+ actionName: "movePoint",
873
+ componentName: "/P",
874
+ args: { x: 9, y: 7 },
875
+ });
876
+ cy.get(cesc("#\\/x"))
877
+ .find(".mjx-mrow")
878
+ .eq(0)
879
+ .invoke("text")
880
+ .then((text) => {
881
+ expect(text.trim()).equal("9x");
882
+ });
883
+ cy.get(cesc("#\\/y"))
884
+ .find(".mjx-mrow")
885
+ .eq(0)
886
+ .invoke("text")
887
+ .then((text) => {
888
+ expect(text.trim()).equal("16y");
889
+ });
890
+ });
891
+ });
892
+
893
+ it("triggerSet triggered when object focused", () => {
894
+ cy.window().then(async (win) => {
895
+ win.postMessage(
896
+ {
897
+ doenetML: `
898
+ <text>a</text>
899
+ <graph>
900
+ <point name="P">(-1,2)</point>
901
+ </graph>
902
+ <math name="x">x</math>
903
+ <math name="y">y</math>
904
+
905
+ <triggerSet triggerWhenObjectsFocused="P" >
906
+ <updateValue name="trip" target="x" newValue="3$x" simplify />
907
+ <updateValue name="quad" target="y" newValue="4$y" simplify />
908
+ </triggerSet>
909
+ `,
910
+ },
911
+ "*",
912
+ );
913
+ });
914
+ cy.get(cesc("#\\/_text1")).should("have.text", "a"); //wait for page to load
915
+
916
+ cy.get(cesc("#\\/x"))
917
+ .find(".mjx-mrow")
918
+ .eq(0)
919
+ .invoke("text")
920
+ .then((text) => {
921
+ expect(text.trim()).equal("x");
922
+ });
923
+ cy.get(cesc("#\\/y"))
924
+ .find(".mjx-mrow")
925
+ .eq(0)
926
+ .invoke("text")
927
+ .then((text) => {
928
+ expect(text.trim()).equal("y");
929
+ });
930
+
931
+ cy.get(cesc("#\\/trip")).should("not.exist");
932
+ cy.get(cesc("#\\/quad")).should("not.exist");
933
+
934
+ cy.window().then(async (win) => {
935
+ await win.callAction1({
936
+ actionName: "movePoint",
937
+ componentName: "/P",
938
+ args: { x: -1, y: -7 },
939
+ });
940
+ cy.get(cesc("#\\/x"))
941
+ .find(".mjx-mrow")
942
+ .eq(0)
943
+ .invoke("text")
944
+ .then((text) => {
945
+ expect(text.trim()).equal("x");
946
+ });
947
+ cy.get(cesc("#\\/y"))
948
+ .find(".mjx-mrow")
949
+ .eq(0)
950
+ .invoke("text")
951
+ .then((text) => {
952
+ expect(text.trim()).equal("y");
953
+ });
954
+ });
955
+
956
+ cy.window().then(async (win) => {
957
+ await win.callAction1({
958
+ actionName: "pointFocused",
959
+ componentName: "/P",
960
+ args: { name: "/P" },
961
+ });
962
+ cy.get(cesc("#\\/x")).should("contain.text", "3x");
963
+ cy.get(cesc("#\\/x"))
964
+ .find(".mjx-mrow")
965
+ .eq(0)
966
+ .invoke("text")
967
+ .then((text) => {
968
+ expect(text.trim()).equal("3x");
969
+ });
970
+ cy.get(cesc("#\\/y"))
971
+ .find(".mjx-mrow")
972
+ .eq(0)
973
+ .invoke("text")
974
+ .then((text) => {
975
+ expect(text.trim()).equal("4y");
976
+ });
977
+ });
978
+
979
+ cy.window().then(async (win) => {
980
+ await win.callAction1({
981
+ actionName: "movePoint",
982
+ componentName: "/P",
983
+ args: { x: 5, y: 9 },
984
+ });
985
+ cy.get(cesc("#\\/x"))
986
+ .find(".mjx-mrow")
987
+ .eq(0)
988
+ .invoke("text")
989
+ .then((text) => {
990
+ expect(text.trim()).equal("3x");
991
+ });
992
+ cy.get(cesc("#\\/y"))
993
+ .find(".mjx-mrow")
994
+ .eq(0)
995
+ .invoke("text")
996
+ .then((text) => {
997
+ expect(text.trim()).equal("4y");
998
+ });
999
+ });
1000
+
1001
+ cy.window().then(async (win) => {
1002
+ await win.callAction1({
1003
+ actionName: "pointFocused",
1004
+ componentName: "/P",
1005
+ args: { name: "/P" },
1006
+ });
1007
+ cy.get(cesc("#\\/x")).should("contain.text", "9x");
1008
+ cy.get(cesc("#\\/x"))
1009
+ .find(".mjx-mrow")
1010
+ .eq(0)
1011
+ .invoke("text")
1012
+ .then((text) => {
1013
+ expect(text.trim()).equal("9x");
1014
+ });
1015
+ cy.get(cesc("#\\/y"))
1016
+ .find(".mjx-mrow")
1017
+ .eq(0)
1018
+ .invoke("text")
1019
+ .then((text) => {
1020
+ expect(text.trim()).equal("16y");
1021
+ });
1022
+ });
1023
+
1024
+ cy.window().then(async (win) => {
1025
+ await win.callAction1({
1026
+ actionName: "movePoint",
1027
+ componentName: "/P",
1028
+ args: { x: 9, y: 7 },
1029
+ });
1030
+ cy.get(cesc("#\\/x"))
1031
+ .find(".mjx-mrow")
1032
+ .eq(0)
1033
+ .invoke("text")
1034
+ .then((text) => {
1035
+ expect(text.trim()).equal("9x");
1036
+ });
1037
+ cy.get(cesc("#\\/y"))
1038
+ .find(".mjx-mrow")
1039
+ .eq(0)
1040
+ .invoke("text")
1041
+ .then((text) => {
1042
+ expect(text.trim()).equal("16y");
1043
+ });
1044
+ });
1045
+ });
1046
+
1047
+ it("triggerWhen supercedes chaining for triggerset", () => {
1048
+ cy.window().then(async (win) => {
1049
+ win.postMessage(
1050
+ {
1051
+ doenetML: `
1052
+ <text>a</text>
1053
+ <graph>
1054
+ <point name="P">(-1,2)</point>
1055
+ </graph>
1056
+
1057
+ <p>Boolean to swap: <boolean name="b" /></p>
1058
+ <p>Say hello: <text name="hello"></text></p>
1059
+ <p>Count: <number name="n">1</number></p>
1060
+ <p>Count down: <number name="m">5</number></p>
1061
+
1062
+ <triggerSet triggerWhen="$(P.x)>0 and $(P.y)>0">
1063
+ <label>perform updates</label>
1064
+ <updateValue target="b" newValue="not$b" type="boolean" />
1065
+ <updateValue target="hello" newValue="$hello hello" type="text" />
1066
+ </triggerSet>
1067
+
1068
+ <triggerSet triggerWith="_triggerset1" triggerWhen="$(P.x)<0 and $(P.y)<0" >
1069
+ <label>perform updates</label>
1070
+ <updateValue target="n" newValue="$n+1" type="number" />
1071
+ <updateValue target="m" newValue="$m-1" type="number" />
1072
+ </triggerSet>
1073
+
1074
+ `,
1075
+ },
1076
+ "*",
1077
+ );
1078
+ });
1079
+ cy.get(cesc("#\\/_text1")).should("have.text", "a"); //wait for page to load
1080
+
1081
+ cy.get(cesc("#\\/b")).should("have.text", "false");
1082
+ cy.get(cesc("#\\/hello")).should("have.text", "");
1083
+ cy.get(cesc("#\\/n")).should("have.text", "1");
1084
+ cy.get(cesc("#\\/m")).should("have.text", "5");
1085
+ cy.get(cesc("#\\/_triggerset1")).should("not.exist");
1086
+ cy.get(cesc("#\\/_triggerset2")).should("not.exist");
1087
+
1088
+ cy.window().then(async (win) => {
1089
+ await win.callAction1({
1090
+ actionName: "movePoint",
1091
+ componentName: "/P",
1092
+ args: { x: -1, y: -7 },
1093
+ });
1094
+ cy.get(cesc("#\\/b")).should("have.text", "false");
1095
+ cy.get(cesc("#\\/hello")).should("have.text", "");
1096
+ cy.get(cesc("#\\/n")).should("have.text", "2");
1097
+ cy.get(cesc("#\\/m")).should("have.text", "4");
1098
+ });
1099
+
1100
+ cy.window().then(async (win) => {
1101
+ await win.callAction1({
1102
+ actionName: "movePoint",
1103
+ componentName: "/P",
1104
+ args: { x: 3, y: -4 },
1105
+ });
1106
+ cy.get(cesc("#\\/b")).should("have.text", "false");
1107
+ cy.get(cesc("#\\/hello")).should("have.text", "");
1108
+ cy.get(cesc("#\\/n")).should("have.text", "2");
1109
+ cy.get(cesc("#\\/m")).should("have.text", "4");
1110
+ });
1111
+
1112
+ cy.window().then(async (win) => {
1113
+ await win.callAction1({
1114
+ actionName: "movePoint",
1115
+ componentName: "/P",
1116
+ args: { x: 1, y: 7 },
1117
+ });
1118
+ cy.get(cesc("#\\/b")).should("have.text", "true");
1119
+ cy.get(cesc("#\\/hello")).should("have.text", " hello");
1120
+ cy.get(cesc("#\\/n")).should("have.text", "2");
1121
+ cy.get(cesc("#\\/m")).should("have.text", "4");
1122
+ });
1123
+
1124
+ cy.window().then(async (win) => {
1125
+ await win.callAction1({
1126
+ actionName: "movePoint",
1127
+ componentName: "/P",
1128
+ args: { x: 5, y: 9 },
1129
+ });
1130
+ cy.get(cesc("#\\/b")).should("have.text", "true");
1131
+ cy.get(cesc("#\\/hello")).should("have.text", " hello");
1132
+ cy.get(cesc("#\\/n")).should("have.text", "2");
1133
+ cy.get(cesc("#\\/m")).should("have.text", "4");
1134
+ });
1135
+
1136
+ cy.window().then(async (win) => {
1137
+ await win.callAction1({
1138
+ actionName: "movePoint",
1139
+ componentName: "/P",
1140
+ args: { x: -3, y: -4 },
1141
+ });
1142
+ cy.get(cesc("#\\/b")).should("have.text", "true");
1143
+ cy.get(cesc("#\\/hello")).should("have.text", " hello");
1144
+ cy.get(cesc("#\\/n")).should("have.text", "3");
1145
+ cy.get(cesc("#\\/m")).should("have.text", "3");
1146
+ });
1147
+
1148
+ cy.window().then(async (win) => {
1149
+ await win.callAction1({
1150
+ actionName: "movePoint",
1151
+ componentName: "/P",
1152
+ args: { x: -6, y: -5 },
1153
+ });
1154
+ cy.get(cesc("#\\/b")).should("have.text", "true");
1155
+ cy.get(cesc("#\\/hello")).should("have.text", " hello");
1156
+ cy.get(cesc("#\\/n")).should("have.text", "3");
1157
+ cy.get(cesc("#\\/m")).should("have.text", "3");
1158
+ });
1159
+
1160
+ cy.window().then(async (win) => {
1161
+ await win.callAction1({
1162
+ actionName: "movePoint",
1163
+ componentName: "/P",
1164
+ args: { x: 4, y: 2 },
1165
+ });
1166
+ cy.get(cesc("#\\/b")).should("have.text", "false");
1167
+ cy.get(cesc("#\\/hello")).should("have.text", " hello hello");
1168
+ cy.get(cesc("#\\/n")).should("have.text", "3");
1169
+ cy.get(cesc("#\\/m")).should("have.text", "3");
1170
+ });
1171
+
1172
+ cy.window().then(async (win) => {
1173
+ await win.callAction1({
1174
+ actionName: "movePoint",
1175
+ componentName: "/P",
1176
+ args: { x: 9, y: 7 },
1177
+ });
1178
+ cy.get(cesc("#\\/b")).should("have.text", "false");
1179
+ cy.get(cesc("#\\/hello")).should("have.text", " hello hello");
1180
+ cy.get(cesc("#\\/n")).should("have.text", "3");
1181
+ cy.get(cesc("#\\/m")).should("have.text", "3");
1182
+ });
1183
+ });
1184
+
1185
+ it("triggerset supercedes triggerWhen for updateValue and callAction children", () => {
1186
+ cy.window().then(async (win) => {
1187
+ win.postMessage(
1188
+ {
1189
+ doenetML: `
1190
+ <text>a</text>
1191
+ <graph name="g">
1192
+ <point name="P">(-1,2)</point>
1193
+ </graph>
1194
+
1195
+ <p>Boolean to swap: <boolean name="b" /></p>
1196
+ <p>Say hello: <text name="hello"></text></p>
1197
+ <p>Count: <number name="n">1</number></p>
1198
+
1199
+ <p name="nums"><aslist><sampleRandomNumbers name="s" numSamples="5" type="discreteUniform" from="1" to="6" /></aslist></p>
1200
+
1201
+ <triggerSet triggerWhen="$(P.x)>0 and $(P.y)>0">
1202
+ <label>perform updates</label>
1203
+ <updateValue target="b" newValue="not$b" type="boolean" />
1204
+ <updateValue target="hello" newValue="$hello hello" type="text" />
1205
+ <updateValue target="n" newValue="$n+1" type="number" triggerWhen="$(P.x)<0 and $(P.y)<0" />
1206
+ <callAction target="s" actionName="resample" name="rs" triggerWhen="$(P.x)<0 and $(P.y)<0" >
1207
+ <label>roll dice and add point</label>
1208
+ </callAction>
1209
+ <callAction name="addPoint" target="g" actionName="addChildren" >
1210
+ <label>add point</label>
1211
+ <point>(3,4)</point>
1212
+ </callAction>
1213
+ </triggerSet>
1214
+
1215
+ `,
1216
+ },
1217
+ "*",
1218
+ );
1219
+ });
1220
+ cy.get(cesc("#\\/_text1")).should("have.text", "a"); //wait for page to load
1221
+
1222
+ cy.window().then(async (win) => {
1223
+ let stateVariables = await win.returnAllStateVariables1();
1224
+ let numbers;
1225
+ let g = stateVariables["/g"];
1226
+
1227
+ expect(g.activeChildren.length).eq(1);
1228
+
1229
+ cy.get(cesc("#\\/nums"))
1230
+ .invoke("text")
1231
+ .then((text) => {
1232
+ numbers = text.split(",").map(Number);
1233
+ expect(numbers.length).eq(5);
1234
+ for (let num of numbers) {
1235
+ expect(Number.isInteger(num)).be.true;
1236
+ expect(num).gte(1);
1237
+ expect(num).lte(6);
1238
+ }
1239
+ });
1240
+
1241
+ cy.get(cesc("#\\/b")).should("have.text", "false");
1242
+ cy.get(cesc("#\\/hello")).should("have.text", "");
1243
+ cy.get(cesc("#\\/n")).should("have.text", "1");
1244
+
1245
+ cy.window().then(async (win) => {
1246
+ await win.callAction1({
1247
+ actionName: "movePoint",
1248
+ componentName: "/P",
1249
+ args: { x: -1, y: -7 },
1250
+ });
1251
+
1252
+ cy.window().then(async (win) => {
1253
+ let stateVariables = await win.returnAllStateVariables1();
1254
+ let g = stateVariables["/g"];
1255
+ expect(g.activeChildren.length).eq(1);
1256
+ });
1257
+ cy.get(cesc("#\\/nums"))
1258
+ .invoke("text")
1259
+ .then((text) => {
1260
+ let numbers2 = text.split(",").map(Number);
1261
+ expect(numbers2).eqls(numbers);
1262
+ });
1263
+ cy.get(cesc("#\\/b")).should("have.text", "false");
1264
+ cy.get(cesc("#\\/hello")).should("have.text", "");
1265
+ cy.get(cesc("#\\/n")).should("have.text", "1");
1266
+ });
1267
+
1268
+ cy.window().then(async (win) => {
1269
+ await win.callAction1({
1270
+ actionName: "movePoint",
1271
+ componentName: "/P",
1272
+ args: { x: 3, y: -4 },
1273
+ });
1274
+ cy.window().then(async (win) => {
1275
+ let stateVariables = await win.returnAllStateVariables1();
1276
+ let g = stateVariables["/g"];
1277
+ expect(g.activeChildren.length).eq(1);
1278
+ });
1279
+ cy.get(cesc("#\\/nums"))
1280
+ .invoke("text")
1281
+ .then((text) => {
1282
+ let numbers2 = text.split(",").map(Number);
1283
+ expect(numbers2).eqls(numbers);
1284
+ });
1285
+ cy.get(cesc("#\\/b")).should("have.text", "false");
1286
+ cy.get(cesc("#\\/hello")).should("have.text", "");
1287
+ cy.get(cesc("#\\/n")).should("have.text", "1");
1288
+ });
1289
+
1290
+ cy.window().then(async (win) => {
1291
+ await win.callAction1({
1292
+ actionName: "movePoint",
1293
+ componentName: "/P",
1294
+ args: { x: 1, y: 7 },
1295
+ });
1296
+
1297
+ cy.waitUntil(() =>
1298
+ cy.window().then(async (win) => {
1299
+ let stateVariables = await win.returnAllStateVariables1();
1300
+ let g = stateVariables["/g"];
1301
+ return g.activeChildren.length === 2;
1302
+ }),
1303
+ );
1304
+ cy.get(cesc("#\\/nums"))
1305
+ .invoke("text")
1306
+ .then((text) => {
1307
+ let numbers2 = text.split(",").map(Number);
1308
+ expect(numbers2).not.eqls(numbers);
1309
+ numbers = numbers2;
1310
+ });
1311
+ cy.get(cesc("#\\/b")).should("have.text", "true");
1312
+ cy.get(cesc("#\\/hello")).should("have.text", " hello");
1313
+ cy.get(cesc("#\\/n")).should("have.text", "2");
1314
+ });
1315
+
1316
+ cy.window().then(async (win) => {
1317
+ await win.callAction1({
1318
+ actionName: "movePoint",
1319
+ componentName: "/P",
1320
+ args: { x: 5, y: 9 },
1321
+ });
1322
+ cy.window().then(async (win) => {
1323
+ let stateVariables = await win.returnAllStateVariables1();
1324
+ let g = stateVariables["/g"];
1325
+ expect(g.activeChildren.length).eq(2);
1326
+ });
1327
+ cy.get(cesc("#\\/nums"))
1328
+ .invoke("text")
1329
+ .then((text) => {
1330
+ let numbers2 = text.split(",").map(Number);
1331
+ expect(numbers2).eqls(numbers);
1332
+ });
1333
+ cy.get(cesc("#\\/b")).should("have.text", "true");
1334
+ cy.get(cesc("#\\/hello")).should("have.text", " hello");
1335
+ cy.get(cesc("#\\/n")).should("have.text", "2");
1336
+ });
1337
+
1338
+ cy.window().then(async (win) => {
1339
+ await win.callAction1({
1340
+ actionName: "movePoint",
1341
+ componentName: "/P",
1342
+ args: { x: -3, y: -4 },
1343
+ });
1344
+ cy.window().then(async (win) => {
1345
+ let stateVariables = await win.returnAllStateVariables1();
1346
+ let g = stateVariables["/g"];
1347
+ expect(g.activeChildren.length).eq(2);
1348
+ });
1349
+ cy.get(cesc("#\\/nums"))
1350
+ .invoke("text")
1351
+ .then((text) => {
1352
+ let numbers2 = text.split(",").map(Number);
1353
+ expect(numbers2).eqls(numbers);
1354
+ });
1355
+ cy.get(cesc("#\\/b")).should("have.text", "true");
1356
+ cy.get(cesc("#\\/hello")).should("have.text", " hello");
1357
+ cy.get(cesc("#\\/n")).should("have.text", "2");
1358
+ });
1359
+
1360
+ cy.window().then(async (win) => {
1361
+ await win.callAction1({
1362
+ actionName: "movePoint",
1363
+ componentName: "/P",
1364
+ args: { x: -6, y: -5 },
1365
+ });
1366
+ cy.window().then(async (win) => {
1367
+ let stateVariables = await win.returnAllStateVariables1();
1368
+ let g = stateVariables["/g"];
1369
+ expect(g.activeChildren.length).eq(2);
1370
+ });
1371
+ cy.get(cesc("#\\/nums"))
1372
+ .invoke("text")
1373
+ .then((text) => {
1374
+ let numbers2 = text.split(",").map(Number);
1375
+ expect(numbers2).eqls(numbers);
1376
+ });
1377
+ cy.get(cesc("#\\/b")).should("have.text", "true");
1378
+ cy.get(cesc("#\\/hello")).should("have.text", " hello");
1379
+ cy.get(cesc("#\\/n")).should("have.text", "2");
1380
+ });
1381
+
1382
+ cy.window().then(async (win) => {
1383
+ await win.callAction1({
1384
+ actionName: "movePoint",
1385
+ componentName: "/P",
1386
+ args: { x: 4, y: 2 },
1387
+ });
1388
+
1389
+ cy.waitUntil(() =>
1390
+ cy.window().then(async (win) => {
1391
+ let stateVariables = await win.returnAllStateVariables1();
1392
+ let g = stateVariables["/g"];
1393
+ return g.activeChildren.length === 3;
1394
+ }),
1395
+ );
1396
+ cy.get(cesc("#\\/nums"))
1397
+ .invoke("text")
1398
+ .then((text) => {
1399
+ let numbers2 = text.split(",").map(Number);
1400
+ expect(numbers2).not.eqls(numbers);
1401
+ numbers = numbers2;
1402
+ });
1403
+ cy.get(cesc("#\\/b")).should("have.text", "false");
1404
+ cy.get(cesc("#\\/hello")).should("have.text", " hello hello");
1405
+ cy.get(cesc("#\\/n")).should("have.text", "3");
1406
+ });
1407
+
1408
+ cy.window().then(async (win) => {
1409
+ await win.callAction1({
1410
+ actionName: "movePoint",
1411
+ componentName: "/P",
1412
+ args: { x: 9, y: 7 },
1413
+ });
1414
+ cy.window().then(async (win) => {
1415
+ let stateVariables = await win.returnAllStateVariables1();
1416
+ let g = stateVariables["/g"];
1417
+ expect(g.activeChildren.length).eq(3);
1418
+ });
1419
+ cy.get(cesc("#\\/nums"))
1420
+ .invoke("text")
1421
+ .then((text) => {
1422
+ let numbers2 = text.split(",").map(Number);
1423
+ expect(numbers2).eqls(numbers);
1424
+ });
1425
+ cy.get(cesc("#\\/b")).should("have.text", "false");
1426
+ cy.get(cesc("#\\/hello")).should("have.text", " hello hello");
1427
+ cy.get(cesc("#\\/n")).should("have.text", "3");
1428
+ });
1429
+ });
1430
+ });
1431
+
1432
+ it("triggerset supercedes chaining for updateValue children", () => {
1433
+ cy.window().then(async (win) => {
1434
+ win.postMessage(
1435
+ {
1436
+ doenetML: `
1437
+ <text>a</text>
1438
+ <graph name="g">
1439
+ <point name="P">(-1,2)</point>
1440
+ </graph>
1441
+
1442
+ <p>Boolean to swap: <boolean name="b" /></p>
1443
+ <p>Say hello: <text name="hello"></text></p>
1444
+ <p>Count: <number name="n">1</number></p>
1445
+ <p>Count down: <number name="m">5</number></p>
1446
+
1447
+ <triggerSet triggerWhen="$(P.x)>0 and $(P.y)>0">
1448
+ <label>perform updates</label>
1449
+ <updateValue target="b" newValue="not$b" type="boolean" />
1450
+ <updateValue target="hello" newValue="$hello hello" type="text" />
1451
+ <updateValue target="n" newValue="$n+1" type="number" triggerWith="uv" />
1452
+ <callAction name="addPoint" target="g" actionName="addChildren" triggerWith="uv" >
1453
+ <label>add point</label>
1454
+ <point>(3,4)</point>
1455
+ </callAction>
1456
+ </triggerSet>
1457
+
1458
+ <updateValue name="uv" target="m" newValue="$m-1" type="number" triggerWhen="$(P.x)<0 and $(P.y)<0" />
1459
+
1460
+ `,
1461
+ },
1462
+ "*",
1463
+ );
1464
+ });
1465
+ cy.get(cesc("#\\/_text1")).should("have.text", "a"); //wait for page to load
1466
+
1467
+ cy.window().then(async (win) => {
1468
+ let stateVariables = await win.returnAllStateVariables1();
1469
+ let g = stateVariables["/g"];
1470
+
1471
+ expect(g.activeChildren.length).eq(1);
1472
+ cy.get(cesc("#\\/b")).should("have.text", "false");
1473
+ cy.get(cesc("#\\/hello")).should("have.text", "");
1474
+ cy.get(cesc("#\\/n")).should("have.text", "1");
1475
+ cy.get(cesc("#\\/m")).should("have.text", "5");
1476
+ cy.get(cesc("#\\/_triggerset1")).should("not.exist");
1477
+ cy.get(cesc("#\\/uv")).should("not.exist");
1478
+
1479
+ cy.window().then(async (win) => {
1480
+ await win.callAction1({
1481
+ actionName: "movePoint",
1482
+ componentName: "/P",
1483
+ args: { x: -1, y: -7 },
1484
+ });
1485
+ cy.get(cesc("#\\/m")).should("have.text", "4");
1486
+ cy.window().then(async (win) => {
1487
+ let stateVariables = await win.returnAllStateVariables1();
1488
+ let g = stateVariables["/g"];
1489
+ expect(g.activeChildren.length).eq(1);
1490
+ });
1491
+ cy.get(cesc("#\\/b")).should("have.text", "false");
1492
+ cy.get(cesc("#\\/hello")).should("have.text", "");
1493
+ cy.get(cesc("#\\/n")).should("have.text", "1");
1494
+ });
1495
+
1496
+ cy.window().then(async (win) => {
1497
+ await win.callAction1({
1498
+ actionName: "movePoint",
1499
+ componentName: "/P",
1500
+ args: { x: 3, y: -4 },
1501
+ });
1502
+ cy.get(cesc("#\\/b")).should("have.text", "false");
1503
+ cy.get(cesc("#\\/hello")).should("have.text", "");
1504
+ cy.get(cesc("#\\/n")).should("have.text", "1");
1505
+ cy.get(cesc("#\\/m")).should("have.text", "4");
1506
+ });
1507
+
1508
+ cy.window().then(async (win) => {
1509
+ await win.callAction1({
1510
+ actionName: "movePoint",
1511
+ componentName: "/P",
1512
+ args: { x: 1, y: 7 },
1513
+ });
1514
+
1515
+ cy.waitUntil(() =>
1516
+ cy.window().then(async (win) => {
1517
+ let stateVariables = await win.returnAllStateVariables1();
1518
+ let g = stateVariables["/g"];
1519
+ return g.activeChildren.length === 2;
1520
+ }),
1521
+ );
1522
+ cy.get(cesc("#\\/b")).should("have.text", "true");
1523
+ cy.get(cesc("#\\/hello")).should("have.text", " hello");
1524
+ cy.get(cesc("#\\/n")).should("have.text", "2");
1525
+ cy.get(cesc("#\\/m")).should("have.text", "4");
1526
+ });
1527
+
1528
+ cy.window().then(async (win) => {
1529
+ await win.callAction1({
1530
+ actionName: "movePoint",
1531
+ componentName: "/P",
1532
+ args: { x: 5, y: 9 },
1533
+ });
1534
+ cy.window().then(async (win) => {
1535
+ let stateVariables = await win.returnAllStateVariables1();
1536
+ let g = stateVariables["/g"];
1537
+ expect(g.activeChildren.length).eq(2);
1538
+ });
1539
+ cy.get(cesc("#\\/b")).should("have.text", "true");
1540
+ cy.get(cesc("#\\/hello")).should("have.text", " hello");
1541
+ cy.get(cesc("#\\/n")).should("have.text", "2");
1542
+ cy.get(cesc("#\\/m")).should("have.text", "4");
1543
+ });
1544
+
1545
+ cy.window().then(async (win) => {
1546
+ await win.callAction1({
1547
+ actionName: "movePoint",
1548
+ componentName: "/P",
1549
+ args: { x: -3, y: -4 },
1550
+ });
1551
+ cy.window().then(async (win) => {
1552
+ let stateVariables = await win.returnAllStateVariables1();
1553
+ let g = stateVariables["/g"];
1554
+ expect(g.activeChildren.length).eq(2);
1555
+ });
1556
+ cy.get(cesc("#\\/b")).should("have.text", "true");
1557
+ cy.get(cesc("#\\/hello")).should("have.text", " hello");
1558
+ cy.get(cesc("#\\/n")).should("have.text", "2");
1559
+ cy.get(cesc("#\\/m")).should("have.text", "3");
1560
+ });
1561
+
1562
+ cy.window().then(async (win) => {
1563
+ await win.callAction1({
1564
+ actionName: "movePoint",
1565
+ componentName: "/P",
1566
+ args: { x: -6, y: -5 },
1567
+ });
1568
+ cy.window().then(async (win) => {
1569
+ let stateVariables = await win.returnAllStateVariables1();
1570
+ let g = stateVariables["/g"];
1571
+ expect(g.activeChildren.length).eq(2);
1572
+ });
1573
+ cy.get(cesc("#\\/b")).should("have.text", "true");
1574
+ cy.get(cesc("#\\/hello")).should("have.text", " hello");
1575
+ cy.get(cesc("#\\/n")).should("have.text", "2");
1576
+ cy.get(cesc("#\\/m")).should("have.text", "3");
1577
+ });
1578
+
1579
+ cy.window().then(async (win) => {
1580
+ await win.callAction1({
1581
+ actionName: "movePoint",
1582
+ componentName: "/P",
1583
+ args: { x: 4, y: 2 },
1584
+ });
1585
+ cy.waitUntil(() =>
1586
+ cy.window().then(async (win) => {
1587
+ let stateVariables = await win.returnAllStateVariables1();
1588
+ let g = stateVariables["/g"];
1589
+ return g.activeChildren.length === 3;
1590
+ }),
1591
+ );
1592
+ cy.get(cesc("#\\/b")).should("have.text", "false");
1593
+ cy.get(cesc("#\\/hello")).should("have.text", " hello hello");
1594
+ cy.get(cesc("#\\/n")).should("have.text", "3");
1595
+ cy.get(cesc("#\\/m")).should("have.text", "3");
1596
+ });
1597
+
1598
+ cy.window().then(async (win) => {
1599
+ await win.callAction1({
1600
+ actionName: "movePoint",
1601
+ componentName: "/P",
1602
+ args: { x: 9, y: 7 },
1603
+ });
1604
+ cy.window().then(async (win) => {
1605
+ let stateVariables = await win.returnAllStateVariables1();
1606
+ let g = stateVariables["/g"];
1607
+ expect(g.activeChildren.length).eq(3);
1608
+ });
1609
+ cy.get(cesc("#\\/b")).should("have.text", "false");
1610
+ cy.get(cesc("#\\/hello")).should("have.text", " hello hello");
1611
+ cy.get(cesc("#\\/n")).should("have.text", "3");
1612
+ cy.get(cesc("#\\/m")).should("have.text", "3");
1613
+ });
1614
+ });
1615
+ });
1616
+
1617
+ it("triggerSet with math in label", () => {
1618
+ cy.window().then(async (win) => {
1619
+ win.postMessage(
1620
+ {
1621
+ doenetML: `
1622
+ <text>a</text>
1623
+ <p>Boolean to swap: <boolean name="b" /></p>
1624
+
1625
+ <triggerSet name="tset">
1626
+ <label>It is <math>∂f/∂x</math></label>
1627
+ <updateValue name="flip" target="b" newValue="not$b" type="boolean" />
1628
+ </triggerSet>
1629
+ `,
1630
+ },
1631
+ "*",
1632
+ );
1633
+ });
1634
+ cy.get(cesc("#\\/_text1")).should("have.text", "a"); //wait for page to load
1635
+
1636
+ cy.get(cesc("#\\/tset")).should("contain.text", "It is ∂f∂x");
1637
+
1638
+ cy.window().then(async (win) => {
1639
+ let stateVariables = await win.returnAllStateVariables1();
1640
+ expect(stateVariables["/tset"].stateValues.label).eq(
1641
+ "It is \\(\\frac{ \\partial f }{ \\partial x }\\)",
1642
+ );
1643
+ });
1644
+ });
1645
+
1646
+ it("triggerSet with label is name", () => {
1647
+ cy.window().then(async (win) => {
1648
+ win.postMessage(
1649
+ {
1650
+ doenetML: `
1651
+ <text>a</text>
1652
+ <p>Boolean to swap: <boolean name="b" /></p>
1653
+
1654
+ <triggerSet name="trigger-me" labelIsName>
1655
+ <updateValue name="flip" target="b" newValue="not$b" type="boolean" />
1656
+ </triggerSet>
1657
+ `,
1658
+ },
1659
+ "*",
1660
+ );
1661
+ });
1662
+ cy.get(cesc("#\\/_text1")).should("have.text", "a"); //wait for page to load
1663
+
1664
+ cy.get(cesc("#\\/trigger-me")).should("contain.text", "trigger me");
1665
+
1666
+ cy.window().then(async (win) => {
1667
+ let stateVariables = await win.returnAllStateVariables1();
1668
+ expect(stateVariables["/trigger-me"].stateValues.label).eq("trigger me");
1669
+ });
1670
+ });
1671
+
1672
+ it("triggerset in graph", () => {
1673
+ cy.window().then(async (win) => {
1674
+ win.postMessage(
1675
+ {
1676
+ doenetML: `
1677
+ <text>a</text>
1678
+ <p>n: <number name="n">1</number></p>
1679
+ <graph >
1680
+ <triggerset anchor="$anchorCoords1" name="triggerset1" positionFromAnchor="$positionFromAnchor1" draggable="$draggable1" disabled="$disabled1" fixed="$fixed1" fixLocation="$fixLocation1">
1681
+ <label>increment and add point</label>
1682
+ <callAction target="_graph1" actionName="addChildren">
1683
+ <point>(3,4)</point>
1684
+ </callAction>
1685
+ <updateValue target="n" newValue="$n+1" />
1686
+ </triggerset>
1687
+ <triggerset name="triggerset2">
1688
+ <label>add point 2 and decrement</label>
1689
+ <callAction target="_graph1" actionName="addChildren">
1690
+ <point>(-3,-4)</point>
1691
+ </callAction>
1692
+ <updateValue target="n" newValue="$n-1" />
1693
+
1694
+ </triggerset>
1695
+ </graph>
1696
+
1697
+ <p name="pAnchor1">Anchor 1 coordinates: $triggerset1.anchor</p>
1698
+ <p name="pAnchor2">Anchor 2 coordinates: $triggerset2.anchor</p>
1699
+ <p name="pChangeAnchor1">Change anchor 1 coordinates: <mathinput name="anchorCoords1" prefill="(1,3)" /></p>
1700
+ <p name="pChangeAnchor2">Change anchor 2 coordinates: <mathinput name="anchorCoords2" bindValueTo="$triggerset2.anchor" /></p>
1701
+ <p name="pPositionFromAnchor1">Position from anchor 1: $triggerset1.positionFromAnchor</p>
1702
+ <p name="pPositionFromAnchor2">Position from anchor 2: $triggerset2.positionFromAnchor</p>
1703
+ <p>Change position from anchor 1
1704
+ <choiceinput inline preselectChoice="1" name="positionFromAnchor1">
1705
+ <choice>upperRight</choice>
1706
+ <choice>upperLeft</choice>
1707
+ <choice>lowerRight</choice>
1708
+ <choice>lowerLeft</choice>
1709
+ <choice>left</choice>
1710
+ <choice>right</choice>
1711
+ <choice>top</choice>
1712
+ <choice>bottom</choice>
1713
+ <choice>center</choice>
1714
+ </choiceinput>
1715
+ </p>
1716
+ <p>Change position from anchor 2
1717
+ <choiceinput inline name="positionFromAnchor2" bindValueTo="$triggerset2.positionFromAnchor">
1718
+ <choice>upperRight</choice>
1719
+ <choice>upperLeft</choice>
1720
+ <choice>lowerRight</choice>
1721
+ <choice>lowerLeft</choice>
1722
+ <choice>left</choice>
1723
+ <choice>right</choice>
1724
+ <choice>top</choice>
1725
+ <choice>bottom</choice>
1726
+ <choice>center</choice>
1727
+ </choiceinput>
1728
+ </p>
1729
+ <p name="pDraggable1">Draggable 1: $draggable1</p>
1730
+ <p name="pDraggable2">Draggable 2: $draggable2</p>
1731
+ <p>Change draggable 1 <booleanInput name="draggable1" prefill="true" /></p>
1732
+ <p>Change draggable 2 <booleanInput name="draggable2" bindValueTo="$triggerset2.draggable" /></p>
1733
+ <p name="pDisabled1">Disabled 1: $disabled1</p>
1734
+ <p name="pDisabled2">Disabled 2: $disabled2</p>
1735
+ <p>Change disabled 1 <booleanInput name="disabled1" prefill="true" /></p>
1736
+ <p>Change disabled 2 <booleanInput name="disabled2" bindValueTo="$triggerset2.disabled" /></p>
1737
+ <p name="pFixed1">Fixed 1: $fixed1</p>
1738
+ <p name="pFixed2">Fixed 2: $fixed2</p>
1739
+ <p>Change fixed 1 <booleanInput name="fixed1" prefill="false" /></p>
1740
+ <p>Change fixed 2 <booleanInput name="fixed2" bindValueTo="$triggerset2.fixed" /></p>
1741
+ <p name="pFixLocation1">FixLocation 1: $fixLocation1</p>
1742
+ <p name="pFixLocation2">FixLocation 2: $fixLocation2</p>
1743
+ <p>Change fixLocation 1 <booleanInput name="fixLocation1" prefill="false" /></p>
1744
+ <p>Change fixLocation 2 <booleanInput name="fixLocation2" bindValueTo="$triggerset2.fixLocation" /></p>
1745
+ <p><booleaninput name="bi" /> <boolean name="b" copySource="bi" /></p>
1746
+
1747
+ `,
1748
+ },
1749
+ "*",
1750
+ );
1751
+ });
1752
+
1753
+ // TODO: how to click on the buttons and test if they are disabled?
1754
+
1755
+ cy.get(cesc("#\\/_text1")).should("have.text", "a"); // to wait until loaded
1756
+
1757
+ cy.get(cesc("#\\/pAnchor1") + " .mjx-mrow")
1758
+ .eq(0)
1759
+ .should("have.text", "(1,3)");
1760
+ cy.get(cesc("#\\/pAnchor2") + " .mjx-mrow")
1761
+ .eq(0)
1762
+ .should("have.text", "(0,0)");
1763
+
1764
+ cy.get(cesc("#\\/pPositionFromAnchor1")).should(
1765
+ "have.text",
1766
+ "Position from anchor 1: upperright",
1767
+ );
1768
+ cy.get(cesc("#\\/pPositionFromAnchor2")).should(
1769
+ "have.text",
1770
+ "Position from anchor 2: center",
1771
+ );
1772
+ cy.get(cesc("#\\/positionFromAnchor1")).should("have.value", "1");
1773
+ cy.get(cesc("#\\/positionFromAnchor2")).should("have.value", "9");
1774
+ cy.get(cesc("#\\/pDraggable1")).should("have.text", "Draggable 1: true");
1775
+ cy.get(cesc("#\\/pDraggable2")).should("have.text", "Draggable 2: true");
1776
+
1777
+ cy.log("move triggersets by dragging");
1778
+
1779
+ cy.window().then(async (win) => {
1780
+ win.callAction1({
1781
+ actionName: "moveButton",
1782
+ componentName: "/triggerset1",
1783
+ args: { x: -2, y: 3 },
1784
+ });
1785
+ win.callAction1({
1786
+ actionName: "moveButton",
1787
+ componentName: "/triggerset2",
1788
+ args: { x: 4, y: -5 },
1789
+ });
1790
+ });
1791
+
1792
+ cy.get(cesc("#\\/pAnchor2") + " .mjx-mrow").should(
1793
+ "contain.text",
1794
+ "(4,−5)",
1795
+ );
1796
+
1797
+ cy.get(cesc("#\\/pAnchor1") + " .mjx-mrow")
1798
+ .eq(0)
1799
+ .should("have.text", "(−2,3)");
1800
+ cy.get(cesc("#\\/pAnchor2") + " .mjx-mrow")
1801
+ .eq(0)
1802
+ .should("have.text", "(4,−5)");
1803
+
1804
+ cy.log("move triggersets by entering coordinates");
1805
+
1806
+ cy.get(cesc("#\\/anchorCoords1") + " textarea").type(
1807
+ "{home}{shift+end}{backspace}(6,7){enter}",
1808
+ { force: true },
1809
+ );
1810
+ cy.get(cesc("#\\/anchorCoords2") + " textarea").type(
1811
+ "{home}{shift+end}{backspace}(8,9){enter}",
1812
+ { force: true },
1813
+ );
1814
+
1815
+ cy.get(cesc("#\\/pAnchor2") + " .mjx-mrow").should("contain.text", "(8,9)");
1816
+
1817
+ cy.get(cesc("#\\/pAnchor1") + " .mjx-mrow")
1818
+ .eq(0)
1819
+ .should("have.text", "(6,7)");
1820
+ cy.get(cesc("#\\/pAnchor2") + " .mjx-mrow")
1821
+ .eq(0)
1822
+ .should("have.text", "(8,9)");
1823
+
1824
+ cy.log("change position from anchor");
1825
+ cy.get(cesc("#\\/positionFromAnchor1")).select("lowerLeft");
1826
+ cy.get(cesc("#\\/positionFromAnchor2")).select("lowerRight");
1827
+
1828
+ cy.get(cesc("#\\/pPositionFromAnchor1")).should(
1829
+ "have.text",
1830
+ "Position from anchor 1: lowerleft",
1831
+ );
1832
+ cy.get(cesc("#\\/pPositionFromAnchor2")).should(
1833
+ "have.text",
1834
+ "Position from anchor 2: lowerright",
1835
+ );
1836
+
1837
+ cy.log("make not draggable");
1838
+
1839
+ cy.get(cesc("#\\/draggable1")).click();
1840
+ cy.get(cesc("#\\/draggable2")).click();
1841
+ cy.get(cesc("#\\/pDraggable1")).should("have.text", "Draggable 1: false");
1842
+ cy.get(cesc("#\\/pDraggable2")).should("have.text", "Draggable 2: false");
1843
+
1844
+ cy.log("cannot move triggersets by dragging");
1845
+ cy.window().then(async (win) => {
1846
+ win.callAction1({
1847
+ actionName: "moveButton",
1848
+ componentName: "/triggerset1",
1849
+ args: { x: -10, y: -9 },
1850
+ });
1851
+ win.callAction1({
1852
+ actionName: "moveButton",
1853
+ componentName: "/triggerset2",
1854
+ args: { x: -8, y: -7 },
1855
+ });
1856
+ });
1857
+
1858
+ // since nothing will change, wait for boolean input to change to know core has responded
1859
+ cy.get(cesc("#\\/bi")).click();
1860
+ cy.get(cesc("#\\/b")).should("have.text", "true");
1861
+
1862
+ cy.get(cesc("#\\/pAnchor1") + " .mjx-mrow")
1863
+ .eq(0)
1864
+ .should("have.text", "(6,7)");
1865
+ cy.get(cesc("#\\/pAnchor2") + " .mjx-mrow")
1866
+ .eq(0)
1867
+ .should("have.text", "(8,9)");
1868
+
1869
+ cy.log("make draggable again");
1870
+
1871
+ cy.get(cesc("#\\/draggable1")).click();
1872
+ cy.get(cesc("#\\/draggable2")).click();
1873
+ cy.get(cesc("#\\/pDraggable1")).should("have.text", "Draggable 1: true");
1874
+ cy.get(cesc("#\\/pDraggable2")).should("have.text", "Draggable 2: true");
1875
+
1876
+ cy.window().then(async (win) => {
1877
+ win.callAction1({
1878
+ actionName: "moveButton",
1879
+ componentName: "/triggerset1",
1880
+ args: { x: -10, y: -9 },
1881
+ });
1882
+ win.callAction1({
1883
+ actionName: "moveButton",
1884
+ componentName: "/triggerset2",
1885
+ args: { x: -8, y: -7 },
1886
+ });
1887
+ });
1888
+
1889
+ cy.get(cesc("#\\/pAnchor2") + " .mjx-mrow").should(
1890
+ "contain.text",
1891
+ "(−8,−7)",
1892
+ );
1893
+
1894
+ cy.get(cesc("#\\/pAnchor1") + " .mjx-mrow")
1895
+ .eq(0)
1896
+ .should("have.text", "(−10,−9)");
1897
+ cy.get(cesc("#\\/pAnchor2") + " .mjx-mrow")
1898
+ .eq(0)
1899
+ .should("have.text", "(−8,−7)");
1900
+
1901
+ cy.log("fix location");
1902
+
1903
+ cy.get(cesc("#\\/fixLocation1")).click();
1904
+ cy.get(cesc("#\\/fixLocation2")).click();
1905
+ cy.get(cesc("#\\/pFixLocation1")).should(
1906
+ "have.text",
1907
+ "FixLocation 1: true",
1908
+ );
1909
+ cy.get(cesc("#\\/pFixLocation2")).should(
1910
+ "have.text",
1911
+ "FixLocation 2: true",
1912
+ );
1913
+
1914
+ cy.log("can change coordinates entering coordinates only for button 1");
1915
+
1916
+ cy.get(cesc("#\\/anchorCoords2") + " textarea").type(
1917
+ "{home}{shift+end}{backspace}(3,4){enter}",
1918
+ { force: true },
1919
+ );
1920
+ cy.get(cesc("#\\/anchorCoords1") + " textarea").type(
1921
+ "{home}{shift+end}{backspace}(1,2){enter}",
1922
+ { force: true },
1923
+ );
1924
+
1925
+ cy.get(cesc("#\\/pAnchor1") + " .mjx-mrow").should("contain.text", "(1,2)");
1926
+
1927
+ cy.get(cesc("#\\/pAnchor1") + " .mjx-mrow")
1928
+ .eq(0)
1929
+ .should("have.text", "(1,2)");
1930
+ cy.get(cesc("#\\/pAnchor2") + " .mjx-mrow")
1931
+ .eq(0)
1932
+ .should("have.text", "(−8,−7)");
1933
+
1934
+ cy.log("cannot move triggersets by dragging");
1935
+ cy.window().then(async (win) => {
1936
+ win.callAction1({
1937
+ actionName: "moveButton",
1938
+ componentName: "/triggerset1",
1939
+ args: { x: 4, y: 6 },
1940
+ });
1941
+ win.callAction1({
1942
+ actionName: "moveButton",
1943
+ componentName: "/triggerset2",
1944
+ args: { x: 7, y: 8 },
1945
+ });
1946
+ });
1947
+
1948
+ // since nothing will change, wait for boolean input to change to know core has responded
1949
+ cy.get(cesc("#\\/bi")).click();
1950
+ cy.get(cesc("#\\/b")).should("have.text", "false");
1951
+
1952
+ cy.get(cesc("#\\/pAnchor1") + " .mjx-mrow")
1953
+ .eq(0)
1954
+ .should("have.text", "(1,2)");
1955
+ cy.get(cesc("#\\/pAnchor2") + " .mjx-mrow")
1956
+ .eq(0)
1957
+ .should("have.text", "(−8,−7)");
1958
+
1959
+ cy.log("can change position from anchor only for button 1");
1960
+ cy.get(cesc("#\\/positionFromAnchor2")).select("bottom");
1961
+ cy.get(cesc("#\\/positionFromAnchor1")).select("top");
1962
+
1963
+ cy.get(cesc("#\\/pPositionFromAnchor1")).should(
1964
+ "have.text",
1965
+ "Position from anchor 1: top",
1966
+ );
1967
+ cy.get(cesc("#\\/pPositionFromAnchor2")).should(
1968
+ "have.text",
1969
+ "Position from anchor 2: lowerright",
1970
+ );
1971
+
1972
+ cy.log("can change disabled attribute");
1973
+ cy.get(cesc("#\\/disabled1")).click();
1974
+ cy.get(cesc("#\\/disabled2")).click();
1975
+ cy.get(cesc("#\\/pDisabled1")).should("have.text", "Disabled 1: false");
1976
+ cy.get(cesc("#\\/pDisabled2")).should("have.text", "Disabled 2: true");
1977
+
1978
+ cy.log("make completely fixed");
1979
+ cy.get(cesc("#\\/fixed1")).click();
1980
+ cy.get(cesc("#\\/fixed2")).click();
1981
+ cy.get(cesc("#\\/pFixed1")).should("have.text", "Fixed 1: true");
1982
+ cy.get(cesc("#\\/pFixed2")).should("have.text", "Fixed 2: true");
1983
+
1984
+ cy.log("can change coordinates entering coordinates only for button 1");
1985
+
1986
+ cy.get(cesc("#\\/anchorCoords2") + " textarea").type(
1987
+ "{home}{shift+end}{backspace}(7,8){enter}",
1988
+ { force: true },
1989
+ );
1990
+ cy.get(cesc("#\\/anchorCoords1") + " textarea").type(
1991
+ "{home}{shift+end}{backspace}(5,6){enter}",
1992
+ { force: true },
1993
+ );
1994
+
1995
+ cy.get(cesc("#\\/pAnchor1") + " .mjx-mrow").should("contain.text", "(5,6)");
1996
+
1997
+ cy.get(cesc("#\\/pAnchor1") + " .mjx-mrow")
1998
+ .eq(0)
1999
+ .should("have.text", "(5,6)");
2000
+ cy.get(cesc("#\\/pAnchor2") + " .mjx-mrow")
2001
+ .eq(0)
2002
+ .should("have.text", "(−8,−7)");
2003
+
2004
+ cy.log("can change position from anchor only for button 1");
2005
+ cy.get(cesc("#\\/positionFromAnchor2")).select("left");
2006
+ cy.get(cesc("#\\/positionFromAnchor1")).select("right");
2007
+
2008
+ cy.get(cesc("#\\/pPositionFromAnchor1")).should(
2009
+ "have.text",
2010
+ "Position from anchor 1: right",
2011
+ );
2012
+ cy.get(cesc("#\\/pPositionFromAnchor2")).should(
2013
+ "have.text",
2014
+ "Position from anchor 2: lowerright",
2015
+ );
2016
+
2017
+ cy.log("can change disabled attribute only for button 1");
2018
+ cy.get(cesc("#\\/disabled2")).click();
2019
+ cy.get(cesc("#\\/disabled1")).click();
2020
+ cy.get(cesc("#\\/pDisabled1")).should("have.text", "Disabled 1: true");
2021
+ cy.get(cesc("#\\/pDisabled2")).should("have.text", "Disabled 2: true");
2022
+ });
2023
+ });