gantt-lib 0.4.0 → 0.4.1

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/dist/index.d.mts CHANGED
@@ -238,8 +238,6 @@ interface GanttChartProps {
238
238
  onDelete?: (taskId: string) => void;
239
239
  /** Callback when a new task is inserted after a specific task via the task list */
240
240
  onInsertAfter?: (taskId: string, newTask: Task) => void;
241
- /** ID of task that should enter edit mode on mount (for auto-edit after insert) */
242
- editingTaskId?: string | null;
243
241
  }
244
242
  /**
245
243
  * Ref handle type for GanttChart — exposes imperative scroll methods.
package/dist/index.d.ts CHANGED
@@ -238,8 +238,6 @@ interface GanttChartProps {
238
238
  onDelete?: (taskId: string) => void;
239
239
  /** Callback when a new task is inserted after a specific task via the task list */
240
240
  onInsertAfter?: (taskId: string, newTask: Task) => void;
241
- /** ID of task that should enter edit mode on mount (for auto-edit after insert) */
242
- editingTaskId?: string | null;
243
241
  }
244
242
  /**
245
243
  * Ref handle type for GanttChart — exposes imperative scroll methods.
package/dist/index.js CHANGED
@@ -2816,12 +2816,12 @@ var GanttChart = (0, import_react13.forwardRef)(({
2816
2816
  highlightExpiredTasks = false,
2817
2817
  onAdd,
2818
2818
  onDelete,
2819
- onInsertAfter,
2820
- editingTaskId
2819
+ onInsertAfter
2821
2820
  }, ref) => {
2822
2821
  const scrollContainerRef = (0, import_react13.useRef)(null);
2823
2822
  const [selectedTaskId, setSelectedTaskId] = (0, import_react13.useState)(null);
2824
2823
  const [selectedChip, setSelectedChip] = (0, import_react13.useState)(null);
2824
+ const [editingTaskId, setEditingTaskId] = (0, import_react13.useState)(null);
2825
2825
  const dateRange = (0, import_react13.useMemo)(() => getMultiMonthDays(tasks), [tasks]);
2826
2826
  const [validationResult, setValidationResult] = (0, import_react13.useState)(null);
2827
2827
  const [cascadeOverrides, setCascadeOverrides] = (0, import_react13.useState)(/* @__PURE__ */ new Map());
@@ -2905,6 +2905,9 @@ var GanttChart = (0, import_react13.forwardRef)(({
2905
2905
  const originalTask = tasks.find((t) => t.id === updatedTask.id);
2906
2906
  if (!originalTask) {
2907
2907
  onChange?.((currentTasks) => currentTasks.map((t) => t.id === updatedTask.id ? updatedTask : t));
2908
+ if (editingTaskId === updatedTask.id) {
2909
+ setEditingTaskId(null);
2910
+ }
2908
2911
  return;
2909
2912
  }
2910
2913
  const origStart = new Date(originalTask.startDate);
@@ -2914,6 +2917,9 @@ var GanttChart = (0, import_react13.forwardRef)(({
2914
2917
  const datesChanged = origStart.getTime() !== newStart.getTime() || origEnd.getTime() !== newEnd.getTime();
2915
2918
  if (!datesChanged) {
2916
2919
  onChange?.((currentTasks) => currentTasks.map((t) => t.id === updatedTask.id ? updatedTask : t));
2920
+ if (editingTaskId === updatedTask.id) {
2921
+ setEditingTaskId(null);
2922
+ }
2917
2923
  return;
2918
2924
  }
2919
2925
  let cascadedTasksForCallback;
@@ -2932,7 +2938,7 @@ var GanttChart = (0, import_react13.forwardRef)(({
2932
2938
  });
2933
2939
  onCascade?.(cascadedTasksForCallback);
2934
2940
  }
2935
- }, [tasks, onChange, disableConstraints, onCascade]);
2941
+ }, [tasks, onChange, disableConstraints, onCascade, editingTaskId]);
2936
2942
  const handleDelete = (0, import_react13.useCallback)((taskId) => {
2937
2943
  onChange?.(
2938
2944
  (currentTasks) => currentTasks.filter((t) => t.id !== taskId).map((t) => ({
@@ -2942,6 +2948,10 @@ var GanttChart = (0, import_react13.forwardRef)(({
2942
2948
  );
2943
2949
  onDelete?.(taskId);
2944
2950
  }, [onChange, onDelete]);
2951
+ const handleInsertAfter = (0, import_react13.useCallback)((taskId, newTask) => {
2952
+ setEditingTaskId(newTask.id);
2953
+ onInsertAfter?.(taskId, newTask);
2954
+ }, [onInsertAfter]);
2945
2955
  const dependencyOverrides = (0, import_react13.useMemo)(() => {
2946
2956
  const map = new Map(cascadeOverrides);
2947
2957
  if (draggedTaskOverride) {
@@ -3034,7 +3044,7 @@ var GanttChart = (0, import_react13.forwardRef)(({
3034
3044
  onSelectedChipChange: setSelectedChip,
3035
3045
  onAdd,
3036
3046
  onDelete: handleDelete,
3037
- onInsertAfter,
3047
+ onInsertAfter: handleInsertAfter,
3038
3048
  editingTaskId
3039
3049
  }
3040
3050
  ),