@dignite-ng/expand.cms 2.0.0-rc.9 → 3.0.0-rc.15
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/lib/cms.module.mjs +35 -5
- package/esm2022/lib/components/admin/entries/create-or-edit-entries.component.mjs +62 -6
- package/esm2022/lib/components/admin/entries/edit.component.mjs +2 -1
- package/esm2022/lib/components/admin/entries/entries.component.mjs +236 -49
- package/esm2022/lib/components/admin/fields/create-or-edit-field.component.mjs +4 -7
- package/esm2022/lib/components/admin/sections/entry-types/create-or-edit.-entry-type-input-base.mjs +5 -29
- package/esm2022/lib/components/admin/sections/entry-types/create-or-edit.component.mjs +40 -23
- package/esm2022/lib/components/dynamic-form/entry/entry-control.component.mjs +15 -5
- package/esm2022/lib/components/dynamic-form/entry/entry-search.component.mjs +107 -0
- package/esm2022/lib/components/dynamic-form/entry/entry-view.component.mjs +60 -0
- package/esm2022/lib/components/dynamic-form/entry/index.mjs +3 -1
- package/esm2022/lib/components/dynamic-form/form-control-group.mjs +9 -1
- package/esm2022/lib/components/dynamic-form/matrix/index.mjs +2 -1
- package/esm2022/lib/components/dynamic-form/matrix/matrix-view.component.mjs +40 -0
- package/esm2022/lib/components/dynamic-form/table/index.mjs +2 -1
- package/esm2022/lib/components/dynamic-form/table/table-config.component.mjs +5 -5
- package/esm2022/lib/components/dynamic-form/table/table-config.mjs +2 -9
- package/esm2022/lib/components/dynamic-form/table/table-view.component.mjs +40 -0
- package/esm2022/lib/proxy/dignite/cms/admin/dynamic-forms/form-admin.service.mjs +2 -2
- package/esm2022/lib/proxy/dignite/cms/admin/dynamic-forms/models.mjs +1 -1
- package/esm2022/lib/proxy/dignite/cms/admin/entries/entry-admin.service.mjs +2 -2
- package/esm2022/lib/proxy/dignite/cms/admin/entries/models.mjs +1 -1
- package/esm2022/lib/proxy/dignite/cms/admin/fields/models.mjs +1 -1
- package/esm2022/lib/proxy/dignite/cms/admin/sections/models.mjs +1 -1
- package/esm2022/lib/proxy/dignite/cms/sections/models.mjs +1 -1
- package/esm2022/lib/services/field-abstracts.service.mjs +3 -3
- package/esm2022/lib/services/form-controls.service.mjs +40 -0
- package/fesm2022/dignite-ng-expand.cms.mjs +778 -256
- package/fesm2022/dignite-ng-expand.cms.mjs.map +1 -1
- package/lib/cms.module.d.ts +16 -10
- package/lib/components/admin/entries/create-or-edit-entries.component.d.ts +5 -1
- package/lib/components/admin/entries/entries.component.d.ts +50 -12
- package/lib/components/admin/fields/create-or-edit-field.component.d.ts +1 -2
- package/lib/components/admin/sections/entry-types/create-or-edit.-entry-type-input-base.d.ts +4 -14
- package/lib/components/admin/sections/entry-types/create-or-edit.component.d.ts +17 -9
- package/lib/components/dynamic-form/entry/entry-control.component.d.ts +5 -2
- package/lib/components/dynamic-form/entry/entry-search.component.d.ts +36 -0
- package/lib/components/dynamic-form/entry/entry-view.component.d.ts +22 -0
- package/lib/components/dynamic-form/entry/index.d.ts +2 -0
- package/lib/components/dynamic-form/matrix/index.d.ts +1 -0
- package/lib/components/dynamic-form/matrix/matrix-view.component.d.ts +17 -0
- package/lib/components/dynamic-form/table/index.d.ts +1 -0
- package/lib/components/dynamic-form/table/table-config.d.ts +1 -1
- package/lib/components/dynamic-form/table/table-view.component.d.ts +17 -0
- package/lib/proxy/dignite/cms/admin/dynamic-forms/models.d.ts +1 -0
- package/lib/proxy/dignite/cms/admin/entries/models.d.ts +1 -0
- package/lib/proxy/dignite/cms/admin/fields/models.d.ts +2 -2
- package/lib/proxy/dignite/cms/admin/sections/models.d.ts +2 -1
- package/lib/proxy/dignite/cms/sections/models.d.ts +2 -1
- package/lib/services/form-controls.service.d.ts +16 -0
- package/package.json +1 -1
|
@@ -1,27 +1,34 @@
|
|
|
1
|
-
import { EXTENSIONS_IDENTIFIER } from
|
|
2
|
-
import { ListService, LIST_QUERY_DEBOUNCE_TIME, ConfigStateService } from
|
|
3
|
-
import { Component, inject } from
|
|
4
|
-
import { FormBuilder } from
|
|
5
|
-
import { ColumnMode } from
|
|
6
|
-
import { finalize } from
|
|
7
|
-
import { ECmsComponent } from
|
|
8
|
-
import { UpdateListService } from
|
|
9
|
-
import { entryStatusOptions } from
|
|
10
|
-
import { RegionalizationService } from
|
|
1
|
+
import { EXTENSIONS_IDENTIFIER } from '@abp/ng.components/extensible';
|
|
2
|
+
import { ListService, LIST_QUERY_DEBOUNCE_TIME, ConfigStateService, } from '@abp/ng.core';
|
|
3
|
+
import { Component, inject } from '@angular/core';
|
|
4
|
+
import { FormBuilder } from '@angular/forms';
|
|
5
|
+
import { ColumnMode } from '@swimlane/ngx-datatable';
|
|
6
|
+
import { finalize } from 'rxjs';
|
|
7
|
+
import { ECmsComponent } from '../../../enums';
|
|
8
|
+
import { UpdateListService } from '@dignite-ng/expand.core';
|
|
9
|
+
import { entryStatusOptions } from '../../../proxy/dignite/cms/entries';
|
|
10
|
+
import { RegionalizationService } from '../../../proxy/dignite/abp/regionalization-management';
|
|
11
|
+
import { SectionType } from '../../../proxy/dignite/cms/sections';
|
|
12
|
+
import { moveItemInArray } from '@angular/cdk/drag-drop';
|
|
11
13
|
import * as i0 from "@angular/core";
|
|
12
14
|
import * as i1 from "../../../proxy/dignite/cms/admin/entries";
|
|
13
15
|
import * as i2 from "../../../proxy/dignite/cms/admin/sections";
|
|
14
16
|
import * as i3 from "@abp/ng.theme.shared";
|
|
15
17
|
import * as i4 from "@abp/ng.core";
|
|
16
18
|
import * as i5 from "@angular/router";
|
|
17
|
-
import * as i6 from "
|
|
18
|
-
import * as i7 from "
|
|
19
|
-
import * as i8 from "
|
|
20
|
-
import * as i9 from "@
|
|
21
|
-
import * as i10 from "@
|
|
22
|
-
import * as i11 from "@
|
|
19
|
+
import * as i6 from "../../../proxy/dignite/cms/admin/dynamic-forms";
|
|
20
|
+
import * as i7 from "../../../proxy/dignite/cms/admin/fields";
|
|
21
|
+
import * as i8 from "../../../services/form-controls.service";
|
|
22
|
+
import * as i9 from "@angular/common";
|
|
23
|
+
import * as i10 from "@angular/forms";
|
|
24
|
+
import * as i11 from "@swimlane/ngx-datatable";
|
|
25
|
+
import * as i12 from "@ngx-validate/core";
|
|
26
|
+
import * as i13 from "@ng-bootstrap/ng-bootstrap";
|
|
27
|
+
import * as i14 from "@abp/ng.components/page";
|
|
28
|
+
import * as i15 from "@dignite-ng/expand.dynamic-form";
|
|
29
|
+
import * as i16 from "@angular/cdk/drag-drop";
|
|
23
30
|
export class EntriesComponent {
|
|
24
|
-
constructor(_EntryAdminService, _SectionAdminService, toaster, confirmation, configState, router, _LocalizationService) {
|
|
31
|
+
constructor(_EntryAdminService, _SectionAdminService, toaster, confirmation, configState, router, _LocalizationService, _FormAdminService, _FieldAdminService, cdRef, _FormControlsService) {
|
|
25
32
|
this._EntryAdminService = _EntryAdminService;
|
|
26
33
|
this._SectionAdminService = _SectionAdminService;
|
|
27
34
|
this.toaster = toaster;
|
|
@@ -29,9 +36,15 @@ export class EntriesComponent {
|
|
|
29
36
|
this.configState = configState;
|
|
30
37
|
this.router = router;
|
|
31
38
|
this._LocalizationService = _LocalizationService;
|
|
39
|
+
this._FormAdminService = _FormAdminService;
|
|
40
|
+
this._FieldAdminService = _FieldAdminService;
|
|
41
|
+
this.cdRef = cdRef;
|
|
42
|
+
this._FormControlsService = _FormControlsService;
|
|
32
43
|
this.fb = inject(FormBuilder);
|
|
33
44
|
this._UpdateListService = inject(UpdateListService);
|
|
34
|
-
this.list = inject(ListService);
|
|
45
|
+
this.list = inject((ListService));
|
|
46
|
+
/**板块类型 */
|
|
47
|
+
this.SectionType = SectionType;
|
|
35
48
|
/**站点下的版块 */
|
|
36
49
|
this.SiteOfSectionList = [];
|
|
37
50
|
/**版块下的语言列表 */
|
|
@@ -40,10 +53,26 @@ export class EntriesComponent {
|
|
|
40
53
|
this.entryTypeList = [];
|
|
41
54
|
/**状态编码 */
|
|
42
55
|
this._entryStatusOptions = entryStatusOptions;
|
|
56
|
+
/**需要查询的动态表单类型 */
|
|
57
|
+
this.enableSearchTypeList = [];
|
|
58
|
+
/**需要查询的动态表单字段 */
|
|
59
|
+
this.enableSearchFieldList = [];
|
|
60
|
+
/**不需要展示的动态表单类型 */
|
|
61
|
+
this.disableshowinTypeList = [];
|
|
62
|
+
/**需要展示的动态列表字段 */
|
|
63
|
+
this.showinFieldList = [];
|
|
64
|
+
/**表单 */
|
|
65
|
+
this.enablegearchFormEntity = this.fb.group({
|
|
66
|
+
extraProperties: this.fb.group({}),
|
|
67
|
+
});
|
|
68
|
+
/**站点下板块的类型 */
|
|
69
|
+
this.SiteOfSectionType = SectionType.Single;
|
|
43
70
|
this.config = inject(ConfigStateService);
|
|
44
71
|
this._RegionalizationService = inject(RegionalizationService);
|
|
45
72
|
/**站点设置语言 */
|
|
46
73
|
this.SiteSettingsAdminLanguages = [];
|
|
74
|
+
/**站点设置的默认语言 */
|
|
75
|
+
this.defaultCultureName = '';
|
|
47
76
|
/**列表相关 */
|
|
48
77
|
this.ColumnMode = ColumnMode;
|
|
49
78
|
this.data = {
|
|
@@ -51,12 +80,8 @@ export class EntriesComponent {
|
|
|
51
80
|
totalCount: 0,
|
|
52
81
|
};
|
|
53
82
|
this.filters = {};
|
|
54
|
-
this.
|
|
55
|
-
|
|
56
|
-
sectionId: [''],
|
|
57
|
-
culture: [''],
|
|
58
|
-
filter: [''],
|
|
59
|
-
});
|
|
83
|
+
this.maxResultCount = 10;
|
|
84
|
+
this.isexpanded = false;
|
|
60
85
|
}
|
|
61
86
|
ngOnInit() {
|
|
62
87
|
this.getPageDate();
|
|
@@ -66,11 +91,23 @@ export class EntriesComponent {
|
|
|
66
91
|
}
|
|
67
92
|
/**获取页面数据 */
|
|
68
93
|
async getPageDate() {
|
|
94
|
+
// await this.getDynamicFormType();
|
|
95
|
+
this.enableSearchTypeList = await this._FormControlsService.getEnableSearchTypeList();
|
|
96
|
+
// this.disableshowinTypeList= this._FormControlsService.getdisableshowinTypeList();
|
|
69
97
|
await this.getSiteOfSectionList();
|
|
70
98
|
await this.getSectionLanguagesList();
|
|
71
|
-
this.filters = this.filtersForm.value;
|
|
72
99
|
this.hookToQuery();
|
|
73
100
|
}
|
|
101
|
+
/**获取动态表单类型 */
|
|
102
|
+
// getDynamicFormType() {
|
|
103
|
+
// return new Promise((resolve, rejects) => {
|
|
104
|
+
// this._FormAdminService.getFormControls().subscribe((res:any) => {
|
|
105
|
+
// // this.dynamicFormTypeList = res.items;
|
|
106
|
+
// this.enableSearchTypeList = res.items.filter(el => el.enableSearch).map(el => el.name);
|
|
107
|
+
// resolve(res.items);
|
|
108
|
+
// });
|
|
109
|
+
// });
|
|
110
|
+
// }
|
|
74
111
|
/**切换板块 */
|
|
75
112
|
async sectionIdChange() {
|
|
76
113
|
this.getSectionOfEntryType();
|
|
@@ -84,20 +121,112 @@ export class EntriesComponent {
|
|
|
84
121
|
/**获取站点下的版块 */
|
|
85
122
|
getSiteOfSectionList() {
|
|
86
123
|
return new Promise((resolve, rejects) => {
|
|
87
|
-
this._SectionAdminService
|
|
124
|
+
this._SectionAdminService
|
|
125
|
+
.getList({
|
|
88
126
|
maxResultCount: 1000,
|
|
89
|
-
})
|
|
127
|
+
})
|
|
128
|
+
.subscribe(async (res) => {
|
|
90
129
|
this.SiteOfSectionList = res.items;
|
|
91
|
-
this.
|
|
92
|
-
this.getSectionOfEntryType();
|
|
130
|
+
this.filters.sectionId = res.items[0]?.id || '';
|
|
131
|
+
await this.getSectionOfEntryType();
|
|
93
132
|
resolve(res.items);
|
|
94
133
|
});
|
|
95
134
|
});
|
|
96
135
|
}
|
|
136
|
+
get extraPropertiesInput() {
|
|
137
|
+
return this.enablegearchFormEntity?.get('extraProperties');
|
|
138
|
+
}
|
|
139
|
+
/**设置筛选条件 */
|
|
140
|
+
setfiltersValue() {
|
|
141
|
+
return new Promise((resolve, rejects) => {
|
|
142
|
+
let extraProperties = this.extraPropertiesInput.value;
|
|
143
|
+
let inputs = [];
|
|
144
|
+
for (const key in extraProperties) {
|
|
145
|
+
const element = extraProperties[key];
|
|
146
|
+
if (Array.isArray(element) ? (element.length > 0 ? element : null) : element) {
|
|
147
|
+
inputs.push({
|
|
148
|
+
name: key,
|
|
149
|
+
value: element === true ? 'True' : Array.isArray(element) ? element.join(',') : element,
|
|
150
|
+
});
|
|
151
|
+
}
|
|
152
|
+
if (element === false) {
|
|
153
|
+
inputs.push({
|
|
154
|
+
name: key,
|
|
155
|
+
value: 'False',
|
|
156
|
+
});
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
this.filters.queryingByFieldsJson = inputs.length > 0 ? JSON.stringify(inputs) : '';
|
|
160
|
+
resolve(true);
|
|
161
|
+
});
|
|
162
|
+
}
|
|
163
|
+
async listget() {
|
|
164
|
+
await this.setfiltersValue();
|
|
165
|
+
this.list.get();
|
|
166
|
+
// this.filters.
|
|
167
|
+
}
|
|
97
168
|
/**获取版块下的条目类型 */
|
|
98
|
-
getSectionOfEntryType() {
|
|
99
|
-
let sectionId = this.filtersForm.get('sectionId').value;
|
|
100
|
-
|
|
169
|
+
async getSectionOfEntryType() {
|
|
170
|
+
// let sectionId = this.filtersForm.get('sectionId').value;
|
|
171
|
+
let sectionId = this.filters.sectionId;
|
|
172
|
+
let SectionInfo = await this.getSectionInfo(sectionId);
|
|
173
|
+
let _entryTypeList = SectionInfo?.entryTypes || [];
|
|
174
|
+
// let _entryTypeList = this.SiteOfSectionList.find(el => el.id == sectionId)?.entryTypes || [];
|
|
175
|
+
this.entryTypeList = _entryTypeList;
|
|
176
|
+
//选择板块的类型SectionType
|
|
177
|
+
this.SiteOfSectionType = this.SiteOfSectionList.find(el => el.id == sectionId)?.type;
|
|
178
|
+
if (this.SiteOfSectionType == SectionType.Structure) {
|
|
179
|
+
this.maxResultCount = 1000;
|
|
180
|
+
}
|
|
181
|
+
else {
|
|
182
|
+
this.maxResultCount = 10;
|
|
183
|
+
}
|
|
184
|
+
if (_entryTypeList.length === 1) {
|
|
185
|
+
this.filters.entryTypeId = this.entryTypeList[0].id;
|
|
186
|
+
// 初始化数组
|
|
187
|
+
this.enableSearchFieldList = [];
|
|
188
|
+
this.showinFieldList = [];
|
|
189
|
+
// 使用for...of替代forEach来处理异步
|
|
190
|
+
for (const el of _entryTypeList) {
|
|
191
|
+
for (const el1 of el.fieldTabs) {
|
|
192
|
+
for (const el2 of el1.fields) {
|
|
193
|
+
// el2.field = await this.getDynamicFormEntity(el2.fieldId);
|
|
194
|
+
if (el2.enableSearch && this.enableSearchTypeList.includes(el2.field.formControlName)) {
|
|
195
|
+
this.enableSearchFieldList.push({
|
|
196
|
+
...el2,
|
|
197
|
+
field: {
|
|
198
|
+
formControlName: el2.field.formControlName,
|
|
199
|
+
formConfiguration: el2.field.formConfiguration,
|
|
200
|
+
name: el2.field.name,
|
|
201
|
+
},
|
|
202
|
+
});
|
|
203
|
+
}
|
|
204
|
+
if (el2.showInList && !this.disableshowinTypeList.includes(el2.field.formControlName)) {
|
|
205
|
+
this.showinFieldList.push(el2);
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
async abpInitss() {
|
|
213
|
+
await this.setfiltersValue();
|
|
214
|
+
}
|
|
215
|
+
/**获取板块详情 */
|
|
216
|
+
getSectionInfo(ids) {
|
|
217
|
+
return new Promise((resolve, rejects) => {
|
|
218
|
+
this._SectionAdminService.get(ids).subscribe(res => {
|
|
219
|
+
resolve(res);
|
|
220
|
+
});
|
|
221
|
+
});
|
|
222
|
+
}
|
|
223
|
+
/**获取字段详情 */
|
|
224
|
+
getDynamicFormEntity(fieldId) {
|
|
225
|
+
return new Promise((resolve, rejects) => {
|
|
226
|
+
this._FieldAdminService.get(fieldId).subscribe(res => {
|
|
227
|
+
resolve(res);
|
|
228
|
+
});
|
|
229
|
+
});
|
|
101
230
|
}
|
|
102
231
|
/**获取版块下的语言列表 */
|
|
103
232
|
getSectionLanguagesList() {
|
|
@@ -105,18 +234,27 @@ export class EntriesComponent {
|
|
|
105
234
|
//获取所有语言 */
|
|
106
235
|
let languagesSystem = this.configState.getDeep('localization.languages');
|
|
107
236
|
//获取系统默认语言 */
|
|
108
|
-
let DefaultLanguage = this.config.getSetting(
|
|
109
|
-
const configCmsSiteLanguages = this.config.getSetting(
|
|
237
|
+
let DefaultLanguage = this.config.getSetting('Abp.Regionalization.DefaultCultureName');
|
|
238
|
+
const configCmsSiteLanguages = this.config.getSetting('Cms.Site.Languages');
|
|
110
239
|
if (!configCmsSiteLanguages) {
|
|
111
240
|
await this.getSiteSettingsLanguages();
|
|
112
241
|
}
|
|
113
|
-
|
|
242
|
+
if (this.defaultCultureName) {
|
|
243
|
+
DefaultLanguage = this.defaultCultureName;
|
|
244
|
+
}
|
|
245
|
+
const LanguagesSite = (configCmsSiteLanguages ? configCmsSiteLanguages.split(',') : '') ||
|
|
246
|
+
this.SiteSettingsAdminLanguages;
|
|
114
247
|
let LanguagesArray = languagesSystem.filter(el => LanguagesSite.includes(el.cultureName));
|
|
115
248
|
//获取当前选择的语言
|
|
116
|
-
let nowculture = this.
|
|
249
|
+
let nowculture = this.filters.culture;
|
|
250
|
+
// let nowculture = this.filtersForm.get('culture').value;
|
|
117
251
|
//当前选择的语言,是否在版块的的语言列表中
|
|
118
252
|
let isexist = LanguagesArray.find(el => el.cultureName == nowculture);
|
|
119
|
-
this.
|
|
253
|
+
this.filters.culture = nowculture
|
|
254
|
+
? isexist
|
|
255
|
+
? nowculture
|
|
256
|
+
: DefaultLanguage
|
|
257
|
+
: DefaultLanguage;
|
|
120
258
|
this.sectionLanguagesList = LanguagesArray;
|
|
121
259
|
resolve(LanguagesArray);
|
|
122
260
|
});
|
|
@@ -128,12 +266,18 @@ export class EntriesComponent {
|
|
|
128
266
|
return new Promise((resolve, rejects) => {
|
|
129
267
|
this._RegionalizationService.get().subscribe(res => {
|
|
130
268
|
this.SiteSettingsAdminLanguages = res.availableCultureNames;
|
|
269
|
+
this.defaultCultureName = res.defaultCultureName;
|
|
131
270
|
resolve(res);
|
|
132
271
|
});
|
|
133
272
|
});
|
|
134
273
|
}
|
|
135
274
|
resetData() {
|
|
136
|
-
this.filters =
|
|
275
|
+
this.filters = {
|
|
276
|
+
sectionId: this.filters.sectionId,
|
|
277
|
+
culture: this.filters.culture,
|
|
278
|
+
};
|
|
279
|
+
this.list.filter = '';
|
|
280
|
+
this.list.maxResultCount = this.maxResultCount;
|
|
137
281
|
this.list.page = 0;
|
|
138
282
|
this.data.items = [];
|
|
139
283
|
this.list.get();
|
|
@@ -141,38 +285,81 @@ export class EntriesComponent {
|
|
|
141
285
|
/**新增-单个 */
|
|
142
286
|
createEntriesBtn() {
|
|
143
287
|
this.router.navigate(['/cms/admin/entries/create'], {
|
|
144
|
-
queryParams: {
|
|
288
|
+
queryParams: {
|
|
289
|
+
cultureName: this.filters.culture,
|
|
290
|
+
sectionId: this.filters.sectionId,
|
|
291
|
+
entryTypeId: this.entryTypeList[0].id,
|
|
292
|
+
},
|
|
145
293
|
});
|
|
146
294
|
}
|
|
147
295
|
createCopyEntriesBtn() {
|
|
148
296
|
this.router.navigate(['/cms/admin/entries/create-copy'], {
|
|
149
|
-
queryParams: {
|
|
297
|
+
queryParams: {
|
|
298
|
+
cultureName: this.filters.culture,
|
|
299
|
+
sectionId: this.filters.sectionId,
|
|
300
|
+
entryTypeId: this.entryTypeList[0].id,
|
|
301
|
+
},
|
|
150
302
|
});
|
|
151
303
|
}
|
|
152
304
|
hookToQuery() {
|
|
153
305
|
const getData = (query) => this._EntryAdminService.getList({
|
|
154
306
|
...query,
|
|
155
307
|
...this.filters,
|
|
308
|
+
maxResultCount: this.maxResultCount,
|
|
156
309
|
});
|
|
157
310
|
const setData = (list) => {
|
|
311
|
+
if (this.SiteOfSectionType == SectionType.Structure) {
|
|
312
|
+
list.items = list.items.sort((a, b) => {
|
|
313
|
+
return a.order - b.order;
|
|
314
|
+
});
|
|
315
|
+
}
|
|
158
316
|
this.data = list;
|
|
159
317
|
};
|
|
160
318
|
this.list.hookToQuery(getData).subscribe(setData);
|
|
161
319
|
}
|
|
162
320
|
/**删除条目 */
|
|
163
321
|
deletefield(row) {
|
|
164
|
-
this.confirmation
|
|
322
|
+
this.confirmation
|
|
323
|
+
.warn(row.displayName, this._LocalizationService.instant(`AbpUi::ItemWillBeDeletedMessage`))
|
|
324
|
+
.subscribe((status) => {
|
|
165
325
|
if (status == 'confirm') {
|
|
166
|
-
this._EntryAdminService
|
|
167
|
-
|
|
326
|
+
this._EntryAdminService
|
|
327
|
+
.delete(row.id)
|
|
328
|
+
.pipe(finalize(() => { }))
|
|
329
|
+
.subscribe(res => {
|
|
168
330
|
this.toaster.success(this._LocalizationService.instant(`AbpUi::DeletedSuccessfully`));
|
|
169
331
|
this.list.get();
|
|
170
332
|
});
|
|
171
333
|
}
|
|
172
334
|
});
|
|
173
335
|
}
|
|
174
|
-
|
|
175
|
-
|
|
336
|
+
drop(event) {
|
|
337
|
+
let previousId = this.data.items[event.previousIndex].id;
|
|
338
|
+
let previousIndexOrder = this.data.items[event.previousIndex].order;
|
|
339
|
+
let currentIndexOrder = this.data.items[event.currentIndex].order;
|
|
340
|
+
let moveorder = currentIndexOrder;
|
|
341
|
+
if (previousIndexOrder < currentIndexOrder) {
|
|
342
|
+
moveorder = currentIndexOrder + 1;
|
|
343
|
+
}
|
|
344
|
+
moveItemInArray(this.data.items, event.previousIndex, event.currentIndex);
|
|
345
|
+
this._EntryAdminService
|
|
346
|
+
.move(previousId, {
|
|
347
|
+
order: moveorder,
|
|
348
|
+
// order: event.currentIndex,
|
|
349
|
+
})
|
|
350
|
+
.pipe(finalize(() => {
|
|
351
|
+
this.list.get();
|
|
352
|
+
}))
|
|
353
|
+
.subscribe(res => { }, err => { });
|
|
354
|
+
// moveItemInArray(this.rows, event.previousIndex, event.currentIndex);
|
|
355
|
+
// this.rows = [...this.rows];
|
|
356
|
+
}
|
|
357
|
+
/**高级筛选切换 */
|
|
358
|
+
expandedChange(event) {
|
|
359
|
+
this.isexpanded = event;
|
|
360
|
+
}
|
|
361
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: EntriesComponent, deps: [{ token: i1.EntryAdminService }, { token: i2.SectionAdminService }, { token: i3.ToasterService }, { token: i3.ConfirmationService }, { token: i4.ConfigStateService }, { token: i5.Router }, { token: i4.LocalizationService }, { token: i6.FormAdminService }, { token: i7.FieldAdminService }, { token: i0.ChangeDetectorRef }, { token: i8.FormControlsService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
362
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.5", type: EntriesComponent, selector: "cms-entries", providers: [
|
|
176
363
|
ListService,
|
|
177
364
|
// Provide this token if you want a different debounce time.
|
|
178
365
|
// Default is 300. Cannot be 0. Any value below 100 is not recommended.
|
|
@@ -181,7 +368,7 @@ export class EntriesComponent {
|
|
|
181
368
|
provide: EXTENSIONS_IDENTIFIER,
|
|
182
369
|
useValue: ECmsComponent.Entries,
|
|
183
370
|
},
|
|
184
|
-
], 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-end\">\r\n <div class=\"mb-3 col-3\">\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-3 col-3\">\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\r\n <div class=\"mb-3 col-3\">\r\n <label class=\"form-label\">{{'AbpUi::Search' | abpLocalization}}\uFF1A</label>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"filter\"\r\n [placeholder]=\"'AbpUi::Search' | abpLocalization\" />\r\n </div>\r\n <div class=\"mb-3 col-3\">\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>\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 \" [rows]=\"data.items\" [list]=\"list\" [columnMode]=\"ColumnMode.force\"\r\n [headerHeight]=\"50\" [footerHeight]=\"50\" rowHeight=\"auto\" [virtualization]=\"false\"\r\n [externalPaging]=\"true\" [count]=\"data.totalCount\" [scrollbarH]=\"true\">\r\n <ngx-datatable-column [name]=\"'Cms::Title' | abpLocalization\" prop=\"title\" [sortable]=\"true\">\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::EntryType' | abpLocalization\" prop=\"entryTypeId\" [sortable]=\"false\">\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::Slug' | abpLocalization\" prop=\"slug\" [sortable]=\"true\">\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\" [width]=\"80\"\r\n [sortable]=\"false\">\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 [width]=\"190\">\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\" [name]=\"'AbpUi::Actions' | abpLocalization\"\r\n [frozenLeft]=\"true\" [width]=\"110\" [maxWidth]=\"110\">\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-primary btn-sm\" ngbDropdownToggle>\r\n <i class=\"me-1 fa fa-cog\"></i> {{'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: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i7.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i7.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i7.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: i7.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i7.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i7.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i7.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i5.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i4.PermissionDirective, selector: "[abpPermission]", inputs: ["abpPermission", "abpPermissionRunChangeDetection"] }, { kind: "component", type: i8.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: i8.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: i8.DataTableColumnCellDirective, selector: "[ngx-datatable-cell-template]" }, { kind: "directive", type: i9.ValidationGroupDirective, selector: "[formGroup],[formGroupName]", exportAs: ["validationGroup"] }, { kind: "directive", type: i9.ValidationDirective, selector: "[formControl],[formControlName]", exportAs: ["validationDirective"] }, { kind: "directive", type: i3.NgxDatatableListDirective, selector: "ngx-datatable[list]", inputs: ["list"], exportAs: ["ngxDatatableList"] }, { kind: "directive", type: i10.NgbDropdown, selector: "[ngbDropdown]", inputs: ["autoClose", "dropdownClass", "open", "placement", "popperOptions", "container", "display"], outputs: ["openChange"], exportAs: ["ngbDropdown"] }, { kind: "directive", type: i10.NgbDropdownToggle, selector: "[ngbDropdownToggle]" }, { kind: "directive", type: i10.NgbDropdownMenu, selector: "[ngbDropdownMenu]" }, { kind: "directive", type: i10.NgbDropdownItem, selector: "[ngbDropdownItem]", inputs: ["tabindex", "disabled"] }, { kind: "directive", type: i10.NgbDropdownButtonItem, selector: "button[ngbDropdownItem]" }, { kind: "component", type: i11.PageComponent, selector: "abp-page", inputs: ["title", "toolbar", "breadcrumb"] }, { kind: "component", type: i11.PageToolbarContainerComponent, selector: "abp-page-toolbar-container" }, { kind: "pipe", type: i6.DatePipe, name: "date" }, { kind: "pipe", type: i4.LocalizationPipe, name: "abpLocalization" }] }); }
|
|
371
|
+
], 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 \">\r\n <div class=\"row align-items-end\">\r\n <div class=\"mb-3 col-3\">\r\n <label class=\"form-label\">{{'Cms::Sections' | abpLocalization}}\uFF1A</label>\r\n <select class=\"form-select col-auto\" [(ngModel)]=\"filters.sectionId\"\r\n (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-3 col-3\">\r\n <label class=\"form-label\">{{'AbpUi::Languages' | abpLocalization}}\uFF1A</label>\r\n <select class=\"form-select col-auto\" [(ngModel)]=\"filters.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 class=\"mb-3 col-6\">\r\n <div class=\"input-group\">\r\n <input type=\"text\" class=\"form-control\" [(ngModel)]=\"filters.filter\"\r\n [placeholder]=\"'Cms::PagerSearch'|abpLocalization\" />\r\n <button type=\"button\" class=\"btn btn-primary\" (click)=\"listget()\">\r\n <i class=\"bi bi-search\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n @if(filters.culture&&enablegearchFormEntity&&enableSearchFieldList.length>0){\r\n <div id=\"entries-advanced-form\" class=\"entries-advanced-form \" [hidden]=\"isexpanded\"\r\n (abpInit)=\"abpInitss()\">\r\n <form [formGroup]=\"enablegearchFormEntity\">\r\n <div class=\"row align-items-end\">\r\n <ng-container *ngFor=\"let el of enableSearchFieldList\">\r\n <ng-container *ngIf=\"el.field&&enablegearchFormEntity&&el.enableSearch\">\r\n <div class=\"col-3\">\r\n <df-dynamic-search [fields]=\"el\" [parentFiledName]=\"'extraProperties'\"\r\n [culture]=\"filters.culture\"\r\n [entity]=\"enablegearchFormEntity\"></df-dynamic-search>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n <div class=\"col-6 mb-3 \">\r\n <button type=\"button\" class=\"btn btn-primary\" (click)=\"listget()\">\r\n <span>{{ 'AbpUi::Refresh' | abpLocalization }}</span>\r\n </button>\r\n </div>\r\n </div>\r\n </form>\r\n </div>\r\n }\r\n </div>\r\n </div>\r\n\r\n\r\n\r\n <div class=\"card mb-0\">\r\n <div class=\"card-body p-0\">\r\n @if(SiteOfSectionType!==SectionType.Structure){\r\n <div class=\"table-responsive table-fixed-header\">\r\n <ngx-datatable class=\"material \" [rows]=\"data.items\" [list]=\"list\" [columnMode]=\"ColumnMode.force\"\r\n [headerHeight]=\"50\" [footerHeight]=\"50\" rowHeight=\"auto\" [virtualization]=\"false\"\r\n [externalPaging]=\"true\" [count]=\"data.totalCount\" [scrollbarH]=\"true\">\r\n <ngx-datatable-column [name]=\"'Cms::Title' | abpLocalization\" prop=\"title\" [sortable]=\"false\">\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::EntryType' | abpLocalization\" prop=\"entryTypeId\"\r\n [sortable]=\"false\">\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::Slug' | abpLocalization\" prop=\"slug\" [sortable]=\"false\">\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\" [width]=\"80\"\r\n [sortable]=\"false\">\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 @for (item of showinFieldList; track $index) {\r\n <ngx-datatable-column [name]=\"'Cms::'+item.displayName | abpLocalization\"\r\n [prop]=\"item?.field?.name\" [sortable]=\"false\">\r\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n <df-dynamic-view [type]=\"item.field.formControlName\" [showInList]=\"true\" [fields]=\"item\"\r\n [value]=\"row?.extraProperties[item.field.name]\"></df-dynamic-view>\r\n </ng-template>\r\n </ngx-datatable-column>\r\n }\r\n <ngx-datatable-column [name]=\"'Cms::PublishTime' | abpLocalization\" prop=\"publishTime\"\r\n [width]=\"190\" [sortable]=\"false\">\r\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n {{value | shortDateTime }}\r\n </ng-template>\r\n </ngx-datatable-column>\r\n <ngx-datatable-column [sortable]=\"false\" [name]=\"'AbpUi::Actions' | abpLocalization\"\r\n [frozenLeft]=\"true\" [width]=\"110\" [maxWidth]=\"110\">\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-primary btn-sm\" ngbDropdownToggle>\r\n <i class=\"me-1 fa fa-cog\"></i> {{'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\r\n </ngx-datatable>\r\n </div>\r\n }\r\n\r\n @if(SiteOfSectionType===SectionType.Structure){\r\n <div class=\"table-responsive table-fixed-header\">\r\n <table class=\"table overflow-nowrap mb-0\" cdkDropList (cdkDropListDropped)=\"drop($event)\">\r\n <thead>\r\n <tr>\r\n <th class=\"sticky-left-card-bg\">{{'AbpUi::Actions' | abpLocalization}}</th>\r\n <th>{{'Cms::Title' | abpLocalization}}</th>\r\n <th>{{'Cms::EntryType' | abpLocalization}}</th>\r\n <th>{{'Cms::Slug' | abpLocalization}}</th>\r\n <th>{{'Cms::Status' | abpLocalization}}</th>\r\n @for (item of showinFieldList; track $index) {\r\n <th>{{'Cms::'+item.displayName | abpLocalization}}</th>\r\n }\r\n <th>{{'Cms::PublishTime' | abpLocalization}}</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let item of data.items\" cdkDrag>\r\n <td class=\"sticky-left-card-bg\">\r\n <div ngbDropdown container=\"body\">\r\n <button type=\"button\" class=\"btn btn-primary btn-sm\" ngbDropdownToggle>\r\n <i class=\"me-1 fa fa-cog\"></i> {{'AbpUi::Actions' | abpLocalization}}\r\n </button>\r\n <div ngbDropdownMenu>\r\n <button ngbDropdownItem\r\n routerLink=\"/cms/admin/entries/{{item.id}}/edit\">{{'AbpUi::Edit' |\r\n abpLocalization}}</button>\r\n <button ngbDropdownItem (click)=\"deletefield(item)\">{{'AbpUi::Delete' |\r\n abpLocalization}}</button>\r\n </div>\r\n </div>\r\n </td>\r\n <td class=\"white-space-normal\">{{item.title}}</td>\r\n <td>\r\n <ng-container *ngFor=\"let item1 of entryTypeList\">\r\n <ng-container\r\n *ngIf=\"item1.id === item.entryTypeId\">{{item1.displayName}}</ng-container>\r\n </ng-container>\r\n </td>\r\n <td>{{item.slug}}</td>\r\n <td>\r\n <ng-container *ngFor=\"let item2 of _entryStatusOptions\">\r\n <ng-container *ngIf=\"item.status=== item2.value\">{{\r\n 'Cms::Enum:EntryStatus:'+item2.key |\r\n abpLocalization }}</ng-container>\r\n </ng-container>\r\n </td>\r\n @for (item1 of showinFieldList; track $index) {\r\n <td>\r\n <df-dynamic-view [type]=\"item1.field.formControlName\" [showInList]=\"true\" [fields]=\"item1\"\r\n [value]=\"item?.extraProperties[item1.field.name]\"></df-dynamic-view>\r\n\r\n </td>\r\n }\r\n <td>{{item.publishTime | shortDateTime }}</td>\r\n </tr>\r\n </tbody>\r\n @if(data.items.length === 0){\r\n <div class=\"text-muted p-2\">\r\n {{ 'Cms::NoDataAvailableInDatatable' | abpLocalization}}\r\n </div>\r\n }\r\n </table>\r\n </div>\r\n <div class=\"card-footer py-2\">\r\n <small class=\"text-muted\"> {{data.totalCount}} {{ 'Cms::Total' | abpLocalization}}</small>\r\n </div>\r\n }\r\n\r\n </div>\r\n </div>\r\n\r\n\r\n\r\n\r\n\r\n\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}.white-space-normal{white-space:normal;min-width:150px}.overflow-nowrap{overflow:auto;white-space:nowrap}::ng-deep .sites-page .table th{padding-left:1rem!important;padding-right:1rem!important}::ng-deep .sites-page .table td{padding:.875rem 1rem!important}::ng-deep .sites-page .table .sticky-left-card-bg{position:sticky;left:0;background:var(--bs-card-bg)}::ng-deep .sites-page .entries-advanced-form{transition:all .3s linear}\n"], dependencies: [{ kind: "directive", type: i9.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i10.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i10.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i10.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i10.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: i10.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i10.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i10.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i10.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i10.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i5.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i4.InitDirective, selector: "[abpInit]", outputs: ["abpInit"] }, { kind: "directive", type: i4.PermissionDirective, selector: "[abpPermission]", inputs: ["abpPermission", "abpPermissionRunChangeDetection"] }, { kind: "component", type: i11.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: i11.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: i11.DataTableColumnCellDirective, selector: "[ngx-datatable-cell-template]" }, { kind: "directive", type: i12.ValidationGroupDirective, selector: "[formGroup],[formGroupName]", exportAs: ["validationGroup"] }, { kind: "directive", type: i3.NgxDatatableListDirective, selector: "ngx-datatable[list]", inputs: ["list"], exportAs: ["ngxDatatableList"] }, { kind: "directive", type: i13.NgbDropdown, selector: "[ngbDropdown]", inputs: ["autoClose", "dropdownClass", "open", "placement", "popperOptions", "container", "display"], outputs: ["openChange"], exportAs: ["ngbDropdown"] }, { kind: "directive", type: i13.NgbDropdownToggle, selector: "[ngbDropdownToggle]" }, { kind: "directive", type: i13.NgbDropdownMenu, selector: "[ngbDropdownMenu]" }, { kind: "directive", type: i13.NgbDropdownItem, selector: "[ngbDropdownItem]", inputs: ["tabindex", "disabled"] }, { kind: "directive", type: i13.NgbDropdownButtonItem, selector: "button[ngbDropdownItem]" }, { kind: "component", type: i14.PageComponent, selector: "abp-page", inputs: ["title", "toolbar", "breadcrumb"] }, { kind: "component", type: i14.PageToolbarContainerComponent, selector: "abp-page-toolbar-container" }, { kind: "component", type: i15.DynamicViewComponent, selector: "df-dynamic-view", inputs: ["showInList", "fields", "type", "value"] }, { kind: "component", type: i15.DynamicSearchComponent, selector: "df-dynamic-search", inputs: ["culture", "parentFiledName", "fields", "entity"] }, { kind: "directive", type: i16.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i16.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "pipe", type: i4.LocalizationPipe, name: "abpLocalization" }, { kind: "pipe", type: i4.ShortDateTimePipe, name: "shortDateTime" }] }); }
|
|
185
372
|
}
|
|
186
373
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: EntriesComponent, decorators: [{
|
|
187
374
|
type: Component,
|
|
@@ -194,6 +381,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
|
|
|
194
381
|
provide: EXTENSIONS_IDENTIFIER,
|
|
195
382
|
useValue: ECmsComponent.Entries,
|
|
196
383
|
},
|
|
197
|
-
], 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-end\">\r\n <div class=\"mb-3 col-3\">\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-3 col-3\">\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\r\n <div class=\"mb-3 col-3\">\r\n <label class=\"form-label\">{{'AbpUi::Search' | abpLocalization}}\uFF1A</label>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"filter\"\r\n [placeholder]=\"'AbpUi::Search' | abpLocalization\" />\r\n </div>\r\n <div class=\"mb-3 col-3\">\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>\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 \" [rows]=\"data.items\" [list]=\"list\" [columnMode]=\"ColumnMode.force\"\r\n [headerHeight]=\"50\" [footerHeight]=\"50\" rowHeight=\"auto\" [virtualization]=\"false\"\r\n [externalPaging]=\"true\" [count]=\"data.totalCount\" [scrollbarH]=\"true\">\r\n <ngx-datatable-column [name]=\"'Cms::Title' | abpLocalization\" prop=\"title\" [sortable]=\"true\">\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::EntryType' | abpLocalization\" prop=\"entryTypeId\" [sortable]=\"false\">\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::Slug' | abpLocalization\" prop=\"slug\" [sortable]=\"true\">\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\" [width]=\"80\"\r\n [sortable]=\"false\">\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 [width]=\"190\">\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\" [name]=\"'AbpUi::Actions' | abpLocalization\"\r\n [frozenLeft]=\"true\" [width]=\"110\" [maxWidth]=\"110\">\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-primary btn-sm\" ngbDropdownToggle>\r\n <i class=\"me-1 fa fa-cog\"></i> {{'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"] }]
|
|
198
|
-
}], ctorParameters: () => [{ type: i1.EntryAdminService }, { type: i2.SectionAdminService }, { type: i3.ToasterService }, { type: i3.ConfirmationService }, { type: i4.ConfigStateService }, { type: i5.Router }, { type: i4.LocalizationService }] });
|
|
199
|
-
//# 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":["\nimport { EXTENSIONS_IDENTIFIER } from \"@abp/ng.components/extensible\";\nimport { ListService, LIST_QUERY_DEBOUNCE_TIME, ConfigStateService, LocalizationService, PagedResultDto, ABP } 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 { Router } from \"@angular/router\";\nimport { ColumnMode } from \"@swimlane/ngx-datatable\";\nimport { finalize } from \"rxjs\";\nimport { ECmsComponent } from \"../../../enums\";\nimport { UpdateListService } from \"@dignite-ng/expand.core\";\nimport { EntryAdminService, EntryDto, GetEntriesInput } from \"../../../proxy/dignite/cms/admin/entries\";\nimport { SectionAdminService } from \"../../../proxy/dignite/cms/admin/sections\";\nimport { entryStatusOptions } from \"../../../proxy/dignite/cms/entries\";\nimport { RegionalizationService } from \"../../../proxy/dignite/abp/regionalization-management\";\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 _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  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.getSiteOfSectionList()\n    await this.getSectionLanguagesList()\n    this.filters = this.filtersForm.value\n    this.hookToQuery()\n  }\n\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\n  /**获取站点下的版块 */\n  getSiteOfSectionList() {\n    return new Promise((resolve, rejects) => {\n      this._SectionAdminService.getList({\n        maxResultCount: 1000,\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  private config = inject(ConfigStateService)\n  private _RegionalizationService = inject(RegionalizationService)\n  /**获取版块下的语言列表 */\n  getSectionLanguagesList() {\n    return new Promise(async (resolve, rejects) => {\n      //获取所有语言 */\n      let languagesSystem = this.configState.getDeep('localization.languages')\n      //获取系统默认语言 */\n      let DefaultLanguage = this.config.getSetting(\"Abp.Regionalization.DefaultCultureName\");\n      const configCmsSiteLanguages = this.config.getSetting(\"Cms.Site.Languages\")\n      if(!configCmsSiteLanguages){\n        await this.getSiteSettingsLanguages()\n      }\n      const LanguagesSite = (configCmsSiteLanguages ? configCmsSiteLanguages.split(',') : '') || this.SiteSettingsAdminLanguages\n      let LanguagesArray = languagesSystem.filter(el => LanguagesSite.includes(el.cultureName))\n      //获取当前选择的语言\n      let nowculture = this.filtersForm.get('culture').value\n      //当前选择的语言，是否在版块的的语言列表中\n      let isexist = LanguagesArray.find(el => el.cultureName == nowculture)\n      this.filtersForm.get('culture').patchValue(nowculture ? isexist ? nowculture : DefaultLanguage : DefaultLanguage)\n      this.sectionLanguagesList = LanguagesArray\n      resolve(LanguagesArray)\n    })\n  }\n\n  /**站点设置语言 */\n  SiteSettingsAdminLanguages: any[] = []\n  /**\n   * 获取站点设置语言\n   */\n  getSiteSettingsLanguages() {\n    return new Promise((resolve, rejects) => {\n      this._RegionalizationService.get().subscribe(res => {\n        this.SiteSettingsAdminLanguages = res.availableCultureNames\n        resolve(res)\n      })\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  createCopyEntriesBtn() {\n    this.router.navigate(['/cms/admin/entries/create-copy'], {\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::DeletedSuccessfully`));\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-end\">\r\n                    <div class=\"mb-3 col-3\">\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-3 col-3\">\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\r\n                    <div class=\"mb-3 col-3\">\r\n                        <label class=\"form-label\">{{'AbpUi::Search' | abpLocalization}}：</label>\r\n                        <input type=\"text\" class=\"form-control\" formControlName=\"filter\"\r\n                            [placeholder]=\"'AbpUi::Search' | abpLocalization\" />\r\n                    </div>\r\n                    <div class=\"mb-3 col-3\">\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>\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 \" [rows]=\"data.items\" [list]=\"list\" [columnMode]=\"ColumnMode.force\"\r\n                        [headerHeight]=\"50\" [footerHeight]=\"50\" rowHeight=\"auto\" [virtualization]=\"false\"\r\n                        [externalPaging]=\"true\" [count]=\"data.totalCount\" [scrollbarH]=\"true\">\r\n                        <ngx-datatable-column [name]=\"'Cms::Title' | abpLocalization\" prop=\"title\" [sortable]=\"true\">\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::EntryType' | abpLocalization\" prop=\"entryTypeId\" [sortable]=\"false\">\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::Slug' | abpLocalization\" prop=\"slug\" [sortable]=\"true\">\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\" [width]=\"80\"\r\n                            [sortable]=\"false\">\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                            [width]=\"190\">\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\" [name]=\"'AbpUi::Actions' | abpLocalization\"\r\n                            [frozenLeft]=\"true\" [width]=\"110\" [maxWidth]=\"110\">\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-primary btn-sm\" ngbDropdownToggle>\r\n                                        <i class=\"me-1 fa fa-cog\"></i> {{'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>"]}
|
|
384
|
+
], 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 \">\r\n <div class=\"row align-items-end\">\r\n <div class=\"mb-3 col-3\">\r\n <label class=\"form-label\">{{'Cms::Sections' | abpLocalization}}\uFF1A</label>\r\n <select class=\"form-select col-auto\" [(ngModel)]=\"filters.sectionId\"\r\n (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-3 col-3\">\r\n <label class=\"form-label\">{{'AbpUi::Languages' | abpLocalization}}\uFF1A</label>\r\n <select class=\"form-select col-auto\" [(ngModel)]=\"filters.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 class=\"mb-3 col-6\">\r\n <div class=\"input-group\">\r\n <input type=\"text\" class=\"form-control\" [(ngModel)]=\"filters.filter\"\r\n [placeholder]=\"'Cms::PagerSearch'|abpLocalization\" />\r\n <button type=\"button\" class=\"btn btn-primary\" (click)=\"listget()\">\r\n <i class=\"bi bi-search\"></i>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n @if(filters.culture&&enablegearchFormEntity&&enableSearchFieldList.length>0){\r\n <div id=\"entries-advanced-form\" class=\"entries-advanced-form \" [hidden]=\"isexpanded\"\r\n (abpInit)=\"abpInitss()\">\r\n <form [formGroup]=\"enablegearchFormEntity\">\r\n <div class=\"row align-items-end\">\r\n <ng-container *ngFor=\"let el of enableSearchFieldList\">\r\n <ng-container *ngIf=\"el.field&&enablegearchFormEntity&&el.enableSearch\">\r\n <div class=\"col-3\">\r\n <df-dynamic-search [fields]=\"el\" [parentFiledName]=\"'extraProperties'\"\r\n [culture]=\"filters.culture\"\r\n [entity]=\"enablegearchFormEntity\"></df-dynamic-search>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n <div class=\"col-6 mb-3 \">\r\n <button type=\"button\" class=\"btn btn-primary\" (click)=\"listget()\">\r\n <span>{{ 'AbpUi::Refresh' | abpLocalization }}</span>\r\n </button>\r\n </div>\r\n </div>\r\n </form>\r\n </div>\r\n }\r\n </div>\r\n </div>\r\n\r\n\r\n\r\n <div class=\"card mb-0\">\r\n <div class=\"card-body p-0\">\r\n @if(SiteOfSectionType!==SectionType.Structure){\r\n <div class=\"table-responsive table-fixed-header\">\r\n <ngx-datatable class=\"material \" [rows]=\"data.items\" [list]=\"list\" [columnMode]=\"ColumnMode.force\"\r\n [headerHeight]=\"50\" [footerHeight]=\"50\" rowHeight=\"auto\" [virtualization]=\"false\"\r\n [externalPaging]=\"true\" [count]=\"data.totalCount\" [scrollbarH]=\"true\">\r\n <ngx-datatable-column [name]=\"'Cms::Title' | abpLocalization\" prop=\"title\" [sortable]=\"false\">\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::EntryType' | abpLocalization\" prop=\"entryTypeId\"\r\n [sortable]=\"false\">\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::Slug' | abpLocalization\" prop=\"slug\" [sortable]=\"false\">\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\" [width]=\"80\"\r\n [sortable]=\"false\">\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 @for (item of showinFieldList; track $index) {\r\n <ngx-datatable-column [name]=\"'Cms::'+item.displayName | abpLocalization\"\r\n [prop]=\"item?.field?.name\" [sortable]=\"false\">\r\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n <df-dynamic-view [type]=\"item.field.formControlName\" [showInList]=\"true\" [fields]=\"item\"\r\n [value]=\"row?.extraProperties[item.field.name]\"></df-dynamic-view>\r\n </ng-template>\r\n </ngx-datatable-column>\r\n }\r\n <ngx-datatable-column [name]=\"'Cms::PublishTime' | abpLocalization\" prop=\"publishTime\"\r\n [width]=\"190\" [sortable]=\"false\">\r\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n {{value | shortDateTime }}\r\n </ng-template>\r\n </ngx-datatable-column>\r\n <ngx-datatable-column [sortable]=\"false\" [name]=\"'AbpUi::Actions' | abpLocalization\"\r\n [frozenLeft]=\"true\" [width]=\"110\" [maxWidth]=\"110\">\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-primary btn-sm\" ngbDropdownToggle>\r\n <i class=\"me-1 fa fa-cog\"></i> {{'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\r\n </ngx-datatable>\r\n </div>\r\n }\r\n\r\n @if(SiteOfSectionType===SectionType.Structure){\r\n <div class=\"table-responsive table-fixed-header\">\r\n <table class=\"table overflow-nowrap mb-0\" cdkDropList (cdkDropListDropped)=\"drop($event)\">\r\n <thead>\r\n <tr>\r\n <th class=\"sticky-left-card-bg\">{{'AbpUi::Actions' | abpLocalization}}</th>\r\n <th>{{'Cms::Title' | abpLocalization}}</th>\r\n <th>{{'Cms::EntryType' | abpLocalization}}</th>\r\n <th>{{'Cms::Slug' | abpLocalization}}</th>\r\n <th>{{'Cms::Status' | abpLocalization}}</th>\r\n @for (item of showinFieldList; track $index) {\r\n <th>{{'Cms::'+item.displayName | abpLocalization}}</th>\r\n }\r\n <th>{{'Cms::PublishTime' | abpLocalization}}</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let item of data.items\" cdkDrag>\r\n <td class=\"sticky-left-card-bg\">\r\n <div ngbDropdown container=\"body\">\r\n <button type=\"button\" class=\"btn btn-primary btn-sm\" ngbDropdownToggle>\r\n <i class=\"me-1 fa fa-cog\"></i> {{'AbpUi::Actions' | abpLocalization}}\r\n </button>\r\n <div ngbDropdownMenu>\r\n <button ngbDropdownItem\r\n routerLink=\"/cms/admin/entries/{{item.id}}/edit\">{{'AbpUi::Edit' |\r\n abpLocalization}}</button>\r\n <button ngbDropdownItem (click)=\"deletefield(item)\">{{'AbpUi::Delete' |\r\n abpLocalization}}</button>\r\n </div>\r\n </div>\r\n </td>\r\n <td class=\"white-space-normal\">{{item.title}}</td>\r\n <td>\r\n <ng-container *ngFor=\"let item1 of entryTypeList\">\r\n <ng-container\r\n *ngIf=\"item1.id === item.entryTypeId\">{{item1.displayName}}</ng-container>\r\n </ng-container>\r\n </td>\r\n <td>{{item.slug}}</td>\r\n <td>\r\n <ng-container *ngFor=\"let item2 of _entryStatusOptions\">\r\n <ng-container *ngIf=\"item.status=== item2.value\">{{\r\n 'Cms::Enum:EntryStatus:'+item2.key |\r\n abpLocalization }}</ng-container>\r\n </ng-container>\r\n </td>\r\n @for (item1 of showinFieldList; track $index) {\r\n <td>\r\n <df-dynamic-view [type]=\"item1.field.formControlName\" [showInList]=\"true\" [fields]=\"item1\"\r\n [value]=\"item?.extraProperties[item1.field.name]\"></df-dynamic-view>\r\n\r\n </td>\r\n }\r\n <td>{{item.publishTime | shortDateTime }}</td>\r\n </tr>\r\n </tbody>\r\n @if(data.items.length === 0){\r\n <div class=\"text-muted p-2\">\r\n {{ 'Cms::NoDataAvailableInDatatable' | abpLocalization}}\r\n </div>\r\n }\r\n </table>\r\n </div>\r\n <div class=\"card-footer py-2\">\r\n <small class=\"text-muted\"> {{data.totalCount}} {{ 'Cms::Total' | abpLocalization}}</small>\r\n </div>\r\n }\r\n\r\n </div>\r\n </div>\r\n\r\n\r\n\r\n\r\n\r\n\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}.white-space-normal{white-space:normal;min-width:150px}.overflow-nowrap{overflow:auto;white-space:nowrap}::ng-deep .sites-page .table th{padding-left:1rem!important;padding-right:1rem!important}::ng-deep .sites-page .table td{padding:.875rem 1rem!important}::ng-deep .sites-page .table .sticky-left-card-bg{position:sticky;left:0;background:var(--bs-card-bg)}::ng-deep .sites-page .entries-advanced-form{transition:all .3s linear}\n"] }]
|
|
385
|
+
}], ctorParameters: () => [{ type: i1.EntryAdminService }, { type: i2.SectionAdminService }, { type: i3.ToasterService }, { type: i3.ConfirmationService }, { type: i4.ConfigStateService }, { type: i5.Router }, { type: i4.LocalizationService }, { type: i6.FormAdminService }, { type: i7.FieldAdminService }, { type: i0.ChangeDetectorRef }, { type: i8.FormControlsService }] });
|
|
386
|
+
//# 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 { EXTENSIONS_IDENTIFIER } from '@abp/ng.components/extensible';\nimport {\n  ListService,\n  LIST_QUERY_DEBOUNCE_TIME,\n  ConfigStateService,\n  LocalizationService,\n  PagedResultDto,\n  ABP,\n} from '@abp/ng.core';\nimport { ToasterService, ConfirmationService, Confirmation } from '@abp/ng.theme.shared';\nimport { ChangeDetectorRef, Component, OnInit, inject } from '@angular/core';\nimport { FormBuilder, FormGroup } from '@angular/forms';\nimport { Router } from '@angular/router';\nimport { ColumnMode } from '@swimlane/ngx-datatable';\nimport { finalize } from 'rxjs';\nimport { ECmsComponent } from '../../../enums';\nimport { UpdateListService } from '@dignite-ng/expand.core';\nimport {\n  EntryAdminService,\n  EntryDto,\n  GetEntriesInput,\n} from '../../../proxy/dignite/cms/admin/entries';\nimport { SectionAdminService } from '../../../proxy/dignite/cms/admin/sections';\nimport { entryStatusOptions } from '../../../proxy/dignite/cms/entries';\nimport { RegionalizationService } from '../../../proxy/dignite/abp/regionalization-management';\nimport { SectionType } from '../../../proxy/dignite/cms/sections';\nimport { moveItemInArray } from '@angular/cdk/drag-drop';\nimport { FormAdminService } from '../../../proxy/dignite/cms/admin/dynamic-forms';\nimport { FieldAdminService } from '../../../proxy/dignite/cms/admin/fields';\nimport { FormControlsService } from '../../../services/form-controls.service';\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  constructor(\n    private _EntryAdminService: EntryAdminService,\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    private _FormAdminService: FormAdminService,\n    private _FieldAdminService: FieldAdminService,\n    private cdRef: ChangeDetectorRef,\n    private _FormControlsService: FormControlsService\n  ) {}\n\n  private fb = inject(FormBuilder);\n  private _UpdateListService = inject(UpdateListService);\n  public readonly list = inject(ListService<GetEntriesInput>);\n\n  /**板块类型 */\n  SectionType = SectionType;\n\n  ngOnInit(): void {\n    this.getPageDate();\n    this._UpdateListService.updateListEvent.subscribe(() => {\n      this.list.get();\n    });\n  }\n\n  /**站点下的版块 */\n  SiteOfSectionList: any[any] = [];\n\n  /**版块下的语言列表 */\n  sectionLanguagesList: any[any] = [];\n  /**版块下的条目类型列表 */\n  entryTypeList: any[any] = [];\n  /**状态编码 */\n  _entryStatusOptions = entryStatusOptions;\n\n  /**获取页面数据 */\n  async getPageDate() {\n    // await this.getDynamicFormType();\n    this.enableSearchTypeList = await this._FormControlsService.getEnableSearchTypeList();\n    //  this.disableshowinTypeList= this._FormControlsService.getdisableshowinTypeList();\n    await this.getSiteOfSectionList();\n    await this.getSectionLanguagesList();\n    this.hookToQuery();\n  }\n  /**需要查询的动态表单类型 */\n  enableSearchTypeList: any[] = [];\n  /**需要查询的动态表单字段 */\n  enableSearchFieldList: any[] = [];\n  /**不需要展示的动态表单类型 */\n  disableshowinTypeList: any[] = [];\n  /**需要展示的动态列表字段 */\n  showinFieldList: any[] = [];\n  /**获取动态表单类型 */\n  // getDynamicFormType() {\n  //   return new Promise((resolve, rejects) => {\n  //     this._FormAdminService.getFormControls().subscribe((res:any) => {\n  //       // this.dynamicFormTypeList = res.items;\n  //       this.enableSearchTypeList = res.items.filter(el => el.enableSearch).map(el => el.name);\n  //       resolve(res.items);\n  //     });\n  //   });\n  // }\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  /**获取站点下的版块 */\n  getSiteOfSectionList() {\n    return new Promise((resolve, rejects) => {\n      this._SectionAdminService\n        .getList({\n          maxResultCount: 1000,\n        })\n        .subscribe(async (res: any) => {\n          this.SiteOfSectionList = res.items;\n          this.filters.sectionId = res.items[0]?.id || '';\n          await this.getSectionOfEntryType();\n          resolve(res.items);\n        });\n    });\n  }\n  /**表单 */\n  enablegearchFormEntity: FormGroup | undefined = this.fb.group({\n    extraProperties: this.fb.group({}),\n  });\n\n  get extraPropertiesInput() {\n    return this.enablegearchFormEntity?.get('extraProperties') as FormGroup;\n  }\n\n  /**设置筛选条件 */\n  setfiltersValue() {\n    return new Promise((resolve, rejects) => {\n      let extraProperties = this.extraPropertiesInput.value;\n      let inputs: any[] = [];\n      for (const key in extraProperties) {\n        const element = extraProperties[key];\n        if (Array.isArray(element) ? (element.length > 0 ? element : null) : element) {\n          inputs.push({\n            name: key,\n            value: element === true ? 'True' : Array.isArray(element) ? element.join(',') : element,\n          });\n        }\n        if (element === false) {\n          inputs.push({\n            name: key,\n            value: 'False',\n          });\n        }\n      }\n      this.filters.queryingByFieldsJson = inputs.length > 0 ? JSON.stringify(inputs) : '';\n      resolve(true);\n    });\n  }\n\n  async listget() {\n    await this.setfiltersValue();\n    this.list.get();\n    // this.filters.\n  }\n\n  /**站点下板块的类型 */\n  SiteOfSectionType: any = SectionType.Single;\n\n  /**获取版块下的条目类型 */\n  async getSectionOfEntryType() {\n    // let sectionId = this.filtersForm.get('sectionId').value;\n    let sectionId = this.filters.sectionId;\n    let SectionInfo: any = await this.getSectionInfo(sectionId);\n    let _entryTypeList = SectionInfo?.entryTypes || [];\n\n    // let _entryTypeList = this.SiteOfSectionList.find(el => el.id == sectionId)?.entryTypes || [];\n    this.entryTypeList = _entryTypeList;\n    //选择板块的类型SectionType\n    this.SiteOfSectionType = this.SiteOfSectionList.find(el => el.id == sectionId)?.type;\n    if (this.SiteOfSectionType == SectionType.Structure) {\n      this.maxResultCount = 1000;\n    } else {\n      this.maxResultCount = 10;\n    }\n\n    if (_entryTypeList.length === 1) {\n      this.filters.entryTypeId = this.entryTypeList[0].id;\n      // 初始化数组\n      this.enableSearchFieldList = [];\n      this.showinFieldList = [];\n      // 使用for...of替代forEach来处理异步\n      for (const el of _entryTypeList) {\n        for (const el1 of el.fieldTabs) {\n          for (const el2 of el1.fields) {\n            // el2.field = await this.getDynamicFormEntity(el2.fieldId);\n            if (el2.enableSearch && this.enableSearchTypeList.includes(el2.field.formControlName)) {\n              this.enableSearchFieldList.push({\n                ...el2,\n                field: {\n                  formControlName: el2.field.formControlName,\n                  formConfiguration: el2.field.formConfiguration,\n                  name: el2.field.name,\n                },\n              });\n            }\n            if (el2.showInList && !this.disableshowinTypeList.includes(el2.field.formControlName)) {\n              this.showinFieldList.push(el2);\n            }\n          }\n        }\n      }\n    }\n  }\n  async abpInitss() {\n    await this.setfiltersValue();\n  }\n  /**获取板块详情 */\n  getSectionInfo(ids) {\n    return new Promise((resolve, rejects) => {\n      this._SectionAdminService.get(ids).subscribe(res => {\n        resolve(res);\n      });\n    });\n  }\n  /**获取字段详情 */\n  getDynamicFormEntity(fieldId: string) {\n    return new Promise((resolve, rejects) => {\n      this._FieldAdminService.get(fieldId).subscribe(res => {\n        resolve(res);\n      });\n    });\n  }\n\n  private config = inject(ConfigStateService);\n  private _RegionalizationService = inject(RegionalizationService);\n  /**获取版块下的语言列表 */\n  getSectionLanguagesList() {\n    return new Promise(async (resolve, rejects) => {\n      //获取所有语言 */\n      let languagesSystem = this.configState.getDeep('localization.languages');\n      //获取系统默认语言 */\n      let DefaultLanguage = this.config.getSetting('Abp.Regionalization.DefaultCultureName');\n      const configCmsSiteLanguages = this.config.getSetting('Cms.Site.Languages');\n      if (!configCmsSiteLanguages) {\n        await this.getSiteSettingsLanguages();\n      }\n      if (this.defaultCultureName) {\n        DefaultLanguage = this.defaultCultureName;\n      }\n      const LanguagesSite =\n        (configCmsSiteLanguages ? configCmsSiteLanguages.split(',') : '') ||\n        this.SiteSettingsAdminLanguages;\n      let LanguagesArray = languagesSystem.filter(el => LanguagesSite.includes(el.cultureName));\n      //获取当前选择的语言\n      let nowculture = this.filters.culture;\n      // let nowculture = this.filtersForm.get('culture').value;\n      //当前选择的语言，是否在版块的的语言列表中\n      let isexist = LanguagesArray.find(el => el.cultureName == nowculture);\n      this.filters.culture = nowculture\n        ? isexist\n          ? nowculture\n          : DefaultLanguage\n        : DefaultLanguage;\n      this.sectionLanguagesList = LanguagesArray;\n      resolve(LanguagesArray);\n    });\n  }\n\n  /**站点设置语言 */\n  SiteSettingsAdminLanguages: any[] = [];\n  /**站点设置的默认语言 */\n  defaultCultureName: any = '';\n  /**\n   * 获取站点设置语言\n   */\n  getSiteSettingsLanguages() {\n    return new Promise((resolve, rejects) => {\n      this._RegionalizationService.get().subscribe(res => {\n        this.SiteSettingsAdminLanguages = res.availableCultureNames;\n        this.defaultCultureName = res.defaultCultureName;\n        resolve(res);\n      });\n    });\n  }\n\n  resetData() {\n    this.filters = {\n      sectionId: this.filters.sectionId,\n      culture: this.filters.culture,\n    } as GetEntriesInput;\n    this.list.filter = '';\n    this.list.maxResultCount = this.maxResultCount;\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: {\n        cultureName: this.filters.culture,\n        sectionId: this.filters.sectionId,\n        entryTypeId: this.entryTypeList[0].id,\n      },\n    });\n  }\n  createCopyEntriesBtn() {\n    this.router.navigate(['/cms/admin/entries/create-copy'], {\n      queryParams: {\n        cultureName: this.filters.culture,\n        sectionId: this.filters.sectionId,\n        entryTypeId: this.entryTypeList[0].id,\n      },\n    });\n  }\n\n  /**列表相关 */\n  ColumnMode = ColumnMode;\n  data: PagedResultDto<EntryDto> | any = {\n    items: [],\n    totalCount: 0,\n  };\n\n  filters = {} as GetEntriesInput;\n\n  maxResultCount = 10;\n\n  hookToQuery() {\n    const getData = (query: ABP.PageQueryParams) =>\n      this._EntryAdminService.getList({\n        ...query,\n        ...this.filters,\n        maxResultCount: this.maxResultCount,\n      });\n    const setData = (list: PagedResultDto<EntryDto> | any) => {\n      if (this.SiteOfSectionType == SectionType.Structure) {\n        list.items = list.items.sort((a, b) => {\n          return a.order - b.order;\n        });\n      }\n      this.data = list;\n    };\n    this.list.hookToQuery(getData).subscribe(setData);\n  }\n\n  /**删除条目 */\n  deletefield(row: any) {\n    this.confirmation\n      .warn(row.displayName, this._LocalizationService.instant(`AbpUi::ItemWillBeDeletedMessage`))\n      .subscribe((status: Confirmation.Status) => {\n        if (status == 'confirm') {\n          this._EntryAdminService\n            .delete(row.id)\n            .pipe(finalize(() => {}))\n            .subscribe(res => {\n              this.toaster.success(this._LocalizationService.instant(`AbpUi::DeletedSuccessfully`));\n              this.list.get();\n            });\n        }\n      });\n  }\n\n  drop(event: any) {\n    let previousId: any = this.data.items[event.previousIndex].id;\n    let previousIndexOrder = this.data.items[event.previousIndex].order;\n    let currentIndexOrder = this.data.items[event.currentIndex].order;\n    let moveorder=currentIndexOrder\n    if(previousIndexOrder<currentIndexOrder){\n      moveorder=currentIndexOrder+1\n    }\n    moveItemInArray(this.data.items, event.previousIndex, event.currentIndex);\n    this._EntryAdminService\n      .move(previousId, {\n        order: moveorder,\n        // order: event.currentIndex,\n      })\n      .pipe(\n        finalize(() => {\n          this.list.get();\n        })\n      )\n      .subscribe(\n        res => {},\n        err => {}\n      );\n    // moveItemInArray(this.rows, event.previousIndex, event.currentIndex);\n    // this.rows = [...this.rows];\n  }\n\n  isexpanded: boolean = false;\n  /**高级筛选切换 */\n  expandedChange(event) {\n    this.isexpanded = event;\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 \">\r\n                <div class=\"row align-items-end\">\r\n                    <div class=\"mb-3 col-3\">\r\n                        <label class=\"form-label\">{{'Cms::Sections' | abpLocalization}}：</label>\r\n                        <select class=\"form-select col-auto\" [(ngModel)]=\"filters.sectionId\"\r\n                            (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-3 col-3\">\r\n                        <label class=\"form-label\">{{'AbpUi::Languages' | abpLocalization}}：</label>\r\n                        <select class=\"form-select col-auto\" [(ngModel)]=\"filters.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 class=\"mb-3 col-6\">\r\n                        <div class=\"input-group\">\r\n                            <input type=\"text\" class=\"form-control\" [(ngModel)]=\"filters.filter\"\r\n                                [placeholder]=\"'Cms::PagerSearch'|abpLocalization\" />\r\n                            <button type=\"button\" class=\"btn btn-primary\" (click)=\"listget()\">\r\n                                <i class=\"bi bi-search\"></i>\r\n                            </button>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n                @if(filters.culture&&enablegearchFormEntity&&enableSearchFieldList.length>0){\r\n                <div id=\"entries-advanced-form\" class=\"entries-advanced-form \" [hidden]=\"isexpanded\"\r\n                    (abpInit)=\"abpInitss()\">\r\n                    <form [formGroup]=\"enablegearchFormEntity\">\r\n                        <div class=\"row align-items-end\">\r\n                            <ng-container *ngFor=\"let el of enableSearchFieldList\">\r\n                                <ng-container *ngIf=\"el.field&&enablegearchFormEntity&&el.enableSearch\">\r\n                                    <div class=\"col-3\">\r\n                                        <df-dynamic-search [fields]=\"el\" [parentFiledName]=\"'extraProperties'\"\r\n                                            [culture]=\"filters.culture\"\r\n                                            [entity]=\"enablegearchFormEntity\"></df-dynamic-search>\r\n                                    </div>\r\n                                </ng-container>\r\n                            </ng-container>\r\n                            <div class=\"col-6 mb-3 \">\r\n                                <button type=\"button\" class=\"btn btn-primary\" (click)=\"listget()\">\r\n                                    <span>{{ 'AbpUi::Refresh' | abpLocalization }}</span>\r\n                                </button>\r\n                            </div>\r\n                        </div>\r\n                    </form>\r\n                </div>\r\n                }\r\n            </div>\r\n        </div>\r\n\r\n\r\n\r\n        <div class=\"card mb-0\">\r\n            <div class=\"card-body p-0\">\r\n                @if(SiteOfSectionType!==SectionType.Structure){\r\n                <div class=\"table-responsive table-fixed-header\">\r\n                    <ngx-datatable class=\"material \" [rows]=\"data.items\" [list]=\"list\" [columnMode]=\"ColumnMode.force\"\r\n                        [headerHeight]=\"50\" [footerHeight]=\"50\" rowHeight=\"auto\" [virtualization]=\"false\"\r\n                        [externalPaging]=\"true\" [count]=\"data.totalCount\" [scrollbarH]=\"true\">\r\n                        <ngx-datatable-column [name]=\"'Cms::Title' | abpLocalization\" prop=\"title\" [sortable]=\"false\">\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::EntryType' | abpLocalization\" prop=\"entryTypeId\"\r\n                            [sortable]=\"false\">\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::Slug' | abpLocalization\" prop=\"slug\" [sortable]=\"false\">\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\" [width]=\"80\"\r\n                            [sortable]=\"false\">\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                        @for (item of showinFieldList; track $index) {\r\n                        <ngx-datatable-column [name]=\"'Cms::'+item.displayName | abpLocalization\"\r\n                            [prop]=\"item?.field?.name\" [sortable]=\"false\">\r\n                            <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n                                <df-dynamic-view [type]=\"item.field.formControlName\" [showInList]=\"true\" [fields]=\"item\"\r\n                                    [value]=\"row?.extraProperties[item.field.name]\"></df-dynamic-view>\r\n                            </ng-template>\r\n                        </ngx-datatable-column>\r\n                        }\r\n                        <ngx-datatable-column [name]=\"'Cms::PublishTime' | abpLocalization\" prop=\"publishTime\"\r\n                            [width]=\"190\" [sortable]=\"false\">\r\n                            <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n                                {{value | shortDateTime }}\r\n                            </ng-template>\r\n                        </ngx-datatable-column>\r\n                        <ngx-datatable-column [sortable]=\"false\" [name]=\"'AbpUi::Actions' | abpLocalization\"\r\n                            [frozenLeft]=\"true\" [width]=\"110\" [maxWidth]=\"110\">\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-primary btn-sm\" ngbDropdownToggle>\r\n                                        <i class=\"me-1 fa fa-cog\"></i> {{'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\r\n                    </ngx-datatable>\r\n                </div>\r\n                }\r\n\r\n                @if(SiteOfSectionType===SectionType.Structure){\r\n                <div class=\"table-responsive table-fixed-header\">\r\n                    <table class=\"table overflow-nowrap mb-0\" cdkDropList (cdkDropListDropped)=\"drop($event)\">\r\n                        <thead>\r\n                            <tr>\r\n                                <th class=\"sticky-left-card-bg\">{{'AbpUi::Actions' | abpLocalization}}</th>\r\n                                <th>{{'Cms::Title' | abpLocalization}}</th>\r\n                                <th>{{'Cms::EntryType' | abpLocalization}}</th>\r\n                                <th>{{'Cms::Slug' | abpLocalization}}</th>\r\n                                <th>{{'Cms::Status' | abpLocalization}}</th>\r\n                                @for (item of showinFieldList; track $index) {\r\n                                <th>{{'Cms::'+item.displayName | abpLocalization}}</th>\r\n                                }\r\n                                <th>{{'Cms::PublishTime' | abpLocalization}}</th>\r\n                            </tr>\r\n                        </thead>\r\n                        <tbody>\r\n                            <tr *ngFor=\"let item of data.items\" cdkDrag>\r\n                                <td class=\"sticky-left-card-bg\">\r\n                                    <div ngbDropdown container=\"body\">\r\n                                        <button type=\"button\" class=\"btn btn-primary btn-sm\" ngbDropdownToggle>\r\n                                            <i class=\"me-1 fa fa-cog\"></i> {{'AbpUi::Actions' | abpLocalization}}\r\n                                        </button>\r\n                                        <div ngbDropdownMenu>\r\n                                            <button ngbDropdownItem\r\n                                                routerLink=\"/cms/admin/entries/{{item.id}}/edit\">{{'AbpUi::Edit' |\r\n                                                abpLocalization}}</button>\r\n                                            <button ngbDropdownItem (click)=\"deletefield(item)\">{{'AbpUi::Delete' |\r\n                                                abpLocalization}}</button>\r\n                                        </div>\r\n                                    </div>\r\n                                </td>\r\n                                <td class=\"white-space-normal\">{{item.title}}</td>\r\n                                <td>\r\n                                    <ng-container *ngFor=\"let item1 of entryTypeList\">\r\n                                        <ng-container\r\n                                            *ngIf=\"item1.id === item.entryTypeId\">{{item1.displayName}}</ng-container>\r\n                                    </ng-container>\r\n                                </td>\r\n                                <td>{{item.slug}}</td>\r\n                                <td>\r\n                                    <ng-container *ngFor=\"let item2 of _entryStatusOptions\">\r\n                                        <ng-container *ngIf=\"item.status=== item2.value\">{{\r\n                                            'Cms::Enum:EntryStatus:'+item2.key |\r\n                                            abpLocalization }}</ng-container>\r\n                                    </ng-container>\r\n                                </td>\r\n                                @for (item1 of showinFieldList; track $index) {\r\n                                <td>\r\n                                    <df-dynamic-view [type]=\"item1.field.formControlName\" [showInList]=\"true\" [fields]=\"item1\"\r\n                                    [value]=\"item?.extraProperties[item1.field.name]\"></df-dynamic-view>\r\n\r\n                                </td>\r\n                                }\r\n                                <td>{{item.publishTime | shortDateTime }}</td>\r\n                            </tr>\r\n                        </tbody>\r\n                        @if(data.items.length === 0){\r\n                        <div class=\"text-muted p-2\">\r\n                            {{ 'Cms::NoDataAvailableInDatatable' | abpLocalization}}\r\n                        </div>\r\n                        }\r\n                    </table>\r\n                </div>\r\n                <div class=\"card-footer py-2\">\r\n                    <small class=\"text-muted\"> {{data.totalCount}} {{ 'Cms::Total' | abpLocalization}}</small>\r\n                </div>\r\n                }\r\n\r\n            </div>\r\n        </div>\r\n\r\n\r\n\r\n\r\n\r\n\r\n    </div>\r\n</abp-page>"]}
|