Skip to content

Commit

Permalink
Wrap some code of complex funcs to subfunctions to improve readability
Browse files Browse the repository at this point in the history
  • Loading branch information
sergeibbb committed Oct 8, 2024
1 parent d481730 commit bd8af98
Showing 1 changed file with 83 additions and 75 deletions.
158 changes: 83 additions & 75 deletions src/plus/launchpad/launchpad.ts
Original file line number Diff line number Diff line change
Expand Up @@ -375,6 +375,87 @@ export class LaunchpadCommand extends QuickCommand<State> {
{ picked, selectTopItem }: { picked?: string; selectTopItem?: boolean },
): StepResultGenerator<GroupedLaunchpadItem | ConnectMoreIntegrationsItem> {
const hasDisconnectedIntegrations = [...context.connectedIntegrations.values()].some(c => !c);

const buildGroupHeading = (
ui: LaunchpadGroup,
groupLength: number,
): [DirectiveQuickPickItem, DirectiveQuickPickItem] => {
return [
createQuickPickSeparator(groupLength ? groupLength.toString() : undefined),
createDirectiveQuickPickItem(Directive.Reload, false, {
label: `$(${
context.collapsed.get(ui) ? 'chevron-down' : 'chevron-up'
})\u00a0\u00a0${launchpadGroupIconMap.get(ui)!}\u00a0\u00a0${launchpadGroupLabelMap
.get(ui)
?.toUpperCase()}`, //'\u00a0',
//detail: groupMap.get(group)?.[0].toUpperCase(),
onDidSelect: () => {
const collapsed = !context.collapsed.get(ui);
context.collapsed.set(ui, collapsed);
if (state.initialGroup == null) {
void this.container.storage.store(
'launchpad:groups:collapsed',
Array.from(context.collapsed.keys()).filter(g => context.collapsed.get(g)),
);
}

if (this.container.telemetry.enabled) {
updateTelemetryContext(context);
this.container.telemetry.sendEvent(
'launchpad/groupToggled',
{
...context.telemetryContext!,
group: ui,
collapsed: collapsed,
},
this.source,
);
}
},
}),
];
};

const buildLaunchpadQuickPickItem = (
i: LaunchpadItem,
ui: LaunchpadGroup,
topItem: LaunchpadItem | undefined,
): LaunchpadItemQuickPickItem => {
const buttons = [];

if (i.actionableCategory === 'mergeable') {
buttons.push(MergeQuickInputButton);
}

buttons.push(
i.viewer.pinned ? UnpinQuickInputButton : PinQuickInputButton,
i.viewer.snoozed ? UnsnoozeQuickInputButton : SnoozeQuickInputButton,
);

buttons.push(...getOpenOnGitProviderQuickInputButtons(i.provider.id));

if (!i.openRepository?.localBranch?.current) {
buttons.push(OpenWorktreeInNewWindowQuickInputButton);
}

return {
label: i.title.length > 60 ? `${i.title.substring(0, 60)}...` : i.title,
// description: `${i.repoAndOwner}#${i.id}, by @${i.author}`,
description: `\u00a0 ${i.repository.owner.login}/${i.repository.name}#${i.id} \u00a0 ${
i.codeSuggestionsCount > 0 ? ` $(gitlens-code-suggestion) ${i.codeSuggestionsCount}` : ''
} \u00a0 ${i.isNew ? '(New since last view)' : ''}`,
detail: ` ${i.viewer.pinned ? '$(pinned) ' : ''}${
i.actionableCategory === 'other' ? '' : `${actionGroupMap.get(i.actionableCategory)![0]} \u2022 `
}${fromNow(i.updatedDate)} by @${i.author!.username}`,

buttons: buttons,
iconPath: i.author?.avatarUrl != null ? Uri.parse(i.author.avatarUrl) : undefined,
item: i,
picked: i.graphQLId === picked || i.graphQLId === topItem?.graphQLId,
group: ui,
};
};

const getItems = (result: LaunchpadCategorizedResult) => {
const items: (LaunchpadItemQuickPickItem | DirectiveQuickPickItem | ConnectMoreIntegrationsItem)[] = [];
if (context.showGraduationPromo) {
Expand All @@ -400,84 +481,11 @@ export class LaunchpadCommand extends QuickCommand<State> {
for (const [ui, groupItems] of uiGroups) {
if (!groupItems.length) continue;

items.push(
createQuickPickSeparator(groupItems.length ? groupItems.length.toString() : undefined),
createDirectiveQuickPickItem(Directive.Reload, false, {
label: `$(${
context.collapsed.get(ui) ? 'chevron-down' : 'chevron-up'
})\u00a0\u00a0${launchpadGroupIconMap.get(ui)!}\u00a0\u00a0${launchpadGroupLabelMap
.get(ui)
?.toUpperCase()}`, //'\u00a0',
//detail: groupMap.get(group)?.[0].toUpperCase(),
onDidSelect: () => {
const collapsed = !context.collapsed.get(ui);
context.collapsed.set(ui, collapsed);
if (state.initialGroup == null) {
void this.container.storage.store(
'launchpad:groups:collapsed',
Array.from(context.collapsed.keys()).filter(g => context.collapsed.get(g)),
);
}

if (this.container.telemetry.enabled) {
updateTelemetryContext(context);
this.container.telemetry.sendEvent(
'launchpad/groupToggled',
{
...context.telemetryContext!,
group: ui,
collapsed: collapsed,
},
this.source,
);
}
},
}),
);
items.push(...buildGroupHeading(ui, groupItems.length));

if (context.collapsed.get(ui)) continue;

items.push(
...groupItems.map(i => {
const buttons = [];

if (i.actionableCategory === 'mergeable') {
buttons.push(MergeQuickInputButton);
}

buttons.push(
i.viewer.pinned ? UnpinQuickInputButton : PinQuickInputButton,
i.viewer.snoozed ? UnsnoozeQuickInputButton : SnoozeQuickInputButton,
);

buttons.push(...getOpenOnGitProviderQuickInputButtons(i.provider.id));

if (!i.openRepository?.localBranch?.current) {
buttons.push(OpenWorktreeInNewWindowQuickInputButton);
}

return {
label: i.title.length > 60 ? `${i.title.substring(0, 60)}...` : i.title,
// description: `${i.repoAndOwner}#${i.id}, by @${i.author}`,
description: `\u00a0 ${i.repository.owner.login}/${i.repository.name}#${i.id} \u00a0 ${
i.codeSuggestionsCount > 0
? ` $(gitlens-code-suggestion) ${i.codeSuggestionsCount}`
: ''
} \u00a0 ${i.isNew ? '(New since last view)' : ''}`,
detail: ` ${i.viewer.pinned ? '$(pinned) ' : ''}${
i.actionableCategory === 'other'
? ''
: `${actionGroupMap.get(i.actionableCategory)![0]} \u2022 `
}${fromNow(i.updatedDate)} by @${i.author!.username}`,

buttons: buttons,
iconPath: i.author?.avatarUrl != null ? Uri.parse(i.author.avatarUrl) : undefined,
item: i,
picked: i.graphQLId === picked || i.graphQLId === topItem?.graphQLId,
group: ui,
};
}),
);
items.push(...groupItems.map(i => buildLaunchpadQuickPickItem(i, ui, topItem)));
}
}

Expand Down

0 comments on commit bd8af98

Please sign in to comment.