@decaf-ts/for-angular 0.0.11 → 0.0.12
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/dist/for-angular/cli/cli-module.d.ts +22 -0
- package/dist/for-angular/cli/cli-module.d.ts.map +1 -0
- package/dist/for-angular/cli/cli-module.js +131 -0
- package/dist/for-angular/cli/cli-module.js.map +1 -0
- package/dist/lib/components/component-renderer/component-renderer.component.d.ts +1 -0
- package/dist/lib/components/component-renderer/component-renderer.component.d.ts.map +1 -0
- package/dist/lib/components/crud-field/crud-field.component.d.ts +1 -0
- package/dist/lib/components/crud-field/crud-field.component.d.ts.map +1 -0
- package/dist/lib/components/crud-form/constants.d.ts +1 -0
- package/dist/lib/components/crud-form/constants.d.ts.map +1 -0
- package/dist/lib/components/crud-form/crud-form.component.d.ts +1 -0
- package/dist/lib/components/crud-form/crud-form.component.d.ts.map +1 -0
- package/dist/lib/components/crud-form/types.d.ts +1 -0
- package/dist/lib/components/crud-form/types.d.ts.map +1 -0
- package/dist/lib/components/empty-state/empty-state.component.d.ts +1 -0
- package/dist/lib/components/empty-state/empty-state.component.d.ts.map +1 -0
- package/dist/lib/components/fieldset/fieldset.component.d.ts +1 -0
- package/dist/lib/components/fieldset/fieldset.component.d.ts.map +1 -0
- package/dist/lib/components/filter/filter.component.d.ts +1 -0
- package/dist/lib/components/filter/filter.component.d.ts.map +1 -0
- package/dist/lib/components/for-angular-components.module.d.ts +1 -0
- package/dist/lib/components/for-angular-components.module.d.ts.map +1 -0
- package/dist/lib/components/index.d.ts +1 -0
- package/dist/lib/components/index.d.ts.map +1 -0
- package/dist/lib/components/layout/layout.component.d.ts +1 -0
- package/dist/lib/components/layout/layout.component.d.ts.map +1 -0
- package/dist/lib/components/list/constants.d.ts +1 -0
- package/dist/lib/components/list/constants.d.ts.map +1 -0
- package/dist/lib/components/list/list.component.d.ts +1 -0
- package/dist/lib/components/list/list.component.d.ts.map +1 -0
- package/dist/lib/components/list-item/list-item.component.d.ts +1 -0
- package/dist/lib/components/list-item/list-item.component.d.ts.map +1 -0
- package/dist/lib/components/model-renderer/model-renderer.component.d.ts +1 -0
- package/dist/lib/components/model-renderer/model-renderer.component.d.ts.map +1 -0
- package/dist/lib/components/pagination/constants.d.ts +1 -0
- package/dist/lib/components/pagination/constants.d.ts.map +1 -0
- package/dist/lib/components/pagination/pagination.component.d.ts +1 -0
- package/dist/lib/components/pagination/pagination.component.d.ts.map +1 -0
- package/dist/lib/components/searchbar/searchbar.component.d.ts +1 -0
- package/dist/lib/components/searchbar/searchbar.component.d.ts.map +1 -0
- package/dist/lib/decaf-ts-for-angular.d.ts.map +1 -0
- package/dist/lib/directives/collapsable.directive.d.ts +1 -0
- package/dist/lib/directives/collapsable.directive.d.ts.map +1 -0
- package/dist/lib/directives/index.d.ts +1 -0
- package/dist/lib/directives/index.d.ts.map +1 -0
- package/dist/lib/engine/DynamicModule.d.ts +1 -0
- package/dist/lib/engine/DynamicModule.d.ts.map +1 -0
- package/dist/lib/engine/NgxBaseComponent.d.ts +1 -0
- package/dist/lib/engine/NgxBaseComponent.d.ts.map +1 -0
- package/dist/lib/engine/NgxCrudFormField.d.ts +1 -0
- package/dist/lib/engine/NgxCrudFormField.d.ts.map +1 -0
- package/dist/lib/engine/NgxFormService.d.ts +1 -0
- package/dist/lib/engine/NgxFormService.d.ts.map +1 -0
- package/dist/lib/engine/NgxRenderingEngine.d.ts +1 -0
- package/dist/lib/engine/NgxRenderingEngine.d.ts.map +1 -0
- package/dist/lib/engine/NgxRenderingEngine2.d.ts +1 -0
- package/dist/lib/engine/NgxRenderingEngine2.d.ts.map +1 -0
- package/dist/lib/engine/ValidatorFactory.d.ts +1 -0
- package/dist/lib/engine/ValidatorFactory.d.ts.map +1 -0
- package/dist/lib/engine/constants.d.ts +1 -0
- package/dist/lib/engine/constants.d.ts.map +1 -0
- package/dist/lib/engine/decorators.d.ts +1 -0
- package/dist/lib/engine/decorators.d.ts.map +1 -0
- package/dist/lib/engine/index.d.ts +1 -0
- package/dist/lib/engine/index.d.ts.map +1 -0
- package/dist/lib/engine/types.d.ts +1 -0
- package/dist/lib/engine/types.d.ts.map +1 -0
- package/dist/lib/esm2022/components/component-renderer/component-renderer.component.mjs +70 -24
- package/dist/lib/esm2022/components/crud-field/crud-field.component.mjs +271 -116
- package/dist/lib/esm2022/components/crud-form/crud-form.component.mjs +170 -37
- package/dist/lib/esm2022/components/empty-state/empty-state.component.mjs +103 -41
- package/dist/lib/esm2022/components/fieldset/fieldset.component.mjs +41 -16
- package/dist/lib/esm2022/components/filter/filter.component.mjs +248 -31
- package/dist/lib/esm2022/components/for-angular-components.module.mjs +38 -37
- package/dist/lib/esm2022/components/layout/layout.component.mjs +84 -15
- package/dist/lib/esm2022/components/list/list.component.mjs +252 -83
- package/dist/lib/esm2022/components/list-item/list-item.component.mjs +250 -46
- package/dist/lib/esm2022/components/model-renderer/model-renderer.component.mjs +66 -22
- package/dist/lib/esm2022/components/pagination/pagination.component.mjs +58 -17
- package/dist/lib/esm2022/components/searchbar/searchbar.component.mjs +66 -56
- package/dist/lib/esm2022/directives/collapsable.directive.mjs +10 -10
- package/dist/lib/esm2022/engine/NgxBaseComponent.mjs +53 -46
- package/dist/lib/esm2022/for-angular.module.mjs +40 -39
- package/dist/lib/fesm2022/decaf-ts-for-angular.mjs +1805 -621
- package/dist/lib/fesm2022/decaf-ts-for-angular.mjs.map +1 -1
- package/dist/lib/for-angular.module.d.ts +1 -0
- package/dist/lib/for-angular.module.d.ts.map +1 -0
- package/dist/lib/helpers/index.d.ts +1 -0
- package/dist/lib/helpers/index.d.ts.map +1 -0
- package/dist/lib/helpers/utils.d.ts +1 -0
- package/dist/lib/helpers/utils.d.ts.map +1 -0
- package/dist/lib/index.d.ts +1 -0
- package/dist/lib/interfaces.d.ts +1 -0
- package/dist/lib/interfaces.d.ts.map +1 -0
- package/dist/lib/public-apis.d.ts +1 -0
- package/dist/lib/public-apis.d.ts.map +1 -0
- package/package.json +3 -2
|
@@ -6,6 +6,8 @@ import { ForAngularModule } from '../../for-angular.module';
|
|
|
6
6
|
import { CollapsableDirective } from '../../directives/collapsable.directive';
|
|
7
7
|
import { IonAccordion, IonAccordionGroup, IonItem } from '@ionic/angular/standalone';
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
9
|
+
const _c0 = ["component"];
|
|
10
|
+
const _c1 = ["*"];
|
|
9
11
|
/**
|
|
10
12
|
* @description Dynamic fieldset component with collapsible accordion functionality.
|
|
11
13
|
* @summary This component provides a sophisticated fieldset container that automatically
|
|
@@ -202,24 +204,47 @@ let FieldsetComponent = class FieldsetComponent {
|
|
|
202
204
|
if (target.tagName === 'ION-ACCORDION-GROUP')
|
|
203
205
|
this.isOpen = !!value;
|
|
204
206
|
}
|
|
205
|
-
static { this.ɵfac =
|
|
206
|
-
static { this.ɵcmp = i0.ɵɵ
|
|
207
|
+
static { this.ɵfac = function FieldsetComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || FieldsetComponent)(); }; }
|
|
208
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: FieldsetComponent, selectors: [["ngx-decaf-fieldset"]], viewQuery: function FieldsetComponent_Query(rf, ctx) { if (rf & 1) {
|
|
209
|
+
i0.ɵɵviewQuery(_c0, 5, ElementRef);
|
|
210
|
+
} if (rf & 2) {
|
|
211
|
+
let _t;
|
|
212
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.component = _t.first);
|
|
213
|
+
} }, inputs: { name: "name", operation: "operation", target: "target" }, standalone: true, features: [i0.ɵɵStandaloneFeature], ngContentSelectors: _c1, decls: 9, vars: 4, consts: [["component", ""], [3, "ionChange"], ["value", "open"], ["slot", "header"], ["slot", "content", "decafCollapsable", ""]], template: function FieldsetComponent_Template(rf, ctx) { if (rf & 1) {
|
|
214
|
+
const _r1 = i0.ɵɵgetCurrentView();
|
|
215
|
+
i0.ɵɵprojectionDef();
|
|
216
|
+
i0.ɵɵelementStart(0, "fieldset", null, 0)(2, "ion-accordion-group", 1);
|
|
217
|
+
i0.ɵɵlistener("ionChange", function FieldsetComponent_Template_ion_accordion_group_ionChange_2_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.handleChange($event)); });
|
|
218
|
+
i0.ɵɵelementStart(3, "ion-accordion", 2)(4, "ion-item", 3)(5, "legend");
|
|
219
|
+
i0.ɵɵtext(6);
|
|
220
|
+
i0.ɵɵelementEnd()();
|
|
221
|
+
i0.ɵɵelementStart(7, "div", 4);
|
|
222
|
+
i0.ɵɵprojection(8);
|
|
223
|
+
i0.ɵɵelementEnd()()()();
|
|
224
|
+
} if (rf & 2) {
|
|
225
|
+
i0.ɵɵclassMap("dcf-fieldset " + ctx.operation);
|
|
226
|
+
i0.ɵɵadvance(6);
|
|
227
|
+
i0.ɵɵtextInterpolate(ctx.name);
|
|
228
|
+
i0.ɵɵadvance();
|
|
229
|
+
i0.ɵɵattribute("aria-hidden", !ctx.isOpen);
|
|
230
|
+
} }, dependencies: [ForAngularModule, IonAccordionGroup, IonAccordion, IonItem, CollapsableDirective], styles: [".dcf-fieldset[_ngcontent-%COMP%]{margin-bottom:1.8rem;padding-bottom:0;padding-top:1rem;border:1px solid var(--ion-color-gray-2);border-radius:8px}.dcf-fieldset[_ngcontent-%COMP%] ion-accordion-group[_ngcontent-%COMP%]{--border-color:red !important}.dcf-fieldset.read[_ngcontent-%COMP%]{margin-top:1.25rem}.dcf-fieldset[_ngcontent-%COMP%] ion-accordion.accordion-collapsing[_ngcontent-%COMP%], .dcf-fieldset[_ngcontent-%COMP%] ion-accordion.accordion-collapsed[_ngcontent-%COMP%]{margin-bottom:1rem}.dcf-fieldset[_ngcontent-%COMP%] ion-accordion[_ngcontent-%COMP%] ion-item[slot=header][_ngcontent-%COMP%]{--border-color: transparent;--border-radius: 6px;--inner-border-width: 0;--padding-start: 12px}.dcf-fieldset[_ngcontent-%COMP%] ion-accordion[_ngcontent-%COMP%] ion-item[slot=header][_ngcontent-%COMP%] legend[_ngcontent-%COMP%]{font-weight:600;font-size:1rem;color:#333;margin:0}.dcf-fieldset[_ngcontent-%COMP%] ion-accordion[_ngcontent-%COMP%] [slot=content][_ngcontent-%COMP%]{padding-top:1rem!important;padding-inline:.75rem;background-color:#fff}"] }); }
|
|
207
231
|
};
|
|
208
232
|
FieldsetComponent = __decorate([
|
|
209
233
|
Dynamic()
|
|
210
234
|
], FieldsetComponent);
|
|
211
235
|
export { FieldsetComponent };
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fieldset.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/fieldset/fieldset.component.ts","../../../../../src/lib/components/fieldset/fieldset.component.html"],"names":[],"mappings":";AACA,OAAO,EAAiB,iBAAiB,EAAE,SAAS,EAAE,sBAAsB,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC1I,OAAO,EAAE,OAAO,EAAkB,MAAM,cAAc,CAAC;AACvD,OAAO,EAAkB,aAAa,EAAE,MAAM,yBAAyB,CAAC;AACxE,OAAO,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAC5D,OAAO,EAAE,oBAAoB,EAAE,MAAM,wCAAwC,CAAC;AAC9E,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;;AAErF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAiDG;AAUI,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;IAAvB;QAeL;;;;;;;;;;WAUG;QAEH,SAAI,GAAW,OAAO,CAAC;QAEvB;;;;;;;;;;WAUG;QAEH,cAAS,GAAkB,aAAa,CAAC,IAAI,CAAC;QAE9C;;;;;;;;;;WAUG;QAEH,WAAM,GAAmB,OAAO,CAAC;QAEjC;;;;;;;;;;WAUG;QACH,WAAM,GAAY,KAAK,CAAC;QAExB;;;;;;;;;;WAUG;QACgB,kBAAa,GAAmB,aAAa,CAAC,MAAM,CAAC;QAExE;;;;;;;;;;WAUG;QACK,sBAAiB,GAAsB,MAAM,CAAC,iBAAiB,CAAC,CAAC;KA0E1E;IAxEC;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA4BG;IACH,eAAe;QACb,IAAI,IAAI,CAAC,SAAS,KAAK,aAAa,CAAC,IAAI,IAAI,IAAI,CAAC,SAAS,KAAK,aAAa,CAAC,MAAM,EAAE,CAAC;YACrF,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;YACnB,MAAM,gBAAgB,GAAG,IAAI,CAAC,SAAS,EAAE,aAAa,CAAC,aAAa,CAAC,qBAAqB,CAAC,CAAC;YAC5F,IAAG,gBAAgB;gBACjB,gBAAgB,CAAC,YAAY,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;QACnD,CAAC;QACD,IAAI,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC;IACzC,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;;;;;;OA0BG;IACH,YAAY,CAAC,KAAkB;QAC7B,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,KAAK,CAAC;QACjC,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,CAAC;QACzB,IAAK,MAAuC,CAAC,OAAO,KAAK,qBAAqB;YAC5E,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,KAAK,CAAC;IAC1B,CAAC;+GAvKU,iBAAiB;mGAAjB,iBAAiB,qOAYmB,UAAU,6BC/E3D,0bAYA,owBDqDY,gBAAgB,+BAAE,iBAAiB,qJAAE,YAAY,6IAAE,OAAO,0NAAE,oBAAoB;;AAE/E,iBAAiB;IAT7B,OAAO,EAAE;GASG,iBAAiB,CAwK7B;;4FAxKY,iBAAiB;kBAR7B,SAAS;iCACI,IAAI,YACN,oBAAoB,WAGrB,CAAC,sBAAsB,CAAC,WACxB,CAAC,gBAAgB,EAAE,iBAAiB,EAAE,YAAY,EAAE,OAAO,EAAE,oBAAoB,CAAC;8BAe3F,SAAS;sBADR,SAAS;uBAAC,WAAW,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,UAAU,EAAE;gBAe3D,IAAI;sBADH,KAAK;gBAeN,SAAS;sBADR,KAAK;gBAeN,MAAM;sBADL,KAAK","sourcesContent":["\nimport { AfterViewInit, ChangeDetectorRef, Component, CUSTOM_ELEMENTS_SCHEMA, ElementRef, inject, Input, ViewChild } from '@angular/core';\nimport { Dynamic, HTMLFormTarget } from '../../engine';\nimport { CrudOperations, OperationKeys } from '@decaf-ts/db-decorators';\nimport { ForAngularModule } from '../../for-angular.module';\nimport { CollapsableDirective } from '../../directives/collapsable.directive';\nimport { IonAccordion, IonAccordionGroup, IonItem } from '@ionic/angular/standalone';\n\n/**\n * @description Dynamic fieldset component with collapsible accordion functionality.\n * @summary This component provides a sophisticated fieldset container that automatically\n * adapts its behavior based on CRUD operations. It integrates seamlessly with Ionic's\n * accordion components to create expandable/collapsible sections for organizing form\n * content and related information. The component intelligently determines its initial\n * state based on the operation type, opening automatically for READ and DELETE operations\n * while remaining closed for CREATE and UPDATE operations.\n *\n * @example\n * ```html\n * <!-- Basic usage with automatic state management -->\n * <ngx-decaf-fieldset\n *   name=\"Personal Information\"\n *   [operation]=\"OperationKeys.READ\"\n *   target=\"_self\">\n *   <ion-input label=\"Name\" placeholder=\"Enter name\"></ion-input>\n *   <ion-input label=\"Email\" type=\"email\" placeholder=\"Enter email\"></ion-input>\n * </ngx-decaf-fieldset>\n *\n * <!-- Advanced usage with custom operation -->\n * <ngx-decaf-fieldset\n *   name=\"Contact Details\"\n *   [operation]=\"currentOperation\"\n *   target=\"_blank\">\n *   <!-- Complex form fields -->\n * </ngx-decaf-fieldset>\n * ```\n *\n * @mermaid\n * sequenceDiagram\n *   participant U as User\n *   participant F as FieldsetComponent\n *   participant I as Ionic Accordion\n *   participant D as DOM\n *\n *   F->>F: ngAfterViewInit()\n *   alt operation is READ or DELETE\n *     F->>F: Set isOpen = true\n *     F->>D: Query accordion element\n *     F->>I: Set value attribute to 'open'\n *     F->>F: Trigger change detection\n *   end\n *   U->>I: Click accordion header\n *   I->>F: handleChange(event)\n *   F->>F: Update isOpen state\n *   F->>I: Reflect new state\n *\n * @memberOf ForAngularModule\n */\n@Dynamic()\n@Component({\n  standalone: true,\n  selector: 'ngx-decaf-fieldset',\n  templateUrl: './fieldset.component.html',\n  styleUrls: ['./fieldset.component.scss'],\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\n  imports: [ForAngularModule, IonAccordionGroup, IonAccordion, IonItem, CollapsableDirective],\n})\nexport class FieldsetComponent implements AfterViewInit {\n\n  /**\n   * @description Reference to the component's native DOM element.\n   * @summary ViewChild reference that provides direct access to the component's root DOM element.\n   * This is essential for manipulating the Ionic accordion group after view initialization,\n   * particularly for setting the initial open state programmatically. The reference is used\n   * to query and modify accordion attributes that control the component's expanded state.\n   *\n   * @type {ElementRef}\n   * @memberOf FieldsetComponent\n   */\n  @ViewChild('component', { static: false, read: ElementRef })\n  component!: ElementRef;\n\n  /**\n   * @description The display name or title of the fieldset section.\n   * @summary Sets the legend or header text that appears in the accordion header. This text\n   * provides a clear label for the collapsible section, helping users understand what content\n   * is contained within. The name is displayed prominently and serves as the clickable area\n   * for expanding/collapsing the fieldset.\n   *\n   * @type {string}\n   * @default 'Child'\n   * @memberOf FieldsetComponent\n   */\n  @Input()\n  name: string = 'Child';\n\n  /**\n   * @description The current CRUD operation context.\n   * @summary Determines the component's initial behavior and state based on the current operation.\n   * This input is crucial for auto-state management: READ and DELETE operations automatically\n   * open the fieldset to show content, while CREATE and UPDATE operations keep it closed\n   * initially. This provides an intuitive user experience aligned with operation semantics.\n   *\n   * @type {OperationKeys}\n   * @default OperationKeys.READ\n   * @memberOf FieldsetComponent\n   */\n  @Input()\n  operation: OperationKeys = OperationKeys.READ;\n\n  /**\n   * @description Form target attribute for nested form submissions.\n   * @summary Specifies where to display the response after submitting forms contained within\n   * the fieldset. This attribute mirrors the HTML form target behavior, allowing control over\n   * whether form submissions open in the same window, new window, or specific frame. Useful\n   * for complex form workflows and multi-step processes.\n   *\n   * @type {HTMLFormTarget}\n   * @default '_self'\n   * @memberOf FieldsetComponent\n   */\n  @Input()\n  target: HTMLFormTarget = '_self';\n\n  /**\n   * @description Current state of the accordion (expanded or collapsed).\n   * @summary Boolean flag that tracks whether the fieldset accordion is currently open or closed.\n   * This property is automatically managed based on user interactions and initial operation state.\n   * It serves as the single source of truth for the component's visibility state and is used\n   * to coordinate between user actions and programmatic state changes.\n   *\n   * @type {boolean}\n   * @default false\n   * @memberOf FieldsetComponent\n   */\n  isOpen: boolean = false;\n\n  /**\n   * @description Reference to CRUD operation constants for template usage.\n   * @summary Exposes the OperationKeys enum to the component template, enabling conditional\n   * rendering and behavior based on operation types. This protected readonly property ensures\n   * that template logic can access operation constants while maintaining encapsulation and\n   * preventing accidental modification of the enum values.\n   *\n   * @type {CrudOperations}\n   * @default OperationKeys.CREATE\n   * @memberOf FieldsetComponent\n   */\n  protected readonly OperationKeys: CrudOperations = OperationKeys.CREATE;\n\n  /**\n   * @description Angular change detection service.\n   * @summary Injected service that provides manual control over change detection cycles.\n   * This is essential for ensuring that programmatic DOM changes (like setting accordion\n   * attributes) are properly reflected in the component's state and trigger appropriate\n   * view updates when modifications occur outside the normal Angular change detection flow.\n   *\n   * @private\n   * @type {ChangeDetectorRef}\n   * @memberOf FieldsetComponent\n   */\n  private changeDetectorRef: ChangeDetectorRef = inject(ChangeDetectorRef);\n\n  /**\n   * @description Initializes the component state after view and child components are rendered.\n   * @summary This lifecycle hook implements intelligent auto-state management based on the current\n   * CRUD operation. For READ and DELETE operations, the fieldset automatically opens to provide\n   * immediate access to information, while CREATE and UPDATE operations keep it closed to maintain\n   * a clean initial interface. The method directly manipulates the DOM to ensure proper accordion\n   * synchronization and triggers change detection to reflect the programmatic state changes.\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as Angular Lifecycle\n   *   participant F as FieldsetComponent\n   *   participant D as DOM\n   *   participant C as ChangeDetector\n   *\n   *   A->>F: ngAfterViewInit()\n   *   alt operation is READ or DELETE\n   *     F->>F: Set isOpen = true\n   *     F->>D: Query ion-accordion-group element\n   *     alt accordion element exists\n   *       F->>D: Set value attribute to 'open'\n   *     end\n   *   end\n   *   F->>C: detectChanges()\n   *   C->>F: Update view with new state\n   *\n   * @returns {void}\n   * @memberOf FieldsetComponent\n   */\n  ngAfterViewInit(): void {\n    if (this.operation === OperationKeys.READ || this.operation === OperationKeys.DELETE) {\n      this.isOpen = true;\n      const accordionElement = this.component?.nativeElement.querySelector('ion-accordion-group');\n      if(accordionElement)\n        accordionElement.setAttribute('value', 'open');\n    }\n    this.changeDetectorRef.detectChanges();\n  }\n\n  /**\n   * @description Handles accordion state change events from user interactions.\n   * @summary Processes CustomEvent objects triggered when users expand or collapse the accordion.\n   * This method extracts the new state from the event details and updates the component's\n   * internal state accordingly. It specifically listens for ION-ACCORDION-GROUP events to\n   * ensure proper event source validation and prevent handling of unrelated events.\n   *\n   * @param {CustomEvent} event - The event object containing accordion state change details\n   * @returns {void}\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant U as User\n   *   participant I as Ion-Accordion\n   *   participant F as FieldsetComponent\n   *\n   *   U->>I: Click accordion header\n   *   I->>F: handleChange(CustomEvent)\n   *   F->>F: Extract target and detail from event\n   *   F->>F: Validate target is ION-ACCORDION-GROUP\n   *   alt valid target\n   *     F->>F: Update isOpen = !!value\n   *   end\n   *   F->>I: Reflect updated state\n   *\n   * @memberOf FieldsetComponent\n   */\n  handleChange(event: CustomEvent): void {\n    const { target, detail } = event;\n    const { value } = detail;\n    if ((target as HTMLIonAccordionGroupElement).tagName === 'ION-ACCORDION-GROUP')\n      this.isOpen = !!value;\n  }\n}\n","<fieldset [class]=\"'dcf-fieldset ' + operation\" #component>\n  <ion-accordion-group (ionChange)=\"handleChange($event)\">\n    <ion-accordion value=\"open\">\n      <ion-item slot=\"header\" >\n        <legend>{{ name }}</legend>\n      </ion-item>\n      <div slot=\"content\" [attr.aria-hidden]=\"!isOpen\" decafCollapsable>\n        <ng-content></ng-content>\n      </div>\n    </ion-accordion>\n  </ion-accordion-group>\n</fieldset>\n"]}
|
|
236
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(FieldsetComponent, [{
|
|
237
|
+
type: Component,
|
|
238
|
+
args: [{ standalone: true, selector: 'ngx-decaf-fieldset', schemas: [CUSTOM_ELEMENTS_SCHEMA], imports: [ForAngularModule, IonAccordionGroup, IonAccordion, IonItem, CollapsableDirective], template: "<fieldset [class]=\"'dcf-fieldset ' + operation\" #component>\n <ion-accordion-group (ionChange)=\"handleChange($event)\">\n <ion-accordion value=\"open\">\n <ion-item slot=\"header\" >\n <legend>{{ name }}</legend>\n </ion-item>\n <div slot=\"content\" [attr.aria-hidden]=\"!isOpen\" decafCollapsable>\n <ng-content></ng-content>\n </div>\n </ion-accordion>\n </ion-accordion-group>\n</fieldset>\n", styles: [".dcf-fieldset{margin-bottom:1.8rem;padding-bottom:0;padding-top:1rem;border:1px solid var(--ion-color-gray-2);border-radius:8px}.dcf-fieldset ion-accordion-group{--border-color:red !important}.dcf-fieldset.read{margin-top:1.25rem}.dcf-fieldset ion-accordion.accordion-collapsing,.dcf-fieldset ion-accordion.accordion-collapsed{margin-bottom:1rem}.dcf-fieldset ion-accordion ion-item[slot=header]{--border-color: transparent;--border-radius: 6px;--inner-border-width: 0;--padding-start: 12px}.dcf-fieldset ion-accordion ion-item[slot=header] legend{font-weight:600;font-size:1rem;color:#333;margin:0}.dcf-fieldset ion-accordion [slot=content]{padding-top:1rem!important;padding-inline:.75rem;background-color:#fff}\n"] }]
|
|
239
|
+
}], null, { component: [{
|
|
240
|
+
type: ViewChild,
|
|
241
|
+
args: ['component', { static: false, read: ElementRef }]
|
|
242
|
+
}], name: [{
|
|
243
|
+
type: Input
|
|
244
|
+
}], operation: [{
|
|
245
|
+
type: Input
|
|
246
|
+
}], target: [{
|
|
247
|
+
type: Input
|
|
248
|
+
}] }); })();
|
|
249
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(FieldsetComponent, { className: "FieldsetComponent", filePath: "components/fieldset/fieldset.component.ts", lineNumber: 68 }); })();
|
|
250
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fieldset.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/fieldset/fieldset.component.ts","../../../../../src/lib/components/fieldset/fieldset.component.html"],"names":[],"mappings":"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","sourcesContent":["\nimport { AfterViewInit, ChangeDetectorRef, Component, CUSTOM_ELEMENTS_SCHEMA, ElementRef, inject, Input, ViewChild } from '@angular/core';\nimport { Dynamic, HTMLFormTarget } from '../../engine';\nimport { CrudOperations, OperationKeys } from '@decaf-ts/db-decorators';\nimport { ForAngularModule } from '../../for-angular.module';\nimport { CollapsableDirective } from '../../directives/collapsable.directive';\nimport { IonAccordion, IonAccordionGroup, IonItem } from '@ionic/angular/standalone';\n\n/**\n * @description Dynamic fieldset component with collapsible accordion functionality.\n * @summary This component provides a sophisticated fieldset container that automatically\n * adapts its behavior based on CRUD operations. It integrates seamlessly with Ionic's\n * accordion components to create expandable/collapsible sections for organizing form\n * content and related information. The component intelligently determines its initial\n * state based on the operation type, opening automatically for READ and DELETE operations\n * while remaining closed for CREATE and UPDATE operations.\n *\n * @example\n * ```html\n * <!-- Basic usage with automatic state management -->\n * <ngx-decaf-fieldset\n *   name=\"Personal Information\"\n *   [operation]=\"OperationKeys.READ\"\n *   target=\"_self\">\n *   <ion-input label=\"Name\" placeholder=\"Enter name\"></ion-input>\n *   <ion-input label=\"Email\" type=\"email\" placeholder=\"Enter email\"></ion-input>\n * </ngx-decaf-fieldset>\n *\n * <!-- Advanced usage with custom operation -->\n * <ngx-decaf-fieldset\n *   name=\"Contact Details\"\n *   [operation]=\"currentOperation\"\n *   target=\"_blank\">\n *   <!-- Complex form fields -->\n * </ngx-decaf-fieldset>\n * ```\n *\n * @mermaid\n * sequenceDiagram\n *   participant U as User\n *   participant F as FieldsetComponent\n *   participant I as Ionic Accordion\n *   participant D as DOM\n *\n *   F->>F: ngAfterViewInit()\n *   alt operation is READ or DELETE\n *     F->>F: Set isOpen = true\n *     F->>D: Query accordion element\n *     F->>I: Set value attribute to 'open'\n *     F->>F: Trigger change detection\n *   end\n *   U->>I: Click accordion header\n *   I->>F: handleChange(event)\n *   F->>F: Update isOpen state\n *   F->>I: Reflect new state\n *\n * @memberOf ForAngularModule\n */\n@Dynamic()\n@Component({\n  standalone: true,\n  selector: 'ngx-decaf-fieldset',\n  templateUrl: './fieldset.component.html',\n  styleUrls: ['./fieldset.component.scss'],\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\n  imports: [ForAngularModule, IonAccordionGroup, IonAccordion, IonItem, CollapsableDirective],\n})\nexport class FieldsetComponent implements AfterViewInit {\n\n  /**\n   * @description Reference to the component's native DOM element.\n   * @summary ViewChild reference that provides direct access to the component's root DOM element.\n   * This is essential for manipulating the Ionic accordion group after view initialization,\n   * particularly for setting the initial open state programmatically. The reference is used\n   * to query and modify accordion attributes that control the component's expanded state.\n   *\n   * @type {ElementRef}\n   * @memberOf FieldsetComponent\n   */\n  @ViewChild('component', { static: false, read: ElementRef })\n  component!: ElementRef;\n\n  /**\n   * @description The display name or title of the fieldset section.\n   * @summary Sets the legend or header text that appears in the accordion header. This text\n   * provides a clear label for the collapsible section, helping users understand what content\n   * is contained within. The name is displayed prominently and serves as the clickable area\n   * for expanding/collapsing the fieldset.\n   *\n   * @type {string}\n   * @default 'Child'\n   * @memberOf FieldsetComponent\n   */\n  @Input()\n  name: string = 'Child';\n\n  /**\n   * @description The current CRUD operation context.\n   * @summary Determines the component's initial behavior and state based on the current operation.\n   * This input is crucial for auto-state management: READ and DELETE operations automatically\n   * open the fieldset to show content, while CREATE and UPDATE operations keep it closed\n   * initially. This provides an intuitive user experience aligned with operation semantics.\n   *\n   * @type {OperationKeys}\n   * @default OperationKeys.READ\n   * @memberOf FieldsetComponent\n   */\n  @Input()\n  operation: OperationKeys = OperationKeys.READ;\n\n  /**\n   * @description Form target attribute for nested form submissions.\n   * @summary Specifies where to display the response after submitting forms contained within\n   * the fieldset. This attribute mirrors the HTML form target behavior, allowing control over\n   * whether form submissions open in the same window, new window, or specific frame. Useful\n   * for complex form workflows and multi-step processes.\n   *\n   * @type {HTMLFormTarget}\n   * @default '_self'\n   * @memberOf FieldsetComponent\n   */\n  @Input()\n  target: HTMLFormTarget = '_self';\n\n  /**\n   * @description Current state of the accordion (expanded or collapsed).\n   * @summary Boolean flag that tracks whether the fieldset accordion is currently open or closed.\n   * This property is automatically managed based on user interactions and initial operation state.\n   * It serves as the single source of truth for the component's visibility state and is used\n   * to coordinate between user actions and programmatic state changes.\n   *\n   * @type {boolean}\n   * @default false\n   * @memberOf FieldsetComponent\n   */\n  isOpen: boolean = false;\n\n  /**\n   * @description Reference to CRUD operation constants for template usage.\n   * @summary Exposes the OperationKeys enum to the component template, enabling conditional\n   * rendering and behavior based on operation types. This protected readonly property ensures\n   * that template logic can access operation constants while maintaining encapsulation and\n   * preventing accidental modification of the enum values.\n   *\n   * @type {CrudOperations}\n   * @default OperationKeys.CREATE\n   * @memberOf FieldsetComponent\n   */\n  protected readonly OperationKeys: CrudOperations = OperationKeys.CREATE;\n\n  /**\n   * @description Angular change detection service.\n   * @summary Injected service that provides manual control over change detection cycles.\n   * This is essential for ensuring that programmatic DOM changes (like setting accordion\n   * attributes) are properly reflected in the component's state and trigger appropriate\n   * view updates when modifications occur outside the normal Angular change detection flow.\n   *\n   * @private\n   * @type {ChangeDetectorRef}\n   * @memberOf FieldsetComponent\n   */\n  private changeDetectorRef: ChangeDetectorRef = inject(ChangeDetectorRef);\n\n  /**\n   * @description Initializes the component state after view and child components are rendered.\n   * @summary This lifecycle hook implements intelligent auto-state management based on the current\n   * CRUD operation. For READ and DELETE operations, the fieldset automatically opens to provide\n   * immediate access to information, while CREATE and UPDATE operations keep it closed to maintain\n   * a clean initial interface. The method directly manipulates the DOM to ensure proper accordion\n   * synchronization and triggers change detection to reflect the programmatic state changes.\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as Angular Lifecycle\n   *   participant F as FieldsetComponent\n   *   participant D as DOM\n   *   participant C as ChangeDetector\n   *\n   *   A->>F: ngAfterViewInit()\n   *   alt operation is READ or DELETE\n   *     F->>F: Set isOpen = true\n   *     F->>D: Query ion-accordion-group element\n   *     alt accordion element exists\n   *       F->>D: Set value attribute to 'open'\n   *     end\n   *   end\n   *   F->>C: detectChanges()\n   *   C->>F: Update view with new state\n   *\n   * @returns {void}\n   * @memberOf FieldsetComponent\n   */\n  ngAfterViewInit(): void {\n    if (this.operation === OperationKeys.READ || this.operation === OperationKeys.DELETE) {\n      this.isOpen = true;\n      const accordionElement = this.component?.nativeElement.querySelector('ion-accordion-group');\n      if(accordionElement)\n        accordionElement.setAttribute('value', 'open');\n    }\n    this.changeDetectorRef.detectChanges();\n  }\n\n  /**\n   * @description Handles accordion state change events from user interactions.\n   * @summary Processes CustomEvent objects triggered when users expand or collapse the accordion.\n   * This method extracts the new state from the event details and updates the component's\n   * internal state accordingly. It specifically listens for ION-ACCORDION-GROUP events to\n   * ensure proper event source validation and prevent handling of unrelated events.\n   *\n   * @param {CustomEvent} event - The event object containing accordion state change details\n   * @returns {void}\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant U as User\n   *   participant I as Ion-Accordion\n   *   participant F as FieldsetComponent\n   *\n   *   U->>I: Click accordion header\n   *   I->>F: handleChange(CustomEvent)\n   *   F->>F: Extract target and detail from event\n   *   F->>F: Validate target is ION-ACCORDION-GROUP\n   *   alt valid target\n   *     F->>F: Update isOpen = !!value\n   *   end\n   *   F->>I: Reflect updated state\n   *\n   * @memberOf FieldsetComponent\n   */\n  handleChange(event: CustomEvent): void {\n    const { target, detail } = event;\n    const { value } = detail;\n    if ((target as HTMLIonAccordionGroupElement).tagName === 'ION-ACCORDION-GROUP')\n      this.isOpen = !!value;\n  }\n}\n","<fieldset [class]=\"'dcf-fieldset ' + operation\" #component>\n  <ion-accordion-group (ionChange)=\"handleChange($event)\">\n    <ion-accordion value=\"open\">\n      <ion-item slot=\"header\" >\n        <legend>{{ name }}</legend>\n      </ion-item>\n      <div slot=\"content\" [attr.aria-hidden]=\"!isOpen\" decafCollapsable>\n        <ng-content></ng-content>\n      </div>\n    </ion-accordion>\n  </ion-accordion-group>\n</fieldset>\n"]}
|