From 2d9798d31f286fa7f72436af1e40b17e3185c896 Mon Sep 17 00:00:00 2001 From: Dirk Peter <67102395+dirk-peter-sag@users.noreply.github.com> Date: Mon, 27 May 2024 17:58:18 +0200 Subject: [PATCH] #3 adds asset selection Co-authored-by: Dirk Peter --- .../reminder-modal.component.html | 19 +++++--- .../reminder-modal.component.less | 9 ++++ .../reminder-modal.component.ts | 46 ++++++++++++------- plugin/reminder-plugin.module.ts | 2 + 4 files changed, 52 insertions(+), 24 deletions(-) create mode 100644 plugin/components/reminder-modal/reminder-modal.component.less diff --git a/plugin/components/reminder-modal/reminder-modal.component.html b/plugin/components/reminder-modal/reminder-modal.component.html index 7eccc35..b75687d 100644 --- a/plugin/components/reminder-modal/reminder-modal.component.html +++ b/plugin/components/reminder-modal/reminder-modal.component.html @@ -4,19 +4,24 @@

Create a Reminder

+ diff --git a/plugin/components/reminder-modal/reminder-modal.component.less b/plugin/components/reminder-modal/reminder-modal.component.less new file mode 100644 index 0000000..1cd9979 --- /dev/null +++ b/plugin/components/reminder-modal/reminder-modal.component.less @@ -0,0 +1,9 @@ +:host ::ng-deep { + .miller-view-wrapper.p-t-72 { + padding-top: 0 !important; + + &:has(.miller-column__header) { + padding-top: 72px !important; + } + } +} diff --git a/plugin/components/reminder-modal/reminder-modal.component.ts b/plugin/components/reminder-modal/reminder-modal.component.ts index f230f7b..34f6ed3 100644 --- a/plugin/components/reminder-modal/reminder-modal.component.ts +++ b/plugin/components/reminder-modal/reminder-modal.component.ts @@ -12,19 +12,20 @@ import { Reminder, ReminderStatus, REMINDER_TEXT_LENGTH, REMINDER_TYPE } from '. @Component({ selector: 'c8y-reminder-modal', - templateUrl: './reminder-modal.component.html' + templateUrl: './reminder-modal.component.html', + styleUrls: ['./reminder-modal.component.less'] }) export class ReminderModalComponent implements OnInit { // TODO selectable context isLoading = false; - asset!: IManagedObject; + asset!: Partial; form = new FormGroup({}); reminder: Partial = { - source: { - id: undefined, - name: undefined - }, + // source: { + // id: undefined, + // name: undefined + // }, text: undefined, time: undefined, type: REMINDER_TYPE @@ -33,15 +34,15 @@ export class ReminderModalComponent implements OnInit { fields: FormlyFieldConfig[] = [ { fieldGroup: [ - { - key: 'source.name', - type: 'input', - props: { - label: this.translateService.instant('Attach to'), - required: true, - disabled: true - } - }, + // { + // key: 'source.name', + // type: 'input', + // props: { + // label: this.translateService.instant('Attach to'), + // required: true, + // disabled: true + // } + // }, { key: 'text', type: 'input', @@ -82,12 +83,19 @@ export class ReminderModalComponent implements OnInit { this.bsModalRef.hide(); } + assetSelected(asset: Partial): void { + this.asset = { + id: asset.id, + name: asset.name + }; + } + async submit(): Promise { this.isLoading = true; const reminder: IEvent = { source: { - id: `${this.reminder.source.id}` + id: `${this.asset.id}` }, type: REMINDER_TYPE, time: moment(this.reminder.time).toISOString(), @@ -130,7 +138,11 @@ export class ReminderModalComponent implements OnInit { private getAssetFromRoute(route: ActivatedRouteSnapshot): IManagedObject { if (!route) console.error('No Route provided'); - else return this.recursiveContextSearch(route); + else { + const mo = this.recursiveContextSearch(route); + + if (has(mo, 'c8y_IsDevice') || has(mo, 'c8y_IsDeviceGroup')) return mo; + } return undefined; } } diff --git a/plugin/reminder-plugin.module.ts b/plugin/reminder-plugin.module.ts index 1c5420c..8150305 100644 --- a/plugin/reminder-plugin.module.ts +++ b/plugin/reminder-plugin.module.ts @@ -2,6 +2,7 @@ import { CommonModule } from '@angular/common'; import { NgModule } from '@angular/core'; import { RouterModule } from '@angular/router'; import { CoreModule, EventRealtimeService, hookAction } from '@c8y/ngx-components'; +import { AssetSelectorModule } from '@c8y/ngx-components/assets-navigator'; import { FormlyModule } from '@ngx-formly/core'; import { MomentModule } from 'ngx-moment'; import { ReminderDrawerComponent } from './components/reminder-drawer/reminder-drawer.component'; @@ -16,6 +17,7 @@ import { ReminderService } from './services/reminder.service'; CommonModule, CoreModule, RouterModule, + AssetSelectorModule, MomentModule, FormlyModule.forChild({ types: [{ name: 'time', component: TimeFieldType }]