diff --git a/projects/editor/src/app/components/dialogs/wizards/audio-row.component.ts b/projects/editor/src/app/components/dialogs/wizards/audio-row.component.ts
new file mode 100644
index 0000000000000000000000000000000000000000..c99af8573e746b8892eb88cd3b7cc737ae67bc68
--- /dev/null
+++ b/projects/editor/src/app/components/dialogs/wizards/audio-row.component.ts
@@ -0,0 +1,42 @@
+import { Component, EventEmitter, Input, Output } from '@angular/core';
+import { MatButtonModule } from '@angular/material/button';
+import { MatFormFieldModule } from '@angular/material/form-field';
+import { MatInputModule } from '@angular/material/input';
+import { MatTooltipModule } from '@angular/material/tooltip';
+import { MatIconModule } from '@angular/material/icon';
+import { FormsModule } from '@angular/forms';
+
+@Component({
+  selector: 'aspect-editor-wizard-audio',
+  standalone: true,
+  imports: [
+    MatButtonModule,
+    MatFormFieldModule,
+    MatInputModule,
+    MatTooltipModule,
+    MatIconModule,
+    FormsModule
+  ],
+  template: `
+    <audio controls [src]=src [style.opacity]="src ? 1 : 0.5"></audio>
+    <button mat-fab color="primary"
+            [matTooltip]="'Medienquelle ändern'" [matTooltipPosition]="'right'"
+            (click)="changeMediaSrc.emit()">
+      <mat-icon>upload_file</mat-icon>
+    </button>
+    <mat-form-field appearance="outline">
+      <mat-label>Maximale Abspielhäufigkeit</mat-label>
+      <input matInput type="number" min="1" [(ngModel)]="maxRuns">
+    </mat-form-field>
+  `,
+  styles: `
+    :host {display: flex; flex-direction: row; justify-content: space-around;}
+    audio {align-self: center; margin-bottom: 20px;}
+  `
+})
+export class AudioRowComponent {
+  @Input() src: string | undefined;
+  @Input() maxRuns!: number;
+  @Output() maxRunsChange = new EventEmitter<number>();
+  @Output() changeMediaSrc = new EventEmitter();
+}
diff --git a/projects/editor/src/app/components/dialogs/wizards/audio.dialog.component.ts b/projects/editor/src/app/components/dialogs/wizards/audio.dialog.component.ts
new file mode 100644
index 0000000000000000000000000000000000000000..70f54b26e6a897bc067fe49fd30d927111559e5e
--- /dev/null
+++ b/projects/editor/src/app/components/dialogs/wizards/audio.dialog.component.ts
@@ -0,0 +1,109 @@
+import { Component } from '@angular/core';
+import { FileService } from 'common/services/file.service';
+import { MatDialogModule } from '@angular/material/dialog';
+import { MatTooltipModule } from '@angular/material/tooltip';
+import { MatIconModule } from '@angular/material/icon';
+import { FormsModule, ReactiveFormsModule } from '@angular/forms';
+import { TranslateModule } from '@ngx-translate/core';
+import { MatButtonModule } from '@angular/material/button';
+import { MatExpansionModule } from '@angular/material/expansion';
+import { MatFormFieldModule } from '@angular/material/form-field';
+import { MatInputModule } from '@angular/material/input';
+import { MatSelectModule } from '@angular/material/select';
+import { RichTextEditorComponent } from 'editor/src/app/text-editor/rich-text-editor.component';
+import { NgIf } from '@angular/common';
+import { AudioRowComponent } from 'editor/src/app/components/dialogs/wizards/audio-row.component';
+
+@Component({
+  selector: 'aspect-editor-audio-wizard-dialog',
+  standalone: true,
+  imports: [
+    NgIf,
+    MatDialogModule,
+    MatExpansionModule,
+    MatButtonModule,
+    MatTooltipModule,
+    MatFormFieldModule,
+    MatInputModule,
+    MatIconModule,
+    ReactiveFormsModule,
+    FormsModule,
+    TranslateModule,
+    MatSelectModule,
+    RichTextEditorComponent,
+    AudioRowComponent
+  ],
+  template: `
+    <div mat-dialog-title>Assistent: Stimulus: Text</div>
+    <div mat-dialog-content>
+      <mat-accordion>
+        <mat-expansion-panel (afterExpand)="variant = 'a'" (closed)="variant = undefined">
+          <mat-expansion-panel-header>
+            <mat-panel-title>Instruktion und Hörtext in einem Audio</mat-panel-title>
+          </mat-expansion-panel-header>
+          <aspect-editor-wizard-audio [src]="src1" [(maxRuns)]="maxRuns1" (changeMediaSrc)="changeMediaSrc('src1')">
+          </aspect-editor-wizard-audio>
+        </mat-expansion-panel>
+
+        <mat-expansion-panel (afterExpand)="variant = 'b'" (closed)="variant = undefined">
+          <mat-expansion-panel-header>
+            <mat-panel-title>Instruktion und Hörtext getrennt</mat-panel-title>
+          </mat-expansion-panel-header>
+
+          <aspect-editor-wizard-audio [src]="src1" [(maxRuns)]="maxRuns1" (changeMediaSrc)="changeMediaSrc('src1')">
+          </aspect-editor-wizard-audio>
+
+          <aspect-editor-wizard-audio [src]="src2" [(maxRuns)]="maxRuns2" (changeMediaSrc)="changeMediaSrc('src2')">
+          </aspect-editor-wizard-audio>
+
+          <mat-form-field>
+            <mat-label>Sprache</mat-label>
+            <mat-select required [(ngModel)]="lang">
+              <mat-option [value]="'german'">Deutsch</mat-option>
+              <mat-option [value]="'english'">Englisch</mat-option>
+              <mat-option [value]="'french'">Französisch</mat-option>
+            </mat-select>
+          </mat-form-field>
+
+          <h3>Situierung, Frage, Operator, Hinweise, o.ä.</h3>
+          <aspect-rich-text-editor [(content)]="text" [showReducedControls]="true"></aspect-rich-text-editor>
+
+        </mat-expansion-panel>
+      </mat-accordion>
+    </div>
+    <div mat-dialog-actions>
+      <button mat-button
+              [disabled]="variant == undefined ||
+                          (variant === 'a' && src1 == undefined) ||
+                          (variant === 'b' && (lang === undefined || src1 == undefined || src2 == undefined))"
+              [mat-dialog-close]="{ variant, src1, maxRuns1, src2, maxRuns2, lang, text }">
+        {{ 'confirm' | translate }}
+      </button>
+      <button mat-button mat-dialog-close>{{ 'cancel' | translate }}</button>
+    </div>
+  `,
+  styles: `
+    .mat-mdc-dialog-content {display: flex;}
+    .audio-row {display: flex; flex-direction: row; justify-content: space-around;}
+  `
+})
+export class AudioWizardDialogComponent {
+  variant: 'a' | 'b' | undefined;
+  src1: string | undefined;
+  maxRuns1: number = 1;
+  src2: string | undefined;
+  maxRuns2: number = 2;
+  lang: 'german' | 'english' | 'french' | undefined;
+  text: string = '<p style="padding-left: 0px; text-indent: 0px; margin-bottom: 10px; margin-top: 0"' +
+    ' indentsize="20"><span style="color: black; font-size: 20px">Hier steht die Situierung.</span></p>' +
+    '<p style="padding-left: 0px; text-indent: 0px; margin-bottom: 10px; margin-top: 0" indent="0" ' +
+    'indentsize="20"><span style="color: black; font-size: 20px">Hier stehen Frage und Operator (ggf. ' +
+    'inklusive technische Handhabung).</span></p><p style="padding-left: 0px; text-indent: 0px; ' +
+    'margin-bottom: 0px; margin-top: 0" indent="0" indentsize="20"><span style="color: black; font-size: 20px">' +
+    'Hier steht eventuell ein Hinweis.</span></p>';
+
+  async changeMediaSrc(src: string) {
+    // @ts-ignore
+    this[src] = await FileService.loadAudio();
+  }
+}
diff --git a/projects/editor/src/app/components/dialogs/wizards/droplist.dialog.component.ts b/projects/editor/src/app/components/dialogs/wizards/droplist.dialog.component.ts
new file mode 100644
index 0000000000000000000000000000000000000000..f3203ffd8fb9466bd3d83bcc2bb96a499fb7ed74
--- /dev/null
+++ b/projects/editor/src/app/components/dialogs/wizards/droplist.dialog.component.ts
@@ -0,0 +1,123 @@
+import { Component } from '@angular/core';
+import { MatDialogModule } from '@angular/material/dialog';
+import { TranslateModule } from '@ngx-translate/core';
+import { MatButtonModule } from '@angular/material/button';
+import { RichTextEditorComponent } from 'editor/src/app/text-editor/rich-text-editor.component';
+import { MatDividerModule } from '@angular/material/divider';
+import { OptionListPanelComponent } from 'editor/src/app/components/properties-panel/option-list-panel.component';
+import { DragNDropValueObject, TextLabel } from 'common/models/elements/label-interfaces';
+import { MatFormFieldModule } from '@angular/material/form-field';
+import { MatOptionModule } from '@angular/material/core';
+import { MatSelectModule } from '@angular/material/select';
+import { FormsModule } from '@angular/forms';
+import { MatRadioModule } from '@angular/material/radio';
+import { NgIf } from '@angular/common';
+
+@Component({
+  selector: 'aspect-editor-droplist-wizard-dialog',
+  standalone: true,
+  imports: [
+    MatDialogModule,
+    TranslateModule,
+    MatButtonModule,
+    RichTextEditorComponent,
+    MatDividerModule,
+    OptionListPanelComponent,
+    MatFormFieldModule,
+    MatOptionModule,
+    MatSelectModule,
+    FormsModule,
+    MatRadioModule,
+    NgIf
+  ],
+  template: `
+    <div mat-dialog-title>Assistent: DnD einseitig</div>
+    <div mat-dialog-content>
+      <h3>Ausrichtung</h3>
+      <mat-radio-group [(ngModel)]="alignment">
+        <mat-radio-button [value]="'column'">Elementliste über Ziellisten</mat-radio-button>
+        <mat-radio-button [value]="'row'">
+          Elementliste neben Ziellisten (nur für kurze Elemente oder einseitige Aufgaben)
+        </mat-radio-button>
+      </mat-radio-group>
+
+      <mat-divider></mat-divider>
+
+      <h3>Frage/Instruktion</h3>
+      <aspect-rich-text-editor [(content)]="text1" [style.min-height.px]="300"></aspect-rich-text-editor>
+
+      <mat-divider></mat-divider>
+
+      <h3>Ãœberschrift Elementliste</h3>
+      <aspect-rich-text-editor [(content)]="headingSourceList" [showReducedControls]="true"
+                               [style.min-height.px]="200"></aspect-rich-text-editor>
+
+      <mat-divider></mat-divider>
+
+      <h3>Elemente</h3>
+      <aspect-option-list-panel [textFieldLabel]="'Neues Element'"
+                                [itemList]="options"
+                                [showImageButton]="true"
+                                [localMode]="true">
+      </aspect-option-list-panel>
+      <mat-form-field [style.width.px]="300">
+        <mat-label>ungefähre Länge der Elemente</mat-label>
+        <mat-select [(ngModel)]="optionLength">
+          <mat-option *ngIf="alignment === 'column'" [value]="'long'">lang (< 8 Wörter)</mat-option>
+          <mat-option [value]="'medium'">mittel (< 5 Wörter)</mat-option>
+          <mat-option [value]="'short'">kurz (< 3 Wörter)</mat-option>
+          <mat-option [value]="'very-short'">sehr kurz (1 Wort/Zahl)</mat-option>
+        </mat-select>
+      </mat-form-field>
+
+      <mat-divider></mat-divider>
+
+      <h3>Ãœberschrift Ziellisten</h3>
+      <aspect-rich-text-editor [(content)]="headingTargetLists" [showReducedControls]="true"
+                               [style.min-height.px]="200"></aspect-rich-text-editor>
+
+      <mat-divider></mat-divider>
+
+      <h3>Zielbeschriftungen</h3>
+      <aspect-option-list-panel [textFieldLabel]="'Neue Zielbeschriftung'"
+                                [itemList]="targetLabels"
+                                [localMode]="true">
+      </aspect-option-list-panel>
+      <mat-form-field [style.width.px]="350">
+        <mat-label>ungefähre Länge der Zielbeschriftungen</mat-label>
+        <mat-select [(ngModel)]="targetLength">
+          <mat-option *ngIf="alignment === 'column'" [value]="'long'">lang (< 8 Wörter)</mat-option>
+          <mat-option [value]="'medium'">mittel (< 5 Wörter)</mat-option>
+          <mat-option [value]="'short'">kurz (< 3 Wörter)</mat-option>
+          <mat-option [value]="'very-short'">sehr kurz (1 Wort/Zahl)</mat-option>
+        </mat-select>
+      </mat-form-field>
+
+    </div>
+    <div mat-dialog-actions>
+      <button mat-button
+              [disabled]="!optionLength || !targetLength"
+              [mat-dialog-close]="{ alignment, text1, headingSourceList, options, optionLength,
+                                    headingTargetLists, targetLength, targetLabels }">
+        {{ 'confirm' | translate }}
+      </button>
+      <button mat-button mat-dialog-close>{{ 'cancel' | translate }}</button>
+    </div>
+  `,
+  styles: `
+    .mat-mdc-dialog-content {display: flex; flex-direction: column;}
+    .mat-mdc-dialog-content > *:not(h3, mat-divider) {margin-left: 30px;}
+    h3 {text-decoration: underline;}
+    .mat-mdc-dialog-content > mat-form-field {align-self: flex-start;}
+  `
+})
+export class DroplistWizardDialogComponent {
+  alignment: 'column' | 'row' = 'column';
+  text1: string = 'Fragetext Blabla';
+  headingSourceList: string = 'heagin 1';
+  options: DragNDropValueObject[] = [];
+  optionLength: 'long' | 'medium' | 'short' | 'very-short' | undefined;
+  headingTargetLists: string = 'heading 2';
+  targetLength: 'long' | 'medium' | 'short' | 'very-short' | undefined;
+  targetLabels: TextLabel[] = [];
+}
diff --git a/projects/editor/src/app/components/dialogs/wizards/geometry.dialog.component.ts b/projects/editor/src/app/components/dialogs/wizards/geometry.dialog.component.ts
new file mode 100644
index 0000000000000000000000000000000000000000..2772577313052230c5e0f13b0cc6d82ec087372f
--- /dev/null
+++ b/projects/editor/src/app/components/dialogs/wizards/geometry.dialog.component.ts
@@ -0,0 +1,80 @@
+import { Component } from '@angular/core';
+import { MatDialogModule } from '@angular/material/dialog';
+import { TranslateModule } from '@ngx-translate/core';
+import { MatButtonModule } from '@angular/material/button';
+import { RichTextEditorComponent } from 'editor/src/app/text-editor/rich-text-editor.component';
+import { MatDividerModule } from '@angular/material/divider';
+import { MatFormFieldModule } from '@angular/material/form-field';
+import { MatIconModule } from '@angular/material/icon';
+import { MatInputModule } from '@angular/material/input';
+import { MatTooltipModule } from '@angular/material/tooltip';
+import { FileService } from 'common/services/file.service';
+import { MatCheckboxModule } from '@angular/material/checkbox';
+import { FormsModule } from '@angular/forms';
+
+@Component({
+  selector: 'aspect-editor-geometry-wizard-dialog',
+  standalone: true,
+  imports: [
+    MatDialogModule,
+    TranslateModule,
+    MatButtonModule,
+    RichTextEditorComponent,
+    MatDividerModule,
+    MatFormFieldModule,
+    MatIconModule,
+    MatInputModule,
+    MatTooltipModule,
+    MatCheckboxModule,
+    FormsModule
+  ],
+  template: `
+    <div mat-dialog-title>Assistent: GeoGebra</div>
+    <div mat-dialog-content>
+      <h3>Text</h3>
+      <aspect-rich-text-editor [(content)]="text1" [style.min-height.px]="300"></aspect-rich-text-editor>
+
+      <mat-divider></mat-divider>
+
+      <h3>GeoGebra-Datei</h3>
+      <mat-form-field matTooltip="{{'propertiesPanel.appDefinition' | translate }}"
+                      appearance="fill" [style.align-self]="'flex-start'">
+        <mat-label>{{ 'propertiesPanel.appDefinition' | translate }}</mat-label>
+        <input matInput disabled
+               [value]="geometryAppDefinition ? 'Definition vorhanden' : 'keine Definition vorhanden'">
+        <button mat-icon-button matSuffix (click)="changeSrc()">
+          <mat-icon>edit</mat-icon>
+        </button>
+      </mat-form-field>
+
+      <mat-divider></mat-divider>
+
+      <h3>Tooltipp</h3>
+      <mat-checkbox [(ngModel)]="showHelper">
+        Anzeigen
+      </mat-checkbox>
+
+    </div>
+    <div mat-dialog-actions>
+      <button mat-button [mat-dialog-close]="{ text1, geometryAppDefinition, text2, showHelper }">
+        {{'confirm' | translate }}
+      </button>
+      <button mat-button mat-dialog-close>{{'cancel' | translate }}</button>
+    </div>
+  `,
+  styles: `
+    .mat-mdc-dialog-content {display: flex; flex-direction: column;}
+    .mat-mdc-dialog-content > *:not(h3, mat-divider) {margin-left: 30px;}
+    h3 {text-decoration: underline;}
+  `
+})
+export class GeometryWizardDialogComponent {
+  text1: string = 'Lorem ipsum dolor sit amet';
+  geometryAppDefinition: string | undefined;
+  text2: string = '';
+  showHelper: boolean = true;
+
+  async changeSrc() {
+    this.geometryAppDefinition = await FileService.loadFile(['.ggb'], true);
+  }
+}
diff --git a/projects/editor/src/app/components/dialogs/wizards/input.dialog.component.ts b/projects/editor/src/app/components/dialogs/wizards/input.dialog.component.ts
index 32d955dd9806865f2d57236cbe2852be30f5d5ca..f741de7f0d0f84a0e1bcc2729ce96943f9709399 100644
--- a/projects/editor/src/app/components/dialogs/wizards/input.dialog.component.ts
+++ b/projects/editor/src/app/components/dialogs/wizards/input.dialog.component.ts
@@ -79,5 +79,5 @@ export class InputWizardDialogComponent {
   useTextAreas: boolean = false;
   numbering: 'latin' | 'decimal' | 'bullets' | 'none' = 'latin';
   fieldLength: 'very-small' | 'small' | 'medium' | 'large' = 'large';
-  expectedCharsCount: number = 136;
+  expectedCharsCount: number = 90;
 }
diff --git a/projects/editor/src/app/components/dialogs/wizards/likert.dialog.component.ts b/projects/editor/src/app/components/dialogs/wizards/likert.dialog.component.ts
index 113fcb28752ec2ae7173960be408812b77e4f496..014802e54c8335ce4b748cdb11a6492fc688e850 100644
--- a/projects/editor/src/app/components/dialogs/wizards/likert.dialog.component.ts
+++ b/projects/editor/src/app/components/dialogs/wizards/likert.dialog.component.ts
@@ -4,7 +4,7 @@ import { TextImageLabel } from 'common/models/elements/label-interfaces';
 @Component({
   selector: 'aspect-editor-likert-wizard-dialog',
   template: `
-    <div mat-dialog-title>Assistent: Richtig/Falsch-Aufgaben</div>
+    <div mat-dialog-title>Assistent: CMC</div>
     <div mat-dialog-content>
       <h3>Text</h3>
       <aspect-rich-text-editor [(content)]="text1" [style.min-height.px]="300"></aspect-rich-text-editor>
@@ -35,7 +35,7 @@ import { TextImageLabel } from 'common/models/elements/label-interfaces';
       </aspect-option-list-panel>
     </div>
     <div mat-dialog-actions>
-      <button mat-button [mat-dialog-close]="{ }">{{'confirm' | translate }}</button>
+      <button mat-button [mat-dialog-close]="{ text1, text2, options, rows }">{{'confirm' | translate }}</button>
       <button mat-button mat-dialog-close>{{'cancel' | translate }}</button>
     </div>
   `,
diff --git a/projects/editor/src/app/components/dialogs/wizards/mathtable.dialog.component.ts b/projects/editor/src/app/components/dialogs/wizards/mathtable.dialog.component.ts
new file mode 100644
index 0000000000000000000000000000000000000000..92b82eb334f287c1398cada7fe3d03e80ff4dd25
--- /dev/null
+++ b/projects/editor/src/app/components/dialogs/wizards/mathtable.dialog.component.ts
@@ -0,0 +1,101 @@
+import {
+  Component, ElementRef, QueryList, ViewChildren
+} from '@angular/core';
+import { MatDialogModule } from '@angular/material/dialog';
+import { TranslateModule } from '@ngx-translate/core';
+import { MatButtonModule } from '@angular/material/button';
+import { MatFormFieldModule } from '@angular/material/form-field';
+import { MatOptionModule } from '@angular/material/core';
+import { MatSelectModule } from '@angular/material/select';
+import { FormsModule } from '@angular/forms';
+import { MatIconModule } from '@angular/material/icon';
+import { MatInputModule } from '@angular/material/input';
+import { NgForOf, NgIf } from '@angular/common';
+import { MatDividerModule } from '@angular/material/divider';
+
+@Component({
+  selector: 'aspect-editor-mathtable-wizard-dialog',
+  standalone: true,
+  imports: [
+    NgIf,
+    NgForOf,
+    MatDialogModule,
+    TranslateModule,
+    MatFormFieldModule,
+    MatOptionModule,
+    MatSelectModule,
+    FormsModule,
+    MatButtonModule,
+    MatIconModule,
+    MatInputModule,
+    MatDividerModule
+  ],
+  template: `
+    <div mat-dialog-title>Assistent: GeoGebra</div>
+    <div mat-dialog-content>
+      <h3>Rechenart</h3>
+      <mat-form-field>
+        <mat-label>Operation auswählen</mat-label>
+        <mat-select required [(ngModel)]="operation">
+          <mat-option [value]="'addition'">Addition</mat-option>
+          <mat-option [value]="'subtraction'">Subtraction</mat-option>
+          <mat-option [value]="'multiplication'">Multiplikation mit mehrstelligen Zahlen</mat-option>
+        </mat-select>
+      </mat-form-field>
+
+      <mat-divider></mat-divider>
+
+      {{ 'termRows' | translate }}
+      <div *ngFor="let term of terms; let i = index;" class="terms">
+        <mat-form-field [style.flex-grow]="1" (input)="changeTerm($any($event.target).value, i)">
+          <mat-label>Term</mat-label>
+          <input matInput [value]="term" #termInput>
+        </mat-form-field>
+        <button mat-icon-button (click)="removeTerm(i)">
+          <mat-icon>clear</mat-icon>
+        </button>
+      </div>
+
+      <button mat-button class="add-button"
+              [disabled]="operation === 'multiplication' && terms.length >= 2"
+              (click)="addTerm()">
+        <mat-icon>add</mat-icon>
+        {{ 'addTermRow' | translate }}
+      </button>
+    </div>
+    <div mat-dialog-actions>
+      <button mat-button [mat-dialog-close]="{ operation, terms }">
+        {{'confirm' | translate }}
+      </button>
+      <button mat-button mat-dialog-close>{{'cancel' | translate }}</button>
+    </div>
+  `,
+  styles: `
+    .mat-mdc-dialog-content {display: flex; flex-direction: column;}
+    .mat-mdc-dialog-content > *:not(h3, mat-divider) {margin-left: 30px;}
+    h3 {text-decoration: underline;}
+    .terms {display: flex; flex-direction: row;}
+  `
+})
+export class MathTableWizardDialogComponent {
+  @ViewChildren('termInput') termInputs!: QueryList<ElementRef>;
+
+  operation: 'addition' | 'subtraction' | 'multiplication' | undefined;
+  terms: string[] = ['123', '456'];
+
+  addTerm() {
+    this.terms.push('');
+  }
+
+  changeTerm(term: string, index: number): void {
+    this.terms[index] = term;
+
+    setTimeout(() => {
+      this.termInputs.toArray()[index].nativeElement.focus();
+    });
+  }
+
+  removeTerm(index: number) {
+    this.terms.splice(index, 1);
+  }
+}
diff --git a/projects/editor/src/app/components/dialogs/wizards/text.dialog.component.ts b/projects/editor/src/app/components/dialogs/wizards/text.dialog.component.ts
index 274764a485823f3c9d627fc690078e86ecd7b25a..51b50c9005472b82bf8ee95c13d6dad4c023e1e6 100644
--- a/projects/editor/src/app/components/dialogs/wizards/text.dialog.component.ts
+++ b/projects/editor/src/app/components/dialogs/wizards/text.dialog.component.ts
@@ -39,7 +39,7 @@ import { Component } from '@angular/core';
   `,
   styles: `
     .mat-mdc-dialog-content {display: flex; flex-direction: column;}
-    .mat-mdc-dialog-content *:not(h3, mat-divider) {margin-left: 30px;}
+    .mat-mdc-dialog-content > *:not(h3, mat-divider) {margin-left: 30px;}
     h3 {text-decoration: underline;}
     .input1 {min-height: 400px;}
     .radios {display: flex; flex-direction: row; gap: 10px;}
@@ -47,7 +47,13 @@ import { Component } from '@angular/core';
   `
 })
 export class TextWizardDialogComponent {
-  text1: string = 'Lorem ipsum dolor sit amet';
+  text1: string = '<p style="padding-left: 0px; text-indent: 0px; margin-bottom: 0px; margin-top: 0" ' +
+    'indentsize="20"><span style="font-size: 24px"><strong>Platzhalter Ãœberschrift</strong></span></p>' +
+    '<p style="padding-left: 0px; text-indent: 0px; margin-bottom: 20px; margin-top: 0" indent="0" indentsize="20">' +
+    '<span style="font-size: 20px">Platzhalter Autor</span></p><p style="padding-left: 0px; text-indent: 0px;' +
+    ' margin-bottom: 0px; margin-top: 0" indent="0" indentsize="20"><span style="font-size: 20px">' +
+    'Platzhalter Text</span></p>';
+
   text2: string = 'Platzhalter Quelle';
   highlightableOrange: boolean = false;
   highlightableTurquoise: boolean = false;
diff --git a/projects/editor/src/app/components/dialogs/wizards/text2.dialog.component.ts b/projects/editor/src/app/components/dialogs/wizards/text2.dialog.component.ts
index 06e50ab834e9ec21decc1d55542fa26b4dd513dd..44ec30a577492e1daab9e53efd5b5c5ac24744e2 100644
--- a/projects/editor/src/app/components/dialogs/wizards/text2.dialog.component.ts
+++ b/projects/editor/src/app/components/dialogs/wizards/text2.dialog.component.ts
@@ -25,7 +25,7 @@ import { Component } from '@angular/core';
   `,
   styles: `
     .mat-mdc-dialog-content {display: flex; flex-direction: column;}
-    .mat-mdc-dialog-content *:not(h3, mat-divider) {margin-left: 30px;}
+    .mat-mdc-dialog-content > *:not(h3, mat-divider) {margin-left: 30px;}
     h3 {text-decoration: underline;}
     .input1 {min-height: 400px;}
   `
diff --git a/projects/editor/src/app/components/new-ui-element-panel/ui-element-toolbox.component.html b/projects/editor/src/app/components/new-ui-element-panel/ui-element-toolbox.component.html
index 697e1a2031191db07b9a0f51dac4bc6f8c950fc8..c33b802ffe31cf2fe4424507b7228ab40576fd02 100644
--- a/projects/editor/src/app/components/new-ui-element-panel/ui-element-toolbox.component.html
+++ b/projects/editor/src/app/components/new-ui-element-panel/ui-element-toolbox.component.html
@@ -231,7 +231,19 @@
             MC mit Bild
           </button>
           <button mat-stroked-button (click)="applyTemplate('likert')">
-            Richtig/Falsch-Aufgaben
+            CMC
+          </button>
+          <button mat-stroked-button (click)="applyTemplate('audio')">
+            Stimulus: Audio
+          </button>
+          <button mat-stroked-button (click)="applyTemplate('geometry')">
+            GeoGebra
+          </button>
+          <button mat-stroked-button (click)="applyTemplate('mathtable')">
+            Rechenkästchen
+          </button>
+          <button mat-stroked-button (click)="applyTemplate('droplist')">
+            DnD einseitig
           </button>
         </mat-expansion-panel>
 
diff --git a/projects/editor/src/app/services/template.service.ts b/projects/editor/src/app/services/template.service.ts
index 0ee8d251945126f9e41e7d385f59ffdeafcc4966..ea8af66307cfeaf05a5f5ef70ec9ed3fd43fa3c5 100644
--- a/projects/editor/src/app/services/template.service.ts
+++ b/projects/editor/src/app/services/template.service.ts
@@ -1,3 +1,5 @@
+/* eslint @typescript-eslint/brace-style: OFF */
+
 import { inject, Injectable } from '@angular/core';
 import { MatDialog } from '@angular/material/dialog';
 import { RadioWizardDialogComponent } from 'editor/src/app/components/dialogs/wizards/radio.dialog.component';
@@ -6,7 +8,7 @@ import { PositionProperties, PropertyGroupGenerators } from 'common/models/eleme
 import { Section, SectionProperties } from 'common/models/section';
 import { UnitService } from 'editor/src/app/services/unit-services/unit.service';
 import { IDService } from 'editor/src/app/services/id.service';
-import { TextImageLabel, TextLabel } from 'common/models/elements/label-interfaces';
+import { DragNDropValueObject, TextImageLabel, TextLabel } from 'common/models/elements/label-interfaces';
 import { PositionedUIElement, UIElement, UIElementType } from 'common/models/elements/element';
 import { TextWizardDialogComponent } from 'editor/src/app/components/dialogs/wizards/text.dialog.component';
 import { LikertWizardDialogComponent } from 'editor/src/app/components/dialogs/wizards/likert.dialog.component';
@@ -14,6 +16,10 @@ import { InputWizardDialogComponent } from 'editor/src/app/components/dialogs/wi
 import { RadioImagesWizardDialogComponent } from 'editor/src/app/components/dialogs/wizards/radio2.dialog.component';
 import { Text2WizardDialogComponent } from 'editor/src/app/components/dialogs/wizards/text2.dialog.component';
 import { LikertRowElement, LikertRowProperties } from 'common/models/elements/compound-elements/likert/likert-row';
+import { AudioWizardDialogComponent } from 'editor/src/app/components/dialogs/wizards/audio.dialog.component';
+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';
 
 @Injectable({
   providedIn: 'root'
@@ -23,6 +29,8 @@ export class TemplateService {
 
   constructor(private unitService: UnitService, private idService: IDService) { }
 
+  static tooltipSrc = '';
+
   async applyTemplate(templateName: string) {
     const templateSection: Section = await this.createTemplateSection(templateName);
     this.unitService.getSelectedPage().addSection(templateSection);
@@ -77,18 +85,51 @@ export class TemplateService {
           break;
         case 'likert':
           this.dialog.open(LikertWizardDialogComponent, {})
-            .afterClosed().subscribe((result: { text1: string, text2: string, options: TextImageLabel[], rows: TextImageLabel[] }) => {
+            .afterClosed().subscribe((result: {
+              text1: string, text2: string, options: TextImageLabel[], rows: TextImageLabel[] }) => {
               if (result) resolve(this.createLikertSection(result));
             });
           break;
+        case 'audio':
+          this.dialog.open(AudioWizardDialogComponent, {})
+            .afterClosed().subscribe((result: {
+              variant: 'a' | 'b', src1: string, maxRuns1: number, src2: string, maxRuns2: number
+              lang: 'german' | 'english' | 'french', text: string }) => {
+              if (result.variant === 'a') resolve(this.createAudioSectionA(result));
+              if (result.variant === 'b') resolve(this.createAudioSectionB(result));
+            });
+          break;
+        case 'geometry':
+          this.dialog.open(GeometryWizardDialogComponent, {})
+            .afterClosed().subscribe((result: {
+              text1: string, geometryAppDefinition: string, text2: string, showHelper: boolean }) => {
+              if (result) resolve(this.createGeometrySection(result));
+            });
+          break;
+        case 'mathtable':
+          this.dialog.open(MathTableWizardDialogComponent, {})
+            .afterClosed().subscribe((result: {
+              operation: 'addition' | 'subtraction' | 'multiplication', terms: string[] }) => {
+              if (result) resolve(this.createMathTableSection(result));
+            });
+          break;
+        case 'droplist':
+          this.dialog.open(DroplistWizardDialogComponent, { })
+            .afterClosed().subscribe((result: {
+              alignment: 'column' | 'row', text1: string, headingSourceList: string,
+              options: DragNDropValueObject[], optionLength: 'long' | 'medium' | 'short' | 'very-short',
+              headingTargetLists: string, targetLength: 'medium' | 'short' | 'very-short',
+              targetLabels: TextLabel[] }) => {
+              if (result) resolve(this.createDroplistSection(result));
+            });
+          break;
         default:
           throw Error(`Template name not found: ${templateName}`);
       }
     });
   }
 
-  private createTextSection(config: { text1: string, text2: string,
-    highlightableOrange: boolean, highlightableTurquoise: boolean, highlightableYellow: boolean }): Section {
+  private createTextSection(config: { text1: string, text2: string, highlightableOrange: boolean, highlightableTurquoise: boolean, highlightableYellow: boolean }): Section {
     return new Section({
       elements: [
         this.createElement(
@@ -103,7 +144,7 @@ export class TemplateService {
         this.createElement(
           'text',
           { gridRow: 2, gridColumn: 1 },
-          { text: config.text2, styling: { fontSize: 16 } }
+          { text: config.text2, styling: { fontSize: 14, lineHeight: 100 } }
         )
       ]
     } as SectionProperties);
@@ -124,7 +165,7 @@ export class TemplateService {
           'button',
           { gridRow: 1, gridColumn: 2 },
           {
-            imageSrc: '',
+            imageSrc: TemplateService.tooltipSrc,
             tooltipText: 'Drücke kurz auf den Knopf mit dem Stift. Drücke danach auf den Anfang' +
               'eines Wortes. Halte gedrückt und ziehe im Text so weit, wie du markieren möchtest.',
             tooltipPosition: 'left'
@@ -138,9 +179,7 @@ export class TemplateService {
     } as SectionProperties);
   }
 
-  private createInputSection(config: { text: string, answerCount: number, useTextAreas: boolean,
-    numbering: 'latin' | 'decimal' | 'bullets' | 'none', fieldLength: 'very-small' | 'small' | 'medium' | 'large',
-    expectedCharsCount: number }): Section {
+  private createInputSection(config: { text: string, answerCount: number, useTextAreas: boolean, numbering: 'latin' | 'decimal' | 'bullets' | 'none', fieldLength: 'very-small' | 'small' | 'medium' | 'large', expectedCharsCount: number }): Section {
     const useNumbering = config.answerCount > 1 && config.numbering !== 'none';
 
     const sectionElements: UIElement[] = [
@@ -283,6 +322,349 @@ export class TemplateService {
     } as SectionProperties);
   }
 
+  private createAudioSectionA(config: { src1: string, maxRuns1: number, src2: string, maxRuns2: number, lang: 'german' | 'english' | 'french' | undefined, text: string }) {
+    return new Section({
+      elements: [
+        this.createElement(
+          'text',
+          { gridRow: 1, gridColumn: 1, marginBottom: { value: 10, unit: 'px' } },
+          { text: 'Drücke zuerst auf das Dreieck, dann startet der Hörtext.' }),
+        this.createElement(
+          'audio',
+          { gridRow: 2, gridColumn: 1, marginBottom: { value: 15, unit: 'px' } },
+          {
+            dimensions: { maxWidth: 500 },
+            src: config.src1,
+            player: {
+              maxRuns: config.maxRuns1,
+              ...TemplateService.getAudioSettings()
+            }
+          })
+      ]
+    } as SectionProperties);
+  }
+
+  private createAudioSectionB(config: { src1: string, maxRuns1: number, src2: string, maxRuns2: number, lang: 'german' | 'english' | 'french', text: string }) {
+    return new Section({
+      elements: [
+        this.createElement(
+          'text',
+          { gridRow: 1, gridColumn: 1, marginBottom: { value: 10, unit: 'px' } },
+          { text: `${TemplateService.getAudioTranslation(config.lang, 'instruction')}:` }),
+        this.createElement(
+          'audio',
+          { gridRow: 2, gridColumn: 1, marginBottom: { value: 15, unit: 'px' } },
+          {
+            src: config.src1,
+            dimensions: { maxWidth: 500 },
+            player: {
+              maxRuns: config.maxRuns1,
+              ...TemplateService.getAudioSettings()
+            }
+          }),
+        this.createElement(
+          'text',
+          { gridRow: 3, gridColumn: 1, marginBottom: { value: 20, unit: 'px' } },
+          { text: config.text }),
+        this.createElement(
+          'text',
+          { gridRow: 4, gridColumn: 1, marginBottom: { value: 10, unit: 'px' } },
+          { text: `${TemplateService.getAudioTranslation(config.lang, 'audio')}:` }),
+        this.createElement(
+          'audio',
+          { gridRow: 5, gridColumn: 1, marginBottom: { value: 30, unit: 'px' } },
+          {
+            dimensions: { maxWidth: 500 },
+            src: config.src2,
+            player: {
+              maxRuns: config.maxRuns2,
+              ...TemplateService.getAudioSettings()
+            }
+          })
+      ]
+    } as SectionProperties);
+  }
+
+  private static getAudioTranslation(lang: 'german' | 'english' | 'french', type: 'instruction' | 'audio'): string {
+    switch (lang) {
+      case 'german': return type === 'instruction' ? 'Instruktion' : 'Hörtext';
+      case 'english': return type === 'instruction' ? 'instruction' : 'audio recording';
+      case 'french': return type === 'instruction' ? 'l\'instruction' : 'texte audio';
+      default: throw Error();
+    }
+  }
+
+  private static getAudioSettings(): Record<string, boolean | string | number> {
+    return {
+      muteControl: false,
+      interactiveMuteControl: false,
+      hintLabel: 'Bitte starten.',
+      hintLabelDelay: 5000
+    };
+  }
+
+  private createGeometrySection(config: { text1: string, geometryAppDefinition: string, text2: string, showHelper: boolean }) {
+    const sectionElements: UIElement[] = [
+      this.createElement(
+        'text',
+        { gridRow: 1, gridColumn: 1, marginBottom: { value: 20, unit: 'px' } },
+        { text: config.text1 }),
+      this.createElement(
+        'geometry',
+        { gridRow: 2, gridColumn: 1, marginBottom: { value: 30, unit: 'px' } },
+        {
+          appDefinition: config.geometryAppDefinition,
+          enableShiftDragZoom: false,
+          showZoomButtons: false,
+          showFullscreenButton: false
+        }),
+      this.createElement(
+        'text',
+        { gridRow: 3, gridColumn: 1, marginBottom: { value: 30, unit: 'px' } },
+        {
+          text: 'Erstellt mit GeoGebra, https://www.geogebra.org (es gelten die GeoGebra-Lizenzbedingungen), ' +
+            'Copyright Text, Grafik und Teilaufgaben: IQB e. V., Lizenz: Creative Commons (CC BY). Volltext ' +
+            'unter: https://creativecommons.org/licenses/by/4.0/de/legalcode',
+          styling: { fontSize: 14, lineHeight: 100 }
+        })
+    ];
+
+    if (config.showHelper) {
+      sectionElements.push(
+        this.createElement(
+          'button',
+          { gridRow: 1, gridColumn: 2 },
+          {
+            imageSrc: TemplateService.tooltipSrc,
+            tooltipText: 'Drücke jeweils auf die Stelle, wo eine Linie beginnen und wo sie enden soll. ' +
+              'Zeichne Linie für Linie.',
+            tooltipPosition: 'left'
+          })
+      );
+    }
+
+    return new Section({
+      elements: sectionElements,
+      ...config.showHelper && { autoColumnSize: false },
+      ...config.showHelper && { gridColumnSizes: [{ value: 1, unit: 'fr' }, { value: 45, unit: 'px' }] }
+    } as SectionProperties);
+  }
+
+  private createMathTableSection(config: { operation: 'addition' | 'subtraction' | 'multiplication', terms: string[] }) {
+    const showTooltip = config.operation === 'subtraction';
+    const text = config.operation === 'multiplication' ? '<p style="padding-left: 0px; text-indent: 0px; margin-bottom: 0px; margin-top: 0" indentsize="20">Rechne schriftlich.</p><p style="padding-left: 0px; text-indent: 0px; margin-bottom: 10px; margin-top: 0" indent="0" indentsize="20"><strong>Tipp:</strong></p><p style="padding-left: 0px; text-indent: 0px; margin-bottom: 10px; margin-top: 0" indent="0" indentsize="20"><span style="font-size: 30px"><img style="display: inline-block; height: 1em; vertical-align: middle" src=""></span> Mit dem Plus fügst du eine weitere Zeile zum Rechnen ein.</p><p style="padding-left: 0px; text-indent: 0px; margin-bottom: 0px; margin-top: 0" indent="0" indentsize="20"><span style="font-size: 30px"><img style="display: inline-block; height: 1em; vertical-align: middle" src=""></span> Mit dem Papierkorb kannst du die eingefügte Zeile wieder entfernen.</p>' : 'Rechne schriftlich.';
+    const sectionElements: UIElement[] = [
+      this.createElement(
+        'text',
+        {
+          gridRow: 1,
+          gridColumn: 1,
+          marginBottom: { value: config.operation === 'multiplication' ? 30 : 10, unit: 'px' }
+        },
+        { text }),
+      this.createElement(
+        'math-table',
+        {
+          gridRow: 2,
+          gridColumn: 1,
+          gridRowRange: showTooltip ? 3 : 1,
+          marginBottom: { value: 30, unit: 'px' }
+        },
+        {
+          text: 'Rechne schriftlich.',
+          operation: config.operation,
+          terms: config.terms,
+          inputAssistancePreset: 'numbers',
+          inputAssistanceFloatingStartPosition: 'endCenter',
+          hasArrowKeys: true
+        })
+    ];
+    if (showTooltip) {
+      sectionElements.push(
+        this.createElement(
+          'button',
+          { gridRow: 2, gridColumn: 2 },
+          {
+            imageSrc: TemplateService.tooltipSrc,
+            tooltipText: 'In den kleinen Feldern oberhalb der Rechnung kannst du mehrstellige Überträge eintragen. ' +
+              'Wenn du einen Übertrag durchstreichen möchtest, drücke zweimal hintereinander auf das jeweilige Feld.',
+            tooltipPosition: 'left'
+          })
+      );
+    }
+    return new Section({
+      elements: sectionElements,
+      ...showTooltip && { autoColumnSize: false },
+      ...showTooltip && { gridColumnSizes: [{ value: 1, unit: 'fr' }, { value: 45, unit: 'px' }] }
+    } as SectionProperties);
+  }
+
+  private createDroplistSection(config: {
+    alignment: 'column' | 'row', text1: string, headingSourceList: string, options: DragNDropValueObject[],
+    optionLength: 'long' | 'medium' | 'short' | 'very-short', headingTargetLists: string,
+    targetLength: 'medium' | 'short' | 'very-short', targetLabels: TextLabel[] })
+  {
+    const sectionElements: UIElement[] = [
+      this.createElement(
+        'text',
+        {
+          gridRow: 1,
+          gridColumn: 1,
+          gridColumnRange: 2,
+          marginBottom: { value: 20, unit: 'px' }
+        },
+        { text: config.text1 }),
+      this.createElement(
+        'text',
+        {
+          gridRow: 2,
+          gridColumn: 1,
+          gridColumnRange: 2,
+          marginBottom: { value: 20, unit: 'px' }
+        },
+        { text: config.headingSourceList }),
+      this.createElement(
+        'drop-list',
+        {
+          gridRow: 3,
+          gridColumn: config.alignment === 'column' ? 1 : 3,
+          ...config.alignment === 'row' && { gridRowRange: config.targetLabels.length },
+          gridColumnRange: config.alignment === 'column' ? 2 : 1,
+          marginBottom: { value: config.alignment === 'column' ? 20 : 40, unit: 'px' },
+          ...config.alignment === 'row' && { marginLeft: { value: 5, unit: 'px' } }
+        },
+        {
+          dimensions: { minHeight: 58 },
+          value: config.options,
+          orientation: config.alignment === 'column' ? 'flex' : 'vertical',
+          highlightReceivingDropList: true
+        }),
+      this.createElement(
+        'text',
+        {
+          gridRow: config.alignment === 'column' ? 4 : 2,
+          gridColumn: config.alignment === 'column' ? 1 : 3,
+          gridColumnRange: 2,
+          marginBottom: { value: 20, unit: 'px' }
+        },
+        { text: config.headingTargetLists })
+    ];
+    const targetListOffset = config.alignment === 'column' ? 5 : 3;
+    config.targetLabels.forEach((label: TextLabel, i: number) => {
+      sectionElements.push(this.createElement(
+        'text',
+        {
+          gridRow: i + targetListOffset,
+          gridColumn: 1,
+          marginTop: { value: 16, unit: 'px' },
+          marginRight: { value: 5, unit: 'px' }
+        },
+        { text: label.text })
+      );
+      sectionElements.push(this.createElement(
+        'drop-list',
+        {
+          gridRow: i + targetListOffset,
+          gridColumn: 2,
+          marginBottom: { value: i === (config.targetLabels.length - 1) ? 40 : 5, unit: 'px' }
+        },
+        {
+          dimensions: { minHeight: 58 },
+          orientation: 'vertical',
+          onlyOneItem: true,
+          allowReplacement: true,
+          highlightReceivingDropList: true
+        })
+      );
+    });
+    return new Section({
+      elements: sectionElements,
+      autoColumnSize: false,
+      gridColumnSizes: config.alignment === 'column' ?
+        TemplateService.getDrolistColSizesVertical(config.optionLength, config.targetLength) :
+        TemplateService.getDrolistColSizesHorizontal(
+          config.optionLength as 'medium' | 'short' | 'very-short', config.targetLength)
+    } as SectionProperties);
+  }
+
+  private static getDrolistColSizesVertical(optionLength: 'long' | 'medium' | 'short' | 'very-short',
+                                            targetLength: 'long' | 'medium' | 'short' | 'very-short')
+    : [ { value: number; unit: string }, { value: number; unit: string } ]
+  {
+    switch (optionLength) {
+      case 'long':
+        switch (targetLength) {
+          case 'long': return [{ value: 4, unit: 'fr' }, { value: 5, unit: 'fr' }];
+          case 'medium': return [{ value: 3, unit: 'fr' }, { value: 5, unit: 'fr' }];
+          case 'short': return [{ value: 1, unit: 'fr' }, { value: 2, unit: 'fr' }];
+          case 'very-short': return [{ value: 125, unit: 'px' }, { value: 1, unit: 'fr' }];
+          default: throw Error(`Unknown targetLength: ${targetLength}`);
+        }
+      case 'medium':
+        switch (targetLength) {
+          case 'long': return [{ value: 5, unit: 'fr' }, { value: 4, unit: 'fr' }];
+          case 'medium': return [{ value: 4, unit: 'fr' }, { value: 5, unit: 'fr' }];
+          case 'short': return [{ value: 3, unit: 'fr' }, { value: 5, unit: 'fr' }];
+          case 'very-short': return [{ value: 125, unit: 'px' }, { value: 1, unit: 'fr' }];
+          default: throw Error(`Unknown targetLength: ${targetLength}`);
+        }
+      case 'short':
+        switch (targetLength) {
+          case 'long':
+            return [{ value: 1, unit: 'fr' }, { value: 125, unit: 'px' }];
+          case 'medium':
+            return [{ value: 1, unit: 'fr' }, { value: 125, unit: 'px' }];
+          case 'short':
+            return [{ value: 250, unit: 'px' }, { value: 1, unit: 'fr' }];
+          case 'very-short':
+            return [{ value: 125, unit: 'px' }, { value: 1, unit: 'fr' }];
+          default:
+            throw Error(`Unknown targetLength: ${targetLength}`);
+        }
+      case 'very-short':
+        switch (targetLength) {
+          case 'long': return [{ value: 1, unit: 'fr' }, { value: 125, unit: 'px' }];
+          case 'medium': return [{ value: 1, unit: 'fr' }, { value: 125, unit: 'px' }];
+          case 'short': return [{ value: 250, unit: 'px' }, { value: 1, unit: 'fr' }];
+          case 'very-short': return [{ value: 125, unit: 'px' }, { value: 1, unit: 'fr' }];
+          default: throw Error(`Unknown targetLength: ${targetLength}`);
+        }
+      default: throw Error(`Unknown optionLength: ${optionLength}`);
+    }
+  }
+
+  private static getDrolistColSizesHorizontal(optionLength: 'medium' | 'short' | 'very-short',
+                                              targetLength: 'medium' | 'short' | 'very-short')
+    : { value: number; unit: string }[]
+  {
+    switch (optionLength) {
+      case 'medium':
+        switch (targetLength) {
+          case 'medium': return [{ value: 4, unit: 'fr' }, { value: 5, unit: 'fr' }, { value: 5, unit: 'fr' }];
+          case 'short': return [{ value: 3, unit: 'fr' }, { value: 5, unit: 'fr' }, { value: 5, unit: 'fr' }];
+          case 'very-short': return [{ value: 125, unit: 'px' }, { value: 1, unit: 'fr' }, { value: 1, unit: 'fr' }];
+          default: throw Error(`Unknown targetLength: ${targetLength}`);
+        }
+      case 'short':
+        switch (targetLength) {
+          case 'medium': return [{ value: 1, unit: 'fr' }, { value: 250, unit: 'px' }, { value: 250, unit: 'px' }];
+          case 'short': return [{ value: 250, unit: 'px' }, { value: 1, unit: 'fr' }, { value: 1, unit: 'fr' }];
+          case 'very-short':
+            return [{ value: 125, unit: 'px' }, { value: 250, unit: 'px' }, { value: 250, unit: 'px' }];
+          default: throw Error(`Unknown targetLength: ${targetLength}`);
+        }
+      case 'very-short':
+        switch (targetLength) {
+          case 'medium': return [{ value: 1, unit: 'fr' }, { value: 125, unit: 'px' }, { value: 125, unit: 'px' }];
+          case 'short': return [{ value: 250, unit: 'px' }, { value: 125, unit: 'px' }, { value: 1, unit: 'fr' }];
+          case 'very-short':
+            return [{ value: 125, unit: 'px' }, { value: 125, unit: 'px' }, { value: 125, unit: 'px' }];
+          default: throw Error(`Unknown targetLength: ${targetLength}`);
+        }
+      default: throw Error(`Unknown optionLength: ${optionLength}`);
+    }
+  }
+
   private createElement(elType: UIElementType, coords: Partial<PositionProperties>,
                         params?: Record<string, any>): PositionedUIElement {
     return ElementFactory.createElement({