@dignite-ng/expand.cms 3.1.5 → 3.1.8

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.
@@ -16,7 +16,6 @@ import { SectionAdminService } from '../../../proxy/dignite/cms/admin/sections';
16
16
  import { entryStatusOptions } from '../../../proxy/dignite/cms/entries';
17
17
  import { RegionalizationService } from '../../../proxy/dignite/abp/regionalization-management';
18
18
  import { SectionType } from '../../../proxy/dignite/cms/sections';
19
- import { moveItemInArray } from '@angular/cdk/drag-drop';
20
19
  import { FormAdminService } from '../../../proxy/dignite/cms/admin/dynamic-forms';
21
20
  import { FieldAdminService } from '../../../proxy/dignite/cms/admin/fields';
22
21
  import { FormControlsService } from '../../../services/form-controls.service';
@@ -38,6 +37,7 @@ import * as i14 from "@abp/ng.components/page";
38
37
  import * as i15 from "@dignite-ng/expand.dynamic-form";
39
38
  import * as i16 from "@angular/cdk/drag-drop";
40
39
  import * as i17 from "../../../pipes/get-localized-entries-by-slug.pipe";
40
+ import * as i18 from "../../../pipes/get-slug-by-id.pipe";
41
41
  export class EntriesComponent {
42
42
  constructor(_EntryAdminService, _SectionAdminService, toaster, confirmation, configState, router, _LocalizationService, _FormAdminService, _FieldAdminService, cdRef, _FormControlsService) {
43
43
  this._EntryAdminService = _EntryAdminService;
@@ -92,6 +92,18 @@ export class EntriesComponent {
92
92
  };
93
93
  this.filters = {};
94
94
  this.maxResultCount = 10;
95
+ this.copylistItem = [];
96
+ this.shouldScrollToTop = true;
97
+ /** 当前拖拽目标节点的ID */
98
+ this.dropTargetId = null;
99
+ /** 拖拽位置:above-上方, below-下方, inside-内部 */
100
+ this.dropPosition = null;
101
+ /** 当前被拖拽的节点 */
102
+ this.draggedItem = null;
103
+ /** 是否正在拖拽 */
104
+ this.isDragging = false;
105
+ /** 是否为无效拖拽目标(拖拽到自身或子节点) */
106
+ this.isInvalidDropTarget = false;
95
107
  this.isexpanded = false;
96
108
  }
97
109
  ngOnInit() {
@@ -129,6 +141,7 @@ export class EntriesComponent {
129
141
  })
130
142
  .subscribe(async (res) => {
131
143
  this.SiteOfSectionList = res.items.filter(el => el.isActive);
144
+ // this.filters.sectionId = res.items[res.items.length-1]?.id || '';
132
145
  this.filters.sectionId = res.items[0]?.id || '';
133
146
  await this.getSectionOfEntryType();
134
147
  resolve(res.items);
@@ -314,17 +327,19 @@ export class EntriesComponent {
314
327
  const setData = (list) => {
315
328
  this.data.items = [];
316
329
  this.data.totalCount = 0;
317
- if (this.SiteOfSectionType == SectionType.Structure) {
318
- list.items = list.items.sort((a, b) => {
319
- return new Date(b.creationTime).getTime() - new Date(a.creationTime).getTime();
320
- });
321
- }
322
330
  for (const element of list.items) {
323
331
  const sectionItem = this.SiteOfSectionList.find(el => el.id == element.sectionId);
324
332
  element.sectionType = sectionItem.type;
325
333
  }
334
+ if (this.SiteOfSectionType == SectionType.Structure) {
335
+ this.copylistItem = list.items;
336
+ list.items = this.buildTree(list.items);
337
+ }
326
338
  this.data = list;
327
- this.scrollToTop();
339
+ if (this.shouldScrollToTop) {
340
+ this.scrollToTop();
341
+ }
342
+ this.shouldScrollToTop = true;
328
343
  };
329
344
  this.list.hookToQuery(getData).subscribe(setData);
330
345
  }
@@ -352,33 +367,241 @@ export class EntriesComponent {
352
367
  }
353
368
  });
354
369
  }
370
+ /**
371
+ * CDK拖拽开始事件
372
+ */
373
+ onDragStarted(event) {
374
+ this.isDragging = true;
375
+ this.draggedItem = event.source.data?.item;
376
+ }
377
+ /**
378
+ * CDK拖拽结束事件
379
+ */
380
+ onDragEnded(event) {
381
+ // 不立即清除状态,让drop方法先执行
382
+ setTimeout(() => {
383
+ this.isDragging = false;
384
+ this.draggedItem = null;
385
+ this.isInvalidDropTarget = false;
386
+ }, 100);
387
+ }
388
+ /**
389
+ * CDK拖拽进入事件
390
+ */
391
+ onDragEntered(event, targetItem) {
392
+ if (!this.isDragging)
393
+ return;
394
+ this.dropTargetId = targetItem.id;
395
+ }
396
+ /**
397
+ * 鼠标移动事件,判断位置
398
+ */
399
+ onMouseMove(event, targetItem) {
400
+ if (!this.isDragging || !this.draggedItem)
401
+ return;
402
+ const target = event.currentTarget.closest('tr');
403
+ if (!target)
404
+ return;
405
+ this.dropTargetId = targetItem.id;
406
+ const rect = target.getBoundingClientRect();
407
+ const y = event.clientY - rect.top;
408
+ const height = rect.height;
409
+ if (y < height * 0.25) {
410
+ this.dropPosition = 'above';
411
+ }
412
+ else if (y > height * 0.75) {
413
+ this.dropPosition = 'below';
414
+ }
415
+ else {
416
+ this.dropPosition = 'inside';
417
+ }
418
+ // 检查是否为无效拖拽目标
419
+ this.isInvalidDropTarget = this.isDescendantOrSelf(this.draggedItem.id, targetItem.id);
420
+ // console.log('拖拽节点ID:', this.draggedItem.id, '目标节点ID:', targetItem.id, '是否无效:', this.isInvalidDropTarget);
421
+ }
422
+ /**
423
+ * 拖拽离开事件处理
424
+ * 清除拖拽目标和位置标识
425
+ */
426
+ onDragLeave(event) {
427
+ // 不立即清除状态,让drop事件能够获取到dropTargetId和dropPosition
428
+ // 状态会在drop事件中清除
429
+ }
430
+ /**
431
+ * 拖拽释放事件处理
432
+ * 根据拖拽位置调用后端API移动节点
433
+ * @param event CDK拖拽事件
434
+ */
355
435
  drop(event) {
356
- const previousId = this.data.items[event.previousIndex].id;
357
- const previousIndexOrder = this.data.items[event.previousIndex].order;
358
- const currentIndexOrder = this.data.items[event.currentIndex].order;
359
- let moveorder = currentIndexOrder;
360
- if (event.previousIndex == event.currentIndex)
436
+ // 获取被拖拽的节点数据
437
+ const draggedData = event.item.data;
438
+ if (!draggedData) {
439
+ console.log('无draggedData');
440
+ this.clearDropState();
441
+ return;
442
+ }
443
+ const draggedItem = draggedData.item;
444
+ // 验证拖拽目标和位置是否有效
445
+ if (!this.dropTargetId || !this.dropPosition) {
446
+ console.log('无拖拽目标或位置');
447
+ this.clearDropState();
361
448
  return;
362
- if (previousIndexOrder < currentIndexOrder) {
363
- moveorder = currentIndexOrder + 1;
364
449
  }
365
- moveItemInArray(this.data.items, event.previousIndex, event.currentIndex);
450
+ // 在原始平铺数据中查找目标节点
451
+ const targetItem = this.findItemById(this.copylistItem, this.dropTargetId);
452
+ // 验证目标节点存在且不是自己或子节点
453
+ if (!targetItem || this.isDescendantOrSelf(draggedItem.id, targetItem.id)) {
454
+ this.toaster.warn(this._LocalizationService.instant('Cms::CannotDragToSelfOrDescendant'));
455
+ this.clearDropState();
456
+ return;
457
+ }
458
+ console.log('拖拽节点:', draggedItem);
459
+ /*
460
+ 拖拽位置:above-上方, below-下方, inside-内部
461
+ dropPosition: 'above' | 'below' | 'inside' | null = null;
462
+ */
463
+ console.log('目标节点:', targetItem);
464
+ console.log('位置:', this.dropPosition);
465
+ // 构建移动参数
466
+ const moveParams = {};
467
+ // 如果是放置到内部,设置parentId为目标节点ID
468
+ if (this.dropPosition === 'inside') {
469
+ moveParams.parentId = targetItem.id;
470
+ }
471
+ // 如果是放置在上方或下方,使用目标节点的parentId和order
472
+ else {
473
+ moveParams.parentId = targetItem.parentId;
474
+ // 上方使用目标节点的order,下方使用order+1
475
+ moveParams.order = this.dropPosition === 'above' ? targetItem.order : targetItem.order + 1;
476
+ }
477
+ console.log('移动参数:', moveParams);
478
+ // 立即更新本地数据
479
+ this.updateLocalData(draggedItem, moveParams);
480
+ this.clearDropState();
481
+ // 调用后端API
366
482
  this._EntryAdminService
367
- .move(previousId, {
368
- order: moveorder,
369
- // order: event.currentIndex,
370
- })
371
- .pipe(finalize(() => {
483
+ .move(draggedItem.id, moveParams)
484
+ .subscribe(() => {
485
+ this.toaster.success(this._LocalizationService.instant('AbpUi::SavedSuccessfully'));
486
+ this.shouldScrollToTop = false;
487
+ this.list.get();
488
+ }, () => {
489
+ this.shouldScrollToTop = false;
372
490
  this.list.get();
373
- }))
374
- .subscribe(res => { }, err => { });
375
- // moveItemInArray(this.rows, event.previousIndex, event.currentIndex);
376
- // this.rows = [...this.rows];
491
+ });
492
+ }
493
+ /**
494
+ * 清除拖拽状态
495
+ */
496
+ clearDropState() {
497
+ this.dropTargetId = null;
498
+ this.dropPosition = null;
499
+ this.isDragging = false;
500
+ this.draggedItem = null;
501
+ this.isInvalidDropTarget = false;
502
+ }
503
+ /**
504
+ * 检查目标节点是否是拖拽节点的后代或自身
505
+ */
506
+ isDescendantOrSelf(draggedId, targetId) {
507
+ if (draggedId === targetId) {
508
+ // console.log('目标是自身');
509
+ return true;
510
+ }
511
+ const result = this.isDescendant(draggedId, targetId);
512
+ // console.log('目标是子节点:', result);
513
+ return result;
514
+ }
515
+ /**
516
+ * 递归检查目标节点是否是拖拽节点的子节点
517
+ */
518
+ isDescendant(parentId, childId) {
519
+ const parent = this.findItemById(this.data.items, parentId);
520
+ if (!parent)
521
+ return false;
522
+ const checkChildren = (node) => {
523
+ if (!node.children || node.children.length === 0)
524
+ return false;
525
+ for (const child of node.children) {
526
+ if (child.id === childId)
527
+ return true;
528
+ if (checkChildren(child))
529
+ return true;
530
+ }
531
+ return false;
532
+ };
533
+ return checkChildren(parent);
534
+ }
535
+ /**
536
+ * 在树形结构或平铺数组中递归查找指定ID的节点
537
+ * @param items 节点数组
538
+ * @param id 要查找的节点ID
539
+ * @returns 找到的节点或null
540
+ */
541
+ findItemById(items, id) {
542
+ for (const item of items) {
543
+ if (item.id === id)
544
+ return item;
545
+ // 如果有子节点,递归查找
546
+ if (item.children) {
547
+ const found = this.findItemById(item.children, id);
548
+ if (found)
549
+ return found;
550
+ }
551
+ }
552
+ return null;
553
+ }
554
+ /**
555
+ * 更新本地数据
556
+ */
557
+ updateLocalData(draggedItem, moveParams) {
558
+ const flatItem = this.copylistItem.find(item => item.id === draggedItem.id);
559
+ if (!flatItem)
560
+ return;
561
+ flatItem.parentId = moveParams.parentId;
562
+ if (moveParams.order !== undefined) {
563
+ flatItem.order = moveParams.order;
564
+ }
565
+ else {
566
+ // 拖拽到内部时,设置为0(子节点开头)
567
+ flatItem.order = 0;
568
+ }
569
+ this.data.items = this.buildTree(this.copylistItem);
377
570
  }
378
571
  /**高级筛选切换 */
379
572
  expandedChange(event) {
380
573
  this.isexpanded = event;
381
574
  }
575
+ /**将平铺数据转换为树形结构并排序 */
576
+ buildTree(items) {
577
+ const map = new Map();
578
+ const roots = [];
579
+ items.forEach(item => {
580
+ map.set(item.id, { ...item, children: [] });
581
+ });
582
+ items.forEach(item => {
583
+ const node = map.get(item.id);
584
+ if (item.parentId === null || item.parentId === undefined) {
585
+ roots.push(node);
586
+ }
587
+ else {
588
+ const parent = map.get(item.parentId);
589
+ if (parent) {
590
+ parent.children.push(node);
591
+ }
592
+ }
593
+ });
594
+ const sortByOrder = (nodes) => {
595
+ nodes.sort((a, b) => a.order - b.order);
596
+ nodes.forEach(node => {
597
+ if (node.children && node.children.length > 0) {
598
+ sortByOrder(node.children);
599
+ }
600
+ });
601
+ };
602
+ sortByOrder(roots);
603
+ return roots;
604
+ }
382
605
  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 }); }
