@c8y/ngx-components 1018.503.45 → 1018.503.50
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/context-dashboard/add-dashboard.factory.d.ts +3 -2
- package/context-dashboard/context-dashboard.model.d.ts +16 -1
- package/context-dashboard/context-dashboard.service.d.ts +4 -2
- package/context-dashboard/report-dashboard/report-dashboard-list.component.d.ts +3 -2
- package/core/common/ApplicationOptions.d.ts +2 -2
- package/core/login/credentials.component.d.ts +1 -3
- package/core/login/login.component.d.ts +3 -1
- package/esm2020/context-dashboard/add-dashboard.factory.mjs +17 -5
- package/esm2020/context-dashboard/context-dashboard.component.mjs +24 -4
- package/esm2020/context-dashboard/context-dashboard.model.mjs +19 -4
- package/esm2020/context-dashboard/context-dashboard.service.mjs +21 -6
- package/esm2020/context-dashboard/dashboard-availability.component.mjs +3 -3
- package/esm2020/context-dashboard/report-dashboard/report-dashboard-list.component.mjs +21 -6
- package/esm2020/core/common/ApplicationOptions.mjs +1 -1
- package/esm2020/core/login/credentials.component.mjs +15 -18
- package/esm2020/core/login/login.component.mjs +18 -15
- package/esm2020/widgets/implementations/device-control-message/device-control-message-widget-view/device-control-message-widget-view.component.mjs +17 -9
- package/esm2020/widgets/implementations/map/map-widget.component.mjs +26 -11
- package/esm2020/widgets/implementations/three-d-rotation/lazy-box-model/lazy-load-box-model.mjs +3 -3
- package/esm2020/widgets/implementations/three-d-rotation/lazy-phone-model/lazy-load-phone-model.mjs +3 -3
- package/fesm2015/c8y-ngx-components-context-dashboard.mjs +91 -15
- package/fesm2015/c8y-ngx-components-context-dashboard.mjs.map +1 -1
- package/fesm2015/c8y-ngx-components-widgets-implementations-device-control-message.mjs +19 -8
- package/fesm2015/c8y-ngx-components-widgets-implementations-device-control-message.mjs.map +1 -1
- package/fesm2015/c8y-ngx-components-widgets-implementations-map.mjs +37 -20
- package/fesm2015/c8y-ngx-components-widgets-implementations-map.mjs.map +1 -1
- package/fesm2015/c8y-ngx-components-widgets-implementations-three-d-rotation-lazy-box-model.mjs +2 -2
- package/fesm2015/c8y-ngx-components-widgets-implementations-three-d-rotation-lazy-box-model.mjs.map +1 -1
- package/fesm2015/c8y-ngx-components-widgets-implementations-three-d-rotation-lazy-phone-model.mjs +2 -2
- package/fesm2015/c8y-ngx-components-widgets-implementations-three-d-rotation-lazy-phone-model.mjs.map +1 -1
- package/fesm2015/c8y-ngx-components.mjs +11 -11
- package/fesm2015/c8y-ngx-components.mjs.map +1 -1
- package/fesm2020/c8y-ngx-components-context-dashboard.mjs +91 -15
- package/fesm2020/c8y-ngx-components-context-dashboard.mjs.map +1 -1
- package/fesm2020/c8y-ngx-components-widgets-implementations-device-control-message.mjs +15 -8
- package/fesm2020/c8y-ngx-components-widgets-implementations-device-control-message.mjs.map +1 -1
- package/fesm2020/c8y-ngx-components-widgets-implementations-map.mjs +25 -13
- package/fesm2020/c8y-ngx-components-widgets-implementations-map.mjs.map +1 -1
- package/fesm2020/c8y-ngx-components-widgets-implementations-three-d-rotation-lazy-box-model.mjs +2 -2
- package/fesm2020/c8y-ngx-components-widgets-implementations-three-d-rotation-lazy-box-model.mjs.map +1 -1
- package/fesm2020/c8y-ngx-components-widgets-implementations-three-d-rotation-lazy-phone-model.mjs +2 -2
- package/fesm2020/c8y-ngx-components-widgets-implementations-three-d-rotation-lazy-phone-model.mjs.map +1 -1
- package/fesm2020/c8y-ngx-components.mjs +11 -11
- package/fesm2020/c8y-ngx-components.mjs.map +1 -1
- package/package.json +1 -1
- package/widgets/implementations/device-control-message/device-control-message-widget-view/device-control-message-widget-view.component.d.ts +4 -2
- package/widgets/implementations/map/map-widget.component.d.ts +7 -4
- package/widgets/implementations/three-d-rotation/lazy-box-model/lazy-load-box-model.d.ts +79 -1
- package/widgets/implementations/three-d-rotation/lazy-phone-model/lazy-load-phone-model.d.ts +76 -1
- package/esm2020/widgets/implementations/three-d-rotation/box-model/c8y-ngx-components-widgets-implementations-three-d-rotation-box-model.mjs +0 -5
- package/esm2020/widgets/implementations/three-d-rotation/box-model/index.mjs +0 -4
- package/esm2020/widgets/implementations/three-d-rotation/phone-model/c8y-ngx-components-widgets-implementations-three-d-rotation-phone-model.mjs +0 -5
- package/esm2020/widgets/implementations/three-d-rotation/phone-model/index.mjs +0 -4
- package/fesm2015/c8y-ngx-components-widgets-implementations-three-d-rotation-box-model.mjs +0 -10
- package/fesm2015/c8y-ngx-components-widgets-implementations-three-d-rotation-box-model.mjs.map +0 -1
- package/fesm2015/c8y-ngx-components-widgets-implementations-three-d-rotation-phone-model.mjs +0 -10
- package/fesm2015/c8y-ngx-components-widgets-implementations-three-d-rotation-phone-model.mjs.map +0 -1
- package/fesm2020/c8y-ngx-components-widgets-implementations-three-d-rotation-box-model.mjs +0 -10
- package/fesm2020/c8y-ngx-components-widgets-implementations-three-d-rotation-box-model.mjs.map +0 -1
- package/fesm2020/c8y-ngx-components-widgets-implementations-three-d-rotation-phone-model.mjs +0 -10
- package/fesm2020/c8y-ngx-components-widgets-implementations-three-d-rotation-phone-model.mjs.map +0 -1
- package/widgets/implementations/three-d-rotation/box-model/index.d.ts +0 -1
- package/widgets/implementations/three-d-rotation/phone-model/index.d.ts +0 -1
|
@@ -6,29 +6,32 @@ import { LoginViews } from './login.model';
|
|
|
6
6
|
import { AlertService } from '../alert/alert.service';
|
|
7
7
|
import { gettext } from '../i18n/gettext';
|
|
8
8
|
import { CredentialsFromQueryParamsService } from './credentials-from-query-params.service';
|
|
9
|
+
import { AppStateService } from '../common/ui-state.service';
|
|
9
10
|
import * as i0 from "@angular/core";
|
|
10
11
|
import * as i1 from "./login.service";
|
|
11
12
|
import * as i2 from "../common/options.service";
|
|
12
13
|
import * as i3 from "../alert/alert.service";
|
|
13
14
|
import * as i4 from "./credentials-from-query-params.service";
|
|
14
|
-
import * as i5 from "
|
|
15
|
-
import * as i6 from "
|
|
16
|
-
import * as i7 from "../authentication/
|
|
17
|
-
import * as i8 from "../
|
|
18
|
-
import * as i9 from "
|
|
19
|
-
import * as i10 from "./
|
|
20
|
-
import * as i11 from "./
|
|
21
|
-
import * as i12 from "./
|
|
22
|
-
import * as i13 from "./
|
|
15
|
+
import * as i5 from "../common/ui-state.service";
|
|
16
|
+
import * as i6 from "@angular/common";
|
|
17
|
+
import * as i7 from "../authentication/sms-challenge.component";
|
|
18
|
+
import * as i8 from "../authentication/provide-phone-number.component";
|
|
19
|
+
import * as i9 from "../alert/alert-outlet.component";
|
|
20
|
+
import * as i10 from "./recover-password.component";
|
|
21
|
+
import * as i11 from "./change-password.component";
|
|
22
|
+
import * as i12 from "./credentials.component";
|
|
23
|
+
import * as i13 from "./totp-auth.component";
|
|
24
|
+
import * as i14 from "./tenant-id-setup.component";
|
|
23
25
|
export class LoginComponent {
|
|
24
26
|
/**
|
|
25
27
|
* Just DI.
|
|
26
28
|
*/
|
|
27
|
-
constructor(loginService, options, alert, credentialsFromQueryParamsService) {
|
|
29
|
+
constructor(loginService, options, alert, credentialsFromQueryParamsService, ui) {
|
|
28
30
|
this.loginService = loginService;
|
|
29
31
|
this.options = options;
|
|
30
32
|
this.alert = alert;
|
|
31
33
|
this.credentialsFromQueryParamsService = credentialsFromQueryParamsService;
|
|
34
|
+
this.ui = ui;
|
|
32
35
|
this.currentView = LoginViews.None;
|
|
33
36
|
this.LOGIN_VIEWS = LoginViews;
|
|
34
37
|
this.disabled = false;
|
|
@@ -111,15 +114,15 @@ export class LoginComponent {
|
|
|
111
114
|
return token;
|
|
112
115
|
}
|
|
113
116
|
}
|
|
114
|
-
LoginComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: LoginComponent, deps: [{ token: i1.LoginService }, { token: i2.OptionsService }, { token: i3.AlertService }, { token: i4.CredentialsFromQueryParamsService }], target: i0.ɵɵFactoryTarget.Component });
|
|
115
|
-
LoginComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: LoginComponent, selector: "c8y-login", inputs: { name: "name" }, host: { listeners: { "keyup": "onkeyup($event)" } }, ngImport: i0, template: "<div\n class=\"loading card fadeInUp animated shadow5\"\n *ngIf=\"currentView !== LOGIN_VIEWS.None\"\n [ngSwitch]=\"currentView\"\n>\n <main class=\"card-block p-b-0\">\n <span class=\"mainlogo\"></span>\n\n <c8y-credentials\n *ngSwitchCase=\"LOGIN_VIEWS.Credentials\"\n (onChangeView)=\"handleLoginTemplate($event)\"\n [loginViewParams]=\"loginViewParams\"\n ></c8y-credentials>\n <c8y-recover-password\n *ngSwitchCase=\"LOGIN_VIEWS.RecoverPassword\"\n (onChangeView)=\"handleLoginTemplate($event)\"\n ></c8y-recover-password>\n <c8y-change-password\n *ngSwitchCase=\"LOGIN_VIEWS.ChangePassword\"\n (onChangeView)=\"handleLoginTemplate($event)\"\n [credentials]=\"credentials\"\n ></c8y-change-password>\n <c8y-totp-auth\n *ngSwitchCase=\"LOGIN_VIEWS.TotpChallenge\"\n (onCancel)=\"reset()\"\n [view]=\"currentView\"\n [credentials]=\"credentials\"\n ></c8y-totp-auth>\n <c8y-totp-auth\n *ngSwitchCase=\"LOGIN_VIEWS.TotpSetup\"\n (onCancel)=\"reset()\"\n [view]=\"currentView\"\n [credentials]=\"credentials\"\n ></c8y-totp-auth>\n <c8y-sms-challenge\n *ngSwitchCase=\"LOGIN_VIEWS.SmsChallenge\"\n (onCancel)=\"reset()\"\n [credentials]=\"credentials\"\n ></c8y-sms-challenge>\n\n <c8y-provide-phone-number\n *ngSwitchCase=\"LOGIN_VIEWS.ProvidePhoneNumber\"\n (onCancel)=\"reset()\"\n (onChangeView)=\"handleLoginTemplate($event)\"\n [credentials]=\"credentials\"\n ></c8y-provide-phone-number>\n <c8y-tenant-id-setup\n *ngSwitchCase=\"LOGIN_VIEWS.TenantIdSetup\"\n (onChangeView)=\"handleLoginTemplate($event)\"\n ></c8y-tenant-id-setup>\n\n <c8y-alert-outlet position=\"static\"></c8y-alert-outlet>\n </main>\n</div>\n", dependencies: [{ kind: "directive", type:
|
|
117
|
+
LoginComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: LoginComponent, deps: [{ token: i1.LoginService }, { token: i2.OptionsService }, { token: i3.AlertService }, { token: i4.CredentialsFromQueryParamsService }, { token: i5.AppStateService }], target: i0.ɵɵFactoryTarget.Component });
|
|
118
|
+
LoginComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: LoginComponent, selector: "c8y-login", inputs: { name: "name" }, host: { listeners: { "keyup": "onkeyup($event)" } }, ngImport: i0, template: "<div\n class=\"loading card fadeInUp animated shadow5\"\n *ngIf=\"currentView !== LOGIN_VIEWS.None\"\n [ngSwitch]=\"currentView\"\n>\n <main class=\"card-block p-b-0\">\n <span class=\"mainlogo\"></span>\n\n <c8y-credentials\n *ngSwitchCase=\"LOGIN_VIEWS.Credentials\"\n (onChangeView)=\"handleLoginTemplate($event)\"\n [loginViewParams]=\"loginViewParams\"\n ></c8y-credentials>\n <c8y-recover-password\n *ngSwitchCase=\"LOGIN_VIEWS.RecoverPassword\"\n (onChangeView)=\"handleLoginTemplate($event)\"\n ></c8y-recover-password>\n <c8y-change-password\n *ngSwitchCase=\"LOGIN_VIEWS.ChangePassword\"\n (onChangeView)=\"handleLoginTemplate($event)\"\n [credentials]=\"credentials\"\n ></c8y-change-password>\n <c8y-totp-auth\n *ngSwitchCase=\"LOGIN_VIEWS.TotpChallenge\"\n (onCancel)=\"reset()\"\n [view]=\"currentView\"\n [credentials]=\"credentials\"\n ></c8y-totp-auth>\n <c8y-totp-auth\n *ngSwitchCase=\"LOGIN_VIEWS.TotpSetup\"\n (onCancel)=\"reset()\"\n [view]=\"currentView\"\n [credentials]=\"credentials\"\n ></c8y-totp-auth>\n <c8y-sms-challenge\n *ngSwitchCase=\"LOGIN_VIEWS.SmsChallenge\"\n (onCancel)=\"reset()\"\n [credentials]=\"credentials\"\n ></c8y-sms-challenge>\n\n <c8y-provide-phone-number\n *ngSwitchCase=\"LOGIN_VIEWS.ProvidePhoneNumber\"\n (onCancel)=\"reset()\"\n (onChangeView)=\"handleLoginTemplate($event)\"\n [credentials]=\"credentials\"\n ></c8y-provide-phone-number>\n <c8y-tenant-id-setup\n *ngSwitchCase=\"LOGIN_VIEWS.TenantIdSetup\"\n (onChangeView)=\"handleLoginTemplate($event)\"\n ></c8y-tenant-id-setup>\n\n <div\n class=\"text-center m-t-8\"\n *ngIf=\"!!(ui.state$ | async).loginExtraLink\"\n >\n <div *ngIf=\"!!(ui.state$ | async).loginExtraLink.length; else singleExtraLink\">\n <a\n class=\"small d-block m-t-8\"\n title=\"{{ link.label }}\"\n role=\"button\"\n *ngFor=\"let link of (ui.state$ | async).loginExtraLink\"\n [href]=\"link.url\"\n >\n {{ link.label }}\n </a>\n </div>\n <ng-template #singleExtraLink>\n <a\n class=\"small\"\n title=\"{{ (ui.state$ | async).loginExtraLink.label }}\"\n role=\"button\"\n [href]=\"(ui.state$ | async).loginExtraLink.url\"\n >\n {{ (ui.state$ | async).loginExtraLink.label }}\n </a>\n </ng-template>\n </div>\n\n <c8y-alert-outlet position=\"static\"></c8y-alert-outlet>\n </main>\n</div>\n", dependencies: [{ kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i6.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: i7.SmsChallengeComponent, selector: "c8y-sms-challenge", inputs: ["credentials"], outputs: ["onCancel"] }, { kind: "component", type: i8.ProvidePhoneNumberComponent, selector: "c8y-provide-phone-number", inputs: ["credentials"], outputs: ["onCancel", "onChangeView"] }, { kind: "component", type: i9.AlertOutletComponent, selector: "c8y-alert-outlet" }, { kind: "component", type: i10.RecoverPasswordComponent, selector: "c8y-recover-password", outputs: ["onChangeView"] }, { kind: "component", type: i11.ChangePasswordComponent, selector: "c8y-change-password", inputs: ["credentials"], outputs: ["onChangeView"] }, { kind: "component", type: i12.CredentialsComponent, selector: "c8y-credentials", inputs: ["loginViewParams"], outputs: ["onChangeView"] }, { kind: "component", type: i13.TotpAuthComponent, selector: "c8y-totp-auth", inputs: ["credentials", "view"], outputs: ["onCancel"] }, { kind: "component", type: i14.TenantIdSetupComponent, selector: "c8y-tenant-id-setup", outputs: ["onChangeView"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }] });
|
|
116
119
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: LoginComponent, decorators: [{
|
|
117
120
|
type: Component,
|
|
118
|
-
args: [{ selector: 'c8y-login', template: "<div\n class=\"loading card fadeInUp animated shadow5\"\n *ngIf=\"currentView !== LOGIN_VIEWS.None\"\n [ngSwitch]=\"currentView\"\n>\n <main class=\"card-block p-b-0\">\n <span class=\"mainlogo\"></span>\n\n <c8y-credentials\n *ngSwitchCase=\"LOGIN_VIEWS.Credentials\"\n (onChangeView)=\"handleLoginTemplate($event)\"\n [loginViewParams]=\"loginViewParams\"\n ></c8y-credentials>\n <c8y-recover-password\n *ngSwitchCase=\"LOGIN_VIEWS.RecoverPassword\"\n (onChangeView)=\"handleLoginTemplate($event)\"\n ></c8y-recover-password>\n <c8y-change-password\n *ngSwitchCase=\"LOGIN_VIEWS.ChangePassword\"\n (onChangeView)=\"handleLoginTemplate($event)\"\n [credentials]=\"credentials\"\n ></c8y-change-password>\n <c8y-totp-auth\n *ngSwitchCase=\"LOGIN_VIEWS.TotpChallenge\"\n (onCancel)=\"reset()\"\n [view]=\"currentView\"\n [credentials]=\"credentials\"\n ></c8y-totp-auth>\n <c8y-totp-auth\n *ngSwitchCase=\"LOGIN_VIEWS.TotpSetup\"\n (onCancel)=\"reset()\"\n [view]=\"currentView\"\n [credentials]=\"credentials\"\n ></c8y-totp-auth>\n <c8y-sms-challenge\n *ngSwitchCase=\"LOGIN_VIEWS.SmsChallenge\"\n (onCancel)=\"reset()\"\n [credentials]=\"credentials\"\n ></c8y-sms-challenge>\n\n <c8y-provide-phone-number\n *ngSwitchCase=\"LOGIN_VIEWS.ProvidePhoneNumber\"\n (onCancel)=\"reset()\"\n (onChangeView)=\"handleLoginTemplate($event)\"\n [credentials]=\"credentials\"\n ></c8y-provide-phone-number>\n <c8y-tenant-id-setup\n *ngSwitchCase=\"LOGIN_VIEWS.TenantIdSetup\"\n (onChangeView)=\"handleLoginTemplate($event)\"\n ></c8y-tenant-id-setup>\n\n <c8y-alert-outlet position=\"static\"></c8y-alert-outlet>\n </main>\n</div>\n" }]
|
|
119
|
-
}], ctorParameters: function () { return [{ type: i1.LoginService }, { type: i2.OptionsService }, { type: i3.AlertService }, { type: i4.CredentialsFromQueryParamsService }]; }, propDecorators: { name: [{
|
|
121
|
+
args: [{ selector: 'c8y-login', template: "<div\n class=\"loading card fadeInUp animated shadow5\"\n *ngIf=\"currentView !== LOGIN_VIEWS.None\"\n [ngSwitch]=\"currentView\"\n>\n <main class=\"card-block p-b-0\">\n <span class=\"mainlogo\"></span>\n\n <c8y-credentials\n *ngSwitchCase=\"LOGIN_VIEWS.Credentials\"\n (onChangeView)=\"handleLoginTemplate($event)\"\n [loginViewParams]=\"loginViewParams\"\n ></c8y-credentials>\n <c8y-recover-password\n *ngSwitchCase=\"LOGIN_VIEWS.RecoverPassword\"\n (onChangeView)=\"handleLoginTemplate($event)\"\n ></c8y-recover-password>\n <c8y-change-password\n *ngSwitchCase=\"LOGIN_VIEWS.ChangePassword\"\n (onChangeView)=\"handleLoginTemplate($event)\"\n [credentials]=\"credentials\"\n ></c8y-change-password>\n <c8y-totp-auth\n *ngSwitchCase=\"LOGIN_VIEWS.TotpChallenge\"\n (onCancel)=\"reset()\"\n [view]=\"currentView\"\n [credentials]=\"credentials\"\n ></c8y-totp-auth>\n <c8y-totp-auth\n *ngSwitchCase=\"LOGIN_VIEWS.TotpSetup\"\n (onCancel)=\"reset()\"\n [view]=\"currentView\"\n [credentials]=\"credentials\"\n ></c8y-totp-auth>\n <c8y-sms-challenge\n *ngSwitchCase=\"LOGIN_VIEWS.SmsChallenge\"\n (onCancel)=\"reset()\"\n [credentials]=\"credentials\"\n ></c8y-sms-challenge>\n\n <c8y-provide-phone-number\n *ngSwitchCase=\"LOGIN_VIEWS.ProvidePhoneNumber\"\n (onCancel)=\"reset()\"\n (onChangeView)=\"handleLoginTemplate($event)\"\n [credentials]=\"credentials\"\n ></c8y-provide-phone-number>\n <c8y-tenant-id-setup\n *ngSwitchCase=\"LOGIN_VIEWS.TenantIdSetup\"\n (onChangeView)=\"handleLoginTemplate($event)\"\n ></c8y-tenant-id-setup>\n\n <div\n class=\"text-center m-t-8\"\n *ngIf=\"!!(ui.state$ | async).loginExtraLink\"\n >\n <div *ngIf=\"!!(ui.state$ | async).loginExtraLink.length; else singleExtraLink\">\n <a\n class=\"small d-block m-t-8\"\n title=\"{{ link.label }}\"\n role=\"button\"\n *ngFor=\"let link of (ui.state$ | async).loginExtraLink\"\n [href]=\"link.url\"\n >\n {{ link.label }}\n </a>\n </div>\n <ng-template #singleExtraLink>\n <a\n class=\"small\"\n title=\"{{ (ui.state$ | async).loginExtraLink.label }}\"\n role=\"button\"\n [href]=\"(ui.state$ | async).loginExtraLink.url\"\n >\n {{ (ui.state$ | async).loginExtraLink.label }}\n </a>\n </ng-template>\n </div>\n\n <c8y-alert-outlet position=\"static\"></c8y-alert-outlet>\n </main>\n</div>\n" }]
|
|
122
|
+
}], ctorParameters: function () { return [{ type: i1.LoginService }, { type: i2.OptionsService }, { type: i3.AlertService }, { type: i4.CredentialsFromQueryParamsService }, { type: i5.AppStateService }]; }, propDecorators: { name: [{
|
|
120
123
|
type: Input
|
|
121
124
|
}], onkeyup: [{
|
|
122
125
|
type: HostListener,
|
|
123
126
|
args: ['keyup', ['$event']]
|
|
124
127
|
}] } });
|
|
125
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"login.component.js","sourceRoot":"","sources":["../../../../core/login/login.component.ts","../../../../core/login/login.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, HostListener, OnDestroy } from '@angular/core';\nimport { ICredentials, TenantLoginOptionType } from '@c8y/client';\nimport { LoginService } from './login.service';\nimport { OptionsService } from '../common/options.service';\nimport { LoginViews } from './login.model';\nimport { AlertService } from '../alert/alert.service';\nimport { gettext } from '../i18n/gettext';\nimport { CredentialsFromQueryParamsService } from './credentials-from-query-params.service';\nimport { CredentialsComponentParams } from './credentials-component-params';\n\n@Component({\n  selector: 'c8y-login',\n  templateUrl: './login.component.html',\n  styles: []\n})\nexport class LoginComponent implements OnInit, OnDestroy {\n  currentView: LoginViews = LoginViews.None;\n  LOGIN_VIEWS = LoginViews;\n\n  disabled = false;\n\n  @Input() name: string;\n\n  credentials: ICredentials = {};\n  loginViewParams: CredentialsComponentParams | { [key: string]: any } = {};\n  displayAlerts = false;\n  private TOKEN_PARAM = 'token';\n\n  /**\n   * Just DI.\n   */\n  constructor(\n    public loginService: LoginService,\n    private options: OptionsService,\n    private alert: AlertService,\n    private credentialsFromQueryParamsService: CredentialsFromQueryParamsService\n  ) {}\n\n  ngOnInit() {\n    const token = this.getResetPasswordToken();\n    if (this.loginService.isFirstLogin) {\n      if (!token) {\n        this.loginAutomatically();\n      } else {\n        this.credentials.token = token;\n        this.reset();\n      }\n    }\n    this.loginService.isFirstLogin = false;\n  }\n\n  ngOnDestroy(): void {\n    // make sure that we do not have any queryParameters related to credentials after logging in or even if we were already logged in.\n    this.credentialsFromQueryParamsService.removeCredentialsFromQueryParams();\n  }\n\n  handleLoginTemplate(event: {\n    view: LoginViews;\n    credentials?: ICredentials;\n    loginViewParams?: CredentialsComponentParams | { [key: string]: any };\n  }) {\n    this.currentView = event.view;\n    this.credentials = event.credentials || {};\n    this.loginViewParams = event.loginViewParams || {};\n  }\n\n  @HostListener('keyup', ['$event']) onkeyup(event: KeyboardEvent) {\n    if (event.key !== 'Enter') {\n      this.loginService.cleanMessages();\n    }\n  }\n\n  reset() {\n    this.loginService.reset();\n    this.setView();\n    this.loginService.cleanMessages();\n  }\n\n  private async loginAutomatically() {\n    this.loginService.automaticLoginInProgress$.next(true);\n    try {\n      await this.loginService.login();\n    } catch (e) {\n      const preferredLoginOptionType = this.loginService.loginMode.type;\n      if (preferredLoginOptionType === TenantLoginOptionType.OAUTH2) {\n        this.loginService.redirectToOauth();\n      } else {\n        this.reset();\n        if (\n          preferredLoginOptionType === TenantLoginOptionType.OAUTH2_INTERNAL &&\n          window.location.protocol !== 'https:'\n        ) {\n          this.alert.danger(gettext('Current login mode only supports HTTPS.'));\n        } else if (e.res && e.res.status === 403) {\n          this.alert.addServerFailure(e);\n        }\n      }\n    }\n    this.loginService.automaticLoginInProgress$.next(false);\n  }\n\n  private setView() {\n    if (this.credentials && this.credentials.token) {\n      this.handleLoginTemplate({ view: LoginViews.ChangePassword, credentials: this.credentials });\n    } else if (this.loginService.showTenantSetup()) {\n      this.handleLoginTemplate({ view: LoginViews.TenantIdSetup });\n    } else {\n      this.handleLoginTemplate({ view: LoginViews.Credentials });\n    }\n  }\n\n  private getResetPasswordToken(): string | undefined {\n    const token = this.options.get<string>(this.TOKEN_PARAM);\n    if (token) {\n      this.options.set(this.TOKEN_PARAM, undefined); // only use once\n    }\n    return token;\n  }\n}\n","<div\n  class=\"loading card fadeInUp animated shadow5\"\n  *ngIf=\"currentView !== LOGIN_VIEWS.None\"\n  [ngSwitch]=\"currentView\"\n>\n  <main class=\"card-block p-b-0\">\n    <span class=\"mainlogo\"></span>\n\n    <c8y-credentials\n      *ngSwitchCase=\"LOGIN_VIEWS.Credentials\"\n      (onChangeView)=\"handleLoginTemplate($event)\"\n      [loginViewParams]=\"loginViewParams\"\n    ></c8y-credentials>\n    <c8y-recover-password\n      *ngSwitchCase=\"LOGIN_VIEWS.RecoverPassword\"\n      (onChangeView)=\"handleLoginTemplate($event)\"\n    ></c8y-recover-password>\n    <c8y-change-password\n      *ngSwitchCase=\"LOGIN_VIEWS.ChangePassword\"\n      (onChangeView)=\"handleLoginTemplate($event)\"\n      [credentials]=\"credentials\"\n    ></c8y-change-password>\n    <c8y-totp-auth\n      *ngSwitchCase=\"LOGIN_VIEWS.TotpChallenge\"\n      (onCancel)=\"reset()\"\n      [view]=\"currentView\"\n      [credentials]=\"credentials\"\n    ></c8y-totp-auth>\n    <c8y-totp-auth\n      *ngSwitchCase=\"LOGIN_VIEWS.TotpSetup\"\n      (onCancel)=\"reset()\"\n      [view]=\"currentView\"\n      [credentials]=\"credentials\"\n    ></c8y-totp-auth>\n    <c8y-sms-challenge\n      *ngSwitchCase=\"LOGIN_VIEWS.SmsChallenge\"\n      (onCancel)=\"reset()\"\n      [credentials]=\"credentials\"\n    ></c8y-sms-challenge>\n\n    <c8y-provide-phone-number\n      *ngSwitchCase=\"LOGIN_VIEWS.ProvidePhoneNumber\"\n      (onCancel)=\"reset()\"\n      (onChangeView)=\"handleLoginTemplate($event)\"\n      [credentials]=\"credentials\"\n    ></c8y-provide-phone-number>\n    <c8y-tenant-id-setup\n      *ngSwitchCase=\"LOGIN_VIEWS.TenantIdSetup\"\n      (onChangeView)=\"handleLoginTemplate($event)\"\n    ></c8y-tenant-id-setup>\n\n    <c8y-alert-outlet position=\"static\"></c8y-alert-outlet>\n  </main>\n</div>\n"]}
|
|
128
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"login.component.js","sourceRoot":"","sources":["../../../../core/login/login.component.ts","../../../../core/login/login.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, HostListener, OnDestroy } from '@angular/core';\nimport { ICredentials, TenantLoginOptionType } from '@c8y/client';\nimport { LoginService } from './login.service';\nimport { OptionsService } from '../common/options.service';\nimport { LoginViews } from './login.model';\nimport { AlertService } from '../alert/alert.service';\nimport { gettext } from '../i18n/gettext';\nimport { CredentialsFromQueryParamsService } from './credentials-from-query-params.service';\nimport { CredentialsComponentParams } from './credentials-component-params';\nimport { AppStateService } from '../common/ui-state.service';\n\n@Component({\n  selector: 'c8y-login',\n  templateUrl: './login.component.html',\n  styles: []\n})\nexport class LoginComponent implements OnInit, OnDestroy {\n  currentView: LoginViews = LoginViews.None;\n  LOGIN_VIEWS = LoginViews;\n\n  disabled = false;\n\n  @Input() name: string;\n\n  credentials: ICredentials = {};\n  loginViewParams: CredentialsComponentParams | { [key: string]: any } = {};\n  displayAlerts = false;\n  private TOKEN_PARAM = 'token';\n\n  /**\n   * Just DI.\n   */\n  constructor(\n    public loginService: LoginService,\n    private options: OptionsService,\n    private alert: AlertService,\n    private credentialsFromQueryParamsService: CredentialsFromQueryParamsService,\n    public ui: AppStateService\n  ) {}\n\n  ngOnInit() {\n    const token = this.getResetPasswordToken();\n    if (this.loginService.isFirstLogin) {\n      if (!token) {\n        this.loginAutomatically();\n      } else {\n        this.credentials.token = token;\n        this.reset();\n      }\n    }\n    this.loginService.isFirstLogin = false;\n  }\n\n  ngOnDestroy(): void {\n    // make sure that we do not have any queryParameters related to credentials after logging in or even if we were already logged in.\n    this.credentialsFromQueryParamsService.removeCredentialsFromQueryParams();\n  }\n\n  handleLoginTemplate(event: {\n    view: LoginViews;\n    credentials?: ICredentials;\n    loginViewParams?: CredentialsComponentParams | { [key: string]: any };\n  }) {\n    this.currentView = event.view;\n    this.credentials = event.credentials || {};\n    this.loginViewParams = event.loginViewParams || {};\n  }\n\n  @HostListener('keyup', ['$event']) onkeyup(event: KeyboardEvent) {\n    if (event.key !== 'Enter') {\n      this.loginService.cleanMessages();\n    }\n  }\n\n  reset() {\n    this.loginService.reset();\n    this.setView();\n    this.loginService.cleanMessages();\n  }\n\n  private async loginAutomatically() {\n    this.loginService.automaticLoginInProgress$.next(true);\n    try {\n      await this.loginService.login();\n    } catch (e) {\n      const preferredLoginOptionType = this.loginService.loginMode.type;\n      if (preferredLoginOptionType === TenantLoginOptionType.OAUTH2) {\n        this.loginService.redirectToOauth();\n      } else {\n        this.reset();\n        if (\n          preferredLoginOptionType === TenantLoginOptionType.OAUTH2_INTERNAL &&\n          window.location.protocol !== 'https:'\n        ) {\n          this.alert.danger(gettext('Current login mode only supports HTTPS.'));\n        } else if (e.res && e.res.status === 403) {\n          this.alert.addServerFailure(e);\n        }\n      }\n    }\n    this.loginService.automaticLoginInProgress$.next(false);\n  }\n\n  private setView() {\n    if (this.credentials && this.credentials.token) {\n      this.handleLoginTemplate({ view: LoginViews.ChangePassword, credentials: this.credentials });\n    } else if (this.loginService.showTenantSetup()) {\n      this.handleLoginTemplate({ view: LoginViews.TenantIdSetup });\n    } else {\n      this.handleLoginTemplate({ view: LoginViews.Credentials });\n    }\n  }\n\n  private getResetPasswordToken(): string | undefined {\n    const token = this.options.get<string>(this.TOKEN_PARAM);\n    if (token) {\n      this.options.set(this.TOKEN_PARAM, undefined); // only use once\n    }\n    return token;\n  }\n}\n","<div\n  class=\"loading card fadeInUp animated shadow5\"\n  *ngIf=\"currentView !== LOGIN_VIEWS.None\"\n  [ngSwitch]=\"currentView\"\n>\n  <main class=\"card-block p-b-0\">\n    <span class=\"mainlogo\"></span>\n\n    <c8y-credentials\n      *ngSwitchCase=\"LOGIN_VIEWS.Credentials\"\n      (onChangeView)=\"handleLoginTemplate($event)\"\n      [loginViewParams]=\"loginViewParams\"\n    ></c8y-credentials>\n    <c8y-recover-password\n      *ngSwitchCase=\"LOGIN_VIEWS.RecoverPassword\"\n      (onChangeView)=\"handleLoginTemplate($event)\"\n    ></c8y-recover-password>\n    <c8y-change-password\n      *ngSwitchCase=\"LOGIN_VIEWS.ChangePassword\"\n      (onChangeView)=\"handleLoginTemplate($event)\"\n      [credentials]=\"credentials\"\n    ></c8y-change-password>\n    <c8y-totp-auth\n      *ngSwitchCase=\"LOGIN_VIEWS.TotpChallenge\"\n      (onCancel)=\"reset()\"\n      [view]=\"currentView\"\n      [credentials]=\"credentials\"\n    ></c8y-totp-auth>\n    <c8y-totp-auth\n      *ngSwitchCase=\"LOGIN_VIEWS.TotpSetup\"\n      (onCancel)=\"reset()\"\n      [view]=\"currentView\"\n      [credentials]=\"credentials\"\n    ></c8y-totp-auth>\n    <c8y-sms-challenge\n      *ngSwitchCase=\"LOGIN_VIEWS.SmsChallenge\"\n      (onCancel)=\"reset()\"\n      [credentials]=\"credentials\"\n    ></c8y-sms-challenge>\n\n    <c8y-provide-phone-number\n      *ngSwitchCase=\"LOGIN_VIEWS.ProvidePhoneNumber\"\n      (onCancel)=\"reset()\"\n      (onChangeView)=\"handleLoginTemplate($event)\"\n      [credentials]=\"credentials\"\n    ></c8y-provide-phone-number>\n    <c8y-tenant-id-setup\n      *ngSwitchCase=\"LOGIN_VIEWS.TenantIdSetup\"\n      (onChangeView)=\"handleLoginTemplate($event)\"\n    ></c8y-tenant-id-setup>\n\n    <div\n      class=\"text-center m-t-8\"\n      *ngIf=\"!!(ui.state$ | async).loginExtraLink\"\n    >\n      <div *ngIf=\"!!(ui.state$ | async).loginExtraLink.length; else singleExtraLink\">\n        <a\n          class=\"small d-block m-t-8\"\n          title=\"{{ link.label }}\"\n          role=\"button\"\n          *ngFor=\"let link of (ui.state$ | async).loginExtraLink\"\n          [href]=\"link.url\"\n        >\n          {{ link.label }}\n        </a>\n      </div>\n      <ng-template #singleExtraLink>\n        <a\n          class=\"small\"\n          title=\"{{ (ui.state$ | async).loginExtraLink.label }}\"\n          role=\"button\"\n          [href]=\"(ui.state$ | async).loginExtraLink.url\"\n        >\n          {{ (ui.state$ | async).loginExtraLink.label }}\n        </a>\n      </ng-template>\n    </div>\n\n    <c8y-alert-outlet position=\"static\"></c8y-alert-outlet>\n  </main>\n</div>\n"]}
|
|
@@ -1,20 +1,23 @@
|
|
|
1
|
-
import { Component, Input } from '@angular/core';
|
|
1
|
+
import { Component, Input, Optional } from '@angular/core';
|
|
2
2
|
import { AlertService, DynamicComponentAlert, gettext } from '@c8y/ngx-components';
|
|
3
3
|
import { OperationService } from '@c8y/client';
|
|
4
4
|
import { TranslateService } from '@ngx-translate/core';
|
|
5
5
|
import { BehaviorSubject } from 'rxjs';
|
|
6
6
|
import { map, shareReplay } from 'rxjs/operators';
|
|
7
|
+
import { ContextDashboardComponent } from '@c8y/ngx-components/context-dashboard';
|
|
7
8
|
import * as i0 from "@angular/core";
|
|
8
9
|
import * as i1 from "@c8y/ngx-components";
|
|
9
10
|
import * as i2 from "@c8y/client";
|
|
10
11
|
import * as i3 from "@ngx-translate/core";
|
|
11
|
-
import * as i4 from "@
|
|
12
|
-
import * as i5 from "@angular/
|
|
12
|
+
import * as i4 from "@c8y/ngx-components/context-dashboard";
|
|
13
|
+
import * as i5 from "@angular/common";
|
|
14
|
+
import * as i6 from "@angular/forms";
|
|
13
15
|
export class DeviceControlMessageWidgetViewComponent {
|
|
14
|
-
constructor(alert, operation, translate) {
|
|
16
|
+
constructor(alert, operation, translate, dashboard) {
|
|
15
17
|
this.alert = alert;
|
|
16
18
|
this.operation = operation;
|
|
17
19
|
this.translate = translate;
|
|
20
|
+
this.dashboard = dashboard;
|
|
18
21
|
this.messageToBeSent = '';
|
|
19
22
|
this.operationAttribute = 'c8y_Message';
|
|
20
23
|
this.currentDevice = new BehaviorSubject(null);
|
|
@@ -30,6 +33,9 @@ export class DeviceControlMessageWidgetViewComponent {
|
|
|
30
33
|
}), shareReplay({ refCount: true, bufferSize: 1 }));
|
|
31
34
|
}
|
|
32
35
|
ngOnInit() {
|
|
36
|
+
if (this.dashboard?.isDeviceTypeDashboard && this.dashboard?.context?.id) {
|
|
37
|
+
this.currentDevice.next(this.dashboard.context);
|
|
38
|
+
}
|
|
33
39
|
this.operationSupportedByDeviceSubscription = this.operationSupportedByDevice$.subscribe(supported => {
|
|
34
40
|
if (!supported) {
|
|
35
41
|
this.alerts.addAlerts(new DynamicComponentAlert({
|
|
@@ -46,7 +52,7 @@ export class DeviceControlMessageWidgetViewComponent {
|
|
|
46
52
|
this.operationSupportedByDeviceSubscription?.unsubscribe();
|
|
47
53
|
}
|
|
48
54
|
ngOnChanges() {
|
|
49
|
-
if (this.config.device) {
|
|
55
|
+
if (!this.dashboard?.isDeviceTypeDashboard && this.config.device) {
|
|
50
56
|
this.currentDevice.next(this.config.device);
|
|
51
57
|
}
|
|
52
58
|
}
|
|
@@ -67,12 +73,14 @@ export class DeviceControlMessageWidgetViewComponent {
|
|
|
67
73
|
}
|
|
68
74
|
}
|
|
69
75
|
}
|
|
70
|
-
DeviceControlMessageWidgetViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: DeviceControlMessageWidgetViewComponent, deps: [{ token: i1.AlertService }, { token: i2.OperationService }, { token: i3.TranslateService }], target: i0.ɵɵFactoryTarget.Component });
|
|
71
|
-
DeviceControlMessageWidgetViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: DeviceControlMessageWidgetViewComponent, selector: "c8y-device-control-message-widget-view", inputs: { config: "config" }, usesOnChanges: true, ngImport: i0, template: "<div *ngIf=\"operationSupportedByDevice$ | async\" class=\"input-group p-16\">\n <input\n type=\"text\"\n class=\"form-control\"\n [(ngModel)]=\"messageToBeSent\"\n placeholder=\"{{ 'Message' | translate }}\"\n />\n <span class=\"input-group-btn\">\n <button\n title=\"{{ 'Send' | translate }}\"\n class=\"btn btn-primary\"\n (click)=\"sendMessage()\"\n [disabled]=\"!messageToBeSent\"\n translate\n >\n Send\n </button>\n </span>\n</div>\n", dependencies: [{ kind: "directive", type: i1.C8yTranslateDirective, selector: "[translate],[ngx-translate]" }, { kind: "directive", type:
|
|
76
|
+
DeviceControlMessageWidgetViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: DeviceControlMessageWidgetViewComponent, deps: [{ token: i1.AlertService }, { token: i2.OperationService }, { token: i3.TranslateService }, { token: i4.ContextDashboardComponent, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
77
|
+
DeviceControlMessageWidgetViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: DeviceControlMessageWidgetViewComponent, selector: "c8y-device-control-message-widget-view", inputs: { config: "config" }, usesOnChanges: true, ngImport: i0, template: "<div *ngIf=\"operationSupportedByDevice$ | async\" class=\"input-group p-16\">\n <input\n type=\"text\"\n class=\"form-control\"\n [(ngModel)]=\"messageToBeSent\"\n placeholder=\"{{ 'Message' | translate }}\"\n />\n <span class=\"input-group-btn\">\n <button\n title=\"{{ 'Send' | translate }}\"\n class=\"btn btn-primary\"\n (click)=\"sendMessage()\"\n [disabled]=\"!messageToBeSent\"\n translate\n >\n Send\n </button>\n </span>\n</div>\n", dependencies: [{ kind: "directive", type: i1.C8yTranslateDirective, selector: "[translate],[ngx-translate]" }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "pipe", type: i1.C8yTranslatePipe, name: "translate" }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }] });
|
|
72
78
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: DeviceControlMessageWidgetViewComponent, decorators: [{
|
|
73
79
|
type: Component,
|
|
74
80
|
args: [{ selector: 'c8y-device-control-message-widget-view', template: "<div *ngIf=\"operationSupportedByDevice$ | async\" class=\"input-group p-16\">\n <input\n type=\"text\"\n class=\"form-control\"\n [(ngModel)]=\"messageToBeSent\"\n placeholder=\"{{ 'Message' | translate }}\"\n />\n <span class=\"input-group-btn\">\n <button\n title=\"{{ 'Send' | translate }}\"\n class=\"btn btn-primary\"\n (click)=\"sendMessage()\"\n [disabled]=\"!messageToBeSent\"\n translate\n >\n Send\n </button>\n </span>\n</div>\n" }]
|
|
75
|
-
}], ctorParameters: function () { return [{ type: i1.AlertService }, { type: i2.OperationService }, { type: i3.TranslateService }
|
|
81
|
+
}], ctorParameters: function () { return [{ type: i1.AlertService }, { type: i2.OperationService }, { type: i3.TranslateService }, { type: i4.ContextDashboardComponent, decorators: [{
|
|
82
|
+
type: Optional
|
|
83
|
+
}] }]; }, propDecorators: { config: [{
|
|
76
84
|
type: Input
|
|
77
85
|
}] } });
|
|
78
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
86
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"device-control-message-widget-view.component.js","sourceRoot":"","sources":["../../../../../../widgets/implementations/device-control-message/device-control-message-widget-view/device-control-message-widget-view.component.ts","../../../../../../widgets/implementations/device-control-message/device-control-message-widget-view/device-control-message-widget-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnChanges, OnDestroy, OnInit, Optional } from '@angular/core';\nimport {\n  AlertService,\n  DynamicComponent,\n  DynamicComponentAlert,\n  DynamicComponentAlertAggregator,\n  gettext\n} from '@c8y/ngx-components';\nimport { IManagedObject, OperationService } from '@c8y/client';\nimport { TranslateService } from '@ngx-translate/core';\nimport { BehaviorSubject, Observable, Subscription } from 'rxjs';\nimport { map, shareReplay } from 'rxjs/operators';\nimport { ContextDashboardComponent } from '@c8y/ngx-components/context-dashboard';\n\n@Component({\n  selector: 'c8y-device-control-message-widget-view',\n  templateUrl: './device-control-message-widget-view.component.html'\n})\nexport class DeviceControlMessageWidgetViewComponent\n  implements OnChanges, DynamicComponent, OnDestroy, OnInit\n{\n  @Input() config: { device?: IManagedObject };\n  operationSupportedByDevice$: Observable<boolean>;\n  messageToBeSent = '';\n  alerts: DynamicComponentAlertAggregator;\n  private readonly operationAttribute = 'c8y_Message';\n  private currentDevice = new BehaviorSubject<IManagedObject | null>(null);\n  private operationSupportedByDeviceSubscription: Subscription;\n\n  constructor(\n    private alert: AlertService,\n    private operation: OperationService,\n    private translate: TranslateService,\n    @Optional() private dashboard: ContextDashboardComponent\n  ) {\n    this.operationSupportedByDevice$ = this.currentDevice.pipe(\n      map(device => {\n        if (!device) {\n          return false;\n        }\n        const supportedOperations = device.c8y_SupportedOperations;\n        if (supportedOperations && Array.isArray(supportedOperations)) {\n          return supportedOperations.includes(this.operationAttribute);\n        }\n        return false;\n      }),\n      shareReplay({ refCount: true, bufferSize: 1 })\n    );\n  }\n\n  ngOnInit(): void {\n    if (this.dashboard?.isDeviceTypeDashboard && this.dashboard?.context?.id) {\n      this.currentDevice.next(this.dashboard.context);\n    }\n    this.operationSupportedByDeviceSubscription = this.operationSupportedByDevice$.subscribe(\n      supported => {\n        if (!supported) {\n          this.alerts.addAlerts(\n            new DynamicComponentAlert({\n              type: 'warning',\n              text: gettext('Operation not supported by this device')\n            })\n          );\n        } else {\n          this.alerts.clear();\n        }\n      }\n    );\n  }\n\n  ngOnDestroy(): void {\n    this.operationSupportedByDeviceSubscription?.unsubscribe();\n  }\n\n  ngOnChanges(): void {\n    if (!this.dashboard?.isDeviceTypeDashboard && this.config.device) {\n      this.currentDevice.next(this.config.device);\n    }\n  }\n\n  async sendMessage() {\n    const msg = this.messageToBeSent;\n    const operationDescription = this.translate.instant(gettext('Send message \"{{msg}}\"'), { msg });\n    try {\n      await this.operation.create({\n        deviceId: this.currentDevice.value?.id,\n        description: operationDescription,\n        [this.operationAttribute]: { text: msg }\n      });\n      this.alert.success(gettext('Message will be sent.'));\n      this.messageToBeSent = '';\n    } catch (e) {\n      this.alert.addServerFailure(e);\n    }\n  }\n}\n","<div *ngIf=\"operationSupportedByDevice$ | async\" class=\"input-group p-16\">\n  <input\n    type=\"text\"\n    class=\"form-control\"\n    [(ngModel)]=\"messageToBeSent\"\n    placeholder=\"{{ 'Message' | translate }}\"\n  />\n  <span class=\"input-group-btn\">\n    <button\n      title=\"{{ 'Send' | translate }}\"\n      class=\"btn btn-primary\"\n      (click)=\"sendMessage()\"\n      [disabled]=\"!messageToBeSent\"\n      translate\n    >\n      Send\n    </button>\n  </span>\n</div>\n"]}
|
|
@@ -1,21 +1,34 @@
|
|
|
1
|
-
import { Component, Input, ViewChild } from '@angular/core';
|
|
1
|
+
import { Component, Input, Optional, ViewChild } from '@angular/core';
|
|
2
|
+
import { InventoryService } from '@c8y/client';
|
|
2
3
|
import { ClusterMapComponent } from '@c8y/ngx-components/map';
|
|
3
4
|
import { DashboardChildComponent } from '@c8y/ngx-components';
|
|
4
5
|
import { filter, takeUntil } from 'rxjs/operators';
|
|
5
6
|
import { Subject } from 'rxjs';
|
|
7
|
+
import { ContextDashboardComponent } from '@c8y/ngx-components/context-dashboard';
|
|
6
8
|
import * as i0 from "@angular/core";
|
|
7
9
|
import * as i1 from "@c8y/ngx-components";
|
|
8
|
-
import * as i2 from "@
|
|
9
|
-
import * as i3 from "@c8y/
|
|
10
|
-
import * as i4 from "@angular/
|
|
11
|
-
import * as i5 from "
|
|
10
|
+
import * as i2 from "@c8y/ngx-components/context-dashboard";
|
|
11
|
+
import * as i3 from "@c8y/client";
|
|
12
|
+
import * as i4 from "@angular/common";
|
|
13
|
+
import * as i5 from "@c8y/ngx-components/map";
|
|
14
|
+
import * as i6 from "@angular/router";
|
|
15
|
+
import * as i7 from "./map-event-info.component";
|
|
12
16
|
export class MapWidgetComponent {
|
|
13
|
-
constructor(dashboardChild) {
|
|
17
|
+
constructor(dashboardChild, dashboardContextComponent, inventory) {
|
|
18
|
+
this.dashboardContextComponent = dashboardContextComponent;
|
|
19
|
+
this.inventory = inventory;
|
|
14
20
|
this.mapConfig = { center: [0, 0] };
|
|
15
21
|
this.destroy$ = new Subject();
|
|
16
22
|
this.listenToWidgetResizeEvent(dashboardChild);
|
|
17
23
|
}
|
|
18
|
-
ngOnInit() {
|
|
24
|
+
async ngOnInit() {
|
|
25
|
+
if (this.dashboardContextComponent?.dashboard?.deviceType && !this.config.device) {
|
|
26
|
+
const context = this.dashboardContextComponent.context;
|
|
27
|
+
if (context?.id) {
|
|
28
|
+
const { id } = context;
|
|
29
|
+
this.config.device = (await this.inventory.detail(id)).data;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
19
32
|
if (this.config.device) {
|
|
20
33
|
this.rootNode = this.config.device;
|
|
21
34
|
}
|
|
@@ -64,15 +77,17 @@ export class MapWidgetComponent {
|
|
|
64
77
|
this.mapConfig.realtime = this.config.realtime || false;
|
|
65
78
|
}
|
|
66
79
|
}
|
|
67
|
-
MapWidgetComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: MapWidgetComponent, deps: [{ token: i1.DashboardChildComponent }], target: i0.ɵɵFactoryTarget.Component });
|
|
68
|
-
MapWidgetComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: MapWidgetComponent, selector: "c8y-map-widget", inputs: { config: "config" }, viewQueries: [{ propertyName: "clusterMap", first: true, predicate: ClusterMapComponent, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<c8y-map-status\n [clusterMap]=\"mapWidget\"\n [(config)]=\"mapConfig\"\n (onUnfollow)=\"stopFollow()\"\n [buttonsConfig]=\"\n config.widgetInstanceGlobalTimeContext ? { realtime: { show: false } } : null\n \"\n></c8y-map-status>\n<c8y-cluster-map\n #mapWidget\n [rootNode]=\"rootNode\"\n [config]=\"mapConfig\"\n>\n <div\n *c8yMapPopup=\"let context\"\n class=\"map-marker\"\n >\n <a\n class=\"text-truncate deviceLink text-12\"\n routerLink=\"/device/{{ context.id }}\"\n >\n <strong>{{ context.name }}</strong>\n </a>\n <c8y-map-event-info [asset]=\"context\">\n <button\n type=\"button\"\n class=\"btn btn-default btn-xs btn-block m-t-8\"\n (click)=\"startFollow(context)\"\n [title]=\"'Activate realtime on this asset and follow it if it moves' | translate\"\n *ngIf=\"!mapConfig.follow\"\n translate\n >\n Follow\n </button>\n <button\n type=\"button\"\n class=\"btn btn-default btn-xs btn-block m-t-8\"\n (click)=\"stopFollow()\"\n [title]=\"'Stop following this asset.' | translate\"\n *ngIf=\"mapConfig.follow\"\n translate\n >\n Unfollow\n </button>\n </c8y-map-event-info>\n </div>\n</c8y-cluster-map>\n", dependencies: [{ kind: "directive", type:
|
|
80
|
+
MapWidgetComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: MapWidgetComponent, deps: [{ token: i1.DashboardChildComponent }, { token: i2.ContextDashboardComponent, optional: true }, { token: i3.InventoryService }], target: i0.ɵɵFactoryTarget.Component });
|
|
81
|
+
MapWidgetComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: MapWidgetComponent, selector: "c8y-map-widget", inputs: { config: "config" }, viewQueries: [{ propertyName: "clusterMap", first: true, predicate: ClusterMapComponent, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<c8y-map-status\n [clusterMap]=\"mapWidget\"\n [(config)]=\"mapConfig\"\n (onUnfollow)=\"stopFollow()\"\n [buttonsConfig]=\"\n config.widgetInstanceGlobalTimeContext ? { realtime: { show: false } } : null\n \"\n></c8y-map-status>\n<c8y-cluster-map\n #mapWidget\n [rootNode]=\"rootNode\"\n [config]=\"mapConfig\"\n>\n <div\n *c8yMapPopup=\"let context\"\n class=\"map-marker\"\n >\n <a\n class=\"text-truncate deviceLink text-12\"\n routerLink=\"/device/{{ context.id }}\"\n >\n <strong>{{ context.name }}</strong>\n </a>\n <c8y-map-event-info [asset]=\"context\">\n <button\n type=\"button\"\n class=\"btn btn-default btn-xs btn-block m-t-8\"\n (click)=\"startFollow(context)\"\n [title]=\"'Activate realtime on this asset and follow it if it moves' | translate\"\n *ngIf=\"!mapConfig.follow\"\n translate\n >\n Follow\n </button>\n <button\n type=\"button\"\n class=\"btn btn-default btn-xs btn-block m-t-8\"\n (click)=\"stopFollow()\"\n [title]=\"'Stop following this asset.' | translate\"\n *ngIf=\"mapConfig.follow\"\n translate\n >\n Unfollow\n </button>\n </c8y-map-event-info>\n </div>\n</c8y-cluster-map>\n", dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.C8yTranslateDirective, selector: "[translate],[ngx-translate]" }, { kind: "component", type: i5.MapStatusComponent, selector: "c8y-map-status", inputs: ["config", "clusterMap", "buttonsConfig"], outputs: ["configChange", "onUnfollow"] }, { kind: "component", type: i5.ClusterMapComponent, selector: "c8y-cluster-map", inputs: ["config", "rootNode", "asset", "showClusterColor"], outputs: ["mapChange"] }, { kind: "directive", type: i5.MapPopupDirective, selector: "[c8yMapPopup]" }, { kind: "directive", type: i6.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: i7.MapEventInfoComponent, selector: "c8y-map-event-info", inputs: ["asset"] }, { kind: "pipe", type: i1.C8yTranslatePipe, name: "translate" }] });
|
|
69
82
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: MapWidgetComponent, decorators: [{
|
|
70
83
|
type: Component,
|
|
71
84
|
args: [{ selector: 'c8y-map-widget', template: "<c8y-map-status\n [clusterMap]=\"mapWidget\"\n [(config)]=\"mapConfig\"\n (onUnfollow)=\"stopFollow()\"\n [buttonsConfig]=\"\n config.widgetInstanceGlobalTimeContext ? { realtime: { show: false } } : null\n \"\n></c8y-map-status>\n<c8y-cluster-map\n #mapWidget\n [rootNode]=\"rootNode\"\n [config]=\"mapConfig\"\n>\n <div\n *c8yMapPopup=\"let context\"\n class=\"map-marker\"\n >\n <a\n class=\"text-truncate deviceLink text-12\"\n routerLink=\"/device/{{ context.id }}\"\n >\n <strong>{{ context.name }}</strong>\n </a>\n <c8y-map-event-info [asset]=\"context\">\n <button\n type=\"button\"\n class=\"btn btn-default btn-xs btn-block m-t-8\"\n (click)=\"startFollow(context)\"\n [title]=\"'Activate realtime on this asset and follow it if it moves' | translate\"\n *ngIf=\"!mapConfig.follow\"\n translate\n >\n Follow\n </button>\n <button\n type=\"button\"\n class=\"btn btn-default btn-xs btn-block m-t-8\"\n (click)=\"stopFollow()\"\n [title]=\"'Stop following this asset.' | translate\"\n *ngIf=\"mapConfig.follow\"\n translate\n >\n Unfollow\n </button>\n </c8y-map-event-info>\n </div>\n</c8y-cluster-map>\n" }]
|
|
72
|
-
}], ctorParameters: function () { return [{ type: i1.DashboardChildComponent }
|
|
85
|
+
}], ctorParameters: function () { return [{ type: i1.DashboardChildComponent }, { type: i2.ContextDashboardComponent, decorators: [{
|
|
86
|
+
type: Optional
|
|
87
|
+
}] }, { type: i3.InventoryService }]; }, propDecorators: { config: [{
|
|
73
88
|
type: Input
|
|
74
89
|
}], clusterMap: [{
|
|
75
90
|
type: ViewChild,
|
|
76
91
|
args: [ClusterMapComponent]
|
|
77
92
|
}] } });
|
|
78
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
93
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map-widget.component.js","sourceRoot":"","sources":["../../../../../widgets/implementations/map/map-widget.component.ts","../../../../../widgets/implementations/map/map-widget.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { IManagedObject, InventoryService } from '@c8y/client';\nimport { ClusterMapComponent, ClusterMapConfig } from '@c8y/ngx-components/map';\nimport { DashboardChildComponent } from '@c8y/ngx-components';\nimport { MapWidgetConfig } from './map-widget.model';\nimport { filter, takeUntil } from 'rxjs/operators';\nimport { Subject } from 'rxjs';\nimport { ContextDashboardComponent } from '@c8y/ngx-components/context-dashboard';\n\n@Component({\n  selector: 'c8y-map-widget',\n  templateUrl: './map-widget.component.html'\n})\nexport class MapWidgetComponent implements OnInit, OnChanges, OnDestroy {\n  mapConfig: ClusterMapConfig = { center: [0, 0] };\n  rootNode: IManagedObject;\n  @Input() config: MapWidgetConfig;\n\n  @ViewChild(ClusterMapComponent)\n  clusterMap: ClusterMapComponent;\n\n  private savedNode: IManagedObject;\n  private destroy$ = new Subject();\n\n  constructor(\n    dashboardChild: DashboardChildComponent,\n    @Optional() private dashboardContextComponent: ContextDashboardComponent,\n    private inventory: InventoryService\n  ) {\n    this.listenToWidgetResizeEvent(dashboardChild);\n  }\n\n  async ngOnInit() {\n    if (this.dashboardContextComponent?.dashboard?.deviceType && !this.config.device) {\n      const context = this.dashboardContextComponent.context;\n      if (context?.id) {\n        const { id } = context;\n        this.config.device = (await this.inventory.detail(id)).data;\n      }\n    }\n    if (this.config.device) {\n      this.rootNode = this.config.device;\n    }\n    this.mapConfig = { ...this.config.mapConfig };\n    if (this.config.widgetInstanceGlobalTimeContext) {\n      this.updateMapConfigRealtime();\n    }\n    this.savedNode = this.rootNode;\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.config?.currentValue?.widgetInstanceGlobalTimeContext) {\n      this.updateMapConfigRealtime();\n    }\n  }\n\n  startFollow(context) {\n    if (context.id !== this.rootNode?.id) {\n      this.rootNode = context;\n    }\n    this.mapConfig = {\n      ...this.config.mapConfig,\n      follow: true,\n      realtime: true\n    };\n  }\n\n  stopFollow() {\n    this.mapConfig = {\n      ...this.config.mapConfig,\n      follow: false\n    };\n    if (this.config.widgetInstanceGlobalTimeContext) {\n      this.updateMapConfigRealtime();\n    }\n    this.rootNode = this.savedNode;\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n  }\n\n  private listenToWidgetResizeEvent(dashboardChild: DashboardChildComponent) {\n    dashboardChild.changeEnd\n      .pipe(\n        filter(child => child.lastChange === 'resize'),\n        takeUntil(this.destroy$)\n      )\n      .subscribe(() => {\n        this.clusterMap.reset();\n      });\n  }\n\n  private updateMapConfigRealtime() {\n    this.mapConfig.realtime = this.config.realtime || false;\n  }\n}\n","<c8y-map-status\n  [clusterMap]=\"mapWidget\"\n  [(config)]=\"mapConfig\"\n  (onUnfollow)=\"stopFollow()\"\n  [buttonsConfig]=\"\n    config.widgetInstanceGlobalTimeContext ? { realtime: { show: false } } : null\n  \"\n></c8y-map-status>\n<c8y-cluster-map\n  #mapWidget\n  [rootNode]=\"rootNode\"\n  [config]=\"mapConfig\"\n>\n  <div\n    *c8yMapPopup=\"let context\"\n    class=\"map-marker\"\n  >\n    <a\n      class=\"text-truncate deviceLink text-12\"\n      routerLink=\"/device/{{ context.id }}\"\n    >\n      <strong>{{ context.name }}</strong>\n    </a>\n    <c8y-map-event-info [asset]=\"context\">\n      <button\n        type=\"button\"\n        class=\"btn btn-default btn-xs btn-block m-t-8\"\n        (click)=\"startFollow(context)\"\n        [title]=\"'Activate realtime on this asset and follow it if it moves' | translate\"\n        *ngIf=\"!mapConfig.follow\"\n        translate\n      >\n        Follow\n      </button>\n      <button\n        type=\"button\"\n        class=\"btn btn-default btn-xs btn-block m-t-8\"\n        (click)=\"stopFollow()\"\n        [title]=\"'Stop following this asset.' | translate\"\n        *ngIf=\"mapConfig.follow\"\n        translate\n      >\n        Unfollow\n      </button>\n    </c8y-map-event-info>\n  </div>\n</c8y-cluster-map>\n"]}
|
package/esm2020/widgets/implementations/three-d-rotation/lazy-box-model/lazy-load-box-model.mjs
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
export async function loadBoxModel() {
|
|
2
|
-
const
|
|
3
|
-
return boxModel;
|
|
2
|
+
const boxModel = await import('@c8y/style/three-d-models/box-model.json');
|
|
3
|
+
return boxModel.default || boxModel;
|
|
4
4
|
}
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF6eS1sb2FkLWJveC1tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3dpZGdldHMvaW1wbGVtZW50YXRpb25zL3RocmVlLWQtcm90YXRpb24vbGF6eS1ib3gtbW9kZWwvbGF6eS1sb2FkLWJveC1tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsS0FBSyxVQUFVLFlBQVk7SUFDaEMsTUFBTSxRQUFRLEdBQUcsTUFBTSxNQUFNLENBQUMsMENBQTBDLENBQUMsQ0FBQztJQUMxRSxPQUFPLFFBQVEsQ0FBQyxPQUFPLElBQUksUUFBUSxDQUFDO0FBQ3RDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgYXN5bmMgZnVuY3Rpb24gbG9hZEJveE1vZGVsKCkge1xuICBjb25zdCBib3hNb2RlbCA9IGF3YWl0IGltcG9ydCgnQGM4eS9zdHlsZS90aHJlZS1kLW1vZGVscy9ib3gtbW9kZWwuanNvbicpO1xuICByZXR1cm4gYm94TW9kZWwuZGVmYXVsdCB8fCBib3hNb2RlbDtcbn1cbiJdfQ==
|
package/esm2020/widgets/implementations/three-d-rotation/lazy-phone-model/lazy-load-phone-model.mjs
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
export async function loadPhoneModel() {
|
|
2
|
-
const
|
|
3
|
-
return phoneModel;
|
|
2
|
+
const phoneModel = await import('@c8y/style/three-d-models/phone-model.json');
|
|
3
|
+
return phoneModel.default || phoneModel;
|
|
4
4
|
}
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF6eS1sb2FkLXBob25lLW1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vd2lkZ2V0cy9pbXBsZW1lbnRhdGlvbnMvdGhyZWUtZC1yb3RhdGlvbi9sYXp5LXBob25lLW1vZGVsL2xhenktbG9hZC1waG9uZS1tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsS0FBSyxVQUFVLGNBQWM7SUFDbEMsTUFBTSxVQUFVLEdBQUcsTUFBTSxNQUFNLENBQUMsNENBQTRDLENBQUMsQ0FBQztJQUM5RSxPQUFPLFVBQVUsQ0FBQyxPQUFPLElBQUksVUFBVSxDQUFDO0FBQzFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgYXN5bmMgZnVuY3Rpb24gbG9hZFBob25lTW9kZWwoKSB7XG4gIGNvbnN0IHBob25lTW9kZWwgPSBhd2FpdCBpbXBvcnQoJ0BjOHkvc3R5bGUvdGhyZWUtZC1tb2RlbHMvcGhvbmUtbW9kZWwuanNvbicpO1xuICByZXR1cm4gcGhvbmVNb2RlbC5kZWZhdWx0IHx8IHBob25lTW9kZWw7XG59XG4iXX0=
|