@cqa-lib/cqa-ui 1.1.508 → 1.1.509
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/esm2020/lib/ai-prompt-card/ai-prompt-card.component.mjs +3 -1
- package/esm2020/lib/sub-steps-confirmation-dialog/sub-steps-confirmation-dialog.component.mjs +94 -31
- package/fesm2015/cqa-lib-cqa-ui.mjs +95 -31
- package/fesm2015/cqa-lib-cqa-ui.mjs.map +1 -1
- package/fesm2020/cqa-lib-cqa-ui.mjs +94 -29
- package/fesm2020/cqa-lib-cqa-ui.mjs.map +1 -1
- package/lib/ai-prompt-card/ai-prompt-card.component.d.ts +1 -1
- package/lib/sub-steps-confirmation-dialog/sub-steps-confirmation-dialog.component.d.ts +72 -11
- package/package.json +1 -1
- package/styles.css +1 -1
|
@@ -23,6 +23,7 @@ export class AiPromptCardComponent {
|
|
|
23
23
|
case 'edited': return 'Edited';
|
|
24
24
|
case 'duplicated': return 'Duplicated';
|
|
25
25
|
case 'deleted': return 'Deleted';
|
|
26
|
+
case 'converted': return 'Converted';
|
|
26
27
|
default: return '';
|
|
27
28
|
}
|
|
28
29
|
}
|
|
@@ -32,6 +33,7 @@ export class AiPromptCardComponent {
|
|
|
32
33
|
case 'edited': return { bg: '#FFFBEB', text: '#B45309', border: '#FDE68A' };
|
|
33
34
|
case 'duplicated': return { bg: '#EEF2FF', text: '#4338CA', border: '#C7D2FE' };
|
|
34
35
|
case 'deleted': return { bg: '#FEF2F2', text: '#B42318', border: '#FECACA' };
|
|
36
|
+
case 'converted': return { bg: '#CFFAFE', text: '#155E75', border: '#A5F3FC' };
|
|
35
37
|
default: return { bg: '#F3F4F6', text: '#374151', border: '#E5E7EB' };
|
|
36
38
|
}
|
|
37
39
|
}
|
|
@@ -56,4 +58,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
56
58
|
}], operationLabel: [{
|
|
57
59
|
type: Input
|
|
58
60
|
}] } });
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ai-prompt-card.component.js","sourceRoot":"","sources":["../../../../../src/lib/ai-prompt-card/ai-prompt-card.component.ts","../../../../../src/lib/ai-prompt-card/ai-prompt-card.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;;;AASjD,MAAM,OAAO,qBAAqB;IALlC;QAWW,aAAQ,GAAG,KAAK,CAAC;KAsC3B;IAnCC,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC;IAC/C,CAAC;IAED,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC;IAC/C,CAAC;IAED,IAAI,UAAU;QACZ,OAAO,QAAQ,IAAI,CAAC,UAAU,KAAK,CAAC;IACtC,CAAC;IAED,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,SAAS,UAAU,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC;IACzF,CAAC;IAED,IAAI,kBAAkB;QACpB,QAAQ,IAAI,CAAC,cAAc,EAAE;YAC3B,KAAK,SAAS,CAAC,CAAI,OAAO,SAAS,CAAC;YACpC,KAAK,QAAQ,CAAC,CAAK,OAAO,QAAQ,CAAC;YACnC,KAAK,YAAY,CAAC,CAAC,OAAO,YAAY,CAAC;YACvC,KAAK,SAAS,CAAC,CAAI,OAAO,SAAS,CAAC;YACpC,OAAO,CAAC,CAAC,OAAO,EAAE,CAAC;SACpB;IACH,CAAC;IAED,IAAI,oBAAoB;QACtB,QAAQ,IAAI,CAAC,cAAc,EAAE;YAC3B,KAAK,SAAS,CAAC,CAAI,OAAO,EAAE,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;YAChF,KAAK,QAAQ,CAAC,CAAK,OAAO,EAAE,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;YAChF,KAAK,YAAY,CAAC,CAAC,OAAO,EAAE,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;YAChF,KAAK,SAAS,CAAC,CAAI,OAAO,EAAE,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;YAChF,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;SACvE;IACH,CAAC;;kHA3CU,qBAAqB;sGAArB,qBAAqB,0PCTlC,q4PAgDA;2FDvCa,qBAAqB;kBALjC,SAAS;+BACE,oBAAoB;8BAKrB,UAAU;sBAAlB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,cAAc;sBAAtB,KAAK","sourcesContent":["import { Component, Input } from '@angular/core';\n\nexport type AiPromptCardOperation = 'created' | 'edited' | 'duplicated' | 'deleted';\n\n@Component({\n  selector: 'cqa-ai-prompt-card',\n  templateUrl: './ai-prompt-card.component.html',\n  styleUrls: []\n})\nexport class AiPromptCardComponent {\n  @Input() stepNumber!: string;\n  @Input() stepName!: string;\n  @Input() timestamp!: string;\n  @Input() runVersion?: string;\n  @Input() promptText!: string;\n  @Input() isFailed = false;\n  @Input() operationLabel?: AiPromptCardOperation;\n\n  get accentColor(): string {\n    return this.isFailed ? '#FB2C36' : '#3F43EE';\n  }\n\n  get titleColor(): string {\n    return this.isFailed ? '#FB2C36' : '#161617';\n  }\n\n  get stepPrefix(): string {\n    return `Step ${this.stepNumber} — `;\n  }\n\n  get metaLine(): string {\n    return this.runVersion ? `${this.timestamp} · Run ${this.runVersion}` : this.timestamp;\n  }\n\n  get operationBadgeText(): string {\n    switch (this.operationLabel) {\n      case 'created':    return 'Created';\n      case 'edited':     return 'Edited';\n      case 'duplicated': return 'Duplicated';\n      case 'deleted':    return 'Deleted';\n      default: return '';\n    }\n  }\n\n  get operationBadgeColors(): { bg: string; text: string; border: string } {\n    switch (this.operationLabel) {\n      case 'created':    return { bg: '#ECFDF5', text: '#047857', border: '#A7F3D0' };\n      case 'edited':     return { bg: '#FFFBEB', text: '#B45309', border: '#FDE68A' };\n      case 'duplicated': return { bg: '#EEF2FF', text: '#4338CA', border: '#C7D2FE' };\n      case 'deleted':    return { bg: '#FEF2F2', text: '#B42318', border: '#FECACA' };\n      default: return { bg: '#F3F4F6', text: '#374151', border: '#E5E7EB' };\n    }\n  }\n}\n","<div class=\"cqa-ui-root cqa-font-inter\" style=\"display: block; width: 100%;\">\n  <div class=\"cqa-bg-white cqa-rounded-lg cqa-overflow-hidden\"\n    style=\"border: 1px solid #E4E4E499;\">\n\n    <!-- Header section: sparkle icon + step title + meta line -->\n    <div class=\"cqa-flex cqa-items-center cqa-gap-2\" style=\"padding: 6px 12px; border-bottom: 1px solid #E4E4E499;\">\n      <svg class=\"cqa-ai-prompt-card__logo\" width=\"18\" height=\"19\" viewBox=\"0 0 18 19\" fill=\"none\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n        [ngStyle]=\"{ color: accentColor, 'flex-shrink': '0', 'margin-top': '2px' }\">\n        <path d=\"M9.01881 0C9.12979 0.0480032 9.17718 0.165227 9.22261 0.274119C9.24539 0.337566 9.26628 0.401358 9.28657 0.465659C9.29452 0.490298 9.30246 0.514938 9.31065 0.540324C9.41613 0.871899 9.51008 1.20702 9.60457 1.54191C9.62593 1.61751 9.64739 1.69308 9.66885 1.76865C9.7781 2.15341 9.88654 2.5384 9.99438 2.92356C10.0095 2.97765 10.0247 3.03175 10.0398 3.08584C10.0826 3.23834 10.1252 3.39085 10.1677 3.54344C10.2573 3.86586 10.3495 4.18733 10.4476 4.50724C10.4561 4.53523 10.4647 4.56321 10.4735 4.59205C10.7284 5.41499 11.0896 6.15257 11.6818 6.78081C11.6965 6.79715 11.7111 6.81349 11.7262 6.83032C11.979 7.10257 12.3034 7.32071 12.6276 7.49678C12.6441 7.5059 12.6606 7.51501 12.6776 7.5244C13.6317 8.04176 14.779 8.2693 15.8124 8.57217C16.2652 8.70496 16.7166 8.84194 17.1663 8.98495C17.1979 8.99499 17.2296 9.00502 17.2612 9.01503C17.3557 9.04495 17.45 9.07539 17.5442 9.10622C17.5662 9.11323 17.5882 9.12024 17.6108 9.12746C17.7406 9.17079 17.8648 9.22194 17.9713 9.31057C18.0038 9.38216 18.0038 9.38216 17.995 9.45376C17.8913 9.55776 17.7884 9.60653 17.6516 9.6541C17.632 9.66112 17.6124 9.66815 17.5923 9.67538C17.3612 9.7572 17.127 9.8288 16.8925 9.89975C16.8444 9.91442 16.7963 9.9291 16.7482 9.94378C16.4514 10.0341 16.1542 10.1226 15.8566 10.21C15.4646 10.3252 15.0733 10.4423 14.6822 10.5607C14.6182 10.5801 14.5541 10.5994 14.49 10.6187C14.1534 10.7199 13.8185 10.8248 13.4863 10.94C13.4587 10.9495 13.4312 10.959 13.4028 10.9688C12.2902 11.3595 11.4422 12.0884 10.9114 13.1543C10.6253 13.7534 10.4565 14.4012 10.2843 15.0405C10.2377 15.2131 10.1882 15.3846 10.1381 15.5561C10.0988 15.6911 10.0604 15.8262 10.023 15.9617C10.0185 15.9778 10.0141 15.9939 10.0095 16.0106C9.98788 16.0886 9.96638 16.1668 9.94503 16.2449C9.89039 16.443 9.83156 16.6395 9.77111 16.8359C9.66383 17.1849 9.5662 17.5365 9.46917 17.8885C9.32288 18.4185 9.32288 18.4185 9.23993 18.6733C9.23443 18.6904 9.22893 18.7076 9.22326 18.7252C9.19298 18.8159 9.16183 18.8994 9.10453 18.9761C9.01734 18.9955 9.01734 18.9955 8.93901 19C8.84946 18.8682 8.79016 18.7406 8.74265 18.5885C8.73574 18.567 8.72882 18.5454 8.7217 18.5232C8.63368 18.2452 8.55502 17.9644 8.47634 17.6836C8.45832 17.6194 8.44021 17.5552 8.42211 17.4911C8.2872 17.0127 8.15451 16.5337 8.02202 16.0546C7.47014 13.6847 7.47014 13.6847 6.078 11.7687C6.05569 11.7504 6.03338 11.732 6.01039 11.7131C5.09826 10.9757 3.89667 10.7027 2.7963 10.3827C2.52415 10.3035 2.2521 10.224 1.98006 10.1444C1.95628 10.1374 1.95628 10.1374 1.93201 10.1303C1.53962 10.0155 1.14735 9.90032 0.756448 9.78042C0.739911 9.77539 0.723375 9.77035 0.706338 9.76517C0.105798 9.58198 0.105798 9.58198 0.00129307 9.45376C-0.00166252 9.39559 -0.00166252 9.39559 0.0249378 9.33443C0.134167 9.22639 0.240153 9.18012 0.38432 9.13307C0.405194 9.12599 0.426068 9.11891 0.447574 9.11162C0.511506 9.09007 0.575577 9.069 0.639702 9.04805C0.658001 9.04198 0.676301 9.03592 0.695155 9.02968C0.82457 8.98684 0.95445 8.94561 1.08452 8.90485C1.11648 8.8948 1.11648 8.8948 1.14909 8.88454C1.70454 8.71017 2.26361 8.54789 2.82252 8.38525C3.23899 8.26404 3.65476 8.14082 4.06921 8.01269C4.08825 8.00683 4.1073 8.00097 4.12692 7.99493C5.087 7.69914 6.02557 7.27945 6.64547 6.44669C6.65475 6.43434 6.66403 6.42199 6.6736 6.40927C7.36395 5.48498 7.63315 4.36097 7.93391 3.26421C8.03285 2.90351 8.13298 2.54314 8.23345 2.18287C8.26127 2.0831 8.28906 1.98333 8.31673 1.88352C8.42788 1.48261 8.5407 1.08224 8.66 0.683712C8.67116 0.646393 8.68227 0.609057 8.69333 0.571704C8.86035 0.00841829 8.86035 0.00841828 9.01881 0Z\" fill=\"currentColor\"/>\n        <path d=\"M14.4717 1.17245C14.5802 1.29646 14.6019 1.4422 14.6357 1.60054C14.7485 2.09799 14.8783 2.55539 15.3291 2.84435C15.6072 2.99959 15.9386 3.07024 16.2468 3.13696C16.3768 3.16569 16.4867 3.20383 16.5982 3.28009C16.6234 3.32036 16.6234 3.32036 16.6219 3.39046C16.596 3.47572 16.5733 3.50321 16.5051 3.55901C16.4306 3.58419 16.4306 3.58419 16.3411 3.60376C16.3073 3.61161 16.2734 3.61954 16.2396 3.62753C16.2215 3.63178 16.2034 3.63602 16.1847 3.64039C15.6337 3.76904 15.6337 3.76904 15.1574 4.06019C15.1419 4.07277 15.1264 4.08536 15.1105 4.09832C14.7701 4.40129 14.6981 4.90525 14.5956 5.32743C14.5897 5.35062 14.5839 5.3738 14.5778 5.39769C14.5727 5.41822 14.5677 5.43874 14.5624 5.45989C14.5403 5.52256 14.5174 5.56343 14.4717 5.61146C14.3444 5.62777 14.3444 5.62777 14.2825 5.61146C14.1841 5.53443 14.162 5.44669 14.1363 5.3288C14.132 5.31054 14.1277 5.29229 14.1233 5.27348C14.1095 5.21517 14.0962 5.15678 14.083 5.09835C13.9793 4.64335 13.8623 4.19694 13.4488 3.93024C13.1256 3.74834 12.7327 3.66231 12.3715 3.59284C12.2725 3.57204 12.2158 3.54587 12.1545 3.46355C12.1412 3.38002 12.1412 3.38002 12.1545 3.29649C12.2487 3.19808 12.3478 3.17406 12.4752 3.14435C12.5153 3.13432 12.5554 3.12422 12.5955 3.11405C12.6163 3.10883 12.637 3.10361 12.6583 3.09824C12.764 3.07078 12.8686 3.04 12.9732 3.00861C12.9922 3.00305 13.0112 2.99749 13.0308 2.99175C13.2434 2.92759 13.4269 2.84553 13.5968 2.69985C13.6127 2.68669 13.6285 2.67352 13.6449 2.65995C13.9094 2.41969 13.9992 2.05873 14.0808 1.72192C14.087 1.69635 14.0932 1.67078 14.0997 1.64444C14.112 1.59308 14.1242 1.54165 14.1361 1.49018C14.1446 1.45436 14.1446 1.45436 14.1533 1.41782C14.1583 1.39643 14.1633 1.37503 14.1684 1.35298C14.1902 1.28487 14.2188 1.23138 14.2589 1.17245C14.336 1.13356 14.39 1.15114 14.4717 1.17245Z\" fill=\"currentColor\"/>\n        <path d=\"M3.5901 13.1885C3.61823 13.1887 3.61823 13.1887 3.64693 13.1889C3.84874 13.1951 3.9853 13.2604 4.13393 13.3974C4.30688 13.5859 4.38674 13.7987 4.3822 14.0528C4.36277 14.2589 4.24237 14.4388 4.09467 14.5781C3.92083 14.7198 3.74546 14.7666 3.52332 14.76C3.33602 14.738 3.15981 14.6482 3.02706 14.5131C2.86197 14.2857 2.8137 14.0772 2.8379 13.7971C2.88788 13.5766 3.03195 13.3976 3.21621 13.2721C3.34422 13.2066 3.44718 13.1873 3.5901 13.1885Z\" fill=\"currentColor\"/>\n      </svg>\n      <div class=\"cqa-flex cqa-flex-col cqa-flex-1\" style=\"gap: 2px;\">\n        <div class=\"cqa-font-semibold cqa-text-[12px] cqa-flex cqa-items-center\" style=\"gap: 6px;\" [ngStyle]=\"{ color: titleColor }\">\n          <span>{{ stepPrefix }}</span><span class=\"cqa-ai-prompt-card__step-name\" [innerHTML]=\"stepName\"></span>\n          <span *ngIf=\"operationLabel\" class=\"cqa-inline-flex cqa-items-center\"\n            [ngStyle]=\"{\n              'background-color': operationBadgeColors.bg,\n              'color': operationBadgeColors.text,\n              'border': '1px solid ' + operationBadgeColors.border,\n              'border-radius': '10px',\n              'padding': '1px 8px',\n              'font-size': '10px',\n              'font-weight': '600',\n              'line-height': '14px'\n            }\">\n            {{ operationBadgeText }}\n          </span>\n        </div>\n        <div class=\"cqa-text-[11px]\" style=\"color: #99999E;\">\n          {{ metaLine }}\n        </div>\n      </div>\n    </div>\n\n    <!-- Body section: quoted prompt with left accent bar -->\n    <div style=\"padding: 6px 12px;\">\n      <div style=\"background-color: #F7F7FA; padding: 10px 12px;  border-radius: 6px;\"\n      [ngStyle]=\"{ 'border-left': '3px solid ' + accentColor }\">\n      <p class=\"cqa-text-xs cqa-italic cqa-m-0\"\n        style=\"color: #4C4C51; line-height: 20.4px;\">\n        \"<span class=\"cqa-ai-prompt-card__prompt-body\" [innerHTML]=\"promptText\"></span>\"\n      </p>\n    </div>\n    </div>\n  </div>\n</div>\n"]}
|
|
61
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ai-prompt-card.component.js","sourceRoot":"","sources":["../../../../../src/lib/ai-prompt-card/ai-prompt-card.component.ts","../../../../../src/lib/ai-prompt-card/ai-prompt-card.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;;;AASjD,MAAM,OAAO,qBAAqB;IALlC;QAWW,aAAQ,GAAG,KAAK,CAAC;KAwC3B;IArCC,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC;IAC/C,CAAC;IAED,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC;IAC/C,CAAC;IAED,IAAI,UAAU;QACZ,OAAO,QAAQ,IAAI,CAAC,UAAU,KAAK,CAAC;IACtC,CAAC;IAED,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,SAAS,UAAU,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC;IACzF,CAAC;IAED,IAAI,kBAAkB;QACpB,QAAQ,IAAI,CAAC,cAAc,EAAE;YAC3B,KAAK,SAAS,CAAC,CAAI,OAAO,SAAS,CAAC;YACpC,KAAK,QAAQ,CAAC,CAAK,OAAO,QAAQ,CAAC;YACnC,KAAK,YAAY,CAAC,CAAC,OAAO,YAAY,CAAC;YACvC,KAAK,SAAS,CAAC,CAAI,OAAO,SAAS,CAAC;YACpC,KAAK,WAAW,CAAC,CAAE,OAAO,WAAW,CAAC;YACtC,OAAO,CAAC,CAAC,OAAO,EAAE,CAAC;SACpB;IACH,CAAC;IAED,IAAI,oBAAoB;QACtB,QAAQ,IAAI,CAAC,cAAc,EAAE;YAC3B,KAAK,SAAS,CAAC,CAAI,OAAO,EAAE,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;YAChF,KAAK,QAAQ,CAAC,CAAK,OAAO,EAAE,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;YAChF,KAAK,YAAY,CAAC,CAAC,OAAO,EAAE,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;YAChF,KAAK,SAAS,CAAC,CAAI,OAAO,EAAE,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;YAChF,KAAK,WAAW,CAAC,CAAE,OAAO,EAAE,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;YAChF,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;SACvE;IACH,CAAC;;kHA7CU,qBAAqB;sGAArB,qBAAqB,0PCTlC,q4PAgDA;2FDvCa,qBAAqB;kBALjC,SAAS;+BACE,oBAAoB;8BAKrB,UAAU;sBAAlB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,cAAc;sBAAtB,KAAK","sourcesContent":["import { Component, Input } from '@angular/core';\n\nexport type AiPromptCardOperation = 'created' | 'edited' | 'duplicated' | 'deleted' | 'converted';\n\n@Component({\n  selector: 'cqa-ai-prompt-card',\n  templateUrl: './ai-prompt-card.component.html',\n  styleUrls: []\n})\nexport class AiPromptCardComponent {\n  @Input() stepNumber!: string;\n  @Input() stepName!: string;\n  @Input() timestamp!: string;\n  @Input() runVersion?: string;\n  @Input() promptText!: string;\n  @Input() isFailed = false;\n  @Input() operationLabel?: AiPromptCardOperation;\n\n  get accentColor(): string {\n    return this.isFailed ? '#FB2C36' : '#3F43EE';\n  }\n\n  get titleColor(): string {\n    return this.isFailed ? '#FB2C36' : '#161617';\n  }\n\n  get stepPrefix(): string {\n    return `Step ${this.stepNumber} — `;\n  }\n\n  get metaLine(): string {\n    return this.runVersion ? `${this.timestamp} · Run ${this.runVersion}` : this.timestamp;\n  }\n\n  get operationBadgeText(): string {\n    switch (this.operationLabel) {\n      case 'created':    return 'Created';\n      case 'edited':     return 'Edited';\n      case 'duplicated': return 'Duplicated';\n      case 'deleted':    return 'Deleted';\n      case 'converted':  return 'Converted';\n      default: return '';\n    }\n  }\n\n  get operationBadgeColors(): { bg: string; text: string; border: string } {\n    switch (this.operationLabel) {\n      case 'created':    return { bg: '#ECFDF5', text: '#047857', border: '#A7F3D0' };\n      case 'edited':     return { bg: '#FFFBEB', text: '#B45309', border: '#FDE68A' };\n      case 'duplicated': return { bg: '#EEF2FF', text: '#4338CA', border: '#C7D2FE' };\n      case 'deleted':    return { bg: '#FEF2F2', text: '#B42318', border: '#FECACA' };\n      case 'converted':  return { bg: '#CFFAFE', text: '#155E75', border: '#A5F3FC' };\n      default: return { bg: '#F3F4F6', text: '#374151', border: '#E5E7EB' };\n    }\n  }\n}\n","<div class=\"cqa-ui-root cqa-font-inter\" style=\"display: block; width: 100%;\">\n  <div class=\"cqa-bg-white cqa-rounded-lg cqa-overflow-hidden\"\n    style=\"border: 1px solid #E4E4E499;\">\n\n    <!-- Header section: sparkle icon + step title + meta line -->\n    <div class=\"cqa-flex cqa-items-center cqa-gap-2\" style=\"padding: 6px 12px; border-bottom: 1px solid #E4E4E499;\">\n      <svg class=\"cqa-ai-prompt-card__logo\" width=\"18\" height=\"19\" viewBox=\"0 0 18 19\" fill=\"none\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n        [ngStyle]=\"{ color: accentColor, 'flex-shrink': '0', 'margin-top': '2px' }\">\n        <path d=\"M9.01881 0C9.12979 0.0480032 9.17718 0.165227 9.22261 0.274119C9.24539 0.337566 9.26628 0.401358 9.28657 0.465659C9.29452 0.490298 9.30246 0.514938 9.31065 0.540324C9.41613 0.871899 9.51008 1.20702 9.60457 1.54191C9.62593 1.61751 9.64739 1.69308 9.66885 1.76865C9.7781 2.15341 9.88654 2.5384 9.99438 2.92356C10.0095 2.97765 10.0247 3.03175 10.0398 3.08584C10.0826 3.23834 10.1252 3.39085 10.1677 3.54344C10.2573 3.86586 10.3495 4.18733 10.4476 4.50724C10.4561 4.53523 10.4647 4.56321 10.4735 4.59205C10.7284 5.41499 11.0896 6.15257 11.6818 6.78081C11.6965 6.79715 11.7111 6.81349 11.7262 6.83032C11.979 7.10257 12.3034 7.32071 12.6276 7.49678C12.6441 7.5059 12.6606 7.51501 12.6776 7.5244C13.6317 8.04176 14.779 8.2693 15.8124 8.57217C16.2652 8.70496 16.7166 8.84194 17.1663 8.98495C17.1979 8.99499 17.2296 9.00502 17.2612 9.01503C17.3557 9.04495 17.45 9.07539 17.5442 9.10622C17.5662 9.11323 17.5882 9.12024 17.6108 9.12746C17.7406 9.17079 17.8648 9.22194 17.9713 9.31057C18.0038 9.38216 18.0038 9.38216 17.995 9.45376C17.8913 9.55776 17.7884 9.60653 17.6516 9.6541C17.632 9.66112 17.6124 9.66815 17.5923 9.67538C17.3612 9.7572 17.127 9.8288 16.8925 9.89975C16.8444 9.91442 16.7963 9.9291 16.7482 9.94378C16.4514 10.0341 16.1542 10.1226 15.8566 10.21C15.4646 10.3252 15.0733 10.4423 14.6822 10.5607C14.6182 10.5801 14.5541 10.5994 14.49 10.6187C14.1534 10.7199 13.8185 10.8248 13.4863 10.94C13.4587 10.9495 13.4312 10.959 13.4028 10.9688C12.2902 11.3595 11.4422 12.0884 10.9114 13.1543C10.6253 13.7534 10.4565 14.4012 10.2843 15.0405C10.2377 15.2131 10.1882 15.3846 10.1381 15.5561C10.0988 15.6911 10.0604 15.8262 10.023 15.9617C10.0185 15.9778 10.0141 15.9939 10.0095 16.0106C9.98788 16.0886 9.96638 16.1668 9.94503 16.2449C9.89039 16.443 9.83156 16.6395 9.77111 16.8359C9.66383 17.1849 9.5662 17.5365 9.46917 17.8885C9.32288 18.4185 9.32288 18.4185 9.23993 18.6733C9.23443 18.6904 9.22893 18.7076 9.22326 18.7252C9.19298 18.8159 9.16183 18.8994 9.10453 18.9761C9.01734 18.9955 9.01734 18.9955 8.93901 19C8.84946 18.8682 8.79016 18.7406 8.74265 18.5885C8.73574 18.567 8.72882 18.5454 8.7217 18.5232C8.63368 18.2452 8.55502 17.9644 8.47634 17.6836C8.45832 17.6194 8.44021 17.5552 8.42211 17.4911C8.2872 17.0127 8.15451 16.5337 8.02202 16.0546C7.47014 13.6847 7.47014 13.6847 6.078 11.7687C6.05569 11.7504 6.03338 11.732 6.01039 11.7131C5.09826 10.9757 3.89667 10.7027 2.7963 10.3827C2.52415 10.3035 2.2521 10.224 1.98006 10.1444C1.95628 10.1374 1.95628 10.1374 1.93201 10.1303C1.53962 10.0155 1.14735 9.90032 0.756448 9.78042C0.739911 9.77539 0.723375 9.77035 0.706338 9.76517C0.105798 9.58198 0.105798 9.58198 0.00129307 9.45376C-0.00166252 9.39559 -0.00166252 9.39559 0.0249378 9.33443C0.134167 9.22639 0.240153 9.18012 0.38432 9.13307C0.405194 9.12599 0.426068 9.11891 0.447574 9.11162C0.511506 9.09007 0.575577 9.069 0.639702 9.04805C0.658001 9.04198 0.676301 9.03592 0.695155 9.02968C0.82457 8.98684 0.95445 8.94561 1.08452 8.90485C1.11648 8.8948 1.11648 8.8948 1.14909 8.88454C1.70454 8.71017 2.26361 8.54789 2.82252 8.38525C3.23899 8.26404 3.65476 8.14082 4.06921 8.01269C4.08825 8.00683 4.1073 8.00097 4.12692 7.99493C5.087 7.69914 6.02557 7.27945 6.64547 6.44669C6.65475 6.43434 6.66403 6.42199 6.6736 6.40927C7.36395 5.48498 7.63315 4.36097 7.93391 3.26421C8.03285 2.90351 8.13298 2.54314 8.23345 2.18287C8.26127 2.0831 8.28906 1.98333 8.31673 1.88352C8.42788 1.48261 8.5407 1.08224 8.66 0.683712C8.67116 0.646393 8.68227 0.609057 8.69333 0.571704C8.86035 0.00841829 8.86035 0.00841828 9.01881 0Z\" fill=\"currentColor\"/>\n        <path d=\"M14.4717 1.17245C14.5802 1.29646 14.6019 1.4422 14.6357 1.60054C14.7485 2.09799 14.8783 2.55539 15.3291 2.84435C15.6072 2.99959 15.9386 3.07024 16.2468 3.13696C16.3768 3.16569 16.4867 3.20383 16.5982 3.28009C16.6234 3.32036 16.6234 3.32036 16.6219 3.39046C16.596 3.47572 16.5733 3.50321 16.5051 3.55901C16.4306 3.58419 16.4306 3.58419 16.3411 3.60376C16.3073 3.61161 16.2734 3.61954 16.2396 3.62753C16.2215 3.63178 16.2034 3.63602 16.1847 3.64039C15.6337 3.76904 15.6337 3.76904 15.1574 4.06019C15.1419 4.07277 15.1264 4.08536 15.1105 4.09832C14.7701 4.40129 14.6981 4.90525 14.5956 5.32743C14.5897 5.35062 14.5839 5.3738 14.5778 5.39769C14.5727 5.41822 14.5677 5.43874 14.5624 5.45989C14.5403 5.52256 14.5174 5.56343 14.4717 5.61146C14.3444 5.62777 14.3444 5.62777 14.2825 5.61146C14.1841 5.53443 14.162 5.44669 14.1363 5.3288C14.132 5.31054 14.1277 5.29229 14.1233 5.27348C14.1095 5.21517 14.0962 5.15678 14.083 5.09835C13.9793 4.64335 13.8623 4.19694 13.4488 3.93024C13.1256 3.74834 12.7327 3.66231 12.3715 3.59284C12.2725 3.57204 12.2158 3.54587 12.1545 3.46355C12.1412 3.38002 12.1412 3.38002 12.1545 3.29649C12.2487 3.19808 12.3478 3.17406 12.4752 3.14435C12.5153 3.13432 12.5554 3.12422 12.5955 3.11405C12.6163 3.10883 12.637 3.10361 12.6583 3.09824C12.764 3.07078 12.8686 3.04 12.9732 3.00861C12.9922 3.00305 13.0112 2.99749 13.0308 2.99175C13.2434 2.92759 13.4269 2.84553 13.5968 2.69985C13.6127 2.68669 13.6285 2.67352 13.6449 2.65995C13.9094 2.41969 13.9992 2.05873 14.0808 1.72192C14.087 1.69635 14.0932 1.67078 14.0997 1.64444C14.112 1.59308 14.1242 1.54165 14.1361 1.49018C14.1446 1.45436 14.1446 1.45436 14.1533 1.41782C14.1583 1.39643 14.1633 1.37503 14.1684 1.35298C14.1902 1.28487 14.2188 1.23138 14.2589 1.17245C14.336 1.13356 14.39 1.15114 14.4717 1.17245Z\" fill=\"currentColor\"/>\n        <path d=\"M3.5901 13.1885C3.61823 13.1887 3.61823 13.1887 3.64693 13.1889C3.84874 13.1951 3.9853 13.2604 4.13393 13.3974C4.30688 13.5859 4.38674 13.7987 4.3822 14.0528C4.36277 14.2589 4.24237 14.4388 4.09467 14.5781C3.92083 14.7198 3.74546 14.7666 3.52332 14.76C3.33602 14.738 3.15981 14.6482 3.02706 14.5131C2.86197 14.2857 2.8137 14.0772 2.8379 13.7971C2.88788 13.5766 3.03195 13.3976 3.21621 13.2721C3.34422 13.2066 3.44718 13.1873 3.5901 13.1885Z\" fill=\"currentColor\"/>\n      </svg>\n      <div class=\"cqa-flex cqa-flex-col cqa-flex-1\" style=\"gap: 2px;\">\n        <div class=\"cqa-font-semibold cqa-text-[12px] cqa-flex cqa-items-center\" style=\"gap: 6px;\" [ngStyle]=\"{ color: titleColor }\">\n          <span>{{ stepPrefix }}</span><span class=\"cqa-ai-prompt-card__step-name\" [innerHTML]=\"stepName\"></span>\n          <span *ngIf=\"operationLabel\" class=\"cqa-inline-flex cqa-items-center\"\n            [ngStyle]=\"{\n              'background-color': operationBadgeColors.bg,\n              'color': operationBadgeColors.text,\n              'border': '1px solid ' + operationBadgeColors.border,\n              'border-radius': '10px',\n              'padding': '1px 8px',\n              'font-size': '10px',\n              'font-weight': '600',\n              'line-height': '14px'\n            }\">\n            {{ operationBadgeText }}\n          </span>\n        </div>\n        <div class=\"cqa-text-[11px]\" style=\"color: #99999E;\">\n          {{ metaLine }}\n        </div>\n      </div>\n    </div>\n\n    <!-- Body section: quoted prompt with left accent bar -->\n    <div style=\"padding: 6px 12px;\">\n      <div style=\"background-color: #F7F7FA; padding: 10px 12px;  border-radius: 6px;\"\n      [ngStyle]=\"{ 'border-left': '3px solid ' + accentColor }\">\n      <p class=\"cqa-text-xs cqa-italic cqa-m-0\"\n        style=\"color: #4C4C51; line-height: 20.4px;\">\n        \"<span class=\"cqa-ai-prompt-card__prompt-body\" [innerHTML]=\"promptText\"></span>\"\n      </p>\n    </div>\n    </div>\n  </div>\n</div>\n"]}
|
package/esm2020/lib/sub-steps-confirmation-dialog/sub-steps-confirmation-dialog.component.mjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, Input, Output,
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
import * as i1 from "@angular/material/icon";
|
|
4
4
|
import * as i2 from "@angular/material/radio";
|
|
@@ -6,31 +6,80 @@ import * as i3 from "../button/button.component";
|
|
|
6
6
|
import * as i4 from "@angular/common";
|
|
7
7
|
/**
|
|
8
8
|
* Confirmation dialog shown before editing an AI-Agent step whose execution has
|
|
9
|
-
* already generated sub-steps (CON-926).
|
|
10
|
-
*
|
|
9
|
+
* already generated sub-steps (CON-926). Also used by CON-1166 to review
|
|
10
|
+
* AI-generated steps before persisting.
|
|
11
|
+
*
|
|
12
|
+
* The caller supplies the whole payload via the `config` input (one object, one
|
|
13
|
+
* reference change = one re-render). `isOpen` stays separate so open/close
|
|
14
|
+
* transitions don't force callers to rebuild the payload.
|
|
11
15
|
*/
|
|
12
16
|
export class SubStepsConfirmationDialogComponent {
|
|
13
|
-
constructor() {
|
|
17
|
+
constructor(cdr) {
|
|
18
|
+
this.cdr = cdr;
|
|
14
19
|
this.isOpen = false;
|
|
15
|
-
this.
|
|
16
|
-
this.description = '';
|
|
17
|
-
this.options = [];
|
|
18
|
-
this.cancelLabel = 'Cancel';
|
|
19
|
-
this.disableBackdropClose = false;
|
|
20
|
+
this.config = { options: [] };
|
|
20
21
|
this.selectionChange = new EventEmitter();
|
|
21
22
|
this.confirm = new EventEmitter();
|
|
22
23
|
this.closeModal = new EventEmitter();
|
|
24
|
+
this.timeoutExpired = new EventEmitter();
|
|
25
|
+
this.remainingSeconds = 0;
|
|
26
|
+
this._tickIntervalId = null;
|
|
27
|
+
this._timeoutEmitted = false;
|
|
23
28
|
}
|
|
24
29
|
ngOnChanges(changes) {
|
|
25
|
-
if (changes['
|
|
26
|
-
const
|
|
27
|
-
|
|
28
|
-
|
|
30
|
+
if (changes['config'] || changes['isOpen']) {
|
|
31
|
+
const options = this.config?.options ?? [];
|
|
32
|
+
const incoming = this.config?.selectedValue;
|
|
33
|
+
const stillValid = options.some(o => o.value === this.selectedValue);
|
|
34
|
+
if (incoming != null && options.some(o => o.value === incoming)) {
|
|
35
|
+
this.selectedValue = incoming;
|
|
36
|
+
}
|
|
37
|
+
else if (!stillValid) {
|
|
38
|
+
this.selectedValue = options.length ? options[0].value : undefined;
|
|
29
39
|
}
|
|
30
40
|
}
|
|
41
|
+
if (changes['isOpen'] || changes['config']) {
|
|
42
|
+
const timeoutSeconds = this.config?.timeoutSeconds;
|
|
43
|
+
if (this.isOpen && typeof timeoutSeconds === 'number' && timeoutSeconds > 0) {
|
|
44
|
+
const prevTimeout = changes['config']
|
|
45
|
+
? changes['config'].previousValue?.timeoutSeconds
|
|
46
|
+
: undefined;
|
|
47
|
+
const opening = !!changes['isOpen'] && this.isOpen;
|
|
48
|
+
if (opening || timeoutSeconds !== prevTimeout || this._tickIntervalId == null) {
|
|
49
|
+
this._startCountdown(timeoutSeconds);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
else {
|
|
53
|
+
this._stopCountdown();
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
ngOnDestroy() {
|
|
58
|
+
this._stopCountdown();
|
|
31
59
|
}
|
|
60
|
+
get title() { return this.config?.title ?? 'This step has generated sub-steps'; }
|
|
61
|
+
get description() { return this.config?.description ?? ''; }
|
|
62
|
+
get subtitle() { return this.config?.subtitle; }
|
|
63
|
+
get options() { return this.config?.options ?? []; }
|
|
64
|
+
get cancelLabel() { return this.config?.cancelLabel ?? 'Cancel'; }
|
|
65
|
+
get disableBackdropClose() { return !!this.config?.disableBackdropClose; }
|
|
66
|
+
get hideCloseButton() { return !!this.config?.hideCloseButton; }
|
|
67
|
+
get hideCancel() { return !!this.config?.hideCancel; }
|
|
68
|
+
get warnings() { return this.config?.warnings ?? []; }
|
|
69
|
+
get previewItems() { return this.config?.previewItems ?? []; }
|
|
70
|
+
get previewOverflowCount() { return this.config?.previewOverflowCount ?? 0; }
|
|
32
71
|
get currentOption() {
|
|
33
|
-
return this.options
|
|
72
|
+
return this.options.find(o => o.value === this.selectedValue);
|
|
73
|
+
}
|
|
74
|
+
get showCountdown() {
|
|
75
|
+
const t = this.config?.timeoutSeconds;
|
|
76
|
+
return typeof t === 'number' && t > 0;
|
|
77
|
+
}
|
|
78
|
+
get countdownLabel() {
|
|
79
|
+
const total = Math.max(0, this.remainingSeconds);
|
|
80
|
+
const m = Math.floor(total / 60);
|
|
81
|
+
const s = total % 60;
|
|
82
|
+
return `${m}:${s.toString().padStart(2, '0')}`;
|
|
34
83
|
}
|
|
35
84
|
isSelected(option) {
|
|
36
85
|
return option.value === this.selectedValue;
|
|
@@ -42,7 +91,7 @@ export class SubStepsConfirmationDialogComponent {
|
|
|
42
91
|
this.selectionChange.emit(option.value);
|
|
43
92
|
}
|
|
44
93
|
onRadioChange(event) {
|
|
45
|
-
const option = this.options
|
|
94
|
+
const option = this.options.find(o => o.value === event.value);
|
|
46
95
|
if (option)
|
|
47
96
|
this.onSelect(option);
|
|
48
97
|
}
|
|
@@ -63,25 +112,37 @@ export class SubStepsConfirmationDialogComponent {
|
|
|
63
112
|
return;
|
|
64
113
|
this.confirm.emit(this.selectedValue);
|
|
65
114
|
}
|
|
115
|
+
_startCountdown(seconds) {
|
|
116
|
+
this._stopCountdown();
|
|
117
|
+
this.remainingSeconds = seconds;
|
|
118
|
+
this._timeoutEmitted = false;
|
|
119
|
+
this._tickIntervalId = setInterval(() => {
|
|
120
|
+
if (this.remainingSeconds > 0) {
|
|
121
|
+
this.remainingSeconds--;
|
|
122
|
+
this.cdr.markForCheck();
|
|
123
|
+
if (this.remainingSeconds === 0 && !this._timeoutEmitted) {
|
|
124
|
+
this._timeoutEmitted = true;
|
|
125
|
+
this.timeoutExpired.emit();
|
|
126
|
+
this._stopCountdown();
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
}, 1000);
|
|
130
|
+
}
|
|
131
|
+
_stopCountdown() {
|
|
132
|
+
if (this._tickIntervalId) {
|
|
133
|
+
clearInterval(this._tickIntervalId);
|
|
134
|
+
this._tickIntervalId = null;
|
|
135
|
+
}
|
|
136
|
+
}
|
|
66
137
|
}
|
|
67
|
-
SubStepsConfirmationDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: SubStepsConfirmationDialogComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
68
|
-
SubStepsConfirmationDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: SubStepsConfirmationDialogComponent, selector: "cqa-sub-steps-confirmation-dialog", inputs: { isOpen: "isOpen",
|
|
138
|
+
SubStepsConfirmationDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: SubStepsConfirmationDialogComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
139
|
+
SubStepsConfirmationDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: SubStepsConfirmationDialogComponent, selector: "cqa-sub-steps-confirmation-dialog", inputs: { isOpen: "isOpen", config: "config" }, outputs: { selectionChange: "selectionChange", confirm: "confirm", closeModal: "closeModal", timeoutExpired: "timeoutExpired" }, usesOnChanges: true, ngImport: i0, template: "<div *ngIf=\"isOpen\" class=\"cqa-ui-root\"\n style=\"position: fixed; inset: 0; z-index: 9999;\">\n <div\n class=\"modal-backdrop cqa-fixed cqa-inset-0 cqa-bg-black cqa-bg-opacity-50 cqa-z-[9999] cqa-flex cqa-items-center cqa-justify-center cqa-p-4\"\n (click)=\"onBackdropClick($event)\">\n <div\n class=\"cqa-rounded-[12px] cqa-bg-white cqa-shadow-xl cqa-w-full cqa-max-w-[560px] cqa-overflow-hidden cqa-flex cqa-flex-col cqa-max-h-[85vh] cqa-font-inter\"\n style=\"box-shadow: 0px 8px 8px -4px #10182808;\" (click)=\"$event.stopPropagation()\">\n\n <!-- Header -->\n <div class=\"cqa-flex cqa-items-start cqa-justify-between cqa-px-6 cqa-py-4\" style=\"border-bottom: 1px solid #E5E5E5;\">\n <div class=\"cqa-flex cqa-flex-col cqa-gap-1 cqa-min-w-0\">\n <h2 class=\"cqa-text-[16px] cqa-font-semibold cqa-text-[#111827] cqa-m-0\">\n {{ title }}\n </h2>\n <span *ngIf=\"subtitle\"\n class=\"cqa-text-[12px] cqa-text-[#4A5565] cqa-m-0\">\n {{ subtitle }}\n </span>\n </div>\n <div class=\"cqa-flex cqa-items-center cqa-gap-2 cqa-flex-shrink-0\">\n <span *ngIf=\"showCountdown\"\n class=\"cqa-text-[12px] cqa-font-medium cqa-text-[#4A5565] cqa-rounded cqa-px-2 cqa-py-0.5\"\n style=\"background: #F3F4F6;\"\n [title]=\"'Auto-discards when timer reaches 0'\">\n {{ countdownLabel }}\n </span>\n <button *ngIf=\"!hideCloseButton\" type=\"button\"\n class=\"cqa-flex cqa-items-center cqa-justify-center cqa-h-6 cqa-w-6 cqa-rounded cqa-text-[#4A5565] hover:cqa-text-[#111827] cqa-bg-transparent cqa-border-0 cqa-cursor-pointer\"\n (click)=\"onClose()\"\n aria-label=\"Close\">\n <mat-icon class=\"cqa-h-5 cqa-w-5 cqa-text-[20px] cqa-leading-5\">close</mat-icon>\n </button>\n </div>\n </div>\n\n <!-- Body -->\n <div class=\"cqa-flex cqa-flex-col cqa-gap-3 cqa-px-6 cqa-py-3 cqa-overflow-y-auto\">\n <p *ngIf=\"description\"\n class=\"cqa-text-[12px] cqa-text-[#101828] cqa-m-0\">\n {{ description }}\n </p>\n\n <!-- Warnings (amber) -->\n <div *ngIf=\"warnings?.length\"\n class=\"cqa-flex cqa-flex-col cqa-gap-1 cqa-rounded-[8px] cqa-px-3 cqa-py-2\"\n style=\"background: #FEF3C7; border: 1px solid #FDE68A;\">\n <div *ngFor=\"let warn of warnings\"\n class=\"cqa-flex cqa-items-start cqa-gap-2 cqa-text-[12px] cqa-text-[#92400E]\">\n <span aria-hidden=\"true\">\u26A0</span>\n <span>{{ warn }}</span>\n </div>\n </div>\n\n <!-- Preview list (optional) -->\n <div *ngIf=\"previewItems?.length\"\n class=\"cqa-flex cqa-flex-col cqa-gap-1 cqa-rounded-[8px] cqa-border cqa-border-solid cqa-border-[#E5E7EB] cqa-px-3 cqa-py-2 cqa-max-h-[100px] cqa-overflow-y-auto\">\n <div *ngFor=\"let item of previewItems; let i = index\"\n class=\"cqa-flex cqa-items-baseline cqa-gap-2 cqa-text-[12px] cqa-text-[#101828]\">\n <span class=\"cqa-text-[#4A5565] cqa-flex-shrink-0\">{{ i + 1 }}.</span>\n <span class=\"cqa-font-semibold cqa-text-[#111827]\">{{ item.primary }}</span>\n <span *ngIf=\"item.secondary\" class=\"cqa-text-[#4A5565]\">\u2014 {{ item.secondary }}</span>\n </div>\n <div *ngIf=\"previewOverflowCount > 0\"\n class=\"cqa-text-[12px] cqa-text-[#4A5565] cqa-italic cqa-mt-1\">\n + {{ previewOverflowCount }} more step<span *ngIf=\"previewOverflowCount !== 1\">s</span>\n </div>\n </div>\n\n <mat-radio-group\n class=\"cqa-flex cqa-flex-col cqa-gap-3 cqa-radio-group\"\n [value]=\"selectedValue\"\n (change)=\"onRadioChange($event)\">\n <label\n *ngFor=\"let option of options\"\n class=\"cqa-radio-card-option qqa-m-0 cqa-flex cqa-items-start cqa-gap-1 cqa-cursor-pointer cqa-rounded-[10px] cqa-border cqa-border-solid cqa-p-4 cqa-transition-colors\"\n [ngClass]=\"isSelected(option)\n ? 'cqa-border-[#B1B2F8] cqa-bg-[#D8D9FC4D]'\n : 'cqa-border-[#E5E7EB] cqa-bg-white hover:cqa-border-[#6366f1]'\">\n <mat-radio-button [value]=\"option.value\" class=\"!cqa-pr-0 cqa-mt-[-2px]\"></mat-radio-button>\n <div class=\"cqa-flex cqa-flex-col cqa-gap-1\">\n <span\n class=\"cqa-text-[12px] cqa-font-bold\"\n [ngClass]=\"option.variant === 'danger' ? 'cqa-text-[#EE3F3F]' : 'cqa-text-[#364153]'\">\n {{ option.title }}\n </span>\n <span class=\"cqa-text-[12px] cqa-text-[#101828]\">\n {{ option.description }}\n </span>\n </div>\n </label>\n </mat-radio-group>\n </div>\n\n <!-- Footer -->\n <div class=\"cqa-flex cqa-items-center cqa-px-6 cqa-py-4 cqa-bg-white\" style=\"gap: 24px;\">\n <div *ngIf=\"!hideCancel\" class=\"cqa-flex-1\" style=\"width: 50%;\">\n <cqa-button\n variant=\"outlined\"\n btnSize=\"lg\"\n [fullWidth]=\"true\"\n [text]=\"cancelLabel\"\n (clicked)=\"onClose()\">\n </cqa-button>\n </div>\n <div class=\"cqa-flex-1\" [style.width]=\"hideCancel ? '100%' : '50%'\">\n <cqa-button\n *ngIf=\"currentOption\"\n [variant]=\"currentOption.buttonVariant || 'filled'\"\n btnSize=\"lg\"\n [fullWidth]=\"true\"\n [text]=\"currentOption.buttonLabel\"\n (clicked)=\"onConfirm()\">\n </cqa-button>\n </div>\n </div>\n </div>\n </div>\n</div>\n", components: [{ type: i1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i2.MatRadioButton, selector: "mat-radio-button", inputs: ["disableRipple", "tabIndex"], exportAs: ["matRadioButton"] }, { type: i3.ButtonComponent, selector: "cqa-button", inputs: ["variant", "btnSize", "disabled", "loading", "icon", "iconPosition", "fullWidth", "iconColor", "type", "text", "customClass", "inlineStyles", "tooltip", "tooltipPosition"], outputs: ["clicked"] }], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.MatRadioGroup, selector: "mat-radio-group", exportAs: ["matRadioGroup"] }, { type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
69
140
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: SubStepsConfirmationDialogComponent, decorators: [{
|
|
70
141
|
type: Component,
|
|
71
|
-
args: [{ selector: 'cqa-sub-steps-confirmation-dialog', template: "<div *ngIf=\"isOpen\" class=\"cqa-ui-root\"\n style=\"position: fixed; inset: 0; z-index: 9999;\">\n <div\n class=\"modal-backdrop cqa-fixed cqa-inset-0 cqa-bg-black cqa-bg-opacity-50 cqa-z-[9999] cqa-flex cqa-items-center cqa-justify-center cqa-p-4\"\n (click)=\"onBackdropClick($event)\">\n <div\n class=\"cqa-rounded-[12px] cqa-bg-white cqa-shadow-xl cqa-w-full cqa-max-w-[560px] cqa-overflow-hidden cqa-flex cqa-flex-col cqa-max-h-[85vh] cqa-font-inter\"\n style=\"box-shadow: 0px 8px 8px -4px #10182808;\" (click)=\"$event.stopPropagation()\">\n\n <!-- Header -->\n <div class=\"cqa-flex cqa-items-start cqa-justify-between cqa-px-6 cqa-py-4\" style=\"border-bottom: 1px solid #E5E5E5;\">\n <h2 class=\"cqa-text-[16px] cqa-font-semibold cqa-text-[#111827] cqa-m-0\">\n
|
|
72
|
-
}], propDecorators: { isOpen: [{
|
|
73
|
-
type: Input
|
|
74
|
-
}], title: [{
|
|
75
|
-
type: Input
|
|
76
|
-
}], description: [{
|
|
142
|
+
args: [{ selector: 'cqa-sub-steps-confirmation-dialog', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div *ngIf=\"isOpen\" class=\"cqa-ui-root\"\n style=\"position: fixed; inset: 0; z-index: 9999;\">\n <div\n class=\"modal-backdrop cqa-fixed cqa-inset-0 cqa-bg-black cqa-bg-opacity-50 cqa-z-[9999] cqa-flex cqa-items-center cqa-justify-center cqa-p-4\"\n (click)=\"onBackdropClick($event)\">\n <div\n class=\"cqa-rounded-[12px] cqa-bg-white cqa-shadow-xl cqa-w-full cqa-max-w-[560px] cqa-overflow-hidden cqa-flex cqa-flex-col cqa-max-h-[85vh] cqa-font-inter\"\n style=\"box-shadow: 0px 8px 8px -4px #10182808;\" (click)=\"$event.stopPropagation()\">\n\n <!-- Header -->\n <div class=\"cqa-flex cqa-items-start cqa-justify-between cqa-px-6 cqa-py-4\" style=\"border-bottom: 1px solid #E5E5E5;\">\n <div class=\"cqa-flex cqa-flex-col cqa-gap-1 cqa-min-w-0\">\n <h2 class=\"cqa-text-[16px] cqa-font-semibold cqa-text-[#111827] cqa-m-0\">\n {{ title }}\n </h2>\n <span *ngIf=\"subtitle\"\n class=\"cqa-text-[12px] cqa-text-[#4A5565] cqa-m-0\">\n {{ subtitle }}\n </span>\n </div>\n <div class=\"cqa-flex cqa-items-center cqa-gap-2 cqa-flex-shrink-0\">\n <span *ngIf=\"showCountdown\"\n class=\"cqa-text-[12px] cqa-font-medium cqa-text-[#4A5565] cqa-rounded cqa-px-2 cqa-py-0.5\"\n style=\"background: #F3F4F6;\"\n [title]=\"'Auto-discards when timer reaches 0'\">\n {{ countdownLabel }}\n </span>\n <button *ngIf=\"!hideCloseButton\" type=\"button\"\n class=\"cqa-flex cqa-items-center cqa-justify-center cqa-h-6 cqa-w-6 cqa-rounded cqa-text-[#4A5565] hover:cqa-text-[#111827] cqa-bg-transparent cqa-border-0 cqa-cursor-pointer\"\n (click)=\"onClose()\"\n aria-label=\"Close\">\n <mat-icon class=\"cqa-h-5 cqa-w-5 cqa-text-[20px] cqa-leading-5\">close</mat-icon>\n </button>\n </div>\n </div>\n\n <!-- Body -->\n <div class=\"cqa-flex cqa-flex-col cqa-gap-3 cqa-px-6 cqa-py-3 cqa-overflow-y-auto\">\n <p *ngIf=\"description\"\n class=\"cqa-text-[12px] cqa-text-[#101828] cqa-m-0\">\n {{ description }}\n </p>\n\n <!-- Warnings (amber) -->\n <div *ngIf=\"warnings?.length\"\n class=\"cqa-flex cqa-flex-col cqa-gap-1 cqa-rounded-[8px] cqa-px-3 cqa-py-2\"\n style=\"background: #FEF3C7; border: 1px solid #FDE68A;\">\n <div *ngFor=\"let warn of warnings\"\n class=\"cqa-flex cqa-items-start cqa-gap-2 cqa-text-[12px] cqa-text-[#92400E]\">\n <span aria-hidden=\"true\">\u26A0</span>\n <span>{{ warn }}</span>\n </div>\n </div>\n\n <!-- Preview list (optional) -->\n <div *ngIf=\"previewItems?.length\"\n class=\"cqa-flex cqa-flex-col cqa-gap-1 cqa-rounded-[8px] cqa-border cqa-border-solid cqa-border-[#E5E7EB] cqa-px-3 cqa-py-2 cqa-max-h-[100px] cqa-overflow-y-auto\">\n <div *ngFor=\"let item of previewItems; let i = index\"\n class=\"cqa-flex cqa-items-baseline cqa-gap-2 cqa-text-[12px] cqa-text-[#101828]\">\n <span class=\"cqa-text-[#4A5565] cqa-flex-shrink-0\">{{ i + 1 }}.</span>\n <span class=\"cqa-font-semibold cqa-text-[#111827]\">{{ item.primary }}</span>\n <span *ngIf=\"item.secondary\" class=\"cqa-text-[#4A5565]\">\u2014 {{ item.secondary }}</span>\n </div>\n <div *ngIf=\"previewOverflowCount > 0\"\n class=\"cqa-text-[12px] cqa-text-[#4A5565] cqa-italic cqa-mt-1\">\n + {{ previewOverflowCount }} more step<span *ngIf=\"previewOverflowCount !== 1\">s</span>\n </div>\n </div>\n\n <mat-radio-group\n class=\"cqa-flex cqa-flex-col cqa-gap-3 cqa-radio-group\"\n [value]=\"selectedValue\"\n (change)=\"onRadioChange($event)\">\n <label\n *ngFor=\"let option of options\"\n class=\"cqa-radio-card-option qqa-m-0 cqa-flex cqa-items-start cqa-gap-1 cqa-cursor-pointer cqa-rounded-[10px] cqa-border cqa-border-solid cqa-p-4 cqa-transition-colors\"\n [ngClass]=\"isSelected(option)\n ? 'cqa-border-[#B1B2F8] cqa-bg-[#D8D9FC4D]'\n : 'cqa-border-[#E5E7EB] cqa-bg-white hover:cqa-border-[#6366f1]'\">\n <mat-radio-button [value]=\"option.value\" class=\"!cqa-pr-0 cqa-mt-[-2px]\"></mat-radio-button>\n <div class=\"cqa-flex cqa-flex-col cqa-gap-1\">\n <span\n class=\"cqa-text-[12px] cqa-font-bold\"\n [ngClass]=\"option.variant === 'danger' ? 'cqa-text-[#EE3F3F]' : 'cqa-text-[#364153]'\">\n {{ option.title }}\n </span>\n <span class=\"cqa-text-[12px] cqa-text-[#101828]\">\n {{ option.description }}\n </span>\n </div>\n </label>\n </mat-radio-group>\n </div>\n\n <!-- Footer -->\n <div class=\"cqa-flex cqa-items-center cqa-px-6 cqa-py-4 cqa-bg-white\" style=\"gap: 24px;\">\n <div *ngIf=\"!hideCancel\" class=\"cqa-flex-1\" style=\"width: 50%;\">\n <cqa-button\n variant=\"outlined\"\n btnSize=\"lg\"\n [fullWidth]=\"true\"\n [text]=\"cancelLabel\"\n (clicked)=\"onClose()\">\n </cqa-button>\n </div>\n <div class=\"cqa-flex-1\" [style.width]=\"hideCancel ? '100%' : '50%'\">\n <cqa-button\n *ngIf=\"currentOption\"\n [variant]=\"currentOption.buttonVariant || 'filled'\"\n btnSize=\"lg\"\n [fullWidth]=\"true\"\n [text]=\"currentOption.buttonLabel\"\n (clicked)=\"onConfirm()\">\n </cqa-button>\n </div>\n </div>\n </div>\n </div>\n</div>\n", styles: [] }]
|
|
143
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { isOpen: [{
|
|
77
144
|
type: Input
|
|
78
|
-
}],
|
|
79
|
-
type: Input
|
|
80
|
-
}], selectedValue: [{
|
|
81
|
-
type: Input
|
|
82
|
-
}], cancelLabel: [{
|
|
83
|
-
type: Input
|
|
84
|
-
}], disableBackdropClose: [{
|
|
145
|
+
}], config: [{
|
|
85
146
|
type: Input
|
|
86
147
|
}], selectionChange: [{
|
|
87
148
|
type: Output
|
|
@@ -89,5 +150,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
89
150
|
type: Output
|
|
90
151
|
}], closeModal: [{
|
|
91
152
|
type: Output
|
|
153
|
+
}], timeoutExpired: [{
|
|
154
|
+
type: Output
|
|
92
155
|
}] } });
|
|
93
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sub-steps-confirmation-dialog.component.js","sourceRoot":"","sources":["../../../../../src/lib/sub-steps-confirmation-dialog/sub-steps-confirmation-dialog.component.ts","../../../../../src/lib/sub-steps-confirmation-dialog/sub-steps-confirmation-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, OnChanges, SimpleChanges } from '@angular/core';\nimport { MatRadioChange } from '@angular/material/radio';\nimport { ButtonVariant } from '../button/button.component';\n\nexport type SubStepsOptionVariant = 'default' | 'danger';\n\nexport interface SubStepsConfirmationOption {\n  /** Unique identifier for the option (emitted via `selectionChange` / `confirm`). */\n  value: string;\n  /** Bold title shown on the card. */\n  title: string;\n  /** Paragraph shown under the title. */\n  description: string;\n  /** `danger` renders the title in red to indicate a destructive choice. */\n  variant?: SubStepsOptionVariant;\n  /** Label for the primary CTA when this option is selected. */\n  buttonLabel: string;\n  /** Variant for the primary CTA when this option is selected. Defaults to `filled`. */\n  buttonVariant?: ButtonVariant;\n}\n\n/**\n * Confirmation dialog shown before editing an AI-Agent step whose execution has\n * already generated sub-steps (CON-926). The caller supplies the option list\n * and copy; this component only renders the UI and emits the user's choice.\n */\n@Component({\n  selector: 'cqa-sub-steps-confirmation-dialog',\n  templateUrl: './sub-steps-confirmation-dialog.component.html',\n  styleUrls: []\n})\nexport class SubStepsConfirmationDialogComponent implements OnChanges {\n  @Input() isOpen = false;\n  @Input() title = 'This step has generated sub-steps';\n  @Input() description = '';\n  @Input() options: SubStepsConfirmationOption[] = [];\n  @Input() selectedValue?: string;\n  @Input() cancelLabel = 'Cancel';\n  @Input() disableBackdropClose = false;\n\n  @Output() selectionChange = new EventEmitter<string>();\n  @Output() confirm = new EventEmitter<string>();\n  @Output() closeModal = new EventEmitter<void>();\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['options'] || changes['selectedValue'] || changes['isOpen']) {\n      const valid = this.options?.some(o => o.value === this.selectedValue);\n      if (!valid && this.options?.length) {\n        this.selectedValue = this.options[0].value;\n      }\n    }\n  }\n\n  get currentOption(): SubStepsConfirmationOption | undefined {\n    return this.options?.find(o => o.value === this.selectedValue);\n  }\n\n  isSelected(option: SubStepsConfirmationOption): boolean {\n    return option.value === this.selectedValue;\n  }\n\n  onSelect(option: SubStepsConfirmationOption): void {\n    if (option.value === this.selectedValue) return;\n    this.selectedValue = option.value;\n    this.selectionChange.emit(option.value);\n  }\n\n  onRadioChange(event: MatRadioChange): void {\n    const option = this.options?.find(o => o.value === event.value);\n    if (option) this.onSelect(option);\n  }\n\n  onBackdropClick(event: MouseEvent): void {\n    if (this.disableBackdropClose) return;\n    const target = event.target as HTMLElement;\n    const currentTarget = event.currentTarget as HTMLElement;\n    if (target === currentTarget || target.classList.contains('modal-backdrop')) {\n      this.closeModal.emit();\n    }\n  }\n\n  onClose(): void {\n    this.closeModal.emit();\n  }\n\n  onConfirm(): void {\n    if (!this.selectedValue) return;\n    this.confirm.emit(this.selectedValue);\n  }\n}\n","<div *ngIf=\"isOpen\" class=\"cqa-ui-root\"\n  style=\"position: fixed; inset: 0; z-index: 9999;\">\n  <div\n    class=\"modal-backdrop cqa-fixed cqa-inset-0 cqa-bg-black cqa-bg-opacity-50 cqa-z-[9999] cqa-flex cqa-items-center cqa-justify-center cqa-p-4\"\n    (click)=\"onBackdropClick($event)\">\n    <div\n      class=\"cqa-rounded-[12px] cqa-bg-white cqa-shadow-xl cqa-w-full cqa-max-w-[560px] cqa-overflow-hidden cqa-flex cqa-flex-col cqa-max-h-[85vh] cqa-font-inter\"\n      style=\"box-shadow: 0px 8px 8px -4px #10182808;\" (click)=\"$event.stopPropagation()\">\n\n    <!-- Header -->\n    <div class=\"cqa-flex cqa-items-start cqa-justify-between cqa-px-6 cqa-py-4\" style=\"border-bottom: 1px solid #E5E5E5;\">\n      <h2 class=\"cqa-text-[16px] cqa-font-semibold cqa-text-[#111827] cqa-m-0\">\n        {{ title }}\n      </h2>\n      <button type=\"button\"\n        class=\"cqa-flex cqa-items-center cqa-justify-center cqa-h-6 cqa-w-6 cqa-rounded cqa-text-[#4A5565] hover:cqa-text-[#111827] cqa-bg-transparent cqa-border-0 cqa-cursor-pointer\"\n        (click)=\"onClose()\"\n        aria-label=\"Close\">\n        <mat-icon class=\"cqa-h-5 cqa-w-5 cqa-text-[20px] cqa-leading-5\">close</mat-icon>\n      </button>\n    </div>\n\n    <!-- Body -->\n    <div class=\"cqa-flex cqa-flex-col cqa-gap-3 cqa-px-6 cqa-py-3 cqa-overflow-y-auto\">\n      <p *ngIf=\"description\"\n        class=\"cqa-text-[12px] cqa-text-[#101828] cqa-m-0\">\n        {{ description }}\n      </p>\n\n      <mat-radio-group\n        class=\"cqa-flex cqa-flex-col cqa-gap-3 cqa-radio-group\"\n        [value]=\"selectedValue\"\n        (change)=\"onRadioChange($event)\">\n        <label\n          *ngFor=\"let option of options\"\n          class=\"cqa-radio-card-option qqa-m-0 cqa-flex cqa-items-start cqa-gap-1 cqa-cursor-pointer cqa-rounded-[10px] cqa-border cqa-border-solid cqa-p-4 cqa-transition-colors\"\n          [ngClass]=\"isSelected(option)\n            ? 'cqa-border-[#B1B2F8] cqa-bg-[#D8D9FC4D]'\n            : 'cqa-border-[#E5E7EB] cqa-bg-white hover:cqa-border-[#6366f1]'\">\n          <mat-radio-button [value]=\"option.value\" class=\"!cqa-pr-0 cqa-mt-[-2px]\"></mat-radio-button>\n          <div class=\"cqa-flex cqa-flex-col cqa-gap-1\">\n            <span\n              class=\"cqa-text-[12px] cqa-font-bold\"\n              [ngClass]=\"option.variant === 'danger' ? 'cqa-text-[#EE3F3F]' : 'cqa-text-[#364153]'\">\n              {{ option.title }}\n            </span>\n            <span class=\"cqa-text-[12px] cqa-text-[#101828]\">\n              {{ option.description }}\n            </span>\n          </div>\n        </label>\n      </mat-radio-group>\n    </div>\n\n    <!-- Footer -->\n    <div class=\"cqa-flex cqa-items-center cqa-px-6 cqa-py-4 cqa-bg-white\" style=\"gap: 24px;\">\n      <div class=\"cqa-flex-1\" style=\"width: 50%;\">\n        <cqa-button\n          variant=\"outlined\"\n          btnSize=\"lg\"\n          [fullWidth]=\"true\"\n          [text]=\"cancelLabel\"\n          (clicked)=\"onClose()\">\n        </cqa-button>\n      </div>\n      <div class=\"cqa-flex-1\" style=\"width: 50%;\">\n        <cqa-button\n          *ngIf=\"currentOption\"\n          [variant]=\"currentOption.buttonVariant || 'filled'\"\n          btnSize=\"lg\"\n          [fullWidth]=\"true\"\n          [text]=\"currentOption.buttonLabel\"\n          (clicked)=\"onConfirm()\">\n        </cqa-button>\n      </div>\n    </div>\n    </div>\n  </div>\n</div>\n"]}
|
|
156
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sub-steps-confirmation-dialog.component.js","sourceRoot":"","sources":["../../../../../src/lib/sub-steps-confirmation-dialog/sub-steps-confirmation-dialog.component.ts","../../../../../src/lib/sub-steps-confirmation-dialog/sub-steps-confirmation-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  SimpleChanges,\n} from '@angular/core';\nimport { MatRadioChange } from '@angular/material/radio';\nimport { ButtonVariant } from '../button/button.component';\n\nexport type SubStepsOptionVariant = 'default' | 'danger';\n\nexport interface SubStepsConfirmationOption {\n  /** Unique identifier for the option (emitted via `selectionChange` / `confirm`). */\n  value: string;\n  /** Bold title shown on the card. */\n  title: string;\n  /** Paragraph shown under the title. */\n  description: string;\n  /** `danger` renders the title in red to indicate a destructive choice. */\n  variant?: SubStepsOptionVariant;\n  /** Label for the primary CTA when this option is selected. */\n  buttonLabel: string;\n  /** Variant for the primary CTA when this option is selected. Defaults to `filled`. */\n  buttonVariant?: ButtonVariant;\n}\n\n/** Single row rendered in the optional preview list above the radio group. */\nexport interface SubStepsConfirmationPreviewItem {\n  /** Bold primary text (e.g. action name). */\n  primary: string;\n  /** Optional secondary text appended after an em-dash (e.g. element label). */\n  secondary?: string;\n}\n\n/**\n * Full configuration payload for the sub-steps confirmation dialog. Pass a new\n * object reference whenever the content should change — the component uses\n * `OnPush` change detection and only reacts to reference changes.\n */\nexport interface SubStepsConfirmationDialogConfig {\n  title?: string;\n  description?: string;\n  /** Optional subtitle shown under the title (e.g. action type / parent context). */\n  subtitle?: string;\n  options: SubStepsConfirmationOption[];\n  selectedValue?: string;\n  cancelLabel?: string;\n  disableBackdropClose?: boolean;\n  /** Hide the top-right close (X) button. */\n  hideCloseButton?: boolean;\n  /** Hide the Cancel button in the footer. CTA expands to full width when true. */\n  hideCancel?: boolean;\n  /** Amber warnings list rendered above the radio group. */\n  warnings?: string[];\n  /** Optional numbered preview list rendered between description and radio group. */\n  previewItems?: SubStepsConfirmationPreviewItem[];\n  /** If >0, render a \"+ N more\" row after the preview list. */\n  previewOverflowCount?: number;\n  /**\n   * If >0, show an `M:SS` countdown in the header. `timeoutExpired` fires once\n   * when the countdown reaches 0. Countdown restarts whenever `isOpen` flips\n   * to true or a new config reference is passed with a different `timeoutSeconds`.\n   */\n  timeoutSeconds?: number;\n}\n\n/**\n * Confirmation dialog shown before editing an AI-Agent step whose execution has\n * already generated sub-steps (CON-926). Also used by CON-1166 to review\n * AI-generated steps before persisting.\n *\n * The caller supplies the whole payload via the `config` input (one object, one\n * reference change = one re-render). `isOpen` stays separate so open/close\n * transitions don't force callers to rebuild the payload.\n */\n@Component({\n  selector: 'cqa-sub-steps-confirmation-dialog',\n  templateUrl: './sub-steps-confirmation-dialog.component.html',\n  styleUrls: [],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SubStepsConfirmationDialogComponent implements OnChanges, OnDestroy {\n  @Input() isOpen = false;\n  @Input() config: SubStepsConfirmationDialogConfig = { options: [] };\n\n  @Output() selectionChange = new EventEmitter<string>();\n  @Output() confirm = new EventEmitter<string>();\n  @Output() closeModal = new EventEmitter<void>();\n  @Output() timeoutExpired = new EventEmitter<void>();\n\n  /** Local selection state. Seeded from `config.selectedValue` and user-driven thereafter. */\n  selectedValue?: string;\n  remainingSeconds = 0;\n\n  private _tickIntervalId: ReturnType<typeof setInterval> | null = null;\n  private _timeoutEmitted = false;\n\n  constructor(private readonly cdr: ChangeDetectorRef) {}\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['config'] || changes['isOpen']) {\n      const options = this.config?.options ?? [];\n      const incoming = this.config?.selectedValue;\n      const stillValid = options.some(o => o.value === this.selectedValue);\n      if (incoming != null && options.some(o => o.value === incoming)) {\n        this.selectedValue = incoming;\n      } else if (!stillValid) {\n        this.selectedValue = options.length ? options[0].value : undefined;\n      }\n    }\n\n    if (changes['isOpen'] || changes['config']) {\n      const timeoutSeconds = this.config?.timeoutSeconds;\n      if (this.isOpen && typeof timeoutSeconds === 'number' && timeoutSeconds > 0) {\n        const prevTimeout = changes['config']\n          ? (changes['config'].previousValue as SubStepsConfirmationDialogConfig | undefined)?.timeoutSeconds\n          : undefined;\n        const opening = !!changes['isOpen'] && this.isOpen;\n        if (opening || timeoutSeconds !== prevTimeout || this._tickIntervalId == null) {\n          this._startCountdown(timeoutSeconds);\n        }\n      } else {\n        this._stopCountdown();\n      }\n    }\n  }\n\n  ngOnDestroy(): void {\n    this._stopCountdown();\n  }\n\n  get title(): string { return this.config?.title ?? 'This step has generated sub-steps'; }\n  get description(): string { return this.config?.description ?? ''; }\n  get subtitle(): string | undefined { return this.config?.subtitle; }\n  get options(): SubStepsConfirmationOption[] { return this.config?.options ?? []; }\n  get cancelLabel(): string { return this.config?.cancelLabel ?? 'Cancel'; }\n  get disableBackdropClose(): boolean { return !!this.config?.disableBackdropClose; }\n  get hideCloseButton(): boolean { return !!this.config?.hideCloseButton; }\n  get hideCancel(): boolean { return !!this.config?.hideCancel; }\n  get warnings(): string[] { return this.config?.warnings ?? []; }\n  get previewItems(): SubStepsConfirmationPreviewItem[] { return this.config?.previewItems ?? []; }\n  get previewOverflowCount(): number { return this.config?.previewOverflowCount ?? 0; }\n\n  get currentOption(): SubStepsConfirmationOption | undefined {\n    return this.options.find(o => o.value === this.selectedValue);\n  }\n\n  get showCountdown(): boolean {\n    const t = this.config?.timeoutSeconds;\n    return typeof t === 'number' && t > 0;\n  }\n\n  get countdownLabel(): string {\n    const total = Math.max(0, this.remainingSeconds);\n    const m = Math.floor(total / 60);\n    const s = total % 60;\n    return `${m}:${s.toString().padStart(2, '0')}`;\n  }\n\n  isSelected(option: SubStepsConfirmationOption): boolean {\n    return option.value === this.selectedValue;\n  }\n\n  onSelect(option: SubStepsConfirmationOption): void {\n    if (option.value === this.selectedValue) return;\n    this.selectedValue = option.value;\n    this.selectionChange.emit(option.value);\n  }\n\n  onRadioChange(event: MatRadioChange): void {\n    const option = this.options.find(o => o.value === event.value);\n    if (option) this.onSelect(option);\n  }\n\n  onBackdropClick(event: MouseEvent): void {\n    if (this.disableBackdropClose) return;\n    const target = event.target as HTMLElement;\n    const currentTarget = event.currentTarget as HTMLElement;\n    if (target === currentTarget || target.classList.contains('modal-backdrop')) {\n      this.closeModal.emit();\n    }\n  }\n\n  onClose(): void {\n    this.closeModal.emit();\n  }\n\n  onConfirm(): void {\n    if (!this.selectedValue) return;\n    this.confirm.emit(this.selectedValue);\n  }\n\n  private _startCountdown(seconds: number): void {\n    this._stopCountdown();\n    this.remainingSeconds = seconds;\n    this._timeoutEmitted = false;\n    this._tickIntervalId = setInterval(() => {\n      if (this.remainingSeconds > 0) {\n        this.remainingSeconds--;\n        this.cdr.markForCheck();\n        if (this.remainingSeconds === 0 && !this._timeoutEmitted) {\n          this._timeoutEmitted = true;\n          this.timeoutExpired.emit();\n          this._stopCountdown();\n        }\n      }\n    }, 1000);\n  }\n\n  private _stopCountdown(): void {\n    if (this._tickIntervalId) {\n      clearInterval(this._tickIntervalId);\n      this._tickIntervalId = null;\n    }\n  }\n}\n","<div *ngIf=\"isOpen\" class=\"cqa-ui-root\"\n  style=\"position: fixed; inset: 0; z-index: 9999;\">\n  <div\n    class=\"modal-backdrop cqa-fixed cqa-inset-0 cqa-bg-black cqa-bg-opacity-50 cqa-z-[9999] cqa-flex cqa-items-center cqa-justify-center cqa-p-4\"\n    (click)=\"onBackdropClick($event)\">\n    <div\n      class=\"cqa-rounded-[12px] cqa-bg-white cqa-shadow-xl cqa-w-full cqa-max-w-[560px] cqa-overflow-hidden cqa-flex cqa-flex-col cqa-max-h-[85vh] cqa-font-inter\"\n      style=\"box-shadow: 0px 8px 8px -4px #10182808;\" (click)=\"$event.stopPropagation()\">\n\n    <!-- Header -->\n    <div class=\"cqa-flex cqa-items-start cqa-justify-between cqa-px-6 cqa-py-4\" style=\"border-bottom: 1px solid #E5E5E5;\">\n      <div class=\"cqa-flex cqa-flex-col cqa-gap-1 cqa-min-w-0\">\n        <h2 class=\"cqa-text-[16px] cqa-font-semibold cqa-text-[#111827] cqa-m-0\">\n          {{ title }}\n        </h2>\n        <span *ngIf=\"subtitle\"\n          class=\"cqa-text-[12px] cqa-text-[#4A5565] cqa-m-0\">\n          {{ subtitle }}\n        </span>\n      </div>\n      <div class=\"cqa-flex cqa-items-center cqa-gap-2 cqa-flex-shrink-0\">\n        <span *ngIf=\"showCountdown\"\n          class=\"cqa-text-[12px] cqa-font-medium cqa-text-[#4A5565] cqa-rounded cqa-px-2 cqa-py-0.5\"\n          style=\"background: #F3F4F6;\"\n          [title]=\"'Auto-discards when timer reaches 0'\">\n          {{ countdownLabel }}\n        </span>\n        <button *ngIf=\"!hideCloseButton\" type=\"button\"\n          class=\"cqa-flex cqa-items-center cqa-justify-center cqa-h-6 cqa-w-6 cqa-rounded cqa-text-[#4A5565] hover:cqa-text-[#111827] cqa-bg-transparent cqa-border-0 cqa-cursor-pointer\"\n          (click)=\"onClose()\"\n          aria-label=\"Close\">\n          <mat-icon class=\"cqa-h-5 cqa-w-5 cqa-text-[20px] cqa-leading-5\">close</mat-icon>\n        </button>\n      </div>\n    </div>\n\n    <!-- Body -->\n    <div class=\"cqa-flex cqa-flex-col cqa-gap-3 cqa-px-6 cqa-py-3 cqa-overflow-y-auto\">\n      <p *ngIf=\"description\"\n        class=\"cqa-text-[12px] cqa-text-[#101828] cqa-m-0\">\n        {{ description }}\n      </p>\n\n      <!-- Warnings (amber) -->\n      <div *ngIf=\"warnings?.length\"\n        class=\"cqa-flex cqa-flex-col cqa-gap-1 cqa-rounded-[8px] cqa-px-3 cqa-py-2\"\n        style=\"background: #FEF3C7; border: 1px solid #FDE68A;\">\n        <div *ngFor=\"let warn of warnings\"\n          class=\"cqa-flex cqa-items-start cqa-gap-2 cqa-text-[12px] cqa-text-[#92400E]\">\n          <span aria-hidden=\"true\">⚠</span>\n          <span>{{ warn }}</span>\n        </div>\n      </div>\n\n      <!-- Preview list (optional) -->\n      <div *ngIf=\"previewItems?.length\"\n        class=\"cqa-flex cqa-flex-col cqa-gap-1 cqa-rounded-[8px] cqa-border cqa-border-solid cqa-border-[#E5E7EB] cqa-px-3 cqa-py-2 cqa-max-h-[100px] cqa-overflow-y-auto\">\n        <div *ngFor=\"let item of previewItems; let i = index\"\n          class=\"cqa-flex cqa-items-baseline cqa-gap-2 cqa-text-[12px] cqa-text-[#101828]\">\n          <span class=\"cqa-text-[#4A5565] cqa-flex-shrink-0\">{{ i + 1 }}.</span>\n          <span class=\"cqa-font-semibold cqa-text-[#111827]\">{{ item.primary }}</span>\n          <span *ngIf=\"item.secondary\" class=\"cqa-text-[#4A5565]\">—&nbsp;&nbsp;{{ item.secondary }}</span>\n        </div>\n        <div *ngIf=\"previewOverflowCount > 0\"\n          class=\"cqa-text-[12px] cqa-text-[#4A5565] cqa-italic cqa-mt-1\">\n          + {{ previewOverflowCount }} more step<span *ngIf=\"previewOverflowCount !== 1\">s</span>\n        </div>\n      </div>\n\n      <mat-radio-group\n        class=\"cqa-flex cqa-flex-col cqa-gap-3 cqa-radio-group\"\n        [value]=\"selectedValue\"\n        (change)=\"onRadioChange($event)\">\n        <label\n          *ngFor=\"let option of options\"\n          class=\"cqa-radio-card-option qqa-m-0 cqa-flex cqa-items-start cqa-gap-1 cqa-cursor-pointer cqa-rounded-[10px] cqa-border cqa-border-solid cqa-p-4 cqa-transition-colors\"\n          [ngClass]=\"isSelected(option)\n            ? 'cqa-border-[#B1B2F8] cqa-bg-[#D8D9FC4D]'\n            : 'cqa-border-[#E5E7EB] cqa-bg-white hover:cqa-border-[#6366f1]'\">\n          <mat-radio-button [value]=\"option.value\" class=\"!cqa-pr-0 cqa-mt-[-2px]\"></mat-radio-button>\n          <div class=\"cqa-flex cqa-flex-col cqa-gap-1\">\n            <span\n              class=\"cqa-text-[12px] cqa-font-bold\"\n              [ngClass]=\"option.variant === 'danger' ? 'cqa-text-[#EE3F3F]' : 'cqa-text-[#364153]'\">\n              {{ option.title }}\n            </span>\n            <span class=\"cqa-text-[12px] cqa-text-[#101828]\">\n              {{ option.description }}\n            </span>\n          </div>\n        </label>\n      </mat-radio-group>\n    </div>\n\n    <!-- Footer -->\n    <div class=\"cqa-flex cqa-items-center cqa-px-6 cqa-py-4 cqa-bg-white\" style=\"gap: 24px;\">\n      <div *ngIf=\"!hideCancel\" class=\"cqa-flex-1\" style=\"width: 50%;\">\n        <cqa-button\n          variant=\"outlined\"\n          btnSize=\"lg\"\n          [fullWidth]=\"true\"\n          [text]=\"cancelLabel\"\n          (clicked)=\"onClose()\">\n        </cqa-button>\n      </div>\n      <div class=\"cqa-flex-1\" [style.width]=\"hideCancel ? '100%' : '50%'\">\n        <cqa-button\n          *ngIf=\"currentOption\"\n          [variant]=\"currentOption.buttonVariant || 'filled'\"\n          btnSize=\"lg\"\n          [fullWidth]=\"true\"\n          [text]=\"currentOption.buttonLabel\"\n          (clicked)=\"onConfirm()\">\n        </cqa-button>\n      </div>\n    </div>\n    </div>\n  </div>\n</div>\n"]}
|