383
606
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.5", type: EntriesComponent, selector: "cms-entries", providers: [
384
607
  ListService,
@@ -389,7 +612,7 @@ export class EntriesComponent {
389
612
  provide: EXTENSIONS_IDENTIFIER,
390
613
  useValue: ECmsComponent.Entries,
391
614
  },
392
- ], ngImport: i0, template: "<abp-page [title]=\"'Cms::Entries' | abpLocalization\" [toolbar]=\"true\">\r\n <abp-page-toolbar-container *ngIf=\"entryTypeList.length < 1\" class=\"col \">\r\n </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 <ng-container *ngFor=\"let item of entryTypeList\">\r\n <button class=\"btn btn-sm btn-primary\"\r\n [disabled]=\"data.totalCount===1&&SiteOfSectionType===SectionType.Single\"\r\n [routerLink]=\"['/cms/admin/entries/create']\"\r\n [queryParams]=\"{cultureName: filters.culture,sectionId:filters.sectionId,entryTypeId:item.id}\"><i\r\n class=\"fa fa-plus me-2\"></i> {{'Cms::NewEntry'|abpLocalization}}</button>\r\n </ng-container>\r\n </div>\r\n </div>\r\n </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::NewEntry' | 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 [disabled]=\"data.totalCount===1&&SiteOfSectionType===SectionType.Single&&isEntryTypeExist(item.id)\"\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-md-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-md-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-md-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-md-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-md-3 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::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::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::SectionType' | abpLocalization\" prop=\"sectionType\"\r\n [sortable]=\"false\">\r\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n {{ 'Cms::Enum:SectionType:'+SectionType[value] |\r\n abpLocalization }}\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 \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\">{{'Cms::Edit' |\r\n abpLocalization}}</button>\r\n @if\r\n (((row|getLocalizedEntriesBySlug:filters.sectionId:sectionLanguagesList)|async)===false)\r\n {\r\n <button ngbDropdownItem [routerLink]=\"['/cms/admin/entries/create']\"\r\n [queryParams]=\"{cultureName: filters.culture,sectionId:filters.sectionId,entryTypeId:row.entryTypeId,entryVersionId:row.id,isOther:1}\">{{'Cms::CreateOtherLanguages'\r\n |\r\n abpLocalization}} </button>\r\n }\r\n <button ngbDropdownItem (click)=\"deletefield(row)\">{{'Cms::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\"> <span\r\n class=\"bi bi-arrows-move fs-5 drag-handle me-2 opacity-0\"></span>{{'AbpUi::Actions'\r\n | abpLocalization}}</th>\r\n <th>{{'Cms::Slug' | abpLocalization}}</th>\r\n <!-- <th>{{'Cms::Title' | abpLocalization}}</th> -->\r\n <th>{{'Cms::SectionType' | abpLocalization}}</th>\r\n <th>{{'Cms::EntryType' | 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 <span class=\"bi bi-arrows-move fs-5 drag-handle me-2\" cdkDragHandle></span>\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 @if\r\n (((item|getLocalizedEntriesBySlug:filters.sectionId:sectionLanguagesList)|async)===false)\r\n {\r\n <button ngbDropdownItem [routerLink]=\"['/cms/admin/entries/create']\"\r\n [queryParams]=\"{cultureName: filters.culture,sectionId:filters.sectionId,entryTypeId:item.entryTypeId,entryVersionId:item.id,isOther:1}\">{{'Cms::CreateOtherLanguages'\r\n |\r\n abpLocalization}}</button>\r\n }\r\n <!-- <button ngbDropdownItem [routerLink]=\"['/cms/admin/entries/create']\"\r\n [queryParams]=\"{cultureName: filters.culture,sectionId:filters.sectionId,entryTypeId:row.entryTypeId,entryVersionId:row.id,isOther:1}\">{{'Cms::CreateOtherLanguages'\r\n |\r\n abpLocalization}} </button> -->\r\n\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 class=\"white-space-normal\">{{item.slug}}</td>\r\n <td>\r\n {{ 'Cms::Enum:SectionType:'+SectionType[item.sectionType] |\r\n abpLocalization }}\r\n </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 \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\"\r\n [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.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: "directive", type: i16.CdkDragHandle, selector: "[cdkDragHandle]", inputs: ["cdkDragHandleDisabled"] }, { kind: "pipe", type: i9.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.LocalizationPipe, name: "abpLocalization" }, { kind: "pipe", type: i4.ShortDateTimePipe, name: "shortDateTime" }, { kind: "pipe", type: i17.GetLocalizedEntriesBySlugPipe, name: "getLocalizedEntriesBySlug" }] }); }
615
+ ], ngImport: i0, template: "<abp-page [title]=\"'Cms::Entries' | abpLocalization\" [toolbar]=\"true\">\r\n <abp-page-toolbar-container *ngIf=\"entryTypeList.length < 1\" class=\"col \">\r\n </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 <ng-container *ngFor=\"let item of entryTypeList\">\r\n <button class=\"btn btn-sm btn-primary\"\r\n [disabled]=\"data.totalCount===1&&SiteOfSectionType===SectionType.Single\"\r\n [routerLink]=\"['/cms/admin/entries/create']\"\r\n [queryParams]=\"{cultureName: filters.culture,sectionId:filters.sectionId,entryTypeId:item.id}\"><i\r\n class=\"fa fa-plus me-2\"></i> {{'Cms::NewEntry'|abpLocalization}}</button>\r\n </ng-container>\r\n </div>\r\n </div>\r\n </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::NewEntry' | 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 [disabled]=\"data.totalCount===1&&SiteOfSectionType===SectionType.Single&&isEntryTypeExist(item.id)\"\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-md-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-md-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-md-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-md-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-md-3 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::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::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::SectionType' | abpLocalization\" prop=\"sectionType\"\r\n [sortable]=\"false\">\r\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n {{ 'Cms::Enum:SectionType:'+SectionType[value] |\r\n abpLocalization }}\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\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\">{{'Cms::Edit' |\r\n abpLocalization}}</button>\r\n @if\r\n (((row|getLocalizedEntriesBySlug:filters.sectionId:sectionLanguagesList)|async)===false)\r\n {\r\n <button ngbDropdownItem [routerLink]=\"['/cms/admin/entries/create']\"\r\n [queryParams]=\"{cultureName: filters.culture,sectionId:filters.sectionId,entryTypeId:row.entryTypeId,entryVersionId:row.id,isOther:1}\">{{'Cms::CreateOtherLanguages'\r\n |\r\n abpLocalization}} </button>\r\n }\r\n <button ngbDropdownItem (click)=\"deletefield(row)\">{{'Cms::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 [cdkDropListSortingDisabled]=\"true\" (cdkDropListDropped)=\"drop($event)\">\r\n <thead>\r\n <tr>\r\n <th class=\"sticky-left-card-bg\"> <span\r\n class=\"bi bi-arrows-move fs-5 drag-handle me-2 opacity-0\"></span>{{'AbpUi::Actions'\r\n | abpLocalization}}</th>\r\n <th>{{'Cms::Slug' | abpLocalization}}</th>\r\n <th>{{'Cms::ParentEntry' | abpLocalization}}</th>\r\n <!-- <th>{{'Cms::Title' | abpLocalization}}</th> -->\r\n <th>{{'Cms::SectionType' | abpLocalization}}</th>\r\n <th>{{'Cms::EntryType' | 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 <ng-container *ngFor=\"let item of data.items\">\r\n <ng-container *ngTemplateOutlet=\"treeRow; context: {item: item, level: 0}\"></ng-container>\r\n </ng-container>\r\n </tbody>\r\n \r\n <ng-template #treeRow let-item=\"item\" let-level=\"level\">\r\n <tr cdkDrag [cdkDragData]=\"{item: item, level: level}\"\r\n [class.drop-above]=\"dropPosition === 'above' && dropTargetId === item.id && !isInvalidDropTarget\"\r\n [class.drop-below]=\"dropPosition === 'below' && dropTargetId === item.id && !isInvalidDropTarget\"\r\n [class.drop-inside]=\"dropPosition === 'inside' && dropTargetId === item.id && !isInvalidDropTarget\"\r\n [class.drop-invalid]=\"dropTargetId === item.id && isInvalidDropTarget\"\r\n [style.cursor]=\"dropTargetId === item.id && isInvalidDropTarget ? 'not-allowed' : ''\"\r\n (cdkDragStarted)=\"onDragStarted($event)\"\r\n (cdkDragEnded)=\"onDragEnded($event)\"\r\n (cdkDragEntered)=\"onDragEntered($event, item)\"\r\n (mousemove)=\"onMouseMove($event, item)\">\r\n <td class=\"sticky-left-card-bg\">\r\n <div ngbDropdown container=\"body\">\r\n <span class=\"bi bi-arrows-move fs-5 drag-handle me-2\" cdkDragHandle></span>\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 @if\r\n (((item|getLocalizedEntriesBySlug:filters.sectionId:sectionLanguagesList)|async)===false)\r\n {\r\n <button ngbDropdownItem [routerLink]=\"['/cms/admin/entries/create']\"\r\n [queryParams]=\"{cultureName: filters.culture,sectionId:filters.sectionId,entryTypeId:item.entryTypeId,entryVersionId:item.id,isOther:1}\">{{'Cms::CreateOtherLanguages'\r\n |\r\n abpLocalization}}</button>\r\n }\r\n <!-- <button ngbDropdownItem [routerLink]=\"['/cms/admin/entries/create']\"\r\n [queryParams]=\"{cultureName: filters.culture,sectionId:filters.sectionId,entryTypeId:row.entryTypeId,entryVersionId:row.id,isOther:1}\">{{'Cms::CreateOtherLanguages'\r\n |\r\n abpLocalization}} </button> -->\r\n\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\" (mousemove)=\"onMouseMove($event, item)\">\r\n <span [style.padding-left.px]=\"level * 20\">{{item.slug}}</span>\r\n </td>\r\n <td class=\"white-space-normal\">{{(item.parentId|getSlugById:copylistItem)||'---'}}</td>\r\n <td>\r\n {{ 'Cms::Enum:SectionType:'+SectionType[item.sectionType] |\r\n abpLocalization }}\r\n </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\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\"\r\n [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 <ng-container *ngIf=\"item.children && item.children.length > 0\">\r\n <ng-container *ngFor=\"let child of item.children\">\r\n <ng-container *ngTemplateOutlet=\"treeRow; context: {item: child, level: level + 1}\"></ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </ng-template>\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 .table .drag-handle{cursor:move;cursor:grab}::ng-deep .sites-page .table .drag-handle:active{cursor:grabbing}::ng-deep .sites-page .entries-advanced-form{transition:all .3s linear}.drop-above{border-top:3px solid #28a745!important}.drop-below{border-bottom:3px solid #28a745!important}.drop-inside{background-color:#28a7451a!important}.drop-invalid{background-color:#dc35451a!important}tr[cdkDrag] td{vertical-align:middle}.drag-handle{cursor:move;cursor:grab}.drag-handle:active{cursor:grabbing}\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: i9.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { 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.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: "directive", type: i16.CdkDragHandle, selector: "[cdkDragHandle]", inputs: ["cdkDragHandleDisabled"] }, { kind: "pipe", type: i9.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.LocalizationPipe, name: "abpLocalization" }, { kind: "pipe", type: i4.ShortDateTimePipe, name: "shortDateTime" }, { kind: "pipe", type: i17.GetLocalizedEntriesBySlugPipe, name: "getLocalizedEntriesBySlug" }, { kind: "pipe", type: i18.GetSlugByIdPipe, name: "getSlugById" }] }); }
393
616
  }
