@tspro/web-music-score 5.4.2 → 5.5.1

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 (43) hide show
  1. package/CHANGELOG.md +15 -0
  2. package/LICENSE +24 -0
  3. package/README.md +8 -546
  4. package/dist/audio/index.d.ts +1 -1
  5. package/dist/audio/index.js +1748 -5
  6. package/dist/audio/index.mjs +9 -6
  7. package/dist/audio-cg/index.js +17487 -46
  8. package/dist/audio-cg/index.mjs +7 -5
  9. package/dist/audio-synth/index.js +18434 -32
  10. package/dist/audio-synth/index.mjs +12 -7
  11. package/dist/chunk-7GVRGM3N.mjs +101 -0
  12. package/dist/chunk-AUOH7S2E.mjs +3877 -0
  13. package/dist/{chunk-MMWSQGVR.mjs → chunk-BZE5UGTJ.mjs} +3 -3
  14. package/dist/{chunk-CVYTUTL6.mjs → chunk-FLBNOYUN.mjs} +2 -2
  15. package/dist/{chunk-42IBAVOC.mjs → chunk-KKIFSIFK.mjs} +18 -13
  16. package/dist/chunk-L7VPSGMT.mjs +18381 -0
  17. package/dist/core/index.js +2 -2
  18. package/dist/core/index.mjs +4 -4
  19. package/dist/{guitar-CNOxM4ZK.d.ts → guitar-CarHGDAt.d.ts} +1 -1
  20. package/dist/iife/audio-cg.global.js +1 -1
  21. package/dist/iife/index.global.js +13 -13
  22. package/dist/{music-objects-DqoO-Sfv.d.mts → music-objects-CcJvZxS6.d.mts} +123 -96
  23. package/dist/{music-objects-T8u8bnNP.d.ts → music-objects-l5Ai97QA.d.ts} +125 -98
  24. package/dist/{note-RVXvpfyV.d.ts → note-CJuq5aBy.d.ts} +1 -1
  25. package/dist/pieces/index.d.mts +12 -6
  26. package/dist/pieces/index.d.ts +14 -8
  27. package/dist/pieces/index.js +25 -13
  28. package/dist/pieces/index.mjs +25 -14
  29. package/dist/react-ui/index.d.mts +1 -1
  30. package/dist/react-ui/index.d.ts +5 -5
  31. package/dist/react-ui/index.js +2274 -22
  32. package/dist/react-ui/index.mjs +18 -15
  33. package/dist/{scale-CUYFBo-8.d.ts → scale-DulPFco_.d.ts} +2 -2
  34. package/dist/score/index.d.mts +51 -3
  35. package/dist/score/index.d.ts +54 -6
  36. package/dist/score/index.js +4941 -872
  37. package/dist/score/index.mjs +1282 -729
  38. package/dist/{tempo-DwuZsv2T.d.ts → tempo-BnUjm25M.d.ts} +1 -1
  39. package/dist/theory/index.d.ts +6 -6
  40. package/dist/theory/index.js +2687 -136
  41. package/dist/theory/index.mjs +41 -49
  42. package/package.json +4 -5
  43. package/dist/chunk-ROBXPR34.mjs +0 -9
@@ -1,18 +1,126 @@
1
- /* WebMusicScore v5.4.2 | (c) 2023-2025 PahkaSoft | MIT License | Includes: Tone.js (MIT License) */
1
+ /* WebMusicScore v5.5.1 | (c) 2023-2025 PahkaSoft | MIT License | Includes: Tone.js (MIT License), Color Name to Code (MIT License) */
2
2
  import {
3
3
  MusicError
4
- } from "../chunk-MMWSQGVR.mjs";
4
+ } from "../chunk-BZE5UGTJ.mjs";
5
5
  import {
6
6
  NoteLengthProps,
7
7
  RhythmProps,
8
8
  validateNoteLength
9
- } from "../chunk-42IBAVOC.mjs";
9
+ } from "../chunk-KKIFSIFK.mjs";
10
10
  import {
11
- __publicField
12
- } from "../chunk-ROBXPR34.mjs";
11
+ AnchoredRect,
12
+ BiMap,
13
+ IndexArray,
14
+ Rect,
15
+ TriMap,
16
+ UniMap,
17
+ ValueSet,
18
+ Vec,
19
+ asMulti,
20
+ device_exports,
21
+ guard_exports,
22
+ utils_exports
23
+ } from "../chunk-AUOH7S2E.mjs";
24
+ import {
25
+ __publicField,
26
+ __spreadProps,
27
+ __spreadValues
28
+ } from "../chunk-7GVRGM3N.mjs";
29
+
30
+ // src/score/engine/settings.ts
31
+ var DebugSettings = {
32
+ DrawDebugRects: false,
33
+ DisableBeams: false
34
+ };
35
+ var DocumentSettings = {
36
+ DocumentScale: 1,
37
+ MinStaffWidth: 75,
38
+ MinColumnsWidth: 10,
39
+ ColumnWidthScale: 1.7,
40
+ PostMeasureBreakWidth: 10,
41
+ NoteDotSpace: 0.5,
42
+ NoteAccSpace: 0.5,
43
+ NoteHeadWidth: 2,
44
+ NoteHeadHeight: 1.3,
45
+ DiamondNoteHeadSize: 1.8,
46
+ DotSize: 0.8,
47
+ StemHeight: 7,
48
+ // One octave
49
+ FlagWidth: 1.5,
50
+ FlagHeight: 4,
51
+ FlagSeparation: 2,
52
+ BeamSeparation: 1.25,
53
+ BeamAngleFactor: 0.5,
54
+ BeamThickness: 4,
55
+ RestDotSpace: 0.5,
56
+ LedgerLineWidth: 3.6,
57
+ StubTieLength: 5,
58
+ StaffHeight: 8,
59
+ TabHeight: 20
60
+ };
61
+ var DocumentColor = {
62
+ HilightStaffPos: "#55cc55",
63
+ HilightObject: "#55cc55",
64
+ PlayCursor: "#44aa44",
65
+ Background: "white",
66
+ Header_Title: "black",
67
+ Header_Composer: "black",
68
+ Header_Arranger: "black",
69
+ RowGroup_Instrument: "black",
70
+ RowGroup_Frame: "black",
71
+ Staff_Frame: "black",
72
+ Staff_Note: "black",
73
+ Staff_Rest: "black",
74
+ Staff_Connective: "black",
75
+ Staff_Signature_Clef: "black",
76
+ Staff_Signature_Key: "black",
77
+ Staff_Signature_Time: "black",
78
+ Staff_Signature_Tempo: "black",
79
+ Staff_Signature_MeasureNum: "black",
80
+ Staff_Element_Fermata: "black",
81
+ Staff_Element_Annotation: "black",
82
+ Staff_Element_Navigation: "black",
83
+ Staff_Element_Label: "black",
84
+ Tab_Frame: "black",
85
+ Tab_Note: "black",
86
+ Tab_Rest: "black",
87
+ Tab_Connective: "black",
88
+ Tab_Tuning: "black",
89
+ //Tab_Signature_Clef: "black",
90
+ //Tab_Signature_Key: "black",
91
+ Tab_Signature_Time: "black",
92
+ Tab_Signature_Tempo: "black",
93
+ Tab_Signature_MeasureNum: "black",
94
+ Tab_Element_Fermata: "black",
95
+ Tab_Element_Annotation: "black",
96
+ Tab_Element_Navigation: "black",
97
+ Tab_Element_Label: "black"
98
+ };
99
+
100
+ // src/score/pub/color.ts
101
+ function eq(a, b) {
102
+ return a.toLocaleLowerCase() === b.toLocaleLowerCase();
103
+ }
104
+ function setColor(color, ...colorAttrs) {
105
+ const setBacground = colorAttrs.length === 1 && eq(colorAttrs[0], "background");
106
+ const setAllColors = colorAttrs.length === 0;
107
+ if (eq(color, ""))
108
+ color = setBacground ? "white" : "black";
109
+ let noMatch = true;
110
+ for (const key in DocumentColor) {
111
+ const keyAttrs = key.split("_");
112
+ const isColorMatch = colorAttrs.length > 0 && colorAttrs.every((a) => keyAttrs.some((b) => eq(a, b)));
113
+ const isBgColorMatch = keyAttrs.length === 1 && eq(keyAttrs[0], "background");
114
+ if (setAllColors && !isBgColorMatch || isColorMatch) {
115
+ DocumentColor[key] = color;
116
+ noMatch = false;
117
+ }
118
+ }
119
+ if (noMatch)
120
+ console.error(`Color attrs ${utils_exports.Str.stringify(colorAttrs)} did not match any color.`);
121
+ }
13
122
 
14
123
  // src/score/pub/div-rect.ts
