@shortcut-cli/shortcut-cli 3.4.0 → 3.6.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 +25 -0
- package/build/_virtual/rolldown_runtime.js +25 -0
- package/build/bin/short-api.js +78 -0
- package/build/bin/short-create.js +52 -573
- package/build/bin/short-epics.js +31 -160
- package/build/bin/short-find.js +4 -588
- package/build/bin/short-install.js +37 -135
- package/build/bin/short-members.js +28 -134
- package/build/bin/short-projects.js +28 -136
- package/build/bin/short-search.js +46 -597
- package/build/bin/short-story.js +201 -737
- package/build/bin/short-workflows.js +27 -133
- package/build/bin/short-workspace.js +62 -648
- package/build/bin/short.js +7 -33
- package/build/lib/client.js +10 -103
- package/build/lib/configure.js +93 -126
- package/build/lib/spinner.js +14 -31
- package/build/lib/stories.js +295 -462
- package/build/package.js +18 -0
- package/package.json +15 -15
|
@@ -1,140 +1,42 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
var __copyProps = (to, from, except, desc) => {
|
|
9
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
10
|
-
for (let key of __getOwnPropNames(from))
|
|
11
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
12
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
13
|
-
}
|
|
14
|
-
return to;
|
|
15
|
-
};
|
|
16
|
-
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
17
|
-
// If the importer is in node compatibility mode or this is not an ESM
|
|
18
|
-
// file that has been converted to a CommonJS file using a Babel-
|
|
19
|
-
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
20
|
-
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
21
|
-
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
22
|
-
mod
|
|
23
|
-
));
|
|
24
|
-
|
|
25
|
-
// src/bin/short-install.ts
|
|
26
|
-
var import_prompt = __toESM(require("prompt"));
|
|
27
|
-
var import_commander = __toESM(require("commander"));
|
|
28
|
-
var import_client = require("@shortcut/client");
|
|
2
|
+
const require_rolldown_runtime = require('../_virtual/rolldown_runtime.js');
|
|
3
|
+
const require_lib_configure = require('../lib/configure.js');
|
|
4
|
+
const require_package = require('../package.js');
|
|
5
|
+
const commander = require_rolldown_runtime.__toESM(require("commander"));
|
|
6
|
+
const __shortcut_client = require_rolldown_runtime.__toESM(require("@shortcut/client"));
|
|
7
|
+
const prompt = require_rolldown_runtime.__toESM(require("prompt"));
|
|
29
8
|
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
import_path.default.resolve(import_os.default.homedir(), ".clubhouse-cli")
|
|
43
|
-
];
|
|
44
|
-
var CONFIG_CACHE = null;
|
|
45
|
-
var loadCachedConfig = () => {
|
|
46
|
-
if (CONFIG_CACHE) {
|
|
47
|
-
return { ...CONFIG_CACHE };
|
|
48
|
-
}
|
|
49
|
-
let config = {};
|
|
50
|
-
const token = process.env.SHORTCUT_API_TOKEN || process.env.CLUBHOUSE_API_TOKEN;
|
|
51
|
-
legacyConfigDirs.forEach((dir) => {
|
|
52
|
-
if (import_fs.default.existsSync(dir)) {
|
|
53
|
-
createConfigDir();
|
|
54
|
-
import_fs.default.renameSync(dir, configDir);
|
|
55
|
-
}
|
|
56
|
-
});
|
|
57
|
-
if (import_fs.default.existsSync(configFile)) {
|
|
58
|
-
try {
|
|
59
|
-
config = JSON.parse(import_fs.default.readFileSync(configFile, "utf8"));
|
|
60
|
-
} catch (e) {
|
|
61
|
-
console.error(e);
|
|
62
|
-
process.exit(10);
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
if (token) {
|
|
66
|
-
config = { token, ...config };
|
|
67
|
-
}
|
|
68
|
-
CONFIG_CACHE = { ...config };
|
|
69
|
-
return config;
|
|
70
|
-
};
|
|
71
|
-
var createConfigDir = () => {
|
|
72
|
-
const dir = import_path.default.dirname(configDir);
|
|
73
|
-
if (!import_fs.default.existsSync(dir)) {
|
|
74
|
-
import_fs.default.mkdirSync(dir);
|
|
75
|
-
}
|
|
76
|
-
if (!import_fs.default.existsSync(configDir)) {
|
|
77
|
-
import_fs.default.mkdirSync(configDir);
|
|
78
|
-
}
|
|
9
|
+
//#region src/bin/short-install.ts
|
|
10
|
+
const extant = require_lib_configure.loadCachedConfig();
|
|
11
|
+
const log = console.log;
|
|
12
|
+
const program = commander.default.version(require_package.version).description("Install access token and other settings for the Shortcut API").option("-f, --force", "Force install/reinstall").option("-r, --refresh", "Refresh the configuration with details from Shortcut.").parse(process.argv);
|
|
13
|
+
const enrichConfigWithMemberDetails = async (config) => {
|
|
14
|
+
log("Fetching user/member details from Shortcut...");
|
|
15
|
+
const member = await new __shortcut_client.ShortcutClient(config.token).getCurrentMemberInfo().then((r) => r.data);
|
|
16
|
+
return {
|
|
17
|
+
mentionName: member.mention_name,
|
|
18
|
+
urlSlug: member.workspace2.url_slug,
|
|
19
|
+
...config
|
|
20
|
+
};
|
|
79
21
|
};
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
var version = "3.4.0";
|
|
98
|
-
|
|
99
|
-
// src/bin/short-install.ts
|
|
100
|
-
var extant = loadCachedConfig();
|
|
101
|
-
var log = console.log;
|
|
102
|
-
var program = import_commander.default.version(version).description("Install access token and other settings for the Shortcut API").option("-f, --force", "Force install/reinstall").option("-r, --refresh", "Refresh the configuration with details from Shortcut.").parse(process.argv);
|
|
103
|
-
var enrichConfigWithMemberDetails = async (config) => {
|
|
104
|
-
log("Fetching user/member details from Shortcut...");
|
|
105
|
-
const member = await new import_client.ShortcutClient(config.token).getCurrentMemberInfo().then((r) => r.data);
|
|
106
|
-
return {
|
|
107
|
-
mentionName: member.mention_name,
|
|
108
|
-
urlSlug: member.workspace2.url_slug,
|
|
109
|
-
...config
|
|
110
|
-
};
|
|
111
|
-
};
|
|
112
|
-
var main = async () => {
|
|
113
|
-
if (program.refresh) {
|
|
114
|
-
updateConfig(await enrichConfigWithMemberDetails(extant));
|
|
115
|
-
} else if (!extant.token || program.force) {
|
|
116
|
-
const schema = {
|
|
117
|
-
properties: {
|
|
118
|
-
token: {
|
|
119
|
-
message: "API Token -> https://app.shortcut.com/xxxx/settings/account/api-tokens",
|
|
120
|
-
required: true
|
|
121
|
-
}
|
|
122
|
-
}
|
|
123
|
-
};
|
|
124
|
-
import_prompt.default.start({ message: "Shortcut" });
|
|
125
|
-
import_prompt.default.get(schema, async (err, result) => {
|
|
126
|
-
if (err) return log(err);
|
|
127
|
-
const config = await enrichConfigWithMemberDetails(result);
|
|
128
|
-
log("Saving config...");
|
|
129
|
-
const success = updateConfig(config);
|
|
130
|
-
if (success) {
|
|
131
|
-
log("Saved config");
|
|
132
|
-
} else {
|
|
133
|
-
log("Error saving config");
|
|
134
|
-
}
|
|
135
|
-
});
|
|
136
|
-
} else if (extant.token) {
|
|
137
|
-
log("A configuration/token is already saved. To override, re-run with --force");
|
|
138
|
-
}
|
|
22
|
+
const main = async () => {
|
|
23
|
+
if (program.refresh) require_lib_configure.updateConfig(await enrichConfigWithMemberDetails(extant));
|
|
24
|
+
else if (!extant.token || program.force) {
|
|
25
|
+
const schema = { properties: { token: {
|
|
26
|
+
message: "API Token -> https://app.shortcut.com/xxxx/settings/account/api-tokens",
|
|
27
|
+
required: true
|
|
28
|
+
} } };
|
|
29
|
+
prompt.default.start({ message: "Shortcut" });
|
|
30
|
+
prompt.default.get(schema, async (err, result) => {
|
|
31
|
+
if (err) return log(err);
|
|
32
|
+
const config = await enrichConfigWithMemberDetails(result);
|
|
33
|
+
log("Saving config...");
|
|
34
|
+
const success = require_lib_configure.updateConfig(config);
|
|
35
|
+
if (success) log("Saved config");
|
|
36
|
+
else log("Error saving config");
|
|
37
|
+
});
|
|
38
|
+
} else if (extant.token) log("A configuration/token is already saved. To override, re-run with --force");
|
|
139
39
|
};
|
|
140
40
|
main();
|
|
41
|
+
|
|
42
|
+
//#endregion
|
|
@@ -1,139 +1,33 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
-
var __copyProps = (to, from, except, desc) => {
|
|
9
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
10
|
-
for (let key of __getOwnPropNames(from))
|
|
11
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
12
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
13
|
-
}
|
|
14
|
-
return to;
|
|
15
|
-
};
|
|
16
|
-
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
17
|
-
// If the importer is in node compatibility mode or this is not an ESM
|
|
18
|
-
// file that has been converted to a CommonJS file using a Babel-
|
|
19
|
-
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
20
|
-
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
21
|
-
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
22
|
-
mod
|
|
23
|
-
));
|
|
24
|
-
|
|
25
|
-
// src/bin/short-members.ts
|
|
26
|
-
var import_chalk = __toESM(require("chalk"));
|
|
27
|
-
var import_commander = __toESM(require("commander"));
|
|
28
|
-
|
|
29
|
-
// src/lib/client.ts
|
|
30
|
-
var import_client = require("@shortcut/client");
|
|
2
|
+
const require_rolldown_runtime = require('../_virtual/rolldown_runtime.js');
|
|
3
|
+
const require_lib_spinner = require('../lib/spinner.js');
|
|
4
|
+
const require_lib_client = require('../lib/client.js');
|
|
5
|
+
const commander = require_rolldown_runtime.__toESM(require("commander"));
|
|
6
|
+
const chalk = require_rolldown_runtime.__toESM(require("chalk"));
|
|
31
7
|
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
import_path.default.resolve(import_os.default.homedir(), ".clubhouse-cli")
|
|
45
|
-
];
|
|
46
|
-
var CONFIG_CACHE = null;
|
|
47
|
-
var loadConfig = () => {
|
|
48
|
-
const config2 = loadCachedConfig();
|
|
49
|
-
if (!config2 || config2 === {} || !config2.token) {
|
|
50
|
-
console.error("Please run 'short install' to configure Shortcut API access.");
|
|
51
|
-
process.exit(11);
|
|
52
|
-
}
|
|
53
|
-
if (!config2.urlSlug) {
|
|
54
|
-
console.error(
|
|
55
|
-
"Your config must be updated with data from Shortcut. Please run 'short install --refresh'."
|
|
56
|
-
);
|
|
57
|
-
process.exit(12);
|
|
58
|
-
}
|
|
59
|
-
return config2;
|
|
8
|
+
//#region src/bin/short-members.ts
|
|
9
|
+
const spin = require_lib_spinner.default("Loading... %s ");
|
|
10
|
+
const log = console.log;
|
|
11
|
+
const program = commander.default.description("Display members available for stories").option("-s, --search [query]", "List members with name containing query", "").option("-d, --disabled", "List members including disabled", "").parse(process.argv);
|
|
12
|
+
const main = async () => {
|
|
13
|
+
spin.start();
|
|
14
|
+
const members = await require_lib_client.default.listMembers(null).then((r) => r.data);
|
|
15
|
+
spin.stop(true);
|
|
16
|
+
const ownerMatch = new RegExp(program.search, "i");
|
|
17
|
+
members.filter((o) => {
|
|
18
|
+
return !!`${o.profile.name} ${o.profile.mention_name}`.match(ownerMatch);
|
|
19
|
+
}).map(printMember);
|
|
60
20
|
};
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
import_fs.default.renameSync(dir, configDir);
|
|
71
|
-
}
|
|
72
|
-
});
|
|
73
|
-
if (import_fs.default.existsSync(configFile)) {
|
|
74
|
-
try {
|
|
75
|
-
config2 = JSON.parse(import_fs.default.readFileSync(configFile, "utf8"));
|
|
76
|
-
} catch (e) {
|
|
77
|
-
console.error(e);
|
|
78
|
-
process.exit(10);
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
if (token) {
|
|
82
|
-
config2 = { token, ...config2 };
|
|
83
|
-
}
|
|
84
|
-
CONFIG_CACHE = { ...config2 };
|
|
85
|
-
return config2;
|
|
86
|
-
};
|
|
87
|
-
var createConfigDir = () => {
|
|
88
|
-
const dir = import_path.default.dirname(configDir);
|
|
89
|
-
if (!import_fs.default.existsSync(dir)) {
|
|
90
|
-
import_fs.default.mkdirSync(dir);
|
|
91
|
-
}
|
|
92
|
-
if (!import_fs.default.existsSync(configDir)) {
|
|
93
|
-
import_fs.default.mkdirSync(configDir);
|
|
94
|
-
}
|
|
95
|
-
};
|
|
96
|
-
|
|
97
|
-
// src/lib/client.ts
|
|
98
|
-
var config = loadConfig();
|
|
99
|
-
var client = new import_client.ShortcutClient(config.token);
|
|
100
|
-
var client_default = client;
|
|
101
|
-
|
|
102
|
-
// src/lib/spinner.ts
|
|
103
|
-
var import_cli_spinner = require("cli-spinner");
|
|
104
|
-
var spinner = (text = "") => {
|
|
105
|
-
const spin2 = new import_cli_spinner.Spinner({
|
|
106
|
-
text: text ? text : "Loading... %s ",
|
|
107
|
-
stream: process.stderr
|
|
108
|
-
});
|
|
109
|
-
spin2.setSpinnerString(27);
|
|
110
|
-
return spin2;
|
|
111
|
-
};
|
|
112
|
-
var spinner_default = spinner;
|
|
113
|
-
|
|
114
|
-
// src/bin/short-members.ts
|
|
115
|
-
var spin = spinner_default("Loading... %s ");
|
|
116
|
-
var log = console.log;
|
|
117
|
-
var program = import_commander.default.description("Display members available for stories").option("-s, --search [query]", "List members with name containing query", "").option("-d, --disabled", "List members including disabled", "").parse(process.argv);
|
|
118
|
-
var main = async () => {
|
|
119
|
-
spin.start();
|
|
120
|
-
const members = await client_default.listMembers(null).then((r) => r.data);
|
|
121
|
-
spin.stop(true);
|
|
122
|
-
const ownerMatch = new RegExp(program.search, "i");
|
|
123
|
-
members.filter((o) => {
|
|
124
|
-
return !!`${o.profile.name} ${o.profile.mention_name}`.match(ownerMatch);
|
|
125
|
-
}).map(printMember);
|
|
126
|
-
};
|
|
127
|
-
var printMember = (member) => {
|
|
128
|
-
if (member.disabled && !program.disabled) return;
|
|
129
|
-
log(import_chalk.default.bold(`#${member.id}`));
|
|
130
|
-
log(import_chalk.default.bold("Name: ") + ` ${member.profile.name}`);
|
|
131
|
-
log(import_chalk.default.bold("Mention Name: ") + ` ${member.profile.mention_name}`);
|
|
132
|
-
log(import_chalk.default.bold("Role: ") + ` ${member.role}`);
|
|
133
|
-
log(import_chalk.default.bold("Email: ") + ` ${member.profile.email_address}`);
|
|
134
|
-
if (member.disabled) {
|
|
135
|
-
log(import_chalk.default.bold("Disabled: ") + ` ${member.disabled}`);
|
|
136
|
-
}
|
|
137
|
-
log();
|
|
21
|
+
const printMember = (member) => {
|
|
22
|
+
if (member.disabled && !program.disabled) return;
|
|
23
|
+
log(chalk.default.bold(`#${member.id}`));
|
|
24
|
+
log(chalk.default.bold("Name: ") + ` ${member.profile.name}`);
|
|
25
|
+
log(chalk.default.bold("Mention Name: ") + ` ${member.profile.mention_name}`);
|
|
26
|
+
log(chalk.default.bold("Role: ") + ` ${member.role}`);
|
|
27
|
+
log(chalk.default.bold("Email: ") + ` ${member.profile.email_address}`);
|
|
28
|
+
if (member.disabled) log(chalk.default.bold("Disabled: ") + ` ${member.disabled}`);
|
|
29
|
+
log();
|
|
138
30
|
};
|
|
139
31
|
main();
|
|
32
|
+
|
|
33
|
+
//#endregion
|
|
@@ -1,141 +1,33 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
-
var __copyProps = (to, from, except, desc) => {
|
|
9
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
10
|
-
for (let key of __getOwnPropNames(from))
|
|
11
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
12
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
13
|
-
}
|
|
14
|
-
return to;
|
|
15
|
-
};
|
|
16
|
-
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
17
|
-
// If the importer is in node compatibility mode or this is not an ESM
|
|
18
|
-
// file that has been converted to a CommonJS file using a Babel-
|
|
19
|
-
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
20
|
-
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
21
|
-
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
22
|
-
mod
|
|
23
|
-
));
|
|
24
|
-
|
|
25
|
-
// src/bin/short-projects.ts
|
|
26
|
-
var import_commander = __toESM(require("commander"));
|
|
27
|
-
var import_chalk = __toESM(require("chalk"));
|
|
28
|
-
|
|
29
|
-
// src/lib/spinner.ts
|
|
30
|
-
var import_cli_spinner = require("cli-spinner");
|
|
31
|
-
var spinner = (text = "") => {
|
|
32
|
-
const spin2 = new import_cli_spinner.Spinner({
|
|
33
|
-
text: text ? text : "Loading... %s ",
|
|
34
|
-
stream: process.stderr
|
|
35
|
-
});
|
|
36
|
-
spin2.setSpinnerString(27);
|
|
37
|
-
return spin2;
|
|
38
|
-
};
|
|
39
|
-
var spinner_default = spinner;
|
|
40
|
-
|
|
41
|
-
// src/lib/client.ts
|
|
42
|
-
var import_client = require("@shortcut/client");
|
|
2
|
+
const require_rolldown_runtime = require('../_virtual/rolldown_runtime.js');
|
|
3
|
+
const require_lib_spinner = require('../lib/spinner.js');
|
|
4
|
+
const require_lib_client = require('../lib/client.js');
|
|
5
|
+
const commander = require_rolldown_runtime.__toESM(require("commander"));
|
|
6
|
+
const chalk = require_rolldown_runtime.__toESM(require("chalk"));
|
|
43
7
|
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
import_path.default.resolve(import_os.default.homedir(), ".clubhouse-cli")
|
|
57
|
-
];
|
|
58
|
-
var CONFIG_CACHE = null;
|
|
59
|
-
var loadConfig = () => {
|
|
60
|
-
const config2 = loadCachedConfig();
|
|
61
|
-
if (!config2 || config2 === {} || !config2.token) {
|
|
62
|
-
console.error("Please run 'short install' to configure Shortcut API access.");
|
|
63
|
-
process.exit(11);
|
|
64
|
-
}
|
|
65
|
-
if (!config2.urlSlug) {
|
|
66
|
-
console.error(
|
|
67
|
-
"Your config must be updated with data from Shortcut. Please run 'short install --refresh'."
|
|
68
|
-
);
|
|
69
|
-
process.exit(12);
|
|
70
|
-
}
|
|
71
|
-
return config2;
|
|
72
|
-
};
|
|
73
|
-
var loadCachedConfig = () => {
|
|
74
|
-
if (CONFIG_CACHE) {
|
|
75
|
-
return { ...CONFIG_CACHE };
|
|
76
|
-
}
|
|
77
|
-
let config2 = {};
|
|
78
|
-
const token = process.env.SHORTCUT_API_TOKEN || process.env.CLUBHOUSE_API_TOKEN;
|
|
79
|
-
legacyConfigDirs.forEach((dir) => {
|
|
80
|
-
if (import_fs.default.existsSync(dir)) {
|
|
81
|
-
createConfigDir();
|
|
82
|
-
import_fs.default.renameSync(dir, configDir);
|
|
83
|
-
}
|
|
84
|
-
});
|
|
85
|
-
if (import_fs.default.existsSync(configFile)) {
|
|
86
|
-
try {
|
|
87
|
-
config2 = JSON.parse(import_fs.default.readFileSync(configFile, "utf8"));
|
|
88
|
-
} catch (e) {
|
|
89
|
-
console.error(e);
|
|
90
|
-
process.exit(10);
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
if (token) {
|
|
94
|
-
config2 = { token, ...config2 };
|
|
95
|
-
}
|
|
96
|
-
CONFIG_CACHE = { ...config2 };
|
|
97
|
-
return config2;
|
|
8
|
+
//#region src/bin/short-projects.ts
|
|
9
|
+
const spin = require_lib_spinner.default();
|
|
10
|
+
const log = console.log;
|
|
11
|
+
const program = commander.default.description("Display projects available for stories").option("-a, --archived", "List only projects including archived", "").option("-d, --detailed", "List more details for each project", "").option("-t, --title [query]", "List projects with name/title containing query", "").parse(process.argv);
|
|
12
|
+
const main = async () => {
|
|
13
|
+
spin.start();
|
|
14
|
+
const projects = await require_lib_client.default.listProjects().then((r) => r.data);
|
|
15
|
+
spin.stop(true);
|
|
16
|
+
const textMatch = new RegExp(program.title, "i");
|
|
17
|
+
projects.filter((o) => {
|
|
18
|
+
return !!`${o.name} ${o.name}`.match(textMatch);
|
|
19
|
+
}).map(printItem);
|
|
98
20
|
};
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
// src/lib/client.ts
|
|
110
|
-
var config = loadConfig();
|
|
111
|
-
var client = new import_client.ShortcutClient(config.token);
|
|
112
|
-
var client_default = client;
|
|
113
|
-
|
|
114
|
-
// src/bin/short-projects.ts
|
|
115
|
-
var spin = spinner_default();
|
|
116
|
-
var log = console.log;
|
|
117
|
-
var program = import_commander.default.description("Display projects available for stories").option("-a, --archived", "List only projects including archived", "").option("-d, --detailed", "List more details for each project", "").option("-t, --title [query]", "List projects with name/title containing query", "").parse(process.argv);
|
|
118
|
-
var main = async () => {
|
|
119
|
-
spin.start();
|
|
120
|
-
const projects = await client_default.listProjects().then((r) => r.data);
|
|
121
|
-
spin.stop(true);
|
|
122
|
-
const textMatch = new RegExp(program.title, "i");
|
|
123
|
-
projects.filter((o) => {
|
|
124
|
-
return !!`${o.name} ${o.name}`.match(textMatch);
|
|
125
|
-
}).map(printItem);
|
|
126
|
-
};
|
|
127
|
-
var printItem = (proj) => {
|
|
128
|
-
if (proj.archived && !program.archived) return;
|
|
129
|
-
log(import_chalk.default.bold(`#${proj.id}`) + import_chalk.default.blue(` ${proj.name}`));
|
|
130
|
-
log(import_chalk.default.bold("Points: ") + ` ${proj.stats.num_points}`);
|
|
131
|
-
log(import_chalk.default.bold("Stories: ") + ` ${proj.stats.num_stories}`);
|
|
132
|
-
log(import_chalk.default.bold("Started: ") + ` ${proj.start_time}`);
|
|
133
|
-
if (proj.archived) {
|
|
134
|
-
log(import_chalk.default.bold("Archived: ") + ` ${proj.archived}`);
|
|
135
|
-
}
|
|
136
|
-
if (program.detailed) {
|
|
137
|
-
log(import_chalk.default.bold("Description: ") + ` ${proj.description}`);
|
|
138
|
-
}
|
|
139
|
-
log();
|
|
21
|
+
const printItem = (proj) => {
|
|
22
|
+
if (proj.archived && !program.archived) return;
|
|
23
|
+
log(chalk.default.bold(`#${proj.id}`) + chalk.default.blue(` ${proj.name}`));
|
|
24
|
+
log(chalk.default.bold("Points: ") + ` ${proj.stats.num_points}`);
|
|
25
|
+
log(chalk.default.bold("Stories: ") + ` ${proj.stats.num_stories}`);
|
|
26
|
+
log(chalk.default.bold("Started: ") + ` ${proj.start_time}`);
|
|
27
|
+
if (proj.archived) log(chalk.default.bold("Archived: ") + ` ${proj.archived}`);
|
|
28
|
+
if (program.detailed) log(chalk.default.bold("Description: ") + ` ${proj.description}`);
|
|
29
|
+
log();
|
|
140
30
|
};
|
|
141
31
|
main();
|
|
32
|
+
|
|
33
|
+
//#endregion
|