@tspro/web-music-score 1.0.0 → 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (43) hide show
  1. package/CHANGELOG.md +19 -0
  2. package/README.md +271 -224
  3. package/dist/audio/index.d.mts +22 -0
  4. package/dist/audio/index.d.ts +22 -0
  5. package/dist/audio/index.js +147 -0
  6. package/dist/audio/index.mjs +109 -0
  7. package/dist/audio-cg/index.d.mts +4 -0
  8. package/dist/audio-cg/index.d.ts +4 -0
  9. package/dist/audio-cg/index.js +124 -0
  10. package/dist/audio-cg/index.mjs +91 -0
  11. package/dist/chunk-2EPWQZKJ.mjs +9 -0
  12. package/dist/core/index.d.mts +21 -0
  13. package/dist/core/index.d.ts +21 -0
  14. package/dist/core/index.js +72 -0
  15. package/dist/core/index.mjs +45 -0
  16. package/dist/guitar-BIFwFT31.d.ts +24 -0
  17. package/dist/guitar-kbJYu3Am.d.mts +24 -0
  18. package/dist/iife/index.global.js +222 -0
  19. package/dist/note-B5ZtlHc8.d.ts +99 -0
  20. package/dist/note-CraqEy8x.d.mts +99 -0
  21. package/dist/pieces/index.d.mts +15 -0
  22. package/dist/pieces/index.d.ts +15 -0
  23. package/dist/pieces/index.js +104 -0
  24. package/dist/pieces/index.mjs +77 -0
  25. package/dist/react-ui/index.d.mts +169 -0
  26. package/dist/react-ui/index.d.ts +169 -0
  27. package/dist/react-ui/index.js +624 -0
  28. package/dist/react-ui/index.mjs +582 -0
  29. package/dist/score/index.d.mts +1558 -0
  30. package/dist/score/index.d.ts +1558 -0
  31. package/dist/score/index.js +6937 -0
  32. package/dist/score/index.mjs +6863 -0
  33. package/dist/tempo--588tdcv.d.ts +203 -0
  34. package/dist/tempo-BEJBHZ5I.d.mts +203 -0
  35. package/dist/theory/index.d.mts +47 -0
  36. package/dist/theory/index.d.ts +47 -0
  37. package/dist/theory/index.js +1783 -0
  38. package/dist/theory/index.mjs +1716 -0
  39. package/package.json +99 -56
  40. package/dist/index.cjs.js +0 -40708
  41. package/dist/index.d.ts +0 -1258
  42. package/dist/index.esm.mjs +0 -40699
  43. package/dist/index.umd.min.js +0 -9
