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 1756a5d
Show file tree
Hide file tree
Showing 5 changed files with 45 additions and 19 deletions.
21 changes: 20 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,13 @@
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 +169,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 } 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
19 changes: 3 additions & 16 deletions src/components/timeline/TimelineViewControls.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@
import { createEventDispatcher } from 'svelte';
import { SearchParameters } from '../../enums/searchParameters';
import { activityDirectivesMap, selectedActivityDirective } from '../../stores/activities';
import { plan, planReadOnly } from '../../stores/plan';
import { plan, planReadOnly, setViewTimeRangeAroundTime } from '../../stores/plan';
import {
selectedSpan,
simulationDataset,
Expand All @@ -27,12 +27,7 @@
} from '../../stores/simulation';
import { timelineInteractionMode, timelineLockStatus, viewIsModified } from '../../stores/views';
import type { TimeRange } from '../../types/timeline';
import {
getActivityDirectiveStartTimeMs,
getDoyTimeFromInterval,
getIntervalInMs,
getUnixEpochTime,
} from '../../utilities/time';
import { getActivityDirectiveStartTimeMs, getDoyTimeFromInterval, getUnixEpochTime } from '../../utilities/time';
import { TimelineLockStatus } from '../../utilities/timeline';
import { showFailureToast, showSuccessToast } from '../../utilities/toast';
import { tooltip } from '../../utilities/tooltip';
Expand Down Expand Up @@ -216,15 +211,7 @@
function scrollToSelection() {
const time = getSelectionTime();
if (!isNaN(time) && (time < viewTimeRange.start || time > viewTimeRange.end)) {
const midSpan = time + getIntervalInMs($selectedSpan?.duration) / 2;
const start = Math.max(maxTimeRange.start, midSpan - viewDuration / 2);
const end = Math.min(maxTimeRange.end, midSpan + viewDuration / 2);
dispatch('viewTimeRangeChanged', {
end,
start,
});
}
setViewTimeRangeAroundTime(time);
}
function openDoc(event: MouseEvent, url: string) {
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);
if (!isNaN(timeInMs) && (timeInMs < currentViewTimeRange.start || timeInMs > currentViewTimeRange.end)) {
const padding = (currentViewTimeRange.end - currentViewTimeRange.start) / 2;
const maxRange = get(maxTimeRange);
viewTimeRange.set({
end: Math.min(maxRange.end, timeInMs + padding),
start: Math.max(maxRange.start, timeInMs - padding),
});
}
}

0 comments on commit 1756a5d

Please sign in to comment.