@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.
@@ -1,140 +1,42 @@
1
1
  #!/usr/bin/env node
2
- var __create = Object.create;
3
- var __defProp = Object.defineProperty;
4
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
- var __getOwnPropNames = Object.getOwnPropertyNames;
6
- var __getProtoOf = Object.getPrototypeOf;
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-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
- // src/lib/configure.ts
31
- var import_path = __toESM(require("path"));
32
- var import_fs = __toESM(require("fs"));
33
- var import_os = __toESM(require("os"));
34
- function getConfigDir(suffix) {
35
- const configBaseDir = process.env.XDG_CONFIG_HOME || import_path.default.resolve(process.env.XDG_DATA_HOME || import_os.default.homedir(), ".config");
36
- return import_path.default.resolve(configBaseDir, suffix);
37
- }
38
- var configDir = getConfigDir("shortcut-cli");
39
- var configFile = import_path.default.resolve(configDir, "config.json");
40
- var legacyConfigDirs = [
41
- getConfigDir("clubhouse-cli"),
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
- var saveConfig = (config) => {
81
- try {
82
- createConfigDir();
83
- import_fs.default.writeFileSync(configFile, JSON.stringify(config), { flag: "w" });
84
- CONFIG_CACHE = { ...config };
85
- return true;
86
- } catch (e) {
87
- console.error(e);
88
- return false;
89
- }
90
- };
91
- var updateConfig = (newConfig) => {
92
- const extantConfig = loadCachedConfig() || {};
93
- return saveConfig({ ...newConfig, ...extantConfig });
94
- };
95
-
96
- // package.json
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
- var __create = Object.create;
3
- var __defProp = Object.defineProperty;
4
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
- var __getOwnPropNames = Object.getOwnPropertyNames;
6
- var __getProtoOf = Object.getPrototypeOf;
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
- // src/lib/configure.ts
33
- var import_path = __toESM(require("path"));
34
- var import_fs = __toESM(require("fs"));
35
- var import_os = __toESM(require("os"));
36
- function getConfigDir(suffix) {
37
- const configBaseDir = process.env.XDG_CONFIG_HOME || import_path.default.resolve(process.env.XDG_DATA_HOME || import_os.default.homedir(), ".config");
38
- return import_path.default.resolve(configBaseDir, suffix);
39
- }
40
- var configDir = getConfigDir("shortcut-cli");
41
- var configFile = import_path.default.resolve(configDir, "config.json");
42
- var legacyConfigDirs = [
43
- getConfigDir("clubhouse-cli"),
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
- var loadCachedConfig = () => {
62
- if (CONFIG_CACHE) {
63
- return { ...CONFIG_CACHE };
64
- }
65
- let config2 = {};
66
- const token = process.env.SHORTCUT_API_TOKEN || process.env.CLUBHOUSE_API_TOKEN;
67
- legacyConfigDirs.forEach((dir) => {
68
- if (import_fs.default.existsSync(dir)) {
69
- createConfigDir();
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
- var __create = Object.create;
3
- var __defProp = Object.defineProperty;
4
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
- var __getOwnPropNames = Object.getOwnPropertyNames;
6
- var __getProtoOf = Object.getPrototypeOf;
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
- // src/lib/configure.ts
45
- var import_path = __toESM(require("path"));
46
- var import_fs = __toESM(require("fs"));
47
- var import_os = __toESM(require("os"));
48
- function getConfigDir(suffix) {
49
- const configBaseDir = process.env.XDG_CONFIG_HOME || import_path.default.resolve(process.env.XDG_DATA_HOME || import_os.default.homedir(), ".config");
50
- return import_path.default.resolve(configBaseDir, suffix);
51
- }
52
- var configDir = getConfigDir("shortcut-cli");
53
- var configFile = import_path.default.resolve(configDir, "config.json");
54
- var legacyConfigDirs = [
55
- getConfigDir("clubhouse-cli"),
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
- var createConfigDir = () => {
100
- const dir = import_path.default.dirname(configDir);
101
- if (!import_fs.default.existsSync(dir)) {
102
- import_fs.default.mkdirSync(dir);
103
- }
104
- if (!import_fs.default.existsSync(configDir)) {
105
- import_fs.default.mkdirSync(configDir);
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