auto-organize 1.0.0 → 1.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +3 -2
- package/src/cli/spinner.js +8 -0
- package/src/index.js +17 -1
- package/src/organizer/organizeDirectory.js +7 -2
- package/src/utils/fsHelpers.js +5 -1
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "auto-organize",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.2.0",
|
|
4
4
|
"description": "CLI tool to organize files in a directory based on their file types.",
|
|
5
5
|
"main": "./bin/auto-organize.js",
|
|
6
6
|
"bin": {
|
|
@@ -45,6 +45,7 @@
|
|
|
45
45
|
"node": ">=18"
|
|
46
46
|
},
|
|
47
47
|
"dependencies": {
|
|
48
|
-
"chalk": "^5.6.2"
|
|
48
|
+
"chalk": "^5.6.2",
|
|
49
|
+
"ora": "^9.1.0"
|
|
49
50
|
}
|
|
50
51
|
}
|
package/src/index.js
CHANGED
|
@@ -3,6 +3,7 @@ import { renderFoldersSummary } from './cli/renderSummary.js';
|
|
|
3
3
|
import { parseArgs } from './utils/parseArgs.js';
|
|
4
4
|
import { getAvailableTypes } from './rules/byType.js';
|
|
5
5
|
import { cliActions } from './cli/cliActions.js';
|
|
6
|
+
import { startSpinner } from './cli/spinner.js';
|
|
6
7
|
|
|
7
8
|
function main() {
|
|
8
9
|
try {
|
|
@@ -10,6 +11,7 @@ function main() {
|
|
|
10
11
|
const cliFlags = parseArgs(cliArguments);
|
|
11
12
|
const availableTypes = getAvailableTypes();
|
|
12
13
|
const currentDir = process.cwd();
|
|
14
|
+
let spinner;
|
|
13
15
|
|
|
14
16
|
const cliResult = cliActions(cliFlags, availableTypes);
|
|
15
17
|
|
|
@@ -17,13 +19,27 @@ function main() {
|
|
|
17
19
|
process.exit(cliResult.code);
|
|
18
20
|
}
|
|
19
21
|
|
|
22
|
+
spinner = startSpinner('Organizing files...');
|
|
20
23
|
const summary = organizeDirectory(currentDir, cliFlags);
|
|
21
24
|
|
|
22
|
-
if(!summary)
|
|
25
|
+
if(!summary){
|
|
26
|
+
spinner.stop();
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
23
29
|
|
|
24
30
|
renderFoldersSummary(summary);
|
|
25
31
|
|
|
32
|
+
if(summary.previewMode){
|
|
33
|
+
console.log("");
|
|
34
|
+
spinner.succeed('Preview generated successfully!');
|
|
35
|
+
}else{
|
|
36
|
+
spinner.succeed('Files organized successfully!');
|
|
37
|
+
}
|
|
38
|
+
|
|
26
39
|
} catch (error) {
|
|
40
|
+
if(spinner){
|
|
41
|
+
spinner.fail('Error organizing files');
|
|
42
|
+
}
|
|
27
43
|
console.error(`\nError: ${error.message}`);
|
|
28
44
|
process.exit(1);
|
|
29
45
|
}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import path from 'path';
|
|
2
|
-
import { getFilesFromDirectory, ensureDirectoryExists, moveFile } from '../utils/fsHelpers.js';
|
|
2
|
+
import { getFilesFromDirectory, ensureDirectoryExists, fileExists, moveFile } from '../utils/fsHelpers.js';
|
|
3
3
|
import { getFolderNameByExtensionType } from '../rules/byType.js';
|
|
4
4
|
import { shouldSkipFile } from '../utils/filesFilters.js';
|
|
5
5
|
import { renderEmptyFolderText } from '../cli/renderEmptyFolderText.js';
|
|
6
|
+
import chalk from 'chalk';
|
|
6
7
|
|
|
7
8
|
function organizeDirectory(baseDir, cliFlags = {}) {
|
|
8
9
|
try{
|
|
@@ -37,10 +38,14 @@ function organizeDirectory(baseDir, cliFlags = {}) {
|
|
|
37
38
|
|
|
38
39
|
if (folderByExtensionTypeWasCreated) folderByExtensionTypeCreated = true;
|
|
39
40
|
|
|
41
|
+
if (fileExists(filePathByExtension)){
|
|
42
|
+
throw new Error(`File collision detected: "${chalk.red(file.name)}" already exists in "${chalk.blueBright(folderNameByExtensionType)}/"`);
|
|
43
|
+
}
|
|
44
|
+
|
|
40
45
|
moveFile(file.path, filePathByExtension);
|
|
41
46
|
});
|
|
42
47
|
|
|
43
|
-
return
|
|
48
|
+
return{
|
|
44
49
|
foldersByExtensionType: outputFoldersSummary,
|
|
45
50
|
folderWasCreated: folderByExtensionTypeCreated,
|
|
46
51
|
previewMode: cliFlags.preview,
|
package/src/utils/fsHelpers.js
CHANGED
|
@@ -26,8 +26,12 @@ function ensureDirectoryExists(dirPath) {
|
|
|
26
26
|
return false;
|
|
27
27
|
}
|
|
28
28
|
|
|
29
|
+
function fileExists(filePath) {
|
|
30
|
+
return fs.existsSync(filePath);
|
|
31
|
+
}
|
|
32
|
+
|
|
29
33
|
function moveFile(sourcePath, targetPath) {
|
|
30
34
|
fs.renameSync(sourcePath, targetPath);
|
|
31
35
|
}
|
|
32
36
|
|
|
33
|
-
export { getFilesFromDirectory, ensureDirectoryExists, moveFile };
|
|
37
|
+
export { getFilesFromDirectory, ensureDirectoryExists, fileExists, moveFile };
|