@profoundlogic/coderflow-server 0.6.0 → 0.6.1

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.
Files changed (174) hide show
  1. package/dist/.claude/settings.local.json +15 -2
  2. package/dist/coder-server.js +1 -1
  3. package/dist/config.js +1 -1
  4. package/dist/lib/agent-keepalive.js +1 -1
  5. package/dist/lib/agent-models.js +1 -1
  6. package/dist/lib/api-keys.js +1 -1
  7. package/dist/lib/apiKeys.js +1 -1
  8. package/dist/lib/app-server-ports.js +1 -1
  9. package/dist/lib/auto-judge.js +1 -1
  10. package/dist/lib/automation-service.js +1 -1
  11. package/dist/lib/basic-auth.js +1 -1
  12. package/dist/lib/bindings.js +1 -1
  13. package/dist/lib/build-history.js +1 -1
  14. package/dist/lib/build-output-service.js +1 -1
  15. package/dist/lib/build-scheduler.js +1 -1
  16. package/dist/lib/build-service.js +1 -1
  17. package/dist/lib/ca-certificates.js +1 -1
  18. package/dist/lib/claude-oauth-refresh.js +1 -1
  19. package/dist/lib/cli/build.js +1 -1
  20. package/dist/lib/cli/cleanup-users.js +1 -1
  21. package/dist/lib/cli/config-command.js +1 -1
  22. package/dist/lib/cli/config.js +1 -1
  23. package/dist/lib/cli/create-user.js +1 -1
  24. package/dist/lib/cli/grant-admin.js +1 -1
  25. package/dist/lib/cli/init.js +1 -1
  26. package/dist/lib/cli/jira.js +1 -1
  27. package/dist/lib/cli/license.js +1 -1
  28. package/dist/lib/cli/list-roles.js +1 -1
  29. package/dist/lib/cli/list-users.js +1 -1
  30. package/dist/lib/cli/server-manager.js +1 -1
  31. package/dist/lib/cli/set-password.js +1 -1
  32. package/dist/lib/config-migration.js +1 -1
  33. package/dist/lib/container-credential-sync.js +1 -1
  34. package/dist/lib/container-tokens.js +1 -1
  35. package/dist/lib/data-dir.js +1 -1
  36. package/dist/lib/deployment-history.js +1 -1
  37. package/dist/lib/deployment-service.js +1 -1
  38. package/dist/lib/docker-utils.js +1 -1
  39. package/dist/lib/email.js +1 -1
  40. package/dist/lib/emailTemplates.js +1 -1
  41. package/dist/lib/entitlement.js +1 -1
  42. package/dist/lib/external-connections.js +1 -1
  43. package/dist/lib/fetch-utils.js +1 -1
  44. package/dist/lib/git-commit-details-route.js +1 -1
  45. package/dist/lib/git-history-diff-guardrails.js +1 -1
  46. package/dist/lib/git-provider-service.js +1 -1
  47. package/dist/lib/git-provider-setup/github-setup-handler.js +1 -1
  48. package/dist/lib/git-provider-setup/index.js +1 -1
  49. package/dist/lib/git-provider-setup/setup-factory.js +1 -1
  50. package/dist/lib/git-provider-setup/setup-interface.js +1 -1
  51. package/dist/lib/git-providers/azure-devops-provider.js +1 -1
  52. package/dist/lib/git-providers/github-app-provider.js +1 -1
  53. package/dist/lib/git-providers/index.js +1 -1
  54. package/dist/lib/git-providers/provider-factory.js +1 -1
  55. package/dist/lib/git-providers/provider-interface.js +1 -1
  56. package/dist/lib/github-urls.js +1 -1
  57. package/dist/lib/group-objective-linking.js +1 -1
  58. package/dist/lib/ibmi-sync.js +1 -1
  59. package/dist/lib/jira-client.js +1 -1
  60. package/dist/lib/judge-blinding.js +1 -1
  61. package/dist/lib/logger.js +1 -1
  62. package/dist/lib/migration-to-scoped-rbac.js +1 -1
  63. package/dist/lib/model-fetcher.js +1 -1
  64. package/dist/lib/notifications.js +1 -1
  65. package/dist/lib/objective-context.js +1 -1
  66. package/dist/lib/oidc-auth.js +1 -1
  67. package/dist/lib/oidc-device-flow.js +1 -1
  68. package/dist/lib/passwordTokens.js +1 -1
  69. package/dist/lib/permission-resolver.js +1 -1
  70. package/dist/lib/pin-cascade.js +1 -1
  71. package/dist/lib/provider-accounts.js +1 -1
  72. package/dist/lib/provider-oauth.js +1 -1
  73. package/dist/lib/provider-profile.js +1 -1
  74. package/dist/lib/provider-token-refresh.js +1 -1
  75. package/dist/lib/rbac-user-state.js +1 -1
  76. package/dist/lib/request-url.js +1 -1
  77. package/dist/lib/rewind.js +1 -1
  78. package/dist/lib/role-definitions.js +1 -1
  79. package/dist/lib/roles.js +1 -1
  80. package/dist/lib/secrets.js +1 -1
  81. package/dist/lib/setup-repo-git-auth.js +1 -1
  82. package/dist/lib/state-capture.js +1 -1
  83. package/dist/lib/static-files.js +1 -1
  84. package/dist/lib/task-name-format.js +1 -1
  85. package/dist/lib/task-name-generator.js +1 -1
  86. package/dist/lib/task-source-metadata.js +1 -1
  87. package/dist/lib/teams.js +1 -1
  88. package/dist/lib/user-git-oauth.js +1 -1
  89. package/dist/lib/user-git-tokens.js +1 -1
  90. package/dist/lib/users.js +1 -1
  91. package/dist/middleware/requireAuth.js +1 -1
  92. package/dist/middleware/requireInit.js +1 -1
  93. package/dist/middleware/requirePermission.js +1 -1
  94. package/dist/package.json +1 -1
  95. package/dist/playwright-test-results/.last-run.json +52 -2
  96. package/dist/playwright.config.js +1 -1
  97. package/dist/playwright.task-terminal.config.js +1 -1
  98. package/dist/routes/apiKeys.js +1 -1
  99. package/dist/routes/auth-oidc.js +1 -1
  100. package/dist/routes/auth.js +1 -1
  101. package/dist/routes/automations.js +1 -1
  102. package/dist/routes/bindings.js +1 -1
  103. package/dist/routes/build.js +1 -1
  104. package/dist/routes/containers.js +1 -1
  105. package/dist/routes/deploy-task.js +1 -1
  106. package/dist/routes/environment-management.js +1 -1
  107. package/dist/routes/environments.js +1 -1
  108. package/dist/routes/external-skills.js +1 -1
  109. package/dist/routes/git-credentials.js +1 -1
  110. package/dist/routes/git-oauth.js +1 -1
  111. package/dist/routes/git-provider-setup.js +1 -1
  112. package/dist/routes/health.js +1 -1
  113. package/dist/routes/jira.js +1 -1
  114. package/dist/routes/objective-management.js +1 -1
  115. package/dist/routes/password.js +1 -1
  116. package/dist/routes/prompt.js +1 -1
  117. package/dist/routes/provider-auth.js +1 -1
  118. package/dist/routes/qa.js +1 -1
  119. package/dist/routes/roles.js +1 -1
  120. package/dist/routes/settings.js +1 -1
  121. package/dist/routes/skill-management.js +1 -1
  122. package/dist/routes/skills.js +1 -1
  123. package/dist/routes/tasks.js +1 -1
  124. package/dist/routes/teams.js +1 -1
  125. package/dist/routes/templates.js +1 -1
  126. package/dist/routes/test-task.js +1 -1
  127. package/dist/routes/test.js +1 -1
  128. package/dist/routes/users.js +1 -1
  129. package/dist/routes/visualizations.js +1 -1
  130. package/dist/scripts/create-user.js +1 -1
  131. package/dist/scripts/migrate-config-to-data-dir.js +1 -1
  132. package/dist/start.js +1 -1
  133. package/dist/web-ui/public/activity-detail-modal.js +1 -1
  134. package/dist/web-ui/public/activity-feed.js +1 -1
  135. package/dist/web-ui/public/activity-formatters.js +1 -1
  136. package/dist/web-ui/public/agent-event-parser.js +1 -1
  137. package/dist/web-ui/public/app.js +1 -1
  138. package/dist/web-ui/public/approve-dialog.js +1 -1
  139. package/dist/web-ui/public/automation-links.js +1 -1
  140. package/dist/web-ui/public/automation-schedule.js +1 -1
  141. package/dist/web-ui/public/comments-widget.js +1 -1
  142. package/dist/web-ui/public/diff-utils.js +1 -1
  143. package/dist/web-ui/public/environments.html +0 -61
  144. package/dist/web-ui/public/environments.js +1 -1
  145. package/dist/web-ui/public/feedback-widget.js +1 -1
  146. package/dist/web-ui/public/file-selection-tree.js +1 -1
  147. package/dist/web-ui/public/git-history-lazy-utils.js +1 -1
  148. package/dist/web-ui/public/git-history.js +1 -1
  149. package/dist/web-ui/public/git-status.js +1 -1
  150. package/dist/web-ui/public/ibmi-file-filter.js +1 -1
  151. package/dist/web-ui/public/index.js +1 -1
  152. package/dist/web-ui/public/login.js +1 -1
  153. package/dist/web-ui/public/markdown-editor.js +1 -1
  154. package/dist/web-ui/public/markdown-file-editor.js +1 -1
  155. package/dist/web-ui/public/modal-maximize.js +1 -1
  156. package/dist/web-ui/public/notifications.js +1 -1
  157. package/dist/web-ui/public/permissions.js +1 -1
  158. package/dist/web-ui/public/pr-dialog.js +1 -1
  159. package/dist/web-ui/public/roles.js +1 -1
  160. package/dist/web-ui/public/server-health.js +1 -1
  161. package/dist/web-ui/public/settings.js +1 -1
  162. package/dist/web-ui/public/setup-password.js +1 -1
  163. package/dist/web-ui/public/skills.js +1 -1
  164. package/dist/web-ui/public/sse-client.js +1 -1
  165. package/dist/web-ui/public/sse-shared-worker.js +1 -1
  166. package/dist/web-ui/public/styles.css +8 -2
  167. package/dist/web-ui/public/task.js +1 -1
  168. package/dist/web-ui/public/teams.js +1 -1
  169. package/dist/web-ui/public/terminal.js +1 -1
  170. package/dist/web-ui/public/theme.js +1 -1
  171. package/dist/web-ui/public/users.js +1 -1
  172. package/dist/web-ui/public/variant-grouping.js +1 -1
  173. package/package.json +1 -1
  174. package/dist/playwright-test-results/result-screenshot.png +0 -0
