master-control 0.4.82 → 0.4.84
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/annuity-calculator-radio/annuity-calculator-radio.component.mjs +2 -2
- package/esm2022/lib/annuity-premium-calculator/annuity-premium-calculator.component.mjs +10 -2
- package/esm2022/lib/medial-questions/medial-questions.component.mjs +10 -4
- package/esm2022/lib/textbox/textbox.component.mjs +3 -3
- package/fesm2022/master-control.mjs +21 -7
- package/fesm2022/master-control.mjs.map +1 -1
- package/lib/medial-questions/medial-questions.component.d.ts +1 -0
- package/master-control-0.4.84.tgz +0 -0
- package/package.json +1 -1
- package/master-control-0.4.82.tgz +0 -0
|
@@ -55,7 +55,7 @@ export class AnnuityCalculatorRadioComponent {
|
|
|
55
55
|
}
|
|
56
56
|
updateArrowPosition() {
|
|
57
57
|
const root = this.el.nativeElement;
|
|
58
|
-
const selected = root.querySelector('.radio-card-gender.selected');
|
|
58
|
+
const selected = root.querySelector('.annuity-radio-card-gender.selected');
|
|
59
59
|
const card = root.querySelector('.acr-card');
|
|
60
60
|
if (selected && card) {
|
|
61
61
|
const selectedRect = selected.getBoundingClientRect();
|
|
@@ -88,4 +88,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
88
88
|
}], growthRateChange: [{
|
|
89
89
|
type: Output
|
|
90
90
|
}] } });
|
|
91
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"annuity-calculator-radio.component.js","sourceRoot":"","sources":["../../../../../projects/master-control/src/lib/annuity-calculator-radio/annuity-calculator-radio.component.ts","../../../../../projects/master-control/src/lib/annuity-calculator-radio/annuity-calculator-radio.component.html"],"names":[],"mappings":"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","sourcesContent":["\nimport { Component, Input, Output, EventEmitter, forwardRef, input, ElementRef } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, ReactiveFormsModule, FormsModule } from '@angular/forms';\nimport { CommonModule } from '@angular/common';\nimport { MatRadioModule, MatRadioChange } from '@angular/material/radio';\n@Component({\n  selector: 'lib-annuity-calculator-radio',\n  templateUrl: './annuity-calculator-radio.component.html',\n  styleUrls: ['./annuity-calculator-radio.component.css'],\n  imports: [CommonModule, MatRadioModule, ReactiveFormsModule,\n    FormsModule],\n  standalone: true,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => AnnuityCalculatorRadioComponent),\n      multi: true\n    }\n  ]\n})\nexport class AnnuityCalculatorRadioComponent implements ControlValueAccessor {\n  constructor(private el: ElementRef) {}\n   reactiveFormControlobject : any = input<any>();\n  field : any = input.required<any>();\n  inputValue: any = null;\n\n  onChange: any = () => {};\n  onTouched: any = () => {};\n\n  @Output() change = new EventEmitter<any>();\n\n  @Output() growthRateChange = new EventEmitter<any>();\n\n  value: any = null;\n\n  writeValue(value: any): void {\n    this.value = value;\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  selectCard(card: any): void {\n    if (card.disabled) return;\n    this.value = card.value;\n    this.onChange(this.value);\n    this.onTouched();\n    this.growthRateChange.emit(card);\n  }\n  onRadioGroupChange(event: MatRadioChange): void {\n    const newValue = event.value;\n    this.inputValue = newValue;\n    this.onChange(newValue);\n    this.onTouched();\n    this.change.emit(newValue);\n    console.log('Radio group changed:', newValue);\n    setTimeout(() => this.updateArrowPosition(), 0);\n  }\n  toggleRadio(value: any, event: Event): void {\n    event.preventDefault();\n    event.stopPropagation();\n    this.inputValue = value;\n    if (this.reactiveFormControlobject && this.reactiveFormControlobject.setValue) {\n      this.reactiveFormControlobject.setValue(value);\n    }\n    this.onRadioGroupChange({ source: {} as any, value: value });\n    setTimeout(() => this.updateArrowPosition(), 0);\n  }\n\n  private updateArrowPosition(): void {\n    const root = this.el.nativeElement;\n    const selected: HTMLElement = root.querySelector('.radio-card-gender.selected');\n    const card: HTMLElement = root.querySelector('.acr-card');\n    if (selected && card) {\n      const selectedRect = selected.getBoundingClientRect();\n      const cardRect = card.getBoundingClientRect();\n      const centerX = selectedRect.left + selectedRect.width / 2 - cardRect.left;\n      card.style.setProperty('--arrow-left', `${centerX}px`);\n    }\n  }\n\n}\n","\n\n<div class=\"acr-wrapper\">\n\n  <!-- Top Header Label -->\n  <div class=\"acr-sub-label\" *ngIf=\"field() && field()?.isVisible\">\n    {{ field()?.label }}\n    <span class=\"error-message\" *ngIf=\"field()?.validators?.isRequired\">*</span>\n  </div>\n\n  <!-- Radio Option Cards -->\n  <div class=\"radio-btn-group1\" *ngIf=\"field()?.configData?.isShowRadioOption\">\n    <div\n      class=\"annuity-radio-card-gender\"\n      *ngFor=\"let data of field()?.options\"\n      [class.selected]=\"inputValue === data.value\"\n      [class.disable-radio-btn]=\"field()?.isDisable || data.disabled === true || data.disabled === 'true'\"\n      (click)=\"(data.disabled === true || data.disabled === 'true') ? null : toggleRadio(data.value, $event)\"\n    >\n      <!-- Hidden native radio input — enables proper [id]/[name] binding for form semantics.\n           Parent projects can bind (change)=\"myHandler($event)\" on the host component. -->\n      <input\n        type=\"radio\"\n        style=\"position: absolute; opacity: 0; width: 0; height: 0; pointer-events: none;\"\n        [id]=\"field()?.fieldName\"\n        [name]=\"field()?.fieldName\"\n        [value]=\"data.value\"\n        [checked]=\"inputValue === data.value\"\n        (growthRateChange)=\"toggleRadio(data.value, $event)\"\n      />\n      <span\n        class=\"forRadioLabelAnnuityRadio\"\n        [ngStyle]=\"{\n          '--radio-button-font-weight': field()?.controlStyle?.fontWeight,\n          '--radio-button-font-size': field()?.controlStyle?.fontSize,\n          '--radio-button-font-color': field()?.controlStyle?.color\n        }\"\n      >{{ data.label }}</span>\n    </div>\n  </div>\n\n  <!-- Card Container -->\n  <div class=\"acr-card-container\" *ngIf=\"field()?.configData?.isShowCard\">\n\n    <div class=\"acr-card\">\n    <div class=\"acr-sub-label\" *ngIf=\"field()?.configData?.subLabel\">\n      {{ field()?.configData?.subLabel }}\n    </div>\n\n    <div class=\"acr-cards-row\">\n      <div\n        class=\"acr-card-option\"\n        *ngFor=\"let card of field()?.configData?.cardsValue\"\n        [class.selected]=\"value === card.value\"\n        [class.disabled]=\"card.disabled\"\n        (click)=\"selectCard(card)\"\n      >\n        <!-- Hidden native radio input — enables proper [id]/[name] binding for form semantics. -->\n        <input\n          type=\"radio\"\n          style=\"position: absolute; opacity: 0; width: 0; height: 0; pointer-events: none;\"\n          [id]=\"field()?.fieldName\"\n          [name]=\"field()?.fieldName\"\n          [value]=\"card.value\"\n          [checked]=\"value === card.value\"\n          (change)=\"selectCard(card)\"\n        />\n        <div class=\"acr-card-main-value\" [innerHTML]=\"card.mainValue\"></div>\n        <div class=\"acr-card-sub-value\" [innerHTML]=\"card.subValue\"></div>\n        <div class=\"acr-card-rate\">{{ card.growthRate }}</div>\n        <div class=\"acr-card-details\">\n          <div class=\"acr-card-detail-row\">\n            <span>Guaranteed </span>\n            <span>:</span>\n            <strong>{{ card.guaranteed }}</strong>\n          </div>\n          <div class=\"acr-card-detail-row\">\n            <span>Variable </span>\n            <span>:</span>\n            <strong>{{ card.variable }}</strong>\n          </div>\n        </div>\n        <div class=\"acr-card-type\">\n          <button class=\"acr-card-type-btn\" [ngClass]=\"{\n      'btn-high': card.value === 'High',\n      'btn-medium': card.value === 'Medium',\n      'btn-low': card.value !== 'High' && card.value !== 'Medium'\n    }\">{{ card.value }} variable</button>\n        </div>\n      </div>\n    </div>\n     <!-- Note — full width, vertically aligned with radio group and card container -->\n  <div class=\"acr-note\" *ngIf=\"field()?.configData?.infoMessage\">\n    <strong>Note:</strong> {{ field()?.configData?.infoMessage }}\n  </div>\n  </div>\n  </div><!-- /acr-card-container -->\n\n</div>\n"]}
|
|
91
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"annuity-calculator-radio.component.js","sourceRoot":"","sources":["../../../../../projects/master-control/src/lib/annuity-calculator-radio/annuity-calculator-radio.component.ts","../../../../../projects/master-control/src/lib/annuity-calculator-radio/annuity-calculator-radio.component.html"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAS,MAAM,EAAE,YAAY,EAAE,UAAU,EAAE,KAAK,EAAc,MAAM,eAAe,CAAC;AACtG,OAAO,EAAwB,iBAAiB,EAAE,mBAAmB,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC3G,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,cAAc,EAAkB,MAAM,yBAAyB,CAAC;;;AAgBzE,MAAM,OAAO,+BAA+B;IACtB;IAApB,YAAoB,EAAc;QAAd,OAAE,GAAF,EAAE,CAAY;IAAG,CAAC;IACrC,yBAAyB,GAAS,KAAK,EAAO,CAAC;IAChD,KAAK,GAAS,KAAK,CAAC,QAAQ,EAAO,CAAC;IACpC,UAAU,GAAQ,IAAI,CAAC;IAEvB,QAAQ,GAAQ,GAAG,EAAE,GAAE,CAAC,CAAC;IACzB,SAAS,GAAQ,GAAG,EAAE,GAAE,CAAC,CAAC;IAEhB,MAAM,GAAG,IAAI,YAAY,EAAO,CAAC;IAEjC,gBAAgB,GAAG,IAAI,YAAY,EAAO,CAAC;IAErD,KAAK,GAAQ,IAAI,CAAC;IAElB,UAAU,CAAC,KAAU;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IAED,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAED,UAAU,CAAC,IAAS;QAClB,IAAI,IAAI,CAAC,QAAQ;YAAE,OAAO;QAC1B,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;QACxB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1B,IAAI,CAAC,SAAS,EAAE,CAAC;QACjB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACnC,CAAC;IACD,kBAAkB,CAAC,KAAqB;QACtC,MAAM,QAAQ,GAAG,KAAK,CAAC,KAAK,CAAC;QAC7B,IAAI,CAAC,UAAU,GAAG,QAAQ,CAAC;QAC3B,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;QACxB,IAAI,CAAC,SAAS,EAAE,CAAC;QACjB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC3B,OAAO,CAAC,GAAG,CAAC,sBAAsB,EAAE,QAAQ,CAAC,CAAC;QAC9C,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,mBAAmB,EAAE,EAAE,CAAC,CAAC,CAAC;IAClD,CAAC;IACD,WAAW,CAAC,KAAU,EAAE,KAAY;QAClC,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,IAAI,CAAC,yBAAyB,IAAI,IAAI,CAAC,yBAAyB,CAAC,QAAQ,EAAE,CAAC;YAC9E,IAAI,CAAC,yBAAyB,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACjD,CAAC;QACD,IAAI,CAAC,kBAAkB,CAAC,EAAE,MAAM,EAAE,EAAS,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC;QAC7D,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,mBAAmB,EAAE,EAAE,CAAC,CAAC,CAAC;IAClD,CAAC;IAEO,mBAAmB;QACzB,MAAM,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC;QACnC,MAAM,QAAQ,GAAgB,IAAI,CAAC,aAAa,CAAC,qCAAqC,CAAC,CAAC;QACxF,MAAM,IAAI,GAAgB,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC;QAC1D,IAAI,QAAQ,IAAI,IAAI,EAAE,CAAC;YACrB,MAAM,YAAY,GAAG,QAAQ,CAAC,qBAAqB,EAAE,CAAC;YACtD,MAAM,QAAQ,GAAG,IAAI,CAAC,qBAAqB,EAAE,CAAC;YAC9C,MAAM,OAAO,GAAG,YAAY,CAAC,IAAI,GAAG,YAAY,CAAC,KAAK,GAAG,CAAC,GAAG,QAAQ,CAAC,IAAI,CAAC;YAC3E,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,cAAc,EAAE,GAAG,OAAO,IAAI,CAAC,CAAC;QACzD,CAAC;IACH,CAAC;wGAhEU,+BAA+B;4FAA/B,+BAA+B,ucAR/B;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,+BAA+B,CAAC;gBAC9D,KAAK,EAAE,IAAI;aACZ;SACF,0BClBH,y5HAmGA,ghJD1FY,YAAY,kbAAE,cAAc,8BAAE,mBAAmB,8BACzD,WAAW;;4FAUF,+BAA+B;kBAf3C,SAAS;+BACE,8BAA8B,WAG/B,CAAC,YAAY,EAAE,cAAc,EAAE,mBAAmB;wBACzD,WAAW,CAAC,cACF,IAAI,aACL;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,gCAAgC,CAAC;4BAC9D,KAAK,EAAE,IAAI;yBACZ;qBACF;+EAWS,MAAM;sBAAf,MAAM;gBAEG,gBAAgB;sBAAzB,MAAM","sourcesContent":["\nimport { Component, Input, Output, EventEmitter, forwardRef, input, ElementRef } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, ReactiveFormsModule, FormsModule } from '@angular/forms';\nimport { CommonModule } from '@angular/common';\nimport { MatRadioModule, MatRadioChange } from '@angular/material/radio';\n@Component({\n  selector: 'lib-annuity-calculator-radio',\n  templateUrl: './annuity-calculator-radio.component.html',\n  styleUrls: ['./annuity-calculator-radio.component.css'],\n  imports: [CommonModule, MatRadioModule, ReactiveFormsModule,\n    FormsModule],\n  standalone: true,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => AnnuityCalculatorRadioComponent),\n      multi: true\n    }\n  ]\n})\nexport class AnnuityCalculatorRadioComponent implements ControlValueAccessor {\n  constructor(private el: ElementRef) {}\n   reactiveFormControlobject : any = input<any>();\n  field : any = input.required<any>();\n  inputValue: any = null;\n\n  onChange: any = () => {};\n  onTouched: any = () => {};\n\n  @Output() change = new EventEmitter<any>();\n\n  @Output() growthRateChange = new EventEmitter<any>();\n\n  value: any = null;\n\n  writeValue(value: any): void {\n    this.value = value;\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  selectCard(card: any): void {\n    if (card.disabled) return;\n    this.value = card.value;\n    this.onChange(this.value);\n    this.onTouched();\n    this.growthRateChange.emit(card);\n  }\n  onRadioGroupChange(event: MatRadioChange): void {\n    const newValue = event.value;\n    this.inputValue = newValue;\n    this.onChange(newValue);\n    this.onTouched();\n    this.change.emit(newValue);\n    console.log('Radio group changed:', newValue);\n    setTimeout(() => this.updateArrowPosition(), 0);\n  }\n  toggleRadio(value: any, event: Event): void {\n    event.preventDefault();\n    event.stopPropagation();\n    this.inputValue = value;\n    if (this.reactiveFormControlobject && this.reactiveFormControlobject.setValue) {\n      this.reactiveFormControlobject.setValue(value);\n    }\n    this.onRadioGroupChange({ source: {} as any, value: value });\n    setTimeout(() => this.updateArrowPosition(), 0);\n  }\n\n  private updateArrowPosition(): void {\n    const root = this.el.nativeElement;\n    const selected: HTMLElement = root.querySelector('.annuity-radio-card-gender.selected');\n    const card: HTMLElement = root.querySelector('.acr-card');\n    if (selected && card) {\n      const selectedRect = selected.getBoundingClientRect();\n      const cardRect = card.getBoundingClientRect();\n      const centerX = selectedRect.left + selectedRect.width / 2 - cardRect.left;\n      card.style.setProperty('--arrow-left', `${centerX}px`);\n    }\n  }\n\n}\n","\n\n<div class=\"acr-wrapper\">\n\n  <!-- Top Header Label -->\n  <div class=\"acr-sub-label\" *ngIf=\"field() && field()?.isVisible\">\n    {{ field()?.label }}\n    <span class=\"error-message\" *ngIf=\"field()?.validators?.isRequired\">*</span>\n  </div>\n\n  <!-- Radio Option Cards -->\n  <div class=\"radio-btn-group1\" *ngIf=\"field()?.configData?.isShowRadioOption\">\n    <div\n      class=\"annuity-radio-card-gender\"\n      *ngFor=\"let data of field()?.options\"\n      [class.selected]=\"inputValue === data.value\"\n      [class.disable-radio-btn]=\"field()?.isDisable || data.disabled === true || data.disabled === 'true'\"\n      (click)=\"(data.disabled === true || data.disabled === 'true') ? null : toggleRadio(data.value, $event)\"\n    >\n      <!-- Hidden native radio input — enables proper [id]/[name] binding for form semantics.\n           Parent projects can bind (change)=\"myHandler($event)\" on the host component. -->\n      <input\n        type=\"radio\"\n        style=\"position: absolute; opacity: 0; width: 0; height: 0; pointer-events: none;\"\n        [id]=\"field()?.fieldName\"\n        [name]=\"field()?.fieldName\"\n        [value]=\"data.value\"\n        [checked]=\"inputValue === data.value\"\n        (growthRateChange)=\"toggleRadio(data.value, $event)\"\n      />\n      <span\n        class=\"forRadioLabelAnnuityRadio\"\n        [ngStyle]=\"{\n          '--radio-button-font-weight': field()?.controlStyle?.fontWeight,\n          '--radio-button-font-size': field()?.controlStyle?.fontSize,\n          '--radio-button-font-color': field()?.controlStyle?.color\n        }\"\n      >{{ data.label }}</span>\n    </div>\n  </div>\n\n  <!-- Card Container -->\n  <div class=\"acr-card-container\" *ngIf=\"field()?.configData?.isShowCard\">\n\n    <div class=\"acr-card\">\n    <div class=\"acr-sub-label\" *ngIf=\"field()?.configData?.subLabel\">\n      {{ field()?.configData?.subLabel }}\n    </div>\n\n    <div class=\"acr-cards-row\">\n      <div\n        class=\"acr-card-option\"\n        *ngFor=\"let card of field()?.configData?.cardsValue\"\n        [class.selected]=\"value === card.value\"\n        [class.disabled]=\"card.disabled\"\n        (click)=\"selectCard(card)\"\n      >\n        <!-- Hidden native radio input — enables proper [id]/[name] binding for form semantics. -->\n        <input\n          type=\"radio\"\n          style=\"position: absolute; opacity: 0; width: 0; height: 0; pointer-events: none;\"\n          [id]=\"field()?.fieldName\"\n          [name]=\"field()?.fieldName\"\n          [value]=\"card.value\"\n          [checked]=\"value === card.value\"\n          (change)=\"selectCard(card)\"\n        />\n        <div class=\"acr-card-main-value\" [innerHTML]=\"card.mainValue\"></div>\n        <div class=\"acr-card-sub-value\" [innerHTML]=\"card.subValue\"></div>\n        <div class=\"acr-card-rate\">{{ card.growthRate }}</div>\n        <div class=\"acr-card-details\">\n          <div class=\"acr-card-detail-row\">\n            <span>Guaranteed </span>\n            <span>:</span>\n            <strong>{{ card.guaranteed }}</strong>\n          </div>\n          <div class=\"acr-card-detail-row\">\n            <span>Variable </span>\n            <span>:</span>\n            <strong>{{ card.variable }}</strong>\n          </div>\n        </div>\n        <div class=\"acr-card-type\">\n          <button class=\"acr-card-type-btn\" [ngClass]=\"{\n      'btn-high': card.value === 'High',\n      'btn-medium': card.value === 'Medium',\n      'btn-low': card.value !== 'High' && card.value !== 'Medium'\n    }\">{{ card.value }} variable</button>\n        </div>\n      </div>\n    </div>\n     <!-- Note — full width, vertically aligned with radio group and card container -->\n  <div class=\"acr-note\" *ngIf=\"field()?.configData?.infoMessage\">\n    <strong>Note:</strong> {{ field()?.configData?.infoMessage }}\n  </div>\n  </div>\n  </div><!-- /acr-card-container -->\n\n</div>\n"]}
|