1
0

auto-git:

[change] main.js
This commit is contained in:
2025-05-31 19:24:35 +02:00
parent dad4eb36b0
commit 536c817ec5

224
main.js
View File

@@ -1387,6 +1387,126 @@ function buildTrayMenu() {
}
});
ipcMain.on('show-folder-context-menu', (event, folderPath) => {
const win = BrowserWindow.fromWebContents(event.sender);
const template = [
{
label: 'Open Folder',
click: () => {
// öffnet den Ordner in der nativen Dateiansicht
shell.openPath(folderPath);
}
},
{
label: 'Copy Folder Path',
click: () => {
clipboard.writeText(folderPath);
}
}
];
const menu = Menu.buildFromTemplate(template);
menu.popup({ window: win });
});
ipcMain.on('show-tree-context-menu', (event, { absPath, relPath, root, type }) => {
const win = BrowserWindow.fromWebContents(event.sender);
const template = [
{
label: 'Open File',
click: () => shell.openPath(absPath),
visible: type === 'file' // Nur für Dateien anzeigen
},
{
label: 'Open Folder',
click: () => shell.openPath(absPath),
visible: type === 'dir' // Nur für Dateien anzeigen
},
{
label: 'Copy File Path',
click: () => clipboard.writeText(absPath),
visible: type === 'file' // Nur für Dateien anzeigen
},
{
label: 'Copy Folder Path',
click: () => clipboard.writeText(absPath),
visible: type === 'dir' // Nur für Dateien anzeigen
},
{
label: 'Add to .gitignore',
click: () => {
const gitignore = path.join(root, '.gitignore');
fs.appendFile(gitignore, `\n${relPath}\n`, (err) => {
if (err) {
dialog.showErrorBox('Error', 'Konnte nicht zu .gitignore hinzufügen:\n' + err.message);
}
});
}
}
];
const menu = Menu.buildFromTemplate(template);
menu.popup({ window: win });
});
// README STUFF
const MAX_TOTAL_SIZE = 100 * 1024; // 100 KB
const CODE_EXTS = [
'.js','.jsx','.ts','.tsx','.py','.sh','.rb','.pl','.php','.java','.c','.cpp','.h','.cs','.go','.rs','.json','.yml','.yaml','.toml','.md','.html','.css','.txt'
];
function isTextFile(filePath) {
// Optional: Mehr Intelligenz!
const ext = path.extname(filePath).toLowerCase();
if (CODE_EXTS.includes(ext)) return true;
// Ignoriere node_modules und große Binaries!
const stat = fs.statSync(filePath);
if (stat.size > 200*1024) return false;
const buffer = fs.readFileSync(filePath, {encoding: null, flag: 'r'});
for (let i = 0; i < Math.min(buffer.length, 400); i++) {
if (buffer[i] === 0) return false;
}
return true;
}
// --- Dateien sammeln ---
function getRelevantFiles(dir, maxSize = MAX_TOTAL_SIZE) {
let files = [];
function walk(current) {
for (const f of fs.readdirSync(current)) {
const full = path.join(current, f);
if (fs.statSync(full).isDirectory()) {
if (f.startsWith('.')) continue; // .git etc auslassen
walk(full);
} else if (isTextFile(full)) {
files.push(full);
}
}
}
walk(dir);
// Sortiere nach Größe, nimm so viele wie ins Limit passen
files = files.map(f => ({f, s: fs.statSync(f).size}))
.sort((a,b)=>a.s-b.s);
let sum = 0, selected = [];
for (let {f,s} of files) {
if (sum + s > maxSize) break;
selected.push(f);
sum += s;
}
return selected;
}
ipcMain.handle('has-readme', async (_evt, folderPath) => {
const readmePath = path.join(folderPath, 'README.md');
return fs.existsSync(readmePath);
@@ -1480,114 +1600,10 @@ Source Code:
};
const MAX_TOTAL_SIZE = 100 * 1024; // 100 KB
const CODE_EXTS = [
'.js','.jsx','.ts','.tsx','.py','.sh','.rb','.pl','.php','.java','.c','.cpp','.h','.cs','.go','.rs','.json','.yml','.yaml','.toml','.md','.html','.css','.txt'
];
function isTextFile(filePath) {
// Optional: Mehr Intelligenz!
const ext = path.extname(filePath).toLowerCase();
if (CODE_EXTS.includes(ext)) return true;
// Ignoriere node_modules und große Binaries!
const stat = fs.statSync(filePath);
if (stat.size > 200*1024) return false;
const buffer = fs.readFileSync(filePath, {encoding: null, flag: 'r'});
for (let i = 0; i < Math.min(buffer.length, 400); i++) {
if (buffer[i] === 0) return false;
}
return true;
}
// --- Dateien sammeln ---
function getRelevantFiles(dir, maxSize = MAX_TOTAL_SIZE) {
let files = [];
function walk(current) {
for (const f of fs.readdirSync(current)) {
const full = path.join(current, f);
if (fs.statSync(full).isDirectory()) {
if (f.startsWith('.')) continue; // .git etc auslassen
walk(full);
} else if (isTextFile(full)) {
files.push(full);
}
}
}
walk(dir);
// Sortiere nach Größe, nimm so viele wie ins Limit passen
files = files.map(f => ({f, s: fs.statSync(f).size}))
.sort((a,b)=>a.s-b.s);
let sum = 0, selected = [];
for (let {f,s} of files) {
if (sum + s > maxSize) break;
selected.push(f);
sum += s;
}
return selected;
}
ipcMain.on('show-folder-context-menu', (event, folderPath) => {
const win = BrowserWindow.fromWebContents(event.sender);
const template = [
{
label: 'Open Folder',
click: () => {
// öffnet den Ordner in der nativen Dateiansicht
shell.openPath(folderPath);
}
},
{
label: 'Copy Folder Path',
click: () => {
clipboard.writeText(folderPath);
}
}
];
const menu = Menu.buildFromTemplate(template);
menu.popup({ window: win });
});
ipcMain.on('show-tree-context-menu', (event, { absPath, relPath, root, type }) => {
const win = BrowserWindow.fromWebContents(event.sender);
const template = [
{
label: 'Open File',
click: () => shell.openPath(absPath),
visible: type === 'file' // Nur für Dateien anzeigen
},
{
label: 'Open Folder',
click: () => shell.openPath(absPath),
visible: type === 'dir' // Nur für Dateien anzeigen
},
{
label: 'Copy File Path',
click: () => clipboard.writeText(absPath),
visible: type === 'file' // Nur für Dateien anzeigen
},
{
label: 'Copy Folder Path',
click: () => clipboard.writeText(absPath),
visible: type === 'dir' // Nur für Dateien anzeigen
},
{
label: 'Add to .gitignore',
click: () => {
const gitignore = path.join(root, '.gitignore');
fs.appendFile(gitignore, `\n${relPath}\n`, (err) => {
if (err) {
dialog.showErrorBox('Error', 'Konnte nicht zu .gitignore hinzufügen:\n' + err.message);
}
});
}
}
];
const menu = Menu.buildFromTemplate(template);
menu.popup({ window: win });
});
ipcMain.on('get-selected-sync', (event) => {
const folders = store.get('folders') || [];
const selectedPath = store.get('selected');