@khatastroffik/treefolder 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/README.md CHANGED
@@ -59,9 +59,15 @@ Notes:
59
59
 
60
60
  ### Sort leaves "folders first"
61
61
 
62
- By default, the list i.e. the leaves of the treeview are sorted following the _"folders first" principle_: All the folders are listed first, then all the files. All items are alphabetically sorted. This apply at any depth within the tree structure.
62
+ By default, the list or the leaves of the treeview are sorted following the _"folders first" principle_: All the folders are listed first, then all the files. All items are alphabetically sorted. This apply at any depth within the tree structure.
63
63
 
64
- This behavior can be _disabled_ using the command line argument `--unsorted`. In this case, all items are sorted the way the operating system does e.g. sorted by their names, regardless of their type (directory or file).
64
+ This behavior can be _disabled_ using the command line argument `--unsorted`. In this case, all items are sorted the way the operating system does by default e.g. sorted by their names, regardless of their type (directory or file).
65
+
66
+ ### List output
67
+
68
+ When the command line argument `--list` (short: `-l`) is used, all the folders and files will be displayed as a flat list instead of as a treeview.
69
+
70
+ Note: the command line arguments `--unsorted` and `--style colored` may also be applied to refine i.e. adapt the list output. See the [List output examples](docs/readme.md#list-output-examples)
65
71
 
66
72
  ### Styled output
67
73
 
@@ -70,7 +76,10 @@ The style can be defined using the command line argument `--style`or `-s` like s
70
76
 
71
77
  → Examples of styled output can be found in the additional documentation: [Styled output examples](docs/readme.md#styled-output-examples)
72
78
 
73
- Note: some environments i.e. shells may not display the symbols (which are represented using specific unicode code points like `U+1F5BF` or `U+1F5C1`) properly. Try to change the _font_ used in the shell in order to display the correct unicode symbols.
79
+ Notes:
80
+
81
+ - some shell environments may not display the symbols (which are represented using specific unicode code points like `U+1F5BF` or `U+1F5C1`) properly. Try to change the _font_ used in the shell or to change the code page used by your shell in the background to interpret the chars, in order to display the unicode symbols properly.
82
+ - On some shell environments e.g. under Windows OS, the output may still be faulty due to the OS automatically pre-formating the output in an inadequate way. Try to use another shell environment then.
74
83
 
75
84
  ### Version information
76
85
 
package/dist/index.js CHANGED
@@ -1,2 +1,2 @@
1
1
  #! /usr/bin/env node
2
- "use strict";var __createBinding=this&&this.__createBinding||(Object.create?function(e,o,n,t){void 0===t&&(t=n);var r=Object.getOwnPropertyDescriptor(o,n);r&&!("get"in r?!o.__esModule:r.writable||r.configurable)||(r={enumerable:!0,get:function(){return o[n]}}),Object.defineProperty(e,t,r)}:function(e,o,n,t){void 0===t&&(t=n),e[t]=o[n]}),__setModuleDefault=this&&this.__setModuleDefault||(Object.create?function(e,o){Object.defineProperty(e,"default",{enumerable:!0,value:o})}:function(e,o){e.default=o}),__importStar=this&&this.__importStar||function(){var e=function(o){return e=Object.getOwnPropertyNames||function(e){var o=[];for(var n in e)Object.prototype.hasOwnProperty.call(e,n)&&(o[o.length]=n);return o},e(o)};return function(o){if(o&&o.__esModule)return o;var n={};if(null!=o)for(var t=e(o),r=0;r<t.length;r++)"default"!==t[r]&&__createBinding(n,o,t[r]);return __setModuleDefault(n,o),n}}(),__importDefault=this&&this.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(exports,"__esModule",{value:!0});const node_fs_1=__importDefault(require("node:fs")),node_path_1=__importDefault(require("node:path")),node_process_1=require("node:process"),node_util_1=__importStar(require("node:util")),package_json_1=require("../package.json"),readdirPromise=node_util_1.default.promisify(node_fs_1.default.readdir),space=" ";var Style;!function(e){e.none="none",e.wireframe="wireframe",e.black="black",e.colored="colored"}(Style||(Style={}));const symbolStyles={none:{closed:"",open:"",file:""},wireframe:{closed:"šŸ—€",open:"šŸ—",file:"šŸ—‹"},black:{closed:"šŸ–æ",open:"šŸ–æ",file:"šŸ—Ž"},colored:{closed:"šŸ“",open:"šŸ“‚",file:"šŸ“„"}},parseArgsOptionsConfig={style:{type:"string",default:"none",short:"s"},verbose:{type:"boolean",default:!1},unsorted:{type:"boolean",default:!1,short:"u"},version:{type:"boolean",default:!1,short:"v"}},config={style:Style.none,symbols:symbolStyles.none,root:".",ignores:["node_modules","dist","build",".git",".husky\\_","logs",".angular","coverage"],verbose:!1,unsorted:!1};let folderCount=0,fileCount=0,ignoredCount=0,cliArgs={};function compareFolderContentItems(e,o){return e.isDirectory()?o.isFile()?-1:e.name.localeCompare(o.name):o.isDirectory()?1:e.name.localeCompare(o.name)}function isIgnored(e,o){const n=config.ignores.includes(node_path_1.default.join(e,o));return n&&ignoredCount++,n}async function getFolderContent(e){const o=(await readdirPromise(e,{withFileTypes:!0})).filter(o=>!isIgnored(e,o.name));return config.unsorted?o:o.sort(compareFolderContentItems)}async function buildTree(e,o,n,t){const r=await getFolderContent(e),i=r.length<1?config.symbols.closed:config.symbols.open;let s=`${o+(n?"":t?`└─${i} `:`ā”œā”€${i} `)}${n&&config.symbols.open?`${i} ${node_path_1.default.basename(e)}`:node_path_1.default.basename(e)}\n`;const l=n?"":t?" ":"│ ",a=r.length-1;for(let n=0;n<r.length;n++){const t=r[n];if(t.isDirectory()&&(s+=await buildTree(node_path_1.default.join(e,t.name),o+l,!1,n===a)),t.isFile()){fileCount++;s+=`${o+l+(n===a?`└─${config.symbols.file} `:`ā”œā”€${config.symbols.file} `)+t.name}\n`}}return folderCount++,s}async function configure(){let e;try{e=(0,node_util_1.parseArgs)({options:parseArgsOptionsConfig,allowPositionals:!0,strict:!0})}catch(e){const o=e;console.error(`[${(0,node_util_1.styleText)("red",o.name)}]: ${o.message}`),(0,node_process_1.exit)(1)}const{values:o,positionals:n}=e;o.version&&(await version(),(0,node_process_1.exit)(0)),config.style=Style[o.style]??config.style,config.symbols=symbolStyles[config.style],config.root=node_path_1.default.resolve(n.length>0?n[0]:config.root),config.ignores=config.ignores.map(e=>node_path_1.default.join(config.root,e)),config.unsorted=Boolean(o.unsorted),config.verbose=Boolean(o.verbose),cliArgs={...o,root:n[0]??"n/a"}}function t(e){return(0,node_util_1.styleText)("number"==typeof e?"yellow":"blueBright",`${e}`)}async function version(){console.info(t(`\n Treefolder aka "tfold"\n Version ${package_json_1.version}\n \n https://npmjs.com/@khatastroffik/treefolder\n\n ā”Œā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”\n | |\n ╭━┳━╭━╭━╮╮\n ā”ƒā”ˆā”ˆā”ˆā”£ā–„ā•‹ā–„ā”«\n ā”ƒā”ˆā”ƒā”ˆā•°ā”ā•°ā”ā”ā”ā”ā”ā”ā•® "K11K"\n ā•°ā”³ā•Æā”ˆā”ˆā”ˆā”ˆā”ˆā”ˆā”ˆā”ˆ ā—¢ā–ˆā—£ a very pragmatic dog\n ā”ƒā”ˆā”ˆā”ˆā”ˆā”ˆā”ˆā”ˆā”ˆā”ˆā”ˆā–ˆā–ˆā–ˆā–ˆ\n ā”ƒā”ˆā”ˆā”ˆā”ˆā”ˆā”ˆā”ˆā”ˆā”ˆā”ˆā—„ā–ˆā—¤\n ā”ƒā”ˆā”ˆā”ˆā”ˆā•­ā”ā”³ā”ā”ā”ā”ā•Æ\n ┣━━━━━━┫\n | |\n └──────────── made by khatastroffik ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”˜\n `))}async function main(){await configure(),console.info(await buildTree(config.root,"",!0,!0)),config.verbose&&(console.info(t("\nCommand line arguments:")),console.info(cliArgs),console.info(t("\nTreefolder configuration:")),console.info(config,"\n"),console.info(t(`Scanned ${t(folderCount)} folders and ${t(fileCount)} files.`)),console.info(t(`Filtered out ${t(ignoredCount)} items (folders or files).`)))}main();
2
+ "use strict";var __createBinding=this&&this.__createBinding||(Object.create?function(e,o,t,n){void 0===n&&(n=t);var r=Object.getOwnPropertyDescriptor(o,t);r&&!("get"in r?!o.__esModule:r.writable||r.configurable)||(r={enumerable:!0,get:function(){return o[t]}}),Object.defineProperty(e,n,r)}:function(e,o,t,n){void 0===n&&(n=t),e[n]=o[t]}),__setModuleDefault=this&&this.__setModuleDefault||(Object.create?function(e,o){Object.defineProperty(e,"default",{enumerable:!0,value:o})}:function(e,o){e.default=o}),__importStar=this&&this.__importStar||function(){var e=function(o){return e=Object.getOwnPropertyNames||function(e){var o=[];for(var t in e)Object.prototype.hasOwnProperty.call(e,t)&&(o[o.length]=t);return o},e(o)};return function(o){if(o&&o.__esModule)return o;var t={};if(null!=o)for(var n=e(o),r=0;r<n.length;r++)"default"!==n[r]&&__createBinding(t,o,n[r]);return __setModuleDefault(t,o),t}}(),__importDefault=this&&this.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(exports,"__esModule",{value:!0});const node_fs_1=__importDefault(require("node:fs")),node_path_1=__importDefault(require("node:path")),node_process_1=require("node:process"),node_util_1=__importStar(require("node:util")),package_json_1=require("../package.json"),readdirPromise=node_util_1.default.promisify(node_fs_1.default.readdir),space=" ";var Style;!function(e){e.none="none",e.wireframe="wireframe",e.black="black",e.colored="colored"}(Style||(Style={}));const symbolStyles={none:{closed:"",open:"",file:""},wireframe:{closed:"šŸ—€ ",open:"šŸ— ",file:"šŸ—‹"},black:{closed:"šŸ–æ ",open:"šŸ–æ ",file:"šŸ—Ž"},colored:{closed:"šŸ“ ",open:"šŸ“‚ ",file:"šŸ“„"}},parseArgsOptionsConfig={style:{type:"string",default:"none",short:"s"},verbose:{type:"boolean",default:!1},unsorted:{type:"boolean",default:!1,short:"u"},version:{type:"boolean",default:!1,short:"v"},list:{type:"boolean",default:!1,short:"l"}},config={style:Style.none,symbols:symbolStyles.none,root:".",ignores:["node_modules","dist","build",".git",".husky\\_","logs",".angular","coverage"],verbose:!1,unsorted:!1,formatAsList:!1};let folderCount=0,fileCount=0,ignoredCount=0,cliArgs={};function formatFolderLeaf(e,o,t,n){return`${e+o+t+node_path_1.default.basename(n)}\n`}function formatFileLeaf(e,o,t,n){return`${e+o+t+n.name}\n`}function formatFolderListItem(e,o,t,n){let r=n+node_path_1.default.sep;return config.style===Style.colored&&(r=(0,node_util_1.styleText)("blueBright",r)),`${r}\n`}function formatFileListItem(e,o,t,n){return`${node_path_1.default.join(n.parentPath,n.name)}\n`}let formatFolder=formatFolderLeaf,formatFile=formatFileLeaf;function colorText(e){return(0,node_util_1.styleText)("number"==typeof e?"yellow":"blueBright",`${e}`)}async function getLatestVersion(){const e=await fetch("https://registry.npmjs.org/@khatastroffik/treefolder");await new Promise(e=>setTimeout(e,100));return(await e.json())["dist-tags"].latest}function compareFolderContentItems(e,o){return e.isDirectory()?o.isFile()?-1:e.name.localeCompare(o.name):o.isDirectory()?1:e.name.localeCompare(o.name)}function isIgnored(e,o){const t=config.ignores.includes(node_path_1.default.join(e,o));return t&&ignoredCount++,t}async function getFolderContent(e){const o=(await readdirPromise(e,{withFileTypes:!0})).filter(o=>!isIgnored(e,o.name));return config.unsorted?o:o.sort(compareFolderContentItems)}async function buildTree(e,o,t,n){const r=await getFolderContent(e),i=r.length<1?config.symbols.closed:config.symbols.open,s=t?"":(n?"└─":"ā”œā”€")+(config.symbols.open?"":" ");let l=formatFolder(o,s,i,e);const a=t?"":n?" ":"│ ",f=r.length-1;for(let t=0;t<r.length;t++){const n=r[t];if(n.isDirectory()&&(l+=await buildTree(node_path_1.default.join(e,n.name),o+a,!1,t===f)),n.isFile()){fileCount++;const e=t===f?`└─${config.symbols.file} `:`ā”œā”€${config.symbols.file} `;l+=formatFile(o,a,e,n)}}return folderCount++,l}async function configure(){let e;try{e=(0,node_util_1.parseArgs)({options:parseArgsOptionsConfig,allowPositionals:!0,strict:!0})}catch(e){const o=e;return console.error(`[${(0,node_util_1.styleText)("red",o.name)}]: ${o.message}`),(0,node_process_1.exit)(1)}const{values:o,positionals:t}=e;if(o.version)return await version(),(0,node_process_1.exit)(0);config.formatAsList=Boolean(o.list),config.formatAsList&&(formatFolder=formatFolderListItem,formatFile=formatFileListItem),config.style=Style[o.style]??config.style,config.symbols=symbolStyles[config.style],config.root=node_path_1.default.resolve(t.length>0?t[0]:config.root),config.ignores=config.ignores.map(e=>node_path_1.default.join(config.root,e)),config.unsorted=Boolean(o.unsorted),config.verbose=Boolean(o.verbose),cliArgs={...o,root:t[0]??"n/a"}}async function version(){let e;const o=await getLatestVersion();o&&o!==package_json_1.version&&(e=(0,node_util_1.styleText)("yellow",`\nā”Œā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”\n| A new version of Treefolder is available: |\n| current: ${package_json_1.version} -> latest: ${o} |\n| |\n| Install the latest version with: |\n| "npm update -g @khatastroffik/treefolder@latest" |\nā””ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”˜\n`)),console.info(colorText(`\n Treefolder aka "tfold"\n Version ${package_json_1.version}\n \n https://npmjs.com/@khatastroffik/treefolder\n${e??'\n ā”Œā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”\n | |\n ╭━┳━╭━╭━╮╮\n ā”ƒā”ˆā”ˆā”ˆā”£ā–„ā•‹ā–„ā”«\n ā”ƒā”ˆā”ƒā”ˆā•°ā”ā•°ā”ā”ā”ā”ā”ā”ā•® "K11K"\n ā•°ā”³ā•Æā”ˆā”ˆā”ˆā”ˆā”ˆā”ˆā”ˆā”ˆ ā—¢ā–ˆā—£ a very pragmatic dog\n ā”ƒā”ˆā”ˆā”ˆā”ˆā”ˆā”ˆā”ˆā”ˆā”ˆā”ˆā–ˆā–ˆā–ˆā–ˆ\n ā”ƒā”ˆā”ˆā”ˆā”ˆā”ˆā”ˆā”ˆā”ˆā”ˆā”ˆā—„ā–ˆā—¤\n ā”ƒā”ˆā”ˆā”ˆā”ˆā•­ā”ā”³ā”ā”ā”ā”ā•Æ\n ┣━━━━━━┫\n | |\n └──────────── made by khatastroffik ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”€ā”˜\n '}`))}async function verbose(){config.verbose&&(console.info(colorText("\nCommand line arguments:")),console.info(cliArgs),console.info(colorText("\nTreefolder configuration:")),console.info(config,"\n"),console.info(colorText(`Scanned ${colorText(folderCount)} folders and ${colorText(fileCount)} files.`)),console.info(colorText(`Filtered out ${colorText(ignoredCount)} items (folders or files).`)))}async function main(){await configure();const e=await buildTree(config.root,"",!0,!0);console.info(e),await verbose()}main();
package/docs/readme.md CHANGED
@@ -1,5 +1,11 @@
1
1
  # Additional documentation
2
2
 
3
+ ## Table of Content
4
+
5
+ - [Styled output examples](#styled-output-examples)
6
+ - [List output examples](#list-output-examples)
7
+ - [Sources &amp; stories](#sources--stories)
8
+
3
9
  ## Styled output examples
4
10
 
5
11
  ### "none" Style &rarr; `--style=none`
@@ -96,6 +102,72 @@ treefolder
96
102
  ā””ā”€šŸ—‹ tsconfig.json
97
103
  ```
98
104
 
105
+ ## List output examples
106
+
107
+ ### Simple list output &rarr; `--list`
108
+
109
+ This is the **default** format of the list output: it displays the full path of the items and all items are sorted using the _"folder first" principle_.
110
+
111
+ ```shell
112
+ C:\development\treefolder\
113
+ C:\development\treefolder\.husky\
114
+ C:\development\treefolder\.husky\pre-commit
115
+ C:\development\treefolder\.vscode\
116
+ C:\development\treefolder\.vscode\settings.json
117
+ C:\development\treefolder\docs\
118
+ C:\development\treefolder\docs\commit-messages-guideline.md
119
+ C:\development\treefolder\docs\readme.md
120
+ C:\development\treefolder\docs\tfold.jpg
121
+ C:\development\treefolder\src\
122
+ C:\development\treefolder\src\index.ts
123
+ C:\development\treefolder\.gitattributes
124
+ C:\development\treefolder\.gitignore
125
+ C:\development\treefolder\CHANGELOG.md
126
+ C:\development\treefolder\eslint.config.mjs
127
+ C:\development\treefolder\jest.config.js
128
+ C:\development\treefolder\LICENSE
129
+ C:\development\treefolder\package.json
130
+ C:\development\treefolder\pnpm-lock.yaml
131
+ C:\development\treefolder\pnpm-workspace.yaml
132
+ C:\development\treefolder\README.md
133
+ C:\development\treefolder\tsconfig.json
134
+ ```
135
+
136
+ ### Unsorted list output &rarr; `--list --unsorted`
137
+
138
+ In this use case, the list items are sorted the way the operating system does by default e.g. sorted by their names, regardless of their type (directory or file).
139
+
140
+ ```shell
141
+ C:\development\treefolder\
142
+ C:\development\treefolder\.gitattributes
143
+ C:\development\treefolder\.gitignore
144
+ C:\development\treefolder\.husky\
145
+ C:\development\treefolder\.husky\pre-commit
146
+ C:\development\treefolder\.vscode\
147
+ C:\development\treefolder\.vscode\settings.json
148
+ C:\development\treefolder\CHANGELOG.md
149
+ C:\development\treefolder\docs\
150
+ C:\development\treefolder\docs\commit-messages-guideline.md
151
+ C:\development\treefolder\docs\readme.md
152
+ C:\development\treefolder\docs\tfold.jpg
153
+ C:\development\treefolder\eslint.config.mjs
154
+ C:\development\treefolder\jest.config.js
155
+ C:\development\treefolder\LICENSE
156
+ C:\development\treefolder\package.json
157
+ C:\development\treefolder\pnpm-lock.yaml
158
+ C:\development\treefolder\pnpm-workspace.yaml
159
+ C:\development\treefolder\README.md
160
+ C:\development\treefolder\src\
161
+ C:\development\treefolder\src\index.ts
162
+ C:\development\treefolder\tsconfig.json
163
+ ```
164
+
165
+ ### Colored list output &rarr; `--list --style colored`
166
+
167
+ In this use case, the list output highlights i.e. colors the _directoy_ items in _bright blue_.
168
+
169
+ There's no _preview_ of such a generated output at the moment, though.
170
+
99
171
  ## Sources &amp; stories
100
172
 
101
173
  ### From trees and leaves
@@ -113,4 +185,4 @@ treefolder
113
185
 
114
186
  ### Other topics
115
187
 
116
- - https://github.com/absolute-version/commit-and-tag-version
188
+ - <https://github.com/absolute-version/commit-and-tag-version>
package/package.json CHANGED
@@ -1,11 +1,16 @@
1
1
  {
2
2
  "name": "@khatastroffik/treefolder",
3
- "version": "1.0.0",
3
+ "version": "1.2.0",
4
4
  "devEngines": {
5
- "packageManager": {
6
- "name": "pnpm",
7
- "version": "10.28.2"
8
- }
5
+ "packageManager": [
6
+ {
7
+ "name": "pnpm",
8
+ "version": "10.28.2"
9
+ },
10
+ {
11
+ "name": "npm"
12
+ }
13
+ ]
9
14
  },
10
15
  "description": "A node.js CLI utility generating a tree representation (treeview) of a folder structure including its contained files and subfolders.",
11
16
  "author": "khatastroffik",