@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.
- package/CHANGELOG.md +19 -0
- package/README.md +271 -224
- package/dist/audio/index.d.mts +22 -0
- package/dist/audio/index.d.ts +22 -0
- package/dist/audio/index.js +147 -0
- package/dist/audio/index.mjs +109 -0
- package/dist/audio-cg/index.d.mts +4 -0
- package/dist/audio-cg/index.d.ts +4 -0
- package/dist/audio-cg/index.js +124 -0
- package/dist/audio-cg/index.mjs +91 -0
- package/dist/chunk-2EPWQZKJ.mjs +9 -0
- package/dist/core/index.d.mts +21 -0
- package/dist/core/index.d.ts +21 -0
- package/dist/core/index.js +72 -0
- package/dist/core/index.mjs +45 -0
- package/dist/guitar-BIFwFT31.d.ts +24 -0
- package/dist/guitar-kbJYu3Am.d.mts +24 -0
- package/dist/iife/index.global.js +222 -0
- package/dist/note-B5ZtlHc8.d.ts +99 -0
- package/dist/note-CraqEy8x.d.mts +99 -0
- package/dist/pieces/index.d.mts +15 -0
- package/dist/pieces/index.d.ts +15 -0
- package/dist/pieces/index.js +104 -0
- package/dist/pieces/index.mjs +77 -0
- package/dist/react-ui/index.d.mts +169 -0
- package/dist/react-ui/index.d.ts +169 -0
- package/dist/react-ui/index.js +624 -0
- package/dist/react-ui/index.mjs +582 -0
- package/dist/score/index.d.mts +1558 -0
- package/dist/score/index.d.ts +1558 -0
- package/dist/score/index.js +6937 -0
- package/dist/score/index.mjs +6863 -0
- package/dist/tempo--588tdcv.d.ts +203 -0
- package/dist/tempo-BEJBHZ5I.d.mts +203 -0
- package/dist/theory/index.d.mts +47 -0
- package/dist/theory/index.d.ts +47 -0
- package/dist/theory/index.js +1783 -0
- package/dist/theory/index.mjs +1716 -0
- package/package.json +99 -56
- package/dist/index.cjs.js +0 -40708
- package/dist/index.d.ts +0 -1258
- package/dist/index.esm.mjs +0 -40699
- 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
|