Remove the Deplicate utils in lib an app , fix #6365, #7807

1.remove the Deplicate utils in lib an app ,fix #6365
2.edit style fix #7807

Signed-off-by: Yogi_Wang <yawang@vmware.com>
This commit is contained in:
Yogi_Wang 2019-05-27 18:37:56 +08:00
parent fbec3ee76f
commit c52cb4fc9a
44 changed files with 165 additions and 459 deletions

View File

@ -1,28 +1,30 @@
export * from './harbor-library.module'; export * from "./harbor-library.module";
export * from './service.config'; export * from "./service.config";
export * from './service/index'; export * from "./service/index";
export * from './error-handler/index'; export * from "./error-handler/index";
export * from './utils'; export * from "./shared/shared.const";
export * from './log/index'; export * from "./shared/shared.utils";
export * from './filter/index'; export * from "./utils";
export * from './endpoint/index'; export * from "./log/index";
export * from './repository/index'; export * from "./filter/index";
export * from './create-edit-endpoint/index'; export * from "./endpoint/index";
export * from './create-edit-rule/index'; export * from "./repository/index";
export * from './tag/index'; export * from "./create-edit-endpoint/index";
export * from './list-replication-rule/index'; export * from "./create-edit-rule/index";
export * from './replication/index'; export * from "./tag/index";
export * from './vulnerability-scanning/index'; export * from "./list-replication-rule/index";
export * from './i18n/index'; export * from "./replication/index";
export * from './push-image/index'; export * from "./vulnerability-scanning/index";
export * from './third-party/index'; export * from "./i18n/index";
export * from './config/index'; export * from "./push-image/index";
export * from './channel/index'; export * from "./third-party/index";
export * from './project-policy-config/index'; export * from "./config/index";
export * from './label/index'; export * from "./channel/index";
export * from './create-edit-label/index'; export * from "./project-policy-config/index";
export * from './gridview/index'; export * from "./label/index";
export * from './repository-gridview/index'; export * from "./create-edit-label/index";
export * from './operation/index'; export * from "./gridview/index";
export * from './_animations/index'; export * from "./repository-gridview/index";
export * from "./operation/index";
export * from "./_animations/index";

View File