394
617
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: EntriesComponent, decorators: [{
395
618
  type: Component,
@@ -402,6 +625,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
402
625
  provide: EXTENSIONS_IDENTIFIER,
403
626
  useValue: ECmsComponent.Entries,
404
627
  },
405
- ], template: "<abp-page [title]=\"'Cms::Entries' | abpLocalization\" [toolbar]=\"true\">\r\n <abp-page-toolbar-container *ngIf=\"entryTypeList.length < 1\" class=\"col \">\r\n </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 <ng-container *ngFor=\"let item of entryTypeList\">\r\n <button class=\"btn btn-sm btn-primary\"\r\n [disabled]=\"data.totalCount===1&&SiteOfSectionType===SectionType.Single\"\r\n [routerLink]=\"['/cms/admin/entries/create']\"\r\n [queryParams]=\"{cultureName: filters.culture,sectionId:filters.sectionId,entryTypeId:item.id}\"><i\r\n class=\"fa fa-plus me-2\"></i> {{'Cms::NewEntry'|abpLocalization}}</button>\r\n </ng-container>\r\n </div>\r\n </div>\r\n </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::NewEntry' | 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 [disabled]=\"data.totalCount===1&&SiteOfSectionType===SectionType.Single&&isEntryTypeExist(item.id)\"\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-md-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-md-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-md-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-md-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-md-3 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::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::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::SectionType' | abpLocalization\" prop=\"sectionType\"\r\n [sortable]=\"false\">\r\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n {{ 'Cms::Enum:SectionType:'+SectionType[value] |\r\n abpLocalization }}\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 \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\">{{'Cms::Edit' |\r\n abpLocalization}}</button>\r\n @if\r\n (((row|getLocalizedEntriesBySlug:filters.sectionId:sectionLanguagesList)|async)===false)\r\n {\r\n <button ngbDropdownItem [routerLink]=\"['/cms/admin/entries/create']\"\r\n [queryParams]=\"{cultureName: filters.culture,sectionId:filters.sectionId,entryTypeId:row.entryTypeId,entryVersionId:row.id,isOther:1}\">{{'Cms::CreateOtherLanguages'\r\n |\r\n abpLocalization}} </button>\r\n }\r\n <button ngbDropdownItem (click)=\"deletefield(row)\">{{'Cms::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\"> <span\r\n class=\"bi bi-arrows-move fs-5 drag-handle me-2 opacity-0\"></span>{{'AbpUi::Actions'\r\n | abpLocalization}}</th>\r\n <th>{{'Cms::Slug' | abpLocalization}}</th>\r\n <!-- <th>{{'Cms::Title' | abpLocalization}}</th> -->\r\n <th>{{'Cms::SectionType' | abpLocalization}}</th>\r\n <th>{{'Cms::EntryType' | 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 <span class=\"bi bi-arrows-move fs-5 drag-handle me-2\" cdkDragHandle></span>\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 @if\r\n (((item|getLocalizedEntriesBySlug:filters.sectionId:sectionLanguagesList)|async)===false)\r\n {\r\n <button ngbDropdownItem [routerLink]=\"['/cms/admin/entries/create']\"\r\n [queryParams]=\"{cultureName: filters.culture,sectionId:filters.sectionId,entryTypeId:item.entryTypeId,entryVersionId:item.id,isOther:1}\">{{'Cms::CreateOtherLanguages'\r\n |\r\n abpLocalization}}</button>\r\n }\r\n <!-- <button ngbDropdownItem [routerLink]=\"['/cms/admin/entries/create']\"\r\n [queryParams]=\"{cultureName: filters.culture,sectionId:filters.sectionId,entryTypeId:row.entryTypeId,entryVersionId:row.id,isOther:1}\">{{'Cms::CreateOtherLanguages'\r\n |\r\n abpLocalization}} </button> -->\r\n\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 class=\"white-space-normal\">{{item.slug}}</td>\r\n <td>\r\n {{ 'Cms::Enum:SectionType:'+SectionType[item.sectionType] |\r\n abpLocalization }}\r\n </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 \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\"\r\n [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"] }]
628
+ ], template: "<abp-page [title]=\"'Cms::Entries' | abpLocalization\" [toolbar]=\"true\">\r\n <abp-page-toolbar-container *ngIf=\"entryTypeList.length < 1\" class=\"col \">\r\n </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 <ng-container *ngFor=\"let item of entryTypeList\">\r\n <button class=\"btn btn-sm btn-primary\"\r\n [disabled]=\"data.totalCount===1&&SiteOfSectionType===SectionType.Single\"\r\n [routerLink]=\"['/cms/admin/entries/create']\"\r\n [queryParams]=\"{cultureName: filters.culture,sectionId:filters.sectionId,entryTypeId:item.id}\"><i\r\n class=\"fa fa-plus me-2\"></i> {{'Cms::NewEntry'|abpLocalization}}</button>\r\n </ng-container>\r\n </div>\r\n </div>\r\n </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::NewEntry' | 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 [disabled]=\"data.totalCount===1&&SiteOfSectionType===SectionType.Single&&isEntryTypeExist(item.id)\"\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-md-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-md-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-md-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-md-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-md-3 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::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::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::SectionType' | abpLocalization\" prop=\"sectionType\"\r\n [sortable]=\"false\">\r\n <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n {{ 'Cms::Enum:SectionType:'+SectionType[value] |\r\n abpLocalization }}\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\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\">{{'Cms::Edit' |\r\n abpLocalization}}</button>\r\n @if\r\n (((row|getLocalizedEntriesBySlug:filters.sectionId:sectionLanguagesList)|async)===false)\r\n {\r\n <button ngbDropdownItem [routerLink]=\"['/cms/admin/entries/create']\"\r\n [queryParams]=\"{cultureName: filters.culture,sectionId:filters.sectionId,entryTypeId:row.entryTypeId,entryVersionId:row.id,isOther:1}\">{{'Cms::CreateOtherLanguages'\r\n |\r\n abpLocalization}} </button>\r\n }\r\n <button ngbDropdownItem (click)=\"deletefield(row)\">{{'Cms::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 [cdkDropListSortingDisabled]=\"true\" (cdkDropListDropped)=\"drop($event)\">\r\n <thead>\r\n <tr>\r\n <th class=\"sticky-left-card-bg\"> <span\r\n class=\"bi bi-arrows-move fs-5 drag-handle me-2 opacity-0\"></span>{{'AbpUi::Actions'\r\n | abpLocalization}}</th>\r\n <th>{{'Cms::Slug' | abpLocalization}}</th>\r\n <th>{{'Cms::ParentEntry' | abpLocalization}}</th>\r\n <!-- <th>{{'Cms::Title' | abpLocalization}}</th> -->\r\n <th>{{'Cms::SectionType' | abpLocalization}}</th>\r\n <th>{{'Cms::EntryType' | 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 <ng-container *ngFor=\"let item of data.items\">\r\n <ng-container *ngTemplateOutlet=\"treeRow; context: {item: item, level: 0}\"></ng-container>\r\n </ng-container>\r\n </tbody>\r\n \r\n <ng-template #treeRow let-item=\"item\" let-level=\"level\">\r\n <tr cdkDrag [cdkDragData]=\"{item: item, level: level}\"\r\n [class.drop-above]=\"dropPosition === 'above' && dropTargetId === item.id && !isInvalidDropTarget\"\r\n [class.drop-below]=\"dropPosition === 'below' && dropTargetId === item.id && !isInvalidDropTarget\"\r\n [class.drop-inside]=\"dropPosition === 'inside' && dropTargetId === item.id && !isInvalidDropTarget\"\r\n [class.drop-invalid]=\"dropTargetId === item.id && isInvalidDropTarget\"\r\n [style.cursor]=\"dropTargetId === item.id && isInvalidDropTarget ? 'not-allowed' : ''\"\r\n (cdkDragStarted)=\"onDragStarted($event)\"\r\n (cdkDragEnded)=\"onDragEnded($event)\"\r\n (cdkDragEntered)=\"onDragEntered($event, item)\"\r\n (mousemove)=\"onMouseMove($event, item)\">\r\n <td class=\"sticky-left-card-bg\">\r\n <div ngbDropdown container=\"body\">\r\n <span class=\"bi bi-arrows-move fs-5 drag-handle me-2\" cdkDragHandle></span>\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 @if\r\n (((item|getLocalizedEntriesBySlug:filters.sectionId:sectionLanguagesList)|async)===false)\r\n {\r\n <button ngbDropdownItem [routerLink]=\"['/cms/admin/entries/create']\"\r\n [queryParams]=\"{cultureName: filters.culture,sectionId:filters.sectionId,entryTypeId:item.entryTypeId,entryVersionId:item.id,isOther:1}\">{{'Cms::CreateOtherLanguages'\r\n |\r\n abpLocalization}}</button>\r\n }\r\n <!-- <button ngbDropdownItem [routerLink]=\"['/cms/admin/entries/create']\"\r\n [queryParams]=\"{cultureName: filters.culture,sectionId:filters.sectionId,entryTypeId:row.entryTypeId,entryVersionId:row.id,isOther:1}\">{{'Cms::CreateOtherLanguages'\r\n |\r\n abpLocalization}} </button> -->\r\n\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\" (mousemove)=\"onMouseMove($event, item)\">\r\n <span [style.padding-left.px]=\"level * 20\">{{item.slug}}</span>\r\n </td>\r\n <td class=\"white-space-normal\">{{(item.parentId|getSlugById:copylistItem)||'---'}}</td>\r\n <td>\r\n {{ 'Cms::Enum:SectionType:'+SectionType[item.sectionType] |\r\n abpLocalization }}\r\n </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\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\"\r\n [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 <ng-container *ngIf=\"item.children && item.children.length > 0\">\r\n <ng-container *ngFor=\"let child of item.children\">\r\n <ng-container *ngTemplateOutlet=\"treeRow; context: {item: child, level: level + 1}\"></ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </ng-template>\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 .table .drag-handle{cursor:move;cursor:grab}::ng-deep .sites-page .table .drag-handle:active{cursor:grabbing}::ng-deep .sites-page .entries-advanced-form{transition:all .3s linear}.drop-above{border-top:3px solid #28a745!important}.drop-below{border-bottom:3px solid #28a745!important}.drop-inside{background-color:#28a7451a!important}.drop-invalid{background-color:#dc35451a!important}tr[cdkDrag] td{vertical-align:middle}.drag-handle{cursor:move;cursor:grab}.drag-handle:active{cursor:grabbing}\n"] }]
406
629
  }], 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 }] });
