@popmenu/audio-player 0.27.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/build/index.js ADDED
@@ -0,0 +1,1082 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var React = require('react');
6
+ var core = require('@material-ui/core');
7
+ require('@material-ui/lab/Alert');
8
+ require('@material-ui/core/AppBar');
9
+ var MuiAvatar = require('@material-ui/core/Avatar');
10
+ var styles = require('@material-ui/core/styles');
11
+ require('@material-ui/core/Badge');
12
+ var MuiButton = require('@material-ui/core/Button');
13
+ var CircularProgress = require('@material-ui/core/CircularProgress');
14
+ require('@material-ui/core/ButtonGroup');
15
+ require('@material-ui/core/Card');
16
+ require('@material-ui/core/CardActionArea');
17
+ require('@material-ui/core/CardActions');
18
+ require('@material-ui/core/CardContent');
19
+ require('@material-ui/core/CardHeader');
20
+ require('@material-ui/core/CardMedia');
21
+ var MuiCheckbox = require('@material-ui/core/Checkbox');
22
+ var FormControlLabel = require('@material-ui/core/FormControlLabel');
23
+ require('@material-ui/core/Chip');
24
+ require('@material-ui/core/Collapse');
25
+ require('@material-ui/core/Dialog');
26
+ require('@material-ui/core/DialogActions');
27
+ require('@material-ui/core/DialogContent');
28
+ require('@material-ui/core/DialogTitle');
29
+ require('@material-ui/core/Drawer');
30
+ require('@material-ui/core/FormControl');
31
+ require('@material-ui/core/Grid');
32
+ var MuiIconButton = require('@material-ui/core/IconButton');
33
+ require('@material-ui/core/InputAdornment');
34
+ require('@material-ui/core/LinearProgress');
35
+ require('@material-ui/core/List');
36
+ require('@material-ui/core/ListItem');
37
+ require('@material-ui/core/ListItemIcon');
38
+ require('@material-ui/core/ListItemSecondaryAction');
39
+ require('@material-ui/core/ListItemText');
40
+ require('@material-ui/core/Menu');
41
+ require('@material-ui/core/MenuItem');
42
+ require('@material-ui/core/MenuList');
43
+ var MuiRadio = require('@material-ui/core/Radio');
44
+ require('@material-ui/core/TextField');
45
+ var MuiSwitch = require('@material-ui/core/Switch');
46
+ require('@material-ui/core/Tab');
47
+ require('@material-ui/core/Tabs');
48
+ var MuiToggleButton = require('@material-ui/lab/ToggleButton');
49
+ var MuiToggleButtonGroup = require('@material-ui/lab/ToggleButtonGroup');
50
+ var MuiTooltip = require('@material-ui/core/Tooltip');
51
+
52
+ function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
53
+
54
+ function _interopNamespace(e) {
55
+ if (e && e.__esModule) return e;
56
+ var n = Object.create(null);
57
+ if (e) {
58
+ Object.keys(e).forEach(function (k) {
59
+ if (k !== 'default') {
60
+ var d = Object.getOwnPropertyDescriptor(e, k);
61
+ Object.defineProperty(n, k, d.get ? d : {
62
+ enumerable: true,
63
+ get: function () {
64
+ return e[k];
65
+ }
66
+ });
67
+ }
68
+ });
69
+ }
70
+ n['default'] = e;
71
+ return Object.freeze(n);
72
+ }
73
+
74
+ var React__namespace = /*#__PURE__*/_interopNamespace(React);
75
+ var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
76
+ var MuiAvatar__default = /*#__PURE__*/_interopDefaultLegacy(MuiAvatar);
77
+ var MuiButton__default = /*#__PURE__*/_interopDefaultLegacy(MuiButton);
78
+ var CircularProgress__default = /*#__PURE__*/_interopDefaultLegacy(CircularProgress);
79
+ var MuiCheckbox__default = /*#__PURE__*/_interopDefaultLegacy(MuiCheckbox);
80
+ var FormControlLabel__default = /*#__PURE__*/_interopDefaultLegacy(FormControlLabel);
81
+ var MuiIconButton__default = /*#__PURE__*/_interopDefaultLegacy(MuiIconButton);
82
+ var MuiRadio__default = /*#__PURE__*/_interopDefaultLegacy(MuiRadio);
83
+ var MuiSwitch__default = /*#__PURE__*/_interopDefaultLegacy(MuiSwitch);
84
+ var MuiToggleButton__default = /*#__PURE__*/_interopDefaultLegacy(MuiToggleButton);
85
+ var MuiToggleButtonGroup__default = /*#__PURE__*/_interopDefaultLegacy(MuiToggleButtonGroup);
86
+ var MuiTooltip__default = /*#__PURE__*/_interopDefaultLegacy(MuiTooltip);
87
+
88
+ /*! *****************************************************************************
89
+ Copyright (c) Microsoft Corporation.
90
+
91
+ Permission to use, copy, modify, and/or distribute this software for any
92
+ purpose with or without fee is hereby granted.
93
+
94
+ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
95
+ REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
96
+ AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
97
+ INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
98
+ LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
99
+ OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
100
+ PERFORMANCE OF THIS SOFTWARE.
101
+ ***************************************************************************** */
102
+
103
+ var __assign$1 = function() {
104
+ __assign$1 = Object.assign || function __assign(t) {
105
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
106
+ s = arguments[i];
107
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];
108
+ }
109
+ return t;
110
+ };
111
+ return __assign$1.apply(this, arguments);
112
+ };
113
+
114
+ var classnames$1 = {exports: {}};
115
+
116
+ /*!
117
+ Copyright (c) 2018 Jed Watson.
118
+ Licensed under the MIT License (MIT), see
119
+ http://jedwatson.github.io/classnames
120
+ */
121
+
122
+ (function (module) {
123
+ /* global define */
124
+
125
+ (function () {
126
+
127
+ var hasOwn = {}.hasOwnProperty;
128
+
129
+ function classNames() {
130
+ var classes = [];
131
+
132
+ for (var i = 0; i < arguments.length; i++) {
133
+ var arg = arguments[i];
134
+ if (!arg) continue;
135
+
136
+ var argType = typeof arg;
137
+
138
+ if (argType === 'string' || argType === 'number') {
139
+ classes.push(arg);
140
+ } else if (Array.isArray(arg)) {
141
+ if (arg.length) {
142
+ var inner = classNames.apply(null, arg);
143
+ if (inner) {
144
+ classes.push(inner);
145
+ }
146
+ }
147
+ } else if (argType === 'object') {
148
+ if (arg.toString === Object.prototype.toString) {
149
+ for (var key in arg) {
150
+ if (hasOwn.call(arg, key) && arg[key]) {
151
+ classes.push(key);
152
+ }
153
+ }
154
+ } else {
155
+ classes.push(arg.toString());
156
+ }
157
+ }
158
+ }
159
+
160
+ return classes.join(' ');
161
+ }
162
+
163
+ if (module.exports) {
164
+ classNames.default = classNames;
165
+ module.exports = classNames;
166
+ } else {
167
+ window.classNames = classNames;
168
+ }
169
+ }());
170
+ }(classnames$1));
171
+
172
+ var classNames$1 = classnames$1.exports;
173
+
174
+ var _path$1l;
175
+
176
+ function _extends$1p() { _extends$1p = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends$1p.apply(this, arguments); }
177
+
178
+ function SvgPause(props) {
179
+ return /*#__PURE__*/React__namespace.createElement("svg", _extends$1p({
180
+ viewBox: "0 0 16 16",
181
+ strokeLinecap: "round",
182
+ strokeLinejoin: "round",
183
+ stroke: "currentColor",
184
+ width: "1em",
185
+ height: "1em",
186
+ fill: "none"
187
+ }, props), _path$1l || (_path$1l = /*#__PURE__*/React__namespace.createElement("path", {
188
+ d: "M6.667 2.667H4v10.666h2.667V2.666zm5.333 0H9.333v10.666H12V2.666z"
189
+ })));
190
+ }
191
+
192
+ var _path$1j;
193
+
194
+ function _extends$1n() { _extends$1n = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends$1n.apply(this, arguments); }
195
+
196
+ function SvgPlay(props) {
197
+ return /*#__PURE__*/React__namespace.createElement("svg", _extends$1n({
198
+ viewBox: "0 0 16 16",
199
+ strokeLinecap: "round",
200
+ strokeLinejoin: "round",
201
+ stroke: "currentColor",
202
+ width: "1em",
203
+ height: "1em",
204
+ fill: "none"
205
+ }, props), _path$1j || (_path$1j = /*#__PURE__*/React__namespace.createElement("path", {
206
+ d: "M3.333 2l9.334 6-9.334 6V2z"
207
+ })));
208
+ }
209
+
210
+ var _path$16;
211
+
212
+ function _extends$1a() { _extends$1a = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends$1a.apply(this, arguments); }
213
+
214
+ function SvgVolumeDown(props) {
215
+ return /*#__PURE__*/React__namespace.createElement("svg", _extends$1a({
216
+ viewBox: "0 0 16 16",
217
+ strokeLinecap: "round",
218
+ strokeLinejoin: "round",
219
+ stroke: "currentColor",
220
+ width: "1em",
221
+ height: "1em",
222
+ fill: "none"
223
+ }, props), _path$16 || (_path$16 = /*#__PURE__*/React__namespace.createElement("path", {
224
+ d: "M8.999 3.333L5.665 6H3v4h2.666L9 12.667V3.333zm3.026 2.307a3.333 3.333 0 010 4.714"
225
+ })));
226
+ }
227
+
228
+ var _path$15;
229
+
230
+ function _extends$19() { _extends$19 = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends$19.apply(this, arguments); }
231
+
232
+ function SvgVolumeMute(props) {
233
+ return /*#__PURE__*/React__namespace.createElement("svg", _extends$19({
234
+ viewBox: "0 0 16 16",
235
+ strokeLinecap: "round",
236
+ strokeLinejoin: "round",
237
+ stroke: "currentColor",
238
+ width: "1em",
239
+ height: "1em",
240
+ fill: "none"
241
+ }, props), _path$15 || (_path$15 = /*#__PURE__*/React__namespace.createElement("path", {
242
+ d: "M7.333 3.333L4 6H1.333v4H4l3.333 2.667V3.333z"
243
+ })));
244
+ }
245
+
246
+ var _path$14;
247
+
248
+ function _extends$18() { _extends$18 = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends$18.apply(this, arguments); }
249
+
250
+ function SvgVolumeOff(props) {
251
+ return /*#__PURE__*/React__namespace.createElement("svg", _extends$18({
252
+ viewBox: "0 0 16 16",
253
+ strokeLinecap: "round",
254
+ strokeLinejoin: "round",
255
+ stroke: "currentColor",
256
+ width: "1em",
257
+ height: "1em",
258
+ fill: "none"
259
+ }, props), _path$14 || (_path$14 = /*#__PURE__*/React__namespace.createElement("path", {
260
+ d: "M7.333 3.333L4 6H1.333v4H4l3.333 2.667V3.333zm8 2.667l-4 4m0-4l4 4"
261
+ })));
262
+ }
263
+
264
+ var _path$13;
265
+
266
+ function _extends$17() { _extends$17 = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends$17.apply(this, arguments); }
267
+
268
+ function SvgVolumeUp(props) {
269
+ return /*#__PURE__*/React__namespace.createElement("svg", _extends$17({
270
+ viewBox: "0 0 16 16",
271
+ strokeLinecap: "round",
272
+ strokeLinejoin: "round",
273
+ stroke: "currentColor",
274
+ width: "1em",
275
+ height: "1em",
276
+ fill: "none"
277
+ }, props), _path$13 || (_path$13 = /*#__PURE__*/React__namespace.createElement("path", {
278
+ d: "M7.333 3.333L4 6H1.333v4H4l3.333 2.667V3.333zm5.38-.046a6.667 6.667 0 010 9.426M10.36 5.64a3.333 3.333 0 010 4.713"
279
+ })));
280
+ }
281
+
282
+ /*! *****************************************************************************
283
+ Copyright (c) Microsoft Corporation.
284
+
285
+ Permission to use, copy, modify, and/or distribute this software for any
286
+ purpose with or without fee is hereby granted.
287
+
288
+ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
289
+ REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
290
+ AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
291
+ INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
292
+ LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
293
+ OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
294
+ PERFORMANCE OF THIS SOFTWARE.
295
+ ***************************************************************************** */
296
+
297
+ var __assign = function() {
298
+ __assign = Object.assign || function __assign(t) {
299
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
300
+ s = arguments[i];
301
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];
302
+ }
303
+ return t;
304
+ };
305
+ return __assign.apply(this, arguments);
306
+ };
307
+
308
+ function __rest(s, e) {
309
+ var t = {};
310
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
311
+ t[p] = s[p];
312
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
313
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
314
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
315
+ t[p[i]] = s[p[i]];
316
+ }
317
+ return t;
318
+ }
319
+
320
+ var _path$2P;
321
+
322
+ function _extends$33() { _extends$33 = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends$33.apply(this, arguments); }
323
+
324
+ function SvgUser(props) {
325
+ return /*#__PURE__*/React__namespace.createElement("svg", _extends$33({
326
+ viewBox: "0 0 16 16",
327
+ strokeLinecap: "round",
328
+ strokeLinejoin: "round",
329
+ stroke: "currentColor",
330
+ width: "1em",
331
+ height: "1em",
332
+ fill: "none"
333
+ }, props), _path$2P || (_path$2P = /*#__PURE__*/React__namespace.createElement("path", {
334
+ d: "M13.333 14v-1.333A2.667 2.667 0 0010.667 10H5.333a2.667 2.667 0 00-2.666 2.667V14M8 7.333A2.667 2.667 0 108 2a2.667 2.667 0 000 5.333z"
335
+ })));
336
+ }
337
+
338
+ var useIconStyles = core.makeStyles(function (_a) {
339
+ var spacing = _a.spacing, palette = _a.palette;
340
+ var getFontSize = function (_a) {
341
+ var size = _a.size;
342
+ var sizes = {
343
+ inherit: 'inherit',
344
+ small: spacing(1.5),
345
+ medium: spacing(2),
346
+ large: spacing(2.5),
347
+ 'extra-large': spacing(3),
348
+ };
349
+ return size ? sizes[size] : 'inherit';
350
+ };
351
+ var getColor = function (props) {
352
+ var semanticColors = ['primary', 'secondary', 'info', 'success', 'warning', 'error'];
353
+ var value = 'inherit';
354
+ if (props.color) {
355
+ if (semanticColors.includes(props.color.split('.')[0])) {
356
+ var _a = props.color.split('.'), color = _a[0], _b = _a[1], variant = _b === void 0 ? 'main' : _b;
357
+ value = palette[color][variant];
358
+ }
359
+ else if (props.color.search(/^(rgb|hsla|#)/) !== -1) {
360
+ value = props.color;
361
+ }
362
+ }
363
+ return value;
364
+ };
365
+ return {
366
+ root: {
367
+ color: getColor,
368
+ fontSize: getFontSize,
369
+ strokeWidth: '1.3px',
370
+ },
371
+ };
372
+ });
373
+
374
+ var classnames = {exports: {}};
375
+
376
+ /*!
377
+ Copyright (c) 2018 Jed Watson.
378
+ Licensed under the MIT License (MIT), see
379
+ http://jedwatson.github.io/classnames
380
+ */
381
+
382
+ (function (module) {
383
+ /* global define */
384
+
385
+ (function () {
386
+
387
+ var hasOwn = {}.hasOwnProperty;
388
+
389
+ function classNames() {
390
+ var classes = [];
391
+
392
+ for (var i = 0; i < arguments.length; i++) {
393
+ var arg = arguments[i];
394
+ if (!arg) continue;
395
+
396
+ var argType = typeof arg;
397
+
398
+ if (argType === 'string' || argType === 'number') {
399
+ classes.push(arg);
400
+ } else if (Array.isArray(arg)) {
401
+ if (arg.length) {
402
+ var inner = classNames.apply(null, arg);
403
+ if (inner) {
404
+ classes.push(inner);
405
+ }
406
+ }
407
+ } else if (argType === 'object') {
408
+ if (arg.toString === Object.prototype.toString) {
409
+ for (var key in arg) {
410
+ if (hasOwn.call(arg, key) && arg[key]) {
411
+ classes.push(key);
412
+ }
413
+ }
414
+ } else {
415
+ classes.push(arg.toString());
416
+ }
417
+ }
418
+ }
419
+
420
+ return classes.join(' ');
421
+ }
422
+
423
+ if (module.exports) {
424
+ classNames.default = classNames;
425
+ module.exports = classNames;
426
+ } else {
427
+ window.classNames = classNames;
428
+ }
429
+ }());
430
+ }(classnames));
431
+
432
+ var classNames = classnames.exports;
433
+
434
+ var iconStaticClassName = 'pop-icon';
435
+ var Icon = function (props) {
436
+ var icon = props.icon, className = props.className, restProps = __rest(props, ["icon", "className"]);
437
+ var classes = useIconStyles(props);
438
+ var isValid = true;
439
+ if (!icon || (typeof icon === 'function' && icon({}) === undefined)) {
440
+ isValid = false;
441
+ }
442
+ return isValid
443
+ ? React.createElement(icon, __assign({ className: classNames([classes.root, iconStaticClassName, className]) }, restProps))
444
+ : null;
445
+ };
446
+ Icon.defaultProps = {
447
+ size: 'inherit',
448
+ color: 'inherit',
449
+ };
450
+ Icon.displayName = 'Icon';
451
+
452
+ var LoadingStatus;
453
+ (function (LoadingStatus) {
454
+ LoadingStatus["ERROR"] = "ERROR";
455
+ LoadingStatus["LOADED"] = "LOADED";
456
+ LoadingStatus["PENDING"] = "PENDING";
457
+ })(LoadingStatus || (LoadingStatus = {}));
458
+ var useImgProps = function (avatarProps) {
459
+ var _a = React__default['default'].useState(LoadingStatus.PENDING), loaded = _a[0], setLoaded = _a[1];
460
+ var imgProps = __assign(__assign({}, avatarProps.imgProps), { onLoad: function (event) {
461
+ var _a, _b;
462
+ setLoaded(LoadingStatus.LOADED);
463
+ (_b = (_a = avatarProps.imgProps) === null || _a === void 0 ? void 0 : _a.onLoad) === null || _b === void 0 ? void 0 : _b.call(_a, event);
464
+ } });
465
+ return { imgProps: imgProps, loaded: loaded };
466
+ };
467
+
468
+ var getAvatarDimensions = function (theme, props) {
469
+ var factors = {
470
+ 'extra-small': 3,
471
+ small: 4,
472
+ medium: 5,
473
+ large: 6,
474
+ 'extra-large': 12.5,
475
+ };
476
+ var sizeFactor = factors[props.size || 'medium'];
477
+ return theme.spacing(sizeFactor);
478
+ };
479
+ var getAvatarFontSize = function (props) {
480
+ var fontSizes = {
481
+ 'extra-small': '0.75rem',
482
+ small: '1rem',
483
+ medium: '1rem',
484
+ large: '1.25rem',
485
+ 'extra-large': '3.5rem',
486
+ };
487
+ return fontSizes[props.size];
488
+ };
489
+ var useAvatarStyles = styles.makeStyles(function (theme) { return ({
490
+ root: function (props) { return ({
491
+ width: getAvatarDimensions(theme, props),
492
+ height: getAvatarDimensions(theme, props),
493
+ fontSize: getAvatarFontSize(props),
494
+ backgroundColor: props.loaded === LoadingStatus.LOADED ? 'transparent' : props.background,
495
+ color: theme.palette.getContrastText(props.background),
496
+ objectFit: props.fit,
497
+ }); },
498
+ fallback: function (props) { return ({
499
+ fontSize: getAvatarDimensions(theme, props),
500
+ strokeWidth: 1,
501
+ }); },
502
+ }); });
503
+
504
+ var Avatar = React.forwardRef(function (props, ref) {
505
+ var children = props.children, src = props.src, alt = props.alt, fallback = props.fallback, muiProps = __rest(props, ["children", "src", "alt", "fallback"]);
506
+ var _a = useImgProps(props), imgProps = _a.imgProps, loaded = _a.loaded;
507
+ var classes = useAvatarStyles(__assign(__assign({}, props), { loaded: loaded }));
508
+ var displayAltTextFallback = src && alt;
509
+ var displayNoFallback = fallback === 'none';
510
+ var displayCustomFallback = fallback !== 'none' && typeof fallback !== 'undefined';
511
+ var Fallback;
512
+ if (displayAltTextFallback) {
513
+ Fallback = null;
514
+ }
515
+ else if (displayNoFallback) {
516
+ Fallback = ' ';
517
+ }
518
+ else if (displayCustomFallback) {
519
+ Fallback = fallback;
520
+ }
521
+ else {
522
+ Fallback = React__default['default'].createElement(Icon, { icon: SvgUser, className: classes.fallback });
523
+ }
524
+ return (React__default['default'].createElement(MuiAvatar__default['default'], __assign({ ref: ref, classes: { root: classes.root }, src: src, alt: alt }, muiProps, { imgProps: imgProps }), children || Fallback));
525
+ });
526
+ Avatar.defaultProps = {
527
+ size: 'medium',
528
+ fit: 'cover',
529
+ background: '#E0E0E0',
530
+ };
531
+ Avatar.displayName = 'Avatar';
532
+
533
+ var useButtonStyles = styles.makeStyles(function () { return ({
534
+ root: {
535
+ minWidth: 'unset',
536
+ },
537
+ label: {
538
+ textTransform: function (_a) {
539
+ var textTransform = _a.textTransform;
540
+ return textTransform;
541
+ },
542
+ },
543
+ }); });
544
+
545
+ var Button = React.forwardRef(function (props, ref) {
546
+ props.textTransform; var loading = props.loading, classesOverride = props.classes, className = props.className, muiProps = __rest(props, ["textTransform", "loading", "classes", "className"]);
547
+ props.classes; var styleProps = __rest(props, ["classes"]);
548
+ var classes = useButtonStyles(styleProps);
549
+ var typography = styles.useTheme().typography;
550
+ var loadingIndicator = {
551
+ startIcon: React__default['default'].createElement(CircularProgress__default['default'], { color: "inherit", size: typography.button.fontSize }),
552
+ disabled: true,
553
+ };
554
+ return (React__default['default'].createElement(MuiButton__default['default'], __assign({ ref: ref, classes: __assign(__assign({}, classes), classesOverride), className: classNames([className, 'pm-button']) }, muiProps, (loading && loadingIndicator))));
555
+ });
556
+ Button.displayName = 'Button';
557
+
558
+ var Checkbox = React.forwardRef(function (props, ref) {
559
+ var label = props.label, disabled = props.disabled, LabelProps = props.LabelProps, muiProps = __rest(props, ["label", "disabled", "LabelProps"]);
560
+ var control = React__default['default'].createElement(MuiCheckbox__default['default'], __assign({ disabled: label ? undefined : disabled }, muiProps));
561
+ return label ? (React__default['default'].createElement(FormControlLabel__default['default'], __assign({ disabled: disabled, inputRef: ref, control: control, label: label }, LabelProps))) : (control);
562
+ });
563
+ Checkbox.displayName = 'Checkbox';
564
+
565
+ var useTypographyStyles = styles.makeStyles(function () { return ({
566
+ root: function (_a) {
567
+ var _b;
568
+ var weight = _a.weight;
569
+ return (__assign((_b = {}, _b["& ." + iconStaticClassName] = {
570
+ position: 'relative',
571
+ top: '0.125em',
572
+ padding: '0 0.125em',
573
+ boxSizing: 'content-box',
574
+ }, _b), (weight && { fontWeight: (weight === 'semi-bold' && 600) || (weight === 'bold' && 700) || 400 })));
575
+ },
576
+ caption: {
577
+ display: 'inline',
578
+ },
579
+ overline: {
580
+ display: 'inline',
581
+ },
582
+ }); });
583
+
584
+ var Typography = React.forwardRef(function (props, ref) {
585
+ props.weight; var restProps = __rest(props, ["weight"]);
586
+ var classes = useTypographyStyles(props);
587
+ return React__default['default'].createElement(core.Typography, __assign({ ref: ref, classes: classes }, restProps));
588
+ });
589
+ Typography.displayName = 'Typography';
590
+
591
+ var getFadeStop = function (_a, typographyVariant) {
592
+ var typography = _a.typography;
593
+ return !isNaN(Number(typography[typographyVariant].lineHeight))
594
+ ? typography[typographyVariant].lineHeight + "rem"
595
+ : typography[typographyVariant].lineHeight;
596
+ };
597
+ core.makeStyles(function (theme) { return ({
598
+ overlay: {
599
+ position: 'absolute',
600
+ top: 0,
601
+ left: 0,
602
+ height: '100%',
603
+ width: '100%',
604
+ background: function (props) { return "linear-gradient(to top, white, #FFF0 " + getFadeStop(theme, props.typographyVariant) + ")"; },
605
+ },
606
+ }); });
607
+
608
+ var SemanticColors;
609
+ (function (SemanticColors) {
610
+ SemanticColors["PRIMARY_MAIN"] = "primary.main";
611
+ SemanticColors["PRIMARY_DARK"] = "primary.dark";
612
+ SemanticColors["PRIMARY_LIGHT"] = "primary.light";
613
+ SemanticColors["SECONDARY_MAIN"] = "secondary.main";
614
+ SemanticColors["SECONDARY_DARK"] = "secondary.dark";
615
+ SemanticColors["SECONDARY_LIGHT"] = "secondary.light";
616
+ })(SemanticColors || (SemanticColors = {}));
617
+ core.makeStyles(function (theme) { return ({
618
+ dividerRoot: {
619
+ gap: theme.spacing(2),
620
+ },
621
+ textRoot: {
622
+ color: function (props) {
623
+ var textColor = props.textColor;
624
+ if (Object.values(SemanticColors).includes(textColor)) {
625
+ var _a = textColor.split('.'), semanticColor = _a[0], shade = _a[1];
626
+ return theme.palette[semanticColor][shade];
627
+ }
628
+ else if (textColor) {
629
+ return textColor;
630
+ }
631
+ else {
632
+ return 'black';
633
+ }
634
+ },
635
+ textTransform: function (props) { return props.textTransform; },
636
+ },
637
+ dividerLine: {
638
+ backgroundColor: function (props) {
639
+ var dividerColor = props.dividerColor;
640
+ if (Object.values(SemanticColors).includes(dividerColor)) {
641
+ var _a = dividerColor.split('.'), semanticColor = _a[0], shade = _a[1];
642
+ return theme.palette[semanticColor][shade];
643
+ }
644
+ else if (dividerColor) {
645
+ return dividerColor;
646
+ }
647
+ else {
648
+ return theme.palette.grey[500];
649
+ }
650
+ },
651
+ },
652
+ }); });
653
+
654
+ var IconButton = React.forwardRef(function (props, ref) {
655
+ return React__default['default'].createElement(MuiIconButton__default['default'], __assign({ ref: ref }, props));
656
+ });
657
+ IconButton.displayName = 'IconButton';
658
+ IconButton.defaultProps = {
659
+ color: 'secondary',
660
+ };
661
+
662
+ var useLinkStyles = styles.makeStyles(function (theme) { return ({
663
+ root: function (props) {
664
+ var _a;
665
+ return (__assign(__assign({ display: 'flex' }, (props.color === undefined && { color: theme.palette.info.main })), (_a = {}, _a["& ." + iconStaticClassName] = {
666
+ alignSelf: 'center',
667
+ }, _a)));
668
+ },
669
+ }); });
670
+
671
+ var Link = React.forwardRef(function (props, ref) {
672
+ var children = props.children, muiProps = __rest(props, ["children"]);
673
+ var classes = useLinkStyles(props);
674
+ return (React__default['default'].createElement(core.Link, __assign({ ref: ref, classes: { root: classes.root } }, muiProps), children));
675
+ });
676
+ Link.defaultProps = {
677
+ variant: 'body1',
678
+ };
679
+ Link.displayName = 'Link';
680
+
681
+ var useStyles = core.makeStyles(function (_a) {
682
+ var spacing = _a.spacing;
683
+ return ({
684
+ root: {
685
+ '&:last-child': {
686
+ marginBottom: 0,
687
+ },
688
+ marginBottom: spacing(4),
689
+ padding: spacing(4),
690
+ },
691
+ });
692
+ });
693
+ var Paper = React.forwardRef(function (props, ref) {
694
+ var legacyStyles = props.legacyStyles, restProps = __rest(props, ["legacyStyles"]);
695
+ var classes = useStyles(props);
696
+ return React__default['default'].createElement(core.Paper, __assign({}, ref, { classes: __assign({}, (legacyStyles && classes)) }, restProps));
697
+ });
698
+ Paper.displayName = 'Paper';
699
+ Paper.defaultProps = {
700
+ legacyStyles: false,
701
+ };
702
+
703
+ var Radio = React.forwardRef(function (props, ref) {
704
+ var label = props.label, disabled = props.disabled, LabelProps = props.LabelProps, muiProps = __rest(props, ["label", "disabled", "LabelProps"]);
705
+ var control = React__default['default'].createElement(MuiRadio__default['default'], __assign({ disabled: label ? undefined : disabled }, muiProps));
706
+ return label ? (React__default['default'].createElement(FormControlLabel__default['default'], __assign({ disabled: disabled, inputRef: ref, control: control, label: label }, LabelProps))) : (control);
707
+ });
708
+ Radio.displayName = 'Radio';
709
+
710
+ styles.makeStyles(function () { return ({
711
+ textfield: {
712
+ background: function (props) { return (props.backgroundTransparency ? '#FFFFFF44' : 'none'); },
713
+ borderTopLeftRadius: 4,
714
+ borderBottomLeftRadius: 4,
715
+ '& fieldset': {
716
+ borderRight: 'none',
717
+ borderTopRightRadius: 0,
718
+ borderBottomRightRadius: 0,
719
+ },
720
+ },
721
+ button: {
722
+ borderTopLeftRadius: 0,
723
+ borderBottomLeftRadius: 0,
724
+ alignSelf: 'stretch',
725
+ },
726
+ input: {
727
+ color: function (props) { return props.inputTextColor || 'inherit'; },
728
+ '&$focused fieldset': {
729
+ top: -4,
730
+ },
731
+ },
732
+ focused: {},
733
+ }); });
734
+
735
+ var useSwitchStyles = styles.makeStyles(function (theme) { return ({
736
+ checked: {
737
+ '& $thumb': {
738
+ background: theme.palette.success.main,
739
+ },
740
+ '&& + $track': {
741
+ backgroundColor: theme.palette.success.main,
742
+ },
743
+ },
744
+ thumb: {},
745
+ track: {},
746
+ }); });
747
+
748
+ var Switch = React.forwardRef(function (props, ref) {
749
+ var label = props.label, disabled = props.disabled, LabelProps = props.LabelProps, muiProps = __rest(props, ["label", "disabled", "LabelProps"]);
750
+ var classes = useSwitchStyles(props);
751
+ var control = React__default['default'].createElement(MuiSwitch__default['default'], __assign({ classes: classes, disabled: label ? undefined : disabled }, muiProps));
752
+ return label ? (React__default['default'].createElement(FormControlLabel__default['default'], __assign({ disabled: disabled, inputRef: ref, control: control, label: label }, LabelProps))) : (control);
753
+ });
754
+ Switch.displayName = 'Switch';
755
+
756
+ var useToggleButtonStyles = styles.makeStyles(function (theme) { return ({
757
+ root: {
758
+ color: theme.palette.text.primary,
759
+ },
760
+ selected: {
761
+ '&&': {
762
+ '&:hover': {
763
+ backgroundColor: function (props) { return theme.palette[props.color || 'primary'].dark; },
764
+ },
765
+ backgroundColor: function (props) { return theme.palette[props.color || 'primary'].main; },
766
+ color: 'white',
767
+ },
768
+ },
769
+ }); });
770
+
771
+ var ToggleButton = React.forwardRef(function (props, ref) {
772
+ var children = props.children, muiProps = __rest(props, ["children"]);
773
+ var classes = useToggleButtonStyles(props);
774
+ return (React__default['default'].createElement(MuiToggleButton__default['default'], __assign({ ref: ref, classes: {
775
+ root: classes.root,
776
+ selected: classes.selected,
777
+ } }, muiProps), children));
778
+ });
779
+ ToggleButton.defaultProps = {
780
+ color: 'primary',
781
+ };
782
+ ToggleButton.displayName = 'ToggleButton';
783
+
784
+ var useToggleButtonGroupStyles = styles.makeStyles(function (theme) { return ({
785
+ root: {
786
+ '&&': {
787
+ backgroundColor: theme.palette.grey[300],
788
+ },
789
+ },
790
+ }); });
791
+
792
+ var ToggleButtonGroup = React.forwardRef(function (props, ref) {
793
+ var children = props.children, _a = props.color, color = _a === void 0 ? 'primary' : _a, muiProps = __rest(props, ["children", "color"]);
794
+ var classes = useToggleButtonGroupStyles(props);
795
+ var childrenWithProps = React__default['default'].Children.map(children, function (child) {
796
+ if (!React__default['default'].isValidElement(child)) {
797
+ return null;
798
+ }
799
+ return React__default['default'].cloneElement(child, { color: color });
800
+ });
801
+ return (React__default['default'].createElement(MuiToggleButtonGroup__default['default'], __assign({ ref: ref, classes: { root: classes.root } }, muiProps), childrenWithProps));
802
+ });
803
+ ToggleButtonGroup.displayName = 'ToggleButtonGroup';
804
+
805
+ var useTooltipStyles = styles.makeStyles(function (_a) {
806
+ var typography = _a.typography;
807
+ return ({
808
+ tooltip: {
809
+ fontSize: typography.pxToRem(16),
810
+ },
811
+ });
812
+ });
813
+
814
+ var Tooltip = React.forwardRef(function (props, ref) {
815
+ var classes = useTooltipStyles(props);
816
+ return React__default['default'].createElement(MuiTooltip__default['default'], __assign({ ref: ref, classes: classes }, props));
817
+ });
818
+ Tooltip.displayName = 'Tooltip';
819
+
820
+ core.makeStyles(function () { return ({
821
+ root: {
822
+ height: 56,
823
+ },
824
+ }); });
825
+ core.makeStyles(function (theme) { return ({
826
+ root: {
827
+ height: '100%',
828
+ width: 'min-content',
829
+ borderRadius: theme.spacing(1),
830
+ },
831
+ input: {
832
+ '&::-webkit-clear-button, &::-webkit-outer-spin-button, &::-webkit-inner-spin-button': {
833
+ display: 'none',
834
+ },
835
+ '-moz-appearance': 'textfield',
836
+ minWidth: 40,
837
+ padding: 0,
838
+ textAlign: 'center',
839
+ },
840
+ adornedStart: {
841
+ padding: 0,
842
+ },
843
+ adornedEnd: {
844
+ padding: 0,
845
+ },
846
+ }); });
847
+
848
+ var AUDIO_PLAYER_EVENT_TYPES;
849
+ (function (AUDIO_PLAYER_EVENT_TYPES) {
850
+ AUDIO_PLAYER_EVENT_TYPES["TOGGLE_PLAYBACK"] = "TOGGLE_PLAYBACK";
851
+ AUDIO_PLAYER_EVENT_TYPES["TOGGLE_VOLUME_CONTROL"] = "TOGGLE_VOLUME_CONTROL";
852
+ AUDIO_PLAYER_EVENT_TYPES["TOGGLE_MUTE"] = "TOGGLE_MUTE";
853
+ AUDIO_PLAYER_EVENT_TYPES["VOLUME_CHANGE"] = "VOLUME_CHANGE";
854
+ AUDIO_PLAYER_EVENT_TYPES["TIME_CHANGE"] = "TIME_CHANGE";
855
+ AUDIO_PLAYER_EVENT_TYPES["DURATION_CHANGE"] = "DURATION_CHANGE";
856
+ AUDIO_PLAYER_EVENT_TYPES["SET_TIME"] = "SET_TIME";
857
+ AUDIO_PLAYER_EVENT_TYPES["CAN_PLAY"] = "CAN_PLAY";
858
+ AUDIO_PLAYER_EVENT_TYPES["RESET"] = "RESET";
859
+ })(AUDIO_PLAYER_EVENT_TYPES || (AUDIO_PLAYER_EVENT_TYPES = {}));
860
+ var PLAYBACK_STATES;
861
+ (function (PLAYBACK_STATES) {
862
+ PLAYBACK_STATES["NONE"] = "NONE";
863
+ PLAYBACK_STATES["PAUSED"] = "PAUSED";
864
+ PLAYBACK_STATES["PLAYING"] = "PLAYING";
865
+ })(PLAYBACK_STATES || (PLAYBACK_STATES = {}));
866
+ var CONTROL_LABELS;
867
+ (function (CONTROL_LABELS) {
868
+ CONTROL_LABELS["PAUSE"] = "PAUSE";
869
+ CONTROL_LABELS["PLAY"] = "PLAY";
870
+ CONTROL_LABELS["MUTE"] = "MUTE";
871
+ CONTROL_LABELS["UNMUTE"] = "UNMUTE";
872
+ })(CONTROL_LABELS || (CONTROL_LABELS = {}));
873
+ var VOLUME_CONTROL_STATES;
874
+ (function (VOLUME_CONTROL_STATES) {
875
+ VOLUME_CONTROL_STATES["SHOW"] = "SHOW";
876
+ VOLUME_CONTROL_STATES["HIDE"] = "HIDE";
877
+ })(VOLUME_CONTROL_STATES || (VOLUME_CONTROL_STATES = {}));
878
+
879
+ var initialAudioPlayerState = {
880
+ playback: PLAYBACK_STATES.NONE,
881
+ volumeControls: VOLUME_CONTROL_STATES.HIDE,
882
+ context: {
883
+ volume: 100,
884
+ playbackButtonLabel: CONTROL_LABELS.PLAY,
885
+ volumeButtonLabel: CONTROL_LABELS.MUTE,
886
+ },
887
+ };
888
+ var getPlayback = function (_a) {
889
+ var audio = _a.current;
890
+ var playback = PLAYBACK_STATES.NONE;
891
+ if (audio) {
892
+ var paused = audio.paused, readyState = audio.readyState;
893
+ if (readyState === 0) {
894
+ playback = PLAYBACK_STATES.NONE;
895
+ }
896
+ else if (paused) {
897
+ playback = PLAYBACK_STATES.PAUSED;
898
+ }
899
+ else {
900
+ playback = PLAYBACK_STATES.PLAYING;
901
+ }
902
+ }
903
+ return playback;
904
+ };
905
+ var audioPlayerReducer = function (state, event) {
906
+ var _a, _b;
907
+ var audioRef = state.context.audioRef;
908
+ var nextState = __assign$1({}, state);
909
+ switch (state.playback) {
910
+ case PLAYBACK_STATES.NONE:
911
+ if (event.type === AUDIO_PLAYER_EVENT_TYPES.CAN_PLAY) {
912
+ nextState.playback = getPlayback(audioRef);
913
+ return nextState;
914
+ }
915
+ break;
916
+ case PLAYBACK_STATES.PAUSED:
917
+ if (event.type === AUDIO_PLAYER_EVENT_TYPES.TOGGLE_PLAYBACK) {
918
+ (_a = audioRef.current) === null || _a === void 0 ? void 0 : _a.play();
919
+ nextState.playback = getPlayback(audioRef);
920
+ nextState.context.playbackButtonLabel = CONTROL_LABELS.PAUSE;
921
+ return nextState;
922
+ }
923
+ break;
924
+ case PLAYBACK_STATES.PLAYING:
925
+ if (event.type === AUDIO_PLAYER_EVENT_TYPES.TOGGLE_PLAYBACK) {
926
+ (_b = audioRef.current) === null || _b === void 0 ? void 0 : _b.pause();
927
+ nextState.playback = getPlayback(audioRef);
928
+ nextState.context.playbackButtonLabel = CONTROL_LABELS.PLAY;
929
+ return nextState;
930
+ }
931
+ if (event.type === AUDIO_PLAYER_EVENT_TYPES.TIME_CHANGE) {
932
+ return nextState;
933
+ }
934
+ break;
935
+ }
936
+ switch (state.volumeControls) {
937
+ case VOLUME_CONTROL_STATES.SHOW:
938
+ if (event.type === AUDIO_PLAYER_EVENT_TYPES.TOGGLE_VOLUME_CONTROL) {
939
+ nextState.volumeControls = VOLUME_CONTROL_STATES.HIDE;
940
+ return nextState;
941
+ }
942
+ if (event.type === AUDIO_PLAYER_EVENT_TYPES.VOLUME_CHANGE) {
943
+ if (nextState.context.volume !== event.context.volume) {
944
+ nextState.context.volume = event.context.volume;
945
+ if (audioRef.current) {
946
+ audioRef.current.volume = event.context.volume;
947
+ }
948
+ return nextState;
949
+ }
950
+ }
951
+ break;
952
+ case VOLUME_CONTROL_STATES.HIDE:
953
+ if (event.type === AUDIO_PLAYER_EVENT_TYPES.TOGGLE_VOLUME_CONTROL) {
954
+ nextState.volumeControls = VOLUME_CONTROL_STATES.SHOW;
955
+ return nextState;
956
+ }
957
+ break;
958
+ }
959
+ switch (event.type) {
960
+ case AUDIO_PLAYER_EVENT_TYPES.TOGGLE_MUTE:
961
+ if (audioRef.current) {
962
+ audioRef.current.muted = !audioRef.current.muted;
963
+ return nextState;
964
+ }
965
+ break;
966
+ case AUDIO_PLAYER_EVENT_TYPES.SET_TIME:
967
+ if (audioRef.current) {
968
+ audioRef.current.currentTime = event.context.time;
969
+ return nextState;
970
+ }
971
+ break;
972
+ case AUDIO_PLAYER_EVENT_TYPES.RESET:
973
+ if (audioRef.current) {
974
+ audioRef.current.currentTime = 0;
975
+ nextState.playback = getPlayback(audioRef);
976
+ return nextState;
977
+ }
978
+ break;
979
+ }
980
+ return state;
981
+ };
982
+
983
+ var useVolumeIcon = function (state) {
984
+ var volumeIcon = SvgVolumeUp;
985
+ if (state.context.volume >= 0.5) {
986
+ volumeIcon = SvgVolumeUp;
987
+ }
988
+ else if (state.context.volume < 0.5 && state.context.volume > 0) {
989
+ volumeIcon = SvgVolumeDown;
990
+ }
991
+ else if (state.context.volume === 0) {
992
+ volumeIcon = SvgVolumeMute;
993
+ }
994
+ if (state.context.audioRef.current) {
995
+ if (state.context.audioRef.current.muted) {
996
+ volumeIcon = SvgVolumeOff;
997
+ }
998
+ }
999
+ return volumeIcon;
1000
+ };
1001
+
1002
+ var appendZero = function (num) { return (num < 10 ? "0" + num : num); };
1003
+ var formatTime = function (time, remaning) {
1004
+ if (remaning === void 0) { remaning = false; }
1005
+ var dateTime = new Date(0, 0, 0, 0, 0, time, 0);
1006
+ var dateTimeH = appendZero(dateTime.getHours());
1007
+ var dateTimeM = appendZero(dateTime.getMinutes());
1008
+ var dateTimeS = appendZero(dateTime.getSeconds());
1009
+ var minus = remaning ? '-' : '';
1010
+ return dateTimeH > 0 ? "" + minus + dateTimeH + ":" + dateTimeM + ":" + dateTimeS : "" + minus + dateTimeM + ":" + dateTimeS;
1011
+ };
1012
+
1013
+ var setupAudioRef = function (config) { return function () {
1014
+ var _a, _b, _c, _d;
1015
+ var audioRef = config.audioRef, send = config.send;
1016
+ var handleDurationChange = function (event) {
1017
+ var duration = event.target.duration;
1018
+ send({ type: AUDIO_PLAYER_EVENT_TYPES.DURATION_CHANGE, context: { duration: duration } });
1019
+ };
1020
+ var handleTimeUpdate = function (event) {
1021
+ var currentTime = event.target.currentTime;
1022
+ send({ type: AUDIO_PLAYER_EVENT_TYPES.TIME_CHANGE, context: { currentTime: currentTime } });
1023
+ };
1024
+ var handleCanPlay = function () {
1025
+ send({ type: AUDIO_PLAYER_EVENT_TYPES.CAN_PLAY });
1026
+ };
1027
+ var handleEnded = function () {
1028
+ send({ type: AUDIO_PLAYER_EVENT_TYPES.RESET });
1029
+ };
1030
+ (_a = audioRef.current) === null || _a === void 0 ? void 0 : _a.addEventListener('durationchange', handleDurationChange);
1031
+ (_b = audioRef.current) === null || _b === void 0 ? void 0 : _b.addEventListener('timeupdate', handleTimeUpdate);
1032
+ (_c = audioRef.current) === null || _c === void 0 ? void 0 : _c.addEventListener('canplay', handleCanPlay);
1033
+ (_d = audioRef.current) === null || _d === void 0 ? void 0 : _d.addEventListener('ended', handleEnded);
1034
+ return function () {
1035
+ var _a, _b, _c, _d;
1036
+ (_a = audioRef.current) === null || _a === void 0 ? void 0 : _a.removeEventListener('durationchange', handleDurationChange);
1037
+ (_b = audioRef.current) === null || _b === void 0 ? void 0 : _b.removeEventListener('timeupdate', handleTimeUpdate);
1038
+ (_c = audioRef.current) === null || _c === void 0 ? void 0 : _c.removeEventListener('canplay', handleCanPlay);
1039
+ (_d = audioRef.current) === null || _d === void 0 ? void 0 : _d.removeEventListener('ended', handleEnded);
1040
+ };
1041
+ }; };
1042
+
1043
+ var AudioPlayer = function (props) {
1044
+ var _a, _b, _c, _d, _f;
1045
+ var src = props.src, _g = props.classes, classes = _g === void 0 ? {} : _g;
1046
+ var volumeRef = React.useRef(null);
1047
+ var audioRef = React.useRef(null);
1048
+ var spacing = core.useTheme().spacing;
1049
+ var _h = React.useState(false), disableRipple = _h[0], setDisableRipple = _h[1];
1050
+ var _j = React.useReducer(audioPlayerReducer, __assign$1(__assign$1({}, initialAudioPlayerState), { context: __assign$1(__assign$1({}, initialAudioPlayerState.context), { audioRef: audioRef }) })), state = _j[0], send = _j[1];
1051
+ React.useEffect(setupAudioRef({ audioRef: audioRef, send: send }), [audioRef]);
1052
+ var PlaybackIcon = state.playback !== PLAYBACK_STATES.PAUSED ? SvgPause : SvgPlay;
1053
+ var VolumeIcon = React.useMemo(function () { return useVolumeIcon(state); }, [state.context.volume, (_a = state.context.audioRef.current) === null || _a === void 0 ? void 0 : _a.muted]);
1054
+ var togglePlayback = function () { return send({ type: AUDIO_PLAYER_EVENT_TYPES.TOGGLE_PLAYBACK }); };
1055
+ var toggleVolumeControl = function () { return send({ type: AUDIO_PLAYER_EVENT_TYPES.TOGGLE_VOLUME_CONTROL }); };
1056
+ var toggleMute = function () { return send({ type: AUDIO_PLAYER_EVENT_TYPES.TOGGLE_MUTE }); };
1057
+ var setTime = function (_e, time) { return send({ type: AUDIO_PLAYER_EVENT_TYPES.SET_TIME, context: { time: time } }); };
1058
+ var setVolume = function (_e, volume) { return send({ type: AUDIO_PLAYER_EVENT_TYPES.VOLUME_CHANGE, context: { volume: volume } }); };
1059
+ return (React__default['default'].createElement(core.Box, { display: "flex", alignItems: "center", gridGap: spacing(1), className: classNames$1([classes.root]) },
1060
+ React__default['default'].createElement("audio", { ref: audioRef, src: src }),
1061
+ React__default['default'].createElement(core.Box, null,
1062
+ React__default['default'].createElement(IconButton, { classes: { root: classes.playbackToggle }, "aria-label": state.context.playbackButtonLabel, disabled: state.playback === PLAYBACK_STATES.NONE, onClick: togglePlayback },
1063
+ React__default['default'].createElement(Icon, { icon: PlaybackIcon })),
1064
+ React__default['default'].createElement(IconButton, { classes: { root: classes.volumeToggle }, "aria-label": state.context.volumeButtonLabel, ref: volumeRef, onClick: toggleMute, onMouseEnter: toggleVolumeControl, onMouseLeave: toggleVolumeControl, disableRipple: disableRipple },
1065
+ React__default['default'].createElement(Icon, { icon: VolumeIcon }),
1066
+ React__default['default'].createElement(core.Popper, { onClick: function (e) { return e.stopPropagation(); }, onMouseEnter: function () { return setDisableRipple(true); }, onMouseLeave: function () { return setDisableRipple(false); }, open: state.volumeControls === VOLUME_CONTROL_STATES.SHOW, anchorEl: function () { return volumeRef.current; }, transition: true, placement: "top", className: classNames$1([classes.volumeSlider]) }, function (_a) {
1067
+ var TransitionProps = _a.TransitionProps;
1068
+ return (React__default['default'].createElement(core.Grow, __assign$1({}, TransitionProps),
1069
+ React__default['default'].createElement(Paper, { elevation: 1 },
1070
+ React__default['default'].createElement(core.Box, { py: 1, height: 80 },
1071
+ React__default['default'].createElement(core.Slider, { color: "secondary", orientation: "vertical", value: state.context.volume, onChange: setVolume, max: 1, step: 0.01 })))));
1072
+ }))),
1073
+ React__default['default'].createElement(core.Box, { display: "flex", flexGrow: 1, alignItems: "center", gridGap: spacing(1) },
1074
+ React__default['default'].createElement(core.Box, { flexBasis: 60, flexShrink: 0 },
1075
+ React__default['default'].createElement(Typography, { classes: { root: classes.playbackText } }, formatTime(((_b = state.context.audioRef.current) === null || _b === void 0 ? void 0 : _b.currentTime) || 0))),
1076
+ React__default['default'].createElement(core.Slider, { classes: { root: classes.playbackSlider }, color: "secondary", value: ((_c = state.context.audioRef.current) === null || _c === void 0 ? void 0 : _c.currentTime) || 0, max: ((_d = state.context.audioRef.current) === null || _d === void 0 ? void 0 : _d.duration) || 1, onChange: setTime, disabled: state.playback === PLAYBACK_STATES.NONE }),
1077
+ React__default['default'].createElement(core.Box, { flexBasis: 60, flexShrink: 0, textAlign: "end" },
1078
+ React__default['default'].createElement(Typography, { classes: { root: classes.lengthText } }, formatTime(((_f = state.context.audioRef.current) === null || _f === void 0 ? void 0 : _f.duration) || 0))))));
1079
+ };
1080
+
1081
+ exports.AudioPlayer = AudioPlayer;
1082
+ //# sourceMappingURL=index.js.map