@ -1,7 +1,7 @@
import {throwError as observableThrowError, Observable } from "rxjs"; import {throwError as observableThrowError, Observable } from "rxjs";
import { Injectable, Inject } from "@angular/core"; import { Injectable, Inject } from "@angular/core";
import { HttpClient } from "@angular/common/http"; import { HttpClient, HttpParams, HttpResponse } from "@angular/common/http";
import { map , catchError } from "rxjs/operators"; import { map , catchError } from "rxjs/operators";
import { SERVICE_CONFIG, IServiceConfig } from "../service.config"; import { SERVICE_CONFIG, IServiceConfig } from "../service.config";
@ -10,7 +10,7 @@ import { ProjectPolicy } from "../project-policy-config/project-policy-config.co
import { import {
HTTP_JSON_OPTIONS, HTTP_JSON_OPTIONS,
HTTP_GET_OPTIONS, HTTP_GET_OPTIONS,
buildHttpRequestOptions buildHttpRequestOptionsWithObserveResponse
} from "../utils"; } from "../utils";
import { RequestQueryParams } from "./RequestQueryParams"; import { RequestQueryParams } from "./RequestQueryParams";
@ -64,10 +64,15 @@ export abstract class ProjectService {
*/ */
abstract listProjects( abstract listProjects(
name: string, name: string,
isPublic: number, isPublic?: number,
page?: number, page?: number,
pageSize?: number pageSize?: number
): Observable<Project[]>; ): Observable<HttpResponse<Project[]>>;
abstract createProject(name: string, metadata: any): Observable<any>;
abstract toggleProjectPublic(projectId: number, isPublic: string): Observable<any>;
abstract deleteProject(projectId: number): Observable<any>;
abstract checkProjectExists(projectName: string): Observable<any>;
abstract checkProjectMember(projectId: number): Observable<any>;
} }
/** /**
@ -100,32 +105,6 @@ export class ProjectDefaultService extends ProjectService {
.pipe(catchError(error => observableThrowError(error))); .pipe(catchError(error => observableThrowError(error)));
} }
public listProjects(
name: string,
isPublic: number,
page?: number,
pageSize?: number
): Observable<Project[]> {
let baseUrl: string = this.config.projectBaseEndpoint
? this.config.projectBaseEndpoint
: "/api/projects";
let params = new RequestQueryParams();
if (page && pageSize) {
params = params.set("page", page + "").set("page_size", pageSize + "");
}
if (name && name.trim() !== "") {
params = params.set("name", name);
}
if (isPublic !== undefined) {
params = params.set("public", "" + isPublic);
}
// let options = new RequestOptions({ headers: this.getHeaders, search: params });
return this.http
.get<Project[]>(baseUrl, buildHttpRequestOptions(params))
.pipe(catchError(error => observableThrowError(error)));
}
public updateProjectPolicy( public updateProjectPolicy(
projectId: number | string, projectId: number | string,
projectPolicy: ProjectPolicy projectPolicy: ProjectPolicy
@ -149,4 +128,53 @@ export class ProjectDefaultService extends ProjectService {
) )
.pipe(catchError(error => observableThrowError(error))); .pipe(catchError(error => observableThrowError(error)));
} }
public listProjects(name: string, isPublic?: number, page?: number, pageSize?: number): Observable<HttpResponse<Project[]>> {
let params = new HttpParams();
if (page && pageSize) {
params = params.set('page', page + '').set('page_size', pageSize + '');
}
if (name && name.trim() !== "") {
params = params.set('name', name);
}
if (isPublic !== undefined) {
params = params.set('public', '' + isPublic);
}
return this.http
.get<HttpResponse<Project[]>>(`/api/projects`, buildHttpRequestOptionsWithObserveResponse(params)).pipe(
catchError(error => observableThrowError(error)), );
}
public createProject(name: string, metadata: any): Observable<any> {
return this.http
.post(`/api/projects`,
JSON.stringify({'project_name': name, 'metadata': {
public: metadata.public ? 'true' : 'false',
}})
, HTTP_JSON_OPTIONS).pipe(
catchError(error => observableThrowError(error)), );
}
public toggleProjectPublic(projectId: number, isPublic: string): Observable<any> {
return this.http
.put(`/api/projects/${projectId}`, { 'metadata': {'public': isPublic} }, HTTP_JSON_OPTIONS).pipe(
catchError(error => observableThrowError(error)), );
}
public deleteProject(projectId: number): Observable<any> {
return this.http
.delete(`/api/projects/${projectId}`)
.pipe(catchError(error => observableThrowError(error)));
}
public checkProjectExists(projectName: string): Observable<any> {
return this.http
.head(`/api/projects/?project_name=${projectName}`).pipe(
catchError(error => observableThrowError(error)), );
}
public checkProjectMember(projectId: number): Observable<any> {
return this.http
.get(`/api/projects/${projectId}/members`, HTTP_GET_OPTIONS).pipe(
catchError(error => observableThrowError(error)), );
}
} }

View File

@ -11,14 +11,7 @@
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and // See the License for the specific language governing permissions and
// limitations under the License. // limitations under the License.
export const supportedLangs = ['en-us', 'zh-cn', 'es-es', 'fr-fr'];
export const enLang = "en-us";
export const languageNames = {
"en-us": "English",
"zh-cn": "中文简体",
"es-es": "Español",
"fr-fr": "Français"
};
export const enum AlertType { export const enum AlertType {
DANGER, WARNING, INFO, SUCCESS DANGER, WARNING, INFO, SUCCESS
} }
@ -91,21 +84,3 @@ export const LabelColor = [
{ 'color': '#F52F52', 'textColor': 'black' }, { 'color': '#FF5501', 'textColor': 'black' }, { 'color': '#F52F52', 'textColor': 'black' }, { 'color': '#FF5501', 'textColor': 'black' },
{ 'color': '#F57600', 'textColor': 'black' }, { 'color': '#FFDC0B', 'textColor': 'black' }, { 'color': '#F57600', 'textColor': 'black' }, { 'color': '#FFDC0B', 'textColor': 'black' },
]; ];
export const RoleMapping = { 'projectAdmin': 'MEMBER.PROJECT_ADMIN', 'master': 'MEMBER.PROJECT_MASTER',
'developer': 'MEMBER.DEVELOPER', 'guest': 'MEMBER.GUEST' };
export enum Roles {
PROJECT_ADMIN = 1,
PROJECT_MASTER = 4,
DEVELOPER = 2,
GUEST = 3,
OTHER = 0,
}
export enum ResourceType {
REPOSITORY = 1,
CHART_VERSION = 2,
REPOSITORY_TAG = 3,
}

View File

@ -32,7 +32,7 @@ import { ChannelService } from "../channel/index";
import { import {
ConfirmationTargets, ConfirmationTargets,
ConfirmationState, ConfirmationState,
ConfirmationButtons, Roles ConfirmationButtons
} from "../shared/shared.const"; } from "../shared/shared.const";
import { ConfirmationDialogComponent } from "../confirmation-dialog/confirmation-dialog.component"; import { ConfirmationDialogComponent } from "../confirmation-dialog/confirmation-dialog.component";

View File

@ -185,8 +185,23 @@ export class CustomComparator<T> implements Comparator<T> {
compare(a: { [key: string]: any | any[] }, b: { [key: string]: any | any[] }) { compare(a: { [key: string]: any | any[] }, b: { [key: string]: any | any[] }) {
let comp = 0; let comp = 0;
if (a && b) { if (a && b) {
let fieldA = a[this.fieldName]; let fieldA, fieldB;
let fieldB = b[this.fieldName]; for (let key of Object.keys(a)) {
if (key === this.fieldName) {
fieldA = a[key];
fieldB = b[key];
break;
} else if (typeof a[key] === 'object') {
let insideObject = a[key];
for (let insideKey in insideObject) {
if (insideKey === this.fieldName) {
fieldA = insideObject[insideKey];
fieldB = b[key][insideKey];
break;
}
}
}
}
switch (this.type) { switch (this.type) {
case "number": case "number":
comp = fieldB - fieldA; comp = fieldB - fieldA;
@ -194,6 +209,9 @@ export class CustomComparator<T> implements Comparator<T> {
case "date": case "date":
comp = new Date(fieldB).getTime() - new Date(fieldA).getTime(); comp = new Date(fieldB).getTime() - new Date(fieldA).getTime();
break; break;
case "string":
comp = fieldB.localeCompare(fieldA);
break;
} }
} }
return comp; return comp;

View File

@ -22,8 +22,7 @@ import { SessionService } from "../../shared/session.service";
import { InlineAlertComponent } from "../../shared/inline-alert/inline-alert.component"; import { InlineAlertComponent } from "../../shared/inline-alert/inline-alert.component";
import { MessageHandlerService } from "../../shared/message-handler/message-handler.service"; import { MessageHandlerService } from "../../shared/message-handler/message-handler.service";
import { SearchTriggerService } from "../../base/global-search/search-trigger.service"; import { SearchTriggerService } from "../../base/global-search/search-trigger.service";
import { CommonRoutes } from "../../shared/shared.const"; import { CopyInputComponent, CommonRoutes } from "@harbor/ui";
import { CopyInputComponent } from "@harbor/ui";
import { AccountSettingsModalService } from './account-settings-modal-service.service'; import { AccountSettingsModalService } from './account-settings-modal-service.service';
import { ConfirmationDialogComponent } from "../../shared/confirmation-dialog/confirmation-dialog.component"; import { ConfirmationDialogComponent } from "../../shared/confirmation-dialog/confirmation-dialog.component";
import { import {

View File

@ -18,7 +18,7 @@ import { NgForm } from '@angular/forms';
import { PasswordSettingService } from '../password-setting.service'; import { PasswordSettingService } from '../password-setting.service';
import { InlineAlertComponent } from '../../../shared/inline-alert/inline-alert.component'; import { InlineAlertComponent } from '../../../shared/inline-alert/inline-alert.component';
import { MessageHandlerService } from '../../../shared/message-handler/message-handler.service'; import { MessageHandlerService } from '../../../shared/message-handler/message-handler.service';
import { CommonRoutes } from '../../../shared/shared.const'; import { CommonRoutes } from '@harbor/ui';
@Component({ @Component({
selector: 'reset-password', selector: 'reset-password',

View File

@ -26,7 +26,7 @@ import { SessionService } from '../../shared/session.service';
import { AboutDialogComponent } from '../../shared/about-dialog/about-dialog.component'; import { AboutDialogComponent } from '../../shared/about-dialog/about-dialog.component';
import { SearchTriggerService } from '../global-search/search-trigger.service'; import { SearchTriggerService } from '../global-search/search-trigger.service';
import { CommonRoutes } from '../../shared/shared.const'; import { CommonRoutes } from '@harbor/ui';
@Component({ @Component({
selector: 'harbor-shell', selector: 'harbor-shell',

View File

@ -22,7 +22,8 @@ import { modalEvents } from '../modal-events.const';
import { SessionService } from '../../shared/session.service'; import { SessionService } from '../../shared/session.service';
import { CookieService, CookieOptions } from 'ngx-cookie'; import { CookieService, CookieOptions } from 'ngx-cookie';
import { supportedLangs, enLang, languageNames, CommonRoutes } from '../../shared/shared.const'; import { supportedLangs, enLang, languageNames } from '../../shared/shared.const';
import { CommonRoutes } from '@harbor/ui';
import { AppConfigService } from '../../app-config.service'; import { AppConfigService } from '../../app-config.service';
import { SearchTriggerService } from '../global-search/search-trigger.service'; import { SearchTriggerService } from '../global-search/search-trigger.service';
import { MessageHandlerService } from '../../shared/message-handler/message-handler.service'; import { MessageHandlerService } from '../../shared/message-handler/message-handler.service';

View File

@ -15,8 +15,7 @@ import { Component, OnInit, OnDestroy, ViewChild } from '@angular/core';
import { Subscription } from "rxjs"; import { Subscription } from "rxjs";
import { import {
Configuration, StringValueItem, SystemSettingsComponent, Configuration, StringValueItem, SystemSettingsComponent,
isEmpty, clone, getChanges, GcRepoService } from '@harbor/ui'; isEmpty, clone } from '@harbor/ui';
import { ConfirmationTargets, ConfirmationState } from '../shared/shared.const'; import { ConfirmationTargets, ConfirmationState } from '../shared/shared.const';
import { SessionService } from '../shared/session.service'; import { SessionService } from '../shared/session.service';
import { ConfirmationDialogService } from '../shared/confirmation-dialog/confirmation-dialog.service'; import { ConfirmationDialogService } from '../shared/confirmation-dialog/confirmation-dialog.service';

View File

@ -16,9 +16,8 @@ import { HttpClient } from '@angular/common/http';
import { map, catchError } from "rxjs/operators"; import { map, catchError } from "rxjs/operators";
import { Observable, throwError as observableThrowError } from "rxjs"; import { Observable, throwError as observableThrowError } from "rxjs";
import { Configuration } from '@harbor/ui'; import { Configuration, HTTP_GET_OPTIONS, HTTP_JSON_OPTIONS } from '@harbor/ui';
import {HTTP_GET_OPTIONS, HTTP_JSON_OPTIONS} from "@harbor/ui";
const configEndpoint = "/api/configurations"; const configEndpoint = "/api/configurations";
const emailEndpoint = "/api/email/ping"; const emailEndpoint = "/api/email/ping";

View File

@ -19,7 +19,7 @@ import { TranslateService } from '@ngx-translate/core';
import { Message } from './message'; import { Message } from './message';
import { MessageService } from './message.service'; import { MessageService } from './message.service';
import { dismissInterval, httpStatusCode, CommonRoutes } from '../shared/shared.const'; import { dismissInterval, httpStatusCode, CommonRoutes } from '@harbor/ui';
@Component({ @Component({
selector: 'global-message', selector: 'global-message',

View File

@ -4,21 +4,21 @@ import { flatMap, catchError } from "rxjs/operators";
import { SessionService } from "./../shared/session.service"; import { SessionService } from "./../shared/session.service";
import { TranslateService } from "@ngx-translate/core"; import { TranslateService } from "@ngx-translate/core";
import { Component, OnInit, ViewChild, OnDestroy } from "@angular/core"; import { Component, OnInit, ViewChild, OnDestroy } from "@angular/core";
import { operateChanges, OperateInfo, OperationService, OperationState } from "@harbor/ui"; import { operateChanges, OperateInfo, OperationService, OperationState, errorHandler as errorHandFn } from "@harbor/ui";
import { import {
ConfirmationTargets, ConfirmationTargets,
ConfirmationState, ConfirmationState,
ConfirmationButtons ConfirmationButtons
} from "../shared/shared.const"; } from "../shared/shared.const";
import { ConfirmationMessage } from "../shared/confirmation-dialog/confirmation-message"; import { ConfirmationMessage } from "../shared/confirmation-dialog/confirmation-message";
import { ConfirmationDialogService } from "./../shared/confirmation-dialog/confirmation-dialog.service"; import { ConfirmationDialogService } from "./../shared/confirmation-dialog/confirmation-dialog.service";
import { AddGroupModalComponent } from "./add-group-modal/add-group-modal.component"; import { AddGroupModalComponent } from "./add-group-modal/add-group-modal.component";
import { UserGroup } from "./group"; import { UserGroup } from "./group";
import { GroupService } from "./group.service"; import { GroupService } from "./group.service";
import { MessageHandlerService } from "../shared/message-handler/message-handler.service"; import { MessageHandlerService } from "../shared/message-handler/message-handler.service";
import { errorHandler as errorHandFn } from "../shared/shared.utils"; import { throwError as observableThrowError } from "rxjs";
import { Observable, throwError as observableThrowError } from "rxjs";
@Component({ @Component({
selector: "app-group", selector: "app-group",
templateUrl: "./group.component.html", templateUrl: "./group.component.html",

View File

@ -2,8 +2,7 @@ import { Router, ActivatedRoute } from '@angular/router';
import { Component, OnInit } from '@angular/core'; import { Component, OnInit } from '@angular/core';
import { OidcOnboardService } from './oidc-onboard.service'; import { OidcOnboardService } from './oidc-onboard.service';
import { FormControl } from '@angular/forms'; import { FormControl } from '@angular/forms';
import { errorHandler } from "../shared/shared.utils"; import { errorHandler, CommonRoutes } from "@harbor/ui";
import { CommonRoutes } from '../shared/shared.const';
@Component({ @Component({
selector: 'app-oidc-onboard', selector: 'app-oidc-onboard',

View File

@ -30,7 +30,7 @@ import { MessageHandlerService } from "../../shared/message-handler/message-hand
import { InlineAlertComponent } from "../../shared/inline-alert/inline-alert.component"; import { InlineAlertComponent } from "../../shared/inline-alert/inline-alert.component";
import { Project } from "../project"; import { Project } from "../project";
import { ProjectService } from "../project.service"; import { ProjectService } from "@harbor/ui";
import { errorHandler } from '@angular/platform-browser/src/browser'; import { errorHandler } from '@angular/platform-browser/src/browser';

View File

@ -25,7 +25,8 @@ import { State,
operateChanges, operateChanges,
OperationService, OperationService,
UserPermissionService, UserPermissionService,
USERSTATICPERMISSION } from "@harbor/ui"; USERSTATICPERMISSION,
errorHandler as errorHandFn } from "@harbor/ui";
import { HelmChartVersion, HelmChartMaintainer } from "../../helm-chart.interface.service"; import { HelmChartVersion, HelmChartMaintainer } from "../../helm-chart.interface.service";
import { HelmChartService } from "../../helm-chart.service"; import { HelmChartService } from "../../helm-chart.service";
@ -39,9 +40,7 @@ import {
ConfirmationState, ConfirmationState,
DefaultHelmIcon, DefaultHelmIcon,
ResourceType, ResourceType,
Roles
} from "../../../../shared/shared.const"; } from "../../../../shared/shared.const";
import { errorHandler as errorHandFn } from "../../../../shared/shared.utils";
@Component({ @Component({
selector: "hbr-helm-chart-version", selector: "hbr-helm-chart-version",

View File

@ -10,10 +10,9 @@ import {
} from "@angular/core"; } from "@angular/core";
import { NgForm } from '@angular/forms'; import { NgForm } from '@angular/forms';
import { TranslateService } from "@ngx-translate/core"; import { TranslateService } from "@ngx-translate/core";
import { import { State, ErrorHandler, SystemInfo, SystemInfoService, DEFAULT_PAGE_SIZE, downloadFile
State, ErrorHandler, SystemInfo, SystemInfoService, DEFAULT_PAGE_SIZE, downloadFile
, OperationService, UserPermissionService, USERSTATICPERMISSION, OperateInfo, OperationState, operateChanges , OperationService, UserPermissionService, USERSTATICPERMISSION, OperateInfo, OperationState, operateChanges
} from "@harbor/ui"; , errorHandler as errorHandFn } from "@harbor/ui";
import { forkJoin, throwError as observableThrowError, Observable } from "rxjs"; import { forkJoin, throwError as observableThrowError, Observable } from "rxjs";
import { finalize, map, catchError } from "rxjs/operators"; import { finalize, map, catchError } from "rxjs/operators";
import { HelmChartItem } from "../helm-chart.interface.service"; import { HelmChartItem } from "../helm-chart.interface.service";
@ -28,7 +27,6 @@ import {
ConfirmationTargets, ConfirmationTargets,
ConfirmationState, ConfirmationState,
} from "../../../shared/shared.const"; } from "../../../shared/shared.const";
import { errorHandler as errorHandFn } from "../../../shared/shared.utils";
@Component({ @Component({
selector: "hbr-helm-chart", selector: "hbr-helm-chart",

View File

@ -24,9 +24,10 @@ import { Router } from "@angular/router";
import { Comparator, State } from "../../../../lib/src/service/interface"; import { Comparator, State } from "../../../../lib/src/service/interface";
import {TranslateService} from "@ngx-translate/core"; import {TranslateService} from "@ngx-translate/core";
import { RoleInfo, ConfirmationTargets, ConfirmationState, ConfirmationButtons } from "../../shared/shared.const"; import { RoleInfo, ConfirmationTargets, ConfirmationState, ConfirmationButtons } from "../../shared/shared.const";
import { CustomComparator, doFiltering, doSorting, calculatePage } from "../../shared/shared.utils";
import { errorHandler as errorHandFn, calculatePage , operateChanges, OperateInfo, OperationService
, OperationState, CustomComparator, doFiltering, doSorting, ProjectService } from "@harbor/ui";
import { SessionService } from "../../shared/session.service"; import { SessionService } from "../../shared/session.service";
import { StatisticHandler } from "../../shared/statictics/statistic-handler.service"; import { StatisticHandler } from "../../shared/statictics/statistic-handler.service";
@ -34,14 +35,11 @@ import { ConfirmationDialogService } from "../../shared/confirmation-dialog/conf
import { MessageHandlerService } from "../../shared/message-handler/message-handler.service"; import { MessageHandlerService } from "../../shared/message-handler/message-handler.service";
import { ConfirmationMessage } from "../../shared/confirmation-dialog/confirmation-message"; import { ConfirmationMessage } from "../../shared/confirmation-dialog/confirmation-message";
import { SearchTriggerService } from "../../base/global-search/search-trigger.service"; import { SearchTriggerService } from "../../base/global-search/search-trigger.service";
import {AppConfigService} from "../../app-config.service"; import { AppConfigService } from "../../app-config.service";
import {operateChanges, OperateInfo, OperationService, OperationState} from "@harbor/ui";
import { Project } from "../project"; import { Project } from "../project";
import { ProjectService } from "../project.service";
import { map, catchError } from "rxjs/operators"; import { map, catchError } from "rxjs/operators";
import { throwError as observableThrowError } from "rxjs"; import { throwError as observableThrowError } from "rxjs";
import { errorHandler as errorHandFn } from "../../shared/shared.utils";
@Component({ @Component({
selector: "list-project", selector: "list-project",

View File

@ -7,7 +7,7 @@ import { Component, OnInit, Input, Output, EventEmitter } from "@angular/core";
import { NgForm } from '@angular/forms'; import { NgForm } from '@angular/forms';
import { TranslateService } from '@ngx-translate/core'; import { TranslateService } from '@ngx-translate/core';
import {operateChanges, OperateInfo, OperationService, OperationState} from "@harbor/ui"; import { operateChanges, OperateInfo, OperationService, OperationState, errorHandler as errorHandFn } from "@harbor/ui";
import { UserGroup } from "./../../../group/group"; import { UserGroup } from "./../../../group/group";
import { MemberService } from "./../member.service"; import { MemberService } from "./../member.service";
@ -16,7 +16,6 @@ import { ProjectRoles } from "../../../shared/shared.const";
import { MessageHandlerService } from '../../../shared/message-handler/message-handler.service'; import { MessageHandlerService } from '../../../shared/message-handler/message-handler.service';
import { Member } from "../member"; import { Member } from "../member";
import { throwError as observableThrowError } from "rxjs"; import { throwError as observableThrowError } from "rxjs";
import { errorHandler as errorHandFn } from "../../../shared/shared.utils";
@Component({ @Component({
selector: "add-group", selector: "add-group",
templateUrl: "./add-group.component.html", templateUrl: "./add-group.component.html",

View File

@ -39,7 +39,7 @@ import {User} from "../../../user/user";
import {Project} from "../../project"; import {Project} from "../../project";
import { Member } from '../member'; import { Member } from '../member';
import { errorHandler as errorHandFn } from "../../../shared/shared.utils"; import { errorHandler as errorHandFn } from "@harbor/ui";
import { MemberService } from '../member.service'; import { MemberService } from '../member.service';
import { HttpResponseBase } from '@angular/common/http'; import { HttpResponseBase } from '@angular/common/http';

View File

@ -17,7 +17,8 @@ import { Component, OnInit, ViewChild, OnDestroy, ChangeDetectionStrategy, Chang
import { ActivatedRoute, Router } from "@angular/router"; import { ActivatedRoute, Router } from "@angular/router";
import { Subscription, forkJoin, Observable } from "rxjs"; import { Subscription, forkJoin, Observable } from "rxjs";
import { TranslateService } from "@ngx-translate/core"; import { TranslateService } from "@ngx-translate/core";
import { operateChanges, OperateInfo, OperationService, OperationState } from "@harbor/ui"; import { operateChanges, OperateInfo, OperationService, OperationState, UserPermissionService, USERSTATICPERMISSION, ErrorHandler
, errorHandler as errorHandFn } from "@harbor/ui";
import { MessageHandlerService } from "../../shared/message-handler/message-handler.service"; import { MessageHandlerService } from "../../shared/message-handler/message-handler.service";
import { ConfirmationTargets, ConfirmationState, ConfirmationButtons } from "../../shared/shared.const"; import { ConfirmationTargets, ConfirmationState, ConfirmationButtons } from "../../shared/shared.const";
@ -32,9 +33,7 @@ import { AddGroupComponent } from './add-group/add-group.component';
import { MemberService } from "./member.service"; import { MemberService } from "./member.service";
import { AddMemberComponent } from "./add-member/add-member.component"; import { AddMemberComponent } from "./add-member/add-member.component";
import { AppConfigService } from "../../app-config.service"; import { AppConfigService } from "../../app-config.service";
import { UserPermissionService, USERSTATICPERMISSION, ErrorHandler } from "@harbor/ui";
import { map, catchError } from "rxjs/operators"; import { map, catchError } from "rxjs/operators";
import { errorHandler as errorHandFn } from "../../shared/shared.utils";
import { throwError as observableThrowError } from "rxjs"; import { throwError as observableThrowError } from "rxjs";
@Component({ @Component({
templateUrl: "member.component.html", templateUrl: "member.component.html",

View File

@ -17,10 +17,9 @@ import { ActivatedRoute, Router } from '@angular/router';
import { Project } from '../project'; import { Project } from '../project';
import { SessionService } from '../../shared/session.service'; import { SessionService } from '../../shared/session.service';
import { ProjectService } from '../../project/project.service';
import { AppConfigService } from "../../app-config.service"; import { AppConfigService } from "../../app-config.service";
import { UserPermissionService, USERSTATICPERMISSION, ErrorHandler } from "@harbor/ui"; import { UserPermissionService, USERSTATICPERMISSION, ErrorHandler, ProjectService } from "@harbor/ui";
import { forkJoin } from "rxjs"; import { forkJoin } from "rxjs";
@Component({ @Component({
selector: 'project-detail', selector: 'project-detail',

View File

@ -16,7 +16,7 @@ import { Injectable } from '@angular/core';
import { Router, Resolve, RouterStateSnapshot, ActivatedRouteSnapshot } from '@angular/router'; import { Router, Resolve, RouterStateSnapshot, ActivatedRouteSnapshot } from '@angular/router';
import { Project } from './project'; import { Project } from './project';
import { ProjectService } from './project.service'; import { ProjectService } from '@harbor/ui';
import { SessionService } from '../shared/session.service'; import { SessionService } from '../shared/session.service';
import { Observable } from 'rxjs'; import { Observable } from 'rxjs';
import { map, catchError } from "rxjs/operators"; import { map, catchError } from "rxjs/operators";

View File

@ -28,7 +28,7 @@ import { MemberComponent } from './member/member.component';
import { AddMemberComponent } from './member/add-member/add-member.component'; import { AddMemberComponent } from './member/add-member/add-member.component';
import { AddGroupComponent } from './member/add-group/add-group.component'; import { AddGroupComponent } from './member/add-group/add-group.component';
import { ProjectService } from './project.service'; // import { ProjectService } from '@harbor/ui';
import { MemberService } from './member/member.service'; import { MemberService } from './member/member.service';
import { RobotService } from './robot-account/robot-account.service'; import { RobotService } from './robot-account/robot-account.service';
import { ProjectRoutingResolver } from './project-routing-resolver.service'; import { ProjectRoutingResolver } from './project-routing-resolver.service';
@ -62,7 +62,7 @@ import { AddRobotComponent } from './robot-account/add-robot/add-robot.component
AddRobotComponent AddRobotComponent
], ],
exports: [ProjectComponent, ListProjectComponent], exports: [ProjectComponent, ListProjectComponent],
providers: [ProjectRoutingResolver, ProjectService, MemberService, RobotService] providers: [ProjectRoutingResolver, MemberService, RobotService]
}) })
export class ProjectModule { export class ProjectModule {

View File

@ -1,87 +0,0 @@
import {throwError as observableThrowError, Observable } from "rxjs";
import {catchError, map} from 'rxjs/operators';
// Copyright (c) 2017 VMware, Inc. 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.
import { Injectable } from '@angular/core';
import { HttpClient, HttpParams, HttpResponse } from '@angular/common/http';
import {HTTP_JSON_OPTIONS, buildHttpRequestOptions, HTTP_GET_OPTIONS, buildHttpRequestOptionsWithObserveResponse} from "@harbor/ui";
import { Project } from "./project";
@Injectable()
export class ProjectService {
constructor(private http: HttpClient) {}
getProject(projectId: number): Observable<any> {
return this.http
.get(`/api/projects/${projectId}`, HTTP_GET_OPTIONS).pipe(
catchError(error => observableThrowError(error)), );
}
listProjects(name: string, isPublic?: number, page?: number, pageSize?: number): Observable<HttpResponse<Project[]>> {
let params = new HttpParams();
if (page && pageSize) {
params = params.set('page', page + '').set('page_size', pageSize + '');
}
if (name && name.trim() !== "") {
params = params.set('name', name);
}
if (isPublic !== undefined) {
params = params.set('public', '' + isPublic);
}
return this.http
.get<HttpResponse<Project[]>>(`/api/projects`, buildHttpRequestOptionsWithObserveResponse(params)).pipe(
catchError(error => observableThrowError(error)), );
}
createProject(name: string, metadata: any): Observable<any> {
return this.http
.post(`/api/projects`,
JSON.stringify({'project_name': name, 'metadata': {
public: metadata.public ? 'true' : 'false',
}})
, HTTP_JSON_OPTIONS).pipe(
catchError(error => observableThrowError(error)), );
}
toggleProjectPublic(projectId: number, isPublic: string): Observable<any> {
return this.http
.put(`/api/projects/${projectId}`, { 'metadata': {'public': isPublic} }, HTTP_JSON_OPTIONS).pipe(
catchError(error => observableThrowError(error)), );
}
deleteProject(projectId: number): Observable<any> {
return this.http
.delete(`/api/projects/${projectId}`)
.pipe(catchError(error => observableThrowError(error)));
}
checkProjectExists(projectName: string): Observable<any> {
return this.http
.head(`/api/projects/?project_name=${projectName}`).pipe(
catchError(error => observableThrowError(error)), );
}
checkProjectMember(projectId: number): Observable<any> {
return this.http
.get(`/api/projects/${projectId}/members`, HTTP_GET_OPTIONS).pipe(
catchError(error => observableThrowError(error)), );
}
}

View File

@ -15,12 +15,12 @@ import { Subscription, forkJoin, Observable, throwError as observableThrowError
import { MessageHandlerService } from "../../shared/message-handler/message-handler.service"; import { MessageHandlerService } from "../../shared/message-handler/message-handler.service";
import { RobotService } from "./robot-account.service"; import { RobotService } from "./robot-account.service";
import { ConfirmationMessage } from "../../shared/confirmation-dialog/confirmation-message"; import { ConfirmationMessage } from "../../shared/confirmation-dialog/confirmation-message";
import { ConfirmationDialogService } from "../../shared/confirmation-dialog/confirmation-dialog.service";
import { import {
ConfirmationTargets, ConfirmationTargets,
ConfirmationState, ConfirmationState,
ConfirmationButtons ConfirmationButtons
} from "../../shared/shared.const"; } from "../../shared/shared.const";
import { ConfirmationDialogService } from "../../shared/confirmation-dialog/confirmation-dialog.service";
import { import {
operateChanges, operateChanges,
OperateInfo, OperateInfo,
@ -28,9 +28,9 @@ import {
OperationState, OperationState,
UserPermissionService, UserPermissionService,
USERSTATICPERMISSION, USERSTATICPERMISSION,
ErrorHandler ErrorHandler,
errorHandler as errorHandFn
} from "@harbor/ui"; } from "@harbor/ui";
import { errorHandler as errorHandFn } from "../../shared/shared.utils";
@Component({ @Component({
selector: "app-robot-account", selector: "app-robot-account",
templateUrl: "./robot-account.component.html", templateUrl: "./robot-account.component.html",

View File

@ -16,8 +16,7 @@ import { ActivatedRoute, Router } from '@angular/router';
import { SessionService } from "../shared/session.service"; import { SessionService } from "../shared/session.service";
import { Project } from "../project/project"; import { Project } from "../project/project";
import { ProjectService } from "../project/project.service"; import { ReplicationComponent, UserPermissionService, USERSTATICPERMISSION, ErrorHandler, ProjectService } from "@harbor/ui";
import { ReplicationComponent, UserPermissionService, USERSTATICPERMISSION, ErrorHandler } from "@harbor/ui";
import { forkJoin } from 'rxjs'; import { forkJoin } from 'rxjs';
@Component({ @Component({

View File

@ -12,9 +12,8 @@
// See the License for the specific language governing permissions and // See the License for the specific language governing permissions and
// limitations under the License. // limitations under the License.
import { Component, OnInit } from '@angular/core'; import { Component, OnInit } from '@angular/core';
import { Repository } from '@harbor/ui'; import { Repository, ListMode } from '@harbor/ui';
import { ListMode } from '../../shared/shared.const';
import { MessageHandlerService } from '../../shared/message-handler/message-handler.service'; import { MessageHandlerService } from '../../shared/message-handler/message-handler.service';
import { TopRepoService } from './top-repository.service'; import { TopRepoService } from './top-repository.service';

View File

@ -15,9 +15,8 @@ import { Injectable } from '@angular/core';
import { HttpClient } from '@angular/common/http'; import { HttpClient } from '@angular/common/http';
import { map, catchError } from "rxjs/operators"; import { map, catchError } from "rxjs/operators";
import { Observable, throwError as observableThrowError } from "rxjs"; import { Observable, throwError as observableThrowError } from "rxjs";
import { Repository } from '@harbor/ui'; import { Repository, HTTP_GET_OPTIONS } from '@harbor/ui';
import {HTTP_GET_OPTIONS} from "@harbor/ui";
export const topRepoEndpoint = "/api/repositories/top"; export const topRepoEndpoint = "/api/repositories/top";
/** /**

View File

@ -11,7 +11,7 @@
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and // See the License for the specific language governing permissions and
// limitations under the License. // limitations under the License.
import { ConfirmationTargets, ConfirmationButtons } from '../../shared/shared.const'; import { ConfirmationTargets, ConfirmationButtons } from '../shared.const';
export class ConfirmationMessage { export class ConfirmationMessage {
public constructor(title: string, public constructor(title: string,

View File

@ -14,7 +14,7 @@
import { Component, Output, EventEmitter } from '@angular/core'; import { Component, Output, EventEmitter } from '@angular/core';
import { TranslateService } from '@ngx-translate/core'; import { TranslateService } from '@ngx-translate/core';
import { errorHandler } from '../shared.utils'; import { errorHandler } from '@harbor/ui';
import { Subscription } from "rxjs"; import { Subscription } from "rxjs";
@Component({ @Component({

View File

@ -4,7 +4,7 @@ import { Component, OnInit, Input } from '@angular/core';
import { HelmChartSearchResultItem, HelmChartVersion, HelmChartMaintainer } from '../../project/helm-chart/helm-chart.interface.service'; import { HelmChartSearchResultItem, HelmChartVersion, HelmChartMaintainer } from '../../project/helm-chart/helm-chart.interface.service';
import { SearchTriggerService } from '../../base/global-search/search-trigger.service'; import { SearchTriggerService } from '../../base/global-search/search-trigger.service';
import { ProjectService } from '../../project/project.service'; import { ProjectService } from '@harbor/ui';
@Component({ @Component({
selector: 'list-chart-version-ro', selector: 'list-chart-version-ro',

View File

@ -13,11 +13,10 @@
// limitations under the License. // limitations under the License.
import { Injectable } from '@angular/core'; import { Injectable } from '@angular/core';
import { TranslateService } from '@ngx-translate/core'; import { TranslateService } from '@ngx-translate/core';
import { ErrorHandler, UserPermissionService } from '@harbor/ui'; import { ErrorHandler, UserPermissionService, httpStatusCode, errorHandler } from '@harbor/ui';
import { AlertType } from '../../shared/shared.const';
import { MessageService } from '../../global-message/message.service'; import { MessageService } from '../../global-message/message.service';
import { AlertType, httpStatusCode } from '../../shared/shared.const';
import { errorHandler } from '../../shared/shared.utils';
import { SessionService } from '../../shared/session.service'; import { SessionService } from '../../shared/session.service';

View File

@ -20,7 +20,8 @@ import {
NavigationExtras NavigationExtras
} from '@angular/router'; } from '@angular/router';
import { SessionService } from '../../shared/session.service'; import { SessionService } from '../../shared/session.service';
import { CommonRoutes, AdmiralQueryParamKey } from '../../shared/shared.const'; import { AdmiralQueryParamKey } from '../../shared/shared.const';
import { CommonRoutes } from '@harbor/ui';
import { AppConfigService } from '../../app-config.service'; import { AppConfigService } from '../../app-config.service';
import { maintainUrlQueryParmas } from '../../shared/shared.utils'; import { maintainUrlQueryParmas } from '../../shared/shared.utils';
import { MessageHandlerService } from '../message-handler/message-handler.service'; import { MessageHandlerService } from '../message-handler/message-handler.service';

View File

@ -19,8 +19,8 @@ import {
CanActivateChild CanActivateChild
} from '@angular/router'; } from '@angular/router';
import { SessionService } from '../../shared/session.service'; import { SessionService } from '../../shared/session.service';
import { ProjectService } from '../../project/project.service'; import { ProjectService } from '@harbor/ui';
import { CommonRoutes } from '../../shared/shared.const'; import { CommonRoutes } from '@harbor/ui';
import { Observable } from 'rxjs'; import { Observable } from 'rxjs';
@Injectable() @Injectable()

View File

@ -18,7 +18,7 @@ import {
RouterStateSnapshot, RouterStateSnapshot,
CanActivateChild CanActivateChild
} from '@angular/router'; } from '@angular/router';
import { CommonRoutes } from '../../shared/shared.const'; import { CommonRoutes } from '@harbor/ui';
import { AppConfigService } from '../../app-config.service'; import { AppConfigService } from '../../app-config.service';
import { Observable } from 'rxjs'; import { Observable } from 'rxjs';

View File

@ -20,9 +20,8 @@ import {
CanActivateChild CanActivateChild
} from '@angular/router'; } from '@angular/router';
import { AppConfigService } from '../../app-config.service'; import { AppConfigService } from '../../app-config.service';
import { UserPermissionService } from "@harbor/ui"; import { UserPermissionService, CommonRoutes } from "@harbor/ui";
import { Observable, of } from 'rxjs'; import { Observable } from 'rxjs';
import { CommonRoutes } from '../../shared/shared.const';
@Injectable() @Injectable()
export class OidcGuard implements CanActivate, CanActivateChild { export class OidcGuard implements CanActivate, CanActivateChild {

View File

@ -19,8 +19,7 @@ import {
CanActivateChild CanActivateChild
} from '@angular/router'; } from '@angular/router';
import { SessionService } from '../../shared/session.service'; import { SessionService } from '../../shared/session.service';
import { CommonRoutes } from '../../shared/shared.const'; import { CommonRoutes, UserPermissionService } from '@harbor/ui';
import { UserPermissionService } from "@harbor/ui";
import { Observable } from 'rxjs'; import { Observable } from 'rxjs';
@Injectable() @Injectable()

View File

@ -20,7 +20,7 @@ import {
NavigationExtras NavigationExtras
} from '@angular/router'; } from '@angular/router';
import { SessionService } from '../../shared/session.service'; import { SessionService } from '../../shared/session.service';
import { CommonRoutes } from '../../shared/shared.const'; import { CommonRoutes } from '@harbor/ui';
import { AppConfigService } from '../../app-config.service'; import { AppConfigService } from '../../app-config.service';
import { Observable } from 'rxjs'; import { Observable } from 'rxjs';

View File

@ -24,13 +24,6 @@ export const enum AlertType {
DANGER, WARNING, INFO, SUCCESS DANGER, WARNING, INFO, SUCCESS
} }
export const dismissInterval = 10 * 1000;
export const httpStatusCode = {
"Unauthorized": 401,
"Forbidden": 403
};
export const enum ConfirmationTargets { export const enum ConfirmationTargets {
EMPTY, EMPTY,
PROJECT, PROJECT,
@ -53,25 +46,9 @@ export const enum ActionType {
ADD_NEW, EDIT ADD_NEW, EDIT
} }
export const ListMode = {
READONLY: "readonly",
FULL: "full"
};
export const CommonRoutes = {
SIGN_IN: "/sign-in",
EMBEDDED_SIGN_IN: "/harbor/sign-in",
SIGN_UP: "/sign-in?sign_up=true",
EMBEDDED_SIGN_UP: "/harbor/sign-in?sign_up=true",
HARBOR_ROOT: "/harbor",
HARBOR_DEFAULT: "/harbor/projects"
};
export const AdmiralQueryParamKey = "admiral_redirect_url"; export const AdmiralQueryParamKey = "admiral_redirect_url";
export const HarborQueryParamKey = "harbor_redirect_url"; export const HarborQueryParamKey = "harbor_redirect_url";
export const CookieKeyOfAdmiral = "admiral.endpoint.latest"; export const CookieKeyOfAdmiral = "admiral.endpoint.latest";
export const enum ConfirmationState { export const enum ConfirmationState {
NA, CONFIRMED, CANCEL NA, CONFIRMED, CANCEL
} }

View File

@ -12,55 +12,10 @@
// See the License for the specific language governing permissions and // See the License for the specific language governing permissions and
// limitations under the License. // limitations under the License.
import { NgForm } from '@angular/forms'; import { NgForm } from '@angular/forms';
import { Comparator, State } from '../../../lib/src/service/interface';
import { RequestQueryParams } from "@harbor/ui";
import { MessageService } from '../global-message/message.service'; import { MessageService } from '../global-message/message.service';
import { httpStatusCode, AlertType } from './shared.const'; import { httpStatusCode } from '@harbor/ui';
import { AlertType } from '../shared/shared.const';
/**
* To handle the error message body
*
**
* returns {string}
*/
export const errorHandler = function (error: any): string {
if (!error) {
return "UNKNOWN_ERROR";
}
try {
return JSON.parse(error.error).message;
} catch (err) { }
if (typeof error.error === "string") {
return error.error;
}
if (error.error && error.error.message) {
return error.error.message;
}
if (!(error.statusCode || error.status)) {
// treat as string message
return '' + error;
} else {
switch (error.statusCode || error.status) {
case 400:
return "BAD_REQUEST_ERROR";
case 401:
return "UNAUTHORIZED_ERROR";
case 403:
return "FORBIDDEN_ERROR";
case 404:
return "NOT_FOUND_ERROR";
case 412:
return "PRECONDITION_FAILED";
case 409:
return "CONFLICT_ERROR";
case 500:
return "SERVER_ERROR";
default:
return "UNKNOWN_ERROR";
}
}
};
/** /**
* To check if form is empty * To check if form is empty
@ -121,148 +76,3 @@ export const maintainUrlQueryParmas = function (uri: string, key: string, value:
} }
}; };
// Copy from ui library utils.ts
/**
* Calculate page number by state
*/
export function calculatePage(state: State): number {
if (!state || !state.page) {
return 1;
}
return Math.ceil((state.page.to + 1) / state.page.size);
}
/**
* Comparator for fields with specific type.
*
*/
export class CustomComparator<T> implements Comparator<T> {
fieldName: string;
type: string;
constructor(fieldName: string, type: string) {
this.fieldName = fieldName;
this.type = type;
}
compare(a: { [key: string]: any | any[] }, b: { [key: string]: any | any[] }) {
let comp = 0;
if (a && b) {
let fieldA, fieldB;
for (let key of Object.keys(a)) {
if (key === this.fieldName) {
fieldA = a[key];
fieldB = b[key];
break;
} else if (typeof a[key] === 'object') {
let insideObject = a[key];
for (let insideKey in insideObject) {
if (insideKey === this.fieldName) {
fieldA = insideObject[insideKey];
fieldB = b[key][insideKey];
break;
}
}
}
}
switch (this.type) {
case "number":
comp = fieldB - fieldA;
break;
case "date":
comp = new Date(fieldB).getTime() - new Date(fieldA).getTime();
break;
case "string":
comp = fieldB.localeCompare(fieldA);
break;
}
}
return comp;
}
}
/**
* Filter columns via RegExp
*
**
* ** deprecated param {State} state
* returns {void}
*/
export function doFiltering<T extends { [key: string]: any | any[] }>(items: T[], state: State): T[] {
if (!items || items.length === 0) {
return items;
}
if (!state || !state.filters || state.filters.length === 0) {
return items;
}
state.filters.forEach((filter: {
property: string;
value: string;
}) => {
items = items.filter(item => regexpFilter(filter["value"], item[filter["property"]]));
});
return items;
}
/**
* Match items via RegExp
*
**
* ** deprecated param {string} terms
* ** deprecated param {*} testedValue
* returns {boolean}
*/
export function regexpFilter(terms: string, testedValue: any): boolean {
let reg = new RegExp('.*' + terms + '.*', 'i');
return reg.test(testedValue);
}
/**
* Sorting the data by column
*
**
* template T
* ** deprecated param {T[]} items
* ** deprecated param {State} state
* returns {T[]}
*/
export function doSorting<T extends { [key: string]: any | any[] }>(items: T[], state: State): T[] {
if (!items || items.length === 0) {
return items;
}
if (!state || !state.sort) {
return items;
}
return items.sort((a: T, b: T) => {
let comp: number = 0;
if (typeof state.sort.by !== "string") {
comp = state.sort.by.compare(a, b);
} else {
let propA = a[state.sort.by.toString()], propB = b[state.sort.by.toString()];
if (typeof propA === "string") {
comp = propA.localeCompare(propB);
} else {
if (propA > propB) {
comp = 1;
} else if (propA < propB) {
comp = -1;
}
}
}
if (state.sort.reverse) {
comp = -comp;
}
return comp;
});
}