407
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entries.component.js","sourceRoot":"","sources":["../../../../../../../../packages/cms/src/lib/components/admin/entries/entries.component.ts","../../../../../../../../packages/cms/src/lib/components/admin/entries/entries.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-constant-condition */\n/* eslint-disable no-async-promise-executor */\n/* eslint-disable @angular-eslint/component-selector */\nimport { 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.data.items = [];\n      this.data.totalCount = 0;\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    this.enableSearchTypeList = await this._FormControlsService.getEnableSearchTypeList();\n    await this.getSiteOfSectionList();\n    await this.getSectionLanguagesList();\n    this.filters.sorting = 'creationTime desc';\n    this.hookToQuery();\n  }\n  /**需要查询的动态表单类型 */\n  enableSearchTypeList: any[] = [];\n  /**需要查询的动态表单字段 */\n  enableSearchFieldList: any[] = [];\n  /**不需要展示的动态表单类型 */\n  disableshowinTypeList: any[] = [];\n  /**需要展示的动态列表字段 */\n  showinFieldList: any[] = [];\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.filter(el => el.isActive );\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      const extraProperties = this.extraPropertiesInput.value;\n      const 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    const sectionId = this.filters.sectionId;\n    const SectionInfo: any = await this.getSectionInfo(sectionId);\n    const _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    this.enableSearchFieldList = [];\n    this.showinFieldList = [];\n    // _entryTypeList.length === 1\n    if (true) {\n      // this.filters.entryTypeId = this.entryTypeList[0].id;\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  }\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      const 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      const LanguagesArray = languagesSystem.filter(el => LanguagesSite.includes(el.cultureName));\n      //获取当前选择的语言\n      const nowculture = this.filters.culture;\n      // let nowculture = this.filtersForm.get('culture').value;\n      //当前选择的语言，是否在版块的的语言列表中\n      const 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     sorting : 'creationTime desc',\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      this.data.items = [];\n      this.data.totalCount = 0;\n      if (this.SiteOfSectionType == SectionType.Structure) {\n        list.items = list.items.sort((a, b) => {\n          return new Date(b.creationTime).getTime() - new Date(a.creationTime).getTime();\n        });\n      }\n      for (const element of list.items) {\n        const sectionItem=this.SiteOfSectionList.find(el=>el.id==element.sectionId);\n        element.sectionType=sectionItem.type;\n      }\n      this.data = list;\n      this.scrollToTop();\n    };\n    this.list.hookToQuery(getData).subscribe(setData);\n  }\n  scrollToTop() {\n    const scrollContainer = document.getElementsByClassName('lpx-scroll-container')[0];\n    (scrollContainer || window).scrollTo(0, 0);\n  }\n\n  /**判断某个类型的条目是否存在 */\n  isEntryTypeExist(entryTypeId: string) {\n    return this.data?.items?.some(el => el.entryTypeId == entryTypeId);\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    const previousId: any = this.data.items[event.previousIndex].id;\n    const previousIndexOrder = this.data.items[event.previousIndex].order;\n    const currentIndexOrder = this.data.items[event.currentIndex].order;\n    let moveorder = currentIndexOrder;\n    if (event.previousIndex == event.currentIndex) return\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 | any = 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 \">\r\n    </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                <ng-container *ngFor=\"let item of entryTypeList\">\r\n                    <button class=\"btn btn-sm btn-primary\"\r\n                        [disabled]=\"data.totalCount===1&&SiteOfSectionType===SectionType.Single\"\r\n                        [routerLink]=\"['/cms/admin/entries/create']\"\r\n                        [queryParams]=\"{cultureName: filters.culture,sectionId:filters.sectionId,entryTypeId:item.id}\"><i\r\n                            class=\"fa fa-plus me-2\"></i> {{'Cms::NewEntry'|abpLocalization}}</button>\r\n                </ng-container>\r\n            </div>\r\n        </div>\r\n    </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::NewEntry' | 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                                [disabled]=\"data.totalCount===1&&SiteOfSectionType===SectionType.Single&&isEntryTypeExist(item.id)\"\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-md-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-md-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-md-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-md-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-md-3 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::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::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::SectionType' | abpLocalization\" prop=\"sectionType\"\r\n                            [sortable]=\"false\">\r\n                            <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n                                {{ 'Cms::Enum:SectionType:'+SectionType[value] |\r\n                                        abpLocalization }}\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                        \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\">{{'Cms::Edit' |\r\n                                            abpLocalization}}</button>\r\n                                        @if\r\n                                        (((row|getLocalizedEntriesBySlug:filters.sectionId:sectionLanguagesList)|async)===false)\r\n                                        {\r\n                                        <button ngbDropdownItem [routerLink]=\"['/cms/admin/entries/create']\"\r\n                                            [queryParams]=\"{cultureName: filters.culture,sectionId:filters.sectionId,entryTypeId:row.entryTypeId,entryVersionId:row.id,isOther:1}\">{{'Cms::CreateOtherLanguages'\r\n                                            |\r\n                                            abpLocalization}} </button>\r\n                                        }\r\n                                        <button ngbDropdownItem (click)=\"deletefield(row)\">{{'Cms::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\"> <span\r\n                                        class=\"bi bi-arrows-move fs-5 drag-handle me-2 opacity-0\"></span>{{'AbpUi::Actions'\r\n                                    | abpLocalization}}</th>\r\n                                      <th>{{'Cms::Slug' | abpLocalization}}</th>\r\n                                <!-- <th>{{'Cms::Title' | abpLocalization}}</th> -->\r\n                                <th>{{'Cms::SectionType' | abpLocalization}}</th>\r\n                                <th>{{'Cms::EntryType' | 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                                        <span class=\"bi bi-arrows-move fs-5 drag-handle me-2\" cdkDragHandle></span>\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                                            @if\r\n                                            (((item|getLocalizedEntriesBySlug:filters.sectionId:sectionLanguagesList)|async)===false)\r\n                                            {\r\n                                            <button ngbDropdownItem [routerLink]=\"['/cms/admin/entries/create']\"\r\n                                                [queryParams]=\"{cultureName: filters.culture,sectionId:filters.sectionId,entryTypeId:item.entryTypeId,entryVersionId:item.id,isOther:1}\">{{'Cms::CreateOtherLanguages'\r\n                                                |\r\n                                                abpLocalization}}</button>\r\n                                            }\r\n                                            <!-- <button ngbDropdownItem [routerLink]=\"['/cms/admin/entries/create']\"\r\n                                                [queryParams]=\"{cultureName: filters.culture,sectionId:filters.sectionId,entryTypeId:row.entryTypeId,entryVersionId:row.id,isOther:1}\">{{'Cms::CreateOtherLanguages'\r\n                                                |\r\n                                                abpLocalization}} </button> -->\r\n\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 class=\"white-space-normal\">{{item.slug}}</td>\r\n                                <td>\r\n                                    {{ 'Cms::Enum:SectionType:'+SectionType[item.sectionType] |\r\n                                    abpLocalization }}\r\n                                </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                                \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\"\r\n                                        [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>"]}
630
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entries.component.js","sourceRoot":"","sources":["../../../../../../../../packages/cms/src/lib/components/admin/entries/entries.component.ts","../../../../../../../../packages/cms/src/lib/components/admin/entries/entries.component.html"],"names":[],"mappings":"AAAA,0CAA0C;AAC1C,8CAA8C;AAC9C,uDAAuD;AACvD,OAAO,EAAE,qBAAqB,EAAE,MAAM,+BAA+B,CAAC;AACtE,OAAO,EACL,WAAW,EACX,wBAAwB,EACxB,kBAAkB,EAClB,mBAAmB,GAGpB,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,cAAc,EAAE,mBAAmB,EAAgB,MAAM,sBAAsB,CAAC;AACzF,OAAO,EAAE,iBAAiB,EAAE,SAAS,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAC7E,OAAO,EAAE,WAAW,EAAa,MAAM,gBAAgB,CAAC;AACxD,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AACzC,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAC;AAChC,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAC/C,OAAO,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAC5D,OAAO,EACL,iBAAiB,GAGlB,MAAM,0CAA0C,CAAC;AAClD,OAAO,EAAE,mBAAmB,EAAE,MAAM,2CAA2C,CAAC;AAChF,OAAO,EAAE,kBAAkB,EAAE,MAAM,oCAAoC,CAAC;AACxE,OAAO,EAAE,sBAAsB,EAAE,MAAM,uDAAuD,CAAC;AAC/F,OAAO,EAAE,WAAW,EAAE,MAAM,qCAAqC,CAAC;AAElE,OAAO,EAAE,gBAAgB,EAAE,MAAM,gDAAgD,CAAC;AAClF,OAAO,EAAE,iBAAiB,EAAE,MAAM,yCAAyC,CAAC;AAC5E,OAAO,EAAE,mBAAmB,EAAE,MAAM,yCAAyC,CAAC;;;;;;;;;;;;;;;;;;;;AAiB9E,MAAM,OAAO,gBAAgB;IAC3B,YACU,kBAAqC,EACrC,oBAAyC,EACzC,OAAuB,EACvB,YAAiC,EACjC,WAA+B,EAC/B,MAAc,EACd,oBAAyC,EACzC,iBAAmC,EACnC,kBAAqC,EACrC,KAAwB,EACxB,oBAAyC;QAVzC,uBAAkB,GAAlB,kBAAkB,CAAmB;QACrC,yBAAoB,GAApB,oBAAoB,CAAqB;QACzC,YAAO,GAAP,OAAO,CAAgB;QACvB,iBAAY,GAAZ,YAAY,CAAqB;QACjC,gBAAW,GAAX,WAAW,CAAoB;QAC/B,WAAM,GAAN,MAAM,CAAQ;QACd,yBAAoB,GAApB,oBAAoB,CAAqB;QACzC,sBAAiB,GAAjB,iBAAiB,CAAkB;QACnC,uBAAkB,GAAlB,kBAAkB,CAAmB;QACrC,UAAK,GAAL,KAAK,CAAmB;QACxB,yBAAoB,GAApB,oBAAoB,CAAqB;QAG3C,OAAE,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;QACzB,uBAAkB,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QACvC,SAAI,GAAG,MAAM,CAAC,CAAA,WAA4B,CAAA,CAAC,CAAC;QAE5D,UAAU;QACV,gBAAW,GAAG,WAAW,CAAC;QAW1B,YAAY;QACZ,sBAAiB,GAAa,EAAE,CAAC;QAEjC,cAAc;QACd,yBAAoB,GAAa,EAAE,CAAC;QACpC,gBAAgB;QAChB,kBAAa,GAAa,EAAE,CAAC;QAC7B,UAAU;QACV,wBAAmB,GAAG,kBAAkB,CAAC;QAUzC,iBAAiB;QACjB,yBAAoB,GAAU,EAAE,CAAC;QACjC,iBAAiB;QACjB,0BAAqB,GAAU,EAAE,CAAC;QAClC,kBAAkB;QAClB,0BAAqB,GAAU,EAAE,CAAC;QAClC,iBAAiB;QACjB,oBAAe,GAAU,EAAE,CAAC;QA6B5B,QAAQ;QACR,2BAAsB,GAA0B,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC;YAC5D,eAAe,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC;SACnC,CAAC,CAAC;QAqCH,cAAc;QACd,sBAAiB,GAAQ,WAAW,CAAC,MAAM,CAAC;QAmEpC,WAAM,GAAG,MAAM,CAAC,kBAAkB,CAAC,CAAC;QACpC,4BAAuB,GAAG,MAAM,CAAC,sBAAsB,CAAC,CAAC;QAkCjE,YAAY;QACZ,+BAA0B,GAAU,EAAE,CAAC;QACvC,eAAe;QACf,uBAAkB,GAAQ,EAAE,CAAC;QA+C7B,UAAU;QACV,eAAU,GAAG,UAAU,CAAC;QACxB,SAAI,GAAmC;YACrC,KAAK,EAAE,EAAE;YACT,UAAU,EAAE,CAAC;SACd,CAAC;QAEF,YAAO,GAAG,EAAqB,CAAC;QAEhC,mBAAc,GAAG,EAAE,CAAC;QACpB,iBAAY,GAAU,EAAE,CAAC;QACzB,sBAAiB,GAAG,IAAI,CAAC;QAwDzB,kBAAkB;QAClB,iBAAY,GAAkB,IAAI,CAAC;QACnC,yCAAyC;QACzC,iBAAY,GAAwC,IAAI,CAAC;QACzD,eAAe;QACf,gBAAW,GAAQ,IAAI,CAAC;QACxB,aAAa;QACb,eAAU,GAAY,KAAK,CAAC;QAC5B,2BAA2B;QAC3B,wBAAmB,GAAY,KAAK,CAAC;QA+NrC,eAAU,GAAkB,KAAK,CAAC;IApjB/B,CAAC;IASJ,QAAQ;QACN,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,IAAI,CAAC,kBAAkB,CAAC,eAAe,CAAC,SAAS,CAAC,GAAG,EAAE;YACrD,IAAI,CAAC,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;YACrB,IAAI,CAAC,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;YACzB,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;QAClB,CAAC,CAAC,CAAC;IACL,CAAC;IAYD,YAAY;IACZ,KAAK,CAAC,WAAW;QACf,IAAI,CAAC,oBAAoB,GAAG,MAAM,IAAI,CAAC,oBAAoB,CAAC,uBAAuB,EAAE,CAAC;QACtF,MAAM,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAClC,MAAM,IAAI,CAAC,uBAAuB,EAAE,CAAC;QACrC,IAAI,CAAC,OAAO,CAAC,OAAO,GAAG,mBAAmB,CAAC;QAC3C,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAUD,UAAU;IACV,KAAK,CAAC,eAAe;QACnB,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC7B,MAAM,IAAI,CAAC,uBAAuB,EAAE,CAAC;QACrC,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;IACD,UAAU;IACV,KAAK,CAAC,aAAa;QACjB,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;IAED,cAAc;IACd,oBAAoB;QAClB,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,OAAO,EAAE,EAAE;YACtC,IAAI,CAAC,oBAAoB;iBACtB,OAAO,CAAC;gBACP,cAAc,EAAE,IAAI;aACrB,CAAC;iBACD,SAAS,CAAC,KAAK,EAAE,GAAQ,EAAE,EAAE;gBAC5B,IAAI,CAAC,iBAAiB,GAAG,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC;gBAC7D,oEAAoE;gBACpE,IAAI,CAAC,OAAO,CAAC,SAAS,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,IAAI,EAAE,CAAC;gBAChD,MAAM,IAAI,CAAC,qBAAqB,EAAE,CAAC;gBACnC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;YACrB,CAAC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACL,CAAC;IAMD,IAAI,oBAAoB;QACtB,OAAO,IAAI,CAAC,sBAAsB,EAAE,GAAG,CAAC,iBAAiB,CAAc,CAAC;IAC1E,CAAC;IAED,YAAY;IACZ,eAAe;QACb,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,OAAO,EAAE,EAAE;YACtC,MAAM,eAAe,GAAG,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC;YACxD,MAAM,MAAM,GAAU,EAAE,CAAC;YACzB,KAAK,MAAM,GAAG,IAAI,eAAe,EAAE,CAAC;gBAClC,MAAM,OAAO,GAAG,eAAe,CAAC,GAAG,CAAC,CAAC;gBACrC,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC;oBAC7E,MAAM,CAAC,IAAI,CAAC;wBACV,IAAI,EAAE,GAAG;wBACT,KAAK,EAAE,OAAO,KAAK,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,OAAO;qBACxF,CAAC,CAAC;gBACL,CAAC;gBACD,IAAI,OAAO,KAAK,KAAK,EAAE,CAAC;oBACtB,MAAM,CAAC,IAAI,CAAC;wBACV,IAAI,EAAE,GAAG;wBACT,KAAK,EAAE,OAAO;qBACf,CAAC,CAAC;gBACL,CAAC;YACH,CAAC;YACD,IAAI,CAAC,OAAO,CAAC,oBAAoB,GAAG,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;YACpF,OAAO,CAAC,IAAI,CAAC,CAAC;QAChB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,OAAO;QACX,MAAM,IAAI,CAAC,eAAe,EAAE,CAAC;QAC7B,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;QAChB,gBAAgB;IAClB,CAAC;IAKD,gBAAgB;IAChB,KAAK,CAAC,qBAAqB;QACzB,2DAA2D;QAC3D,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC;QACzC,MAAM,WAAW,GAAQ,MAAM,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;QAC9D,MAAM,cAAc,GAAG,WAAW,EAAE,UAAU,IAAI,EAAE,CAAC;QAErD,gGAAgG;QAChG,IAAI,CAAC,aAAa,GAAG,cAAc,CAAC;QACpC,oBAAoB;QACpB,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,IAAI,SAAS,CAAC,EAAE,IAAI,CAAC;QACrF,IAAI,IAAI,CAAC,iBAAiB,IAAI,WAAW,CAAC,SAAS,EAAE,CAAC;YACpD,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC7B,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC;QAC3B,CAAC;QACD,QAAQ;QACR,IAAI,CAAC,qBAAqB,GAAG,EAAE,CAAC;QAChC,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;QAC1B,8BAA8B;QAC9B,IAAI,IAAI,EAAE,CAAC;YACT,uDAAuD;YACvD,2BAA2B;YAC3B,KAAK,MAAM,EAAE,IAAI,cAAc,EAAE,CAAC;gBAChC,KAAK,MAAM,GAAG,IAAI,EAAE,CAAC,SAAS,EAAE,CAAC;oBAC/B,KAAK,MAAM,GAAG,IAAI,GAAG,CAAC,MAAM,EAAE,CAAC;wBAC7B,4DAA4D;wBAC5D,IAAI,GAAG,CAAC,YAAY,IAAI,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,eAAe,CAAC,EAAE,CAAC;4BACtF,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC;gCAC9B,GAAG,GAAG;gCACN,KAAK,EAAE;oCACL,eAAe,EAAE,GAAG,CAAC,KAAK,CAAC,eAAe;oCAC1C,iBAAiB,EAAE,GAAG,CAAC,KAAK,CAAC,iBAAiB;oCAC9C,IAAI,EAAE,GAAG,CAAC,KAAK,CAAC,IAAI;iCACrB;6BACF,CAAC,CAAC;wBACL,CAAC;wBACD,IAAI,GAAG,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,eAAe,CAAC,EAAE,CAAC;4BACtF,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;wBACjC,CAAC;oBACH,CAAC;gBACH,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IACD,KAAK,CAAC,SAAS;QACb,MAAM,IAAI,CAAC,eAAe,EAAE,CAAC;IAC/B,CAAC;IACD,YAAY;IACZ,cAAc,CAAC,GAAG;QAChB,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,OAAO,EAAE,EAAE;YACtC,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;gBACjD,OAAO,CAAC,GAAG,CAAC,CAAC;YACf,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IACD,YAAY;IACZ,oBAAoB,CAAC,OAAe;QAClC,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,OAAO,EAAE,EAAE;YACtC,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;gBACnD,OAAO,CAAC,GAAG,CAAC,CAAC;YACf,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAID,gBAAgB;IAChB,uBAAuB;QACrB,OAAO,IAAI,OAAO,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,EAAE;YAC5C,WAAW;YACX,MAAM,eAAe,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,wBAAwB,CAAC,CAAC;YAC3E,aAAa;YACb,IAAI,eAAe,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,wCAAwC,CAAC,CAAC;YACvF,MAAM,sBAAsB,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,oBAAoB,CAAC,CAAC;YAC5E,IAAI,CAAC,sBAAsB,EAAE,CAAC;gBAC5B,MAAM,IAAI,CAAC,wBAAwB,EAAE,CAAC;YACxC,CAAC;YACD,IAAI,IAAI,CAAC,kBAAkB,EAAE,CAAC;gBAC5B,eAAe,GAAG,IAAI,CAAC,kBAAkB,CAAC;YAC5C,CAAC;YACD,MAAM,aAAa,GACjB,CAAC,sBAAsB,CAAC,CAAC,CAAC,sBAAsB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;gBACjE,IAAI,CAAC,0BAA0B,CAAC;YAClC,MAAM,cAAc,GAAG,eAAe,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,aAAa,CAAC,QAAQ,CAAC,EAAE,CAAC,WAAW,CAAC,CAAC,CAAC;YAC5F,WAAW;YACX,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC;YACxC,0DAA0D;YAC1D,sBAAsB;YACtB,MAAM,OAAO,GAAG,cAAc,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,WAAW,IAAI,UAAU,CAAC,CAAC;YACxE,IAAI,CAAC,OAAO,CAAC,OAAO,GAAG,UAAU;gBAC/B,CAAC,CAAC,OAAO;oBACP,CAAC,CAAC,UAAU;oBACZ,CAAC,CAAC,eAAe;gBACnB,CAAC,CAAC,eAAe,CAAC;YACpB,IAAI,CAAC,oBAAoB,GAAG,cAAc,CAAC;YAC3C,OAAO,CAAC,cAAc,CAAC,CAAC;QAC1B,CAAC,CAAC,CAAC;IACL,CAAC;IAMD;;OAEG;IACH,wBAAwB;QACtB,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,OAAO,EAAE,EAAE;YACtC,IAAI,CAAC,uBAAuB,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;gBACjD,IAAI,CAAC,0BAA0B,GAAG,GAAG,CAAC,qBAAqB,CAAC;gBAC5D,IAAI,CAAC,kBAAkB,GAAG,GAAG,CAAC,kBAAkB,CAAC;gBACjD,OAAO,CAAC,GAAG,CAAC,CAAC;YACf,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED,SAAS;QACP,IAAI,CAAC,OAAO,GAAG;YACb,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,SAAS;YACjC,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,OAAO;YAC7B,OAAO,EAAE,mBAAmB;SACV,CAAC;QACrB,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;QACtB,IAAI,CAAC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC;QAC/C,IAAI,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;QACnB,IAAI,CAAC,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;QACrB,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;IAClB,CAAC;IAED,WAAW;IACX,gBAAgB;QACd,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,2BAA2B,CAAC,EAAE;YAClD,WAAW,EAAE;gBACX,WAAW,EAAE,IAAI,CAAC,OAAO,CAAC,OAAO;gBACjC,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,SAAS;gBACjC,WAAW,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,EAAE;aACtC;SACF,CAAC,CAAC;IACL,CAAC;IACD,oBAAoB;QAClB,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,gCAAgC,CAAC,EAAE;YACvD,WAAW,EAAE;gBACX,WAAW,EAAE,IAAI,CAAC,OAAO,CAAC,OAAO;gBACjC,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,SAAS;gBACjC,WAAW,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,EAAE;aACtC;SACF,CAAC,CAAC;IACL,CAAC;IAeD,WAAW;QACT,MAAM,OAAO,GAAG,CAAC,KAA0B,EAAE,EAAE,CAC7C,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC;YAC9B,GAAG,KAAK;YACR,GAAG,IAAI,CAAC,OAAO;YACf,cAAc,EAAE,IAAI,CAAC,cAAc;SACpC,CAAC,CAAC;QACL,MAAM,OAAO,GAAG,CAAC,IAAoC,EAAE,EAAE;YACvD,IAAI,CAAC,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;YACrB,IAAI,CAAC,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;YACzB,KAAK,MAAM,OAAO,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;gBACjC,MAAM,WAAW,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,IAAI,OAAO,CAAC,SAAS,CAAC,CAAC;gBAClF,OAAO,CAAC,WAAW,GAAG,WAAW,CAAC,IAAI,CAAC;YACzC,CAAC;YACD,IAAI,IAAI,CAAC,iBAAiB,IAAI,WAAW,CAAC,SAAS,EAAE,CAAC;gBACpD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC;gBAC/B,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC1C,CAAC;YAED,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;YACjB,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;gBAC3B,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,CAAC;YACD,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAChC,CAAC,CAAC;QACF,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;IACpD,CAAC;IACD,WAAW;QACT,MAAM,eAAe,GAAG,QAAQ,CAAC,sBAAsB,CAAC,sBAAsB,CAAC,CAAC,CAAC,CAAC,CAAC;QACnF,CAAC,eAAe,IAAI,MAAM,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC7C,CAAC;IAED,mBAAmB;IACnB,gBAAgB,CAAC,WAAmB;QAClC,OAAO,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,WAAW,IAAI,WAAW,CAAC,CAAC;IACrE,CAAC;IAED,UAAU;IACV,WAAW,CAAC,GAAQ;QAClB,IAAI,CAAC,YAAY;aACd,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,iCAAiC,CAAC,CAAC;aAC3F,SAAS,CAAC,CAAC,MAA2B,EAAE,EAAE;YACzC,IAAI,MAAM,IAAI,SAAS,EAAE,CAAC;gBACxB,IAAI,CAAC,kBAAkB;qBACpB,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC;qBACd,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC,CAAC;qBACxB,SAAS,CAAC,GAAG,CAAC,EAAE;oBACf,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,4BAA4B,CAAC,CAAC,CAAC;oBACtF,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;gBAClB,CAAC,CAAC,CAAC;YACP,CAAC;QACH,CAAC,CAAC,CAAC;IACP,CAAC;IAaD;;OAEG;IACH,aAAa,CAAC,KAAU;QACtB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QACvB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC;IAC7C,CAAC;IAED;;OAEG;IACH,WAAW,CAAC,KAAU;QACpB,qBAAqB;QACrB,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;YACxB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;YACxB,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC;QACnC,CAAC,EAAE,GAAG,CAAC,CAAC;IACV,CAAC;IAED;;OAEG;IACH,aAAa,CAAC,KAAU,EAAE,UAAe;QACvC,IAAI,CAAC,IAAI,CAAC,UAAU;YAAE,OAAO;QAC7B,IAAI,CAAC,YAAY,GAAG,UAAU,CAAC,EAAE,CAAC;IACpC,CAAC;IAED;;OAEG;IACH,WAAW,CAAC,KAAiB,EAAE,UAAe;QAC5C,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,WAAW;YAAE,OAAO;QAElD,MAAM,MAAM,GAAI,KAAK,CAAC,aAA6B,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAClE,IAAI,CAAC,MAAM;YAAE,OAAO;QAEpB,IAAI,CAAC,YAAY,GAAG,UAAU,CAAC,EAAE,CAAC;QAElC,MAAM,IAAI,GAAG,MAAM,CAAC,qBAAqB,EAAE,CAAC;QAC5C,MAAM,CAAC,GAAG,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC;QACnC,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QAE3B,IAAI,CAAC,GAAG,MAAM,GAAG,IAAI,EAAE,CAAC;YACtB,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC;QAC9B,CAAC;aAAM,IAAI,CAAC,GAAG,MAAM,GAAG,IAAI,EAAE,CAAC;YAC7B,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC;QAC9B,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC;QAC/B,CAAC;QAED,cAAc;QACd,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE,EAAE,UAAU,CAAC,EAAE,CAAC,CAAC;QACvF,4GAA4G;IAC9G,CAAC;IAED;;;OAGG;IACH,WAAW,CAAC,KAAgB;QAC1B,gDAAgD;QAChD,gBAAgB;IAClB,CAAC;IAED;;;;OAIG;IACH,IAAI,CAAC,KAAU;QACb,aAAa;QACb,MAAM,WAAW,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC;QACpC,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;YAC5B,IAAI,CAAC,cAAc,EAAE,CAAC;YACtB,OAAO;QACT,CAAC;QAED,MAAM,WAAW,GAAG,WAAW,CAAC,IAAI,CAAC;QAErC,gBAAgB;QAChB,IAAI,CAAC,IAAI,CAAC,YAAY,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;YAC7C,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;YACxB,IAAI,CAAC,cAAc,EAAE,CAAC;YACtB,OAAO;QACT,CAAC;QAED,iBAAiB;QACjB,MAAM,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;QAE3E,oBAAoB;QACpB,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,kBAAkB,CAAC,WAAW,CAAC,EAAE,EAAE,UAAU,CAAC,EAAE,CAAC,EAAE,CAAC;YAC1E,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,mCAAmC,CAAC,CAAC,CAAC;YAC1F,IAAI,CAAC,cAAc,EAAE,CAAC;YACtB,OAAO;QACT,CAAC;QAED,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;QAClC;;;UAGE;QACF,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;QACjC,OAAO,CAAC,GAAG,CAAC,KAAK,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;QAEtC,SAAS;QACT,MAAM,UAAU,GAAQ,EAAE,CAAC;QAE3B,6BAA6B;QAC7B,IAAI,IAAI,CAAC,YAAY,KAAK,QAAQ,EAAE,CAAC;YACnC,UAAU,CAAC,QAAQ,GAAG,UAAU,CAAC,EAAE,CAAC;QACtC,CAAC;QACD,oCAAoC;aAC/B,CAAC;YACJ,UAAU,CAAC,QAAQ,GAAG,UAAU,CAAC,QAAQ,CAAC;YAC1C,6BAA6B;YAC7B,UAAU,CAAC,KAAK,GAAG,IAAI,CAAC,YAAY,KAAK,OAAO,CAAC,CAAC,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,UAAU,CAAC,KAAK,GAAG,CAAC,CAAC;QAC7F,CAAC;QAED,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;QAEjC,WAAW;QACX,IAAI,CAAC,eAAe,CAAC,WAAW,EAAE,UAAU,CAAC,CAAC;QAC9C,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,UAAU;QACV,IAAI,CAAC,kBAAkB;aACpB,IAAI,CAAC,WAAW,CAAC,EAAE,EAAE,UAAU,CAAC;aAChC,SAAS,CACR,GAAG,EAAE;YACH,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,0BAA0B,CAAC,CAAC,CAAC;YACpF,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;YAC/B,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;QAClB,CAAC,EACD,GAAG,EAAE;YACH,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;YAC/B,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;QAClB,CAAC,CACF,CAAC;IAEN,CAAC;IAED;;OAEG;IACK,cAAc;QACpB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC;IACnC,CAAC;IAED;;OAEG;IACK,kBAAkB,CAAC,SAAiB,EAAE,QAAgB;QAC5D,IAAI,SAAS,KAAK,QAAQ,EAAE,CAAC;YAC3B,wBAAwB;YACxB,OAAO,IAAI,CAAC;QACd,CAAC;QACD,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;QACtD,kCAAkC;QAClC,OAAO,MAAM,CAAC;IAChB,CAAC;IAED;;OAEG;IACK,YAAY,CAAC,QAAgB,EAAE,OAAe;QACpD,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;QAC5D,IAAI,CAAC,MAAM;YAAE,OAAO,KAAK,CAAC;QAE1B,MAAM,aAAa,GAAG,CAAC,IAAS,EAAW,EAAE;YAC3C,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC;gBAAE,OAAO,KAAK,CAAC;YAC/D,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAClC,IAAI,KAAK,CAAC,EAAE,KAAK,OAAO;oBAAE,OAAO,IAAI,CAAC;gBACtC,IAAI,aAAa,CAAC,KAAK,CAAC;oBAAE,OAAO,IAAI,CAAC;YACxC,CAAC;YACD,OAAO,KAAK,CAAC;QACf,CAAC,CAAC;QAEF,OAAO,aAAa,CAAC,MAAM,CAAC,CAAC;IAC/B,CAAC;IAED;;;;;OAKG;IACH,YAAY,CAAC,KAAY,EAAE,EAAU;QACnC,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YACzB,IAAI,IAAI,CAAC,EAAE,KAAK,EAAE;gBAAE,OAAO,IAAI,CAAC;YAChC,cAAc;YACd,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAClB,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;gBACnD,IAAI,KAAK;oBAAE,OAAO,KAAK,CAAC;YAC1B,CAAC;QACH,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;OAEG;IACK,eAAe,CAAC,WAAgB,EAAE,UAAe;QACvD,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,KAAK,WAAW,CAAC,EAAE,CAAC,CAAC;QAC5E,IAAI,CAAC,QAAQ;YAAE,OAAO;QAEtB,QAAQ,CAAC,QAAQ,GAAG,UAAU,CAAC,QAAQ,CAAC;QACxC,IAAI,UAAU,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;YACnC,QAAQ,CAAC,KAAK,GAAG,UAAU,CAAC,KAAK,CAAC;QACpC,CAAC;aAAM,CAAC;YACN,qBAAqB;YACrB,QAAQ,CAAC,KAAK,GAAG,CAAC,CAAC;QACrB,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACtD,CAAC;IAGD,YAAY;IACZ,cAAc,CAAC,KAAK;QAClB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;IAC1B,CAAC;IAED,qBAAqB;IACrB,SAAS,CAAC,KAAY;QACpB,MAAM,GAAG,GAAG,IAAI,GAAG,EAAE,CAAC;QACtB,MAAM,KAAK,GAAU,EAAE,CAAC;QAExB,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACnB,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,GAAG,IAAI,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC;QAC9C,CAAC,CAAC,CAAC;QAEH,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACnB,MAAM,IAAI,GAAG,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YAC9B,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI,IAAI,IAAI,CAAC,QAAQ,KAAK,SAAS,EAAE,CAAC;gBAC1D,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACnB,CAAC;iBAAM,CAAC;gBACN,MAAM,MAAM,GAAG,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;gBACtC,IAAI,MAAM,EAAE,CAAC;oBACX,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBAC7B,CAAC;YACH,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,MAAM,WAAW,GAAG,CAAC,KAAY,EAAE,EAAE;YACnC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC;YACxC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;gBACnB,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBAC9C,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;gBAC7B,CAAC;YACH,CAAC,CAAC,CAAC;QACL,CAAC,CAAC;QAEF,WAAW,CAAC,KAAK,CAAC,CAAC;QACnB,OAAO,KAAK,CAAC;IACf,CAAC;8GAvmBU,gBAAgB;kGAAhB,gBAAgB,sCAXhB;YACT,WAAW;YACX,4DAA4D;YAC5D,uEAAuE;YACvE,EAAE,OAAO,EAAE,wBAAwB,EAAE,QAAQ,EAAE,GAAG,EAAE;YACpD;gBACE,OAAO,EAAE,qBAAqB;gBAC9B,QAAQ,EAAE,aAAa,CAAC,OAAO;aAChC;SACF,0BC/CH,o8qBAwTW;;2FDvQE,gBAAgB;kBAf5B,SAAS;+BACE,aAAa,aAGZ;wBACT,WAAW;wBACX,4DAA4D;wBAC5D,uEAAuE;wBACvE,EAAE,OAAO,EAAE,wBAAwB,EAAE,QAAQ,EAAE,GAAG,EAAE;wBACpD;4BACE,OAAO,EAAE,qBAAqB;4BAC9B,QAAQ,EAAE,aAAa,CAAC,OAAO;yBAChC;qBACF","sourcesContent":["/* eslint-disable no-constant-condition */\n/* eslint-disable no-async-promise-executor */\n/* eslint-disable @angular-eslint/component-selector */\nimport { 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.data.items = [];\n      this.data.totalCount = 0;\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    this.enableSearchTypeList = await this._FormControlsService.getEnableSearchTypeList();\n    await this.getSiteOfSectionList();\n    await this.getSectionLanguagesList();\n    this.filters.sorting = 'creationTime desc';\n    this.hookToQuery();\n  }\n  /**需要查询的动态表单类型 */\n  enableSearchTypeList: any[] = [];\n  /**需要查询的动态表单字段 */\n  enableSearchFieldList: any[] = [];\n  /**不需要展示的动态表单类型 */\n  disableshowinTypeList: any[] = [];\n  /**需要展示的动态列表字段 */\n  showinFieldList: any[] = [];\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.filter(el => el.isActive);\n          // this.filters.sectionId = res.items[res.items.length-1]?.id || '';\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      const extraProperties = this.extraPropertiesInput.value;\n      const 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    const sectionId = this.filters.sectionId;\n    const SectionInfo: any = await this.getSectionInfo(sectionId);\n    const _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    this.enableSearchFieldList = [];\n    this.showinFieldList = [];\n    // _entryTypeList.length === 1\n    if (true) {\n      // this.filters.entryTypeId = this.entryTypeList[0].id;\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      const 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      const LanguagesArray = languagesSystem.filter(el => LanguagesSite.includes(el.cultureName));\n      //获取当前选择的语言\n      const nowculture = this.filters.culture;\n      // let nowculture = this.filtersForm.get('culture').value;\n      //当前选择的语言，是否在版块的的语言列表中\n      const 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      sorting: 'creationTime desc',\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  copylistItem: any[] = [];\n  shouldScrollToTop = true;\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      this.data.items = [];\n      this.data.totalCount = 0;\n      for (const element of list.items) {\n        const sectionItem = this.SiteOfSectionList.find(el => el.id == element.sectionId);\n        element.sectionType = sectionItem.type;\n      }\n      if (this.SiteOfSectionType == SectionType.Structure) {\n        this.copylistItem = list.items;\n        list.items = this.buildTree(list.items);\n      }\n\n      this.data = list;\n      if (this.shouldScrollToTop) {\n        this.scrollToTop();\n      }\n      this.shouldScrollToTop = true;\n    };\n    this.list.hookToQuery(getData).subscribe(setData);\n  }\n  scrollToTop() {\n    const scrollContainer = document.getElementsByClassName('lpx-scroll-container')[0];\n    (scrollContainer || window).scrollTo(0, 0);\n  }\n\n  /**判断某个类型的条目是否存在 */\n  isEntryTypeExist(entryTypeId: string) {\n    return this.data?.items?.some(el => el.entryTypeId == entryTypeId);\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  /** 当前拖拽目标节点的ID */\n  dropTargetId: string | null = null;\n  /** 拖拽位置：above-上方, below-下方, inside-内部 */\n  dropPosition: 'above' | 'below' | 'inside' | null = null;\n  /** 当前被拖拽的节点 */\n  draggedItem: any = null;\n  /** 是否正在拖拽 */\n  isDragging: boolean = false;\n  /** 是否为无效拖拽目标（拖拽到自身或子节点） */\n  isInvalidDropTarget: boolean = false;\n\n  /**\n   * CDK拖拽开始事件\n   */\n  onDragStarted(event: any) {\n    this.isDragging = true;\n    this.draggedItem = event.source.data?.item;\n  }\n\n  /**\n   * CDK拖拽结束事件\n   */\n  onDragEnded(event: any) {\n    // 不立即清除状态,让drop方法先执行\n    setTimeout(() => {\n      this.isDragging = false;\n      this.draggedItem = null;\n      this.isInvalidDropTarget = false;\n    }, 100);\n  }\n\n  /**\n   * CDK拖拽进入事件\n   */\n  onDragEntered(event: any, targetItem: any) {\n    if (!this.isDragging) return;\n    this.dropTargetId = targetItem.id;\n  }\n\n  /**\n   * 鼠标移动事件,判断位置\n   */\n  onMouseMove(event: MouseEvent, targetItem: any) {\n    if (!this.isDragging || !this.draggedItem) return;\n    \n    const target = (event.currentTarget as HTMLElement).closest('tr');\n    if (!target) return;\n    \n    this.dropTargetId = targetItem.id;\n    \n    const rect = target.getBoundingClientRect();\n    const y = event.clientY - rect.top;\n    const height = rect.height;\n    \n    if (y < height * 0.25) {\n      this.dropPosition = 'above';\n    } else if (y > height * 0.75) {\n      this.dropPosition = 'below';\n    } else {\n      this.dropPosition = 'inside';\n    }\n    \n    // 检查是否为无效拖拽目标\n    this.isInvalidDropTarget = this.isDescendantOrSelf(this.draggedItem.id, targetItem.id);\n    // console.log('拖拽节点ID:', this.draggedItem.id, '目标节点ID:', targetItem.id, '是否无效:', this.isInvalidDropTarget);\n  }\n\n  /**\n   * 拖拽离开事件处理\n   * 清除拖拽目标和位置标识\n   */\n  onDragLeave(event: DragEvent) {\n    // 不立即清除状态，让drop事件能够获取到dropTargetId和dropPosition\n    // 状态会在drop事件中清除\n  }\n\n  /**\n   * 拖拽释放事件处理\n   * 根据拖拽位置调用后端API移动节点\n   * @param event CDK拖拽事件\n   */\n  drop(event: any) {\n    // 获取被拖拽的节点数据\n    const draggedData = event.item.data;\n    if (!draggedData) {\n      console.log('无draggedData');\n      this.clearDropState();\n      return;\n    }\n    \n    const draggedItem = draggedData.item;\n    \n    // 验证拖拽目标和位置是否有效\n    if (!this.dropTargetId || !this.dropPosition) {\n      console.log('无拖拽目标或位置');\n      this.clearDropState();\n      return;\n    }\n    \n    // 在原始平铺数据中查找目标节点\n    const targetItem = this.findItemById(this.copylistItem, this.dropTargetId);\n    \n    // 验证目标节点存在且不是自己或子节点\n    if (!targetItem || this.isDescendantOrSelf(draggedItem.id, targetItem.id)) {\n      this.toaster.warn(this._LocalizationService.instant('Cms::CannotDragToSelfOrDescendant'));\n      this.clearDropState();\n      return;\n    }\n  \n    console.log('拖拽节点:', draggedItem);\n    /* \n     拖拽位置：above-上方, below-下方, inside-内部 \n      dropPosition: 'above' | 'below' | 'inside' | null = null;\n    */\n    console.log('目标节点:', targetItem);\n    console.log('位置:', this.dropPosition);\n    \n    // 构建移动参数\n    const moveParams: any = {};\n    \n    // 如果是放置到内部，设置parentId为目标节点ID\n    if (this.dropPosition === 'inside') {\n      moveParams.parentId = targetItem.id;\n    } \n    // 如果是放置在上方或下方，使用目标节点的parentId和order\n    else {\n      moveParams.parentId = targetItem.parentId;\n      // 上方使用目标节点的order，下方使用order+1\n      moveParams.order = this.dropPosition === 'above' ? targetItem.order : targetItem.order + 1;\n    }\n\n    console.log('移动参数:', moveParams);\n\n    // 立即更新本地数据\n    this.updateLocalData(draggedItem, moveParams);\n    this.clearDropState();\n    // 调用后端API\n    this._EntryAdminService\n      .move(draggedItem.id, moveParams)\n      .subscribe(\n        () => {\n          this.toaster.success(this._LocalizationService.instant('AbpUi::SavedSuccessfully'));\n          this.shouldScrollToTop = false;\n          this.list.get();\n        },\n        () => {\n          this.shouldScrollToTop = false;\n          this.list.get();\n        }\n      );\n\n  }\n\n  /**\n   * 清除拖拽状态\n   */\n  private clearDropState() {\n    this.dropTargetId = null;\n    this.dropPosition = null;\n    this.isDragging = false;\n    this.draggedItem = null;\n    this.isInvalidDropTarget = false;\n  }\n\n  /**\n   * 检查目标节点是否是拖拽节点的后代或自身\n   */\n  private isDescendantOrSelf(draggedId: string, targetId: string): boolean {\n    if (draggedId === targetId) {\n      // console.log('目标是自身');\n      return true;\n    }\n    const result = this.isDescendant(draggedId, targetId);\n    // console.log('目标是子节点:', result);\n    return result;\n  }\n\n  /**\n   * 递归检查目标节点是否是拖拽节点的子节点\n   */\n  private isDescendant(parentId: string, childId: string): boolean {\n    const parent = this.findItemById(this.data.items, parentId);\n    if (!parent) return false;\n    \n    const checkChildren = (node: any): boolean => {\n      if (!node.children || node.children.length === 0) return false;\n      for (const child of node.children) {\n        if (child.id === childId) return true;\n        if (checkChildren(child)) return true;\n      }\n      return false;\n    };\n    \n    return checkChildren(parent);\n  }\n\n  /**\n   * 在树形结构或平铺数组中递归查找指定ID的节点\n   * @param items 节点数组\n   * @param id 要查找的节点ID\n   * @returns 找到的节点或null\n   */\n  findItemById(items: any[], id: string): any {\n    for (const item of items) {\n      if (item.id === id) return item;\n      // 如果有子节点，递归查找\n      if (item.children) {\n        const found = this.findItemById(item.children, id);\n        if (found) return found;\n      }\n    }\n    return null;\n  }\n\n  /**\n   * 更新本地数据\n   */\n  private updateLocalData(draggedItem: any, moveParams: any) {\n    const flatItem = this.copylistItem.find(item => item.id === draggedItem.id);\n    if (!flatItem) return;\n\n    flatItem.parentId = moveParams.parentId;\n    if (moveParams.order !== undefined) {\n      flatItem.order = moveParams.order;\n    } else {\n      // 拖拽到内部时，设置为0（子节点开头）\n      flatItem.order = 0;\n    }\n\n    this.data.items = this.buildTree(this.copylistItem);\n  }\n\n  isexpanded: boolean | any = false;\n  /**高级筛选切换 */\n  expandedChange(event) {\n    this.isexpanded = event;\n  }\n\n  /**将平铺数据转换为树形结构并排序 */\n  buildTree(items: any[]): any[] {\n    const map = new Map();\n    const roots: any[] = [];\n\n    items.forEach(item => {\n      map.set(item.id, { ...item, children: [] });\n    });\n\n    items.forEach(item => {\n      const node = map.get(item.id);\n      if (item.parentId === null || item.parentId === undefined) {\n        roots.push(node);\n      } else {\n        const parent = map.get(item.parentId);\n        if (parent) {\n          parent.children.push(node);\n        }\n      }\n    });\n\n    const sortByOrder = (nodes: any[]) => {\n      nodes.sort((a, b) => a.order - b.order);\n      nodes.forEach(node => {\n        if (node.children && node.children.length > 0) {\n          sortByOrder(node.children);\n        }\n      });\n    };\n\n    sortByOrder(roots);\n    return roots;\n  }\n}\n","<abp-page [title]=\"'Cms::Entries' | abpLocalization\" [toolbar]=\"true\">\r\n    <abp-page-toolbar-container *ngIf=\"entryTypeList.length < 1\" class=\"col \">\r\n    </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                <ng-container *ngFor=\"let item of entryTypeList\">\r\n                    <button class=\"btn btn-sm btn-primary\"\r\n                        [disabled]=\"data.totalCount===1&&SiteOfSectionType===SectionType.Single\"\r\n                        [routerLink]=\"['/cms/admin/entries/create']\"\r\n                        [queryParams]=\"{cultureName: filters.culture,sectionId:filters.sectionId,entryTypeId:item.id}\"><i\r\n                            class=\"fa fa-plus me-2\"></i> {{'Cms::NewEntry'|abpLocalization}}</button>\r\n                </ng-container>\r\n            </div>\r\n        </div>\r\n    </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::NewEntry' | 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                                [disabled]=\"data.totalCount===1&&SiteOfSectionType===SectionType.Single&&isEntryTypeExist(item.id)\"\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-md-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-md-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-md-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-md-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-md-3 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::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::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::SectionType' | abpLocalization\" prop=\"sectionType\"\r\n                            [sortable]=\"false\">\r\n                            <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\r\n                                {{ 'Cms::Enum:SectionType:'+SectionType[value] |\r\n                                        abpLocalization }}\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\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\">{{'Cms::Edit' |\r\n                                            abpLocalization}}</button>\r\n                                        @if\r\n                                        (((row|getLocalizedEntriesBySlug:filters.sectionId:sectionLanguagesList)|async)===false)\r\n                                        {\r\n                                        <button ngbDropdownItem [routerLink]=\"['/cms/admin/entries/create']\"\r\n                                            [queryParams]=\"{cultureName: filters.culture,sectionId:filters.sectionId,entryTypeId:row.entryTypeId,entryVersionId:row.id,isOther:1}\">{{'Cms::CreateOtherLanguages'\r\n                                            |\r\n                                            abpLocalization}} </button>\r\n                                        }\r\n                                        <button ngbDropdownItem (click)=\"deletefield(row)\">{{'Cms::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 [cdkDropListSortingDisabled]=\"true\" (cdkDropListDropped)=\"drop($event)\">\r\n                        <thead>\r\n                            <tr>\r\n                                <th class=\"sticky-left-card-bg\"> <span\r\n                                        class=\"bi bi-arrows-move fs-5 drag-handle me-2 opacity-0\"></span>{{'AbpUi::Actions'\r\n                                    | abpLocalization}}</th>\r\n                                <th>{{'Cms::Slug' | abpLocalization}}</th>\r\n                                <th>{{'Cms::ParentEntry' | abpLocalization}}</th>\r\n                                <!-- <th>{{'Cms::Title' | abpLocalization}}</th> -->\r\n                                <th>{{'Cms::SectionType' | abpLocalization}}</th>\r\n                                <th>{{'Cms::EntryType' | 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                            <ng-container *ngFor=\"let item of data.items\">\r\n                                <ng-container *ngTemplateOutlet=\"treeRow; context: {item: item, level: 0}\"></ng-container>\r\n                            </ng-container>\r\n                        </tbody>\r\n                        \r\n                        <ng-template #treeRow let-item=\"item\" let-level=\"level\">\r\n                            <tr cdkDrag [cdkDragData]=\"{item: item, level: level}\"\r\n                                [class.drop-above]=\"dropPosition === 'above' && dropTargetId === item.id && !isInvalidDropTarget\"\r\n                                [class.drop-below]=\"dropPosition === 'below' && dropTargetId === item.id && !isInvalidDropTarget\"\r\n                                [class.drop-inside]=\"dropPosition === 'inside' && dropTargetId === item.id && !isInvalidDropTarget\"\r\n                                [class.drop-invalid]=\"dropTargetId === item.id && isInvalidDropTarget\"\r\n                                [style.cursor]=\"dropTargetId === item.id && isInvalidDropTarget ? 'not-allowed' : ''\"\r\n                                (cdkDragStarted)=\"onDragStarted($event)\"\r\n                                (cdkDragEnded)=\"onDragEnded($event)\"\r\n                                (cdkDragEntered)=\"onDragEntered($event, item)\"\r\n                                (mousemove)=\"onMouseMove($event, item)\">\r\n                                <td class=\"sticky-left-card-bg\">\r\n                                    <div ngbDropdown container=\"body\">\r\n                                        <span class=\"bi bi-arrows-move fs-5 drag-handle me-2\" cdkDragHandle></span>\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                                            @if\r\n                                            (((item|getLocalizedEntriesBySlug:filters.sectionId:sectionLanguagesList)|async)===false)\r\n                                            {\r\n                                            <button ngbDropdownItem [routerLink]=\"['/cms/admin/entries/create']\"\r\n                                                [queryParams]=\"{cultureName: filters.culture,sectionId:filters.sectionId,entryTypeId:item.entryTypeId,entryVersionId:item.id,isOther:1}\">{{'Cms::CreateOtherLanguages'\r\n                                                |\r\n                                                abpLocalization}}</button>\r\n                                            }\r\n                                            <!-- <button ngbDropdownItem [routerLink]=\"['/cms/admin/entries/create']\"\r\n                                                [queryParams]=\"{cultureName: filters.culture,sectionId:filters.sectionId,entryTypeId:row.entryTypeId,entryVersionId:row.id,isOther:1}\">{{'Cms::CreateOtherLanguages'\r\n                                                |\r\n                                                abpLocalization}} </button> -->\r\n\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\" (mousemove)=\"onMouseMove($event, item)\">\r\n                                    <span [style.padding-left.px]=\"level * 20\">{{item.slug}}</span>\r\n                                </td>\r\n                                <td class=\"white-space-normal\">{{(item.parentId|getSlugById:copylistItem)||'---'}}</td>\r\n                                <td>\r\n                                    {{ 'Cms::Enum:SectionType:'+SectionType[item.sectionType] |\r\n                                    abpLocalization }}\r\n                                </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\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\"\r\n                                        [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                            <ng-container *ngIf=\"item.children && item.children.length > 0\">\r\n                                <ng-container *ngFor=\"let child of item.children\">\r\n                                    <ng-container *ngTemplateOutlet=\"treeRow; context: {item: child, level: level + 1}\"></ng-container>\r\n                                </ng-container>\r\n                            </ng-container>\r\n                        </ng-template>\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>"]}