From bc2984889e6eedd4acb37fa302273953e8b5fb67 Mon Sep 17 00:00:00 2001 From: rhenck <richard.henck@iqb.hu-berlin.de> Date: Mon, 15 Jul 2024 15:37:23 +0200 Subject: [PATCH] [editor] Fix template insert The selected section is replaced with the new section when empty. Otherwise the new section is appended below the selected section. There is no way to influence this behaviour (contrary the section-insert-dialog). --- projects/common/models/page.ts | 4 ++++ projects/common/models/section.ts | 4 ++++ .../editor/src/app/services/template.service.ts | 17 ++++++++++++++--- 3 files changed, 22 insertions(+), 3 deletions(-) diff --git a/projects/common/models/page.ts b/projects/common/models/page.ts index d1c1d729b..ac593c89f 100644 --- a/projects/common/models/page.ts +++ b/projects/common/models/page.ts @@ -57,6 +57,10 @@ export class Page { } } + replaceSection(sectionIndex: number, section: Section): void { + this.sections.splice(sectionIndex, 1, section); + } + deleteSection(sectionIndex: number){ this.sections.splice(sectionIndex, 1); } diff --git a/projects/common/models/section.ts b/projects/common/models/section.ts index 9960eaee9..35215dd7d 100644 --- a/projects/common/models/section.ts +++ b/projects/common/models/section.ts @@ -106,6 +106,10 @@ export class Section { .filter((gridRow: number | null): gridRow is number => gridRow !== null); return Math.max(...x, 0); } + + isEmpty(): boolean { + return this.elements.length === 0; + } } export interface SectionProperties { diff --git a/projects/editor/src/app/services/template.service.ts b/projects/editor/src/app/services/template.service.ts index 623882309..ac3b96d2b 100644 --- a/projects/editor/src/app/services/template.service.ts +++ b/projects/editor/src/app/services/template.service.ts @@ -20,6 +20,7 @@ import { AudioWizardDialogComponent } from 'editor/src/app/components/dialogs/wi import { GeometryWizardDialogComponent } from 'editor/src/app/components/dialogs/wizards/geometry.dialog.component'; import { DroplistWizardDialogComponent } from 'editor/src/app/components/dialogs/wizards/droplist.dialog.component'; import { MathTableWizardDialogComponent } from 'editor/src/app/components/dialogs/wizards/mathtable.dialog.component'; +import { SelectionService } from 'editor/src/app/services/selection.service'; @Injectable({ providedIn: 'root' @@ -27,14 +28,24 @@ import { MathTableWizardDialogComponent } from 'editor/src/app/components/dialog export class TemplateService { readonly dialog = inject(MatDialog); - constructor(private unitService: UnitService, private idService: IDService) { } + constructor(private unitService: UnitService, + private selectionService: SelectionService, + private idService: IDService) { } static tooltipSrc = ''; async applyTemplate(templateName: string) { const templateSection: Section = await this.createTemplateSection(templateName); - this.unitService.getSelectedPage().addSection(templateSection); - this.unitService.updateUnitDefinition(); + + const selectedPage = this.unitService.getSelectedPage(); + const selectedSectionIndex = this.selectionService.selectedSectionIndex; + if (this.unitService.getSelectedSection().isEmpty()) { + selectedPage.replaceSection(selectedSectionIndex, templateSection); + } else { + selectedPage.addSection(templateSection, selectedSectionIndex); + } + + await this.unitService.updateUnitDefinition(); } private createTemplateSection(templateName: string): Promise<Section> { -- GitLab