View File

@ -14,7 +14,7 @@
import { Directive, OnChanges, Input, SimpleChanges } from '@angular/core'; import { Directive, OnChanges, Input, SimpleChanges } from '@angular/core';
import { NG_ASYNC_VALIDATORS, Validator, Validators, ValidatorFn, AbstractControl } from '@angular/forms'; import { NG_ASYNC_VALIDATORS, Validator, Validators, ValidatorFn, AbstractControl } from '@angular/forms';
import { ProjectService } from '../project/project.service'; import { ProjectService, ProjectDefaultService } from '@harbor/ui';
import { MemberService } from '../project/member/member.service'; import { MemberService } from '../project/member/member.service';
import { Member } from '../project/member/member'; import { Member } from '../project/member/member';
@ -23,7 +23,8 @@ import { Observable } from 'rxjs';
@Directive({ @Directive({
selector: '[targetExists]', selector: '[targetExists]',
providers: [ providers: [
ProjectService, MemberService, MemberService,
{ provide: ProjectService, useClass: ProjectDefaultService },
{ provide: NG_ASYNC_VALIDATORS, useExisting: TargetExistsValidatorDirective, multi: true }, { provide: NG_ASYNC_VALIDATORS, useExisting: TargetExistsValidatorDirective, multi: true },
] ]
}) })