15
- import { Utils } from "@tspro/ts-utils-lib";
16
124
  var DivRect = class _DivRect {
17
125
  constructor(...args) {
18
126
  __publicField(this, "left");
@@ -284,10 +392,10 @@ var DivRect = class _DivRect {
284
392
  clipInPlace(clipRect) {
285
393
  this.left = Math.max(this.left, clipRect.left);
286
394
  this.right = Math.min(this.right, clipRect.right);
287
- this.anchorX = Utils.Math.clamp(this.anchorX, this.left, this.right);
395
+ this.anchorX = utils_exports.Math.clamp(this.anchorX, this.left, this.right);
288
396
  this.top = Math.max(this.top, clipRect.top);
289
397
  this.bottom = Math.min(this.bottom, clipRect.bottom);
290
- this.anchorY = Utils.Math.clamp(this.anchorY, this.top, this.bottom);
398
+ this.anchorY = utils_exports.Math.clamp(this.anchorY, this.top, this.bottom);
291
399
  return this;
292
400
  }
293
401
  /**
@@ -333,11 +441,7 @@ var DivRect = class _DivRect {
333
441
  }
334
442
  };
335
443
 
336
- // src/score/pub/document-builder.ts
337
- import { Guard as Guard12, Utils as Utils12 } from "@tspro/ts-utils-lib";
338
-
339
444
  // src/score/pub/types.ts
340
- import { Guard } from "@tspro/ts-utils-lib";
341
445
  var StaffPreset = /* @__PURE__ */ ((StaffPreset2) => {
342
446
  StaffPreset2["Treble"] = "treble";
343
447
  StaffPreset2["Bass"] = "bass";
@@ -356,7 +460,7 @@ function getVoiceIds() {
356
460
  return [0, 1, 2, 3];
357
461
  }
358
462
  function isVoiceId(voiceId) {
359
- return Guard.isIncluded(voiceId, getVoiceIds());
463
+ return guard_exports.isIncluded(voiceId, getVoiceIds());
360
464
  }
361
465
  function validateVoiceId(voiceId) {
362
466
  if (isVoiceId(voiceId)) {
@@ -369,7 +473,7 @@ function getStringNumbers() {
369
473
  return [1, 2, 3, 4, 5, 6];
370
474
  }
371
475
  function isStringNumber(stringNum) {
372
- return Guard.isIncluded(stringNum, getStringNumbers());
476
+ return guard_exports.isIncluded(stringNum, getStringNumbers());
373
477
  }
374
478
  function validateStringNumber(stringNum) {
375
479
  if (isStringNumber(stringNum)) {
@@ -382,7 +486,7 @@ function getVerseNumbers() {
382
486
  return [1, 2, 3];
383
487
  }
384
488
  function isVerseNumber(verse) {
385
- return Guard.isIncluded(verse, getVerseNumbers());
489
+ return guard_exports.isIncluded(verse, getVerseNumbers());
386
490
  }
387
491
  function validateVerseNumber(verseNum) {
388
492
  if (isVerseNumber(verseNum)) {
@@ -497,7 +601,6 @@ var PlayState = /* @__PURE__ */ ((PlayState2) => {
497
601
  })(PlayState || {});
498
602
 
499
603
  // src/score/engine/music-object.ts
500
- import { AnchoredRect } from "@tspro/ts-utils-lib";
501
604
  var MusicObjectLink = class {
502
605
  constructor(head) {
503
606
  __publicField(this, "head");
@@ -526,6 +629,7 @@ var MusicObject = class {
526
629
  this.parent = parent;
527
630
  __publicField(this, "anchoredLayoutObjects", []);
528
631
  __publicField(this, "link");
632
+ __publicField(this, "userData", {});
529
633
  __publicField(this, "rect", new AnchoredRect());
530
634
  __publicField(this, "needRectUpdate", true);
531
635
  }
@@ -616,58 +720,413 @@ import { Note as Note9 } from "@tspro/web-music-score/theory";
616
720
  // src/score/engine/obj-staff-and-tab.ts
617
721
  import { getTuningStrings, Note as Note8, validateTuningName } from "@tspro/web-music-score/theory";
618
722
 
619
- // src/score/engine/render-context.ts
620
- import { Utils as Utils2, Vec, Device, UniMap, AnchoredRect as AnchoredRect2 } from "@tspro/ts-utils-lib";
723
+ // node_modules/color-name-to-code/dist/color-name.enum.js
724
+ var ColorName;
725
+ (function(ColorName2) {
726
+ ColorName2["AliceBlue"] = "aliceblue";
727
+ ColorName2["AntiqueWhite"] = "antiquewhite";
728
+ ColorName2["Aqua"] = "aqua";
729
+ ColorName2["Aquamarine"] = "aquamarine";
730
+ ColorName2["Azure"] = "azure";
731
+ ColorName2["Beige"] = "beige";
732
+ ColorName2["Bisque"] = "bisque";
733
+ ColorName2["Black"] = "black";
734
+ ColorName2["BlanchedAlmond"] = "blanchedalmond";
735
+ ColorName2["Blue"] = "blue";
736
+ ColorName2["BlueViolet"] = "blueviolet";
737
+ ColorName2["Brown"] = "brown";
738
+ ColorName2["BurlyWood"] = "burlywood";
739
+ ColorName2["CadetBlue"] = "cadetblue";
740
+ ColorName2["Chartreuse"] = "chartreuse";
741
+ ColorName2["Chocolate"] = "chocolate";
742
+ ColorName2["Coral"] = "coral";
743
+ ColorName2["CornflowerBlue"] = "cornflowerblue";
744
+ ColorName2["CornSilk"] = "cornsilk";
745
+ ColorName2["Crimson"] = "crimson";
746
+ ColorName2["Cyan"] = "cyan";
747
+ ColorName2["DarkBlue"] = "darkblue";
748
+ ColorName2["DarkCyan"] = "darkcyan";
749
+ ColorName2["DarkGoldenRod"] = "darkgoldenrod";
750
+ ColorName2["DarkGray"] = "darkgray";
751
+ ColorName2["DarkGreen"] = "darkgreen";
752
+ ColorName2["DarkGrey"] = "darkgrey";
753
+ ColorName2["DarkKhaki"] = "darkkhaki";
754
+ ColorName2["DarkMagenta"] = "darkmagenta";
755
+ ColorName2["DarkOliveGreen"] = "darkolivegreen";
756
+ ColorName2["DarkOrange"] = "darkorange";
757
+ ColorName2["DarkOrchid"] = "darkorchid";
758
+ ColorName2["DarkRed"] = "darkred";
759
+ ColorName2["DarkSalmon"] = "darksalmon";
760
+ ColorName2["DarkSeaGreen"] = "darkseagreen";
761
+ ColorName2["DarkSlateBlue"] = "darkslateblue";
762
+ ColorName2["DarkSlateGray"] = "darkslategray";
763
+ ColorName2["DarkSlateGrey"] = "darkslategrey";
764
+ ColorName2["DarkTurquoise"] = "darkturquoise";
765
+ ColorName2["DarkViolet"] = "darkviolet";
766
+ ColorName2["DeepPink"] = "deeppink";
767
+ ColorName2["DeepSkyBlue"] = "deepskyblue";
768
+ ColorName2["DimGray"] = "dimgray";
769
+ ColorName2["DimGrey"] = "dimgrey";
770
+ ColorName2["DodgerBlue"] = "dodgerblue";
771
+ ColorName2["FireBrick"] = "firebrick";
772
+ ColorName2["FloralWhite"] = "floralwhite";
773
+ ColorName2["ForestGreen"] = "forestgreen";
774
+ ColorName2["Fuchsia"] = "fuchsia";
775
+ ColorName2["Gainsboro"] = "gainsboro";
776
+ ColorName2["GhostWhite"] = "ghostwhite";
777
+ ColorName2["Gold"] = "gold";
778
+ ColorName2["GoldenRod"] = "goldenrod";
779
+ ColorName2["Gray"] = "gray";
780
+ ColorName2["Green"] = "green";
781
+ ColorName2["GreenYellow"] = "greenyellow";
782
+ ColorName2["Grey"] = "grey";
783
+ ColorName2["Honeydew"] = "honeydew";
784
+ ColorName2["HotPink"] = "hotpink";
785
+ ColorName2["IndianRed"] = "indianred";
786
+ ColorName2["Indigo"] = "indigo";
787
+ ColorName2["Ivory"] = "ivory";
788
+ ColorName2["Khaki"] = "khaki";
789
+ ColorName2["Lavender"] = "lavender";
790
+ ColorName2["LavenderBlush"] = "lavenderblush";
791
+ ColorName2["LawnGreen"] = "lawngreen";
792
+ ColorName2["LemonChiffon"] = "lemonchiffon";
793
+ ColorName2["LightBlue"] = "lightblue";
794
+ ColorName2["LightCoral"] = "lightcoral";
795
+ ColorName2["LightCyan"] = "lightcyan";
796
+ ColorName2["LightGoldenRodYellow"] = "lightgoldenrodyellow";
797
+ ColorName2["LightGray"] = "lightgray";
798
+ ColorName2["LightGreen"] = "lightgreen";
799
+ ColorName2["LightGrey"] = "lightgrey";
800
+ ColorName2["LightPink"] = "lightpink";
801
+ ColorName2["LightSalmon"] = "lightsalmon";
802
+ ColorName2["LightSeaGreen"] = "lightseagreen";
803
+ ColorName2["LightSkyBlue"] = "lightskyblue";
804
+ ColorName2["LightSlateGray"] = "lightslategray";
805
+ ColorName2["LightSlateGrey"] = "lightslategrey";
806
+ ColorName2["LightSteelBlue"] = "lightsteelblue";
807
+ ColorName2["LightYellow"] = "lightyellow";
808
+ ColorName2["Lime"] = "lime";
809
+ ColorName2["LimeGreen"] = "limegreen";
810
+ ColorName2["Linen"] = "linen";
811
+ ColorName2["Magenta"] = "magenta";
812
+ ColorName2["Maroon"] = "maroon";
813
+ ColorName2["MediumAquamarine"] = "mediumaquamarine";
814
+ ColorName2["MediumBlue"] = "mediumblue";
815
+ ColorName2["MediumOrchid"] = "mediumorchid";
816
+ ColorName2["MediumPurple"] = "mediumpurple";
817
+ ColorName2["MediumSeaGreen"] = "mediumseagreen";
818
+ ColorName2["MediumSlateBlue"] = "mediumslateblue";
819
+ ColorName2["MediumSpringGreen"] = "mediumspringgreen";
820
+ ColorName2["MediumTurquoise"] = "mediumturquoise";
821
+ ColorName2["MediumVioletRed"] = "mediumvioletred";
822
+ ColorName2["MidnightBlue"] = "midnightblue";
823
+ ColorName2["MintCream"] = "mintcream";
824
+ ColorName2["MistyRose"] = "mistyrose";
825
+ ColorName2["Moccasin"] = "moccasin";
826
+ ColorName2["NavajoWhite"] = "navajowhite";
827
+ ColorName2["Navy"] = "navy";
828
+ ColorName2["OldLace"] = "oldlace";
829
+ ColorName2["Olive"] = "olive";
830
+ ColorName2["OliveDrab"] = "olivedrab";
831
+ ColorName2["Orange"] = "orange";
832
+ ColorName2["OrangeRed"] = "orangered";
833
+ ColorName2["Orchid"] = "orchid";
834
+ ColorName2["PaleGoldenRod"] = "palegoldenrod";
835
+ ColorName2["PaleGreen"] = "palegreen";
836
+ ColorName2["PaleTurquoise"] = "paleturquoise";
837
+ ColorName2["PaleVioletRed"] = "palevioletred";
838
+ ColorName2["PapayaWhip"] = "papayawhip";
839
+ ColorName2["PeachPuff"] = "peachpuff";
840
+ ColorName2["Peru"] = "peru";
841
+ ColorName2["Pink"] = "pink";
842
+ ColorName2["Plum"] = "plum";
843
+ ColorName2["PowderBlue"] = "powderblue";
844
+ ColorName2["Purple"] = "purple";
845
+ ColorName2["RebeccaPurple"] = "rebeccapurple";
846
+ ColorName2["Red"] = "red";
847
+ ColorName2["RosyBrown"] = "rosybrown";
848
+ ColorName2["RoyalBlue"] = "royalblue";
849
+ ColorName2["SaddleBrown"] = "saddlebrown";
850
+ ColorName2["Salmon"] = "salmon";
851
+ ColorName2["SandyBrown"] = "sandybrown";
852
+ ColorName2["SeaGreen"] = "seagreen";
853
+ ColorName2["SeaShell"] = "seashell";
854
+ ColorName2["Sienna"] = "sienna";
855
+ ColorName2["Silver"] = "silver";
856
+ ColorName2["SkyBlue"] = "skyblue";
857
+ ColorName2["SlateBlue"] = "slateblue";
858
+ ColorName2["SlateGray"] = "slategray";
859
+ ColorName2["SlateGrey"] = "slategrey";
860
+ ColorName2["Snow"] = "snow";
861
+ ColorName2["SpringGreen"] = "springgreen";
862
+ ColorName2["SteelBlue"] = "steelblue";
863
+ ColorName2["Tan"] = "tan";
864
+ ColorName2["Teal"] = "teal";
865
+ ColorName2["Thistle"] = "thistle";
866
+ ColorName2["Tomato"] = "tomato";
867
+ ColorName2["Turquoise"] = "turquoise";
868
+ ColorName2["Violet"] = "violet";
869
+ ColorName2["Wheat"] = "wheat";
870
+ ColorName2["White"] = "white";
871
+ ColorName2["WhiteSmoke"] = "whitesmoke";
872
+ ColorName2["Yellow"] = "yellow";
873
+ ColorName2["YellowGreen"] = "yellowgreen";
874
+ })(ColorName = ColorName || (ColorName = {}));
621
875
 
622
- // src/score/engine/settings.ts
623
- var DebugSettings = {
624
- DrawDebugRects: false,
625
- DisableBeams: false
876
+ // node_modules/color-name-to-code/dist/color-code-format.enum.js
877
+ var ColorCodeFormat;
878
+ (function(ColorCodeFormat2) {
879
+ ColorCodeFormat2["Hex"] = "hex";
880
+ ColorCodeFormat2["RGB"] = "rgb";
881
+ ColorCodeFormat2["Array"] = "array";
882
+ })(ColorCodeFormat = ColorCodeFormat || (ColorCodeFormat = {}));
883
+
884
+ // node_modules/color-name/index.js
885
+ var colors = {
886
+ aliceblue: [240, 248, 255],
887
+ antiquewhite: [250, 235, 215],
888
+ aqua: [0, 255, 255],
889
+ aquamarine: [127, 255, 212],
890
+ azure: [240, 255, 255],
891
+ beige: [245, 245, 220],
892
+ bisque: [255, 228, 196],
893
+ black: [0, 0, 0],
894
+ blanchedalmond: [255, 235, 205],
895
+ blue: [0, 0, 255],
896
+ blueviolet: [138, 43, 226],
897
+ brown: [165, 42, 42],
898
+ burlywood: [222, 184, 135],
899
+ cadetblue: [95, 158, 160],
900
+ chartreuse: [127, 255, 0],
901
+ chocolate: [210, 105, 30],
902
+ coral: [255, 127, 80],
903
+ cornflowerblue: [100, 149, 237],
904
+ cornsilk: [255, 248, 220],
905
+ crimson: [220, 20, 60],
906
+ cyan: [0, 255, 255],
907
+ darkblue: [0, 0, 139],
908
+ darkcyan: [0, 139, 139],
909
+ darkgoldenrod: [184, 134, 11],
910
+ darkgray: [169, 169, 169],
911
+ darkgreen: [0, 100, 0],
912
+ darkgrey: [169, 169, 169],
913
+ darkkhaki: [189, 183, 107],
914
+ darkmagenta: [139, 0, 139],
915
+ darkolivegreen: [85, 107, 47],
916
+ darkorange: [255, 140, 0],
917
+ darkorchid: [153, 50, 204],
918
+ darkred: [139, 0, 0],
919
+ darksalmon: [233, 150, 122],
920
+ darkseagreen: [143, 188, 143],
921
+ darkslateblue: [72, 61, 139],
922
+ darkslategray: [47, 79, 79],
923
+ darkslategrey: [47, 79, 79],
924
+ darkturquoise: [0, 206, 209],
925
+ darkviolet: [148, 0, 211],
926
+ deeppink: [255, 20, 147],
927
+ deepskyblue: [0, 191, 255],
928
+ dimgray: [105, 105, 105],
929
+ dimgrey: [105, 105, 105],
930
+ dodgerblue: [30, 144, 255],
931
+ firebrick: [178, 34, 34],
932
+ floralwhite: [255, 250, 240],
933
+ forestgreen: [34, 139, 34],
934
+ fuchsia: [255, 0, 255],
935
+ gainsboro: [220, 220, 220],
936
+ ghostwhite: [248, 248, 255],
937
+ gold: [255, 215, 0],
938
+ goldenrod: [218, 165, 32],
939
+ gray: [128, 128, 128],
940
+ green: [0, 128, 0],
941
+ greenyellow: [173, 255, 47],
942
+ grey: [128, 128, 128],
943
+ honeydew: [240, 255, 240],
944
+ hotpink: [255, 105, 180],
945
+ indianred: [205, 92, 92],
946
+ indigo: [75, 0, 130],
947
+ ivory: [255, 255, 240],
948
+ khaki: [240, 230, 140],
949
+ lavender: [230, 230, 250],
950
+ lavenderblush: [255, 240, 245],
951
+ lawngreen: [124, 252, 0],
952
+ lemonchiffon: [255, 250, 205],
953
+ lightblue: [173, 216, 230],
954
+ lightcoral: [240, 128, 128],
955
+ lightcyan: [224, 255, 255],
956
+ lightgoldenrodyellow: [250, 250, 210],
957
+ lightgray: [211, 211, 211],
958
+ lightgreen: [144, 238, 144],
959
+ lightgrey: [211, 211, 211],
960
+ lightpink: [255, 182, 193],
961
+ lightsalmon: [255, 160, 122],
962
+ lightseagreen: [32, 178, 170],
963
+ lightskyblue: [135, 206, 250],
964
+ lightslategray: [119, 136, 153],
965
+ lightslategrey: [119, 136, 153],
966
+ lightsteelblue: [176, 196, 222],
967
+ lightyellow: [255, 255, 224],
968
+ lime: [0, 255, 0],
969
+ limegreen: [50, 205, 50],
970
+ linen: [250, 240, 230],
971
+ magenta: [255, 0, 255],
972
+ maroon: [128, 0, 0],
973
+ mediumaquamarine: [102, 205, 170],
974
+ mediumblue: [0, 0, 205],
975
+ mediumorchid: [186, 85, 211],
976
+ mediumpurple: [147, 112, 219],
977
+ mediumseagreen: [60, 179, 113],
978
+ mediumslateblue: [123, 104, 238],
979
+ mediumspringgreen: [0, 250, 154],
980
+ mediumturquoise: [72, 209, 204],
981
+ mediumvioletred: [199, 21, 133],
982
+ midnightblue: [25, 25, 112],
983
+ mintcream: [245, 255, 250],
984
+ mistyrose: [255, 228, 225],
985
+ moccasin: [255, 228, 181],
986
+ navajowhite: [255, 222, 173],
987
+ navy: [0, 0, 128],
988
+ oldlace: [253, 245, 230],
989
+ olive: [128, 128, 0],
990
+ olivedrab: [107, 142, 35],
991
+ orange: [255, 165, 0],
992
+ orangered: [255, 69, 0],
993
+ orchid: [218, 112, 214],
994
+ palegoldenrod: [238, 232, 170],
995
+ palegreen: [152, 251, 152],
996
+ paleturquoise: [175, 238, 238],
997
+ palevioletred: [219, 112, 147],
998
+ papayawhip: [255, 239, 213],
999
+ peachpuff: [255, 218, 185],
1000
+ peru: [205, 133, 63],
1001
+ pink: [255, 192, 203],
1002
+ plum: [221, 160, 221],
1003
+ powderblue: [176, 224, 230],
1004
+ purple: [128, 0, 128],
1005
+ rebeccapurple: [102, 51, 153],
1006
+ red: [255, 0, 0],
1007
+ rosybrown: [188, 143, 143],
1008
+ royalblue: [65, 105, 225],
1009
+ saddlebrown: [139, 69, 19],
1010
+ salmon: [250, 128, 114],
1011
+ sandybrown: [244, 164, 96],
1012
+ seagreen: [46, 139, 87],
1013
+ seashell: [255, 245, 238],
1014
+ sienna: [160, 82, 45],
1015
+ silver: [192, 192, 192],
1016
+ skyblue: [135, 206, 235],
1017
+ slateblue: [106, 90, 205],
1018
+ slategray: [112, 128, 144],
1019
+ slategrey: [112, 128, 144],
1020
+ snow: [255, 250, 250],
1021
+ springgreen: [0, 255, 127],
1022
+ steelblue: [70, 130, 180],
1023
+ tan: [210, 180, 140],
1024
+ teal: [0, 128, 128],
1025
+ thistle: [216, 191, 216],
1026
+ tomato: [255, 99, 71],
1027
+ turquoise: [64, 224, 208],
1028
+ violet: [238, 130, 238],
1029
+ wheat: [245, 222, 179],
1030
+ white: [255, 255, 255],
1031
+ whitesmoke: [245, 245, 245],
1032
+ yellow: [255, 255, 0],
1033
+ yellowgreen: [154, 205, 50]
626
1034
  };
627
- var DocumentSettings = {
628
- DocumentScale: 1,
629
- MinStaffWidth: 75,
630
- MinColumnsWidth: 10,
631
- ColumnWidthScale: 1.7,
632
- PostMeasureBreakWidth: 10,
633
- NoteDotSpace: 0.5,
634
- NoteAccSpace: 0.5,
635
- NoteHeadWidth: 2,
636
- NoteHeadHeight: 1.3,
637
- DiamondNoteHeadSize: 1.8,
638
- DotSize: 0.8,
639
- StemHeight: 7,
640
- // One octave
641
- FlagWidth: 1.5,
642
- FlagHeight: 4,
643
- FlagSeparation: 2,
644
- BeamSeparation: 1.25,
645
- BeamAngleFactor: 0.5,
646
- BeamThickness: 4,
647
- RestDotSpace: 0.5,
648
- LedgerLineWidth: 3.6,
649
- StubTieLength: 5,
650
- StaffHeight: 8,
651
- TabHeight: 20
1035
+ for (const key in colors) Object.freeze(colors[key]);
1036
+ var color_name_default = Object.freeze(colors);
1037
+
1038
+ // node_modules/color-name-to-code/dist/color-names.js
1039
+ var colorNames = color_name_default;
1040
+
1041
+ // node_modules/color-name-to-code/dist/color-array-to-hex.js
1042
+ var colorArrayToHexDefaultOptions = {
1043
+ hash: true,
1044
+ lowercase: false,
1045
+ short: false
652
1046
  };
1047
+ function colorArrayToHex(arr, partialOptions) {
1048
+ const options = __spreadValues(__spreadValues({}, colorArrayToHexDefaultOptions), partialOptions);
1049
+ const { hash, lowercase, short } = options;
1050
+ let hex = arr.map((num) => {
1051
+ let str = num.toString(16);
1052
+ str = str.length === 1 ? `0${str}` : str;
1053
+ return str;
1054
+ }).join("");
1055
+ if (short) {
1056
+ const chars = [...hex];
1057
+ if (chars[0] === chars[1] && chars[2] === chars[3] && chars[4] === chars[5]) {
1058
+ hex = `${chars[0]}${chars[2]}${chars[4]}`;
1059
+ }
1060
+ }
1061
+ hex = lowercase ? hex.toLowerCase() : hex.toUpperCase();
1062
+ if (hash) {
1063
+ hex = `#${hex}`;
1064
+ }
1065
+ return hex;
1066
+ }
653
1067
 
654
- // src/score/engine/render-context.ts
655
- import { MusicError as MusicError2, MusicErrorType as MusicErrorType2 } from "@tspro/web-music-score/core";
1068
+ // node_modules/color-name-to-code/dist/color-array-to-rgb.js
1069
+ function colorArrayToRGB(arr, alpha = 1) {
1070
+ alpha = Math.min(1, Math.max(0, alpha));
1071
+ if (alpha < 1) {
1072
+ return `rgba(${arr[0]}, ${arr[1]}, ${arr[2]}, ${alpha})`;
1073
+ }
1074
+ return `rgb(${arr[0]}, ${arr[1]}, ${arr[2]})`;
1075
+ }
656
1076
 
657
- // src/score/engine/assets/F-clef.png
658
- var F_clef_default = "";
1077
+ // node_modules/color-name-to-code/dist/color-name-to-code.js
1078
+ var colorNameToCodeDefaultOptions = __spreadProps(__spreadValues({}, colorArrayToHexDefaultOptions), {
1079
+ fallback: true,
1080
+ alpha: 1,
1081
+ format: ColorCodeFormat.Hex
1082
+ });
1083
+ function colorNameToCode(value, partialOptions = {}) {
1084
+ const options = __spreadValues(__spreadValues({}, colorNameToCodeDefaultOptions), partialOptions);
1085
+ const { fallback, format, hash, lowercase, short, alpha } = options;
1086
+ value = `${value}`;
1087
+ const colorName = value.toLowerCase().replaceAll(/[^a-z]/g, "");
1088
+ let colorArray = colorNames[colorName];
1089
+ if (!colorArray) {
1090
+ if (!fallback) {
1091
+ throw new Error(`no matching color found for '${value}'`);
1092
+ }
1093
+ const hex = value.toLowerCase().replaceAll(/[^\da-f]/g, "");
1094
+ colorArray = (hex.length <= 3 ? [hex.slice(0, 1).repeat(2), hex.slice(1, 2).repeat(2), hex.slice(2, 3).repeat(2)] : [hex.slice(0, 2), hex.slice(2, 4), hex.slice(4, 6)]).map((str) => Number.parseInt(str.length < 2 ? `${"0".repeat(2 - str.length)}${str}` : str, 16));
1095
+ }
1096
+ switch (format) {
1097
+ case ColorCodeFormat.Array: {
1098
+ return [...colorArray];
1099
+ }
1100
+ case ColorCodeFormat.RGB: {
1101
+ return colorArrayToRGB(colorArray, alpha);
1102
+ }
1103
+ default: {
1104
+ return colorArrayToHex(colorArray, { hash, lowercase, short });
1105
+ }
1106
+ }
1107
+ }
659
1108
 
660
1109
  // src/score/engine/assets/G-clef.png
661
1110
  var G_clef_default = "";
662
1111
 
1112
+ // src/score/engine/assets/F-clef.png
1113
+ var F_clef_default = "";
1114
+
663
1115
  // src/score/engine/render-context.ts
664
- var HilightStaffPosRectColor = "#55cc55";
665
- var HilightObjectRectColor = "#55cc55";
666
- var PlayPosIndicatorColor = "#44aa44";
667
- var ImageAssets = new UniMap([
668
- [0 /* G_Clef */, { src: G_clef_default }],
669
- [1 /* F_Clef */, { src: F_clef_default }]
1116
+ var ImageData = new UniMap([
1117
+ [0 /* G_Clef */, G_clef_default],
1118
+ [1 /* F_Clef */, F_clef_default]
670
1119
  ]);
1120
+ var getImageData = (asset) => ImageData.getOrDefault(asset, "");
1121
+ var ImageCache = new BiMap();
1122
+ function colorNameToRGBA(name, alpha = 1) {
1123
+ const hex = colorNameToCode(name).replace("#", "");
1124
+ const r = parseInt(hex.slice(0, 2), 16);
1125
+ const g = parseInt(hex.slice(2, 4), 16);
1126
+ const b = parseInt(hex.slice(4, 6), 16);
1127
+ const a = Math.round(alpha * 255);
1128
+ return [r, g, b, a];
1129
+ }
671
1130
  function staffPosEquals(a, b) {
672
1131
  if (!a && !b) return true;
673
1132
  else if (!a || !b) return false;
@@ -702,23 +1161,9 @@ var RenderContext = class {
702
1161
  __publicField(this, "onMouseLeaveFn");
703
1162
  __publicField(this, "onTouchEndFn");
704
1163
  this.devicePixelRatio = window.devicePixelRatio;
705
- this.fontSize = Device.FontSize * DocumentSettings.DocumentScale * this.devicePixelRatio;
1164
+ this.fontSize = device_exports.FontSize * DocumentSettings.DocumentScale * this.devicePixelRatio;
706
1165
  this.unitSize = this.fontSize * 0.3;
707
1166
  this._lineWidth = this.unitSize * 0.2;
708
- ImageAssets.forEach((asset) => {
709
- if (asset.finished !== true) {
710
- const img = new Image();
711
- img.src = asset.src;
712
- img.onload = () => {
713
- asset.img = img;
714
- this.finishImageAsset(asset);
715
- };
716
- img.onerror = () => {
717
- this.finishImageAsset(asset);
718
- throw new MusicError2(MusicErrorType2.Score, "Failed to load image: " + asset.src);
719
- };
720
- }
721
- });
722
1167
  this.onClickFn = this.onClick.bind(this);
723
1168
  this.onMouseMoveFn = this.onMouseMove.bind(this);
724
1169
  this.onMouseLeaveFn = this.onMouseLeave.bind(this);
@@ -731,16 +1176,66 @@ var RenderContext = class {
731
1176
  var _a;
732
1177
  return (_a = this.mdoc) == null ? void 0 : _a.getMusicObject();
733
1178
  }
734
- finishImageAsset(asset) {
735
- asset.finished = true;
736
- let allFinished = ImageAssets.every((asset2) => asset2.finished === true);
737
- if (allFinished) {
738
- this.onLoad();
739
- }
1179
+ getImageAsset(asset, color) {
1180
+ var _a;
1181
+ color != null ? color : color = "";
1182
+ return (_a = ImageCache.getOrCreate(asset, color, () => {
1183
+ const a = { src: getImageData(asset), color, loaded: false, colorized: false };
1184
+ const img = new Image();
1185
+ img.src = a.src;
1186
+ img.onload = () => {
1187
+ a.img = img;
1188
+ this.onImageLoaded(a);
1189
+ };
1190
+ img.onerror = () => {
1191
+ console.error("Failed to load image: " + a.src);
1192
+ };
1193
+ return a;
1194
+ })) == null ? void 0 : _a.img;
740
1195
  }
741
- getImageAsset(imageAsset) {
1196
+ forceDraw() {
742
1197
  var _a;
743
- return (_a = ImageAssets.get(imageAsset)) == null ? void 0 : _a.img;
1198
+ (_a = this.doc) == null ? void 0 : _a.requestFullLayout();
1199
+ this.draw();
1200
+ }
1201
+ onImageLoaded(data) {
1202
+ if (data.loaded || !data.img) return;
1203
+ if (data.colorized || data.color === "") {
1204
+ this.forceDraw();
1205
+ data.loaded = true;
1206
+ return;
1207
+ }
1208
+ const [nr, ng, nb, na] = colorNameToRGBA(data.color);
1209
+ const threshold = 40;
1210
+ const canvas = document.createElement("canvas");
1211
+ canvas.width = data.img.width;
1212
+ canvas.height = data.img.height;
1213
+ const ctx = canvas.getContext("2d");
1214
+ if (ctx == null) {
1215
+ console.error("Failed to colorize image: ctx = null.");
1216
+ return;
1217
+ }
1218
+ ctx.drawImage(data.img, 0, 0);
1219
+ const imageData = ctx.getImageData(0, 0, canvas.width, canvas.height);
1220
+ const d = imageData.data;
1221
+ for (let i = 0; i < d.length; i += 4) {
1222
+ const r = d[i], g = d[i + 1], b = d[i + 2], a = d[i + 3];
1223
+ if (a === 0) continue;
1224
+ if (r < threshold && g < threshold && b < threshold) {
1225
+ d[i + 0] = nr;
1226
+ d[i + 1] = ng;
1227
+ d[i + 2] = nb;
1228
+ }
1229
+ }
1230
+ ctx.putImageData(imageData, 0, 0);
1231
+ data.img.src = canvas.toDataURL("image/png");
1232
+ data.img.onload = () => {
1233
+ data.colorized = true;
1234
+ this.onImageLoaded(data);
1235
+ };
1236
+ data.img.onerror = () => {
1237
+ console.error("Failed to colorize image.");
1238
+ };
744
1239
  }
745
1240
  setDocument(mdoc) {
746
1241
  if (this.mdoc === mdoc) {
@@ -860,12 +1355,6 @@ var RenderContext = class {
860
1355
  onTouchEnd(e) {
861
1356
  this.usingTouch = true;
862
1357
  }
863
- onLoad() {
864
- if (this.doc) {
865
- this.doc.requestFullLayout();
866
- this.draw();
867
- }
868
- }
869
1358
  hilightObject(obj) {
870
1359
  this.hilightedObj = obj;
871
1360
  }
@@ -914,7 +1403,7 @@ var RenderContext = class {
914
1403
  if (!staff) {
915
1404
  return;
916
1405
  }
917
- this.fillColor(HilightStaffPosRectColor);
1406
+ this.fillColor(DocumentColor.HilightStaffPos);
918
1407
  this.fillRect(staff.row.getRect().left, staff.getDiatonicIdY(diatonicId) - unitSize, staff.row.getRect().width, 2 * unitSize);
919
1408
  if (mousePos !== void 0) {
920
1409
  this.drawLedgerLines(staff, diatonicId, mousePos.x);
@@ -926,13 +1415,13 @@ var RenderContext = class {
926
1415
  return;
927
1416
  }
928
1417
  let rect = hilightedObj.getRect();
929
- this.lineColor(HilightObjectRectColor);
1418
+ this.lineColor(DocumentColor.HilightObject);
930
1419
  this.strokeRect(rect.left, rect.top, rect.width, rect.height);
931
1420
  }
932
1421
  drawPlayCursor() {
933
1422
  let { cursorRect: r } = this;
934
1423
  if (r) {
935
- this.color(PlayPosIndicatorColor).lineWidth(2).strokeLine(r.centerX, r.top, r.centerX, r.bottom);
1424
+ this.color(DocumentColor.PlayCursor).lineWidth(2).strokeLine(r.centerX, r.top, r.centerX, r.bottom);
936
1425
  }
937
1426
  }
938
1427
  txFromScreenCoord(screenCoord) {
@@ -942,8 +1431,10 @@ var RenderContext = class {
942
1431
  return coord.div(this.devicePixelRatio);
943
1432
  }
944
1433
  clearCanvas() {
945
- var _a;
946
- (_a = this.ctx) == null ? void 0 : _a.clearRect(0, 0, this.ctx.canvas.width, this.ctx.canvas.height);
1434
+ if (this.ctx) {
1435
+ this.ctx.canvas.style.background = DocumentColor.Background;
1436
+ this.ctx.clearRect(0, 0, this.ctx.canvas.width, this.ctx.canvas.height);
1437
+ }
947
1438
  }
948
1439
  drawDebugRect(r) {
949
1440
  if (DebugSettings.DrawDebugRects) {
@@ -998,7 +1489,7 @@ var RenderContext = class {
998
1489
  toph = unitSize * (0.5 + flagCount - adj);
999
1490
  bottomh = unitSize * (1 + flagCount + adj);
1000
1491
  }
1001
- return new AnchoredRect2(-leftw, 0, rightw, -toph, 0, bottomh);
1492
+ return new AnchoredRect(-leftw, 0, rightw, -toph, 0, bottomh);
1002
1493
  }
1003
1494
  drawRest(restSize, x, y) {
1004
1495
  let { unitSize } = this;
@@ -1184,7 +1675,7 @@ var RenderContext = class {
1184
1675
  this.ctx.font = savedFont;
1185
1676
  return metrics.width;
1186
1677
  } else {
1187
- return Utils2.Dom.getCanvasTextWidth(text, font);
1678
+ return utils_exports.Dom.getCanvasTextWidth(text, font);
1188
1679
  }
1189
1680
  }
1190
1681
  arc(x, y, radius, startRadians, endRadians) {
@@ -1289,11 +1780,9 @@ var RenderContext = class {
1289
1780
  };
1290
1781
 
1291
1782
  // src/score/engine/obj-staff-and-tab.ts
1292
- import { MusicError as MusicError15, MusicErrorType as MusicErrorType15 } from "@tspro/web-music-score/core";
1293
- import { AnchoredRect as AnchoredRect22, Guard as Guard9, UniMap as UniMap8, Utils as Utils10 } from "@tspro/ts-utils-lib";
1783
+ import { MusicError as MusicError13, MusicErrorType as MusicErrorType13 } from "@tspro/web-music-score/core";
1294
1784
 
1295
1785
  // src/score/engine/obj-measure.ts
1296
- import { Guard as Guard8, IndexArray as IndexArray2, UniMap as UniMap6, TriMap as TriMap2, ValueSet, Utils as Utils9, asMulti, AnchoredRect as AnchoredRect20 } from "@tspro/ts-utils-lib";
1297
1786
  import { getScale, Scale, validateScaleType, Note as Note7, RhythmProps as RhythmProps5, KeySignature as KeySignature2, getDefaultKeySignature, PitchNotation, SymbolSet, validateNoteLength as validateNoteLength2, NoteLengthProps as NoteLengthProps5 } from "@tspro/web-music-score/theory";
1298
1787
  import { getDefaultTempo, getDefaultTimeSignature } from "@tspro/web-music-score/theory";
1299
1788
 
@@ -1323,7 +1812,6 @@ var AccidentalState = class {
1323
1812
  import { Note as Note2, getTempoString, KeySignature } from "@tspro/web-music-score/theory";
1324
1813
 
1325
1814
  // src/score/engine/obj-image.ts
1326
- import { AnchoredRect as AnchoredRect3 } from "@tspro/ts-utils-lib";
1327
1815
  var ObjImage = class extends MusicObject {
1328
1816
  constructor(parent, image, anchorX, anchorY, imageScale) {
1329
1817
  super(parent);
@@ -1346,9 +1834,9 @@ var ObjImage = class extends MusicObject {
1346
1834
  try {
1347
1835
  let w = image.naturalWidth * imageScale * unitSize;
1348
1836
  let h = image.naturalHeight * imageScale * unitSize;
1349
- this.rect = AnchoredRect3.createSections(w * anchorX, w * (1 - anchorX), h * anchorY, h * (1 - anchorY));
1837
+ this.rect = AnchoredRect.createSections(w * anchorX, w * (1 - anchorX), h * anchorY, h * (1 - anchorY));
1350
1838
  } catch (err) {
1351
- this.rect = new AnchoredRect3();
1839
+ this.rect = new AnchoredRect();
1352
1840
  }
1353
1841
  }
1354
1842
  offset(dx, dy) {
@@ -1362,8 +1850,7 @@ var ObjImage = class extends MusicObject {
1362
1850
  };
1363
1851
 
1364
1852
  // src/score/engine/obj-accidental.ts
1365
- import { MusicError as MusicError3, MusicErrorType as MusicErrorType3 } from "@tspro/web-music-score/core";
1366
- import { AnchoredRect as AnchoredRect4 } from "@tspro/ts-utils-lib";
1853
+ import { MusicError as MusicError2, MusicErrorType as MusicErrorType2 } from "@tspro/web-music-score/core";
1367
1854
  var ObjAccidental = class extends MusicObject {
1368
1855
  constructor(parent, diatonicId, accidental, color = "black") {
1369
1856
  super(parent);
@@ -1383,22 +1870,22 @@ var ObjAccidental = class extends MusicObject {
1383
1870
  let { unitSize } = ctx;
1384
1871
  switch (this.accidental) {
1385
1872
  case -2:
1386
- this.rect = AnchoredRect4.createSections(unitSize * 1.25, unitSize * 1.25, unitSize * 4, unitSize * 1.2);
1873
+ this.rect = AnchoredRect.createSections(unitSize * 1.25, unitSize * 1.25, unitSize * 4, unitSize * 1.2);
1387
1874
  break;
1388
1875
  case -1:
1389
- this.rect = AnchoredRect4.createSections(unitSize * 0.75, unitSize * 0.75, unitSize * 4, unitSize * 1.2);
1876
+ this.rect = AnchoredRect.createSections(unitSize * 0.75, unitSize * 0.75, unitSize * 4, unitSize * 1.2);
1390
1877
  break;
1391
1878
  case 0:
1392
- this.rect = AnchoredRect4.createSections(unitSize * 0.75, unitSize * 0.75, unitSize * 2.2, unitSize * 2.2);
1879
+ this.rect = AnchoredRect.createSections(unitSize * 0.75, unitSize * 0.75, unitSize * 2.2, unitSize * 2.2);
1393
1880
  break;
1394
1881
  case 1:
1395
- this.rect = AnchoredRect4.createSections(unitSize * 0.75, unitSize * 0.75, unitSize * 2, unitSize * 2);
1882
+ this.rect = AnchoredRect.createSections(unitSize * 0.75, unitSize * 0.75, unitSize * 2, unitSize * 2);
1396
1883
  break;
1397
1884
  case 2:
1398
- this.rect = AnchoredRect4.createSections(unitSize * 1, unitSize * 1, unitSize * 1, unitSize * 1);
1885
+ this.rect = AnchoredRect.createSections(unitSize * 1, unitSize * 1, unitSize * 1, unitSize * 1);
1399
1886
  break;
1400
1887
  default:
1401
- throw new MusicError3(MusicErrorType3.Score, "Invalid accidental value: " + this.accidental);
1888
+ throw new MusicError2(MusicErrorType2.Score, "Invalid accidental value: " + this.accidental);
1402
1889
  }
1403
1890
  }
1404
1891
  offset(dx, dy) {
@@ -1438,7 +1925,6 @@ var ObjAccidental = class extends MusicObject {
1438
1925
  };
1439
1926
 
1440
1927
  // src/score/engine/obj-text.ts
1441
- import { AnchoredRect as AnchoredRect5 } from "@tspro/ts-utils-lib";
1442
1928
  var DefaultBoxedPadding = 0.5;
1443
1929
  var ObjText = class extends MusicObject {
1444
1930
  constructor(parent, text, anchorX, anchorY) {
@@ -1475,7 +1961,7 @@ var ObjText = class extends MusicObject {
1475
1961
  if (this.textLines.length === 0) {
1476
1962
  this.textLines = [""];
1477
1963
  }
1478
- this.rect = new AnchoredRect5();
1964
+ this.rect = new AnchoredRect();
1479
1965
  this.mi = new MText(this);
1480
1966
  }
1481
1967
  getMusicInterface() {
@@ -1484,18 +1970,6 @@ var ObjText = class extends MusicObject {
1484
1970
  getText() {
1485
1971
  return this.text;
1486
1972
  }
1487
- updateAnchorX(anchorX) {
1488
- this.anchorX = anchorX;
1489
- let { width } = this.rect;
1490
- this.rect.left = this.rect.anchorX - width * anchorX;
1491
- this.rect.right = this.rect.anchorX + width * (1 - anchorX);
1492
- }
1493
- updateAnchorY(anchorY) {
1494
- this.anchorY = anchorY;
1495
- let { height } = this.rect;
1496
- this.rect.top = this.rect.anchorY - height * anchorY;
1497
- this.rect.bottom = this.rect.anchorY + height * (1 - anchorY);
1498
- }
1499
1973
  pick(x, y) {
1500
1974
  return this.rect.contains(x, y) ? [this] : [];
1501
1975
  }
@@ -1511,7 +1985,7 @@ var ObjText = class extends MusicObject {
1511
1985
  if (this.boxed === "square" || this.boxed === "circle") {
1512
1986
  h = w = Math.max(h, w);
1513
1987
  }
1514
- this.rect = AnchoredRect5.createSections(w * anchorX, w * (1 - anchorX), h * anchorY, h * (1 - anchorY));
1988
+ this.rect = AnchoredRect.createSections(w * anchorX, w * (1 - anchorX), h * anchorY, h * (1 - anchorY));
1515
1989
  }
1516
1990
  offset(dx, dy) {
1517
1991
  this.rect.offsetInPlace(dx, dy);
@@ -1557,8 +2031,7 @@ var ObjText = class extends MusicObject {
1557
2031
  };
1558
2032
 
1559
2033
  // src/score/engine/obj-signature.ts
1560
- import { MusicError as MusicError4, MusicErrorType as MusicErrorType4 } from "@tspro/web-music-score/core";
1561
- import { AnchoredRect as AnchoredRect6 } from "@tspro/ts-utils-lib";
2034
+ import { MusicError as MusicError3, MusicErrorType as MusicErrorType3 } from "@tspro/web-music-score/core";
1562
2035
  var ObjStaffSignature = class extends MusicObject {
1563
2036
  constructor(measure, staff) {
1564
2037
  super(measure);
@@ -1575,22 +2048,29 @@ var ObjStaffSignature = class extends MusicObject {
1575
2048
  __publicField(this, "mi");
1576
2049
  this.mi = new MStaffSignature(this);
1577
2050
  }
2051
+ get doc() {
2052
+ return this.measure.doc;
2053
+ }
1578
2054
  getMusicInterface() {
1579
2055
  return this.mi;
1580
2056
  }
1581
2057
  updateClefImage(ctx, showClef) {
1582
2058
  if (showClef) {
1583
- let img = ctx.getImageAsset(this.staff.clefImageAsset);
2059
+ let color = DocumentColor.Staff_Signature_Clef;
2060
+ if (["black", "#000", "#000000"].includes(color))
2061
+ color = "";
2062
+ let img = ctx.getImageAsset(this.staff.clefImageAsset, color);
1584
2063
  this.clefImage = img ? new ObjImage(this, img, 0, 0.5, 0.1) : void 0;
1585
- this.eightBelowClef = this.clefImage && this.staff.isOctaveDown ? new ObjText(this, "8", 0.5, 0) : void 0;
2064
+ this.eightBelowClef = this.clefImage && this.staff.isOctaveDown ? new ObjText(this, { text: "8", color }, 0.5, 0) : void 0;
1586
2065
  } else {
1587
2066
  this.clefImage = void 0;
1588
2067
  }
1589
2068
  }
1590
2069
  updateMeasureNumber(showMeasureNumber) {
1591
2070
  if (showMeasureNumber) {
2071
+ let color = DocumentColor.Staff_Signature_MeasureNum;
1592
2072
  let text = this.measure.getMeasureNumber().toString();
1593
- this.measureNumber = new ObjText(this, text, 0, 1);
2073
+ this.measureNumber = new ObjText(this, { text, color }, 0, 1);
1594
2074
  } else {
1595
2075
  this.measureNumber = void 0;
1596
2076
  }
@@ -1598,6 +2078,7 @@ var ObjStaffSignature = class extends MusicObject {
1598
2078
  updateKeySignature(showKeySignature) {
1599
2079
  if (showKeySignature) {
1600
2080
  let { measure } = this;
2081
+ let color = DocumentColor.Staff_Signature_Key;
1601
2082
  let prevMeasure = measure.getPrevMeasure();
1602
2083
  let prevKeySignature = prevMeasure ? prevMeasure.getKeySignature() : void 0;
1603
2084
  let newKeySignature = measure.getKeySignature();
@@ -1605,11 +2086,11 @@ var ObjStaffSignature = class extends MusicObject {
1605
2086
  this.ksNewAccidentals = [];
1606
2087
  if (prevKeySignature && !KeySignature.equals(newKeySignature, prevKeySignature)) {
1607
2088
  prevKeySignature.getOrderedAccidentalNotes().forEach((accNote) => {
1608
- this.ksNeutralizeAccidentals.push(new ObjAccidental(this, this.getAccidentalDiatonicId(accNote), 0));
2089
+ this.ksNeutralizeAccidentals.push(new ObjAccidental(this, this.getAccidentalDiatonicId(accNote), 0, color));
1609
2090
  });
1610
2091
  }
1611
2092
  newKeySignature.getOrderedAccidentalNotes().forEach((accNote) => {
1612
- this.ksNewAccidentals.push(new ObjAccidental(this, this.getAccidentalDiatonicId(accNote), accNote.accidental));
2093
+ this.ksNewAccidentals.push(new ObjAccidental(this, this.getAccidentalDiatonicId(accNote), accNote.accidental, color));
1613
2094
  });
1614
2095
  } else {
1615
2096
  this.ksNeutralizeAccidentals = [];
@@ -1619,18 +2100,20 @@ var ObjStaffSignature = class extends MusicObject {
1619
2100
  updateTimeSignature(showTimeSignature) {
1620
2101
  if (showTimeSignature) {
1621
2102
  let timeSignature = this.measure.getTimeSignature();
2103
+ let color = DocumentColor.Staff_Signature_Time;
1622
2104
  let beatCount = timeSignature.beatCount.toString();
1623
- this.beatCountText = new ObjText(this, { text: beatCount, scale: 1.4 }, 0.5, 0.5);
2105
+ this.beatCountText = new ObjText(this, { text: beatCount, color, scale: 1.4 }, 0.5, 0.5);
1624
2106
  let beatSize = timeSignature.beatSize.toString();
1625
- this.beatSizeText = new ObjText(this, { text: beatSize, scale: 1.4 }, 0.5, 0.5);
2107
+ this.beatSizeText = new ObjText(this, { text: beatSize, color, scale: 1.4 }, 0.5, 0.5);
1626
2108
  } else {
1627
2109
  this.beatCountText = this.beatSizeText = void 0;
1628
2110
  }
1629
2111
  }
1630
2112
  updateTempo(showTempo) {
1631
2113
  if (showTempo) {
1632
- let tempoStr = getTempoString(this.measure.getTempo());
1633
- this.tempoText = new ObjText(this, tempoStr, 0.5, 1);
2114
+ let color = DocumentColor.Staff_Signature_Tempo;
2115
+ let text = getTempoString(this.measure.getTempo());
2116
+ this.tempoText = new ObjText(this, { text, color }, 0.5, 1);
1634
2117
  } else {
1635
2118
  this.tempoText = void 0;
1636
2119
  }
@@ -1654,7 +2137,7 @@ var ObjStaffSignature = class extends MusicObject {
1654
2137
  if (bottomAccidentalDiatonicId !== void 0) {
1655
2138
  return Note2.findNextDiatonicIdAbove(accNote.diatonicId, bottomAccidentalDiatonicId, false);
1656
2139
  } else {
1657
- throw new MusicError4(MusicErrorType4.Score, "Cannot get accidental diatonicId because note has no accidental.");
2140
+ throw new MusicError3(MusicErrorType3.Score, "Cannot get accidental diatonicId because note has no accidental.");
1658
2141
  }
1659
2142
  }
1660
2143
  pick(x, y) {
@@ -1717,7 +2200,7 @@ var ObjStaffSignature = class extends MusicObject {
1717
2200
  let { staff } = this;
1718
2201
  let paddingX = unitSize;
1719
2202
  let x = 0;
1720
- this.rect = new AnchoredRect6();
2203
+ this.rect = new AnchoredRect();
1721
2204
  if (this.clefImage) {
1722
2205
  x += paddingX;
1723
2206
  this.clefImage.layout(ctx);
@@ -1784,11 +2267,11 @@ var ObjStaffSignature = class extends MusicObject {
1784
2267
  this.tempoText.layout(ctx);
1785
2268
  this.tempoText.setCenterX(x);
1786
2269
  this.tempoText.setBottom(staff.getTopLineY());
1787
- if (this.clefImage && AnchoredRect6.overlap(this.clefImage.getRect(), this.tempoText.getRect())) {
2270
+ if (this.clefImage && AnchoredRect.overlap(this.clefImage.getRect(), this.tempoText.getRect())) {
1788
2271
  this.tempoText.setBottom(this.clefImage.getRect().top);
1789
2272
  }
1790
2273
  [...this.ksNeutralizeAccidentals, ...this.ksNewAccidentals].forEach((acc) => {
1791
- if (this.tempoText && AnchoredRect6.overlap(acc.getRect(), this.tempoText.getRect())) {
2274
+ if (this.tempoText && AnchoredRect.overlap(acc.getRect(), this.tempoText.getRect())) {
1792
2275
  this.tempoText.setBottom(acc.getRect().top);
1793
2276
  }
1794
2277
  });
@@ -1835,10 +2318,14 @@ var ObjTabSignature = class extends MusicObject {
1835
2318
  getMusicInterface() {
1836
2319
  return this.mi;
1837
2320
  }
2321
+ get doc() {
2322
+ return this.measure.doc;
2323
+ }
1838
2324
  updateMeasureNumber(showMeasureNumber) {
1839
2325
  if (showMeasureNumber) {
2326
+ let color = DocumentColor.Tab_Signature_MeasureNum;
1840
2327
  let text = this.measure.getMeasureNumber().toString();
1841
- this.measureNumber = new ObjText(this, text, 0, 1);
2328
+ this.measureNumber = new ObjText(this, { text, color }, 0, 1);
1842
2329
  } else {
1843
2330
  this.measureNumber = void 0;
1844
2331
  }
@@ -1846,18 +2333,20 @@ var ObjTabSignature = class extends MusicObject {
1846
2333
  updateTimeSignature(showTimeSignature) {
1847
2334
  if (showTimeSignature) {
1848
2335
  let timeSignature = this.measure.getTimeSignature();
2336
+ let color = DocumentColor.Tab_Signature_Time;
1849
2337
  let beatCount = timeSignature.beatCount.toString();
1850
- this.beatCountText = new ObjText(this, { text: beatCount, scale: 1.4 }, 0.5, 0.5);
2338
+ this.beatCountText = new ObjText(this, { text: beatCount, color, scale: 1.4 }, 0.5, 0.5);
1851
2339
  let beatSize = timeSignature.beatSize.toString();
1852
- this.beatSizeText = new ObjText(this, { text: beatSize, scale: 1.4 }, 0.5, 0.5);
2340
+ this.beatSizeText = new ObjText(this, { text: beatSize, color, scale: 1.4 }, 0.5, 0.5);
1853
2341
  } else {
1854
2342
  this.beatCountText = this.beatSizeText = void 0;
1855
2343
  }
1856
2344
  }
1857
2345
  updateTempo(showTempo) {
1858
2346
  if (showTempo) {
1859
- let tempoStr = getTempoString(this.measure.getTempo());
1860
- this.tempoText = new ObjText(this, tempoStr, 0, 1);
2347
+ let color = DocumentColor.Tab_Signature_Tempo;
2348
+ let text = getTempoString(this.measure.getTempo());
2349
+ this.tempoText = new ObjText(this, { text, color }, 0, 1);
1861
2350
  } else {
1862
2351
  this.tempoText = void 0;
1863
2352
  }
@@ -1899,7 +2388,7 @@ var ObjTabSignature = class extends MusicObject {
1899
2388
  let paddingX = unitSize;
1900
2389
  let x = 0;
1901
2390
  let topLineY = tab.getTopLineY();
1902
- this.rect = new AnchoredRect6();
2391
+ this.rect = new AnchoredRect();
1903
2392
  if (this.measureNumber) {
1904
2393
  this.measureNumber.layout(ctx);
1905
2394
  this.measureNumber.setLeft(0);
@@ -1950,7 +2439,6 @@ var ObjTabSignature = class extends MusicObject {
1950
2439
  };
1951
2440
 
1952
2441
  // src/score/engine/player.ts
1953
- import { Rect as Rect2, UniMap as UniMap3, Utils as Utils5 } from "@tspro/ts-utils-lib";
1954
2442
  import { NoteLength as NoteLength4, RhythmProps as RhythmProps4, alterTempoSpeed } from "@tspro/web-music-score/theory";
1955
2443
  import * as Audio from "@tspro/web-music-score/audio";
1956
2444
 
@@ -1958,7 +2446,6 @@ import * as Audio from "@tspro/web-music-score/audio";
1958
2446
  import { Note as Note5 } from "@tspro/web-music-score/theory";
1959
2447
 
1960
2448
  // src/score/engine/obj-arpeggio.ts
1961
- import { AnchoredRect as AnchoredRect7 } from "@tspro/ts-utils-lib";
1962
2449
  var ObjArpeggio = class extends MusicObject {
1963
2450
  constructor(col, line, arpeggioDir) {
1964
2451
  super(col);
@@ -1989,7 +2476,7 @@ var ObjArpeggio = class extends MusicObject {
1989
2476
  this.numCycles = Math.ceil((bottom - top) / this.cycleHeight) + 2;
1990
2477
  let width = unitSize * 2;
1991
2478
  let height = this.numCycles * this.cycleHeight;
1992
- this.rect = new AnchoredRect7(-width / 2, width / 2, -height / 2 - this.topArrowHeight, height / 2 + this.bottomArrowHeight);
2479
+ this.rect = new AnchoredRect(-width / 2, width / 2, -height / 2 - this.topArrowHeight, height / 2 + this.bottomArrowHeight);
1993
2480
  }
1994
2481
  offset(dx, dy) {
1995
2482
  this.rect.offsetInPlace(dx, dy);
@@ -2025,8 +2512,7 @@ var ObjArpeggio = class extends MusicObject {
2025
2512
 
2026
2513
  // src/score/engine/obj-rest.ts
2027
2514
  import { Note as Note3, NoteLengthProps as NoteLengthProps2, RhythmProps as RhythmProps2, Tuplet } from "@tspro/web-music-score/theory";
2028
- import { MusicError as MusicError5, MusicErrorType as MusicErrorType5 } from "@tspro/web-music-score/core";
2029
- import { AnchoredRect as AnchoredRect8 } from "@tspro/ts-utils-lib";
2515
+ import { MusicError as MusicError4, MusicErrorType as MusicErrorType4 } from "@tspro/web-music-score/core";
2030
2516
  function getDiatonicIdFromStaffPos(staffPos) {
2031
2517
  if (typeof staffPos === "number") {
2032
2518
  return Note3.getChromaticNote(staffPos).diatonicId;
@@ -2043,7 +2529,7 @@ var ObjStaffRest = class extends MusicObject {
2043
2529
  super(staff);
2044
2530
  this.staff = staff;
2045
2531
  this.rest = rest;
2046
- __publicField(this, "restRect", new AnchoredRect8());
2532
+ __publicField(this, "restRect", new AnchoredRect());
2047
2533
  __publicField(this, "dotRects", []);
2048
2534
  __publicField(this, "mi");
2049
2535
  staff.addObject(this);
@@ -2091,7 +2577,7 @@ var _ObjRest = class _ObjRest extends MusicObject {
2091
2577
  }
2092
2578
  this.runningDiatonicId = this.setDiatonicId;
2093
2579
  this.runningStemDir = "up" /* Up */;
2094
- this.color = (_c = options == null ? void 0 : options.color) != null ? _c : "black";
2580
+ this.color = (_c = options == null ? void 0 : options.color) != null ? _c : DocumentColor.Staff_Rest;
2095
2581
  this.hide = (_d = options == null ? void 0 : options.hide) != null ? _d : false;
2096
2582
  this.oldStyleTriplet = tupletRatio === void 0 && ((options == null ? void 0 : options.triplet) === true || NoteLengthProps2.get(noteLength).isTriplet);
2097
2583
  let dotCount = typeof (options == null ? void 0 : options.dotted) === "number" ? options.dotted > 0 ? options.dotted : void 0 : (options == null ? void 0 : options.dotted) === true ? 1 : void 0;
@@ -2200,7 +2686,7 @@ var _ObjRest = class _ObjRest extends MusicObject {
2200
2686
  case 64:
2201
2687
  return -3;
2202
2688
  default:
2203
- throw new MusicError5(MusicErrorType5.Score, `Get rest dot vertical displacement: Invalid note size: ${noteSize}`);
2689
+ throw new MusicError4(MusicErrorType4.Score, `Get rest dot vertical displacement: Invalid note size: ${noteSize}`);
2204
2690
  }
2205
2691
  }
2206
2692
  updateAccidentalState(accState) {
@@ -2224,7 +2710,7 @@ var _ObjRest = class _ObjRest extends MusicObject {
2224
2710
  let dotWidth = DocumentSettings.DotSize * unitSize;
2225
2711
  let dotX = obj.restRect.rightw + (DocumentSettings.RestDotSpace + DocumentSettings.DotSize * unitSize) + i * DocumentSettings.DotSize * unitSize * 1.5;
2226
2712
  let dotY = this.getRestDotVerticalDisplacement(noteSize) * unitSize;
2227
- obj.dotRects.push(AnchoredRect8.createCentered(dotX, dotY, dotWidth, dotWidth));
2713
+ obj.dotRects.push(AnchoredRect.createCentered(dotX, dotY, dotWidth, dotWidth));
2228
2714
  }
2229
2715
  obj.setAnchor(0, staff.getDiatonicIdY(diatonicId));
2230
2716
  this.staffObjects.push(obj);
@@ -2233,7 +2719,7 @@ var _ObjRest = class _ObjRest extends MusicObject {
2233
2719
  }
2234
2720
  updateRect() {
2235
2721
  if (this.staffObjects.length === 0) {
2236
- this.rect = new AnchoredRect8();
2722
+ this.rect = new AnchoredRect();
2237
2723
  } else {
2238
2724
  this.rect = this.staffObjects[0].getRect().clone();
2239
2725
  if (this.staffObjects.length > 1) {
@@ -2265,18 +2751,17 @@ __publicField(_ObjRest, "UndefinedDiatonicId", Infinity);
2265
2751
  var ObjRest = _ObjRest;
2266
2752
 
2267
2753
  // src/score/engine/obj-note-group.ts
2268
- import { AnchoredRect as AnchoredRect9, Guard as Guard2, Utils as Utils3 } from "@tspro/ts-utils-lib";
2269
2754
  import { Note as Note4, NoteLengthProps as NoteLengthProps3, RhythmProps as RhythmProps3, Tuplet as Tuplet2 } from "@tspro/web-music-score/theory";
2270
- import { MusicError as MusicError6, MusicErrorType as MusicErrorType6 } from "@tspro/web-music-score/core";
2755
+ import { MusicError as MusicError5, MusicErrorType as MusicErrorType5 } from "@tspro/web-music-score/core";
2271
2756
  function getArpeggio(a) {
2272
- return Guard2.isEnumValue(a, Arpeggio) ? a : a === true ? "up" /* Up */ : void 0;
2757
+ return guard_exports.isEnumValue(a, Arpeggio) ? a : a === true ? "up" /* Up */ : void 0;
2273
2758
  }
2274
2759
  function sortNotesAndStrings(notes, strings) {
2275
- let stringArr = Utils3.Arr.isArray(strings) ? strings : strings !== void 0 ? [strings] : [];
2760
+ let stringArr = utils_exports.Arr.isArray(strings) ? strings : strings !== void 0 ? [strings] : [];
2276
2761
  let noteStringData = notes.map((note, i) => {
2277
2762
  return { note, string: stringArr[i] };
2278
2763
  });
2279
- noteStringData = Utils3.Arr.removeDuplicates(noteStringData, (a, b) => Note4.equals(a.note, b.note)).sort((a, b) => Note4.compareFunc(a.note, b.note));
2764
+ noteStringData = utils_exports.Arr.removeDuplicates(noteStringData, (a, b) => Note4.equals(a.note, b.note)).sort((a, b) => Note4.compareFunc(a.note, b.note));
2280
2765
  return {
2281
2766
  sortedNotes: noteStringData.map((e) => e.note),
2282
2767
  sortedStrings: noteStringData.every((e) => e.string === void 0) ? void 0 : noteStringData.map((e) => e.string)
@@ -2398,8 +2883,8 @@ var ObjNoteGroup = class _ObjNoteGroup extends MusicObject {
2398
2883
  __publicField(this, "tabObjects", []);
2399
2884
  __publicField(this, "isNoteDisplaced");
2400
2885
  __publicField(this, "mi");
2401
- if (!Guard2.isIntegerGte(notes.length, 1)) {
2402
- throw new MusicError6(MusicErrorType6.Score, "Cannot create note group object because notes array is empty.");
2886
+ if (!guard_exports.isIntegerGte(notes.length, 1)) {
2887
+ throw new MusicError5(MusicErrorType5.Score, "Cannot create note group object because notes array is empty.");
2403
2888
  }
2404
2889
  let { sortedNotes, sortedStrings } = sortNotesAndStrings(notes, options == null ? void 0 : options.string);
2405
2890
  this.notes = sortedNotes;
@@ -2409,7 +2894,7 @@ var ObjNoteGroup = class _ObjNoteGroup extends MusicObject {
2409
2894
  this.runningDiatonicId = this.setDiatonicId;
2410
2895
  this.runningStemDir = "up" /* Up */;
2411
2896
  this.runningStringNumbers = [];
2412
- this.color = (_a = options == null ? void 0 : options.color) != null ? _a : "black";
2897
+ this.color = (_a = options == null ? void 0 : options.color) != null ? _a : DocumentColor.Staff_Note;
2413
2898
  this.staccato = (_b = options == null ? void 0 : options.staccato) != null ? _b : false;
2414
2899
  this.diamond = (_c = options == null ? void 0 : options.diamond) != null ? _c : false;
2415
2900
  this.arpeggio = getArpeggio(options == null ? void 0 : options.arpeggio);
@@ -2451,9 +2936,9 @@ var ObjNoteGroup = class _ObjNoteGroup extends MusicObject {
2451
2936
  }
2452
2937
  startConnective(connectiveProps) {
2453
2938
  if (!this.row.hasStaff && connectiveProps.connective === "tie" /* Tie */) {
2454
- throw new MusicError6(MusicErrorType6.Score, "Ties not implemented for guitar tabs alone, staff is required!");
2939
+ throw new MusicError5(MusicErrorType5.Score, "Ties not implemented for guitar tabs alone, staff is required!");
2455
2940
  } else if (!this.row.hasStaff && connectiveProps.connective === "slur" /* Slur */) {
2456
- throw new MusicError6(MusicErrorType6.Score, "Slurs not implemented for guitar tabs alone, staff is required!");
2941
+ throw new MusicError5(MusicErrorType5.Score, "Slurs not implemented for guitar tabs alone, staff is required!");
2457
2942
  }
2458
2943
  this.startConnnectives.push(connectiveProps);
2459
2944
  this.doc.addConnectiveProps(connectiveProps);
@@ -2491,7 +2976,7 @@ var ObjNoteGroup = class _ObjNoteGroup extends MusicObject {
2491
2976
  var _a;
2492
2977
  if (line instanceof ObjStaff) {
2493
2978
  if (noteIndex < 0 || noteIndex >= this.notes.length) {
2494
- throw new MusicError6(MusicErrorType6.Score, "Invalid noteIndex: " + noteIndex);
2979
+ throw new MusicError5(MusicErrorType5.Score, "Invalid noteIndex: " + noteIndex);
2495
2980
  }
2496
2981
  let obj = this.staffObjects.find((obj2) => obj2.staff === line);
2497
2982
  if (!obj || noteIndex < 0 || noteIndex >= obj.noteHeadRects.length) {
@@ -2539,7 +3024,7 @@ var ObjNoteGroup = class _ObjNoteGroup extends MusicObject {
2539
3024
  case "stemTip" /* StemTip */:
2540
3025
  return { x: anchorX, y: stemTip.anchorY + (stemDir === "up" /* Up */ ? -padding : padding) };
2541
3026
  default:
2542
- throw new MusicError6(MusicErrorType6.Score, "Invalid noteAnchor: " + noteAnchor);
3027
+ throw new MusicError5(MusicErrorType5.Score, "Invalid noteAnchor: " + noteAnchor);
2543
3028
  }
2544
3029
  } else if (line instanceof ObjTab) {
2545
3030
  let fretNumber = (_a = this.tabObjects.find((obj) => obj.tab === line)) == null ? void 0 : _a.fretNumbers[noteIndex];
@@ -2689,7 +3174,7 @@ var ObjNoteGroup = class _ObjNoteGroup extends MusicObject {
2689
3174
  if (j >= 0) {
2690
3175
  tieNoteGroups = tieNoteGroups.slice(0, j);
2691
3176
  }
2692
- return Utils3.Math.sum(tieNoteGroups.map((ng) => ng.rhythmProps.ticks));
3177
+ return utils_exports.Math.sum(tieNoteGroups.map((ng) => ng.rhythmProps.ticks));
2693
3178
  });
2694
3179
  return tiedTicks.length === 0 ? this.rhythmProps.ticks : Math.max(...tiedTicks);
2695
3180
  }
@@ -2728,7 +3213,7 @@ var ObjNoteGroup = class _ObjNoteGroup extends MusicObject {
2728
3213
  if (isTopNote && stemDir === "up" /* Up */) stemTipStaff = noteStaff;
2729
3214
  if (isBottomNote && stemDir === "down" /* Down */) stemTipStaff = noteStaff;
2730
3215
  if (isTopNote && stemDir === "down" /* Down */) stemBaseStaff = noteStaff;
2731
- let noteHeadRect = obj.noteHeadRects[noteIndex] = AnchoredRect9.createCentered(noteX, noteY, noteHeadWidth, noteHeadHeight);
3216
+ let noteHeadRect = obj.noteHeadRects[noteIndex] = AnchoredRect.createCentered(noteX, noteY, noteHeadWidth, noteHeadHeight);
2732
3217
  noteStaff.addObject(noteHeadRect);
2733
3218
  if (accState.needAccidental(note)) {
2734
3219
  let acc = obj.accidentals[noteIndex] = new ObjAccidental(this, note.diatonicId, note.accidental, this.color);
@@ -2744,7 +3229,7 @@ var ObjNoteGroup = class _ObjNoteGroup extends MusicObject {
2744
3229
  for (let i = 0; i < dotCount; i++) {
2745
3230
  let dotX = noteHeadRect.right + DocumentSettings.NoteDotSpace * unitSize + dotWidth / 2 + i * dotWidth * 1.5;
2746
3231
  let dotY = noteY + this.getDotVerticalDisplacement(staff, note.diatonicId, stemDir) * unitSize;
2747
- let r = AnchoredRect9.createCentered(dotX, dotY, dotWidth, dotWidth);
3232
+ let r = AnchoredRect.createCentered(dotX, dotY, dotWidth, dotWidth);
2748
3233
  obj.dotRects.push(r);
2749
3234
  noteStaff.addObject(r);
2750
3235
  }
@@ -2752,13 +3237,13 @@ var ObjNoteGroup = class _ObjNoteGroup extends MusicObject {
2752
3237
  if (stemDir === "up" /* Up */ && isBottomNote) {
2753
3238
  let dotX = noteX;
2754
3239
  let dotY = noteY + unitSize * (isNoteOnLine ? 3 : 2);
2755
- let r = AnchoredRect9.createCentered(dotX, dotY, dotWidth, dotWidth);
3240
+ let r = AnchoredRect.createCentered(dotX, dotY, dotWidth, dotWidth);
2756
3241
  obj.dotRects.push(r);
2757
3242
  stemBaseStaff.addObject(r);
2758
3243
  } else if (stemDir === "down" /* Down */ && isTopNote) {
2759
3244
  let dotX = noteX;
2760
3245
  let dotY = noteY - unitSize * (isNoteOnLine ? 3 : 2);
2761
- let r = AnchoredRect9.createCentered(dotX, dotY, dotWidth, dotWidth);
3246
+ let r = AnchoredRect.createCentered(dotX, dotY, dotWidth, dotWidth);
2762
3247
  obj.dotRects.push(r);
2763
3248
  stemBaseStaff.addObject(r);
2764
3249
  }
@@ -2771,8 +3256,8 @@ var ObjNoteGroup = class _ObjNoteGroup extends MusicObject {
2771
3256
  let stemTipY = stemDir === "up" /* Up */ ? topNoteY - stemHeight : bottomNoteY + stemHeight;
2772
3257
  let stemBaseY = stemDir === "up" /* Up */ ? bottomNoteY : topNoteY;
2773
3258
  if (hasStem) {
2774
- obj.stemTip = new AnchoredRect9(stemX, stemX, stemTipY, stemTipY);
2775
- obj.stemBase = new AnchoredRect9(stemX, stemX, stemBaseY, stemBaseY);
3259
+ obj.stemTip = new AnchoredRect(stemX, stemX, stemTipY, stemTipY);
3260
+ obj.stemBase = new AnchoredRect(stemX, stemX, stemBaseY, stemBaseY);
2776
3261
  stemTipStaff.addObject(obj.stemTip);
2777
3262
  stemBaseStaff.addObject(obj.stemBase);
2778
3263
  }
@@ -2781,7 +3266,7 @@ var ObjNoteGroup = class _ObjNoteGroup extends MusicObject {
2781
3266
  let flagHeight = flagCount === 0 ? 0 : DocumentSettings.FlagHeight * unitSize;
2782
3267
  for (let i = 0; i < flagCount; i++) {
2783
3268
  let flagAddY = i * unitSize * DocumentSettings.FlagSeparation;
2784
- let r = obj.flagRects[i] = stemDir === "up" /* Up */ ? new AnchoredRect9(stemX, stemX + flagWidth, stemTipY + flagAddY, stemTipY + flagHeight + flagAddY) : new AnchoredRect9(stemX, stemX + flagWidth, stemTipY - flagHeight - flagAddY, stemTipY - flagAddY);
3269
+ let r = obj.flagRects[i] = stemDir === "up" /* Up */ ? new AnchoredRect(stemX, stemX + flagWidth, stemTipY + flagAddY, stemTipY + flagHeight + flagAddY) : new AnchoredRect(stemX, stemX + flagWidth, stemTipY - flagHeight - flagAddY, stemTipY - flagAddY);
2785
3270
  stemTipStaff.addObject(r);
2786
3271
  }
2787
3272
  }
@@ -2794,12 +3279,13 @@ var ObjNoteGroup = class _ObjNoteGroup extends MusicObject {
2794
3279
  return;
2795
3280
  }
2796
3281
  let obj = new ObjTabNoteGroup(tab, this);
3282
+ const bgcolor = DocumentColor.Background;
3283
+ const color = DocumentColor.Tab_Note;
2797
3284
  this.notes.forEach((note, noteIndex) => {
2798
3285
  let stringNumber = this.runningStringNumbers[noteIndex];
2799
- if (Guard2.isIntegerBetween(stringNumber, 1, 6)) {
3286
+ if (guard_exports.isIntegerBetween(stringNumber, 1, 6)) {
2800
3287
  let fretId = note.chromaticId - tab.getTuningStrings()[stringNumber - 1].chromaticId;
2801
- let color = fretId < 0 ? "red" : "black";
2802
- let fretNumber = new ObjText(this, { text: String(fretId), color, bgcolor: "white" }, 0.5, 0.5);
3288
+ let fretNumber = new ObjText(this, { text: String(fretId), color, bgcolor }, 0.5, 0.5);
2803
3289
  fretNumber.layout(ctx);
2804
3290
  fretNumber.setAnchor(this.col.getRect().anchorX, tab.getStringY(stringNumber - 1));
2805
3291
  obj.fretNumbers.push(fretNumber);
@@ -2818,7 +3304,7 @@ var ObjNoteGroup = class _ObjNoteGroup extends MusicObject {
2818
3304
  } else if (this.tabObjects.length > 0 && this.tabObjects[0].fretNumbers.length > 0) {
2819
3305
  this.rect = this.tabObjects[0].fretNumbers[0].getRect().clone();
2820
3306
  } else {
2821
- this.rect = new AnchoredRect9();
3307
+ this.rect = new AnchoredRect();
2822
3308
  return;
2823
3309
  }
2824
3310
  this.staffObjects.forEach((obj) => this.rect.expandInPlace(obj.getRect()));
@@ -2915,8 +3401,7 @@ var ObjNoteGroup = class _ObjNoteGroup extends MusicObject {
2915
3401
  };
2916
3402
 
2917
3403
  // src/score/engine/obj-rhythm-column.ts
2918
- import { MusicError as MusicError7, MusicErrorType as MusicErrorType7 } from "@tspro/web-music-score/core";
2919
- import { IndexArray, UniMap as UniMap2, TriMap, AnchoredRect as AnchoredRect10 } from "@tspro/ts-utils-lib";
3404
+ import { MusicError as MusicError6, MusicErrorType as MusicErrorType6 } from "@tspro/web-music-score/core";
2920
3405
  var ObjRhythmColumn = class extends MusicObject {
2921
3406
  constructor(measure, positionTicks) {
2922
3407
  super(measure);
@@ -2926,8 +3411,8 @@ var ObjRhythmColumn = class extends MusicObject {
2926
3411
  __publicField(this, "lyricsObject", new TriMap());
2927
3412
  __publicField(this, "minDiatonicId");
2928
3413
  __publicField(this, "maxDiatonicId");
2929
- __publicField(this, "staffMinDiatonicId", new UniMap2());
2930
- __publicField(this, "staffMaxDiatonicId", new UniMap2());
3414
+ __publicField(this, "staffMinDiatonicId", new UniMap());
3415
+ __publicField(this, "staffMaxDiatonicId", new UniMap());
2931
3416
  __publicField(this, "arpeggioDir");
2932
3417
  __publicField(this, "arpeggios", []);
2933
3418
  __publicField(this, "playerProps");
@@ -2952,7 +3437,7 @@ var ObjRhythmColumn = class extends MusicObject {
2952
3437
  if (colId >= 0 && colId < this.measure.getColumnCount()) {
2953
3438
  return this.measure.getColumn(colId + 1);
2954
3439
  } else {
2955
- throw new MusicError7(MusicErrorType7.Score, "Cannot get next column in measure because current column's id in mesure is invalid.");
3440
+ throw new MusicError6(MusicErrorType6.Score, "Cannot get next column in measure because current column's id in mesure is invalid.");
2956
3441
  }
2957
3442
  }
2958
3443
  /**
@@ -3142,7 +3627,7 @@ var ObjRhythmColumn = class extends MusicObject {
3142
3627
  return;
3143
3628
  }
3144
3629
  let { row } = this;
3145
- this.rect = new AnchoredRect10();
3630
+ this.rect = new AnchoredRect();
3146
3631
  this.requestRectUpdate();
3147
3632
  let leftw = 0;
3148
3633
  let rightw = 0;
@@ -3259,6 +3744,7 @@ var ObjRhythmColumn = class extends MusicObject {
3259
3744
  this.rect.offsetInPlace(dx, dy);
3260
3745
  }
3261
3746
  draw(ctx) {
3747
+ ctx.color(DocumentColor.Staff_Frame);
3262
3748
  this.row.getStaves().forEach((staff) => {
3263
3749
  let minDiatonicId = this.staffMinDiatonicId.get(staff);
3264
3750
  let maxDiatonicId = this.staffMaxDiatonicId.get(staff);
@@ -3274,35 +3760,29 @@ var ObjRhythmColumn = class extends MusicObject {
3274
3760
  }
3275
3761
  };
3276
3762
 
3277
- // src/score/engine/extension.ts
3278
- import { MusicError as MusicError8, MusicErrorType as MusicErrorType8 } from "@tspro/web-music-score/core";
3279
-
3280
- // src/score/engine/element-data.ts
3281
- import { Guard as Guard3, Utils as Utils4 } from "@tspro/ts-utils-lib";
3282
-
3283
3763
  // src/score/engine/obj-special-text.ts
3284
- import { AnchoredRect as AnchoredRect11 } from "@tspro/ts-utils-lib";
3285
3764
  var _ObjSpecialText = class _ObjSpecialText extends MusicObject {
3286
- constructor(parent, text) {
3765
+ constructor(parent, text, color = "black") {
3287
3766
  super(parent);
3288
3767
  this.text = text;
3768
+ this.color = color;
3289
3769
  __publicField(this, "components", []);
3290
3770
  __publicField(this, "mi");
3291
3771
  switch (this.text) {
3292
3772
  case _ObjSpecialText.Coda:
3293
3773
  this.components = [
3294
- new ObjText(this, { text: "\u{1D10C}", scale: 1.7 }, 0.5, 0.3),
3295
- new ObjText(this, " Coda", 0, 1)
3774
+ new ObjText(this, { text: "\u{1D10C}", scale: 1.7, color }, 0.5, 0.3),
3775
+ new ObjText(this, { text: " Coda", color }, 0, 1)
3296
3776
  ];
3297
3777
  break;
3298
3778
  case _ObjSpecialText.toCoda:
3299
3779
  this.components = [
3300
- new ObjText(this, "toCoda ", 1, 1),
3301
- new ObjText(this, { text: "\u{1D10C}", scale: 1.7 }, 0.5, 0.3)
3780
+ new ObjText(this, { text: "toCoda ", color }, 1, 1),
3781
+ new ObjText(this, { text: "\u{1D10C}", scale: 1.7, color }, 0.5, 0.3)
3302
3782
  ];
3303
3783
  break;
3304
3784
  case _ObjSpecialText.Segno:
3305
- this.components = [new ObjText(this, { text: "\u{1D10B}", scale: 1.1 }, 0.5, 1)];
3785
+ this.components = [new ObjText(this, { text: "\u{1D10B}", scale: 1.1, color }, 0.5, 1)];
3306
3786
  break;
3307
3787
  default:
3308
3788
  this.components = [];
@@ -3328,7 +3808,7 @@ var _ObjSpecialText = class _ObjSpecialText extends MusicObject {
3328
3808
  codaText.layout(ctx);
3329
3809
  codaSym.setAnchorY(codaText.getRect().centerY);
3330
3810
  codaText.setLeft(codaSym.getRect().right);
3331
- this.rect = new AnchoredRect11(
3811
+ this.rect = new AnchoredRect(
3332
3812
  codaSym.getRect().left,
3333
3813
  codaSym.getRect().anchorX,
3334
3814
  codaText.getRect().right,
@@ -3345,7 +3825,7 @@ var _ObjSpecialText = class _ObjSpecialText extends MusicObject {
3345
3825
  codaSym.layout(ctx);
3346
3826
  codaSym.setAnchorY(toCodaText.getRect().centerY);
3347
3827
  toCodaText.setRight(codaSym.getRect().left);
3348
- this.rect = new AnchoredRect11(
3828
+ this.rect = new AnchoredRect(
3349
3829
  toCodaText.getRect().left,
3350
3830
  codaSym.getRect().anchorX,
3351
3831
  codaSym.getRect().right,
@@ -3377,6 +3857,84 @@ __publicField(_ObjSpecialText, "Coda", "Coda \u{1D10C}");
3377
3857
  __publicField(_ObjSpecialText, "Segno", "\u{1D10B}");
3378
3858
  var ObjSpecialText = _ObjSpecialText;
3379
3859
 
3860
+ // src/score/engine/extension.ts
3861
+ function getTextContent(obj) {
3862
+ if (obj instanceof ObjText || obj instanceof ObjSpecialText)
3863
+ return obj.getText();
3864
+ if (obj instanceof ObjMeasure)
3865
+ return "[measure]";
3866
+ return "";
3867
+ }
3868
+ var ExtensionRange = class {
3869
+ constructor(startColumn) {
3870
+ this.startColumn = startColumn;
3871
+ __publicField(this, "columnRange");
3872
+ __publicField(this, "stopObject");
3873
+ this.columnRange = [startColumn];
3874
+ }
3875
+ get endColumn() {
3876
+ return this.columnRange[this.columnRange.length - 1];
3877
+ }
3878
+ addColumn(col) {
3879
+ if (this.endColumn !== col) this.columnRange.push(col);
3880
+ }
3881
+ setStopObject(obj) {
3882
+ this.stopObject = obj;
3883
+ }
3884
+ };
3885
+ var _Extension = class _Extension extends MusicObjectLink {
3886
+ constructor(headObj, startColumn, length, visible, lineStyle, linePos) {
3887
+ super(headObj.musicObj);
3888
+ this.headObj = headObj;
3889
+ __publicField(this, "length");
3890
+ __publicField(this, "visible");
3891
+ __publicField(this, "lineStyle");
3892
+ __publicField(this, "linePos");
3893
+ __publicField(this, "startColumn");
3894
+ this.length = length + 1;
3895
+ this.visible = visible;
3896
+ this.lineStyle = lineStyle;
3897
+ this.linePos = linePos;
3898
+ this.startColumn = startColumn;
3899
+ }
3900
+ isVisible() {
3901
+ return this.visible;
3902
+ }
3903
+ getLineStyle() {
3904
+ return this.lineStyle;
3905
+ }
3906
+ getLinePos() {
3907
+ return this.linePos;
3908
+ }
3909
+ whatStopped(col) {
3910
+ const m = col.measure;
3911
+ const cols = m.getColumns();
3912
+ const stoppingCol = col.getAnchoredLayoutObjects().filter((obj) => obj !== this.headObj && obj.layoutGroupId === this.headObj.layoutGroupId).map((obj) => obj.musicObj).filter((obj) => obj instanceof ObjText || obj instanceof ObjSpecialText)[0];
3913
+ return stoppingCol ? stoppingCol : col === cols[cols.length - 1] && m.hasEndSection() || m.hasEndSong() || _Extension.StopNavigations.some((nav) => m.hasNavigation(nav)) ? m.getBarLineRight() : void 0;
3914
+ }
3915
+ getRange() {
3916
+ let { startColumn, length } = this;
3917
+ let curColumn = startColumn;
3918
+ let range = new ExtensionRange(curColumn);
3919
+ let ticksLeft = length;
3920
+ while (true) {
3921
+ if (ticksLeft <= 0) return range;
3922
+ const stopObject = this.whatStopped(curColumn);
3923
+ if (stopObject !== void 0) {
3924
+ range.setStopObject(stopObject);
3925
+ return range;
3926
+ }
3927
+ ticksLeft -= curColumn.getTicksToNextColumn();
3928
+ curColumn = curColumn.getNextColumn();
3929
+ if (!curColumn) return range;
3930
+ if (ticksLeft > 0)
3931
+ range.addColumn(curColumn);
3932
+ }
3933
+ }
3934
+ };
3935
+ __publicField(_Extension, "StopNavigations", ["endRepeat" /* EndRepeat */, "ending" /* Ending */]);
3936
+ var Extension = _Extension;
3937
+
3380
3938
  // src/score/engine/element-data.ts
3381
3939
  function getNavigationString(navigation) {
3382
3940
  switch (navigation) {
@@ -3400,140 +3958,24 @@ function getNavigationString(navigation) {
3400
3958
  return navigation[0].toUpperCase() + navigation.substring(1);
3401
3959
  }
3402
3960
  }
3403
- function isDynamicsText(text) {
3404
- return Guard3.isEnumValue(text, DynamicsAnnotation);
3405
- }
3406
3961
  function getDynamicsVolume(text) {
3407
3962
  if (/^(p+|f+|m|mp|mf)$/.test(text)) {
3408
- let volume = 0.5 - Utils4.Str.charCount(text, "p") * 0.1 + Utils4.Str.charCount(text, "f") * 0.1;
3409
- return Utils4.Math.clamp(volume, 0, 1);
3963
+ let volume = 0.5 - utils_exports.Str.charCount(text, "p") * 0.1 + utils_exports.Str.charCount(text, "f") * 0.1;
3964
+ return utils_exports.Math.clamp(volume, 0, 1);
3410
3965
  } else {
3411
3966
  return void 0;
3412
3967
  }
3413
3968
  }
3414
- function isTempoText(text) {
3415
- return Guard3.isEnumValue(text, TempoAnnotation);
3416
- }
3417
3969
  function getAnnotation(text) {
3418
- if (Guard3.isEnumValue(text, DynamicsAnnotation)) {
3970
+ if (guard_exports.isEnumValue(text, DynamicsAnnotation)) {
3419
3971
  return "dynamics" /* Dynamics */;
3420
- } else if (Guard3.isEnumValue(text, TempoAnnotation)) {
3972
+ } else if (guard_exports.isEnumValue(text, TempoAnnotation)) {
3421
3973
  return "tempo" /* Tempo */;
3422
3974
  } else {
3423
3975
  return void 0;
3424
3976
  }
3425
3977
  }
3426
3978
 
3427
- // src/score/engine/extension.ts
3428
- function getTextAnchorY(linePos) {
3429
- switch (linePos) {
3430
- case "bottom":
3431
- return 0.8;
3432
- case "middle":
3433
- return 0.5;
3434
- }
3435
- }
3436
- function getContext(elementText) {
3437
- if (isDynamicsText(elementText)) {
3438
- return 2 /* Volume */;
3439
- } else if (isTempoText(elementText)) {
3440
- return 1 /* Tempo */;
3441
- } else {
3442
- return 0 /* Undefined */;
3443
- }
3444
- }
3445
- var Extension = class extends MusicObjectLink {
3446
- constructor(head, startColumn, length, visible, lineStyle, linePos) {
3447
- super(head);
3448
- __publicField(this, "length");
3449
- __publicField(this, "visible");
3450
- __publicField(this, "lineStyle");
3451
- __publicField(this, "linePos");
3452
- __publicField(this, "startColumn");
3453
- __publicField(this, "context");
3454
- this.length = length;
3455
- this.visible = visible;
3456
- this.lineStyle = lineStyle;
3457
- this.linePos = linePos;
3458
- this.startColumn = startColumn;
3459
- this.context = head instanceof ObjText ? getContext(head.getText()) : 0 /* Undefined */;
3460
- if (head instanceof ObjText) {
3461
- head.updateAnchorY(getTextAnchorY(linePos));
3462
- } else {
3463
- throw new MusicError8(MusicErrorType8.Score, "Update anchor's y-coordinate is only implemented for text objects.");
3464
- }
3465
- }
3466
- isVisible() {
3467
- return this.visible;
3468
- }
3469
- getLineStyle() {
3470
- return this.lineStyle;
3471
- }
3472
- getLinePos() {
3473
- return this.linePos;
3474
- }
3475
- getSpanBreakText(col, context) {
3476
- if (col === col.measure.getColumn(0)) {
3477
- let prevMeasure = col.measure.getPrevMeasure();
3478
- if (prevMeasure) {
3479
- if (prevMeasure.hasEndSection() || prevMeasure.hasEndSong()) {
3480
- return "section-break";
3481
- }
3482
- let elemArr = ["endRepeat" /* EndRepeat */, "ending" /* Ending */];
3483
- for (let i = 0; i < elemArr.length; i++) {
3484
- if (prevMeasure.hasNavigation(elemArr[i])) {
3485
- return "section-break";
3486
- }
3487
- }
3488
- }
3489
- }
3490
- if (context === 1 /* Tempo */) {
3491
- let objArr = col.getAnchoredLayoutObjects();
3492
- for (let i = 0; i < objArr.length; i++) {
3493
- let text = objArr[i].getTextContent();
3494
- if (text && isTempoText(text)) {
3495
- return text;
3496
- }
3497
- }
3498
- } else if (context === 2 /* Volume */) {
3499
- let objArr = col.getAnchoredLayoutObjects();
3500
- for (let i = 0; i < objArr.length; i++) {
3501
- let text = objArr[i].getTextContent();
3502
- if (text && isDynamicsText(text)) {
3503
- return text;
3504
- }
3505
- }
3506
- }
3507
- return void 0;
3508
- }
3509
- getExtensionRangeInfo() {
3510
- let { startColumn, length: extensionLength, context } = this;
3511
- let columnRange = [startColumn];
3512
- if (extensionLength <= 0) {
3513
- return { startColumn, endColumn: startColumn, columnRange, extensionBreakText: void 0 };
3514
- }
3515
- let ticksLeft = extensionLength;
3516
- let endColumn = startColumn;
3517
- while (true) {
3518
- let nextColumn = endColumn.getNextColumn();
3519
- if (!nextColumn) {
3520
- return { startColumn, endColumn, columnRange, extensionBreakText: void 0 };
3521
- }
3522
- let extensionBreakText = this.getSpanBreakText(nextColumn, context);
3523
- if (extensionBreakText !== void 0) {
3524
- return { startColumn, endColumn, columnRange, extensionBreakText };
3525
- }
3526
- ticksLeft -= endColumn.getTicksToNextColumn();
3527
- if (ticksLeft <= 0) {
3528
- return { startColumn, endColumn, columnRange, extensionBreakText: void 0 };
3529
- } else {
3530
- endColumn = nextColumn;
3531
- columnRange.push(endColumn);
3532
- }
3533
- }
3534
- }
3535
- };
3536
-
3537
3979
  // src/score/engine/player.ts
3538
3980
  var AccelerandoSpeedMul = 2;
3539
3981
  var RitardandoSpeedDiv = 2;
@@ -3573,7 +4015,7 @@ var PlayerColumnProps = class {
3573
4015
  return this.speed;
3574
4016
  }
3575
4017
  getTempo() {
3576
- let speed = Utils5.Math.clamp(this.getSpeed(), 0.1, 10);
4018
+ let speed = utils_exports.Math.clamp(this.getSpeed(), 0.1, 10);
3577
4019
  return alterTempoSpeed(this.measure.getTempo(), speed);
3578
4020
  }
3579
4021
  setVolume(volume) {
@@ -3598,7 +4040,7 @@ var PlayerColumnProps = class {
3598
4040
  if (symbolsTicks.length === 0) {
3599
4041
  return 0;
3600
4042
  } else {
3601
- return Utils5.Math.sum(symbolsTicks) / symbolsTicks.length;
4043
+ return utils_exports.Math.sum(symbolsTicks) / symbolsTicks.length;
3602
4044
  }
3603
4045
  }
3604
4046
  }
@@ -3721,8 +4163,8 @@ var Player = class _Player {
3721
4163
  }
3722
4164
  let curSpeed = 1;
3723
4165
  let curVolume = getDefaultVolume();
3724
- let speedMap = new UniMap3();
3725
- let volumeMap = new UniMap3();
4166
+ let speedMap = new UniMap();
4167
+ let volumeMap = new UniMap();
3726
4168
  const pushSpeed = (col, speed) => speedMap.getOrCreate(col, []).push(speed);
3727
4169
  const pushVolume = (col, volume) => volumeMap.getOrCreate(col, []).push(volume);
3728
4170
  this.playerColumnSequence.forEach((col) => {
@@ -3730,8 +4172,7 @@ var Player = class _Player {
3730
4172
  return;
3731
4173
  }
3732
4174
  col.getAnchoredLayoutObjects().forEach((layoutObj) => {
3733
- var _a;
3734
- let text = (_a = layoutObj.getTextContent()) != null ? _a : "";
4175
+ const text = getTextContent(layoutObj.musicObj);
3735
4176
  let vol;
3736
4177
  if (text === "a tempo" /* a_tempo */) {
3737
4178
  curSpeed = 1;
@@ -3739,14 +4180,15 @@ var Player = class _Player {
3739
4180
  curVolume = vol;
3740
4181
  } else if (layoutObj.musicObj.getLink() instanceof Extension) {
3741
4182
  let extension = layoutObj.musicObj.getLink();
3742
- let { columnRange, extensionBreakText } = extension.getExtensionRangeInfo();
3743
- let totalTicks = Utils5.Math.sum(columnRange.map((c) => c.getTicksToNextColumn()));
4183
+ const range = extension.getRange();
4184
+ const stopText = range.stopObject ? getTextContent(range.stopObject) : "";
4185
+ let totalTicks = utils_exports.Math.sum(range.columnRange.map((c) => c.getTicksToNextColumn()));
3744
4186
  switch (text) {
3745
4187
  case "accel." /* accel */: {
3746
4188
  let startSpeed = curSpeed;
3747
4189
  let endSpeed = startSpeed * AccelerandoSpeedMul;
3748
4190
  let accuTicks = 0;
3749
- columnRange.forEach((c) => {
4191
+ range.columnRange.forEach((c) => {
3750
4192
  accuTicks += c.getTicksToNextColumn();
3751
4193
  pushSpeed(c, startSpeed + (endSpeed - startSpeed) * accuTicks / totalTicks);
3752
4194
  });
@@ -3756,7 +4198,7 @@ var Player = class _Player {
3756
4198
  let startSpeed = curSpeed;
3757
4199
  let endSpeed = startSpeed / RitardandoSpeedDiv;
3758
4200
  let accuTicks = 0;
3759
- columnRange.forEach((c) => {
4201
+ range.columnRange.forEach((c) => {
3760
4202
  accuTicks += c.getTicksToNextColumn();
3761
4203
  pushSpeed(c, startSpeed + (endSpeed - startSpeed) * accuTicks / totalTicks);
3762
4204
  });
@@ -3765,11 +4207,11 @@ var Player = class _Player {
3765
4207
  case "cresc." /* cresc */: {
3766
4208
  let startVol = curVolume;
3767
4209
  let endVol = startVol + CrescendoVolumeAdd;
3768
- if (extensionBreakText && (vol = getDynamicsVolume(extensionBreakText)) !== void 0 && vol > startVol) {
4210
+ if (range.stopObject && (vol = getDynamicsVolume(stopText)) !== void 0 && vol > startVol) {
3769
4211
  endVol = vol;
3770
4212
  }
3771
4213
  let accuTicks = 0;
3772
- columnRange.forEach((c) => {
4214
+ range.columnRange.forEach((c) => {
3773
4215
  accuTicks += c.getTicksToNextColumn();
3774
4216
  pushVolume(c, startVol + (endVol - startVol) * accuTicks / totalTicks);
3775
4217
  });
@@ -3779,11 +4221,11 @@ var Player = class _Player {
3779
4221
  case "dim." /* dim */: {
3780
4222
  let startVol = curVolume;
3781
4223
  let endVol = startVol - DiminuendoVolumeSub;
3782
- if (extensionBreakText && (vol = getDynamicsVolume(extensionBreakText)) !== void 0 && vol < startVol) {
4224
+ if (range.stopObject && (vol = getDynamicsVolume(stopText)) !== void 0 && vol < startVol) {
3783
4225
  endVol = vol;
3784
4226
  }
3785
4227
  let accuTicks = 0;
3786
- columnRange.forEach((c) => {
4228
+ range.columnRange.forEach((c) => {
3787
4229
  accuTicks += c.getTicksToNextColumn();
3788
4230
  pushVolume(c, startVol + (endVol - startVol) * accuTicks / totalTicks);
3789
4231
  });
@@ -3794,11 +4236,11 @@ var Player = class _Player {
3794
4236
  });
3795
4237
  let speedArr = speedMap.getOrDefault(col, []);
3796
4238
  if (speedArr.length > 0) {
3797
- curSpeed = Utils5.Math.sum(speedArr) / speedArr.length;
4239
+ curSpeed = utils_exports.Math.sum(speedArr) / speedArr.length;
3798
4240
  }
3799
4241
  let volumeArr = volumeMap.getOrDefault(col, []);
3800
4242
  if (volumeArr.length > 0) {
3801
- curVolume = Utils5.Math.sum(volumeArr) / volumeArr.length;
4243
+ curVolume = utils_exports.Math.sum(volumeArr) / volumeArr.length;
3802
4244
  }
3803
4245
  col.getPlayerProps().setSpeed(curSpeed);
3804
4246
  col.getPlayerProps().setVolume(curVolume);
@@ -3918,17 +4360,17 @@ var Player = class _Player {
3918
4360
  let measure = col.measure;
3919
4361
  let x = col.getRect().anchorX;
3920
4362
  let { top, height } = measure.row.getRect();
3921
- return new Rect2(x, top, 0, height);
4363
+ return new Rect(x, top, 0, height);
3922
4364
  }
3923
4365
  };
3924
4366
 
3925
4367
  // src/score/engine/obj-bar-line.ts
3926
- import { AnchoredRect as AnchoredRect13, UniMap as UniMap4 } from "@tspro/ts-utils-lib";
3927
4368
  var ObjStaffBarLine = class extends MusicObject {
3928
- constructor(barLine, line) {
4369
+ constructor(barLine, line, rowGroup) {
3929
4370
  super(line);
3930
4371
  this.barLine = barLine;
3931
4372
  this.line = line;
4373
+ this.rowGroup = rowGroup;
3932
4374
  __publicField(this, "vlines", []);
3933
4375
  __publicField(this, "dots", []);
3934
4376
  __publicField(this, "mi");
@@ -3942,12 +4384,12 @@ var ObjStaffBarLine = class extends MusicObject {
3942
4384
  return this.getRect().contains(x, y) ? [this] : [];
3943
4385
  }
3944
4386
  updateRect() {
3945
- this.rect = new AnchoredRect13(0, 0, this.line.getTopLineY(), this.line.getBottomLineY());
4387
+ this.rect = new AnchoredRect(0, 0, this.line.getTopLineY(), this.line.getBottomLineY());
3946
4388
  this.vlines.forEach(
3947
- (l) => this.rect.expandInPlace(new AnchoredRect13(l.left, l.left + l.width, this.rect.top, this.rect.bottom))
4389
+ (l) => this.rect.expandInPlace(new AnchoredRect(l.left, l.left + l.width, this.rect.top, this.rect.bottom))
3948
4390
  );
3949
4391
  this.dots.forEach(
3950
- (d) => this.rect.expandInPlace(new AnchoredRect13(d.x - d.r, d.x + d.r, d.y - d.r, d.y + d.r))
4392
+ (d) => this.rect.expandInPlace(new AnchoredRect(d.x - d.r, d.x + d.r, d.y - d.r, d.y + d.r))
3951
4393
  );
3952
4394
  }
3953
4395
  offset(dx, dy) {
@@ -3964,9 +4406,15 @@ var ObjBarLine = class extends MusicObject {
3964
4406
  super(measure);
3965
4407
  this.measure = measure;
3966
4408
  __publicField(this, "notationLineObjects", []);
3967
- __publicField(this, "notationLineObjectsByGrp", new UniMap4());
4409
+ __publicField(this, "notationLineObjectsByGrp", new UniMap());
3968
4410
  __publicField(this, "barLineType", 0 /* None */);
3969
4411
  }
4412
+ get doc() {
4413
+ return this.measure.doc;
4414
+ }
4415
+ get row() {
4416
+ return this.measure.row;
4417
+ }
3970
4418
  pick(x, y) {
3971
4419
  if (!this.getRect().contains(x, y)) {
3972
4420
  return [];
@@ -3994,7 +4442,7 @@ var ObjBarLine = class extends MusicObject {
3994
4442
  this.notationLineObjectsByGrp.clear();
3995
4443
  row.getRowGroups().forEach((grp) => {
3996
4444
  grp.lines.forEach((line) => {
3997
- let obj = new ObjStaffBarLine(this, line);
4445
+ let obj = new ObjStaffBarLine(this, line, grp);
3998
4446
  this.notationLineObjects.push(obj);
3999
4447
  this.notationLineObjectsByGrp.getOrCreate(grp, []).push(obj);
4000
4448
  let lineCenterY;
@@ -4058,7 +4506,7 @@ var ObjBarLine = class extends MusicObject {
4058
4506
  this.rect.expandInPlace(this.notationLineObjects[i].getRect());
4059
4507
  }
4060
4508
  } else {
4061
- this.rect = new AnchoredRect13();
4509
+ this.rect = new AnchoredRect();
4062
4510
  }
4063
4511
  }
4064
4512
  offset(dx, dy) {
@@ -4069,16 +4517,10 @@ var ObjBarLine = class extends MusicObject {
4069
4517
  if (this.barLineType === 0 /* None */)
4070
4518
  return;
4071
4519
  ctx.drawDebugRect(this.getRect());
4072
- ctx.color("black");
4073
- for (const [grp, objects] of this.notationLineObjectsByGrp) {
4074
- objects.forEach((obj, i) => {
4075
- obj.dots.forEach((d) => ctx.fillCircle(d.x, d.y, d.r));
4076
- if (i === 0) {
4077
- let { top, height } = obj.barLine.getRect();
4078
- obj.vlines.forEach((l) => ctx.fillRect(l.left, top, l.width, height));
4079
- }
4080
- });
4081
- }
4520
+ this.notationLineObjects.forEach((o) => {
4521
+ o.vlines.forEach((l) => o.line.drawVerticalLine(ctx, l.left, l.width));
4522
+ o.dots.forEach((d) => ctx.fillCircle(d.x, d.y, d.r));
4523
+ });
4082
4524
  }
4083
4525
  };
4084
4526
  var ObjBarLineLeft = class extends ObjBarLine {
@@ -4143,25 +4585,25 @@ var ObjBarLineRight = class extends ObjBarLine {
4143
4585
  };
4144
4586
 
4145
4587
  // src/score/engine/obj-ending.ts
4146
- import { AnchoredRect as AnchoredRect14, Guard as Guard4 } from "@tspro/ts-utils-lib";
4147
- import { MusicError as MusicError9, MusicErrorType as MusicErrorType9 } from "@tspro/web-music-score/core";
4588
+ import { MusicError as MusicError7, MusicErrorType as MusicErrorType7 } from "@tspro/web-music-score/core";
4148
4589
  var ObjEnding = class extends MusicObject {
4149
- constructor(measure, passages) {
4590
+ constructor(measure, color, passages) {
4150
4591
  super(measure);
4151
4592
  this.measure = measure;
4593
+ this.color = color;
4152
4594
  this.passages = passages;
4153
4595
  __publicField(this, "endingText");
4154
4596
  __publicField(this, "shapeRects", []);
4155
4597
  __publicField(this, "mi");
4156
4598
  this.mi = new MEnding(this);
4157
- if (!Guard4.isIntegerGte(passages.length, 1)) {
4158
- throw new MusicError9(MusicErrorType9.Score, "Passages is empty.");
4159
- } else if (!this.passages.every((p) => Guard4.isIntegerGte(p, 1))) {
4160
- throw new MusicError9(MusicErrorType9.Score, "Invalid passages: " + this.passages);
4599
+ if (!guard_exports.isIntegerGte(passages.length, 1)) {
4600
+ throw new MusicError7(MusicErrorType7.Score, "Passages is empty.");
4601
+ } else if (!this.passages.every((p) => guard_exports.isIntegerGte(p, 1))) {
4602
+ throw new MusicError7(MusicErrorType7.Score, "Invalid passages: " + this.passages);
4161
4603
  }
4162
4604
  this.passages.sort((a, b) => a - b);
4163
- let text = this.passages.map((p) => p + ".").join("");
4164
- this.endingText = new ObjText(this, text, 0, 1);
4605
+ const text = this.passages.map((p) => p + ".").join("");
4606
+ this.endingText = new ObjText(this, { text, color }, 0, 1);
4165
4607
  }
4166
4608
  getMusicInterface() {
4167
4609
  return this.mi;
@@ -4184,7 +4626,7 @@ var ObjEnding = class extends MusicObject {
4184
4626
  return this.rect.contains(x, y) ? [this] : [];
4185
4627
  }
4186
4628
  layout(ctx) {
4187
- this.rect = new AnchoredRect14();
4629
+ this.rect = new AnchoredRect();
4188
4630
  this.shapeRects = [this.rect.clone()];
4189
4631
  }
4190
4632
  layoutFitToMeasure(ctx) {
@@ -4194,13 +4636,13 @@ var ObjEnding = class extends MusicObject {
4194
4636
  let textRect = this.endingText.getRect();
4195
4637
  let measureContent = measure.getColumnsContentRect();
4196
4638
  let endingHeight = textRect.height;
4197
- this.rect = new AnchoredRect14(measureContent.left + unitSize, measureContent.right - unitSize, -endingHeight, 0);
4639
+ this.rect = new AnchoredRect(measureContent.left + unitSize, measureContent.right - unitSize, -endingHeight, 0);
4198
4640
  this.endingText.setLeft(this.rect.left + unitSize / 2);
4199
4641
  this.endingText.setBottom(this.rect.bottom);
4200
4642
  this.shapeRects = [
4201
- new AnchoredRect14(this.rect.left, this.rect.left + 1, this.rect.top, this.rect.bottom),
4202
- new AnchoredRect14(this.rect.left, this.rect.right, this.rect.top, this.rect.top + 1),
4203
- new AnchoredRect14(this.rect.right - 1, this.rect.right, this.rect.top, this.rect.bottom),
4643
+ new AnchoredRect(this.rect.left, this.rect.left + 1, this.rect.top, this.rect.bottom),
4644
+ new AnchoredRect(this.rect.left, this.rect.right, this.rect.top, this.rect.top + 1),
4645
+ new AnchoredRect(this.rect.right - 1, this.rect.right, this.rect.top, this.rect.bottom),
4204
4646
  this.endingText.getRect().clone()
4205
4647
  ];
4206
4648
  }
@@ -4212,7 +4654,7 @@ var ObjEnding = class extends MusicObject {
4212
4654
  draw(ctx) {
4213
4655
  let { rect } = this;
4214
4656
  ctx.drawDebugRect(this.rect);
4215
- ctx.color("black").lineWidth(1);
4657
+ ctx.color(this.color).lineWidth(1);
4216
4658
  ctx.beginPath();
4217
4659
  ctx.moveTo(rect.left, rect.bottom);
4218
4660
  ctx.lineTo(rect.left, rect.top);
@@ -4226,9 +4668,8 @@ var ObjEnding = class extends MusicObject {
4226
4668
  };
4227
4669
 
4228
4670
  // src/score/engine/obj-beam-group.ts
4229
- import { AnchoredRect as AnchoredRect15, Utils as Utils6 } from "@tspro/ts-utils-lib";
4230
4671
  import { NoteLength as NoteLength5, Tuplet as Tuplet3, NoteLengthProps as NoteLengthProps4 } from "@tspro/web-music-score/theory";
4231
- import { MusicError as MusicError10, MusicErrorType as MusicErrorType10 } from "@tspro/web-music-score/core";
4672
+ import { MusicError as MusicError8, MusicErrorType as MusicErrorType8 } from "@tspro/web-music-score/core";
4232
4673
  var adjustBeamAngle = (dx, dy) => {
4233
4674
  let T = DocumentSettings.BeamAngleFactor;
4234
4675
  if (!Number.isFinite(T) || T === 0) {
@@ -4256,7 +4697,7 @@ var BeamPoint = class {
4256
4697
  this.beamGroup.requestRectUpdate();
4257
4698
  }
4258
4699
  getRect() {
4259
- return new AnchoredRect15(this.x, this.x, this.x, this.y - this.topBeamsHeight, this.y, this.y + this.bottomBeamsHeight);
4700
+ return new AnchoredRect(this.x, this.x, this.x, this.y - this.topBeamsHeight, this.y, this.y + this.bottomBeamsHeight);
4260
4701
  }
4261
4702
  };
4262
4703
  var ObjStaffBeamGroup = class extends MusicObject {
@@ -4313,9 +4754,9 @@ var ObjBeamGroup = class _ObjBeamGroup extends MusicObject {
4313
4754
  this.mi = new MBeamGroup(this);
4314
4755
  let beamGroupName = tupletRatio ? "Tuplet" : "BeamGroup";
4315
4756
  if (!symbols.every((s) => s.measure === symbols[0].measure)) {
4316
- throw new MusicError10(MusicErrorType10.Score, `All ${beamGroupName} symbols are not in same measure.`);
4757
+ throw new MusicError8(MusicErrorType8.Score, `All ${beamGroupName} symbols are not in same measure.`);
4317
4758
  } else if (symbols.length < 2) {
4318
- throw new MusicError10(MusicErrorType10.Score, `${beamGroupName} needs minimum 2 symbols, but ${symbols.length} given.`);
4759
+ throw new MusicError8(MusicErrorType8.Score, `${beamGroupName} needs minimum 2 symbols, but ${symbols.length} given.`);
4319
4760
  }
4320
4761
  if (tupletRatio !== void 0) {
4321
4762
  let isGroup = symbols.length < 3 || symbols.some((s) => !(s instanceof ObjNoteGroup)) || symbols.some((s) => s.rhythmProps.flagCount !== symbols[0].rhythmProps.flagCount);
@@ -4335,7 +4776,7 @@ var ObjBeamGroup = class _ObjBeamGroup extends MusicObject {
4335
4776
  symbols.forEach((s) => s.setBeamGroup(this));
4336
4777
  symbols[0].measure.addBeamGroup(this);
4337
4778
  } else {
4338
- throw new MusicError10(MusicErrorType10.Score, `Cannot add ${beamGroupName} because some symbol already has one.`);
4779
+ throw new MusicError8(MusicErrorType8.Score, `Cannot add ${beamGroupName} because some symbol already has one.`);
4339
4780
  }
4340
4781
  if (this.type === 0 /* RegularBeam */) {
4341
4782
  this.symbols.filter((sym) => sym instanceof ObjNoteGroup).some((sym, i) => {
@@ -4350,7 +4791,7 @@ var ObjBeamGroup = class _ObjBeamGroup extends MusicObject {
4350
4791
  if (this.type === 0 /* RegularBeam */) {
4351
4792
  throw new InvalidBeamGroup(this, "Beam symbols have different voiceId.");
4352
4793
  } else {
4353
- throw new MusicError10(MusicErrorType10.Score, `Tuplet symbols have different voiceId.`);
4794
+ throw new MusicError8(MusicErrorType8.Score, `Tuplet symbols have different voiceId.`);
4354
4795
  }
4355
4796
  }
4356
4797
  symbols[0].row.getStaves().forEach((staff) => {
@@ -4534,7 +4975,7 @@ var ObjBeamGroup = class _ObjBeamGroup extends MusicObject {
4534
4975
  symbolY.forEach((symY, i) => {
4535
4976
  let symX = symbolX[i];
4536
4977
  if (symX !== void 0 && symY !== void 0) {
4537
- let beamY = Utils6.Math.interpolateY(leftX, leftY, rightX, rightY, symX);
4978
+ let beamY = utils_exports.Math.interpolateY(leftX, leftY, rightX, rightY, symX);
4538
4979
  let raiseY = symY - beamY;
4539
4980
  if (stemDir === "up" /* Up */ && raiseY < 0) {
4540
4981
  raiseBeamY = Math.min(raiseBeamY, raiseY);
@@ -4549,8 +4990,8 @@ var ObjBeamGroup = class _ObjBeamGroup extends MusicObject {
4549
4990
  let obj = new ObjStaffBeamGroup(mainStaff, this);
4550
4991
  if (type === 2 /* TupletGroup */) {
4551
4992
  let ef = unitSize / (rightX - leftX);
4552
- let l = Utils6.Math.interpolateCoord(leftX, leftY + groupLineDy, rightX, rightY + groupLineDy, -ef);
4553
- let r = Utils6.Math.interpolateCoord(leftX, leftY + groupLineDy, rightX, rightY + groupLineDy, 1 + ef);
4993
+ let l = utils_exports.Math.interpolateCoord(leftX, leftY + groupLineDy, rightX, rightY + groupLineDy, -ef);
4994
+ let r = utils_exports.Math.interpolateCoord(leftX, leftY + groupLineDy, rightX, rightY + groupLineDy, 1 + ef);
4554
4995
  obj.points.push(new BeamPoint(leftStaff, this, leftSymbol, l.x, l.y));
4555
4996
  obj.points.push(new BeamPoint(rightStaff, this, rightSymbol, r.x, r.y));
4556
4997
  obj.tupletNumberOffsetY = 0;
@@ -4599,7 +5040,7 @@ var ObjBeamGroup = class _ObjBeamGroup extends MusicObject {
4599
5040
  }
4600
5041
  updateRect() {
4601
5042
  if (this.staffObjects.length === 0) {
4602
- this.rect = new AnchoredRect15();
5043
+ this.rect = new AnchoredRect();
4603
5044
  } else {
4604
5045
  this.staffObjects.forEach((obj) => obj.updateRect());
4605
5046
  this.rect = this.staffObjects[0].getRect().clone();
@@ -4616,7 +5057,7 @@ var ObjBeamGroup = class _ObjBeamGroup extends MusicObject {
4616
5057
  obj.points.forEach((pt) => {
4617
5058
  if (pt.symbol instanceof ObjNoteGroup) {
4618
5059
  if (pt !== left && pt !== right) {
4619
- pt.y = Utils6.Math.interpolateY(left.x, left.y, right.x, right.y, pt.x);
5060
+ pt.y = utils_exports.Math.interpolateY(left.x, left.y, right.x, right.y, pt.x);
4620
5061
  }
4621
5062
  pt.symbol.setStemTipY(pt.staff, pt.y);
4622
5063
  }
@@ -4642,8 +5083,8 @@ var ObjBeamGroup = class _ObjBeamGroup extends MusicObject {
4642
5083
  let { x: rx, y: ry } = obj.points[obj.points.length - 1];
4643
5084
  if (obj.tupletNumber) {
4644
5085
  let tf = obj.tupletNumber.getRect().width / (rx - lx) * 1.2;
4645
- let lc = Utils6.Math.interpolateCoord(lx, ly, rx, ry, 0.5 - tf / 2);
4646
- let rc = Utils6.Math.interpolateCoord(lx, ly, rx, ry, 0.5 + tf / 2);
5086
+ let lc = utils_exports.Math.interpolateCoord(lx, ly, rx, ry, 0.5 - tf / 2);
5087
+ let rc = utils_exports.Math.interpolateCoord(lx, ly, rx, ry, 0.5 + tf / 2);
4647
5088
  ctx.strokeLine(lx, ly, lc.x, lc.y);
4648
5089
  ctx.strokeLine(rc.x, rc.y, rx, ry);
4649
5090
  } else {
@@ -4757,12 +5198,11 @@ var ObjBeamGroup = class _ObjBeamGroup extends MusicObject {
4757
5198
  };
4758
5199
 
4759
5200
  // src/score/engine/obj-fermata.ts
4760
- import { AnchoredRect as AnchoredRect16 } from "@tspro/ts-utils-lib";
4761
5201
  var ObjFermata = class extends MusicObject {
4762
- constructor(parent, pos) {
5202
+ constructor(parent, pos, color) {
4763
5203
  super(parent);
4764
5204
  this.pos = pos;
4765
- __publicField(this, "color", "black");
5205
+ this.color = color;
4766
5206
  __publicField(this, "mi");
4767
5207
  this.mi = new MFermata(this);
4768
5208
  }
@@ -4785,7 +5225,7 @@ var ObjFermata = class extends MusicObject {
4785
5225
  let { unitSize } = ctx;
4786
5226
  let width = unitSize * 4;
4787
5227
  let height = unitSize * 3;
4788
- this.rect = new AnchoredRect16(-width / 2, width / 2, -height, 0);
5228
+ this.rect = new AnchoredRect(-width / 2, width / 2, -height, 0);
4789
5229
  }
4790
5230
  offset(dx, dy) {
4791
5231
  this.rect.offsetInPlace(dx, dy);
@@ -4800,7 +5240,7 @@ var ObjFermata = class extends MusicObject {
4800
5240
  let bottom = (upsideDown ? this.rect.top : this.rect.bottom) + dy;
4801
5241
  let height = bottom - top;
4802
5242
  ctx.drawDebugRect(this.rect);
4803
- ctx.color("black").lineWidth(1);
5243
+ ctx.color(this.color).lineWidth(1);
4804
5244
  ctx.beginPath();
4805
5245
  ctx.moveTo(left, bottom);
4806
5246
  ctx.bezierCurveTo(left, top, right, top, right, bottom);
@@ -4813,15 +5253,19 @@ var ObjFermata = class extends MusicObject {
4813
5253
  };
4814
5254
 
4815
5255
  // src/score/engine/obj-extension-line.ts
4816
- import { AnchoredRect as AnchoredRect17 } from "@tspro/ts-utils-lib";
5256
+ function isExtensionStartObject(obj) {
5257
+ return obj instanceof ObjText || obj instanceof ObjSpecialText;
5258
+ }
5259
+ function isExtensionStopObject(obj) {
5260
+ return obj instanceof ObjBarLineRight || obj instanceof ObjText || obj instanceof ObjSpecialText;
5261
+ }
4817
5262
  var ObjExtensionLine = class extends MusicObject {
4818
- constructor(measure, line, extension, leftObj, rightObj) {
5263
+ constructor(measure, line, extension, cols) {
4819
5264
  super(measure);
4820
5265
  this.measure = measure;
4821
5266
  this.line = line;
4822
5267
  this.extension = extension;
4823
- this.leftObj = leftObj;
4824
- this.rightObj = rightObj;
5268
+ this.cols = cols;
4825
5269
  __publicField(this, "mi");
4826
5270
  extension.addTail(this);
4827
5271
  this.mi = new MExtensionLine(this);
@@ -4832,52 +5276,61 @@ var ObjExtensionLine = class extends MusicObject {
4832
5276
  getMusicInterface() {
4833
5277
  return this.mi;
4834
5278
  }
4835
- getLineLeft() {
4836
- if (this.leftObj instanceof ObjBarLineLeft) {
4837
- return this.leftObj.getRect().anchorX;
4838
- } else {
4839
- return this.leftObj.getRect().right;
4840
- }
4841
- }
4842
- getLineRight() {
4843
- if (this.rightObj instanceof ObjRhythmColumn) {
4844
- let col = this.rightObj;
4845
- let nextCol = col.getNextColumn();
4846
- if (nextCol && nextCol.measure === col.measure) {
4847
- return (col.getRect().right + nextCol.getRect().left) / 2;
4848
- } else {
4849
- return (col.getRect().right + col.measure.getBarLineRight().getRect().left) / 2;
4850
- }
4851
- } else {
4852
- return this.rightObj.getRect().anchorX;
4853
- }
5279
+ getLineLeft(ctx) {
5280
+ let obj = this.cols[0];
5281
+ if (isExtensionStartObject(obj))
5282
+ return obj.getRect().right + ctx.unitSize;
5283
+ if (obj instanceof ObjBarLineLeft)
5284
+ return obj.getRect().anchorX;
5285
+ if (obj instanceof ObjRhythmColumn) {
5286
+ const mcols = obj.measure.getColumns();
5287
+ if (obj === mcols[0])
5288
+ return obj.measure.getRect().left;
5289
+ }
5290
+ return obj.getRect().right;
5291
+ }
5292
+ getLineRight(ctx) {
5293
+ let obj = this.cols[this.cols.length - 1];
5294
+ if (isExtensionStopObject(obj))
5295
+ return obj.getRect().left - ctx.unitSize;
5296
+ if (obj instanceof ObjRhythmColumn) {
5297
+ const mcols = obj.measure.getColumns();
5298
+ if (obj === mcols[mcols.length - 1])
5299
+ return obj.measure.getRect().right;
5300
+ let next = obj.getNextColumn();
5301
+ if (next && next.measure === obj.measure)
5302
+ return (obj.getRect().right + next.getRect().left) / 2;
5303
+ }
5304
+ return obj.getRect().anchorX;
4854
5305
  }
4855
5306
  layoutFitToMeasure(ctx) {
4856
- let { unitSize } = ctx;
4857
- let lineLeft = this.getLineLeft();
4858
- let lineRight = this.getLineRight();
4859
- let lineRectH = unitSize;
4860
- this.rect = new AnchoredRect17(lineLeft, lineRight, -lineRectH / 2, lineRectH / 2);
5307
+ let recth = ctx.unitSize;
5308
+ let lineLeft = this.getLineLeft(ctx);
5309
+ let lineRight = this.getLineRight(ctx);
5310
+ [lineLeft, lineRight] = [Math.min(lineLeft, lineRight), Math.max(lineLeft, lineRight)];
5311
+ this.rect = new AnchoredRect(lineLeft, lineRight, -recth / 2, recth / 2);
4861
5312
  }
4862
5313
  pick(x, y) {
4863
5314
  return this.rect.contains(x, y) ? [this] : [];
4864
5315
  }
4865
5316
  layout(ctx) {
4866
- this.rect = new AnchoredRect17();
5317
+ this.rect = new AnchoredRect();
4867
5318
  }
4868
5319
  offset(dx, dy) {
4869
5320
  this.rect.offsetInPlace(dx, dy);
4870
5321
  }
4871
5322
  draw(ctx) {
4872
5323
  let { rect } = this;
4873
- if (this.extension.getLineStyle() === "dashed") {
5324
+ const head = this.extension.headObj.musicObj;
5325
+ const color = String(head.userData["extension-color"]);
5326
+ if (this.extension.getLineStyle() === "dashed")
4874
5327
  ctx.setLineDash([7, 3]);
4875
- }
4876
- ctx.color("black").lineWidth(1);
5328
+ ctx.color(color).lineWidth(1);
4877
5329
  ctx.strokeLine(rect.left, rect.anchorY, rect.right, rect.anchorY);
4878
5330
  ctx.setLineDash([]);
4879
5331
  let tails = this.extension.getTails();
4880
- if (tails.length > 0 && this === tails[tails.length - 1]) {
5332
+ let last = tails[tails.length - 1];
5333
+ if (this === last && !isExtensionStopObject(this.cols[this.cols.length - 1])) {
4881
5334
  let tipH = rect.anchorY > this.line.getRect().anchorY ? -ctx.unitSize : ctx.unitSize;
4882
5335
  ctx.strokeLine(rect.right, rect.anchorY, rect.right, rect.anchorY + tipH);
4883
5336
  }
@@ -4885,14 +5338,13 @@ var ObjExtensionLine = class extends MusicObject {
4885
5338
  };
4886
5339
 
4887
5340
  // src/score/engine/obj-measure.ts
4888
- import { MusicError as MusicError13, MusicErrorType as MusicErrorType13 } from "@tspro/web-music-score/core";
5341
+ import { MusicError as MusicError11, MusicErrorType as MusicErrorType11 } from "@tspro/web-music-score/core";
4889
5342
 
4890
5343
  // src/score/engine/connective-props.ts
4891
5344
  import { Note as Note6 } from "@tspro/web-music-score/theory";
4892
5345
 
4893
5346
  // src/score/engine/obj-connective.ts
4894
- import { AnchoredRect as AnchoredRect18, Guard as Guard5, Utils as Utils7 } from "@tspro/ts-utils-lib";
4895
- import { MusicError as MusicError11, MusicErrorType as MusicErrorType11 } from "@tspro/web-music-score/core";
5347
+ import { MusicError as MusicError9, MusicErrorType as MusicErrorType9 } from "@tspro/web-music-score/core";
4896
5348
  var ObjConnective = class extends MusicObject {
4897
5349
  constructor(connectiveProps, line, measure, leftNoteGroup, leftNoteId, ...args) {
4898
5350
  var _a;
@@ -4922,7 +5374,7 @@ var ObjConnective = class extends MusicObject {
4922
5374
  this.rightNoteGroup = args[0];
4923
5375
  this.rightNoteId = args[1];
4924
5376
  this.tieType = void 0;
4925
- } else if (Guard5.isEnumValue(args[0], TieType)) {
5377
+ } else if (guard_exports.isEnumValue(args[0], TieType)) {
4926
5378
  this.rightNoteGroup = void 0;
4927
5379
  this.rightNoteId = void 0;
4928
5380
  this.tieType = args[0];
@@ -4933,6 +5385,9 @@ var ObjConnective = class extends MusicObject {
4933
5385
  getMusicInterface() {
4934
5386
  return this.mi;
4935
5387
  }
5388
+ get doc() {
5389
+ return this.measure.doc;
5390
+ }
4936
5391
  isInsideMeasure() {
4937
5392
  return this.rightNoteGroup === void 0 || this.leftNoteGroup.measure === this.rightNoteGroup.measure;
4938
5393
  }
@@ -4983,7 +5438,7 @@ var ObjConnective = class extends MusicObject {
4983
5438
  rx = contentRect.right;
4984
5439
  ry = leftPos.y + (rightPos.y - leftPos.y) * tLeft / (tLeft + tRight);
4985
5440
  } else {
4986
- throw new MusicError11(MusicErrorType11.Score, "Cannot layout connective object because no valid left and right note groups.");
5441
+ throw new MusicError9(MusicErrorType9.Score, "Cannot layout connective object because no valid left and right note groups.");
4987
5442
  }
4988
5443
  let spanDy = arcDir === "up" ? -1 : 1;
4989
5444
  let arcHeight = spanDy * unitSize * Math.log2(rx - lx) / 3;
@@ -4992,12 +5447,12 @@ var ObjConnective = class extends MusicObject {
4992
5447
  this.rx = rx;
4993
5448
  this.ry = ry;
4994
5449
  this.arcHeight = this.connectiveProps.connective === "slide" /* Slide */ ? 0 : arcHeight;
4995
- let { nx, ny } = Utils7.Math.calcNormal(lx, ly, rx, ry);
5450
+ let { nx, ny } = utils_exports.Math.calcNormal(lx, ly, rx, ry);
4996
5451
  this.cp1x = lx * 0.7 + rx * 0.3 + nx * this.arcHeight;
4997
5452
  this.cp1y = ly * 0.7 + ry * 0.3 + ny * this.arcHeight;
4998
5453
  this.cp2x = lx * 0.3 + rx * 0.7 + nx * this.arcHeight;
4999
5454
  this.cp2y = ly * 0.3 + ry * 0.7 + ny * this.arcHeight;
5000
- this.rect = new AnchoredRect18(
5455
+ this.rect = new AnchoredRect(
5001
5456
  Math.min(this.lx, this.cp1x, this.cp2x, this.rx),
5002
5457
  Math.max(this.lx, this.cp1x, this.cp2x, this.rx),
5003
5458
  Math.min(this.ly, this.cp1y, this.cp2y, this.ry),
@@ -5029,7 +5484,10 @@ var ObjConnective = class extends MusicObject {
5029
5484
  ctx.drawDebugRect(rect);
5030
5485
  let t = _lineWidth * 1.5;
5031
5486
  let s = _lineWidth * 0.25;
5032
- ctx.color("black").lineWidth(1);
5487
+ ctx.lineWidth(1);
5488
+ ctx.color(
5489
+ this.line instanceof ObjTab ? DocumentColor.Tab_Connective : DocumentColor.Staff_Connective
5490
+ );
5033
5491
  if (this.arcHeight === 0) {
5034
5492
  ctx.beginPath();
5035
5493
  ctx.moveTo(this.lx, this.ly);
@@ -5047,8 +5505,7 @@ var ObjConnective = class extends MusicObject {
5047
5505
  };
5048
5506
 
5049
5507
  // src/score/engine/connective-props.ts
5050
- import { MusicError as MusicError12, MusicErrorType as MusicErrorType12 } from "@tspro/web-music-score/core";
5051
- import { Guard as Guard6 } from "@tspro/ts-utils-lib";
5508
+ import { MusicError as MusicError10, MusicErrorType as MusicErrorType10 } from "@tspro/web-music-score/core";
5052
5509
  var ConnectiveProps = class {
5053
5510
  constructor(connective, span, noteAnchor, startNoteGroup) {
5054
5511
  this.connective = connective;
@@ -5121,7 +5578,7 @@ var ConnectiveProps = class {
5121
5578
  this.noteGroups[0].row.getNotationLines().forEach((line) => {
5122
5579
  this.computeParams(line);
5123
5580
  if (connective === "tie" /* Tie */) {
5124
- if (Guard6.isEnumValue(span, TieType)) {
5581
+ if (guard_exports.isEnumValue(span, TieType)) {
5125
5582
  let leftNoteGroup = this.noteGroups[0];
5126
5583
  for (let noteId = 0; noteId < leftNoteGroup.notes.length; noteId++) {
5127
5584
  this.createObjConnectiveWithTieType(line, leftNoteGroup, noteId, span);
@@ -5187,13 +5644,12 @@ var ConnectiveProps = class {
5187
5644
  addConnective(leftNoteGroup.measure, leftNoteGroup, leftNoteId, rightNoteGroup, rightNoteId);
5188
5645
  addConnective(rightNoteGroup.measure, leftNoteGroup, leftNoteId, rightNoteGroup, rightNoteId);
5189
5646
  } else {
5190
- throw new MusicError12(MusicErrorType12.Score, "Cannot create connective because it is jumping measures.");
5647
+ throw new MusicError10(MusicErrorType10.Score, "Cannot create connective because it is jumping measures.");
5191
5648
  }
5192
5649
  }
5193
5650
  };
5194
5651
 
5195
5652
  // src/score/engine/obj-lyrics.ts
5196
- import { Guard as Guard7 } from "@tspro/ts-utils-lib";
5197
5653
  var ObjLyrics = class extends MusicObject {
5198
5654
  constructor(col, verse, line, vpos, lyricsLength, lyricsText, lyricsOptions) {
5199
5655
  super(col);
@@ -5209,7 +5665,7 @@ var ObjLyrics = class extends MusicObject {
5209
5665
  __publicField(this, "mi");
5210
5666
  this.rhythmProps = RhythmProps.get(lyricsLength);
5211
5667
  let halign = (lyricsOptions == null ? void 0 : lyricsOptions.align) === "left" /* Left */ ? 0 : (lyricsOptions == null ? void 0 : lyricsOptions.align) === "right" /* Right */ ? 1 : 0.5;
5212
- this.hyphen = Guard7.isEnumValue(lyricsOptions == null ? void 0 : lyricsOptions.hyphen, LyricsHyphen) ? lyricsOptions == null ? void 0 : lyricsOptions.hyphen : void 0;
5668
+ this.hyphen = guard_exports.isEnumValue(lyricsOptions == null ? void 0 : lyricsOptions.hyphen, LyricsHyphen) ? lyricsOptions == null ? void 0 : lyricsOptions.hyphen : void 0;
5213
5669
  this.text = new ObjText(this, { text: lyricsText, color: this.color, scale: 0.8 }, halign, 0);
5214
5670
  this.rect = this.text.getRect().clone();
5215
5671
  this.mi = new MLyrics(this);
@@ -5259,7 +5715,6 @@ var ObjLyrics = class extends MusicObject {
5259
5715
  };
5260
5716
 
5261
5717
  // src/score/engine/obj-tab-rhythm.ts
5262
- import { AnchoredRect as AnchoredRect19, UniMap as UniMap5, Utils as Utils8 } from "@tspro/ts-utils-lib";
5263
5718
  var ObjTabRhythm = class extends MusicObject {
5264
5719
  constructor(measure, tab) {
5265
5720
  super(measure);
@@ -5268,22 +5723,25 @@ var ObjTabRhythm = class extends MusicObject {
5268
5723
  __publicField(this, "voiceId");
5269
5724
  __publicField(this, "mi");
5270
5725
  // Keep non-static
5271
- __publicField(this, "tupletPartsTextObjMap", new UniMap5());
5726
+ __publicField(this, "tupletPartsTextObjMap", new UniMap());
5272
5727
  this.voiceId = getVoiceIds().filter((voiceId) => tab.containsVoiceId(voiceId));
5273
- this.rect = new AnchoredRect19();
5728
+ this.rect = new AnchoredRect();
5274
5729
  this.mi = new MTabRhythm(this);
5275
5730
  }
5276
5731
  getMusicInterface() {
5277
5732
  return this.mi;
5278
5733
  }
5734
+ get doc() {
5735
+ return this.measure.doc;
5736
+ }
5279
5737
  pick(x, y) {
5280
5738
  return this.rect.contains(x, y) ? [this] : [];
5281
5739
  }
5282
5740
  layout(ctx) {
5283
5741
  let columns = this.measure.getColumns();
5284
- let numColsInVoiceId = getVoiceIds().map((voiceId) => Utils8.Math.sum(columns.map((col) => col.getVoiceSymbol(voiceId) ? 1 : 0)));
5285
- this.voiceId.sort((a, b) => Utils8.Math.cmp(numColsInVoiceId[a], numColsInVoiceId[b]));
5286
- this.rect = new AnchoredRect19();
5742
+ let numColsInVoiceId = getVoiceIds().map((voiceId) => utils_exports.Math.sum(columns.map((col) => col.getVoiceSymbol(voiceId) ? 1 : 0)));
5743
+ this.voiceId.sort((a, b) => utils_exports.Math.cmp(numColsInVoiceId[a], numColsInVoiceId[b]));
5744
+ this.rect = new AnchoredRect();
5287
5745
  }
5288
5746
  hasTuplets() {
5289
5747
  return this.measure.getBeamGroups().some((beamGroup) => beamGroup.isTuplet());
@@ -5305,7 +5763,7 @@ var ObjTabRhythm = class extends MusicObject {
5305
5763
  }
5306
5764
  draw(ctx) {
5307
5765
  ctx.drawDebugRect(this.rect);
5308
- ctx.color("black").lineWidth(1);
5766
+ ctx.lineWidth(1);
5309
5767
  let { unitSize, fontSize } = ctx;
5310
5768
  let flagSize = unitSize;
5311
5769
  let dotSpace = unitSize;
@@ -5327,20 +5785,23 @@ var ObjTabRhythm = class extends MusicObject {
5327
5785
  let nextSym = symbols[j + 1];
5328
5786
  let colX = sym.col.getRect().anchorX;
5329
5787
  if (sym instanceof ObjNoteGroup) {
5788
+ ctx.lineWidth(1);
5789
+ ctx.color(DocumentColor.Tab_Note);
5330
5790
  if (sym.rhythmProps.noteSize >= 2) {
5331
5791
  ctx.lineWidth(sym.rhythmProps.noteSize === 4 ? 2 : 1);
5332
5792
  ctx.strokeLine(colX, stemBottom, colX, stemTop);
5333
5793
  }
5334
- ctx.lineWidth(1);
5335
5794
  if (symbols.length === 1) {
5336
5795
  for (let i = 0; i < sym.rhythmProps.flagCount; i++) {
5337
- ctx.drawFlag(new AnchoredRect19(colX, colX + flagSize, stemTop + i * flagSize, stemTop + (i + 2) * flagSize), "up");
5796
+ ctx.drawFlag(new AnchoredRect(colX, colX + flagSize, stemTop + i * flagSize, stemTop + (i + 2) * flagSize), "up");
5338
5797
  }
5339
5798
  }
5340
5799
  for (let i = 0; i < sym.rhythmProps.dotCount; i++) {
5341
5800
  ctx.fillCircle(colX + dotSpace * (i + 1), stemBottom - dotWidth, dotWidth);
5342
5801
  }
5343
5802
  } else if (sym instanceof ObjRest) {
5803
+ ctx.lineWidth(1);
5804
+ ctx.color(DocumentColor.Tab_Rest);
5344
5805
  let cx = colX;
5345
5806
  let cy = (stemTop + stemBottom) / 2;
5346
5807
  let scale = 0.65;
@@ -5361,6 +5822,7 @@ var ObjTabRhythm = class extends MusicObject {
5361
5822
  let leftBeamCount = left.hasTuplet() ? 1 : left instanceof ObjNoteGroup ? left.getRightBeamCount() : 1;
5362
5823
  let rightBeamCount = right.hasTuplet() ? 1 : right instanceof ObjNoteGroup ? right.getLeftBeamCount() : 1;
5363
5824
  let maxBeamCount = Math.max(leftBeamCount, rightBeamCount);
5825
+ ctx.color(DocumentColor.Tab_Note);
5364
5826
  ctx.lineWidth(2);
5365
5827
  for (let i = 0; i < maxBeamCount; i++) {
5366
5828
  let leftT = rightBeamCount > leftBeamCount && i >= leftBeamCount ? 0.75 : 0;
@@ -5376,6 +5838,7 @@ var ObjTabRhythm = class extends MusicObject {
5376
5838
  }
5377
5839
  }
5378
5840
  if (beamGroup && beamGroup.isTuplet()) {
5841
+ ctx.color(DocumentColor.Tab_Note);
5379
5842
  let cx = (symbols[0].col.getRect().anchorX + symbols[symbols.length - 1].col.getRect().anchorX) / 2;
5380
5843
  let text = beamGroup.getTupletRatioText();
5381
5844
  let textObj = this.tupletPartsTextObjMap.get(text);
@@ -5398,11 +5861,19 @@ var ObjTabRhythm = class extends MusicObject {
5398
5861
  };
5399
5862
 
5400
5863
  // src/score/engine/obj-measure.ts
5864
+ function getExtensionAnchorY(linePos) {
5865
+ switch (linePos) {
5866
+ case "bottom":
5867
+ return 0.8;
5868
+ case "middle":
5869
+ return 0.5;
5870
+ }
5871
+ }
5401
5872
  function getExtensionTicks(extensionLength) {
5402
5873
  if (typeof extensionLength === "string") {
5403
5874
  extensionLength = [extensionLength];
5404
5875
  }
5405
- if (Guard8.isArray(extensionLength)) {
5876
+ if (guard_exports.isArray(extensionLength)) {
5406
5877
  let totalTicks = 0;
5407
5878
  for (let i = 0; i < extensionLength.length; ) {
5408
5879
  let str = extensionLength[i];
@@ -5433,7 +5904,7 @@ function getVerseLayoutGroupId(verse) {
5433
5904
  case 3:
5434
5905
  return 10 /* LyricsVerse3 */;
5435
5906
  default:
5436
- throw new MusicError13(MusicErrorType13.Unknown, "VerseNumber is not 1, 2 or 3.");
5907
+ throw new MusicError11(MusicErrorType11.Unknown, "VerseNumber is not 1, 2 or 3.");
5437
5908
  }
5438
5909
  }
5439
5910
  var MeasureRegions = class {
@@ -5479,10 +5950,10 @@ var ObjMeasure = class extends MusicObject {
5479
5950
  __publicField(this, "measureId");
5480
5951
  __publicField(this, "regions", new MeasureRegions());
5481
5952
  __publicField(this, "needLayout", true);
5482
- __publicField(this, "voiceSymbols", asMulti(new IndexArray2()));
5953
+ __publicField(this, "voiceSymbols", asMulti(new IndexArray()));
5483
5954
  __publicField(this, "lastAddedRhythmColumn");
5484
5955
  __publicField(this, "lastAddedRhythmSymbol");
5485
- __publicField(this, "addExtensionToMusicObjects", []);
5956
+ __publicField(this, "addExtensionTo", []);
5486
5957
  __publicField(this, "layoutObjects", []);
5487
5958
  __publicField(this, "postMeasureBreakWidth", 0);
5488
5959
  __publicField(this, "passCount", 0);
@@ -5494,8 +5965,8 @@ var ObjMeasure = class extends MusicObject {
5494
5965
  __publicField(this, "endRepeatPlayCount", 2);
5495
5966
  // play twice.
5496
5967
  __publicField(this, "endRepeatPlayCountText");
5497
- __publicField(this, "staticObjectsCache", new UniMap6());
5498
- __publicField(this, "lyricsObjectsCache", new TriMap2());
5968
+ __publicField(this, "staticObjectsCache", new UniMap());
5969
+ __publicField(this, "lyricsObjectsCache", new TriMap());
5499
5970
  __publicField(this, "mi");
5500
5971
  this.mi = new MMeasure(this);
5501
5972
  this.prevMeasure = row.doc.getLastMeasure();
@@ -5536,7 +6007,7 @@ var ObjMeasure = class extends MusicObject {
5536
6007
  updateRunningArguments(runningArgs) {
5537
6008
  var _a;
5538
6009
  runningArgs != null ? runningArgs : runningArgs = [];
5539
- let numVoices = Utils9.Math.sum(getVoiceIds().map((voiceId) => this.getVoiceSymbols(voiceId).length > 0 ? 1 : 0));
6010
+ let numVoices = utils_exports.Math.sum(getVoiceIds().map((voiceId) => this.getVoiceSymbols(voiceId).length > 0 ? 1 : 0));
5540
6011
  getVoiceIds().forEach((voiceId) => {
5541
6012
  var _a2;
5542
6013
  const getDefaultDiatonicId = () => {
@@ -5674,6 +6145,12 @@ var ObjMeasure = class extends MusicObject {
5674
6145
  isLastMeasure() {
5675
6146
  return this.nextMeasure === void 0;
5676
6147
  }
6148
+ isFirstMeasureInRow() {
6149
+ return this === this.row.getFirstMeasure();
6150
+ }
6151
+ isLastMeasureInRow() {
6152
+ return this === this.row.getLastMeasure();
6153
+ }
5677
6154
  getNextMeasure() {
5678
6155
  return this.nextMeasure;
5679
6156
  }
@@ -5695,7 +6172,7 @@ var ObjMeasure = class extends MusicObject {
5695
6172
  this.alterKeySignature = args[0];
5696
6173
  } else if (args[0] instanceof Scale) {
5697
6174
  this.alterKeySignature = args[0];
5698
- } else if (Guard8.isNonEmptyString(args[0])) {
6175
+ } else if (guard_exports.isNonEmptyString(args[0])) {
5699
6176
  if (args.length === 1) {
5700
6177
  this.alterKeySignature = getScale(args[0]);
5701
6178
  } else if (args.length === 2) {
@@ -5704,7 +6181,7 @@ var ObjMeasure = class extends MusicObject {
5704
6181
  let scaleType = validateScaleType("" + args[1]);
5705
6182
  this.alterKeySignature = getScale(tonic, scaleType);
5706
6183
  } catch (e) {
5707
- throw new MusicError13(MusicErrorType13.Score, "Cannot set key signature because invalid args: " + args);
6184
+ throw new MusicError11(MusicErrorType11.Score, "Cannot set key signature because invalid args: " + args);
5708
6185
  }
5709
6186
  }
5710
6187
  }
@@ -5788,9 +6265,11 @@ var ObjMeasure = class extends MusicObject {
5788
6265
  return this.postMeasureBreakWidth;
5789
6266
  }
5790
6267
  addLayoutObject(musicObj, line, layoutGroupId, verticalPos) {
5791
- this.layoutObjects.push(new LayoutObjectWrapper(musicObj, line, layoutGroupId, verticalPos));
6268
+ const layoutObj = new LayoutObjectWrapper(musicObj, line, layoutGroupId, verticalPos);
6269
+ this.layoutObjects.push(layoutObj);
5792
6270
  this.requestLayout();
5793
6271
  this.requestRectUpdate();
6272
+ return layoutObj;
5794
6273
  }
5795
6274
  forEachStaffGroup(staffTabOrGroups, defaultVerticalPos, addFn) {
5796
6275
  const lines = this.row.getNotationLines();
@@ -5806,7 +6285,7 @@ var ObjMeasure = class extends MusicObject {
5806
6285
  let grp = this.doc.getStaffGroup(staffTabOrGroup);
5807
6286
  if (grp && !prevGroups.includes(staffTabOrGroup)) {
5808
6287
  let curGroups = [...prevGroups, staffTabOrGroup];
5809
- (Guard8.isArray(grp.staffsTabsAndGroups) ? grp.staffsTabsAndGroups : [grp.staffsTabsAndGroups]).forEach((staffTabOrGroup2) => {
6288
+ (guard_exports.isArray(grp.staffsTabsAndGroups) ? grp.staffsTabsAndGroups : [grp.staffsTabsAndGroups]).forEach((staffTabOrGroup2) => {
5810
6289
  switch (grp.verticalPosition) {
5811
6290
  case "above" /* Above */:
5812
6291
  addToStaffTabOrGroup(staffTabOrGroup2, 0 /* Above */, curGroups);
@@ -5833,7 +6312,7 @@ var ObjMeasure = class extends MusicObject {
5833
6312
  } else {
5834
6313
  addToStaffTabOrGroup(0, defaultVerticalPos);
5835
6314
  }
5836
- } else if (Guard8.isArray(staffTabOrGroups)) {
6315
+ } else if (guard_exports.isArray(staffTabOrGroups)) {
5837
6316
  staffTabOrGroups.forEach((staffTabOrGroup) => addToStaffTabOrGroup(staffTabOrGroup, defaultVerticalPos));
5838
6317
  } else {
5839
6318
  addToStaffTabOrGroup(staffTabOrGroups, defaultVerticalPos);
@@ -5842,10 +6321,11 @@ var ObjMeasure = class extends MusicObject {
5842
6321
  addFermata(staffTabOrGroups, fermata) {
5843
6322
  let anchor = fermata === "atMeasureEnd" /* AtMeasureEnd */ ? this.barLineRight : this.lastAddedRhythmColumn;
5844
6323
  if (!anchor) {
5845
- throw new MusicError13(MusicErrorType13.Score, "Cannot add Fermata because anchor is undefined.");
6324
+ throw new MusicError11(MusicErrorType11.Score, "Cannot add Fermata because anchor is undefined.");
5846
6325
  }
5847
6326
  this.forEachStaffGroup(staffTabOrGroups, 0 /* Above */, (line, vpos) => {
5848
- this.addLayoutObject(new ObjFermata(anchor, vpos), line, 1 /* Fermata */, vpos);
6327
+ const color = line instanceof ObjTab ? DocumentColor.Staff_Element_Fermata : DocumentColor.Tab_Element_Fermata;
6328
+ this.addLayoutObject(new ObjFermata(anchor, vpos, color), line, 1 /* Fermata */, vpos);
5849
6329
  });
5850
6330
  this.disableExtension();
5851
6331
  this.requestLayout();
@@ -5858,12 +6338,15 @@ var ObjMeasure = class extends MusicObject {
5858
6338
  switch (navigation) {
5859
6339
  case "ending" /* Ending */:
5860
6340
  if (this.navigationSet.has(navigation)) {
5861
- throw new MusicError13(MusicErrorType13.Score, "Cannot add ending beasure measure already has one.");
6341
+ throw new MusicError11(MusicErrorType11.Score, "Cannot add ending beasure measure already has one.");
5862
6342
  }
5863
6343
  let anchor = this;
5864
6344
  let passages = args;
5865
6345
  addLayoutObjectProps = {
5866
- createObj: () => new ObjEnding(anchor, passages),
6346
+ createObj: (line) => {
6347
+ const color = line instanceof ObjTab ? DocumentColor.Staff_Element_Navigation : DocumentColor.Tab_Element_Navigation;
6348
+ return new ObjEnding(anchor, color, passages);
6349
+ },
5867
6350
  layoutGroupId: 4 /* Ending */,
5868
6351
  defaultVerticalPos: 0 /* Above */
5869
6352
  };
@@ -5875,7 +6358,10 @@ var ObjMeasure = class extends MusicObject {
5875
6358
  let anchor2 = this.barLineRight;
5876
6359
  let text = getNavigationString(navigation);
5877
6360
  addLayoutObjectProps = {
5878
- createObj: () => new ObjText(anchor2, text, 1, 1),
6361
+ createObj: (line) => {
6362
+ const color = line instanceof ObjTab ? DocumentColor.Staff_Element_Navigation : DocumentColor.Tab_Element_Navigation;
6363
+ return new ObjText(anchor2, { text, color }, 1, 1);
6364
+ },
5879
6365
  layoutGroupId: 3 /* Navigation */,
5880
6366
  defaultVerticalPos: 0 /* Above */
5881
6367
  };
@@ -5887,7 +6373,10 @@ var ObjMeasure = class extends MusicObject {
5887
6373
  let anchor2 = this.barLineRight;
5888
6374
  let text = getNavigationString(navigation);
5889
6375
  addLayoutObjectProps = {
5890
- createObj: () => new ObjText(anchor2, text, 1, 1),
6376
+ createObj: (line) => {
6377
+ const color = line instanceof ObjTab ? DocumentColor.Staff_Element_Navigation : DocumentColor.Tab_Element_Navigation;
6378
+ return new ObjText(anchor2, { text, color }, 1, 1);
6379
+ },
5891
6380
  layoutGroupId: 3 /* Navigation */,
5892
6381
  defaultVerticalPos: 0 /* Above */
5893
6382
  };
@@ -5898,7 +6387,10 @@ var ObjMeasure = class extends MusicObject {
5898
6387
  let anchor2 = this.barLineLeft;
5899
6388
  let text = getNavigationString(navigation);
5900
6389
  addLayoutObjectProps = {
5901
- createObj: () => new ObjSpecialText(anchor2, text),
6390
+ createObj: (line) => {
6391
+ const color = line instanceof ObjTab ? DocumentColor.Staff_Element_Navigation : DocumentColor.Tab_Element_Navigation;
6392
+ return new ObjSpecialText(anchor2, text, color);
6393
+ },
5902
6394
  layoutGroupId: 3 /* Navigation */,
5903
6395
  defaultVerticalPos: 0 /* Above */
5904
6396
  };
@@ -5908,7 +6400,10 @@ var ObjMeasure = class extends MusicObject {
5908
6400
  let anchor2 = this.barLineRight;
5909
6401
  let text = getNavigationString(navigation);
5910
6402
  addLayoutObjectProps = {
5911
- createObj: () => new ObjSpecialText(anchor2, text),
6403
+ createObj: (line) => {
6404
+ const color = line instanceof ObjTab ? DocumentColor.Staff_Element_Navigation : DocumentColor.Tab_Element_Navigation;
6405
+ return new ObjSpecialText(anchor2, text, color);
6406
+ },
5912
6407
  layoutGroupId: 3 /* Navigation */,
5913
6408
  defaultVerticalPos: 0 /* Above */
5914
6409
  };
@@ -5917,15 +6412,17 @@ var ObjMeasure = class extends MusicObject {
5917
6412
  case "endRepeat" /* EndRepeat */:
5918
6413
  if (args.length === 0) {
5919
6414
  this.endRepeatPlayCount = 2;
5920
- } else if (Guard8.isIntegerGte(args[0], 2)) {
6415
+ } else if (guard_exports.isIntegerGte(args[0], 2)) {
5921
6416
  this.endRepeatPlayCount = args[0];
5922
6417
  } else {
5923
- throw new MusicError13(MusicErrorType13.Score, "Invalid end repeat play count (should be 2 or greater integer): " + args[0]);
6418
+ throw new MusicError11(MusicErrorType11.Score, "Invalid end repeat play count (should be 2 or greater integer): " + args[0]);
5924
6419
  }
5925
6420
  if (this.endRepeatPlayCount !== 2) {
5926
- let textProps = {
5927
- text: "" + this.endRepeatPlayCount + "x",
5928
- scale: 0.8
6421
+ const text = `${this.endRepeatPlayCount}x`;
6422
+ const textProps = {
6423
+ text,
6424
+ scale: 0.8,
6425
+ color: DocumentColor.Staff_Frame
5929
6426
  };
5930
6427
  this.endRepeatPlayCountText = new ObjText(this, textProps, 0.5, 1);
5931
6428
  }
@@ -5933,7 +6430,7 @@ var ObjMeasure = class extends MusicObject {
5933
6430
  }
5934
6431
  if (addLayoutObjectProps) {
5935
6432
  this.forEachStaffGroup(staffTabOrGroups, addLayoutObjectProps.defaultVerticalPos, (line, vpos) => {
5936
- this.addLayoutObject(addLayoutObjectProps.createObj(), line, addLayoutObjectProps.layoutGroupId, vpos);
6433
+ this.addLayoutObject(addLayoutObjectProps.createObj(line), line, addLayoutObjectProps.layoutGroupId, vpos);
5937
6434
  });
5938
6435
  }
5939
6436
  this.navigationSet.add(navigation);
@@ -5945,38 +6442,45 @@ var ObjMeasure = class extends MusicObject {
5945
6442
  addAnnotation(staffTabOrGroups, annotation, text) {
5946
6443
  let anchor = this.lastAddedRhythmColumn;
5947
6444
  if (!anchor) {
5948
- throw new MusicError13(MusicErrorType13.Score, "Cannot add annotation because anchor is undefined.");
6445
+ throw new MusicError11(MusicErrorType11.Score, "Cannot add annotation because anchor is undefined.");
5949
6446
  } else if (text.length === 0) {
5950
- throw new MusicError13(MusicErrorType13.Score, "Cannot add annotation because annotation text is empty.");
6447
+ throw new MusicError11(MusicErrorType11.Score, "Cannot add annotation because annotation text is empty.");
5951
6448
  }
5952
6449
  let textProps = { text };
5953
6450
  let layoutGroupId;
5954
6451
  let defaultVerticalPos;
6452
+ let linePos;
5955
6453
  switch (annotation) {
5956
6454
  case "dynamics" /* Dynamics */:
5957
6455
  layoutGroupId = 6 /* DynamicsAnnotation */;
5958
6456
  defaultVerticalPos = 0 /* Above */;
5959
6457
  textProps.italic = true;
6458
+ linePos = "bottom";
5960
6459
  break;
5961
6460
  case "tempo" /* Tempo */:
5962
6461
  layoutGroupId = 5 /* TempoAnnotation */;
5963
6462
  defaultVerticalPos = 0 /* Above */;
5964
6463
  textProps.italic = true;
6464
+ linePos = "bottom";
5965
6465
  break;
5966
6466
  }
6467
+ const anchorX = 0.5;
6468
+ const anchorY = getExtensionAnchorY(linePos);
5967
6469
  this.disableExtension();
5968
6470
  this.forEachStaffGroup(staffTabOrGroups, defaultVerticalPos, (line, vpos) => {
5969
- let textObj = new ObjText(anchor, textProps, 0.5, 1);
5970
- this.addLayoutObject(textObj, line, layoutGroupId, vpos);
5971
- this.enableExtension(textObj);
6471
+ const color = line instanceof ObjTab ? DocumentColor.Staff_Element_Annotation : DocumentColor.Tab_Element_Annotation;
6472
+ textProps.color = color;
6473
+ let textObj = new ObjText(anchor, textProps, anchorX, anchorY);
6474
+ const layoutObj = this.addLayoutObject(textObj, line, layoutGroupId, vpos);
6475
+ this.enableExtension(layoutObj, color);
5972
6476
  });
5973
6477
  }
5974
6478
  addLabel(staffTabOrGroups, label, text) {
5975
6479
  let anchor = this.lastAddedRhythmColumn;
5976
6480
  if (!anchor) {
5977
- throw new MusicError13(MusicErrorType13.Score, "Cannot add label because anchor is undefined.");
6481
+ throw new MusicError11(MusicErrorType11.Score, "Cannot add label because anchor is undefined.");
5978
6482
  } else if (text.length === 0) {
5979
- throw new MusicError13(MusicErrorType13.Score, "Cannot add label because label text is empty.");
6483
+ throw new MusicError11(MusicErrorType11.Score, "Cannot add label because label text is empty.");
5980
6484
  }
5981
6485
  let textProps = { text };
5982
6486
  let layoutGroupId;
@@ -5993,52 +6497,57 @@ var ObjMeasure = class extends MusicObject {
5993
6497
  }
5994
6498
  this.disableExtension();
5995
6499
  this.forEachStaffGroup(staffTabOrGroups, defaultVerticalPos, (line, vpos) => {
6500
+ const color = line instanceof ObjTab ? DocumentColor.Staff_Element_Label : DocumentColor.Tab_Element_Label;
6501
+ textProps.color = color;
5996
6502
  let textObj = new ObjText(anchor, textProps, 0.5, 1);
5997
- this.addLayoutObject(textObj, line, layoutGroupId, vpos);
5998
- this.enableExtension(textObj);
6503
+ const layoutObj = this.addLayoutObject(textObj, line, layoutGroupId, vpos);
6504
+ this.enableExtension(layoutObj, color);
5999
6505
  });
6000
6506
  }
6001
6507
  addConnective(connective, ...args) {
6002
6508
  let anchor = this.lastAddedRhythmSymbol;
6003
6509
  if (!(anchor instanceof ObjNoteGroup)) {
6004
- throw new MusicError13(MusicErrorType13.Score, "Connective can be added to note group only.");
6510
+ throw new MusicError11(MusicErrorType11.Score, "Connective can be added to note group only.");
6005
6511
  }
6006
6512
  if (connective === "tie" /* Tie */) {
6007
- let tieSpan = Guard8.isInteger(args[0]) || Guard8.isEnumValue(args[0], TieType) ? args[0] : 2;
6008
- let noteAnchor = Guard8.isEnumValue(args[1], NoteAnchor) ? args[1] : "auto" /* Auto */;
6513
+ let tieSpan = guard_exports.isInteger(args[0]) || guard_exports.isEnumValue(args[0], TieType) ? args[0] : 2;
6514
+ let noteAnchor = guard_exports.isEnumValue(args[1], NoteAnchor) ? args[1] : "auto" /* Auto */;
6009
6515
  anchor.startConnective(new ConnectiveProps("tie" /* Tie */, tieSpan, noteAnchor, anchor));
6010
6516
  } else if (connective === "slur" /* Slur */) {
6011
- let slurSpan = Guard8.isInteger(args[0]) ? args[0] : 2;
6012
- let noteAnchor = Guard8.isEnumValue(args[1], NoteAnchor) ? args[1] : "auto" /* Auto */;
6517
+ let slurSpan = guard_exports.isInteger(args[0]) ? args[0] : 2;
6518
+ let noteAnchor = guard_exports.isEnumValue(args[1], NoteAnchor) ? args[1] : "auto" /* Auto */;
6013
6519
  anchor.startConnective(new ConnectiveProps("slur" /* Slur */, slurSpan, noteAnchor, anchor));
6014
6520
  } else if (connective === "slide" /* Slide */) {
6015
- let noteAnchor = Guard8.isEnumValue(args[0], NoteAnchor) ? args[0] : "auto" /* Auto */;
6521
+ let noteAnchor = guard_exports.isEnumValue(args[0], NoteAnchor) ? args[0] : "auto" /* Auto */;
6016
6522
  anchor.startConnective(new ConnectiveProps("slide" /* Slide */, 2, noteAnchor, anchor));
6017
6523
  }
6018
6524
  }
6019
6525
  addExtension(extensionLength, extensionVisible) {
6020
- this.addExtensionToMusicObjects.forEach((musicObj) => {
6021
- let anchor = musicObj.getParent();
6526
+ this.addExtensionTo.forEach((data) => {
6527
+ const { layoutObj, color } = data;
6528
+ const { musicObj } = layoutObj;
6529
+ musicObj.userData["extension-color"] = color;
6530
+ const anchor = musicObj.getParent();
6022
6531
  if (musicObj instanceof ObjText && anchor instanceof ObjRhythmColumn) {
6023
6532
  let lineStyle = "dashed";
6024
6533
  let linePos = "bottom";
6025
- let extension = new Extension(musicObj, anchor, getExtensionTicks(extensionLength), extensionVisible, lineStyle, linePos);
6534
+ let extension = new Extension(layoutObj, anchor, getExtensionTicks(extensionLength), extensionVisible, lineStyle, linePos);
6026
6535
  musicObj.setLink(extension);
6027
6536
  } else {
6028
- throw new MusicError13(MusicErrorType13.Score, "Cannot add extension becaue no compatible music object to attach it to.");
6537
+ throw new MusicError11(MusicErrorType11.Score, "Cannot add extension becaue no compatible music object to attach it to.");
6029
6538
  }
6030
6539
  });
6031
- if (this.addExtensionToMusicObjects.length === 0) {
6032
- throw new MusicError13(MusicErrorType13.Score, "Cannot add extension because music object to attach it to is undefined.");
6540
+ if (this.addExtensionTo.length === 0) {
6541
+ throw new MusicError11(MusicErrorType11.Score, "Cannot add extension because music object to attach it to is undefined.");
6033
6542
  }
6034
6543
  this.disableExtension();
6035
6544
  this.requestLayout();
6036
6545
  }
6037
- enableExtension(musicObject) {
6038
- this.addExtensionToMusicObjects.push(musicObject);
6546
+ enableExtension(layoutObj, color) {
6547
+ this.addExtensionTo.push({ layoutObj, color });
6039
6548
  }
6040
6549
  disableExtension() {
6041
- this.addExtensionToMusicObjects = [];
6550
+ this.addExtensionTo = [];
6042
6551
  }
6043
6552
  getEnding() {
6044
6553
  return this.layoutObjects.map((layoutObj) => layoutObj.musicObj).find((musicObj) => musicObj instanceof ObjEnding);
@@ -6098,7 +6607,7 @@ var ObjMeasure = class extends MusicObject {
6098
6607
  col.addLyricsObject(lyricsObj);
6099
6608
  let lyricsArr = this.lyricsObjectsCache.getOrCreate(line, vpos, verse, []);
6100
6609
  lyricsArr.push(lyricsObj);
6101
- lyricsArr.sort((a, b) => Utils9.Math.cmp(a.col.positionTicks, b.col.positionTicks));
6610
+ lyricsArr.sort((a, b) => utils_exports.Math.cmp(a.col.positionTicks, b.col.positionTicks));
6102
6611
  (_a = lyricsObj.measure.getPrevLyricsObject(lyricsObj)) == null ? void 0 : _a.setNextLyricsObject(lyricsObj);
6103
6612
  this.addLayoutObject(lyricsObj, line, getVerseLayoutGroupId(verse), vpos);
6104
6613
  this.lastAddedRhythmColumn = col;
@@ -6128,7 +6637,7 @@ var ObjMeasure = class extends MusicObject {
6128
6637
  return col2;
6129
6638
  }
6130
6639
  }
6131
- throw new MusicError13(MusicErrorType13.Score, "Error in rhythm column. Should never get here.");
6640
+ throw new MusicError11(MusicErrorType11.Score, "Error in rhythm column. Should never get here.");
6132
6641
  }
6133
6642
  getMeasureTicks() {
6134
6643
  return this.getTimeSignature().measureTicks;
@@ -6147,7 +6656,7 @@ var ObjMeasure = class extends MusicObject {
6147
6656
  }
6148
6657
  // Get content rect excluding signature
6149
6658
  getColumnsContentRect() {
6150
- return new AnchoredRect20(
6659
+ return new AnchoredRect(
6151
6660
  this.barLineLeft.getRect().anchorX,
6152
6661
  this.barLineRight.getRect().anchorX,
6153
6662
  this.getRect().top,
@@ -6230,24 +6739,35 @@ var ObjMeasure = class extends MusicObject {
6230
6739
  }
6231
6740
  createExtensions() {
6232
6741
  this.layoutObjects.forEach((layoutObj) => {
6233
- var _a;
6234
6742
  let { musicObj, measure, layoutGroupId, verticalPos, line } = layoutObj;
6235
6743
  if (musicObj.getLink() instanceof Extension) {
6236
6744
  let extension = musicObj.getLink();
6237
- if (extension.getHead() === musicObj) {
6238
- extension.getTails().forEach((musicObj2) => measure.removeLayoutObjects(musicObj2));
6239
- let { startColumn, endColumn } = extension.getExtensionRangeInfo();
6240
- if (extension.isVisible() && startColumn !== endColumn) {
6241
- for (let m = startColumn.measure; m !== void 0; m = m === endColumn.measure ? void 0 : m.getNextMeasure()) {
6242
- let leftObj = m === startColumn.measure ? extension.getHead() : m.getBarLineLeft();
6243
- let rightObj = m === endColumn.measure ? endColumn : m.getBarLineRight();
6244
- const lines = m.row.getNotationLines();
6245
- let line2 = (_a = lines.find((l) => l.name !== "" && l.name === line.name)) != null ? _a : lines[line.id];
6246
- if (line2) {
6247
- m.addLayoutObject(new ObjExtensionLine(m, line2, extension, leftObj, rightObj), line2, layoutGroupId, verticalPos);
6248
- }
6249
- }
6250
- }
6745
+ if (extension.getHead() !== musicObj)
6746
+ return;
6747
+ extension.getTails().forEach((musicObj2) => measure.removeLayoutObjects(musicObj2));
6748
+ if (!extension.isVisible())
6749
+ return;
6750
+ const range = extension.getRange();
6751
+ const rcols = range.columnRange.slice();
6752
+ for (let isFirst = true; rcols.length > 1; isFirst = false) {
6753
+ const { measure: measure2 } = rcols[0];
6754
+ const i = rcols.findIndex((col) => col.measure !== measure2);
6755
+ const mcols = rcols.splice(0, i > 0 ? i : rcols.length);
6756
+ if (mcols.length < 2) continue;
6757
+ const lineMatch = measure2.row.findMatchingLine(line);
6758
+ if (!lineMatch) continue;
6759
+ const isLast = rcols.length === 0;
6760
+ const extCols = [
6761
+ ...isFirst ? [musicObj] : [],
6762
+ ...mcols,
6763
+ ...isLast && range.stopObject ? [range.stopObject] : []
6764
+ ];
6765
+ measure2.addLayoutObject(
6766
+ new ObjExtensionLine(measure2, lineMatch, extension, extCols),
6767
+ lineMatch,
6768
+ layoutGroupId,
6769
+ verticalPos
6770
+ );
6251
6771
  }
6252
6772
  }
6253
6773
  });
@@ -6301,7 +6821,7 @@ var ObjMeasure = class extends MusicObject {
6301
6821
  let beamGroupSize = ts.beamGroupSizes[groupId];
6302
6822
  let beamGroupSizeList = [beamGroupSize];
6303
6823
  if (beamGroupSize.length > 1) {
6304
- beamGroupSizeList.unshift([Utils9.Math.sum(beamGroupSize)]);
6824
+ beamGroupSizeList.unshift([utils_exports.Math.sum(beamGroupSize)]);
6305
6825
  }
6306
6826
  let beamCreated = false;
6307
6827
  let groupStartTicksSave = groupStartTicks;
@@ -6316,7 +6836,7 @@ var ObjMeasure = class extends MusicObject {
6316
6836
  let symbolEndTicks = symbolStartTicks + symbol.rhythmProps.ticks;
6317
6837
  return symbolStartTicks >= groupStartTicks && symbolEndTicks <= groupEndTicks;
6318
6838
  });
6319
- let groupSymbolsTicks = Utils9.Math.sum(groupSymbols.map((sym) => sym.rhythmProps.ticks));
6839
+ let groupSymbolsTicks = utils_exports.Math.sum(groupSymbols.map((sym) => sym.rhythmProps.ticks));
6320
6840
  if (groupSymbolsTicks === beamGroupTicks && groupSymbols.every((n) => n instanceof ObjNoteGroup) && (groupSymbols.every((n) => n.rhythmProps.flagCount === 1) || beamGroupSizeList.length === 0)) {
6321
6841
  if (ObjBeamGroup.createBeam(groupSymbols)) {
6322
6842
  beamCreated = true;
@@ -6347,7 +6867,7 @@ var ObjMeasure = class extends MusicObject {
6347
6867
  this.completeRests(getVoiceIds().filter((id) => this.getConsumedTicks(id) > 0));
6348
6868
  }
6349
6869
  return;
6350
- } else if (Guard8.isArray(voiceId)) {
6870
+ } else if (guard_exports.isArray(voiceId)) {
6351
6871
  voiceId.forEach((id) => this.completeRests(id));
6352
6872
  return;
6353
6873
  } else {
@@ -6386,7 +6906,7 @@ var ObjMeasure = class extends MusicObject {
6386
6906
  this.requestRectUpdate();
6387
6907
  let { unitSize } = ctx;
6388
6908
  this.postMeasureBreakWidth = this.hasPostMeasureBreak() ? DocumentSettings.PostMeasureBreakWidth * unitSize : 0;
6389
- let isFirstMeasureInRow = this === this.row.getFirstMeasure();
6909
+ let isFirstMeasureInRow = this.isFirstMeasureInRow();
6390
6910
  let isAfterMeasureBreak = ((_a = this.getPrevMeasure()) == null ? void 0 : _a.hasPostMeasureBreak()) === true;
6391
6911
  this.regions.tabTuning_0 = isFirstMeasureInRow && this.row.hasTab ? unitSize * 4 : 0;
6392
6912
  let showClef = isFirstMeasureInRow || isAfterMeasureBreak;
@@ -6419,11 +6939,12 @@ var ObjMeasure = class extends MusicObject {
6419
6939
  }
6420
6940
  });
6421
6941
  this.tabStringNotes.length = 0;
6422
- if (this === this.row.getFirstMeasure()) {
6942
+ if (this.isFirstMeasureInRow()) {
6423
6943
  this.row.getTabs().forEach((tab) => {
6424
6944
  for (let stringId = 0; stringId < 6; stringId++) {
6425
6945
  let note = tab.getTuningStrings()[stringId].format(PitchNotation.Helmholtz, SymbolSet.Unicode);
6426
- let obj = new ObjText(this, { text: note, scale: 0.8 }, 1, 0.5);
6946
+ let color = DocumentColor.Tab_Tuning;
6947
+ let obj = new ObjText(this, { text: note, scale: 0.8, color }, 1, 0.5);
6427
6948
  obj.layout(ctx);
6428
6949
  obj.setRight(this.regions.tabTuning_0 * 0.8);
6429
6950
  obj.setCenterY(tab.getStringY(stringId));
@@ -6456,7 +6977,7 @@ var ObjMeasure = class extends MusicObject {
6456
6977
  return;
6457
6978
  }
6458
6979
  width = Math.max(width, this.getMinWidth());
6459
- this.rect = new AnchoredRect20();
6980
+ this.rect = new AnchoredRect();
6460
6981
  this.rect.anchorX = this.rect.left + width / 2;
6461
6982
  this.rect.right = this.rect.left + width;
6462
6983
  this.signatures.forEach((signature) => {
@@ -6541,7 +7062,7 @@ var ObjMeasure = class extends MusicObject {
6541
7062
  ...this.beamGroups.filter((b) => !b.isEmpty()).map((b) => b.getRect().bottom),
6542
7063
  ...this.layoutObjects.filter((o) => o.isPositionResolved()).map((o) => o.musicObj.getRect().bottom)
6543
7064
  );
6544
- if (this === this.row.getLastMeasure()) {
7065
+ if (this.isLastMeasureInRow()) {
6545
7066
  this.rect.right = Math.max(
6546
7067
  this.rect.right,
6547
7068
  ...this.layoutObjects.filter((o) => o.isPositionResolved() && o.musicObj instanceof ObjFermata).map((o) => o.musicObj.getRect().right)
@@ -6569,21 +7090,31 @@ var ObjMeasure = class extends MusicObject {
6569
7090
  }
6570
7091
  draw(ctx) {
6571
7092
  ctx.drawDebugRect(this.getRect());
7093
+ ctx.lineWidth(1);
6572
7094
  let left = this.getStaffLineLeft();
6573
7095
  let right = this.getStaffLineRight();
6574
- ctx.color("black").lineWidth(1);
6575
- const drawLine = (y) => ctx.strokeLine(left, y, right, y);
7096
+ const drawLine = (y, color) => ctx.color(color).strokeLine(left, y, right, y);
6576
7097
  this.row.getNotationLines().forEach((line) => {
6577
7098
  if (line instanceof ObjStaff) {
6578
7099
  for (let p = line.bottomLineDiatonicId; p <= line.topLineDiatonicId; p += 2) {
6579
- drawLine(line.getDiatonicIdY(p));
7100
+ drawLine(line.getDiatonicIdY(p), DocumentColor.Staff_Frame);
6580
7101
  }
6581
7102
  } else if (line instanceof ObjTab) {
6582
7103
  for (let stringId = 0; stringId < 6; stringId++) {
6583
- drawLine(line.getStringY(stringId));
7104
+ drawLine(line.getStringY(stringId), DocumentColor.Tab_Frame);
6584
7105
  }
6585
7106
  }
6586
7107
  });
7108
+ if (this.isFirstMeasureInRow() && this.row.getNotationLines().length === 1) {
7109
+ this.row.getTabs().forEach((tab) => {
7110
+ const grp = tab.getRowGroup();
7111
+ if (grp.hasBrace) return;
7112
+ const left2 = this.getStaffLineLeft();
7113
+ const top = tab.getTopLineY();
7114
+ const bottom = tab.getBottomLineY();
7115
+ ctx.color(DocumentColor.Tab_Frame).lineWidth(1).strokeLine(left2, top, left2, bottom);
7116
+ });
7117
+ }
6587
7118
  this.signatures.forEach((signature) => signature.draw(ctx));
6588
7119
  this.tabStringNotes.forEach((obj) => obj.draw(ctx));
6589
7120
  this.barLineLeft.draw(ctx);
@@ -6599,8 +7130,7 @@ var ObjMeasure = class extends MusicObject {
6599
7130
  };
6600
7131
 
6601
7132
  // src/score/engine/layout-object.ts
6602
- import { MusicError as MusicError14, MusicErrorType as MusicErrorType14 } from "@tspro/web-music-score/core";
6603
- import { AnchoredRect as AnchoredRect21, asMulti as asMulti2, IndexArray as IndexArray3, UniMap as UniMap7 } from "@tspro/ts-utils-lib";
7133
+ import { MusicError as MusicError12, MusicErrorType as MusicErrorType12 } from "@tspro/web-music-score/core";
6604
7134
  var LayoutGroupId = /* @__PURE__ */ ((LayoutGroupId2) => {
6605
7135
  LayoutGroupId2[LayoutGroupId2["TabRhythm"] = 0] = "TabRhythm";
6606
7136
  LayoutGroupId2[LayoutGroupId2["Fermata"] = 1] = "Fermata";
@@ -6615,7 +7145,7 @@ var LayoutGroupId = /* @__PURE__ */ ((LayoutGroupId2) => {
6615
7145
  LayoutGroupId2[LayoutGroupId2["LyricsVerse3"] = 10] = "LyricsVerse3";
6616
7146
  return LayoutGroupId2;
6617
7147
  })(LayoutGroupId || {});
6618
- var LayoutGroupIdAttrs = new UniMap7([
7148
+ var LayoutGroupIdAttrs = new UniMap([
6619
7149
  [0 /* TabRhythm */, { rowAlign: true }],
6620
7150
  [1 /* Fermata */, { reserveSpace: true }],
6621
7151
  [2 /* NoteLabel */, { reserveSpace: true }],
@@ -6635,7 +7165,7 @@ function requireParentMeasure(p) {
6635
7165
  }
6636
7166
  p = p.getParent();
6637
7167
  }
6638
- throw new MusicError14(MusicErrorType14.Score, "Parent measure is required but not found!");
7168
+ throw new MusicError12(MusicErrorType12.Score, "Parent measure is required but not found!");
6639
7169
  }
6640
7170
  var StaffGroup = class {
6641
7171
  constructor(groupName, staffsTabsAndGroups, verticalPosition) {
@@ -6659,7 +7189,7 @@ var LayoutObjectWrapper = class {
6659
7189
  this.row = this.measure.row;
6660
7190
  let anchor = this.musicObj.getParent();
6661
7191
  if (!anchor) {
6662
- throw new MusicError14(MusicErrorType14.Score, "Parent music object is required as an anchor.");
7192
+ throw new MusicError12(MusicErrorType12.Score, "Parent music object is required as an anchor.");
6663
7193
  }
6664
7194
  this.anchor = anchor;
6665
7195
  this.anchor.addAnchoredLayoutObject(this);
@@ -6687,7 +7217,7 @@ var LayoutObjectWrapper = class {
6687
7217
  let staticShapeRects = staticObj.getShapeRects();
6688
7218
  objShapeRects.forEach((objR) => {
6689
7219
  staticShapeRects.forEach((staticR) => {
6690
- if (AnchoredRect21.overlapX(objR, staticR)) {
7220
+ if (AnchoredRect.overlapX(objR, staticR)) {
6691
7221
  y = verticalPos === 1 /* Below */ ? Math.max(y, staticR.bottom + objR.toph + objR.anchorY) : Math.min(y, staticR.top - objR.bottomh - objR.anchorY);
6692
7222
  }
6693
7223
  });
@@ -6695,13 +7225,6 @@ var LayoutObjectWrapper = class {
6695
7225
  });
6696
7226
  return y;
6697
7227
  }
6698
- getTextContent() {
6699
- if (this.musicObj instanceof ObjText || this.musicObj instanceof ObjSpecialText) {
6700
- return this.musicObj.getText();
6701
- } else {
6702
- return void 0;
6703
- }
6704
- }
6705
7228
  layout(ctx) {
6706
7229
  this.line.addObject(this);
6707
7230
  }
@@ -6719,7 +7242,7 @@ var LayoutGroup = class {
6719
7242
  constructor(layoutGroupId) {
6720
7243
  this.layoutGroupId = layoutGroupId;
6721
7244
  // key = VerticalPos
6722
- __publicField(this, "layoutObject", asMulti2(new IndexArray3()));
7245
+ __publicField(this, "layoutObject", asMulti(new IndexArray()));
6723
7246
  __publicField(this, "rowAlign");
6724
7247
  __publicField(this, "reserveSpace");
6725
7248
  __publicField(this, "padding");
@@ -6749,12 +7272,15 @@ var LayoutGroup = class {
6749
7272
  };
6750
7273
 
6751
7274
  // src/score/engine/obj-staff-and-tab.ts
6752
- var ObjNotationLine5 = class extends MusicObject {
7275
+ var ObjNotationLine6 = class extends MusicObject {
6753
7276
  constructor(row) {
6754
7277
  super(row);
6755
7278
  this.row = row;
6756
7279
  __publicField(this, "objects", []);
6757
- __publicField(this, "layoutGroups", new UniMap8());
7280
+ __publicField(this, "layoutGroups", new UniMap());
7281
+ }
7282
+ getRowGroup() {
7283
+ return this.row.getRowGroupByLineId(this.id);
6758
7284
  }
6759
7285
  addObject(o) {
6760
7286
  this.objects.push(o);
@@ -6769,7 +7295,7 @@ var ObjNotationLine5 = class extends MusicObject {
6769
7295
  this.layoutGroups.forEach((layoutGroup) => layoutGroup.layout(ctx));
6770
7296
  }
6771
7297
  layoutLayoutGroups(ctx) {
6772
- for (const groupId of Utils10.Enum.getEnumValues(LayoutGroupId)) {
7298
+ for (const groupId of utils_exports.Enum.getEnumValues(LayoutGroupId)) {
6773
7299
  const layoutGroup = this.getLayoutGroup(groupId);
6774
7300
  if (layoutGroup) {
6775
7301
  this.layoutLayoutGroup(ctx, layoutGroup, 0 /* Above */);
@@ -6820,11 +7346,20 @@ var ObjNotationLine5 = class extends MusicObject {
6820
7346
  });
6821
7347
  }
6822
7348
  }
7349
+ drawVerticalLine(ctx, left, width, isSystemBarLine = false) {
7350
+ ctx.color(this.getConfig().type === "tab" ? DocumentColor.Tab_Frame : DocumentColor.Staff_Frame);
7351
+ const i = this.row.getNotationLines().indexOf(this);
7352
+ const nextLine = i >= 0 ? this.row.getNotationLines()[i + 1] : void 0;
7353
+ const isGroupLine = this.getRowGroup().lines.length > 1;
7354
+ const isGrandTreble = this instanceof ObjStaff && this.isGrandTreble();
7355
+ const top = this.getTopLineY();
7356
+ const bottom = nextLine && (isSystemBarLine || isGroupLine || isGrandTreble) ? nextLine.getTopLineY() : this.getBottomLineY();
7357
+ ctx.fillRect(left, top, width, bottom - top);
7358
+ }
6823
7359
  };
6824
- var ObjStaff = class extends ObjNotationLine5 {
7360
+ var ObjStaff = class extends ObjNotationLine6 {
6825
7361
  constructor(row, staffConfig, id) {
6826
7362
  super(row);
6827
- this.row = row;
6828
7363
  this.staffConfig = staffConfig;
6829
7364
  this.id = id;
6830
7365
  __publicField(this, "clefImageAsset");
@@ -6848,7 +7383,7 @@ var ObjStaff = class extends ObjNotationLine5 {
6848
7383
  this.clefLineDiatonicId = getDiatonicId("F3", staffConfig.isOctaveDown === true);
6849
7384
  this.middleLineDiatonicId = this.clefLineDiatonicId - 2;
6850
7385
  } else {
6851
- throw new MusicError15(MusicErrorType15.Score, `Invalid staffConfig.clef ${staffConfig.clef}.`);
7386
+ throw new MusicError13(MusicErrorType13.Score, `Invalid staffConfig.clef ${staffConfig.clef}.`);
6852
7387
  }
6853
7388
  this.topLineDiatonicId = this.middleLineDiatonicId + 4;
6854
7389
  this.bottomLineDiatonicId = this.middleLineDiatonicId - 4;
@@ -6879,9 +7414,14 @@ var ObjStaff = class extends ObjNotationLine5 {
6879
7414
  return this.bottomLineY;
6880
7415
  }
6881
7416
  joinGrandStaff(staff) {
6882
- if (staff !== this) {
7417
+ if (staff !== this)
6883
7418
  this.joinedGrandStaff = staff;
6884
- }
7419
+ }
7420
+ isGrandTreble() {
7421
+ return this.joinedGrandStaff !== void 0 && this.staffConfig.clef === "G" /* G */;
7422
+ }
7423
+ isGrandBass() {
7424
+ return this.joinedGrandStaff !== void 0 && this.staffConfig.clef === "F" /* F */;
6885
7425
  }
6886
7426
  getLineSpacing() {
6887
7427
  return (this.bottomLineY - this.topLineY) / 4;
@@ -6899,7 +7439,7 @@ var ObjStaff = class extends ObjNotationLine5 {
6899
7439
  } else if (this.joinedGrandStaff && this.joinedGrandStaff.containsDiatonicId(diatonicId)) {
6900
7440
  return this.joinedGrandStaff.getDiatonicIdY(diatonicId);
6901
7441
  } else {
6902
- throw new MusicError15(MusicErrorType15.Score, "Staff does not contain diatonicId " + diatonicId);
7442
+ throw new MusicError13(MusicErrorType13.Score, "Staff does not contain diatonicId " + diatonicId);
6903
7443
  }
6904
7444
  }
6905
7445
  getActualStaff(diatonicId) {
@@ -6908,7 +7448,7 @@ var ObjStaff = class extends ObjNotationLine5 {
6908
7448
  } else if (this.joinedGrandStaff && this.joinedGrandStaff.containsDiatonicId(diatonicId)) {
6909
7449
  return this.joinedGrandStaff;
6910
7450
  } else {
6911
- throw new MusicError15(MusicErrorType15.Score, "Staff does not contain diatonicId " + diatonicId);
7451
+ throw new MusicError13(MusicErrorType13.Score, "Staff does not contain diatonicId " + diatonicId);
6912
7452
  }
6913
7453
  }
6914
7454
  getDiatonicIdAt(y) {
@@ -6922,7 +7462,7 @@ var ObjStaff = class extends ObjNotationLine5 {
6922
7462
  return diatonicId % 2 !== this.middleLineDiatonicId % 2;
6923
7463
  }
6924
7464
  containsVoiceId(voiceId) {
6925
- return Guard9.isUndefined(this.staffConfig.voiceId) || Utils10.Arr.toArray(this.staffConfig.voiceId).includes(voiceId);
7465
+ return guard_exports.isUndefined(this.staffConfig.voiceId) || utils_exports.Arr.toArray(this.staffConfig.voiceId).includes(voiceId);
6926
7466
  }
6927
7467
  calcTop() {
6928
7468
  let top = this.topLineY;
@@ -6952,7 +7492,7 @@ var ObjStaff = class extends ObjNotationLine5 {
6952
7492
  let h = unitSize * DocumentSettings.StaffHeight;
6953
7493
  this.topLineY = -h / 2;
6954
7494
  this.bottomLineY = h / 2;
6955
- this.rect = new AnchoredRect22(0, 0, this.topLineY, this.bottomLineY);
7495
+ this.rect = new AnchoredRect(0, 0, this.topLineY, this.bottomLineY);
6956
7496
  }
6957
7497
  layoutWidth(ctx) {
6958
7498
  this.rect.left = this.row.getRect().left;
@@ -6973,10 +7513,9 @@ var ObjStaff = class extends ObjNotationLine5 {
6973
7513
  draw(ctx) {
6974
7514
  }
6975
7515
  };
6976
- var ObjTab = class extends ObjNotationLine5 {
7516
+ var ObjTab = class extends ObjNotationLine6 {
6977
7517
  constructor(row, tabConfig, id) {
6978
7518
  super(row);
6979
- this.row = row;
6980
7519
  this.tabConfig = tabConfig;
6981
7520
  this.id = id;
6982
7521
  __publicField(this, "top", 0);
@@ -6984,7 +7523,7 @@ var ObjTab = class extends ObjNotationLine5 {
6984
7523
  __publicField(this, "tuningName");
6985
7524
  __publicField(this, "tuningStrings");
6986
7525
  __publicField(this, "mi");
6987
- if (Guard9.isArray(tabConfig.tuning)) {
7526
+ if (guard_exports.isArray(tabConfig.tuning)) {
6988
7527
  this.tuningName = void 0;
6989
7528
  this.tuningStrings = tabConfig.tuning.map((noteName) => Note8.getNote(noteName)).reverse();
6990
7529
  } else if (typeof tabConfig.tuning === "string") {
@@ -7035,7 +7574,7 @@ var ObjTab = class extends ObjNotationLine5 {
7035
7574
  return this.bottom;
7036
7575
  }
7037
7576
  containsVoiceId(voiceId) {
7038
- return Guard9.isUndefined(this.tabConfig.voiceId) || Utils10.Arr.toArray(this.tabConfig.voiceId).includes(voiceId);
7577
+ return guard_exports.isUndefined(this.tabConfig.voiceId) || utils_exports.Arr.toArray(this.tabConfig.voiceId).includes(voiceId);
7039
7578
  }
7040
7579
  containsDiatonicId(diatonicId) {
7041
7580
  return true;
@@ -7058,7 +7597,7 @@ var ObjTab = class extends ObjNotationLine5 {
7058
7597
  let h = unitSize * DocumentSettings.TabHeight;
7059
7598
  this.top = -h / 2;
7060
7599
  this.bottom = h / 2;
7061
- this.rect = new AnchoredRect22(0, 0, this.top, this.bottom);
7600
+ this.rect = new AnchoredRect(0, 0, this.top, this.bottom);
7062
7601
  }
7063
7602
  layoutWidth(ctx) {
7064
7603
  this.rect.left = this.row.getRect().left;
@@ -7081,11 +7620,15 @@ var ObjTab = class extends ObjNotationLine5 {
7081
7620
  };
7082
7621
 
7083
7622
  // src/score/engine/obj-score-row.ts
7084
- import { MusicError as MusicError16, MusicErrorType as MusicErrorType16 } from "@tspro/web-music-score/core";
7085
- import { AnchoredRect as AnchoredRect24, Guard as Guard10, Utils as Utils11 } from "@tspro/ts-utils-lib";
7623
+ import { MusicError as MusicError14, MusicErrorType as MusicErrorType14 } from "@tspro/web-music-score/core";
7086
7624
 
7087
7625
  // src/score/engine/obj-score-row-group.ts
7088
- import { AnchoredRect as AnchoredRect23 } from "@tspro/ts-utils-lib";
7626
+ function parseInstr(instr) {
7627
+ const instrName = (instr.startsWith("!{") ? instr.substring(2) : instr.startsWith("!") ? instr.substring(1) : instr).trim();
7628
+ const hideInstr = instr.startsWith("!");
7629
+ const hideBrace = instr.startsWith("!{");
7630
+ return { instrName, hideInstr, hideBrace };
7631
+ }
7089
7632
  var ObjScoreRowGroup = class extends MusicObject {
7090
7633
  constructor(lines) {
7091
7634
  var _a;
@@ -7093,11 +7636,16 @@ var ObjScoreRowGroup = class extends MusicObject {
7093
7636
  this.lines = lines;
7094
7637
  __publicField(this, "space", 0);
7095
7638
  __publicField(this, "instrument");
7639
+ __publicField(this, "hasBrace");
7096
7640
  __publicField(this, "instrText");
7097
- __publicField(this, "braceRect", new AnchoredRect23());
7641
+ __publicField(this, "braceRect", new AnchoredRect());
7098
7642
  __publicField(this, "mi");
7099
- this.instrument = (_a = lines[0].getConfig().instrument) != null ? _a : "";
7100
- this.instrText = new ObjText(this, { text: this.instrument, color: "black", scale: 1 }, 1, 0.5);
7643
+ const color = DocumentColor.RowGroup_Instrument;
7644
+ const instr = parseInstr((_a = lines[0].getConfig().instrument) != null ? _a : "");
7645
+ this.instrument = instr.instrName;
7646
+ this.hasBrace = instr.hideBrace ? false : this.hasInstrument && lines.length >= 2;
7647
+ const text = instr.hideInstr ? "" : this.instrument;
7648
+ this.instrText = new ObjText(this, { text, color, scale: 1 }, 1, 0.5);
7101
7649
  this.mi = new MScoreRowGroup(this);
7102
7650
  }
7103
7651
  getMusicInterface() {
@@ -7106,12 +7654,12 @@ var ObjScoreRowGroup = class extends MusicObject {
7106
7654
  get row() {
7107
7655
  return this.lines[0].row;
7108
7656
  }
7109
- get hasBrace() {
7110
- return this.hasInstrument && this.lines.length > 1;
7111
- }
7112
7657
  get hasInstrument() {
7113
7658
  return this.instrument.length > 0;
7114
7659
  }
7660
+ hasNotationLine(line) {
7661
+ return this.lines.includes(line);
7662
+ }
7115
7663
  pick(x, y) {
7116
7664
  if (!this.getRect().contains(x, y))
7117
7665
  return [];
@@ -7129,7 +7677,7 @@ var ObjScoreRowGroup = class extends MusicObject {
7129
7677
  layout(ctx) {
7130
7678
  this.space = ctx.unitSize;
7131
7679
  this.instrText.layout(ctx);
7132
- this.braceRect = new AnchoredRect23(-(this.hasBrace ? ctx.unitSize * 5 : 0), 0, 0, 0);
7680
+ this.braceRect = new AnchoredRect(-(this.hasBrace ? ctx.unitSize * 5 : 0), 0, 0, 0);
7133
7681
  this.forceRectUpdate();
7134
7682
  }
7135
7683
  layoutToNotationLines() {
@@ -7146,7 +7694,8 @@ var ObjScoreRowGroup = class extends MusicObject {
7146
7694
  draw(ctx) {
7147
7695
  this.instrText.draw(ctx);
7148
7696
  if (this.hasBrace) {
7149
- ctx.color("brack").lineWidth(1).drawBracket(this.braceRect, "{");
7697
+ const r = this.braceRect;
7698
+ ctx.color(DocumentColor.RowGroup_Frame).lineWidth(1).drawBracket(r, "{");
7150
7699
  }
7151
7700
  }
7152
7701
  };
@@ -7200,6 +7749,7 @@ var ObjScoreRow = class extends MusicObject {
7200
7749
  __publicField(this, "staves");
7201
7750
  __publicField(this, "tabs");
7202
7751
  __publicField(this, "measures", []);
7752
+ __publicField(this, "rowGroupByLine");
7203
7753
  __publicField(this, "needLayout", true);
7204
7754
  __publicField(this, "mi");
7205
7755
  this.notationLines = this.createNotationLines();
@@ -7216,6 +7766,7 @@ var ObjScoreRow = class extends MusicObject {
7216
7766
  }
7217
7767
  }
7218
7768
  this.rowGroups = lineGroups.filter((lines) => lines.length > 0).map((lines) => new ObjScoreRowGroup(lines));
7769
+ this.rowGroupByLine = this.notationLines.map((line) => this.rowGroups.find((grp) => grp.lines.includes(line)));
7219
7770
  if (this.prevRow) {
7220
7771
  this.prevRow.nextRow = this;
7221
7772
  }
@@ -7242,9 +7793,12 @@ var ObjScoreRow = class extends MusicObject {
7242
7793
  getRowGroups() {
7243
7794
  return this.rowGroups;
7244
7795
  }
7796
+ getRowGroupByLineId(id) {
7797
+ return this.rowGroupByLine[id];
7798
+ }
7245
7799
  findMatchingLine(line) {
7246
7800
  return line.row === this ? line : this.notationLines.find(
7247
- (curLine) => Utils11.Obj.deepEqual(line.row.scoreConfig, curLine.row.scoreConfig) && line.id === curLine.id || Guard10.isNonEmptyString(line.getConfig().name) && line.getConfig().name === curLine.getConfig().name && line.getConfig().type === curLine.getConfig().type
7801
+ (curLine) => utils_exports.Obj.deepEqual(line.row.scoreConfig, curLine.row.scoreConfig) && line.id === curLine.id || guard_exports.isNonEmptyString(line.getConfig().name) && line.getConfig().name === curLine.getConfig().name && line.getConfig().type === curLine.getConfig().type
7248
7802
  );
7249
7803
  }
7250
7804
  get regions() {
@@ -7267,7 +7821,7 @@ var ObjScoreRow = class extends MusicObject {
7267
7821
  if (topStaff) {
7268
7822
  return topStaff;
7269
7823
  } else {
7270
- throw new MusicError16(MusicErrorType16.Score, "Top staff is required!");
7824
+ throw new MusicError14(MusicErrorType14.Score, "Top staff is required!");
7271
7825
  }
7272
7826
  }
7273
7827
  getBottomStaff() {
@@ -7275,7 +7829,7 @@ var ObjScoreRow = class extends MusicObject {
7275
7829
  if (bottomStaff) {
7276
7830
  return bottomStaff;
7277
7831
  } else {
7278
- throw new MusicError16(MusicErrorType16.Score, "Bottom staff is required!");
7832
+ throw new MusicError14(MusicErrorType14.Score, "Bottom staff is required!");
7279
7833
  }
7280
7834
  }
7281
7835
  getStaff(diatonicId) {
@@ -7322,7 +7876,7 @@ var ObjScoreRow = class extends MusicObject {
7322
7876
  let r = this.getRect();
7323
7877
  let firstMeasure = this.getFirstMeasure();
7324
7878
  let left = firstMeasure ? firstMeasure.getColumnsContentRect().left : r.left;
7325
- return new AnchoredRect24(left, (left + r.right) / 2, r.right, r.top, r.anchorY, r.bottom);
7879
+ return new AnchoredRect(left, (left + r.right) / 2, r.right, r.top, r.anchorY, r.bottom);
7326
7880
  }
7327
7881
  getDiatonicIdAt(y) {
7328
7882
  for (let i = 0; i < this.notationLines.length; i++) {
@@ -7369,7 +7923,7 @@ var ObjScoreRow = class extends MusicObject {
7369
7923
  return "up" /* Up */;
7370
7924
  }
7371
7925
  let diatonicIds = noteGroupDiatonicIds.length > 0 ? noteGroupDiatonicIds : restDiatonicIds;
7372
- let avgDiatonicId = Math.floor(Utils11.Math.avg(...diatonicIds));
7926
+ let avgDiatonicId = Math.floor(utils_exports.Math.avg(...diatonicIds));
7373
7927
  let staves = this.getStaves().filter((staff) => staff.containsVoiceId(voiceId) && staff.containsDiatonicId(avgDiatonicId));
7374
7928
  return staves.length > 0 ? avgDiatonicId >= staves[0].middleLineDiatonicId ? "down" /* Down */ : "up" /* Up */ : "up" /* Up */;
7375
7929
  }
@@ -7401,7 +7955,7 @@ var ObjScoreRow = class extends MusicObject {
7401
7955
  if (!this.needLayout) {
7402
7956
  return;
7403
7957
  }
7404
- this.rect = new AnchoredRect24(this.regions.left, this.regions.right, 0, 0);
7958
+ this.rect = new AnchoredRect(this.regions.left, this.regions.right, 0, 0);
7405
7959
  this.notationLines.forEach((line) => line.layoutWidth(ctx));
7406
7960
  this.rowGroups.forEach((grp) => grp.setRight(this.regions.instrRight));
7407
7961
  let targetColumnsAreaWidth = this.regions.staffWidth;
@@ -7440,7 +7994,7 @@ var ObjScoreRow = class extends MusicObject {
7440
7994
  top = Math.min(...this.measures.map((m) => m.getRect().top));
7441
7995
  bottom = Math.max(...this.measures.map((m) => m.getRect().bottom));
7442
7996
  }
7443
- this.rect = new AnchoredRect24(left, right, top, bottom);
7997
+ this.rect = new AnchoredRect(left, right, top, bottom);
7444
7998
  }
7445
7999
  alignStemsToBeams() {
7446
8000
  this.measures.forEach((m) => m.alignStemsToBeams());
@@ -7484,6 +8038,10 @@ var ObjScoreRow = class extends MusicObject {
7484
8038
  this.notationLines.forEach((l) => l.offset(dx, dy));
7485
8039
  this.rowGroups.forEach((grp) => grp.offset(dx, dy));
7486
8040
  }
8041
+ getStaffLineLeft() {
8042
+ var _a;
8043
+ return (_a = this.getFirstMeasure()) == null ? void 0 : _a.getStaffLineLeft();
8044
+ }
7487
8045
  draw(ctx) {
7488
8046
  ctx.drawDebugRect(this.getRect());
7489
8047
  const { left, top, width, height } = this.getRect();
@@ -7491,21 +8049,18 @@ var ObjScoreRow = class extends MusicObject {
7491
8049
  ctx.save();
7492
8050
  ctx.rect(left - p, top, width + 2 * p, height);
7493
8051
  ctx.clip();
7494
- if (this.getFirstMeasure() && (this.notationLines.length > 1 || this.notationLines[0] instanceof ObjTab)) {
7495
- let left2 = this.getFirstMeasure().getStaffLineLeft();
7496
- let top2 = Math.min(...this.notationLines.map((line) => line.getTopLineY()));
7497
- let bottom = Math.max(...this.notationLines.map((line) => line.getBottomLineY()));
7498
- ctx.color("black").lineWidth(1).strokeLine(left2, top2, left2, bottom);
7499
- }
7500
8052
  this.measures.forEach((m) => m.draw(ctx));
7501
8053
  this.notationLines.forEach((m) => m.draw(ctx));
8054
+ const staffLeft = this.getStaffLineLeft();
8055
+ if (staffLeft !== void 0 && this.notationLines.length > 1) {
8056
+ this.notationLines.forEach((line) => line.drawVerticalLine(ctx, staffLeft, ctx._lineWidth, true));
8057
+ }
7502
8058
  this.rowGroups.forEach((grp) => grp.draw(ctx));
7503
8059
  ctx.restore();
7504
8060
  }
7505
8061
  };
7506
8062
 
7507
8063
  // src/score/engine/obj-header.ts
7508
- import { AnchoredRect as AnchoredRect25 } from "@tspro/ts-utils-lib";
7509
8064
  var ObjHeader = class extends MusicObject {
7510
8065
  constructor(doc, title, composer, arranger) {
7511
8066
  super(doc);
@@ -7518,9 +8073,12 @@ var ObjHeader = class extends MusicObject {
7518
8073
  __publicField(this, "arrangerText");
7519
8074
  __publicField(this, "mi");
7520
8075
  this.mi = new MHeader(this);
7521
- this.titleText = this.title ? new ObjText(this, { text: this.title, scale: 2 }, 0.5, 0) : void 0;
7522
- this.composerText = this.composer ? new ObjText(this, this.composer, 1, 0) : void 0;
7523
- this.arrangerText = this.arranger ? new ObjText(this, "Arr.: " + this.arranger, 1, 0) : void 0;
8076
+ const titleColor = DocumentColor.Header_Title;
8077
+ const compColor = DocumentColor.Header_Composer;
8078
+ const arrColor = DocumentColor.Header_Arranger;
8079
+ this.titleText = this.title ? new ObjText(this, { text: this.title, color: titleColor, scale: 2 }, 0.5, 0) : void 0;
8080
+ this.composerText = this.composer ? new ObjText(this, { text: this.composer, color: compColor }, 1, 0) : void 0;
8081
+ this.arrangerText = this.arranger ? new ObjText(this, { text: "Arr.: " + this.arranger, color: arrColor }, 1, 0) : void 0;
7524
8082
  }
7525
8083
  getMusicInterface() {
7526
8084
  return this.mi;
@@ -7553,7 +8111,7 @@ var ObjHeader = class extends MusicObject {
7553
8111
  let top = 0;
7554
8112
  const left = this.doc.regions.staffLeft;
7555
8113
  const right = this.doc.regions.staffRight;
7556
- this.rect = new AnchoredRect25(left, right, 0, 0);
8114
+ this.rect = new AnchoredRect(left, right, 0, 0);
7557
8115
  if (this.titleText) {
7558
8116
  this.titleText.layout(ctx);
7559
8117
  this.titleText.setCenterX((left + right) / 2);
@@ -7602,8 +8160,7 @@ var ObjHeader = class extends MusicObject {
7602
8160
  };
7603
8161
 
7604
8162
  // src/score/engine/obj-document.ts
7605
- import { AnchoredRect as AnchoredRect26, Guard as Guard11, UniMap as UniMap9 } from "@tspro/ts-utils-lib";
7606
- import { MusicError as MusicError17, MusicErrorType as MusicErrorType17 } from "@tspro/web-music-score/core";
8163
+ import { MusicError as MusicError15, MusicErrorType as MusicErrorType15 } from "@tspro/web-music-score/core";
7607
8164
  var ObjDocument = class extends MusicObject {
7608
8165
  constructor() {
7609
8166
  super(void 0);
@@ -7617,7 +8174,7 @@ var ObjDocument = class extends MusicObject {
7617
8174
  __publicField(this, "header");
7618
8175
  __publicField(this, "newRowRequested", false);
7619
8176
  __publicField(this, "allConnectiveProps", []);
7620
- __publicField(this, "staffGroups", new UniMap9());
8177
+ __publicField(this, "staffGroups", new UniMap());
7621
8178
  __publicField(this, "mi");
7622
8179
  this.mi = new MDocument2(this);
7623
8180
  }
@@ -7625,7 +8182,7 @@ var ObjDocument = class extends MusicObject {
7625
8182
  return this.mi;
7626
8183
  }
7627
8184
  setScoreConfiguration(config) {
7628
- if (Guard11.isEnumValue(config, StaffPreset)) {
8185
+ if (guard_exports.isEnumValue(config, StaffPreset)) {
7629
8186
  switch (config) {
7630
8187
  default:
7631
8188
  case "treble" /* Treble */:
@@ -7653,7 +8210,7 @@ var ObjDocument = class extends MusicObject {
7653
8210
  ];
7654
8211
  break;
7655
8212
  }
7656
- } else if (Guard11.isArray(config)) {
8213
+ } else if (guard_exports.isArray(config)) {
7657
8214
  this.curScoreConfig = config;
7658
8215
  } else {
7659
8216
  this.curScoreConfig = [config];
@@ -7666,10 +8223,10 @@ var ObjDocument = class extends MusicObject {
7666
8223
  }
7667
8224
  if (treble && treble.type === "staff" && treble.isGrand) {
7668
8225
  if (treble.grandId !== void 0) {
7669
- throw new MusicError17(MusicErrorType17.Score, `Grand staff error: mixing isGrand and grandId!`);
8226
+ throw new MusicError15(MusicErrorType15.Score, `Grand staff error: mixing isGrand and grandId!`);
7670
8227
  } else if (bass && bass.type === "staff" && bass.isGrand) {
7671
8228
  if (bass.grandId !== void 0) {
7672
- throw new MusicError17(MusicErrorType17.Score, `Grand staff error: mixing isGrand and grandId!`);
8229
+ throw new MusicError15(MusicErrorType15.Score, `Grand staff error: mixing isGrand and grandId!`);
7673
8230
  } else {
7674
8231
  treble.grandId = grandId;
7675
8232
  bass.grandId = grandId;
@@ -7677,7 +8234,7 @@ var ObjDocument = class extends MusicObject {
7677
8234
  cfgId += 2;
7678
8235
  }
7679
8236
  } else {
7680
- throw new MusicError17(MusicErrorType17.Score, `Grand staff error: invalid use of isGrand!`);
8237
+ throw new MusicError15(MusicErrorType15.Score, `Grand staff error: invalid use of isGrand!`);
7681
8238
  }
7682
8239
  } else {
7683
8240
  cfgId++;
@@ -7688,20 +8245,20 @@ var ObjDocument = class extends MusicObject {
7688
8245
  let bass = this.curScoreConfig[cfgId + 1];
7689
8246
  if (treble && bass && treble.type === "staff" && bass.type === "staff" && treble.grandId !== void 0 && treble.grandId === bass.grandId) {
7690
8247
  if (usedGrandIdes.includes(treble.grandId)) {
7691
- throw new MusicError17(MusicErrorType17.Score, `Grand staff error: grandId "${treble.grandId}" already used!`);
8248
+ throw new MusicError15(MusicErrorType15.Score, `Grand staff error: grandId "${treble.grandId}" already used!`);
7692
8249
  } else if (treble.clef !== "G" /* G */) {
7693
- throw new MusicError17(MusicErrorType17.Score, `Grand staff error: Invalid treble clef "${treble.clef}"!`);
8250
+ throw new MusicError15(MusicErrorType15.Score, `Grand staff error: Invalid treble clef "${treble.clef}"!`);
7694
8251
  } else if (bass.clef !== "F" /* F */) {
7695
- throw new MusicError17(MusicErrorType17.Score, `Grand staff error: Invalid treble clef "${treble.clef}"!`);
8252
+ throw new MusicError15(MusicErrorType15.Score, `Grand staff error: Invalid treble clef "${treble.clef}"!`);
7696
8253
  } else if (treble.isOctaveDown || bass.isOctaveDown) {
7697
- throw new MusicError17(MusicErrorType17.Score, `Grand staff error: cannot use isOctaveDown option!`);
8254
+ throw new MusicError15(MusicErrorType15.Score, `Grand staff error: cannot use isOctaveDown option!`);
7698
8255
  }
7699
8256
  usedGrandIdes.push(treble.grandId);
7700
8257
  treble.minNote = "C4";
7701
8258
  bass.maxNote = "B3";
7702
8259
  cfgId += 2;
7703
8260
  } else if (treble && treble.type === "staff" && treble.grandId !== void 0) {
7704
- throw new MusicError17(MusicErrorType17.Score, `Grand staff error: invalid use of grandId "${treble.grandId}"!`);
8261
+ throw new MusicError15(MusicErrorType15.Score, `Grand staff error: invalid use of grandId "${treble.grandId}"!`);
7705
8262
  } else {
7706
8263
  cfgId++;
7707
8264
  }
@@ -7847,7 +8404,7 @@ var ObjDocument = class extends MusicObject {
7847
8404
  this.rows.forEach((row) => row.layoutStretch(ctx));
7848
8405
  this.rows.forEach((row) => row.layoutLayoutGroups(ctx));
7849
8406
  this.rows.forEach((row) => row.layoutSetNotationLines(ctx));
7850
- this.rect = new AnchoredRect26();
8407
+ this.rect = new AnchoredRect();
7851
8408
  if (this.header) {
7852
8409
  this.header.layout(ctx);
7853
8410
  this.rect.expandInPlace(this.header.getRect());
@@ -7864,13 +8421,10 @@ var ObjDocument = class extends MusicObject {
7864
8421
  }
7865
8422
  drawContent() {
7866
8423
  const { ctx } = this;
7867
- if (!ctx) {
7868
- return;
7869
- }
8424
+ if (!ctx) return;
7870
8425
  this.rows.forEach((row) => row.draw(ctx));
7871
- if (this.header) {
8426
+ if (this.header)
7872
8427
  this.header.draw(ctx);
7873
- }
7874
8428
  }
7875
8429
  pickStaffPosAt(x, y) {
7876
8430
  if (!this.rect.contains(x, y)) {
@@ -7913,7 +8467,7 @@ var ObjDocument = class extends MusicObject {
7913
8467
 
7914
8468
  // src/score/pub/document-builder.ts
7915
8469
  import { BeamGrouping, isNoteLength, isTupletRatio, KeySignature as KeySignature3, Note as Note10, NoteLength as NoteLength8, RhythmProps as RhythmProps6, Scale as Scale2, ScaleType, SymbolSet as SymbolSet2, TimeSignature as TimeSignature2, TimeSignatures, TuningNameList } from "@tspro/web-music-score/theory";
7916
- import { MusicError as MusicError18, MusicErrorType as MusicErrorType18 } from "@tspro/web-music-score/core";
8470
+ import { MusicError as MusicError16, MusicErrorType as MusicErrorType16 } from "@tspro/web-music-score/core";
7917
8471
  var assertingFunction = "";
7918
8472
  function setAssertFunction(fnName, ...fnArgs) {
7919
8473
  let argsStr = fnArgs.map((arg) => JSON.stringify(arg)).join(", ");
@@ -7921,95 +8475,95 @@ function setAssertFunction(fnName, ...fnArgs) {
7921
8475
  }
7922
8476
  function assertArg(...conditions) {
7923
8477
  conditions.forEach((condition) => {
7924
- if (!condition) throw new MusicError18(MusicErrorType18.Score, assertingFunction);
8478
+ if (!condition) throw new MusicError16(MusicErrorType16.Score, assertingFunction);
7925
8479
  });
7926
8480
  }
7927
8481
  function assertArgMsg(condition, msg) {
7928
- if (!condition) throw new MusicError18(MusicErrorType18.Score, msg);
8482
+ if (!condition) throw new MusicError16(MusicErrorType16.Score, msg);
7929
8483
  }
7930
8484
  function assertBaseConfig(baseConfig) {
7931
8485
  var _a;
7932
8486
  assertArg(
7933
- Guard12.isObject(baseConfig),
7934
- Guard12.isStringOrUndefined(baseConfig.name),
7935
- Guard12.isUndefined(baseConfig.voiceId) || isVoiceId(baseConfig.voiceId) || Guard12.isArray(baseConfig.voiceId) && baseConfig.voiceId.every((voiceId) => isVoiceId(voiceId))
8487
+ guard_exports.isObject(baseConfig),
8488
+ guard_exports.isStringOrUndefined(baseConfig.name),
8489
+ guard_exports.isUndefined(baseConfig.voiceId) || isVoiceId(baseConfig.voiceId) || guard_exports.isArray(baseConfig.voiceId) && baseConfig.voiceId.every((voiceId) => isVoiceId(voiceId))
7936
8490
  );
7937
- if (!Guard12.isUndefined(baseConfig.voiceIds)) {
7938
- assertArg(isVoiceId(baseConfig.voiceIds) || Guard12.isArray(baseConfig.voiceIds) && baseConfig.voiceIds.every((voiceId) => isVoiceId(voiceId)));
8491
+ if (!guard_exports.isUndefined(baseConfig.voiceIds)) {
8492
+ assertArg(isVoiceId(baseConfig.voiceIds) || guard_exports.isArray(baseConfig.voiceIds) && baseConfig.voiceIds.every((voiceId) => isVoiceId(voiceId)));
7939
8493
  console.warn(`Staff/tab config property 'voiceIds' is deprecated, use 'voiceId' instead.`);
7940
- let arr = Utils12.Arr.toArray((_a = baseConfig.voiceId) != null ? _a : []);
7941
- Utils12.Arr.toArray(baseConfig.voiceIds).forEach((voiceId) => arr.push(voiceId));
8494
+ let arr = utils_exports.Arr.toArray((_a = baseConfig.voiceId) != null ? _a : []);
8495
+ utils_exports.Arr.toArray(baseConfig.voiceIds).forEach((voiceId) => arr.push(voiceId));
7942
8496
  baseConfig.voiceId = arr;
7943
8497
  }
7944
- if (Guard12.isArray(baseConfig.voiceId)) {
7945
- baseConfig.voiceId = Utils12.Arr.removeDuplicates(baseConfig.voiceId);
8498
+ if (guard_exports.isArray(baseConfig.voiceId)) {
8499
+ baseConfig.voiceId = utils_exports.Arr.removeDuplicates(baseConfig.voiceId);
7946
8500
  }
7947
- assertArg(Guard12.isStringOrUndefined(baseConfig.instrument));
8501
+ assertArg(guard_exports.isStringOrUndefined(baseConfig.instrument));
7948
8502
  }
7949
8503
  function assertStaffConfig(staffConfig) {
7950
8504
  assertBaseConfig(staffConfig);
7951
8505
  assertArg(
7952
- Guard12.isObject(staffConfig),
7953
- Guard12.isStrictEqual(staffConfig.type, "staff"),
7954
- Guard12.isEnumValue(staffConfig.clef, Clef),
7955
- Guard12.isBooleanOrUndefined(staffConfig.isOctaveDown),
7956
- Guard12.isUndefined(staffConfig.minNote) || Note10.isNote(staffConfig.minNote),
7957
- Guard12.isUndefined(staffConfig.maxNote) || Note10.isNote(staffConfig.maxNote),
7958
- Guard12.isStringOrUndefined(staffConfig.grandId),
7959
- Guard12.isBooleanOrUndefined(staffConfig.isGrand)
8506
+ guard_exports.isObject(staffConfig),
8507
+ guard_exports.isStrictEqual(staffConfig.type, "staff"),
8508
+ guard_exports.isEnumValue(staffConfig.clef, Clef),
8509
+ guard_exports.isBooleanOrUndefined(staffConfig.isOctaveDown),
8510
+ guard_exports.isUndefined(staffConfig.minNote) || Note10.isNote(staffConfig.minNote),
8511
+ guard_exports.isUndefined(staffConfig.maxNote) || Note10.isNote(staffConfig.maxNote),
8512
+ guard_exports.isStringOrUndefined(staffConfig.grandId),
8513
+ guard_exports.isBooleanOrUndefined(staffConfig.isGrand)
7960
8514
  );
7961
- if (!Guard12.isUndefined(staffConfig.isGrand))
8515
+ if (!guard_exports.isUndefined(staffConfig.isGrand))
7962
8516
  console.warn(`Staff config property 'isGrand' is deprecated, use 'grandId' instead.`);
7963
8517
  }
7964
8518
  function assertTabConfig(tabConfig) {
7965
8519
  assertBaseConfig(tabConfig);
7966
8520
  assertArg(
7967
- Guard12.isObject(tabConfig),
7968
- Guard12.isStrictEqual(tabConfig.type, "tab"),
7969
- Guard12.isUndefined(tabConfig.tuning) || Guard12.isString(tabConfig.tuning) && Guard12.isIncluded(tabConfig.tuning, TuningNameList) || Guard12.isArray(tabConfig.tuning) && Guard12.isStrictEqual(tabConfig.tuning.length, getStringNumbers().length && tabConfig.tuning.every((s) => Note10.isNote(s)))
8521
+ guard_exports.isObject(tabConfig),
8522
+ guard_exports.isStrictEqual(tabConfig.type, "tab"),
8523
+ guard_exports.isUndefined(tabConfig.tuning) || guard_exports.isString(tabConfig.tuning) && guard_exports.isIncluded(tabConfig.tuning, TuningNameList) || guard_exports.isArray(tabConfig.tuning) && guard_exports.isStrictEqual(tabConfig.tuning.length, getStringNumbers().length && tabConfig.tuning.every((s) => Note10.isNote(s)))
7970
8524
  );
7971
8525
  }
7972
8526
  function assertNoteOptions(noteOptions) {
7973
8527
  assertArg(
7974
- Guard12.isObject(noteOptions),
7975
- Guard12.isBooleanOrUndefined(noteOptions.dotted) || Guard12.isIntegerGte(noteOptions.dotted, 0),
7976
- Guard12.isEnumValueOrUndefined(noteOptions.stem, Stem),
7977
- Guard12.isStringOrUndefined(noteOptions.color),
7978
- Guard12.isBooleanOrUndefined(noteOptions.arpeggio) || Guard12.isEnumValue(noteOptions.arpeggio, Arpeggio),
7979
- Guard12.isBooleanOrUndefined(noteOptions.staccato),
7980
- Guard12.isBooleanOrUndefined(noteOptions.diamond),
7981
- Guard12.isBooleanOrUndefined(noteOptions.triplet),
7982
- Guard12.isUndefined(noteOptions.string) || isStringNumber(noteOptions.string) || Guard12.isEmptyArray(noteOptions.string) || Guard12.isNonEmptyArray(noteOptions.string) && noteOptions.string.every((string) => isStringNumber(string))
8528
+ guard_exports.isObject(noteOptions),
8529
+ guard_exports.isBooleanOrUndefined(noteOptions.dotted) || guard_exports.isIntegerGte(noteOptions.dotted, 0),
8530
+ guard_exports.isEnumValueOrUndefined(noteOptions.stem, Stem),
8531
+ guard_exports.isStringOrUndefined(noteOptions.color),
8532
+ guard_exports.isBooleanOrUndefined(noteOptions.arpeggio) || guard_exports.isEnumValue(noteOptions.arpeggio, Arpeggio),
8533
+ guard_exports.isBooleanOrUndefined(noteOptions.staccato),
8534
+ guard_exports.isBooleanOrUndefined(noteOptions.diamond),
8535
+ guard_exports.isBooleanOrUndefined(noteOptions.triplet),
8536
+ guard_exports.isUndefined(noteOptions.string) || isStringNumber(noteOptions.string) || guard_exports.isEmptyArray(noteOptions.string) || guard_exports.isNonEmptyArray(noteOptions.string) && noteOptions.string.every((string) => isStringNumber(string))
7983
8537
  );
7984
- assertArgMsg(Guard12.isUndefined(noteOptions.tieSpan), `NoteOptions.tieSpan was removed. Use addConnective("tie", tieSpan)`);
7985
- assertArgMsg(Guard12.isUndefined(noteOptions.slurSpan), `NoteOptions.slurSpan was removed. Use addConnective("slur", slurSpan)`);
8538
+ assertArgMsg(guard_exports.isUndefined(noteOptions.tieSpan), `NoteOptions.tieSpan was removed. Use addConnective("tie", tieSpan)`);
8539
+ assertArgMsg(guard_exports.isUndefined(noteOptions.slurSpan), `NoteOptions.slurSpan was removed. Use addConnective("slur", slurSpan)`);
7986
8540
  }
7987
8541
  function assertRestOptions(restOptions) {
7988
8542
  assertArg(
7989
- Guard12.isObject(restOptions),
7990
- Guard12.isBooleanOrUndefined(restOptions.dotted) || Guard12.isIntegerGte(restOptions.dotted, 0),
7991
- Guard12.isStringOrUndefined(restOptions.staffPos) || Guard12.isInteger(restOptions.staffPos) || restOptions.staffPos instanceof Note10,
7992
- Guard12.isStringOrUndefined(restOptions.color),
7993
- Guard12.isBooleanOrUndefined(restOptions.hide),
7994
- Guard12.isBooleanOrUndefined(restOptions.triplet)
8543
+ guard_exports.isObject(restOptions),
8544
+ guard_exports.isBooleanOrUndefined(restOptions.dotted) || guard_exports.isIntegerGte(restOptions.dotted, 0),
8545
+ guard_exports.isStringOrUndefined(restOptions.staffPos) || guard_exports.isInteger(restOptions.staffPos) || restOptions.staffPos instanceof Note10,
8546
+ guard_exports.isStringOrUndefined(restOptions.color),
8547
+ guard_exports.isBooleanOrUndefined(restOptions.hide),
8548
+ guard_exports.isBooleanOrUndefined(restOptions.triplet)
7995
8549
  );
7996
8550
  }
7997
8551
  function assertLyricsOptions(lyricsOptions) {
7998
8552
  assertArg(
7999
- Guard12.isObject(lyricsOptions),
8000
- Guard12.isEnumValueOrUndefined(lyricsOptions.align, LyricsAlign),
8001
- Guard12.isEnumValueOrUndefined(lyricsOptions.hyphen, LyricsHyphen)
8553
+ guard_exports.isObject(lyricsOptions),
8554
+ guard_exports.isEnumValueOrUndefined(lyricsOptions.align, LyricsAlign),
8555
+ guard_exports.isEnumValueOrUndefined(lyricsOptions.hyphen, LyricsHyphen)
8002
8556
  );
8003
8557
  }
8004
8558
  function assertMeasureOptions(measureOptions) {
8005
8559
  assertArg(
8006
- Guard12.isObject(measureOptions),
8007
- Guard12.isBooleanOrUndefined(measureOptions.showNumber)
8560
+ guard_exports.isObject(measureOptions),
8561
+ guard_exports.isBooleanOrUndefined(measureOptions.showNumber)
8008
8562
  );
8009
8563
  }
8010
8564
  function assertStaffTabOrGRoups(staffTabOrGroups) {
8011
8565
  assertArg(
8012
- Guard12.isStringOrUndefined(staffTabOrGroups) || Guard12.isIntegerGte(staffTabOrGroups, 0) || Guard12.isNonEmptyArray(staffTabOrGroups) && staffTabOrGroups.every((staffTabOrGroup) => Guard12.isString(staffTabOrGroup) || Guard12.isIntegerGte(staffTabOrGroup, 0))
8566
+ guard_exports.isStringOrUndefined(staffTabOrGroups) || guard_exports.isIntegerGte(staffTabOrGroups, 0) || guard_exports.isNonEmptyArray(staffTabOrGroups) && staffTabOrGroups.every((staffTabOrGroup) => guard_exports.isString(staffTabOrGroup) || guard_exports.isIntegerGte(staffTabOrGroup, 0))
8013
8567
  );
8014
8568
  }
8015
8569
  var _DocumentBuilder = class _DocumentBuilder {
@@ -8023,19 +8577,19 @@ var _DocumentBuilder = class _DocumentBuilder {
8023
8577
  }
8024
8578
  setScoreConfiguration(config) {
8025
8579
  setAssertFunction("setScoreConfiguration", config);
8026
- if (Guard12.isEnumValue(config, StaffPreset)) {
8580
+ if (guard_exports.isEnumValue(config, StaffPreset)) {
8027
8581
  this.doc.setScoreConfiguration(config);
8028
- } else if (Guard12.isObject(config) && config.type === "staff") {
8582
+ } else if (guard_exports.isObject(config) && config.type === "staff") {
8029
8583
  assertStaffConfig(config);
8030
8584
  this.doc.setScoreConfiguration(config);
8031
- } else if (Guard12.isObject(config) && config.type === "tab") {
8585
+ } else if (guard_exports.isObject(config) && config.type === "tab") {
8032
8586
  assertTabConfig(config);
8033
8587
  this.doc.setScoreConfiguration(config);
8034
- } else if (Guard12.isNonEmptyArray(config)) {
8588
+ } else if (guard_exports.isNonEmptyArray(config)) {
8035
8589
  config.forEach((c) => {
8036
- if (Guard12.isObject(c) && c.type === "staff") {
8590
+ if (guard_exports.isObject(c) && c.type === "staff") {
8037
8591
  assertStaffConfig(c);
8038
- } else if (Guard12.isObject(c) && c.type === "tab") {
8592
+ } else if (guard_exports.isObject(c) && c.type === "tab") {
8039
8593
  assertTabConfig(c);
8040
8594
  } else {
8041
8595
  assertArg(false);
@@ -8068,9 +8622,9 @@ var _DocumentBuilder = class _DocumentBuilder {
8068
8622
  setHeader(title, composer, arranger) {
8069
8623
  setAssertFunction("setHeader", title, composer, arranger);
8070
8624
  assertArg(
8071
- Guard12.isStringOrUndefined(title),
8072
- Guard12.isStringOrUndefined(composer),
8073
- Guard12.isStringOrUndefined(arranger)
8625
+ guard_exports.isStringOrUndefined(title),
8626
+ guard_exports.isStringOrUndefined(composer),
8627
+ guard_exports.isStringOrUndefined(arranger)
8074
8628
  );
8075
8629
  this.doc.setHeader(title, composer, arranger);
8076
8630
  return this;
@@ -8082,7 +8636,7 @@ var _DocumentBuilder = class _DocumentBuilder {
8082
8636
  */
8083
8637
  setMeasuresPerRow(measuresPerRow) {
8084
8638
  setAssertFunction("setMeasuresPerRow", measuresPerRow);
8085
- assertArg(Guard12.isIntegerGte(measuresPerRow, 1) || Guard12.isPosInfinity(measuresPerRow));
8639
+ assertArg(guard_exports.isIntegerGte(measuresPerRow, 1) || guard_exports.isPosInfinity(measuresPerRow));
8086
8640
  this.doc.setMeasuresPerRow(measuresPerRow);
8087
8641
  return this;
8088
8642
  }
@@ -8100,7 +8654,7 @@ var _DocumentBuilder = class _DocumentBuilder {
8100
8654
  }
8101
8655
  setKeySignature(...args) {
8102
8656
  setAssertFunction("setKeySignature", ...args);
8103
- assertArg(args[0] instanceof Scale2 || args[0] instanceof KeySignature3 || Guard12.isNonEmptyString(args[0]) && Guard12.isEnumValueOrUndefined(args[1], ScaleType));
8657
+ assertArg(args[0] instanceof Scale2 || args[0] instanceof KeySignature3 || guard_exports.isNonEmptyString(args[0]) && guard_exports.isEnumValueOrUndefined(args[1], ScaleType));
8104
8658
  this.getMeasure().setKeySignature(...args);
8105
8659
  return this;
8106
8660
  }
@@ -8108,9 +8662,9 @@ var _DocumentBuilder = class _DocumentBuilder {
8108
8662
  setAssertFunction("setTimeSignature", ...args);
8109
8663
  if (args[0] instanceof TimeSignature2) {
8110
8664
  this.getMeasure().setTimeSignature(args[0]);
8111
- } else if (Guard12.isEnumValue(args[0], TimeSignatures) && Guard12.isEnumValueOrUndefined(args[1], BeamGrouping)) {
8665
+ } else if (guard_exports.isEnumValue(args[0], TimeSignatures) && guard_exports.isEnumValueOrUndefined(args[1], BeamGrouping)) {
8112
8666
  this.getMeasure().setTimeSignature(new TimeSignature2(args[0], args[1]));
8113
- } else if (Guard12.isIntegerGte(args[0], 1) && Guard12.isIntegerGte(args[1], 1) && Guard12.isEnumValueOrUndefined(args[2], BeamGrouping)) {
8667
+ } else if (guard_exports.isIntegerGte(args[0], 1) && guard_exports.isIntegerGte(args[1], 1) && guard_exports.isEnumValueOrUndefined(args[2], BeamGrouping)) {
8114
8668
  this.getMeasure().setTimeSignature(new TimeSignature2(args[0], args[1], args[2]));
8115
8669
  } else {
8116
8670
  assertArg(false);
@@ -8120,8 +8674,8 @@ var _DocumentBuilder = class _DocumentBuilder {
8120
8674
  setTempo(beatsPerMinute, beatLength, dotted) {
8121
8675
  setAssertFunction("setTempo", beatsPerMinute, beatLength, dotted);
8122
8676
  assertArg(
8123
- Guard12.isIntegerGte(beatsPerMinute, 1),
8124
- Guard12.isUndefined(beatLength) && Guard12.isUndefined(dotted) || isNoteLength(beatLength) && (Guard12.isBooleanOrUndefined(dotted) || Guard12.isIntegerGte(dotted, 0))
8677
+ guard_exports.isIntegerGte(beatsPerMinute, 1),
8678
+ guard_exports.isUndefined(beatLength) && guard_exports.isUndefined(dotted) || isNoteLength(beatLength) && (guard_exports.isBooleanOrUndefined(dotted) || guard_exports.isIntegerGte(dotted, 0))
8125
8679
  );
8126
8680
  this.getMeasure().setTempo(beatsPerMinute, beatLength, dotted);
8127
8681
  return this;
@@ -8138,15 +8692,15 @@ var _DocumentBuilder = class _DocumentBuilder {
8138
8692
  setAssertFunction("addNote", voiceId, note, noteLength, noteOptions);
8139
8693
  assertArg(
8140
8694
  isVoiceId(voiceId),
8141
- note instanceof Note10 || Guard12.isNonEmptyString(note) || Guard12.isArray(note) && note.every((note2) => note2 instanceof Note10 || Guard12.isNonEmptyString(note2)),
8695
+ note instanceof Note10 || guard_exports.isNonEmptyString(note) || guard_exports.isArray(note) && note.every((note2) => note2 instanceof Note10 || guard_exports.isNonEmptyString(note2)),
8142
8696
  isNoteLength(noteLength)
8143
8697
  );
8144
8698
  noteOptions != null ? noteOptions : noteOptions = {};
8145
8699
  assertNoteOptions(noteOptions);
8146
- if (Guard12.isArray(note)) {
8700
+ if (guard_exports.isArray(note)) {
8147
8701
  let string = noteOptions.string;
8148
8702
  note.forEach((note2, noteId) => {
8149
- noteOptions.string = Guard12.isArray(string) ? string[noteId] : string;
8703
+ noteOptions.string = guard_exports.isArray(string) ? string[noteId] : string;
8150
8704
  this.getMeasure().addNoteGroup(voiceId, [note2], noteLength, noteOptions);
8151
8705
  });
8152
8706
  } else {
@@ -8166,7 +8720,7 @@ var _DocumentBuilder = class _DocumentBuilder {
8166
8720
  setAssertFunction("addChord", voiceId, notes, noteLength, noteOptions);
8167
8721
  assertArg(
8168
8722
  isVoiceId(voiceId),
8169
- Guard12.isNonEmptyArray(notes) && notes.every((note) => note instanceof Note10 || Guard12.isNonEmptyString(note)),
8723
+ guard_exports.isNonEmptyArray(notes) && notes.every((note) => note instanceof Note10 || guard_exports.isNonEmptyString(note)),
8170
8724
  isNoteLength(noteLength)
8171
8725
  );
8172
8726
  noteOptions != null ? noteOptions : noteOptions = {};
@@ -8211,24 +8765,24 @@ var _DocumentBuilder = class _DocumentBuilder {
8211
8765
  setAssertFunction("addTuplet", voiceId, tupletRatio);
8212
8766
  assertArg(
8213
8767
  isVoiceId(voiceId),
8214
- Guard12.isFunction(tupletBuilder),
8215
- isTupletRatio(tupletRatio) && Guard12.isBooleanOrUndefined(tupletRatio.showRatio)
8768
+ guard_exports.isFunction(tupletBuilder),
8769
+ isTupletRatio(tupletRatio) && guard_exports.isBooleanOrUndefined(tupletRatio.showRatio)
8216
8770
  );
8217
8771
  let tupletSymbols = [];
8218
8772
  const helper = {
8219
8773
  addNote: (note, noteLength, noteOptions) => {
8220
8774
  setAssertFunction("addTuplet => addNote", note, noteLength, noteOptions);
8221
8775
  assertArg(
8222
- note instanceof Note10 || Guard12.isNonEmptyString(note) || Guard12.isArray(note) && note.every((note2) => note2 instanceof Note10 || Guard12.isNonEmptyString(note2)),
8776
+ note instanceof Note10 || guard_exports.isNonEmptyString(note) || guard_exports.isArray(note) && note.every((note2) => note2 instanceof Note10 || guard_exports.isNonEmptyString(note2)),
8223
8777
  isNoteLength(noteLength)
8224
8778
  );
8225
8779
  noteOptions != null ? noteOptions : noteOptions = {};
8226
8780
  delete noteOptions.triplet;
8227
8781
  assertNoteOptions(noteOptions);
8228
- if (Guard12.isArray(note)) {
8782
+ if (guard_exports.isArray(note)) {
8229
8783
  let string = noteOptions.string;
8230
8784
  note.forEach((note2, noteId) => {
8231
- noteOptions.string = Guard12.isArray(string) ? string[noteId] : string;
8785
+ noteOptions.string = guard_exports.isArray(string) ? string[noteId] : string;
8232
8786
  let s = this.getMeasure().addNoteGroup(voiceId, [note2], noteLength, noteOptions, tupletRatio);
8233
8787
  tupletSymbols.push(s);
8234
8788
  });
@@ -8241,7 +8795,7 @@ var _DocumentBuilder = class _DocumentBuilder {
8241
8795
  addChord: (notes, noteLength, noteOptions) => {
8242
8796
  setAssertFunction("addTuplet => addChord", notes, noteLength, noteOptions);
8243
8797
  assertArg(
8244
- Guard12.isNonEmptyArray(notes) && notes.every((note) => note instanceof Note10 || Guard12.isNonEmptyString(note)),
8798
+ guard_exports.isNonEmptyArray(notes) && notes.every((note) => note instanceof Note10 || guard_exports.isNonEmptyString(note)),
8245
8799
  isNoteLength(noteLength)
8246
8800
  );
8247
8801
  noteOptions != null ? noteOptions : noteOptions = {};
@@ -8271,8 +8825,8 @@ var _DocumentBuilder = class _DocumentBuilder {
8271
8825
  assertStaffTabOrGRoups(staffTabOrGroups);
8272
8826
  assertArg(
8273
8827
  isVerseNumber(verse),
8274
- Guard12.isEnumValue(lyricsLength, NoteLength8),
8275
- Guard12.isString(lyricsText) || Guard12.isArray(lyricsText) && lyricsText.every((text) => Guard12.isString(text))
8828
+ guard_exports.isEnumValue(lyricsLength, NoteLength8),
8829
+ guard_exports.isString(lyricsText) || guard_exports.isArray(lyricsText) && lyricsText.every((text) => guard_exports.isString(text))
8276
8830
  );
8277
8831
  lyricsOptions != null ? lyricsOptions : lyricsOptions = {};
8278
8832
  assertLyricsOptions(lyricsOptions);
@@ -8281,7 +8835,7 @@ var _DocumentBuilder = class _DocumentBuilder {
8281
8835
  } else {
8282
8836
  (_a = lyricsOptions.align) != null ? _a : lyricsOptions.align = this.currentLyricsAlign;
8283
8837
  }
8284
- if (Guard12.isArray(lyricsText)) {
8838
+ if (guard_exports.isArray(lyricsText)) {
8285
8839
  lyricsText.forEach((text) => this.getMeasure().addLyrics(staffTabOrGroups, verse, lyricsLength, text, lyricsOptions));
8286
8840
  } else {
8287
8841
  this.getMeasure().addLyrics(staffTabOrGroups, verse, lyricsLength, lyricsText, lyricsOptions);
@@ -8315,7 +8869,7 @@ var _DocumentBuilder = class _DocumentBuilder {
8315
8869
  }
8316
8870
  addFermataInternal(staffTabOrGroups, fermata) {
8317
8871
  assertStaffTabOrGRoups(staffTabOrGroups);
8318
- assertArg(Guard12.isEnumValue(fermata, Fermata));
8872
+ assertArg(guard_exports.isEnumValue(fermata, Fermata));
8319
8873
  this.getMeasure().addFermata(staffTabOrGroups, fermata);
8320
8874
  return this;
8321
8875
  }
@@ -8341,7 +8895,7 @@ var _DocumentBuilder = class _DocumentBuilder {
8341
8895
  addNavigationInternal(staffTabOrGroups, navigation, ...args) {
8342
8896
  assertStaffTabOrGRoups(staffTabOrGroups);
8343
8897
  assertArg(
8344
- Guard12.isStrictEqual(navigation, "endRepeat" /* EndRepeat */) && Guard12.isStrictEqual(args.length, 1) || Guard12.isStrictEqual(navigation, "ending" /* Ending */) && Guard12.isIntegerGte(args.length, 1) && args.every((passage) => Guard12.isIntegerGte(passage, 1)) || Guard12.isEnumValue(navigation, Navigation) && Guard12.isEmptyArray(args)
8898
+ guard_exports.isStrictEqual(navigation, "endRepeat" /* EndRepeat */) && guard_exports.isStrictEqual(args.length, 1) || guard_exports.isStrictEqual(navigation, "ending" /* Ending */) && guard_exports.isIntegerGte(args.length, 1) && args.every((passage) => guard_exports.isIntegerGte(passage, 1)) || guard_exports.isEnumValue(navigation, Navigation) && guard_exports.isEmptyArray(args)
8345
8899
  );
8346
8900
  this.getMeasure().addNavigation(staffTabOrGroups, navigation, ...args);
8347
8901
  return this;
@@ -8357,12 +8911,12 @@ var _DocumentBuilder = class _DocumentBuilder {
8357
8911
  addAnnotationInternal(staffTabOrGroups, annotation, text) {
8358
8912
  annotation != null ? annotation : annotation = getAnnotation(text);
8359
8913
  if (annotation === void 0) {
8360
- throw new MusicError18(MusicErrorType18.Score, `Annotation text "${text}" is not known annotation.`);
8914
+ throw new MusicError16(MusicErrorType16.Score, `Annotation text "${text}" is not known annotation.`);
8361
8915
  }
8362
8916
  assertStaffTabOrGRoups(staffTabOrGroups);
8363
8917
  assertArg(
8364
- Guard12.isEnumValue(annotation, Annotation),
8365
- Guard12.isNonEmptyString(text)
8918
+ guard_exports.isEnumValue(annotation, Annotation),
8919
+ guard_exports.isNonEmptyString(text)
8366
8920
  );
8367
8921
  this.getMeasure().addAnnotation(staffTabOrGroups, annotation, text);
8368
8922
  return this;
@@ -8386,8 +8940,8 @@ var _DocumentBuilder = class _DocumentBuilder {
8386
8940
  addLabelInternal(staffTabOrGroups, label, text) {
8387
8941
  assertStaffTabOrGRoups(staffTabOrGroups);
8388
8942
  assertArg(
8389
- Guard12.isEnumValue(label, Label),
8390
- Guard12.isNonEmptyString(text)
8943
+ guard_exports.isEnumValue(label, Label),
8944
+ guard_exports.isNonEmptyString(text)
8391
8945
  );
8392
8946
  this.getMeasure().addLabel(staffTabOrGroups, label, text);
8393
8947
  return this;
@@ -8415,21 +8969,21 @@ var _DocumentBuilder = class _DocumentBuilder {
8415
8969
  }
8416
8970
  addConnective(connective, ...args) {
8417
8971
  setAssertFunction("addConnective", connective, ...args);
8418
- assertArg(Guard12.isEnumValue(connective, Connective));
8972
+ assertArg(guard_exports.isEnumValue(connective, Connective));
8419
8973
  if (connective === "tie" /* Tie */) {
8420
- assertArg(Guard12.isIntegerOrUndefined(args[0]) || Guard12.isEnumValue(args[0], TieType));
8421
- assertArg(Guard12.isEnumValueOrUndefined(args[1], NoteAnchor));
8974
+ assertArg(guard_exports.isIntegerOrUndefined(args[0]) || guard_exports.isEnumValue(args[0], TieType));
8975
+ assertArg(guard_exports.isEnumValueOrUndefined(args[1], NoteAnchor));
8422
8976
  let tieSpan = args[0];
8423
8977
  let noteAnchor = args[1];
8424
8978
  this.getMeasure().addConnective(connective, tieSpan, noteAnchor);
8425
8979
  } else if (connective === "slur" /* Slur */) {
8426
- assertArg(Guard12.isIntegerOrUndefined(args[0]));
8427
- assertArg(Guard12.isEnumValueOrUndefined(args[1], NoteAnchor));
8980
+ assertArg(guard_exports.isIntegerOrUndefined(args[0]));
8981
+ assertArg(guard_exports.isEnumValueOrUndefined(args[1], NoteAnchor));
8428
8982
  let slurSpan = args[0];
8429
8983
  let noteAnchor = args[1];
8430
8984
  this.getMeasure().addConnective(connective, slurSpan, noteAnchor);
8431
8985
  } else if (connective === "slide" /* Slide */) {
8432
- assertArg(Guard12.isEnumValueOrUndefined(args[0], NoteAnchor));
8986
+ assertArg(guard_exports.isEnumValueOrUndefined(args[0], NoteAnchor));
8433
8987
  let noteAnchor = args[0];
8434
8988
  this.getMeasure().addConnective(connective, noteAnchor);
8435
8989
  }
@@ -8449,20 +9003,20 @@ var _DocumentBuilder = class _DocumentBuilder {
8449
9003
  */
8450
9004
  addExtension(extensionBuilder) {
8451
9005
  setAssertFunction("addExtension");
8452
- assertArgMsg(Guard12.isFunctionOrUndefined(extensionBuilder), "addExtension() has new usage, e.g. addExtension(ext => ext.measures(2)).");
9006
+ assertArgMsg(guard_exports.isFunctionOrUndefined(extensionBuilder), "addExtension() has new usage, e.g. addExtension(ext => ext.measures(2)).");
8453
9007
  let ticks = 0;
8454
9008
  let visible = true;
8455
9009
  const helper = {
8456
9010
  notes: (noteLength, noteCount) => {
8457
9011
  setAssertFunction("addExtension.notes", noteLength, noteCount);
8458
9012
  assertArg(isNoteLength(noteLength));
8459
- assertArg(Guard12.isUndefined(noteCount) || Guard12.isNumber(noteCount) && noteCount >= 0);
9013
+ assertArg(guard_exports.isUndefined(noteCount) || guard_exports.isNumber(noteCount) && noteCount >= 0);
8460
9014
  ticks += RhythmProps6.get(noteLength).ticks * (noteCount != null ? noteCount : 1);
8461
9015
  return helper;
8462
9016
  },
8463
9017
  measures: (measureCount) => {
8464
9018
  setAssertFunction("addExtension.measures", measureCount);
8465
- assertArg(Guard12.isNumber(measureCount) && measureCount >= 1);
9019
+ assertArg(guard_exports.isNumber(measureCount) && measureCount >= 1);
8466
9020
  ticks += this.getMeasure().getMeasureTicks() * measureCount;
8467
9021
  return helper;
8468
9022
  },
@@ -8495,9 +9049,9 @@ var _DocumentBuilder = class _DocumentBuilder {
8495
9049
  addStaffGroup(groupName, staffsTabsAndGroups, verticalPosition = "auto" /* Auto */) {
8496
9050
  setAssertFunction("addStaffGroup", groupName, staffsTabsAndGroups, verticalPosition);
8497
9051
  assertArg(
8498
- Guard12.isNonEmptyString(groupName),
8499
- Guard12.isNonEmptyString(staffsTabsAndGroups) || Guard12.isIntegerGte(staffsTabsAndGroups, 0) || Guard12.isNonEmptyArray(staffsTabsAndGroups) && staffsTabsAndGroups.every((line) => Guard12.isNonEmptyString(line) || Guard12.isIntegerGte(line, 0)),
8500
- Guard12.isEnumValue(verticalPosition, VerticalPosition)
9052
+ guard_exports.isNonEmptyString(groupName),
9053
+ guard_exports.isNonEmptyString(staffsTabsAndGroups) || guard_exports.isIntegerGte(staffsTabsAndGroups, 0) || guard_exports.isNonEmptyArray(staffsTabsAndGroups) && staffsTabsAndGroups.every((line) => guard_exports.isNonEmptyString(line) || guard_exports.isIntegerGte(line, 0)),
9054
+ guard_exports.isEnumValue(verticalPosition, VerticalPosition)
8501
9055
  );
8502
9056
  this.doc.addStaffGroup(groupName, staffsTabsAndGroups, verticalPosition);
8503
9057
  return this;
@@ -8537,7 +9091,7 @@ var _DocumentBuilder = class _DocumentBuilder {
8537
9091
  */
8538
9092
  completeRests(voiceId) {
8539
9093
  setAssertFunction("completeRests", voiceId);
8540
- assertArg(Guard12.isUndefined(voiceId) || isVoiceId(voiceId) || Guard12.isArray(voiceId) && voiceId.every((id) => isVoiceId(id)));
9094
+ assertArg(guard_exports.isUndefined(voiceId) || isVoiceId(voiceId) || guard_exports.isArray(voiceId) && voiceId.every((id) => isVoiceId(id)));
8541
9095
  this.getMeasure().completeRests(voiceId);
8542
9096
  return this;
8543
9097
  }
@@ -8551,8 +9105,8 @@ var _DocumentBuilder = class _DocumentBuilder {
8551
9105
  addScaleArpeggio(scale, bottomNote, numOctaves) {
8552
9106
  setAssertFunction("addScaleArpeggio", scale, bottomNote, numOctaves);
8553
9107
  assertArg(
8554
- Guard12.isNonEmptyString(bottomNote),
8555
- Guard12.isIntegerGte(numOctaves, 1)
9108
+ guard_exports.isNonEmptyString(bottomNote),
9109
+ guard_exports.isIntegerGte(numOctaves, 1)
8556
9110
  );
8557
9111
  let ts = this.getMeasure().getTimeSignature();
8558
9112
  let notes = scale.getScaleNotes(bottomNote, numOctaves);
@@ -8571,7 +9125,7 @@ __publicField(_DocumentBuilder, "DefaultMeasureOptions", {});
8571
9125
  var DocumentBuilder = _DocumentBuilder;
8572
9126
 
8573
9127
  // src/score/pub/event.ts
8574
- import { MusicError as MusicError19, MusicErrorType as MusicErrorType19 } from "@tspro/web-music-score/core";
9128
+ import { MusicError as MusicError17, MusicErrorType as MusicErrorType17 } from "@tspro/web-music-score/core";
8575
9129
  var ScoreEvent = class {
8576
9130
  /**
8577
9131
  * Create new score event instance.
@@ -8614,7 +9168,7 @@ var ScoreObjectEvent = class extends ScoreEvent {
8614
9168
  this.renderContext = renderContext;
8615
9169
  this.objects = objects;
8616
9170
  if (arguments.length === 0) {
8617
- throw new MusicError19(MusicErrorType19.Score, "Empty array in score object event!");
9171
+ throw new MusicError17(MusicErrorType17.Score, "Empty array in score object event!");
8618
9172
  }
8619
9173
  }
8620
9174
  /**
@@ -8639,21 +9193,19 @@ var ScoreObjectEvent = class extends ScoreEvent {
8639
9193
 
8640
9194
  // src/score/pub/music-interface.ts
8641
9195
  import * as Audio2 from "@tspro/web-music-score/audio";
8642
- import { Guard as Guard14, UniMap as UniMap10, ValueSet as ValueSet2, Utils as Utils13 } from "@tspro/ts-utils-lib";
8643
9196
 
8644
9197
  // src/score/pub/music-objects.ts
8645
- import { Guard as Guard13 } from "@tspro/ts-utils-lib";
8646
- import { MusicError as MusicError20, MusicErrorType as MusicErrorType20 } from "@tspro/web-music-score/core";
9198
+ import { MusicError as MusicError18, MusicErrorType as MusicErrorType18 } from "@tspro/web-music-score/core";
8647
9199
  function assertArg2(condition, argName, argValue) {
8648
9200
  if (!condition) {
8649
- throw new MusicError20(MusicErrorType20.Score, `Invalid arg: ${argName} = ${argValue}`);
9201
+ throw new MusicError18(MusicErrorType18.Score, `Invalid arg: ${argName} = ${argValue}`);
8650
9202
  }
8651
9203
  }
8652
9204
  function getNotationLine(line) {
8653
9205
  if (line instanceof ObjStaff || line instanceof ObjTab) {
8654
9206
  return line.getMusicInterface();
8655
9207
  } else {
8656
- throw new MusicError20(MusicErrorType20.Score, `Notation line not staff nor tab.`);
9208
+ throw new MusicError18(MusicErrorType18.Score, `Notation line not staff nor tab.`);
8657
9209
  }
8658
9210
  }
8659
9211
  var MusicInterface5 = class {
@@ -8823,7 +9375,7 @@ var _MDocument = class _MDocument extends MusicInterface5 {
8823
9375
  * @returns - Player instance.
8824
9376
  */
8825
9377
  play(playStateChangeListener) {
8826
- assertArg2(Guard13.isFunctionOrUndefined(playStateChangeListener), "playStateChangeListener", playStateChangeListener);
9378
+ assertArg2(guard_exports.isFunctionOrUndefined(playStateChangeListener), "playStateChangeListener", playStateChangeListener);
8827
9379
  return new MPlayer(this, playStateChangeListener).play();
8828
9380
  }
8829
9381
  };
@@ -8853,7 +9405,7 @@ var _MEnding = class _MEnding extends MusicInterface5 {
8853
9405
  * @returns - Boolean whether this ending has asked passage number.
8854
9406
  */
8855
9407
  hasPassage(passage) {
8856
- assertArg2(Guard13.isIntegerGte(passage, 1), "passage", passage);
9408
+ assertArg2(guard_exports.isIntegerGte(passage, 1), "passage", passage);
8857
9409
  return this.obj.hasPassage(passage);
8858
9410
  }
8859
9411
  };
@@ -9005,7 +9557,7 @@ var _MStaffBarLine = class _MStaffBarLine extends MusicInterface5 {
9005
9557
  if (barLine instanceof ObjBarLineLeft || barLine instanceof ObjBarLineRight) {
9006
9558
  return barLine.getMusicInterface();
9007
9559
  } else {
9008
- throw new MusicError20(MusicErrorType20.Score, `Bar line not left nor right.`);
9560
+ throw new MusicError18(MusicErrorType18.Score, `Bar line not left nor right.`);
9009
9561
  }
9010
9562
  }
9011
9563
  /**
@@ -9539,10 +10091,10 @@ __publicField(_MExtensionLine, "Name", "ExtensionLine");
9539
10091
  var MExtensionLine = _MExtensionLine;
9540
10092
 
9541
10093
  // src/score/pub/music-interface.ts
9542
- import { MusicError as MusicError21, MusicErrorType as MusicErrorType21 } from "@tspro/web-music-score/core";
10094
+ import { MusicError as MusicError19, MusicErrorType as MusicErrorType19 } from "@tspro/web-music-score/core";
9543
10095
  function assertArg3(condition, argName, argValue) {
9544
10096
  if (!condition) {
9545
- throw new MusicError21(MusicErrorType21.Score, `Invalid arg: ${argName} = ${argValue}`);
10097
+ throw new MusicError19(MusicErrorType19.Score, `Invalid arg: ${argName} = ${argValue}`);
9546
10098
  }
9547
10099
  }
9548
10100
  function require_t(t, message) {
@@ -9561,7 +10113,7 @@ var _MPlayer = class _MPlayer {
9561
10113
  constructor(doc, playStateChangeListener) {
9562
10114
  __publicField(this, "player");
9563
10115
  assertArg3(doc instanceof MDocument2, "doc", doc);
9564
- assertArg3(Guard14.isFunctionOrUndefined(playStateChangeListener), "playStateChangeListener", playStateChangeListener);
10116
+ assertArg3(guard_exports.isFunctionOrUndefined(playStateChangeListener), "playStateChangeListener", playStateChangeListener);
9565
10117
  this.player = new Player();
9566
10118
  this.player.setDocument(doc.getMusicObject());
9567
10119
  this.player.setCursorPositionChangeListener((cursorRect) => {
@@ -9605,7 +10157,7 @@ var _MPlayer = class _MPlayer {
9605
10157
  return this;
9606
10158
  }
9607
10159
  };
9608
- __publicField(_MPlayer, "currentlyPlaying", new ValueSet2());
10160
+ __publicField(_MPlayer, "currentlyPlaying", new ValueSet());
9609
10161
  var MPlayer = _MPlayer;
9610
10162
  var MRenderContext2 = class {
9611
10163
  /**
@@ -9621,7 +10173,7 @@ var MRenderContext2 = class {
9621
10173
  * @returns - This render context instance.
9622
10174
  */
9623
10175
  setDocument(doc) {
9624
- assertArg3(Guard14.isUndefined(doc) || doc instanceof MDocument2, "doc", doc);
10176
+ assertArg3(guard_exports.isUndefined(doc) || doc instanceof MDocument2, "doc", doc);
9625
10177
  this.ctx.setDocument(doc);
9626
10178
  return this;
9627
10179
  }
@@ -9631,7 +10183,7 @@ var MRenderContext2 = class {
9631
10183
  * @returns - This render context instance.
9632
10184
  */
9633
10185
  setCanvas(canvas) {
9634
- canvas = require_t(Utils13.Dom.getCanvas(canvas), typeof canvas === "string" ? "Cannot set render canvas because invalid canvas id: " + canvas : "Cannot set render canvas because given canvas is undefined.");
10186
+ canvas = require_t(utils_exports.Dom.getCanvas(canvas), typeof canvas === "string" ? "Cannot set render canvas because invalid canvas id: " + canvas : "Cannot set render canvas because given canvas is undefined.");
9635
10187
  this.ctx.setCanvas(canvas);
9636
10188
  return this;
9637
10189
  }
@@ -9640,7 +10192,7 @@ var MRenderContext2 = class {
9640
10192
  * @param scoreEventListener - Score event listener.
9641
10193
  */
9642
10194
  setScoreEventListener(scoreEventListener) {
9643
- assertArg3(Guard14.isFunctionOrUndefined(scoreEventListener), "scoreEventListener", scoreEventListener);
10195
+ assertArg3(guard_exports.isFunctionOrUndefined(scoreEventListener), "scoreEventListener", scoreEventListener);
9644
10196
  this.ctx.setScoreEventListener(scoreEventListener);
9645
10197
  }
9646
10198
  /**
@@ -9715,7 +10267,7 @@ var _MPlaybackButtons = class _MPlaybackButtons {
9715
10267
  * @returns
9716
10268
  */
9717
10269
  setDocument(doc) {
9718
- assertArg3(Guard14.isUndefined(doc) || doc instanceof MDocument2, "doc", doc);
10270
+ assertArg3(guard_exports.isUndefined(doc) || doc instanceof MDocument2, "doc", doc);
9719
10271
  this.onStop();
9720
10272
  if (doc) {
9721
10273
  this.player = new MPlayer(doc, (playState) => {
@@ -9759,9 +10311,9 @@ var _MPlaybackButtons = class _MPlaybackButtons {
9759
10311
  * @returns - This playback buttons class instance.
9760
10312
  */
9761
10313
  setPlayButton(btn, btnLabel) {
9762
- assertArg3(Guard14.isStringOrUndefined(btnLabel), "btnLabel", btnLabel);
10314
+ assertArg3(guard_exports.isStringOrUndefined(btnLabel), "btnLabel", btnLabel);
9763
10315
  _MPlaybackButtons.removeOnClickListeners(this.playButton, this.onPlay);
9764
- this.playButton = require_t(Utils13.Dom.getButton(btn), "Play button required!");
10316
+ this.playButton = require_t(utils_exports.Dom.getButton(btn), "Play button required!");
9765
10317
  this.playLabel = btnLabel != null ? btnLabel : "Play";
9766
10318
  _MPlaybackButtons.removeOnClickListeners(this.playButton, "all");
9767
10319
  _MPlaybackButtons.addOnClickListener(this.playButton, this.onPlay);
@@ -9775,9 +10327,9 @@ var _MPlaybackButtons = class _MPlaybackButtons {
9775
10327
  * @returns - This playback buttons class instance.
9776
10328
  */
9777
10329
  setStopButton(btn, btnLabel) {
9778
- assertArg3(Guard14.isStringOrUndefined(btnLabel), "btnLabel", btnLabel);
10330
+ assertArg3(guard_exports.isStringOrUndefined(btnLabel), "btnLabel", btnLabel);
9779
10331
  _MPlaybackButtons.removeOnClickListeners(this.stopButton, this.onStop);
9780
- this.stopButton = require_t(Utils13.Dom.getButton(btn), "Stop button required!");
10332
+ this.stopButton = require_t(utils_exports.Dom.getButton(btn), "Stop button required!");
9781
10333
  this.stopLabel = btnLabel != null ? btnLabel : "Stop";
9782
10334
  _MPlaybackButtons.removeOnClickListeners(this.stopButton, "all");
9783
10335
  _MPlaybackButtons.addOnClickListener(this.stopButton, this.onStop);
@@ -9792,10 +10344,10 @@ var _MPlaybackButtons = class _MPlaybackButtons {
9792
10344
  * @returns - This playback buttons class instance.
9793
10345
  */
9794
10346
  setPlayStopButton(btn, playLabel, stopLabel) {
9795
- assertArg3(Guard14.isStringOrUndefined(playLabel), "playLabel", playLabel);
9796
- assertArg3(Guard14.isStringOrUndefined(stopLabel), "stopLabel", stopLabel);
10347
+ assertArg3(guard_exports.isStringOrUndefined(playLabel), "playLabel", playLabel);
10348
+ assertArg3(guard_exports.isStringOrUndefined(stopLabel), "stopLabel", stopLabel);
9797
10349
  _MPlaybackButtons.removeOnClickListeners(this.playStopButton, this.onPlayStop);
9798
- this.playStopButton = require_t(Utils13.Dom.getButton(btn), "Play/stop button required!");
10350
+ this.playStopButton = require_t(utils_exports.Dom.getButton(btn), "Play/stop button required!");
9799
10351
  this.playLabel = playLabel != null ? playLabel : "Play";
9800
10352
  this.stopLabel = stopLabel != null ? stopLabel : "Stop";
9801
10353
  _MPlaybackButtons.removeOnClickListeners(this.playStopButton, "all");
@@ -9810,9 +10362,9 @@ var _MPlaybackButtons = class _MPlaybackButtons {
9810
10362
  * @returns - This playback buttons class instance.
9811
10363
  */
9812
10364
  setPauseButton(btn, btnLabel) {
9813
- assertArg3(Guard14.isStringOrUndefined(btnLabel), "btnLabel", btnLabel);
10365
+ assertArg3(guard_exports.isStringOrUndefined(btnLabel), "btnLabel", btnLabel);
9814
10366
  _MPlaybackButtons.removeOnClickListeners(this.pauseButton, this.onPause);
9815
- this.pauseButton = require_t(Utils13.Dom.getButton(btn), "Pause button required!");
10367
+ this.pauseButton = require_t(utils_exports.Dom.getButton(btn), "Pause button required!");
9816
10368
  this.pauseLabel = btnLabel != null ? btnLabel : "Pause";
9817
10369
  _MPlaybackButtons.removeOnClickListeners(this.pauseButton, "all");
9818
10370
  _MPlaybackButtons.addOnClickListener(this.pauseButton, this.onPause);
@@ -9833,12 +10385,12 @@ var _MPlaybackButtons = class _MPlaybackButtons {
9833
10385
  this.savedOnClickListeners.set(btn, curListeners);
9834
10386
  }
9835
10387
  static addOnClickListener(btn, onClickListener) {
9836
- assertArg3(Guard14.isFunction(onClickListener), "onClick", onClickListener);
10388
+ assertArg3(guard_exports.isFunction(onClickListener), "onClick", onClickListener);
9837
10389
  btn.addEventListener("click", onClickListener);
9838
10390
  this.savedOnClickListeners.getOrCreate(btn, []).push(onClickListener);
9839
10391
  }
9840
10392
  };
9841
- __publicField(_MPlaybackButtons, "savedOnClickListeners", new UniMap10());
10393
+ __publicField(_MPlaybackButtons, "savedOnClickListeners", new UniMap());
9842
10394
  var MPlaybackButtons = _MPlaybackButtons;
9843
10395
 
9844
10396
  // src/score/index.ts
@@ -9909,6 +10461,7 @@ export {
9909
10461
  isStringNumber,
9910
10462
  isVerseNumber,
9911
10463
  isVoiceId,
10464
+ setColor,
9912
10465
  validateStringNumber,
9913
10466
  validateVerseNumber,
9914
10467
  validateVoiceId