Skip to content

Commit

Permalink
Add "scroll to activity" to activity directive table context menu (#1433
Browse files Browse the repository at this point in the history
)
  • Loading branch information
ivydeliz committed Nov 5, 2024
1 parent 953b7ca commit 3578382
Show file tree
Hide file tree
Showing 4 changed files with 43 additions and 3 deletions.
22 changes: 21 additions & 1 deletion src/components/activity/ActivityDirectivesTable.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,9 @@
import BulkActionDataGrid from '../ui/DataGrid/BulkActionDataGrid.svelte';
import type DataGrid from '../ui/DataGrid/DataGrid.svelte';
import DataGridActions from '../ui/DataGrid/DataGridActions.svelte';
import ContextMenuItem from '../context-menu/ContextMenuItem.svelte';
import ContextMenuSeparator from '../context-menu/ContextMenuSeparator.svelte';
import { createEventDispatcher } from 'svelte';
export let activityDirectives: ActivityDirective[] = [];
export let activityDirectiveErrorRollupsMap: Record<ActivityDirectiveId, ActivityErrorRollup> | undefined = undefined;
Expand All @@ -26,6 +29,10 @@
export let user: User | null;
export let filterExpression: string = '';
const dispatch = createEventDispatcher<{
scrollToTime: number;
}>();
type ActivityDirectiveWithErrorCounts = ActivityDirective & { errorCounts?: ActivityErrorCounts };
type CellRendererParams = {
deleteActivityDirective: (activity: ActivityDirective) => void;
Expand Down Expand Up @@ -129,6 +136,14 @@
function getRowId(activityDirective: ActivityDirective): ActivityDirectiveId {
return activityDirective.id;
}
function scrollToActivityInTimeline() {
const directive = activityDirectives.find(item => item.id === selectedActivityDirectiveId) ?? null;
if (directive?.start_time_ms) {
dispatch('scrollToTime', directive.start_time_ms);
}
}
</script>

<BulkActionDataGrid
Expand All @@ -155,4 +170,9 @@
on:gridSizeChanged
on:selectionChanged
on:rowDoubleClicked
/>
>
<svelte:fragment slot="single-selection-context-menu">
<ContextMenuItem on:click={scrollToActivityInTimeline}>Scroll to Activity</ContextMenuItem>
<ContextMenuSeparator></ContextMenuSeparator>
</svelte:fragment>
</BulkActionDataGrid>
7 changes: 6 additions & 1 deletion src/components/activity/ActivityDirectivesTablePanel.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@
import { InvalidDate } from '../../constants/time';
import { activityDirectivesMap, selectActivity, selectedActivityDirectiveId } from '../../stores/activities';
import { activityErrorRollupsMap } from '../../stores/errors';
import { plan, planReadOnly } from '../../stores/plan';
import { plan, planReadOnly, setViewTimeRangeAroundTime, viewTimeRange } from '../../stores/plan';
import { plugins } from '../../stores/plugins';
import { view, viewTogglePanel, viewUpdateActivityDirectivesTable } from '../../stores/views';
import type { ActivityDirective } from '../../types/activity';
Expand Down Expand Up @@ -364,6 +364,10 @@
viewUpdateActivityDirectivesTable({ autoSizeColumns: 'off' });
}
}
function scrollToTime({ detail }: CustomEvent<number>) {
setViewTimeRangeAroundTime(detail);
}
</script>

<Panel padBody={false}>
Expand Down Expand Up @@ -417,6 +421,7 @@
on:gridSizeChanged={onGridSizeChangedDebounced}
on:rowDoubleClicked={onRowDoubleClicked}
on:selectionChanged={onSelectionChanged}
on:scrollToTime={scrollToTime}
/>
</svelte:fragment>
</Panel>
Expand Down
3 changes: 3 additions & 0 deletions src/components/ui/DataGrid/BulkActionDataGrid.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -171,6 +171,9 @@
on:selectionChanged
>
<svelte:fragment slot="context-menu">
{#if selectedItemIds.length === 1}
<slot name="single-selection-context-menu"/>
{/if}
{#if showContextMenu}
<ContextMenuHeader>Bulk Actions</ContextMenuHeader>
<ContextMenuItem on:click={selectAllItems}>
Expand Down
14 changes: 13 additions & 1 deletion src/stores/plan.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { derived, writable, type Readable, type Writable } from 'svelte/store';
import { derived, writable, type Readable, type Writable, get } from 'svelte/store';
import type { ActivityType } from '../types/activity';
import type { Plan, PlanMergeRequest, PlanMergeRequestSchema, PlanMetadata } from '../types/plan';
import type { PlanDataset } from '../types/simulation';
Expand Down Expand Up @@ -114,3 +114,15 @@ export function resetPlanStores() {
export function setActivityEditingLocked(locked: boolean) {
activityEditingLocked.set(locked);
}

export function setViewTimeRangeAroundTime(timeInMs: number) {
const currentViewTimeRange = get(viewTimeRange);
const padding = (currentViewTimeRange.end - currentViewTimeRange.start)/2;
const max = get(planEndTimeMs);
const min = get(planStartTimeMs);
viewTimeRange.set({
end: Math.min(max, timeInMs + padding),
start: Math.max(min, timeInMs - padding)
});

}

0 comments on commit 3578382

Please sign in to comment.