Adding a custom editor dialog
To add your custom editor, you should:
- Import the custom Form component for adding/editing tasks
- Use the
api.intercept
method to disable opening the default editor by blocking theshow-editor
action (return false) - Add the Form tag, define tasks and taskTypes, and add the action handler function that triggers the
update-task
ordelete-task
action.
<script>
import { getData } from "../data";
import { Gantt } from "wx-svelte-gantt";
import { Form } from "../custom/Form.svelte";
const data = getData();
const taskTypes = [
{ id: "task", label: "Task" },
{ id: "milestone", label: "Milestone" },
{ id: "summary", label: "Project" },
];
let task = $state();
let store;
function init(api) {
store = api.getState().tasks;
api.intercept("show-editor", data => {
task = store.byId(data.id);
return false;
});
}
let api;
function formAction(ev) {
const { action, data } = ev;
switch (action) {
case "close-form":
task = null;
break;
default:
api.exec(action, data); //”update-task”, “delete-task” actions
break;
}
}
</script>
<Gantt
tasks={data.tasks}
links={data.links}
scales={data.scales}
bind:this={api}
{init}
/>
{#if task}
<Form {task} {taskTypes} onaction={formAction} />
{/if}