@bnsights/bbsf-controls 1.0.133 → 1.0.134
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md
CHANGED
|
@@ -5,6 +5,10 @@ BBSF Controls package is part of BBSF 3 packages. It has all the form controls t
|
|
|
5
5
|
For more info please visit [BBSF Controls documenation](https://bbsfadmin.bnsights.com/controls) or [BBSF documentation](https://bnsightsprojects.visualstudio.com/BBSF%203/_wiki/wikis/BBSF-3.wiki/65/BBSF-Documentation)
|
|
6
6
|
|
|
7
7
|
# Change Log
|
|
8
|
+
## 1.0.134 / 24-3-2024
|
|
9
|
+
===================
|
|
10
|
+
* Fix delete in repeater control
|
|
11
|
+
|
|
8
12
|
## 1.0.133 / 24-3-2024
|
|
9
13
|
===================
|
|
10
14
|
* Fix naming convention in repeater control while edit
|
|
@@ -68,7 +68,7 @@ export class RepeaterComponent {
|
|
|
68
68
|
if (this.items.length == this.options.minRequiredItems && this.options.isRequired)
|
|
69
69
|
return;
|
|
70
70
|
let deletedControls = [];
|
|
71
|
-
let controlNames = this.options.repeaterStructure.map(e => e.controlOptions.
|
|
71
|
+
let controlNames = this.options.repeaterStructure.map(e => e.controlOptions.name);
|
|
72
72
|
for (const key in this.repeaterGroup.controls) {
|
|
73
73
|
if (Object.prototype.hasOwnProperty.call(this.repeaterGroup.controls, key)) {
|
|
74
74
|
for (let index = 0; index < controlNames.length; index++) {
|
|
@@ -122,4 +122,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.6", ngImpor
|
|
|
122
122
|
type: ViewChild,
|
|
123
123
|
args: ['delete', { static: false }]
|
|
124
124
|
}] } });
|
|
125
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"repeater.component.js","sourceRoot":"","sources":["../../../../../../../projects/bbsf-controls/src/lib/controls/Repeater/repeater/repeater.component.ts","../../../../../../../projects/bbsf-controls/src/lib/controls/Repeater/repeater/repeater.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, QueryList, TemplateRef, ViewChild, ViewChildren } from '@angular/core';\r\nimport { FormGroup } from '@angular/forms';\r\nimport { RepeaterOptions } from '../../../Shared/Models/RepeaterOptions';\r\nimport { NgTemplateNameDirective } from '../../../Shared/Directives/template-name.directive';\r\n\r\n\r\n@Component({\r\n  selector: 'BBSF-repeater',\r\n  templateUrl: './repeater.component.html'\r\n})\r\nexport class RepeaterComponent implements OnInit {\r\n  @Input() group: FormGroup;\r\n  @Input() options: RepeaterOptions;\r\n  @Input() initialTemplate: TemplateRef<any>;\r\n  @ViewChildren(NgTemplateNameDirective) private _templates: QueryList<NgTemplateNameDirective>;\r\n  @ViewChild('delete', { static: false }) delete: TemplateRef<any>;\r\n  templateRefs: Array<TemplateRef<any>> = [];\r\n  items: number[] = [];\r\n  originalItems: any[] = [];\r\n  repeaterGroup: FormGroup;\r\n  currentTemplate: TemplateRef<any>;\r\n  repeaterContext = { index: 0, delete: null, elements: null };\r\n\r\n  constructor() { }\r\n\r\n  ngOnInit(): void {\r\n    this.currentTemplate = this.initialTemplate;\r\n    this.repeaterGroup = new FormGroup({});\r\n    this.group.addControl(this.options.name, this.repeaterGroup);\r\n    if (this.options.repeaterValue.length > 0) {\r\n      this.originalItems = this.options.repeaterValue;\r\n      for (let index = 0; index < this.options.repeaterValue.length; index++) {\r\n        this.items.push(index + 1);\r\n      }\r\n    }\r\n    else\r\n      for (let index = 0; index < this.options.minRequiredItems; index++) {\r\n        this.items.push(index);\r\n      }\r\n\r\n    this.repeaterGroup.valueChanges.subscribe((res) => {\r\n      let result = [];\r\n      let rowNumber = [];\r\n      let addItems = [];\r\n      for (const key in this.repeaterGroup.controls) {\r\n        if (Object.prototype.hasOwnProperty.call(this.repeaterGroup.controls, key)) {\r\n          const keySplitArr = key.split('.');\r\n          let item = {\r\n            [keySplitArr[1]]: { [keySplitArr[0]]: this.group.controls[this.options.name].value[key] }\r\n          };\r\n          addItems.push(item);\r\n          if (!rowNumber.includes(keySplitArr[1]))\r\n            rowNumber.push(keySplitArr[1]);\r\n        }\r\n      }\r\n      for (let index = 0; index < rowNumber.length; index++) {\r\n        const row = rowNumber[index];\r\n        let addObject = {};\r\n        let filteredElements = addItems.filter(item => item[row]);\r\n        for (let index = 0; index < filteredElements.length; index++) {\r\n          const filteredElement = filteredElements[index];\r\n          for (const key in filteredElement) {\r\n            if (Object.prototype.hasOwnProperty.call(filteredElement, key)) {\r\n              const element = filteredElement[key];\r\n              for (const key in element) {\r\n                if (Object.prototype.hasOwnProperty.call(element, key)) {\r\n                  const value = element[key];\r\n                  addObject[key] = value;\r\n                }\r\n              }\r\n            }\r\n          }\r\n        }\r\n        result.push(addObject);\r\n      }\r\n      this.options.repeaterValue = result;\r\n    });\r\n\r\n  }\r\n\r\n  deleteItem(Index) {\r\n    if (this.items.length == this.options.minRequiredItems && this.options.isRequired)\r\n      return;\r\n    let deletedControls: any[] = [];\r\n    let controlNames = this.options.repeaterStructure.map(e => e.controlOptions.Name);\r\n    for (const key in this.repeaterGroup.controls) {\r\n      if (Object.prototype.hasOwnProperty.call(this.repeaterGroup.controls, key)) {\r\n        for (let index = 0; index < controlNames.length; index++) {\r\n          const element = controlNames[index];\r\n          const keySplitArr = key.split('.');\r\n          if (keySplitArr[0] + keySplitArr[1] == `${element}${Index}`) {\r\n            const element = this.repeaterGroup.controls[key];\r\n            deletedControls.push({ [key]: element });\r\n          }\r\n        }\r\n      }\r\n    }\r\n    for (let index = 0; index < deletedControls.length; index++) {\r\n      const element = deletedControls[index];\r\n      for (const key in element) {\r\n        if (Object.prototype.hasOwnProperty.call(element, key)) {\r\n          this.repeaterGroup.removeControl(key);\r\n        }\r\n      }\r\n    }\r\n    this.items = this.items.filter((res) => res != this.items[Index]);\r\n  }\r\n\r\n\r\n  addItem() {\r\n    this.items.push(this.items.length);\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    let templateRefs = (this._templates[\"_results\"] as any[]).map((item) => item[\"template\"]);\r\n    this.templateRefs = templateRefs;\r\n    this.repeaterContext.elements = this.templateRefs;\r\n    this.repeaterContext.delete = this.delete;\r\n\r\n  }\r\n\r\n  setCurrentIndex(i: number) {\r\n    this.repeaterContext.index = i;\r\n  }\r\n\r\n}\r\n","<ng-container *ngFor='let item of items ; index as i'>\r\n  {{setCurrentIndex(i)}}\r\n  <ng-container *ngTemplateOutlet=\"currentTemplate; context: repeaterContext\">\r\n  </ng-container>\r\n\r\n</ng-container>\r\n\r\n<ng-container *ngTemplateOutlet=\"add\">\r\n</ng-container>\r\n\r\n<ng-template *ngFor=\"let repeaterField of options.repeaterStructure ; index as i\" name=\"R{{i}}\" let-Index=\"itemIndex\" let-control=\"controlIndex\">\r\n  <repeater-field-builder *ngIf=\"repeaterField\" [repeaterField]=\"repeaterField\" [itemNumber]=\"Index\" [itemsValue]=\"originalItems\"\r\n    [controlNumber]=\"control\" [group]=\"repeaterGroup\">\r\n  </repeater-field-builder>\r\n</ng-template>\r\n\r\n<ng-template #delete let-item=\"itemIndex\">\r\n  <button *ngIf=\"!options.isReadonly\" class=\"{{options.deleteButtonExtraClasses}}\" type=\"button\" (click)=\"deleteItem(item)\"\r\n    [disabled]=\"items.length ==options.minRequiredItems&&options.isRequired\">\r\n    <span [innerHTML]=\"options.deleteButtonText\"></span>\r\n  </button>\r\n</ng-template>\r\n\r\n<ng-template #add>\r\n  <button *ngIf=\"!options.isReadonly\" class=\"{{options.addButtonExtraClasses}}\" type=\"button\" (click)=\"addItem()\">\r\n    <span [innerHTML]=\"options.addButtonText\"></span>\r\n  </button>\r\n</ng-template>"]}
|
|
125
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"repeater.component.js","sourceRoot":"","sources":["../../../../../../../projects/bbsf-controls/src/lib/controls/Repeater/repeater/repeater.component.ts","../../../../../../../projects/bbsf-controls/src/lib/controls/Repeater/repeater/repeater.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, QueryList, TemplateRef, ViewChild, ViewChildren } from '@angular/core';\r\nimport { FormGroup } from '@angular/forms';\r\nimport { RepeaterOptions } from '../../../Shared/Models/RepeaterOptions';\r\nimport { NgTemplateNameDirective } from '../../../Shared/Directives/template-name.directive';\r\n\r\n\r\n@Component({\r\n  selector: 'BBSF-repeater',\r\n  templateUrl: './repeater.component.html'\r\n})\r\nexport class RepeaterComponent implements OnInit {\r\n  @Input() group: FormGroup;\r\n  @Input() options: RepeaterOptions;\r\n  @Input() initialTemplate: TemplateRef<any>;\r\n  @ViewChildren(NgTemplateNameDirective) private _templates: QueryList<NgTemplateNameDirective>;\r\n  @ViewChild('delete', { static: false }) delete: TemplateRef<any>;\r\n  templateRefs: Array<TemplateRef<any>> = [];\r\n  items: number[] = [];\r\n  originalItems: any[] = [];\r\n  repeaterGroup: FormGroup;\r\n  currentTemplate: TemplateRef<any>;\r\n  repeaterContext = { index: 0, delete: null, elements: null };\r\n\r\n  constructor() { }\r\n\r\n  ngOnInit(): void {\r\n    this.currentTemplate = this.initialTemplate;\r\n    this.repeaterGroup = new FormGroup({});\r\n    this.group.addControl(this.options.name, this.repeaterGroup);\r\n    if (this.options.repeaterValue.length > 0) {\r\n      this.originalItems = this.options.repeaterValue;\r\n      for (let index = 0; index < this.options.repeaterValue.length; index++) {\r\n        this.items.push(index + 1);\r\n      }\r\n    }\r\n    else\r\n      for (let index = 0; index < this.options.minRequiredItems; index++) {\r\n        this.items.push(index);\r\n      }\r\n\r\n    this.repeaterGroup.valueChanges.subscribe((res) => {\r\n      let result = [];\r\n      let rowNumber = [];\r\n      let addItems = [];\r\n      for (const key in this.repeaterGroup.controls) {\r\n        if (Object.prototype.hasOwnProperty.call(this.repeaterGroup.controls, key)) {\r\n          const keySplitArr = key.split('.');\r\n          let item = {\r\n            [keySplitArr[1]]: { [keySplitArr[0]]: this.group.controls[this.options.name].value[key] }\r\n          };\r\n          addItems.push(item);\r\n          if (!rowNumber.includes(keySplitArr[1]))\r\n            rowNumber.push(keySplitArr[1]);\r\n        }\r\n      }\r\n      for (let index = 0; index < rowNumber.length; index++) {\r\n        const row = rowNumber[index];\r\n        let addObject = {};\r\n        let filteredElements = addItems.filter(item => item[row]);\r\n        for (let index = 0; index < filteredElements.length; index++) {\r\n          const filteredElement = filteredElements[index];\r\n          for (const key in filteredElement) {\r\n            if (Object.prototype.hasOwnProperty.call(filteredElement, key)) {\r\n              const element = filteredElement[key];\r\n              for (const key in element) {\r\n                if (Object.prototype.hasOwnProperty.call(element, key)) {\r\n                  const value = element[key];\r\n                  addObject[key] = value;\r\n                }\r\n              }\r\n            }\r\n          }\r\n        }\r\n        result.push(addObject);\r\n      }\r\n      this.options.repeaterValue = result;\r\n    });\r\n\r\n  }\r\n\r\n  deleteItem(Index) {\r\n    if (this.items.length == this.options.minRequiredItems && this.options.isRequired)\r\n      return;\r\n    let deletedControls: any[] = [];\r\n    let controlNames = this.options.repeaterStructure.map(e => e.controlOptions.name);\r\n    for (const key in this.repeaterGroup.controls) {\r\n      if (Object.prototype.hasOwnProperty.call(this.repeaterGroup.controls, key)) {\r\n        for (let index = 0; index < controlNames.length; index++) {\r\n          const element = controlNames[index];\r\n          const keySplitArr = key.split('.');\r\n          if (keySplitArr[0] + keySplitArr[1] == `${element}${Index}`) {\r\n            const element = this.repeaterGroup.controls[key];\r\n            deletedControls.push({ [key]: element });\r\n          }\r\n        }\r\n      }\r\n    }\r\n    for (let index = 0; index < deletedControls.length; index++) {\r\n      const element = deletedControls[index];\r\n      for (const key in element) {\r\n        if (Object.prototype.hasOwnProperty.call(element, key)) {\r\n          this.repeaterGroup.removeControl(key);\r\n        }\r\n      }\r\n    }\r\n    this.items = this.items.filter((res) => res != this.items[Index]);\r\n  }\r\n\r\n\r\n  addItem() {\r\n    this.items.push(this.items.length);\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    let templateRefs = (this._templates[\"_results\"] as any[]).map((item) => item[\"template\"]);\r\n    this.templateRefs = templateRefs;\r\n    this.repeaterContext.elements = this.templateRefs;\r\n    this.repeaterContext.delete = this.delete;\r\n\r\n  }\r\n\r\n  setCurrentIndex(i: number) {\r\n    this.repeaterContext.index = i;\r\n  }\r\n\r\n}\r\n","<ng-container *ngFor='let item of items ; index as i'>\r\n  {{setCurrentIndex(i)}}\r\n  <ng-container *ngTemplateOutlet=\"currentTemplate; context: repeaterContext\">\r\n  </ng-container>\r\n\r\n</ng-container>\r\n\r\n<ng-container *ngTemplateOutlet=\"add\">\r\n</ng-container>\r\n\r\n<ng-template *ngFor=\"let repeaterField of options.repeaterStructure ; index as i\" name=\"R{{i}}\" let-Index=\"itemIndex\" let-control=\"controlIndex\">\r\n  <repeater-field-builder *ngIf=\"repeaterField\" [repeaterField]=\"repeaterField\" [itemNumber]=\"Index\" [itemsValue]=\"originalItems\"\r\n    [controlNumber]=\"control\" [group]=\"repeaterGroup\">\r\n  </repeater-field-builder>\r\n</ng-template>\r\n\r\n<ng-template #delete let-item=\"itemIndex\">\r\n  <button *ngIf=\"!options.isReadonly\" class=\"{{options.deleteButtonExtraClasses}}\" type=\"button\" (click)=\"deleteItem(item)\"\r\n    [disabled]=\"items.length ==options.minRequiredItems&&options.isRequired\">\r\n    <span [innerHTML]=\"options.deleteButtonText\"></span>\r\n  </button>\r\n</ng-template>\r\n\r\n<ng-template #add>\r\n  <button *ngIf=\"!options.isReadonly\" class=\"{{options.addButtonExtraClasses}}\" type=\"button\" (click)=\"addItem()\">\r\n    <span [innerHTML]=\"options.addButtonText\"></span>\r\n  </button>\r\n</ng-template>"]}
|
|
@@ -8136,7 +8136,7 @@ class RepeaterComponent {
|
|
|
8136
8136
|
if (this.items.length == this.options.minRequiredItems && this.options.isRequired)
|
|
8137
8137
|
return;
|
|
8138
8138
|
let deletedControls = [];
|
|
8139
|
-
let controlNames = this.options.repeaterStructure.map(e => e.controlOptions.
|
|
8139
|
+
let controlNames = this.options.repeaterStructure.map(e => e.controlOptions.name);
|
|
8140
8140
|
for (const key in this.repeaterGroup.controls) {
|
|
8141
8141
|
if (Object.prototype.hasOwnProperty.call(this.repeaterGroup.controls, key)) {
|
|
8142
8142
|
for (let index = 0; index < controlNames.length; index++) {
|