@@ -1 +1 @@
1
- import{API,Utils,initializeAdminMenu}from'./app.js';import{initTheme,mountThemeToggle}from'./theme.js';const state={'teams':[],'users':[],'roles':[],'environments':[],'teamBindings':[],'currentUser':null,'editingTeamId':null,'bindingsTeamId':null,'deletingTeamId':null,'modalSnapshot':null};document['addEventListener']('DOMContentLoaded',async()=>{initTheme(),mountThemeToggle();try{state['currentUser']=await API['getCurrentUser']();}catch{window['location']['href']='login.html';return;}await initializeAdminMenu(state['currentUser']);const _0x22d493=state['currentUser'];if(!Permissions['hasServerPermission'](_0x22d493,'*')&&!Permissions['hasTeamPermission'](_0x22d493,'teams:manage')&&!Permissions['hasAnyEnvironment'](_0x22d493)){Utils['showToast']('Access\x20denied:\x20You\x20do\x20not\x20have\x20permission\x20to\x20view\x20teams','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}(Permissions['hasServerPermission'](_0x22d493,'*')||Permissions['hasTeamPermission'](_0x22d493,'teams:manage'))&&(document['getElementById']('create-team-btn')['hidden']=![]),bindEventListeners(),await Promise['all']([loadTeams(),loadUsers(),loadRoles(),loadEnvironments()]),renderTeams();});async function loadTeams(){const _0x279f1a=document['getElementById']('teams-loading'),_0x4346f4=document['getElementById']('teams-error'),_0x575a4e=document['getElementById']('teams-content');try{_0x279f1a['hidden']=![],_0x4346f4['hidden']=!![],_0x575a4e['hidden']=!![];const {teams:_0x103d75}=await API['getTeams']();state['teams']=_0x103d75||[],renderTeams(),_0x279f1a['hidden']=!![],_0x575a4e['hidden']=![];}catch(_0x171a1f){_0x279f1a['hidden']=!![],_0x4346f4['hidden']=![],document['getElementById']('teams-error-message')['textContent']=_0x171a1f['message'];}}async function loadUsers(){try{const {users:_0x1bab0e}=await API['getUsers']();state['users']=_0x1bab0e||[];}catch{state['users']=[];}}async function loadRoles(){try{const {roles:_0x2e0e75}=await API['getRoleDefinitions']();state['roles']=_0x2e0e75||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x3f9141=await API['getEnvironments']();state['environments']=_0x3f9141['environments']||[];}catch{state['environments']=[];}}function renderTeams(){const _0x383e6e=document['getElementById']('teams-table-body'),_0x529269=document['getElementById']('team-count');if(!_0x383e6e)return;_0x529269&&(_0x529269['textContent']=state['teams']['length']+'\x20team'+(state['teams']['length']===0x1?'':'s'));if(state['teams']['length']===0x0){_0x383e6e['innerHTML']='\x0a\x20\x20\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td\x20colspan=\x223\x22\x20style=\x22text-align:\x20center;\x20color:\x20var(--color-text-secondary);\x20padding:\x202rem;\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20No\x20teams\x20yet.\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage')?'Click\x20<strong>Create\x20Team</strong>\x20to\x20get\x20started.':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20</tr>';return;}const _0x5075eb=Permissions['hasServerPermission'](state['currentUser'],'*');_0x383e6e['innerHTML']=state['teams']['map'](_0x113658=>{const _0x14671e=_0x5075eb||_0x113658['canManageTeam'],_0x209c5c=_0x5075eb||_0x113658['canManageMembers'],_0x4a0d59=_0x14671e||_0x209c5c,_0x5f0bae=(_0x113658['members']||[])['length'];return'\x0a\x20\x20\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20style=\x22font-weight:\x20600;\x22>'+Utils['escapeHtml'](_0x113658['name'])+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x113658['description']?'<div\x20style=\x22font-size:\x200.8em;\x20color:\x20var(--color-text-secondary);\x20margin-top:\x200.15rem;\x22>'+Utils['escapeHtml'](_0x113658['description'])+'</div>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+_0x5f0bae+'</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22user-actions\x22\x20style=\x22display:\x20flex;\x20gap:\x200.25rem;\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x4a0d59?'<button\x20class=\x22btn-icon\x22\x20title=\x22Edit\x20team\x22\x20onclick=\x22window.openTeamModal(\x27'+_0x113658['id']+'\x27)\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2216\x22\x20height=\x2216\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M11\x204H4a2\x202\x200\x200\x200-2\x202v14a2\x202\x200\x200\x200\x202\x202h14a2\x202\x200\x200\x200\x202-2v-7\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M18.5\x202.5a2.121\x202.121\x200\x200\x201\x203\x203L12\x2015l-4\x201\x201-4\x209.5-9.5z\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x14671e?'<button\x20class=\x22btn-icon\x22\x20title=\x22Access\x20bindings\x22\x20onclick=\x22window.openBindingsModal(\x27'+_0x113658['id']+'\x27)\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2216\x22\x20height=\x2216\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M12\x2022s8-4\x208-10V5l-8-3-8\x203v7c0\x206\x208\x2010\x208\x2010z\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x14671e?'<button\x20class=\x22btn-icon\x20btn-danger\x22\x20title=\x22Delete\x20team\x22\x20onclick=\x22window.deleteTeam(\x27'+_0x113658['id']+'\x27)\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2216\x22\x20height=\x2216\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<polyline\x20points=\x223\x206\x205\x206\x2021\x206\x22></polyline>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M19\x206v14a2\x202\x200\x200\x201-2\x202H7a2\x202\x200\x200\x201-2-2V6m3\x200V4a2\x202\x200\x200\x201\x202-2h4a2\x202\x200\x200\x201\x202\x202v2\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20</tr>';})['join']('');}function bindEventListeners(){document['getElementById']('create-team-btn')?.['addEventListener']('click',showCreateTeamModal),document['getElementById']('retry-teams-btn')?.['addEventListener']('click',loadTeams),document['getElementById']('close-team-modal')?.['addEventListener']('click',requestHideTeamModal),document['getElementById']('cancel-team')?.['addEventListener']('click',requestHideTeamModal),document['getElementById']('save-team')?.['addEventListener']('click',saveTeam),document['querySelector']('#team-modal\x20.modal-overlay')?.['addEventListener']('click',requestHideTeamModal),document['getElementById']('add-member-btn')?.['addEventListener']('click',addMember),document['getElementById']('close-bindings-modal')?.['addEventListener']('click',hideBindingsModal),document['querySelector']('#bindings-modal\x20.modal-overlay')?.['addEventListener']('click',hideBindingsModal),document['getElementById']('add-binding-btn')?.['addEventListener']('click',()=>{document['getElementById']('add-binding-form')['hidden']=![],document['getElementById']('add-binding-btn')['hidden']=!![],populateBindingForm();}),document['getElementById']('cancel-binding-btn')?.['addEventListener']('click',()=>{document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![];}),document['getElementById']('save-binding-btn')?.['addEventListener']('click',saveBinding),document['getElementById']('binding-resource-type')?.['addEventListener']('change',onBindingResourceTypeChange),document['getElementById']('close-delete-team-modal')?.['addEventListener']('click',hideDeleteModal),document['getElementById']('cancel-delete-team')?.['addEventListener']('click',hideDeleteModal),document['getElementById']('confirm-delete-team')?.['addEventListener']('click',confirmDeleteTeam),document['querySelector']('#delete-team-modal\x20.modal-overlay')?.['addEventListener']('click',hideDeleteModal);}function showCreateTeamModal(){state['editingTeamId']=null,state['modalSnapshot']={'name':'','description':''},document['getElementById']('team-modal-title')['textContent']='Create\x20Team',document['getElementById']('team-name')['value']='',document['getElementById']('team-name')['disabled']=![],document['getElementById']('team-description')['value']='',document['getElementById']('team-description')['disabled']=![],document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=!![],document['getElementById']('save-team')['hidden']=![],document['getElementById']('team-modal-footer')['hidden']=![],document['getElementById']('team-modal')['hidden']=![],setTimeout(()=>document['getElementById']('team-name')['focus'](),0x64);}window['openTeamModal']=function(_0x191b33){const _0x5ac3ca=state['teams']['find'](_0x8c2e00=>_0x8c2e00['id']===_0x191b33);if(!_0x5ac3ca)return;state['editingTeamId']=_0x191b33;const _0x16eb21=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x590289=_0x16eb21||_0x5ac3ca['canManageTeam'],_0x262970=_0x16eb21||_0x5ac3ca['canManageMembers'],_0x55cc2c=_0x590289,_0x249ce1=_0x590289||_0x262970,_0x18e8c5=_0x5ac3ca['name'],_0xcec83e=_0x5ac3ca['description']||'';state['modalSnapshot']={'name':_0x18e8c5,'description':_0xcec83e},document['getElementById']('team-modal-title')['textContent']=_0x18e8c5,document['getElementById']('team-name')['value']=_0x18e8c5,document['getElementById']('team-name')['disabled']=!_0x55cc2c,document['getElementById']('team-description')['value']=_0xcec83e,document['getElementById']('team-description')['disabled']=!_0x55cc2c,document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=![],document['getElementById']('save-team')['hidden']=!_0x55cc2c,renderMembersList(_0x5ac3ca),updateMemberSelect(_0x5ac3ca),document['getElementById']('team-modal')['hidden']=![];};function isTeamModalDirty(){if(!state['modalSnapshot'])return![];const _0x428d4f=document['getElementById']('team-name')['value']['trim'](),_0x1fc31a=document['getElementById']('team-description')['value']['trim']();return _0x428d4f!==state['modalSnapshot']['name']||_0x1fc31a!==state['modalSnapshot']['description'];}function requestHideTeamModal(){if(isTeamModalDirty()){if(!confirm('You\x20have\x20unsaved\x20changes.\x20Discard\x20them?'))return;}hideTeamModal();}function hideTeamModal(){document['getElementById']('team-modal')['hidden']=!![],document['getElementById']('team-name')['disabled']=![],document['getElementById']('team-description')['disabled']=![],state['editingTeamId']=null,state['modalSnapshot']=null;}window['openBindingsModal']=function(_0x2f1bed){const _0x43714d=state['teams']['find'](_0x1e74b2=>_0x1e74b2['id']===_0x2f1bed);if(!_0x43714d)return;state['bindingsTeamId']=_0x2f1bed,document['getElementById']('bindings-modal-title')['textContent']='Access\x20Bindings\x20—\x20'+_0x43714d['name'],document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('bindings-modal')['hidden']=![],loadTeamBindings(_0x2f1bed);};function hideBindingsModal(){document['getElementById']('bindings-modal')['hidden']=!![],state['bindingsTeamId']=null;}function renderMembersList(_0x29e5a0){const _0x153307=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x18b2f4=_0x153307||_0x29e5a0['canManageMembers']||_0x29e5a0['canManageTeam'],_0x5b0625=_0x29e5a0['members']||[],_0x5e5410=document['getElementById']('members-list');if(_0x5b0625['length']===0x0){_0x5e5410['innerHTML']='<p\x20style=\x22font-size:\x200.875rem;\x20color:\x20var(--color-text-secondary);\x20margin:\x200.25rem\x200;\x22>No\x20members\x20yet</p>';return;}_0x5e5410['innerHTML']=_0x5b0625['map'](_0x4f937a=>{const _0x25416e=state['users']['find'](_0x3bd4f4=>_0x3bd4f4['id']===_0x4f937a),_0x58f256=_0x25416e?''+Utils['escapeHtml'](_0x25416e['username'])+(_0x25416e['name']?'\x20<span\x20style=\x22color:\x20var(--color-text-secondary);\x20font-size:\x200.85em;\x22>('+Utils['escapeHtml'](_0x25416e['name'])+')</span>':''):Utils['escapeHtml'](_0x4f937a);return'\x0a\x20\x20\x20\x20\x20\x20<div\x20style=\x22display:\x20flex;\x20align-items:\x20center;\x20justify-content:\x20space-between;\x20padding:\x200.35rem\x200;\x20border-bottom:\x201px\x20solid\x20var(--color-border);\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<span\x20style=\x22font-size:\x200.875rem;\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x58f256+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x18b2f4?'<button\x20type=\x22button\x22\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.removeMemberClick(\x27'+_0x4f937a+'\x27)\x22\x20style=\x22color:\x20var(--color-danger);\x20padding:\x200.15rem\x200.4rem;\x20font-size:\x200.8rem;\x22>Remove</button>':'')+'\x0a\x20\x20\x20\x20\x20\x20</div>';})['join']('');const _0x2d404e=document['getElementById']('add-member-row');if(_0x2d404e)_0x2d404e['style']['display']=_0x18b2f4?'flex':'none';}function updateMemberSelect(_0x318301){const _0x4aba73=document['getElementById']('add-member-select');if(!_0x4aba73)return;const _0x1747f3=new Set(_0x318301['members']||[]),_0xb2f04a=state['users']['filter'](_0x142ca2=>!_0x1747f3['has'](_0x142ca2['id']));_0x4aba73['innerHTML']='<option\x20value=\x22\x22>Add\x20a\x20member…</option>'+_0xb2f04a['map'](_0x1f8ca1=>'<option\x20value=\x22'+_0x1f8ca1['id']+'\x22>'+Utils['escapeHtml'](_0x1f8ca1['username'])+(_0x1f8ca1['name']?'\x20('+Utils['escapeHtml'](_0x1f8ca1['name'])+')':'')+'</option>')['join']('');}async function addMember(){const _0x5228ab=document['getElementById']('add-member-select'),_0x3f6d36=_0x5228ab['value'];if(!_0x3f6d36||!state['editingTeamId'])return;try{const {team:_0x2ee22a}=await API['addTeamMember'](state['editingTeamId'],_0x3f6d36);syncTeamInState(_0x2ee22a),renderMembersList(_0x2ee22a),updateMemberSelect(_0x2ee22a),_0x5228ab['value']='',Utils['showToast']('Member\x20added','success');}catch(_0x41f130){Utils['showToast'](_0x41f130['message'],'error');}}window['removeMemberClick']=async function(_0x9861bd){if(!state['editingTeamId'])return;try{const {team:_0x3712f8}=await API['removeTeamMember'](state['editingTeamId'],_0x9861bd);syncTeamInState(_0x3712f8),renderMembersList(_0x3712f8),updateMemberSelect(_0x3712f8),Utils['showToast']('Member\x20removed','success');}catch(_0x24e079){Utils['showToast'](_0x24e079['message'],'error');}};async function loadTeamBindings(_0x2b813c){const _0x182db3=document['getElementById']('bindings-loading'),_0x518290=document['getElementById']('bindings-empty'),_0x56d112=document['getElementById']('bindings-list-container'),_0x2c0444=document['getElementById']('add-binding-btn');_0x182db3['hidden']=![],_0x518290['hidden']=!![],_0x56d112['style']['display']='none',_0x2c0444['hidden']=!![],document['getElementById']('add-binding-form')['hidden']=!![];try{const {bindings:_0xf16268}=await API['getBindings']({'subject_type':'team','subject_id':_0x2b813c});state['teamBindings']=_0xf16268||[],_0x182db3['hidden']=!![],state['teamBindings']['length']===0x0?_0x518290['hidden']=![]:(_0x56d112['style']['display']='',renderBindingsTable()),(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage'))&&(_0x2c0444['hidden']=![]);}catch(_0x4a94c7){_0x182db3['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x4a94c7['message'],'error');}}function renderBindingsTable(){const _0x4f2928=document['getElementById']('bindings-table-body');if(!_0x4f2928)return;const _0x4135b3=Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage');_0x4f2928['innerHTML']=state['teamBindings']['map'](_0xa0e590=>{const _0x5e7ccc=_0xa0e590['resource_type']==='server'?'Server':_0xa0e590['resource_id']==='*'?'All\x20'+_0xa0e590['resource_type']+'s':Utils['escapeHtml'](_0xa0e590['resource_name']||_0xa0e590['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x5e7ccc+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0xa0e590['role_name']||_0xa0e590['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x4135b3?'<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteBindingClick(\x27'+_0xa0e590['id']+'\x27)\x22\x20style=\x22color:\x20var(--color-danger);\x22>Remove</button>':'—')+'\x0a\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20</tr>';})['join']('');}function populateBindingForm(){const _0x4560b4=document['getElementById']('binding-resource-type');_0x4560b4['value']='environment',updateBindingFormForResourceType('environment');}function onBindingResourceTypeChange(){const _0x168aea=document['getElementById']('binding-resource-type')['value'];updateBindingFormForResourceType(_0x168aea);}function updateBindingFormForResourceType(_0x4ecc6f){const _0x3a6619=document['getElementById']('binding-resource-container'),_0x24393c=document['getElementById']('binding-resource'),_0x1f83bc=document['getElementById']('binding-role');if(_0x4ecc6f==='server')_0x3a6619['style']['display']='none';else{_0x3a6619['style']['display']='';if(_0x4ecc6f==='environment'){const _0x36b901=new Set(state['teamBindings']['filter'](_0x2d29ab=>_0x2d29ab['resource_type']==='environment')['map'](_0x123b81=>_0x123b81['resource_id'])),_0xdda47e=state['environments']['filter'](_0x89be3=>!_0x36b901['has'](_0x89be3['name']));_0x24393c['innerHTML']=_0xdda47e['length']?_0xdda47e['map'](_0x46baa4=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x46baa4['name'])+'\x22>'+Utils['escapeHtml'](_0x46baa4['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x4ecc6f==='team'){const _0xf146d7=new Set(state['teamBindings']['filter'](_0x3d3372=>_0x3d3372['resource_type']==='team')['map'](_0x591bd3=>_0x591bd3['resource_id'])),_0x179a93=state['teams']['filter'](_0x318097=>!_0xf146d7['has'](_0x318097['id']));_0x24393c['innerHTML']=_0x179a93['length']?_0x179a93['map'](_0x2eeb29=>'<option\x20value=\x22'+_0x2eeb29['id']+'\x22>'+Utils['escapeHtml'](_0x2eeb29['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x50d9f6=state['roles']['filter'](_0x59f3ef=>_0x59f3ef['resource_type']===_0x4ecc6f);_0x1f83bc['innerHTML']=_0x50d9f6['length']?_0x50d9f6['filter'](_0x5ecb7a=>{const _0x7bdead=_0x4ecc6f==='server'?undefined:_0x24393c['value'];return!state['teamBindings']['some'](_0x3933d2=>_0x3933d2['resource_type']===_0x4ecc6f&&_0x3933d2['role_id']===_0x5ecb7a['id']&&(_0x4ecc6f==='server'||_0x3933d2['resource_id']===_0x7bdead));})['map'](_0x53f9a3=>'<option\x20value=\x22'+_0x53f9a3['id']+'\x22>'+Utils['escapeHtml'](_0x53f9a3['name'])+'</option>')['join']('')||'<option\x20value=\x22\x22>No\x20available\x20roles</option>':'<option\x20value=\x22\x22>No\x20roles\x20for\x20this\x20resource\x20type</option>';}async function saveBinding(){const _0x34d511=document['getElementById']('binding-resource-type')['value'],_0x215889=document['getElementById']('binding-role')['value'];if(!_0x215889||!state['bindingsTeamId'])return;const _0x1a3603=_0x34d511==='server'?undefined:document['getElementById']('binding-resource')['value'];if(_0x34d511!=='server'&&!_0x1a3603)return;const _0x4391a7=document['getElementById']('save-binding-btn');_0x4391a7['disabled']=!![],_0x4391a7['textContent']='Adding…';try{const _0x2404be={'subject_type':'team','subject_id':state['bindingsTeamId'],'role_id':_0x215889,'resource_type':_0x34d511};if(_0x1a3603)_0x2404be['resource_id']=_0x1a3603;await API['createBinding'](_0x2404be),Utils['showToast']('Binding\x20added','success'),document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![],await loadTeamBindings(state['bindingsTeamId']);}catch(_0x1e6aea){Utils['showToast'](_0x1e6aea['message'],'error');}finally{_0x4391a7['disabled']=![],_0x4391a7['textContent']='Add\x20Binding';}}window['deleteBindingClick']=async function(_0x2f495d){try{await API['deleteBinding'](_0x2f495d),Utils['showToast']('Binding\x20removed','success'),await loadTeamBindings(state['bindingsTeamId']);}catch(_0x348062){Utils['showToast'](_0x348062['message'],'error');}};async function saveTeam(){const _0x5f22e7=document['getElementById']('team-name')['value']['trim'](),_0x58f856=document['getElementById']('team-description')['value']['trim'](),_0x57d739=document['getElementById']('team-form-error'),_0x54fc38=document['getElementById']('save-team');if(!_0x5f22e7){_0x57d739['textContent']='Team\x20name\x20is\x20required',_0x57d739['hidden']=![];return;}_0x57d739['hidden']=!![];const _0x4a825c=_0x54fc38['textContent'];_0x54fc38['disabled']=!![],_0x54fc38['textContent']=state['editingTeamId']?'Saving…':'Creating…';try{if(state['editingTeamId']){const {team:_0x990f35}=await API['updateTeam'](state['editingTeamId'],{'name':_0x5f22e7,'description':_0x58f856});syncTeamInState(_0x990f35),document['getElementById']('team-modal-title')['textContent']=_0x990f35['name'],Utils['showToast']('Team\x20updated','success');}else await API['createTeam']({'name':_0x5f22e7,'description':_0x58f856}),Utils['showToast']('Team\x20created','success');_0x54fc38['disabled']=![],_0x54fc38['textContent']=_0x4a825c,hideTeamModal(),await loadTeams();}catch(_0x1bb954){_0x57d739['textContent']=_0x1bb954['message'],_0x57d739['hidden']=![],_0x54fc38['disabled']=![],_0x54fc38['textContent']=_0x4a825c;}}window['deleteTeam']=function(_0x264344){const _0x20a39a=state['teams']['find'](_0x2163be=>_0x2163be['id']===_0x264344);if(!_0x20a39a)return;state['deletingTeamId']=_0x264344,document['getElementById']('delete-team-name')['textContent']=_0x20a39a['name'],document['getElementById']('delete-team-modal')['hidden']=![];};function hideDeleteModal(){document['getElementById']('delete-team-modal')['hidden']=!![],state['deletingTeamId']=null;}async function confirmDeleteTeam(){if(!state['deletingTeamId'])return;const _0x38f20a=document['getElementById']('confirm-delete-team');_0x38f20a['disabled']=!![],_0x38f20a['textContent']='Deleting…';try{await API['deleteTeam'](state['deletingTeamId']),Utils['showToast']('Team\x20deleted','success'),_0x38f20a['disabled']=![],_0x38f20a['textContent']='Delete\x20Team',hideDeleteModal(),await loadTeams();}catch(_0x25bcc4){Utils['showToast']('Failed\x20to\x20delete\x20team:\x20'+_0x25bcc4['message'],'error'),_0x38f20a['disabled']=![],_0x38f20a['textContent']='Delete\x20Team';}}function syncTeamInState(_0x8d1482){const _0x2eac60=state['teams']['findIndex'](_0x37df84=>_0x37df84['id']===_0x8d1482['id']);if(_0x2eac60>=0x0)state['teams'][_0x2eac60]=_0x8d1482;renderTeams();}
1
+ import{API,Utils,initializeAdminMenu}from'./app.js';import{initTheme,mountThemeToggle}from'./theme.js';const state={'teams':[],'users':[],'roles':[],'environments':[],'teamBindings':[],'currentUser':null,'editingTeamId':null,'bindingsTeamId':null,'deletingTeamId':null,'modalSnapshot':null};document['addEventListener']('DOMContentLoaded',async()=>{initTheme(),mountThemeToggle();try{state['currentUser']=await API['getCurrentUser']();}catch{window['location']['href']='login.html';return;}await initializeAdminMenu(state['currentUser']);const _0x52fadc=state['currentUser'];if(!Permissions['hasServerPermission'](_0x52fadc,'*')&&!Permissions['hasTeamPermission'](_0x52fadc,'teams:manage')&&!Permissions['hasAnyEnvironment'](_0x52fadc)){Utils['showToast']('Access\x20denied:\x20You\x20do\x20not\x20have\x20permission\x20to\x20view\x20teams','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}(Permissions['hasServerPermission'](_0x52fadc,'*')||Permissions['hasTeamPermission'](_0x52fadc,'teams:manage'))&&(document['getElementById']('create-team-btn')['hidden']=![]),bindEventListeners(),await Promise['all']([loadTeams(),loadUsers(),loadRoles(),loadEnvironments()]),renderTeams();});async function loadTeams(){const _0xfe8779=document['getElementById']('teams-loading'),_0x46a239=document['getElementById']('teams-error'),_0x3d214d=document['getElementById']('teams-content');try{_0xfe8779['hidden']=![],_0x46a239['hidden']=!![],_0x3d214d['hidden']=!![];const {teams:_0xc0ced2}=await API['getTeams']();state['teams']=_0xc0ced2||[],renderTeams(),_0xfe8779['hidden']=!![],_0x3d214d['hidden']=![];}catch(_0x33387d){_0xfe8779['hidden']=!![],_0x46a239['hidden']=![],document['getElementById']('teams-error-message')['textContent']=_0x33387d['message'];}}async function loadUsers(){try{const {users:_0x3a76eb}=await API['getUsers']();state['users']=_0x3a76eb||[];}catch{state['users']=[];}}async function loadRoles(){try{const {roles:_0x153870}=await API['getRoleDefinitions']();state['roles']=_0x153870||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x2965f8=await API['getEnvironments']();state['environments']=_0x2965f8['environments']||[];}catch{state['environments']=[];}}function renderTeams(){const _0x41b505=document['getElementById']('teams-table-body'),_0x27efdc=document['getElementById']('team-count');if(!_0x41b505)return;_0x27efdc&&(_0x27efdc['textContent']=state['teams']['length']+'\x20team'+(state['teams']['length']===0x1?'':'s'));if(state['teams']['length']===0x0){_0x41b505['innerHTML']='\x0a\x20\x20\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td\x20colspan=\x223\x22\x20style=\x22text-align:\x20center;\x20color:\x20var(--color-text-secondary);\x20padding:\x202rem;\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20No\x20teams\x20yet.\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage')?'Click\x20<strong>Create\x20Team</strong>\x20to\x20get\x20started.':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20</tr>';return;}const _0x3d29e2=Permissions['hasServerPermission'](state['currentUser'],'*');_0x41b505['innerHTML']=state['teams']['map'](_0x5e48ae=>{const _0x55072d=_0x3d29e2||_0x5e48ae['canManageTeam'],_0x104fa7=_0x3d29e2||_0x5e48ae['canManageMembers'],_0x33efe4=_0x55072d||_0x104fa7,_0xa91122=(_0x5e48ae['members']||[])['length'];return'\x0a\x20\x20\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20style=\x22font-weight:\x20600;\x22>'+Utils['escapeHtml'](_0x5e48ae['name'])+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x5e48ae['description']?'<div\x20style=\x22font-size:\x200.8em;\x20color:\x20var(--color-text-secondary);\x20margin-top:\x200.15rem;\x22>'+Utils['escapeHtml'](_0x5e48ae['description'])+'</div>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+_0xa91122+'</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22user-actions\x22\x20style=\x22display:\x20flex;\x20gap:\x200.25rem;\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x33efe4?'<button\x20class=\x22btn-icon\x22\x20title=\x22Edit\x20team\x22\x20onclick=\x22window.openTeamModal(\x27'+_0x5e48ae['id']+'\x27)\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2216\x22\x20height=\x2216\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M11\x204H4a2\x202\x200\x200\x200-2\x202v14a2\x202\x200\x200\x200\x202\x202h14a2\x202\x200\x200\x200\x202-2v-7\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M18.5\x202.5a2.121\x202.121\x200\x200\x201\x203\x203L12\x2015l-4\x201\x201-4\x209.5-9.5z\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x55072d?'<button\x20class=\x22btn-icon\x22\x20title=\x22Access\x20bindings\x22\x20onclick=\x22window.openBindingsModal(\x27'+_0x5e48ae['id']+'\x27)\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2216\x22\x20height=\x2216\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M12\x2022s8-4\x208-10V5l-8-3-8\x203v7c0\x206\x208\x2010\x208\x2010z\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x55072d?'<button\x20class=\x22btn-icon\x20btn-danger\x22\x20title=\x22Delete\x20team\x22\x20onclick=\x22window.deleteTeam(\x27'+_0x5e48ae['id']+'\x27)\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2216\x22\x20height=\x2216\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<polyline\x20points=\x223\x206\x205\x206\x2021\x206\x22></polyline>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M19\x206v14a2\x202\x200\x200\x201-2\x202H7a2\x202\x200\x200\x201-2-2V6m3\x200V4a2\x202\x200\x200\x201\x202-2h4a2\x202\x200\x200\x201\x202\x202v2\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20</tr>';})['join']('');}function bindEventListeners(){document['getElementById']('create-team-btn')?.['addEventListener']('click',showCreateTeamModal),document['getElementById']('retry-teams-btn')?.['addEventListener']('click',loadTeams),document['getElementById']('close-team-modal')?.['addEventListener']('click',requestHideTeamModal),document['getElementById']('cancel-team')?.['addEventListener']('click',requestHideTeamModal),document['getElementById']('save-team')?.['addEventListener']('click',saveTeam),document['querySelector']('#team-modal\x20.modal-overlay')?.['addEventListener']('click',requestHideTeamModal),document['getElementById']('add-member-btn')?.['addEventListener']('click',addMember),document['getElementById']('close-bindings-modal')?.['addEventListener']('click',hideBindingsModal),document['querySelector']('#bindings-modal\x20.modal-overlay')?.['addEventListener']('click',hideBindingsModal),document['getElementById']('add-binding-btn')?.['addEventListener']('click',()=>{document['getElementById']('add-binding-form')['hidden']=![],document['getElementById']('add-binding-btn')['hidden']=!![],populateBindingForm();}),document['getElementById']('cancel-binding-btn')?.['addEventListener']('click',()=>{document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![];}),document['getElementById']('save-binding-btn')?.['addEventListener']('click',saveBinding),document['getElementById']('binding-resource-type')?.['addEventListener']('change',onBindingResourceTypeChange),document['getElementById']('close-delete-team-modal')?.['addEventListener']('click',hideDeleteModal),document['getElementById']('cancel-delete-team')?.['addEventListener']('click',hideDeleteModal),document['getElementById']('confirm-delete-team')?.['addEventListener']('click',confirmDeleteTeam),document['querySelector']('#delete-team-modal\x20.modal-overlay')?.['addEventListener']('click',hideDeleteModal);}function showCreateTeamModal(){state['editingTeamId']=null,state['modalSnapshot']={'name':'','description':''},document['getElementById']('team-modal-title')['textContent']='Create\x20Team',document['getElementById']('team-name')['value']='',document['getElementById']('team-name')['disabled']=![],document['getElementById']('team-description')['value']='',document['getElementById']('team-description')['disabled']=![],document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=!![],document['getElementById']('save-team')['hidden']=![],document['getElementById']('team-modal-footer')['hidden']=![],document['getElementById']('team-modal')['hidden']=![],setTimeout(()=>document['getElementById']('team-name')['focus'](),0x64);}window['openTeamModal']=function(_0x323f78){const _0x11d0f1=state['teams']['find'](_0x32ebf0=>_0x32ebf0['id']===_0x323f78);if(!_0x11d0f1)return;state['editingTeamId']=_0x323f78;const _0x3d9c66=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x3d4282=_0x3d9c66||_0x11d0f1['canManageTeam'],_0x37c232=_0x3d9c66||_0x11d0f1['canManageMembers'],_0x454ccc=_0x3d4282,_0xec64c2=_0x3d4282||_0x37c232,_0x54bf50=_0x11d0f1['name'],_0x5f48c6=_0x11d0f1['description']||'';state['modalSnapshot']={'name':_0x54bf50,'description':_0x5f48c6},document['getElementById']('team-modal-title')['textContent']=_0x54bf50,document['getElementById']('team-name')['value']=_0x54bf50,document['getElementById']('team-name')['disabled']=!_0x454ccc,document['getElementById']('team-description')['value']=_0x5f48c6,document['getElementById']('team-description')['disabled']=!_0x454ccc,document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=![],document['getElementById']('save-team')['hidden']=!_0x454ccc,renderMembersList(_0x11d0f1),updateMemberSelect(_0x11d0f1),document['getElementById']('team-modal')['hidden']=![];};function isTeamModalDirty(){if(!state['modalSnapshot'])return![];const _0x3af903=document['getElementById']('team-name')['value']['trim'](),_0x223008=document['getElementById']('team-description')['value']['trim']();return _0x3af903!==state['modalSnapshot']['name']||_0x223008!==state['modalSnapshot']['description'];}function requestHideTeamModal(){if(isTeamModalDirty()){if(!confirm('You\x20have\x20unsaved\x20changes.\x20Discard\x20them?'))return;}hideTeamModal();}function hideTeamModal(){document['getElementById']('team-modal')['hidden']=!![],document['getElementById']('team-name')['disabled']=![],document['getElementById']('team-description')['disabled']=![],state['editingTeamId']=null,state['modalSnapshot']=null;}window['openBindingsModal']=function(_0x386520){const _0x4eea26=state['teams']['find'](_0x368602=>_0x368602['id']===_0x386520);if(!_0x4eea26)return;state['bindingsTeamId']=_0x386520,document['getElementById']('bindings-modal-title')['textContent']='Access\x20Bindings\x20—\x20'+_0x4eea26['name'],document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('bindings-modal')['hidden']=![],loadTeamBindings(_0x386520);};function hideBindingsModal(){document['getElementById']('bindings-modal')['hidden']=!![],state['bindingsTeamId']=null;}function renderMembersList(_0x5d1213){const _0x15f5b3=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x2a3467=_0x15f5b3||_0x5d1213['canManageMembers']||_0x5d1213['canManageTeam'],_0x24fae5=_0x5d1213['members']||[],_0x4d86dc=document['getElementById']('members-list');if(_0x24fae5['length']===0x0){_0x4d86dc['innerHTML']='<p\x20style=\x22font-size:\x200.875rem;\x20color:\x20var(--color-text-secondary);\x20margin:\x200.25rem\x200;\x22>No\x20members\x20yet</p>';return;}_0x4d86dc['innerHTML']=_0x24fae5['map'](_0x1754f5=>{const _0x4db157=state['users']['find'](_0x57f974=>_0x57f974['id']===_0x1754f5),_0x22d5be=_0x4db157?''+Utils['escapeHtml'](_0x4db157['username'])+(_0x4db157['name']?'\x20<span\x20style=\x22color:\x20var(--color-text-secondary);\x20font-size:\x200.85em;\x22>('+Utils['escapeHtml'](_0x4db157['name'])+')</span>':''):Utils['escapeHtml'](_0x1754f5);return'\x0a\x20\x20\x20\x20\x20\x20<div\x20style=\x22display:\x20flex;\x20align-items:\x20center;\x20justify-content:\x20space-between;\x20padding:\x200.35rem\x200;\x20border-bottom:\x201px\x20solid\x20var(--color-border);\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<span\x20style=\x22font-size:\x200.875rem;\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x22d5be+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x2a3467?'<button\x20type=\x22button\x22\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.removeMemberClick(\x27'+_0x1754f5+'\x27)\x22\x20style=\x22color:\x20var(--color-danger);\x20padding:\x200.15rem\x200.4rem;\x20font-size:\x200.8rem;\x22>Remove</button>':'')+'\x0a\x20\x20\x20\x20\x20\x20</div>';})['join']('');const _0x1bdb07=document['getElementById']('add-member-row');if(_0x1bdb07)_0x1bdb07['style']['display']=_0x2a3467?'flex':'none';}function updateMemberSelect(_0x4d4ed5){const _0x59ae73=document['getElementById']('add-member-select');if(!_0x59ae73)return;const _0x4e48a9=new Set(_0x4d4ed5['members']||[]),_0x2e00b3=state['users']['filter'](_0x277eab=>!_0x4e48a9['has'](_0x277eab['id']));_0x59ae73['innerHTML']='<option\x20value=\x22\x22>Add\x20a\x20member…</option>'+_0x2e00b3['map'](_0xb1b1a3=>'<option\x20value=\x22'+_0xb1b1a3['id']+'\x22>'+Utils['escapeHtml'](_0xb1b1a3['username'])+(_0xb1b1a3['name']?'\x20('+Utils['escapeHtml'](_0xb1b1a3['name'])+')':'')+'</option>')['join']('');}async function addMember(){const _0x4ffa0e=document['getElementById']('add-member-select'),_0xc65394=_0x4ffa0e['value'];if(!_0xc65394||!state['editingTeamId'])return;try{const {team:_0x97c472}=await API['addTeamMember'](state['editingTeamId'],_0xc65394);syncTeamInState(_0x97c472),renderMembersList(_0x97c472),updateMemberSelect(_0x97c472),_0x4ffa0e['value']='',Utils['showToast']('Member\x20added','success');}catch(_0x4c25ba){Utils['showToast'](_0x4c25ba['message'],'error');}}window['removeMemberClick']=async function(_0x45fc5f){if(!state['editingTeamId'])return;try{const {team:_0x372d0e}=await API['removeTeamMember'](state['editingTeamId'],_0x45fc5f);syncTeamInState(_0x372d0e),renderMembersList(_0x372d0e),updateMemberSelect(_0x372d0e),Utils['showToast']('Member\x20removed','success');}catch(_0x27b8a0){Utils['showToast'](_0x27b8a0['message'],'error');}};async function loadTeamBindings(_0x44de38){const _0x52ab07=document['getElementById']('bindings-loading'),_0x2f65ee=document['getElementById']('bindings-empty'),_0x2979d0=document['getElementById']('bindings-list-container'),_0x3e4d43=document['getElementById']('add-binding-btn');_0x52ab07['hidden']=![],_0x2f65ee['hidden']=!![],_0x2979d0['style']['display']='none',_0x3e4d43['hidden']=!![],document['getElementById']('add-binding-form')['hidden']=!![];try{const {bindings:_0x1a206b}=await API['getBindings']({'subject_type':'team','subject_id':_0x44de38});state['teamBindings']=_0x1a206b||[],_0x52ab07['hidden']=!![],state['teamBindings']['length']===0x0?_0x2f65ee['hidden']=![]:(_0x2979d0['style']['display']='',renderBindingsTable()),(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage'))&&(_0x3e4d43['hidden']=![]);}catch(_0x2675a0){_0x52ab07['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x2675a0['message'],'error');}}function renderBindingsTable(){const _0x2ebeb1=document['getElementById']('bindings-table-body');if(!_0x2ebeb1)return;const _0x5e1306=Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage');_0x2ebeb1['innerHTML']=state['teamBindings']['map'](_0x9b3bdb=>{const _0x5080c0=_0x9b3bdb['resource_type']==='server'?'Server':_0x9b3bdb['resource_id']==='*'?'All\x20'+_0x9b3bdb['resource_type']+'s':Utils['escapeHtml'](_0x9b3bdb['resource_name']||_0x9b3bdb['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x5080c0+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x9b3bdb['role_name']||_0x9b3bdb['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x5e1306?'<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteBindingClick(\x27'+_0x9b3bdb['id']+'\x27)\x22\x20style=\x22color:\x20var(--color-danger);\x22>Remove</button>':'—')+'\x0a\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20</tr>';})['join']('');}function populateBindingForm(){const _0x3815f7=document['getElementById']('binding-resource-type');_0x3815f7['value']='environment',updateBindingFormForResourceType('environment');}function onBindingResourceTypeChange(){const _0x56f485=document['getElementById']('binding-resource-type')['value'];updateBindingFormForResourceType(_0x56f485);}function updateBindingFormForResourceType(_0x4f6d6d){const _0x4d1f30=document['getElementById']('binding-resource-container'),_0x38a7e9=document['getElementById']('binding-resource'),_0x1c9190=document['getElementById']('binding-role');if(_0x4f6d6d==='server')_0x4d1f30['style']['display']='none';else{_0x4d1f30['style']['display']='';if(_0x4f6d6d==='environment'){const _0x90af21=new Set(state['teamBindings']['filter'](_0x503a59=>_0x503a59['resource_type']==='environment')['map'](_0x1b72ee=>_0x1b72ee['resource_id'])),_0x1f5523=state['environments']['filter'](_0x434563=>!_0x90af21['has'](_0x434563['name']));_0x38a7e9['innerHTML']=_0x1f5523['length']?_0x1f5523['map'](_0x132ffc=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x132ffc['name'])+'\x22>'+Utils['escapeHtml'](_0x132ffc['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x4f6d6d==='team'){const _0x5cc237=new Set(state['teamBindings']['filter'](_0x3e00d1=>_0x3e00d1['resource_type']==='team')['map'](_0xee2fa5=>_0xee2fa5['resource_id'])),_0x17288f=state['teams']['filter'](_0x4eef1b=>!_0x5cc237['has'](_0x4eef1b['id']));_0x38a7e9['innerHTML']=_0x17288f['length']?_0x17288f['map'](_0x4622b8=>'<option\x20value=\x22'+_0x4622b8['id']+'\x22>'+Utils['escapeHtml'](_0x4622b8['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x110560=state['roles']['filter'](_0x78b7cd=>_0x78b7cd['resource_type']===_0x4f6d6d);_0x1c9190['innerHTML']=_0x110560['length']?_0x110560['filter'](_0x40390d=>{const _0x1f2e54=_0x4f6d6d==='server'?undefined:_0x38a7e9['value'];return!state['teamBindings']['some'](_0x1c3ae4=>_0x1c3ae4['resource_type']===_0x4f6d6d&&_0x1c3ae4['role_id']===_0x40390d['id']&&(_0x4f6d6d==='server'||_0x1c3ae4['resource_id']===_0x1f2e54));})['map'](_0x114eac=>'<option\x20value=\x22'+_0x114eac['id']+'\x22>'+Utils['escapeHtml'](_0x114eac['name'])+'</option>')['join']('')||'<option\x20value=\x22\x22>No\x20available\x20roles</option>':'<option\x20value=\x22\x22>No\x20roles\x20for\x20this\x20resource\x20type</option>';}async function saveBinding(){const _0x55596b=document['getElementById']('binding-resource-type')['value'],_0x26bc15=document['getElementById']('binding-role')['value'];if(!_0x26bc15||!state['bindingsTeamId'])return;const _0x1bfab0=_0x55596b==='server'?undefined:document['getElementById']('binding-resource')['value'];if(_0x55596b!=='server'&&!_0x1bfab0)return;const _0x25d3bf=document['getElementById']('save-binding-btn');_0x25d3bf['disabled']=!![],_0x25d3bf['textContent']='Adding…';try{const _0x13325a={'subject_type':'team','subject_id':state['bindingsTeamId'],'role_id':_0x26bc15,'resource_type':_0x55596b};if(_0x1bfab0)_0x13325a['resource_id']=_0x1bfab0;await API['createBinding'](_0x13325a),Utils['showToast']('Binding\x20added','success'),document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![],await loadTeamBindings(state['bindingsTeamId']);}catch(_0x366ad4){Utils['showToast'](_0x366ad4['message'],'error');}finally{_0x25d3bf['disabled']=![],_0x25d3bf['textContent']='Add\x20Binding';}}window['deleteBindingClick']=async function(_0x48ba33){try{await API['deleteBinding'](_0x48ba33),Utils['showToast']('Binding\x20removed','success'),await loadTeamBindings(state['bindingsTeamId']);}catch(_0x37f6e0){Utils['showToast'](_0x37f6e0['message'],'error');}};async function saveTeam(){const _0x3f1494=document['getElementById']('team-name')['value']['trim'](),_0x5c8a19=document['getElementById']('team-description')['value']['trim'](),_0x2e6432=document['getElementById']('team-form-error'),_0x5e47e4=document['getElementById']('save-team');if(!_0x3f1494){_0x2e6432['textContent']='Team\x20name\x20is\x20required',_0x2e6432['hidden']=![];return;}_0x2e6432['hidden']=!![];const _0x3353b4=_0x5e47e4['textContent'];_0x5e47e4['disabled']=!![],_0x5e47e4['textContent']=state['editingTeamId']?'Saving…':'Creating…';try{if(state['editingTeamId']){const {team:_0x155938}=await API['updateTeam'](state['editingTeamId'],{'name':_0x3f1494,'description':_0x5c8a19});syncTeamInState(_0x155938),document['getElementById']('team-modal-title')['textContent']=_0x155938['name'],Utils['showToast']('Team\x20updated','success');}else await API['createTeam']({'name':_0x3f1494,'description':_0x5c8a19}),Utils['showToast']('Team\x20created','success');_0x5e47e4['disabled']=![],_0x5e47e4['textContent']=_0x3353b4,hideTeamModal(),await loadTeams();}catch(_0x114089){_0x2e6432['textContent']=_0x114089['message'],_0x2e6432['hidden']=![],_0x5e47e4['disabled']=![],_0x5e47e4['textContent']=_0x3353b4;}}window['deleteTeam']=function(_0x2396fe){const _0x24c809=state['teams']['find'](_0x2dba4b=>_0x2dba4b['id']===_0x2396fe);if(!_0x24c809)return;state['deletingTeamId']=_0x2396fe,document['getElementById']('delete-team-name')['textContent']=_0x24c809['name'],document['getElementById']('delete-team-modal')['hidden']=![];};function hideDeleteModal(){document['getElementById']('delete-team-modal')['hidden']=!![],state['deletingTeamId']=null;}async function confirmDeleteTeam(){if(!state['deletingTeamId'])return;const _0x5848e9=document['getElementById']('confirm-delete-team');_0x5848e9['disabled']=!![],_0x5848e9['textContent']='Deleting…';try{await API['deleteTeam'](state['deletingTeamId']),Utils['showToast']('Team\x20deleted','success'),_0x5848e9['disabled']=![],_0x5848e9['textContent']='Delete\x20Team',hideDeleteModal(),await loadTeams();}catch(_0x4afb93){Utils['showToast']('Failed\x20to\x20delete\x20team:\x20'+_0x4afb93['message'],'error'),_0x5848e9['disabled']=![],_0x5848e9['textContent']='Delete\x20Team';}}function syncTeamInState(_0x294ae8){const _0x5d60fc=state['teams']['findIndex'](_0x503080=>_0x503080['id']===_0x294ae8['id']);if(_0x5d60fc>=0x0)state['teams'][_0x5d60fc]=_0x294ae8;renderTeams();}
@@ -1 +1 @@
1
- import{API,Utils}from'./app.js';import{Terminal}from'/vendor/xterm/5.3.0/xterm.esm.js';import{FitAddon}from'/vendor/xterm-addon-fit/0.7.0/xterm-addon-fit.esm.js';import{getCurrentTheme,initTheme,mountThemeToggle,onThemeChange}from'./theme.js';const params=Utils['getQueryParams'](),containerId=params['container'],command=(params['cmd']||'')['trim'](),useServerExec=params['server_exec']==='true',isEmbedded=params['embedded']==='true',terminalTabId=params['tabId']||'',titleEl=document['getElementById']('terminal-title'),subtitleEl=document['getElementById']('terminal-subtitle'),statusEl=document['getElementById']('terminal-status'),terminalEl=document['getElementById']('terminal-container'),closeBtn=document['getElementById']('close-terminal');initTheme();isEmbedded?(document['documentElement']['classList']['add']('terminal-embedded'),document['body']['classList']['add']('terminal-embedded')):mountThemeToggle({'targetSelectors':['.terminal-actions']});const getXtermTheme=()=>{return{'background':'#0f172a','foreground':'#e2e8f0','cursor':'#e2e8f0','cursorAccent':'#0f172a'};};closeBtn&&closeBtn['addEventListener']('click',()=>{if(isEmbedded&&window['parent']&&window['parent']!==window){window['parent']['postMessage']({'type':'coderflow-terminal-close','tabId':terminalTabId},window['location']['origin']);return;}window['close']();});if(!containerId){updateStatus('Missing\x20container\x20identifier','error');throw new Error('container\x20parameter\x20is\x20required');}document['title']='Terminal\x20·\x20'+containerId['slice'](0x0,0xc),enrichContainerDetails(containerId)['catch'](()=>{subtitleEl['textContent']='Container\x20'+containerId['substring'](0x0,0xc);});const term=new Terminal({'convertEol':!![],'cursorBlink':!![],'fontFamily':'JetBrains\x20Mono,\x20SFMono-Regular,\x20Consolas,\x20monospace','fontSize':0x10,'theme':getXtermTheme()}),fitAddon=new FitAddon();term['loadAddon'](fitAddon),term['open'](terminalEl),term['focus']();let isFitting=![];const doFit=()=>{if(isFitting)return;isFitting=!![],fitAddon['fit'](),sendResize(),term['scrollToBottom'](),setTimeout(()=>{isFitting=![];},0x32);};window['addEventListener']('resize',()=>{requestAnimationFrame(()=>{!isFitting&&doFit();});});const resizeObserver=new ResizeObserver(()=>{requestAnimationFrame(()=>{!isFitting&&doFit();});});resizeObserver['observe'](terminalEl);const socketProtocol=window['location']['protocol']==='https:'?'wss':'ws',socketUrl=new URL('/ws/containers/'+encodeURIComponent(containerId),window['location']['href']);command&&useServerExec&&socketUrl['searchParams']['set']('cmd',command);socketUrl['protocol']=socketProtocol+':';const socket=new WebSocket(socketUrl['toString']());term['onData'](_0x27e3c5=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':_0x27e3c5}));});let commandSent=![],hasReceivedOutput=![];socket['addEventListener']('message',_0x28bc01=>{try{const _0x3ea49e=JSON['parse'](_0x28bc01['data']);if(_0x3ea49e['type']==='data'&&typeof _0x3ea49e['data']==='string')term['write'](_0x3ea49e['data']),!hasReceivedOutput&&_0x3ea49e['data']['length']>0x0&&(hasReceivedOutput=!![],command&&!useServerExec&&!commandSent&&(commandSent=!![],setTimeout(()=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':command+'\x0d'}));},0xc8)));else{if(_0x3ea49e['type']==='status'&&_0x3ea49e['status']){if(_0x3ea49e['status']==='connected'){if(command&&useServerExec)updateStatus('Running:\x20'+command,'info');else command?updateStatus('Preparing:\x20'+command,'info'):updateStatus('Terminal\x20connected','success');doFit(),term['focus'](),command&&!useServerExec&&!commandSent&&setTimeout(()=>{!commandSent&&socket['readyState']===WebSocket['OPEN']&&(commandSent=!![],socket['send'](JSON['stringify']({'type':'data','data':command+'\x0d'})),updateStatus('Running:\x20'+command,'info'));},0x7d0);}else updateStatus('Session\x20'+_0x3ea49e['status'],_0x3ea49e['status']==='connected'?'success':'info');}else _0x3ea49e['type']==='error'&&_0x3ea49e['message']&&updateStatus(_0x3ea49e['message'],'error');}}catch(_0x4bed96){console['error']('Failed\x20to\x20parse\x20terminal\x20message',_0x4bed96);}}),socket['addEventListener']('close',_0x498570=>{const _0x40960f=_0x498570['reason']||'Connection\x20closed';updateStatus(_0x40960f,_0x498570['wasClean']?'info':'error'),isEmbedded&&terminalTabId&&window['parent']&&window['parent']!==window&&window['parent']['postMessage']({'type':'coderflow-terminal-disconnected','tabId':terminalTabId},window['location']['origin']);}),socket['addEventListener']('error',_0x3b4a02=>{console['error']('Terminal\x20websocket\x20error',_0x3b4a02),updateStatus('Connection\x20error','error');});function sendResize(){if(socket['readyState']!==WebSocket['OPEN'])return;const _0x31f8ea=term['cols'],_0xc62233=term['rows'];socket['send'](JSON['stringify']({'type':'resize','cols':_0x31f8ea,'rows':_0xc62233}));}function updateStatus(_0x3996d7,_0x3d9d43='info'){if(!statusEl)return;statusEl['textContent']=_0x3996d7,statusEl['dataset']['variant']=_0x3d9d43;}async function enrichContainerDetails(_0x258fe5){try{const _0x4ef81e=await API['getContainer'](_0x258fe5);updateTerminalDetails(_0x4ef81e);}catch{try{const _0x94b2c8=await API['getContainers'](),_0x563c2d=(_0x94b2c8['containers']||[])['find'](_0x54acb5=>_0x54acb5['containerId']===_0x258fe5||_0x54acb5['name']===_0x258fe5||_0x54acb5['fullContainerId']?.['startsWith'](_0x258fe5));if(_0x563c2d){updateTerminalDetails(_0x563c2d);return;}subtitleEl['textContent']='Container\x20'+_0x258fe5['substring'](0x0,0xc);}catch{subtitleEl['textContent']='Container\x20'+_0x258fe5['substring'](0x0,0xc);}}}function updateTerminalDetails(_0x2e3385){const _0x1b80e2=_0x2e3385['containerId']||_0x2e3385['name']||_0x2e3385['fullContainerId']||containerId,_0x1a8e55=_0x2e3385['environment']?'Environment\x20'+_0x2e3385['environment']:'Environment\x20unknown',_0x284090=_0x2e3385['defaultAgent']?'\x20·\x20Agent\x20'+_0x2e3385['defaultAgent']:'',_0x5717ab=_0x2e3385['createdAt']?'\x20·\x20Started\x20'+Utils['formatRelativeTime'](_0x2e3385['createdAt']):'';titleEl['textContent']='Terminal\x20·\x20'+_0x1b80e2['substring'](0x0,0xc);const _0x5db70c=command?'\x20·\x20Command\x20'+command:'';subtitleEl['textContent']=''+_0x1a8e55+_0x284090+_0x5717ab+_0x5db70c;}
1
+ import{API,Utils}from'./app.js';import{Terminal}from'/vendor/xterm/5.3.0/xterm.esm.js';import{FitAddon}from'/vendor/xterm-addon-fit/0.7.0/xterm-addon-fit.esm.js';import{getCurrentTheme,initTheme,mountThemeToggle,onThemeChange}from'./theme.js';const params=Utils['getQueryParams'](),containerId=params['container'],command=(params['cmd']||'')['trim'](),useServerExec=params['server_exec']==='true',isEmbedded=params['embedded']==='true',terminalTabId=params['tabId']||'',titleEl=document['getElementById']('terminal-title'),subtitleEl=document['getElementById']('terminal-subtitle'),statusEl=document['getElementById']('terminal-status'),terminalEl=document['getElementById']('terminal-container'),closeBtn=document['getElementById']('close-terminal');initTheme();isEmbedded?(document['documentElement']['classList']['add']('terminal-embedded'),document['body']['classList']['add']('terminal-embedded')):mountThemeToggle({'targetSelectors':['.terminal-actions']});const getXtermTheme=()=>{return{'background':'#0f172a','foreground':'#e2e8f0','cursor':'#e2e8f0','cursorAccent':'#0f172a'};};closeBtn&&closeBtn['addEventListener']('click',()=>{if(isEmbedded&&window['parent']&&window['parent']!==window){window['parent']['postMessage']({'type':'coderflow-terminal-close','tabId':terminalTabId},window['location']['origin']);return;}window['close']();});if(!containerId){updateStatus('Missing\x20container\x20identifier','error');throw new Error('container\x20parameter\x20is\x20required');}document['title']='Terminal\x20·\x20'+containerId['slice'](0x0,0xc),enrichContainerDetails(containerId)['catch'](()=>{subtitleEl['textContent']='Container\x20'+containerId['substring'](0x0,0xc);});const term=new Terminal({'convertEol':!![],'cursorBlink':!![],'fontFamily':'JetBrains\x20Mono,\x20SFMono-Regular,\x20Consolas,\x20monospace','fontSize':0x10,'theme':getXtermTheme()}),fitAddon=new FitAddon();term['loadAddon'](fitAddon),term['open'](terminalEl),term['focus']();let isFitting=![];const doFit=()=>{if(isFitting)return;isFitting=!![],fitAddon['fit'](),sendResize(),term['scrollToBottom'](),setTimeout(()=>{isFitting=![];},0x32);};window['addEventListener']('resize',()=>{requestAnimationFrame(()=>{!isFitting&&doFit();});});const resizeObserver=new ResizeObserver(()=>{requestAnimationFrame(()=>{!isFitting&&doFit();});});resizeObserver['observe'](terminalEl);const socketProtocol=window['location']['protocol']==='https:'?'wss':'ws',socketUrl=new URL('/ws/containers/'+encodeURIComponent(containerId),window['location']['href']);command&&useServerExec&&socketUrl['searchParams']['set']('cmd',command);socketUrl['protocol']=socketProtocol+':';const socket=new WebSocket(socketUrl['toString']());term['onData'](_0x6023f7=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':_0x6023f7}));});let commandSent=![],hasReceivedOutput=![];socket['addEventListener']('message',_0x2ceb01=>{try{const _0x2941d1=JSON['parse'](_0x2ceb01['data']);if(_0x2941d1['type']==='data'&&typeof _0x2941d1['data']==='string')term['write'](_0x2941d1['data']),!hasReceivedOutput&&_0x2941d1['data']['length']>0x0&&(hasReceivedOutput=!![],command&&!useServerExec&&!commandSent&&(commandSent=!![],setTimeout(()=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':command+'\x0d'}));},0xc8)));else{if(_0x2941d1['type']==='status'&&_0x2941d1['status']){if(_0x2941d1['status']==='connected'){if(command&&useServerExec)updateStatus('Running:\x20'+command,'info');else command?updateStatus('Preparing:\x20'+command,'info'):updateStatus('Terminal\x20connected','success');doFit(),term['focus'](),command&&!useServerExec&&!commandSent&&setTimeout(()=>{!commandSent&&socket['readyState']===WebSocket['OPEN']&&(commandSent=!![],socket['send'](JSON['stringify']({'type':'data','data':command+'\x0d'})),updateStatus('Running:\x20'+command,'info'));},0x7d0);}else updateStatus('Session\x20'+_0x2941d1['status'],_0x2941d1['status']==='connected'?'success':'info');}else _0x2941d1['type']==='error'&&_0x2941d1['message']&&updateStatus(_0x2941d1['message'],'error');}}catch(_0x1791e7){console['error']('Failed\x20to\x20parse\x20terminal\x20message',_0x1791e7);}}),socket['addEventListener']('close',_0x4a87c7=>{const _0x49d516=_0x4a87c7['reason']||'Connection\x20closed';updateStatus(_0x49d516,_0x4a87c7['wasClean']?'info':'error'),isEmbedded&&terminalTabId&&window['parent']&&window['parent']!==window&&window['parent']['postMessage']({'type':'coderflow-terminal-disconnected','tabId':terminalTabId},window['location']['origin']);}),socket['addEventListener']('error',_0x22fbc8=>{console['error']('Terminal\x20websocket\x20error',_0x22fbc8),updateStatus('Connection\x20error','error');});function sendResize(){if(socket['readyState']!==WebSocket['OPEN'])return;const _0x4c4480=term['cols'],_0x1df69f=term['rows'];socket['send'](JSON['stringify']({'type':'resize','cols':_0x4c4480,'rows':_0x1df69f}));}function updateStatus(_0x293364,_0x5694ef='info'){if(!statusEl)return;statusEl['textContent']=_0x293364,statusEl['dataset']['variant']=_0x5694ef;}async function enrichContainerDetails(_0x494027){try{const _0x24166e=await API['getContainer'](_0x494027);updateTerminalDetails(_0x24166e);}catch{try{const _0x147cc1=await API['getContainers'](),_0x116574=(_0x147cc1['containers']||[])['find'](_0x336b9b=>_0x336b9b['containerId']===_0x494027||_0x336b9b['name']===_0x494027||_0x336b9b['fullContainerId']?.['startsWith'](_0x494027));if(_0x116574){updateTerminalDetails(_0x116574);return;}subtitleEl['textContent']='Container\x20'+_0x494027['substring'](0x0,0xc);}catch{subtitleEl['textContent']='Container\x20'+_0x494027['substring'](0x0,0xc);}}}function updateTerminalDetails(_0x2a5441){const _0x272326=_0x2a5441['containerId']||_0x2a5441['name']||_0x2a5441['fullContainerId']||containerId,_0x417381=_0x2a5441['environment']?'Environment\x20'+_0x2a5441['environment']:'Environment\x20unknown',_0xc8512c=_0x2a5441['defaultAgent']?'\x20·\x20Agent\x20'+_0x2a5441['defaultAgent']:'',_0x42e193=_0x2a5441['createdAt']?'\x20·\x20Started\x20'+Utils['formatRelativeTime'](_0x2a5441['createdAt']):'';titleEl['textContent']='Terminal\x20·\x20'+_0x272326['substring'](0x0,0xc);const _0x380b0f=command?'\x20·\x20Command\x20'+command:'';subtitleEl['textContent']=''+_0x417381+_0xc8512c+_0x42e193+_0x380b0f;}
@@ -1 +1 @@
1
- const THEME_STORAGE_KEY='profound-coder-theme',THEME_CHANGE_EVENT='profound-theme-change',VALID_THEMES=new Set(['light','dark']),DEFAULT_TARGET_SELECTORS=['#theme-toggle-container','.header-actions','.status-actions','.terminal-actions','.top-bar'];function readStoredTheme(){try{const _0x58d91b=localStorage['getItem'](THEME_STORAGE_KEY);if(_0x58d91b&&VALID_THEMES['has'](_0x58d91b))return _0x58d91b;}catch(_0x375186){console['warn']('[Theme]\x20Failed\x20to\x20read\x20stored\x20theme\x20preference:',_0x375186);}return null;}export function getPreferredTheme(){const _0x3a0f09=readStoredTheme();if(_0x3a0f09)return _0x3a0f09;const _0x3dfc45=window['matchMedia']&&window['matchMedia']('(prefers-color-scheme:\x20dark)')['matches'];return _0x3dfc45?'dark':'light';}export function getCurrentTheme(){const _0x547311=document['documentElement']['dataset']['theme'];if(_0x547311&&VALID_THEMES['has'](_0x547311))return _0x547311;return getPreferredTheme();}export function applyTheme(_0x3b9f8a,{persist:persist=!![],emitEvent:emitEvent=!![]}={}){const _0x3f3368=VALID_THEMES['has'](_0x3b9f8a)?_0x3b9f8a:'light';document['documentElement']['dataset']['theme']=_0x3f3368,document['documentElement']['style']['colorScheme']=_0x3f3368==='dark'?'dark':'light';if(persist)try{localStorage['setItem'](THEME_STORAGE_KEY,_0x3f3368);}catch(_0x11fdda){console['warn']('[Theme]\x20Failed\x20to\x20persist\x20theme\x20preference:',_0x11fdda);}return emitEvent&&window['dispatchEvent'](new CustomEvent(THEME_CHANGE_EVENT,{'detail':{'theme':_0x3f3368}})),_0x3f3368;}export function initTheme(_0x3dde30={}){const {emitEvent:emitEvent=![]}=_0x3dde30;return applyTheme(getPreferredTheme(),{'persist':![],'emitEvent':emitEvent});}export function toggleTheme(){const _0x74be8=getCurrentTheme()==='dark'?'light':'dark';return applyTheme(_0x74be8);}export function onThemeChange(_0x2c3bbf,{runImmediately:runImmediately=![]}={}){const _0x2dae1e=_0x13e2cf=>{_0x2c3bbf(_0x13e2cf['detail']['theme']);};return window['addEventListener'](THEME_CHANGE_EVENT,_0x2dae1e),runImmediately&&_0x2c3bbf(getCurrentTheme()),()=>window['removeEventListener'](THEME_CHANGE_EVENT,_0x2dae1e);}export function mountThemeToggle(_0x48a923={}){const {targetSelectors:targetSelectors=DEFAULT_TARGET_SELECTORS}=_0x48a923,_0x22eee1=targetSelectors['map'](_0x3f9887=>document['querySelector'](_0x3f9887))['find'](Boolean),_0x4cd81b=document['createElement']('button');_0x4cd81b['type']='button',_0x4cd81b['className']='btn-ghost\x20theme-toggle-btn',_0x4cd81b['id']='theme-toggle-btn',_0x4cd81b['setAttribute']('aria-pressed','false'),_0x4cd81b['style']['padding']='8px',_0x4cd81b['style']['lineHeight']='0',_0x4cd81b['style']['width']='36px',_0x4cd81b['style']['height']='36px',_0x4cd81b['style']['display']='flex',_0x4cd81b['style']['alignItems']='center',_0x4cd81b['style']['justifyContent']='center';const _0x3ecfa2=document['createElement']('span');_0x3ecfa2['className']='theme-icon',_0x3ecfa2['style']['display']='flex',_0x4cd81b['append'](_0x3ecfa2);const _0x379e7a='<svg\x20xmlns=\x22http://www.w3.org/2000/svg\x22\x20width=\x2220\x22\x20height=\x2220\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22><path\x20d=\x22M21\x2012.79A9\x209\x200\x201\x201\x2011.21\x203\x207\x207\x200\x200\x200\x2021\x2012.79z\x22></path></svg>',_0x392360='<svg\x20xmlns=\x22http://www.w3.org/2000/svg\x22\x20width=\x2220\x22\x20height=\x2220\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22><circle\x20cx=\x2212\x22\x20cy=\x2212\x22\x20r=\x225\x22></circle><line\x20x1=\x2212\x22\x20y1=\x221\x22\x20x2=\x2212\x22\x20y2=\x223\x22></line><line\x20x1=\x2212\x22\x20y1=\x2221\x22\x20x2=\x2212\x22\x20y2=\x2223\x22></line><line\x20x1=\x224.22\x22\x20y1=\x224.22\x22\x20x2=\x225.64\x22\x20y2=\x225.64\x22></line><line\x20x1=\x2218.36\x22\x20y1=\x2218.36\x22\x20x2=\x2219.78\x22\x20y2=\x2219.78\x22></line><line\x20x1=\x221\x22\x20y1=\x2212\x22\x20x2=\x223\x22\x20y2=\x2212\x22></line><line\x20x1=\x2221\x22\x20y1=\x2212\x22\x20x2=\x2223\x22\x20y2=\x2212\x22></line><line\x20x1=\x224.22\x22\x20y1=\x2219.78\x22\x20x2=\x225.64\x22\x20y2=\x2218.36\x22></line><line\x20x1=\x2218.36\x22\x20y1=\x225.64\x22\x20x2=\x2219.78\x22\x20y2=\x224.22\x22></line></svg>',_0x47ebc2=_0x367099=>{const _0xbcc5aa=_0x367099==='dark';_0x3ecfa2['innerHTML']=_0xbcc5aa?_0x379e7a:_0x392360,_0x4cd81b['title']=_0xbcc5aa?'Switch\x20to\x20light\x20mode':'Switch\x20to\x20dark\x20mode',_0x4cd81b['dataset']['theme']=_0x367099,_0x4cd81b['setAttribute']('aria-pressed',String(_0xbcc5aa));};return _0x4cd81b['addEventListener']('click',()=>{const _0x51d93b=getCurrentTheme()==='dark'?'light':'dark';applyTheme(_0x51d93b);}),_0x22eee1?_0x22eee1['appendChild'](_0x4cd81b):(_0x4cd81b['classList']['add']('theme-toggle-floating'),document['body']['appendChild'](_0x4cd81b)),_0x47ebc2(initTheme()),onThemeChange(_0x47ebc2),_0x4cd81b;}export{THEME_STORAGE_KEY,THEME_CHANGE_EVENT};
1
+ const THEME_STORAGE_KEY='profound-coder-theme',THEME_CHANGE_EVENT='profound-theme-change',VALID_THEMES=new Set(['light','dark']),DEFAULT_TARGET_SELECTORS=['#theme-toggle-container','.header-actions','.status-actions','.terminal-actions','.top-bar'];function readStoredTheme(){try{const _0x3d61e9=localStorage['getItem'](THEME_STORAGE_KEY);if(_0x3d61e9&&VALID_THEMES['has'](_0x3d61e9))return _0x3d61e9;}catch(_0x51d611){console['warn']('[Theme]\x20Failed\x20to\x20read\x20stored\x20theme\x20preference:',_0x51d611);}return null;}export function getPreferredTheme(){const _0x49a41f=readStoredTheme();if(_0x49a41f)return _0x49a41f;const _0x202f16=window['matchMedia']&&window['matchMedia']('(prefers-color-scheme:\x20dark)')['matches'];return _0x202f16?'dark':'light';}export function getCurrentTheme(){const _0x48f943=document['documentElement']['dataset']['theme'];if(_0x48f943&&VALID_THEMES['has'](_0x48f943))return _0x48f943;return getPreferredTheme();}export function applyTheme(_0x30433a,{persist:persist=!![],emitEvent:emitEvent=!![]}={}){const _0x5a5685=VALID_THEMES['has'](_0x30433a)?_0x30433a:'light';document['documentElement']['dataset']['theme']=_0x5a5685,document['documentElement']['style']['colorScheme']=_0x5a5685==='dark'?'dark':'light';if(persist)try{localStorage['setItem'](THEME_STORAGE_KEY,_0x5a5685);}catch(_0x56c854){console['warn']('[Theme]\x20Failed\x20to\x20persist\x20theme\x20preference:',_0x56c854);}return emitEvent&&window['dispatchEvent'](new CustomEvent(THEME_CHANGE_EVENT,{'detail':{'theme':_0x5a5685}})),_0x5a5685;}export function initTheme(_0x4650c7={}){const {emitEvent:emitEvent=![]}=_0x4650c7;return applyTheme(getPreferredTheme(),{'persist':![],'emitEvent':emitEvent});}export function toggleTheme(){const _0x550a54=getCurrentTheme()==='dark'?'light':'dark';return applyTheme(_0x550a54);}export function onThemeChange(_0xc0664d,{runImmediately:runImmediately=![]}={}){const _0x3a41dc=_0x17d90a=>{_0xc0664d(_0x17d90a['detail']['theme']);};return window['addEventListener'](THEME_CHANGE_EVENT,_0x3a41dc),runImmediately&&_0xc0664d(getCurrentTheme()),()=>window['removeEventListener'](THEME_CHANGE_EVENT,_0x3a41dc);}export function mountThemeToggle(_0x5c372f={}){const {targetSelectors:targetSelectors=DEFAULT_TARGET_SELECTORS}=_0x5c372f,_0x377f28=targetSelectors['map'](_0x570fa0=>document['querySelector'](_0x570fa0))['find'](Boolean),_0x2b8c7c=document['createElement']('button');_0x2b8c7c['type']='button',_0x2b8c7c['className']='btn-ghost\x20theme-toggle-btn',_0x2b8c7c['id']='theme-toggle-btn',_0x2b8c7c['setAttribute']('aria-pressed','false'),_0x2b8c7c['style']['padding']='8px',_0x2b8c7c['style']['lineHeight']='0',_0x2b8c7c['style']['width']='36px',_0x2b8c7c['style']['height']='36px',_0x2b8c7c['style']['display']='flex',_0x2b8c7c['style']['alignItems']='center',_0x2b8c7c['style']['justifyContent']='center';const _0x5e9927=document['createElement']('span');_0x5e9927['className']='theme-icon',_0x5e9927['style']['display']='flex',_0x2b8c7c['append'](_0x5e9927);const _0x352514='<svg\x20xmlns=\x22http://www.w3.org/2000/svg\x22\x20width=\x2220\x22\x20height=\x2220\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22><path\x20d=\x22M21\x2012.79A9\x209\x200\x201\x201\x2011.21\x203\x207\x207\x200\x200\x200\x2021\x2012.79z\x22></path></svg>',_0x399755='<svg\x20xmlns=\x22http://www.w3.org/2000/svg\x22\x20width=\x2220\x22\x20height=\x2220\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22><circle\x20cx=\x2212\x22\x20cy=\x2212\x22\x20r=\x225\x22></circle><line\x20x1=\x2212\x22\x20y1=\x221\x22\x20x2=\x2212\x22\x20y2=\x223\x22></line><line\x20x1=\x2212\x22\x20y1=\x2221\x22\x20x2=\x2212\x22\x20y2=\x2223\x22></line><line\x20x1=\x224.22\x22\x20y1=\x224.22\x22\x20x2=\x225.64\x22\x20y2=\x225.64\x22></line><line\x20x1=\x2218.36\x22\x20y1=\x2218.36\x22\x20x2=\x2219.78\x22\x20y2=\x2219.78\x22></line><line\x20x1=\x221\x22\x20y1=\x2212\x22\x20x2=\x223\x22\x20y2=\x2212\x22></line><line\x20x1=\x2221\x22\x20y1=\x2212\x22\x20x2=\x2223\x22\x20y2=\x2212\x22></line><line\x20x1=\x224.22\x22\x20y1=\x2219.78\x22\x20x2=\x225.64\x22\x20y2=\x2218.36\x22></line><line\x20x1=\x2218.36\x22\x20y1=\x225.64\x22\x20x2=\x2219.78\x22\x20y2=\x224.22\x22></line></svg>',_0x2f6c79=_0x228b6d=>{const _0x3cdf77=_0x228b6d==='dark';_0x5e9927['innerHTML']=_0x3cdf77?_0x352514:_0x399755,_0x2b8c7c['title']=_0x3cdf77?'Switch\x20to\x20light\x20mode':'Switch\x20to\x20dark\x20mode',_0x2b8c7c['dataset']['theme']=_0x228b6d,_0x2b8c7c['setAttribute']('aria-pressed',String(_0x3cdf77));};return _0x2b8c7c['addEventListener']('click',()=>{const _0x13ec84=getCurrentTheme()==='dark'?'light':'dark';applyTheme(_0x13ec84);}),_0x377f28?_0x377f28['appendChild'](_0x2b8c7c):(_0x2b8c7c['classList']['add']('theme-toggle-floating'),document['body']['appendChild'](_0x2b8c7c)),_0x2f6c79(initTheme()),onThemeChange(_0x2f6c79),_0x2b8c7c;}export{THEME_STORAGE_KEY,THEME_CHANGE_EVENT};
@@ -1 +1 @@
1
- import{API,Utils,ConfirmDialog,initializeAdminMenu}from'./app.js';import{initTheme,mountThemeToggle}from'./theme.js';const state={'users':[],'editingUserId':null,'bindingsUserId':null,'deletingUserId':null,'setupLinkData':null,'emailConfigured':![],'currentUser':null,'roles':[],'environments':[],'teams':[],'userBindings':[],'bindingsDirty':![]};document['addEventListener']('DOMContentLoaded',async()=>{initTheme(),mountThemeToggle(),await checkAdminAccess(),await initializeAdminMenu(state['currentUser']),await Promise['all']([checkEmailConfig(),loadRoles(),loadEnvironments(),loadTeams()]),bindEventListeners(),await loadUsers();});async function checkAdminAccess(){try{const _0x32fde5=await API['getCurrentUser']();state['currentUser']=_0x32fde5;if(!Permissions['hasServerPermission'](_0x32fde5,'*')&&!Permissions['hasServerPermission'](_0x32fde5,'users:create')){Utils['showToast']('Access\x20denied:\x20Server\x20admin\x20privileges\x20required','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}}catch(_0x6b65a9){window['location']['href']='login.html';}}async function checkEmailConfig(){try{const _0x499dc2=await API['getEmailConfig']();state['emailConfigured']=_0x499dc2['configured'];}catch(_0x47bf8f){console['error']('Failed\x20to\x20check\x20email\x20config',_0x47bf8f),state['emailConfigured']=![];}}async function loadRoles(){try{const {roles:_0x2da283}=await API['getRoleDefinitions']();state['roles']=_0x2da283||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x437432=await API['getEnvironments']();state['environments']=_0x437432['environments']||[];}catch{state['environments']=[];}}async function loadTeams(){try{const {teams:_0x1697e8}=await API['getTeams']();state['teams']=_0x1697e8||[];}catch{state['teams']=[];}}function bindEventListeners(){document['getElementById']('create-user-btn')?.['addEventListener']('click',showCreateUserModal),document['getElementById']('close-user-modal')?.['addEventListener']('click',hideUserModal),document['getElementById']('cancel-user')?.['addEventListener']('click',hideUserModal),document['getElementById']('save-user')?.['addEventListener']('click',saveUser),document['querySelector']('#user-modal\x20.modal-overlay')?.['addEventListener']('click',hideUserModal),document['getElementById']('close-delete-modal')?.['addEventListener']('click',hideDeleteModal),document['getElementById']('cancel-delete')?.['addEventListener']('click',hideDeleteModal),document['getElementById']('confirm-delete')?.['addEventListener']('click',confirmDeleteUser),document['querySelector']('#delete-modal\x20.modal-overlay')?.['addEventListener']('click',hideDeleteModal),document['getElementById']('close-setup-link-modal')?.['addEventListener']('click',hideSetupLinkModal),document['getElementById']('close-setup-link')?.['addEventListener']('click',hideSetupLinkModal),document['getElementById']('copy-setup-link')?.['addEventListener']('click',copySetupLink),document['getElementById']('email-setup-link')?.['addEventListener']('click',emailSetupLink),document['querySelector']('#setup-link-modal\x20.modal-overlay')?.['addEventListener']('click',hideSetupLinkModal),document['getElementById']('skip-password')?.['addEventListener']('change',handleSkipPasswordChange),document['getElementById']('retry-users-btn')?.['addEventListener']('click',loadUsers),document['getElementById']('close-bindings-modal')?.['addEventListener']('click',hideAccessBindingsModal),document['getElementById']('close-bindings-modal-footer')?.['addEventListener']('click',hideAccessBindingsModal),document['querySelector']('#bindings-modal\x20.modal-overlay')?.['addEventListener']('click',hideAccessBindingsModal),document['getElementById']('add-user-binding-btn')?.['addEventListener']('click',()=>{document['getElementById']('add-user-binding-form')['hidden']=![],document['getElementById']('add-user-binding-btn')['hidden']=!![],populateUserBindingForm();}),document['getElementById']('cancel-user-binding-btn')?.['addEventListener']('click',()=>{document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![];}),document['getElementById']('save-user-binding-btn')?.['addEventListener']('click',saveUserBinding),document['getElementById']('user-binding-resource-type')?.['addEventListener']('change',onUserBindingResourceTypeChange);}async function loadUsers(){const _0x19fddd=document['getElementById']('users-loading'),_0x3ce9cf=document['getElementById']('users-error'),_0x29c937=document['getElementById']('users-content');try{_0x19fddd['hidden']=![],_0x3ce9cf['hidden']=!![],_0x29c937['hidden']=!![];const _0x445acc=await API['getUsers']();state['users']=_0x445acc['users']||[],renderUsers(),_0x19fddd['hidden']=!![],_0x29c937['hidden']=![];}catch(_0x69960e){console['error']('Failed\x20to\x20load\x20users',_0x69960e),_0x19fddd['hidden']=!![],_0x3ce9cf['hidden']=![],document['getElementById']('users-error-message')['textContent']=_0x69960e['message'];}}function renderUsers(){const _0xbb9429=document['getElementById']('users-table-body'),_0x2e98af=document['getElementById']('user-count');if(!_0xbb9429)return;_0x2e98af&&(_0x2e98af['textContent']=state['users']['length']+'\x20user'+(state['users']['length']===0x1?'':'s'));const _0x3036ed=[...state['users']]['sort']((_0x396053,_0x72fc0f)=>{const _0x294e1f=new Date(_0x396053['created_at'])['getTime'](),_0x429a59=new Date(_0x72fc0f['created_at'])['getTime']();return _0x429a59-_0x294e1f;});_0xbb9429['innerHTML']=_0x3036ed['map'](_0x4d90d7=>'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22user-username\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+Utils['escapeHtml'](_0x4d90d7['username'])+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x4d90d7['name'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x4d90d7['email'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22access-badges\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x4d90d7['isServerAdmin']?'<span\x20class=\x22role-badge\x20role-admin\x22>Server\x20Admin</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x4d90d7['hasUserBinding']?'<span\x20class=\x22role-badge\x20role-user-binding\x22>User\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x4d90d7['hasTeamBinding']?'<span\x20class=\x22role-badge\x20role-team-binding\x22>Team\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['formatRelativeTime'](_0x4d90d7['created_at'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22user-actions\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-icon\x20btn-small\x22\x20onclick=\x22window.editUser(\x27'+_0x4d90d7['id']+'\x27)\x22\x20title=\x22Edit\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2214\x22\x20height=\x2214\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M11\x204H4a2\x202\x200\x200\x200-2\x202v14a2\x202\x200\x200\x200\x202\x202h14a2\x202\x200\x200\x200\x202-2v-7\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M18.5\x202.5a2.121\x202.121\x200\x200\x201\x203\x203L12\x2015l-4\x201\x201-4\x209.5-9.5z\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-icon\x20btn-small\x22\x20onclick=\x22window.showAccessBindings(\x27'+_0x4d90d7['id']+'\x27)\x22\x20title=\x22Access\x20Bindings\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2214\x22\x20height=\x2214\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M12\x2022s8-4\x208-10V5l-8-3-8\x203v7c0\x206\x208\x2010\x208\x2010z\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-icon\x20btn-small\x20btn-danger\x22\x20onclick=\x22window.deleteUser(\x27'+_0x4d90d7['id']+'\x27)\x22\x20title=\x22Delete\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2214\x22\x20height=\x2214\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<polyline\x20points=\x223\x206\x205\x206\x2021\x206\x22></polyline>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M19\x206v14a2\x202\x200\x200\x201-2\x202H7a2\x202\x200\x200\x201-2-2V6m3\x200V4a2\x202\x200\x200\x201\x202-2h4a2\x202\x200\x200\x201\x202\x202v2\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-secondary\x20btn-small\x22\x20onclick=\x22window.resetPassword(\x27'+_0x4d90d7['id']+'\x27)\x22>Reset\x20Password</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20</tr>\x0a\x20\x20')['join']('');}window['showAccessBindings']=function(_0x1e6642){const _0x178390=state['users']['find'](_0x4e2dff=>_0x4e2dff['id']===_0x1e6642);if(!_0x178390)return;state['bindingsUserId']=_0x1e6642,state['bindingsDirty']=![];const _0x50d2cb=document['getElementById']('bindings-modal'),_0x17664b=document['getElementById']('bindings-modal-title');_0x17664b['textContent']='Access\x20Bindings\x20—\x20'+_0x178390['name'],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],_0x50d2cb['hidden']=![],loadUserBindings(_0x1e6642);};function hasUnsavedBindingChanges(){const _0x2c3468=document['getElementById']('add-user-binding-form');return _0x2c3468&&!_0x2c3468['hidden'];}async function hideAccessBindingsModal(){if(hasUnsavedBindingChanges()){if(!confirm('You\x20have\x20an\x20unsaved\x20binding.\x20Discard\x20changes?'))return;document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![];}const _0x25b8e7=document['getElementById']('bindings-modal');_0x25b8e7['hidden']=!![];const _0x1fdf37=state['bindingsDirty'];state['bindingsUserId']=null,state['userBindings']=[],state['bindingsDirty']=![],_0x1fdf37&&await loadUsers();}async function loadUserBindings(_0x1a9498){const _0x4bda10=document['getElementById']('user-bindings-loading'),_0xac8efd=document['getElementById']('user-bindings-empty'),_0x26de29=document['getElementById']('user-bindings-list-container'),_0x516694=document['getElementById']('add-user-binding-btn'),_0x2b2d02=document['getElementById']('user-team-bindings-note'),_0x55011f=document['getElementById']('user-team-bindings-text');_0x4bda10['hidden']=![],_0xac8efd['hidden']=!![],_0x26de29['style']['display']='none',_0x516694['hidden']=!![],_0x2b2d02['hidden']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![];try{const [_0x23fa29,_0x277779]=await Promise['all']([API['getBindings']({'subject_type':'user','subject_id':_0x1a9498}),API['getTeams']()]);state['userBindings']=_0x23fa29['bindings']||[];const _0x61479d=(_0x277779['teams']||[])['filter'](_0x54c1e7=>(_0x54c1e7['members']||[])['includes'](_0x1a9498)),_0x3d96d2=[];if(_0x61479d['length']>0x0){const _0x1cce6d=await Promise['all'](_0x61479d['map'](_0x3c7fc7=>API['getBindings']({'subject_type':'team','subject_id':_0x3c7fc7['id']})));for(let _0x20825b=0x0;_0x20825b<_0x61479d['length'];_0x20825b++){const _0x2fb765=_0x1cce6d[_0x20825b]['bindings']||[];_0x2fb765['length']>0x0&&_0x3d96d2['push'](_0x61479d[_0x20825b]);}}_0x4bda10['hidden']=!![];state['userBindings']['length']===0x0?_0xac8efd['hidden']=![]:(_0x26de29['style']['display']='',renderUserBindingsTable());if(_0x3d96d2['length']>0x0){const _0x500647=_0x3d96d2['map'](_0x7d2fe5=>_0x7d2fe5['name']),_0x2a0642=_0x500647['length']<=0x3?_0x500647['join'](',\x20'):_0x500647['slice'](0x0,0x3)['join'](',\x20')+(',\x20and\x20'+(_0x500647['length']-0x3)+'\x20more');_0x55011f['textContent']='This\x20user\x20also\x20has\x20access\x20via\x20team\x20memberships\x20('+_0x2a0642+').';}else _0x55011f['textContent']='This\x20user\x20has\x20no\x20access\x20via\x20team\x20memberships.';_0x2b2d02['hidden']=![],_0x516694['hidden']=![];}catch(_0x54730e){_0x4bda10['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x54730e['message'],'error');}}function renderUserBindingsTable(){const _0x41dfb3=document['getElementById']('user-bindings-table-body');if(!_0x41dfb3)return;_0x41dfb3['innerHTML']=state['userBindings']['map'](_0x7c16ce=>{const _0x8a0fe3=_0x7c16ce['resource_type']==='server'?'Server':_0x7c16ce['resource_id']==='*'?'All\x20'+_0x7c16ce['resource_type']+'s':Utils['escapeHtml'](_0x7c16ce['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x8a0fe3+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x7c16ce['role_name']||_0x7c16ce['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteUserBindingClick(\x27'+_0x7c16ce['id']+'\x27)\x22\x20style=\x22color:\x20var(--color-danger);\x22>Remove</button>\x0a\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20</tr>';})['join']('');}function populateUserBindingForm(){const _0x30e3c0=document['getElementById']('user-binding-resource-type');_0x30e3c0['value']='environment',updateUserBindingFormForResourceType('environment');}function onUserBindingResourceTypeChange(){const _0x42b778=document['getElementById']('user-binding-resource-type')['value'];updateUserBindingFormForResourceType(_0x42b778);}function updateUserBindingFormForResourceType(_0x2403b5){const _0x116772=document['getElementById']('user-binding-resource-container'),_0x49a630=document['getElementById']('user-binding-resource'),_0x285d86=document['getElementById']('user-binding-role');if(_0x2403b5==='server')_0x116772['style']['display']='none';else{_0x116772['style']['display']='';if(_0x2403b5==='environment'){const _0x21bae2=new Set(state['userBindings']['filter'](_0x3ba069=>_0x3ba069['resource_type']==='environment')['map'](_0x5501d7=>_0x5501d7['resource_id'])),_0x5d8f5a=state['environments']['filter'](_0x5a5fd9=>!_0x21bae2['has'](_0x5a5fd9['name']));_0x49a630['innerHTML']=_0x5d8f5a['length']?_0x5d8f5a['map'](_0x46580f=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x46580f['name'])+'\x22>'+Utils['escapeHtml'](_0x46580f['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x2403b5==='team'){const _0x53192c=new Set(state['userBindings']['filter'](_0x5267e0=>_0x5267e0['resource_type']==='team')['map'](_0x9560ab=>_0x9560ab['resource_id'])),_0x4e6fc5=state['teams']['filter'](_0x9e8332=>!_0x53192c['has'](_0x9e8332['id']));_0x49a630['innerHTML']=_0x4e6fc5['length']?_0x4e6fc5['map'](_0x3dd644=>'<option\x20value=\x22'+_0x3dd644['id']+'\x22>'+Utils['escapeHtml'](_0x3dd644['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x5210cd=state['roles']['filter'](_0x17bd1b=>_0x17bd1b['resource_type']===_0x2403b5);_0x285d86['innerHTML']=_0x5210cd['length']?_0x5210cd['filter'](_0x47a1b3=>{const _0x2602c3=_0x2403b5==='server'?undefined:_0x49a630['value'];return!state['userBindings']['some'](_0x497fac=>_0x497fac['resource_type']===_0x2403b5&&_0x497fac['role_id']===_0x47a1b3['id']&&(_0x2403b5==='server'||_0x497fac['resource_id']===_0x2602c3));})['map'](_0x518783=>'<option\x20value=\x22'+_0x518783['id']+'\x22>'+Utils['escapeHtml'](_0x518783['name'])+'</option>')['join']('')||'<option\x20value=\x22\x22>No\x20available\x20roles</option>':'<option\x20value=\x22\x22>No\x20roles\x20for\x20this\x20resource\x20type</option>';}async function saveUserBinding(){const _0x3791e4=document['getElementById']('user-binding-resource-type')['value'],_0x34fb6f=document['getElementById']('user-binding-role')['value'];if(!_0x34fb6f||!state['bindingsUserId'])return;const _0x16f5af=_0x3791e4==='server'?undefined:document['getElementById']('user-binding-resource')['value'];if(_0x3791e4!=='server'&&!_0x16f5af)return;const _0x29c5d0=document['getElementById']('save-user-binding-btn');_0x29c5d0['disabled']=!![],_0x29c5d0['textContent']='Adding…';try{const _0x33bfcb={'subject_type':'user','subject_id':state['bindingsUserId'],'role_id':_0x34fb6f,'resource_type':_0x3791e4};if(_0x16f5af)_0x33bfcb['resource_id']=_0x16f5af;await API['createBinding'](_0x33bfcb),Utils['showToast']('Binding\x20added','success'),state['bindingsDirty']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],await loadUserBindings(state['bindingsUserId']);}catch(_0x4e1787){Utils['showToast'](_0x4e1787['message'],'error');}finally{_0x29c5d0['disabled']=![],_0x29c5d0['textContent']='Add\x20Binding';}}window['deleteUserBindingClick']=async function(_0x469a10){try{await API['deleteBinding'](_0x469a10),Utils['showToast']('Binding\x20removed','success'),state['bindingsDirty']=!![],await loadUserBindings(state['bindingsUserId']);}catch(_0x2ab25d){Utils['showToast'](_0x2ab25d['message'],'error');}};function showCreateUserModal(){state['editingUserId']=null;const _0x3159f8=document['getElementById']('user-modal'),_0x9b4c18=document['getElementById']('modal-title'),_0x18fc55=document['getElementById']('user-password'),_0x17991c=document['getElementById']('password-required'),_0x28089b=document['getElementById']('password-hint'),_0xf1c158=document['getElementById']('skip-password-container'),_0x551a0c=document['getElementById']('skip-password');_0x9b4c18['textContent']='Create\x20User',document['getElementById']('user-form')['reset'](),_0x18fc55['required']=!![];if(_0x17991c)_0x17991c['textContent']='*';_0xf1c158&&(_0xf1c158['style']['display']='block',_0x551a0c['checked']=![]),_0x28089b&&(_0x28089b['textContent']='Minimum\x208\x20characters'),_0x3159f8['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);}window['editUser']=function(_0x381fb4){const _0x773b4e=state['users']['find'](_0x27e475=>_0x27e475['id']===_0x381fb4);if(!_0x773b4e)return;state['editingUserId']=_0x381fb4;const _0x45fb26=document['getElementById']('user-modal'),_0x37c406=document['getElementById']('modal-title'),_0x3dcca3=document['getElementById']('user-password'),_0x481242=document['getElementById']('password-required'),_0x1ec292=document['getElementById']('password-hint'),_0x19fa73=document['getElementById']('skip-password-container');_0x37c406['textContent']='Edit\x20User',document['getElementById']('user-username')['value']=_0x773b4e['username'],document['getElementById']('user-name')['value']=_0x773b4e['name'],document['getElementById']('user-email')['value']=_0x773b4e['email'],_0x3dcca3['value']='',_0x3dcca3['required']=![];if(_0x481242)_0x481242['textContent']='';_0x19fa73&&(_0x19fa73['style']['display']='none'),_0x1ec292&&(_0x1ec292['textContent']='Leave\x20blank\x20to\x20keep\x20current\x20password'),_0x45fb26['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);};function hideUserModal(){const _0x1945ae=document['getElementById']('user-modal'),_0x18ec52=document['getElementById']('form-error'),_0x5140a7=document['getElementById']('save-user');_0x1945ae['hidden']=!![],_0x18ec52['hidden']=!![],state['editingUserId']=null,_0x5140a7&&(_0x5140a7['disabled']=![],_0x5140a7['textContent']='Save\x20User');}async function saveUser(){const _0x5a959d=document['getElementById']('user-form'),_0x6378c0=document['getElementById']('skip-password')?.['checked']||![];if(!_0x6378c0&&!_0x5a959d['checkValidity']()){_0x5a959d['reportValidity']();return;}const _0x501d3d=document['getElementById']('form-error'),_0x1d0a79=document['getElementById']('save-user'),_0x45c1c5=document['getElementById']('user-username')['value']['trim'](),_0x3c1592=document['getElementById']('user-name')['value']['trim'](),_0x2ec141=document['getElementById']('user-email')['value']['trim'](),_0x1770dc=document['getElementById']('user-password')['value'];if(!_0x45c1c5||!_0x3c1592||!_0x2ec141){_0x501d3d['textContent']='Please\x20fill\x20in\x20all\x20required\x20fields',_0x501d3d['hidden']=![],_0x501d3d['scrollIntoView']({'behavior':'smooth','block':'nearest'});return;}_0x501d3d['hidden']=!![];const _0xe83287=_0x1d0a79['textContent'];_0x1d0a79['disabled']=!![],_0x1d0a79['textContent']=state['editingUserId']?'Updating...':'Creating...';try{if(state['editingUserId']){const _0x20a3bb={'username':_0x45c1c5,'name':_0x3c1592,'email':_0x2ec141};_0x1770dc&&(_0x20a3bb['password']=_0x1770dc),await API['updateUser'](state['editingUserId'],_0x20a3bb),Utils['showToast']('User\x20updated\x20successfully','success'),await loadUsers(),hideUserModal();}else{const _0x2f9ae7={'username':_0x45c1c5,'name':_0x3c1592,'email':_0x2ec141};if(!_0x6378c0){if(!_0x1770dc)throw new Error('Password\x20is\x20required\x20for\x20new\x20users');_0x2f9ae7['password']=_0x1770dc;}const _0x5f0f86=await API['createUser'](_0x2f9ae7),_0x78a074=_0x5f0f86['user'];if(_0x6378c0||!_0x1770dc){const _0x13295b=await API['createPasswordToken'](_0x78a074['id'],'setup',![]);state['setupLinkData']={'username':_0x78a074['username'],'email':_0x78a074['email'],'url':_0x13295b['token']['setupUrl'],'userId':_0x78a074['id'],'type':'setup','emailSent':![]},await loadUsers(),hideUserModal(),showSetupLinkModal();}else Utils['showToast']('User\x20created\x20successfully','success'),await loadUsers(),hideUserModal();}}catch(_0x327c42){console['error']('Failed\x20to\x20save\x20user',_0x327c42),_0x501d3d['textContent']=_0x327c42['message'],_0x501d3d['hidden']=![],_0x501d3d['scrollIntoView']({'behavior':'smooth','block':'nearest'}),_0x1d0a79['disabled']=![],_0x1d0a79['textContent']=_0xe83287;}}window['deleteUser']=function(_0x64debc){const _0x37a532=state['users']['find'](_0x5dba48=>_0x5dba48['id']===_0x64debc);if(!_0x37a532)return;state['deletingUserId']=_0x64debc;const _0x779793=document['getElementById']('delete-modal'),_0x392228=document['getElementById']('delete-user-name');_0x392228['textContent']=_0x37a532['name']+'\x20('+_0x37a532['username']+')',_0x779793['hidden']=![];};function hideDeleteModal(){const _0x409721=document['getElementById']('delete-modal');_0x409721['hidden']=!![],state['deletingUserId']=null;const _0x46bfe9=document['getElementById']('confirm-delete');_0x46bfe9&&(_0x46bfe9['disabled']=![],_0x46bfe9['textContent']='Delete\x20User');}async function confirmDeleteUser(){if(!state['deletingUserId'])return;const _0x20461a=document['getElementById']('confirm-delete'),_0x526676=_0x20461a['textContent'];_0x20461a['disabled']=!![],_0x20461a['textContent']='Deleting...';try{await API['deleteUser'](state['deletingUserId']),Utils['showToast']('User\x20deleted\x20successfully','success'),await loadUsers(),hideDeleteModal();}catch(_0xf73f9a){console['error']('Failed\x20to\x20delete\x20user',_0xf73f9a),Utils['showToast']('Failed\x20to\x20delete\x20user:\x20'+_0xf73f9a['message'],'error'),_0x20461a['disabled']=![],_0x20461a['textContent']=_0x526676;}}function handleSkipPasswordChange(_0x2ddbe2){const _0x2e2c27=document['getElementById']('user-password'),_0x16b6ca=_0x2ddbe2['target']['checked'];_0x16b6ca?(_0x2e2c27['required']=![],_0x2e2c27['disabled']=!![],_0x2e2c27['value']=''):(_0x2e2c27['required']=!![],_0x2e2c27['disabled']=![]);}function showSetupLinkModal(){if(!state['setupLinkData'])return;const _0x528b81=document['getElementById']('setup-link-modal'),_0x425777=document['getElementById']('setup-link-username'),_0x2f3c1e=document['getElementById']('setup-link-url'),_0x4dffcb=document['getElementById']('email-setup-link'),_0x4d6ff5=document['getElementById']('email-button-text');_0x425777['textContent']=state['setupLinkData']['username'],_0x2f3c1e['textContent']=state['setupLinkData']['url'],_0x4dffcb&&_0x4d6ff5&&(_0x4dffcb['disabled']=![],_0x4d6ff5['textContent']='Email\x20Link',state['emailConfigured']&&!state['setupLinkData']['emailSent']?_0x4dffcb['style']['display']='inline-block':_0x4dffcb['style']['display']='none'),_0x528b81['hidden']=![];}function hideSetupLinkModal(){const _0x18cefc=document['getElementById']('setup-link-modal');_0x18cefc['hidden']=!![],state['setupLinkData']=null;}async function copySetupLink(){if(!state['setupLinkData'])return;try{await navigator['clipboard']['writeText'](state['setupLinkData']['url']),Utils['showToast']('Link\x20copied\x20to\x20clipboard','success');}catch(_0x4ad039){console['error']('Failed\x20to\x20copy\x20link',_0x4ad039),Utils['showToast']('Failed\x20to\x20copy\x20link','error');}}async function emailSetupLink(){if(!state['setupLinkData'])return;const _0x50ea43=document['getElementById']('email-setup-link'),_0x194caf=document['getElementById']('email-button-text');if(!_0x50ea43||!_0x194caf)return;const _0x501969=_0x194caf['textContent'];_0x50ea43['disabled']=!![],_0x194caf['textContent']='Sending...';try{const _0x35d7f6=await API['createPasswordToken'](state['setupLinkData']['userId'],state['setupLinkData']['type'],!![]);if(_0x35d7f6['emailSent'])Utils['showToast']('Email\x20sent\x20to\x20'+state['setupLinkData']['email'],'success'),state['setupLinkData']['emailSent']=!![],_0x50ea43['style']['display']='none';else{const _0x1a8122=_0x35d7f6['emailError']||'Failed\x20to\x20send\x20email';Utils['showToast'](_0x1a8122,'error'),_0x50ea43['disabled']=![],_0x194caf['textContent']=_0x501969;}}catch(_0x5f1ac9){console['error']('Failed\x20to\x20email\x20setup\x20link',_0x5f1ac9),Utils['showToast']('Failed\x20to\x20send\x20email:\x20'+_0x5f1ac9['message'],'error'),_0x50ea43['disabled']=![],_0x194caf['textContent']=_0x501969;}}window['resetPassword']=async function(_0x4692c7){const _0x11dcad=state['users']['find'](_0x36dea2=>_0x36dea2['id']===_0x4692c7);if(!_0x11dcad)return;const _0x49a827=await ConfirmDialog['show']({'title':'Reset\x20Password','message':'Generate\x20a\x20password\x20reset\x20link\x20for\x20'+_0x11dcad['name']+'\x20('+_0x11dcad['username']+')?\x20This\x20will\x20create\x20a\x20link\x20that\x20they\x20can\x20use\x20to\x20set\x20a\x20new\x20password.','confirmText':'Generate\x20Link'});if(!_0x49a827)return;try{const _0xaeea9d=await API['createPasswordToken'](_0x4692c7,'reset',![]);state['setupLinkData']={'username':_0x11dcad['username'],'email':_0x11dcad['email'],'url':_0xaeea9d['token']['setupUrl'],'userId':_0x11dcad['id'],'type':'reset','emailSent':![]},showSetupLinkModal();}catch(_0x4fd5f9){console['error']('Failed\x20to\x20create\x20password\x20reset\x20link',_0x4fd5f9),Utils['showToast']('Failed\x20to\x20create\x20password\x20reset\x20link:\x20'+_0x4fd5f9['message'],'error');}};
1
+ import{API,Utils,ConfirmDialog,initializeAdminMenu}from'./app.js';import{initTheme,mountThemeToggle}from'./theme.js';const state={'users':[],'editingUserId':null,'bindingsUserId':null,'deletingUserId':null,'setupLinkData':null,'emailConfigured':![],'currentUser':null,'roles':[],'environments':[],'teams':[],'userBindings':[],'bindingsDirty':![]};document['addEventListener']('DOMContentLoaded',async()=>{initTheme(),mountThemeToggle(),await checkAdminAccess(),await initializeAdminMenu(state['currentUser']),await Promise['all']([checkEmailConfig(),loadRoles(),loadEnvironments(),loadTeams()]),bindEventListeners(),await loadUsers();});async function checkAdminAccess(){try{const _0x309ddd=await API['getCurrentUser']();state['currentUser']=_0x309ddd;if(!Permissions['hasServerPermission'](_0x309ddd,'*')&&!Permissions['hasServerPermission'](_0x309ddd,'users:create')){Utils['showToast']('Access\x20denied:\x20Server\x20admin\x20privileges\x20required','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}}catch(_0x28f8dc){window['location']['href']='login.html';}}async function checkEmailConfig(){try{const _0x15c047=await API['getEmailConfig']();state['emailConfigured']=_0x15c047['configured'];}catch(_0xdabbb1){console['error']('Failed\x20to\x20check\x20email\x20config',_0xdabbb1),state['emailConfigured']=![];}}async function loadRoles(){try{const {roles:_0x380be3}=await API['getRoleDefinitions']();state['roles']=_0x380be3||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x4d949b=await API['getEnvironments']();state['environments']=_0x4d949b['environments']||[];}catch{state['environments']=[];}}async function loadTeams(){try{const {teams:_0x141bf9}=await API['getTeams']();state['teams']=_0x141bf9||[];}catch{state['teams']=[];}}function bindEventListeners(){document['getElementById']('create-user-btn')?.['addEventListener']('click',showCreateUserModal),document['getElementById']('close-user-modal')?.['addEventListener']('click',hideUserModal),document['getElementById']('cancel-user')?.['addEventListener']('click',hideUserModal),document['getElementById']('save-user')?.['addEventListener']('click',saveUser),document['querySelector']('#user-modal\x20.modal-overlay')?.['addEventListener']('click',hideUserModal),document['getElementById']('close-delete-modal')?.['addEventListener']('click',hideDeleteModal),document['getElementById']('cancel-delete')?.['addEventListener']('click',hideDeleteModal),document['getElementById']('confirm-delete')?.['addEventListener']('click',confirmDeleteUser),document['querySelector']('#delete-modal\x20.modal-overlay')?.['addEventListener']('click',hideDeleteModal),document['getElementById']('close-setup-link-modal')?.['addEventListener']('click',hideSetupLinkModal),document['getElementById']('close-setup-link')?.['addEventListener']('click',hideSetupLinkModal),document['getElementById']('copy-setup-link')?.['addEventListener']('click',copySetupLink),document['getElementById']('email-setup-link')?.['addEventListener']('click',emailSetupLink),document['querySelector']('#setup-link-modal\x20.modal-overlay')?.['addEventListener']('click',hideSetupLinkModal),document['getElementById']('skip-password')?.['addEventListener']('change',handleSkipPasswordChange),document['getElementById']('retry-users-btn')?.['addEventListener']('click',loadUsers),document['getElementById']('close-bindings-modal')?.['addEventListener']('click',hideAccessBindingsModal),document['getElementById']('close-bindings-modal-footer')?.['addEventListener']('click',hideAccessBindingsModal),document['querySelector']('#bindings-modal\x20.modal-overlay')?.['addEventListener']('click',hideAccessBindingsModal),document['getElementById']('add-user-binding-btn')?.['addEventListener']('click',()=>{document['getElementById']('add-user-binding-form')['hidden']=![],document['getElementById']('add-user-binding-btn')['hidden']=!![],populateUserBindingForm();}),document['getElementById']('cancel-user-binding-btn')?.['addEventListener']('click',()=>{document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![];}),document['getElementById']('save-user-binding-btn')?.['addEventListener']('click',saveUserBinding),document['getElementById']('user-binding-resource-type')?.['addEventListener']('change',onUserBindingResourceTypeChange);}async function loadUsers(){const _0x1b39cb=document['getElementById']('users-loading'),_0x2acf59=document['getElementById']('users-error'),_0x179869=document['getElementById']('users-content');try{_0x1b39cb['hidden']=![],_0x2acf59['hidden']=!![],_0x179869['hidden']=!![];const _0x32ed21=await API['getUsers']();state['users']=_0x32ed21['users']||[],renderUsers(),_0x1b39cb['hidden']=!![],_0x179869['hidden']=![];}catch(_0x1e91f1){console['error']('Failed\x20to\x20load\x20users',_0x1e91f1),_0x1b39cb['hidden']=!![],_0x2acf59['hidden']=![],document['getElementById']('users-error-message')['textContent']=_0x1e91f1['message'];}}function renderUsers(){const _0x568ba2=document['getElementById']('users-table-body'),_0x5f34cd=document['getElementById']('user-count');if(!_0x568ba2)return;_0x5f34cd&&(_0x5f34cd['textContent']=state['users']['length']+'\x20user'+(state['users']['length']===0x1?'':'s'));const _0x48f961=[...state['users']]['sort']((_0x4be3ea,_0x2d45a5)=>{const _0x26e9bd=new Date(_0x4be3ea['created_at'])['getTime'](),_0x1ceeaf=new Date(_0x2d45a5['created_at'])['getTime']();return _0x1ceeaf-_0x26e9bd;});_0x568ba2['innerHTML']=_0x48f961['map'](_0x6092c4=>'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22user-username\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+Utils['escapeHtml'](_0x6092c4['username'])+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x6092c4['name'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x6092c4['email'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22access-badges\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x6092c4['isServerAdmin']?'<span\x20class=\x22role-badge\x20role-admin\x22>Server\x20Admin</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x6092c4['hasUserBinding']?'<span\x20class=\x22role-badge\x20role-user-binding\x22>User\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x6092c4['hasTeamBinding']?'<span\x20class=\x22role-badge\x20role-team-binding\x22>Team\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['formatRelativeTime'](_0x6092c4['created_at'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22user-actions\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-icon\x20btn-small\x22\x20onclick=\x22window.editUser(\x27'+_0x6092c4['id']+'\x27)\x22\x20title=\x22Edit\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2214\x22\x20height=\x2214\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M11\x204H4a2\x202\x200\x200\x200-2\x202v14a2\x202\x200\x200\x200\x202\x202h14a2\x202\x200\x200\x200\x202-2v-7\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M18.5\x202.5a2.121\x202.121\x200\x200\x201\x203\x203L12\x2015l-4\x201\x201-4\x209.5-9.5z\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-icon\x20btn-small\x22\x20onclick=\x22window.showAccessBindings(\x27'+_0x6092c4['id']+'\x27)\x22\x20title=\x22Access\x20Bindings\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2214\x22\x20height=\x2214\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M12\x2022s8-4\x208-10V5l-8-3-8\x203v7c0\x206\x208\x2010\x208\x2010z\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-icon\x20btn-small\x20btn-danger\x22\x20onclick=\x22window.deleteUser(\x27'+_0x6092c4['id']+'\x27)\x22\x20title=\x22Delete\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2214\x22\x20height=\x2214\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<polyline\x20points=\x223\x206\x205\x206\x2021\x206\x22></polyline>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M19\x206v14a2\x202\x200\x200\x201-2\x202H7a2\x202\x200\x200\x201-2-2V6m3\x200V4a2\x202\x200\x200\x201\x202-2h4a2\x202\x200\x200\x201\x202\x202v2\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-secondary\x20btn-small\x22\x20onclick=\x22window.resetPassword(\x27'+_0x6092c4['id']+'\x27)\x22>Reset\x20Password</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20</tr>\x0a\x20\x20')['join']('');}window['showAccessBindings']=function(_0x202900){const _0x12c856=state['users']['find'](_0xfea04c=>_0xfea04c['id']===_0x202900);if(!_0x12c856)return;state['bindingsUserId']=_0x202900,state['bindingsDirty']=![];const _0x4406b4=document['getElementById']('bindings-modal'),_0x14d9c3=document['getElementById']('bindings-modal-title');_0x14d9c3['textContent']='Access\x20Bindings\x20—\x20'+_0x12c856['name'],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],_0x4406b4['hidden']=![],loadUserBindings(_0x202900);};function hasUnsavedBindingChanges(){const _0x19b6af=document['getElementById']('add-user-binding-form');return _0x19b6af&&!_0x19b6af['hidden'];}async function hideAccessBindingsModal(){if(hasUnsavedBindingChanges()){if(!confirm('You\x20have\x20an\x20unsaved\x20binding.\x20Discard\x20changes?'))return;document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![];}const _0x29e662=document['getElementById']('bindings-modal');_0x29e662['hidden']=!![];const _0x2bfa5b=state['bindingsDirty'];state['bindingsUserId']=null,state['userBindings']=[],state['bindingsDirty']=![],_0x2bfa5b&&await loadUsers();}async function loadUserBindings(_0x166423){const _0x4a3403=document['getElementById']('user-bindings-loading'),_0x5d3a0d=document['getElementById']('user-bindings-empty'),_0x1c9f13=document['getElementById']('user-bindings-list-container'),_0x4be6eb=document['getElementById']('add-user-binding-btn'),_0x28b228=document['getElementById']('user-team-bindings-note'),_0x4c307a=document['getElementById']('user-team-bindings-text');_0x4a3403['hidden']=![],_0x5d3a0d['hidden']=!![],_0x1c9f13['style']['display']='none',_0x4be6eb['hidden']=!![],_0x28b228['hidden']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![];try{const [_0xd4a750,_0x8347cf]=await Promise['all']([API['getBindings']({'subject_type':'user','subject_id':_0x166423}),API['getTeams']()]);state['userBindings']=_0xd4a750['bindings']||[];const _0x16e67e=(_0x8347cf['teams']||[])['filter'](_0x337a13=>(_0x337a13['members']||[])['includes'](_0x166423)),_0x5ec26f=[];if(_0x16e67e['length']>0x0){const _0x31a6be=await Promise['all'](_0x16e67e['map'](_0x5e9e5f=>API['getBindings']({'subject_type':'team','subject_id':_0x5e9e5f['id']})));for(let _0x266bd3=0x0;_0x266bd3<_0x16e67e['length'];_0x266bd3++){const _0x569a59=_0x31a6be[_0x266bd3]['bindings']||[];_0x569a59['length']>0x0&&_0x5ec26f['push'](_0x16e67e[_0x266bd3]);}}_0x4a3403['hidden']=!![];state['userBindings']['length']===0x0?_0x5d3a0d['hidden']=![]:(_0x1c9f13['style']['display']='',renderUserBindingsTable());if(_0x5ec26f['length']>0x0){const _0x4c2e70=_0x5ec26f['map'](_0x3a52c9=>_0x3a52c9['name']),_0x43705a=_0x4c2e70['length']<=0x3?_0x4c2e70['join'](',\x20'):_0x4c2e70['slice'](0x0,0x3)['join'](',\x20')+(',\x20and\x20'+(_0x4c2e70['length']-0x3)+'\x20more');_0x4c307a['textContent']='This\x20user\x20also\x20has\x20access\x20via\x20team\x20memberships\x20('+_0x43705a+').';}else _0x4c307a['textContent']='This\x20user\x20has\x20no\x20access\x20via\x20team\x20memberships.';_0x28b228['hidden']=![],_0x4be6eb['hidden']=![];}catch(_0xa6e900){_0x4a3403['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0xa6e900['message'],'error');}}function renderUserBindingsTable(){const _0x1ec6ef=document['getElementById']('user-bindings-table-body');if(!_0x1ec6ef)return;_0x1ec6ef['innerHTML']=state['userBindings']['map'](_0x2fcadb=>{const _0x51550d=_0x2fcadb['resource_type']==='server'?'Server':_0x2fcadb['resource_id']==='*'?'All\x20'+_0x2fcadb['resource_type']+'s':Utils['escapeHtml'](_0x2fcadb['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x51550d+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x2fcadb['role_name']||_0x2fcadb['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteUserBindingClick(\x27'+_0x2fcadb['id']+'\x27)\x22\x20style=\x22color:\x20var(--color-danger);\x22>Remove</button>\x0a\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20</tr>';})['join']('');}function populateUserBindingForm(){const _0x5b3993=document['getElementById']('user-binding-resource-type');_0x5b3993['value']='environment',updateUserBindingFormForResourceType('environment');}function onUserBindingResourceTypeChange(){const _0x2efa0c=document['getElementById']('user-binding-resource-type')['value'];updateUserBindingFormForResourceType(_0x2efa0c);}function updateUserBindingFormForResourceType(_0x261e4e){const _0x25182f=document['getElementById']('user-binding-resource-container'),_0x180a03=document['getElementById']('user-binding-resource'),_0x2897fb=document['getElementById']('user-binding-role');if(_0x261e4e==='server')_0x25182f['style']['display']='none';else{_0x25182f['style']['display']='';if(_0x261e4e==='environment'){const _0x9cbfd5=new Set(state['userBindings']['filter'](_0x133252=>_0x133252['resource_type']==='environment')['map'](_0x345bd2=>_0x345bd2['resource_id'])),_0x34c5d7=state['environments']['filter'](_0x19e334=>!_0x9cbfd5['has'](_0x19e334['name']));_0x180a03['innerHTML']=_0x34c5d7['length']?_0x34c5d7['map'](_0x2d3bae=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x2d3bae['name'])+'\x22>'+Utils['escapeHtml'](_0x2d3bae['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x261e4e==='team'){const _0x546b39=new Set(state['userBindings']['filter'](_0x18d004=>_0x18d004['resource_type']==='team')['map'](_0x3b27c6=>_0x3b27c6['resource_id'])),_0x5a460=state['teams']['filter'](_0xfb6586=>!_0x546b39['has'](_0xfb6586['id']));_0x180a03['innerHTML']=_0x5a460['length']?_0x5a460['map'](_0x5888a8=>'<option\x20value=\x22'+_0x5888a8['id']+'\x22>'+Utils['escapeHtml'](_0x5888a8['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x11b318=state['roles']['filter'](_0x45a2ea=>_0x45a2ea['resource_type']===_0x261e4e);_0x2897fb['innerHTML']=_0x11b318['length']?_0x11b318['filter'](_0x85ef66=>{const _0x3e7c1a=_0x261e4e==='server'?undefined:_0x180a03['value'];return!state['userBindings']['some'](_0x1bd25f=>_0x1bd25f['resource_type']===_0x261e4e&&_0x1bd25f['role_id']===_0x85ef66['id']&&(_0x261e4e==='server'||_0x1bd25f['resource_id']===_0x3e7c1a));})['map'](_0x36bbb1=>'<option\x20value=\x22'+_0x36bbb1['id']+'\x22>'+Utils['escapeHtml'](_0x36bbb1['name'])+'</option>')['join']('')||'<option\x20value=\x22\x22>No\x20available\x20roles</option>':'<option\x20value=\x22\x22>No\x20roles\x20for\x20this\x20resource\x20type</option>';}async function saveUserBinding(){const _0x2d3f39=document['getElementById']('user-binding-resource-type')['value'],_0x222867=document['getElementById']('user-binding-role')['value'];if(!_0x222867||!state['bindingsUserId'])return;const _0x3648eb=_0x2d3f39==='server'?undefined:document['getElementById']('user-binding-resource')['value'];if(_0x2d3f39!=='server'&&!_0x3648eb)return;const _0x4b0b03=document['getElementById']('save-user-binding-btn');_0x4b0b03['disabled']=!![],_0x4b0b03['textContent']='Adding…';try{const _0xfda10c={'subject_type':'user','subject_id':state['bindingsUserId'],'role_id':_0x222867,'resource_type':_0x2d3f39};if(_0x3648eb)_0xfda10c['resource_id']=_0x3648eb;await API['createBinding'](_0xfda10c),Utils['showToast']('Binding\x20added','success'),state['bindingsDirty']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],await loadUserBindings(state['bindingsUserId']);}catch(_0xde1255){Utils['showToast'](_0xde1255['message'],'error');}finally{_0x4b0b03['disabled']=![],_0x4b0b03['textContent']='Add\x20Binding';}}window['deleteUserBindingClick']=async function(_0x54caeb){try{await API['deleteBinding'](_0x54caeb),Utils['showToast']('Binding\x20removed','success'),state['bindingsDirty']=!![],await loadUserBindings(state['bindingsUserId']);}catch(_0x5fcc95){Utils['showToast'](_0x5fcc95['message'],'error');}};function showCreateUserModal(){state['editingUserId']=null;const _0x83d2c6=document['getElementById']('user-modal'),_0x19330a=document['getElementById']('modal-title'),_0x23a649=document['getElementById']('user-password'),_0x358849=document['getElementById']('password-required'),_0x3fad18=document['getElementById']('password-hint'),_0x3f9a1e=document['getElementById']('skip-password-container'),_0x5b8b94=document['getElementById']('skip-password');_0x19330a['textContent']='Create\x20User',document['getElementById']('user-form')['reset'](),_0x23a649['required']=!![];if(_0x358849)_0x358849['textContent']='*';_0x3f9a1e&&(_0x3f9a1e['style']['display']='block',_0x5b8b94['checked']=![]),_0x3fad18&&(_0x3fad18['textContent']='Minimum\x208\x20characters'),_0x83d2c6['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);}window['editUser']=function(_0x1dac27){const _0x440bd0=state['users']['find'](_0x35ed39=>_0x35ed39['id']===_0x1dac27);if(!_0x440bd0)return;state['editingUserId']=_0x1dac27;const _0x48927b=document['getElementById']('user-modal'),_0x378b6a=document['getElementById']('modal-title'),_0x2e0d97=document['getElementById']('user-password'),_0x3c9da5=document['getElementById']('password-required'),_0x8ef254=document['getElementById']('password-hint'),_0x3b1bb8=document['getElementById']('skip-password-container');_0x378b6a['textContent']='Edit\x20User',document['getElementById']('user-username')['value']=_0x440bd0['username'],document['getElementById']('user-name')['value']=_0x440bd0['name'],document['getElementById']('user-email')['value']=_0x440bd0['email'],_0x2e0d97['value']='',_0x2e0d97['required']=![];if(_0x3c9da5)_0x3c9da5['textContent']='';_0x3b1bb8&&(_0x3b1bb8['style']['display']='none'),_0x8ef254&&(_0x8ef254['textContent']='Leave\x20blank\x20to\x20keep\x20current\x20password'),_0x48927b['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);};function hideUserModal(){const _0x443906=document['getElementById']('user-modal'),_0x484a51=document['getElementById']('form-error'),_0x57eaf8=document['getElementById']('save-user');_0x443906['hidden']=!![],_0x484a51['hidden']=!![],state['editingUserId']=null,_0x57eaf8&&(_0x57eaf8['disabled']=![],_0x57eaf8['textContent']='Save\x20User');}async function saveUser(){const _0x2da3db=document['getElementById']('user-form'),_0x3f909c=document['getElementById']('skip-password')?.['checked']||![];if(!_0x3f909c&&!_0x2da3db['checkValidity']()){_0x2da3db['reportValidity']();return;}const _0x32be79=document['getElementById']('form-error'),_0x58405a=document['getElementById']('save-user'),_0x2a3508=document['getElementById']('user-username')['value']['trim'](),_0x57571b=document['getElementById']('user-name')['value']['trim'](),_0x320533=document['getElementById']('user-email')['value']['trim'](),_0x50ad7d=document['getElementById']('user-password')['value'];if(!_0x2a3508||!_0x57571b||!_0x320533){_0x32be79['textContent']='Please\x20fill\x20in\x20all\x20required\x20fields',_0x32be79['hidden']=![],_0x32be79['scrollIntoView']({'behavior':'smooth','block':'nearest'});return;}_0x32be79['hidden']=!![];const _0x389329=_0x58405a['textContent'];_0x58405a['disabled']=!![],_0x58405a['textContent']=state['editingUserId']?'Updating...':'Creating...';try{if(state['editingUserId']){const _0x3f3042={'username':_0x2a3508,'name':_0x57571b,'email':_0x320533};_0x50ad7d&&(_0x3f3042['password']=_0x50ad7d),await API['updateUser'](state['editingUserId'],_0x3f3042),Utils['showToast']('User\x20updated\x20successfully','success'),await loadUsers(),hideUserModal();}else{const _0x2e8594={'username':_0x2a3508,'name':_0x57571b,'email':_0x320533};if(!_0x3f909c){if(!_0x50ad7d)throw new Error('Password\x20is\x20required\x20for\x20new\x20users');_0x2e8594['password']=_0x50ad7d;}const _0x20e151=await API['createUser'](_0x2e8594),_0x1cc459=_0x20e151['user'];if(_0x3f909c||!_0x50ad7d){const _0x6cedc6=await API['createPasswordToken'](_0x1cc459['id'],'setup',![]);state['setupLinkData']={'username':_0x1cc459['username'],'email':_0x1cc459['email'],'url':_0x6cedc6['token']['setupUrl'],'userId':_0x1cc459['id'],'type':'setup','emailSent':![]},await loadUsers(),hideUserModal(),showSetupLinkModal();}else Utils['showToast']('User\x20created\x20successfully','success'),await loadUsers(),hideUserModal();}}catch(_0x38177e){console['error']('Failed\x20to\x20save\x20user',_0x38177e),_0x32be79['textContent']=_0x38177e['message'],_0x32be79['hidden']=![],_0x32be79['scrollIntoView']({'behavior':'smooth','block':'nearest'}),_0x58405a['disabled']=![],_0x58405a['textContent']=_0x389329;}}window['deleteUser']=function(_0x2dc2b1){const _0x14a524=state['users']['find'](_0x4f9749=>_0x4f9749['id']===_0x2dc2b1);if(!_0x14a524)return;state['deletingUserId']=_0x2dc2b1;const _0x39636f=document['getElementById']('delete-modal'),_0x381715=document['getElementById']('delete-user-name');_0x381715['textContent']=_0x14a524['name']+'\x20('+_0x14a524['username']+')',_0x39636f['hidden']=![];};function hideDeleteModal(){const _0x579dc1=document['getElementById']('delete-modal');_0x579dc1['hidden']=!![],state['deletingUserId']=null;const _0x300e52=document['getElementById']('confirm-delete');_0x300e52&&(_0x300e52['disabled']=![],_0x300e52['textContent']='Delete\x20User');}async function confirmDeleteUser(){if(!state['deletingUserId'])return;const _0x39a6ce=document['getElementById']('confirm-delete'),_0x30b6b7=_0x39a6ce['textContent'];_0x39a6ce['disabled']=!![],_0x39a6ce['textContent']='Deleting...';try{await API['deleteUser'](state['deletingUserId']),Utils['showToast']('User\x20deleted\x20successfully','success'),await loadUsers(),hideDeleteModal();}catch(_0xe3ab42){console['error']('Failed\x20to\x20delete\x20user',_0xe3ab42),Utils['showToast']('Failed\x20to\x20delete\x20user:\x20'+_0xe3ab42['message'],'error'),_0x39a6ce['disabled']=![],_0x39a6ce['textContent']=_0x30b6b7;}}function handleSkipPasswordChange(_0x2ac191){const _0x3a484f=document['getElementById']('user-password'),_0x3760eb=_0x2ac191['target']['checked'];_0x3760eb?(_0x3a484f['required']=![],_0x3a484f['disabled']=!![],_0x3a484f['value']=''):(_0x3a484f['required']=!![],_0x3a484f['disabled']=![]);}function showSetupLinkModal(){if(!state['setupLinkData'])return;const _0x2ee6ac=document['getElementById']('setup-link-modal'),_0x2d36f9=document['getElementById']('setup-link-username'),_0x4a1006=document['getElementById']('setup-link-url'),_0x195e3a=document['getElementById']('email-setup-link'),_0x2e4fb3=document['getElementById']('email-button-text');_0x2d36f9['textContent']=state['setupLinkData']['username'],_0x4a1006['textContent']=state['setupLinkData']['url'],_0x195e3a&&_0x2e4fb3&&(_0x195e3a['disabled']=![],_0x2e4fb3['textContent']='Email\x20Link',state['emailConfigured']&&!state['setupLinkData']['emailSent']?_0x195e3a['style']['display']='inline-block':_0x195e3a['style']['display']='none'),_0x2ee6ac['hidden']=![];}function hideSetupLinkModal(){const _0x452296=document['getElementById']('setup-link-modal');_0x452296['hidden']=!![],state['setupLinkData']=null;}async function copySetupLink(){if(!state['setupLinkData'])return;try{await navigator['clipboard']['writeText'](state['setupLinkData']['url']),Utils['showToast']('Link\x20copied\x20to\x20clipboard','success');}catch(_0x2981a6){console['error']('Failed\x20to\x20copy\x20link',_0x2981a6),Utils['showToast']('Failed\x20to\x20copy\x20link','error');}}async function emailSetupLink(){if(!state['setupLinkData'])return;const _0x510b07=document['getElementById']('email-setup-link'),_0x1adf4b=document['getElementById']('email-button-text');if(!_0x510b07||!_0x1adf4b)return;const _0x5e33ec=_0x1adf4b['textContent'];_0x510b07['disabled']=!![],_0x1adf4b['textContent']='Sending...';try{const _0x4413ec=await API['createPasswordToken'](state['setupLinkData']['userId'],state['setupLinkData']['type'],!![]);if(_0x4413ec['emailSent'])Utils['showToast']('Email\x20sent\x20to\x20'+state['setupLinkData']['email'],'success'),state['setupLinkData']['emailSent']=!![],_0x510b07['style']['display']='none';else{const _0x2ed0c6=_0x4413ec['emailError']||'Failed\x20to\x20send\x20email';Utils['showToast'](_0x2ed0c6,'error'),_0x510b07['disabled']=![],_0x1adf4b['textContent']=_0x5e33ec;}}catch(_0x1b6a5d){console['error']('Failed\x20to\x20email\x20setup\x20link',_0x1b6a5d),Utils['showToast']('Failed\x20to\x20send\x20email:\x20'+_0x1b6a5d['message'],'error'),_0x510b07['disabled']=![],_0x1adf4b['textContent']=_0x5e33ec;}}window['resetPassword']=async function(_0x22ccc6){const _0x23393a=state['users']['find'](_0x18237b=>_0x18237b['id']===_0x22ccc6);if(!_0x23393a)return;const _0x19ec95=await ConfirmDialog['show']({'title':'Reset\x20Password','message':'Generate\x20a\x20password\x20reset\x20link\x20for\x20'+_0x23393a['name']+'\x20('+_0x23393a['username']+')?\x20This\x20will\x20create\x20a\x20link\x20that\x20they\x20can\x20use\x20to\x20set\x20a\x20new\x20password.','confirmText':'Generate\x20Link'});if(!_0x19ec95)return;try{const _0x55751f=await API['createPasswordToken'](_0x22ccc6,'reset',![]);state['setupLinkData']={'username':_0x23393a['username'],'email':_0x23393a['email'],'url':_0x55751f['token']['setupUrl'],'userId':_0x23393a['id'],'type':'reset','emailSent':![]},showSetupLinkModal();}catch(_0x5a6e62){console['error']('Failed\x20to\x20create\x20password\x20reset\x20link',_0x5a6e62),Utils['showToast']('Failed\x20to\x20create\x20password\x20reset\x20link:\x20'+_0x5a6e62['message'],'error');}};
@@ -1 +1 @@
1
- import{API,Utils}from'./app.js';const dragState={'draggedTaskId':null,'draggedElement':null,'sourceGroupId':null,'isDragging':![]},AGENT_ICONS={'claude':'<svg\x20viewBox=\x220\x200\x2016\x2016\x22\x20fill=\x22currentColor\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20aria-hidden=\x22true\x22><path\x20d=\x22m3.127\x2010.604\x203.135-1.76.053-.153-.053-.085H6.11l-.525-.032-1.791-.048-1.554-.065-1.505-.08-.38-.081L0\x207.832l.036-.234.32-.214.455.04\x201.009.069\x201.513.105\x201.097.064\x201.626.17h.259l.036-.105-.089-.065-.068-.064-1.566-1.062-1.695-1.121-.887-.646-.48-.327-.243-.306-.104-.67.435-.48.585.04.15.04.593.456\x201.267.981\x201.654\x201.218.242.202.097-.068.012-.049-.109-.181-.9-1.626-.96-1.655-.428-.686-.113-.411a2\x202\x200\x200\x201-.068-.484l.496-.674L4.446\x200l.662.089.279.242.411.94.666\x201.48\x201.033\x202.014.302.597.162.553.06.17h.105v-.097l.085-1.134.157-1.392.154-1.792.052-.504.25-.605.497-.327.387.186.319.456-.045.294-.19\x201.23-.37\x201.93-.243\x201.29h.142l.161-.16.654-.868\x201.097-1.372.484-.545.565-.601.363-.287h.686l.505.751-.226.775-.707.895-.585.759-.839\x201.13-.524.904.048.072.125-.012\x201.897-.403\x201.024-.186\x201.223-.21.553.258.06.263-.218.536-1.307.323-1.533.307-2.284.54-.028.02.032.04\x201.029.098.44.024h1.077l2.005.15.525.346.315.424-.053.323-.807.411-3.631-.863-.872-.218h-.12v.073l.726.71\x201.331\x201.202\x201.667\x201.55.084.383-.214.302-.226-.032-1.464-1.101-.565-.497-1.28-1.077h-.084v.113l.295.432\x201.557\x202.34.08.718-.112.234-.404.141-.444-.08-.911-1.28-.94-1.44-.759-1.291-.093.053-.448\x204.821-.21.246-.484.186-.403-.307-.214-.496.214-.98.258-1.28.21-1.016.19-1.263.112-.42-.008-.028-.092.012-.953\x201.307-1.448\x201.957-1.146\x201.227-.274.109-.477-.247.045-.44.266-.39\x201.586-2.018.956-1.25.617-.723-.004-.105h-.036l-4.212\x204.212z\x22/></svg>','codex':'<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22currentColor\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20aria-hidden=\x22true\x22><path\x20d=\x22M22.2819\x209.8211a5.9847\x205.9847\x200\x200\x200-.5157-4.9108\x206.0462\x206.0462\x200\x200\x200-6.5098-2.9A6.0651\x206.0651\x200\x200\x200\x204.9807\x204.1818a5.9847\x205.9847\x200\x200\x200-3.9977\x202.9\x206.0462\x206.0462\x200\x200\x200\x20.7427\x207.0966\x205.98\x205.98\x200\x200\x200\x20.511\x204.9107\x206.051\x206.051\x200\x200\x200\x206.5146\x202.9001A5.9847\x205.9847\x200\x200\x200\x2013.2599\x2024a6.0557\x206.0557\x200\x200\x200\x205.7718-4.2058\x205.9894\x205.9894\x200\x200\x200\x203.9977-2.9001\x206.0557\x206.0557\x200\x200\x200-.7475-7.0729zm-9.022\x2012.6081a4.4755\x204.4755\x200\x200\x201-2.8764-1.0408l.1419-.0804\x204.7783-2.7582a.7948.7948\x200\x200\x200\x20.3927-.6813v-6.7369l2.02\x201.1686a.071.071\x200\x200\x201\x20.038.052v5.5826a4.504\x204.504\x200\x200\x201-4.4945\x204.4944zm-9.6607-4.1254a4.4708\x204.4708\x200\x200\x201-.5346-3.0137l.142.0852\x204.783\x202.7582a.7712.7712\x200\x200\x200\x20.7806\x200l5.8428-3.3685v2.3324a.0804.0804\x200\x200\x201-.0332.0615L9.74\x2019.9502a4.4992\x204.4992\x200\x200\x201-6.1408-1.6464zM2.3408\x207.8956a4.485\x204.485\x200\x200\x201\x202.3655-1.9728V11.6a.7664.7664\x200\x200\x200\x20.3879.6765l5.8144\x203.3543-2.0201\x201.1685a.0757.0757\x200\x200\x201-.071\x200l-4.8303-2.7865A4.504\x204.504\x200\x200\x201\x202.3408\x207.872zm16.5963\x203.8558L13.1038\x208.364\x2015.1192\x207.2a.0757.0757\x200\x200\x201\x20.071\x200l4.8303\x202.7913a4.4944\x204.4944\x200\x200\x201-.6765\x208.1042v-5.6772a.79.79\x200\x200\x200-.407-.667zm2.0107-3.0231l-.142-.0852-4.7735-2.7818a.7759.7759\x200\x200\x200-.7854\x200L9.409\x209.2297V6.8974a.0662.0662\x200\x200\x201\x20.0284-.0615l4.8303-2.7866a4.4992\x204.4992\x200\x200\x201\x206.6802\x204.66zM8.3065\x2012.863l-2.02-1.1638a.0804.0804\x200\x200\x201-.038-.0567V6.0742a4.4992\x204.4992\x200\x200\x201\x207.3757-3.4537l-.142.0805L8.704\x205.459a.7948.7948\x200\x200\x200-.3927.6813zm1.0976-2.3654l2.602-1.4998\x202.6069\x201.4998v2.9994l-2.5974\x201.4997-2.6067-1.4997Z\x22/></svg>','gemini':'<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20aria-hidden=\x22true\x22><path\x20d=\x22M12\x202L9.09\x209.09\x202\x2012l7.09\x202.91L12\x2022l2.91-7.09L22\x2012l-7.09-2.91z\x22></path></svg>','unknown':'<svg\x20viewBox=\x220\x200\x2020\x2020\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x221.6\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20aria-hidden=\x22true\x22><circle\x20cx=\x2210\x22\x20cy=\x2210\x22\x20r=\x228\x22\x20/><path\x20d=\x22M10\x206.5c-1.1\x200-2\x20.7-2\x201.6\x200\x20.9\x201\x201.3\x201.6\x201.7.7.4\x201\x20.8\x201\x201.5V12\x22\x20/><circle\x20cx=\x2210\x22\x20cy=\x2214\x22\x20r=\x220.8\x22\x20fill=\x22currentColor\x22\x20stroke=\x22none\x22\x20/></svg>'},STATUS_ICONS={'running':'<svg\x20class=\x22status-icon\x20spinning\x22\x20viewBox=\x220\x200\x2016\x2016\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222.5\x22\x20stroke-linecap=\x22round\x22><path\x20d=\x22M8\x202\x20A6\x206\x200\x200\x201\x2014\x208\x22/></svg>','completed':'<svg\x20class=\x22status-icon\x22\x20viewBox=\x220\x200\x2016\x2016\x22\x20fill=\x22currentColor\x22><path\x20d=\x22M8\x200a8\x208\x200\x201\x200\x200\x2016A8\x208\x200\x200\x200\x208\x200zm3.78\x206.28-4.5\x204.5a.75.75\x200\x200\x201-1.06\x200l-2-2a.75.75\x200\x201\x201\x201.06-1.06L6.75\x209.19l3.97-3.97a.75.75\x200\x201\x201\x201.06\x201.06z\x22/></svg>','failed':'<svg\x20class=\x22status-icon\x22\x20viewBox=\x220\x200\x2016\x2016\x22\x20fill=\x22currentColor\x22><path\x20d=\x22M8\x200a8\x208\x200\x201\x200\x200\x2016A8\x208\x200\x200\x200\x208\x200zm3.53\x2010.47a.75.75\x200\x201\x201-1.06\x201.06L8\x209.06l-2.47\x202.47a.75.75\x200\x200\x201-1.06-1.06L6.94\x208\x204.47\x205.53a.75.75\x200\x200\x201\x201.06-1.06L8\x206.94l2.47-2.47a.75.75\x200\x200\x201\x201.06\x201.06L9.06\x208l2.47\x202.47z\x22/></svg>','staged':'<svg\x20class=\x22status-icon\x22\x20viewBox=\x220\x200\x2016\x2016\x22\x20fill=\x22currentColor\x22><path\x20d=\x22M8\x200a8\x208\x200\x201\x200\x200\x2016A8\x208\x200\x200\x200\x208\x200zm0\x2012a.75.75\x200\x201\x201\x200-1.5.75.75\x200\x200\x201\x200\x201.5zm1-3.5a1\x201\x200\x200\x201-2\x200V5a1\x201\x200\x201\x201\x202\x200v3.5z\x22/></svg>','queued':'<svg\x20class=\x22status-icon\x22\x20viewBox=\x220\x200\x2016\x2016\x22\x20fill=\x22currentColor\x22><path\x20d=\x22M8\x200a8\x208\x200\x201\x200\x200\x2016A8\x208\x200\x200\x200\x208\x200zm0\x2014A6\x206\x200\x201\x201\x208\x202a6\x206\x200\x200\x201\x200\x2012zm1-6.5V4H7v4.5l3\x203\x201.5-1.5-2.5-2.5z\x22/></svg>'};export class VariantGroupingManager{constructor(_0x2dfb8d={}){this['container']=null,this['onGroupChange']=_0x2dfb8d['onGroupChange']||(()=>{}),this['onAddExistingTask']=_0x2dfb8d['onAddExistingTask']||(()=>{}),this['tasks']=[],this['groupId']=_0x2dfb8d['groupId']||null,this['isOpen']=![];}['init'](_0xac93e7,_0x2e56aa,_0x9676a){this['container']=_0xac93e7,this['tasks']=_0x2e56aa,this['groupId']=_0x9676a,this['render'](),this['attachEventListeners']();}['updateTasks'](_0x257473){const _0x30c956=new Map(_0x257473['map'](_0x3d59c9=>[_0x3d59c9['taskId'],_0x3d59c9]));this['tasks']=this['tasks']['map'](_0x4f243e=>{const _0x33cecd=_0x30c956['get'](_0x4f243e['taskId']);return _0x33cecd?_0x33cecd:_0x4f243e;});for(const _0x5c16c0 of _0x257473){!this['tasks']['some'](_0x5d1ccf=>_0x5d1ccf['taskId']===_0x5c16c0['taskId'])&&this['tasks']['push'](_0x5c16c0);}this['isOpen']&&this['render']();}['open'](){this['isOpen']=!![],this['render'](),this['container']?.['classList']['add']('open');}['close'](){this['isOpen']=![],this['container']?.['classList']['remove']('open');}['render'](){if(!this['container'])return;const _0x10a281=this['tasks']['filter'](_0x18e35d=>_0x18e35d['groupId']===this['groupId'])['sort']((_0x3eb092,_0x194684)=>(_0x3eb092['groupIndex']??0x0)-(_0x194684['groupIndex']??0x0)),_0x113478=this['tasks']['filter'](_0x507d81=>!_0x507d81['groupId']||_0x507d81['groupId']!==this['groupId']);this['container']['innerHTML']='\x0a\x20\x20\x20\x20\x20\x20<div\x20class=\x22variant-grouping-manager\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-header\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<h3>Manage\x20Task\x20Group</h3>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22vgm-close-btn\x22\x20title=\x22Close\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20width=\x2220\x22\x20height=\x2220\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M18\x206L6\x2018M6\x206l12\x2012\x22/>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-content\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-section\x20vgm-grouped\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-section-header\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-section-title\x22>Grouped\x20Variants</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-section-count\x22>'+_0x10a281['length']+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-drop-zone\x20vgm-grouped-zone\x22\x20data-zone=\x22grouped\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x10a281['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20add\x20to\x20group</div>':_0x10a281['map']((_0x21a3a8,_0x2624c4)=>this['renderVariantCard'](_0x21a3a8,_0x2624c4,!![]))['join'](''))+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-divider\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-divider-line\x22></div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-divider-text\x22>Drag\x20to\x20move</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-divider-line\x22></div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-section\x20vgm-ungrouped\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-section-header\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-section-title\x22>Ungrouped\x20Tasks</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-section-count\x22>'+_0x113478['length']+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-drop-zone\x20vgm-ungrouped-zone\x22\x20data-zone=\x22ungrouped\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x113478['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20remove\x20from\x20group</div>':_0x113478['map']((_0x1bf5a4,_0x47b365)=>this['renderVariantCard'](_0x1bf5a4,_0x47b365,![]))['join'](''))+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-actions\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22vgm-btn\x20vgm-btn-secondary\x20vgm-add-existing-btn\x22\x20title=\x22Add\x20an\x20existing\x20task\x20to\x20this\x20group\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M12\x205v14M5\x2012h14\x22/>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20Add\x20Existing\x20Task\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20';}['renderVariantCard'](_0x115d6a,_0x247a4d,_0x201e46){const _0x56991a=_0x115d6a['envVars']?.['CODER_AGENT']||_0x115d6a['envVars']?.['default_agent']||'claude',_0x2c9d9c=AGENT_ICONS[_0x56991a['toLowerCase']()]||AGENT_ICONS['claude'],_0xd4114f=STATUS_ICONS[_0x115d6a['status']]||'',_0x476021='status-'+(_0x115d6a['status']||'unknown'),_0x58f05b=_0x115d6a['isWinner']?'<span\x20class=\x22vgm-badge\x20vgm-badge-winner\x22\x20title=\x22Winner\x22>★</span>':'',_0xd4bda4=_0x115d6a['approvedBy']?'<span\x20class=\x22vgm-badge\x20vgm-badge-approved\x22\x20title=\x22Approved\x22><svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22\x20width=\x2212\x22\x20height=\x2212\x22><path\x20d=\x22M14\x209V5a3\x203\x200\x200\x200-3-3l-4\x209v11h11.28a2\x202\x200\x200\x200\x202-1.7l1.38-9a2\x202\x200\x200\x200-2-2.3zM7\x2022H4a2\x202\x200\x200\x201-2-2v-7a2\x202\x200\x200\x201\x202-2h3\x22></path></svg></span>':'';return'\x0a\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-card\x20'+_0x476021+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20draggable=\x22true\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-task-id=\x22'+_0x115d6a['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-is-grouped=\x22'+_0x201e46+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-index=\x22'+_0x247a4d+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-drag-handle\x22\x20title=\x22Drag\x20to\x20reorder\x20or\x20move\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20fill=\x22currentColor\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M8\x206h2v2H8V6zm6\x200h2v2h-2V6zM8\x2011h2v2H8v-2zm6\x200h2v2h-2v-2zm-6\x205h2v2H8v-2zm6\x200h2v2h-2v-2z\x22/>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-icon\x22\x20data-agent=\x22'+_0x56991a['toLowerCase']()+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x2c9d9c+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-info\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-name\x22>'+Utils['escapeHtml'](_0x115d6a['name']||'Task\x20'+_0x115d6a['taskId']['slice'](-0x6))+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-meta\x22>'+Utils['escapeHtml'](_0x56991a)+'\x20·\x20'+(_0x115d6a['status']||'unknown')+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-badges\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x58f05b+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0xd4bda4+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-status\x20'+_0x476021+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0xd4114f+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22vgm-variant-remove-btn\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20title=\x22'+(_0x201e46?'Remove\x20from\x20group':'Add\x20to\x20group')+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-task-id=\x22'+_0x115d6a['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-action=\x22'+(_0x201e46?'remove':'add')+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x201e46?'<path\x20d=\x22M18\x206L6\x2018M6\x206l12\x2012\x22/>':'<path\x20d=\x22M12\x205v14M5\x2012h14\x22/>')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20';}['attachEventListeners'](){if(!this['container'])return;this['container']['addEventListener']('click',_0x28c69f=>{_0x28c69f['target']['closest']('.vgm-close-btn')&&(this['close'](),this['onGroupChange'](this['tasks'])),_0x28c69f['target']['closest']('.vgm-add-existing-btn')&&(this['close'](),this['onAddExistingTask'](this['groupId']));}),this['container']['addEventListener']('click',async _0x58e7ea=>{const _0x140df0=_0x58e7ea['target']['closest']('.vgm-variant-remove-btn');if(!_0x140df0)return;const _0x29be3f=_0x140df0['dataset']['taskId'],_0x4a2d3f=_0x140df0['dataset']['action'];try{_0x4a2d3f==='remove'?await this['removeFromGroup'](_0x29be3f):await this['addToGroup'](_0x29be3f);}catch(_0x28216b){console['error']('Failed\x20to\x20update\x20group:',_0x28216b),Utils['showToast'](_0x28216b['message']||'Failed\x20to\x20update\x20group','error');}}),this['container']['addEventListener']('dragstart',_0x2f7da1=>this['handleDragStart'](_0x2f7da1)),this['container']['addEventListener']('dragend',_0x330cf5=>this['handleDragEnd'](_0x330cf5)),this['container']['addEventListener']('dragover',_0xa0b039=>this['handleDragOver'](_0xa0b039)),this['container']['addEventListener']('dragleave',_0x341110=>this['handleDragLeave'](_0x341110)),this['container']['addEventListener']('drop',_0x2ae6f4=>this['handleDrop'](_0x2ae6f4));}['handleDragStart'](_0x1eec60){const _0x156710=_0x1eec60['target']['closest']('.vgm-variant-card');if(!_0x156710)return;dragState['draggedTaskId']=_0x156710['dataset']['taskId'],dragState['draggedElement']=_0x156710,dragState['sourceGroupId']=_0x156710['dataset']['isGrouped']==='true'?this['groupId']:null,dragState['isDragging']=!![],_0x156710['classList']['add']('dragging'),_0x1eec60['dataTransfer']['effectAllowed']='move',_0x1eec60['dataTransfer']['setData']('text/plain',_0x156710['dataset']['taskId']),this['container']['classList']['add']('is-dragging');}['handleDragEnd'](_0x2e2fac){const _0x226199=_0x2e2fac['target']['closest']('.vgm-variant-card');_0x226199&&_0x226199['classList']['remove']('dragging'),this['container']['querySelectorAll']('.drag-over,\x20.drop-indicator')['forEach'](_0x4ea944=>{_0x4ea944['classList']['remove']('drag-over','drop-indicator','drop-before','drop-after');}),this['container']['classList']['remove']('is-dragging'),dragState['isDragging']=![],dragState['draggedTaskId']=null,dragState['draggedElement']=null,dragState['sourceGroupId']=null;}['handleDragOver'](_0x197791){_0x197791['preventDefault'](),_0x197791['dataTransfer']['dropEffect']='move';const _0x517ad3=_0x197791['target']['closest']('.vgm-drop-zone'),_0x20be5f=_0x197791['target']['closest']('.vgm-variant-card');this['container']['querySelectorAll']('.vgm-drop-zone')['forEach'](_0x2fe533=>{_0x2fe533['classList']['toggle']('drag-over',_0x2fe533===_0x517ad3);});if(_0x20be5f&&_0x20be5f!==dragState['draggedElement']){const _0x2120fa=_0x20be5f['getBoundingClientRect'](),_0x18271f=_0x2120fa['top']+_0x2120fa['height']/0x2,_0x541399=_0x197791['clientY']<_0x18271f;this['container']['querySelectorAll']('.vgm-variant-card')['forEach'](_0x115cbf=>{_0x115cbf!==_0x20be5f&&_0x115cbf['classList']['remove']('drop-before','drop-after');}),_0x20be5f['classList']['toggle']('drop-before',_0x541399),_0x20be5f['classList']['toggle']('drop-after',!_0x541399);}}['handleDragLeave'](_0x133ac3){const _0x152336=_0x133ac3['target']['closest']('.vgm-drop-zone');_0x152336&&!_0x152336['contains'](_0x133ac3['relatedTarget'])&&_0x152336['classList']['remove']('drag-over');}async['handleDrop'](_0x1696c8){_0x1696c8['preventDefault']();const _0x33c8f0=_0x1696c8['target']['closest']('.vgm-drop-zone'),_0x1de470=_0x1696c8['target']['closest']('.vgm-variant-card'),_0x1e10aa=_0x1696c8['dataTransfer']['getData']('text/plain');if(!_0x33c8f0||!_0x1e10aa)return;this['container']['querySelectorAll']('.drag-over,\x20.drop-before,\x20.drop-after')['forEach'](_0x3a6d52=>{_0x3a6d52['classList']['remove']('drag-over','drop-before','drop-after');});const _0x6300d2=_0x33c8f0['dataset']['zone'],_0x4b9005=_0x6300d2==='grouped',_0x229560=dragState['sourceGroupId']===this['groupId'];try{if(_0x4b9005&&!_0x229560){let _0x1f6716=this['tasks']['filter'](_0x253584=>_0x253584['groupId']===this['groupId'])['length'];if(_0x1de470){const _0x3fea5e=_0x1de470['dataset']['taskId'],_0x300039=this['tasks']['find'](_0x304f74=>_0x304f74['taskId']===_0x3fea5e);if(_0x300039?.['groupIndex']!==undefined){const _0x2bfb78=_0x1de470['getBoundingClientRect'](),_0x4ad05b=_0x1696c8['clientY']<_0x2bfb78['top']+_0x2bfb78['height']/0x2;_0x1f6716=_0x300039['groupIndex']+(_0x4ad05b?0x0:0x1);}}await this['addToGroup'](_0x1e10aa,_0x1f6716);}else{if(!_0x4b9005&&_0x229560)await this['removeFromGroup'](_0x1e10aa);else _0x4b9005&&_0x229560&&_0x1de470&&await this['reorderInGroup'](_0x1e10aa,_0x1de470,_0x1696c8['clientY']);}}catch(_0x413c0f){console['error']('Drop\x20operation\x20failed:',_0x413c0f),Utils['showToast'](_0x413c0f['message']||'Failed\x20to\x20move\x20variant','error');}}async['addToGroup'](_0x1f5769,_0x346691){const _0x5353c5=this['tasks']['find'](_0x3e84f4=>_0x3e84f4['taskId']===_0x1f5769);if(!_0x5353c5)return;_0x346691===undefined&&(_0x346691=this['tasks']['filter'](_0x34906d=>_0x34906d['groupId']===this['groupId'])['length']),!this['groupId']&&(this['groupId']=API['generateGroupId'](),await API['createTaskGroup']({'groupId':this['groupId']})),await API['updateTaskGroup'](_0x1f5769,this['groupId'],_0x346691),_0x5353c5['groupId']=this['groupId'],_0x5353c5['groupIndex']=_0x346691,this['render'](),this['onGroupChange'](this['tasks']);}async['removeFromGroup'](_0x1977e2){const _0x4fd329=this['tasks']['find'](_0x45af17=>_0x45af17['taskId']===_0x1977e2);if(!_0x4fd329)return;await API['removeTaskFromGroup'](_0x1977e2),_0x4fd329['groupId']=null,_0x4fd329['groupIndex']=null,this['render'](),this['onGroupChange'](this['tasks']);}async['reorderInGroup'](_0x384789,_0x3d86ac,_0x203360){const _0xc5fda3=this['tasks']['find'](_0xfebd1b=>_0xfebd1b['taskId']===_0x384789),_0x1c3e27=_0x3d86ac['dataset']['taskId'],_0x3f5be8=this['tasks']['find'](_0x1984c8=>_0x1984c8['taskId']===_0x1c3e27);if(!_0xc5fda3||!_0x3f5be8||_0xc5fda3['taskId']===_0x3f5be8['taskId'])return;const _0x3dcd5f=_0x3d86ac['getBoundingClientRect'](),_0x53bb70=_0x203360<_0x3dcd5f['top']+_0x3dcd5f['height']/0x2;let _0x4fd5b0=_0x3f5be8['groupIndex']??0x0;if(!_0x53bb70)_0x4fd5b0++;if((_0xc5fda3['groupIndex']??0x0)<(_0x3f5be8['groupIndex']??0x0))_0x4fd5b0--;if(_0x4fd5b0===_0xc5fda3['groupIndex'])return;await API['updateTaskGroup'](_0x384789,this['groupId'],_0x4fd5b0);const _0x53df7a=this['tasks']['filter'](_0x7e261d=>_0x7e261d['groupId']===this['groupId'])['sort']((_0x1ebd5f,_0xf35b5e)=>(_0x1ebd5f['groupIndex']??0x0)-(_0xf35b5e['groupIndex']??0x0)),_0x5de195=_0x53df7a['findIndex'](_0x2e876d=>_0x2e876d['taskId']===_0x384789);_0x5de195!==-0x1&&_0x53df7a['splice'](_0x5de195,0x1),_0x53df7a['splice'](_0x4fd5b0,0x0,_0xc5fda3),_0x53df7a['forEach']((_0x98bd63,_0xc8035b)=>{_0x98bd63['groupIndex']=_0xc8035b;}),this['render'](),this['onGroupChange'](this['tasks']);}}export function initializeTabDragDrop(_0x5c6be9,_0x14a34e,_0x34ad51,_0x438eba={}){if(!_0x5c6be9)return;const {onReorder:_0xcb79c8,onRemove:_0x21040c}=_0x438eba,_0x83ead1=_0x5c6be9['querySelectorAll']('.task-tab');_0x83ead1['forEach']((_0x4af619,_0xd4838d)=>{_0x4af619['setAttribute']('draggable','true'),_0x4af619['dataset']['index']=_0xd4838d,_0x4af619['addEventListener']('dragstart',_0x30643f=>{_0x30643f['dataTransfer']['effectAllowed']='move',_0x30643f['dataTransfer']['setData']('text/plain',_0x4af619['dataset']['taskId']),_0x4af619['classList']['add']('dragging'),_0x5c6be9['classList']['add']('is-dragging');}),_0x4af619['addEventListener']('dragend',()=>{_0x4af619['classList']['remove']('dragging'),_0x5c6be9['classList']['remove']('is-dragging'),_0x5c6be9['querySelectorAll']('.drop-indicator')['forEach'](_0x16c229=>{_0x16c229['classList']['remove']('drop-indicator','drop-before','drop-after');});}),_0x4af619['addEventListener']('dragover',_0x556155=>{_0x556155['preventDefault'](),_0x556155['dataTransfer']['dropEffect']='move';if(_0x4af619['classList']['contains']('dragging'))return;const _0x142242=_0x4af619['getBoundingClientRect'](),_0x2e6281=_0x142242['left']+_0x142242['width']/0x2,_0x686e59=_0x556155['clientX']<_0x2e6281;_0x83ead1['forEach'](_0x41fd7d=>_0x41fd7d['classList']['remove']('drop-before','drop-after')),_0x4af619['classList']['add'](_0x686e59?'drop-before':'drop-after');}),_0x4af619['addEventListener']('dragleave',()=>{_0x4af619['classList']['remove']('drop-before','drop-after');}),_0x4af619['addEventListener']('drop',async _0x494e01=>{_0x494e01['preventDefault']();const _0x4ba2f9=_0x494e01['dataTransfer']['getData']('text/plain'),_0x461b8d=_0x4af619['dataset']['taskId'];if(_0x4ba2f9===_0x461b8d)return;const _0x5ad4cd=_0x4af619['getBoundingClientRect'](),_0x32d243=_0x494e01['clientX']<_0x5ad4cd['left']+_0x5ad4cd['width']/0x2;_0x4af619['classList']['remove']('drop-before','drop-after'),_0xcb79c8&&await _0xcb79c8(_0x4ba2f9,_0x461b8d,_0x32d243);});});const _0x229ef4=document['createElement']('div');return _0x229ef4['className']='task-tab-remove-zone',_0x229ef4['innerHTML']='\x0a\x20\x20\x20\x20<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20<path\x20d=\x22M18\x206L6\x2018M6\x206l12\x2012\x22/>\x0a\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20<span>Remove\x20from\x20group</span>\x0a\x20\x20',_0x229ef4['style']['display']='none',_0x229ef4['addEventListener']('dragover',_0xe95e7d=>{_0xe95e7d['preventDefault'](),_0x229ef4['classList']['add']('drag-over');}),_0x229ef4['addEventListener']('dragleave',()=>{_0x229ef4['classList']['remove']('drag-over');}),_0x229ef4['addEventListener']('drop',async _0x5d5ea2=>{_0x5d5ea2['preventDefault'](),_0x229ef4['classList']['remove']('drag-over');const _0x332720=_0x5d5ea2['dataTransfer']['getData']('text/plain');_0x21040c&&await _0x21040c(_0x332720);}),_0x5c6be9['addEventListener']('dragstart',()=>{_0x14a34e['length']>0x1&&(_0x229ef4['style']['display']='flex');}),_0x5c6be9['addEventListener']('dragend',()=>{_0x229ef4['style']['display']='none';}),_0x5c6be9['appendChild'](_0x229ef4),{'destroy':()=>{_0x229ef4['remove']();}};}export default VariantGroupingManager;
1
+ import{API,Utils}from'./app.js';const dragState={'draggedTaskId':null,'draggedElement':null,'sourceGroupId':null,'isDragging':![]},AGENT_ICONS={'claude':'<svg\x20viewBox=\x220\x200\x2016\x2016\x22\x20fill=\x22currentColor\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20aria-hidden=\x22true\x22><path\x20d=\x22m3.127\x2010.604\x203.135-1.76.053-.153-.053-.085H6.11l-.525-.032-1.791-.048-1.554-.065-1.505-.08-.38-.081L0\x207.832l.036-.234.32-.214.455.04\x201.009.069\x201.513.105\x201.097.064\x201.626.17h.259l.036-.105-.089-.065-.068-.064-1.566-1.062-1.695-1.121-.887-.646-.48-.327-.243-.306-.104-.67.435-.48.585.04.15.04.593.456\x201.267.981\x201.654\x201.218.242.202.097-.068.012-.049-.109-.181-.9-1.626-.96-1.655-.428-.686-.113-.411a2\x202\x200\x200\x201-.068-.484l.496-.674L4.446\x200l.662.089.279.242.411.94.666\x201.48\x201.033\x202.014.302.597.162.553.06.17h.105v-.097l.085-1.134.157-1.392.154-1.792.052-.504.25-.605.497-.327.387.186.319.456-.045.294-.19\x201.23-.37\x201.93-.243\x201.29h.142l.161-.16.654-.868\x201.097-1.372.484-.545.565-.601.363-.287h.686l.505.751-.226.775-.707.895-.585.759-.839\x201.13-.524.904.048.072.125-.012\x201.897-.403\x201.024-.186\x201.223-.21.553.258.06.263-.218.536-1.307.323-1.533.307-2.284.54-.028.02.032.04\x201.029.098.44.024h1.077l2.005.15.525.346.315.424-.053.323-.807.411-3.631-.863-.872-.218h-.12v.073l.726.71\x201.331\x201.202\x201.667\x201.55.084.383-.214.302-.226-.032-1.464-1.101-.565-.497-1.28-1.077h-.084v.113l.295.432\x201.557\x202.34.08.718-.112.234-.404.141-.444-.08-.911-1.28-.94-1.44-.759-1.291-.093.053-.448\x204.821-.21.246-.484.186-.403-.307-.214-.496.214-.98.258-1.28.21-1.016.19-1.263.112-.42-.008-.028-.092.012-.953\x201.307-1.448\x201.957-1.146\x201.227-.274.109-.477-.247.045-.44.266-.39\x201.586-2.018.956-1.25.617-.723-.004-.105h-.036l-4.212\x204.212z\x22/></svg>','codex':'<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22currentColor\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20aria-hidden=\x22true\x22><path\x20d=\x22M22.2819\x209.8211a5.9847\x205.9847\x200\x200\x200-.5157-4.9108\x206.0462\x206.0462\x200\x200\x200-6.5098-2.9A6.0651\x206.0651\x200\x200\x200\x204.9807\x204.1818a5.9847\x205.9847\x200\x200\x200-3.9977\x202.9\x206.0462\x206.0462\x200\x200\x200\x20.7427\x207.0966\x205.98\x205.98\x200\x200\x200\x20.511\x204.9107\x206.051\x206.051\x200\x200\x200\x206.5146\x202.9001A5.9847\x205.9847\x200\x200\x200\x2013.2599\x2024a6.0557\x206.0557\x200\x200\x200\x205.7718-4.2058\x205.9894\x205.9894\x200\x200\x200\x203.9977-2.9001\x206.0557\x206.0557\x200\x200\x200-.7475-7.0729zm-9.022\x2012.6081a4.4755\x204.4755\x200\x200\x201-2.8764-1.0408l.1419-.0804\x204.7783-2.7582a.7948.7948\x200\x200\x200\x20.3927-.6813v-6.7369l2.02\x201.1686a.071.071\x200\x200\x201\x20.038.052v5.5826a4.504\x204.504\x200\x200\x201-4.4945\x204.4944zm-9.6607-4.1254a4.4708\x204.4708\x200\x200\x201-.5346-3.0137l.142.0852\x204.783\x202.7582a.7712.7712\x200\x200\x200\x20.7806\x200l5.8428-3.3685v2.3324a.0804.0804\x200\x200\x201-.0332.0615L9.74\x2019.9502a4.4992\x204.4992\x200\x200\x201-6.1408-1.6464zM2.3408\x207.8956a4.485\x204.485\x200\x200\x201\x202.3655-1.9728V11.6a.7664.7664\x200\x200\x200\x20.3879.6765l5.8144\x203.3543-2.0201\x201.1685a.0757.0757\x200\x200\x201-.071\x200l-4.8303-2.7865A4.504\x204.504\x200\x200\x201\x202.3408\x207.872zm16.5963\x203.8558L13.1038\x208.364\x2015.1192\x207.2a.0757.0757\x200\x200\x201\x20.071\x200l4.8303\x202.7913a4.4944\x204.4944\x200\x200\x201-.6765\x208.1042v-5.6772a.79.79\x200\x200\x200-.407-.667zm2.0107-3.0231l-.142-.0852-4.7735-2.7818a.7759.7759\x200\x200\x200-.7854\x200L9.409\x209.2297V6.8974a.0662.0662\x200\x200\x201\x20.0284-.0615l4.8303-2.7866a4.4992\x204.4992\x200\x200\x201\x206.6802\x204.66zM8.3065\x2012.863l-2.02-1.1638a.0804.0804\x200\x200\x201-.038-.0567V6.0742a4.4992\x204.4992\x200\x200\x201\x207.3757-3.4537l-.142.0805L8.704\x205.459a.7948.7948\x200\x200\x200-.3927.6813zm1.0976-2.3654l2.602-1.4998\x202.6069\x201.4998v2.9994l-2.5974\x201.4997-2.6067-1.4997Z\x22/></svg>','gemini':'<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20aria-hidden=\x22true\x22><path\x20d=\x22M12\x202L9.09\x209.09\x202\x2012l7.09\x202.91L12\x2022l2.91-7.09L22\x2012l-7.09-2.91z\x22></path></svg>','unknown':'<svg\x20viewBox=\x220\x200\x2020\x2020\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x221.6\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20aria-hidden=\x22true\x22><circle\x20cx=\x2210\x22\x20cy=\x2210\x22\x20r=\x228\x22\x20/><path\x20d=\x22M10\x206.5c-1.1\x200-2\x20.7-2\x201.6\x200\x20.9\x201\x201.3\x201.6\x201.7.7.4\x201\x20.8\x201\x201.5V12\x22\x20/><circle\x20cx=\x2210\x22\x20cy=\x2214\x22\x20r=\x220.8\x22\x20fill=\x22currentColor\x22\x20stroke=\x22none\x22\x20/></svg>'},STATUS_ICONS={'running':'<svg\x20class=\x22status-icon\x20spinning\x22\x20viewBox=\x220\x200\x2016\x2016\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222.5\x22\x20stroke-linecap=\x22round\x22><path\x20d=\x22M8\x202\x20A6\x206\x200\x200\x201\x2014\x208\x22/></svg>','completed':'<svg\x20class=\x22status-icon\x22\x20viewBox=\x220\x200\x2016\x2016\x22\x20fill=\x22currentColor\x22><path\x20d=\x22M8\x200a8\x208\x200\x201\x200\x200\x2016A8\x208\x200\x200\x200\x208\x200zm3.78\x206.28-4.5\x204.5a.75.75\x200\x200\x201-1.06\x200l-2-2a.75.75\x200\x201\x201\x201.06-1.06L6.75\x209.19l3.97-3.97a.75.75\x200\x201\x201\x201.06\x201.06z\x22/></svg>','failed':'<svg\x20class=\x22status-icon\x22\x20viewBox=\x220\x200\x2016\x2016\x22\x20fill=\x22currentColor\x22><path\x20d=\x22M8\x200a8\x208\x200\x201\x200\x200\x2016A8\x208\x200\x200\x200\x208\x200zm3.53\x2010.47a.75.75\x200\x201\x201-1.06\x201.06L8\x209.06l-2.47\x202.47a.75.75\x200\x200\x201-1.06-1.06L6.94\x208\x204.47\x205.53a.75.75\x200\x200\x201\x201.06-1.06L8\x206.94l2.47-2.47a.75.75\x200\x200\x201\x201.06\x201.06L9.06\x208l2.47\x202.47z\x22/></svg>','staged':'<svg\x20class=\x22status-icon\x22\x20viewBox=\x220\x200\x2016\x2016\x22\x20fill=\x22currentColor\x22><path\x20d=\x22M8\x200a8\x208\x200\x201\x200\x200\x2016A8\x208\x200\x200\x200\x208\x200zm0\x2012a.75.75\x200\x201\x201\x200-1.5.75.75\x200\x200\x201\x200\x201.5zm1-3.5a1\x201\x200\x200\x201-2\x200V5a1\x201\x200\x201\x201\x202\x200v3.5z\x22/></svg>','queued':'<svg\x20class=\x22status-icon\x22\x20viewBox=\x220\x200\x2016\x2016\x22\x20fill=\x22currentColor\x22><path\x20d=\x22M8\x200a8\x208\x200\x201\x200\x200\x2016A8\x208\x200\x200\x200\x208\x200zm0\x2014A6\x206\x200\x201\x201\x208\x202a6\x206\x200\x200\x201\x200\x2012zm1-6.5V4H7v4.5l3\x203\x201.5-1.5-2.5-2.5z\x22/></svg>'};export class VariantGroupingManager{constructor(_0x24a5f1={}){this['container']=null,this['onGroupChange']=_0x24a5f1['onGroupChange']||(()=>{}),this['onAddExistingTask']=_0x24a5f1['onAddExistingTask']||(()=>{}),this['tasks']=[],this['groupId']=_0x24a5f1['groupId']||null,this['isOpen']=![];}['init'](_0x459661,_0x4818ed,_0x31fbba){this['container']=_0x459661,this['tasks']=_0x4818ed,this['groupId']=_0x31fbba,this['render'](),this['attachEventListeners']();}['updateTasks'](_0x3a05ed){const _0x4ff1f0=new Map(_0x3a05ed['map'](_0x14e016=>[_0x14e016['taskId'],_0x14e016]));this['tasks']=this['tasks']['map'](_0x4dbc6e=>{const _0x4f4a10=_0x4ff1f0['get'](_0x4dbc6e['taskId']);return _0x4f4a10?_0x4f4a10:_0x4dbc6e;});for(const _0x159047 of _0x3a05ed){!this['tasks']['some'](_0x459235=>_0x459235['taskId']===_0x159047['taskId'])&&this['tasks']['push'](_0x159047);}this['isOpen']&&this['render']();}['open'](){this['isOpen']=!![],this['render'](),this['container']?.['classList']['add']('open');}['close'](){this['isOpen']=![],this['container']?.['classList']['remove']('open');}['render'](){if(!this['container'])return;const _0x8c2b1=this['tasks']['filter'](_0x18f7e6=>_0x18f7e6['groupId']===this['groupId'])['sort']((_0x1f346d,_0x3342fd)=>(_0x1f346d['groupIndex']??0x0)-(_0x3342fd['groupIndex']??0x0)),_0x2f9214=this['tasks']['filter'](_0x7d7b29=>!_0x7d7b29['groupId']||_0x7d7b29['groupId']!==this['groupId']);this['container']['innerHTML']='\x0a\x20\x20\x20\x20\x20\x20<div\x20class=\x22variant-grouping-manager\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-header\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<h3>Manage\x20Task\x20Group</h3>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22vgm-close-btn\x22\x20title=\x22Close\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20width=\x2220\x22\x20height=\x2220\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M18\x206L6\x2018M6\x206l12\x2012\x22/>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-content\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-section\x20vgm-grouped\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-section-header\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-section-title\x22>Grouped\x20Variants</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-section-count\x22>'+_0x8c2b1['length']+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-drop-zone\x20vgm-grouped-zone\x22\x20data-zone=\x22grouped\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x8c2b1['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20add\x20to\x20group</div>':_0x8c2b1['map']((_0x2b130b,_0x4e3876)=>this['renderVariantCard'](_0x2b130b,_0x4e3876,!![]))['join'](''))+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-divider\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-divider-line\x22></div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-divider-text\x22>Drag\x20to\x20move</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-divider-line\x22></div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-section\x20vgm-ungrouped\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-section-header\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-section-title\x22>Ungrouped\x20Tasks</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-section-count\x22>'+_0x2f9214['length']+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-drop-zone\x20vgm-ungrouped-zone\x22\x20data-zone=\x22ungrouped\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x2f9214['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20remove\x20from\x20group</div>':_0x2f9214['map']((_0x476fb5,_0x5ba148)=>this['renderVariantCard'](_0x476fb5,_0x5ba148,![]))['join'](''))+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-actions\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22vgm-btn\x20vgm-btn-secondary\x20vgm-add-existing-btn\x22\x20title=\x22Add\x20an\x20existing\x20task\x20to\x20this\x20group\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M12\x205v14M5\x2012h14\x22/>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20Add\x20Existing\x20Task\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20';}['renderVariantCard'](_0x2f7c8b,_0x39eb8e,_0x133e07){const _0x1c135=_0x2f7c8b['envVars']?.['CODER_AGENT']||_0x2f7c8b['envVars']?.['default_agent']||'claude',_0x2774ac=AGENT_ICONS[_0x1c135['toLowerCase']()]||AGENT_ICONS['claude'],_0x19e751=STATUS_ICONS[_0x2f7c8b['status']]||'',_0x51dd17='status-'+(_0x2f7c8b['status']||'unknown'),_0x4f72e0=_0x2f7c8b['isWinner']?'<span\x20class=\x22vgm-badge\x20vgm-badge-winner\x22\x20title=\x22Winner\x22>★</span>':'',_0x1dd471=_0x2f7c8b['approvedBy']?'<span\x20class=\x22vgm-badge\x20vgm-badge-approved\x22\x20title=\x22Approved\x22><svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22\x20width=\x2212\x22\x20height=\x2212\x22><path\x20d=\x22M14\x209V5a3\x203\x200\x200\x200-3-3l-4\x209v11h11.28a2\x202\x200\x200\x200\x202-1.7l1.38-9a2\x202\x200\x200\x200-2-2.3zM7\x2022H4a2\x202\x200\x200\x201-2-2v-7a2\x202\x200\x200\x201\x202-2h3\x22></path></svg></span>':'';return'\x0a\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-card\x20'+_0x51dd17+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20draggable=\x22true\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-task-id=\x22'+_0x2f7c8b['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-is-grouped=\x22'+_0x133e07+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-index=\x22'+_0x39eb8e+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-drag-handle\x22\x20title=\x22Drag\x20to\x20reorder\x20or\x20move\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20fill=\x22currentColor\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M8\x206h2v2H8V6zm6\x200h2v2h-2V6zM8\x2011h2v2H8v-2zm6\x200h2v2h-2v-2zm-6\x205h2v2H8v-2zm6\x200h2v2h-2v-2z\x22/>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-icon\x22\x20data-agent=\x22'+_0x1c135['toLowerCase']()+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x2774ac+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-info\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-name\x22>'+Utils['escapeHtml'](_0x2f7c8b['name']||'Task\x20'+_0x2f7c8b['taskId']['slice'](-0x6))+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-meta\x22>'+Utils['escapeHtml'](_0x1c135)+'\x20·\x20'+(_0x2f7c8b['status']||'unknown')+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-badges\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x4f72e0+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x1dd471+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-status\x20'+_0x51dd17+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x19e751+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22vgm-variant-remove-btn\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20title=\x22'+(_0x133e07?'Remove\x20from\x20group':'Add\x20to\x20group')+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-task-id=\x22'+_0x2f7c8b['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-action=\x22'+(_0x133e07?'remove':'add')+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x133e07?'<path\x20d=\x22M18\x206L6\x2018M6\x206l12\x2012\x22/>':'<path\x20d=\x22M12\x205v14M5\x2012h14\x22/>')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20';}['attachEventListeners'](){if(!this['container'])return;this['container']['addEventListener']('click',_0x53fa1b=>{_0x53fa1b['target']['closest']('.vgm-close-btn')&&(this['close'](),this['onGroupChange'](this['tasks'])),_0x53fa1b['target']['closest']('.vgm-add-existing-btn')&&(this['close'](),this['onAddExistingTask'](this['groupId']));}),this['container']['addEventListener']('click',async _0xc1c690=>{const _0x35889f=_0xc1c690['target']['closest']('.vgm-variant-remove-btn');if(!_0x35889f)return;const _0x3243c8=_0x35889f['dataset']['taskId'],_0x16353=_0x35889f['dataset']['action'];try{_0x16353==='remove'?await this['removeFromGroup'](_0x3243c8):await this['addToGroup'](_0x3243c8);}catch(_0x202579){console['error']('Failed\x20to\x20update\x20group:',_0x202579),Utils['showToast'](_0x202579['message']||'Failed\x20to\x20update\x20group','error');}}),this['container']['addEventListener']('dragstart',_0x250bbe=>this['handleDragStart'](_0x250bbe)),this['container']['addEventListener']('dragend',_0x57f25c=>this['handleDragEnd'](_0x57f25c)),this['container']['addEventListener']('dragover',_0x330c47=>this['handleDragOver'](_0x330c47)),this['container']['addEventListener']('dragleave',_0x49adf5=>this['handleDragLeave'](_0x49adf5)),this['container']['addEventListener']('drop',_0x49d460=>this['handleDrop'](_0x49d460));}['handleDragStart'](_0x33a329){const _0x3b6094=_0x33a329['target']['closest']('.vgm-variant-card');if(!_0x3b6094)return;dragState['draggedTaskId']=_0x3b6094['dataset']['taskId'],dragState['draggedElement']=_0x3b6094,dragState['sourceGroupId']=_0x3b6094['dataset']['isGrouped']==='true'?this['groupId']:null,dragState['isDragging']=!![],_0x3b6094['classList']['add']('dragging'),_0x33a329['dataTransfer']['effectAllowed']='move',_0x33a329['dataTransfer']['setData']('text/plain',_0x3b6094['dataset']['taskId']),this['container']['classList']['add']('is-dragging');}['handleDragEnd'](_0x3b4acd){const _0x4bd992=_0x3b4acd['target']['closest']('.vgm-variant-card');_0x4bd992&&_0x4bd992['classList']['remove']('dragging'),this['container']['querySelectorAll']('.drag-over,\x20.drop-indicator')['forEach'](_0xd77e01=>{_0xd77e01['classList']['remove']('drag-over','drop-indicator','drop-before','drop-after');}),this['container']['classList']['remove']('is-dragging'),dragState['isDragging']=![],dragState['draggedTaskId']=null,dragState['draggedElement']=null,dragState['sourceGroupId']=null;}['handleDragOver'](_0x4c3200){_0x4c3200['preventDefault'](),_0x4c3200['dataTransfer']['dropEffect']='move';const _0x498ad9=_0x4c3200['target']['closest']('.vgm-drop-zone'),_0xe1778a=_0x4c3200['target']['closest']('.vgm-variant-card');this['container']['querySelectorAll']('.vgm-drop-zone')['forEach'](_0x5ea0ca=>{_0x5ea0ca['classList']['toggle']('drag-over',_0x5ea0ca===_0x498ad9);});if(_0xe1778a&&_0xe1778a!==dragState['draggedElement']){const _0x1bded6=_0xe1778a['getBoundingClientRect'](),_0x5c9064=_0x1bded6['top']+_0x1bded6['height']/0x2,_0x5b2ef8=_0x4c3200['clientY']<_0x5c9064;this['container']['querySelectorAll']('.vgm-variant-card')['forEach'](_0x264902=>{_0x264902!==_0xe1778a&&_0x264902['classList']['remove']('drop-before','drop-after');}),_0xe1778a['classList']['toggle']('drop-before',_0x5b2ef8),_0xe1778a['classList']['toggle']('drop-after',!_0x5b2ef8);}}['handleDragLeave'](_0x58f406){const _0x3960c0=_0x58f406['target']['closest']('.vgm-drop-zone');_0x3960c0&&!_0x3960c0['contains'](_0x58f406['relatedTarget'])&&_0x3960c0['classList']['remove']('drag-over');}async['handleDrop'](_0x576cd9){_0x576cd9['preventDefault']();const _0x499bc7=_0x576cd9['target']['closest']('.vgm-drop-zone'),_0x21a6b9=_0x576cd9['target']['closest']('.vgm-variant-card'),_0x2f2ba4=_0x576cd9['dataTransfer']['getData']('text/plain');if(!_0x499bc7||!_0x2f2ba4)return;this['container']['querySelectorAll']('.drag-over,\x20.drop-before,\x20.drop-after')['forEach'](_0x26589d=>{_0x26589d['classList']['remove']('drag-over','drop-before','drop-after');});const _0x4f0037=_0x499bc7['dataset']['zone'],_0x2064b1=_0x4f0037==='grouped',_0x308aaf=dragState['sourceGroupId']===this['groupId'];try{if(_0x2064b1&&!_0x308aaf){let _0x59f223=this['tasks']['filter'](_0x190c88=>_0x190c88['groupId']===this['groupId'])['length'];if(_0x21a6b9){const _0x35b932=_0x21a6b9['dataset']['taskId'],_0x25d96f=this['tasks']['find'](_0xb72b21=>_0xb72b21['taskId']===_0x35b932);if(_0x25d96f?.['groupIndex']!==undefined){const _0x3ba06a=_0x21a6b9['getBoundingClientRect'](),_0x5cd823=_0x576cd9['clientY']<_0x3ba06a['top']+_0x3ba06a['height']/0x2;_0x59f223=_0x25d96f['groupIndex']+(_0x5cd823?0x0:0x1);}}await this['addToGroup'](_0x2f2ba4,_0x59f223);}else{if(!_0x2064b1&&_0x308aaf)await this['removeFromGroup'](_0x2f2ba4);else _0x2064b1&&_0x308aaf&&_0x21a6b9&&await this['reorderInGroup'](_0x2f2ba4,_0x21a6b9,_0x576cd9['clientY']);}}catch(_0x14b9d9){console['error']('Drop\x20operation\x20failed:',_0x14b9d9),Utils['showToast'](_0x14b9d9['message']||'Failed\x20to\x20move\x20variant','error');}}async['addToGroup'](_0x284ffd,_0x37addc){const _0x16df3e=this['tasks']['find'](_0x6c911a=>_0x6c911a['taskId']===_0x284ffd);if(!_0x16df3e)return;_0x37addc===undefined&&(_0x37addc=this['tasks']['filter'](_0x5835af=>_0x5835af['groupId']===this['groupId'])['length']),!this['groupId']&&(this['groupId']=API['generateGroupId'](),await API['createTaskGroup']({'groupId':this['groupId']})),await API['updateTaskGroup'](_0x284ffd,this['groupId'],_0x37addc),_0x16df3e['groupId']=this['groupId'],_0x16df3e['groupIndex']=_0x37addc,this['render'](),this['onGroupChange'](this['tasks']);}async['removeFromGroup'](_0x11f626){const _0x12e610=this['tasks']['find'](_0x2cc277=>_0x2cc277['taskId']===_0x11f626);if(!_0x12e610)return;await API['removeTaskFromGroup'](_0x11f626),_0x12e610['groupId']=null,_0x12e610['groupIndex']=null,this['render'](),this['onGroupChange'](this['tasks']);}async['reorderInGroup'](_0x14cd66,_0x1c9ef0,_0x52b897){const _0x395338=this['tasks']['find'](_0x498dcf=>_0x498dcf['taskId']===_0x14cd66),_0x2a2b26=_0x1c9ef0['dataset']['taskId'],_0x2b2927=this['tasks']['find'](_0x4b9468=>_0x4b9468['taskId']===_0x2a2b26);if(!_0x395338||!_0x2b2927||_0x395338['taskId']===_0x2b2927['taskId'])return;const _0x1a5886=_0x1c9ef0['getBoundingClientRect'](),_0x5003b8=_0x52b897<_0x1a5886['top']+_0x1a5886['height']/0x2;let _0x21db5a=_0x2b2927['groupIndex']??0x0;if(!_0x5003b8)_0x21db5a++;if((_0x395338['groupIndex']??0x0)<(_0x2b2927['groupIndex']??0x0))_0x21db5a--;if(_0x21db5a===_0x395338['groupIndex'])return;await API['updateTaskGroup'](_0x14cd66,this['groupId'],_0x21db5a);const _0x10b6a4=this['tasks']['filter'](_0x220725=>_0x220725['groupId']===this['groupId'])['sort']((_0x10b690,_0x3b7552)=>(_0x10b690['groupIndex']??0x0)-(_0x3b7552['groupIndex']??0x0)),_0x32ea49=_0x10b6a4['findIndex'](_0x11d34b=>_0x11d34b['taskId']===_0x14cd66);_0x32ea49!==-0x1&&_0x10b6a4['splice'](_0x32ea49,0x1),_0x10b6a4['splice'](_0x21db5a,0x0,_0x395338),_0x10b6a4['forEach']((_0x251ff1,_0x2c9ae4)=>{_0x251ff1['groupIndex']=_0x2c9ae4;}),this['render'](),this['onGroupChange'](this['tasks']);}}export function initializeTabDragDrop(_0x587b9d,_0x4b8605,_0x3d9ecd,_0x549bed={}){if(!_0x587b9d)return;const {onReorder:_0x2940ef,onRemove:_0x1f9059}=_0x549bed,_0x53bfa0=_0x587b9d['querySelectorAll']('.task-tab');_0x53bfa0['forEach']((_0x21bdae,_0x2ea79a)=>{_0x21bdae['setAttribute']('draggable','true'),_0x21bdae['dataset']['index']=_0x2ea79a,_0x21bdae['addEventListener']('dragstart',_0x2e6a95=>{_0x2e6a95['dataTransfer']['effectAllowed']='move',_0x2e6a95['dataTransfer']['setData']('text/plain',_0x21bdae['dataset']['taskId']),_0x21bdae['classList']['add']('dragging'),_0x587b9d['classList']['add']('is-dragging');}),_0x21bdae['addEventListener']('dragend',()=>{_0x21bdae['classList']['remove']('dragging'),_0x587b9d['classList']['remove']('is-dragging'),_0x587b9d['querySelectorAll']('.drop-indicator')['forEach'](_0x4d57d5=>{_0x4d57d5['classList']['remove']('drop-indicator','drop-before','drop-after');});}),_0x21bdae['addEventListener']('dragover',_0x528116=>{_0x528116['preventDefault'](),_0x528116['dataTransfer']['dropEffect']='move';if(_0x21bdae['classList']['contains']('dragging'))return;const _0x323d19=_0x21bdae['getBoundingClientRect'](),_0x56d7ba=_0x323d19['left']+_0x323d19['width']/0x2,_0x4c202e=_0x528116['clientX']<_0x56d7ba;_0x53bfa0['forEach'](_0x1a8750=>_0x1a8750['classList']['remove']('drop-before','drop-after')),_0x21bdae['classList']['add'](_0x4c202e?'drop-before':'drop-after');}),_0x21bdae['addEventListener']('dragleave',()=>{_0x21bdae['classList']['remove']('drop-before','drop-after');}),_0x21bdae['addEventListener']('drop',async _0xccb590=>{_0xccb590['preventDefault']();const _0x3d92fb=_0xccb590['dataTransfer']['getData']('text/plain'),_0x5acf57=_0x21bdae['dataset']['taskId'];if(_0x3d92fb===_0x5acf57)return;const _0x38de6c=_0x21bdae['getBoundingClientRect'](),_0x1c7fe8=_0xccb590['clientX']<_0x38de6c['left']+_0x38de6c['width']/0x2;_0x21bdae['classList']['remove']('drop-before','drop-after'),_0x2940ef&&await _0x2940ef(_0x3d92fb,_0x5acf57,_0x1c7fe8);});});const _0x1e72b1=document['createElement']('div');return _0x1e72b1['className']='task-tab-remove-zone',_0x1e72b1['innerHTML']='\x0a\x20\x20\x20\x20<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20<path\x20d=\x22M18\x206L6\x2018M6\x206l12\x2012\x22/>\x0a\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20<span>Remove\x20from\x20group</span>\x0a\x20\x20',_0x1e72b1['style']['display']='none',_0x1e72b1['addEventListener']('dragover',_0x4d3337=>{_0x4d3337['preventDefault'](),_0x1e72b1['classList']['add']('drag-over');}),_0x1e72b1['addEventListener']('dragleave',()=>{_0x1e72b1['classList']['remove']('drag-over');}),_0x1e72b1['addEventListener']('drop',async _0x4653c0=>{_0x4653c0['preventDefault'](),_0x1e72b1['classList']['remove']('drag-over');const _0x1cf2a9=_0x4653c0['dataTransfer']['getData']('text/plain');_0x1f9059&&await _0x1f9059(_0x1cf2a9);}),_0x587b9d['addEventListener']('dragstart',()=>{_0x4b8605['length']>0x1&&(_0x1e72b1['style']['display']='flex');}),_0x587b9d['addEventListener']('dragend',()=>{_0x1e72b1['style']['display']='none';}),_0x587b9d['appendChild'](_0x1e72b1),{'destroy':()=>{_0x1e72b1['remove']();}};}export default VariantGroupingManager;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@profoundlogic/coderflow-server",
3
- "version": "0.6.0",
3
+ "version": "0.6.1",
4
4
  "description": "AI Coder Server - Manages Docker containers for AI agent task execution",
5
5
  "main": "dist/start.js",
6
6
  "type": "module",