View File

@ -20,7 +20,7 @@ import { SessionService } from '../shared/session.service';
import { SignInCredential } from '../shared/sign-in-credential'; import { SignInCredential } from '../shared/sign-in-credential';
import { SignUpComponent } from '../account/sign-up/sign-up.component'; import { SignUpComponent } from '../account/sign-up/sign-up.component';
import { CommonRoutes } from '../shared/shared.const'; import { CommonRoutes } from '@harbor/ui';
import { ForgotPasswordComponent } from '../account/password-setting/forgot-password/forgot-password.component'; import { ForgotPasswordComponent } from '../account/password-setting/forgot-password/forgot-password.component';
import { AppConfigService } from '../app-config.service'; import { AppConfigService } from '../app-config.service';

View File

@ -16,8 +16,8 @@ import { Component, OnInit, ViewChild, OnDestroy, ChangeDetectionStrategy, Chang
import { Subscription, Observable, forkJoin } from "rxjs"; import { Subscription, Observable, forkJoin } from "rxjs";
import { TranslateService } from '@ngx-translate/core'; import { TranslateService } from '@ngx-translate/core';
import { ConfirmationState, ConfirmationTargets, ConfirmationButtons } from '../shared/shared.const'; import { ConfirmationState, ConfirmationTargets, ConfirmationButtons } from '../shared/shared.const';
import { operateChanges, OperateInfo, OperationService, OperationState, errorHandler as errorHandFn } from '@harbor/ui';
import { ConfirmationDialogService } from '../shared/confirmation-dialog/confirmation-dialog.service'; import { ConfirmationDialogService } from '../shared/confirmation-dialog/confirmation-dialog.service';
import { ConfirmationMessage } from '../shared/confirmation-dialog/confirmation-message'; import { ConfirmationMessage } from '../shared/confirmation-dialog/confirmation-message';
import { MessageHandlerService } from '../shared/message-handler/message-handler.service'; import { MessageHandlerService } from '../shared/message-handler/message-handler.service';
@ -27,10 +27,8 @@ import { NewUserModalComponent } from './new-user-modal.component';
import { UserService } from './user.service'; import { UserService } from './user.service';
import { User } from './user'; import { User } from './user';
import { ChangePasswordComponent } from "./change-password/change-password.component"; import { ChangePasswordComponent } from "./change-password/change-password.component";
import { operateChanges, OperateInfo, OperationService, OperationState } from "@harbor/ui";
import { map, catchError } from 'rxjs/operators'; import { map, catchError } from 'rxjs/operators';
import { throwError as observableThrowError } from "rxjs"; import { throwError as observableThrowError } from "rxjs";
import { errorHandler as errorHandFn } from "../shared/shared.utils";
/** /**
* NOTES: * NOTES: