json-crud-ui-components 1.6.2 → 1.7.2

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.
Files changed (79) hide show
  1. package/bin/v7/commands/init/steps/checks.js +21 -0
  2. package/bin/v7/commands/init/steps/resolveFolderName.js +14 -0
  3. package/bin/v7/commands/init.js +75 -0
  4. package/package.json +1 -1
  5. package/bin/v5/commands/init.js +0 -25
  6. package/bin/v5/commands/initJs/steps/checks.js +0 -23
  7. package/bin/v5/commands/initJs/steps/resolveFolderName.js +0 -17
  8. package/bin/v5/commands/initJs/template/v3/FormLoad/DomContentLoaded/buildHeader.js +0 -58
  9. package/bin/v5/commands/initJs/template/v3/FormLoad/DomContentLoaded/buildMenuItem.js +0 -121
  10. package/bin/v5/commands/initJs/template/v3/FormLoad/DomContentLoaded/runAfterDomLoad.js +0 -7
  11. package/bin/v5/commands/initJs/template/v3/FormLoad/DomContentLoaded/start.js +0 -7
  12. package/bin/v5/commands/initJs/template/v3/FormLoad/start.js +0 -5
  13. package/bin/v5/commands/initJs/template/v3/headers.json +0 -45
  14. package/bin/v5/commands/initJs/template/v3/start.js +0 -7
  15. /package/bin/{v5 → v7}/commands/addListeners/steps/announce.js +0 -0
  16. /package/bin/{v5 → v7}/commands/addListeners/steps/checks.js +0 -0
  17. /package/bin/{v5 → v7}/commands/addListeners/steps/createProject.js +0 -0
  18. /package/bin/{v5 → v7}/commands/addListeners/steps/locateDestination.js +0 -0
  19. /package/bin/{v5 → v7}/commands/addListeners/steps/locateSource.js +0 -0
  20. /package/bin/{v5 → v7}/commands/addListeners/steps/resolveFolderName.js +0 -0
  21. /package/bin/{v5 → v7}/commands/addListeners/template/v2/hookAllListeners.js +0 -0
  22. /package/bin/{v5 → v7}/commands/addListeners.js +0 -0
  23. /package/bin/{v5 → v7}/commands/buildHeader/steps/announce.js +0 -0
  24. /package/bin/{v5 → v7}/commands/buildHeader/steps/createProject.js +0 -0
  25. /package/bin/{v5 → v7}/commands/buildHeader/steps/locateDestination.js +0 -0
  26. /package/bin/{v5 → v7}/commands/buildHeader/steps/locateSource.js +0 -0
  27. /package/bin/{v5 → v7}/commands/buildHeader/steps/resolveFolderName.js +0 -0
  28. /package/bin/{v5 → v7}/commands/buildHeader/template/v1/buildHeader.js +0 -0
  29. /package/bin/{v5 → v7}/commands/buildHeader.js +0 -0
  30. /package/bin/{v5 → v7}/commands/htmlIdClick/steps/announce.js +0 -0
  31. /package/bin/{v5 → v7}/commands/htmlIdClick/steps/checks.js +0 -0
  32. /package/bin/{v5 → v7}/commands/htmlIdClick/steps/createProject.js +0 -0
  33. /package/bin/{v5 → v7}/commands/htmlIdClick/steps/locateDestination.js +0 -0
  34. /package/bin/{v5 → v7}/commands/htmlIdClick/steps/locateSource.js +0 -0
  35. /package/bin/{v5 → v7}/commands/htmlIdClick/steps/resolveFolderName.js +0 -0
  36. /package/bin/{v5 → v7}/commands/htmlIdClick/template/v1/clickFunc.js +0 -0
  37. /package/bin/{v5 → v7}/commands/htmlIdClick/template/v1/start.js +0 -0
  38. /package/bin/{v5 → v7}/commands/htmlIdClick.js +0 -0
  39. /package/bin/{v5 → v7}/commands/init/steps/announce.js +0 -0
  40. /package/bin/{v5 → v7}/commands/init/steps/createProject.js +0 -0
  41. /package/bin/{v5 → v7}/commands/init/steps/locateDestination.js +0 -0
  42. /package/bin/{v5 → v7}/commands/init/steps/locateSource.js +0 -0
  43. /package/bin/{v5/commands/init/template/v3 → v7/commands/init/template/v5/Index}/FormLoad/DomContentLoaded/buildHeader.js +0 -0
  44. /package/bin/{v5/commands/init/template/v3 → v7/commands/init/template/v5/Index}/FormLoad/DomContentLoaded/buildMenuItem.js +0 -0
  45. /package/bin/{v5/commands/init/template/v3 → v7/commands/init/template/v5/Index}/FormLoad/DomContentLoaded/runAfterDomLoad.js +0 -0
  46. /package/bin/{v5/commands/init/template/v3 → v7/commands/init/template/v5/Index}/FormLoad/DomContentLoaded/start.js +0 -0
  47. /package/bin/{v5/commands/init/template/v3 → v7/commands/init/template/v5/Index}/FormLoad/start.js +0 -0
  48. /package/bin/{v5/commands/init/template/v3 → v7/commands/init/template/v5/Index}/headers.json +0 -0
  49. /package/bin/{v5/commands/init/template/v3 → v7/commands/init/template/v5/Index}/start.js +0 -0
  50. /package/bin/{v5/commands/init/template/v4 → v7/commands/init/template/v5}/index.html +0 -0
  51. /package/bin/{v5/commands/init/template/v4 → v7/commands/init/template/v5}/tailwindcss-3.4.17.css +0 -0
  52. /package/bin/{v5 → v7}/commands/initHtml/steps/announce.js +0 -0
  53. /package/bin/{v5 → v7}/commands/initHtml/steps/checks.js +0 -0
  54. /package/bin/{v5 → v7}/commands/initHtml/steps/createProject.js +0 -0
  55. /package/bin/{v5 → v7}/commands/initHtml/steps/locateDestination.js +0 -0
  56. /package/bin/{v5 → v7}/commands/initHtml/steps/locateSource.js +0 -0
  57. /package/bin/{v5/commands/init → v7/commands/initHtml}/steps/resolveFolderName.js +0 -0
  58. /package/bin/{v5/commands/initHtml/template/v4 → v7/commands/initHtml/template/v5}/index.html +0 -0
  59. /package/bin/{v5/commands/initHtml/template/v4 → v7/commands/initHtml/template/v5}/tailwindcss-3.4.17.css +0 -0
  60. /package/bin/{v5 → v7}/commands/initHtml.js +0 -0
  61. /package/bin/{v5 → v7}/commands/initJs/steps/announce.js +0 -0
  62. /package/bin/{v5/commands/init → v7/commands/initJs}/steps/checks.js +0 -0
  63. /package/bin/{v5 → v7}/commands/initJs/steps/createProject.js +0 -0
  64. /package/bin/{v5 → v7}/commands/initJs/steps/locateDestination.js +0 -0
  65. /package/bin/{v5 → v7}/commands/initJs/steps/locateSource.js +0 -0
  66. /package/bin/{v5/commands/initHtml → v7/commands/initJs}/steps/resolveFolderName.js +0 -0
  67. /package/bin/{v5/commands/initHtml/template/v3 → v7/commands/initJs/template/v4}/FormLoad/DomContentLoaded/buildHeader.js +0 -0
  68. /package/bin/{v5/commands/initHtml/template/v3 → v7/commands/initJs/template/v4}/FormLoad/DomContentLoaded/buildMenuItem.js +0 -0
  69. /package/bin/{v5/commands/initHtml/template/v3 → v7/commands/initJs/template/v4}/FormLoad/DomContentLoaded/runAfterDomLoad.js +0 -0
  70. /package/bin/{v5/commands/initHtml/template/v3 → v7/commands/initJs/template/v4}/FormLoad/DomContentLoaded/start.js +0 -0
  71. /package/bin/{v5/commands/initHtml/template/v3 → v7/commands/initJs/template/v4}/FormLoad/start.js +0 -0
  72. /package/bin/{v5/commands/initHtml/template/v3 → v7/commands/initJs/template/v4}/headers.json +0 -0
  73. /package/bin/{v5/commands/initHtml/template/v3 → v7/commands/initJs/template/v4}/start.js +0 -0
  74. /package/bin/{v5 → v7}/commands/initJs.js +0 -0
  75. /package/bin/{v5 → v7}/core/getAllVersions.js +0 -0
  76. /package/bin/{v5 → v7}/core/parseInput.js +0 -0
  77. /package/bin/{v5 → v7}/core/resolveCommand.js +0 -0
  78. /package/bin/{v5 → v7}/core/showUsage.js +0 -0
  79. /package/bin/{v5 → v7}/start.js +0 -0
