diff --git a/main/http_server/axe-os/src/app/app.module.ts b/main/http_server/axe-os/src/app/app.module.ts
index 1587610b3..741af5115 100644
--- a/main/http_server/axe-os/src/app/app.module.ts
+++ b/main/http_server/axe-os/src/app/app.module.ts
@@ -1,7 +1,7 @@
import { CommonModule, HashLocationStrategy, LocationStrategy } from '@angular/common';
import { HttpClientModule } from '@angular/common/http';
import { NgModule } from '@angular/core';
-import { ReactiveFormsModule } from '@angular/forms';
+import { FormsModule, ReactiveFormsModule } from '@angular/forms';
import { BrowserModule } from '@angular/platform-browser';
import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
import { ToastrModule } from 'ngx-toastr';
@@ -40,6 +40,7 @@ const components = [
AppRoutingModule,
HttpClientModule,
ReactiveFormsModule,
+ FormsModule,
ToastrModule.forRoot({
positionClass: 'toast-bottom-right'
}),
diff --git a/main/http_server/axe-os/src/app/components/edit/edit.component.ts b/main/http_server/axe-os/src/app/components/edit/edit.component.ts
index 3d88da769..1da53380a 100644
--- a/main/http_server/axe-os/src/app/components/edit/edit.component.ts
+++ b/main/http_server/axe-os/src/app/components/edit/edit.component.ts
@@ -104,6 +104,10 @@ export class EditComponent implements OnInit {
form.invertfanpolarity = form.invertfanpolarity == true ? 1 : 0;
form.autofanspeed = form.autofanspeed == true ? 1 : 0;
+ if (form.wifiPass === 'password') {
+ delete form.wifiPass;
+ }
+
this.systemService.updateSystem(this.uri, form)
.pipe(this.loadingService.lockUIUntilComplete())
.subscribe({
diff --git a/main/http_server/axe-os/src/app/components/settings/settings.component.html b/main/http_server/axe-os/src/app/components/settings/settings.component.html
index 8311164bd..e15016d12 100644
--- a/main/http_server/axe-os/src/app/components/settings/settings.component.html
+++ b/main/http_server/axe-os/src/app/components/settings/settings.component.html
@@ -4,6 +4,23 @@
Settings
+
+
+
+
Latest Release: {{latestRelease.name}}
+
+
+
+
+
+
diff --git a/main/http_server/axe-os/src/app/components/settings/settings.component.scss b/main/http_server/axe-os/src/app/components/settings/settings.component.scss
index aeb89d19c..bb58d6e30 100644
--- a/main/http_server/axe-os/src/app/components/settings/settings.component.scss
+++ b/main/http_server/axe-os/src/app/components/settings/settings.component.scss
@@ -28,4 +28,8 @@ select {
select {
min-width: 518px
}
+}
+
+a {
+ color: white;
}
\ No newline at end of file
diff --git a/main/http_server/axe-os/src/app/components/settings/settings.component.ts b/main/http_server/axe-os/src/app/components/settings/settings.component.ts
index 9d387fcd5..74e8baeb8 100644
--- a/main/http_server/axe-os/src/app/components/settings/settings.component.ts
+++ b/main/http_server/axe-os/src/app/components/settings/settings.component.ts
@@ -2,7 +2,8 @@ import { HttpErrorResponse, HttpEventType } from '@angular/common/http';
import { Component } from '@angular/core';
import { FormBuilder, FormGroup, Validators } from '@angular/forms';
import { ToastrService } from 'ngx-toastr';
-import { startWith } from 'rxjs';
+import { map, Observable, startWith } from 'rxjs';
+import { GithubUpdateService } from 'src/app/services/github-update.service';
import { LoadingService } from 'src/app/services/loading.service';
import { SystemService } from 'src/app/services/system.service';
import { eASICModel } from 'src/models/enum/eASICModel';
@@ -24,17 +25,26 @@ export class SettingsComponent {
public eASICModel = eASICModel;
public ASICModel!: eASICModel;
+ public latestRelease$: Observable
;
+
constructor(
private fb: FormBuilder,
private systemService: SystemService,
private toastr: ToastrService,
private toastrService: ToastrService,
- private loadingService: LoadingService
+ private loadingService: LoadingService,
+ private githubUpdateService: GithubUpdateService
) {
+
+
window.addEventListener('resize', this.checkDevTools);
this.checkDevTools();
+ this.latestRelease$ = this.githubUpdateService.getReleases().pipe(map(releases => {
+ return releases[0];
+ }))
+
this.systemService.getInfo()
.pipe(this.loadingService.lockUIUntilComplete())
.subscribe(info => {
@@ -99,6 +109,10 @@ export class SettingsComponent {
form.invertfanpolarity = form.invertfanpolarity == true ? 1 : 0;
form.autofanspeed = form.autofanspeed == true ? 1 : 0;
+ if (form.wifiPass === 'password') {
+ delete form.wifiPass;
+ }
+
this.systemService.updateSystem(undefined, form)
.pipe(this.loadingService.lockUIUntilComplete())
.subscribe({
diff --git a/main/http_server/axe-os/src/app/services/github-update.service.spec.ts b/main/http_server/axe-os/src/app/services/github-update.service.spec.ts
new file mode 100644
index 000000000..43f5df9dd
--- /dev/null
+++ b/main/http_server/axe-os/src/app/services/github-update.service.spec.ts
@@ -0,0 +1,16 @@
+import { TestBed } from '@angular/core/testing';
+
+import { GithubUpdateService } from './github-update.service';
+
+describe('GithubUpdateService', () => {
+ let service: GithubUpdateService;
+
+ beforeEach(() => {
+ TestBed.configureTestingModule({});
+ service = TestBed.inject(GithubUpdateService);
+ });
+
+ it('should be created', () => {
+ expect(service).toBeTruthy();
+ });
+});
diff --git a/main/http_server/axe-os/src/app/services/github-update.service.ts b/main/http_server/axe-os/src/app/services/github-update.service.ts
new file mode 100644
index 000000000..e3784205f
--- /dev/null
+++ b/main/http_server/axe-os/src/app/services/github-update.service.ts
@@ -0,0 +1,19 @@
+import { HttpClient } from '@angular/common/http';
+import { Injectable } from '@angular/core';
+import { Observable } from 'rxjs';
+
+@Injectable({
+ providedIn: 'root'
+})
+export class GithubUpdateService {
+
+ constructor(
+ private httpClient: HttpClient
+ ) { }
+
+
+ public getReleases() {
+ return this.httpClient.get(`https://api.github.com/repos/skot/esp-miner/releases`) as Observable;
+ }
+
+}
\ No newline at end of file
diff --git a/main/http_server/axe-os/src/app/services/system.service.ts b/main/http_server/axe-os/src/app/services/system.service.ts
index cc607b8db..d380918d4 100644
--- a/main/http_server/axe-os/src/app/services/system.service.ts
+++ b/main/http_server/axe-os/src/app/services/system.service.ts
@@ -62,7 +62,7 @@ export class SystemService {
}
- private otaUpdate(file: File, url: string) {
+ private otaUpdate(file: File | Blob, url: string) {
return new Observable>((subscriber) => {
const reader = new FileReader();
@@ -78,12 +78,13 @@ export class SystemService {
},
}).subscribe({
next: (e) => {
- subscriber.next(e)
+
},
error: (err) => {
subscriber.error(err)
},
complete: () => {
+ subscriber.next()
subscriber.complete();
}
});
@@ -92,10 +93,10 @@ export class SystemService {
});
}
- public performOTAUpdate(file: File) {
+ public performOTAUpdate(file: File | Blob) {
return this.otaUpdate(file, `/api/system/OTA`);
}
- public performWWWOTAUpdate(file: File) {
+ public performWWWOTAUpdate(file: File | Blob) {
return this.otaUpdate(file, `/api/system/OTAWWW`);
}