@dignite-ng/expand.cms 0.0.24 → 0.0.26
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/config/cms-config.module.mjs +7 -6
- package/esm2022/config/dignite-ng-expand.cms-config.mjs +1 -1
- package/esm2022/config/enums/index.mjs +1 -1
- package/esm2022/config/enums/route-names.mjs +1 -1
- package/esm2022/config/providers/index.mjs +1 -1
- package/esm2022/config/providers/route.provider.mjs +1 -1
- package/esm2022/config/public-api.mjs +1 -1
- package/esm2022/dignite-ng-expand.cms.mjs +1 -1
- package/esm2022/lib/cms-routing.module.mjs +7 -6
- package/esm2022/lib/cms.module.mjs +12 -10
- package/esm2022/lib/components/admin/entries/create-or-edit-entries.component.mjs +46 -39
- package/esm2022/lib/components/admin/entries/create-or-update-entry-input-base.mjs +20 -20
- package/esm2022/lib/components/admin/entries/create.component.mjs +27 -21
- package/esm2022/lib/components/admin/entries/edit.component.mjs +29 -24
- package/esm2022/lib/components/admin/entries/entries.component.mjs +46 -42
- package/esm2022/lib/components/admin/entries/index.mjs +1 -1
- package/esm2022/lib/components/admin/fields/create-field.component.mjs +21 -16
- package/esm2022/lib/components/admin/fields/create-or-edit-field.component.mjs +19 -11
- package/esm2022/lib/components/admin/fields/create-or-update-field-input-base.mjs +13 -13
- package/esm2022/lib/components/admin/fields/edit-field.component.mjs +27 -19
- package/esm2022/lib/components/admin/fields/field-group.component.mjs +30 -23
- package/esm2022/lib/components/admin/fields/fields.component.mjs +26 -22
- package/esm2022/lib/components/admin/fields/index.mjs +1 -1
- package/esm2022/lib/components/admin/index.mjs +1 -1
- package/esm2022/lib/components/admin/sections/create-or-update-sections-input-base.mjs +15 -15
- package/esm2022/lib/components/admin/sections/entry-types/create-or-edit.-entry-type-input-base.mjs +26 -26
- package/esm2022/lib/components/admin/sections/entry-types/create-or-edit.component.mjs +71 -42
- package/esm2022/lib/components/admin/sections/entry-types/index.mjs +1 -1
- package/esm2022/lib/components/admin/sections/index.mjs +1 -1
- package/esm2022/lib/components/admin/sections/sections.component.mjs +92 -55
- package/esm2022/lib/components/admin/sites/create-or-update-sites-input-base.mjs +6 -6
- package/esm2022/lib/components/admin/sites/index.mjs +1 -1
- package/esm2022/lib/components/admin/sites/sites.component.mjs +37 -23
- package/esm2022/lib/components/dynamic-form/entry/entry-config.component.mjs +28 -17
- package/esm2022/lib/components/dynamic-form/entry/entry-config.mjs +7 -7
- package/esm2022/lib/components/dynamic-form/entry/entry-control.component.mjs +24 -13
- package/esm2022/lib/components/dynamic-form/entry/index.mjs +1 -1
- package/esm2022/lib/components/dynamic-form/form-control-group.mjs +1 -1
- package/esm2022/lib/components/dynamic-form/index.mjs +1 -1
- package/esm2022/lib/components/dynamic-form/matrix/index.mjs +1 -1
- package/esm2022/lib/components/dynamic-form/matrix/matrix-config.component.mjs +35 -19
- package/esm2022/lib/components/dynamic-form/matrix/matrix-config.mjs +16 -16
- package/esm2022/lib/components/dynamic-form/matrix/matrix-control.component.mjs +28 -12
- package/esm2022/lib/components/dynamic-form/table/index.mjs +1 -1
- package/esm2022/lib/components/dynamic-form/table/table-config.component.mjs +34 -13
- package/esm2022/lib/components/dynamic-form/table/table-config.mjs +15 -15
- package/esm2022/lib/components/dynamic-form/table/table-control.component.mjs +23 -10
- package/esm2022/lib/components/index.mjs +1 -1
- package/esm2022/lib/constants/styles.mjs +1 -1
- package/esm2022/lib/enums/ecms-component.mjs +1 -1
- package/esm2022/lib/enums/index.mjs +1 -1
- package/esm2022/lib/proxy/admin/dynamic-forms/form-admin.service.mjs +13 -12
- package/esm2022/lib/proxy/admin/dynamic-forms/index.mjs +1 -1
- package/esm2022/lib/proxy/admin/dynamic-forms/models.mjs +1 -1
- package/esm2022/lib/proxy/admin/entries/entry-admin.service.mjs +56 -55
- package/esm2022/lib/proxy/admin/entries/index.mjs +1 -1
- package/esm2022/lib/proxy/admin/entries/models.mjs +1 -1
- package/esm2022/lib/proxy/admin/fields/field-admin.service.mjs +36 -35
- package/esm2022/lib/proxy/admin/fields/field-group-admin.service.mjs +32 -31
- package/esm2022/lib/proxy/admin/fields/index.mjs +1 -1
- package/esm2022/lib/proxy/admin/fields/models.mjs +1 -1
- package/esm2022/lib/proxy/admin/sections/entry-type-admin.service.mjs +32 -31
- package/esm2022/lib/proxy/admin/sections/index.mjs +1 -1
- package/esm2022/lib/proxy/admin/sections/models.mjs +1 -1
- package/esm2022/lib/proxy/admin/sections/section-admin.service.mjs +42 -41
- package/esm2022/lib/proxy/admin/sites/index.mjs +1 -1
- package/esm2022/lib/proxy/admin/sites/models.mjs +1 -1
- package/esm2022/lib/proxy/admin/sites/site-admin.service.mjs +40 -39
- package/esm2022/lib/proxy/dignite/abp/data/index.mjs +1 -1
- package/esm2022/lib/proxy/dignite/abp/data/models.mjs +1 -1
- package/esm2022/lib/proxy/entries/entry-status.enum.mjs +1 -1
- package/esm2022/lib/proxy/entries/index.mjs +1 -1
- package/esm2022/lib/proxy/fields/models.mjs +1 -1
- package/esm2022/lib/proxy/sections/index.mjs +1 -1
- package/esm2022/lib/proxy/sections/models.mjs +1 -1
- package/esm2022/lib/proxy/sections/section-type.enum.mjs +1 -1
- package/esm2022/lib/proxy/sites/models.mjs +1 -1
- package/esm2022/lib/proxy/volo/cms-kit/users/models.mjs +1 -1
- package/esm2022/lib/services/appent-content.mjs +1 -1
- package/esm2022/lib/services/cms-api.service.mjs +8 -7
- package/esm2022/lib/services/cms.service.mjs +9 -8
- package/esm2022/lib/services/field-abstracts.service.mjs +13 -12
- package/esm2022/lib/services/index.mjs +1 -1
- package/esm2022/lib/services/simple-reuse-strategy.mjs +2 -4
- package/esm2022/lib/services/update-list.service.mjs +9 -9
- package/esm2022/lib/toolbar/index.mjs +1 -1
- package/esm2022/lib/toolbar/toolbar-btn-default-action.mjs +1 -1
- package/esm2022/lib/toolbar/toolbar-config.mjs +1 -1
- package/esm2022/public-api.mjs +1 -1
- package/fesm2022/dignite-ng-expand.cms-config.mjs +4 -4
- package/fesm2022/dignite-ng-expand.cms-config.mjs.map +1 -1
- package/fesm2022/dignite-ng-expand.cms.mjs +983 -701
- package/fesm2022/dignite-ng-expand.cms.mjs.map +1 -1
- package/lib/components/admin/sections/sections.component.d.ts +3 -4
- package/package.json +1 -1
|
@@ -1,12 +1,6 @@
|
|
|
1
|
-
|
|
2
|
-
import { ToasterService } from '@abp/ng.theme.shared';
|
|
3
|
-
import { Component, ElementRef, ViewChild, inject } from '@angular/core';
|
|
1
|
+
import { Component, ViewChild, inject } from '@angular/core';
|
|
4
2
|
import { FormBuilder } from '@angular/forms';
|
|
5
|
-
import { ActivatedRoute, Router } from '@angular/router';
|
|
6
|
-
import { Location } from '@angular/common';
|
|
7
3
|
import { CreateOrUpdateEntryInputBase } from './create-or-update-entry-input-base';
|
|
8
|
-
import { LocalizationService } from '@abp/ng.core';
|
|
9
|
-
import { EntryAdminService } from '../../../proxy/admin/entries';
|
|
10
4
|
import { EXTENSIONS_IDENTIFIER } from '@abp/ng.theme.shared/extensions';
|
|
11
5
|
import { ECmsComponent } from '../../../enums/ecms-component';
|
|
12
6
|
import { UpdateListService } from '../../../services/update-list.service';
|
|
@@ -20,7 +14,13 @@ import * as i6 from "@angular/forms";
|
|
|
20
14
|
import * as i7 from "@ngx-validate/core";
|
|
21
15
|
import * as i8 from "@abp/ng.components/page";
|
|
22
16
|
import * as i9 from "./create-or-edit-entries.component";
|
|
23
|
-
|
|
17
|
+
class EditComponent {
|
|
18
|
+
toaster;
|
|
19
|
+
_location;
|
|
20
|
+
route;
|
|
21
|
+
_EntryAdminService;
|
|
22
|
+
router;
|
|
23
|
+
_LocalizationService;
|
|
24
24
|
constructor(toaster, _location, route, _EntryAdminService, router, _LocalizationService) {
|
|
25
25
|
this.toaster = toaster;
|
|
26
26
|
this._location = _location;
|
|
@@ -28,15 +28,19 @@ export class EditComponent {
|
|
|
28
28
|
this._EntryAdminService = _EntryAdminService;
|
|
29
29
|
this.router = router;
|
|
30
30
|
this._LocalizationService = _LocalizationService;
|
|
31
|
-
this.fb = inject(FormBuilder);
|
|
32
|
-
this._updateListService = inject(UpdateListService);
|
|
33
|
-
/**是否是草稿 */
|
|
34
|
-
this.draftType = false;
|
|
35
|
-
/**页面传值用于传递到子组件 */
|
|
36
|
-
this.queryParams = '' || {};
|
|
37
|
-
/**指定id的条目信息 */
|
|
38
|
-
this.entrySelect = '';
|
|
39
31
|
}
|
|
32
|
+
fb = inject(FormBuilder);
|
|
33
|
+
_updateListService = inject(UpdateListService);
|
|
34
|
+
/**表单实体 */
|
|
35
|
+
newEntity;
|
|
36
|
+
/**是否是草稿 */
|
|
37
|
+
draftType = false;
|
|
38
|
+
/**页面传值用于传递到子组件 */
|
|
39
|
+
queryParams = '' || {};
|
|
40
|
+
/**指定id的条目信息 */
|
|
41
|
+
entrySelect = '';
|
|
42
|
+
/**获取提交按钮替身,用于真实触发表单提交 */
|
|
43
|
+
submitclick;
|
|
40
44
|
async ngOnInit() {
|
|
41
45
|
this.queryParams.RevisionEntryId = this.route.snapshot.params.entrieId;
|
|
42
46
|
this.newEntity = this.fb.group(new CreateOrUpdateEntryInputBase());
|
|
@@ -54,10 +58,10 @@ export class EditComponent {
|
|
|
54
58
|
/**保存 */
|
|
55
59
|
save(draft) {
|
|
56
60
|
this.newEntity.patchValue({
|
|
57
|
-
draft: draft
|
|
61
|
+
draft: draft,
|
|
58
62
|
});
|
|
59
63
|
let input = this.newEntity.value;
|
|
60
|
-
input.publishTime = new Date(new Date(input.publishTime).getTime() +
|
|
64
|
+
input.publishTime = new Date(new Date(input.publishTime).getTime() + 8 * 60 * 60 * 1000).toISOString();
|
|
61
65
|
input.culture = this.newEntity.get('culture').value;
|
|
62
66
|
input.concurrencyStamp = this.entrySelect.concurrencyStamp;
|
|
63
67
|
if (!this.newEntity.valid)
|
|
@@ -79,15 +83,16 @@ export class EditComponent {
|
|
|
79
83
|
backTo() {
|
|
80
84
|
this._location.back();
|
|
81
85
|
}
|
|
82
|
-
static
|
|
83
|
-
static
|
|
86
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EditComponent, deps: [{ token: i1.ToasterService }, { token: i2.Location }, { token: i3.ActivatedRoute }, { token: i4.EntryAdminService }, { token: i3.Router }, { token: i5.LocalizationService }], target: i0.ɵɵFactoryTarget.Component });
|
|
87
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EditComponent, selector: "cms-edit", providers: [
|
|
84
88
|
{
|
|
85
89
|
provide: EXTENSIONS_IDENTIFIER,
|
|
86
90
|
useValue: ECmsComponent.Entries_Edit,
|
|
87
91
|
},
|
|
88
|
-
], viewQueries: [{ propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }], ngImport: i0, template: "<form class=\"row g-3 needs-validation\" [formGroup]=\"newEntity\" (ngSubmit)=\"save(draftType)\">\n <abp-page [title]=\"'AbpUi::Edit' | abpLocalization\" [toolbar]=\"true\">\n <button type=\"submit\" style=\"display: none\" #submitclick></button>\n <ng-container *ngIf=\"entrySelect\">\n <cms-create-or-edit-entries [entity]=\"newEntity\" [ParentQueryParams]=\"queryParams\"\n [parentEntrySelect]=\"entrySelect\" [isEdit]=\"true\"></cms-create-or-edit-entries>\n </ng-container>\n </abp-page>\n</form>", styles: ["::ng-deep .edit-entry-page .dignite_page{height:calc(100vh - 125px);overflow:auto;background:transparent}::ng-deep .edit-entry-page .form-control,::ng-deep .edit-entry-page .form-select{padding:.475rem 1.25rem}::ng-deep .edit-entry-page .cursor-move{cursor:move}::ng-deep .edit-entry-page .bordernNavs{border:var(--bs-border-width) solid var(--lpx-border-color);padding-left:inherit;padding-right:inherit}::ng-deep .edit-entry-page .flex-between{display:flex;align-items:center;justify-content:space-between}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i6.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i6.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i5.FormSubmitDirective, selector: "form[ngSubmit][formGroup]", inputs: ["debounce", "notValidateOnSubmit", "markAsDirtyWhenSubmit"], outputs: ["ngSubmit"] }, { kind: "directive", type: i7.ValidationGroupDirective, selector: "[formGroup],[formGroupName]", exportAs: ["validationGroup"] }, { kind: "component", type: i8.PageComponent, selector: "abp-page", inputs: ["title", "toolbar", "breadcrumb"] }, { kind: "component", type: i9.CreateOrEditEntriesComponent, selector: "cms-create-or-edit-entries", inputs: ["isEdit", "ParentQueryParams", "entity", "parentEntrySelect"] }, { kind: "pipe", type: i5.LocalizationPipe, name: "abpLocalization" }] });
|
|
92
|
+
], viewQueries: [{ propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }], ngImport: i0, template: "<form class=\"row g-3 needs-validation\" [formGroup]=\"newEntity\" (ngSubmit)=\"save(draftType)\">\n <abp-page [title]=\"'AbpUi::Edit' | abpLocalization\" [toolbar]=\"true\">\n <button type=\"submit\" style=\"display: none\" #submitclick></button>\n <ng-container *ngIf=\"entrySelect\">\n <cms-create-or-edit-entries [entity]=\"newEntity\" [ParentQueryParams]=\"queryParams\"\n [parentEntrySelect]=\"entrySelect\" [isEdit]=\"true\"></cms-create-or-edit-entries>\n </ng-container>\n </abp-page>\n</form>", styles: ["::ng-deep .edit-entry-page .dignite_page{height:calc(100vh - 125px);overflow:auto;background:transparent}::ng-deep .edit-entry-page .form-control,::ng-deep .edit-entry-page .form-select{padding:.475rem 1.25rem}::ng-deep .edit-entry-page .cursor-move{cursor:move}::ng-deep .edit-entry-page .bordernNavs{border:var(--bs-border-width) solid var(--lpx-border-color);padding-left:inherit;padding-right:inherit}::ng-deep .edit-entry-page .flex-between{display:flex;align-items:center;justify-content:space-between}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i6.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i6.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i5.FormSubmitDirective, selector: "form[ngSubmit][formGroup]", inputs: ["debounce", "notValidateOnSubmit", "markAsDirtyWhenSubmit"], outputs: ["ngSubmit"] }, { kind: "directive", type: i7.ValidationGroupDirective, selector: "[formGroup],[formGroupName]", exportAs: ["validationGroup"] }, { kind: "component", type: i8.PageComponent, selector: "abp-page", inputs: ["title", "toolbar", "breadcrumb"] }, { kind: "component", type: i9.CreateOrEditEntriesComponent, selector: "cms-create-or-edit-entries", inputs: ["isEdit", "ParentQueryParams", "entity", "parentEntrySelect"] }, { kind: "pipe", type: i5.LocalizationPipe, name: "abpLocalization" }] });
|
|
89
93
|
}
|
|
90
|
-
|
|
94
|
+
export { EditComponent };
|
|
95
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EditComponent, decorators: [{
|
|
91
96
|
type: Component,
|
|
92
97
|
args: [{ selector: 'cms-edit', providers: [
|
|
93
98
|
{
|
|
@@ -95,8 +100,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.9", ngImpor
|
|
|
95
100
|
useValue: ECmsComponent.Entries_Edit,
|
|
96
101
|
},
|
|
97
102
|
], template: "<form class=\"row g-3 needs-validation\" [formGroup]=\"newEntity\" (ngSubmit)=\"save(draftType)\">\n <abp-page [title]=\"'AbpUi::Edit' | abpLocalization\" [toolbar]=\"true\">\n <button type=\"submit\" style=\"display: none\" #submitclick></button>\n <ng-container *ngIf=\"entrySelect\">\n <cms-create-or-edit-entries [entity]=\"newEntity\" [ParentQueryParams]=\"queryParams\"\n [parentEntrySelect]=\"entrySelect\" [isEdit]=\"true\"></cms-create-or-edit-entries>\n </ng-container>\n </abp-page>\n</form>", styles: ["::ng-deep .edit-entry-page .dignite_page{height:calc(100vh - 125px);overflow:auto;background:transparent}::ng-deep .edit-entry-page .form-control,::ng-deep .edit-entry-page .form-select{padding:.475rem 1.25rem}::ng-deep .edit-entry-page .cursor-move{cursor:move}::ng-deep .edit-entry-page .bordernNavs{border:var(--bs-border-width) solid var(--lpx-border-color);padding-left:inherit;padding-right:inherit}::ng-deep .edit-entry-page .flex-between{display:flex;align-items:center;justify-content:space-between}\n"] }]
|
|
98
|
-
}], ctorParameters: ()
|
|
103
|
+
}], ctorParameters: function () { return [{ type: i1.ToasterService }, { type: i2.Location }, { type: i3.ActivatedRoute }, { type: i4.EntryAdminService }, { type: i3.Router }, { type: i5.LocalizationService }]; }, propDecorators: { submitclick: [{
|
|
99
104
|
type: ViewChild,
|
|
100
105
|
args: ['submitclick', { static: true }]
|
|
101
106
|
}] } });
|
|
102
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
107
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"edit.component.js","sourceRoot":"","sources":["../../../../../../../projects/cms/src/lib/components/admin/entries/edit.component.ts","../../../../../../../projects/cms/src/lib/components/admin/entries/edit.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @angular-eslint/use-lifecycle-interface */\nimport { ToasterService } from '@abp/ng.theme.shared';\nimport { Component, ElementRef, OnInit, ViewChild, inject } from '@angular/core';\nimport { FormBuilder, FormGroup } from '@angular/forms';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { Location } from '@angular/common';\nimport { CreateOrUpdateEntryInputBase } from './create-or-update-entry-input-base';\nimport { LocalizationService } from '@abp/ng.core';\nimport { EntryAdminService } from '../../../proxy/admin/entries';\nimport { EXTENSIONS_IDENTIFIER } from '@abp/ng.theme.shared/extensions';\nimport { ECmsComponent } from '../../../enums/ecms-component';\nimport { UpdateListService } from '../../../services/update-list.service';\n\n@Component({\n  selector: 'cms-edit',\n  templateUrl: './edit.component.html',\n  styleUrls: ['./edit.component.scss'],\n  providers: [\n    {\n      provide: EXTENSIONS_IDENTIFIER,\n      useValue: ECmsComponent.Entries_Edit,\n    },\n  ],\n})\nexport class EditComponent implements OnInit {\n  constructor(\n    private toaster: ToasterService,\n    public _location: Location,\n    private route: ActivatedRoute,\n    private _EntryAdminService: EntryAdminService,\n    private router: Router,\n    private _LocalizationService: LocalizationService\n  ) {}\n  private fb = inject(FormBuilder);\n  private _updateListService = inject(UpdateListService);\n  \n  /**表单实体 */\n  newEntity: FormGroup | undefined;\n\n  /**是否是草稿 */\n  draftType: boolean = false;\n\n  /**页面传值用于传递到子组件 */\n  queryParams: any = '' || {};\n\n  /**指定id的条目信息 */\n  entrySelect: any = '';\n\n  /**获取提交按钮替身，用于真实触发表单提交 */\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\n\n  async ngOnInit() {\n    this.queryParams.RevisionEntryId = this.route.snapshot.params.entrieId;\n    this.newEntity = this.fb.group(new CreateOrUpdateEntryInputBase());\n    await this.getEntrySelect();\n  }\n\n  /**获取条目信息 */\n  getEntrySelect() {\n    return new Promise((resolve, rejects) => {\n      this._EntryAdminService.get(this.queryParams.RevisionEntryId).subscribe(res => {\n        this.entrySelect = res;\n        resolve(res);\n      });\n    });\n  }\n\n  /**保存 */\n  save(draft) {\n    this.newEntity.patchValue({\n      draft: draft,\n    });\n    let input = this.newEntity.value;\n    input.publishTime = new Date(\n      new Date(input.publishTime).getTime() + 8 * 60 * 60 * 1000\n    ).toISOString();\n    input.culture = this.newEntity.get('culture').value;\n    input.concurrencyStamp = this.entrySelect.concurrencyStamp;\n    if (!this.newEntity.valid) return;\n    this._EntryAdminService.update(this.entrySelect.id, input).subscribe(res => {\n      this.toaster.success(this._LocalizationService.instant(`CmsKit::SavedSuccessfully`));\n      this.router.navigateByUrl('', { skipLocationChange: true }).then(() => {\n        this.router.navigate([`/cms/admin/entries`]);\n        this._updateListService.updateList();\n      });\n    });\n  }\n\n  /**触发点击按钮替身 */\n  clickSubmit(type) {\n    this.draftType = type;\n    this.submitclick.nativeElement.click();\n  }\n  /**返回上一页 */\n  backTo() {\n    this._location.back();\n  }\n}\n","<form class=\"row g-3 needs-validation\" [formGroup]=\"newEntity\" (ngSubmit)=\"save(draftType)\">\n    <abp-page [title]=\"'AbpUi::Edit' | abpLocalization\" [toolbar]=\"true\">\n        <button type=\"submit\" style=\"display: none\" #submitclick></button>\n        <ng-container *ngIf=\"entrySelect\">\n            <cms-create-or-edit-entries [entity]=\"newEntity\" [ParentQueryParams]=\"queryParams\"\n                [parentEntrySelect]=\"entrySelect\" [isEdit]=\"true\"></cms-create-or-edit-entries>\n        </ng-container>\n    </abp-page>\n</form>"]}
|
|
@@ -1,16 +1,11 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { ToasterService, ConfirmationService } from '@abp/ng.theme.shared';
|
|
1
|
+
import { LIST_QUERY_DEBOUNCE_TIME, ListService } from '@abp/ng.core';
|
|
3
2
|
import { Component, inject } from '@angular/core';
|
|
4
3
|
import { FormBuilder } from '@angular/forms';
|
|
5
|
-
import { EntryAdminService } from '../../../proxy/admin/entries';
|
|
6
4
|
import { ColumnMode } from "@swimlane/ngx-datatable";
|
|
7
5
|
import { finalize } from 'rxjs/operators';
|
|
8
|
-
import { SiteAdminService } from '../../../proxy/admin/sites';
|
|
9
|
-
import { SectionAdminService } from '../../../proxy/admin/sections';
|
|
10
6
|
import { entryStatusOptions } from '../../../proxy/entries';
|
|
11
7
|
import { EXTENSIONS_IDENTIFIER } from '@abp/ng.theme.shared/extensions';
|
|
12
8
|
import { ECmsComponent } from '../../../enums/ecms-component';
|
|
13
|
-
import { Router } from '@angular/router';
|
|
14
9
|
import { UpdateListService } from '../../../services/update-list.service';
|
|
15
10
|
import * as i0 from "@angular/core";
|
|
16
11
|
import * as i1 from "../../../proxy/admin/entries";
|
|
@@ -25,7 +20,15 @@ import * as i9 from "@swimlane/ngx-datatable";
|
|
|
25
20
|
import * as i10 from "@ngx-validate/core";
|
|
26
21
|
import * as i11 from "@ng-bootstrap/ng-bootstrap";
|
|
27
22
|
import * as i12 from "@abp/ng.components/page";
|
|
28
|
-
|
|
23
|
+
class EntriesComponent {
|
|
24
|
+
_EntryAdminService;
|
|
25
|
+
_SiteAdminService;
|
|
26
|
+
_SectionAdminService;
|
|
27
|
+
toaster;
|
|
28
|
+
confirmation;
|
|
29
|
+
configState;
|
|
30
|
+
router;
|
|
31
|
+
_LocalizationService;
|
|
29
32
|
constructor(_EntryAdminService, _SiteAdminService, _SectionAdminService, toaster, confirmation, configState, router, _LocalizationService) {
|
|
30
33
|
this._EntryAdminService = _EntryAdminService;
|
|
31
34
|
this._SiteAdminService = _SiteAdminService;
|
|
@@ -35,41 +38,28 @@ export class EntriesComponent {
|
|
|
35
38
|
this.configState = configState;
|
|
36
39
|
this.router = router;
|
|
37
40
|
this._LocalizationService = _LocalizationService;
|
|
38
|
-
this.fb = inject(FormBuilder);
|
|
39
|
-
this._UpdateListService = inject(UpdateListService);
|
|
40
|
-
this.list = inject(ListService);
|
|
41
|
-
/**站点列表 */
|
|
42
|
-
this.siteList = [];
|
|
43
|
-
/**选择的站点id */
|
|
44
|
-
this.siteId = '';
|
|
45
|
-
/**站点下的版块 */
|
|
46
|
-
this.SiteOfSectionList = [];
|
|
47
|
-
/**版块下的语言列表 */
|
|
48
|
-
this.sectionLanguagesList = [];
|
|
49
|
-
/**版块下的条目类型列表 */
|
|
50
|
-
this.entryTypeList = [];
|
|
51
|
-
/**状态编码 */
|
|
52
|
-
this._entryStatusOptions = entryStatusOptions;
|
|
53
|
-
/**列表相关 */
|
|
54
|
-
this.ColumnMode = ColumnMode;
|
|
55
|
-
this.data = {
|
|
56
|
-
items: [],
|
|
57
|
-
totalCount: 0,
|
|
58
|
-
};
|
|
59
|
-
this.filters = {};
|
|
60
|
-
this.filtersForm = this.fb.group({
|
|
61
|
-
siteId: [''],
|
|
62
|
-
sectionId: [''],
|
|
63
|
-
culture: [''],
|
|
64
|
-
filter: [''],
|
|
65
|
-
});
|
|
66
41
|
}
|
|
42
|
+
fb = inject(FormBuilder);
|
|
43
|
+
_UpdateListService = inject(UpdateListService);
|
|
44
|
+
list = inject(ListService);
|
|
67
45
|
ngOnInit() {
|
|
68
46
|
this.getPageDate();
|
|
69
47
|
this._UpdateListService.updateListEvent.subscribe(() => {
|
|
70
48
|
this.list.get();
|
|
71
49
|
});
|
|
72
50
|
}
|
|
51
|
+
/**站点列表 */
|
|
52
|
+
siteList = [];
|
|
53
|
+
/**选择的站点id */
|
|
54
|
+
siteId = '';
|
|
55
|
+
/**站点下的版块 */
|
|
56
|
+
SiteOfSectionList = [];
|
|
57
|
+
/**版块下的语言列表 */
|
|
58
|
+
sectionLanguagesList = [];
|
|
59
|
+
/**版块下的条目类型列表 */
|
|
60
|
+
entryTypeList = [];
|
|
61
|
+
/**状态编码 */
|
|
62
|
+
_entryStatusOptions = entryStatusOptions;
|
|
73
63
|
/**获取页面数据 */
|
|
74
64
|
async getPageDate() {
|
|
75
65
|
await this.getsiteList();
|
|
@@ -156,6 +146,19 @@ export class EntriesComponent {
|
|
|
156
146
|
queryParams: { cultureName: this.filters.culture, sectionId: this.filters.sectionId, entryTypeId: this.entryTypeList[0].id }
|
|
157
147
|
});
|
|
158
148
|
}
|
|
149
|
+
/**列表相关 */
|
|
150
|
+
ColumnMode = ColumnMode;
|
|
151
|
+
data = {
|
|
152
|
+
items: [],
|
|
153
|
+
totalCount: 0,
|
|
154
|
+
};
|
|
155
|
+
filters = {};
|
|
156
|
+
filtersForm = this.fb.group({
|
|
157
|
+
siteId: [''],
|
|
158
|
+
sectionId: [''],
|
|
159
|
+
culture: [''],
|
|
160
|
+
filter: [''],
|
|
161
|
+
});
|
|
159
162
|
hookToQuery() {
|
|
160
163
|
const getData = (query) => this._EntryAdminService.getList({
|
|
161
164
|
...query,
|
|
@@ -178,8 +181,8 @@ export class EntriesComponent {
|
|
|
178
181
|
}
|
|
179
182
|
});
|
|
180
183
|
}
|
|
181
|
-
static
|
|
182
|
-
static
|
|
184
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EntriesComponent, deps: [{ token: i1.EntryAdminService }, { token: i2.SiteAdminService }, { token: i3.SectionAdminService }, { token: i4.ToasterService }, { token: i4.ConfirmationService }, { token: i5.ConfigStateService }, { token: i6.Router }, { token: i5.LocalizationService }], target: i0.ɵɵFactoryTarget.Component });
|
|
185
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EntriesComponent, selector: "cms-entries", providers: [
|
|
183
186
|
ListService,
|
|
184
187
|
// Provide this token if you want a different debounce time.
|
|
185
188
|
// Default is 300. Cannot be 0. Any value below 100 is not recommended.
|
|
@@ -188,9 +191,10 @@ export class EntriesComponent {
|
|
|
188
191
|
provide: EXTENSIONS_IDENTIFIER,
|
|
189
192
|
useValue: ECmsComponent.Entries,
|
|
190
193
|
},
|
|
191
|
-
], ngImport: i0, template: "<abp-page [title]=\"'Cms::Entries' | abpLocalization\" [toolbar]=\"true\">\r\n <abp-page-toolbar-container *ngIf=\"entryTypeList.length < 1\" class=\"col \"></abp-page-toolbar-container>\r\n <abp-page-toolbar-container *ngIf=\"entryTypeList.length > 1\" class=\"col \">\r\n <div class=\"row justify-content-end mx-0 gap-2\" *abpPermission=\"'CmsAdmin.Entry.Create'\">\r\n <div class=\"col-auto px-0 pt-0\">\r\n <div ngbDropdown class=\"d-inline-block\">\r\n <button type=\"button\" class=\"btn btn-primary btn-sm ms-2\" id=\"dropdownBasic1\" ngbDropdownToggle>\r\n <i class=\"fa fa-plus pe-1\" aria-hidden=\"true\"></i>{{'Cms::New' | abpLocalization}}\r\n </button>\r\n <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\">\r\n <ng-container *ngFor=\"let item of entryTypeList\">\r\n <button ngbDropdownItem [routerLink]=\"['/cms/admin/entries/create']\"\r\n [queryParams]=\"{cultureName: filters.culture,sectionId:filters.sectionId,entryTypeId:item.id}\">{{item.displayName}}</button>\r\n </ng-container>\r\n </div>\r\n </div> \r\n </div>\r\n </div>\r\n </abp-page-toolbar-container>\r\n <div id=\"sites-page\" class=\"sites-page\">\r\n <div class=\"card\">\r\n <div class=\"card-body px-2 py-sm-2 border-bottom\">\r\n <div class=\"input-group\" [formGroup]=\"filtersForm\">\r\n <select class=\"form-select col-auto\" formControlName=\"siteId\" (change)=\"siteIdChange()\">\r\n <ng-container *ngFor=\"let item of siteList\">\r\n <option [value]=\"item.id\">{{item.displayName}}</option>\r\n </ng-container>\r\n </select> \r\n <select class=\"form-select col-auto\" formControlName=\"sectionId\" (change)=\"sectionIdChange()\">\r\n <ng-container *ngFor=\"let item of SiteOfSectionList\">\r\n <option [value]=\"item.id\">{{item.displayName}}</option>\r\n </ng-container>\r\n </select> \r\n <select class=\"form-select col-auto\" formControlName=\"culture\" (change)=\"cultureChange()\">\r\n <ng-container *ngFor=\"let item of sectionLanguagesList\">\r\n <option [value]=\"item.cultureName\">{{item.displayName}}</option>\r\n </ng-container>\r\n </select>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"filter\"\r\n [placeholder]=\"'AbpUi::Search' | abpLocalization\" />\r\n <button class=\"btn btn-primary px-3\" type=\"button\" id=\"button-addon2\" (click)=\"resetData()\">\r\n <i class=\"fa fa-search\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"card mb-0\">\r\n <div class=\"card-body p-0\">\r\n <div class=\"table-responsive table-fixed-header\">\r\n <ngx-datatable class=\"material container-height\" [rows]=\"data.items\" [list]=\"list\"\r\n [columnMode]=\"'force'\" [headerHeight]=\"50\" [footerHeight]=\"50\" rowHeight=\"auto\"\r\n [scrollbarV]=\"true\" [virtualization]=\"false\" [externalPaging]=\"true\"\r\n [count]=\"data.totalCount\">\r\n <ngx-datatable-column [name]=\"'Cms::EntryType' | abpLocalization\" prop=\"entryTypeId\">\r\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n <ng-container *ngFor=\"let item of entryTypeList\">\r\n <ng-container *ngIf=\"item.id === value\">{{item.displayName}}</ng-container>\r\n </ng-container>\r\n </ng-template>\r\n </ngx-datatable-column>\r\n <ngx-datatable-column [name]=\"'Cms::Title' | abpLocalization\" prop=\"title\">\r\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n {{ value }}\r\n </ng-template>\r\n </ngx-datatable-column>\r\n <ngx-datatable-column [name]=\"'Cms::Slug' | abpLocalization\" prop=\"slug\">\r\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n {{ value }}\r\n </ng-template>\r\n </ngx-datatable-column>\r\n <ngx-datatable-column [name]=\"'Cms::Status' | abpLocalization\" prop=\"status\">\r\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n <ng-container *ngFor=\"let item of _entryStatusOptions\">\r\n <ng-container *ngIf=\"item.value=== value\">{{ 'Cms::Enum:EntryStatus:'+item.key |\r\n abpLocalization }}</ng-container>\r\n </ng-container>\r\n </ng-template>\r\n </ngx-datatable-column>\r\n <ngx-datatable-column [name]=\"'Cms::PublishTime' | abpLocalization\" prop=\"publishTime\">\r\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n {{value | date: 'YYYY/MM/dd HH:mm:s' }}\r\n </ng-template>\r\n </ngx-datatable-column>\r\n <ngx-datatable-column [sortable]=\"false\">\r\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n <div ngbDropdown container=\"body\">\r\n <button type=\"button\" class=\"btn btn-outline-primary btn-sm\" ngbDropdownToggle>\r\n {{'AbpUi::Actions' | abpLocalization}}\r\n </button>\r\n <div ngbDropdownMenu>\r\n <button ngbDropdownItem\r\n routerLink=\"/cms/admin/entries/{{row.id}}/edit\">{{'AbpUi::Edit' |\r\n abpLocalization}}</button>\r\n <button ngbDropdownItem (click)=\"deletefield(row)\">{{'AbpUi::Delete' |\r\n abpLocalization}}</button>\r\n </div>\r\n </div>\r\n </ng-template>\r\n </ngx-datatable-column>\r\n </ngx-datatable>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</abp-page>", styles: ["::ng-deep .sites-page .dignite_page{background:transparent}::ng-deep .sites-page .list-group-flush>.list-group-item:first-child{border-top-width:var(--bs-list-group-border-width)}::ng-deep .sites-page .card-header input{flex:2 1 auto}::ng-deep .sites-page .card-header .form-select{padding:.475rem 3.75rem .475rem 1.25rem}::ng-deep .sites-page .container-height{height:calc(100vh - 220px)}::ng-deep .sites-page .morentr{border:2px solid transparent}::ng-deep .sites-page .borderdrag{border:2px solid var(--ck-color-selector-column-resizer-hover)!important}::ng-deep .sites-page .borderdragtd{background-color:var(--ck-color-selector-column-resizer-hover)!important}::ng-deep .sites-page .testtr{border-color:transparent}::ng-deep .sites-page .testtr td{padding:2px}::ng-deep .sites-page .testtr:hover{background-color:transparent}.cdk-drag-preview{display:table;box-sizing:border-box;border-radius:4px;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.cdk-drag-placeholder{opacity:0}.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.example-box:last-child{border:0}.example-list.cdk-drop-list-dragging .example-box:not(.cdk-drag-placeholder){transition:transform .25s cubic-bezier(0,0,.2,1)}::ng-deep .sites-modal-form .form-control{padding:.4rem 1.25rem}\n"], dependencies: [{ kind: "directive", type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i8.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i8.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i8.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i8.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i8.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i8.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i8.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i6.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i5.PermissionDirective, selector: "[abpPermission]", inputs: ["abpPermission", "abpPermissionRunChangeDetection"] }, { kind: "component", type: i9.DatatableComponent, selector: "ngx-datatable", inputs: ["targetMarkerTemplate", "rows", "groupRowsBy", "groupedRows", "columns", "selected", "scrollbarV", "scrollbarH", "rowHeight", "columnMode", "headerHeight", "footerHeight", "externalPaging", "externalSorting", "limit", "count", "offset", "loadingIndicator", "selectionType", "reorderable", "swapColumns", "sortType", "sorts", "cssClasses", "messages", "rowClass", "selectCheck", "displayCheck", "groupExpansionDefault", "trackByProp", "selectAllRowsOnPage", "virtualization", "treeFromRelation", "treeToRelation", "summaryRow", "summaryHeight", "summaryPosition", "rowIdentity"], outputs: ["scroll", "activate", "select", "sort", "page", "reorder", "resize", "tableContextmenu", "treeAction"] }, { kind: "directive", type: i9.DataTableColumnDirective, selector: "ngx-datatable-column", inputs: ["name", "prop", "frozenLeft", "frozenRight", "flexGrow", "resizeable", "comparator", "pipe", "sortable", "draggable", "canAutoResize", "minWidth", "width", "maxWidth", "checkboxable", "headerCheckboxable", "headerClass", "cellClass", "isTreeColumn", "treeLevelIndent", "summaryFunc", "summaryTemplate", "cellTemplate", "headerTemplate", "treeToggleTemplate"] }, { kind: "directive", type: i9.DataTableColumnCellDirective, selector: "[ngx-datatable-cell-template]" }, { kind: "directive", type: i10.ValidationGroupDirective, selector: "[formGroup],[formGroupName]", exportAs: ["validationGroup"] }, { kind: "directive", type: i10.ValidationDirective, selector: "[formControl],[formControlName]", exportAs: ["validationDirective"] }, { kind: "directive", type: i4.NgxDatatableListDirective, selector: "ngx-datatable[list]", inputs: ["list"], exportAs: ["ngxDatatableList"] }, { kind: "directive", type: i11.NgbDropdown, selector: "[ngbDropdown]", inputs: ["autoClose", "dropdownClass", "open", "placement", "popperOptions", "container", "display"], outputs: ["openChange"], exportAs: ["ngbDropdown"] }, { kind: "directive", type: i11.NgbDropdownToggle, selector: "[ngbDropdownToggle]" }, { kind: "directive", type: i11.NgbDropdownMenu, selector: "[ngbDropdownMenu]" }, { kind: "directive", type: i11.NgbDropdownItem, selector: "[ngbDropdownItem]", inputs: ["tabindex", "disabled"] }, { kind: "directive", type: i11.NgbDropdownButtonItem, selector: "button[ngbDropdownItem]" }, { kind: "component", type: i12.PageComponent, selector: "abp-page", inputs: ["title", "toolbar", "breadcrumb"] }, { kind: "component", type: i12.PageToolbarContainerComponent, selector: "abp-page-toolbar-container" }, { kind: "pipe", type: i7.DatePipe, name: "date" }, { kind: "pipe", type: i5.LocalizationPipe, name: "abpLocalization" }] }); }
|
|
194
|
+
], ngImport: i0, template: "<abp-page [title]=\"'Cms::Entries' | abpLocalization\" [toolbar]=\"true\">\r\n <abp-page-toolbar-container *ngIf=\"entryTypeList.length < 1\" class=\"col \"></abp-page-toolbar-container>\r\n <abp-page-toolbar-container *ngIf=\"entryTypeList.length > 1\" class=\"col \">\r\n <div class=\"row justify-content-end mx-0 gap-2\" *abpPermission=\"'CmsAdmin.Entry.Create'\">\r\n <div class=\"col-auto px-0 pt-0\">\r\n <div ngbDropdown class=\"d-inline-block\">\r\n <button type=\"button\" class=\"btn btn-primary btn-sm ms-2\" id=\"dropdownBasic1\" ngbDropdownToggle>\r\n <i class=\"fa fa-plus pe-1\" aria-hidden=\"true\"></i>{{'Cms::New' | abpLocalization}}\r\n </button>\r\n <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\">\r\n <ng-container *ngFor=\"let item of entryTypeList\">\r\n <button ngbDropdownItem [routerLink]=\"['/cms/admin/entries/create']\"\r\n [queryParams]=\"{cultureName: filters.culture,sectionId:filters.sectionId,entryTypeId:item.id}\">{{item.displayName}}</button>\r\n </ng-container>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </abp-page-toolbar-container>\r\n <div id=\"sites-page\" class=\"sites-page\">\r\n <div class=\"card\">\r\n <div class=\"card-body px-2 py-sm-2 border-bottom\" [formGroup]=\"filtersForm\">\r\n <div class=\"row align-items-start\">\r\n <div class=\"mb-2 col-4\">\r\n <label class=\"form-label\">{{'Cms::Sites' | abpLocalization}}\uFF1A</label>\r\n <select class=\"form-select col-auto\" formControlName=\"siteId\" (change)=\"siteIdChange()\">\r\n <ng-container *ngFor=\"let item of siteList\">\r\n <option [value]=\"item.id\">{{item.displayName}}</option>\r\n </ng-container>\r\n </select>\r\n </div>\r\n <div class=\"mb-2 col-4\">\r\n <label class=\"form-label\">{{'Cms::Sections' | abpLocalization}}\uFF1A</label>\r\n <select class=\"form-select col-auto\" formControlName=\"sectionId\" (change)=\"sectionIdChange()\">\r\n <ng-container *ngFor=\"let item of SiteOfSectionList\">\r\n <option [value]=\"item.id\">{{item.displayName}}</option>\r\n </ng-container>\r\n </select>\r\n </div>\r\n <div class=\"mb-2 col-4\">\r\n <label class=\"form-label\">{{'AbpUi::Languages' | abpLocalization}}\uFF1A</label>\r\n <select class=\"form-select col-auto\" formControlName=\"culture\" (change)=\"cultureChange()\">\r\n <ng-container *ngFor=\"let item of sectionLanguagesList\">\r\n <option [value]=\"item.cultureName\">{{item.displayName}}</option>\r\n </ng-container>\r\n </select>\r\n </div>\r\n </div>\r\n <div class=\"input-group\">\r\n <input type=\"text\" class=\"form-control\" formControlName=\"filter\"\r\n [placeholder]=\"'AbpUi::Search' | abpLocalization\" />\r\n <button class=\"btn btn-primary px-3\" type=\"button\" id=\"button-addon2\" (click)=\"resetData()\">\r\n <i class=\"fa fa-search\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"card mb-0\">\r\n <div class=\"card-body p-0\">\r\n <div class=\"table-responsive table-fixed-header\">\r\n <ngx-datatable class=\"material container-height\" [rows]=\"data.items\" [list]=\"list\"\r\n [columnMode]=\"'force'\" [headerHeight]=\"50\" [footerHeight]=\"50\" rowHeight=\"auto\"\r\n [virtualization]=\"false\" [externalPaging]=\"true\" [count]=\"data.totalCount\">\r\n <ngx-datatable-column [name]=\"'Cms::EntryType' | abpLocalization\" prop=\"entryTypeId\">\r\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n <ng-container *ngFor=\"let item of entryTypeList\">\r\n <ng-container *ngIf=\"item.id === value\">{{item.displayName}}</ng-container>\r\n </ng-container>\r\n </ng-template>\r\n </ngx-datatable-column>\r\n <ngx-datatable-column [name]=\"'Cms::Title' | abpLocalization\" prop=\"title\">\r\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n {{ value }}\r\n </ng-template>\r\n </ngx-datatable-column>\r\n <ngx-datatable-column [name]=\"'Cms::Slug' | abpLocalization\" prop=\"slug\">\r\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n {{ value }}\r\n </ng-template>\r\n </ngx-datatable-column>\r\n <ngx-datatable-column [name]=\"'Cms::Status' | abpLocalization\" prop=\"status\">\r\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n <ng-container *ngFor=\"let item of _entryStatusOptions\">\r\n <ng-container *ngIf=\"item.value=== value\">{{ 'Cms::Enum:EntryStatus:'+item.key |\r\n abpLocalization }}</ng-container>\r\n </ng-container>\r\n </ng-template>\r\n </ngx-datatable-column>\r\n <ngx-datatable-column [name]=\"'Cms::PublishTime' | abpLocalization\" prop=\"publishTime\">\r\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n {{value | date: 'YYYY/MM/dd HH:mm:s' }}\r\n </ng-template>\r\n </ngx-datatable-column>\r\n <ngx-datatable-column [sortable]=\"false\">\r\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n <div ngbDropdown container=\"body\">\r\n <button type=\"button\" class=\"btn btn-outline-primary btn-sm\" ngbDropdownToggle>\r\n {{'AbpUi::Actions' | abpLocalization}}\r\n </button>\r\n <div ngbDropdownMenu>\r\n <button ngbDropdownItem\r\n routerLink=\"/cms/admin/entries/{{row.id}}/edit\">{{'AbpUi::Edit' |\r\n abpLocalization}}</button>\r\n <button ngbDropdownItem (click)=\"deletefield(row)\">{{'AbpUi::Delete' |\r\n abpLocalization}}</button>\r\n </div>\r\n </div>\r\n </ng-template>\r\n </ngx-datatable-column>\r\n </ngx-datatable>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</abp-page>", styles: ["::ng-deep .sites-page .dignite_page{background:transparent}::ng-deep .sites-page .list-group-flush>.list-group-item:first-child{border-top-width:var(--bs-list-group-border-width)}::ng-deep .sites-page .card-header input{flex:2 1 auto}::ng-deep .sites-page .card-header .form-select{padding:.475rem 3.75rem .475rem 1.25rem}::ng-deep .sites-page .morentr{border:2px solid transparent}::ng-deep .sites-page .borderdrag{border:2px solid var(--ck-color-selector-column-resizer-hover)!important}::ng-deep .sites-page .borderdragtd{background-color:var(--ck-color-selector-column-resizer-hover)!important}::ng-deep .sites-page .testtr{border-color:transparent}::ng-deep .sites-page .testtr td{padding:2px}::ng-deep .sites-page .testtr:hover{background-color:transparent}.cdk-drag-preview{display:table;box-sizing:border-box;border-radius:4px;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.cdk-drag-placeholder{opacity:0}.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.example-box:last-child{border:0}.example-list.cdk-drop-list-dragging .example-box:not(.cdk-drag-placeholder){transition:transform .25s cubic-bezier(0,0,.2,1)}::ng-deep .sites-modal-form .form-control{padding:.4rem 1.25rem}\n"], dependencies: [{ kind: "directive", type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i8.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i8.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i8.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i8.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i8.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i8.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i8.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i6.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i5.PermissionDirective, selector: "[abpPermission]", inputs: ["abpPermission", "abpPermissionRunChangeDetection"] }, { kind: "component", type: i9.DatatableComponent, selector: "ngx-datatable", inputs: ["targetMarkerTemplate", "rows", "groupRowsBy", "groupedRows", "columns", "selected", "scrollbarV", "scrollbarH", "rowHeight", "columnMode", "headerHeight", "footerHeight", "externalPaging", "externalSorting", "limit", "count", "offset", "loadingIndicator", "selectionType", "reorderable", "swapColumns", "sortType", "sorts", "cssClasses", "messages", "rowClass", "selectCheck", "displayCheck", "groupExpansionDefault", "trackByProp", "selectAllRowsOnPage", "virtualization", "treeFromRelation", "treeToRelation", "summaryRow", "summaryHeight", "summaryPosition", "rowIdentity"], outputs: ["scroll", "activate", "select", "sort", "page", "reorder", "resize", "tableContextmenu", "treeAction"] }, { kind: "directive", type: i9.DataTableColumnDirective, selector: "ngx-datatable-column", inputs: ["name", "prop", "frozenLeft", "frozenRight", "flexGrow", "resizeable", "comparator", "pipe", "sortable", "draggable", "canAutoResize", "minWidth", "width", "maxWidth", "checkboxable", "headerCheckboxable", "headerClass", "cellClass", "isTreeColumn", "treeLevelIndent", "summaryFunc", "summaryTemplate", "cellTemplate", "headerTemplate", "treeToggleTemplate"] }, { kind: "directive", type: i9.DataTableColumnCellDirective, selector: "[ngx-datatable-cell-template]" }, { kind: "directive", type: i10.ValidationGroupDirective, selector: "[formGroup],[formGroupName]", exportAs: ["validationGroup"] }, { kind: "directive", type: i10.ValidationDirective, selector: "[formControl],[formControlName]", exportAs: ["validationDirective"] }, { kind: "directive", type: i4.NgxDatatableListDirective, selector: "ngx-datatable[list]", inputs: ["list"], exportAs: ["ngxDatatableList"] }, { kind: "directive", type: i11.NgbDropdown, selector: "[ngbDropdown]", inputs: ["autoClose", "dropdownClass", "open", "placement", "popperOptions", "container", "display"], outputs: ["openChange"], exportAs: ["ngbDropdown"] }, { kind: "directive", type: i11.NgbDropdownToggle, selector: "[ngbDropdownToggle]" }, { kind: "directive", type: i11.NgbDropdownMenu, selector: "[ngbDropdownMenu]" }, { kind: "directive", type: i11.NgbDropdownItem, selector: "[ngbDropdownItem]", inputs: ["disabled"] }, { kind: "component", type: i12.PageComponent, selector: "abp-page", inputs: ["title", "toolbar", "breadcrumb"] }, { kind: "component", type: i12.PageToolbarContainerComponent, selector: "abp-page-toolbar-container" }, { kind: "pipe", type: i7.DatePipe, name: "date" }, { kind: "pipe", type: i5.LocalizationPipe, name: "abpLocalization" }] });
|
|
192
195
|
}
|
|
193
|
-
|
|
196
|
+
export { EntriesComponent };
|
|
197
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EntriesComponent, decorators: [{
|
|
194
198
|
type: Component,
|
|
195
199
|
args: [{ selector: 'cms-entries', providers: [
|
|
196
200
|
ListService,
|
|
@@ -201,6 +205,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.9", ngImpor
|
|
|
201
205
|
provide: EXTENSIONS_IDENTIFIER,
|
|
202
206
|
useValue: ECmsComponent.Entries,
|
|
203
207
|
},
|
|
204
|
-
], template: "<abp-page [title]=\"'Cms::Entries' | abpLocalization\" [toolbar]=\"true\">\r\n <abp-page-toolbar-container *ngIf=\"entryTypeList.length < 1\" class=\"col \"></abp-page-toolbar-container>\r\n <abp-page-toolbar-container *ngIf=\"entryTypeList.length > 1\" class=\"col \">\r\n <div class=\"row justify-content-end mx-0 gap-2\" *abpPermission=\"'CmsAdmin.Entry.Create'\">\r\n <div class=\"col-auto px-0 pt-0\">\r\n <div ngbDropdown class=\"d-inline-block\">\r\n <button type=\"button\" class=\"btn btn-primary btn-sm ms-2\" id=\"dropdownBasic1\" ngbDropdownToggle>\r\n <i class=\"fa fa-plus pe-1\" aria-hidden=\"true\"></i>{{'Cms::New' | abpLocalization}}\r\n </button>\r\n <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\">\r\n <ng-container *ngFor=\"let item of entryTypeList\">\r\n <button ngbDropdownItem [routerLink]=\"['/cms/admin/entries/create']\"\r\n [queryParams]=\"{cultureName: filters.culture,sectionId:filters.sectionId,entryTypeId:item.id}\">{{item.displayName}}</button>\r\n </ng-container>\r\n </div>\r\n </div
|
|
205
|
-
}], ctorParameters: ()
|
|
206
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entries.component.js","sourceRoot":"","sources":["../../../../../../../../packages/cms/src/lib/components/admin/entries/entries.component.ts","../../../../../../../../packages/cms/src/lib/components/admin/entries/entries.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ABP, ConfigStateService, LIST_QUERY_DEBOUNCE_TIME, ListService, LocalizationService, PagedResultDto } from '@abp/ng.core';\nimport { ToasterService, ConfirmationService, Confirmation } from '@abp/ng.theme.shared';\nimport { Component, OnInit, inject } from '@angular/core';\nimport { FormBuilder, FormGroup } from '@angular/forms';\nimport { EntryAdminService, EntryDto, GetEntriesInput } from '../../../proxy/admin/entries';\nimport { ColumnMode } from \"@swimlane/ngx-datatable\";\nimport { finalize } from 'rxjs/operators';\nimport { SiteAdminService } from '../../../proxy/admin/sites';\nimport { SectionAdminService } from '../../../proxy/admin/sections';\nimport { entryStatusOptions } from '../../../proxy/entries';\nimport { EXTENSIONS_IDENTIFIER } from '@abp/ng.theme.shared/extensions';\nimport { ECmsComponent } from '../../../enums/ecms-component';\nimport { Router } from '@angular/router';\nimport { UpdateListService } from '../../../services/update-list.service';\n\n\n@Component({\n  selector: 'cms-entries',\n  templateUrl: './entries.component.html',\n  styleUrls: ['./entries.component.scss'],\n  providers: [\n    ListService,\n    // Provide this token if you want a different debounce time.\n    // Default is 300. Cannot be 0. Any value below 100 is not recommended.\n    { provide: LIST_QUERY_DEBOUNCE_TIME, useValue: 500 },\n    {\n      provide: EXTENSIONS_IDENTIFIER,\n      useValue: ECmsComponent.Entries,\n    },\n  ]\n})\nexport class EntriesComponent implements OnInit {\n  \n  constructor(\n    private _EntryAdminService: EntryAdminService,\n    private _SiteAdminService: SiteAdminService,\n    private _SectionAdminService: SectionAdminService,\n    private toaster: ToasterService,\n    private confirmation: ConfirmationService,\n    private configState: ConfigStateService,\n    private router: Router,\n    private _LocalizationService: LocalizationService,\n  ) {\n  }\n\n  private fb=inject(FormBuilder)\n  private _UpdateListService=inject(UpdateListService)\n  public readonly list=inject(ListService)\n\n\n  ngOnInit(): void {\n    this.getPageDate()\n    this._UpdateListService.updateListEvent.subscribe(() => {\n      this.list.get()\n    });\n  }\n\n  /**站点列表 */\n  siteList: any[any] = []\n  /**选择的站点id */\n  siteId: string = ''\n  /**站点下的版块 */\n  SiteOfSectionList: any[any] = []\n\n\n  /**版块下的语言列表 */\n  sectionLanguagesList: any[any] = []\n  /**版块下的条目类型列表 */\n  entryTypeList: any[any] = []\n  /**状态编码 */\n  _entryStatusOptions = entryStatusOptions\n\n  /**获取页面数据 */\n  async getPageDate() {\n    await this.getsiteList()\n    await this.getSiteOfSectionList()\n    await this.getSectionLanguagesList()\n    this.filters=this.filtersForm.value\n    this.hookToQuery()\n  }\n\n  /**切换站点 */\n  async siteIdChange() {\n    await this.getSiteOfSectionList()\n    await this.getSectionLanguagesList()\n    this.resetData()\n  }\n  /**切换板块 */\n  async sectionIdChange() {\n    this.getSectionOfEntryType()\n    await this.getSectionLanguagesList()\n    this.resetData()\n  }\n  /**切换语言 */\n  async cultureChange() {\n    this.resetData()\n  }\n  /**获取站点列表 */\n  getsiteList() {\n    return new Promise((resolve, rejects) => {\n      this._SiteAdminService.getList({}).subscribe(res => {\n        this.siteList = res.items\n        this.filtersForm.get('siteId').patchValue(res.items[0]?.id || '')\n        resolve(res.items)\n      })\n    })\n  }\n\n  /**获取站点下的版块 */\n  getSiteOfSectionList() {\n    return new Promise((resolve, rejects) => {\n      let siteId = this.filtersForm.get('siteId').value\n      this._SectionAdminService.getList({\n        maxResultCount: 1000,\n        siteId: siteId\n      }).subscribe(res => {\n        this.SiteOfSectionList = res.items\n        this.filtersForm.get('sectionId').patchValue(res.items[0]?.id || '')\n        this.getSectionOfEntryType()\n        resolve(res.items)\n      })\n    })\n  }\n\n  /**获取版块下的条目类型 */\n  getSectionOfEntryType() {\n    let sectionId = this.filtersForm.get('sectionId').value\n    this.entryTypeList = this.SiteOfSectionList.find(el => el.id == sectionId)?.entryTypes || []\n  }\n\n  /**获取版块下的语言列表 */\n  getSectionLanguagesList() {\n    return new Promise((resolve, rejects) => {\n  \n      //获取所有语言 */\n      let languages = this.configState.getDeep('localization.languages')\n      //当前选择的板块id\n      let sectionId = this.filtersForm.get('sectionId').value\n      //板块下的语言\n      let sectionOfLanguages = this.SiteOfSectionList.find(el => el.id == sectionId)?.site?.languages || []\n      //获取系统语言 */\n      let systemculture=this.configState.getDeep('localization.currentCulture.name')\n      //获取当前选择的语言\n      let nowculture=this.filtersForm.get('culture').value\n      //当前选择的语言，是否在版块的的语言列表中\n      let isexist=  sectionOfLanguages.find(el=>el.cultureName==nowculture)\n      this.filtersForm.get('culture').patchValue(nowculture?isexist?nowculture:systemculture:systemculture)\n      this.sectionLanguagesList = languages.filter(el => sectionOfLanguages.find(ell => ell.cultureName === el.cultureName))\n      resolve(sectionOfLanguages)\n    })\n  }\n\n\n\n    resetData() {\n      this.filters=this.filtersForm.value\n      this.list.page = 0\n      this.data.items = []\n      this.list.get()\n    }\n\n  /**新增-单个 */\n  createEntriesBtn() {\n    this.router.navigate(['/cms/admin/entries/create'], {\n      queryParams: { cultureName: this.filters.culture, sectionId: this.filters.sectionId, entryTypeId: this.entryTypeList[0].id }\n    })\n  }\n\n  /**列表相关 */\n  ColumnMode = ColumnMode;\n  data: PagedResultDto<EntryDto> = {\n    items: [],\n    totalCount: 0,\n  };\n\n  filters = {} as GetEntriesInput;\n  filtersForm: FormGroup = this.fb.group({\n    siteId: [''],\n    sectionId: [''],\n    culture: [''],\n    filter: [''],\n  })\n\n  hookToQuery() {\n    \n    const getData = (query: ABP.PageQueryParams) => this._EntryAdminService.getList({\n      ...query,\n      ...this.filters,\n    });\n    const setData = (list: PagedResultDto<EntryDto>) => {\n      this.data = list\n    };\n    this.list.hookToQuery(getData).subscribe(setData);\n  }\n\n\n  /**删除条目 */\n  deletefield(row: any) {\n    this.confirmation.warn(\n      row.displayName,\n      this._LocalizationService.instant(`AbpUi::ItemWillBeDeletedMessage`),\n    ).subscribe((status: Confirmation.Status) => {\n      if (status == 'confirm') {\n        this._EntryAdminService.delete(row.id).pipe(finalize(() => {\n        })).subscribe(res => {\n          this.toaster.success(this._LocalizationService.instant(`AbpUi::SuccessfullyDeleted`));\n          this.list.get()\n        })\n      }\n\n    });\n  }\n\n\n}\n","<abp-page [title]=\"'Cms::Entries' | abpLocalization\" [toolbar]=\"true\">\r\n    <abp-page-toolbar-container *ngIf=\"entryTypeList.length < 1\" class=\"col \"></abp-page-toolbar-container>\r\n    <abp-page-toolbar-container *ngIf=\"entryTypeList.length > 1\" class=\"col \">\r\n        <div class=\"row justify-content-end mx-0 gap-2\" *abpPermission=\"'CmsAdmin.Entry.Create'\">\r\n            <div class=\"col-auto px-0 pt-0\">\r\n                <div ngbDropdown class=\"d-inline-block\">\r\n                    <button type=\"button\" class=\"btn btn-primary btn-sm ms-2\" id=\"dropdownBasic1\" ngbDropdownToggle>\r\n                        <i class=\"fa fa-plus pe-1\" aria-hidden=\"true\"></i>{{'Cms::New' | abpLocalization}}\r\n                    </button>\r\n                    <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\">\r\n                        <ng-container *ngFor=\"let item of entryTypeList\">\r\n                            <button ngbDropdownItem [routerLink]=\"['/cms/admin/entries/create']\"\r\n                                [queryParams]=\"{cultureName: filters.culture,sectionId:filters.sectionId,entryTypeId:item.id}\">{{item.displayName}}</button>\r\n                        </ng-container>\r\n                    </div>\r\n                </div> \r\n            </div>\r\n        </div>\r\n    </abp-page-toolbar-container>\r\n    <div id=\"sites-page\" class=\"sites-page\">\r\n        <div class=\"card\">\r\n            <div class=\"card-body px-2 py-sm-2 border-bottom\">\r\n                <div class=\"input-group\" [formGroup]=\"filtersForm\">\r\n                    <select class=\"form-select col-auto\" formControlName=\"siteId\"  (change)=\"siteIdChange()\">\r\n                        <ng-container *ngFor=\"let item of siteList\">\r\n                            <option [value]=\"item.id\">{{item.displayName}}</option>\r\n                        </ng-container>\r\n                    </select> \r\n                    <select class=\"form-select col-auto\" formControlName=\"sectionId\"  (change)=\"sectionIdChange()\">\r\n                        <ng-container *ngFor=\"let item of SiteOfSectionList\">\r\n                            <option [value]=\"item.id\">{{item.displayName}}</option>\r\n                        </ng-container>\r\n                    </select> \r\n                    <select class=\"form-select col-auto\" formControlName=\"culture\"  (change)=\"cultureChange()\">\r\n                        <ng-container *ngFor=\"let item of sectionLanguagesList\">\r\n                            <option [value]=\"item.cultureName\">{{item.displayName}}</option>\r\n                        </ng-container>\r\n                    </select>\r\n                    <input type=\"text\" class=\"form-control\" formControlName=\"filter\"\r\n                        [placeholder]=\"'AbpUi::Search' | abpLocalization\" />\r\n                    <button class=\"btn btn-primary px-3\" type=\"button\" id=\"button-addon2\" (click)=\"resetData()\">\r\n                        <i class=\"fa fa-search\"></i>\r\n                    </button>\r\n                </div>\r\n            </div>\r\n        </div>\r\n        <div class=\"card mb-0\">\r\n            <div class=\"card-body p-0\">\r\n                <div class=\"table-responsive table-fixed-header\">\r\n                        <ngx-datatable class=\"material container-height\" [rows]=\"data.items\" [list]=\"list\"\r\n                            [columnMode]=\"'force'\" [headerHeight]=\"50\" [footerHeight]=\"50\" rowHeight=\"auto\"\r\n                            [scrollbarV]=\"true\" [virtualization]=\"false\" [externalPaging]=\"true\"\r\n                            [count]=\"data.totalCount\">\r\n                            <ngx-datatable-column [name]=\"'Cms::EntryType' | abpLocalization\" prop=\"entryTypeId\">\r\n                                <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n                                    <ng-container *ngFor=\"let item of entryTypeList\">\r\n                                        <ng-container *ngIf=\"item.id === value\">{{item.displayName}}</ng-container>\r\n                                    </ng-container>\r\n                                </ng-template>\r\n                            </ngx-datatable-column>\r\n                            <ngx-datatable-column [name]=\"'Cms::Title' | abpLocalization\" prop=\"title\">\r\n                                <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n                                    {{ value }}\r\n                                </ng-template>\r\n                            </ngx-datatable-column>\r\n                            <ngx-datatable-column [name]=\"'Cms::Slug' | abpLocalization\" prop=\"slug\">\r\n                                <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n                                    {{ value }}\r\n                                </ng-template>\r\n                            </ngx-datatable-column>\r\n                            <ngx-datatable-column [name]=\"'Cms::Status' | abpLocalization\" prop=\"status\">\r\n                                <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n                                    <ng-container *ngFor=\"let item of _entryStatusOptions\">\r\n                                        <ng-container *ngIf=\"item.value=== value\">{{ 'Cms::Enum:EntryStatus:'+item.key |\r\n                                            abpLocalization }}</ng-container>\r\n                                    </ng-container>\r\n                                </ng-template>\r\n                            </ngx-datatable-column>\r\n                            <ngx-datatable-column [name]=\"'Cms::PublishTime' | abpLocalization\" prop=\"publishTime\">\r\n                                <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n                                    {{value | date: 'YYYY/MM/dd HH:mm:s' }}\r\n                                </ng-template>\r\n                            </ngx-datatable-column>\r\n                            <ngx-datatable-column [sortable]=\"false\">\r\n                                <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n                                    <div ngbDropdown container=\"body\">\r\n                                        <button type=\"button\" class=\"btn btn-outline-primary btn-sm\" ngbDropdownToggle>\r\n                                            {{'AbpUi::Actions' | abpLocalization}}\r\n                                        </button>\r\n                                        <div ngbDropdownMenu>\r\n                                            <button ngbDropdownItem\r\n                                                routerLink=\"/cms/admin/entries/{{row.id}}/edit\">{{'AbpUi::Edit' |\r\n                                                abpLocalization}}</button>\r\n                                            <button ngbDropdownItem (click)=\"deletefield(row)\">{{'AbpUi::Delete' |\r\n                                                abpLocalization}}</button>\r\n                                        </div>\r\n                                    </div>\r\n                                </ng-template>\r\n                            </ngx-datatable-column>\r\n                        </ngx-datatable>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</abp-page>"]}
|
|
208
|
+
], template: "<abp-page [title]=\"'Cms::Entries' | abpLocalization\" [toolbar]=\"true\">\r\n <abp-page-toolbar-container *ngIf=\"entryTypeList.length < 1\" class=\"col \"></abp-page-toolbar-container>\r\n <abp-page-toolbar-container *ngIf=\"entryTypeList.length > 1\" class=\"col \">\r\n <div class=\"row justify-content-end mx-0 gap-2\" *abpPermission=\"'CmsAdmin.Entry.Create'\">\r\n <div class=\"col-auto px-0 pt-0\">\r\n <div ngbDropdown class=\"d-inline-block\">\r\n <button type=\"button\" class=\"btn btn-primary btn-sm ms-2\" id=\"dropdownBasic1\" ngbDropdownToggle>\r\n <i class=\"fa fa-plus pe-1\" aria-hidden=\"true\"></i>{{'Cms::New' | abpLocalization}}\r\n </button>\r\n <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\">\r\n <ng-container *ngFor=\"let item of entryTypeList\">\r\n <button ngbDropdownItem [routerLink]=\"['/cms/admin/entries/create']\"\r\n [queryParams]=\"{cultureName: filters.culture,sectionId:filters.sectionId,entryTypeId:item.id}\">{{item.displayName}}</button>\r\n </ng-container>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </abp-page-toolbar-container>\r\n <div id=\"sites-page\" class=\"sites-page\">\r\n <div class=\"card\">\r\n <div class=\"card-body px-2 py-sm-2 border-bottom\" [formGroup]=\"filtersForm\">\r\n <div class=\"row align-items-start\">\r\n <div class=\"mb-2 col-4\">\r\n <label class=\"form-label\">{{'Cms::Sites' | abpLocalization}}\uFF1A</label>\r\n <select class=\"form-select col-auto\" formControlName=\"siteId\" (change)=\"siteIdChange()\">\r\n <ng-container *ngFor=\"let item of siteList\">\r\n <option [value]=\"item.id\">{{item.displayName}}</option>\r\n </ng-container>\r\n </select>\r\n </div>\r\n <div class=\"mb-2 col-4\">\r\n <label class=\"form-label\">{{'Cms::Sections' | abpLocalization}}\uFF1A</label>\r\n <select class=\"form-select col-auto\" formControlName=\"sectionId\" (change)=\"sectionIdChange()\">\r\n <ng-container *ngFor=\"let item of SiteOfSectionList\">\r\n <option [value]=\"item.id\">{{item.displayName}}</option>\r\n </ng-container>\r\n </select>\r\n </div>\r\n <div class=\"mb-2 col-4\">\r\n <label class=\"form-label\">{{'AbpUi::Languages' | abpLocalization}}\uFF1A</label>\r\n <select class=\"form-select col-auto\" formControlName=\"culture\" (change)=\"cultureChange()\">\r\n <ng-container *ngFor=\"let item of sectionLanguagesList\">\r\n <option [value]=\"item.cultureName\">{{item.displayName}}</option>\r\n </ng-container>\r\n </select>\r\n </div>\r\n </div>\r\n <div class=\"input-group\">\r\n <input type=\"text\" class=\"form-control\" formControlName=\"filter\"\r\n [placeholder]=\"'AbpUi::Search' | abpLocalization\" />\r\n <button class=\"btn btn-primary px-3\" type=\"button\" id=\"button-addon2\" (click)=\"resetData()\">\r\n <i class=\"fa fa-search\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"card mb-0\">\r\n <div class=\"card-body p-0\">\r\n <div class=\"table-responsive table-fixed-header\">\r\n <ngx-datatable class=\"material container-height\" [rows]=\"data.items\" [list]=\"list\"\r\n [columnMode]=\"'force'\" [headerHeight]=\"50\" [footerHeight]=\"50\" rowHeight=\"auto\"\r\n [virtualization]=\"false\" [externalPaging]=\"true\" [count]=\"data.totalCount\">\r\n <ngx-datatable-column [name]=\"'Cms::EntryType' | abpLocalization\" prop=\"entryTypeId\">\r\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n <ng-container *ngFor=\"let item of entryTypeList\">\r\n <ng-container *ngIf=\"item.id === value\">{{item.displayName}}</ng-container>\r\n </ng-container>\r\n </ng-template>\r\n </ngx-datatable-column>\r\n <ngx-datatable-column [name]=\"'Cms::Title' | abpLocalization\" prop=\"title\">\r\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n {{ value }}\r\n </ng-template>\r\n </ngx-datatable-column>\r\n <ngx-datatable-column [name]=\"'Cms::Slug' | abpLocalization\" prop=\"slug\">\r\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n {{ value }}\r\n </ng-template>\r\n </ngx-datatable-column>\r\n <ngx-datatable-column [name]=\"'Cms::Status' | abpLocalization\" prop=\"status\">\r\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n <ng-container *ngFor=\"let item of _entryStatusOptions\">\r\n <ng-container *ngIf=\"item.value=== value\">{{ 'Cms::Enum:EntryStatus:'+item.key |\r\n abpLocalization }}</ng-container>\r\n </ng-container>\r\n </ng-template>\r\n </ngx-datatable-column>\r\n <ngx-datatable-column [name]=\"'Cms::PublishTime' | abpLocalization\" prop=\"publishTime\">\r\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n {{value | date: 'YYYY/MM/dd HH:mm:s' }}\r\n </ng-template>\r\n </ngx-datatable-column>\r\n <ngx-datatable-column [sortable]=\"false\">\r\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n <div ngbDropdown container=\"body\">\r\n <button type=\"button\" class=\"btn btn-outline-primary btn-sm\" ngbDropdownToggle>\r\n {{'AbpUi::Actions' | abpLocalization}}\r\n </button>\r\n <div ngbDropdownMenu>\r\n <button ngbDropdownItem\r\n routerLink=\"/cms/admin/entries/{{row.id}}/edit\">{{'AbpUi::Edit' |\r\n abpLocalization}}</button>\r\n <button ngbDropdownItem (click)=\"deletefield(row)\">{{'AbpUi::Delete' |\r\n abpLocalization}}</button>\r\n </div>\r\n </div>\r\n </ng-template>\r\n </ngx-datatable-column>\r\n </ngx-datatable>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</abp-page>", styles: ["::ng-deep .sites-page .dignite_page{background:transparent}::ng-deep .sites-page .list-group-flush>.list-group-item:first-child{border-top-width:var(--bs-list-group-border-width)}::ng-deep .sites-page .card-header input{flex:2 1 auto}::ng-deep .sites-page .card-header .form-select{padding:.475rem 3.75rem .475rem 1.25rem}::ng-deep .sites-page .morentr{border:2px solid transparent}::ng-deep .sites-page .borderdrag{border:2px solid var(--ck-color-selector-column-resizer-hover)!important}::ng-deep .sites-page .borderdragtd{background-color:var(--ck-color-selector-column-resizer-hover)!important}::ng-deep .sites-page .testtr{border-color:transparent}::ng-deep .sites-page .testtr td{padding:2px}::ng-deep .sites-page .testtr:hover{background-color:transparent}.cdk-drag-preview{display:table;box-sizing:border-box;border-radius:4px;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.cdk-drag-placeholder{opacity:0}.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.example-box:last-child{border:0}.example-list.cdk-drop-list-dragging .example-box:not(.cdk-drag-placeholder){transition:transform .25s cubic-bezier(0,0,.2,1)}::ng-deep .sites-modal-form .form-control{padding:.4rem 1.25rem}\n"] }]
|
|
209
|
+
}], ctorParameters: function () { return [{ type: i1.EntryAdminService }, { type: i2.SiteAdminService }, { type: i3.SectionAdminService }, { type: i4.ToasterService }, { type: i4.ConfirmationService }, { type: i5.ConfigStateService }, { type: i6.Router }, { type: i5.LocalizationService }]; } });
|
|
210
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entries.component.js","sourceRoot":"","sources":["../../../../../../../projects/cms/src/lib/components/admin/entries/entries.component.ts","../../../../../../../projects/cms/src/lib/components/admin/entries/entries.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ABP, ConfigStateService, LIST_QUERY_DEBOUNCE_TIME, ListService, LocalizationService, PagedResultDto } from '@abp/ng.core';\nimport { ToasterService, ConfirmationService, Confirmation } from '@abp/ng.theme.shared';\nimport { Component, OnInit, inject } from '@angular/core';\nimport { FormBuilder, FormGroup } from '@angular/forms';\nimport { EntryAdminService, EntryDto, GetEntriesInput } from '../../../proxy/admin/entries';\nimport { ColumnMode } from \"@swimlane/ngx-datatable\";\nimport { finalize } from 'rxjs/operators';\nimport { SiteAdminService } from '../../../proxy/admin/sites';\nimport { SectionAdminService } from '../../../proxy/admin/sections';\nimport { entryStatusOptions } from '../../../proxy/entries';\nimport { EXTENSIONS_IDENTIFIER } from '@abp/ng.theme.shared/extensions';\nimport { ECmsComponent } from '../../../enums/ecms-component';\nimport { Router } from '@angular/router';\nimport { UpdateListService } from '../../../services/update-list.service';\n\n\n@Component({\n  selector: 'cms-entries',\n  templateUrl: './entries.component.html',\n  styleUrls: ['./entries.component.scss'],\n  providers: [\n    ListService,\n    // Provide this token if you want a different debounce time.\n    // Default is 300. Cannot be 0. Any value below 100 is not recommended.\n    { provide: LIST_QUERY_DEBOUNCE_TIME, useValue: 500 },\n    {\n      provide: EXTENSIONS_IDENTIFIER,\n      useValue: ECmsComponent.Entries,\n    },\n  ]\n})\nexport class EntriesComponent implements OnInit {\n  \n  constructor(\n    private _EntryAdminService: EntryAdminService,\n    private _SiteAdminService: SiteAdminService,\n    private _SectionAdminService: SectionAdminService,\n    private toaster: ToasterService,\n    private confirmation: ConfirmationService,\n    private configState: ConfigStateService,\n    private router: Router,\n    private _LocalizationService: LocalizationService,\n  ) {\n  }\n\n  private fb=inject(FormBuilder)\n  private _UpdateListService=inject(UpdateListService)\n  public readonly list=inject(ListService)\n\n\n  ngOnInit(): void {\n    this.getPageDate()\n    this._UpdateListService.updateListEvent.subscribe(() => {\n      this.list.get()\n    });\n  }\n\n  /**站点列表 */\n  siteList: any[any] = []\n  /**选择的站点id */\n  siteId: string = ''\n  /**站点下的版块 */\n  SiteOfSectionList: any[any] = []\n\n\n  /**版块下的语言列表 */\n  sectionLanguagesList: any[any] = []\n  /**版块下的条目类型列表 */\n  entryTypeList: any[any] = []\n  /**状态编码 */\n  _entryStatusOptions = entryStatusOptions\n\n  /**获取页面数据 */\n  async getPageDate() {\n    await this.getsiteList()\n    await this.getSiteOfSectionList()\n    await this.getSectionLanguagesList()\n    this.filters=this.filtersForm.value\n    this.hookToQuery()\n  }\n\n  /**切换站点 */\n  async siteIdChange() {\n    await this.getSiteOfSectionList()\n    await this.getSectionLanguagesList()\n    this.resetData()\n  }\n  /**切换板块 */\n  async sectionIdChange() {\n    this.getSectionOfEntryType()\n    await this.getSectionLanguagesList()\n    this.resetData()\n  }\n  /**切换语言 */\n  async cultureChange() {\n    this.resetData()\n  }\n  /**获取站点列表 */\n  getsiteList() {\n    return new Promise((resolve, rejects) => {\n      this._SiteAdminService.getList({}).subscribe(res => {\n        this.siteList = res.items\n        this.filtersForm.get('siteId').patchValue(res.items[0]?.id || '')\n        resolve(res.items)\n      })\n    })\n  }\n\n  /**获取站点下的版块 */\n  getSiteOfSectionList() {\n    return new Promise((resolve, rejects) => {\n      let siteId = this.filtersForm.get('siteId').value\n      this._SectionAdminService.getList({\n        maxResultCount: 1000,\n        siteId: siteId\n      }).subscribe(res => {\n        this.SiteOfSectionList = res.items\n        this.filtersForm.get('sectionId').patchValue(res.items[0]?.id || '')\n        this.getSectionOfEntryType()\n        resolve(res.items)\n      })\n    })\n  }\n\n  /**获取版块下的条目类型 */\n  getSectionOfEntryType() {\n    let sectionId = this.filtersForm.get('sectionId').value\n    this.entryTypeList = this.SiteOfSectionList.find(el => el.id == sectionId)?.entryTypes || []\n  }\n\n  /**获取版块下的语言列表 */\n  getSectionLanguagesList() {\n    return new Promise((resolve, rejects) => {\n  \n      //获取所有语言 */\n      let languages = this.configState.getDeep('localization.languages')\n      //当前选择的板块id\n      let sectionId = this.filtersForm.get('sectionId').value\n      //板块下的语言\n      let sectionOfLanguages = this.SiteOfSectionList.find(el => el.id == sectionId)?.site?.languages || []\n      //获取系统语言 */\n      let systemculture=this.configState.getDeep('localization.currentCulture.name')\n      //获取当前选择的语言\n      let nowculture=this.filtersForm.get('culture').value\n      //当前选择的语言，是否在版块的的语言列表中\n      let isexist=  sectionOfLanguages.find(el=>el.cultureName==nowculture)\n      this.filtersForm.get('culture').patchValue(nowculture?isexist?nowculture:systemculture:systemculture)\n      this.sectionLanguagesList = languages.filter(el => sectionOfLanguages.find(ell => ell.cultureName === el.cultureName))\n      resolve(sectionOfLanguages)\n    })\n  }\n\n\n\n    resetData() {\n      this.filters=this.filtersForm.value\n      this.list.page = 0\n      this.data.items = []\n      this.list.get()\n    }\n\n  /**新增-单个 */\n  createEntriesBtn() {\n    this.router.navigate(['/cms/admin/entries/create'], {\n      queryParams: { cultureName: this.filters.culture, sectionId: this.filters.sectionId, entryTypeId: this.entryTypeList[0].id }\n    })\n  }\n\n  /**列表相关 */\n  ColumnMode = ColumnMode;\n  data: PagedResultDto<EntryDto> = {\n    items: [],\n    totalCount: 0,\n  };\n\n  filters = {} as GetEntriesInput;\n  filtersForm: FormGroup = this.fb.group({\n    siteId: [''],\n    sectionId: [''],\n    culture: [''],\n    filter: [''],\n  })\n\n  hookToQuery() {\n    \n    const getData = (query: ABP.PageQueryParams) => this._EntryAdminService.getList({\n      ...query,\n      ...this.filters,\n    });\n    const setData = (list: PagedResultDto<EntryDto>) => {\n      this.data = list\n    };\n    this.list.hookToQuery(getData).subscribe(setData);\n  }\n\n\n  /**删除条目 */\n  deletefield(row: any) {\n    this.confirmation.warn(\n      row.displayName,\n      this._LocalizationService.instant(`AbpUi::ItemWillBeDeletedMessage`),\n    ).subscribe((status: Confirmation.Status) => {\n      if (status == 'confirm') {\n        this._EntryAdminService.delete(row.id).pipe(finalize(() => {\n        })).subscribe(res => {\n          this.toaster.success(this._LocalizationService.instant(`AbpUi::SuccessfullyDeleted`));\n          this.list.get()\n        })\n      }\n\n    });\n  }\n\n\n}\n","<abp-page [title]=\"'Cms::Entries' | abpLocalization\" [toolbar]=\"true\">\r\n    <abp-page-toolbar-container *ngIf=\"entryTypeList.length < 1\" class=\"col \"></abp-page-toolbar-container>\r\n    <abp-page-toolbar-container *ngIf=\"entryTypeList.length > 1\" class=\"col \">\r\n        <div class=\"row justify-content-end mx-0 gap-2\" *abpPermission=\"'CmsAdmin.Entry.Create'\">\r\n            <div class=\"col-auto px-0 pt-0\">\r\n                <div ngbDropdown class=\"d-inline-block\">\r\n                    <button type=\"button\" class=\"btn btn-primary btn-sm ms-2\" id=\"dropdownBasic1\" ngbDropdownToggle>\r\n                        <i class=\"fa fa-plus pe-1\" aria-hidden=\"true\"></i>{{'Cms::New' | abpLocalization}}\r\n                    </button>\r\n                    <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\">\r\n                        <ng-container *ngFor=\"let item of entryTypeList\">\r\n                            <button ngbDropdownItem [routerLink]=\"['/cms/admin/entries/create']\"\r\n                                [queryParams]=\"{cultureName: filters.culture,sectionId:filters.sectionId,entryTypeId:item.id}\">{{item.displayName}}</button>\r\n                        </ng-container>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </abp-page-toolbar-container>\r\n    <div id=\"sites-page\" class=\"sites-page\">\r\n        <div class=\"card\">\r\n            <div class=\"card-body px-2 py-sm-2 border-bottom\" [formGroup]=\"filtersForm\">\r\n                <div class=\"row align-items-start\">\r\n                    <div class=\"mb-2 col-4\">\r\n                        <label class=\"form-label\">{{'Cms::Sites' | abpLocalization}}：</label>\r\n                        <select class=\"form-select col-auto\" formControlName=\"siteId\" (change)=\"siteIdChange()\">\r\n                            <ng-container *ngFor=\"let item of siteList\">\r\n                                <option [value]=\"item.id\">{{item.displayName}}</option>\r\n                            </ng-container>\r\n                        </select>\r\n                    </div>\r\n                    <div class=\"mb-2 col-4\">\r\n                        <label class=\"form-label\">{{'Cms::Sections' | abpLocalization}}：</label>\r\n                        <select class=\"form-select col-auto\" formControlName=\"sectionId\" (change)=\"sectionIdChange()\">\r\n                            <ng-container *ngFor=\"let item of SiteOfSectionList\">\r\n                                <option [value]=\"item.id\">{{item.displayName}}</option>\r\n                            </ng-container>\r\n                        </select>\r\n                    </div>\r\n                    <div class=\"mb-2 col-4\">\r\n                        <label class=\"form-label\">{{'AbpUi::Languages' | abpLocalization}}：</label>\r\n                        <select class=\"form-select col-auto\" formControlName=\"culture\" (change)=\"cultureChange()\">\r\n                            <ng-container *ngFor=\"let item of sectionLanguagesList\">\r\n                                <option [value]=\"item.cultureName\">{{item.displayName}}</option>\r\n                            </ng-container>\r\n                        </select>\r\n                    </div>\r\n                </div>\r\n                <div class=\"input-group\">\r\n                    <input type=\"text\" class=\"form-control\" formControlName=\"filter\"\r\n                        [placeholder]=\"'AbpUi::Search' | abpLocalization\" />\r\n                    <button class=\"btn btn-primary px-3\" type=\"button\" id=\"button-addon2\" (click)=\"resetData()\">\r\n                        <i class=\"fa fa-search\"></i>\r\n                    </button>\r\n                </div>\r\n            </div>\r\n        </div>\r\n        <div class=\"card mb-0\">\r\n            <div class=\"card-body p-0\">\r\n                <div class=\"table-responsive table-fixed-header\">\r\n                    <ngx-datatable class=\"material container-height\" [rows]=\"data.items\" [list]=\"list\"\r\n                        [columnMode]=\"'force'\" [headerHeight]=\"50\" [footerHeight]=\"50\" rowHeight=\"auto\"\r\n                        [virtualization]=\"false\" [externalPaging]=\"true\" [count]=\"data.totalCount\">\r\n                        <ngx-datatable-column [name]=\"'Cms::EntryType' | abpLocalization\" prop=\"entryTypeId\">\r\n                            <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n                                <ng-container *ngFor=\"let item of entryTypeList\">\r\n                                    <ng-container *ngIf=\"item.id === value\">{{item.displayName}}</ng-container>\r\n                                </ng-container>\r\n                            </ng-template>\r\n                        </ngx-datatable-column>\r\n                        <ngx-datatable-column [name]=\"'Cms::Title' | abpLocalization\" prop=\"title\">\r\n                            <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n                                {{ value }}\r\n                            </ng-template>\r\n                        </ngx-datatable-column>\r\n                        <ngx-datatable-column [name]=\"'Cms::Slug' | abpLocalization\" prop=\"slug\">\r\n                            <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n                                {{ value }}\r\n                            </ng-template>\r\n                        </ngx-datatable-column>\r\n                        <ngx-datatable-column [name]=\"'Cms::Status' | abpLocalization\" prop=\"status\">\r\n                            <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n                                <ng-container *ngFor=\"let item of _entryStatusOptions\">\r\n                                    <ng-container *ngIf=\"item.value=== value\">{{ 'Cms::Enum:EntryStatus:'+item.key |\r\n                                        abpLocalization }}</ng-container>\r\n                                </ng-container>\r\n                            </ng-template>\r\n                        </ngx-datatable-column>\r\n                        <ngx-datatable-column [name]=\"'Cms::PublishTime' | abpLocalization\" prop=\"publishTime\">\r\n                            <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n                                {{value | date: 'YYYY/MM/dd HH:mm:s' }}\r\n                            </ng-template>\r\n                        </ngx-datatable-column>\r\n                        <ngx-datatable-column [sortable]=\"false\">\r\n                            <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n                                <div ngbDropdown container=\"body\">\r\n                                    <button type=\"button\" class=\"btn btn-outline-primary btn-sm\" ngbDropdownToggle>\r\n                                        {{'AbpUi::Actions' | abpLocalization}}\r\n                                    </button>\r\n                                    <div ngbDropdownMenu>\r\n                                        <button ngbDropdownItem\r\n                                            routerLink=\"/cms/admin/entries/{{row.id}}/edit\">{{'AbpUi::Edit' |\r\n                                            abpLocalization}}</button>\r\n                                        <button ngbDropdownItem (click)=\"deletefield(row)\">{{'AbpUi::Delete' |\r\n                                            abpLocalization}}</button>\r\n                                    </div>\r\n                                </div>\r\n                            </ng-template>\r\n                        </ngx-datatable-column>\r\n                    </ngx-datatable>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</abp-page>"]}
|
|
@@ -2,4 +2,4 @@ export * from './entries.component';
|
|
|
2
2
|
export * from './create.component';
|
|
3
3
|
export * from './edit.component';
|
|
4
4
|
export * from './create-or-edit-entries.component';
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jbXMvc3JjL2xpYi9jb21wb25lbnRzL2FkbWluL2VudHJpZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxxQkFBcUIsQ0FBQTtBQUNuQyxjQUFjLG9CQUFvQixDQUFBO0FBQ2xDLGNBQWMsa0JBQWtCLENBQUE7QUFDaEMsY0FBYyxvQ0FBb0MsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZW50cmllcy5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vY3JlYXRlLmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9lZGl0LmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9jcmVhdGUtb3ItZWRpdC1lbnRyaWVzLmNvbXBvbmVudCciXX0=
|