summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--components/datalake-handler/admin/src/src/app/app-routing.module.ts5
-rw-r--r--components/datalake-handler/admin/src/src/app/app.module.ts19
-rw-r--r--components/datalake-handler/admin/src/src/app/shared/components/Button/button.component.html6
-rw-r--r--components/datalake-handler/admin/src/src/app/shared/components/Button/button.component.ts8
-rw-r--r--components/datalake-handler/admin/src/src/app/shared/layout/sidebar/sidebar.component.html3
-rw-r--r--components/datalake-handler/admin/src/src/app/shared/modules/table/table.component.html4
-rw-r--r--components/datalake-handler/admin/src/src/app/shared/modules/table/table.component.ts15
-rw-r--r--components/datalake-handler/admin/src/src/app/views/tools/modal-tools/modal-tools.component.css58
-rw-r--r--components/datalake-handler/admin/src/src/app/views/tools/modal-tools/modal-tools.component.html125
-rw-r--r--components/datalake-handler/admin/src/src/app/views/tools/modal-tools/modal-tools.component.spec.ts47
-rw-r--r--components/datalake-handler/admin/src/src/app/views/tools/modal-tools/modal-tools.component.ts98
-rw-r--r--components/datalake-handler/admin/src/src/app/views/tools/tool-add-modal/tool-add-modal.component.css34
-rw-r--r--components/datalake-handler/admin/src/src/app/views/tools/tool-add-modal/tool-add-modal.component.html63
-rw-r--r--components/datalake-handler/admin/src/src/app/views/tools/tool-add-modal/tool-add-modal.component.spec.ts47
-rw-r--r--components/datalake-handler/admin/src/src/app/views/tools/tool-add-modal/tool-add-modal.component.ts123
-rw-r--r--components/datalake-handler/admin/src/src/app/views/tools/tools.component.css21
-rw-r--r--components/datalake-handler/admin/src/src/app/views/tools/tools.component.html58
-rw-r--r--components/datalake-handler/admin/src/src/app/views/tools/tools.component.spec.ts47
-rw-r--r--components/datalake-handler/admin/src/src/app/views/tools/tools.component.ts184
-rw-r--r--components/datalake-handler/admin/src/src/assets/i18n/en-us.json6
20 files changed, 951 insertions, 20 deletions
diff --git a/components/datalake-handler/admin/src/src/app/app-routing.module.ts b/components/datalake-handler/admin/src/src/app/app-routing.module.ts
index 71c11201..ae2f9b6e 100644
--- a/components/datalake-handler/admin/src/src/app/app-routing.module.ts
+++ b/components/datalake-handler/admin/src/src/app/app-routing.module.ts
@@ -35,9 +35,8 @@ import { KafkaComponent } from "./views/kafka/kafka.component";
import { TopicsComponent } from "./views/topics/topics.component";
import { DatabaseComponent } from "./views/database/database.component";
import { AboutComponent } from "./views/about/about.component";
-import { DashboardSettingComponent } from './views/dashboard-setting/dashboard-setting.component';
-import { DashboardListComponent } from './views/dashboard-setting/dashboard-list/dashboard-list.component';
import { TemplateComponent } from './views/dashboard-setting/template/template.component';
+import {ToolsComponent} from "./views/tools/tools.component";
const routes: Routes = [
{ path: "", redirectTo: "/feeder", pathMatch: "full" },
@@ -47,7 +46,7 @@ const routes: Routes = [
{ path: "topics", component: TopicsComponent },
{ path: "database", component: DatabaseComponent },
{ path: "about", component: AboutComponent },
- { path: 'dashboard-setting/dashboard-list', component: DashboardListComponent },
+ { path: 'tools', component: ToolsComponent },
{ path: 'dashboard-setting/template', component: TemplateComponent },
];
diff --git a/components/datalake-handler/admin/src/src/app/app.module.ts b/components/datalake-handler/admin/src/src/app/app.module.ts
index 3c52716c..927f229a 100644
--- a/components/datalake-handler/admin/src/src/app/app.module.ts
+++ b/components/datalake-handler/admin/src/src/app/app.module.ts
@@ -65,6 +65,12 @@ import { HdfsComponent } from "./views/database/database-list/dbs-modal/hdfs/hdf
import { DatabaseAddModalComponent } from "./views/database/database-list/database-add-modal/database-add-modal.component";
import { ElasticsearchComponent } from "./views/database/database-list/dbs-modal/elasticsearch/elasticsearch.component";
import { DruidComponent } from "./views/database/database-list/dbs-modal/druid/druid.component";
+import { KafkaListComponent } from './views/kafka/kafka-list/kafka-list.component';
+import { NewKafkaModalComponent } from './views/kafka/kafka-list/new-kafka-modal/new-kafka-modal.component';
+import { EditKafkaModalComponent } from './views/kafka/kafka-list/edit-kafka-modal/edit-kafka-modal.component';
+import { ToolsComponent } from './views/tools/tools.component';
+import { ModalToolsComponent } from './views/tools/modal-tools/modal-tools.component';
+import { ToolAddModalComponent } from './views/tools/tool-add-modal/tool-add-modal.component';
// Modals
import { TopicDetailModalComponent } from "./views/topics/topic-list/topic-detail-modal/topic-detail-modal.component";
@@ -94,10 +100,6 @@ import { ModalDemoComponent } from "./views/test/modal-demo/modal-demo.component
import { KafkaComponent } from './views/kafka/kafka.component';
// Angular SVG Icon
import { AngularSvgIconModule } from "angular-svg-icon";
-import { KafkaListComponent } from './views/kafka/kafka-list/kafka-list.component';
-import { NewKafkaModalComponent } from './views/kafka/kafka-list/new-kafka-modal/new-kafka-modal.component';
-import { EditKafkaModalComponent } from './views/kafka/kafka-list/edit-kafka-modal/edit-kafka-modal.component';
-
@NgModule({
declarations: [
@@ -139,7 +141,10 @@ import { EditKafkaModalComponent } from './views/kafka/kafka-list/edit-kafka-mod
KafkaComponent,
KafkaListComponent,
NewKafkaModalComponent,
- EditKafkaModalComponent
+ EditKafkaModalComponent,
+ ToolsComponent,
+ ModalToolsComponent,
+ ToolAddModalComponent
],
imports: [
BrowserModule,
@@ -178,7 +183,9 @@ import { EditKafkaModalComponent } from './views/kafka/kafka-list/edit-kafka-mod
ModalDemoComponent,
KafkaComponent,
NewKafkaModalComponent,
- EditKafkaModalComponent
+ EditKafkaModalComponent,
+ ToolAddModalComponent,
+ ModalToolsComponent
]
})
export class AppModule {}
diff --git a/components/datalake-handler/admin/src/src/app/shared/components/Button/button.component.html b/components/datalake-handler/admin/src/src/app/shared/components/Button/button.component.html
index 3e753df3..7986886a 100644
--- a/components/datalake-handler/admin/src/src/app/shared/components/Button/button.component.html
+++ b/components/datalake-handler/admin/src/src/app/shared/components/Button/button.component.html
@@ -15,12 +15,14 @@
<i *ngIf="this.text==='search'" class="fa fa-search"></i>
<i *ngIf="this.text==='plus'" class="fa fa-plus fa-xs" aria-hidden="true"></i>
<i *ngIf="this.text==='trash'" class="fa fa-trash fa-xs" aria-hidden="true"></i>
+ <i *ngIf="this.text==='cog'" class="fas fa-cog fa-xs" aria-hidden="true"></i>
</span>
</button>
<!-- icon type buttons -->
-<button type="button" *ngIf="this.buttonstyle===3" class="btn dl-icon-enable p-2">
+<button type="button" *ngIf="this.buttonstyle===3" class="btn dl-icon-enable p-2" (click)="buttonClick(this.text)">
<i *ngIf="this.text==='search'" class="fa fa-search"></i>
<i *ngIf="this.text==='plus'" class="fa fa-plus fa-xs" aria-hidden="true"></i>
<i *ngIf="this.text==='trash'" class="fa fa-trash fa-xs" aria-hidden="true"></i>
-</button> \ No newline at end of file
+ <i *ngIf="this.text==='cog'" class="fas fa-cog fa-xs" aria-hidden="true"></i>
+</button>
diff --git a/components/datalake-handler/admin/src/src/app/shared/components/Button/button.component.ts b/components/datalake-handler/admin/src/src/app/shared/components/Button/button.component.ts
index b01260e9..c78bfe51 100644
--- a/components/datalake-handler/admin/src/src/app/shared/components/Button/button.component.ts
+++ b/components/datalake-handler/admin/src/src/app/shared/components/Button/button.component.ts
@@ -20,9 +20,11 @@
*
* @author Xu Ran
*
+ * @contributor Chunmeng Guo
+ *
*/
-import { Component, OnInit, Input } from '@angular/core';
+import {Component, OnInit, Input, Output, EventEmitter} from '@angular/core';
@Component({
selector: 'app-button',
@@ -42,6 +44,7 @@ export class ButtonComponent implements OnInit {
@Input() text: string;
@Input() style: string;
@Input() color: string;
+ @Output() btnAction = new EventEmitter<object>()
buttonstyle: number;
buttoncolor: number;
constructor() { }
@@ -72,4 +75,7 @@ export class ButtonComponent implements OnInit {
}
}
+ buttonClick(string) {
+ this.btnAction.emit(string);
+ }
}
diff --git a/components/datalake-handler/admin/src/src/app/shared/layout/sidebar/sidebar.component.html b/components/datalake-handler/admin/src/src/app/shared/layout/sidebar/sidebar.component.html
index 42835a54..2e463883 100644
--- a/components/datalake-handler/admin/src/src/app/shared/layout/sidebar/sidebar.component.html
+++ b/components/datalake-handler/admin/src/src/app/shared/layout/sidebar/sidebar.component.html
@@ -59,8 +59,7 @@ limitations under the License.
<li class="nav-item">
<a class="nav-link" [routerLinkActive]="['active']" [routerLinkActiveOptions]="{exact:true}"
- routerLink="/dashboard-setting/dashboard-list"
- >
+ routerLink="/tools">
<i class="fas fa-external-link-alt" aria-hidden="true">&nbsp;</i>
{{"SIDEBAR.DASHBOARDLIST" | translate}}
</a>
diff --git a/components/datalake-handler/admin/src/src/app/shared/modules/table/table.component.html b/components/datalake-handler/admin/src/src/app/shared/modules/table/table.component.html
index e37065bc..80be23dd 100644
--- a/components/datalake-handler/admin/src/src/app/shared/modules/table/table.component.html
+++ b/components/datalake-handler/admin/src/src/app/shared/modules/table/table.component.html
@@ -19,7 +19,7 @@
</app-button>
</span>
<span *ngIf="column.icon&&column.icon.length!==0">
- <app-button [text]="column.icon" [style]="'icon'" [color]="'dark'">
+ <app-button [text]="column.icon" [style]="'icon'" [color]="'dark'" (btnAction)="tableAction($event, row.id)">
</app-button>
</span>
</ng-template>
@@ -37,4 +37,4 @@
</ngx-datatable>
</div>
-</div> \ No newline at end of file
+</div>
diff --git a/components/datalake-handler/admin/src/src/app/shared/modules/table/table.component.ts b/components/datalake-handler/admin/src/src/app/shared/modules/table/table.component.ts
index 933582a4..9c69e125 100644
--- a/components/datalake-handler/admin/src/src/app/shared/modules/table/table.component.ts
+++ b/components/datalake-handler/admin/src/src/app/shared/modules/table/table.component.ts
@@ -1,4 +1,8 @@
-import { Component, OnInit, Input } from '@angular/core';
+import {Component, OnInit, Input, Output, EventEmitter} from '@angular/core';
+
+/**
+ * @contributor Chunmeng Guo
+ */
@Component({
selector: 'app-table',
@@ -8,7 +12,7 @@ import { Component, OnInit, Input } from '@angular/core';
export class TableComponent implements OnInit {
@Input() columns: Array<any> = [];
@Input() data: Array<any> = [];
-
+ @Output() btnTableAction = new EventEmitter<object>()
loadingIndicator: boolean = false;
template_list: Array<any> = [];
@@ -27,4 +31,11 @@ export class TableComponent implements OnInit {
ngOnInit() {
}
+
+ tableAction($event, actionId: number) {
+ let passValueArr: Array<any> = [];
+ passValueArr.push($event);
+ passValueArr.push(actionId);
+ this.btnTableAction.emit(passValueArr);
+ }
}
diff --git a/components/datalake-handler/admin/src/src/app/views/tools/modal-tools/modal-tools.component.css b/components/datalake-handler/admin/src/src/app/views/tools/modal-tools/modal-tools.component.css
new file mode 100644
index 00000000..1d234f73
--- /dev/null
+++ b/components/datalake-handler/admin/src/src/app/views/tools/modal-tools/modal-tools.component.css
@@ -0,0 +1,58 @@
+/*
+ Copyright (C) 2019 CMCC, Inc. and others. All rights reserved.
+
+ Licensed under the Apache License, Version 2.0 (the "License");
+ you may not use this file except in compliance with the License.
+ You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+*/
+
+.row-wrapper{
+ display: flex;
+}
+.row-quarter-item{
+ width: 20%;
+ margin-bottom: 15px;
+}
+.row-half-item{
+ width: 45%;
+}
+.row-half-item2{
+ width: 50%;
+}
+.usual-item{
+ margin-left: 2%;
+}
+.usual-item2{
+ margin-left: 6.5%;
+}
+input::-webkit-input-placeholder {
+ font-size: 12px;
+ color: #999999 !important;
+}
+input:-moz-placeholder {
+ /* Mozilla Firefox 4 to 18 */
+ font-size: 12px;
+ color: #999999 !important;
+}
+input::-moz-placeholder {
+ /* Mozilla Firefox 19+ */
+ font-size: 12px;
+ color: #999999 !important;
+}
+input::-ms-input-placeholder {
+ /* Internet Explorer 10+ */
+ font-size: 12px;
+ color: #999999 !important;
+}
+
+.input_style {
+ width: 200px;
+}
diff --git a/components/datalake-handler/admin/src/src/app/views/tools/modal-tools/modal-tools.component.html b/components/datalake-handler/admin/src/src/app/views/tools/modal-tools/modal-tools.component.html
new file mode 100644
index 00000000..0b0b4622
--- /dev/null
+++ b/components/datalake-handler/admin/src/src/app/views/tools/modal-tools/modal-tools.component.html
@@ -0,0 +1,125 @@
+<!--
+ Copyright (C) 2019 CMCC, Inc. and others. All rights reserved.
+
+ Licensed under the Apache License, Version 2.0 (the "License");
+ you may not use this file except in compliance with the License.
+ You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+-->
+
+<div class="p-1">
+ <div class="modal-header pb-0 border-0">
+ <div class="container-fluid">
+ <div class="row">
+ <div class="col-md-12">
+ <label class="dl-h3">{{ this.toolInputTitle }}</label>
+ </div>
+ </div>
+ <div class="row">
+ <div class="col-md-12">
+ <hr>
+ </div>
+ </div>
+ </div>
+ </div>
+
+ <div class="modal-body border-0">
+ <div class="container">
+
+ <div class="form-group row row-wrapper">
+ <div class="row-half-item usual-item">
+ <div>
+ <label class="dl-emphasis1" >{{ 'NAME' | translate }}</label>
+ </div>
+ <div>
+ <input [(ngModel)]="this.toolInput.name" class="form-control dl-input-text input_style" placeholder="" type="text"/>
+ </div>
+ </div>
+
+ <div class="row-half-item usual-item">
+ <div>
+ <label class="dl-emphasis1" >{{ 'STATUS' | translate }}</label>
+ </div>
+ <div>
+ <label class="dl-switch">
+ <input [(ngModel)]="this.toolInput.enabled" id="switch" type="checkbox" />
+ <span class="dl-slider round"></span>
+ </label>
+ </div>
+ </div>
+ </div>
+
+ <div class="form-group row row-wrapper">
+ <div class="row-half-item usual-item">
+ <div>
+ <label class="dl-emphasis1" >{{ 'HOST' | translate }}</label>
+ </div>
+ <div>
+ <input [(ngModel)]="this.toolInput.host" class="form-control dl-input-text input_style" type="text" placeholder="0.0.0.0" required="required" />
+ </div>
+ </div>
+
+ <div class="row-half-item usual-item">
+ <div>
+ <label class="dl-emphasis1" >{{ 'PORT' | translate }}</label>
+ </div>
+ <div>
+ <input [(ngModel)]="this.toolInput.port" class="form-control dl-input-text input_style" type="text" placeholder="0.0.0.0" required="required" />
+ </div>
+ </div>
+ </div>
+
+ <div class="form-group row row-wrapper">
+ <div class="row-half-item usual-item">
+ <div>
+ <label class="dl-emphasis1" >{{ 'Username' | translate }}</label>
+ </div>
+ <div>
+ <input [(ngModel)]="this.toolInput.login" class="form-control dl-input-text input_style" type="text" placeholder="login" required="required" />
+ </div>
+ </div>
+
+ <div class="row-half-item usual-item">
+ <div>
+ <label class="dl-emphasis1" >{{ 'Password' | translate }}</label>
+ </div>
+ <div>
+ <input [(ngModel)]="this.toolInput.pass" class="form-control dl-input-text input_style" type="text" placeholder="pass" required="required" />
+ </div>
+ </div>
+ </div>
+ </div>
+ </div>
+
+
+ <div class="modal-footer border-0 pt-0 pb-2">
+ <div class="container">
+ <div class="row">
+ <div class="col-md-6 p-0">
+
+ </div>
+ <div class="col-md-3 p-1">
+ <span>
+ <button type="button" class="btn dl-btn-dark btn-block" (click)="this.passBack()">
+ Save
+ </button>
+ </span>
+ </div>
+ <div class="col-md-3 p-1">
+ <span>
+ <button type="button" class="btn dl-btn-light btn-block" (click)="activeModal.close('Close click')">
+ Cancel
+ </button>
+ </span>
+ </div>
+ </div>
+ </div>
+ </div>
+</div>
diff --git a/components/datalake-handler/admin/src/src/app/views/tools/modal-tools/modal-tools.component.spec.ts b/components/datalake-handler/admin/src/src/app/views/tools/modal-tools/modal-tools.component.spec.ts
new file mode 100644
index 00000000..44c6e2ce
--- /dev/null
+++ b/components/datalake-handler/admin/src/src/app/views/tools/modal-tools/modal-tools.component.spec.ts
@@ -0,0 +1,47 @@
+/*
+ Copyright (C) 2019 CMCC, Inc. and others. All rights reserved.
+
+ Licensed under the Apache License, Version 2.0 (the "License");
+ you may not use this file except in compliance with the License.
+ You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+*/
+
+/**
+ *
+ * @author Chunmeng Guo
+ *
+ */
+
+import { async, ComponentFixture, TestBed } from '@angular/core/testing';
+
+import { ModalToolsComponent } from './modal-tools.component';
+
+describe('ModalToolsComponent', () => {
+ let component: ModalToolsComponent;
+ let fixture: ComponentFixture<ModalToolsComponent>;
+
+ beforeEach(async(() => {
+ TestBed.configureTestingModule({
+ declarations: [ ModalToolsComponent ]
+ })
+ .compileComponents();
+ }));
+
+ beforeEach(() => {
+ fixture = TestBed.createComponent(ModalToolsComponent);
+ component = fixture.componentInstance;
+ fixture.detectChanges();
+ });
+
+ it('should create', () => {
+ expect(component).toBeTruthy();
+ });
+});
diff --git a/components/datalake-handler/admin/src/src/app/views/tools/modal-tools/modal-tools.component.ts b/components/datalake-handler/admin/src/src/app/views/tools/modal-tools/modal-tools.component.ts
new file mode 100644
index 00000000..8ffeaadf
--- /dev/null
+++ b/components/datalake-handler/admin/src/src/app/views/tools/modal-tools/modal-tools.component.ts
@@ -0,0 +1,98 @@
+/*
+ Copyright (C) 2019 CMCC, Inc. and others. All rights reserved.
+
+ Licensed under the Apache License, Version 2.0 (the "License");
+ you may not use this file except in compliance with the License.
+ You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+*/
+
+/**
+ *
+ * @author Chunmeng Guo
+ *
+ */
+
+import {Component, EventEmitter, Input, OnInit, Output} from '@angular/core';
+import {Db} from "src/app/core/models/db.model";
+import {NgbActiveModal} from "@ng-bootstrap/ng-bootstrap";
+import {AdminService} from "src/app/core/services/admin.service";
+import {NgxSpinnerService} from "ngx-spinner";
+
+@Component({
+ selector: 'app-modal-tools',
+ templateUrl: './modal-tools.component.html',
+ styleUrls: ['./modal-tools.component.css']
+})
+export class ModalToolsComponent implements OnInit {
+
+ @Output() passEntry: EventEmitter<any> = new EventEmitter();
+ @Input() editTool: Db;
+ @Input() tool: Db;
+ @Input() toolList_length;
+ toolInput: Db;
+ d_dbTypeId: string = "";
+
+ defaultDbType: string;
+ toolInputTitle = "";
+ data: string;
+ constructor(
+ public activeModal: NgbActiveModal,
+ public adminService: AdminService,
+ private spinner: NgxSpinnerService
+ ) { }
+
+ ngOnInit() {
+ if (this.editTool == null) {
+ this.toolInput = new Db();
+ const feed = {
+ id: null,
+ name: this.tool.name,
+ enabled: this.tool.enabled,
+ host: this.tool.host,
+ port: this.tool.port,
+ database: this.tool.database,
+ encrypt: this.tool.encrypt,
+ login: this.tool.login,
+ pass: this.tool.pass,
+ dbTypeId: this.tool.dbTypeId
+ }
+ this.toolInput = feed;
+ this.toolInputTitle = this.data === "Kibana" ? "New Kibana" : "New Superset";
+ console.log("create db");
+
+ } else {
+ this.toolInput = this.editTool;
+ this.toolInputTitle = "Edit " + this.editTool.name;
+ this.defaultDbType = this.toolInput.dbTypeId;
+ console.log("edit db");
+ }
+ }
+
+ passBack() {
+ this.spinner.show();
+ if (this.toolInput.name == '' || this.toolInput.name == undefined) {
+ return false;
+ }
+ this.editTool = this.toolInput;
+ if (this.data == '' || this.data == undefined) {
+ this.editTool.dbTypeId = this.toolInput.dbTypeId;
+ } else {
+ this.editTool.dbTypeId = this.data === "Kibana" ? "KIBANA" : "SUPERSET";
+ }
+ this.editTool.encrypt = false;
+ console.log(this.editTool, "editTool");
+ this.passEntry.emit(this.editTool);
+ setTimeout(() => {
+ this.spinner.hide();
+ }, 500);
+ }
+
+}
diff --git a/components/datalake-handler/admin/src/src/app/views/tools/tool-add-modal/tool-add-modal.component.css b/components/datalake-handler/admin/src/src/app/views/tools/tool-add-modal/tool-add-modal.component.css
new file mode 100644
index 00000000..b55b3001
--- /dev/null
+++ b/components/datalake-handler/admin/src/src/app/views/tools/tool-add-modal/tool-add-modal.component.css
@@ -0,0 +1,34 @@
+/*
+ Copyright (C) 2019 CMCC, Inc. and others. All rights reserved.
+
+ Licensed under the Apache License, Version 2.0 (the "License");
+ you may not use this file except in compliance with the License.
+ You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+*/
+
+.nav-pills .nav-link.active,
+.nav-pills .nav-link:hover {
+ color: #ffffff;
+ background-color: #5DBEBB;
+}
+
+.nav-link {
+ font-family: "Open Sans", sans-serif;
+ font-weight: 400;
+ font-size: 14px;
+ color: #313449;
+ text-align: left;
+ border-radius: 0px;
+}
+
+.nav-pills .show>.nav-link {
+ background-color: #FFFFFF;
+}
diff --git a/components/datalake-handler/admin/src/src/app/views/tools/tool-add-modal/tool-add-modal.component.html b/components/datalake-handler/admin/src/src/app/views/tools/tool-add-modal/tool-add-modal.component.html
new file mode 100644
index 00000000..2169325f
--- /dev/null
+++ b/components/datalake-handler/admin/src/src/app/views/tools/tool-add-modal/tool-add-modal.component.html
@@ -0,0 +1,63 @@
+<!--
+ Copyright (C) 2019 CMCC, Inc. and others. All rights reserved.
+
+ Licensed under the Apache License, Version 2.0 (the "License");
+ you may not use this file except in compliance with the License.
+ You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+-->
+
+<div class="p-0">
+ <div class="modal-header pb-0 border-0">
+ <div class="container-fluid">
+ <div class="row">
+ <div class="col-md-12">
+ <label class="dl-h3">{{ 'NEW_TOOL' | translate }}</label>
+ </div>
+ </div>
+ <div class="row">
+ <div class="col-md-12">
+ <hr/>
+ </div>
+ </div>
+ </div>
+ </div>
+ <div class="modal-body p-0">
+ <div class="container-fluid">
+ <div class="tab-content mb-auto" id="v-pills-tabContent">
+ <!-- All -->
+ <div class="tab-pane fade show active" id="v-pills-all" role="tabpanel" aria-labelledby="v-pills-all-tab">
+ <div class="nav flex-column nav-pills" id="menu-tab2" role="tablist" aria-orientation="vertical">
+ <a class="nav-link" (click)="this.clickItem('Kibana')" data-toggle="pill" role="tab"
+ aria-selected="true">Kibana</a>
+ <a class="nav-link" (click)="this.clickItem('Superset')" data-toggle="pill" role="tab"
+ aria-selected="true">Superset</a>
+ </div>
+ </div>
+ </div>
+ <div class="d-flex mt-auto justify-content-end p-3">
+ <div class="p-1 col-sm-3">
+ <span>
+ <button type="button" class="btn dl-btn-dark btn-block" (click)="this.passBack()">
+ Next
+ </button>
+ </span>
+ </div>
+ <div class="p-1 col-sm-3">
+ <span>
+ <button type="button" class="btn dl-btn-light btn-block" (click)="activeModal.close('Close click')">
+ Cancel
+ </button>
+ </span>
+ </div>
+ </div>
+ </div>
+ </div>
+</div>
diff --git a/components/datalake-handler/admin/src/src/app/views/tools/tool-add-modal/tool-add-modal.component.spec.ts b/components/datalake-handler/admin/src/src/app/views/tools/tool-add-modal/tool-add-modal.component.spec.ts
new file mode 100644
index 00000000..cabc951e
--- /dev/null
+++ b/components/datalake-handler/admin/src/src/app/views/tools/tool-add-modal/tool-add-modal.component.spec.ts
@@ -0,0 +1,47 @@
+/*
+ Copyright (C) 2019 CMCC, Inc. and others. All rights reserved.
+
+ Licensed under the Apache License, Version 2.0 (the "License");
+ you may not use this file except in compliance with the License.
+ You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+*/
+
+/**
+ *
+ * @author Chunmeng Guo
+ *
+ */
+
+import { async, ComponentFixture, TestBed } from '@angular/core/testing';
+
+import { ToolAddModalComponent } from './tool-add-modal.component';
+
+describe('ToolAddModalComponent', () => {
+ let component: ToolAddModalComponent;
+ let fixture: ComponentFixture<ToolAddModalComponent>;
+
+ beforeEach(async(() => {
+ TestBed.configureTestingModule({
+ declarations: [ ToolAddModalComponent ]
+ })
+ .compileComponents();
+ }));
+
+ beforeEach(() => {
+ fixture = TestBed.createComponent(ToolAddModalComponent);
+ component = fixture.componentInstance;
+ fixture.detectChanges();
+ });
+
+ it('should create', () => {
+ expect(component).toBeTruthy();
+ });
+});
diff --git a/components/datalake-handler/admin/src/src/app/views/tools/tool-add-modal/tool-add-modal.component.ts b/components/datalake-handler/admin/src/src/app/views/tools/tool-add-modal/tool-add-modal.component.ts
new file mode 100644
index 00000000..25087d80
--- /dev/null
+++ b/components/datalake-handler/admin/src/src/app/views/tools/tool-add-modal/tool-add-modal.component.ts
@@ -0,0 +1,123 @@
+/*
+ Copyright (C) 2019 CMCC, Inc. and others. All rights reserved.
+
+ Licensed under the Apache License, Version 2.0 (the "License");
+ you may not use this file except in compliance with the License.
+ You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+*/
+
+/**
+ *
+ * @author Chunmeng Guo
+ *
+ */
+
+import {Component, EventEmitter, OnInit, Output} from '@angular/core';
+import {Db} from "src/app/core/models/db.model";
+import {NgbActiveModal, NgbModal} from "@ng-bootstrap/ng-bootstrap";
+import {NgxSpinnerService} from "ngx-spinner";
+import {ToastrNotificationService} from "src/app/shared/components/toastr-notification/toastr-notification.service";
+import {RestApiService} from "src/app/core/services/rest-api.service";
+import {ModalToolsComponent} from "src/app/views/tools/modal-tools/modal-tools.component";
+
+@Component({
+ selector: 'app-tool-add-modal',
+ templateUrl: './tool-add-modal.component.html',
+ styleUrls: ['./tool-add-modal.component.css']
+})
+export class ToolAddModalComponent implements OnInit {
+
+ @Output() passEntry: EventEmitter<any> = new EventEmitter();
+ seletedItem: string = "";
+ toolList: any = [];
+ loading: Boolean = true;
+ toolNew: Db;
+ tool_NewBody: Db;
+ constructor(
+ public activeModal: NgbActiveModal,
+ private spinner: NgxSpinnerService,
+ private notificationService: ToastrNotificationService,
+ private modalService: NgbModal,
+ private dbApiService: RestApiService
+ ) { }
+
+ ngOnInit() {
+ }
+
+ clickItem(name: string) {
+ this.seletedItem = name;
+ }
+
+ passBack() {
+ console.log(this.seletedItem, "next");
+ this.openNewModal(this.seletedItem);
+ }
+
+ newTool(modalRef) {
+ this.toolNew = new Db();
+ this.tool_NewBody = new Db();
+ modalRef.componentInstance.tool = this.tool_NewBody;
+ modalRef.componentInstance.toolList_length = this.toolList.length;
+ modalRef.componentInstance.passEntry.subscribe(receivedEntry => {
+ this.tool_NewBody = receivedEntry;
+ this.dbApiService
+ .createDb(this.tool_NewBody)
+ .subscribe(
+ res => {
+ this.spinner.hide();
+ if (res.statusCode == 200) {
+ this.toolNew = res.returnBody;
+ this.toolList.push(this.toolNew);
+ this.toolList = [...this.toolList];
+ this.notificationService.success("SUCCESSFULLY_CREARED");
+ } else {
+ this.notificationService.error("FAILED_CREARED");
+ }
+ modalRef.close();
+ },
+ err => {
+ this.spinner.hide();
+ this.notificationService.error(err);
+ modalRef.close();
+ }
+ );
+ });
+ }
+
+ openNewModal(name: string) {
+ let modalRef;
+
+ switch (name) {
+ case "Kibana": {
+ modalRef = this.modalService.open(ModalToolsComponent, {
+ size: "lg",
+ centered: true
+ });
+ modalRef.componentInstance.data = name;
+ this.newTool(modalRef);
+ break;
+ }
+ case "Superset": {
+ modalRef = this.modalService.open(ModalToolsComponent, {
+ size: "lg",
+ centered: true
+ });
+ modalRef.componentInstance.data = name;
+ this.newTool(modalRef);
+ break;
+ }
+ default: {
+ break;
+ }
+ }
+ }
+
+}
diff --git a/components/datalake-handler/admin/src/src/app/views/tools/tools.component.css b/components/datalake-handler/admin/src/src/app/views/tools/tools.component.css
new file mode 100644
index 00000000..2fabd8a0
--- /dev/null
+++ b/components/datalake-handler/admin/src/src/app/views/tools/tools.component.css
@@ -0,0 +1,21 @@
+/*
+ Copyright (C) 2019 CMCC, Inc. and others. All rights reserved.
+
+ Licensed under the Apache License, Version 2.0 (the "License");
+ you may not use this file except in compliance with the License.
+ You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+*/
+
+.topic-list-panel {
+ background: #FFFFFF;
+ box-shadow: 3px 3px 11px 0 #D2D3D5;
+ border-radius: 20px;
+}
diff --git a/components/datalake-handler/admin/src/src/app/views/tools/tools.component.html b/components/datalake-handler/admin/src/src/app/views/tools/tools.component.html
new file mode 100644
index 00000000..c55fa463
--- /dev/null
+++ b/components/datalake-handler/admin/src/src/app/views/tools/tools.component.html
@@ -0,0 +1,58 @@
+<!--
+ Copyright (C) 2019 CMCC, Inc. and others. All rights reserved.
+
+ Licensed under the Apache License, Version 2.0 (the "License");
+ you may not use this file except in compliance with the License.
+ You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+-->
+
+<div class="row">
+ <div class="col-md-12 pb-2 path">
+ Home > Tools
+ </div>
+ <div class="col-md-12">
+ <div class="topic-list-panel">
+ <div class="row">
+ <div class="col-md-12">
+ <div class="d-flex justify-content-end p-2">
+ <!-- Search bar -->
+ <div class="p-1">
+ <div class="input-group">
+ <input #searchText type="text" class="form-control dl-input-text-search" placeholder="Search..."
+ (keyup)="this.updateFilter($event.target.value)" />
+ <div class="input-group-append">
+ <button type="button" class="btn dl-btn-dark">
+ <i class="fa fa-search"></i>
+ </button>
+ </div>
+ </div>
+ </div>
+
+ <!-- button -->
+ <div class="p-1">
+ <app-button [text]="'plus'" [style]="'inlineicon'" [color]="'dark'" (click)="openModalDemo()"></app-button>
+ </div>
+ </div>
+ </div>
+ </div>
+ <!-- datatable -->
+ <div class="row">
+ <div class="col-md-12">
+ <app-table [data]="toolsList" [columns]="toolsColumns" (btnTableAction)="dataAction($event)">
+ </app-table>
+ </div>
+ </div>
+ </div>
+ </div>
+</div>
+
+
+
diff --git a/components/datalake-handler/admin/src/src/app/views/tools/tools.component.spec.ts b/components/datalake-handler/admin/src/src/app/views/tools/tools.component.spec.ts
new file mode 100644
index 00000000..6c02dd8c
--- /dev/null
+++ b/components/datalake-handler/admin/src/src/app/views/tools/tools.component.spec.ts
@@ -0,0 +1,47 @@
+/*
+ Copyright (C) 2019 CMCC, Inc. and others. All rights reserved.
+
+ Licensed under the Apache License, Version 2.0 (the "License");
+ you may not use this file except in compliance with the License.
+ You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+*/
+
+/**
+ *
+ * @author Chunmeng Guo
+ *
+ */
+
+import { async, ComponentFixture, TestBed } from '@angular/core/testing';
+
+import { ToolsComponent } from './tools.component';
+
+describe('ToolsComponent', () => {
+ let component: ToolsComponent;
+ let fixture: ComponentFixture<ToolsComponent>;
+
+ beforeEach(async(() => {
+ TestBed.configureTestingModule({
+ declarations: [ ToolsComponent ]
+ })
+ .compileComponents();
+ }));
+
+ beforeEach(() => {
+ fixture = TestBed.createComponent(ToolsComponent);
+ component = fixture.componentInstance;
+ fixture.detectChanges();
+ });
+
+ it('should create', () => {
+ expect(component).toBeTruthy();
+ });
+});
diff --git a/components/datalake-handler/admin/src/src/app/views/tools/tools.component.ts b/components/datalake-handler/admin/src/src/app/views/tools/tools.component.ts
new file mode 100644
index 00000000..ebe33e49
--- /dev/null
+++ b/components/datalake-handler/admin/src/src/app/views/tools/tools.component.ts
@@ -0,0 +1,184 @@
+/*
+ Copyright (C) 2019 CMCC, Inc. and others. All rights reserved.
+
+ Licensed under the Apache License, Version 2.0 (the "License");
+ you may not use this file except in compliance with the License.
+ You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+*/
+
+/**
+ *
+ * @author Chunmeng Guo
+ *
+ */
+
+import {Component, ElementRef, OnInit, ViewChild} from '@angular/core';
+import {AdminService} from "src/app/core/services/admin.service";
+import {Db} from "src/app/core/models/db.model";
+import {RestApiService} from "src/app/core/services/rest-api.service";
+import {AlertComponent} from "src/app/shared/components/alert/alert.component";
+import {ToastrNotificationService} from "src/app/shared/components/toastr-notification/toastr-notification.service";
+import {NgbModal} from "@ng-bootstrap/ng-bootstrap";
+import {ToolAddModalComponent} from "src/app/views/tools/tool-add-modal/tool-add-modal.component";
+import {ModalToolsComponent} from "src/app/views/tools/modal-tools/modal-tools.component";
+
+@Component({
+ selector: 'app-tools',
+ templateUrl: './tools.component.html',
+ styleUrls: ['./tools.component.css']
+})
+export class ToolsComponent implements OnInit {
+
+ toolsColumns: Array<any> = [];
+ toolsList: Array<any> = [];
+ dbs: Db[] = [];
+ toolNew: Db;
+ loading: Boolean = true;
+ flag: Boolean = false;
+
+ @ViewChild("searchText") searchText: ElementRef;
+
+ constructor(
+ private adminService: AdminService,
+ private notificationService: ToastrNotificationService,
+ private modalService: NgbModal,
+ private dbApiService: RestApiService,
+ ) {
+ this.adminService.setTitle("SIDEBAR.DASHBOARDLIST");
+ this.initData().then(data => { });
+ }
+
+ ngOnInit() {
+ this.toolsColumns = [
+ {
+ name: "STATUS",
+ width: "50",
+ dataIndex: "enabled"
+ },
+ {
+ name: "NAME",
+ width: "220",
+ dataIndex: "name"
+ },
+ {
+ name: "DB_TYPE",
+ width: "220",
+ dataIndex: "dbTypeId"
+ },
+ {
+ name: "",
+ width: "5",
+ dataIndex: "",
+ icon: "trash"
+ },
+ {
+ name: "",
+ width: "5",
+ dataIndex: "",
+ icon: "cog"
+ }
+ ];
+ }
+
+ async initData() {
+ this.toolsList = await this.dbApiService.getDbEncryptList(this.flag).toPromise();
+ }
+
+ updateFilter(searchValue) {
+ const val = searchValue.toLowerCase();
+ // filter our data
+ const temps = this.toolsList.filter(function (d) {
+ return d.name.toLowerCase().indexOf(val) != -1 || !val;
+ });
+ // update the rows
+ this.toolsList = temps;
+ }
+
+ openModalDemo() {
+ this.modalService.open(ToolAddModalComponent, {
+ windowClass: "dl-md-modal dbs",
+ size: "sm",
+ centered: true
+ });
+ }
+
+ dataAction($event) {
+ if($event[0] == "trash"){
+ console.log($event, "tools 中触发执行删除操作");
+ this.deleteToolModel($event[1]);
+ }else {
+ console.log($event, "tools 中触发执行修改操作");
+ this.updateToolModel($event[1]);
+ }
+ }
+
+ deleteToolModel(id: number) {
+
+ const modalRef = this.modalService.open(AlertComponent, {
+ size: "sm",
+ centered: true
+ });
+ modalRef.componentInstance.message = "ARE_YOU_SURE_DELETE";
+ modalRef.componentInstance.passEntry.subscribe(receivedEntry => {
+ // Delete tool
+ this.dbApiService.deleteDb(id).subscribe(
+ res => {
+ if (JSON.stringify(res).length <= 2) {
+ this.toolsList = [...this.toolsList];
+ this.notificationService.success("SUCCESSFULLY_DELETED");
+ this.initData();
+ } else {
+ this.notificationService.error("FAILED_DELETED");
+ this.initData();
+ }
+ modalRef.close();
+ },
+ err => {
+ this.notificationService.error(err);
+ modalRef.close();
+ }
+ );
+ });
+ }
+
+ updateToolModel(id: number) {
+ const modalRef = this.modalService.open(ModalToolsComponent, {
+ size: "lg",
+ centered: true
+ });
+ const index = this.toolsList.findIndex(t => t.id === id);
+ modalRef.componentInstance.editTool = this.toolsList[index];
+ modalRef.componentInstance.passEntry.subscribe(receivedEntry => {
+ this.toolNew = receivedEntry;
+ this.dbApiService
+ .updateDb(this.toolNew)
+ .subscribe(
+ res => {
+ if (res.statusCode == 200) {
+ this.toolsList[index] = this.toolNew;
+ this.toolsList = [...this.toolsList];
+ this.notificationService.success("SUCCESSFULLY_UPDATED");
+ this.initData();
+ } else {
+ this.notificationService.error("FAILED_UPDATED");
+ this.initData();
+ }
+ modalRef.close();
+ },
+ err => {
+ this.notificationService.error(err);
+ modalRef.close();
+ }
+ );
+ })
+
+ }
+}
diff --git a/components/datalake-handler/admin/src/src/assets/i18n/en-us.json b/components/datalake-handler/admin/src/src/assets/i18n/en-us.json
index 046a57f7..05730d9d 100644
--- a/components/datalake-handler/admin/src/src/assets/i18n/en-us.json
+++ b/components/datalake-handler/admin/src/src/assets/i18n/en-us.json
@@ -5,7 +5,7 @@
"TOPICS": "Topics",
"DATABASE": "Database",
"DASHBOARD": "Portal Setting",
- "DASHBOARDLIST": "Portal",
+ "DASHBOARDLIST": "Tools",
"TEMPLATE": "Design",
"ABOUT": "About"
},
@@ -82,5 +82,7 @@
"NEW_MONGODB": "New MongoDB",
"NEW_HDFS": "New Hdfs",
"SECURE_COMMUNICATION": "Secure Communication",
- "DB_TYPE": "DbType"
+ "DB_TYPE": "DbType",
+ "NEW_TOOL": "New Tool",
+ "NEW_KIBANA": "New Kibana"
}