@@ -0,0 +1,21 @@
1
+ import fs from "fs";
2
+ import path from "path";
3
+
4
+ const validate = ({ toPath, inFolderName }) => {
5
+ const fullPath = path.join(toPath, inFolderName);
6
+
7
+ if (!fs.existsSync(fullPath)) {
8
+ return false;
9
+ };
10
+
11
+ const files = fs.readdirSync(fullPath);
12
+
13
+ if (files.length > 0) {
14
+ console.log("Folder should be empty");
15
+ return true;
16
+ };
17
+
18
+ return false;
19
+ };
20
+
21
+ export default validate;
@@ -0,0 +1,14 @@
1
+ import fs from "fs";
2
+
3
+ export default function resolveFolderName({ name, defaultFolerName = "IndexV1" }) {
4
+ if (name === null) {
5
+ name = defaultFolerName;
6
+ };
7
+
8
+ // case 2: user provided → strict
9
+ if (fs.existsSync(name)) {
10
+ throw new Error(`Folder already exists: ${name}`);
11
+ };
12
+
13
+ return name;
14
+ };
@@ -0,0 +1,75 @@
1
+ import { locateSource } from "./init/steps/locateSource.js";
2
+ import { locateDestination } from "./init/steps/locateDestination.js";
3
+
4
+ import { createProject } from "./init/steps/createProject.js";
5
+ import { announce } from "./init/steps/announce.js";
6
+
7
+ import resolveFolderName from "./init/steps/resolveFolderName.js";
8
+ import checks from "./init/steps/checks.js";
9
+
10
+ export default ({
11
+ folderName = "",
12
+ toPath = process.cwd(),
13
+ inAnnounce = true,
14
+ showLog = false
15
+ }) => {
16
+ if (showLog) {
17
+ console.log("Resolving folder name...");
18
+ };
19
+
20
+ const resolvedFolderName = resolveFolderName({
21
+ name: folderName
22
+ });
23
+
24
+ if (showLog) {
25
+ console.log(`resolvedFolderName : ${resolvedFolderName}`);
26
+ };
27
+
28
+ const fromChecks = checks({
29
+ toPath,
30
+ inAnnounce,
31
+ inFolderName: resolvedFolderName,
32
+ showLog
33
+ });
34
+
35
+ if (fromChecks) return false;
36
+
37
+ if (showLog) {
38
+ console.log("Locating source...");
39
+ }
40
+
41
+ const source = locateSource({
42
+ showLog
43
+ });
44
+
45
+ if (showLog) {
46
+ console.log("Locating destination...");
47
+ }
48
+
49
+ const destination = locateDestination({
50
+ inResolvedFolderName: resolvedFolderName,
51
+ showLog
52
+ });
53
+
54
+ if (showLog) {
55
+ console.log("Creating project...");
56
+ }
57
+
58
+ createProject({
59
+ source,
60
+ destination,
61
+ showLog
62
+ });
63
+
64
+ if (inAnnounce) {
65
+
66
+ if (showLog) {
67
+ console.log("Announcing...");
68
+ }
69
+
70
+ announce({
71
+ inResolvedFolderName: resolvedFolderName,
72
+ showLog
73
+ });
74
+ }
75
+ };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "json-crud-ui-components",
3
- "version": "1.6.2",
3
+ "version": "1.7.2",
4
4
  "description": "working on ui for our json crud using modules",
