mirror of
https://github.com/goharbor/harbor.git
synced 2025-01-04 15:08:21 +01:00
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:
parent
fbec3ee76f
commit
c52cb4fc9a
@ -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";
|
||||||
|
|
||||||
|
@ -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)), );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -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,
|
|
||||||
}
|
|
||||||
|
@ -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";
|
||||||
|
@ -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;
|
||||||
|
@ -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 {
|
||||||
|
@ -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',
|
||||||
|
@ -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',
|
||||||
|
@ -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';
|
||||||
|
@ -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';
|
||||||
|
@ -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";
|
||||||
|
@ -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',
|
||||||
|
@ -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",
|
||||||
|
@ -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',
|
||||||
|
@ -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';
|
||||||
|
|
||||||
|
|
||||||
|
@ -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",
|
||||||
|
@ -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",
|
||||||
|
@ -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",
|
||||||
|
@ -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",
|
||||||
|
@ -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';
|
||||||
|
@ -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",
|
||||||
|
@ -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',
|
||||||
|
@ -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";
|
||||||
|
@ -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 {
|
||||||
|
|
||||||
|
@ -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)), );
|
|
||||||
}
|
|
||||||
}
|
|
@ -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",
|
||||||
|
@ -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({
|
||||||
|
@ -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';
|
||||||
|
|
||||||
|
@ -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";
|
||||||
/**
|
/**
|
||||||
|
@ -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,
|
||||||
|
@ -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({
|
||||||
|
@ -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',
|
||||||
|
@ -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';
|
||||||
|
|
||||||
|
|
||||||
|
@ -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';
|
||||||
|
@ -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()
|
||||||
|
@ -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';
|
||||||
|
|
||||||
|
@ -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 {
|
||||||
|
@ -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()
|
||||||
|
@ -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';
|
||||||
|
|
||||||
|
@ -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
|
||||||
}
|
}
|
||||||
|
@ -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;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
@ -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 },
|
||||||
]
|
]
|
||||||
})
|
})
|
||||||
|
@ -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';
|
||||||
|
@ -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:
|
||||||
|
Loading…
Reference in New Issue
Block a user