@easy-editor/materials-dashboard-audio 0.0.2

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 (44) hide show
  1. package/.vite/plugins/vite-plugin-external-deps.ts +224 -0
  2. package/.vite/plugins/vite-plugin-material-dev.ts +218 -0
  3. package/CHANGELOG.md +7 -0
  4. package/LICENSE +9 -0
  5. package/dist/component.esm.js +165 -0
  6. package/dist/component.esm.js.map +1 -0
  7. package/dist/component.js +173 -0
  8. package/dist/component.js.map +1 -0
  9. package/dist/component.min.js +2 -0
  10. package/dist/component.min.js.map +1 -0
  11. package/dist/index.cjs +456 -0
  12. package/dist/index.cjs.map +1 -0
  13. package/dist/index.esm.js +453 -0
  14. package/dist/index.esm.js.map +1 -0
  15. package/dist/index.js +460 -0
  16. package/dist/index.js.map +1 -0
  17. package/dist/index.min.js +2 -0
  18. package/dist/index.min.js.map +1 -0
  19. package/dist/meta.esm.js +292 -0
  20. package/dist/meta.esm.js.map +1 -0
  21. package/dist/meta.js +303 -0
  22. package/dist/meta.js.map +1 -0
  23. package/dist/meta.min.js +2 -0
  24. package/dist/meta.min.js.map +1 -0
  25. package/dist/src/component.d.ts +23 -0
  26. package/dist/src/configure.d.ts +7 -0
  27. package/dist/src/constants.d.ts +16 -0
  28. package/dist/src/index.d.ts +6 -0
  29. package/dist/src/meta.d.ts +7 -0
  30. package/dist/src/snippets.d.ts +7 -0
  31. package/package.json +68 -0
  32. package/rollup.config.js +222 -0
  33. package/src/component.module.css +104 -0
  34. package/src/component.tsx +140 -0
  35. package/src/configure.ts +247 -0
  36. package/src/constants.ts +18 -0
  37. package/src/index.tsx +7 -0
  38. package/src/meta.ts +28 -0
  39. package/src/snippets.ts +50 -0
  40. package/src/type.d.ts +8 -0
  41. package/tsconfig.build.json +12 -0
  42. package/tsconfig.json +9 -0
  43. package/tsconfig.test.json +7 -0
  44. package/vite.config.ts +54 -0
