Compare commits
1 Commits
86e30e6ec3
...
plugin_mig
| Author | SHA1 | Date | |
|---|---|---|---|
| 8f367c9264 |
@ -16,18 +16,18 @@
|
|||||||
{
|
{
|
||||||
"endTime": 30,
|
"endTime": 30,
|
||||||
"filename": "C:\\Users\\mickl\\Desktop\\cliptrim-ui\\ClipTrimApp\\audio-service\\recordings\\audio_capture_20260220_193822.wav",
|
"filename": "C:\\Users\\mickl\\Desktop\\cliptrim-ui\\ClipTrimApp\\audio-service\\recordings\\audio_capture_20260220_193822.wav",
|
||||||
"name": "Pee pee poo poo",
|
"name": "Pee pee\npoo poo",
|
||||||
"playbackType": "playStop",
|
"playbackType": "playStop",
|
||||||
"startTime": 27.587412587412587,
|
"startTime": 27.756510985786615,
|
||||||
"volume": 1
|
"volume": 1
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"endTime": 27.516843118383072,
|
"endTime": 28.597210828548004,
|
||||||
"filename": "C:\\Users\\mickl\\Desktop\\cliptrim-ui\\ClipTrimApp\\audio-service\\recordings\\audio_capture_20260220_200442.wav",
|
"filename": "C:\\Users\\mickl\\Desktop\\cliptrim-ui\\ClipTrimApp\\audio-service\\recordings\\audio_capture_20260220_200442.wav",
|
||||||
"name": "Clip 20260220_200442",
|
"name": "Clip 20260220_200442",
|
||||||
"playbackType": "playOverlap",
|
"playbackType": "playStop",
|
||||||
"startTime": 25.120307988450435,
|
"startTime": 26.1853978671042,
|
||||||
"volume": 0.64
|
"volume": 1
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|||||||
Binary file not shown.
@ -28,9 +28,9 @@ class AudioRecorder:
|
|||||||
self.channels = 2
|
self.channels = 2
|
||||||
self.buffer = np.zeros((int(self.duration * self.sample_rate), self.channels), dtype=np.float32)
|
self.buffer = np.zeros((int(self.duration * self.sample_rate), self.channels), dtype=np.float32)
|
||||||
self.recordings_dir = "recordings"
|
self.recordings_dir = "recordings"
|
||||||
|
|
||||||
self.stream = sd.InputStream(
|
self.stream = sd.InputStream(
|
||||||
samplerate=self.sample_rate,
|
samplerate=self.sample_rate,
|
||||||
|
channels=self.channels,
|
||||||
callback=self.record_callback
|
callback=self.record_callback
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -43,9 +43,10 @@ class AudioRecorder:
|
|||||||
self.stream.stop()
|
self.stream.stop()
|
||||||
|
|
||||||
self.buffer = np.zeros((int(self.duration * self.sample_rate), self.channels), dtype=np.float32)
|
self.buffer = np.zeros((int(self.duration * self.sample_rate), self.channels), dtype=np.float32)
|
||||||
print(f"AudioRecorder initialized with duration={self.duration}s, sample_rate={self.sample_rate}Hz, channels={self.channels}")
|
|
||||||
self.stream = sd.InputStream(
|
self.stream = sd.InputStream(
|
||||||
samplerate=self.sample_rate,
|
samplerate=self.sample_rate,
|
||||||
|
channels=self.channels,
|
||||||
callback=self.record_callback
|
callback=self.record_callback
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|||||||
Binary file not shown.
@ -42,3 +42,12 @@ def recording_delete():
|
|||||||
return jsonify({'status': 'success'})
|
return jsonify({'status': 'success'})
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
return jsonify({'status': 'error', 'message': str(e)}), 400
|
return jsonify({'status': 'error', 'message': str(e)}), 400
|
||||||
|
|
||||||
|
@recording_bp.route('/playback/start', methods=['POST'])
|
||||||
|
def playback_start():
|
||||||
|
print('HTTP: Starting audio playback')
|
||||||
|
try:
|
||||||
|
# os.remove(filename)
|
||||||
|
return jsonify({'status': 'success'})
|
||||||
|
except Exception as e:
|
||||||
|
return jsonify({'status': 'error', 'message': str(e)}), 400
|
||||||
@ -2,8 +2,6 @@ import { MemoryRouter as Router, Routes, Route } from 'react-router-dom';
|
|||||||
import { useEffect, useState } from 'react';
|
import { useEffect, useState } from 'react';
|
||||||
import { Provider } from 'react-redux';
|
import { Provider } from 'react-redux';
|
||||||
import Dialog from '@mui/material/Dialog';
|
import Dialog from '@mui/material/Dialog';
|
||||||
|
|
||||||
import { ThemeProvider, createTheme } from '@mui/material/styles';
|
|
||||||
import DialogTitle from '@mui/material/DialogTitle';
|
import DialogTitle from '@mui/material/DialogTitle';
|
||||||
import DialogContent from '@mui/material/DialogContent';
|
import DialogContent from '@mui/material/DialogContent';
|
||||||
import DialogActions from '@mui/material/DialogActions';
|
import DialogActions from '@mui/material/DialogActions';
|
||||||
@ -12,8 +10,6 @@ import './App.css';
|
|||||||
import ClipList from './components/ClipList';
|
import ClipList from './components/ClipList';
|
||||||
import { useAppDispatch, useAppSelector } from './hooks';
|
import { useAppDispatch, useAppSelector } from './hooks';
|
||||||
import { store } from '../redux/main';
|
import { store } from '../redux/main';
|
||||||
import { useNavigate } from 'react-router-dom';
|
|
||||||
import SettingsPage from './Settings';
|
|
||||||
|
|
||||||
function MainPage() {
|
function MainPage() {
|
||||||
const dispatch = useAppDispatch();
|
const dispatch = useAppDispatch();
|
||||||
@ -25,7 +21,6 @@ function MainPage() {
|
|||||||
);
|
);
|
||||||
const [newCollectionOpen, setNewCollectionOpen] = useState(false);
|
const [newCollectionOpen, setNewCollectionOpen] = useState(false);
|
||||||
const [newCollectionName, setNewCollectionName] = useState<string>('');
|
const [newCollectionName, setNewCollectionName] = useState<string>('');
|
||||||
const navigate = useNavigate();
|
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
const fetchMetadata = async () => {
|
const fetchMetadata = async () => {
|
||||||
@ -142,22 +137,6 @@ function MainPage() {
|
|||||||
</li>
|
</li>
|
||||||
))}
|
))}
|
||||||
</ul>
|
</ul>
|
||||||
{/* Settings Button at Bottom Left */}
|
|
||||||
<div className="mt-auto mb-2">
|
|
||||||
<button
|
|
||||||
type="button"
|
|
||||||
className="w-full rounded px-4 py-2 bg-neutral-800 text-offwhite hover:bg-plumDark text-left"
|
|
||||||
style={{
|
|
||||||
position: 'absolute',
|
|
||||||
bottom: 16,
|
|
||||||
left: 8,
|
|
||||||
width: 'calc(100% - 16px)',
|
|
||||||
}}
|
|
||||||
onClick={() => navigate('/settings')}
|
|
||||||
>
|
|
||||||
⚙️ Settings
|
|
||||||
</button>
|
|
||||||
</div>
|
|
||||||
</nav>
|
</nav>
|
||||||
{/* Main Content */}
|
{/* Main Content */}
|
||||||
<div
|
<div
|
||||||
@ -171,39 +150,13 @@ function MainPage() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export default function App() {
|
export default function App() {
|
||||||
const theme = createTheme({
|
|
||||||
colorSchemes: {
|
|
||||||
light: false,
|
|
||||||
dark: {
|
|
||||||
palette: {
|
|
||||||
primary: {
|
|
||||||
main: '#6e44ba', // plum
|
|
||||||
dark: '#6e44ba', // plum
|
|
||||||
contrastText: '#ffffff',
|
|
||||||
},
|
|
||||||
secondary: {
|
|
||||||
main: '#4f3186', // plumDark
|
|
||||||
dark: '#4f3186', // plumDark
|
|
||||||
contrastText: '#ffffff',
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
// colorSchemes: {
|
|
||||||
// light: false,
|
|
||||||
// dark: true,
|
|
||||||
// },
|
|
||||||
});
|
|
||||||
return (
|
return (
|
||||||
<Provider store={store}>
|
<Provider store={store}>
|
||||||
<ThemeProvider theme={theme}>
|
|
||||||
<Router>
|
<Router>
|
||||||
<Routes>
|
<Routes>
|
||||||
<Route path="/" element={<MainPage />} />
|
<Route path="/" element={<MainPage />} />
|
||||||
<Route path="/settings" element={<SettingsPage />} />
|
|
||||||
</Routes>
|
</Routes>
|
||||||
</Router>
|
</Router>
|
||||||
</ThemeProvider>
|
|
||||||
</Provider>
|
</Provider>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,196 +0,0 @@
|
|||||||
import React, { useEffect, useState } from 'react';
|
|
||||||
import { useNavigate } from 'react-router-dom';
|
|
||||||
|
|
||||||
import './App.css';
|
|
||||||
import TextField from '@mui/material/TextField';
|
|
||||||
import Select from '@mui/material/Select';
|
|
||||||
import MenuItem from '@mui/material/MenuItem';
|
|
||||||
|
|
||||||
type AudioDevice = {
|
|
||||||
id: string;
|
|
||||||
label: string;
|
|
||||||
};
|
|
||||||
|
|
||||||
type Settings = {
|
|
||||||
httpPort: string;
|
|
||||||
inputDevice: AudioDevice;
|
|
||||||
outputDevice: AudioDevice;
|
|
||||||
recordingLength: number;
|
|
||||||
outputFolder: string;
|
|
||||||
};
|
|
||||||
|
|
||||||
const defaultSettings: Settings = {
|
|
||||||
httpPort: '',
|
|
||||||
inputDevice: { id: '', label: '' },
|
|
||||||
outputDevice: { id: '', label: '' },
|
|
||||||
recordingLength: 0,
|
|
||||||
outputFolder: '',
|
|
||||||
};
|
|
||||||
|
|
||||||
const fetchAudioDevices = async (): Promise<AudioDevice[]> => {
|
|
||||||
// Replace with actual backend call
|
|
||||||
// Example: return window.api.getAudioDevices();
|
|
||||||
return [
|
|
||||||
{ id: 'default-in', label: 'Default Input' },
|
|
||||||
{ id: 'mic-1', label: 'Microphone 1' },
|
|
||||||
{ id: 'default-out', label: 'Default Output' },
|
|
||||||
{ id: 'spk-1', label: 'Speakers 1' },
|
|
||||||
];
|
|
||||||
};
|
|
||||||
|
|
||||||
const sendSettingsToBackend = (settings: Settings) => {
|
|
||||||
// Replace with actual backend call
|
|
||||||
// Example: window.api.updateSettings(settings);
|
|
||||||
console.log('Settings updated:', settings);
|
|
||||||
};
|
|
||||||
|
|
||||||
export default function SettingsPage() {
|
|
||||||
const [settings, setSettings] = useState<Settings>(defaultSettings);
|
|
||||||
const [inputDevices, setInputDevices] = useState<AudioDevice[]>([]);
|
|
||||||
const [outputDevices, setOutputDevices] = useState<AudioDevice[]>([]);
|
|
||||||
const navigate = useNavigate();
|
|
||||||
|
|
||||||
useEffect(() => {
|
|
||||||
fetchAudioDevices()
|
|
||||||
.then((devices) => {
|
|
||||||
// For demo, split devices by id
|
|
||||||
setInputDevices(devices.filter((d) => d.id.includes('in')));
|
|
||||||
setOutputDevices(devices.filter((d) => d.id.includes('out')));
|
|
||||||
return devices;
|
|
||||||
})
|
|
||||||
.catch((error) => {
|
|
||||||
console.error('Error fetching audio devices:', error);
|
|
||||||
});
|
|
||||||
}, []);
|
|
||||||
|
|
||||||
useEffect(() => {
|
|
||||||
sendSettingsToBackend(settings);
|
|
||||||
}, [settings]);
|
|
||||||
|
|
||||||
const handleChange = () => {
|
|
||||||
// const { name, value } = e.target;
|
|
||||||
// setSettings((prev) => ({
|
|
||||||
// ...prev,
|
|
||||||
// [name]: value,
|
|
||||||
// }));
|
|
||||||
};
|
|
||||||
|
|
||||||
const handleFolderChange = async () => {
|
|
||||||
// Replace with actual folder picker
|
|
||||||
// Example: const folder = await window.api.selectFolder();
|
|
||||||
const folder = window.prompt(
|
|
||||||
'Enter output folder path:',
|
|
||||||
settings.outputFolder,
|
|
||||||
);
|
|
||||||
if (folder !== null) {
|
|
||||||
setSettings((prev) => ({
|
|
||||||
...prev,
|
|
||||||
outputFolder: folder,
|
|
||||||
}));
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
return (
|
|
||||||
<div className="min-w-screen min-h-screen bg-midnight text-offwhite flex items-center justify-center relative">
|
|
||||||
<div className="w-3/4 min-w-[600px] max-w-[800px] self-start flex flex-col font-sans bg-midnight text-offwhite p-6 rounded-lg relative">
|
|
||||||
{/* X Close Button */}
|
|
||||||
<button
|
|
||||||
type="button"
|
|
||||||
className="absolute top-6 right-6 text-3xl font-bold text-offwhite bg-transparent hover:text-plumDark"
|
|
||||||
aria-label="Close settings"
|
|
||||||
onClick={() => navigate('/')}
|
|
||||||
>
|
|
||||||
×
|
|
||||||
</button>
|
|
||||||
<span className="text-2xl font-bold mb-4">Settings</span>
|
|
||||||
<div className="mb-4 flex justify-between">
|
|
||||||
<span>HTTP Port:</span>
|
|
||||||
<TextField
|
|
||||||
variant="standard"
|
|
||||||
type="text"
|
|
||||||
name="httpPort"
|
|
||||||
value={settings.httpPort}
|
|
||||||
onChange={(e) => {
|
|
||||||
setSettings((prev) => ({ ...prev, httpPort: e.target.value }));
|
|
||||||
}}
|
|
||||||
className="ml-2 text-white w-[150px]"
|
|
||||||
/>
|
|
||||||
</div>
|
|
||||||
<div className="mb-4 flex justify-between">
|
|
||||||
<span>Input Audio Device:</span>
|
|
||||||
<Select
|
|
||||||
variant="standard"
|
|
||||||
name="inputDevice"
|
|
||||||
value={settings.inputDevice}
|
|
||||||
onChange={(e) => {
|
|
||||||
setSettings((prev) => ({ ...prev, inputDevice: e.target.value }));
|
|
||||||
}}
|
|
||||||
className="ml-2 w-64"
|
|
||||||
>
|
|
||||||
{inputDevices.map((dev) => (
|
|
||||||
<MenuItem key={dev.id} value={dev.id}>
|
|
||||||
{dev.label}
|
|
||||||
</MenuItem>
|
|
||||||
))}
|
|
||||||
</Select>
|
|
||||||
</div>
|
|
||||||
<div className="mb-4 flex justify-between">
|
|
||||||
<span>Output Audio Device:</span>
|
|
||||||
<Select
|
|
||||||
variant="standard"
|
|
||||||
name="outputDevice"
|
|
||||||
value={settings.outputDevice}
|
|
||||||
onChange={(e) => {
|
|
||||||
setSettings((prev) => ({
|
|
||||||
...prev,
|
|
||||||
outputDevice: e.target.value,
|
|
||||||
}));
|
|
||||||
}}
|
|
||||||
className="ml-2 w-64"
|
|
||||||
>
|
|
||||||
{outputDevices.map((dev) => (
|
|
||||||
<MenuItem key={dev.id} value={dev.id}>
|
|
||||||
{dev.label}
|
|
||||||
</MenuItem>
|
|
||||||
))}
|
|
||||||
</Select>
|
|
||||||
</div>
|
|
||||||
<div className="mb-4 flex justify-between">
|
|
||||||
<span>Recording Length (seconds):</span>
|
|
||||||
<TextField
|
|
||||||
variant="standard"
|
|
||||||
type="text"
|
|
||||||
name="recordingLength"
|
|
||||||
value={settings.recordingLength}
|
|
||||||
onChange={(e) => {
|
|
||||||
setSettings((prev) => ({
|
|
||||||
...prev,
|
|
||||||
recordingLength: e.target.value,
|
|
||||||
}));
|
|
||||||
}}
|
|
||||||
className="ml-2 w-[150px]"
|
|
||||||
/>
|
|
||||||
</div>
|
|
||||||
<div className="mb-4 flex justify-between">
|
|
||||||
<span>Clip Output Folder:</span>
|
|
||||||
<div className="flex justify-end">
|
|
||||||
<TextField
|
|
||||||
variant="standard"
|
|
||||||
type="text"
|
|
||||||
name="outputFolder"
|
|
||||||
value={settings.outputFolder}
|
|
||||||
className="ml-2 w-[300px]"
|
|
||||||
/>
|
|
||||||
<button
|
|
||||||
type="button"
|
|
||||||
onClick={handleFolderChange}
|
|
||||||
className="ml-2 px-3 py-1 rounded bg-plumDark text-offwhite hover:bg-plum"
|
|
||||||
>
|
|
||||||
...
|
|
||||||
</button>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
);
|
|
||||||
}
|
|
||||||
@ -9,9 +9,6 @@ import Dialog from '@mui/material/Dialog';
|
|||||||
import DialogTitle from '@mui/material/DialogTitle';
|
import DialogTitle from '@mui/material/DialogTitle';
|
||||||
import DialogContent from '@mui/material/DialogContent';
|
import DialogContent from '@mui/material/DialogContent';
|
||||||
import DialogActions from '@mui/material/DialogActions';
|
import DialogActions from '@mui/material/DialogActions';
|
||||||
import Slider from '@mui/material/Slider';
|
|
||||||
import ToggleButton from '@mui/material/ToggleButton';
|
|
||||||
import ToggleButtonGroup from '@mui/material/ToggleButtonGroup';
|
|
||||||
import { useWavesurfer } from '@wavesurfer/react';
|
import { useWavesurfer } from '@wavesurfer/react';
|
||||||
import RegionsPlugin from 'wavesurfer.js/dist/plugins/regions.esm.js';
|
import RegionsPlugin from 'wavesurfer.js/dist/plugins/regions.esm.js';
|
||||||
import ZoomPlugin from 'wavesurfer.js/dist/plugins/zoom.esm.js';
|
import ZoomPlugin from 'wavesurfer.js/dist/plugins/zoom.esm.js';
|
||||||
@ -22,10 +19,8 @@ import ArrowDownwardIcon from '@mui/icons-material/ArrowDownward';
|
|||||||
import DeleteIcon from '@mui/icons-material/Delete';
|
import DeleteIcon from '@mui/icons-material/Delete';
|
||||||
import { useSortable } from '@dnd-kit/sortable';
|
import { useSortable } from '@dnd-kit/sortable';
|
||||||
import { CSS } from '@dnd-kit/utilities';
|
import { CSS } from '@dnd-kit/utilities';
|
||||||
import { ClipMetadata, PlaybackType } from '../../redux/types';
|
import { ClipMetadata } from '../../redux/types';
|
||||||
import { useAppSelector } from '../hooks';
|
import { useAppSelector } from '../hooks';
|
||||||
import PlayStopIcon from './playStopIcon';
|
|
||||||
import PlayOverlapIcon from './playOverlapIcon';
|
|
||||||
|
|
||||||
export interface AudioTrimmerProps {
|
export interface AudioTrimmerProps {
|
||||||
metadata: ClipMetadata;
|
metadata: ClipMetadata;
|
||||||
@ -48,7 +43,6 @@ export default function AudioTrimmer({
|
|||||||
const [deleteDialogOpen, setDeleteDialogOpen] = useState(false);
|
const [deleteDialogOpen, setDeleteDialogOpen] = useState(false);
|
||||||
const [dropdownOpen, setDropdownOpen] = useState(false);
|
const [dropdownOpen, setDropdownOpen] = useState(false);
|
||||||
const [nameInput, setNameInput] = useState<string>(metadata.name);
|
const [nameInput, setNameInput] = useState<string>(metadata.name);
|
||||||
const [volumeInput, setVolumeInput] = useState<number>(metadata.volume ?? 1);
|
|
||||||
const collectionNames = useAppSelector((state) =>
|
const collectionNames = useAppSelector((state) =>
|
||||||
state.collections.map((col) => col.name),
|
state.collections.map((col) => col.name),
|
||||||
);
|
);
|
||||||
@ -229,7 +223,6 @@ export default function AudioTrimmer({
|
|||||||
} else {
|
} else {
|
||||||
const allRegions = (plugins[0] as RegionsPlugin).getRegions();
|
const allRegions = (plugins[0] as RegionsPlugin).getRegions();
|
||||||
if (allRegions.length > 0) {
|
if (allRegions.length > 0) {
|
||||||
wavesurfer.setVolume(metadata.volume ?? 1);
|
|
||||||
wavesurfer.play(allRegions[0].start, allRegions[0].end);
|
wavesurfer.play(allRegions[0].start, allRegions[0].end);
|
||||||
} else {
|
} else {
|
||||||
wavesurfer.play();
|
wavesurfer.play();
|
||||||
@ -301,18 +294,15 @@ export default function AudioTrimmer({
|
|||||||
>
|
>
|
||||||
<DialogTitle>Edit Clip Name</DialogTitle>
|
<DialogTitle>Edit Clip Name</DialogTitle>
|
||||||
<DialogContent>
|
<DialogContent>
|
||||||
<input
|
<textarea
|
||||||
// eslint-disable-next-line jsx-a11y/no-autofocus
|
|
||||||
autoFocus
|
autoFocus
|
||||||
className="font-bold text-lg bg-transparent outline-none border-b border-plum focus:border-plumDark text-white mb-1 w-full text-center"
|
className="font-bold text-lg bg-transparent outline-none border-b border-plum focus:border-plumDark text-white mb-1 w-full text-center resize-y"
|
||||||
type="text"
|
|
||||||
value={nameInput}
|
value={nameInput}
|
||||||
onChange={(e) => setNameInput(e.target.value)}
|
onChange={(e) => setNameInput(e.target.value)}
|
||||||
onKeyDown={(e) => {
|
rows={3}
|
||||||
if (e.key === 'Enter') handleDialogSave();
|
|
||||||
}}
|
|
||||||
onFocus={(event) => event.target.select()}
|
onFocus={(event) => event.target.select()}
|
||||||
aria-label="Edit clip name"
|
aria-label="Edit clip name"
|
||||||
|
style={{ minHeight: '3em' }}
|
||||||
/>
|
/>
|
||||||
</DialogContent>
|
</DialogContent>
|
||||||
<DialogActions>
|
<DialogActions>
|
||||||
@ -411,74 +401,12 @@ export default function AudioTrimmer({
|
|||||||
<div className="m-1 wavesurfer-scroll-container">
|
<div className="m-1 wavesurfer-scroll-container">
|
||||||
<div ref={containerRef} className="wavesurfer-inner" />
|
<div ref={containerRef} className="wavesurfer-inner" />
|
||||||
</div>
|
</div>
|
||||||
<div className="flex justify-between mt-2">
|
<div className="grid justify-items-stretch grid-cols-2 text-neutral-500">
|
||||||
<span className="w-1/5 flex-none text-sm text-neutral-500 self-center">
|
<div className="m-1 flex justify-start">
|
||||||
|
<text className="text-sm ">
|
||||||
Clip: {formatTime(metadata.startTime ?? 0)} -{' '}
|
Clip: {formatTime(metadata.startTime ?? 0)} -{' '}
|
||||||
{formatTime(metadata.endTime ?? 0)}
|
{formatTime(metadata.endTime ?? 0)}
|
||||||
</span>
|
</text>
|
||||||
<div className="w-3/5 flex-1 flex justify-center items-center">
|
|
||||||
<Slider
|
|
||||||
value={volumeInput}
|
|
||||||
min={0}
|
|
||||||
max={1}
|
|
||||||
step={0.01}
|
|
||||||
onChange={(e, newValue) => setVolumeInput(newValue as number)}
|
|
||||||
onChangeCommitted={(e, newValue) => {
|
|
||||||
const newVolume = newValue as number;
|
|
||||||
console.log('Volume change:', newVolume);
|
|
||||||
if (onSave) onSave({ ...metadata, volume: newVolume });
|
|
||||||
}}
|
|
||||||
color="secondary"
|
|
||||||
className="p-0 m-0"
|
|
||||||
/>
|
|
||||||
{/* <input
|
|
||||||
type="range"
|
|
||||||
min={0}
|
|
||||||
max={1}
|
|
||||||
step={0.01}
|
|
||||||
value={volumeInput}
|
|
||||||
onChange={(e) => {
|
|
||||||
const newVolume = parseFloat(e.target.value);
|
|
||||||
setVolumeInput(newVolume);
|
|
||||||
}}
|
|
||||||
onDragEnd={(e) => {
|
|
||||||
console.log('Volume change:');
|
|
||||||
// const newVolume = parseFloat(e.target.value);
|
|
||||||
// if (onSave) onSave({ ...metadata, volume: newVolume });
|
|
||||||
}}
|
|
||||||
className="mx-2 w-full accent-plum"
|
|
||||||
aria-label="Volume slider"
|
|
||||||
/> */}
|
|
||||||
</div>
|
|
||||||
<div className="w-1/5 flex justify-end text-sm text-neutral-500">
|
|
||||||
<ToggleButtonGroup value={metadata.playbackType}>
|
|
||||||
<ToggleButton
|
|
||||||
value="playStop"
|
|
||||||
color="primary"
|
|
||||||
onClick={() => {
|
|
||||||
if (onSave)
|
|
||||||
onSave({
|
|
||||||
...metadata,
|
|
||||||
playbackType: PlaybackType.PlayStop,
|
|
||||||
});
|
|
||||||
}}
|
|
||||||
>
|
|
||||||
<PlayStopIcon />
|
|
||||||
</ToggleButton>
|
|
||||||
<ToggleButton
|
|
||||||
value="playOverlap"
|
|
||||||
color="primary"
|
|
||||||
onClick={() => {
|
|
||||||
if (onSave)
|
|
||||||
onSave({
|
|
||||||
...metadata,
|
|
||||||
playbackType: PlaybackType.PlayOverlap,
|
|
||||||
});
|
|
||||||
}}
|
|
||||||
>
|
|
||||||
<PlayOverlapIcon />
|
|
||||||
</ToggleButton>
|
|
||||||
</ToggleButtonGroup>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@ -31,33 +31,6 @@ export default function ClipList({ collection }: ClipListProps) {
|
|||||||
useSensor(PointerSensor, { activationConstraint: { distance: 5 } }),
|
useSensor(PointerSensor, { activationConstraint: { distance: 5 } }),
|
||||||
);
|
);
|
||||||
|
|
||||||
const handleDrop = (event: React.DragEvent<HTMLDivElement>) => {
|
|
||||||
event.preventDefault();
|
|
||||||
console.log('Files dropped:', event.dataTransfer.files);
|
|
||||||
const files = Array.from(event.dataTransfer.files).filter((file) =>
|
|
||||||
file.type.startsWith('audio/'),
|
|
||||||
);
|
|
||||||
if (files.length > 0) {
|
|
||||||
const formData = new FormData();
|
|
||||||
files.forEach((file) => formData.append('files', file));
|
|
||||||
|
|
||||||
// todo send the file to the backend and add to the collection
|
|
||||||
|
|
||||||
// fetch('http://localhost:5010/file/upload', {
|
|
||||||
// method: 'POST',
|
|
||||||
// body: formData,
|
|
||||||
// })
|
|
||||||
// .then((res) => res.json())
|
|
||||||
// .catch((err) => console.error('Error uploading files:', err));
|
|
||||||
// Implement your onDrop logic here
|
|
||||||
// onDrop(files, selectedCollection);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
const handleDragOver = (event: React.DragEvent<HTMLDivElement>) => {
|
|
||||||
event.preventDefault();
|
|
||||||
};
|
|
||||||
|
|
||||||
async function handleDragEnd(event: any) {
|
async function handleDragEnd(event: any) {
|
||||||
const { active, over } = event;
|
const { active, over } = event;
|
||||||
if (active.id !== over?.id) {
|
if (active.id !== over?.id) {
|
||||||
@ -172,11 +145,7 @@ export default function ClipList({ collection }: ClipListProps) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div
|
<div className="min-h-full flex flex-col justify-start bg-midnight text-offwhite">
|
||||||
className="min-h-full flex flex-col justify-start bg-midnight text-offwhite"
|
|
||||||
onDrop={handleDrop}
|
|
||||||
onDragOver={handleDragOver}
|
|
||||||
>
|
|
||||||
<DndContext
|
<DndContext
|
||||||
sensors={sensors}
|
sensors={sensors}
|
||||||
collisionDetection={closestCenter}
|
collisionDetection={closestCenter}
|
||||||
|
|||||||
@ -1,29 +0,0 @@
|
|||||||
import React from 'react';
|
|
||||||
|
|
||||||
export default function PlayOverlapIcon({
|
|
||||||
size = 24,
|
|
||||||
color = 'currentColor',
|
|
||||||
}: {
|
|
||||||
size?: number;
|
|
||||||
color?: string;
|
|
||||||
}) {
|
|
||||||
return (
|
|
||||||
<svg
|
|
||||||
width={size}
|
|
||||||
height={size}
|
|
||||||
viewBox="0 0 32 24"
|
|
||||||
fill="none"
|
|
||||||
xmlns="http://www.w3.org/2000/svg"
|
|
||||||
>
|
|
||||||
{/* Filled play arrow */}
|
|
||||||
<polygon points="4,4 4,20 16,12" fill={color} />
|
|
||||||
{/* Outlined play arrow (underneath and to the right) */}
|
|
||||||
<polygon
|
|
||||||
points="12,4 12,20 24,12"
|
|
||||||
fill="none"
|
|
||||||
stroke={color}
|
|
||||||
strokeWidth={1}
|
|
||||||
/>
|
|
||||||
</svg>
|
|
||||||
);
|
|
||||||
}
|
|
||||||
@ -1,23 +0,0 @@
|
|||||||
export default function PlayStopIcon({
|
|
||||||
size = 24,
|
|
||||||
color = 'currentColor',
|
|
||||||
}: {
|
|
||||||
size?: number;
|
|
||||||
color?: string;
|
|
||||||
}) {
|
|
||||||
return (
|
|
||||||
<svg
|
|
||||||
width={size}
|
|
||||||
height={size}
|
|
||||||
viewBox="0 0 48 24"
|
|
||||||
fill="none"
|
|
||||||
xmlns="http://www.w3.org/2000/svg"
|
|
||||||
aria-label="Play/Stop Icon"
|
|
||||||
>
|
|
||||||
{/* Play Arrow */}
|
|
||||||
<polygon points="4,4 20,12 4,20" fill={color} />
|
|
||||||
{/* Stop Square */}
|
|
||||||
<rect x="28" y="4" width="16" height="16" rx="2" fill={color} />
|
|
||||||
</svg>
|
|
||||||
);
|
|
||||||
}
|
|
||||||
1
stream_deck_plugin/.gitignore
vendored
1
stream_deck_plugin/.gitignore
vendored
@ -5,4 +5,3 @@ ClipTrimDotNet/bin/
|
|||||||
ClipTrimDotNet/obj/
|
ClipTrimDotNet/obj/
|
||||||
ClipTrimDotNet/dist/
|
ClipTrimDotNet/dist/
|
||||||
ClipTrimDotNet/node_modules/
|
ClipTrimDotNet/node_modules/
|
||||||
.vs/
|
|
||||||
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
1026
stream_deck_plugin/.vs/ClipTrimDotNet/config/applicationhost.config
Normal file
1026
stream_deck_plugin/.vs/ClipTrimDotNet/config/applicationhost.config
Normal file
File diff suppressed because it is too large
Load Diff
BIN
stream_deck_plugin/.vs/ClipTrimDotNet/v17/.suo
Normal file
BIN
stream_deck_plugin/.vs/ClipTrimDotNet/v17/.suo
Normal file
Binary file not shown.
@ -0,0 +1,96 @@
|
|||||||
|
{
|
||||||
|
"Version": 1,
|
||||||
|
"WorkspaceRootPath": "C:\\Users\\mickl\\Desktop\\cliptrim-ui\\ClipTrimApp\\stream_deck_plugin\\",
|
||||||
|
"Documents": [
|
||||||
|
{
|
||||||
|
"AbsoluteMoniker": "D:0:0:{4635D874-69C0-4010-BE46-77EF92EB1553}|ClipTrimDotNet\\ClipTrimDotNet.csproj|c:\\users\\mickl\\desktop\\cliptrim-ui\\cliptrimapp\\stream_deck_plugin\\cliptrimdotnet\\client\\cliptrimclient.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}",
|
||||||
|
"RelativeMoniker": "D:0:0:{4635D874-69C0-4010-BE46-77EF92EB1553}|ClipTrimDotNet\\ClipTrimDotNet.csproj|solutionrelative:cliptrimdotnet\\client\\cliptrimclient.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"AbsoluteMoniker": "D:0:0:{4635D874-69C0-4010-BE46-77EF92EB1553}|ClipTrimDotNet\\ClipTrimDotNet.csproj|c:\\users\\mickl\\desktop\\cliptrim-ui\\cliptrimapp\\stream_deck_plugin\\cliptrimdotnet\\player.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}",
|
||||||
|
"RelativeMoniker": "D:0:0:{4635D874-69C0-4010-BE46-77EF92EB1553}|ClipTrimDotNet\\ClipTrimDotNet.csproj|solutionrelative:cliptrimdotnet\\player.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"AbsoluteMoniker": "D:0:0:{4635D874-69C0-4010-BE46-77EF92EB1553}|ClipTrimDotNet\\ClipTrimDotNet.csproj|c:\\users\\mickl\\desktop\\cliptrim-ui\\cliptrimapp\\stream_deck_plugin\\cliptrimdotnet\\profileswitcher.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}",
|
||||||
|
"RelativeMoniker": "D:0:0:{4635D874-69C0-4010-BE46-77EF92EB1553}|ClipTrimDotNet\\ClipTrimDotNet.csproj|solutionrelative:cliptrimdotnet\\profileswitcher.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"AbsoluteMoniker": "D:0:0:{4635D874-69C0-4010-BE46-77EF92EB1553}|ClipTrimDotNet\\ClipTrimDotNet.csproj|c:\\users\\mickl\\desktop\\cliptrim-ui\\cliptrimapp\\stream_deck_plugin\\cliptrimdotnet\\client\\collectionmetadata.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}",
|
||||||
|
"RelativeMoniker": "D:0:0:{4635D874-69C0-4010-BE46-77EF92EB1553}|ClipTrimDotNet\\ClipTrimDotNet.csproj|solutionrelative:cliptrimdotnet\\client\\collectionmetadata.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"DocumentGroupContainers": [
|
||||||
|
{
|
||||||
|
"Orientation": 0,
|
||||||
|
"VerticalTabListWidth": 256,
|
||||||
|
"DocumentGroups": [
|
||||||
|
{
|
||||||
|
"DockedWidth": 297,
|
||||||
|
"SelectedChildIndex": 2,
|
||||||
|
"Children": [
|
||||||
|
{
|
||||||
|
"$type": "Bookmark",
|
||||||
|
"Name": "ST:0:0:{57d563b6-44a5-47df-85be-f4199ad6b651}"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"$type": "Document",
|
||||||
|
"DocumentIndex": 2,
|
||||||
|
"Title": "ProfileSwitcher.cs",
|
||||||
|
"DocumentMoniker": "C:\\Users\\mickl\\Desktop\\cliptrim-ui\\ClipTrimApp\\stream_deck_plugin\\ClipTrimDotNet\\ProfileSwitcher.cs",
|
||||||
|
"RelativeDocumentMoniker": "ClipTrimDotNet\\ProfileSwitcher.cs",
|
||||||
|
"ToolTip": "C:\\Users\\mickl\\Desktop\\cliptrim-ui\\ClipTrimApp\\stream_deck_plugin\\ClipTrimDotNet\\ProfileSwitcher.cs",
|
||||||
|
"RelativeToolTip": "ClipTrimDotNet\\ProfileSwitcher.cs",
|
||||||
|
"ViewState": "AgIAAFkAAAAAAAAAAAAlwG8AAABKAAAAAAAAAA==",
|
||||||
|
"Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|",
|
||||||
|
"WhenOpened": "2026-02-21T15:06:24.045Z",
|
||||||
|
"EditorCaption": ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"$type": "Document",
|
||||||
|
"DocumentIndex": 0,
|
||||||
|
"Title": "ClipTrimClient.cs",
|
||||||
|
"DocumentMoniker": "C:\\Users\\mickl\\Desktop\\cliptrim-ui\\ClipTrimApp\\stream_deck_plugin\\ClipTrimDotNet\\Client\\ClipTrimClient.cs",
|
||||||
|
"RelativeDocumentMoniker": "ClipTrimDotNet\\Client\\ClipTrimClient.cs",
|
||||||
|
"ToolTip": "C:\\Users\\mickl\\Desktop\\cliptrim-ui\\ClipTrimApp\\stream_deck_plugin\\ClipTrimDotNet\\Client\\ClipTrimClient.cs",
|
||||||
|
"RelativeToolTip": "ClipTrimDotNet\\Client\\ClipTrimClient.cs",
|
||||||
|
"ViewState": "AgIAAEgAAAAAAAAAAAAuwGMAAAAJAAAAAAAAAA==",
|
||||||
|
"Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|",
|
||||||
|
"WhenOpened": "2026-02-21T15:03:49.814Z",
|
||||||
|
"EditorCaption": ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"$type": "Document",
|
||||||
|
"DocumentIndex": 3,
|
||||||
|
"Title": "CollectionMetaData.cs",
|
||||||
|
"DocumentMoniker": "C:\\Users\\mickl\\Desktop\\cliptrim-ui\\ClipTrimApp\\stream_deck_plugin\\ClipTrimDotNet\\Client\\CollectionMetaData.cs",
|
||||||
|
"RelativeDocumentMoniker": "ClipTrimDotNet\\Client\\CollectionMetaData.cs",
|
||||||
|
"ToolTip": "C:\\Users\\mickl\\Desktop\\cliptrim-ui\\ClipTrimApp\\stream_deck_plugin\\ClipTrimDotNet\\Client\\CollectionMetaData.cs",
|
||||||
|
"RelativeToolTip": "ClipTrimDotNet\\Client\\CollectionMetaData.cs",
|
||||||
|
"ViewState": "AgIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA==",
|
||||||
|
"Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|",
|
||||||
|
"WhenOpened": "2026-02-21T15:03:47.862Z",
|
||||||
|
"EditorCaption": ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"$type": "Document",
|
||||||
|
"DocumentIndex": 1,
|
||||||
|
"Title": "Player.cs",
|
||||||
|
"DocumentMoniker": "C:\\Users\\mickl\\Desktop\\cliptrim-ui\\ClipTrimApp\\stream_deck_plugin\\ClipTrimDotNet\\Player.cs",
|
||||||
|
"RelativeDocumentMoniker": "ClipTrimDotNet\\Player.cs",
|
||||||
|
"ToolTip": "C:\\Users\\mickl\\Desktop\\cliptrim-ui\\ClipTrimApp\\stream_deck_plugin\\ClipTrimDotNet\\Player.cs*",
|
||||||
|
"RelativeToolTip": "ClipTrimDotNet\\Player.cs*",
|
||||||
|
"ViewState": "AgIAAHIAAAAAAAAAAAA3wIYAAABMAAAAAAAAAA==",
|
||||||
|
"Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|",
|
||||||
|
"WhenOpened": "2026-02-21T15:00:23.762Z",
|
||||||
|
"EditorCaption": ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"$type": "Bookmark",
|
||||||
|
"Name": "ST:0:0:{cce594b6-0c39-4442-ba28-10c64ac7e89f}"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
113
stream_deck_plugin/.vs/ClipTrimDotNet/v17/DocumentLayout.json
Normal file
113
stream_deck_plugin/.vs/ClipTrimDotNet/v17/DocumentLayout.json
Normal file
@ -0,0 +1,113 @@
|
|||||||
|
{
|
||||||
|
"Version": 1,
|
||||||
|
"WorkspaceRootPath": "C:\\Users\\mickl\\Desktop\\cliptrim-ui\\ClipTrimApp\\stream_deck_plugin\\",
|
||||||
|
"Documents": [
|
||||||
|
{
|
||||||
|
"AbsoluteMoniker": "D:0:0:{4635D874-69C0-4010-BE46-77EF92EB1553}|ClipTrimDotNet\\ClipTrimDotNet.csproj|c:\\users\\mickl\\desktop\\cliptrim-ui\\cliptrimapp\\stream_deck_plugin\\cliptrimdotnet\\wavplayer.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}",
|
||||||
|
"RelativeMoniker": "D:0:0:{4635D874-69C0-4010-BE46-77EF92EB1553}|ClipTrimDotNet\\ClipTrimDotNet.csproj|solutionrelative:cliptrimdotnet\\wavplayer.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"AbsoluteMoniker": "D:0:0:{4635D874-69C0-4010-BE46-77EF92EB1553}|ClipTrimDotNet\\ClipTrimDotNet.csproj|c:\\users\\mickl\\desktop\\cliptrim-ui\\cliptrimapp\\stream_deck_plugin\\cliptrimdotnet\\player.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}",
|
||||||
|
"RelativeMoniker": "D:0:0:{4635D874-69C0-4010-BE46-77EF92EB1553}|ClipTrimDotNet\\ClipTrimDotNet.csproj|solutionrelative:cliptrimdotnet\\player.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"AbsoluteMoniker": "D:0:0:{4635D874-69C0-4010-BE46-77EF92EB1553}|ClipTrimDotNet\\ClipTrimDotNet.csproj|c:\\users\\mickl\\desktop\\cliptrim-ui\\cliptrimapp\\stream_deck_plugin\\cliptrimdotnet\\profileswitcher.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}",
|
||||||
|
"RelativeMoniker": "D:0:0:{4635D874-69C0-4010-BE46-77EF92EB1553}|ClipTrimDotNet\\ClipTrimDotNet.csproj|solutionrelative:cliptrimdotnet\\profileswitcher.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"AbsoluteMoniker": "D:0:0:{4635D874-69C0-4010-BE46-77EF92EB1553}|ClipTrimDotNet\\ClipTrimDotNet.csproj|c:\\users\\mickl\\desktop\\cliptrim-ui\\cliptrimapp\\stream_deck_plugin\\cliptrimdotnet\\client\\cliptrimclient.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}",
|
||||||
|
"RelativeMoniker": "D:0:0:{4635D874-69C0-4010-BE46-77EF92EB1553}|ClipTrimDotNet\\ClipTrimDotNet.csproj|solutionrelative:cliptrimdotnet\\client\\cliptrimclient.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"AbsoluteMoniker": "D:0:0:{4635D874-69C0-4010-BE46-77EF92EB1553}|ClipTrimDotNet\\ClipTrimDotNet.csproj|c:\\users\\mickl\\desktop\\cliptrim-ui\\cliptrimapp\\stream_deck_plugin\\cliptrimdotnet\\client\\collectionmetadata.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}",
|
||||||
|
"RelativeMoniker": "D:0:0:{4635D874-69C0-4010-BE46-77EF92EB1553}|ClipTrimDotNet\\ClipTrimDotNet.csproj|solutionrelative:cliptrimdotnet\\client\\collectionmetadata.cs||{A6C744A8-0E4A-4FC6-886A-064283054674}"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"DocumentGroupContainers": [
|
||||||
|
{
|
||||||
|
"Orientation": 0,
|
||||||
|
"VerticalTabListWidth": 256,
|
||||||
|
"DocumentGroups": [
|
||||||
|
{
|
||||||
|
"DockedWidth": 297,
|
||||||
|
"SelectedChildIndex": 1,
|
||||||
|
"Children": [
|
||||||
|
{
|
||||||
|
"$type": "Bookmark",
|
||||||
|
"Name": "ST:0:0:{57d563b6-44a5-47df-85be-f4199ad6b651}"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"$type": "Document",
|
||||||
|
"DocumentIndex": 0,
|
||||||
|
"Title": "WavPlayer.cs",
|
||||||
|
"DocumentMoniker": "C:\\Users\\mickl\\Desktop\\cliptrim-ui\\ClipTrimApp\\stream_deck_plugin\\ClipTrimDotNet\\WavPlayer.cs",
|
||||||
|
"RelativeDocumentMoniker": "ClipTrimDotNet\\WavPlayer.cs",
|
||||||
|
"ToolTip": "C:\\Users\\mickl\\Desktop\\cliptrim-ui\\ClipTrimApp\\stream_deck_plugin\\ClipTrimDotNet\\WavPlayer.cs",
|
||||||
|
"RelativeToolTip": "ClipTrimDotNet\\WavPlayer.cs",
|
||||||
|
"ViewState": "AgIAALYAAAAAAAAAAAAAALsAAAANAAAAAAAAAA==",
|
||||||
|
"Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|",
|
||||||
|
"WhenOpened": "2026-02-21T15:16:26.477Z",
|
||||||
|
"EditorCaption": ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"$type": "Document",
|
||||||
|
"DocumentIndex": 2,
|
||||||
|
"Title": "ProfileSwitcher.cs",
|
||||||
|
"DocumentMoniker": "C:\\Users\\mickl\\Desktop\\cliptrim-ui\\ClipTrimApp\\stream_deck_plugin\\ClipTrimDotNet\\ProfileSwitcher.cs",
|
||||||
|
"RelativeDocumentMoniker": "ClipTrimDotNet\\ProfileSwitcher.cs",
|
||||||
|
"ToolTip": "C:\\Users\\mickl\\Desktop\\cliptrim-ui\\ClipTrimApp\\stream_deck_plugin\\ClipTrimDotNet\\ProfileSwitcher.cs",
|
||||||
|
"RelativeToolTip": "ClipTrimDotNet\\ProfileSwitcher.cs",
|
||||||
|
"ViewState": "AgIAAG8AAAAAAAAAAAAWwG8AAABKAAAAAAAAAA==",
|
||||||
|
"Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|",
|
||||||
|
"WhenOpened": "2026-02-21T15:06:24.045Z",
|
||||||
|
"EditorCaption": ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"$type": "Document",
|
||||||
|
"DocumentIndex": 3,
|
||||||
|
"Title": "ClipTrimClient.cs",
|
||||||
|
"DocumentMoniker": "C:\\Users\\mickl\\Desktop\\cliptrim-ui\\ClipTrimApp\\stream_deck_plugin\\ClipTrimDotNet\\Client\\ClipTrimClient.cs",
|
||||||
|
"RelativeDocumentMoniker": "ClipTrimDotNet\\Client\\ClipTrimClient.cs",
|
||||||
|
"ToolTip": "C:\\Users\\mickl\\Desktop\\cliptrim-ui\\ClipTrimApp\\stream_deck_plugin\\ClipTrimDotNet\\Client\\ClipTrimClient.cs",
|
||||||
|
"RelativeToolTip": "ClipTrimDotNet\\Client\\ClipTrimClient.cs",
|
||||||
|
"ViewState": "AgIAAEgAAAAAAAAAAAAuwGIAAAApAAAAAAAAAA==",
|
||||||
|
"Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|",
|
||||||
|
"WhenOpened": "2026-02-21T15:03:49.814Z",
|
||||||
|
"EditorCaption": ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"$type": "Document",
|
||||||
|
"DocumentIndex": 4,
|
||||||
|
"Title": "CollectionMetaData.cs",
|
||||||
|
"DocumentMoniker": "C:\\Users\\mickl\\Desktop\\cliptrim-ui\\ClipTrimApp\\stream_deck_plugin\\ClipTrimDotNet\\Client\\CollectionMetaData.cs",
|
||||||
|
"RelativeDocumentMoniker": "ClipTrimDotNet\\Client\\CollectionMetaData.cs",
|
||||||
|
"ToolTip": "C:\\Users\\mickl\\Desktop\\cliptrim-ui\\ClipTrimApp\\stream_deck_plugin\\ClipTrimDotNet\\Client\\CollectionMetaData.cs",
|
||||||
|
"RelativeToolTip": "ClipTrimDotNet\\Client\\CollectionMetaData.cs",
|
||||||
|
"ViewState": "AgIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA==",
|
||||||
|
"Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|",
|
||||||
|
"WhenOpened": "2026-02-21T15:03:47.862Z",
|
||||||
|
"EditorCaption": ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"$type": "Document",
|
||||||
|
"DocumentIndex": 1,
|
||||||
|
"Title": "Player.cs",
|
||||||
|
"DocumentMoniker": "C:\\Users\\mickl\\Desktop\\cliptrim-ui\\ClipTrimApp\\stream_deck_plugin\\ClipTrimDotNet\\Player.cs",
|
||||||
|
"RelativeDocumentMoniker": "ClipTrimDotNet\\Player.cs",
|
||||||
|
"ToolTip": "C:\\Users\\mickl\\Desktop\\cliptrim-ui\\ClipTrimApp\\stream_deck_plugin\\ClipTrimDotNet\\Player.cs",
|
||||||
|
"RelativeToolTip": "ClipTrimDotNet\\Player.cs",
|
||||||
|
"ViewState": "AgIAAHoAAAAAAAAAAAAswIwAAAAbAAAAAAAAAA==",
|
||||||
|
"Icon": "ae27a6b0-e345-4288-96df-5eaf394ee369.000738|",
|
||||||
|
"WhenOpened": "2026-02-21T15:00:23.762Z",
|
||||||
|
"EditorCaption": ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"$type": "Bookmark",
|
||||||
|
"Name": "ST:0:0:{cce594b6-0c39-4442-ba28-10c64ac7e89f}"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
42
stream_deck_plugin/ClipTrimDotNet/Client/ClipMetadata.cs
Normal file
42
stream_deck_plugin/ClipTrimDotNet/Client/ClipMetadata.cs
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
using Newtonsoft.Json;
|
||||||
|
using Newtonsoft.Json.Converters;
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace ClipTrimDotNet.Client
|
||||||
|
{
|
||||||
|
public enum PlaybackType
|
||||||
|
{
|
||||||
|
playStop,
|
||||||
|
playOverlap
|
||||||
|
}
|
||||||
|
public class ClipMetadata
|
||||||
|
{
|
||||||
|
[JsonProperty(PropertyName = "filename")]
|
||||||
|
public string Filename { get; set; }
|
||||||
|
|
||||||
|
|
||||||
|
[JsonProperty(PropertyName = "name")]
|
||||||
|
public string Name { get; set; }
|
||||||
|
|
||||||
|
|
||||||
|
[JsonProperty(PropertyName = "volume")]
|
||||||
|
public double Volume { get; set; } = 1.0;
|
||||||
|
|
||||||
|
|
||||||
|
[JsonProperty(PropertyName = "startTime")]
|
||||||
|
public double StartTime { get; set; } = 0.0;
|
||||||
|
|
||||||
|
|
||||||
|
[JsonProperty(PropertyName = "endTime")]
|
||||||
|
public double EndTime { get; set; } = 0.0;
|
||||||
|
|
||||||
|
|
||||||
|
[JsonProperty(PropertyName = "playbackType")]
|
||||||
|
[JsonConverter(typeof(StringEnumConverter))]
|
||||||
|
public PlaybackType PlaybackType { get; set; } = PlaybackType.playStop;
|
||||||
|
}
|
||||||
|
}
|
||||||
110
stream_deck_plugin/ClipTrimDotNet/Client/ClipTrimClient.cs
Normal file
110
stream_deck_plugin/ClipTrimDotNet/Client/ClipTrimClient.cs
Normal file
@ -0,0 +1,110 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Net.Http;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using Newtonsoft.Json;
|
||||||
|
|
||||||
|
namespace ClipTrimDotNet.Client
|
||||||
|
{
|
||||||
|
public class ClipTrimClient
|
||||||
|
{
|
||||||
|
private static ClipTrimClient? instance;
|
||||||
|
public static ClipTrimClient Instance
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
if (instance == null)
|
||||||
|
{
|
||||||
|
instance = new ClipTrimClient();
|
||||||
|
}
|
||||||
|
return instance;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private HttpClient httpClient;
|
||||||
|
|
||||||
|
public ClipTrimClient()
|
||||||
|
{
|
||||||
|
httpClient = new HttpClient()
|
||||||
|
{
|
||||||
|
BaseAddress = new Uri("http://localhost:5010/"),
|
||||||
|
Timeout = TimeSpan.FromSeconds(10)
|
||||||
|
};
|
||||||
|
Task.Run(ShortPoll);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async Task ShortPoll()
|
||||||
|
{
|
||||||
|
while (true)
|
||||||
|
{
|
||||||
|
await GetMetadata();
|
||||||
|
await Task.Delay(TimeSpan.FromSeconds(5)); await Task.Delay(TimeSpan.FromSeconds(5));
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<CollectionMetaData> Collections { get; private set; } = new List<CollectionMetaData>();
|
||||||
|
public CollectionMetaData? SelectedCollection { get; private set; }
|
||||||
|
public int PageIndex { get; private set; } = 0;
|
||||||
|
private async Task GetMetadata()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
var response = await httpClient.GetAsync("meta");
|
||||||
|
if (response.IsSuccessStatusCode)
|
||||||
|
{
|
||||||
|
var json = await response.Content.ReadAsStringAsync();
|
||||||
|
dynamic collections = JsonConvert.DeserializeObject(json);
|
||||||
|
collections = collections.collections;
|
||||||
|
Collections = JsonConvert.DeserializeObject<List<CollectionMetaData>>(collections.ToString());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
//Logger.Instance.LogMessage(TracingLevel.INFO, $"Error pinging ClipTrim API: {ex.Message}");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<string> GetCollectionNames()
|
||||||
|
{
|
||||||
|
//await GetMetadata();
|
||||||
|
return Collections.Select(x => x.Name).ToList();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SetSelectedCollectionByName(string name)
|
||||||
|
{
|
||||||
|
var collection = Collections.FirstOrDefault(x => x.Name == name);
|
||||||
|
if (collection != null)
|
||||||
|
{
|
||||||
|
SelectedCollection = collection;
|
||||||
|
PageIndex = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public ClipMetadata? GetClipByPagedIndex(int index)
|
||||||
|
{
|
||||||
|
if (SelectedCollection == null) return null;
|
||||||
|
int clipIndex = PageIndex * 10 + index;
|
||||||
|
if (clipIndex >= 0 && clipIndex < SelectedCollection.Clips.Count)
|
||||||
|
{
|
||||||
|
return SelectedCollection.Clips[clipIndex];
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public async void PlayClip(ClipMetadata? metadata)
|
||||||
|
{
|
||||||
|
if (metadata == null) return;
|
||||||
|
|
||||||
|
var response = await httpClient.PostAsync("playback/start", new StringContent(JsonConvert.SerializeObject(metadata), Encoding.UTF8, "application/json"));
|
||||||
|
if (!response.IsSuccessStatusCode)
|
||||||
|
{
|
||||||
|
//Logger.Instance.LogMessage(TracingLevel.INFO, $"Error playing clip: {response.ReasonPhrase}");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,23 @@
|
|||||||
|
using Newtonsoft.Json;
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace ClipTrimDotNet.Client
|
||||||
|
{
|
||||||
|
public class CollectionMetaData
|
||||||
|
{
|
||||||
|
[JsonProperty(PropertyName = "name")]
|
||||||
|
public string Name { get; set; }
|
||||||
|
|
||||||
|
|
||||||
|
[JsonProperty(PropertyName = "clips")]
|
||||||
|
public List<ClipMetadata> Clips { get; set; } = new List<ClipMetadata>();
|
||||||
|
|
||||||
|
|
||||||
|
[JsonProperty(PropertyName = "id")]
|
||||||
|
public int Id { get; set; }
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -13,6 +13,7 @@
|
|||||||
<FileAlignment>512</FileAlignment>
|
<FileAlignment>512</FileAlignment>
|
||||||
<AutoGenerateBindingRedirects>true</AutoGenerateBindingRedirects>
|
<AutoGenerateBindingRedirects>true</AutoGenerateBindingRedirects>
|
||||||
<Deterministic>true</Deterministic>
|
<Deterministic>true</Deterministic>
|
||||||
|
<Nullable>enable</Nullable>
|
||||||
<TargetFrameworkProfile />
|
<TargetFrameworkProfile />
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
|
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
|
||||||
@ -63,20 +64,20 @@
|
|||||||
<HintPath>..\packages\NAudio.WinMM.2.2.1\lib\netstandard2.0\NAudio.WinMM.dll</HintPath>
|
<HintPath>..\packages\NAudio.WinMM.2.2.1\lib\netstandard2.0\NAudio.WinMM.dll</HintPath>
|
||||||
</Reference>
|
</Reference>
|
||||||
<Reference Include="Newtonsoft.Json, Version=13.0.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeed, processorArchitecture=MSIL">
|
<Reference Include="Newtonsoft.Json, Version=13.0.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeed, processorArchitecture=MSIL">
|
||||||
<HintPath>..\packages\Newtonsoft.Json.13.0.3\lib\net45\Newtonsoft.Json.dll</HintPath>
|
<HintPath>..\packages\Newtonsoft.Json.13.0.4\lib\net45\Newtonsoft.Json.dll</HintPath>
|
||||||
</Reference>
|
</Reference>
|
||||||
<Reference Include="NLog, Version=5.0.0.0, Culture=neutral, PublicKeyToken=5120e14c03d0593c, processorArchitecture=MSIL">
|
<Reference Include="NLog, Version=6.0.0.0, Culture=neutral, PublicKeyToken=5120e14c03d0593c, processorArchitecture=MSIL">
|
||||||
<HintPath>..\packages\NLog.5.2.8\lib\net46\NLog.dll</HintPath>
|
<HintPath>..\packages\NLog.6.0.5\lib\net46\NLog.dll</HintPath>
|
||||||
</Reference>
|
</Reference>
|
||||||
<Reference Include="StreamDeckTools, Version=6.2.0.0, Culture=neutral, processorArchitecture=MSIL">
|
<Reference Include="StreamDeckTools, Version=6.3.2.0, Culture=neutral, processorArchitecture=MSIL">
|
||||||
<HintPath>..\packages\StreamDeck-Tools.6.2.0\lib\netstandard2.0\StreamDeckTools.dll</HintPath>
|
<HintPath>..\packages\StreamDeck-Tools.6.3.2\lib\netstandard2.0\StreamDeckTools.dll</HintPath>
|
||||||
</Reference>
|
</Reference>
|
||||||
<Reference Include="System" />
|
<Reference Include="System" />
|
||||||
<Reference Include="System.Configuration" />
|
<Reference Include="System.Configuration" />
|
||||||
<Reference Include="System.Core" />
|
<Reference Include="System.Core" />
|
||||||
<Reference Include="System.Drawing" />
|
<Reference Include="System.Drawing" />
|
||||||
<Reference Include="System.Drawing.Common, Version=8.0.0.0, Culture=neutral, PublicKeyToken=cc7b13ffcd2ddd51, processorArchitecture=MSIL">
|
<Reference Include="System.Drawing.Common, Version=9.0.0.0, Culture=neutral, PublicKeyToken=cc7b13ffcd2ddd51, processorArchitecture=MSIL">
|
||||||
<HintPath>..\packages\System.Drawing.Common.8.0.1\lib\net462\System.Drawing.Common.dll</HintPath>
|
<HintPath>..\packages\System.Drawing.Common.9.0.10\lib\net462\System.Drawing.Common.dll</HintPath>
|
||||||
</Reference>
|
</Reference>
|
||||||
<Reference Include="System.IO.Compression" />
|
<Reference Include="System.IO.Compression" />
|
||||||
<Reference Include="System.Runtime.Serialization" />
|
<Reference Include="System.Runtime.Serialization" />
|
||||||
@ -97,6 +98,9 @@
|
|||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<Compile Include="BaseTest.cs" />
|
<Compile Include="BaseTest.cs" />
|
||||||
|
<Compile Include="Client\ClipMetadata.cs" />
|
||||||
|
<Compile Include="Client\ClipTrimClient.cs" />
|
||||||
|
<Compile Include="Client\CollectionMetaData.cs" />
|
||||||
<Compile Include="GlobalSettings.cs" />
|
<Compile Include="GlobalSettings.cs" />
|
||||||
<Compile Include="Player.cs" />
|
<Compile Include="Player.cs" />
|
||||||
<Compile Include="ProfileSwitcher.cs" />
|
<Compile Include="ProfileSwitcher.cs" />
|
||||||
@ -150,8 +154,7 @@
|
|||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
|
<Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
<PreBuildEvent>npm run stop
|
<PreBuildEvent>npm run stop</PreBuildEvent>
|
||||||
timeout /t 1 /nobreak</PreBuildEvent>
|
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
<PostBuildEvent>npm run start</PostBuildEvent>
|
<PostBuildEvent>npm run start</PostBuildEvent>
|
||||||
|
|||||||
@ -1,5 +1,6 @@
|
|||||||
using BarRaider.SdTools;
|
using BarRaider.SdTools;
|
||||||
using BarRaider.SdTools.Wrappers;
|
using BarRaider.SdTools.Wrappers;
|
||||||
|
using ClipTrimDotNet.Client;
|
||||||
using NAudio.CoreAudioApi.Interfaces;
|
using NAudio.CoreAudioApi.Interfaces;
|
||||||
using Newtonsoft.Json;
|
using Newtonsoft.Json;
|
||||||
using Newtonsoft.Json.Linq;
|
using Newtonsoft.Json.Linq;
|
||||||
@ -18,9 +19,8 @@ namespace ClipTrimDotNet
|
|||||||
public class Player : KeypadBase
|
public class Player : KeypadBase
|
||||||
{
|
{
|
||||||
|
|
||||||
private TitleParameters? titleParameters = null;
|
private ClipMetadata? metadata;
|
||||||
private string userTitle;
|
private KeyCoordinates coordinates;
|
||||||
private static int counter = 0;
|
|
||||||
private class PluginSettings
|
private class PluginSettings
|
||||||
{
|
{
|
||||||
public static PluginSettings CreateDefaultSettings()
|
public static PluginSettings CreateDefaultSettings()
|
||||||
@ -62,6 +62,7 @@ namespace ClipTrimDotNet
|
|||||||
{
|
{
|
||||||
this.settings = payload.Settings.ToObject<PluginSettings>();
|
this.settings = payload.Settings.ToObject<PluginSettings>();
|
||||||
}
|
}
|
||||||
|
this.coordinates = payload.Coordinates;
|
||||||
GlobalSettingsManager.Instance.RequestGlobalSettings();
|
GlobalSettingsManager.Instance.RequestGlobalSettings();
|
||||||
CheckFile();
|
CheckFile();
|
||||||
}
|
}
|
||||||
@ -71,34 +72,43 @@ namespace ClipTrimDotNet
|
|||||||
Tools.AutoPopulateSettings(GlobalSettings.Instance, e.Settings);
|
Tools.AutoPopulateSettings(GlobalSettings.Instance, e.Settings);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public int GetIndex()
|
||||||
|
{
|
||||||
|
return Math.Max((coordinates.Row - 1) * 5 + coordinates.Column, 0);
|
||||||
|
}
|
||||||
|
|
||||||
private async void CheckFile()
|
private async void CheckFile()
|
||||||
{
|
{
|
||||||
|
|
||||||
if (settings == null || GlobalSettings.Instance.BasePath == null || GlobalSettings.Instance.ProfileName ==null) return;
|
//if (settings == null || GlobalSettings.Instance.ProfileName ==null) return;
|
||||||
|
metadata = ClipTrimClient.Instance.GetClipByPagedIndex(GetIndex());
|
||||||
|
await Connection.SetTitleAsync($"{metadata?.Name ?? ""}");
|
||||||
|
|
||||||
var files = Directory.GetFiles(Path.Combine(Path.GetDirectoryName(GlobalSettings.Instance.BasePath), GlobalSettings.Instance.ProfileName), "*.wav", SearchOption.TopDirectoryOnly)
|
return;
|
||||||
.OrderBy(file => File.GetCreationTime(file))
|
|
||||||
.ToArray();
|
//var files = Directory.GetFiles(Path.Combine(Path.GetDirectoryName(GlobalSettings.Instance.BasePath), GlobalSettings.Instance.ProfileName), "*.wav", SearchOption.TopDirectoryOnly)
|
||||||
int? i = this.settings.Index;
|
// .OrderBy(file => File.GetCreationTime(file))
|
||||||
string new_path = "";
|
// .ToArray();
|
||||||
if (i != null && i >= 0 && i < files.Length)
|
//int? i = this.settings.Index;
|
||||||
{
|
//string new_path = "";
|
||||||
new_path = files[i ?? 0];
|
//if (i != null && i >= 0 && i < files.Length)
|
||||||
}
|
//{
|
||||||
|
// new_path = files[i ?? 0];
|
||||||
|
//}
|
||||||
|
|
||||||
|
|
||||||
await Connection.SetTitleAsync(Path.GetFileNameWithoutExtension(new_path));
|
//await Connection.SetTitleAsync(Path.GetFileNameWithoutExtension(new_path));
|
||||||
if (new_path != settings.Path)
|
//if (new_path != settings.Path)
|
||||||
{
|
//{
|
||||||
settings.Path = new_path;
|
// settings.Path = new_path;
|
||||||
if(new_path != "")
|
// if(new_path != "")
|
||||||
{
|
// {
|
||||||
FileEntry opts = GlobalSettings.Instance.GetFileOptionsInCurrentProfile(new_path);
|
// FileEntry opts = GlobalSettings.Instance.GetFileOptionsInCurrentProfile(new_path);
|
||||||
settings.Volume = opts.Volume;
|
// settings.Volume = opts.Volume;
|
||||||
settings.PlayType = opts.Playtype;
|
// settings.PlayType = opts.Playtype;
|
||||||
}
|
// }
|
||||||
await SaveSettings();
|
// await SaveSettings();
|
||||||
}
|
//}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -109,8 +119,8 @@ namespace ClipTrimDotNet
|
|||||||
|
|
||||||
private void Connection_OnTitleParametersDidChange(object sender, SDEventReceivedEventArgs<BarRaider.SdTools.Events.TitleParametersDidChange> e)
|
private void Connection_OnTitleParametersDidChange(object sender, SDEventReceivedEventArgs<BarRaider.SdTools.Events.TitleParametersDidChange> e)
|
||||||
{
|
{
|
||||||
titleParameters = e.Event?.Payload?.TitleParameters;
|
//titleParameters = e.Event?.Payload?.TitleParameters;
|
||||||
userTitle = e.Event?.Payload?.Title;
|
//userTitle = e.Event?.Payload?.Title;
|
||||||
}
|
}
|
||||||
|
|
||||||
public override void Dispose()
|
public override void Dispose()
|
||||||
@ -125,14 +135,15 @@ namespace ClipTrimDotNet
|
|||||||
//Logger.Instance.LogMessage(TracingLevel.INFO, "Key Pressedd");
|
//Logger.Instance.LogMessage(TracingLevel.INFO, "Key Pressedd");
|
||||||
Tools.AutoPopulateSettings(settings, payload.Settings);
|
Tools.AutoPopulateSettings(settings, payload.Settings);
|
||||||
// Logger.Instance.LogMessage(TracingLevel.INFO, JsonConvert.SerializeObject(settings));
|
// Logger.Instance.LogMessage(TracingLevel.INFO, JsonConvert.SerializeObject(settings));
|
||||||
try
|
ClipTrimClient.Instance.PlayClip(metadata);
|
||||||
{
|
//try
|
||||||
WavPlayer.Instance.Play(settings.Path, GlobalSettings.Instance.OutputDevice, settings.Volume, settings.PlayType == "Play/Overlap" ? WavPlayer.PlayMode.PlayOverlap : WavPlayer.PlayMode.PlayStop);
|
//{
|
||||||
}
|
// WavPlayer.Instance.Play(settings.Path, GlobalSettings.Instance.OutputDevice, settings.Volume, settings.PlayType == "Play/Overlap" ? WavPlayer.PlayMode.PlayOverlap : WavPlayer.PlayMode.PlayStop);
|
||||||
catch
|
//}
|
||||||
{
|
//catch
|
||||||
|
//{
|
||||||
|
|
||||||
}
|
//}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -1,5 +1,6 @@
|
|||||||
using BarRaider.SdTools;
|
using BarRaider.SdTools;
|
||||||
using BarRaider.SdTools.Wrappers;
|
using BarRaider.SdTools.Wrappers;
|
||||||
|
using ClipTrimDotNet.Client;
|
||||||
using NAudio.CoreAudioApi.Interfaces;
|
using NAudio.CoreAudioApi.Interfaces;
|
||||||
using NAudio.Wave;
|
using NAudio.Wave;
|
||||||
using Newtonsoft.Json;
|
using Newtonsoft.Json;
|
||||||
@ -60,7 +61,7 @@ namespace ClipTrimDotNet
|
|||||||
private async void SetTitle()
|
private async void SetTitle()
|
||||||
{
|
{
|
||||||
|
|
||||||
await Connection.SetTitleAsync(settings.ProfileName);
|
await Connection.SetTitleAsync(settings.ProfileName + " A");
|
||||||
}
|
}
|
||||||
|
|
||||||
private async void Connection_OnSendToPlugin(object sender, SDEventReceivedEventArgs<BarRaider.SdTools.Events.SendToPlugin> e)
|
private async void Connection_OnSendToPlugin(object sender, SDEventReceivedEventArgs<BarRaider.SdTools.Events.SendToPlugin> e)
|
||||||
@ -68,8 +69,9 @@ namespace ClipTrimDotNet
|
|||||||
//Logger.Instance.LogMessage(TracingLevel.INFO, "get profiles");
|
//Logger.Instance.LogMessage(TracingLevel.INFO, "get profiles");
|
||||||
if (e.Event.Payload["event"].ToString() == "getProfiles")
|
if (e.Event.Payload["event"].ToString() == "getProfiles")
|
||||||
{
|
{
|
||||||
string basePath = "C:\\Users\\mickl\\Music\\clips";
|
//string basePath = "C:\\Users\\mickl\\Music\\clips";
|
||||||
var files = Directory.GetDirectories(basePath, "*", SearchOption.TopDirectoryOnly).Select(x => Path.GetFileNameWithoutExtension(x)).Where(x => x != "original");
|
//var files = Directory.GetDirectories(basePath, "*", SearchOption.TopDirectoryOnly).Select(x => Path.GetFileNameWithoutExtension(x)).Where(x => x != "original");
|
||||||
|
var files = ClipTrimClient.Instance.GetCollectionNames();
|
||||||
var items = files.Select(x => new DataSourceItem { label = x, value = x});
|
var items = files.Select(x => new DataSourceItem { label = x, value = x});
|
||||||
var obj = new JObject();
|
var obj = new JObject();
|
||||||
obj["event"] = "getProfiles";
|
obj["event"] = "getProfiles";
|
||||||
@ -110,6 +112,7 @@ namespace ClipTrimDotNet
|
|||||||
//Logger.Instance.LogMessage(TracingLevel.INFO, "KeyPressed");
|
//Logger.Instance.LogMessage(TracingLevel.INFO, "KeyPressed");
|
||||||
//Logger.Instance.LogMessage(TracingLevel.INFO, JsonConvert.SerializeObject(settings));
|
//Logger.Instance.LogMessage(TracingLevel.INFO, JsonConvert.SerializeObject(settings));
|
||||||
//Logger.Instance.LogMessage(TracingLevel.INFO, JsonConvert.SerializeObject(GlobalSettings.Instance));
|
//Logger.Instance.LogMessage(TracingLevel.INFO, JsonConvert.SerializeObject(GlobalSettings.Instance));
|
||||||
|
ClipTrimClient.Instance.SetSelectedCollectionByName(settings.ProfileName);
|
||||||
GlobalSettings.Instance.SetCurrentProfile(settings.ProfileName);
|
GlobalSettings.Instance.SetCurrentProfile(settings.ProfileName);
|
||||||
Logger.Instance.LogMessage(TracingLevel.INFO, JsonConvert.SerializeObject(GlobalSettings.Instance));
|
Logger.Instance.LogMessage(TracingLevel.INFO, JsonConvert.SerializeObject(GlobalSettings.Instance));
|
||||||
|
|
||||||
|
|||||||
@ -9,10 +9,10 @@
|
|||||||
<package id="NAudio.Wasapi" version="2.2.1" targetFramework="net48" />
|
<package id="NAudio.Wasapi" version="2.2.1" targetFramework="net48" />
|
||||||
<package id="NAudio.WinForms" version="2.2.1" targetFramework="net48" />
|
<package id="NAudio.WinForms" version="2.2.1" targetFramework="net48" />
|
||||||
<package id="NAudio.WinMM" version="2.2.1" targetFramework="net48" />
|
<package id="NAudio.WinMM" version="2.2.1" targetFramework="net48" />
|
||||||
<package id="Newtonsoft.Json" version="13.0.3" targetFramework="net472" />
|
<package id="Newtonsoft.Json" version="13.0.4" targetFramework="net48" />
|
||||||
<package id="NLog" version="5.2.8" targetFramework="net472" />
|
<package id="NLog" version="6.0.5" targetFramework="net48" />
|
||||||
<package id="StreamDeck-Tools" version="6.2.0" targetFramework="net472" />
|
<package id="StreamDeck-Tools" version="6.3.2" targetFramework="net48" />
|
||||||
<package id="System.Drawing.Common" version="8.0.1" targetFramework="net472" />
|
<package id="System.Drawing.Common" version="9.0.10" targetFramework="net48" />
|
||||||
<package id="System.Security.AccessControl" version="4.7.0" targetFramework="net48" />
|
<package id="System.Security.AccessControl" version="4.7.0" targetFramework="net48" />
|
||||||
<package id="System.Security.Principal.Windows" version="4.7.0" targetFramework="net48" />
|
<package id="System.Security.Principal.Windows" version="4.7.0" targetFramework="net48" />
|
||||||
</packages>
|
</packages>
|
||||||
Reference in New Issue
Block a user