@@ -0,0 +1,624 @@
1
+ /* WebMusicScore v2.0.0 | (c) 2023 PahkaSoft | MIT License | Includes: Tone.js (MIT License) */
2
+ "use strict";
3
+ var __create = Object.create;
4
+ var __defProp = Object.defineProperty;
5
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
6
+ var __getOwnPropNames = Object.getOwnPropertyNames;
7
+ var __getProtoOf = Object.getPrototypeOf;
8
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
9
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
10
+ var __export = (target, all) => {
11
+ for (var name in all)
12
+ __defProp(target, name, { get: all[name], enumerable: true });
13
+ };
14
+ var __copyProps = (to, from, except, desc) => {
15
+ if (from && typeof from === "object" || typeof from === "function") {
16
+ for (let key of __getOwnPropNames(from))
17
+ if (!__hasOwnProp.call(to, key) && key !== except)
18
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
19
+ }
20
+ return to;
21
+ };
22
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
23
+ // If the importer is in node compatibility mode or this is not an ESM
24
+ // file that has been converted to a CommonJS file using a Babel-
25
+ // compatible transform (i.e. "__esModule" has not been set), then set
26
+ // "default" to the CommonJS "module.exports" for node compatibility.
27
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
28
+ mod
29
+ ));
30
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
31
+ var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
32
+
33
+ // src/react-ui/index.ts
34
+ var react_ui_exports = {};
35
+ __export(react_ui_exports, {
36
+ CircleOfFifths: () => CircleOfFifths,
37
+ FretPosition: () => FretPosition,
38
+ FretPositionData: () => FretPositionData,
39
+ GuitarContext: () => GuitarContext,
40
+ GuitarView: () => GuitarView,
41
+ MusicScoreView: () => MusicScoreView,
42
+ PlaybackButtons: () => PlaybackButtons,
43
+ PlaybackButtonsLayout: () => PlaybackButtonsLayout
44
+ });
45
+ module.exports = __toCommonJS(react_ui_exports);
46
+
47
+ // src/react-ui/circle-of-fifths.tsx
48
+ var React = __toESM(require("react"));
49
+ var import_theory = require("@tspro/web-music-score/theory");
50
+ var import_score = require("@tspro/web-music-score/score");
51
+ var import_ts_utils_lib = require("@tspro/ts-utils-lib");
52
+ var import_jsx_runtime = require("react/jsx-runtime");
53
+ var SelectedColor = "#0A0";
54
+ var MajorScaleTonics = [
55
+ ["C"],
56
+ ["G"],
57
+ ["D"],
58
+ ["A"],
59
+ ["E"],
60
+ ["B", "Cb"],
61
+ ["F#", "Gb"],
62
+ ["C#", "Db"],
63
+ ["Ab"],
64
+ ["Eb"],
65
+ ["Bb"],
66
+ ["F"]
67
+ ];
68
+ var MinorScaleTonics = [
69
+ ["A"],
70
+ ["E"],
71
+ ["B"],
72
+ ["F#"],
73
+ ["C#"],
74
+ ["G#", "Ab"],
75
+ ["D#", "Eb"],
76
+ ["A#", "Bb"],
77
+ ["F"],
78
+ ["C"],
79
+ ["G"],
80
+ ["D"]
81
+ ];
82
+ var CircleOfFifths = class extends React.Component {
83
+ constructor(props) {
84
+ super(props);
85
+ }
86
+ onScaleChange(tonic, scaleType) {
87
+ try {
88
+ let scale = (0, import_theory.getScale)(tonic, scaleType);
89
+ this.props.onScaleChange(scale);
90
+ } catch (err) {
91
+ console.error("Invalid scale", tonic, scaleType);
92
+ }
93
+ }
94
+ render() {
95
+ var _a, _b;
96
+ let { style, scale } = this.props;
97
+ let defaultSize = import_ts_utils_lib.Device.toPx("22em");
98
+ let dim = import_ts_utils_lib.Utils.Dom.getDimension(style);
99
+ let width = (_a = dim.width) != null ? _a : defaultSize;
100
+ let height = (_b = dim.height) != null ? _b : defaultSize;
101
+ style = Object.assign({}, style, { width, height });
102
+ let circleRect = new import_score.DivRect(0, width, 0, height).scaleCopy(0.65);
103
+ let lineWidth = Math.max(1, circleRect.width / 100);
104
+ let fontSize = circleRect.width / 15;
105
+ let tonicSize = fontSize * 2;
106
+ let components = [];
107
+ components.push(/* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { style: {
108
+ position: "absolute",
109
+ left: circleRect.left - lineWidth / 2,
110
+ top: circleRect.top - lineWidth / 2,
111
+ width: circleRect.width + lineWidth,
112
+ height: circleRect.height + lineWidth,
113
+ border: lineWidth + "px solid black",
114
+ borderRadius: "50%"
115
+ } }, "circle"));
116
+ for (let i = 0; i < 12; i++) {
117
+ let rad = 2 * Math.PI * i / 12;
118
+ let dx = Math.sin(rad);
119
+ let dy = -Math.cos(rad);
120
+ let x = circleRect.centerX + dx * circleRect.width / 2;
121
+ let y = circleRect.centerY + dy * circleRect.height / 2;
122
+ components.push(/* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { style: {
123
+ position: "absolute",
124
+ left: x - lineWidth / 2,
125
+ top: y - lineWidth * 4 / 2,
126
+ width: lineWidth,
127
+ height: lineWidth * 4,
128
+ backgroundColor: "black",
129
+ transform: "rotate(" + rad + "rad)"
130
+ } }, "m" + i));
131
+ let tonics = [
132
+ MinorScaleTonics[i][1],
133
+ MinorScaleTonics[i][0],
134
+ void 0,
135
+ MajorScaleTonics[i][0],
136
+ MajorScaleTonics[i][1]
137
+ ];
138
+ for (let k = -2; k <= 2; k++) {
139
+ const tonic = tonics[k + 2];
140
+ if (tonic) {
141
+ const scaleType = k < 0 ? import_theory.ScaleType.NaturalMinor : import_theory.ScaleType.Major;
142
+ let tonicStr = import_theory.Note.getScientificNoteName(tonic, import_theory.SymbolSet.Unicode);
143
+ if (scaleType === import_theory.ScaleType.NaturalMinor) {
144
+ tonicStr += "m";
145
+ }
146
+ let isSelected = scaleType === scale.scaleType && tonic === scale.tonic;
147
+ components.push(/* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { style: {
148
+ position: "absolute",
149
+ cursor: "pointer",
150
+ left: x + dx * fontSize * k * 1.5 - tonicSize / 2,
151
+ top: y + dy * fontSize * k * 1.5 - tonicSize / 2,
152
+ width: tonicSize,
153
+ height: tonicSize,
154
+ backgroundColor: isSelected ? SelectedColor : "",
155
+ borderRadius: isSelected ? "50%" : "",
156
+ fontSize,
157
+ lineHeight: 1,
158
+ display: "flex",
159
+ justifyContent: "center",
160
+ // Align horizontal
161
+ alignItems: "center"
162
+ // Align vertical
163
+ }, onClick: () => this.onScaleChange(tonic, scaleType), children: tonicStr }, "kn_" + i + "_" + (k + 2)));
164
+ }
165
+ }
166
+ }
167
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { style, children: components });
168
+ }
169
+ };
170
+
171
+ // src/react-ui/guitar-context.ts
172
+ var import_theory2 = require("@tspro/web-music-score/theory");
173
+ var import_theory3 = require("@tspro/web-music-score/theory");
174
+
175
+ // src/react-ui/assets/guitar.json
176
+ var guitar_default = {
177
+ width: 1223,
178
+ height: 234,
179
+ maxFret: 18,
180
+ nut: {
181
+ x: 1099,
182
+ topStringY: 59,
183
+ bottomStringY: 162
184
+ },
185
+ fret12: {
186
+ x: 330,
187
+ topStringY: 54,
188
+ bottomStringY: 174
189
+ }
190
+ };
191
+
192
+ // src/react-ui/guitar-context.ts
193
+ var import_core = require("@tspro/web-music-score/core");
194
+ var import_ts_utils_lib2 = require("@tspro/ts-utils-lib");
195
+ var DefaultColors = {
196
+ ScaleNoteColor: "#0A0",
197
+ ScaleRootNoteColor: "#00A",
198
+ NonScaleNoteColor: "#A00",
199
+ DefaultBorderColor: "white",
200
+ TextColor: "white"
201
+ };
202
+ var FretPosition = class {
203
+ constructor(guitarCtx, stringId, fretId, chromaticId) {
204
+ this.guitarCtx = guitarCtx;
205
+ this.stringId = stringId;
206
+ this.fretId = fretId;
207
+ this.chromaticId = chromaticId;
208
+ __publicField(this, "note");
209
+ __publicField(this, "isScaleNote");
210
+ __publicField(this, "isScaleRootNote");
211
+ __publicField(this, "isVisible", false);
212
+ __publicField(this, "text", "");
213
+ __publicField(this, "textColor", DefaultColors.TextColor);
214
+ __publicField(this, "fillColor");
215
+ __publicField(this, "borderColor");
216
+ __publicField(this, "isBarre", false);
217
+ let { scale } = guitarCtx;
218
+ this.note = scale.getPreferredChromaticNote(chromaticId);
219
+ this.isScaleNote = scale.isScaleNote(this.note);
220
+ this.isScaleRootNote = scale.isScaleRootNote(this.note);
221
+ }
222
+ get chromaticClass() {
223
+ return import_theory3.Note.getChromaticClass(this.chromaticId);
224
+ }
225
+ show() {
226
+ this.isVisible = true;
227
+ }
228
+ hide() {
229
+ this.isVisible = false;
230
+ }
231
+ setDefaultText() {
232
+ let { pitchNotation, scale, guitarNoteLabel } = this.guitarCtx;
233
+ switch (guitarNoteLabel) {
234
+ case import_theory2.GuitarNoteLabel.OmitOctave:
235
+ this.text = this.note.formatOmitOctave(import_theory2.SymbolSet.Unicode);
236
+ break;
237
+ case import_theory2.GuitarNoteLabel.Interval:
238
+ this.text = scale.getIntervalFromRootNote(this.note).toAbbrString().replace("P1", "R");
239
+ break;
240
+ default:
241
+ this.text = this.note.format(pitchNotation, import_theory2.SymbolSet.Unicode);
242
+ break;
243
+ }
244
+ }
245
+ setDefaultFillColor() {
246
+ this.fillColor = this.isScaleRootNote ? DefaultColors.ScaleRootNoteColor : this.isScaleNote ? DefaultColors.ScaleNoteColor : DefaultColors.NonScaleNoteColor;
247
+ }
248
+ setDefaultBorderColor(showBorder = false) {
249
+ this.borderColor = showBorder ? DefaultColors.DefaultBorderColor : void 0;
250
+ }
251
+ };
252
+ var GuitarContext = class _GuitarContext {
253
+ constructor(tuningName, scale, handedness, pitchNotation, guitarNoteLabel) {
254
+ this.tuningName = tuningName;
255
+ this.scale = scale;
256
+ this.handedness = handedness;
257
+ this.pitchNotation = pitchNotation;
258
+ this.guitarNoteLabel = guitarNoteLabel;
259
+ __publicField(this, "maxFretId");
260
+ __publicField(this, "fretPositionTable");
261
+ __publicField(this, "tuningStrings");
262
+ this.maxFretId = guitar_default.maxFret;
263
+ this.tuningStrings = (0, import_theory3.getTuningStrings)(tuningName);
264
+ this.fretPositionTable = [[], [], [], [], [], []];
265
+ for (let stringId = 0; stringId < 6; stringId++) {
266
+ let openStringChromaticId = this.tuningStrings[stringId].chromaticId;
267
+ for (let fretId = 0; fretId <= this.maxFretId; fretId++) {
268
+ let chromaticId = openStringChromaticId + fretId;
269
+ this.fretPositionTable[stringId][fretId] = new FretPosition(this, stringId, fretId, chromaticId);
270
+ }
271
+ }
272
+ }
273
+ getFretPosition(stringId, fretId) {
274
+ if (!import_ts_utils_lib2.Utils.Is.isInteger(stringId) || stringId < 0 || stringId > 5) {
275
+ throw new import_core.MusicError(import_core.MusicErrorType.InvalidArg, `Invalid stringId: + ${stringId}`);
276
+ } else if (!import_ts_utils_lib2.Utils.Is.isInteger(fretId) || fretId < 0 || fretId > this.maxFretId) {
277
+ throw new import_core.MusicError(import_core.MusicErrorType.InvalidArg, `Invalid fretId: ${fretId}`);
278
+ } else {
279
+ return this.fretPositionTable[stringId][fretId];
280
+ }
281
+ }
282
+ getStringTuning(stringId) {
283
+ return this.tuningStrings[stringId];
284
+ }
285
+ getTuningOverview() {
286
+ return this.tuningStrings.slice().reverse().map((note) => note.format(this.pitchNotation, import_theory2.SymbolSet.Unicode)).join(" - ");
287
+ }
288
+ alterTuningName(tuningName) {
289
+ return tuningName === this.tuningName ? this : new _GuitarContext(tuningName, this.scale, this.handedness, this.pitchNotation, this.guitarNoteLabel);
290
+ }
291
+ alterScale(scale) {
292
+ return import_theory3.Scale.equals(scale, this.scale) ? this : new _GuitarContext(this.tuningName, scale, this.handedness, this.pitchNotation, this.guitarNoteLabel);
293
+ }
294
+ alterHandedness(handedness) {
295
+ return handedness === this.handedness ? this : new _GuitarContext(this.tuningName, this.scale, handedness, this.pitchNotation, this.guitarNoteLabel);
296
+ }
297
+ alterPitchNotation(pitchNotation) {
298
+ return pitchNotation === this.pitchNotation ? this : new _GuitarContext(this.tuningName, this.scale, this.handedness, pitchNotation, this.guitarNoteLabel);
299
+ }
300
+ alterGuitarNoteLabel(guitarNoteLabel) {
301
+ return guitarNoteLabel === this.guitarNoteLabel ? this : new _GuitarContext(this.tuningName, this.scale, this.handedness, this.pitchNotation, guitarNoteLabel);
302
+ }
303
+ };
304
+
305
+ // src/react-ui/guitar-view.tsx
306
+ var React2 = __toESM(require("react"));
307
+ var import_ts_utils_lib3 = require("@tspro/ts-utils-lib");
308
+ var import_score2 = require("@tspro/web-music-score/score");
309
+ var import_theory4 = require("@tspro/web-music-score/theory");
310
+
311
+ // src/react-ui/assets/guitar.png
312
+ var guitar_default2 = "";
313
+
314
+ // src/react-ui/guitar-view.tsx
315
+ var import_core2 = require("@tspro/web-music-score/core");
316
+ var import_jsx_runtime2 = require("react/jsx-runtime");
317
+ var t_table = [
318
+ 0,
319
+ /* nut */
320
+ 0.056,
321
+ 0.109,
322
+ 0.159,
323
+ 0.206,
324
+ 0.251,
325
+ 0.293,
326
+ 0.333,
327
+ 0.37,
328
+ 0.405,
329
+ 0.439,
330
+ 0.47,
331
+ 0.5,
332
+ 0.528,
333
+ 0.555,
334
+ 0.58,
335
+ 0.603,
336
+ 0.625,
337
+ 0.646,
338
+ 0.666,
339
+ 0.685,
340
+ 0.703,
341
+ 0.719,
342
+ 0.735,
343
+ 0.75
344
+ ];
345
+ function fret_t(fretId) {
346
+ if (!import_ts_utils_lib3.Utils.Is.isInteger(fretId) || fretId < 0 || fretId > t_table.length - 1) {
347
+ throw new import_core2.MusicError(import_core2.MusicErrorType.InvalidArg, `Invalid fretId: ${fretId}`);
348
+ } else {
349
+ return t_table[fretId] * 2;
350
+ }
351
+ }
352
+ var Fret = class _Fret {
353
+ constructor(x, topStringY, bottomStringY) {
354
+ this.x = x;
355
+ this.topStringY = topStringY;
356
+ this.bottomStringY = bottomStringY;
357
+ }
358
+ static _lerp(from, to, t) {
359
+ return new _Fret(
360
+ from.x * (1 - t) + to.x * t,
361
+ from.topStringY * (1 - t) + to.topStringY * t,
362
+ from.bottomStringY * (1 - t) + to.bottomStringY * t
363
+ );
364
+ }
365
+ static lerp(fret0, fret12, fret) {
366
+ return _Fret._lerp(fret0, fret12, fret_t(fret));
367
+ }
368
+ static scale(fretData, scale) {
369
+ return new _Fret(fretData.x * scale, fretData.topStringY * scale, fretData.bottomStringY * scale);
370
+ }
371
+ };
372
+ var FretPositionData = class {
373
+ constructor(fretPosition, cellRect, noteRect) {
374
+ this.fretPosition = fretPosition;
375
+ this.cellRect = cellRect;
376
+ this.noteRect = noteRect;
377
+ }
378
+ };
379
+ var GuitarView = class extends React2.Component {
380
+ constructor(props) {
381
+ super(props);
382
+ __publicField(this, "state");
383
+ this.state = this.getLayoutState();
384
+ }
385
+ componentDidUpdate(prevProps) {
386
+ let { style, guitarContext: guitarCtx } = this.props;
387
+ if (import_ts_utils_lib3.Utils.Dom.styleLayoutChanged(style, prevProps.style) || guitarCtx !== prevProps.guitarContext) {
388
+ this.setState(this.getLayoutState());
389
+ }
390
+ }
391
+ getLayoutState() {
392
+ var _a, _b;
393
+ let { guitarContext: guitarCtx, style } = this.props;
394
+ let dim = import_ts_utils_lib3.Utils.Dom.getDimension(style);
395
+ let width = (_a = dim.width) != null ? _a : window.innerWidth;
396
+ let height = guitar_default.height * width / guitar_default.width;
397
+ let s = width / guitar_default.width;
398
+ let nut = Fret.scale(guitar_default.nut, s);
399
+ let fret12 = Fret.scale(guitar_default.fret12, s);
400
+ let frets = [];
401
+ for (let fret = 0; fret <= guitarCtx.maxFretId; fret++) {
402
+ frets.push(Fret.lerp(nut, fret12, fret));
403
+ }
404
+ let noteWidth = Math.round(frets[frets.length - 2].x - frets[frets.length - 1].x);
405
+ let table = [[], [], [], [], [], []];
406
+ for (let stringId = 0; stringId < 6; stringId++) {
407
+ for (let fretId = 0; fretId < frets.length; fretId++) {
408
+ let left = frets[fretId];
409
+ let right = (_b = frets[fretId - 1]) != null ? _b : new Fret(width, left.topStringY, left.bottomStringY);
410
+ let cellHeight = (left.bottomStringY - left.topStringY) / 5;
411
+ let cellRect = import_score2.DivRect.create(
412
+ left.x,
413
+ left.bottomStringY - cellHeight * (stringId + 0.5),
414
+ right.x - left.x,
415
+ cellHeight
416
+ );
417
+ if (guitarCtx.handedness === import_theory4.Handedness.LeftHanded) {
418
+ cellRect = new import_score2.DivRect(width - cellRect.right, width - cellRect.left, cellRect.top, cellRect.bottom);
419
+ }
420
+ let noteRect = import_score2.DivRect.create(
421
+ cellRect.left + (guitarCtx.handedness === import_theory4.Handedness.LeftHanded ? cellRect.width - noteWidth : 0),
422
+ cellRect.top,
423
+ noteWidth,
424
+ cellRect.height
425
+ ).scaleCopy(0.75, 0.95);
426
+ let fretPosition = guitarCtx.getFretPosition(stringId, fretId);
427
+ table[stringId][fretId] = new FretPositionData(fretPosition, cellRect, noteRect);
428
+ }
429
+ }
430
+ return { table, width, height };
431
+ }
432
+ onHover(fretPositionData) {
433
+ }
434
+ onClick(fretPositionData) {
435
+ let { onClickFretPosition: onClicFretPosition } = this.props;
436
+ if (fretPositionData && onClicFretPosition) {
437
+ onClicFretPosition(fretPositionData.fretPosition);
438
+ }
439
+ }
440
+ render() {
441
+ let { width, height, table } = this.state;
442
+ let { guitarContext: guitarCtx, onUpdateFretPosition, style } = this.props;
443
+ style = Object.assign({}, style, { width, height });
444
+ let components = [];
445
+ components.push(
446
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
447
+ "img",
448
+ {
449
+ src: guitar_default2,
450
+ className: guitarCtx.handedness === import_theory4.Handedness.LeftHanded ? "left-handed" : "",
451
+ style: { position: "absolute", width, height, zIndex: 0 }
452
+ },
453
+ "guitar"
454
+ )
455
+ );
456
+ table.forEach((frets) => frets.forEach((fretPositionData) => {
457
+ var _a;
458
+ let { fretPosition, noteRect } = fretPositionData;
459
+ if (onUpdateFretPosition) {
460
+ onUpdateFretPosition(fretPosition);
461
+ }
462
+ if (fretPosition.isVisible) {
463
+ let border = fretPosition.borderColor !== void 0 ? Math.round(noteRect.width / 10) : 0;
464
+ let boxShadow = "0 0 0 " + border + "px " + ((_a = fretPosition.borderColor) != null ? _a : "black");
465
+ components.push(/* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
466
+ "span",
467
+ {
468
+ style: {
469
+ position: "absolute",
470
+ zIndex: fretPosition.borderColor !== void 0 ? 2 : 1,
471
+ cursor: "pointer",
472
+ borderRadius: fretPosition.fretId > 0 ? "50%" : "",
473
+ color: fretPosition.textColor,
474
+ background: fretPosition.fillColor,
475
+ boxShadow,
476
+ WebkitBoxShadow: boxShadow,
477
+ MozBoxShadow: boxShadow,
478
+ left: noteRect.left,
479
+ top: noteRect.top,
480
+ width: noteRect.width,
481
+ height: noteRect.height,
482
+ lineHeight: "0.75",
483
+ fontSize: noteRect.height * 0.6 + "px",
484
+ display: "flex",
485
+ justifyContent: "center",
486
+ // Align horizontal
487
+ alignItems: "center"
488
+ // Align vertical
489
+ },
490
+ children: fretPosition.text
491
+ },
492
+ "sel_" + fretPosition.stringId + "_" + fretPosition.fretId
493
+ ));
494
+ }
495
+ }));
496
+ table.forEach((string, stringId) => string.forEach((cell, fretId) => {
497
+ components.push(/* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
498
+ "div",
499
+ {
500
+ onClick: () => this.onClick(cell),
501
+ onMouseEnter: () => this.onHover(cell),
502
+ onMouseLeave: () => this.onHover(void 0),
503
+ style: {
504
+ position: "absolute",
505
+ zIndex: 3,
506
+ cursor: "pointer",
507
+ left: cell.cellRect.left,
508
+ top: cell.cellRect.top,
509
+ width: cell.cellRect.width,
510
+ height: cell.cellRect.height
511
+ }
512
+ },
513
+ "table_" + stringId + "_" + fretId
514
+ ));
515
+ }));
516
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("div", { style, children: components });
517
+ }
518
+ };
519
+
520
+ // src/react-ui/music-score-view.tsx
521
+ var React3 = __toESM(require("react"));
522
+ var import_score3 = require("@tspro/web-music-score/score");
523
+ var import_jsx_runtime3 = require("react/jsx-runtime");
524
+ var MusicScoreView = class extends React3.Component {
525
+ constructor(props) {
526
+ super(props);
527
+ __publicField(this, "renderer");
528
+ this.renderer = new import_score3.MRenderer();
529
+ this.renderer.setDocument(props.doc);
530
+ if (props.onScoreEvent) {
531
+ this.renderer.setScoreEventListener(props.onScoreEvent);
532
+ }
533
+ }
534
+ componentDidUpdate(prevProps, prevState) {
535
+ if (prevProps.doc !== this.props.doc) {
536
+ this.renderer.setDocument(this.props.doc);
537
+ this.renderer.draw();
538
+ }
539
+ }
540
+ render() {
541
+ const setCanvas = (canvas) => {
542
+ if (canvas) {
543
+ this.renderer.setCanvas(canvas);
544
+ this.renderer.draw();
545
+ }
546
+ };
547
+ return /* @__PURE__ */ (0, import_jsx_runtime3.jsx)("canvas", { style: { position: "relative" }, ref: setCanvas, children: "Canvas error!" });
548
+ }
549
+ };
550
+
551
+ // src/react-ui/playback-buttons.tsx
552
+ var React4 = __toESM(require("react"));
553
+ var import_score4 = require("@tspro/web-music-score/score");
554
+ var import_jsx_runtime4 = require("react/jsx-runtime");
555
+ var PlaybackButtonsLayout = /* @__PURE__ */ ((PlaybackButtonsLayout2) => {
556
+ PlaybackButtonsLayout2[PlaybackButtonsLayout2["PlayStopSingle"] = 0] = "PlayStopSingle";
557
+ PlaybackButtonsLayout2[PlaybackButtonsLayout2["PlayStop"] = 1] = "PlayStop";
558
+ PlaybackButtonsLayout2[PlaybackButtonsLayout2["PlayPauseStop"] = 2] = "PlayPauseStop";
559
+ return PlaybackButtonsLayout2;
560
+ })(PlaybackButtonsLayout || {});
561
+ var PlaybackButtons = class extends React4.Component {
562
+ constructor(props) {
563
+ super(props);
564
+ __publicField(this, "state");
565
+ this.state = {
566
+ controller: new import_score4.MPlaybackButtons().setDocument(props.doc)
567
+ };
568
+ }
569
+ componentDidUpdate(prevProps) {
570
+ if (this.props.doc !== prevProps.doc) {
571
+ this.state.controller.setDocument(this.props.doc);
572
+ }
573
+ }
574
+ render() {
575
+ let { buttonLayout, playLabel, pauseLabel, stopLabel } = this.props;
576
+ let { controller } = this.state;
577
+ buttonLayout = buttonLayout != null ? buttonLayout : 2 /* PlayPauseStop */;
578
+ playLabel = playLabel != null ? playLabel : "Play";
579
+ pauseLabel = pauseLabel != null ? pauseLabel : "Pause";
580
+ stopLabel = stopLabel != null ? stopLabel : "Stop";
581
+ if (buttonLayout === 0 /* PlayStopSingle */) {
582
+ return /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("button", { className: "btn btn-primary", ref: (btn) => {
583
+ if (btn) controller.setPlayStopButton(btn, playLabel, stopLabel);
584
+ } });
585
+ } else if (buttonLayout === 1 /* PlayStop */) {
586
+ return /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)("div", { className: "btn-group", children: [
587
+ /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("button", { className: "btn btn-primary", ref: (btn) => {
588
+ if (btn) controller.setPlayButton(btn, playLabel);
589
+ } }),
590
+ /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("button", { className: "btn btn-primary", ref: (btn) => {
591
+ if (btn) controller.setStopButton(btn, stopLabel);
592
+ } })
593
+ ] });
594
+ } else {
595
+ return /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)("div", { className: "btn-group", children: [
596
+ /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("button", { className: "btn btn-primary", ref: (btn) => {
597
+ if (btn) controller.setPlayButton(btn, playLabel);
598
+ } }),
599
+ /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("button", { className: "btn btn-primary", ref: (btn) => {
600
+ if (btn) controller.setPauseButton(btn, pauseLabel);
601
+ } }),
602
+ /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("button", { className: "btn btn-primary", ref: (btn) => {
603
+ if (btn) controller.setStopButton(btn, stopLabel);
604
+ } })
605
+ ] });
606
+ }
607
+ }
608
+ };
609
+
610
+ // src/react-ui/index.ts
611
+ var import_core3 = require("@tspro/web-music-score/core");
612
+ (0, import_core3.init)();
613
+ // Annotate the CommonJS export names for ESM import in node:
614
+ 0 && (module.exports = {
615
+ CircleOfFifths,
616
+ FretPosition,
617
+ FretPositionData,
618
+ GuitarContext,
619
+ GuitarView,
620
+ MusicScoreView,
621
+ PlaybackButtons,
622
+ PlaybackButtonsLayout
623
+ });
624
+ //# sourceMappingURL=index.js.map