jspsych-tangram 0.0.5 → 0.0.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.cjs CHANGED
@@ -3549,6 +3549,7 @@ function startConstructionTrial(display_element, params, _jsPsych) {
3549
3549
  "medtriangle",
3550
3550
  "largetriangle"
3551
3551
  ]);
3552
+ const PRIMITIVE_BLUEPRINTS_ORDERED = [...PRIMITIVE_BLUEPRINTS].sort((a, b) => params.primitiveOrder.indexOf(a.kind) - params.primitiveOrder.indexOf(b.kind));
3552
3553
  const sectors = params.tangrams.map((tangramSpec, index) => {
3553
3554
  const filteredTans = tangramSpec.solutionTans.filter((tan) => {
3554
3555
  const tanName = tan.name ?? tan.kind;
@@ -3575,7 +3576,7 @@ function startConstructionTrial(display_element, params, _jsPsych) {
3575
3576
  const firstMacro = params.quickstash_macros[0];
3576
3577
  if (firstMacro && "parts" in firstMacro && firstMacro.parts && firstMacro.parts[0] && "anchorOffset" in firstMacro.parts[0]) {
3577
3578
  const primsByKind = /* @__PURE__ */ new Map();
3578
- PRIMITIVE_BLUEPRINTS.forEach((p) => primsByKind.set(p.kind, p));
3579
+ PRIMITIVE_BLUEPRINTS_ORDERED.forEach((p) => primsByKind.set(p.kind, p));
3579
3580
  quickstash = params.quickstash_macros.map(
3580
3581
  (anchorComposite) => convertAnchorCompositeToPixels(anchorComposite, primsByKind, CONFIG.layout.grid.stepPx)
3581
3582
  // Use current CONFIG grid step
@@ -3587,7 +3588,7 @@ function startConstructionTrial(display_element, params, _jsPsych) {
3587
3588
  const gameBoardProps = {
3588
3589
  sectors,
3589
3590
  quickstash,
3590
- primitives: PRIMITIVE_BLUEPRINTS,
3591
+ primitives: PRIMITIVE_BLUEPRINTS_ORDERED,
3591
3592
  layout: params.layout,
3592
3593
  target: params.target,
3593
3594
  input: params.input,
@@ -3618,6 +3619,12 @@ const info$1 = {
3618
3619
  default: [],
3619
3620
  description: "Array of MacroSpec objects created in prep trial"
3620
3621
  },
3622
+ /** Array of primitive names in the order they should be displayed */
3623
+ primitive_order: {
3624
+ type: jspsych.ParameterType.OBJECT,
3625
+ default: ["square", "smalltriangle", "parallelogram", "medtriangle", "largetriangle"],
3626
+ description: "Array of primitive names in the order they should be displayed"
3627
+ },
3621
3628
  /** Whether to place pieces in workspace or directly on silhouette */
3622
3629
  target: {
3623
3630
  type: jspsych.ParameterType.SELECT,
@@ -3719,6 +3726,7 @@ class TangramConstructPlugin {
3719
3726
  const params = {
3720
3727
  tangrams: trial.tangrams,
3721
3728
  quickstash_macros: trial.quickstash_macros,
3729
+ primitiveOrder: trial.primitive_order,
3722
3730
  target: trial.target,
3723
3731
  input: trial.input,
3724
3732
  layout: trial.layout,
@@ -3740,9 +3748,11 @@ function startPrepTrial(display_element, params, jsPsych) {
3740
3748
  layoutMode,
3741
3749
  requireAllSlots,
3742
3750
  quickstashMacros,
3751
+ primitiveOrder,
3743
3752
  onInteraction,
3744
3753
  onTrialEnd
3745
3754
  } = params;
3755
+ const PRIMITIVE_BLUEPRINTS_ORDERED = [...PRIMITIVE_BLUEPRINTS].sort((a, b) => primitiveOrder.indexOf(a.kind) - primitiveOrder.indexOf(b.kind));
3746
3756
  const prepSectors = Array.from({ length: numQuickstashSlots }, (_, i) => ({
3747
3757
  id: `prep-sector-${i}`,
3748
3758
  tangramId: `prep-sector-${i}`,
@@ -3756,7 +3766,7 @@ function startPrepTrial(display_element, params, jsPsych) {
3756
3766
  const handleControllerReady = (controller, layout, force) => {
3757
3767
  if (quickstashMacros && quickstashMacros.length > 0 && layout) {
3758
3768
  const primsByKind = /* @__PURE__ */ new Map();
3759
- PRIMITIVE_BLUEPRINTS.forEach((p) => primsByKind.set(p.kind, p));
3769
+ PRIMITIVE_BLUEPRINTS_ORDERED.forEach((p) => primsByKind.set(p.kind, p));
3760
3770
  quickstashMacros.forEach((anchorComposite, macroIndex) => {
3761
3771
  const sectorId = `prep-sector-${macroIndex}`;
3762
3772
  const compositeBlueprint = convertAnchorCompositeToPixels(
@@ -3813,7 +3823,7 @@ function startPrepTrial(display_element, params, jsPsych) {
3813
3823
  sectors: prepSectors,
3814
3824
  quickstash: [],
3815
3825
  // No pre-made macros
3816
- primitives: PRIMITIVE_BLUEPRINTS,
3826
+ primitives: PRIMITIVE_BLUEPRINTS_ORDERED,
3817
3827
  layout: layoutMode,
3818
3828
  target: "workspace",
3819
3829
  // Pieces go in sectors
@@ -3874,6 +3884,12 @@ const info = {
3874
3884
  default: [],
3875
3885
  description: "Array of AnchorComposite objects to edit as primitive pieces"
3876
3886
  },
3887
+ /** Array of primitive names in the order they should be displayed */
3888
+ primitive_order: {
3889
+ type: jspsych.ParameterType.OBJECT,
3890
+ default: ["square", "smalltriangle", "parallelogram", "medtriangle", "largetriangle"],
3891
+ description: "Array of primitive names in the order they should be displayed"
3892
+ },
3877
3893
  /** Callback fired after each interaction (optional analytics hook) */
3878
3894
  onInteraction: {
3879
3895
  type: jspsych.ParameterType.FUNCTION,
@@ -3924,6 +3940,7 @@ class TangramPrepPlugin {
3924
3940
  layoutMode: trial.layout,
3925
3941
  requireAllSlots: trial.require_all_slots,
3926
3942
  quickstashMacros: trial.quickstash_macros,
3943
+ primitiveOrder: trial.primitive_order,
3927
3944
  onInteraction: trial.onInteraction,
3928
3945
  onTrialEnd: wrappedOnTrialEnd
3929
3946
  };