@dignite-ng/expand.cms 0.0.55 → 0.0.56
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/config/components/domains/domains.component.mjs +3 -3
- package/esm2022/lib/cms-routing.module.mjs +1 -1
- package/esm2022/lib/cms.module.mjs +6 -3
- package/esm2022/lib/components/admin/entries/create-or-edit-entries.component.mjs +145 -227
- package/esm2022/lib/components/admin/entries/create-or-update-entry-input-base.mjs +4 -11
- package/esm2022/lib/components/admin/entries/create.component.mjs +77 -56
- package/esm2022/lib/components/admin/entries/edit.component.mjs +75 -52
- package/esm2022/lib/components/admin/entries/entries.component.mjs +6 -1
- package/esm2022/lib/components/admin/fields/create-field.component.mjs +10 -2
- package/esm2022/lib/components/admin/fields/create-or-edit-field.component.mjs +12 -6
- package/esm2022/lib/components/admin/fields/edit-field.component.mjs +7 -4
- package/esm2022/lib/components/admin/sections/entry-types/create-or-edit.component.mjs +12 -6
- package/esm2022/lib/components/admin/sections/sections.component.mjs +11 -4
- package/esm2022/lib/components/dynamic-form/entry/entry-config.component.mjs +14 -12
- package/esm2022/lib/components/dynamic-form/entry/entry-control.component.mjs +9 -13
- package/esm2022/lib/components/dynamic-form/matrix/matrix-config.component.mjs +15 -17
- package/esm2022/lib/components/dynamic-form/matrix/matrix-control.component.mjs +18 -22
- package/esm2022/lib/components/dynamic-form/table/table-config.component.mjs +3 -3
- package/esm2022/lib/components/dynamic-form/table/table-control.component.mjs +3 -3
- package/esm2022/lib/constants/styles.mjs +2 -4
- package/esm2022/lib/resolvers/page-default-toolbar-actions.mjs +1 -1
- package/esm2022/lib/resolvers/table-default-entity-props.mjs +1 -2
- package/fesm2022/dignite-ng-expand.cms-config.mjs +2 -2
- package/fesm2022/dignite-ng-expand.cms-config.mjs.map +1 -1
- package/fesm2022/dignite-ng-expand.cms.mjs +391 -415
- package/fesm2022/dignite-ng-expand.cms.mjs.map +1 -1
- package/lib/cms.module.d.ts +2 -1
- package/lib/components/admin/entries/create-or-edit-entries.component.d.ts +34 -69
- package/lib/components/admin/entries/create-or-update-entry-input-base.d.ts +3 -3
- package/lib/components/admin/entries/create.component.d.ts +26 -23
- package/lib/components/admin/entries/edit.component.d.ts +29 -23
- package/lib/components/admin/entries/entries.component.d.ts +1 -0
- package/lib/components/admin/sections/sections.component.d.ts +1 -0
- package/lib/components/dynamic-form/entry/entry-config.component.d.ts +4 -4
- package/lib/components/dynamic-form/matrix/matrix-config.component.d.ts +4 -4
- package/lib/components/dynamic-form/matrix/matrix-control.component.d.ts +5 -5
- package/lib/constants/styles.d.ts +1 -1
- package/package.json +1 -1
|
@@ -1,228 +1,151 @@
|
|
|
1
|
-
import { ConfigStateService } from '@abp/ng.core';
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
1
|
+
import { ConfigStateService, LocalizationService } from '@abp/ng.core';
|
|
2
|
+
import { ToasterService } from '@abp/ng.theme.shared';
|
|
3
|
+
import { Component, inject, Input, ViewChild, } from '@angular/core';
|
|
4
|
+
import { Router } from '@angular/router';
|
|
5
|
+
import { EntryAdminService } from '../../../proxy/admin/entries';
|
|
6
|
+
import { SectionAdminService } from '../../../proxy/admin/sections';
|
|
7
|
+
import { DatePipe, Location } from '@angular/common';
|
|
8
|
+
import { CmsApiService } from '../../../services';
|
|
4
9
|
import * as i0 from "@angular/core";
|
|
5
|
-
import * as i1 from "@
|
|
6
|
-
import * as i2 from "@angular/
|
|
7
|
-
import * as i3 from "@
|
|
8
|
-
import * as i4 from "
|
|
9
|
-
import * as i5 from "
|
|
10
|
-
import * as i6 from "@
|
|
11
|
-
import * as i7 from "
|
|
12
|
-
import * as i8 from "@angular/forms";
|
|
13
|
-
import * as i9 from "@ngx-validate/core";
|
|
14
|
-
import * as i10 from "@ng-bootstrap/ng-bootstrap";
|
|
15
|
-
import * as i11 from "@dignite-ng/expand.dynamic-form";
|
|
10
|
+
import * as i1 from "@angular/common";
|
|
11
|
+
import * as i2 from "@angular/forms";
|
|
12
|
+
import * as i3 from "@angular/router";
|
|
13
|
+
import * as i4 from "@abp/ng.core";
|
|
14
|
+
import * as i5 from "@ngx-validate/core";
|
|
15
|
+
import * as i6 from "@ng-bootstrap/ng-bootstrap";
|
|
16
|
+
import * as i7 from "@dignite-ng/expand.dynamic-form";
|
|
16
17
|
export class CreateOrEditEntriesComponent {
|
|
17
|
-
constructor(
|
|
18
|
-
this.toaster =
|
|
19
|
-
this._location =
|
|
20
|
-
this.configState =
|
|
21
|
-
this._SectionAdminService =
|
|
22
|
-
this._EntryAdminService =
|
|
23
|
-
this.datePipe =
|
|
24
|
-
this._LocalizationService =
|
|
25
|
-
this.router =
|
|
26
|
-
this._CmsApiService =
|
|
27
|
-
/**语言 */
|
|
28
|
-
this.cultureName = '';
|
|
29
|
-
/**条目类型id */
|
|
30
|
-
this.entryTypeId = '';
|
|
31
|
-
/**新建版本的版本id,同条目id */
|
|
32
|
-
this.RevisionEntryId = '';
|
|
33
|
-
/**选择的条目项 */
|
|
34
|
-
this.entryTypesItem = '';
|
|
35
|
-
/**版块id */
|
|
36
|
-
this.sectionId = '';
|
|
37
|
-
/**版块详情 */
|
|
38
|
-
this.SectionSelect = '';
|
|
18
|
+
constructor() {
|
|
19
|
+
this.toaster = inject(ToasterService);
|
|
20
|
+
this._location = inject(Location);
|
|
21
|
+
this.configState = inject(ConfigStateService);
|
|
22
|
+
this._SectionAdminService = inject(SectionAdminService);
|
|
23
|
+
this._EntryAdminService = inject(EntryAdminService);
|
|
24
|
+
this.datePipe = inject(DatePipe);
|
|
25
|
+
this._LocalizationService = inject(LocalizationService);
|
|
26
|
+
this.router = inject(Router);
|
|
27
|
+
this._CmsApiService = inject(CmsApiService);
|
|
39
28
|
/**语言列表 */
|
|
40
29
|
this.languagesList = [];
|
|
41
|
-
|
|
42
|
-
this.
|
|
30
|
+
/**条目列表-选择上级条目 */
|
|
31
|
+
this.entryList = [];
|
|
32
|
+
/**条目信息 */
|
|
33
|
+
this.entryInfo = '';
|
|
34
|
+
/**版本信息 */
|
|
35
|
+
this.sectionInfo = '';
|
|
36
|
+
/**需要展示的b板块下条目类型 */
|
|
37
|
+
this.showEntryType = '';
|
|
38
|
+
/**版本条目id */
|
|
39
|
+
this.entryVersionId = '';
|
|
43
40
|
/**版本列表 */
|
|
44
41
|
this.AllVersionsList = [];
|
|
45
|
-
/**是否是编辑 */
|
|
46
42
|
this.isEdit = false;
|
|
47
|
-
|
|
48
|
-
this.
|
|
49
|
-
|
|
50
|
-
this.
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
this.
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
set parentEntrySelect(v) {
|
|
65
|
-
if (v) {
|
|
66
|
-
let V_extraProperties = this._CmsApiService.deepClone(this.convertExtraProperties(v.extraProperties));
|
|
67
|
-
v.extraProperties = V_extraProperties;
|
|
68
|
-
this.entrySelect = v;
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
/**将对象中的ExtraProperties赋值到extraProperties */
|
|
72
|
-
convertExtraProperties(obj) {
|
|
73
|
-
for (let key in obj) {
|
|
74
|
-
if (Array.isArray(obj[key])) {
|
|
75
|
-
obj[key].forEach(item => {
|
|
76
|
-
if (item.hasOwnProperty('ExtraProperties')) {
|
|
77
|
-
item['extraProperties'] = item['ExtraProperties'];
|
|
78
|
-
}
|
|
79
|
-
});
|
|
80
|
-
}
|
|
43
|
+
this.sectionId = '';
|
|
44
|
+
this.entryTypeId = '';
|
|
45
|
+
/**是否加载完成 */
|
|
46
|
+
this.isLoad = false;
|
|
47
|
+
}
|
|
48
|
+
set select(v) {
|
|
49
|
+
this.entryVersionId = v.id;
|
|
50
|
+
this.entryInfo = v;
|
|
51
|
+
}
|
|
52
|
+
set entity(value) {
|
|
53
|
+
this.formEntity = value;
|
|
54
|
+
if (value) {
|
|
55
|
+
let languages = this.configState.getDeep('localization.languages');
|
|
56
|
+
this.languagesList = languages;
|
|
57
|
+
this.loadData();
|
|
81
58
|
}
|
|
82
|
-
return obj;
|
|
83
|
-
}
|
|
84
|
-
/**别名表单实体 */
|
|
85
|
-
get sluginput() {
|
|
86
|
-
return this._entity.get('slug');
|
|
87
59
|
}
|
|
88
|
-
|
|
60
|
+
/**语言控件 */
|
|
89
61
|
get cultureInput() {
|
|
90
|
-
return this.
|
|
62
|
+
return this.formEntity?.get('culture');
|
|
91
63
|
}
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
get extraProperties() {
|
|
98
|
-
return this._entity.get('extraProperties');
|
|
99
|
-
}
|
|
100
|
-
async ngAfterContentInit() {
|
|
101
|
-
//Called after ngOnInit when the component's or directive's content has been initialized.
|
|
102
|
-
//Add 'implements AfterContentInit' to the class.
|
|
103
|
-
let queryParams = this.FromParentQueryParams;
|
|
104
|
-
if (this._entity && this.FromParentQueryParams) {
|
|
105
|
-
this._entity.setControl('slug', new FormControl('', {
|
|
106
|
-
validators: Validators.required,
|
|
107
|
-
asyncValidators: this.repetitionAsyncValidator(),
|
|
108
|
-
updateOn: 'blur'
|
|
109
|
-
}));
|
|
110
|
-
this._entity.setControl('culture_shadow', new FormControl('', {
|
|
111
|
-
asyncValidators: this.cultureAsyncValidator_test(),
|
|
112
|
-
updateOn: 'blur'
|
|
113
|
-
}));
|
|
114
|
-
if (queryParams.RevisionEntryId && this.entrySelect) {
|
|
115
|
-
this.RevisionEntryId = queryParams.RevisionEntryId;
|
|
116
|
-
this.setEntryconfig(this.entrySelect);
|
|
117
|
-
}
|
|
118
|
-
else {
|
|
119
|
-
this.setEntryconfig(queryParams);
|
|
120
|
-
}
|
|
121
|
-
if (this.sectionId)
|
|
122
|
-
await this.getSectionSelect();
|
|
123
|
-
if (this.RevisionEntryId)
|
|
124
|
-
await this.getAllVersionsList();
|
|
125
|
-
this.culture_shadowInput.patchValue(this.cultureInput.value);
|
|
126
|
-
this._entity.get('culture').disable();
|
|
127
|
-
this.submitclick?.nativeElement?.click();
|
|
64
|
+
/**加载数据 */
|
|
65
|
+
async loadData() {
|
|
66
|
+
if (this.sectionId) {
|
|
67
|
+
await this.getSectionInfo();
|
|
68
|
+
await this.getEntryList();
|
|
128
69
|
}
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
this.
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
entryTypeId: this.entryTypeId
|
|
144
|
-
}).subscribe(res => {
|
|
145
|
-
if (res) {
|
|
146
|
-
resolve({ repetition: this._LocalizationService.instant(`Cms::EntriesAlreadyExistEntryType`, this.entryTypesItem.displayName, this.languagesList.find(el => el.cultureName == subculture).displayName) });
|
|
147
|
-
}
|
|
148
|
-
else {
|
|
149
|
-
resolve(null);
|
|
150
|
-
}
|
|
151
|
-
});
|
|
70
|
+
this.cultureInput.disable();
|
|
71
|
+
let repetition = await this.cultureAsyncValidator();
|
|
72
|
+
if (repetition)
|
|
73
|
+
this.cultureInput.setErrors(repetition);
|
|
74
|
+
if (this.entryInfo) {
|
|
75
|
+
await this.getAllVersionsList();
|
|
76
|
+
this.formEntity.patchValue({
|
|
77
|
+
entryTypeId: this.entryInfo.entryTypeId,
|
|
78
|
+
publishTime: this.entryInfo.publishTime,
|
|
79
|
+
title: this.entryInfo.title,
|
|
80
|
+
slug: this.entryInfo.slug,
|
|
81
|
+
parentId: this.entryInfo.parentId,
|
|
82
|
+
versionNotes: this.entryInfo.versionNotes,
|
|
83
|
+
initialVersionId: this.entryInfo.id,
|
|
152
84
|
});
|
|
153
|
-
}
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
this.
|
|
161
|
-
|
|
162
|
-
|
|
85
|
+
}
|
|
86
|
+
else {
|
|
87
|
+
this.formEntity.patchValue({
|
|
88
|
+
entryTypeId: this.entryTypeId,
|
|
89
|
+
publishTime: this.datePipe.transform(new Date(), 'yyyy-MM-dd HH:mm:ss'),
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
this.isLoad = true;
|
|
93
|
+
setTimeout(() => {
|
|
94
|
+
this.submitclick?.nativeElement.click();
|
|
95
|
+
}, 0);
|
|
163
96
|
}
|
|
164
97
|
/**定义自定义异步验证 */
|
|
165
|
-
|
|
166
|
-
return (
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
98
|
+
cultureAsyncValidator() {
|
|
99
|
+
return new Promise(resolve => {
|
|
100
|
+
let culture = this.cultureInput.value;
|
|
101
|
+
if (culture == this.entryInfo?.culture || this.sectionInfo.type !== 0)
|
|
102
|
+
return resolve(null);
|
|
103
|
+
this._EntryAdminService
|
|
104
|
+
.cultureExistWithSingleSection({
|
|
105
|
+
culture: culture,
|
|
106
|
+
sectionId: this.sectionId,
|
|
107
|
+
entryTypeId: this.entryTypeId,
|
|
108
|
+
})
|
|
109
|
+
.subscribe(res => {
|
|
110
|
+
if (res) {
|
|
111
|
+
resolve({
|
|
112
|
+
repetition: this._LocalizationService.instant(`Cms::EntriesAlreadyExistEntryType`, '', this.languagesList.find(el => el.cultureName == culture).displayName),
|
|
113
|
+
});
|
|
114
|
+
}
|
|
115
|
+
else {
|
|
170
116
|
resolve(null);
|
|
171
|
-
return;
|
|
172
117
|
}
|
|
173
|
-
this._EntryAdminService.slugExists({
|
|
174
|
-
culture: this.cultureName,
|
|
175
|
-
sectionId: this.sectionId,
|
|
176
|
-
slug: subslug
|
|
177
|
-
}).subscribe(res => {
|
|
178
|
-
if (res) {
|
|
179
|
-
resolve({ repetition: this._LocalizationService.instant(`Cms::EntrySlug{0}AlreadyExist`, ctrl.value) });
|
|
180
|
-
}
|
|
181
|
-
else {
|
|
182
|
-
resolve(null);
|
|
183
|
-
}
|
|
184
|
-
});
|
|
185
118
|
});
|
|
186
|
-
};
|
|
119
|
+
});
|
|
187
120
|
}
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
return new Promise((resolve,
|
|
191
|
-
this._SectionAdminService.get(this.sectionId).subscribe(
|
|
192
|
-
|
|
193
|
-
this.
|
|
194
|
-
|
|
195
|
-
this.SectionSelect = res;
|
|
196
|
-
await this.getTypeEntryList();
|
|
197
|
-
this.entryTypesItem = entryTypesItem;
|
|
198
|
-
this.entryTypesList = res.entryTypes.filter(el => el.id == this.entryTypeId);
|
|
199
|
-
this._entity.patchValue({
|
|
200
|
-
...this.entrySelect,
|
|
201
|
-
initialVersionId: this.entrySelect?.initialVersionId || this.RevisionEntryId || '',
|
|
202
|
-
culture: this.cultureName,
|
|
203
|
-
entryTypeId: this.entryTypeId,
|
|
204
|
-
publishTime: this.datePipe.transform(new Date(), 'yyyy-MM-dd HH:mm:ss'),
|
|
205
|
-
});
|
|
206
|
-
resolve(true);
|
|
121
|
+
/**获取板块信息 */
|
|
122
|
+
getSectionInfo() {
|
|
123
|
+
return new Promise((resolve, reject) => {
|
|
124
|
+
this._SectionAdminService.get(this.sectionId).subscribe(res => {
|
|
125
|
+
this.showEntryType = res.entryTypes.find(el => el.id == this.entryTypeId);
|
|
126
|
+
this.sectionInfo = res;
|
|
127
|
+
resolve(res);
|
|
207
128
|
});
|
|
208
129
|
});
|
|
209
130
|
}
|
|
210
|
-
|
|
211
|
-
|
|
131
|
+
/**获取板块下所有条目 */
|
|
132
|
+
getEntryList() {
|
|
212
133
|
return new Promise((resolve, rejects) => {
|
|
213
|
-
this._EntryAdminService
|
|
134
|
+
this._EntryAdminService
|
|
135
|
+
.getList({
|
|
214
136
|
sectionId: this.sectionId,
|
|
215
137
|
maxResultCount: 1000,
|
|
216
|
-
culture: this.
|
|
217
|
-
})
|
|
218
|
-
|
|
219
|
-
let
|
|
138
|
+
culture: this.cultureInput.value,
|
|
139
|
+
})
|
|
140
|
+
.subscribe((res) => {
|
|
141
|
+
let entryList = res.items.filter(el => el.id !== this.entryInfo?.id);
|
|
142
|
+
let parentList = entryList.filter(el => !el.parentId);
|
|
220
143
|
parentList.forEach(el => {
|
|
221
144
|
let layer = 0;
|
|
222
145
|
el.layer = new Array(layer);
|
|
223
|
-
el.children = this.groupByParentId(
|
|
146
|
+
el.children = this.groupByParentId(entryList, el.id, layer + 1);
|
|
224
147
|
});
|
|
225
|
-
this.
|
|
148
|
+
this.entryList = parentList;
|
|
226
149
|
resolve(res);
|
|
227
150
|
});
|
|
228
151
|
});
|
|
@@ -233,38 +156,34 @@ export class CreateOrEditEntriesComponent {
|
|
|
233
156
|
result = arr.filter(el => el.parentId == id);
|
|
234
157
|
result.forEach(el => {
|
|
235
158
|
el.layer = new Array(layer);
|
|
236
|
-
el.children = this.groupByParentId(arr, el.id,
|
|
159
|
+
el.children = this.groupByParentId(arr, el.id, layer + 1);
|
|
237
160
|
});
|
|
238
161
|
return result;
|
|
239
162
|
}
|
|
240
|
-
/**获取条目版本列表 */
|
|
241
|
-
getAllVersionsList() {
|
|
242
|
-
return new Promise((resolve, rejects) => {
|
|
243
|
-
this._EntryAdminService.getAllVersions(this.RevisionEntryId).subscribe(res => {
|
|
244
|
-
this.AllVersionsList = res.items;
|
|
245
|
-
resolve(res);
|
|
246
|
-
});
|
|
247
|
-
});
|
|
248
|
-
}
|
|
249
163
|
/**标题转化别名 */
|
|
250
164
|
setTitleToSlugBlur(event) {
|
|
251
165
|
let val = event.target.value;
|
|
252
|
-
let slug = this.
|
|
166
|
+
let slug = this.formEntity.get('slug');
|
|
253
167
|
let pinyinstr = '';
|
|
254
168
|
if (slug.value)
|
|
255
169
|
return;
|
|
256
170
|
pinyinstr = this._CmsApiService.chineseToPinyin(val);
|
|
257
|
-
this.
|
|
258
|
-
slug: pinyinstr || val
|
|
171
|
+
this.formEntity.patchValue({
|
|
172
|
+
slug: pinyinstr || val,
|
|
259
173
|
});
|
|
260
174
|
}
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
return
|
|
175
|
+
/**获取条目版本列表 */
|
|
176
|
+
getAllVersionsList() {
|
|
177
|
+
return new Promise((resolve, rejects) => {
|
|
178
|
+
this._EntryAdminService.getAllVersions(this.entryInfo.id).subscribe(res => {
|
|
179
|
+
this.AllVersionsList = res.items;
|
|
180
|
+
resolve(res);
|
|
181
|
+
});
|
|
182
|
+
});
|
|
264
183
|
}
|
|
265
184
|
/**激活 */
|
|
266
185
|
ActivatedVersion(VersionId) {
|
|
267
|
-
this._EntryAdminService.activate(VersionId).subscribe(
|
|
186
|
+
this._EntryAdminService.activate(VersionId).subscribe(res => {
|
|
268
187
|
this.AllVersionsList.forEach(el => {
|
|
269
188
|
el.isActivatedVersion = el.id === VersionId;
|
|
270
189
|
});
|
|
@@ -284,25 +203,24 @@ export class CreateOrEditEntriesComponent {
|
|
|
284
203
|
this.getAllVersionsList();
|
|
285
204
|
});
|
|
286
205
|
}
|
|
287
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: CreateOrEditEntriesComponent, deps: [
|
|
288
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.5", type: CreateOrEditEntriesComponent, selector: "cms-create-or-edit-entries", inputs: { isEdit: "isEdit", ParentQueryParams: "ParentQueryParams", entity: "entity", parentEntrySelect: "parentEntrySelect" }, viewQueries: [{ propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }, { propertyName: "FormDynamicontrolRef", predicate: ["FormDynamicontrolRef"], descendants: true, read: ViewContainerRef }], ngImport: i0, template: "<form class=\"create-or-edit-entry-page\" [formGroup]=\"_entity\">\n <button type=\"submit\" style=\"display: none;\" #submitclick></button>\n <div class=\"container \">\n <div class=\"row\">\n <div class=\"col-md-8 \">\n <div class=\"card p-2\">\n <div class=\"mb-3\">\n <label class=\"form-label\" for=\"title\">{{'Cms::Title' | abpLocalization}}</label>\n <input type=\"text\" class=\"form-control\" (blur)=\"setTitleToSlugBlur($event)\"\n formControlName=\"title\">\n </div>\n <ng-container *ngFor=\"let item of entryTypesItem?.fieldTabs;let i =index\">\n <ng-container *ngFor=\"let el of item.fields;let i1 =index\">\n <ng-container *ngIf=\"el&&_entity\">\n <df-dynamic [entity]=\"_entity\" [fields]=\"el\"\n [selected]=\"entrySelect ? entrySelect.extraProperties[el.field.name] : ''\"\n [parentFiledName]=\"'extraProperties'\" [culture]=\"cultureInput.value\"></df-dynamic>\n </ng-container>\n </ng-container>\n </ng-container>\n </div>\n </div>\n <div class=\"col-md-4 \">\n <div class=\"card mb-0 p-2\">\n <div class=\"mb-3\">\n <label class=\"form-label\" for=\"slug\">{{'Cms::Slug' | abpLocalization}}</label>\n <input type=\"text\" class=\"form-control\" formControlName=\"slug\">\n <div class=\"text-danger invalid-feedback\" *ngIf=\"sluginput.errors?.repetition\">\n {{sluginput.errors?.repetition}}\n </div>\n </div>\n <div class=\"mb-3\">\n <label class=\"form-label\" for=\"culture\">{{'AbpUi::Languages' | abpLocalization}}</label>\n <select class=\"form-select \" formControlName=\"culture\">\n <ng-container *ngFor=\"let item of languagesList;let i =index\">\n <option [value]=\"item.cultureName\">{{item.displayName}}</option>\n </ng-container>\n </select>\n <input type=\"text\" formControlName=\"culture_shadow\"\n style=\"position: absolute;z-index: -1;opacity: 0;\">\n <div class=\"text-danger invalid-feedback\" *ngIf=\"culture_shadowInput?.errors?.repetition\">\n {{culture_shadowInput?.errors?.repetition}}\n </div>\n </div>\n <div class=\"mb-3\" *ngIf=\"SectionSelect.type===1\">\n <label class=\"form-label\" for=\"parentId\">{{'Cms::ParentEntry' | abpLocalization}}</label>\n <select class=\"form-select\" formControlName=\"parentId\">\n <option value=\"\"></option>\n <ng-container *ngFor=\"let item of entryTypesList;let i =index\">\n <option [value]=\"item.id\">{{item.title}}</option>\n <ng-container *ngFor=\"let el of item.children\">\n <ng-container *ngTemplateOutlet=\"childTemplate; context: {\n $implicit: {\n value: el,\n }\n }\"></ng-container>\n <ng-template #childTemplate let-data>\n <option [value]=\"data.value.id\">\n <ng-container *ngFor=\"let item of data.value.layer\">--</ng-container>\n {{data.value.title}}\n </option>\n <ng-container *ngFor=\"let el of data.value.children\">\n <ng-container *ngTemplateOutlet=\"childTemplate; context: {\n $implicit: {\n value: el,\n }\n }\"></ng-container>\n </ng-container>\n\n </ng-template>\n </ng-container>\n\n </ng-container>\n </select>\n\n\n\n </div>\n <div class=\"mb-3\">\n <label class=\"form-label\" for=\"publishTime\">{{'Cms::PublishTime' | abpLocalization}}</label>\n <input type=\"datetime-local\" class=\"form-control\" step=\"1\" formControlName=\"publishTime\">\n </div>\n <div class=\"mb-3\" *ngIf=\"isEdit\">\n <label class=\"form-label\" for=\"publishTime\">{{'Cms::Version' | abpLocalization}}</label>\n <ul class=\"list-group\">\n <ng-container *ngFor=\"let item of AllVersionsList\">\n <li class=\"list-group-item flex-between\">\n <div>\n {{item.initialVersionId?(item.creationTime| date: 'YYYY/MM/dd HH:mm:s'):('Cms::InitialVersion' | abpLocalization)}}\n <span class=\"badge text-bg-success ms-1\"\n *ngIf=\"item.isActivatedVersion\">{{'Cms::IsActive' | abpLocalization}}</span>\n <span class=\"badge text-bg-primary ms-1\"\n *ngIf=\"item.id === RevisionEntryId\">{{'Cms::Editing' |\n abpLocalization}}</span>\n </div>\n <div>\n <div ngbDropdown class=\"d-inline-block\">\n <button type=\"button\" class=\"btn btn-link-primary p-2 \"\n style=\"line-height: 0;\" id=\"dropdownBasic1\" ngbDropdownToggle>\n </button>\n <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\">\n <button ngbDropdownItem type=\"button\" *ngIf=\"!item.isActivatedVersion\"\n (click)=\"ActivatedVersion(item.id)\">\n <i class=\"fas fa-check me-1\"></i>{{'Cms::IsActive' |\n abpLocalization}}\n </button>\n <button ngbDropdownItem type=\"button\"\n routerLink=\"/cms/admin/entries/create\"\n [queryParams]=\"{RevisionEntryId:item.id}\">\n <i class=\"fas fa-plus me-1\"></i>{{'Cms::NewVersion' |\n abpLocalization}}\n </button>\n <button ngbDropdownItem type=\"button\" (click.stop)=\"toEditUrl(item.id)\"\n *ngIf=\"item.id !== RevisionEntryId\">\n <i class=\"fas fa-edit me-1\"></i>{{'AbpUi::Edit' | abpLocalization}}\n </button>\n <button ngbDropdownItem type=\"button\"\n (click.stop)=\"delectVersion(item.id)\"\n *ngIf=\"item.initialVersionId&&!item.isActivatedVersion&&item.id !== RevisionEntryId\">\n <i class=\"fas fa-trash me-1\"></i>{{'AbpUi::Delete' |\n abpLocalization}}\n </button>\n </div>\n </div>\n </div>\n </li>\n </ng-container>\n </ul>\n </div>\n <div class=\"mb-3\">\n <label class=\"form-label\" for=\"versionNotes\">{{'Cms::RevisionNotes' | abpLocalization}}</label>\n <textarea class=\"form-control\" formControlName=\"versionNotes\" rows=\"3\"></textarea>\n </div>\n </div>\n </div>\n </div>\n </div>\n</form>", styles: ["::ng-deep .create-or-edit-entry-page .dignite_page{height:calc(100vh - 125px);overflow:auto;background:transparent}::ng-deep .create-or-edit-entry-page .form-control,::ng-deep .create-or-edit-entry-page .form-select{padding:.475rem 1.25rem}::ng-deep .create-or-edit-entry-page .cursor-move{cursor:move}::ng-deep .create-or-edit-entry-page .bordernNavs{border:var(--bs-border-width) solid var(--lpx-border-color);padding-left:inherit;padding-right:inherit}::ng-deep .create-or-edit-entry-page .flex-between{display:flex;align-items:center;justify-content:space-between}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i8.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i8.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i8.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i8.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i8.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i8.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i8.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i8.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i6.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i3.StopPropagationDirective, selector: "[click.stop]", outputs: ["click.stop"] }, { kind: "directive", type: i9.ValidationGroupDirective, selector: "[formGroup],[formGroupName]", exportAs: ["validationGroup"] }, { kind: "directive", type: i9.ValidationDirective, selector: "[formControl],[formControlName]", exportAs: ["validationDirective"] }, { 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.DynamicComponent, selector: "df-dynamic", inputs: ["selected", "type", "entity", "culture", "parentFiledName", "fields"] }, { kind: "pipe", type: i2.DatePipe, name: "date" }, { kind: "pipe", type: i3.LocalizationPipe, name: "abpLocalization" }] }); }
|
|
206
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: CreateOrEditEntriesComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
207
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.5", type: CreateOrEditEntriesComponent, selector: "cms-create-or-edit-entries", inputs: { isEdit: "isEdit", sectionId: "sectionId", entryTypeId: "entryTypeId", select: "select", entity: "entity" }, viewQueries: [{ propertyName: "submitclick", first: true, predicate: ["submitclick"], descendants: true, static: true }], ngImport: i0, template: "<form [formGroup]=\"formEntity\">\r\n <div class=\"row\">\r\n <div class=\"col-md-8\">\r\n <div class=\"card\">\r\n <div class=\"card-body\">\r\n <div class=\"mb-3\">\r\n <div class=\"form-label\">{{'Cms::Title' | abpLocalization}}</div>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"title\"\r\n (blur)=\"setTitleToSlugBlur($event)\">\r\n </div>\r\n <i></i>\r\n <ng-container *ngIf=\"isLoad\">\r\n <ng-container *ngFor=\"let item of showEntryType?.fieldTabs;let i =index\">\r\n <ng-container *ngFor=\"let el of item.fields;let i1 =index\">\r\n <ng-container *ngIf=\"el&&formEntity\">\r\n <df-dynamic [fields]=\"el\"\r\n [selected]=\"entryInfo ? entryInfo.extraProperties[el.field.name] : ''\"\r\n [parentFiledName]=\"'extraProperties'\"\r\n [culture]=\"cultureInput.value\" [entity]=\"formEntity\"></df-dynamic>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"col-md-4\">\r\n <div class=\"card\">\r\n <div class=\"card-body\">\r\n <div class=\"mb-3\">\r\n <div class=\"form-label\">{{'Cms::Slug' | abpLocalization}}</div>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"slug\">\r\n </div>\r\n <div class=\"mb-3\">\r\n <div class=\"form-label\">{{'AbpUi::Languages' | abpLocalization}}</div>\r\n <select class=\"form-select \" formControlName=\"culture\">\r\n <ng-container *ngFor=\"let item of languagesList;let i =index\">\r\n <option [value]=\"item.cultureName\">{{item.displayName}}</option>\r\n </ng-container>\r\n </select>\r\n <div class=\"text-danger\" *ngIf=\"cultureInput.dirty\">\r\n {{cultureInput?.errors?.repetition}}\r\n </div>\r\n </div>\r\n <div class=\"mb-3\" *ngIf=\"sectionInfo.type===1\">\r\n <label class=\"form-label\" for=\"parentId\">{{'Cms::ParentEntry' | abpLocalization}}</label>\r\n <select class=\"form-select\" formControlName=\"parentId\">\r\n <option value=\"\"></option>\r\n <ng-container *ngFor=\"let item of entryList;let i =index\">\r\n <option [value]=\"item.id\">{{item.title}}</option>\r\n <ng-container *ngFor=\"let el of item.children\">\r\n <ng-container *ngTemplateOutlet=\"childTemplate; context: {\r\n $implicit: {\r\n value: el,\r\n }\r\n }\"></ng-container>\r\n <ng-template #childTemplate let-data>\r\n <option [value]=\"data.value.id\">\r\n <ng-container *ngFor=\"let item of data.value.layer\">--</ng-container>\r\n {{data.value.title}}\r\n </option>\r\n <ng-container *ngFor=\"let el of data.value.children\">\r\n <ng-container *ngTemplateOutlet=\"childTemplate; context: {\r\n $implicit: {\r\n value: el,\r\n }\r\n }\"></ng-container>\r\n </ng-container>\r\n </ng-template>\r\n </ng-container>\r\n </ng-container>\r\n </select>\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"publishTime\">{{'Cms::PublishTime' | abpLocalization}}</label>\r\n <input type=\"datetime-local\" class=\"form-control\" step=\"1\" formControlName=\"publishTime\">\r\n </div>\r\n <div class=\"mb-3\" *ngIf=\"isEdit\">\r\n <label class=\"form-label\" for=\"publishTime\">{{'Cms::Version' | abpLocalization}}</label>\r\n <ul class=\"list-group\">\r\n <ng-container *ngFor=\"let item of AllVersionsList\">\r\n <li\r\n class=\"list-group-item flex-between d-flex align-items-center justify-content-between\">\r\n <div>\r\n {{item.initialVersionId?(item.creationTime| date: 'YYYY/MM/dd HH:mm:s'):('Cms::InitialVersion' | abpLocalization)}}\r\n <span class=\"badge text-bg-success ms-1\"\r\n *ngIf=\"item.isActivatedVersion\">{{'Cms::IsActive' | abpLocalization}}</span>\r\n <span class=\"badge text-bg-primary ms-1\"\r\n *ngIf=\"item.id === entryVersionId\">{{'Cms::Editing' |\r\n abpLocalization}}</span>\r\n </div>\r\n <div>\r\n <div ngbDropdown class=\"d-inline-block\">\r\n <button type=\"button\" class=\"btn btn-link-primary p-2 \"\r\n style=\"line-height: 0;\" id=\"dropdownBasic1\" ngbDropdownToggle>\r\n </button>\r\n <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\">\r\n <button ngbDropdownItem type=\"button\" *ngIf=\"!item.isActivatedVersion\"\r\n (click)=\"ActivatedVersion(item.id)\">\r\n <i class=\"fas fa-check me-1\"></i>{{'Cms::IsActive' |\r\n abpLocalization}}\r\n </button>\r\n <button ngbDropdownItem type=\"button\"\r\n routerLink=\"/cms/admin/entries/create\"\r\n [queryParams]=\"{entryVersionId:item.id}\">\r\n <i class=\"fas fa-plus me-1\"></i>{{'Cms::NewVersion' |\r\n abpLocalization}}\r\n </button>\r\n <button ngbDropdownItem type=\"button\" (click.stop)=\"toEditUrl(item.id)\"\r\n *ngIf=\"item.id !== entryVersionId\">\r\n <i class=\"fas fa-edit me-1\"></i>{{'AbpUi::Edit' | abpLocalization}}\r\n </button>\r\n <button ngbDropdownItem type=\"button\"\r\n (click.stop)=\"delectVersion(item.id)\"\r\n *ngIf=\"item.initialVersionId&&!item.isActivatedVersion&&item.id !== entryVersionId\">\r\n <i class=\"fas fa-trash me-1\"></i>{{'AbpUi::Delete' |\r\n abpLocalization}}\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </li>\r\n </ng-container>\r\n </ul>\r\n </div>\r\n <div class=\"mb-3\" *ngIf=\"entryInfo\">\r\n <label class=\"form-label\" for=\"versionNotes\">{{'Cms::RevisionNotes' | abpLocalization}}</label>\r\n <textarea class=\"form-control\" formControlName=\"versionNotes\" rows=\"3\"></textarea>\r\n </div>\r\n\r\n\r\n\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <button type=\"submit\" style=\"display: none;\" #submitclick></button>\r\n</form>", styles: [""], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.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: i2.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i3.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i4.StopPropagationDirective, selector: "[click.stop]", outputs: ["click.stop"] }, { kind: "directive", type: i5.ValidationGroupDirective, selector: "[formGroup],[formGroupName]", exportAs: ["validationGroup"] }, { kind: "directive", type: i5.ValidationDirective, selector: "[formControl],[formControlName]", exportAs: ["validationDirective"] }, { kind: "directive", type: i6.NgbDropdown, selector: "[ngbDropdown]", inputs: ["autoClose", "dropdownClass", "open", "placement", "popperOptions", "container", "display"], outputs: ["openChange"], exportAs: ["ngbDropdown"] }, { kind: "directive", type: i6.NgbDropdownToggle, selector: "[ngbDropdownToggle]" }, { kind: "directive", type: i6.NgbDropdownMenu, selector: "[ngbDropdownMenu]" }, { kind: "directive", type: i6.NgbDropdownItem, selector: "[ngbDropdownItem]", inputs: ["tabindex", "disabled"] }, { kind: "directive", type: i6.NgbDropdownButtonItem, selector: "button[ngbDropdownItem]" }, { kind: "component", type: i7.DynamicComponent, selector: "df-dynamic", inputs: ["selected", "type", "entity", "culture", "parentFiledName", "fields"] }, { kind: "pipe", type: i1.DatePipe, name: "date" }, { kind: "pipe", type: i4.LocalizationPipe, name: "abpLocalization" }] }); }
|
|
289
208
|
}
|
|
290
209
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: CreateOrEditEntriesComponent, decorators: [{
|
|
291
210
|
type: Component,
|
|
292
|
-
args: [{ selector: 'cms-create-or-edit-entries', template: "<form class=\"create-or-edit-entry-page\" [formGroup]=\"_entity\">\n <button type=\"submit\" style=\"display: none;\" #submitclick></button>\n <div class=\"container \">\n <div class=\"row\">\n <div class=\"col-md-8 \">\n <div class=\"card p-2\">\n <div class=\"mb-3\">\n <label class=\"form-label\" for=\"title\">{{'Cms::Title' | abpLocalization}}</label>\n <input type=\"text\" class=\"form-control\" (blur)=\"setTitleToSlugBlur($event)\"\n formControlName=\"title\">\n </div>\n <ng-container *ngFor=\"let item of entryTypesItem?.fieldTabs;let i =index\">\n <ng-container *ngFor=\"let el of item.fields;let i1 =index\">\n <ng-container *ngIf=\"el&&_entity\">\n <df-dynamic [entity]=\"_entity\" [fields]=\"el\"\n [selected]=\"entrySelect ? entrySelect.extraProperties[el.field.name] : ''\"\n [parentFiledName]=\"'extraProperties'\" [culture]=\"cultureInput.value\"></df-dynamic>\n </ng-container>\n </ng-container>\n </ng-container>\n </div>\n </div>\n <div class=\"col-md-4 \">\n <div class=\"card mb-0 p-2\">\n <div class=\"mb-3\">\n <label class=\"form-label\" for=\"slug\">{{'Cms::Slug' | abpLocalization}}</label>\n <input type=\"text\" class=\"form-control\" formControlName=\"slug\">\n <div class=\"text-danger invalid-feedback\" *ngIf=\"sluginput.errors?.repetition\">\n {{sluginput.errors?.repetition}}\n </div>\n </div>\n <div class=\"mb-3\">\n <label class=\"form-label\" for=\"culture\">{{'AbpUi::Languages' | abpLocalization}}</label>\n <select class=\"form-select \" formControlName=\"culture\">\n <ng-container *ngFor=\"let item of languagesList;let i =index\">\n <option [value]=\"item.cultureName\">{{item.displayName}}</option>\n </ng-container>\n </select>\n <input type=\"text\" formControlName=\"culture_shadow\"\n style=\"position: absolute;z-index: -1;opacity: 0;\">\n <div class=\"text-danger invalid-feedback\" *ngIf=\"culture_shadowInput?.errors?.repetition\">\n {{culture_shadowInput?.errors?.repetition}}\n </div>\n </div>\n <div class=\"mb-3\" *ngIf=\"SectionSelect.type===1\">\n <label class=\"form-label\" for=\"parentId\">{{'Cms::ParentEntry' | abpLocalization}}</label>\n <select class=\"form-select\" formControlName=\"parentId\">\n <option value=\"\"></option>\n <ng-container *ngFor=\"let item of entryTypesList;let i =index\">\n <option [value]=\"item.id\">{{item.title}}</option>\n <ng-container *ngFor=\"let el of item.children\">\n <ng-container *ngTemplateOutlet=\"childTemplate; context: {\n $implicit: {\n value: el,\n }\n }\"></ng-container>\n <ng-template #childTemplate let-data>\n <option [value]=\"data.value.id\">\n <ng-container *ngFor=\"let item of data.value.layer\">--</ng-container>\n {{data.value.title}}\n </option>\n <ng-container *ngFor=\"let el of data.value.children\">\n <ng-container *ngTemplateOutlet=\"childTemplate; context: {\n $implicit: {\n value: el,\n }\n }\"></ng-container>\n </ng-container>\n\n </ng-template>\n </ng-container>\n\n </ng-container>\n </select>\n\n\n\n </div>\n <div class=\"mb-3\">\n <label class=\"form-label\" for=\"publishTime\">{{'Cms::PublishTime' | abpLocalization}}</label>\n <input type=\"datetime-local\" class=\"form-control\" step=\"1\" formControlName=\"publishTime\">\n </div>\n <div class=\"mb-3\" *ngIf=\"isEdit\">\n <label class=\"form-label\" for=\"publishTime\">{{'Cms::Version' | abpLocalization}}</label>\n <ul class=\"list-group\">\n <ng-container *ngFor=\"let item of AllVersionsList\">\n <li class=\"list-group-item flex-between\">\n <div>\n {{item.initialVersionId?(item.creationTime| date: 'YYYY/MM/dd HH:mm:s'):('Cms::InitialVersion' | abpLocalization)}}\n <span class=\"badge text-bg-success ms-1\"\n *ngIf=\"item.isActivatedVersion\">{{'Cms::IsActive' | abpLocalization}}</span>\n <span class=\"badge text-bg-primary ms-1\"\n *ngIf=\"item.id === RevisionEntryId\">{{'Cms::Editing' |\n abpLocalization}}</span>\n </div>\n <div>\n <div ngbDropdown class=\"d-inline-block\">\n <button type=\"button\" class=\"btn btn-link-primary p-2 \"\n style=\"line-height: 0;\" id=\"dropdownBasic1\" ngbDropdownToggle>\n </button>\n <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\">\n <button ngbDropdownItem type=\"button\" *ngIf=\"!item.isActivatedVersion\"\n (click)=\"ActivatedVersion(item.id)\">\n <i class=\"fas fa-check me-1\"></i>{{'Cms::IsActive' |\n abpLocalization}}\n </button>\n <button ngbDropdownItem type=\"button\"\n routerLink=\"/cms/admin/entries/create\"\n [queryParams]=\"{RevisionEntryId:item.id}\">\n <i class=\"fas fa-plus me-1\"></i>{{'Cms::NewVersion' |\n abpLocalization}}\n </button>\n <button ngbDropdownItem type=\"button\" (click.stop)=\"toEditUrl(item.id)\"\n *ngIf=\"item.id !== RevisionEntryId\">\n <i class=\"fas fa-edit me-1\"></i>{{'AbpUi::Edit' | abpLocalization}}\n </button>\n <button ngbDropdownItem type=\"button\"\n (click.stop)=\"delectVersion(item.id)\"\n *ngIf=\"item.initialVersionId&&!item.isActivatedVersion&&item.id !== RevisionEntryId\">\n <i class=\"fas fa-trash me-1\"></i>{{'AbpUi::Delete' |\n abpLocalization}}\n </button>\n </div>\n </div>\n </div>\n </li>\n </ng-container>\n </ul>\n </div>\n <div class=\"mb-3\">\n <label class=\"form-label\" for=\"versionNotes\">{{'Cms::RevisionNotes' | abpLocalization}}</label>\n <textarea class=\"form-control\" formControlName=\"versionNotes\" rows=\"3\"></textarea>\n </div>\n </div>\n </div>\n </div>\n </div>\n</form>", styles: ["::ng-deep .create-or-edit-entry-page .dignite_page{height:calc(100vh - 125px);overflow:auto;background:transparent}::ng-deep .create-or-edit-entry-page .form-control,::ng-deep .create-or-edit-entry-page .form-select{padding:.475rem 1.25rem}::ng-deep .create-or-edit-entry-page .cursor-move{cursor:move}::ng-deep .create-or-edit-entry-page .bordernNavs{border:var(--bs-border-width) solid var(--lpx-border-color);padding-left:inherit;padding-right:inherit}::ng-deep .create-or-edit-entry-page .flex-between{display:flex;align-items:center;justify-content:space-between}\n"] }]
|
|
293
|
-
}],
|
|
294
|
-
type: ViewChild,
|
|
295
|
-
args: ['submitclick', { static: true }]
|
|
296
|
-
}], isEdit: [{
|
|
211
|
+
args: [{ selector: 'cms-create-or-edit-entries', template: "<form [formGroup]=\"formEntity\">\r\n <div class=\"row\">\r\n <div class=\"col-md-8\">\r\n <div class=\"card\">\r\n <div class=\"card-body\">\r\n <div class=\"mb-3\">\r\n <div class=\"form-label\">{{'Cms::Title' | abpLocalization}}</div>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"title\"\r\n (blur)=\"setTitleToSlugBlur($event)\">\r\n </div>\r\n <i></i>\r\n <ng-container *ngIf=\"isLoad\">\r\n <ng-container *ngFor=\"let item of showEntryType?.fieldTabs;let i =index\">\r\n <ng-container *ngFor=\"let el of item.fields;let i1 =index\">\r\n <ng-container *ngIf=\"el&&formEntity\">\r\n <df-dynamic [fields]=\"el\"\r\n [selected]=\"entryInfo ? entryInfo.extraProperties[el.field.name] : ''\"\r\n [parentFiledName]=\"'extraProperties'\"\r\n [culture]=\"cultureInput.value\" [entity]=\"formEntity\"></df-dynamic>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"col-md-4\">\r\n <div class=\"card\">\r\n <div class=\"card-body\">\r\n <div class=\"mb-3\">\r\n <div class=\"form-label\">{{'Cms::Slug' | abpLocalization}}</div>\r\n <input type=\"text\" class=\"form-control\" formControlName=\"slug\">\r\n </div>\r\n <div class=\"mb-3\">\r\n <div class=\"form-label\">{{'AbpUi::Languages' | abpLocalization}}</div>\r\n <select class=\"form-select \" formControlName=\"culture\">\r\n <ng-container *ngFor=\"let item of languagesList;let i =index\">\r\n <option [value]=\"item.cultureName\">{{item.displayName}}</option>\r\n </ng-container>\r\n </select>\r\n <div class=\"text-danger\" *ngIf=\"cultureInput.dirty\">\r\n {{cultureInput?.errors?.repetition}}\r\n </div>\r\n </div>\r\n <div class=\"mb-3\" *ngIf=\"sectionInfo.type===1\">\r\n <label class=\"form-label\" for=\"parentId\">{{'Cms::ParentEntry' | abpLocalization}}</label>\r\n <select class=\"form-select\" formControlName=\"parentId\">\r\n <option value=\"\"></option>\r\n <ng-container *ngFor=\"let item of entryList;let i =index\">\r\n <option [value]=\"item.id\">{{item.title}}</option>\r\n <ng-container *ngFor=\"let el of item.children\">\r\n <ng-container *ngTemplateOutlet=\"childTemplate; context: {\r\n $implicit: {\r\n value: el,\r\n }\r\n }\"></ng-container>\r\n <ng-template #childTemplate let-data>\r\n <option [value]=\"data.value.id\">\r\n <ng-container *ngFor=\"let item of data.value.layer\">--</ng-container>\r\n {{data.value.title}}\r\n </option>\r\n <ng-container *ngFor=\"let el of data.value.children\">\r\n <ng-container *ngTemplateOutlet=\"childTemplate; context: {\r\n $implicit: {\r\n value: el,\r\n }\r\n }\"></ng-container>\r\n </ng-container>\r\n </ng-template>\r\n </ng-container>\r\n </ng-container>\r\n </select>\r\n </div>\r\n <div class=\"mb-3\">\r\n <label class=\"form-label\" for=\"publishTime\">{{'Cms::PublishTime' | abpLocalization}}</label>\r\n <input type=\"datetime-local\" class=\"form-control\" step=\"1\" formControlName=\"publishTime\">\r\n </div>\r\n <div class=\"mb-3\" *ngIf=\"isEdit\">\r\n <label class=\"form-label\" for=\"publishTime\">{{'Cms::Version' | abpLocalization}}</label>\r\n <ul class=\"list-group\">\r\n <ng-container *ngFor=\"let item of AllVersionsList\">\r\n <li\r\n class=\"list-group-item flex-between d-flex align-items-center justify-content-between\">\r\n <div>\r\n {{item.initialVersionId?(item.creationTime| date: 'YYYY/MM/dd HH:mm:s'):('Cms::InitialVersion' | abpLocalization)}}\r\n <span class=\"badge text-bg-success ms-1\"\r\n *ngIf=\"item.isActivatedVersion\">{{'Cms::IsActive' | abpLocalization}}</span>\r\n <span class=\"badge text-bg-primary ms-1\"\r\n *ngIf=\"item.id === entryVersionId\">{{'Cms::Editing' |\r\n abpLocalization}}</span>\r\n </div>\r\n <div>\r\n <div ngbDropdown class=\"d-inline-block\">\r\n <button type=\"button\" class=\"btn btn-link-primary p-2 \"\r\n style=\"line-height: 0;\" id=\"dropdownBasic1\" ngbDropdownToggle>\r\n </button>\r\n <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\">\r\n <button ngbDropdownItem type=\"button\" *ngIf=\"!item.isActivatedVersion\"\r\n (click)=\"ActivatedVersion(item.id)\">\r\n <i class=\"fas fa-check me-1\"></i>{{'Cms::IsActive' |\r\n abpLocalization}}\r\n </button>\r\n <button ngbDropdownItem type=\"button\"\r\n routerLink=\"/cms/admin/entries/create\"\r\n [queryParams]=\"{entryVersionId:item.id}\">\r\n <i class=\"fas fa-plus me-1\"></i>{{'Cms::NewVersion' |\r\n abpLocalization}}\r\n </button>\r\n <button ngbDropdownItem type=\"button\" (click.stop)=\"toEditUrl(item.id)\"\r\n *ngIf=\"item.id !== entryVersionId\">\r\n <i class=\"fas fa-edit me-1\"></i>{{'AbpUi::Edit' | abpLocalization}}\r\n </button>\r\n <button ngbDropdownItem type=\"button\"\r\n (click.stop)=\"delectVersion(item.id)\"\r\n *ngIf=\"item.initialVersionId&&!item.isActivatedVersion&&item.id !== entryVersionId\">\r\n <i class=\"fas fa-trash me-1\"></i>{{'AbpUi::Delete' |\r\n abpLocalization}}\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </li>\r\n </ng-container>\r\n </ul>\r\n </div>\r\n <div class=\"mb-3\" *ngIf=\"entryInfo\">\r\n <label class=\"form-label\" for=\"versionNotes\">{{'Cms::RevisionNotes' | abpLocalization}}</label>\r\n <textarea class=\"form-control\" formControlName=\"versionNotes\" rows=\"3\"></textarea>\r\n </div>\r\n\r\n\r\n\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <button type=\"submit\" style=\"display: none;\" #submitclick></button>\r\n</form>" }]
|
|
212
|
+
}], propDecorators: { isEdit: [{
|
|
297
213
|
type: Input
|
|
298
|
-
}],
|
|
214
|
+
}], sectionId: [{
|
|
299
215
|
type: Input
|
|
300
|
-
}],
|
|
216
|
+
}], entryTypeId: [{
|
|
217
|
+
type: Input
|
|
218
|
+
}], select: [{
|
|
301
219
|
type: Input
|
|
302
|
-
}],
|
|
220
|
+
}], entity: [{
|
|
303
221
|
type: Input
|
|
304
|
-
}],
|
|
305
|
-
type:
|
|
306
|
-
args: ['
|
|
222
|
+
}], submitclick: [{
|
|
223
|
+
type: ViewChild,
|
|
224
|
+
args: ['submitclick', { static: true }]
|
|
307
225
|
}] } });
|
|
308
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-or-edit-entries.component.js","sourceRoot":"","sources":["../../../../../../../projects/cms/src/lib/components/admin/entries/create-or-edit-entries.component.ts","../../../../../../../projects/cms/src/lib/components/admin/entries/create-or-edit-entries.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ConfigStateService, LocalizationService } from '@abp/ng.core';\nimport { ToasterService } from '@abp/ng.theme.shared';\nimport { AfterContentInit, Component, ElementRef, inject, Input, QueryList, ViewChild, ViewChildren, ViewContainerRef } from '@angular/core';\nimport { AbstractControl, FormControl, FormGroup, ValidationErrors, Validators } from '@angular/forms';\nimport { Router } from '@angular/router';\nimport { EntryAdminService } from '../../../proxy/admin/entries';\nimport { SectionAdminService } from '../../../proxy/admin/sections';\nimport { Observable } from 'rxjs';\nimport { DatePipe, Location } from '@angular/common';\nimport { CmsApiService } from '../../../services';\n\n@Component({\n  selector: 'cms-create-or-edit-entries',\n  templateUrl: './create-or-edit-entries.component.html',\n  styleUrls: ['./create-or-edit-entries.component.scss']\n})\nexport class CreateOrEditEntriesComponent implements AfterContentInit {\n\n\n  constructor(\n    private toaster: ToasterService,\n    public _location: Location,\n    private configState: ConfigStateService,\n    private _SectionAdminService: SectionAdminService,\n    private _EntryAdminService: EntryAdminService,\n    private datePipe: DatePipe,\n    private _LocalizationService: LocalizationService,\n    private router: Router,\n    private _CmsApiService: CmsApiService,\n  ) { }\n\n  /**获取提交按钮替身，用于真实触发表单提交 */\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\n  /**语言 */\n  cultureName: string = ''\n  /**条目类型id */\n  entryTypeId: string = ''\n\n  /**新建版本的版本id，同条目id */\n  RevisionEntryId: any = ''\n  /**选择的条目项 */\n  entryTypesItem: any = ''\n  /**版块id */\n  sectionId: string = ''\n  /**版块详情 */\n  SectionSelect: any = ''\n  /**语言列表 */\n  languagesList: any[] = []\n  /**条目类型列表-用于选择上级条目 */\n  entryTypesList: any[] = []\n  /**版本列表 */\n  AllVersionsList: any[] = []\n\n  /**是否是编辑 */\n  @Input() isEdit = false\n\n  /**来自父组件的传值 */\n  FromParentQueryParams: any = ''\n  @Input()\n  public set ParentQueryParams(v: any) {\n    if (v) {\n      this.FromParentQueryParams = v;\n    }\n  }\n\n  /**表单实体 */\n  _entity: FormGroup | undefined\n  @Input()\n  public set entity(v: any) {\n    if (v) {\n      this._entity = v;\n    }\n  }\n  /**指定id的条目信息 */\n  entrySelect: any = ''\n  @Input()\n  public set parentEntrySelect(v: any) {\n    if (v) {\n      let V_extraProperties = this._CmsApiService.deepClone(this.convertExtraProperties(v.extraProperties))\n      v.extraProperties = V_extraProperties\n      this.entrySelect = v;\n    }\n  }\n  /**将对象中的ExtraProperties赋值到extraProperties */\n  convertExtraProperties(obj) {\n    for (let key in obj) {\n      if (Array.isArray(obj[key])) {\n        obj[key].forEach(item => {\n          if (item.hasOwnProperty('ExtraProperties')) {\n            item['extraProperties'] = item['ExtraProperties'];\n          }\n        });\n      }\n    }\n    return obj;\n  }\n\n  /**别名表单实体 */\n  get sluginput() {\n    return this._entity.get('slug')\n  }\n  /**语言表单实体 */\n  get cultureInput() {\n    return this._entity.get('culture') as FormControl;\n  }\n  /**语言表单实体影子 */\n  get culture_shadowInput() {\n    return this._entity.get('culture_shadow') as FormControl;\n  }\n\n  /**extraProperties配置表单实体 */\n  get extraProperties() {\n    return this._entity.get('extraProperties') as FormGroup\n  }\n  async ngAfterContentInit(): Promise<void> {\n    //Called after ngOnInit when the component's or directive's content has been initialized.\n    //Add 'implements AfterContentInit' to the class.\n    let queryParams = this.FromParentQueryParams\n    if (this._entity && this.FromParentQueryParams) {\n      this._entity.setControl('slug', new FormControl('', {\n        validators: Validators.required,\n        asyncValidators: this.repetitionAsyncValidator(),\n        updateOn: 'blur'\n      }))\n      this._entity.setControl('culture_shadow', new FormControl('', {\n        asyncValidators: this.cultureAsyncValidator_test(),\n        updateOn: 'blur'\n      }))\n      if (queryParams.RevisionEntryId && this.entrySelect) {\n        this.RevisionEntryId = queryParams.RevisionEntryId\n        this.setEntryconfig(this.entrySelect);\n      } else {\n        this.setEntryconfig(queryParams);\n      }\n      if (this.sectionId) await this.getSectionSelect();\n      if (this.RevisionEntryId) await this.getAllVersionsList()\n\n      this.culture_shadowInput.patchValue(this.cultureInput.value);\n      this._entity.get('culture').disable();\n      this.submitclick?.nativeElement?.click()\n    }\n\n\n  }\n\n  /**表单控件模板-动态表单配置组件 */\n  @ViewChildren('FormDynamicontrolRef', { read: ViewContainerRef }) FormDynamicontrolRef: QueryList<ViewContainerRef>;\n\n\n\n\n\n  /**定义自定义异步验证 */\n  cultureAsyncValidator_test() {\n    return (ctrl: AbstractControl): Promise<ValidationErrors | null> | Observable<ValidationErrors | null> => {\n      return new Promise(resolve => {\n        let subculture = ctrl.value\n        if (!subculture) return resolve(null)\n        console.log(ctrl.value, 'ctrl.value');\n        if (subculture == this.entrySelect?.culture || this.SectionSelect.type !== 0) return resolve(null);\n        this._EntryAdminService.cultureExistWithSingleSection({\n          culture: subculture,\n          sectionId: this.sectionId,\n          entryTypeId: this.entryTypeId\n        }).subscribe(res => {\n          if (res) {\n            resolve({ repetition: this._LocalizationService.instant(`Cms::EntriesAlreadyExistEntryType`, this.entryTypesItem.displayName, this.languagesList.find(el => el.cultureName == subculture).displayName) });\n          } else {\n            resolve(null);\n          }\n        })\n      });\n    };\n  }\n\n\n  /**  \n * 设置条目详情  \n * @param {object} source - 数据源对象  \n */\n  setEntryconfig(source: any) {\n    this.entryTypeId = source.entryTypeId;\n    this.cultureName = source.culture || source.cultureName;\n    this.sectionId = source.sectionId;\n  }\n  time: number = 0\n\n  /**定义自定义异步验证 */\n  repetitionAsyncValidator() {\n    return (ctrl: AbstractControl): Promise<ValidationErrors | null> | Observable<ValidationErrors | null> => {\n      return new Promise(resolve => {\n        let subslug = ctrl.value\n        if (subslug == this.entrySelect?.slug) {\n          resolve(null);\n          return\n        }\n        this._EntryAdminService.slugExists({\n          culture: this.cultureName,\n          sectionId: this.sectionId,\n          slug: subslug\n        }).subscribe(res => {\n          if (res) {\n            resolve({ repetition: this._LocalizationService.instant(`Cms::EntrySlug{0}AlreadyExist`, ctrl.value) });\n          } else {\n            resolve(null);\n          }\n        })\n      });\n    };\n  }\n\n  private config = inject(ConfigStateService)\n\n  /**获取版块详情 */\n  getSectionSelect() {\n    return new Promise((resolve, rejects) => {\n      this._SectionAdminService.get(this.sectionId).subscribe(async (res) => {\n        let languages = this.configState.getDeep('localization.languages')\n        this.languagesList = languages\n        let entryTypesItem = res.entryTypes.find(el => el.id == this.entryTypeId)\n        this.SectionSelect = res\n        await this.getTypeEntryList()\n        this.entryTypesItem = entryTypesItem\n        this.entryTypesList = res.entryTypes.filter(el => el.id == this.entryTypeId)\n        this._entity.patchValue({\n          ...this.entrySelect,\n          initialVersionId: this.entrySelect?.initialVersionId || this.RevisionEntryId || '',\n          culture: this.cultureName,\n          entryTypeId: this.entryTypeId,\n          publishTime: this.datePipe.transform(new Date(), 'yyyy-MM-dd HH:mm:ss'),\n        })\n        resolve(true)\n      })\n    })\n  }\n  /**获取条目类型下所有条目列表 */\n  getTypeEntryList() {\n    return new Promise((resolve, rejects) => {\n      this._EntryAdminService.getList({\n        sectionId: this.sectionId,\n        maxResultCount: 1000,\n        culture: this.cultureName\n      }).subscribe((res: any) => {\n        let entryTypesList = res.items.filter(el => el.id != this.entrySelect.id)\n        let parentList = entryTypesList.filter(el => !el.parentId)\n        parentList.forEach(el => {\n          let layer: number = 0\n          el.layer = new Array(layer)\n          el.children = this.groupByParentId(entryTypesList, el.id, (layer + 1))\n        })\n        this.entryTypesList = parentList\n        resolve(res)\n      })\n    })\n  }\n\n  /**对数组按照父子关系进行分组 */\n  groupByParentId(arr, id = '', layer) {\n    let result = [];\n    result = arr.filter(el => el.parentId == id)\n    result.forEach(el => {\n      el.layer = new Array(layer)\n      el.children = this.groupByParentId(arr, el.id, (layer + 1))\n    })\n    return result\n  }\n\n\n\n  /**获取条目版本列表 */\n  getAllVersionsList() {\n    return new Promise((resolve, rejects) => {\n      this._EntryAdminService.getAllVersions(this.RevisionEntryId).subscribe(res => {\n        this.AllVersionsList = res.items\n        resolve(res)\n      })\n    })\n  }\n\n  /**标题转化别名 */\n  setTitleToSlugBlur(event) {\n    let val = event.target.value\n    let slug = this._entity.get('slug')\n    let pinyinstr = ''\n    if (slug.value) return\n    pinyinstr = this._CmsApiService.chineseToPinyin(val)\n    this._entity.patchValue({\n      slug: pinyinstr || val\n    })\n  }\n  /**使用Unicode编码范围判断是否是中文字符 */\n  isChinese(str) {\n    return /^[\\u4e00-\\u9fa5]+$/.test(str);\n  }\n\n  /**激活 */\n  ActivatedVersion(VersionId) {\n    this._EntryAdminService.activate(VersionId).subscribe((res) => {\n      this.AllVersionsList.forEach(el => {\n        el.isActivatedVersion = el.id === VersionId\n      })\n      return\n    })\n  }\n  /**编辑版本 */\n  toEditUrl(id) {\n    this.router.navigateByUrl('', { skipLocationChange: true }).then(() => {\n      this.router.navigate([`/cms/admin/entries/${id}/edit`]);\n    });\n  }\n  /**删除版本 */\n  delectVersion(vid) {\n    this._EntryAdminService.delete(vid).subscribe(res => {\n      this.toaster.success(this._LocalizationService.instant(`AbpUi::DeletedSuccessfully`));\n      this.getAllVersionsList()\n    })\n  }\n\n}\n","<form class=\"create-or-edit-entry-page\" [formGroup]=\"_entity\">\n    <button type=\"submit\" style=\"display: none;\" #submitclick></button>\n    <div class=\"container \">\n        <div class=\"row\">\n            <div class=\"col-md-8 \">\n                <div class=\"card  p-2\">\n                    <div class=\"mb-3\">\n                        <label class=\"form-label\" for=\"title\">{{'Cms::Title' | abpLocalization}}</label>\n                        <input type=\"text\" class=\"form-control\" (blur)=\"setTitleToSlugBlur($event)\"\n                            formControlName=\"title\">\n                    </div>\n                    <ng-container *ngFor=\"let item of entryTypesItem?.fieldTabs;let i =index\">\n                        <ng-container *ngFor=\"let el of item.fields;let i1 =index\">\n                            <ng-container *ngIf=\"el&&_entity\">\n                                <df-dynamic [entity]=\"_entity\" [fields]=\"el\"\n                                    [selected]=\"entrySelect ? entrySelect.extraProperties[el.field.name] : ''\"\n                                    [parentFiledName]=\"'extraProperties'\" [culture]=\"cultureInput.value\"></df-dynamic>\n                            </ng-container>\n                        </ng-container>\n                    </ng-container>\n                </div>\n            </div>\n            <div class=\"col-md-4 \">\n                <div class=\"card mb-0 p-2\">\n                    <div class=\"mb-3\">\n                        <label class=\"form-label\" for=\"slug\">{{'Cms::Slug' | abpLocalization}}</label>\n                        <input type=\"text\" class=\"form-control\" formControlName=\"slug\">\n                        <div class=\"text-danger invalid-feedback\" *ngIf=\"sluginput.errors?.repetition\">\n                            {{sluginput.errors?.repetition}}\n                        </div>\n                    </div>\n                    <div class=\"mb-3\">\n                        <label class=\"form-label\" for=\"culture\">{{'AbpUi::Languages' | abpLocalization}}</label>\n                            <select class=\"form-select \"  formControlName=\"culture\">\n                                <ng-container *ngFor=\"let item of languagesList;let i =index\">\n                                    <option [value]=\"item.cultureName\">{{item.displayName}}</option>\n                                </ng-container>\n                            </select>\n                            <input type=\"text\" formControlName=\"culture_shadow\"\n                                style=\"position: absolute;z-index: -1;opacity: 0;\">\n                            <div class=\"text-danger invalid-feedback\" *ngIf=\"culture_shadowInput?.errors?.repetition\">\n                                {{culture_shadowInput?.errors?.repetition}}\n                            </div>\n                    </div>\n                    <div class=\"mb-3\" *ngIf=\"SectionSelect.type===1\">\n                        <label class=\"form-label\" for=\"parentId\">{{'Cms::ParentEntry' | abpLocalization}}</label>\n                        <select class=\"form-select\" formControlName=\"parentId\">\n                            <option value=\"\"></option>\n                            <ng-container *ngFor=\"let item of entryTypesList;let i =index\">\n                                <option [value]=\"item.id\">{{item.title}}</option>\n                                <ng-container *ngFor=\"let el of item.children\">\n                                    <ng-container *ngTemplateOutlet=\"childTemplate; context: {\n                                        $implicit: {\n                                        value: el,\n                                        }\n                                    }\"></ng-container>\n                                    <ng-template #childTemplate let-data>\n                                        <option [value]=\"data.value.id\">\n                                            <ng-container *ngFor=\"let item of data.value.layer\">--</ng-container>\n                                            {{data.value.title}}\n                                        </option>\n                                        <ng-container *ngFor=\"let el of data.value.children\">\n                                            <ng-container *ngTemplateOutlet=\"childTemplate; context: {\n                                                $implicit: {\n                                                value: el,\n                                                }\n                                            }\"></ng-container>\n                                        </ng-container>\n\n                                    </ng-template>\n                                </ng-container>\n\n                            </ng-container>\n                        </select>\n\n\n\n                    </div>\n                    <div class=\"mb-3\">\n                        <label class=\"form-label\" for=\"publishTime\">{{'Cms::PublishTime' | abpLocalization}}</label>\n                        <input type=\"datetime-local\" class=\"form-control\" step=\"1\" formControlName=\"publishTime\">\n                    </div>\n                    <div class=\"mb-3\" *ngIf=\"isEdit\">\n                        <label class=\"form-label\" for=\"publishTime\">{{'Cms::Version' | abpLocalization}}</label>\n                        <ul class=\"list-group\">\n                            <ng-container *ngFor=\"let item of AllVersionsList\">\n                                <li class=\"list-group-item flex-between\">\n                                    <div>\n                                        {{item.initialVersionId?(item.creationTime| date: 'YYYY/MM/dd HH:mm:s'):('Cms::InitialVersion' | abpLocalization)}}\n                                        <span class=\"badge text-bg-success ms-1\"\n                                            *ngIf=\"item.isActivatedVersion\">{{'Cms::IsActive' | abpLocalization}}</span>\n                                        <span class=\"badge text-bg-primary ms-1\"\n                                            *ngIf=\"item.id === RevisionEntryId\">{{'Cms::Editing' |\n                                            abpLocalization}}</span>\n                                    </div>\n                                    <div>\n                                        <div ngbDropdown class=\"d-inline-block\">\n                                            <button type=\"button\" class=\"btn btn-link-primary p-2 \"\n                                                style=\"line-height: 0;\" id=\"dropdownBasic1\" ngbDropdownToggle>\n                                            </button>\n                                            <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\">\n                                                <button ngbDropdownItem type=\"button\" *ngIf=\"!item.isActivatedVersion\"\n                                                    (click)=\"ActivatedVersion(item.id)\">\n                                                    <i class=\"fas fa-check me-1\"></i>{{'Cms::IsActive' |\n                                                    abpLocalization}}\n                                                </button>\n                                                <button ngbDropdownItem type=\"button\"\n                                                    routerLink=\"/cms/admin/entries/create\"\n                                                    [queryParams]=\"{RevisionEntryId:item.id}\">\n                                                    <i class=\"fas fa-plus me-1\"></i>{{'Cms::NewVersion' |\n                                                    abpLocalization}}\n                                                </button>\n                                                <button ngbDropdownItem type=\"button\" (click.stop)=\"toEditUrl(item.id)\"\n                                                    *ngIf=\"item.id !== RevisionEntryId\">\n                                                    <i class=\"fas fa-edit me-1\"></i>{{'AbpUi::Edit' | abpLocalization}}\n                                                </button>\n                                                <button ngbDropdownItem type=\"button\"\n                                                    (click.stop)=\"delectVersion(item.id)\"\n                                                    *ngIf=\"item.initialVersionId&&!item.isActivatedVersion&&item.id !== RevisionEntryId\">\n                                                    <i class=\"fas fa-trash me-1\"></i>{{'AbpUi::Delete' |\n                                                    abpLocalization}}\n                                                </button>\n                                            </div>\n                                        </div>\n                                    </div>\n                                </li>\n                            </ng-container>\n                        </ul>\n                    </div>\n                    <div class=\"mb-3\">\n                        <label class=\"form-label\" for=\"versionNotes\">{{'Cms::RevisionNotes' | abpLocalization}}</label>\n                        <textarea class=\"form-control\" formControlName=\"versionNotes\" rows=\"3\"></textarea>\n                    </div>\n                </div>\n            </div>\n        </div>\n    </div>\n</form>"]}
|
|
226
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-or-edit-entries.component.js","sourceRoot":"","sources":["../../../../../../../projects/cms/src/lib/components/admin/entries/create-or-edit-entries.component.ts","../../../../../../../projects/cms/src/lib/components/admin/entries/create-or-edit-entries.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ConfigStateService, LocalizationService } from '@abp/ng.core';\nimport { ToasterService } from '@abp/ng.theme.shared';\nimport {\n  Component,\n  ElementRef,\n  inject,\n  Input,\n  ViewChild,\n} from '@angular/core';\nimport {\n  FormControl,\n  FormGroup,\n} from '@angular/forms';\nimport { Router } from '@angular/router';\nimport { EntryAdminService } from '../../../proxy/admin/entries';\nimport { SectionAdminService } from '../../../proxy/admin/sections';\nimport { DatePipe, Location } from '@angular/common';\nimport { CmsApiService } from '../../../services';\n\n@Component({\n  selector: 'cms-create-or-edit-entries',\n  templateUrl: './create-or-edit-entries.component.html',\n  styleUrls: ['./create-or-edit-entries.component.scss'],\n})\nexport class CreateOrEditEntriesComponent{\n  private toaster = inject(ToasterService);\n  public _location = inject(Location);\n  private configState = inject(ConfigStateService);\n  private _SectionAdminService = inject(SectionAdminService);\n  private _EntryAdminService = inject(EntryAdminService);\n  private datePipe = inject(DatePipe);\n  private _LocalizationService = inject(LocalizationService);\n  private router = inject(Router);\n  private _CmsApiService = inject(CmsApiService);\n\n  /**语言列表 */\n  languagesList: any[] = [];\n  /**条目列表-选择上级条目 */\n  entryList: any[] = [];\n  /**条目信息 */\n  entryInfo: any = '';\n  /**版本信息 */\n  sectionInfo: any = '';\n  /**需要展示的b板块下条目类型 */\n  showEntryType: any = '';\n  /**版本条目id */\n  entryVersionId: any = '';\n  /**版本列表 */\n  AllVersionsList: any[] = [];\n\n  @Input() isEdit: boolean = false;\n\n  @Input() sectionId: string = '';\n  @Input() entryTypeId: string = '';\n  @Input() public set select(v: any) {\n    this.entryVersionId = v.id;\n    this.entryInfo = v;\n  }\n\n  formEntity: FormGroup | undefined;\n  @Input() set entity(value: FormGroup | undefined) {\n    this.formEntity = value;\n    if (value) {\n      let languages = this.configState.getDeep('localization.languages');\n      this.languagesList = languages;\n      this.loadData();\n    }\n  }\n  /**是否加载完成 */\n  isLoad: boolean = false;\n\n  /**语言控件 */\n  get cultureInput(): FormControl {\n    return this.formEntity?.get('culture') as FormControl;\n  }\n\n  /**获取提交按钮替身，用于真实触发表单提交 */\n  @ViewChild('submitclick', { static: true }) submitclick: ElementRef;\n\n\n  /**加载数据 */\n  async loadData() {\n    if (this.sectionId) {\n      await this.getSectionInfo();\n      await this.getEntryList();\n    }\n\n    this.cultureInput.disable();\n    let repetition = await this.cultureAsyncValidator();\n    if (repetition) this.cultureInput.setErrors(repetition);\n\n    if (this.entryInfo) {\n      await this.getAllVersionsList();\n      this.formEntity.patchValue({\n        entryTypeId: this.entryInfo.entryTypeId,\n        publishTime: this.entryInfo.publishTime,\n        title: this.entryInfo.title,\n        slug: this.entryInfo.slug,\n        parentId: this.entryInfo.parentId,\n        versionNotes: this.entryInfo.versionNotes,\n        initialVersionId: this.entryInfo.id,\n      });\n    } else {\n      this.formEntity.patchValue({\n        entryTypeId: this.entryTypeId,\n        publishTime: this.datePipe.transform(new Date(), 'yyyy-MM-dd HH:mm:ss'),\n      });\n    }\n    this.isLoad=true;\n    setTimeout(() => {\n      this.submitclick?.nativeElement.click();\n    }, 0);\n  }\n\n  /**定义自定义异步验证 */\n  cultureAsyncValidator() {\n    return new Promise(resolve => {\n      let culture = this.cultureInput.value;\n      if (culture == this.entryInfo?.culture || this.sectionInfo.type !== 0) return resolve(null);\n      this._EntryAdminService\n        .cultureExistWithSingleSection({\n          culture: culture,\n          sectionId: this.sectionId,\n          entryTypeId: this.entryTypeId,\n        })\n        .subscribe(res => {\n          if (res) {\n            resolve({\n              repetition: this._LocalizationService.instant(\n                `Cms::EntriesAlreadyExistEntryType`,\n                '',\n                this.languagesList.find(el => el.cultureName == culture).displayName\n              ),\n            });\n          } else {\n            resolve(null);\n          }\n        });\n    });\n  }\n\n  /**获取板块信息 */\n  getSectionInfo() {\n    return new Promise((resolve, reject) => {\n      this._SectionAdminService.get(this.sectionId).subscribe(res => {\n        this.showEntryType = res.entryTypes.find(el => el.id == this.entryTypeId);\n        this.sectionInfo = res;\n        resolve(res);\n      });\n    });\n  }\n  /**获取板块下所有条目 */\n  getEntryList() {\n    return new Promise((resolve, rejects) => {\n      this._EntryAdminService\n        .getList({\n          sectionId: this.sectionId,\n          maxResultCount: 1000,\n          culture: this.cultureInput.value,\n        })\n        .subscribe((res: any) => {\n          let entryList = res.items.filter(el => el.id !== this.entryInfo?.id);\n          let parentList = entryList.filter(el => !el.parentId);\n          parentList.forEach(el => {\n            let layer: number = 0;\n            el.layer = new Array(layer);\n            el.children = this.groupByParentId(entryList, el.id, layer + 1);\n          });\n          this.entryList = parentList;\n          resolve(res);\n        });\n    });\n  }\n  /**对数组按照父子关系进行分组 */\n  groupByParentId(arr, id = '', layer) {\n    let result = [];\n    result = arr.filter(el => el.parentId == id);\n    result.forEach(el => {\n      el.layer = new Array(layer);\n      el.children = this.groupByParentId(arr, el.id, layer + 1);\n    });\n    return result;\n  }\n  /**标题转化别名 */\n  setTitleToSlugBlur(event) {\n    let val = event.target.value;\n    let slug = this.formEntity.get('slug');\n    let pinyinstr = '';\n    if (slug.value) return;\n    pinyinstr = this._CmsApiService.chineseToPinyin(val);\n    this.formEntity.patchValue({\n      slug: pinyinstr || val,\n    });\n  }\n\n  /**获取条目版本列表 */\n  getAllVersionsList() {\n    return new Promise((resolve, rejects) => {\n      this._EntryAdminService.getAllVersions(this.entryInfo.id).subscribe(res => {\n        this.AllVersionsList = res.items;\n        resolve(res);\n      });\n    });\n  }\n\n  /**激活 */\n  ActivatedVersion(VersionId) {\n    this._EntryAdminService.activate(VersionId).subscribe(res => {\n      this.AllVersionsList.forEach(el => {\n        el.isActivatedVersion = el.id === VersionId;\n      });\n      return;\n    });\n  }\n  /**编辑版本 */\n  toEditUrl(id) {\n    this.router.navigateByUrl('', { skipLocationChange: true }).then(() => {\n      this.router.navigate([`/cms/admin/entries/${id}/edit`]);\n    });\n  }\n  /**删除版本 */\n  delectVersion(vid) {\n    this._EntryAdminService.delete(vid).subscribe(res => {\n      this.toaster.success(this._LocalizationService.instant(`AbpUi::DeletedSuccessfully`));\n      this.getAllVersionsList();\n    });\n  }\n}\n","<form [formGroup]=\"formEntity\">\r\n    <div class=\"row\">\r\n        <div class=\"col-md-8\">\r\n            <div class=\"card\">\r\n                <div class=\"card-body\">\r\n                    <div class=\"mb-3\">\r\n                        <div class=\"form-label\">{{'Cms::Title' | abpLocalization}}</div>\r\n                        <input type=\"text\" class=\"form-control\" formControlName=\"title\"\r\n                            (blur)=\"setTitleToSlugBlur($event)\">\r\n                    </div>\r\n                    <i></i>\r\n                    <ng-container *ngIf=\"isLoad\">\r\n                        <ng-container *ngFor=\"let item of showEntryType?.fieldTabs;let i =index\">\r\n                            <ng-container *ngFor=\"let el of item.fields;let i1 =index\">\r\n                                <ng-container *ngIf=\"el&&formEntity\">\r\n                                    <df-dynamic [fields]=\"el\"\r\n                                        [selected]=\"entryInfo ? entryInfo.extraProperties[el.field.name] : ''\"\r\n                                        [parentFiledName]=\"'extraProperties'\"\r\n                                        [culture]=\"cultureInput.value\"  [entity]=\"formEntity\"></df-dynamic>\r\n                                </ng-container>\r\n                            </ng-container>\r\n                        </ng-container>\r\n                    </ng-container>\r\n                </div>\r\n            </div>\r\n        </div>\r\n        <div class=\"col-md-4\">\r\n            <div class=\"card\">\r\n                <div class=\"card-body\">\r\n                    <div class=\"mb-3\">\r\n                        <div class=\"form-label\">{{'Cms::Slug' | abpLocalization}}</div>\r\n                        <input type=\"text\" class=\"form-control\" formControlName=\"slug\">\r\n                    </div>\r\n                    <div class=\"mb-3\">\r\n                        <div class=\"form-label\">{{'AbpUi::Languages' | abpLocalization}}</div>\r\n                        <select class=\"form-select \" formControlName=\"culture\">\r\n                            <ng-container *ngFor=\"let item of languagesList;let i =index\">\r\n                                <option [value]=\"item.cultureName\">{{item.displayName}}</option>\r\n                            </ng-container>\r\n                        </select>\r\n                        <div class=\"text-danger\" *ngIf=\"cultureInput.dirty\">\r\n                            {{cultureInput?.errors?.repetition}}\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"mb-3\" *ngIf=\"sectionInfo.type===1\">\r\n                        <label class=\"form-label\" for=\"parentId\">{{'Cms::ParentEntry' | abpLocalization}}</label>\r\n                        <select class=\"form-select\" formControlName=\"parentId\">\r\n                            <option value=\"\"></option>\r\n                            <ng-container *ngFor=\"let item of entryList;let i =index\">\r\n                                <option [value]=\"item.id\">{{item.title}}</option>\r\n                                <ng-container *ngFor=\"let el of item.children\">\r\n                                    <ng-container *ngTemplateOutlet=\"childTemplate; context: {\r\n                                        $implicit: {\r\n                                        value: el,\r\n                                        }\r\n                                    }\"></ng-container>\r\n                                    <ng-template #childTemplate let-data>\r\n                                        <option [value]=\"data.value.id\">\r\n                                            <ng-container *ngFor=\"let item of data.value.layer\">--</ng-container>\r\n                                            {{data.value.title}}\r\n                                        </option>\r\n                                        <ng-container *ngFor=\"let el of data.value.children\">\r\n                                            <ng-container *ngTemplateOutlet=\"childTemplate; context: {\r\n                                                $implicit: {\r\n                                                value: el,\r\n                                                }\r\n                                            }\"></ng-container>\r\n                                        </ng-container>\r\n                                    </ng-template>\r\n                                </ng-container>\r\n                            </ng-container>\r\n                        </select>\r\n                    </div>\r\n                    <div class=\"mb-3\">\r\n                        <label class=\"form-label\" for=\"publishTime\">{{'Cms::PublishTime' | abpLocalization}}</label>\r\n                        <input type=\"datetime-local\" class=\"form-control\" step=\"1\" formControlName=\"publishTime\">\r\n                    </div>\r\n                    <div class=\"mb-3\" *ngIf=\"isEdit\">\r\n                        <label class=\"form-label\" for=\"publishTime\">{{'Cms::Version' | abpLocalization}}</label>\r\n                        <ul class=\"list-group\">\r\n                            <ng-container *ngFor=\"let item of AllVersionsList\">\r\n                                <li\r\n                                    class=\"list-group-item flex-between d-flex align-items-center justify-content-between\">\r\n                                    <div>\r\n                                        {{item.initialVersionId?(item.creationTime| date: 'YYYY/MM/dd HH:mm:s'):('Cms::InitialVersion' | abpLocalization)}}\r\n                                        <span class=\"badge text-bg-success ms-1\"\r\n                                            *ngIf=\"item.isActivatedVersion\">{{'Cms::IsActive' | abpLocalization}}</span>\r\n                                        <span class=\"badge text-bg-primary ms-1\"\r\n                                            *ngIf=\"item.id === entryVersionId\">{{'Cms::Editing' |\r\n                                            abpLocalization}}</span>\r\n                                    </div>\r\n                                    <div>\r\n                                        <div ngbDropdown class=\"d-inline-block\">\r\n                                            <button type=\"button\" class=\"btn btn-link-primary p-2 \"\r\n                                                style=\"line-height: 0;\" id=\"dropdownBasic1\" ngbDropdownToggle>\r\n                                            </button>\r\n                                            <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\">\r\n                                                <button ngbDropdownItem type=\"button\" *ngIf=\"!item.isActivatedVersion\"\r\n                                                    (click)=\"ActivatedVersion(item.id)\">\r\n                                                    <i class=\"fas fa-check me-1\"></i>{{'Cms::IsActive' |\r\n                                                    abpLocalization}}\r\n                                                </button>\r\n                                                <button ngbDropdownItem type=\"button\"\r\n                                                    routerLink=\"/cms/admin/entries/create\"\r\n                                                    [queryParams]=\"{entryVersionId:item.id}\">\r\n                                                    <i class=\"fas fa-plus me-1\"></i>{{'Cms::NewVersion' |\r\n                                                    abpLocalization}}\r\n                                                </button>\r\n                                                <button ngbDropdownItem type=\"button\" (click.stop)=\"toEditUrl(item.id)\"\r\n                                                    *ngIf=\"item.id !== entryVersionId\">\r\n                                                    <i class=\"fas fa-edit me-1\"></i>{{'AbpUi::Edit' | abpLocalization}}\r\n                                                </button>\r\n                                                <button ngbDropdownItem type=\"button\"\r\n                                                    (click.stop)=\"delectVersion(item.id)\"\r\n                                                    *ngIf=\"item.initialVersionId&&!item.isActivatedVersion&&item.id !== entryVersionId\">\r\n                                                    <i class=\"fas fa-trash me-1\"></i>{{'AbpUi::Delete' |\r\n                                                    abpLocalization}}\r\n                                                </button>\r\n                                            </div>\r\n                                        </div>\r\n                                    </div>\r\n                                </li>\r\n                            </ng-container>\r\n                        </ul>\r\n                    </div>\r\n                    <div class=\"mb-3\" *ngIf=\"entryInfo\">\r\n                        <label class=\"form-label\" for=\"versionNotes\">{{'Cms::RevisionNotes' | abpLocalization}}</label>\r\n                        <textarea class=\"form-control\" formControlName=\"versionNotes\" rows=\"3\"></textarea>\r\n                    </div>\r\n\r\n\r\n\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n    <button type=\"submit\" style=\"display: none;\" #submitclick></button>\r\n</form>"]}
|