5
5
  "keywords": [
6
6
  "cli",
@@ -1,25 +0,0 @@
1
- import { locateSource } from "./init/steps/locateSource.js";
2
- import { locateDestination } from "./init/steps/locateDestination.js";
3
-
4
- import { createProject } from "./init/steps/createProject.js";
5
- import { announce } from "./init/steps/announce.js";
6
-
7
- import resolveFolderName from "./init/steps/resolveFolderName.js";
8
- import checks from "./init/steps/checks.js";
9
-
10
- export default ({ folderName = "", toPath = process.cwd(), inAnnounce = true }) => {
11
- const fromChecks = checks({ toPath, inAnnounce });
12
-
13
- if (fromChecks) return false;
14
-
15
- const resolvedFolderName = resolveFolderName({
16
- name: folderName
17
- });
18
-
19
- const source = locateSource();
20
- const destination = locateDestination({ inResolvedFolderName: resolvedFolderName });
21
-
22
- createProject({ source, destination });
23
-
24
- if (inAnnounce) announce({ inResolvedFolderName: resolvedFolderName });
25
- };
@@ -1,23 +0,0 @@
1
- import path from "path";
2
- import fs from "fs";
3
-
4
- const validate = ({ toPath }) => {
5
- const htmlPath = path.join(toPath, "index.html");
6
- const indexPath = path.join(toPath, "index");
7
-
8
- if (!fs.existsSync(htmlPath)) {
9
- console.log("index.html not found");
10
-
11
- return true;
12
- };
13
-
14
- if (fs.existsSync(indexPath)) {
15
- console.log("index folder found");
16
-
17
- return true;
18
- };
19
-
20
- return false;
21
- };
22
-
23
- export default validate;
@@ -1,17 +0,0 @@
1
- import fs from "fs";
2
-
3
- export default function resolveFolderName({ name, inType = "basic" }) {
4
- const defaultFolerName = "Index";
5
-
6
- // case 1: force new → timestamp
7
- if (name === null) {
8
- name = defaultFolerName;
9
- };
10
-
11
- // case 2: user provided → strict
12
- if (fs.existsSync(name)) {
13
- throw new Error(`Folder already exists: ${name}`);
14
- };
15
-
16
- return name;
17
- };
@@ -1,58 +0,0 @@
1
- import { initHeader } from "../../../../../../header/v6/initHeader.js";
2
-
3
- const buildHeader = async () => {
4
- const headerConfig1 = {
5
- items: [
6
- {
7
- text: "ShowAll",
8
- id: "ShowAllHtmlId",
9
- icon: [
10
- "M4 6h16",
11
- "M4 10h16",
12
- "M4 14h10",
13
- "M6 4h12a2 2 0 012 2v12a2 2 0 01-2 2H6a2 2 0 01-2-2V6a2 2 0 012-2z"
14
- ]
15
- },
16
- {
17
- text: "StockItems",
18
- id: "StockItemsHtmlId",
19
- icon: [
20
- "M3 7l9 4 9-4",
21
- "M3 7l9-4 9 4",
22
- "M3 7v10l9 4 9-4V7",
23
- "M12 11v10"
24
- ]
25
- },
26
- {
27
- text: "Transactions",
28
- id: "1",
29
- icon: [
30
-
31
- "M6 2h9l5 5v15a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2z",
32
- "M14 2v6h6",
33
- "M8 12h8",
34
- "M8 16h8"
35
- ],
36
- href: "../../Transactions/V7/Create/index.html"
37
- },
38
- {
39
- text: "FromTally",
40
- id: "ImportHtmlId",
41
- icon: [
42
- "M4 6h16",
43
- "M4 10h16",
44
- "M4 14h10",
45
- "M6 4h12a2 2 0 012 2v12a2 2 0 01-2 2H6a2 2 0 01-2-2V6a2 2 0 012-2z"
46
- ]
47
- }
48
- ]
49
- };
50
-
51
- const fromFetch = await fetch("./Index/headers.json");
52
- const headerConfig = await fromFetch.json();
53
-
54
- await initHeader(headerConfig);
55
- // callKSHeader(headerConfig).then();
56
- };
57
-
58
- export { buildHeader };
@@ -1,121 +0,0 @@
1
- // orchestrator
2
- export const buildMenuItem = ({
3
- inTextToShow,
4
- inHtmlId,
5
- inIconPaths,
6
- inHref
7
- }) => {
8
- const textToShow = inTextToShow;
9
- const htmlId = inHtmlId;
10
- const iconPaths = inIconPaths;
11
-
12
- const li = createLi();
13
- const a = createAnchor({ inHtmlId: htmlId, inHref });
14
- const span = createLabel({ inTextToShow: textToShow });
15
- const svg = createIcon({ inIconPaths: iconPaths });
16
-
17
- a.append(svg, span);
18
- li.appendChild(a);
19
-
20
- return li;
21
- };
22
-
23
- const createLi = () => {
24
- const htmlLi = document.createElement("li");
25
-
26
- htmlLi.className = "md:text-center";
27
-
28
- return htmlLi;
29
-
30
-
31
- };
32
-
33
- // createAnchor
34
- const createAnchor = ({ inHtmlId = "htmlId",
35
- inHref = "#"
36
- }) => {
37
- const a = document.createElement("a");
38
- a.id = inHtmlId;
39
- a.href = inHref;
40
- // a.className =
41
- // "group flex items-center md:flex-col md:items-center gap-0 md:gap-1 cursor-pointer hover:bg-gray-700 px-2 py-1 rounded transition-colors duration-200 active:scale-95 focus:outline-none focus:ring-2 focus:ring-gray-500";
42
-
43
- a.className = `flex justify-between items-center bg-gray-700 px-4 py-2 rounded-md
44
- hover:bg-gray-600 active:bg-gray-500 active:scale-95
45
- transition-all duration-150
46
- md:flex-col md:justify-center md:items-center
47
- lg:bg-transparent lg:px-2 lg:py-1`;
48
-
49
- return a;
50
- };
51
-
52
- // createLabel (no transform → no height change)
53
- const createLabel = ({ inTextToShow = "Menu1" }) => {
54
- const span = document.createElement("span");
55
- span.className =
56
- "ml-3 text-right w-full text-base md:w-auto md:text-center md:ml-0 lg:text-lg";
57
-
58
- span.textContent = inTextToShow;
59
-
60
- return span;
61
- };
62
-
63
- // createIcon (safe transform: no layout shift)
64
- const createIcon = ({ inIconPaths = [] }) => {
65
- const svg = document.createElementNS("http://www.w3.org/2000/svg", "svg");
66
- // svg.setAttribute(
67
- // "class",
68
- // "w-6 h-6 md:order-1 md:mb-0 text-gray-400 group-hover:text-white transition-all duration-200 transform group-hover:scale-95 group-hover:-translate-y-0.5"
69
- // );
70
-
71
-
72
- svg.setAttribute(
73
- "class",
74
- "text-gray-300 w-6 h-6 lg:w-7 lg:h-7"
75
- );
76
-
77
-
78
- // <svg class="text-gray-300 w-6 h-6 lg:w-7 lg:h-7" fill="none" stroke="currentColor"
79
-
80
-
81
- svg.setAttribute("fill", "none");
82
- svg.setAttribute("stroke", "currentColor");
83
- svg.setAttribute("viewBox", "0 0 24 24");
84
- svg.setAttribute("stroke-width", "1.5");
85
- svg.setAttribute("stroke-linecap", "round");
86
- svg.setAttribute("stroke-linejoin", "round");
87
-
88
- inIconPaths.forEach(d => {
89
- const path = document.createElementNS("http://www.w3.org/2000/svg", "path");
90
- path.setAttribute("d", d);
91
- svg.appendChild(path);
92
- });
93
-
94
- return svg;
95
- };
96
-
97
-
98
-
99
- // <li class="md:text-center">
100
- // <a id="LedgersHtmlId"
101
- // href="#" class="flex justify-between items-center bg-gray-700 px-4 py-2 rounded-md
102
- // hover:bg-gray-600 active:bg-gray-500 active:scale-95
103
- // transition-all duration-150
104
- // md:flex-col md:justify-center md:items-center
105
- // lg:bg-transparent lg:px-2 lg:py-1">
106
-
107
- // <!-- LEFT: ICON -->
108
- // <svg class="text-gray-300 w-6 h-6 lg:w-7 lg:h-7" fill="none" stroke="currentColor"
109
- // viewBox="0 0 24 24">
110
- // <path
111
- // d="M4 6h16M4 10h16M4 14h10M6 4h12a2 2 0 012 2v12a2 2 0 01-2 2H6a2 2 0 01-2-2V6a2 2 0 012-2z" />
112
- // </svg>
113
-
114
- // <!-- RIGHT: LABEL -->
115
- // <span class="ml-3 text-right w-full text-base
116
- // md:w-auto md:text-center md:ml-0
117
- // lg:text-lg
118
- // ">Ledgers</span>
119
-
120
- // </a>
121
- // </li>
@@ -1,7 +0,0 @@
1
- import { buildHeader } from "./buildHeader.js";
2
-
3
- const runAfterDomLoad = () => {
4
- buildHeader().then();
5
- };
6
-
7
- export { runAfterDomLoad };
@@ -1,7 +0,0 @@
1
- import { runAfterDomLoad } from "./runAfterDomLoad.js";
2
-
3
- export function startDomContentLoaded() {
4
- document.addEventListener("DOMContentLoaded", () => {
5
- runAfterDomLoad();
6
- });
7
- }
@@ -1,5 +0,0 @@
1
- import { startDomContentLoaded } from "./DomContentLoaded/start.js";
2
-
3
- export function startFormLoad() {
4
- startDomContentLoaded();
5
- }
@@ -1,45 +0,0 @@
1
- {
2
- "items": [
3
- {
4
- "text": "ShowAll",
5
- "id": "ShowAllHtmlId",
6
- "icon": [
7
- "M4 6h16",
8
- "M4 10h16",
9
- "M4 14h10",
10
- "M6 4h12a2 2 0 012 2v12a2 2 0 01-2 2H6a2 2 0 01-2-2V6a2 2 0 012-2z"
11
- ]
12
- },
13
- {
14
- "text": "Search",
15
- "id": "SearchHtmlId",
16
- "icon": [
17
- "M3 7l9 4 9-4",
18
- "M3 7l9-4 9 4",
19
- "M3 7v10l9 4 9-4V7",
20
- "M12 11v10"
21
- ]
22
- },
23
- {
24
- "text": "Transactions",
25
- "id": "1",
26
- "icon": [
27
- "M6 2h9l5 5v15a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2z",
28
- "M14 2v6h6",
29
- "M8 12h8",
30
- "M8 16h8"
31
- ],
32
- "href": "../../Transactions/V7/Create/index.html"
33
- },
34
- {
35
- "text": "FromTally",
36
- "id": "ImportHtmlId",
37
- "icon": [
38
- "M4 6h16",
39
- "M4 10h16",
40
- "M4 14h10",
41
- "M6 4h12a2 2 0 012 2v12a2 2 0 01-2 2H6a2 2 0 01-2-2V6a2 2 0 012-2z"
42
- ]
43
- }
44
- ]
45
- }
@@ -1,7 +0,0 @@
1
- import { startFormLoad } from "./FormLoad/start.js";
2
-
3
- function startApp() {
4
- startFormLoad();
5
- };
6
-
7
- startApp();
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes