Very basic but dynamically-generated config form

This commit is contained in:
shamoon
2023-12-20 23:43:44 -08:00
parent 6e03d9848c
commit 937f5e3ffa
6 changed files with 339 additions and 154 deletions

View File

@@ -1,116 +1,41 @@
<pngx-page-header title="Configuration" i18n-title></pngx-page-header>
<form [formGroup]="configForm" (ngSubmit)="saveConfig()" class="pb-4">
<form [formGroup]="configForm" (ngSubmit)="saveConfig()" class="pb-4">
<h4 i18n>OCR Settings</h4>
<div class="row mb-3">
<div class="col-md-3 col-form-label pt-0">
<span i18n>Output Type</span>
</div>
<div class="col">
<pngx-input-select [items]="ConfigChoices.output_type" formControlName="output_type" [allowNull]="true"></pngx-input-select>
</div>
</div>
<div class="row mb-3">
<div class="col-md-3 col-form-label pt-0">
<span i18n>Pages</span>
</div>
<div class="col">
<pngx-input-number formControlName="pages" [showAdd]="false"></pngx-input-number>
</div>
</div>
<div class="row mb-3">
<div class="col-md-3 col-form-label pt-0">
<span i18n>Mode</span>
</div>
<div class="col">
<pngx-input-select [items]="ConfigChoices.mode" formControlName="mode" [allowNull]="true"></pngx-input-select>
</div>
</div>
<div class="row mb-3">
<div class="col-md-3 col-form-label pt-0">
<span i18n>Skip Archive File</span>
</div>
<div class="col">
<pngx-input-select [items]="ConfigChoices.skip_archive_file" formControlName="skip_archive_file" [allowNull]="true"></pngx-input-select>
</div>
</div>
<div class="row mb-3">
<div class="col-md-3 col-form-label pt-0">
<span i18n>Image DPI</span>
</div>
<div class="col">
<pngx-input-number formControlName="image_dpi" [showAdd]="false"></pngx-input-number>
</div>
</div>
<div class="row mb-3">
<div class="col-md-3 col-form-label pt-0">
<span i18n>Clean</span>
</div>
<div class="col">
<pngx-input-select [items]="ConfigChoices.unpaper_clean" formControlName="unpaper_clean" [allowNull]="true"></pngx-input-select>
</div>
</div>
<div class="row mb-3">
<div class="col-md-3 col-form-label pt-0">
<span i18n>Deskew</span>
</div>
<div class="col">
<pngx-input-check formControlName="deskew"></pngx-input-check>
</div>
</div>
<div class="row mb-3">
<div class="col-md-3 col-form-label pt-0">
<span i18n>Rotate Pages</span>
</div>
<div class="col">
<pngx-input-check formControlName="rotate_pages"></pngx-input-check>
</div>
</div>
<div class="row mb-3">
<div class="col-md-3 col-form-label pt-0">
<span i18n>Rotate Pages Threshold</span>
</div>
<div class="col">
<pngx-input-number formControlName="rotate_pages_threshold" [showAdd]="false"></pngx-input-number>
</div>
</div>
<div class="row mb-3">
<div class="col-md-3 col-form-label pt-0">
<span i18n>Max Image Pixels</span>
</div>
<div class="col">
<pngx-input-number formControlName="max_image_pixels" [showAdd]="false"></pngx-input-number>
</div>
</div>
<div class="row mb-3">
<div class="col-md-3 col-form-label pt-0">
<span i18n>Color Conversion Strategy</span>
</div>
<div class="col">
<pngx-input-select [items]="ConfigChoices.color_conversion_strategy" formControlName="color_conversion_strategy" [allowNull]="true"></pngx-input-select>
</div>
</div>
<div class="row mb-3">
<div class="col-md-3 col-form-label pt-0">
<span i18n>OCR Arguments</span>
</div>
<div class="col">
<pngx-input-text formControlName="user_args"></pngx-input-text>
</div>
</div>
<button type="submit" class="btn btn-primary mb-2" [disabled]="loading ||(isDirty$ | async) === false" i18n>Save</button>
</form>
<ul ngbNav #nav="ngbNav" class="nav-tabs">
@for (category of optionCategories; track category) {
<li [ngbNavItem]="category">
<a ngbNavLink i18n>{{category}}</a>
<ng-template ngbNavContent>
<div class="p-3">
@for (option of getCategoryOptions(category); track option.key) {
<div class="row mb-3">
<div class="col-md-3 col-form-label pt-0">
<span i18n>{{option.title}}</span>
<p>See <a [href]="getDocsUrl(option.config_key)" target="_blank" referrerpolicy="no-referrer">{{option.config_key}}</a></p>
</div>
<div class="col">
@switch (option.type) {
@case (ConfigOptionType.Select) { <pngx-input-select [formControlName]="option.key" [items]="option.choices" [allowNull]="true"></pngx-input-select> }
@case (ConfigOptionType.Number) { <pngx-input-number [formControlName]="option.key" [showAdd]="false"></pngx-input-number> }
@case (ConfigOptionType.Boolean) { <pngx-input-check [formControlName]="option.key"></pngx-input-check> }
@case (ConfigOptionType.String) { <pngx-input-text [formControlName]="option.key"></pngx-input-text> }
}
</div>
</div>
}
</div>
</ng-template>
</li>
}
</ul>
<div [ngbNavOutlet]="nav" class="border-start border-end border-bottom p-3 mb-3 shadow-sm"></div>
<div class="btn-toolbar" role="toolbar">
<div class="btn-group me-2">
<button type="button" (click)="discardChanges()" class="btn btn-secondary" [disabled]="loading || (isDirty$ | async) === false" i18n>Discard</button>
</div>
<div class="btn-group">
<button type="submit" class="btn btn-primary" [disabled]="loading || (isDirty$ | async) === false" i18n>Save</button>
</div>
</div>
</form>