-
Notifications
You must be signed in to change notification settings - Fork 0
/
chef.html
150 lines (138 loc) · 6.7 KB
/
chef.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
<!DOCTYPE html>
<html lang="fr">
<head>
<meta charset="utf8" />
<title>Chef d'orchestre ∣ Orchestre de lumière</title>
<link rel="stylesheet" type="text/css" href="https://cdn.jsdelivr.net/gh/ychalier/pifekit/pifekit.min.css" />
<script type="text/javascript" src="https://cdn.jsdelivr.net/gh/ychalier/pifekit/pifekit.min.js"></script>
<link rel="stylesheet" href="style.css" />
</head>
<body class="container">
<div class="columns">
<div class="column col-6">
<button class="btn btn-primary my-2" onclick="CONTROLLER.stop();">Pause</button>
<div class="panel my-2">
<div class="panel-header">
<div class="panel-title h5">Musicians</div>
</div>
<div id="connected-slaves" class="panel-body"></div>
<div class="panel-footer">
<button class="btn btn-primary" onclick="fetchSlaves()">Refresh</button>
</div>
</div>
</div>
<div class="column col-6">
<div class="panel my-2" id="panel-music-upload">
<div class="panel-header">
<div class="panel-title h5">Music Score</div>
</div>
<div class="panel-body">
<div class="form-group">
<label class="form-label">Select JSON file</label>
<input class="form-input" type="file" id="input-upload-json" accept=".json" />
</div>
<div class="form-group">
<label class="form-label">Select MP3 file</label>
<input class="form-input" type="file" id="input-upload-audio" accept=".mp3" />
</div>
</div>
<div class="panel-footer">
<button class="btn btn-primary" id="button-music-upload">Load</button>
</div>
</div>
<div class="panel hidden my-2" id="panel-music-play">
<div class="panel-header">
<div class="panel-title h5">Music Score</div>
<div class="panel-subtitle">
<b><span id="midi-duration"></span></b> s ·
<b><span id="midi-channels-count"></span></b> channel(s)
</div>
</div>
<div class="panel-body">
<canvas id="canvas-midi" height="300"></canvas>
</div>
<div class="panel-footer d-flex" style="align-items: center">
<button class="btn btn-primary" id="button-music-play"><i class="icon icon-play"></i></button>
<audio class="mx-2" id="audio-player" controls></audio>
</div>
</div>
<div class="panel my-2">
<div class="panel-header">
<div class="panel-title h5">Gradient</div>
</div>
<div class="panel-body">
<div class="form-group">
<label class="form-label" for="input-gradient-keyframes">Keyframes</label>
<input class="form-input" id="input-gradient-keyframes" type="text" value="#000000 0%, #ffffff 100%" style="font-family: Fira Code, monospace;" />
<div class="form-input-hint">
<button class="btn btn-color" keyframes="#f2627c 0%, #277bcc 50%, #f2627c 100%"></button>
<button class="btn btn-color" keyframes="#ff0000 0%, #ff7f00 14%, #ffff00 28%, #008000 42%, #0000ff 56%, #4b0082 70%, #9400d3 84%, #ff0000 100%"></button>
</div>
</div>
<div class="form-group">
<label class="form-label" for="input-gradient-speed">Speed</label>
<input class="form-input" id="input-gradient-speed" type="number" step="0.1" value="1" />
</div>
<div class="form-group">
<label class="form-label" for="input-gradient-spread">Spread</label>
<input class="form-input" id="input-gradient-spread" type="number" step="0.1" value="0" />
</div>
</div>
<div class="panel-footer">
<button class="btn btn-primary" id="button-gradient">Start</button>
</div>
</div>
<div class="panel my-2">
<div class="panel-header">
<div class="panel-title h5">Broadcast a color</div>
</div>
<div class="panel-body">
<input class="form-input" id="input-broadcast-color" type="color" />
</div>
<div class="panel-footer">
<button class="btn btn-primary" id="button-broadcast">Broadcast</button>
</div>
</div>
</div>
</div>
<div id="snackbar"></div>
<div id="modal-slave" class="modal">
<span class="modal-overlay" onclick="closeModal('modal-slave')"></span>
<div class="modal-container">
<form id="form-slave">
<div class="modal-body">
<input id="input-slave-id" hidden />
<div class="form-group">
<label class="form-label" for="input-slave-name">Name</label>
<input class="form-input" id="input-slave-name" />
</div>
<div class="form-group">
<label class="form-label">Midi Channel</label>
<div id="input-slave-midichannel"></div>
</div>
</div>
<div class="modal-footer">
<button class="btn btn-primary">Save</button>
</div>
</form>
</div>
</div>
<template id="template-slave">
<div class="tile my-1">
<div class="tile-icon"><i class="icon icon-icon-resize-horiz"></i></div>
<div class="tile-content">
<div class="tile-title"></div>
<div class="tile-subtitle"><span class="slave-midi-channel"></span></div>
</div>
<div class="tile-action">
<button class="btn btn-primary btn-up"><i class="icon icon-arrow-up"></i></button>
<button class="btn btn-primary btn-down"><i class="icon icon-arrow-down"></i></button>
</div>
</div>
</template>
<script type="text/javascript" src="master.js"></script>
<script type="text/javascript">
setupMaster();
</script>
</body>
</html>