mirror of
https://github.com/goharbor/harbor.git
synced 2024-12-25 18:18:04 +01:00
Merge pull request #11007 from jwangyangls/artifact-filter-changes
[OCI] Artifact filter params changes in ui
This commit is contained in:
commit
580b74035d
@ -31,7 +31,7 @@
|
|||||||
<div>
|
<div>
|
||||||
<div class="row flex-items-xs-right rightPos">
|
<div class="row flex-items-xs-right rightPos">
|
||||||
<div id="filterArea" *ngIf="!depth">
|
<div id="filterArea" *ngIf="!depth">
|
||||||
<div class='filterLabelPiece' *ngIf="(openLabelFilterPiece &&filterByType ==='label.id')"
|
<div class='filterLabelPiece' *ngIf="(openLabelFilterPiece &&filterByType ==='labels')"
|
||||||
[style.left.px]='96'>
|
[style.left.px]='96'>
|
||||||
<hbr-label-piece *ngIf="showlabel" [hidden]='!filterOneLabel' [label]="filterOneLabel"
|
<hbr-label-piece *ngIf="showlabel" [hidden]='!filterOneLabel' [label]="filterOneLabel"
|
||||||
[labelWidth]="130"></hbr-label-piece>
|
[labelWidth]="130"></hbr-label-piece>
|
||||||
@ -59,7 +59,7 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
<div class="label-filter-panel" *ngIf="!withAdmiral" [hidden]="!(openLabelFilterPanel&&filterByType==='label.id')">
|
<div class="label-filter-panel" *ngIf="!withAdmiral" [hidden]="!(openLabelFilterPanel&&filterByType==='labels')">
|
||||||
<a class="filterClose" (click)="closeFilter()">×</a>
|
<a class="filterClose" (click)="closeFilter()">×</a>
|
||||||
<label
|
<label
|
||||||
class="filterLabelHeader filter-dark">{{'REPOSITORY.FILTER_ARTIFACT_BY_LABEL' | translate}}</label>
|
class="filterLabelHeader filter-dark">{{'REPOSITORY.FILTER_ARTIFACT_BY_LABEL' | translate}}</label>
|
||||||
@ -146,7 +146,7 @@
|
|||||||
|
|
||||||
</clr-dg-action-bar>
|
</clr-dg-action-bar>
|
||||||
|
|
||||||
<clr-dg-column class="flex-max-width" [clrDgField]="'q'">{{'REPOSITORY.ARTIFACTS_COUNT' | translate}}
|
<clr-dg-column class="flex-max-width">{{'REPOSITORY.ARTIFACTS_COUNT' | translate}}
|
||||||
</clr-dg-column>
|
</clr-dg-column>
|
||||||
<clr-dg-column *ngIf="depth">{{'REPOSITORY.PLATFORM' | translate}}</clr-dg-column>
|
<clr-dg-column *ngIf="depth">{{'REPOSITORY.PLATFORM' | translate}}</clr-dg-column>
|
||||||
<clr-dg-column class="w-rem-4">{{'REPOSITORY.TAGS_COUNT' | translate}}</clr-dg-column>
|
<clr-dg-column class="w-rem-4">{{'REPOSITORY.TAGS_COUNT' | translate}}</clr-dg-column>
|
||||||
|
@ -366,7 +366,7 @@ describe("ArtifactListTabComponent (inline template)", () => {
|
|||||||
fixture.detectChanges();
|
fixture.detectChanges();
|
||||||
await fixture.whenStable();
|
await fixture.whenStable();
|
||||||
filtereName = 'sha256:3e33e3e3';
|
filtereName = 'sha256:3e33e3e3';
|
||||||
comp.doSearchArtifactNames('sha256:3e33e3e3');
|
comp.doSearchArtifactByFilter('sha256:3e33e3e3');
|
||||||
fixture.detectChanges();
|
fixture.detectChanges();
|
||||||
await fixture.whenStable();
|
await fixture.whenStable();
|
||||||
fixture.detectChanges();
|
fixture.detectChanges();
|
||||||
|
@ -144,7 +144,7 @@ export class ArtifactListTabComponent implements OnInit, OnDestroy {
|
|||||||
pageSize: number = DEFAULT_PAGE_SIZE;
|
pageSize: number = DEFAULT_PAGE_SIZE;
|
||||||
currentPage = 1;
|
currentPage = 1;
|
||||||
totalCount = 0;
|
totalCount = 0;
|
||||||
currentState: State;
|
currentState: ClrDatagridStateInterface;
|
||||||
|
|
||||||
hasAddLabelImagePermission: boolean;
|
hasAddLabelImagePermission: boolean;
|
||||||
hasRetagImagePermission: boolean;
|
hasRetagImagePermission: boolean;
|
||||||
@ -163,7 +163,8 @@ export class ArtifactListTabComponent implements OnInit, OnDestroy {
|
|||||||
mutipleFilter = clone(mutipleFilter);
|
mutipleFilter = clone(mutipleFilter);
|
||||||
filterByType: string = this.mutipleFilter[0].filterBy;
|
filterByType: string = this.mutipleFilter[0].filterBy;
|
||||||
openSelectFilterPiece = false;
|
openSelectFilterPiece = false;
|
||||||
|
// could Pagination filter
|
||||||
|
filters: string[];
|
||||||
constructor(
|
constructor(
|
||||||
private errorHandlerService: ErrorHandler,
|
private errorHandlerService: ErrorHandler,
|
||||||
private userPermissionService: UserPermissionService,
|
private userPermissionService: UserPermissionService,
|
||||||
@ -282,32 +283,16 @@ export class ArtifactListTabComponent implements OnInit, OnDestroy {
|
|||||||
this.lastFilteredTagName = filterWords;
|
this.lastFilteredTagName = filterWords;
|
||||||
this.currentPage = 1;
|
this.currentPage = 1;
|
||||||
|
|
||||||
let st: State = this.currentState;
|
let st: ClrDatagridStateInterface = this.currentState;
|
||||||
if (!st) {
|
if (!st) {
|
||||||
st = { page: {} };
|
st = { page: {} };
|
||||||
}
|
}
|
||||||
st.page.size = this.pageSize;
|
st.page.size = this.pageSize;
|
||||||
st.page.from = 0;
|
st.page.from = 0;
|
||||||
st.page.to = this.pageSize - 1;
|
st.page.to = this.pageSize - 1;
|
||||||
|
this.filters = [];
|
||||||
st.filters = [{ property: this.filterByType, value: this.lastFilteredTagName }];
|
if (this.lastFilteredTagName) {
|
||||||
this.clrLoad(st);
|
this.filters.push(`${this.filterByType}=~${this.lastFilteredTagName}`);
|
||||||
}
|
|
||||||
doSearchArtifactNames(artifactName: string) {
|
|
||||||
this.lastFilteredTagName = artifactName;
|
|
||||||
this.currentPage = 1;
|
|
||||||
|
|
||||||
let st: State = this.currentState;
|
|
||||||
if (!st) {
|
|
||||||
st = { page: {} };
|
|
||||||
}
|
|
||||||
st.page.size = this.pageSize;
|
|
||||||
st.page.from = 0;
|
|
||||||
st.page.to = this.pageSize - 1;
|
|
||||||
st.filters = [{ property: this.filterByType, value: this.lastFilteredTagName }];
|
|
||||||
let selectedLab = this.imageFilterLabels.find(label => label.iconsShow === true);
|
|
||||||
if (selectedLab) {
|
|
||||||
st.filters.push({ property: this.filterByType, value: selectedLab.label.id });
|
|
||||||
}
|
}
|
||||||
this.clrLoad(st);
|
this.clrLoad(st);
|
||||||
}
|
}
|
||||||
@ -345,10 +330,12 @@ export class ArtifactListTabComponent implements OnInit, OnDestroy {
|
|||||||
if (sortBy) {
|
if (sortBy) {
|
||||||
params.sort = sortBy;
|
params.sort = sortBy;
|
||||||
}
|
}
|
||||||
if (state.filters && state.filters.length) {
|
if (this.filters && this.filters.length) {
|
||||||
state.filters.forEach(item => {
|
let q = "";
|
||||||
params[item.property] = item.value;
|
this.filters.forEach(item => {
|
||||||
|
q += item;
|
||||||
});
|
});
|
||||||
|
params.q = encodeURIComponent(q);
|
||||||
}
|
}
|
||||||
if (this.artifactDigest) {
|
if (this.artifactDigest) {
|
||||||
const artifactParam: NewArtifactService.GetArtifactParams = {
|
const artifactParam: NewArtifactService.GetArtifactParams = {
|
||||||
@ -424,7 +411,15 @@ export class ArtifactListTabComponent implements OnInit, OnDestroy {
|
|||||||
}
|
}
|
||||||
|
|
||||||
refresh() {
|
refresh() {
|
||||||
this.doSearchArtifactNames(this.lastFilteredTagName);
|
this.currentPage = 1;
|
||||||
|
let st: ClrDatagridStateInterface = this.currentState;
|
||||||
|
if (!st) {
|
||||||
|
st = { page: {} };
|
||||||
|
st.page.size = this.pageSize;
|
||||||
|
st.page.from = 0;
|
||||||
|
st.page.to = this.pageSize - 1;
|
||||||
|
}
|
||||||
|
this.clrLoad(st);
|
||||||
}
|
}
|
||||||
getArtifactAnnotationsArray(artifactList: Artifact[]) {
|
getArtifactAnnotationsArray(artifactList: Artifact[]) {
|
||||||
artifactList.forEach(artifact => {
|
artifactList.forEach(artifact => {
|
||||||
@ -581,18 +576,15 @@ export class ArtifactListTabComponent implements OnInit, OnDestroy {
|
|||||||
|
|
||||||
// reload data
|
// reload data
|
||||||
this.currentPage = 1;
|
this.currentPage = 1;
|
||||||
let st: State = this.currentState;
|
let st: ClrDatagridStateInterface = this.currentState;
|
||||||
if (!st) {
|
if (!st) {
|
||||||
st = { page: {} };
|
st = { page: {} };
|
||||||
}
|
}
|
||||||
st.page.size = this.pageSize;
|
st.page.size = this.pageSize;
|
||||||
st.page.from = 0;
|
st.page.from = 0;
|
||||||
st.page.to = this.pageSize - 1;
|
st.page.to = this.pageSize - 1;
|
||||||
if (this.lastFilteredTagName) {
|
|
||||||
st.filters = [{ property: 'name', value: this.lastFilteredTagName }, { property: 'labels.id', value: labelId }];
|
this.filters = [`${this.filterByType}=(${labelId})`];
|
||||||
} else {
|
|
||||||
st.filters = [{ property: 'labels.id', value: labelId }];
|
|
||||||
}
|
|
||||||
|
|
||||||
this.clrLoad(st);
|
this.clrLoad(st);
|
||||||
}
|
}
|
||||||
@ -606,18 +598,15 @@ export class ArtifactListTabComponent implements OnInit, OnDestroy {
|
|||||||
|
|
||||||
// reload data
|
// reload data
|
||||||
this.currentPage = 1;
|
this.currentPage = 1;
|
||||||
let st: State = this.currentState;
|
let st: ClrDatagridStateInterface = this.currentState;
|
||||||
if (!st) {
|
if (!st) {
|
||||||
st = { page: {} };
|
st = { page: {} };
|
||||||
}
|
}
|
||||||
st.page.size = this.pageSize;
|
st.page.size = this.pageSize;
|
||||||
st.page.from = 0;
|
st.page.from = 0;
|
||||||
st.page.to = this.pageSize - 1;
|
st.page.to = this.pageSize - 1;
|
||||||
if (this.lastFilteredTagName) {
|
|
||||||
st.filters = [{ property: 'name', value: this.lastFilteredTagName }];
|
this.filters = [];
|
||||||
} else {
|
|
||||||
st.filters = [];
|
|
||||||
}
|
|
||||||
this.clrLoad(st);
|
this.clrLoad(st);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -922,7 +911,7 @@ export class ArtifactListTabComponent implements OnInit, OnDestroy {
|
|||||||
}
|
}
|
||||||
selectFilterType() {
|
selectFilterType() {
|
||||||
this.lastFilteredTagName = '';
|
this.lastFilteredTagName = '';
|
||||||
if (this.filterByType === 'label.id') {
|
if (this.filterByType === 'labels') {
|
||||||
this.openLabelFilterPanel = true;
|
this.openLabelFilterPanel = true;
|
||||||
this.openLabelFilterPiece = true;
|
this.openLabelFilterPiece = true;
|
||||||
} else {
|
} else {
|
||||||
@ -933,26 +922,38 @@ export class ArtifactListTabComponent implements OnInit, OnDestroy {
|
|||||||
data.iconsShow = false;
|
data.iconsShow = false;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
this.doSearchArtifactNames("");
|
|
||||||
}
|
|
||||||
|
|
||||||
selectFilter(showItem: string, filterItem: string) {
|
|
||||||
this.lastFilteredTagName = filterItem;
|
|
||||||
this.currentPage = 1;
|
this.currentPage = 1;
|
||||||
|
let st: ClrDatagridStateInterface = this.currentState;
|
||||||
let st: State = this.currentState;
|
|
||||||
if (!st) {
|
if (!st) {
|
||||||
st = { page: {} };
|
st = { page: {} };
|
||||||
}
|
}
|
||||||
st.page.size = this.pageSize;
|
st.page.size = this.pageSize;
|
||||||
st.page.from = 0;
|
st.page.from = 0;
|
||||||
st.page.to = this.pageSize - 1;
|
st.page.to = this.pageSize - 1;
|
||||||
st.filters = [{ property: this.filterByType, value: filterItem }];
|
this.filters = [];
|
||||||
|
this.clrLoad(st);
|
||||||
|
}
|
||||||
|
|
||||||
|
selectFilter(showItem: string, filterItem: string) {
|
||||||
|
this.lastFilteredTagName = filterItem;
|
||||||
|
this.currentPage = 1;
|
||||||
|
|
||||||
|
let st: ClrDatagridStateInterface = this.currentState;
|
||||||
|
if (!st) {
|
||||||
|
st = { page: {} };
|
||||||
|
}
|
||||||
|
st.page.size = this.pageSize;
|
||||||
|
st.page.from = 0;
|
||||||
|
st.page.to = this.pageSize - 1;
|
||||||
|
this.filters = [];
|
||||||
|
if (filterItem) {
|
||||||
|
this.filters.push(`${this.filterByType}=${filterItem}`);
|
||||||
|
}
|
||||||
|
|
||||||
this.clrLoad(st);
|
this.clrLoad(st);
|
||||||
}
|
}
|
||||||
get isFilterReadonly() {
|
get isFilterReadonly() {
|
||||||
return this.filterByType === 'label.id' ? 'readonly' : null;
|
return this.filterByType === 'labels' ? 'readonly' : null;
|
||||||
}
|
}
|
||||||
getArtifactIcon(artifacts: ArtifactFront[]) {
|
getArtifactIcon(artifacts: ArtifactFront[]) {
|
||||||
for (const artifact of artifacts) {
|
for (const artifact of artifacts) {
|
||||||
|
@ -43,7 +43,7 @@ export const mutipleFilter = [
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
filterBy: 'label.id',
|
filterBy: 'labels',
|
||||||
filterByShowText: 'Label',
|
filterByShowText: 'Label',
|
||||||
listItem: []
|
listItem: []
|
||||||
},
|
},
|
||||||
|
@ -156,8 +156,10 @@ export class RepositoryGridviewComponent implements OnChanges, OnInit, OnDestroy
|
|||||||
projectName: this.projectName,
|
projectName: this.projectName,
|
||||||
page: this.currentPage,
|
page: this.currentPage,
|
||||||
pageSize: this.pageSize,
|
pageSize: this.pageSize,
|
||||||
name: this.lastFilteredRepoName
|
|
||||||
};
|
};
|
||||||
|
if (this.lastFilteredRepoName) {
|
||||||
|
params.q = encodeURIComponent(`name=~${this.lastFilteredRepoName}`);
|
||||||
|
}
|
||||||
this.loading = true;
|
this.loading = true;
|
||||||
return this.newRepoService.listRepositoriesResponse(params);
|
return this.newRepoService.listRepositoriesResponse(params);
|
||||||
})
|
})
|
||||||
|
Loading…
Reference in New Issue
Block a user