@oh-gc/cli 0.4.2 → 0.4.3
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 +2 -0
- package/dist/api/prs.d.ts +8 -3
- package/dist/api/prs.js +7 -2
- package/dist/api/prs.js.map +1 -1
- package/dist/commands/pr/comment.d.ts +3 -0
- package/dist/commands/pr/comment.js +19 -4
- package/dist/commands/pr/comment.js.map +1 -1
- package/dist/commands/pr/create.js +4 -1
- package/dist/commands/pr/create.js.map +1 -1
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -101,6 +101,8 @@ oh-gc repo:set-remote upstream
|
|
|
101
101
|
| `oh-gc pr:create --repo owner/repo --head feature` | Create cross-repo PR |
|
|
102
102
|
| `oh-gc pr:comment <number>` | Add a comment interactively |
|
|
103
103
|
| `oh-gc pr:comment <number> --body "..."` | Add a comment with a flag |
|
|
104
|
+
| `oh-gc pr:comment <number> --repo owner/repo --body "..."` | Add comment on different repo |
|
|
105
|
+
| `oh-gc pr:comment <number> --body "..." --path file.ts --line 10` | Comment on specific line |
|
|
104
106
|
| `oh-gc pr:merge <number>` | Merge PR (default: merge commit) |
|
|
105
107
|
| `oh-gc pr:merge <number> --method squash` | Squash merge |
|
|
106
108
|
| `oh-gc pr:merge <number> --method rebase` | Rebase merge |
|
package/dist/api/prs.d.ts
CHANGED
|
@@ -48,13 +48,15 @@ export interface ListPRsParams {
|
|
|
48
48
|
}
|
|
49
49
|
export declare function listPRs(token: string, owner: string, repo: string, params?: ListPRsParams): Promise<PR[]>;
|
|
50
50
|
export declare function getPR(token: string, owner: string, repo: string, number: number): Promise<PR>;
|
|
51
|
-
export
|
|
51
|
+
export interface CreatePRParams {
|
|
52
52
|
title: string;
|
|
53
53
|
body: string;
|
|
54
54
|
head: string;
|
|
55
55
|
base: string;
|
|
56
56
|
draft?: boolean;
|
|
57
|
-
|
|
57
|
+
fork_path?: string;
|
|
58
|
+
}
|
|
59
|
+
export declare function createPR(token: string, owner: string, repo: string, params: CreatePRParams): Promise<PR>;
|
|
58
60
|
export declare function mergePR(token: string, owner: string, repo: string, number: number, params?: {
|
|
59
61
|
merge_method?: string;
|
|
60
62
|
title?: string;
|
|
@@ -70,4 +72,7 @@ export interface PRComment {
|
|
|
70
72
|
};
|
|
71
73
|
created_at?: string;
|
|
72
74
|
}
|
|
73
|
-
export declare function commentPR(token: string, owner: string, repo: string, number: number, body: string
|
|
75
|
+
export declare function commentPR(token: string, owner: string, repo: string, number: number, body: string, options?: {
|
|
76
|
+
path?: string;
|
|
77
|
+
position?: number;
|
|
78
|
+
}): Promise<PRComment>;
|
package/dist/api/prs.js
CHANGED
|
@@ -23,7 +23,12 @@ async function createPR(token, owner, repo, params) {
|
|
|
23
23
|
async function mergePR(token, owner, repo, number, params = {}) {
|
|
24
24
|
return (0, client_1.apiRequest)(`/repos/${owner}/${repo}/pulls/${number}/merge`, token, { method: 'PUT', body: params });
|
|
25
25
|
}
|
|
26
|
-
async function commentPR(token, owner, repo, number, body) {
|
|
27
|
-
|
|
26
|
+
async function commentPR(token, owner, repo, number, body, options) {
|
|
27
|
+
const requestBody = { body };
|
|
28
|
+
if (options?.path)
|
|
29
|
+
requestBody.path = options.path;
|
|
30
|
+
if (options?.position !== undefined)
|
|
31
|
+
requestBody.position = options.position;
|
|
32
|
+
return (0, client_1.apiRequest)(`/repos/${owner}/${repo}/pulls/${number}/comments`, token, { method: 'POST', body: requestBody });
|
|
28
33
|
}
|
|
29
34
|
//# sourceMappingURL=prs.js.map
|
package/dist/api/prs.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prs.js","sourceRoot":"","sources":["../../src/api/prs.ts"],"names":[],"mappings":";;AAuCA,0BASC;AAED,sBAOC;
|
|
1
|
+
{"version":3,"file":"prs.js","sourceRoot":"","sources":["../../src/api/prs.ts"],"names":[],"mappings":";;AAuCA,0BASC;AAED,sBAOC;AAWD,4BAUC;AAED,0BAYC;AAUD,8BAiBC;AAvHD,qCAAqC;AAuC9B,KAAK,UAAU,OAAO,CAC3B,KAAa,EACb,KAAa,EACb,IAAY,EACZ,SAAwB,EAAE;IAE1B,OAAO,IAAA,mBAAU,EAAO,UAAU,KAAK,IAAI,IAAI,QAAQ,EAAE,KAAK,EAAE;QAC9D,KAAK,EAAE,MAAqD;KAC7D,CAAC,CAAA;AACJ,CAAC;AAEM,KAAK,UAAU,KAAK,CACzB,KAAa,EACb,KAAa,EACb,IAAY,EACZ,MAAc;IAEd,OAAO,IAAA,mBAAU,EAAK,UAAU,KAAK,IAAI,IAAI,UAAU,MAAM,EAAE,EAAE,KAAK,CAAC,CAAA;AACzE,CAAC;AAWM,KAAK,UAAU,QAAQ,CAC5B,KAAa,EACb,KAAa,EACb,IAAY,EACZ,MAAsB;IAEtB,OAAO,IAAA,mBAAU,EAAK,UAAU,KAAK,IAAI,IAAI,QAAQ,EAAE,KAAK,EAAE;QAC5D,MAAM,EAAE,MAAM;QACd,IAAI,EAAE,MAAM;KACb,CAAC,CAAA;AACJ,CAAC;AAEM,KAAK,UAAU,OAAO,CAC3B,KAAa,EACb,KAAa,EACb,IAAY,EACZ,MAAc,EACd,SAA0E,EAAE;IAE5E,OAAO,IAAA,mBAAU,EACf,UAAU,KAAK,IAAI,IAAI,UAAU,MAAM,QAAQ,EAC/C,KAAK,EACL,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,EAAE,CAChC,CAAA;AACH,CAAC;AAUM,KAAK,UAAU,SAAS,CAC7B,KAAa,EACb,KAAa,EACb,IAAY,EACZ,MAAc,EACd,IAAY,EACZ,OAA8C;IAE9C,MAAM,WAAW,GAAgD,EAAE,IAAI,EAAE,CAAA;IACzE,IAAI,OAAO,EAAE,IAAI;QAAE,WAAW,CAAC,IAAI,GAAG,OAAO,CAAC,IAAI,CAAA;IAClD,IAAI,OAAO,EAAE,QAAQ,KAAK,SAAS;QAAE,WAAW,CAAC,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAA;IAE5E,OAAO,IAAA,mBAAU,EACf,UAAU,KAAK,IAAI,IAAI,UAAU,MAAM,WAAW,EAClD,KAAK,EACL,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,WAAW,EAAE,CACtC,CAAA;AACH,CAAC"}
|
|
@@ -7,6 +7,9 @@ export default class PRComment extends BaseCommand {
|
|
|
7
7
|
};
|
|
8
8
|
static flags: {
|
|
9
9
|
body: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
10
|
+
repo: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
11
|
+
path: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
12
|
+
line: import("@oclif/core/lib/interfaces").OptionFlag<number | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
10
13
|
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
11
14
|
};
|
|
12
15
|
run(): Promise<void>;
|
|
@@ -49,8 +49,14 @@ class PRComment extends base_command_1.BaseCommand {
|
|
|
49
49
|
this.error('Not logged in. Run: oh-gc auth:login');
|
|
50
50
|
let owner, repo;
|
|
51
51
|
try {
|
|
52
|
-
|
|
53
|
-
|
|
52
|
+
if (flags.repo) {
|
|
53
|
+
;
|
|
54
|
+
({ owner, repo } = (0, index_2.parseRepoString)(flags.repo));
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
;
|
|
58
|
+
({ owner, repo } = (0, index_2.resolveRepo)());
|
|
59
|
+
}
|
|
54
60
|
}
|
|
55
61
|
catch (err) {
|
|
56
62
|
this.error(err.message);
|
|
@@ -68,12 +74,17 @@ class PRComment extends base_command_1.BaseCommand {
|
|
|
68
74
|
if (!body)
|
|
69
75
|
this.error('Comment body cannot be empty.');
|
|
70
76
|
try {
|
|
71
|
-
const comment = await (0, prs_1.commentPR)(token, owner, repo, parseInt(args.number, 10), body);
|
|
77
|
+
const comment = await (0, prs_1.commentPR)(token, owner, repo, parseInt(args.number, 10), body, flags.path ? { path: flags.path, position: flags.line } : undefined);
|
|
72
78
|
if (flags.json) {
|
|
73
79
|
(0, index_3.printJson)(comment);
|
|
74
80
|
}
|
|
75
81
|
else {
|
|
76
|
-
|
|
82
|
+
if (flags.path && flags.line) {
|
|
83
|
+
this.log(`Added comment on PR #${args.number} at ${flags.path}:${flags.line}`);
|
|
84
|
+
}
|
|
85
|
+
else {
|
|
86
|
+
this.log(`Added comment on PR #${args.number}`);
|
|
87
|
+
}
|
|
77
88
|
if (comment.html_url) {
|
|
78
89
|
this.log(comment.html_url);
|
|
79
90
|
}
|
|
@@ -90,6 +101,7 @@ PRComment.description = 'Add a comment to a pull request';
|
|
|
90
101
|
PRComment.examples = [
|
|
91
102
|
'<%= config.bin %> pr:comment 12',
|
|
92
103
|
'<%= config.bin %> pr:comment 12 --body "Looks good to me!"',
|
|
104
|
+
'<%= config.bin %> pr:comment 12 --body "Nitpick" --path src/main.ts --line 10',
|
|
93
105
|
];
|
|
94
106
|
PRComment.args = {
|
|
95
107
|
number: core_1.Args.string({ description: 'Pull request number', required: true }),
|
|
@@ -97,6 +109,9 @@ PRComment.args = {
|
|
|
97
109
|
PRComment.flags = {
|
|
98
110
|
...base_command_1.BaseCommand.baseFlags,
|
|
99
111
|
body: core_1.Flags.string({ description: 'Comment body' }),
|
|
112
|
+
repo: core_1.Flags.string({ description: 'Target repository (owner/repo), defaults to current repo' }),
|
|
113
|
+
path: core_1.Flags.string({ description: 'File path for line-specific comment (e.g., src/main.ts)' }),
|
|
114
|
+
line: core_1.Flags.integer({ description: 'Line number for line-specific comment' }),
|
|
100
115
|
};
|
|
101
116
|
exports.default = PRComment;
|
|
102
117
|
//# sourceMappingURL=comment.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"comment.js","sourceRoot":"","sources":["../../../src/commands/pr/comment.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,sCAAyC;AACzC,wDAAyC;AACzC,qDAAgD;AAChD,8CAA6C;AAC7C,
|
|
1
|
+
{"version":3,"file":"comment.js","sourceRoot":"","sources":["../../../src/commands/pr/comment.ts"],"names":[],"mappings":"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"}
|
|
@@ -83,11 +83,13 @@ class PRCreate extends base_command_1.BaseCommand {
|
|
|
83
83
|
let head = flags.head ?? currentBranch;
|
|
84
84
|
if (!head)
|
|
85
85
|
this.error('Could not determine current branch. Use --head to specify.');
|
|
86
|
-
// For cross-repo PRs, prefix head with fork owner
|
|
86
|
+
// For cross-repo PRs, prefix head with fork owner and set fork_path
|
|
87
|
+
let forkPath;
|
|
87
88
|
if (flags.repo) {
|
|
88
89
|
const forkOwner = (0, index_2.getForkOwner)();
|
|
89
90
|
if (forkOwner && !head.includes(':')) {
|
|
90
91
|
head = `${forkOwner}:${head}`;
|
|
92
|
+
forkPath = `${forkOwner}/${(0, index_2.resolveRepo)().repo}`;
|
|
91
93
|
}
|
|
92
94
|
}
|
|
93
95
|
const title = flags.title ?? (await prompt('Title: '));
|
|
@@ -101,6 +103,7 @@ class PRCreate extends base_command_1.BaseCommand {
|
|
|
101
103
|
head,
|
|
102
104
|
base: flags.base,
|
|
103
105
|
draft: flags.draft,
|
|
106
|
+
fork_path: forkPath,
|
|
104
107
|
});
|
|
105
108
|
if (flags.json) {
|
|
106
109
|
(0, index_3.printJson)(pr);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create.js","sourceRoot":"","sources":["../../../src/commands/pr/create.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,sCAAmC;AACnC,wDAAyC;AACzC,2DAA6C;AAC7C,qDAAgD;AAChD,8CAA6C;AAC7C,2CAA4E;AAC5E,uCAAwC;AACxC,6CAA+C;AAC/C,0CAA0C;AAE1C,KAAK,UAAU,MAAM,CAAC,QAAgB;IACpC,MAAM,EAAE,GAAG,QAAQ,CAAC,eAAe,CAAC,EAAE,KAAK,EAAE,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,CAAC,MAAM,EAAE,CAAC,CAAA;IACrF,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;QAC7B,EAAE,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC,MAAM,EAAE,EAAE;YAC/B,EAAE,CAAC,KAAK,EAAE,CAAA;YACV,OAAO,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,CAAA;QACxB,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC;AAED,SAAS,gBAAgB;IACvB,IAAI,CAAC;QACH,OAAO,IAAA,6BAAQ,EAAC,2BAA2B,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,CAAC,CAAC,IAAI,EAAE,CAAA;IAC3E,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,EAAE,CAAA;IACX,CAAC;AACH,CAAC;AAED,MAAqB,QAAS,SAAQ,0BAAW;IAiB/C,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAA;QAE5C,MAAM,KAAK,GAAG,IAAA,gBAAQ,GAAE,CAAA;QACxB,IAAI,CAAC,KAAK;YAAE,IAAI,CAAC,KAAK,CAAC,sCAAsC,CAAC,CAAA;QAE9D,IAAI,KAAa,EAAE,IAAY,CAAA;QAC/B,IAAI,CAAC;YACH,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;gBACf,CAAC;gBAAA,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,IAAA,uBAAe,EAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAA;YAClD,CAAC;iBAAM,CAAC;gBACN,CAAC;gBAAA,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,IAAA,mBAAW,GAAE,CAAC,CAAA;YACpC,CAAC;QACH,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,CAAC,KAAK,CAAE,GAAa,CAAC,OAAO,CAAC,CAAA;QACpC,CAAC;QAED,MAAM,aAAa,GAAG,gBAAgB,EAAE,CAAA;QACxC,IAAI,IAAI,GAAG,KAAK,CAAC,IAAI,IAAI,aAAa,CAAA;QACtC,IAAI,CAAC,IAAI;YAAE,IAAI,CAAC,KAAK,CAAC,4DAA4D,CAAC,CAAA;QAEnF,
|
|
1
|
+
{"version":3,"file":"create.js","sourceRoot":"","sources":["../../../src/commands/pr/create.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,sCAAmC;AACnC,wDAAyC;AACzC,2DAA6C;AAC7C,qDAAgD;AAChD,8CAA6C;AAC7C,2CAA4E;AAC5E,uCAAwC;AACxC,6CAA+C;AAC/C,0CAA0C;AAE1C,KAAK,UAAU,MAAM,CAAC,QAAgB;IACpC,MAAM,EAAE,GAAG,QAAQ,CAAC,eAAe,CAAC,EAAE,KAAK,EAAE,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,CAAC,MAAM,EAAE,CAAC,CAAA;IACrF,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;QAC7B,EAAE,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC,MAAM,EAAE,EAAE;YAC/B,EAAE,CAAC,KAAK,EAAE,CAAA;YACV,OAAO,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,CAAA;QACxB,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC;AAED,SAAS,gBAAgB;IACvB,IAAI,CAAC;QACH,OAAO,IAAA,6BAAQ,EAAC,2BAA2B,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,CAAC,CAAC,IAAI,EAAE,CAAA;IAC3E,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,EAAE,CAAA;IACX,CAAC;AACH,CAAC;AAED,MAAqB,QAAS,SAAQ,0BAAW;IAiB/C,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAA;QAE5C,MAAM,KAAK,GAAG,IAAA,gBAAQ,GAAE,CAAA;QACxB,IAAI,CAAC,KAAK;YAAE,IAAI,CAAC,KAAK,CAAC,sCAAsC,CAAC,CAAA;QAE9D,IAAI,KAAa,EAAE,IAAY,CAAA;QAC/B,IAAI,CAAC;YACH,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;gBACf,CAAC;gBAAA,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,IAAA,uBAAe,EAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAA;YAClD,CAAC;iBAAM,CAAC;gBACN,CAAC;gBAAA,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,IAAA,mBAAW,GAAE,CAAC,CAAA;YACpC,CAAC;QACH,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,CAAC,KAAK,CAAE,GAAa,CAAC,OAAO,CAAC,CAAA;QACpC,CAAC;QAED,MAAM,aAAa,GAAG,gBAAgB,EAAE,CAAA;QACxC,IAAI,IAAI,GAAG,KAAK,CAAC,IAAI,IAAI,aAAa,CAAA;QACtC,IAAI,CAAC,IAAI;YAAE,IAAI,CAAC,KAAK,CAAC,4DAA4D,CAAC,CAAA;QAEnF,oEAAoE;QACpE,IAAI,QAA4B,CAAA;QAChC,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;YACf,MAAM,SAAS,GAAG,IAAA,oBAAY,GAAE,CAAA;YAChC,IAAI,SAAS,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;gBACrC,IAAI,GAAG,GAAG,SAAS,IAAI,IAAI,EAAE,CAAA;gBAC7B,QAAQ,GAAG,GAAG,SAAS,IAAI,IAAA,mBAAW,GAAE,CAAC,IAAI,EAAE,CAAA;YACjD,CAAC;QACH,CAAC;QAED,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,IAAI,CAAC,MAAM,MAAM,CAAC,SAAS,CAAC,CAAC,CAAA;QACtD,IAAI,CAAC,KAAK;YAAE,IAAI,CAAC,KAAK,CAAC,wBAAwB,CAAC,CAAA;QAEhD,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,IAAI,CAAC,MAAM,MAAM,CAAC,qCAAqC,CAAC,CAAC,CAAA;QAEhF,IAAI,CAAC;YACH,MAAM,EAAE,GAAG,MAAM,IAAA,cAAQ,EAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE;gBAC5C,KAAK;gBACL,IAAI,EAAE,IAAI,IAAI,EAAE;gBAChB,IAAI;gBACJ,IAAI,EAAE,KAAK,CAAC,IAAI;gBAChB,KAAK,EAAE,KAAK,CAAC,KAAK;gBAClB,SAAS,EAAE,QAAQ;aACpB,CAAC,CAAA;YAEF,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;gBACf,IAAA,iBAAS,EAAC,EAAE,CAAC,CAAA;YACf,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,GAAG,CAAC,eAAe,EAAE,CAAC,MAAM,KAAK,EAAE,CAAC,KAAK,EAAE,CAAC,CAAA;gBACjD,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAA;YACvB,CAAC;QACH,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,GAAG,YAAY,qBAAY;gBAAE,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;YACxD,IAAI,CAAC,KAAK,CAAC,+DAA+D,CAAC,CAAA;QAC7E,CAAC;IACH,CAAC;;AAxEM,oBAAW,GAAG,uBAAuB,CAAA;AACrC,iBAAQ,GAAG;IAChB,6BAA6B;IAC7B,4EAA4E;IAC5E,mFAAmF;CACpF,CAAA;AACM,cAAK,GAAG;IACb,GAAG,0BAAW,CAAC,SAAS;IACxB,KAAK,EAAE,YAAK,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,UAAU,EAAE,CAAC;IAChD,IAAI,EAAE,YAAK,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAC;IACrD,IAAI,EAAE,YAAK,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,+BAA+B,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC;IACrF,IAAI,EAAE,YAAK,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,yCAAyC,EAAE,CAAC;IAC9E,KAAK,EAAE,YAAK,CAAC,OAAO,CAAC,EAAE,WAAW,EAAE,oBAAoB,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;IAC3E,IAAI,EAAE,YAAK,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,4EAA4E,EAAE,CAAC;CAClH,CAAA;kBAfkB,QAAQ"}
|