mirror of
https://github.com/th-ch/youtube-music.git
synced 2026-01-15 04:11:47 +00:00
Set metadata in back (to have cover)
This commit is contained in:
@ -1,6 +1,8 @@
|
|||||||
|
const { writeFileSync } = require("fs");
|
||||||
const { join } = require("path");
|
const { join } = require("path");
|
||||||
|
|
||||||
const { dialog } = require("electron");
|
const ID3Writer = require("browser-id3-writer");
|
||||||
|
const { dialog, ipcMain } = require("electron");
|
||||||
|
|
||||||
const getSongInfo = require("../../providers/song-info");
|
const getSongInfo = require("../../providers/song-info");
|
||||||
const { injectCSS, listenAction } = require("../utils");
|
const { injectCSS, listenAction } = require("../utils");
|
||||||
@ -38,6 +40,34 @@ function handle(win) {
|
|||||||
console.log("Unknown action: " + action);
|
console.log("Unknown action: " + action);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
ipcMain.on("add-metadata", (event, filePath, songBuffer, currentMetadata) => {
|
||||||
|
let fileBuffer = songBuffer;
|
||||||
|
const songMetadata = { ...metadata, ...currentMetadata };
|
||||||
|
|
||||||
|
try {
|
||||||
|
const coverBuffer = songMetadata.image.toPNG();
|
||||||
|
const writer = new ID3Writer(songBuffer);
|
||||||
|
|
||||||
|
// Create the metadata tags
|
||||||
|
writer
|
||||||
|
.setFrame("TIT2", songMetadata.title)
|
||||||
|
.setFrame("TPE1", [songMetadata.artist])
|
||||||
|
.setFrame("APIC", {
|
||||||
|
type: 3,
|
||||||
|
data: coverBuffer,
|
||||||
|
description: "",
|
||||||
|
});
|
||||||
|
writer.addTag();
|
||||||
|
fileBuffer = Buffer.from(writer.arrayBuffer);
|
||||||
|
} catch (error) {
|
||||||
|
sendError(win, error);
|
||||||
|
}
|
||||||
|
|
||||||
|
writeFileSync(filePath, fileBuffer);
|
||||||
|
// Notify the youtube-dl file
|
||||||
|
event.reply("add-metadata-done");
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
module.exports = handle;
|
module.exports = handle;
|
||||||
|
|||||||
@ -1,9 +1,7 @@
|
|||||||
const { randomBytes } = require("crypto");
|
const { randomBytes } = require("crypto");
|
||||||
const { writeFileSync } = require("fs");
|
|
||||||
const { join } = require("path");
|
const { join } = require("path");
|
||||||
|
|
||||||
const Mutex = require("async-mutex").Mutex;
|
const Mutex = require("async-mutex").Mutex;
|
||||||
const ID3Writer = require("browser-id3-writer");
|
|
||||||
const { ipcRenderer } = require("electron");
|
const { ipcRenderer } = require("electron");
|
||||||
const is = require("electron-is");
|
const is = require("electron-is");
|
||||||
const filenamify = require("filenamify");
|
const filenamify = require("filenamify");
|
||||||
@ -133,29 +131,12 @@ const toMP3 = async (
|
|||||||
const fileBuffer = ffmpeg.FS("readFile", safeVideoName + "." + extension);
|
const fileBuffer = ffmpeg.FS("readFile", safeVideoName + "." + extension);
|
||||||
|
|
||||||
// Add the metadata
|
// Add the metadata
|
||||||
try {
|
sendFeedback("Adding metadata…");
|
||||||
const writer = new ID3Writer(fileBuffer);
|
ipcRenderer.send("add-metadata", filePath, fileBuffer, {
|
||||||
if (metadata.image) {
|
artist: metadata.artist,
|
||||||
const coverBuffer = metadata.image.toPNG();
|
title: metadata.title,
|
||||||
|
});
|
||||||
// Create the metadata tags
|
ipcRenderer.once("add-metadata-done", reinit);
|
||||||
writer
|
|
||||||
.setFrame("TIT2", metadata.title)
|
|
||||||
.setFrame("TPE1", [metadata.artist])
|
|
||||||
.setFrame("APIC", {
|
|
||||||
type: 3,
|
|
||||||
data: coverBuffer,
|
|
||||||
description: "",
|
|
||||||
});
|
|
||||||
writer.addTag();
|
|
||||||
}
|
|
||||||
|
|
||||||
writeFileSync(filePath, Buffer.from(writer.arrayBuffer));
|
|
||||||
} catch (error) {
|
|
||||||
sendError(error);
|
|
||||||
} finally {
|
|
||||||
reinit();
|
|
||||||
}
|
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
sendError(e);
|
sendError(e);
|
||||||
} finally {
|
} finally {
|
||||||
|
|||||||
Reference in New Issue
Block a user