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 8, 2024
1 parent f7862d2 commit e218d5e
Show file tree
Hide file tree
Showing 5 changed files with 53 additions and 20 deletions.
29 changes: 28 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 @@ -22,10 +25,15 @@
export let dataGrid: DataGrid<ActivityDirective> | undefined = undefined;
export let plan: Plan | null;
export let selectedActivityDirectiveId: ActivityDirectiveId | null = null;
export let bulkSelectedActivityDirectiveIds: ActivityDirectiveId[] = [];
export let planReadOnly: boolean = false;
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,11 +137,22 @@
function getRowId(activityDirective: ActivityDirective): ActivityDirectiveId {
return activityDirective.id;
}
function scrollToActivityInTimeline() {
const directiveId =
(bulkSelectedActivityDirectiveIds.length > 0 && bulkSelectedActivityDirectiveIds[0]) ||
selectedActivityDirectiveId;
const directive = activityDirectives.find(item => item.id === directiveId) ?? null;
if (directive?.start_time_ms) {
dispatch('scrollToTime', directive.start_time_ms);
}
}
</script>

<BulkActionDataGrid
bind:dataGrid
bind:selectedItemId={selectedActivityDirectiveId}
bind:selectedItemIds={bulkSelectedActivityDirectiveIds}
autoSizeColumnsToFit={false}
columnDefs={completeColumnDefs}
{columnStates}
Expand All @@ -155,4 +174,12 @@
on:gridSizeChanged
on:selectionChanged
on:rowDoubleClicked
/>
>
<svelte:fragment slot="context-menu">
<!-- Context menu for a single activity directive specifically -->
{#if bulkSelectedActivityDirectiveIds.length === 1}
<ContextMenuItem on:click={scrollToActivityInTimeline}>Scroll to Activity</ContextMenuItem>
<ContextMenuSeparator></ContextMenuSeparator>
{/if}
</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
4 changes: 3 additions & 1 deletion src/components/ui/DataGrid/BulkActionDataGrid.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@
export let pluralItemDisplayText: string = '';
export let scrollToSelection: boolean = false;
export let selectedItemId: RowId | null = null;
export let selectedItemIds: RowId[] = [];
export let showContextMenu: boolean = true;
export let singleItemDisplayText: string = '';
export let suppressDragLeaveHidesColumns: boolean = true;
Expand All @@ -48,7 +49,6 @@
let isFiltered: boolean = false;
let deletePermission: boolean = true;
let selectedItemIds: RowId[] = [];
$: if (typeof hasDeletePermission === 'function' && user) {
if (selectedItemIds.length > 0) {
Expand Down Expand Up @@ -172,6 +172,8 @@
>
<svelte:fragment slot="context-menu">
{#if showContextMenu}
<!-- to further extend context menu -->
<slot name="context-menu" />
<ContextMenuHeader>Bulk Actions</ContextMenuHeader>
<ContextMenuItem on:click={selectAllItems}>
Select All {isFiltered ? 'Visible ' : ''}{pluralItemDisplayText}
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 e218d5e

Please sign in to comment.