@@ -0,0 +1,453 @@
1
+ import { useRef, useState, useEffect } from 'react';
2
+ import { jsx, jsxs } from 'react/jsx-runtime';
3
+
4
+ function styleInject(css, ref) {
5
+ if (ref === void 0) ref = {};
6
+ var insertAt = ref.insertAt;
7
+ if (typeof document === 'undefined') {
8
+ return;
9
+ }
10
+ var head = document.head || document.getElementsByTagName('head')[0];
11
+ var style = document.createElement('style');
12
+ style.type = 'text/css';
13
+ if (insertAt === 'top') {
14
+ if (head.firstChild) {
15
+ head.insertBefore(style, head.firstChild);
16
+ } else {
17
+ head.appendChild(style);
18
+ }
19
+ } else {
20
+ head.appendChild(style);
21
+ }
22
+ if (style.styleSheet) {
23
+ style.styleSheet.cssText = css;
24
+ } else {
25
+ style.appendChild(document.createTextNode(css));
26
+ }
27
+ }
28
+
29
+ var css_248z = ".component-module__container___VbZSk{align-items:center;background:rgba(10,10,26,.95);border:1px solid rgba(26,26,62,.8);border-radius:8px;display:flex;gap:12px;height:100%;padding:12px 16px;width:100%}.component-module__playButton___M6QVA{align-items:center;background:linear-gradient(135deg,#00d4ff,#9b59b6);border:none;border-radius:50%;cursor:pointer;display:flex;flex-shrink:0;height:40px;justify-content:center;transition:transform .2s ease;width:40px}.component-module__playButton___M6QVA:hover{transform:scale(1.05)}.component-module__playIcon___t8-WV{border-bottom:8px solid transparent;border-left:12px solid #fff;border-top:8px solid transparent;height:0;margin-left:3px;width:0}.component-module__pauseIcon___8XmSk{display:flex;gap:3px}.component-module__pauseBar___eM6DG{background:#fff;border-radius:2px;height:14px;width:4px}.component-module__info___VyTlr{flex:1;min-width:0}.component-module__title___Hj54k{color:#e6e6e6;font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.component-module__progressContainer___HvygE{align-items:center;display:flex;gap:8px;margin-top:4px}.component-module__progressBar___wROZC{background:rgba(26,26,62,.8);border-radius:2px;cursor:pointer;flex:1;height:4px;overflow:hidden}.component-module__progressFill___F8n5d{background:linear-gradient(90deg,#00d4ff,#9b59b6);border-radius:2px;height:100%;transition:width .1s linear}.component-module__time___-5GMu{color:hsla(0,0%,100%,.6);font-family:Courier New,Courier,monospace;font-size:12px;min-width:80px;text-align:right}.component-module__nativeAudio___vCo17{width:100%}";
30
+ var styles = {"container":"component-module__container___VbZSk","playButton":"component-module__playButton___M6QVA","playIcon":"component-module__playIcon___t8-WV","pauseIcon":"component-module__pauseIcon___8XmSk","pauseBar":"component-module__pauseBar___eM6DG","info":"component-module__info___VyTlr","title":"component-module__title___Hj54k","progressContainer":"component-module__progressContainer___HvygE","progressBar":"component-module__progressBar___wROZC","progressFill":"component-module__progressFill___F8n5d","time":"component-module__time___-5GMu","nativeAudio":"component-module__nativeAudio___vCo17"};
31
+ styleInject(css_248z);
32
+
33
+ /**
34
+ * Audio Component
35
+ * 音频播放组件
36
+ */
37
+
38
+ const formatTime = seconds => {
39
+ const mins = Math.floor(seconds / 60);
40
+ const secs = Math.floor(seconds % 60);
41
+ return `${mins}:${secs.toString().padStart(2, '0')}`;
42
+ };
43
+ const Audio = ({
44
+ ref,
45
+ src = '',
46
+ title = '音频文件',
47
+ autoPlay = false,
48
+ loop = false,
49
+ audioStyle = 'custom',
50
+ style: externalStyle
51
+ }) => {
52
+ const audioRef = useRef(null);
53
+ const [isPlaying, setIsPlaying] = useState(false);
54
+ const [currentTime, setCurrentTime] = useState(0);
55
+ const [duration, setDuration] = useState(0);
56
+ useEffect(() => {
57
+ const audio = audioRef.current;
58
+ if (!audio) {
59
+ return;
60
+ }
61
+ const handleTimeUpdate = () => setCurrentTime(audio.currentTime);
62
+ const handleLoadedMetadata = () => setDuration(audio.duration);
63
+ const handleEnded = () => setIsPlaying(false);
64
+ audio.addEventListener('timeupdate', handleTimeUpdate);
65
+ audio.addEventListener('loadedmetadata', handleLoadedMetadata);
66
+ audio.addEventListener('ended', handleEnded);
67
+ return () => {
68
+ audio.removeEventListener('timeupdate', handleTimeUpdate);
69
+ audio.removeEventListener('loadedmetadata', handleLoadedMetadata);
70
+ audio.removeEventListener('ended', handleEnded);
71
+ };
72
+ }, []);
73
+ const togglePlay = () => {
74
+ if (audioRef.current) {
75
+ if (isPlaying) {
76
+ audioRef.current.pause();
77
+ } else {
78
+ audioRef.current.play();
79
+ }
80
+ setIsPlaying(!isPlaying);
81
+ }
82
+ };
83
+ const handleProgressClick = e => {
84
+ if (audioRef.current && duration) {
85
+ const rect = e.currentTarget.getBoundingClientRect();
86
+ const percent = (e.clientX - rect.left) / rect.width;
87
+ audioRef.current.currentTime = percent * duration;
88
+ }
89
+ };
90
+ const progress = duration ? currentTime / duration * 100 : 0;
91
+
92
+ // 原生样式
93
+ if (audioStyle === 'native') {
94
+ return /*#__PURE__*/jsx("div", {
95
+ className: styles.container,
96
+ ref: ref,
97
+ style: externalStyle,
98
+ children: /*#__PURE__*/jsx("audio", {
99
+ autoPlay: autoPlay,
100
+ className: styles.nativeAudio,
101
+ controls: true,
102
+ loop: loop,
103
+ ref: audioRef,
104
+ src: src
105
+ })
106
+ });
107
+ }
108
+
109
+ // 自定义样式
110
+ return /*#__PURE__*/jsxs("div", {
111
+ className: styles.container,
112
+ ref: ref,
113
+ style: externalStyle,
114
+ children: [/*#__PURE__*/jsx("audio", {
115
+ autoPlay: autoPlay,
116
+ loop: loop,
117
+ ref: audioRef,
118
+ src: src
119
+ }), /*#__PURE__*/jsx("button", {
120
+ "aria-label": isPlaying ? 'Pause' : 'Play',
121
+ className: styles.playButton,
122
+ onClick: togglePlay,
123
+ type: "button",
124
+ children: isPlaying ? /*#__PURE__*/jsxs("div", {
125
+ className: styles.pauseIcon,
126
+ children: [/*#__PURE__*/jsx("div", {
127
+ className: styles.pauseBar
128
+ }), /*#__PURE__*/jsx("div", {
129
+ className: styles.pauseBar
130
+ })]
131
+ }) : /*#__PURE__*/jsx("div", {
132
+ className: styles.playIcon
133
+ })
134
+ }), /*#__PURE__*/jsxs("div", {
135
+ className: styles.info,
136
+ children: [/*#__PURE__*/jsx("div", {
137
+ className: styles.title,
138
+ children: title
139
+ }), /*#__PURE__*/jsxs("div", {
140
+ className: styles.progressContainer,
141
+ children: [/*#__PURE__*/jsx("button", {
142
+ "aria-label": "Seek to position",
143
+ className: styles.progressBar
144
+ // @ts-expect-error
145
+ ,
146
+ onClick: handleProgressClick,
147
+ type: "button",
148
+ children: /*#__PURE__*/jsx("div", {
149
+ className: styles.progressFill,
150
+ style: {
151
+ width: `${progress}%`
152
+ }
153
+ })
154
+ }), /*#__PURE__*/jsxs("span", {
155
+ className: styles.time,
156
+ children: [formatTime(currentTime), " / ", formatTime(duration || 0)]
157
+ })]
158
+ })]
159
+ })]
160
+ });
161
+ };
162
+
163
+ const MaterialGroup = {
164
+ MEDIA: 'media'};
165
+
166
+ const COMPONENT_NAME = 'EasyEditorMaterialsAudio';
167
+ const PACKAGE_NAME = '@easy-editor/materials-dashboard-audio';
168
+
169
+ const configure = {
170
+ props: [{
171
+ type: 'group',
172
+ title: '属性',
173
+ setter: 'TabSetter',
174
+ items: [{
175
+ type: 'group',
176
+ key: 'config',
177
+ title: '配置',
178
+ setter: {
179
+ componentName: 'CollapseSetter',
180
+ props: {
181
+ icon: false
182
+ }
183
+ },
184
+ items: [
185
+ {
186
+ name: 'id',
187
+ title: 'ID',
188
+ setter: 'NodeIdSetter',
189
+ extraProps: {
190
+ label: false
191
+ }
192
+ }, {
193
+ name: 'title',
194
+ title: '标题',
195
+ setter: 'StringSetter',
196
+ extraProps: {
197
+ getValue(target) {
198
+ return target.getExtraPropValue('title');
199
+ },
200
+ setValue(target, value) {
201
+ target.setExtraPropValue('title', value);
202
+ }
203
+ }
204
+ }, {
205
+ type: 'group',
206
+ title: '基础属性',
207
+ setter: {
208
+ componentName: 'CollapseSetter',
209
+ props: {
210
+ icon: false
211
+ }
212
+ },
213
+ items: [{
214
+ name: 'rect',
215
+ title: '位置尺寸',
216
+ setter: 'RectSetter',
217
+ extraProps: {
218
+ getValue(target) {
219
+ return target.getExtraPropValue('$dashboard.rect');
220
+ },
221
+ setValue(target, value) {
222
+ target.setExtraPropValue('$dashboard.rect', value);
223
+ }
224
+ }
225
+ }]
226
+ },
227
+ {
228
+ type: 'group',
229
+ title: '内容',
230
+ setter: {
231
+ componentName: 'CollapseSetter',
232
+ props: {
233
+ icon: false
234
+ }
235
+ },
236
+ items: [{
237
+ name: '__upload',
238
+ title: '上传',
239
+ setter: {
240
+ componentName: 'UploadSetter',
241
+ props: {
242
+ accept: '.mp3,.wav,.ogg'
243
+ }
244
+ },
245
+ extraProps: {
246
+ setValue(target, value) {
247
+ if (value) {
248
+ const {
249
+ base64,
250
+ raw
251
+ } = value;
252
+ if (base64) {
253
+ target.parent.setPropValue('src', base64);
254
+ }
255
+ if (raw?.width) {
256
+ target.parent.setExtraPropValue('$dashboard.rect.width', raw.width);
257
+ }
258
+ if (raw?.height) {
259
+ target.parent.setExtraPropValue('$dashboard.rect.height', raw.height);
260
+ }
261
+ } else {
262
+ target.parent.clearPropValue('src');
263
+ }
264
+ }
265
+ }
266
+ }, {
267
+ name: 'src',
268
+ title: '音频地址',
269
+ setter: 'StringSetter'
270
+ }, {
271
+ name: 'title',
272
+ title: '标题',
273
+ setter: 'StringSetter',
274
+ extraProps: {
275
+ defaultValue: '音频文件'
276
+ }
277
+ }]
278
+ }, {
279
+ type: 'group',
280
+ title: '播放',
281
+ setter: {
282
+ componentName: 'CollapseSetter',
283
+ props: {
284
+ icon: false
285
+ }
286
+ },
287
+ items: [{
288
+ name: 'autoPlay',
289
+ title: '自动播放',
290
+ setter: 'SwitchSetter',
291
+ extraProps: {
292
+ defaultValue: false
293
+ }
294
+ }, {
295
+ name: 'loop',
296
+ title: '循环播放',
297
+ setter: 'SwitchSetter',
298
+ extraProps: {
299
+ defaultValue: false
300
+ }
301
+ }, {
302
+ name: 'audioStyle',
303
+ title: '样式类型',
304
+ setter: {
305
+ componentName: 'SelectSetter',
306
+ props: {
307
+ options: [{
308
+ label: '自定义',
309
+ value: 'custom'
310
+ }, {
311
+ label: '原生',
312
+ value: 'native'
313
+ }]
314
+ }
315
+ },
316
+ extraProps: {
317
+ defaultValue: 'custom'
318
+ }
319
+ }, {
320
+ name: 'playbackRate',
321
+ title: '播放速度',
322
+ setter: {
323
+ componentName: 'SelectSetter',
324
+ props: {
325
+ options: [{
326
+ label: '0.5x',
327
+ value: 0.5
328
+ }, {
329
+ label: '0.75x',
330
+ value: 0.75
331
+ }, {
332
+ label: '1x (正常)',
333
+ value: 1
334
+ }, {
335
+ label: '1.25x',
336
+ value: 1.25
337
+ }, {
338
+ label: '1.5x',
339
+ value: 1.5
340
+ }, {
341
+ label: '2x',
342
+ value: 2
343
+ }]
344
+ }
345
+ },
346
+ extraProps: {
347
+ defaultValue: 1
348
+ }
349
+ }, {
350
+ name: 'volume',
351
+ title: '音量',
352
+ setter: {
353
+ componentName: 'SliderSetter',
354
+ props: {
355
+ min: 0,
356
+ max: 100,
357
+ step: 1,
358
+ suffix: '%'
359
+ }
360
+ },
361
+ extraProps: {
362
+ defaultValue: 100
363
+ }
364
+ }]
365
+ }]
366
+ }, {
367
+ type: 'group',
368
+ key: 'data',
369
+ title: '数据',
370
+ items: [{
371
+ name: 'dataBinding',
372
+ title: '数据绑定',
373
+ setter: 'DataBindingSetter'
374
+ }]
375
+ }, {
376
+ type: 'group',
377
+ key: 'advanced',
378
+ title: '高级',
379
+ items: [{
380
+ name: 'condition',
381
+ title: '显隐控制',
382
+ setter: 'SwitchSetter',
383
+ extraProps: {
384
+ defaultValue: true,
385
+ supportVariable: true
386
+ }
387
+ }]
388
+ }]
389
+ }],
390
+ component: {},
391
+ supports: {},
392
+ advanced: {}
393
+ };
394
+
395
+ const snippets = [{
396
+ title: '音频播放器',
397
+ screenshot: '',
398
+ schema: {
399
+ componentName: COMPONENT_NAME,
400
+ props: {
401
+ src: '',
402
+ title: '音频文件',
403
+ autoPlay: false,
404
+ loop: false,
405
+ audioStyle: 'custom'
406
+ },
407
+ $dashboard: {
408
+ rect: {
409
+ width: 300,
410
+ height: 60
411
+ }
412
+ }
413
+ }
414
+ }, {
415
+ title: '原生音频',
416
+ screenshot: '',
417
+ schema: {
418
+ componentName: COMPONENT_NAME,
419
+ props: {
420
+ src: '',
421
+ title: '音频文件',
422
+ audioStyle: 'native'
423
+ },
424
+ $dashboard: {
425
+ rect: {
426
+ width: 300,
427
+ height: 60
428
+ }
429
+ }
430
+ }
431
+ }];
432
+
433
+ var version = "0.0.1";
434
+ var pkg = {
435
+ version: version};
436
+
437
+ const meta = {
438
+ componentName: COMPONENT_NAME,
439
+ title: '音频',
440
+ group: MaterialGroup.MEDIA,
441
+ devMode: 'proCode',
442
+ npm: {
443
+ package: PACKAGE_NAME,
444
+ version: pkg.version,
445
+ globalName: COMPONENT_NAME,
446
+ componentName: COMPONENT_NAME
447
+ },
448
+ snippets,
449
+ configure
450
+ };
451
+
452
+ export { Audio as component, meta };
453
+ //# sourceMappingURL=index.esm.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.esm.js","sources":["../../../../../node_modules/.pnpm/style-inject@0.3.0/node_modules/style-inject/dist/style-inject.es.js","../src/component.tsx","../../../../shared/src/index.ts","../src/constants.ts","../src/configure.ts","../src/snippets.ts","../src/meta.ts"],"sourcesContent":["function styleInject(css, ref) {\n if ( ref === void 0 ) ref = {};\n var insertAt = ref.insertAt;\n\n if (!css || typeof document === 'undefined') { return; }\n\n var head = document.head || document.getElementsByTagName('head')[0];\n var style = document.createElement('style');\n style.type = 'text/css';\n\n if (insertAt === 'top') {\n if (head.firstChild) {\n head.insertBefore(style, head.firstChild);\n } else {\n head.appendChild(style);\n }\n } else {\n head.appendChild(style);\n }\n\n if (style.styleSheet) {\n style.styleSheet.cssText = css;\n } else {\n style.appendChild(document.createTextNode(css));\n }\n}\n\nexport default styleInject;\n","/**\n * Audio Component\n * 音频播放组件\n */\n\nimport { useState, useRef, useEffect, type CSSProperties, type Ref } from 'react'\nimport styles from './component.module.css'\n\nexport type AudioStyle = 'custom' | 'native'\n\nexport interface AudioProps {\n ref?: Ref<HTMLDivElement>\n /** 音频地址 */\n src?: string\n /** 标题 */\n title?: string\n /** 自动播放 */\n autoPlay?: boolean\n /** 循环播放 */\n loop?: boolean\n /** 样式类型 */\n audioStyle?: AudioStyle\n /** 外部样式 */\n style?: CSSProperties\n}\n\nconst formatTime = (seconds: number): string => {\n const mins = Math.floor(seconds / 60)\n const secs = Math.floor(seconds % 60)\n return `${mins}:${secs.toString().padStart(2, '0')}`\n}\n\nexport const Audio: React.FC<AudioProps> = ({\n ref,\n src = '',\n title = '音频文件',\n autoPlay = false,\n loop = false,\n audioStyle = 'custom',\n style: externalStyle,\n}) => {\n const audioRef = useRef<HTMLAudioElement>(null)\n const [isPlaying, setIsPlaying] = useState(false)\n const [currentTime, setCurrentTime] = useState(0)\n const [duration, setDuration] = useState(0)\n\n useEffect(() => {\n const audio = audioRef.current\n if (!audio) {\n return\n }\n\n const handleTimeUpdate = () => setCurrentTime(audio.currentTime)\n const handleLoadedMetadata = () => setDuration(audio.duration)\n const handleEnded = () => setIsPlaying(false)\n\n audio.addEventListener('timeupdate', handleTimeUpdate)\n audio.addEventListener('loadedmetadata', handleLoadedMetadata)\n audio.addEventListener('ended', handleEnded)\n\n return () => {\n audio.removeEventListener('timeupdate', handleTimeUpdate)\n audio.removeEventListener('loadedmetadata', handleLoadedMetadata)\n audio.removeEventListener('ended', handleEnded)\n }\n }, [])\n\n const togglePlay = () => {\n if (audioRef.current) {\n if (isPlaying) {\n audioRef.current.pause()\n } else {\n audioRef.current.play()\n }\n setIsPlaying(!isPlaying)\n }\n }\n\n const handleProgressClick = (e: React.MouseEvent<HTMLDivElement>) => {\n if (audioRef.current && duration) {\n const rect = e.currentTarget.getBoundingClientRect()\n const percent = (e.clientX - rect.left) / rect.width\n audioRef.current.currentTime = percent * duration\n }\n }\n\n const progress = duration ? (currentTime / duration) * 100 : 0\n\n // 原生样式\n if (audioStyle === 'native') {\n return (\n <div className={styles.container} ref={ref} style={externalStyle}>\n <audio autoPlay={autoPlay} className={styles.nativeAudio} controls loop={loop} ref={audioRef} src={src} />\n </div>\n )\n }\n\n // 自定义样式\n return (\n <div className={styles.container} ref={ref} style={externalStyle}>\n <audio autoPlay={autoPlay} loop={loop} ref={audioRef} src={src} />\n\n <button\n aria-label={isPlaying ? 'Pause' : 'Play'}\n className={styles.playButton}\n onClick={togglePlay}\n type='button'\n >\n {isPlaying ? (\n <div className={styles.pauseIcon}>\n <div className={styles.pauseBar} />\n <div className={styles.pauseBar} />\n </div>\n ) : (\n <div className={styles.playIcon} />\n )}\n </button>\n\n <div className={styles.info}>\n <div className={styles.title}>{title}</div>\n <div className={styles.progressContainer}>\n <button\n aria-label='Seek to position'\n className={styles.progressBar}\n // @ts-expect-error\n onClick={handleProgressClick}\n type='button'\n >\n <div className={styles.progressFill} style={{ width: `${progress}%` }} />\n </button>\n <span className={styles.time}>\n {formatTime(currentTime)} / {formatTime(duration || 0)}\n </span>\n </div>\n </div>\n </div>\n )\n}\n\nexport default Audio\n","/**\n * Shared types, components and utilities for EasyEditor materials\n * @package @easy-editor/materials-shared\n */\n\n// 物料分组常量\nexport const MaterialGroup = {\n /** 内置 */\n INNER: 'inner',\n /** 基础 */\n BASIC: 'basic',\n /** 图表 */\n CHART: 'chart',\n /** 数据展示 */\n DISPLAY: 'display',\n /** 媒体 */\n MEDIA: 'media',\n /** 交互 */\n INTERACTION: 'interaction',\n /** 地图 */\n MAP: 'map',\n} as const\n\nexport type MaterialGroup = (typeof MaterialGroup)[keyof typeof MaterialGroup]\n\n// 工具函数\nexport { cn } from './lib/utils'\n\nexport * from './types'\n","/**\n * 物料常量配置\n * 统一管理全局变量名等配置,确保 meta.ts 和 rollup.config.js 使用相同的值\n */\n\n/**\n * UMD 全局变量基础名称\n * 用于构建:\n * - 元数据:${GLOBAL_NAME}Meta (例如: EasyEditorMaterialsAudioMeta)\n * - 组件:${GLOBAL_NAME}Component (例如: EasyEditorMaterialsAudioComponent)\n * - 完整构建:${GLOBAL_NAME} (例如: EasyEditorMaterialsAudio)\n */\nexport const COMPONENT_NAME = 'EasyEditorMaterialsAudio'\n\n/**\n * 包名\n */\nexport const PACKAGE_NAME = '@easy-editor/materials-dashboard-audio'\n","/**\n * Audio Configure\n * 音频组件配置\n */\n\nimport type { Configure } from '@easy-editor/core'\nimport type { UploadValue } from '@easy-editor/materials-shared'\n\nexport const configure: Configure = {\n props: [\n {\n type: 'group',\n title: '属性',\n setter: 'TabSetter',\n items: [\n {\n type: 'group',\n key: 'config',\n title: '配置',\n setter: {\n componentName: 'CollapseSetter',\n props: {\n icon: false,\n },\n },\n items: [\n // 基础配置\n {\n name: 'id',\n title: 'ID',\n setter: 'NodeIdSetter',\n extraProps: {\n // @ts-expect-error label is not a valid extra prop\n label: false,\n },\n },\n {\n name: 'title',\n title: '标题',\n setter: 'StringSetter',\n extraProps: {\n getValue(target) {\n return target.getExtraPropValue('title')\n },\n setValue(target, value) {\n target.setExtraPropValue('title', value)\n },\n },\n },\n {\n type: 'group',\n title: '基础属性',\n setter: {\n componentName: 'CollapseSetter',\n props: {\n icon: false,\n },\n },\n items: [\n {\n name: 'rect',\n title: '位置尺寸',\n setter: 'RectSetter',\n extraProps: {\n getValue(target) {\n return target.getExtraPropValue('$dashboard.rect')\n },\n setValue(target, value) {\n target.setExtraPropValue('$dashboard.rect', value)\n },\n },\n },\n ],\n },\n // 组件配置\n {\n type: 'group',\n title: '内容',\n setter: {\n componentName: 'CollapseSetter',\n props: {\n icon: false,\n },\n },\n items: [\n {\n name: '__upload',\n title: '上传',\n setter: {\n componentName: 'UploadSetter',\n props: {\n accept: '.mp3,.wav,.ogg',\n },\n },\n extraProps: {\n setValue(target, value: UploadValue) {\n if (value) {\n const { base64, raw } = value\n if (base64) {\n target.parent.setPropValue('src', base64)\n }\n if (raw?.width) {\n target.parent.setExtraPropValue('$dashboard.rect.width', raw.width)\n }\n if (raw?.height) {\n target.parent.setExtraPropValue('$dashboard.rect.height', raw.height)\n }\n } else {\n target.parent.clearPropValue('src')\n }\n },\n },\n },\n {\n name: 'src',\n title: '音频地址',\n setter: 'StringSetter',\n },\n {\n name: 'title',\n title: '标题',\n setter: 'StringSetter',\n extraProps: {\n defaultValue: '音频文件',\n },\n },\n ],\n },\n {\n type: 'group',\n title: '播放',\n setter: {\n componentName: 'CollapseSetter',\n props: {\n icon: false,\n },\n },\n items: [\n {\n name: 'autoPlay',\n title: '自动播放',\n setter: 'SwitchSetter',\n extraProps: {\n defaultValue: false,\n },\n },\n {\n name: 'loop',\n title: '循环播放',\n setter: 'SwitchSetter',\n extraProps: {\n defaultValue: false,\n },\n },\n {\n name: 'audioStyle',\n title: '样式类型',\n setter: {\n componentName: 'SelectSetter',\n props: {\n options: [\n { label: '自定义', value: 'custom' },\n { label: '原生', value: 'native' },\n ],\n },\n },\n extraProps: {\n defaultValue: 'custom',\n },\n },\n {\n name: 'playbackRate',\n title: '播放速度',\n setter: {\n componentName: 'SelectSetter',\n props: {\n options: [\n { label: '0.5x', value: 0.5 },\n { label: '0.75x', value: 0.75 },\n { label: '1x (正常)', value: 1 },\n { label: '1.25x', value: 1.25 },\n { label: '1.5x', value: 1.5 },\n { label: '2x', value: 2 },\n ],\n },\n },\n extraProps: {\n defaultValue: 1,\n },\n },\n {\n name: 'volume',\n title: '音量',\n setter: {\n componentName: 'SliderSetter',\n props: {\n min: 0,\n max: 100,\n step: 1,\n suffix: '%',\n },\n },\n extraProps: {\n defaultValue: 100,\n },\n },\n ],\n },\n ],\n },\n {\n type: 'group',\n key: 'data',\n title: '数据',\n items: [\n {\n name: 'dataBinding',\n title: '数据绑定',\n setter: 'DataBindingSetter',\n },\n ],\n },\n {\n type: 'group',\n key: 'advanced',\n title: '高级',\n items: [\n {\n name: 'condition',\n title: '显隐控制',\n setter: 'SwitchSetter',\n extraProps: {\n defaultValue: true,\n supportVariable: true,\n },\n },\n ],\n },\n ],\n },\n ],\n component: {},\n supports: {},\n advanced: {},\n}\n\nexport default configure\n","/**\n * Audio Snippets\n * 音频组件代码片段\n */\n\nimport type { Snippet } from '@easy-editor/core'\nimport { COMPONENT_NAME } from './constants'\n\nexport const snippets: Snippet[] = [\n {\n title: '音频播放器',\n screenshot: '',\n schema: {\n componentName: COMPONENT_NAME,\n props: {\n src: '',\n title: '音频文件',\n autoPlay: false,\n loop: false,\n audioStyle: 'custom',\n },\n $dashboard: {\n rect: {\n width: 300,\n height: 60,\n },\n },\n },\n },\n {\n title: '原生音频',\n screenshot: '',\n schema: {\n componentName: COMPONENT_NAME,\n props: {\n src: '',\n title: '音频文件',\n audioStyle: 'native',\n },\n $dashboard: {\n rect: {\n width: 300,\n height: 60,\n },\n },\n },\n },\n]\n\nexport default snippets\n","/**\n * Audio Meta\n * 音频组件元数据\n */\n\nimport type { ComponentMetadata } from '@easy-editor/core'\nimport { MaterialGroup } from '@easy-editor/materials-shared'\nimport { COMPONENT_NAME, PACKAGE_NAME } from './constants'\nimport configure from './configure'\nimport snippets from './snippets'\nimport pkg from '../package.json'\n\nexport const meta: ComponentMetadata = {\n componentName: COMPONENT_NAME,\n title: '音频',\n group: MaterialGroup.MEDIA,\n devMode: 'proCode',\n npm: {\n package: PACKAGE_NAME,\n version: pkg.version,\n globalName: COMPONENT_NAME,\n componentName: COMPONENT_NAME,\n },\n snippets,\n configure,\n}\n\nexport default meta\n"],"names":["styleInject","css","ref","insertAt","document","head","getElementsByTagName","style","createElement","type","firstChild","insertBefore","appendChild","styleSheet","cssText","createTextNode","formatTime","seconds","mins","Math","floor","secs","toString","padStart","Audio","src","title","autoPlay","loop","audioStyle","externalStyle","audioRef","useRef","isPlaying","setIsPlaying","useState","currentTime","setCurrentTime","duration","setDuration","useEffect","audio","current","handleTimeUpdate","handleLoadedMetadata","handleEnded","addEventListener","removeEventListener","togglePlay","pause","play","handleProgressClick","e","rect","currentTarget","getBoundingClientRect","percent","clientX","left","width","progress","_jsx","className","styles","container","children","nativeAudio","controls","_jsxs","playButton","onClick","pauseIcon","pauseBar","playIcon","info","progressContainer","progressBar","progressFill","time","MaterialGroup","INNER","MEDIA","COMPONENT_NAME","PACKAGE_NAME","configure","props","setter","items","key","componentName","icon","name","extraProps","label","getValue","target","getExtraPropValue","setValue","value","setExtraPropValue","accept","base64","raw","parent","setPropValue","height","clearPropValue","defaultValue","options","min","max","step","suffix","supportVariable","component","supports","advanced","snippets","screenshot","schema","$dashboard","meta","group","devMode","npm","package","version","pkg","globalName"],"mappings":"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","x_google_ignoreList":[0]}