@profoundlogic/coderflow-server 0.8.9 → 0.9.0

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 (182) hide show
  1. package/dist/coder-server.js +1 -1
  2. package/dist/config.js +1 -1
  3. package/dist/lib/agent-keepalive.js +1 -1
  4. package/dist/lib/agent-models.js +1 -1
  5. package/dist/lib/api-keys.js +1 -1
  6. package/dist/lib/apiKeys.js +1 -1
  7. package/dist/lib/app-server-ports.js +1 -1
  8. package/dist/lib/auto-judge.js +1 -1
  9. package/dist/lib/automation-service.js +1 -1
  10. package/dist/lib/basic-auth.js +1 -1
  11. package/dist/lib/bindings.js +1 -1
  12. package/dist/lib/build-history.js +1 -1
  13. package/dist/lib/build-output-service.js +1 -1
  14. package/dist/lib/build-scheduler.js +1 -1
  15. package/dist/lib/build-service.js +1 -1
  16. package/dist/lib/ca-certificates.js +1 -1
  17. package/dist/lib/claude-oauth-refresh.js +1 -1
  18. package/dist/lib/cli/build.js +1 -1
  19. package/dist/lib/cli/cleanup-users.js +1 -1
  20. package/dist/lib/cli/config-command.js +1 -1
  21. package/dist/lib/cli/config.js +1 -1
  22. package/dist/lib/cli/create-user.js +1 -1
  23. package/dist/lib/cli/grant-admin.js +1 -1
  24. package/dist/lib/cli/init.js +1 -1
  25. package/dist/lib/cli/jira.js +1 -1
  26. package/dist/lib/cli/license.js +1 -1
  27. package/dist/lib/cli/list-roles.js +1 -1
  28. package/dist/lib/cli/list-users.js +1 -1
  29. package/dist/lib/cli/server-manager.js +1 -1
  30. package/dist/lib/cli/set-password.js +1 -1
  31. package/dist/lib/compression-filter.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/memory-utils.js +1 -1
  63. package/dist/lib/migration-to-scoped-rbac.js +1 -1
  64. package/dist/lib/model-fetcher.js +1 -1
  65. package/dist/lib/notifications.js +1 -1
  66. package/dist/lib/objective-context.js +1 -1
  67. package/dist/lib/oidc-auth.js +1 -1
  68. package/dist/lib/oidc-device-flow.js +1 -1
  69. package/dist/lib/passwordTokens.js +1 -1
  70. package/dist/lib/permission-resolver.js +1 -1
  71. package/dist/lib/pin-cascade.js +1 -1
  72. package/dist/lib/provider-accounts.js +1 -1
  73. package/dist/lib/provider-oauth.js +1 -1
  74. package/dist/lib/provider-profile.js +1 -1
  75. package/dist/lib/provider-token-refresh.js +1 -1
  76. package/dist/lib/rbac-user-state.js +1 -1
  77. package/dist/lib/request-url.js +1 -1
  78. package/dist/lib/rewind.js +1 -1
  79. package/dist/lib/role-definitions.js +1 -1
  80. package/dist/lib/roles.js +1 -1
  81. package/dist/lib/secrets.js +1 -1
  82. package/dist/lib/setup-repo-git-auth.js +1 -1
  83. package/dist/lib/slack-service.js +1 -1
  84. package/dist/lib/state-capture.js +1 -1
  85. package/dist/lib/static-files.js +1 -1
  86. package/dist/lib/task-aliases.js +1 -1
  87. package/dist/lib/task-container-init.js +1 -1
  88. package/dist/lib/task-context-usage.js +1 -1
  89. package/dist/lib/task-git-auth-errors.js +1 -1
  90. package/dist/lib/task-name-format.js +1 -1
  91. package/dist/lib/task-name-generator.js +1 -1
  92. package/dist/lib/task-source-metadata.js +1 -1
  93. package/dist/lib/teams.js +1 -1
  94. package/dist/lib/user-git-oauth.js +1 -1
  95. package/dist/lib/user-git-tokens.js +1 -1
  96. package/dist/lib/users.js +1 -1
  97. package/dist/middleware/requireAuth.js +1 -1
  98. package/dist/middleware/requireInit.js +1 -1
  99. package/dist/middleware/requirePermission.js +1 -1
  100. package/dist/package.json +1 -1
  101. package/dist/playwright.config.js +1 -1
  102. package/dist/playwright.task-terminal.config.js +1 -1
  103. package/dist/routes/apiKeys.js +1 -1
  104. package/dist/routes/auth-oidc.js +1 -1
  105. package/dist/routes/auth.js +1 -1
  106. package/dist/routes/automations.js +1 -1
  107. package/dist/routes/bindings.js +1 -1
  108. package/dist/routes/build.js +1 -1
  109. package/dist/routes/containers.js +1 -1
  110. package/dist/routes/deploy-task.js +1 -1
  111. package/dist/routes/environment-management.js +1 -1
  112. package/dist/routes/environments.js +1 -1
  113. package/dist/routes/external-skills.js +1 -1
  114. package/dist/routes/git-credentials.js +1 -1
  115. package/dist/routes/git-oauth.js +1 -1
  116. package/dist/routes/git-provider-setup.js +1 -1
  117. package/dist/routes/health.js +1 -1
  118. package/dist/routes/jira.js +1 -1
  119. package/dist/routes/logs.js +1 -1
  120. package/dist/routes/objective-management.js +1 -1
  121. package/dist/routes/password.js +1 -1
  122. package/dist/routes/prompt.js +1 -1
  123. package/dist/routes/provider-auth.js +1 -1
  124. package/dist/routes/qa.js +1 -1
  125. package/dist/routes/roles.js +1 -1
  126. package/dist/routes/settings.js +1 -1
  127. package/dist/routes/skill-management.js +1 -1
  128. package/dist/routes/skills.js +1 -1
  129. package/dist/routes/slack.js +1 -1
  130. package/dist/routes/stats.js +1 -1
  131. package/dist/routes/tasks.js +1 -1
  132. package/dist/routes/teams.js +1 -1
  133. package/dist/routes/templates.js +1 -1
  134. package/dist/routes/test-task.js +1 -1
  135. package/dist/routes/test.js +1 -1
  136. package/dist/routes/users.js +1 -1
  137. package/dist/routes/visualizations.js +1 -1
  138. package/dist/scripts/create-user.js +1 -1
  139. package/dist/scripts/migrate-config-to-data-dir.js +1 -1
  140. package/dist/start.js +1 -1
  141. package/dist/web-ui/public/activity-detail-modal.js +1 -1
  142. package/dist/web-ui/public/activity-feed.js +1 -1
  143. package/dist/web-ui/public/activity-formatters.js +1 -1
  144. package/dist/web-ui/public/admin.js +1 -1
  145. package/dist/web-ui/public/agent-event-parser.js +1 -1
  146. package/dist/web-ui/public/app.js +1 -1
  147. package/dist/web-ui/public/approve-dialog.js +1 -1
  148. package/dist/web-ui/public/automation-links.js +1 -1
  149. package/dist/web-ui/public/automation-schedule.js +1 -1
  150. package/dist/web-ui/public/comments-widget.js +1 -1
  151. package/dist/web-ui/public/diff-utils.js +1 -1
  152. package/dist/web-ui/public/docs/docsify-proxy-helper.js +1 -1
  153. package/dist/web-ui/public/environments.js +1 -1
  154. package/dist/web-ui/public/feedback-widget.js +1 -1
  155. package/dist/web-ui/public/file-selection-tree.js +1 -1
  156. package/dist/web-ui/public/git-history-lazy-utils.js +1 -1
  157. package/dist/web-ui/public/git-history.js +1 -1
  158. package/dist/web-ui/public/git-status.js +1 -1
  159. package/dist/web-ui/public/ibmi-file-filter.js +1 -1
  160. package/dist/web-ui/public/index.js +1 -1
  161. package/dist/web-ui/public/login.js +1 -1
  162. package/dist/web-ui/public/markdown-editor.js +1 -1
  163. package/dist/web-ui/public/markdown-file-editor.js +1 -1
  164. package/dist/web-ui/public/modal-maximize.js +1 -1
  165. package/dist/web-ui/public/notifications.js +1 -1
  166. package/dist/web-ui/public/permissions.js +1 -1
  167. package/dist/web-ui/public/pr-dialog.js +1 -1
  168. package/dist/web-ui/public/roles.js +1 -1
  169. package/dist/web-ui/public/settings.js +1 -1
  170. package/dist/web-ui/public/setup-password.js +1 -1
  171. package/dist/web-ui/public/skills.js +1 -1
  172. package/dist/web-ui/public/sse-client.js +1 -1
  173. package/dist/web-ui/public/sse-client.transport-warning.js +1 -1
  174. package/dist/web-ui/public/sse-shared-worker.js +1 -1
  175. package/dist/web-ui/public/task-judging-helpers.js +1 -1
  176. package/dist/web-ui/public/task.js +1 -1
  177. package/dist/web-ui/public/teams.js +1 -1
  178. package/dist/web-ui/public/terminal.js +1 -1
  179. package/dist/web-ui/public/theme.js +1 -1
  180. package/dist/web-ui/public/users.js +1 -1
  181. package/dist/web-ui/public/variant-grouping.js +1 -1
  182. package/package.json +1 -1
@@ -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 _0x5ccbe5=state['currentUser'];if(!Permissions['hasServerPermission'](_0x5ccbe5,'teams:view')&&!Permissions['hasTeamPermission'](_0x5ccbe5,'teams:manage')){Utils['showToast']('Access\x20denied:\x20You\x20do\x20not\x20have\x20permission\x20to\x20view\x20teams','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}(Permissions['hasServerPermission'](_0x5ccbe5,'*')||Permissions['hasTeamPermission'](_0x5ccbe5,'teams:manage'))&&(document['getElementById']('create-team-btn')['hidden']=![]),bindEventListeners(),await Promise['all']([loadTeams(),loadUsers(),loadRoles(),loadEnvironments()]),renderTeams();});async function loadTeams(){const _0x1d5edb=document['getElementById']('teams-loading'),_0x31581c=document['getElementById']('teams-error'),_0x1c1b80=document['getElementById']('teams-content');try{_0x1d5edb['hidden']=![],_0x31581c['hidden']=!![],_0x1c1b80['hidden']=!![];const {teams:_0x31e7b9}=await API['getTeams']();state['teams']=_0x31e7b9||[],renderTeams(),_0x1d5edb['hidden']=!![],_0x1c1b80['hidden']=![];}catch(_0x15a135){_0x1d5edb['hidden']=!![],_0x31581c['hidden']=![],document['getElementById']('teams-error-message')['textContent']=_0x15a135['message'];}}async function loadUsers(){try{const {users:_0x313c9a}=await API['getUsers']();state['users']=_0x313c9a||[];}catch{state['users']=[];}}async function loadRoles(){try{const {roles:_0x2e5c3d}=await API['getRoleDefinitions']();state['roles']=_0x2e5c3d||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x3de23c=await API['getEnvironments']();state['environments']=_0x3de23c['environments']||[];}catch{state['environments']=[];}}function renderTeams(){const _0x1207ef=document['getElementById']('teams-table-body'),_0x2bd390=document['getElementById']('team-count');if(!_0x1207ef)return;_0x2bd390&&(_0x2bd390['textContent']=state['teams']['length']+'\x20team'+(state['teams']['length']===0x1?'':'s'));if(state['teams']['length']===0x0){_0x1207ef['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 _0x38f0e4=Permissions['hasServerPermission'](state['currentUser'],'*');_0x1207ef['innerHTML']=state['teams']['map'](_0x2b37bd=>{const _0x185203=_0x38f0e4||_0x2b37bd['canManageTeam'],_0x5a3c2a=_0x38f0e4||_0x2b37bd['canManageMembers'],_0x3c3180=_0x185203||_0x5a3c2a,_0x4aba89=(_0x2b37bd['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'](_0x2b37bd['name'])+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x2b37bd['description']?'<div\x20style=\x22font-size:\x200.8em;\x20color:\x20var(--color-text-secondary);\x20margin-top:\x200.15rem;\x22>'+Utils['escapeHtml'](_0x2b37bd['description'])+'</div>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+_0x4aba89+'</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'+(_0x3c3180?'<button\x20class=\x22btn-icon\x22\x20title=\x22Edit\x20team\x22\x20onclick=\x22window.openTeamModal(\x27'+_0x2b37bd['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'+(_0x185203?'<button\x20class=\x22btn-icon\x22\x20title=\x22Access\x20bindings\x22\x20onclick=\x22window.openBindingsModal(\x27'+_0x2b37bd['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'+(_0x185203?'<button\x20class=\x22btn-icon\x20btn-danger\x22\x20title=\x22Delete\x20team\x22\x20onclick=\x22window.deleteTeam(\x27'+_0x2b37bd['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(_0x2d2973){const _0xb24f03=state['teams']['find'](_0x3217b7=>_0x3217b7['id']===_0x2d2973);if(!_0xb24f03)return;state['editingTeamId']=_0x2d2973;const _0x15ae89=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x14d32b=_0x15ae89||_0xb24f03['canManageTeam'],_0x5e0829=_0x15ae89||_0xb24f03['canManageMembers'],_0x5656b2=_0x14d32b,_0x281281=_0x14d32b||_0x5e0829,_0x1b56c4=_0xb24f03['name'],_0x3558ed=_0xb24f03['description']||'';state['modalSnapshot']={'name':_0x1b56c4,'description':_0x3558ed},document['getElementById']('team-modal-title')['textContent']=_0x1b56c4,document['getElementById']('team-name')['value']=_0x1b56c4,document['getElementById']('team-name')['disabled']=!_0x5656b2,document['getElementById']('team-description')['value']=_0x3558ed,document['getElementById']('team-description')['disabled']=!_0x5656b2,document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=![],document['getElementById']('save-team')['hidden']=!_0x5656b2,renderMembersList(_0xb24f03),updateMemberSelect(_0xb24f03),document['getElementById']('team-modal')['hidden']=![];};function isTeamModalDirty(){if(!state['modalSnapshot'])return![];const _0x32c614=document['getElementById']('team-name')['value']['trim'](),_0x255410=document['getElementById']('team-description')['value']['trim']();return _0x32c614!==state['modalSnapshot']['name']||_0x255410!==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(_0x3921b5){const _0x3d6498=state['teams']['find'](_0x51b1c7=>_0x51b1c7['id']===_0x3921b5);if(!_0x3d6498)return;state['bindingsTeamId']=_0x3921b5,document['getElementById']('bindings-modal-title')['textContent']='Access\x20Bindings\x20—\x20'+_0x3d6498['name'],document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('bindings-modal')['hidden']=![],loadTeamBindings(_0x3921b5);};function hideBindingsModal(){document['getElementById']('bindings-modal')['hidden']=!![],state['bindingsTeamId']=null;}function renderMembersList(_0x2ebefe){const _0x5e63ea=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x3159de=_0x5e63ea||_0x2ebefe['canManageMembers']||_0x2ebefe['canManageTeam'],_0x2b9b6c=_0x2ebefe['members']||[],_0x154232=document['getElementById']('members-list');if(_0x2b9b6c['length']===0x0){_0x154232['innerHTML']='<p\x20style=\x22font-size:\x200.875rem;\x20color:\x20var(--color-text-secondary);\x20margin:\x200.25rem\x200;\x22>No\x20members\x20yet</p>';return;}_0x154232['innerHTML']=_0x2b9b6c['map'](_0x50956f=>{const _0x79a5d4=state['users']['find'](_0x17557b=>_0x17557b['id']===_0x50956f),_0x1cea69=_0x79a5d4?''+Utils['escapeHtml'](_0x79a5d4['username'])+(_0x79a5d4['name']?'\x20<span\x20style=\x22color:\x20var(--color-text-secondary);\x20font-size:\x200.85em;\x22>('+Utils['escapeHtml'](_0x79a5d4['name'])+')</span>':''):Utils['escapeHtml'](_0x50956f);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'+_0x1cea69+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x3159de?'<button\x20type=\x22button\x22\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.removeMemberClick(\x27'+_0x50956f+'\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 _0x3ef144=document['getElementById']('add-member-row');if(_0x3ef144)_0x3ef144['style']['display']=_0x3159de?'flex':'none';}function updateMemberSelect(_0x2ae28c){const _0x207dcd=document['getElementById']('add-member-select');if(!_0x207dcd)return;const _0x1a2897=new Set(_0x2ae28c['members']||[]),_0x184e83=state['users']['filter'](_0x5a474e=>!_0x1a2897['has'](_0x5a474e['id']));_0x207dcd['innerHTML']='<option\x20value=\x22\x22>Add\x20a\x20member…</option>'+_0x184e83['map'](_0x12bb91=>'<option\x20value=\x22'+_0x12bb91['id']+'\x22>'+Utils['escapeHtml'](_0x12bb91['username'])+(_0x12bb91['name']?'\x20('+Utils['escapeHtml'](_0x12bb91['name'])+')':'')+'</option>')['join']('');}async function addMember(){const _0x60de0f=document['getElementById']('add-member-select'),_0x2e5661=_0x60de0f['value'];if(!_0x2e5661||!state['editingTeamId'])return;try{const {team:_0x3eddcb}=await API['addTeamMember'](state['editingTeamId'],_0x2e5661);syncTeamInState(_0x3eddcb),renderMembersList(_0x3eddcb),updateMemberSelect(_0x3eddcb),_0x60de0f['value']='',Utils['showToast']('Member\x20added','success');}catch(_0x30a087){Utils['showToast'](_0x30a087['message'],'error');}}window['removeMemberClick']=async function(_0x174213){if(!state['editingTeamId'])return;try{const {team:_0x19fd86}=await API['removeTeamMember'](state['editingTeamId'],_0x174213);syncTeamInState(_0x19fd86),renderMembersList(_0x19fd86),updateMemberSelect(_0x19fd86),Utils['showToast']('Member\x20removed','success');}catch(_0x3959f0){Utils['showToast'](_0x3959f0['message'],'error');}};async function loadTeamBindings(_0x32fe42){const _0x245f01=document['getElementById']('bindings-loading'),_0x55c350=document['getElementById']('bindings-empty'),_0x308969=document['getElementById']('bindings-list-container'),_0x26a9c3=document['getElementById']('add-binding-btn');_0x245f01['hidden']=![],_0x55c350['hidden']=!![],_0x308969['style']['display']='none',_0x26a9c3['hidden']=!![],document['getElementById']('add-binding-form')['hidden']=!![];try{const {bindings:_0x371105}=await API['getBindings']({'subject_type':'team','subject_id':_0x32fe42});state['teamBindings']=_0x371105||[],_0x245f01['hidden']=!![],state['teamBindings']['length']===0x0?_0x55c350['hidden']=![]:(_0x308969['style']['display']='',renderBindingsTable()),(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage'))&&(_0x26a9c3['hidden']=![]);}catch(_0x35f656){_0x245f01['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x35f656['message'],'error');}}function renderBindingsTable(){const _0x43ffa6=document['getElementById']('bindings-table-body');if(!_0x43ffa6)return;const _0x2e03a2=Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage');_0x43ffa6['innerHTML']=state['teamBindings']['map'](_0x34fc3e=>{const _0x4c2c9d=_0x34fc3e['resource_type']==='server'?'Server':_0x34fc3e['resource_id']==='*'?'All\x20'+_0x34fc3e['resource_type']+'s':Utils['escapeHtml'](_0x34fc3e['resource_name']||_0x34fc3e['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x4c2c9d+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x34fc3e['role_name']||_0x34fc3e['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x2e03a2?'<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteBindingClick(\x27'+_0x34fc3e['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 _0x3ac560=document['getElementById']('binding-resource-type');_0x3ac560['value']='environment',updateBindingFormForResourceType('environment');}function onBindingResourceTypeChange(){const _0x14bd4c=document['getElementById']('binding-resource-type')['value'];updateBindingFormForResourceType(_0x14bd4c);}function updateBindingFormForResourceType(_0xc6fe18){const _0x5a63f0=document['getElementById']('binding-resource-container'),_0x38976f=document['getElementById']('binding-resource'),_0x56e18e=document['getElementById']('binding-role');if(_0xc6fe18==='server')_0x5a63f0['style']['display']='none';else{_0x5a63f0['style']['display']='';if(_0xc6fe18==='environment'){const _0x467596=new Set(state['teamBindings']['filter'](_0x2d42c2=>_0x2d42c2['resource_type']==='environment')['map'](_0x50faeb=>_0x50faeb['resource_id'])),_0x3dcd26=state['environments']['filter'](_0x69654c=>!_0x467596['has'](_0x69654c['name']));_0x38976f['innerHTML']=_0x3dcd26['length']?_0x3dcd26['map'](_0x5bdcf6=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x5bdcf6['name'])+'\x22>'+Utils['escapeHtml'](_0x5bdcf6['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0xc6fe18==='team'){const _0x117d3f=new Set(state['teamBindings']['filter'](_0x47cbef=>_0x47cbef['resource_type']==='team')['map'](_0x149fdf=>_0x149fdf['resource_id'])),_0x3d3461=state['teams']['filter'](_0x2161cc=>!_0x117d3f['has'](_0x2161cc['id']));_0x38976f['innerHTML']=_0x3d3461['length']?_0x3d3461['map'](_0x5040b0=>'<option\x20value=\x22'+_0x5040b0['id']+'\x22>'+Utils['escapeHtml'](_0x5040b0['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x297ec5=state['roles']['filter'](_0x21a474=>_0x21a474['resource_type']===_0xc6fe18);_0x56e18e['innerHTML']=_0x297ec5['length']?_0x297ec5['filter'](_0x4e0709=>{const _0x46a876=_0xc6fe18==='server'?undefined:_0x38976f['value'];return!state['teamBindings']['some'](_0x1bb4f5=>_0x1bb4f5['resource_type']===_0xc6fe18&&_0x1bb4f5['role_id']===_0x4e0709['id']&&(_0xc6fe18==='server'||_0x1bb4f5['resource_id']===_0x46a876));})['map'](_0xd08845=>'<option\x20value=\x22'+_0xd08845['id']+'\x22>'+Utils['escapeHtml'](_0xd08845['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 _0x2a4f92=document['getElementById']('binding-resource-type')['value'],_0x4c1fb1=document['getElementById']('binding-role')['value'];if(!_0x4c1fb1||!state['bindingsTeamId'])return;const _0x3d1fa4=_0x2a4f92==='server'?undefined:document['getElementById']('binding-resource')['value'];if(_0x2a4f92!=='server'&&!_0x3d1fa4)return;const _0x31b33c=document['getElementById']('save-binding-btn');_0x31b33c['disabled']=!![],_0x31b33c['textContent']='Adding…';try{const _0x315dab={'subject_type':'team','subject_id':state['bindingsTeamId'],'role_id':_0x4c1fb1,'resource_type':_0x2a4f92};if(_0x3d1fa4)_0x315dab['resource_id']=_0x3d1fa4;await API['createBinding'](_0x315dab),Utils['showToast']('Binding\x20added','success'),document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![],await loadTeamBindings(state['bindingsTeamId']);}catch(_0x1406a7){Utils['showToast'](_0x1406a7['message'],'error');}finally{_0x31b33c['disabled']=![],_0x31b33c['textContent']='Add\x20Binding';}}window['deleteBindingClick']=async function(_0x3d3189){try{await API['deleteBinding'](_0x3d3189),Utils['showToast']('Binding\x20removed','success'),await loadTeamBindings(state['bindingsTeamId']);}catch(_0x2e76b1){Utils['showToast'](_0x2e76b1['message'],'error');}};async function saveTeam(){const _0x4bd295=document['getElementById']('team-name')['value']['trim'](),_0x2ad19e=document['getElementById']('team-description')['value']['trim'](),_0x11e5a3=document['getElementById']('team-form-error'),_0x501104=document['getElementById']('save-team');if(!_0x4bd295){_0x11e5a3['textContent']='Team\x20name\x20is\x20required',_0x11e5a3['hidden']=![];return;}_0x11e5a3['hidden']=!![];const _0x62058e=_0x501104['textContent'];_0x501104['disabled']=!![],_0x501104['textContent']=state['editingTeamId']?'Saving…':'Creating…';try{if(state['editingTeamId']){const {team:_0x237cf5}=await API['updateTeam'](state['editingTeamId'],{'name':_0x4bd295,'description':_0x2ad19e});syncTeamInState(_0x237cf5),document['getElementById']('team-modal-title')['textContent']=_0x237cf5['name'],Utils['showToast']('Team\x20updated','success');}else await API['createTeam']({'name':_0x4bd295,'description':_0x2ad19e}),Utils['showToast']('Team\x20created','success');_0x501104['disabled']=![],_0x501104['textContent']=_0x62058e,hideTeamModal(),await loadTeams();}catch(_0x1c44c8){_0x11e5a3['textContent']=_0x1c44c8['message'],_0x11e5a3['hidden']=![],_0x501104['disabled']=![],_0x501104['textContent']=_0x62058e;}}window['deleteTeam']=function(_0x237196){const _0xe669f7=state['teams']['find'](_0xdb8222=>_0xdb8222['id']===_0x237196);if(!_0xe669f7)return;state['deletingTeamId']=_0x237196,document['getElementById']('delete-team-name')['textContent']=_0xe669f7['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 _0x5ae815=document['getElementById']('confirm-delete-team');_0x5ae815['disabled']=!![],_0x5ae815['textContent']='Deleting…';try{await API['deleteTeam'](state['deletingTeamId']),Utils['showToast']('Team\x20deleted','success'),_0x5ae815['disabled']=![],_0x5ae815['textContent']='Delete\x20Team',hideDeleteModal(),await loadTeams();}catch(_0x881bd2){Utils['showToast']('Failed\x20to\x20delete\x20team:\x20'+_0x881bd2['message'],'error'),_0x5ae815['disabled']=![],_0x5ae815['textContent']='Delete\x20Team';}}function syncTeamInState(_0xf54e36){const _0x242d5f=state['teams']['findIndex'](_0x50ac5b=>_0x50ac5b['id']===_0xf54e36['id']);if(_0x242d5f>=0x0)state['teams'][_0x242d5f]=_0xf54e36;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 _0x11e4c4=state['currentUser'];if(!Permissions['hasServerPermission'](_0x11e4c4,'teams:view')&&!Permissions['hasTeamPermission'](_0x11e4c4,'teams:manage')){Utils['showToast']('Access\x20denied:\x20You\x20do\x20not\x20have\x20permission\x20to\x20view\x20teams','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}(Permissions['hasServerPermission'](_0x11e4c4,'*')||Permissions['hasTeamPermission'](_0x11e4c4,'teams:manage'))&&(document['getElementById']('create-team-btn')['hidden']=![]),bindEventListeners(),await Promise['all']([loadTeams(),loadUsers(),loadRoles(),loadEnvironments()]),renderTeams();});async function loadTeams(){const _0x44eec4=document['getElementById']('teams-loading'),_0x5e35d6=document['getElementById']('teams-error'),_0x11ee3f=document['getElementById']('teams-content');try{_0x44eec4['hidden']=![],_0x5e35d6['hidden']=!![],_0x11ee3f['hidden']=!![];const {teams:_0x4a3d6f}=await API['getTeams']();state['teams']=_0x4a3d6f||[],renderTeams(),_0x44eec4['hidden']=!![],_0x11ee3f['hidden']=![];}catch(_0x1f5ee9){_0x44eec4['hidden']=!![],_0x5e35d6['hidden']=![],document['getElementById']('teams-error-message')['textContent']=_0x1f5ee9['message'];}}async function loadUsers(){try{const {users:_0x46bda8}=await API['getUsers']();state['users']=_0x46bda8||[];}catch{state['users']=[];}}async function loadRoles(){try{const {roles:_0x5567ea}=await API['getRoleDefinitions']();state['roles']=_0x5567ea||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x39a3e0=await API['getEnvironments']();state['environments']=_0x39a3e0['environments']||[];}catch{state['environments']=[];}}function renderTeams(){const _0x4d68c7=document['getElementById']('teams-table-body'),_0x1745c1=document['getElementById']('team-count');if(!_0x4d68c7)return;_0x1745c1&&(_0x1745c1['textContent']=state['teams']['length']+'\x20team'+(state['teams']['length']===0x1?'':'s'));if(state['teams']['length']===0x0){_0x4d68c7['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 _0x382cfd=Permissions['hasServerPermission'](state['currentUser'],'*');_0x4d68c7['innerHTML']=state['teams']['map'](_0x108a0e=>{const _0x185643=_0x382cfd||_0x108a0e['canManageTeam'],_0x38efa9=_0x382cfd||_0x108a0e['canManageMembers'],_0x5dde51=_0x185643||_0x38efa9,_0x2caa7b=(_0x108a0e['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'](_0x108a0e['name'])+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x108a0e['description']?'<div\x20style=\x22font-size:\x200.8em;\x20color:\x20var(--color-text-secondary);\x20margin-top:\x200.15rem;\x22>'+Utils['escapeHtml'](_0x108a0e['description'])+'</div>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+_0x2caa7b+'</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'+(_0x5dde51?'<button\x20class=\x22btn-icon\x22\x20title=\x22Edit\x20team\x22\x20onclick=\x22window.openTeamModal(\x27'+_0x108a0e['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'+(_0x185643?'<button\x20class=\x22btn-icon\x22\x20title=\x22Access\x20bindings\x22\x20onclick=\x22window.openBindingsModal(\x27'+_0x108a0e['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'+(_0x185643?'<button\x20class=\x22btn-icon\x20btn-danger\x22\x20title=\x22Delete\x20team\x22\x20onclick=\x22window.deleteTeam(\x27'+_0x108a0e['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(_0x35bdae){const _0x452a77=state['teams']['find'](_0x525681=>_0x525681['id']===_0x35bdae);if(!_0x452a77)return;state['editingTeamId']=_0x35bdae;const _0x42df8d=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x413433=_0x42df8d||_0x452a77['canManageTeam'],_0x525c72=_0x42df8d||_0x452a77['canManageMembers'],_0x156bfe=_0x413433,_0x7b317d=_0x413433||_0x525c72,_0x5cdede=_0x452a77['name'],_0x3280ea=_0x452a77['description']||'';state['modalSnapshot']={'name':_0x5cdede,'description':_0x3280ea},document['getElementById']('team-modal-title')['textContent']=_0x5cdede,document['getElementById']('team-name')['value']=_0x5cdede,document['getElementById']('team-name')['disabled']=!_0x156bfe,document['getElementById']('team-description')['value']=_0x3280ea,document['getElementById']('team-description')['disabled']=!_0x156bfe,document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=![],document['getElementById']('save-team')['hidden']=!_0x156bfe,renderMembersList(_0x452a77),updateMemberSelect(_0x452a77),document['getElementById']('team-modal')['hidden']=![];};function isTeamModalDirty(){if(!state['modalSnapshot'])return![];const _0x4390ce=document['getElementById']('team-name')['value']['trim'](),_0x981ce5=document['getElementById']('team-description')['value']['trim']();return _0x4390ce!==state['modalSnapshot']['name']||_0x981ce5!==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(_0x4a59a3){const _0x5e0748=state['teams']['find'](_0xfd1715=>_0xfd1715['id']===_0x4a59a3);if(!_0x5e0748)return;state['bindingsTeamId']=_0x4a59a3,document['getElementById']('bindings-modal-title')['textContent']='Access\x20Bindings\x20—\x20'+_0x5e0748['name'],document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('bindings-modal')['hidden']=![],loadTeamBindings(_0x4a59a3);};function hideBindingsModal(){document['getElementById']('bindings-modal')['hidden']=!![],state['bindingsTeamId']=null;}function renderMembersList(_0x1a6ae1){const _0x59d3b6=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x4ea0d5=_0x59d3b6||_0x1a6ae1['canManageMembers']||_0x1a6ae1['canManageTeam'],_0x4ee7e3=_0x1a6ae1['members']||[],_0x2cd94a=document['getElementById']('members-list');if(_0x4ee7e3['length']===0x0){_0x2cd94a['innerHTML']='<p\x20style=\x22font-size:\x200.875rem;\x20color:\x20var(--color-text-secondary);\x20margin:\x200.25rem\x200;\x22>No\x20members\x20yet</p>';return;}_0x2cd94a['innerHTML']=_0x4ee7e3['map'](_0x2f1ea7=>{const _0xd5cce8=state['users']['find'](_0x5a5644=>_0x5a5644['id']===_0x2f1ea7),_0x31f5a2=_0xd5cce8?''+Utils['escapeHtml'](_0xd5cce8['username'])+(_0xd5cce8['name']?'\x20<span\x20style=\x22color:\x20var(--color-text-secondary);\x20font-size:\x200.85em;\x22>('+Utils['escapeHtml'](_0xd5cce8['name'])+')</span>':''):Utils['escapeHtml'](_0x2f1ea7);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'+_0x31f5a2+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x4ea0d5?'<button\x20type=\x22button\x22\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.removeMemberClick(\x27'+_0x2f1ea7+'\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 _0x111e9d=document['getElementById']('add-member-row');if(_0x111e9d)_0x111e9d['style']['display']=_0x4ea0d5?'flex':'none';}function updateMemberSelect(_0x3c253b){const _0x17f13a=document['getElementById']('add-member-select');if(!_0x17f13a)return;const _0x39f37c=new Set(_0x3c253b['members']||[]),_0x462cdb=state['users']['filter'](_0xf2c99d=>!_0x39f37c['has'](_0xf2c99d['id']));_0x17f13a['innerHTML']='<option\x20value=\x22\x22>Add\x20a\x20member…</option>'+_0x462cdb['map'](_0x165fcf=>'<option\x20value=\x22'+_0x165fcf['id']+'\x22>'+Utils['escapeHtml'](_0x165fcf['username'])+(_0x165fcf['name']?'\x20('+Utils['escapeHtml'](_0x165fcf['name'])+')':'')+'</option>')['join']('');}async function addMember(){const _0x1b8c20=document['getElementById']('add-member-select'),_0xd5db08=_0x1b8c20['value'];if(!_0xd5db08||!state['editingTeamId'])return;try{const {team:_0x3ea34f}=await API['addTeamMember'](state['editingTeamId'],_0xd5db08);syncTeamInState(_0x3ea34f),renderMembersList(_0x3ea34f),updateMemberSelect(_0x3ea34f),_0x1b8c20['value']='',Utils['showToast']('Member\x20added','success');}catch(_0x3b04db){Utils['showToast'](_0x3b04db['message'],'error');}}window['removeMemberClick']=async function(_0x227b8f){if(!state['editingTeamId'])return;try{const {team:_0x4c1c1a}=await API['removeTeamMember'](state['editingTeamId'],_0x227b8f);syncTeamInState(_0x4c1c1a),renderMembersList(_0x4c1c1a),updateMemberSelect(_0x4c1c1a),Utils['showToast']('Member\x20removed','success');}catch(_0x14c847){Utils['showToast'](_0x14c847['message'],'error');}};async function loadTeamBindings(_0x112803){const _0x597fba=document['getElementById']('bindings-loading'),_0x494b05=document['getElementById']('bindings-empty'),_0x358427=document['getElementById']('bindings-list-container'),_0x4b90bb=document['getElementById']('add-binding-btn');_0x597fba['hidden']=![],_0x494b05['hidden']=!![],_0x358427['style']['display']='none',_0x4b90bb['hidden']=!![],document['getElementById']('add-binding-form')['hidden']=!![];try{const {bindings:_0x4c72c5}=await API['getBindings']({'subject_type':'team','subject_id':_0x112803});state['teamBindings']=_0x4c72c5||[],_0x597fba['hidden']=!![],state['teamBindings']['length']===0x0?_0x494b05['hidden']=![]:(_0x358427['style']['display']='',renderBindingsTable()),(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage'))&&(_0x4b90bb['hidden']=![]);}catch(_0x58dfb6){_0x597fba['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x58dfb6['message'],'error');}}function renderBindingsTable(){const _0x290b49=document['getElementById']('bindings-table-body');if(!_0x290b49)return;const _0x4335e6=Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage');_0x290b49['innerHTML']=state['teamBindings']['map'](_0x3658bd=>{const _0x3b8521=_0x3658bd['resource_type']==='server'?'Server':_0x3658bd['resource_id']==='*'?'All\x20'+_0x3658bd['resource_type']+'s':Utils['escapeHtml'](_0x3658bd['resource_name']||_0x3658bd['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x3b8521+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x3658bd['role_name']||_0x3658bd['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x4335e6?'<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteBindingClick(\x27'+_0x3658bd['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 _0x280852=document['getElementById']('binding-resource-type');_0x280852['value']='environment',updateBindingFormForResourceType('environment');}function onBindingResourceTypeChange(){const _0x1f7e24=document['getElementById']('binding-resource-type')['value'];updateBindingFormForResourceType(_0x1f7e24);}function updateBindingFormForResourceType(_0x2f215e){const _0x552213=document['getElementById']('binding-resource-container'),_0x1ea7a4=document['getElementById']('binding-resource'),_0x53e856=document['getElementById']('binding-role');if(_0x2f215e==='server')_0x552213['style']['display']='none';else{_0x552213['style']['display']='';if(_0x2f215e==='environment'){const _0x1a366a=new Set(state['teamBindings']['filter'](_0x22ec2b=>_0x22ec2b['resource_type']==='environment')['map'](_0x45041e=>_0x45041e['resource_id'])),_0x1b34ca=state['environments']['filter'](_0x2fa43a=>!_0x1a366a['has'](_0x2fa43a['name']));_0x1ea7a4['innerHTML']=_0x1b34ca['length']?_0x1b34ca['map'](_0x5049c8=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x5049c8['name'])+'\x22>'+Utils['escapeHtml'](_0x5049c8['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x2f215e==='team'){const _0xc88492=new Set(state['teamBindings']['filter'](_0x2068a7=>_0x2068a7['resource_type']==='team')['map'](_0x29019c=>_0x29019c['resource_id'])),_0x2a3f25=state['teams']['filter'](_0xde2bd3=>!_0xc88492['has'](_0xde2bd3['id']));_0x1ea7a4['innerHTML']=_0x2a3f25['length']?_0x2a3f25['map'](_0x47d4e5=>'<option\x20value=\x22'+_0x47d4e5['id']+'\x22>'+Utils['escapeHtml'](_0x47d4e5['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x4422b5=state['roles']['filter'](_0x1c7547=>_0x1c7547['resource_type']===_0x2f215e);_0x53e856['innerHTML']=_0x4422b5['length']?_0x4422b5['filter'](_0x417d17=>{const _0x4dcda5=_0x2f215e==='server'?undefined:_0x1ea7a4['value'];return!state['teamBindings']['some'](_0x158d01=>_0x158d01['resource_type']===_0x2f215e&&_0x158d01['role_id']===_0x417d17['id']&&(_0x2f215e==='server'||_0x158d01['resource_id']===_0x4dcda5));})['map'](_0x580fcd=>'<option\x20value=\x22'+_0x580fcd['id']+'\x22>'+Utils['escapeHtml'](_0x580fcd['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 _0x1086b2=document['getElementById']('binding-resource-type')['value'],_0x5121e2=document['getElementById']('binding-role')['value'];if(!_0x5121e2||!state['bindingsTeamId'])return;const _0x43a316=_0x1086b2==='server'?undefined:document['getElementById']('binding-resource')['value'];if(_0x1086b2!=='server'&&!_0x43a316)return;const _0x582550=document['getElementById']('save-binding-btn');_0x582550['disabled']=!![],_0x582550['textContent']='Adding…';try{const _0x1507d4={'subject_type':'team','subject_id':state['bindingsTeamId'],'role_id':_0x5121e2,'resource_type':_0x1086b2};if(_0x43a316)_0x1507d4['resource_id']=_0x43a316;await API['createBinding'](_0x1507d4),Utils['showToast']('Binding\x20added','success'),document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![],await loadTeamBindings(state['bindingsTeamId']);}catch(_0x522fd6){Utils['showToast'](_0x522fd6['message'],'error');}finally{_0x582550['disabled']=![],_0x582550['textContent']='Add\x20Binding';}}window['deleteBindingClick']=async function(_0x2a15fc){try{await API['deleteBinding'](_0x2a15fc),Utils['showToast']('Binding\x20removed','success'),await loadTeamBindings(state['bindingsTeamId']);}catch(_0xc1e638){Utils['showToast'](_0xc1e638['message'],'error');}};async function saveTeam(){const _0x46c7f5=document['getElementById']('team-name')['value']['trim'](),_0x219a43=document['getElementById']('team-description')['value']['trim'](),_0x185d13=document['getElementById']('team-form-error'),_0x1eaaf3=document['getElementById']('save-team');if(!_0x46c7f5){_0x185d13['textContent']='Team\x20name\x20is\x20required',_0x185d13['hidden']=![];return;}_0x185d13['hidden']=!![];const _0x47c12d=_0x1eaaf3['textContent'];_0x1eaaf3['disabled']=!![],_0x1eaaf3['textContent']=state['editingTeamId']?'Saving…':'Creating…';try{if(state['editingTeamId']){const {team:_0x2471fa}=await API['updateTeam'](state['editingTeamId'],{'name':_0x46c7f5,'description':_0x219a43});syncTeamInState(_0x2471fa),document['getElementById']('team-modal-title')['textContent']=_0x2471fa['name'],Utils['showToast']('Team\x20updated','success');}else await API['createTeam']({'name':_0x46c7f5,'description':_0x219a43}),Utils['showToast']('Team\x20created','success');_0x1eaaf3['disabled']=![],_0x1eaaf3['textContent']=_0x47c12d,hideTeamModal(),await loadTeams();}catch(_0x18f1b6){_0x185d13['textContent']=_0x18f1b6['message'],_0x185d13['hidden']=![],_0x1eaaf3['disabled']=![],_0x1eaaf3['textContent']=_0x47c12d;}}window['deleteTeam']=function(_0x109155){const _0x3c4c96=state['teams']['find'](_0x411c85=>_0x411c85['id']===_0x109155);if(!_0x3c4c96)return;state['deletingTeamId']=_0x109155,document['getElementById']('delete-team-name')['textContent']=_0x3c4c96['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 _0x41403a=document['getElementById']('confirm-delete-team');_0x41403a['disabled']=!![],_0x41403a['textContent']='Deleting…';try{await API['deleteTeam'](state['deletingTeamId']),Utils['showToast']('Team\x20deleted','success'),_0x41403a['disabled']=![],_0x41403a['textContent']='Delete\x20Team',hideDeleteModal(),await loadTeams();}catch(_0xb0cdff){Utils['showToast']('Failed\x20to\x20delete\x20team:\x20'+_0xb0cdff['message'],'error'),_0x41403a['disabled']=![],_0x41403a['textContent']='Delete\x20Team';}}function syncTeamInState(_0x390692){const _0x1570ce=state['teams']['findIndex'](_0x1c1dee=>_0x1c1dee['id']===_0x390692['id']);if(_0x1570ce>=0x0)state['teams'][_0x1570ce]=_0x390692;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'](_0x1c463a=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':_0x1c463a}));});let commandSent=![],hasReceivedOutput=![];socket['addEventListener']('message',_0x5c2b51=>{try{const _0x2b190c=JSON['parse'](_0x5c2b51['data']);if(_0x2b190c['type']==='data'&&typeof _0x2b190c['data']==='string')term['write'](_0x2b190c['data']),!hasReceivedOutput&&_0x2b190c['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(_0x2b190c['type']==='status'&&_0x2b190c['status']){if(_0x2b190c['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'+_0x2b190c['status'],_0x2b190c['status']==='connected'?'success':'info');}else _0x2b190c['type']==='error'&&_0x2b190c['message']&&updateStatus(_0x2b190c['message'],'error');}}catch(_0x541ed8){console['error']('Failed\x20to\x20parse\x20terminal\x20message',_0x541ed8);}}),socket['addEventListener']('close',_0x44971e=>{const _0x154911=_0x44971e['reason']||'Connection\x20closed';updateStatus(_0x154911,_0x44971e['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',_0x399fa7=>{console['error']('Terminal\x20websocket\x20error',_0x399fa7),updateStatus('Connection\x20error','error');});function sendResize(){if(socket['readyState']!==WebSocket['OPEN'])return;const _0x1e181a=term['cols'],_0x1eb3f7=term['rows'];socket['send'](JSON['stringify']({'type':'resize','cols':_0x1e181a,'rows':_0x1eb3f7}));}function updateStatus(_0x40593d,_0x5b631c='info'){if(!statusEl)return;statusEl['textContent']=_0x40593d,statusEl['dataset']['variant']=_0x5b631c;}async function enrichContainerDetails(_0x441ac8){try{const _0x4204d1=await API['getContainer'](_0x441ac8);updateTerminalDetails(_0x4204d1);}catch{try{const _0x4b8f5b=await API['getContainers'](),_0x48e52b=(_0x4b8f5b['containers']||[])['find'](_0x5807c6=>_0x5807c6['containerId']===_0x441ac8||_0x5807c6['name']===_0x441ac8||_0x5807c6['fullContainerId']?.['startsWith'](_0x441ac8));if(_0x48e52b){updateTerminalDetails(_0x48e52b);return;}subtitleEl['textContent']='Container\x20'+_0x441ac8['substring'](0x0,0xc);}catch{subtitleEl['textContent']='Container\x20'+_0x441ac8['substring'](0x0,0xc);}}}function updateTerminalDetails(_0x36c036){const _0x31d04d=_0x36c036['containerId']||_0x36c036['name']||_0x36c036['fullContainerId']||containerId,_0xc05596=_0x36c036['environment']?'Environment\x20'+_0x36c036['environment']:'Environment\x20unknown',_0xd1a277=_0x36c036['defaultAgent']?'\x20·\x20Agent\x20'+_0x36c036['defaultAgent']:'',_0x22907c=_0x36c036['createdAt']?'\x20·\x20Started\x20'+Utils['formatRelativeTime'](_0x36c036['createdAt']):'';titleEl['textContent']='Terminal\x20·\x20'+_0x31d04d['substring'](0x0,0xc);const _0x4b6b4f=command?'\x20·\x20Command\x20'+command:'';subtitleEl['textContent']=''+_0xc05596+_0xd1a277+_0x22907c+_0x4b6b4f;}
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'](_0x9d601b=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':_0x9d601b}));});let commandSent=![],hasReceivedOutput=![];socket['addEventListener']('message',_0x5648d8=>{try{const _0xf21160=JSON['parse'](_0x5648d8['data']);if(_0xf21160['type']==='data'&&typeof _0xf21160['data']==='string')term['write'](_0xf21160['data']),!hasReceivedOutput&&_0xf21160['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(_0xf21160['type']==='status'&&_0xf21160['status']){if(_0xf21160['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'+_0xf21160['status'],_0xf21160['status']==='connected'?'success':'info');}else _0xf21160['type']==='error'&&_0xf21160['message']&&updateStatus(_0xf21160['message'],'error');}}catch(_0x5c7c11){console['error']('Failed\x20to\x20parse\x20terminal\x20message',_0x5c7c11);}}),socket['addEventListener']('close',_0x413477=>{const _0x372c70=_0x413477['reason']||'Connection\x20closed';updateStatus(_0x372c70,_0x413477['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',_0xad2d87=>{console['error']('Terminal\x20websocket\x20error',_0xad2d87),updateStatus('Connection\x20error','error');});function sendResize(){if(socket['readyState']!==WebSocket['OPEN'])return;const _0xa426ef=term['cols'],_0x5c84b7=term['rows'];socket['send'](JSON['stringify']({'type':'resize','cols':_0xa426ef,'rows':_0x5c84b7}));}function updateStatus(_0x121474,_0x454491='info'){if(!statusEl)return;statusEl['textContent']=_0x121474,statusEl['dataset']['variant']=_0x454491;}async function enrichContainerDetails(_0x5b7dd9){try{const _0x2eb1b4=await API['getContainer'](_0x5b7dd9);updateTerminalDetails(_0x2eb1b4);}catch{try{const _0x4ee5b3=await API['getContainers'](),_0x3dd705=(_0x4ee5b3['containers']||[])['find'](_0x34e662=>_0x34e662['containerId']===_0x5b7dd9||_0x34e662['name']===_0x5b7dd9||_0x34e662['fullContainerId']?.['startsWith'](_0x5b7dd9));if(_0x3dd705){updateTerminalDetails(_0x3dd705);return;}subtitleEl['textContent']='Container\x20'+_0x5b7dd9['substring'](0x0,0xc);}catch{subtitleEl['textContent']='Container\x20'+_0x5b7dd9['substring'](0x0,0xc);}}}function updateTerminalDetails(_0x299416){const _0xa3eed9=_0x299416['containerId']||_0x299416['name']||_0x299416['fullContainerId']||containerId,_0x5ebb8e=_0x299416['environment']?'Environment\x20'+_0x299416['environment']:'Environment\x20unknown',_0x24edd8=_0x299416['defaultAgent']?'\x20·\x20Agent\x20'+_0x299416['defaultAgent']:'',_0x5a7e03=_0x299416['createdAt']?'\x20·\x20Started\x20'+Utils['formatRelativeTime'](_0x299416['createdAt']):'';titleEl['textContent']='Terminal\x20·\x20'+_0xa3eed9['substring'](0x0,0xc);const _0x3524d2=command?'\x20·\x20Command\x20'+command:'';subtitleEl['textContent']=''+_0x5ebb8e+_0x24edd8+_0x5a7e03+_0x3524d2;}
@@ -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 _0x491272=localStorage['getItem'](THEME_STORAGE_KEY);if(_0x491272&&VALID_THEMES['has'](_0x491272))return _0x491272;}catch(_0xf36534){console['warn']('[Theme]\x20Failed\x20to\x20read\x20stored\x20theme\x20preference:',_0xf36534);}return null;}export function getPreferredTheme(){const _0x34c58f=readStoredTheme();if(_0x34c58f)return _0x34c58f;const _0x19c125=window['matchMedia']&&window['matchMedia']('(prefers-color-scheme:\x20dark)')['matches'];return _0x19c125?'dark':'light';}export function getCurrentTheme(){const _0x42a6af=document['documentElement']['dataset']['theme'];if(_0x42a6af&&VALID_THEMES['has'](_0x42a6af))return _0x42a6af;return getPreferredTheme();}export function applyTheme(_0x4ddb25,{persist:persist=!![],emitEvent:emitEvent=!![]}={}){const _0x1cd522=VALID_THEMES['has'](_0x4ddb25)?_0x4ddb25:'light';document['documentElement']['dataset']['theme']=_0x1cd522,document['documentElement']['style']['colorScheme']=_0x1cd522==='dark'?'dark':'light';if(persist)try{localStorage['setItem'](THEME_STORAGE_KEY,_0x1cd522);}catch(_0x249ad2){console['warn']('[Theme]\x20Failed\x20to\x20persist\x20theme\x20preference:',_0x249ad2);}return emitEvent&&window['dispatchEvent'](new CustomEvent(THEME_CHANGE_EVENT,{'detail':{'theme':_0x1cd522}})),_0x1cd522;}export function initTheme(_0x21469b={}){const {emitEvent:emitEvent=![]}=_0x21469b;return applyTheme(getPreferredTheme(),{'persist':![],'emitEvent':emitEvent});}export function toggleTheme(){const _0x23c080=getCurrentTheme()==='dark'?'light':'dark';return applyTheme(_0x23c080);}export function onThemeChange(_0x3234ac,{runImmediately:runImmediately=![]}={}){const _0x5e67fd=_0x2ba85f=>{_0x3234ac(_0x2ba85f['detail']['theme']);};return window['addEventListener'](THEME_CHANGE_EVENT,_0x5e67fd),runImmediately&&_0x3234ac(getCurrentTheme()),()=>window['removeEventListener'](THEME_CHANGE_EVENT,_0x5e67fd);}export function mountThemeToggle(_0x1f2d80={}){const {targetSelectors:targetSelectors=DEFAULT_TARGET_SELECTORS}=_0x1f2d80,_0x24dce9=targetSelectors['map'](_0xc3943f=>document['querySelector'](_0xc3943f))['find'](Boolean),_0x44cbff=document['createElement']('button');_0x44cbff['type']='button',_0x44cbff['className']='btn-ghost\x20theme-toggle-btn',_0x44cbff['id']='theme-toggle-btn',_0x44cbff['setAttribute']('aria-pressed','false'),_0x44cbff['style']['padding']='8px',_0x44cbff['style']['lineHeight']='0',_0x44cbff['style']['width']='36px',_0x44cbff['style']['height']='36px',_0x44cbff['style']['display']='flex',_0x44cbff['style']['alignItems']='center',_0x44cbff['style']['justifyContent']='center';const _0x477c81=document['createElement']('span');_0x477c81['className']='theme-icon',_0x477c81['style']['display']='flex',_0x44cbff['append'](_0x477c81);const _0xadecdb='<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>',_0x4bc4fd='<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>',_0x1a5f04=_0x1ef607=>{const _0x5f2ab4=_0x1ef607==='dark';_0x477c81['innerHTML']=_0x5f2ab4?_0xadecdb:_0x4bc4fd,_0x44cbff['title']=_0x5f2ab4?'Switch\x20to\x20light\x20mode':'Switch\x20to\x20dark\x20mode',_0x44cbff['dataset']['theme']=_0x1ef607,_0x44cbff['setAttribute']('aria-pressed',String(_0x5f2ab4));};return _0x44cbff['addEventListener']('click',()=>{const _0x58a97a=getCurrentTheme()==='dark'?'light':'dark';applyTheme(_0x58a97a);}),_0x24dce9?_0x24dce9['appendChild'](_0x44cbff):(_0x44cbff['classList']['add']('theme-toggle-floating'),document['body']['appendChild'](_0x44cbff)),_0x1a5f04(initTheme()),onThemeChange(_0x1a5f04),_0x44cbff;}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 _0x5487a2=localStorage['getItem'](THEME_STORAGE_KEY);if(_0x5487a2&&VALID_THEMES['has'](_0x5487a2))return _0x5487a2;}catch(_0x385be8){console['warn']('[Theme]\x20Failed\x20to\x20read\x20stored\x20theme\x20preference:',_0x385be8);}return null;}export function getPreferredTheme(){const _0x2b60c0=readStoredTheme();if(_0x2b60c0)return _0x2b60c0;const _0x22506f=window['matchMedia']&&window['matchMedia']('(prefers-color-scheme:\x20dark)')['matches'];return _0x22506f?'dark':'light';}export function getCurrentTheme(){const _0x76e0da=document['documentElement']['dataset']['theme'];if(_0x76e0da&&VALID_THEMES['has'](_0x76e0da))return _0x76e0da;return getPreferredTheme();}export function applyTheme(_0x34bfb2,{persist:persist=!![],emitEvent:emitEvent=!![]}={}){const _0x15b5e9=VALID_THEMES['has'](_0x34bfb2)?_0x34bfb2:'light';document['documentElement']['dataset']['theme']=_0x15b5e9,document['documentElement']['style']['colorScheme']=_0x15b5e9==='dark'?'dark':'light';if(persist)try{localStorage['setItem'](THEME_STORAGE_KEY,_0x15b5e9);}catch(_0xcd428c){console['warn']('[Theme]\x20Failed\x20to\x20persist\x20theme\x20preference:',_0xcd428c);}return emitEvent&&window['dispatchEvent'](new CustomEvent(THEME_CHANGE_EVENT,{'detail':{'theme':_0x15b5e9}})),_0x15b5e9;}export function initTheme(_0x14097d={}){const {emitEvent:emitEvent=![]}=_0x14097d;return applyTheme(getPreferredTheme(),{'persist':![],'emitEvent':emitEvent});}export function toggleTheme(){const _0x5d7082=getCurrentTheme()==='dark'?'light':'dark';return applyTheme(_0x5d7082);}export function onThemeChange(_0x37d731,{runImmediately:runImmediately=![]}={}){const _0xa62a80=_0x45362d=>{_0x37d731(_0x45362d['detail']['theme']);};return window['addEventListener'](THEME_CHANGE_EVENT,_0xa62a80),runImmediately&&_0x37d731(getCurrentTheme()),()=>window['removeEventListener'](THEME_CHANGE_EVENT,_0xa62a80);}export function mountThemeToggle(_0x26cef9={}){const {targetSelectors:targetSelectors=DEFAULT_TARGET_SELECTORS}=_0x26cef9,_0x68a14e=targetSelectors['map'](_0x6b261d=>document['querySelector'](_0x6b261d))['find'](Boolean),_0x24f7ce=document['createElement']('button');_0x24f7ce['type']='button',_0x24f7ce['className']='btn-ghost\x20theme-toggle-btn',_0x24f7ce['id']='theme-toggle-btn',_0x24f7ce['setAttribute']('aria-pressed','false'),_0x24f7ce['style']['padding']='8px',_0x24f7ce['style']['lineHeight']='0',_0x24f7ce['style']['width']='36px',_0x24f7ce['style']['height']='36px',_0x24f7ce['style']['display']='flex',_0x24f7ce['style']['alignItems']='center',_0x24f7ce['style']['justifyContent']='center';const _0x4bab4e=document['createElement']('span');_0x4bab4e['className']='theme-icon',_0x4bab4e['style']['display']='flex',_0x24f7ce['append'](_0x4bab4e);const _0x40e76c='<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>',_0x185782='<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>',_0x5a74be=_0x3d5874=>{const _0x857cc4=_0x3d5874==='dark';_0x4bab4e['innerHTML']=_0x857cc4?_0x40e76c:_0x185782,_0x24f7ce['title']=_0x857cc4?'Switch\x20to\x20light\x20mode':'Switch\x20to\x20dark\x20mode',_0x24f7ce['dataset']['theme']=_0x3d5874,_0x24f7ce['setAttribute']('aria-pressed',String(_0x857cc4));};return _0x24f7ce['addEventListener']('click',()=>{const _0x280d8b=getCurrentTheme()==='dark'?'light':'dark';applyTheme(_0x280d8b);}),_0x68a14e?_0x68a14e['appendChild'](_0x24f7ce):(_0x24f7ce['classList']['add']('theme-toggle-floating'),document['body']['appendChild'](_0x24f7ce)),_0x5a74be(initTheme()),onThemeChange(_0x5a74be),_0x24f7ce;}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 _0x14a2bb=await API['getCurrentUser']();state['currentUser']=_0x14a2bb;if(!Permissions['hasServerPermission'](_0x14a2bb,'*')&&!Permissions['hasServerPermission'](_0x14a2bb,'users:create')){Utils['showToast']('Access\x20denied:\x20Server\x20admin\x20privileges\x20required','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}}catch(_0x1653f0){window['location']['href']='login.html';}}async function checkEmailConfig(){try{const _0x1a4a28=await API['getEmailConfig']();state['emailConfigured']=_0x1a4a28['configured'];}catch(_0xcd665){console['error']('Failed\x20to\x20check\x20email\x20config',_0xcd665),state['emailConfigured']=![];}}async function loadRoles(){try{const {roles:_0x283b1d}=await API['getRoleDefinitions']();state['roles']=_0x283b1d||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x125826=await API['getEnvironments']();state['environments']=_0x125826['environments']||[];}catch{state['environments']=[];}}async function loadTeams(){try{const {teams:_0x5db86d}=await API['getTeams']();state['teams']=_0x5db86d||[];}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 _0x3ceabc=document['getElementById']('users-loading'),_0x47f48d=document['getElementById']('users-error'),_0x3eb584=document['getElementById']('users-content');try{_0x3ceabc['hidden']=![],_0x47f48d['hidden']=!![],_0x3eb584['hidden']=!![];const _0x4f1183=await API['getUsers']();state['users']=_0x4f1183['users']||[],renderUsers(),_0x3ceabc['hidden']=!![],_0x3eb584['hidden']=![];}catch(_0x12a9ea){console['error']('Failed\x20to\x20load\x20users',_0x12a9ea),_0x3ceabc['hidden']=!![],_0x47f48d['hidden']=![],document['getElementById']('users-error-message')['textContent']=_0x12a9ea['message'];}}function renderUsers(){const _0x16a7cb=document['getElementById']('users-table-body'),_0x36c9aa=document['getElementById']('user-count');if(!_0x16a7cb)return;_0x36c9aa&&(_0x36c9aa['textContent']=state['users']['length']+'\x20user'+(state['users']['length']===0x1?'':'s'));const _0x24630e=[...state['users']]['sort']((_0x17bc0e,_0xb838d2)=>{const _0x810376=new Date(_0x17bc0e['created_at'])['getTime'](),_0x55d5f4=new Date(_0xb838d2['created_at'])['getTime']();return _0x55d5f4-_0x810376;});_0x16a7cb['innerHTML']=_0x24630e['map'](_0x45406f=>'\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'](_0x45406f['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'](_0x45406f['name'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x45406f['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'+(_0x45406f['isServerAdmin']?'<span\x20class=\x22role-badge\x20role-admin\x22>Server\x20Admin</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x45406f['hasUserBinding']?'<span\x20class=\x22role-badge\x20role-user-binding\x22>User\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x45406f['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'](_0x45406f['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'+_0x45406f['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'+_0x45406f['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'+_0x45406f['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'+_0x45406f['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(_0x5f402e){const _0x46554a=state['users']['find'](_0xdcdccf=>_0xdcdccf['id']===_0x5f402e);if(!_0x46554a)return;state['bindingsUserId']=_0x5f402e,state['bindingsDirty']=![];const _0x22097f=document['getElementById']('bindings-modal'),_0x12b1fc=document['getElementById']('bindings-modal-title');_0x12b1fc['textContent']='Access\x20Bindings\x20—\x20'+_0x46554a['name'],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],_0x22097f['hidden']=![],loadUserBindings(_0x5f402e);};function hasUnsavedBindingChanges(){const _0x543ee7=document['getElementById']('add-user-binding-form');return _0x543ee7&&!_0x543ee7['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 _0x1279e9=document['getElementById']('bindings-modal');_0x1279e9['hidden']=!![];const _0x314ce0=state['bindingsDirty'];state['bindingsUserId']=null,state['userBindings']=[],state['bindingsDirty']=![],_0x314ce0&&await loadUsers();}async function loadUserBindings(_0x5e5c81){const _0x47ab9c=document['getElementById']('user-bindings-loading'),_0x4dc824=document['getElementById']('user-bindings-empty'),_0x1cc5e0=document['getElementById']('user-bindings-list-container'),_0x39414d=document['getElementById']('add-user-binding-btn'),_0x421cd3=document['getElementById']('user-team-bindings-note'),_0x1b931e=document['getElementById']('user-team-bindings-text');_0x47ab9c['hidden']=![],_0x4dc824['hidden']=!![],_0x1cc5e0['style']['display']='none',_0x39414d['hidden']=!![],_0x421cd3['hidden']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![];try{const [_0x2079a2,_0xcdd7b3]=await Promise['all']([API['getBindings']({'subject_type':'user','subject_id':_0x5e5c81}),API['getTeams']()]);state['userBindings']=_0x2079a2['bindings']||[];const _0x158d62=(_0xcdd7b3['teams']||[])['filter'](_0x31f951=>(_0x31f951['members']||[])['includes'](_0x5e5c81)),_0x2a23ee=[];if(_0x158d62['length']>0x0){const _0x38ef4c=await Promise['all'](_0x158d62['map'](_0x409f36=>API['getBindings']({'subject_type':'team','subject_id':_0x409f36['id']})));for(let _0x574e3c=0x0;_0x574e3c<_0x158d62['length'];_0x574e3c++){const _0xb57769=_0x38ef4c[_0x574e3c]['bindings']||[];_0xb57769['length']>0x0&&_0x2a23ee['push'](_0x158d62[_0x574e3c]);}}_0x47ab9c['hidden']=!![];state['userBindings']['length']===0x0?_0x4dc824['hidden']=![]:(_0x1cc5e0['style']['display']='',renderUserBindingsTable());if(_0x2a23ee['length']>0x0){const _0x1a3d46=_0x2a23ee['map'](_0x9587fe=>_0x9587fe['name']),_0x47c1d6=_0x1a3d46['length']<=0x3?_0x1a3d46['join'](',\x20'):_0x1a3d46['slice'](0x0,0x3)['join'](',\x20')+(',\x20and\x20'+(_0x1a3d46['length']-0x3)+'\x20more');_0x1b931e['textContent']='This\x20user\x20also\x20has\x20access\x20via\x20team\x20memberships\x20('+_0x47c1d6+').';}else _0x1b931e['textContent']='This\x20user\x20has\x20no\x20access\x20via\x20team\x20memberships.';_0x421cd3['hidden']=![],_0x39414d['hidden']=![];}catch(_0x233c53){_0x47ab9c['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x233c53['message'],'error');}}function renderUserBindingsTable(){const _0x44915b=document['getElementById']('user-bindings-table-body');if(!_0x44915b)return;_0x44915b['innerHTML']=state['userBindings']['map'](_0x30c39d=>{const _0x2370c8=_0x30c39d['resource_type']==='server'?'Server':_0x30c39d['resource_id']==='*'?'All\x20'+_0x30c39d['resource_type']+'s':Utils['escapeHtml'](_0x30c39d['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x2370c8+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x30c39d['role_name']||_0x30c39d['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'+_0x30c39d['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 _0xdbc57f=document['getElementById']('user-binding-resource-type');_0xdbc57f['value']='environment',updateUserBindingFormForResourceType('environment');}function onUserBindingResourceTypeChange(){const _0xfbd1a0=document['getElementById']('user-binding-resource-type')['value'];updateUserBindingFormForResourceType(_0xfbd1a0);}function updateUserBindingFormForResourceType(_0x252f5e){const _0x4e8788=document['getElementById']('user-binding-resource-container'),_0x28b287=document['getElementById']('user-binding-resource'),_0x3cd887=document['getElementById']('user-binding-role');if(_0x252f5e==='server')_0x4e8788['style']['display']='none';else{_0x4e8788['style']['display']='';if(_0x252f5e==='environment'){const _0x5eb4c0=new Set(state['userBindings']['filter'](_0x9b8ec5=>_0x9b8ec5['resource_type']==='environment')['map'](_0x22b3a2=>_0x22b3a2['resource_id'])),_0x598f0e=state['environments']['filter'](_0x12075f=>!_0x5eb4c0['has'](_0x12075f['name']));_0x28b287['innerHTML']=_0x598f0e['length']?_0x598f0e['map'](_0x2983dd=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x2983dd['name'])+'\x22>'+Utils['escapeHtml'](_0x2983dd['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x252f5e==='team'){const _0x32296e=new Set(state['userBindings']['filter'](_0x3c1d9a=>_0x3c1d9a['resource_type']==='team')['map'](_0x245dee=>_0x245dee['resource_id'])),_0xf00853=state['teams']['filter'](_0x1ff846=>!_0x32296e['has'](_0x1ff846['id']));_0x28b287['innerHTML']=_0xf00853['length']?_0xf00853['map'](_0x16e183=>'<option\x20value=\x22'+_0x16e183['id']+'\x22>'+Utils['escapeHtml'](_0x16e183['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x13fd6c=state['roles']['filter'](_0x5c6949=>_0x5c6949['resource_type']===_0x252f5e);_0x3cd887['innerHTML']=_0x13fd6c['length']?_0x13fd6c['filter'](_0x10b589=>{const _0x54e641=_0x252f5e==='server'?undefined:_0x28b287['value'];return!state['userBindings']['some'](_0x4133bf=>_0x4133bf['resource_type']===_0x252f5e&&_0x4133bf['role_id']===_0x10b589['id']&&(_0x252f5e==='server'||_0x4133bf['resource_id']===_0x54e641));})['map'](_0x3aa0e1=>'<option\x20value=\x22'+_0x3aa0e1['id']+'\x22>'+Utils['escapeHtml'](_0x3aa0e1['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 _0x35de0d=document['getElementById']('user-binding-resource-type')['value'],_0x4792fa=document['getElementById']('user-binding-role')['value'];if(!_0x4792fa||!state['bindingsUserId'])return;const _0x4edfd1=_0x35de0d==='server'?undefined:document['getElementById']('user-binding-resource')['value'];if(_0x35de0d!=='server'&&!_0x4edfd1)return;const _0x271281=document['getElementById']('save-user-binding-btn');_0x271281['disabled']=!![],_0x271281['textContent']='Adding…';try{const _0x4a268c={'subject_type':'user','subject_id':state['bindingsUserId'],'role_id':_0x4792fa,'resource_type':_0x35de0d};if(_0x4edfd1)_0x4a268c['resource_id']=_0x4edfd1;await API['createBinding'](_0x4a268c),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(_0x5a906b){Utils['showToast'](_0x5a906b['message'],'error');}finally{_0x271281['disabled']=![],_0x271281['textContent']='Add\x20Binding';}}window['deleteUserBindingClick']=async function(_0x5938ec){try{await API['deleteBinding'](_0x5938ec),Utils['showToast']('Binding\x20removed','success'),state['bindingsDirty']=!![],await loadUserBindings(state['bindingsUserId']);}catch(_0x5a465d){Utils['showToast'](_0x5a465d['message'],'error');}};function showCreateUserModal(){state['editingUserId']=null;const _0x5d8ef2=document['getElementById']('user-modal'),_0x70adcf=document['getElementById']('modal-title'),_0x447031=document['getElementById']('user-password'),_0x35cc34=document['getElementById']('password-required'),_0x2de829=document['getElementById']('password-hint'),_0x4ff869=document['getElementById']('skip-password-container'),_0x3abb0e=document['getElementById']('skip-password');_0x70adcf['textContent']='Create\x20User',document['getElementById']('user-form')['reset'](),_0x447031['required']=!![];if(_0x35cc34)_0x35cc34['textContent']='*';_0x4ff869&&(_0x4ff869['style']['display']='block',_0x3abb0e['checked']=![]),_0x2de829&&(_0x2de829['textContent']='Minimum\x208\x20characters'),_0x5d8ef2['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);}window['editUser']=function(_0x1285c1){const _0x42322b=state['users']['find'](_0x3531a4=>_0x3531a4['id']===_0x1285c1);if(!_0x42322b)return;state['editingUserId']=_0x1285c1;const _0x7699ae=document['getElementById']('user-modal'),_0x1a43b4=document['getElementById']('modal-title'),_0x2cad17=document['getElementById']('user-password'),_0x362097=document['getElementById']('password-required'),_0x369a2b=document['getElementById']('password-hint'),_0x25d349=document['getElementById']('skip-password-container');_0x1a43b4['textContent']='Edit\x20User',document['getElementById']('user-username')['value']=_0x42322b['username'],document['getElementById']('user-name')['value']=_0x42322b['name'],document['getElementById']('user-email')['value']=_0x42322b['email'],_0x2cad17['value']='',_0x2cad17['required']=![];if(_0x362097)_0x362097['textContent']='';_0x25d349&&(_0x25d349['style']['display']='none'),_0x369a2b&&(_0x369a2b['textContent']='Leave\x20blank\x20to\x20keep\x20current\x20password'),_0x7699ae['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);};function hideUserModal(){const _0x596830=document['getElementById']('user-modal'),_0x1cd7ab=document['getElementById']('form-error'),_0x14ef07=document['getElementById']('save-user');_0x596830['hidden']=!![],_0x1cd7ab['hidden']=!![],state['editingUserId']=null,_0x14ef07&&(_0x14ef07['disabled']=![],_0x14ef07['textContent']='Save\x20User');}async function saveUser(){const _0x2b0fbc=document['getElementById']('user-form'),_0x5653b7=document['getElementById']('skip-password')?.['checked']||![];if(!_0x5653b7&&!_0x2b0fbc['checkValidity']()){_0x2b0fbc['reportValidity']();return;}const _0x20e648=document['getElementById']('form-error'),_0x1690f1=document['getElementById']('save-user'),_0x44ae01=document['getElementById']('user-username')['value']['trim'](),_0x573e51=document['getElementById']('user-name')['value']['trim'](),_0x520446=document['getElementById']('user-email')['value']['trim'](),_0x12f798=document['getElementById']('user-password')['value'];if(!_0x44ae01||!_0x573e51||!_0x520446){_0x20e648['textContent']='Please\x20fill\x20in\x20all\x20required\x20fields',_0x20e648['hidden']=![],_0x20e648['scrollIntoView']({'behavior':'smooth','block':'nearest'});return;}_0x20e648['hidden']=!![];const _0x1deb28=_0x1690f1['textContent'];_0x1690f1['disabled']=!![],_0x1690f1['textContent']=state['editingUserId']?'Updating...':'Creating...';try{if(state['editingUserId']){const _0x1eb91d={'username':_0x44ae01,'name':_0x573e51,'email':_0x520446};_0x12f798&&(_0x1eb91d['password']=_0x12f798),await API['updateUser'](state['editingUserId'],_0x1eb91d),Utils['showToast']('User\x20updated\x20successfully','success'),await loadUsers(),hideUserModal();}else{const _0xbb3f92={'username':_0x44ae01,'name':_0x573e51,'email':_0x520446};if(!_0x5653b7){if(!_0x12f798)throw new Error('Password\x20is\x20required\x20for\x20new\x20users');_0xbb3f92['password']=_0x12f798;}const _0x1ef5c1=await API['createUser'](_0xbb3f92),_0x5152ad=_0x1ef5c1['user'];if(_0x5653b7||!_0x12f798){const _0x4df786=await API['createPasswordToken'](_0x5152ad['id'],'setup',![]);state['setupLinkData']={'username':_0x5152ad['username'],'email':_0x5152ad['email'],'url':_0x4df786['token']['setupUrl'],'userId':_0x5152ad['id'],'type':'setup','emailSent':![]},await loadUsers(),hideUserModal(),showSetupLinkModal();}else Utils['showToast']('User\x20created\x20successfully','success'),await loadUsers(),hideUserModal();}}catch(_0x44c859){console['error']('Failed\x20to\x20save\x20user',_0x44c859),_0x20e648['textContent']=_0x44c859['message'],_0x20e648['hidden']=![],_0x20e648['scrollIntoView']({'behavior':'smooth','block':'nearest'}),_0x1690f1['disabled']=![],_0x1690f1['textContent']=_0x1deb28;}}window['deleteUser']=function(_0x517003){const _0x3de230=state['users']['find'](_0x117182=>_0x117182['id']===_0x517003);if(!_0x3de230)return;state['deletingUserId']=_0x517003;const _0x1d284f=document['getElementById']('delete-modal'),_0x174536=document['getElementById']('delete-user-name');_0x174536['textContent']=_0x3de230['name']+'\x20('+_0x3de230['username']+')',_0x1d284f['hidden']=![];};function hideDeleteModal(){const _0x367ca6=document['getElementById']('delete-modal');_0x367ca6['hidden']=!![],state['deletingUserId']=null;const _0x30ae1a=document['getElementById']('confirm-delete');_0x30ae1a&&(_0x30ae1a['disabled']=![],_0x30ae1a['textContent']='Delete\x20User');}async function confirmDeleteUser(){if(!state['deletingUserId'])return;const _0x5b2787=document['getElementById']('confirm-delete'),_0x199515=_0x5b2787['textContent'];_0x5b2787['disabled']=!![],_0x5b2787['textContent']='Deleting...';try{await API['deleteUser'](state['deletingUserId']),Utils['showToast']('User\x20deleted\x20successfully','success'),await loadUsers(),hideDeleteModal();}catch(_0x33c1d4){console['error']('Failed\x20to\x20delete\x20user',_0x33c1d4),Utils['showToast']('Failed\x20to\x20delete\x20user:\x20'+_0x33c1d4['message'],'error'),_0x5b2787['disabled']=![],_0x5b2787['textContent']=_0x199515;}}function handleSkipPasswordChange(_0x4c7fce){const _0x251824=document['getElementById']('user-password'),_0x1315d2=_0x4c7fce['target']['checked'];_0x1315d2?(_0x251824['required']=![],_0x251824['disabled']=!![],_0x251824['value']=''):(_0x251824['required']=!![],_0x251824['disabled']=![]);}function showSetupLinkModal(){if(!state['setupLinkData'])return;const _0x2fd0aa=document['getElementById']('setup-link-modal'),_0x4346d0=document['getElementById']('setup-link-username'),_0x4b75f7=document['getElementById']('setup-link-url'),_0x422c27=document['getElementById']('email-setup-link'),_0x5e6da3=document['getElementById']('email-button-text');_0x4346d0['textContent']=state['setupLinkData']['username'],_0x4b75f7['textContent']=state['setupLinkData']['url'],_0x422c27&&_0x5e6da3&&(_0x422c27['disabled']=![],_0x5e6da3['textContent']='Email\x20Link',state['emailConfigured']&&!state['setupLinkData']['emailSent']?_0x422c27['style']['display']='inline-block':_0x422c27['style']['display']='none'),_0x2fd0aa['hidden']=![];}function hideSetupLinkModal(){const _0x4966a0=document['getElementById']('setup-link-modal');_0x4966a0['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(_0x36b065){console['error']('Failed\x20to\x20copy\x20link',_0x36b065),Utils['showToast']('Failed\x20to\x20copy\x20link','error');}}async function emailSetupLink(){if(!state['setupLinkData'])return;const _0x5cbc70=document['getElementById']('email-setup-link'),_0x43921e=document['getElementById']('email-button-text');if(!_0x5cbc70||!_0x43921e)return;const _0x3b4099=_0x43921e['textContent'];_0x5cbc70['disabled']=!![],_0x43921e['textContent']='Sending...';try{const _0x274813=await API['createPasswordToken'](state['setupLinkData']['userId'],state['setupLinkData']['type'],!![]);if(_0x274813['emailSent'])Utils['showToast']('Email\x20sent\x20to\x20'+state['setupLinkData']['email'],'success'),state['setupLinkData']['emailSent']=!![],_0x5cbc70['style']['display']='none';else{const _0x119fd7=_0x274813['emailError']||'Failed\x20to\x20send\x20email';Utils['showToast'](_0x119fd7,'error'),_0x5cbc70['disabled']=![],_0x43921e['textContent']=_0x3b4099;}}catch(_0x2eb2de){console['error']('Failed\x20to\x20email\x20setup\x20link',_0x2eb2de),Utils['showToast']('Failed\x20to\x20send\x20email:\x20'+_0x2eb2de['message'],'error'),_0x5cbc70['disabled']=![],_0x43921e['textContent']=_0x3b4099;}}window['resetPassword']=async function(_0x5dec2b){const _0x2cf772=state['users']['find'](_0x3ab48b=>_0x3ab48b['id']===_0x5dec2b);if(!_0x2cf772)return;const _0x4bbe5f=await ConfirmDialog['show']({'title':'Reset\x20Password','message':'Generate\x20a\x20password\x20reset\x20link\x20for\x20'+_0x2cf772['name']+'\x20('+_0x2cf772['username']+')?\x20This\x20will\x20create\x20a\x20link\x20that\x20they\x20can\x20use\x20to\x20set\x20a\x20new\x20password.','confirmText':'Generate\x20Link'});if(!_0x4bbe5f)return;try{const _0x3dba61=await API['createPasswordToken'](_0x5dec2b,'reset',![]);state['setupLinkData']={'username':_0x2cf772['username'],'email':_0x2cf772['email'],'url':_0x3dba61['token']['setupUrl'],'userId':_0x2cf772['id'],'type':'reset','emailSent':![]},showSetupLinkModal();}catch(_0x51465c){console['error']('Failed\x20to\x20create\x20password\x20reset\x20link',_0x51465c),Utils['showToast']('Failed\x20to\x20create\x20password\x20reset\x20link:\x20'+_0x51465c['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 _0x461788=await API['getCurrentUser']();state['currentUser']=_0x461788;if(!Permissions['hasServerPermission'](_0x461788,'*')&&!Permissions['hasServerPermission'](_0x461788,'users:create')){Utils['showToast']('Access\x20denied:\x20Server\x20admin\x20privileges\x20required','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}}catch(_0x1bbd83){window['location']['href']='login.html';}}async function checkEmailConfig(){try{const _0x3e915e=await API['getEmailConfig']();state['emailConfigured']=_0x3e915e['configured'];}catch(_0x46e0fa){console['error']('Failed\x20to\x20check\x20email\x20config',_0x46e0fa),state['emailConfigured']=![];}}async function loadRoles(){try{const {roles:_0x138b27}=await API['getRoleDefinitions']();state['roles']=_0x138b27||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x5976ea=await API['getEnvironments']();state['environments']=_0x5976ea['environments']||[];}catch{state['environments']=[];}}async function loadTeams(){try{const {teams:_0x14f3bd}=await API['getTeams']();state['teams']=_0x14f3bd||[];}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 _0x31a8df=document['getElementById']('users-loading'),_0x248ce7=document['getElementById']('users-error'),_0x223860=document['getElementById']('users-content');try{_0x31a8df['hidden']=![],_0x248ce7['hidden']=!![],_0x223860['hidden']=!![];const _0x1f2b59=await API['getUsers']();state['users']=_0x1f2b59['users']||[],renderUsers(),_0x31a8df['hidden']=!![],_0x223860['hidden']=![];}catch(_0x4103fe){console['error']('Failed\x20to\x20load\x20users',_0x4103fe),_0x31a8df['hidden']=!![],_0x248ce7['hidden']=![],document['getElementById']('users-error-message')['textContent']=_0x4103fe['message'];}}function renderUsers(){const _0x14b8e8=document['getElementById']('users-table-body'),_0x57622d=document['getElementById']('user-count');if(!_0x14b8e8)return;_0x57622d&&(_0x57622d['textContent']=state['users']['length']+'\x20user'+(state['users']['length']===0x1?'':'s'));const _0x4e3523=[...state['users']]['sort']((_0x48faf,_0x12fd35)=>{const _0xc6ba1d=new Date(_0x48faf['created_at'])['getTime'](),_0x241754=new Date(_0x12fd35['created_at'])['getTime']();return _0x241754-_0xc6ba1d;});_0x14b8e8['innerHTML']=_0x4e3523['map'](_0x47c8a5=>'\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'](_0x47c8a5['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'](_0x47c8a5['name'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x47c8a5['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'+(_0x47c8a5['isServerAdmin']?'<span\x20class=\x22role-badge\x20role-admin\x22>Server\x20Admin</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x47c8a5['hasUserBinding']?'<span\x20class=\x22role-badge\x20role-user-binding\x22>User\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x47c8a5['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'](_0x47c8a5['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'+_0x47c8a5['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'+_0x47c8a5['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'+_0x47c8a5['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'+_0x47c8a5['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(_0x306992){const _0x15a28d=state['users']['find'](_0x3d28fb=>_0x3d28fb['id']===_0x306992);if(!_0x15a28d)return;state['bindingsUserId']=_0x306992,state['bindingsDirty']=![];const _0x585e37=document['getElementById']('bindings-modal'),_0x3024c5=document['getElementById']('bindings-modal-title');_0x3024c5['textContent']='Access\x20Bindings\x20—\x20'+_0x15a28d['name'],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],_0x585e37['hidden']=![],loadUserBindings(_0x306992);};function hasUnsavedBindingChanges(){const _0x40d73c=document['getElementById']('add-user-binding-form');return _0x40d73c&&!_0x40d73c['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 _0x1ff1a7=document['getElementById']('bindings-modal');_0x1ff1a7['hidden']=!![];const _0x3bfe9a=state['bindingsDirty'];state['bindingsUserId']=null,state['userBindings']=[],state['bindingsDirty']=![],_0x3bfe9a&&await loadUsers();}async function loadUserBindings(_0x5f7d16){const _0x264fca=document['getElementById']('user-bindings-loading'),_0x2dc385=document['getElementById']('user-bindings-empty'),_0x790637=document['getElementById']('user-bindings-list-container'),_0xf54984=document['getElementById']('add-user-binding-btn'),_0x52b7b8=document['getElementById']('user-team-bindings-note'),_0x82fea0=document['getElementById']('user-team-bindings-text');_0x264fca['hidden']=![],_0x2dc385['hidden']=!![],_0x790637['style']['display']='none',_0xf54984['hidden']=!![],_0x52b7b8['hidden']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![];try{const [_0x59d650,_0x73750a]=await Promise['all']([API['getBindings']({'subject_type':'user','subject_id':_0x5f7d16}),API['getTeams']()]);state['userBindings']=_0x59d650['bindings']||[];const _0x4cf109=(_0x73750a['teams']||[])['filter'](_0xe7bf11=>(_0xe7bf11['members']||[])['includes'](_0x5f7d16)),_0x820abd=[];if(_0x4cf109['length']>0x0){const _0x1e0fea=await Promise['all'](_0x4cf109['map'](_0x1a257e=>API['getBindings']({'subject_type':'team','subject_id':_0x1a257e['id']})));for(let _0x1b2ec5=0x0;_0x1b2ec5<_0x4cf109['length'];_0x1b2ec5++){const _0x3f6434=_0x1e0fea[_0x1b2ec5]['bindings']||[];_0x3f6434['length']>0x0&&_0x820abd['push'](_0x4cf109[_0x1b2ec5]);}}_0x264fca['hidden']=!![];state['userBindings']['length']===0x0?_0x2dc385['hidden']=![]:(_0x790637['style']['display']='',renderUserBindingsTable());if(_0x820abd['length']>0x0){const _0x52e846=_0x820abd['map'](_0x46b0a0=>_0x46b0a0['name']),_0x44b9c4=_0x52e846['length']<=0x3?_0x52e846['join'](',\x20'):_0x52e846['slice'](0x0,0x3)['join'](',\x20')+(',\x20and\x20'+(_0x52e846['length']-0x3)+'\x20more');_0x82fea0['textContent']='This\x20user\x20also\x20has\x20access\x20via\x20team\x20memberships\x20('+_0x44b9c4+').';}else _0x82fea0['textContent']='This\x20user\x20has\x20no\x20access\x20via\x20team\x20memberships.';_0x52b7b8['hidden']=![],_0xf54984['hidden']=![];}catch(_0x344d08){_0x264fca['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x344d08['message'],'error');}}function renderUserBindingsTable(){const _0xc60db5=document['getElementById']('user-bindings-table-body');if(!_0xc60db5)return;_0xc60db5['innerHTML']=state['userBindings']['map'](_0x27b284=>{const _0x2c62f1=_0x27b284['resource_type']==='server'?'Server':_0x27b284['resource_id']==='*'?'All\x20'+_0x27b284['resource_type']+'s':Utils['escapeHtml'](_0x27b284['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x2c62f1+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x27b284['role_name']||_0x27b284['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'+_0x27b284['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 _0x760d47=document['getElementById']('user-binding-resource-type');_0x760d47['value']='environment',updateUserBindingFormForResourceType('environment');}function onUserBindingResourceTypeChange(){const _0x5b678b=document['getElementById']('user-binding-resource-type')['value'];updateUserBindingFormForResourceType(_0x5b678b);}function updateUserBindingFormForResourceType(_0x2f610f){const _0x21a13d=document['getElementById']('user-binding-resource-container'),_0x11d0f7=document['getElementById']('user-binding-resource'),_0x580055=document['getElementById']('user-binding-role');if(_0x2f610f==='server')_0x21a13d['style']['display']='none';else{_0x21a13d['style']['display']='';if(_0x2f610f==='environment'){const _0x608c8d=new Set(state['userBindings']['filter'](_0x4b1197=>_0x4b1197['resource_type']==='environment')['map'](_0x43b3a3=>_0x43b3a3['resource_id'])),_0x552e30=state['environments']['filter'](_0x563230=>!_0x608c8d['has'](_0x563230['name']));_0x11d0f7['innerHTML']=_0x552e30['length']?_0x552e30['map'](_0x2ec374=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x2ec374['name'])+'\x22>'+Utils['escapeHtml'](_0x2ec374['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x2f610f==='team'){const _0x501a3a=new Set(state['userBindings']['filter'](_0x4765ee=>_0x4765ee['resource_type']==='team')['map'](_0x2212c1=>_0x2212c1['resource_id'])),_0x55ff56=state['teams']['filter'](_0x3d12ae=>!_0x501a3a['has'](_0x3d12ae['id']));_0x11d0f7['innerHTML']=_0x55ff56['length']?_0x55ff56['map'](_0x39b338=>'<option\x20value=\x22'+_0x39b338['id']+'\x22>'+Utils['escapeHtml'](_0x39b338['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x45c3f5=state['roles']['filter'](_0x14de52=>_0x14de52['resource_type']===_0x2f610f);_0x580055['innerHTML']=_0x45c3f5['length']?_0x45c3f5['filter'](_0x13d95b=>{const _0x3522fc=_0x2f610f==='server'?undefined:_0x11d0f7['value'];return!state['userBindings']['some'](_0x5ad715=>_0x5ad715['resource_type']===_0x2f610f&&_0x5ad715['role_id']===_0x13d95b['id']&&(_0x2f610f==='server'||_0x5ad715['resource_id']===_0x3522fc));})['map'](_0x297e60=>'<option\x20value=\x22'+_0x297e60['id']+'\x22>'+Utils['escapeHtml'](_0x297e60['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 _0x146d0b=document['getElementById']('user-binding-resource-type')['value'],_0x1a84da=document['getElementById']('user-binding-role')['value'];if(!_0x1a84da||!state['bindingsUserId'])return;const _0x8b23f8=_0x146d0b==='server'?undefined:document['getElementById']('user-binding-resource')['value'];if(_0x146d0b!=='server'&&!_0x8b23f8)return;const _0x45b30e=document['getElementById']('save-user-binding-btn');_0x45b30e['disabled']=!![],_0x45b30e['textContent']='Adding…';try{const _0x3df1f5={'subject_type':'user','subject_id':state['bindingsUserId'],'role_id':_0x1a84da,'resource_type':_0x146d0b};if(_0x8b23f8)_0x3df1f5['resource_id']=_0x8b23f8;await API['createBinding'](_0x3df1f5),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(_0x2cc0ac){Utils['showToast'](_0x2cc0ac['message'],'error');}finally{_0x45b30e['disabled']=![],_0x45b30e['textContent']='Add\x20Binding';}}window['deleteUserBindingClick']=async function(_0x232202){try{await API['deleteBinding'](_0x232202),Utils['showToast']('Binding\x20removed','success'),state['bindingsDirty']=!![],await loadUserBindings(state['bindingsUserId']);}catch(_0x3fc7a6){Utils['showToast'](_0x3fc7a6['message'],'error');}};function showCreateUserModal(){state['editingUserId']=null;const _0x503133=document['getElementById']('user-modal'),_0x4e7d6e=document['getElementById']('modal-title'),_0x554c93=document['getElementById']('user-password'),_0x33f3db=document['getElementById']('password-required'),_0x435925=document['getElementById']('password-hint'),_0x3ef207=document['getElementById']('skip-password-container'),_0x419a62=document['getElementById']('skip-password');_0x4e7d6e['textContent']='Create\x20User',document['getElementById']('user-form')['reset'](),_0x554c93['required']=!![];if(_0x33f3db)_0x33f3db['textContent']='*';_0x3ef207&&(_0x3ef207['style']['display']='block',_0x419a62['checked']=![]),_0x435925&&(_0x435925['textContent']='Minimum\x208\x20characters'),_0x503133['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);}window['editUser']=function(_0x3674fb){const _0x3f64e3=state['users']['find'](_0x493acc=>_0x493acc['id']===_0x3674fb);if(!_0x3f64e3)return;state['editingUserId']=_0x3674fb;const _0x56b7b0=document['getElementById']('user-modal'),_0x36bd18=document['getElementById']('modal-title'),_0x3a6399=document['getElementById']('user-password'),_0x413dc5=document['getElementById']('password-required'),_0x5bfee9=document['getElementById']('password-hint'),_0x25f3f2=document['getElementById']('skip-password-container');_0x36bd18['textContent']='Edit\x20User',document['getElementById']('user-username')['value']=_0x3f64e3['username'],document['getElementById']('user-name')['value']=_0x3f64e3['name'],document['getElementById']('user-email')['value']=_0x3f64e3['email'],_0x3a6399['value']='',_0x3a6399['required']=![];if(_0x413dc5)_0x413dc5['textContent']='';_0x25f3f2&&(_0x25f3f2['style']['display']='none'),_0x5bfee9&&(_0x5bfee9['textContent']='Leave\x20blank\x20to\x20keep\x20current\x20password'),_0x56b7b0['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);};function hideUserModal(){const _0x522faa=document['getElementById']('user-modal'),_0x33f299=document['getElementById']('form-error'),_0x2ac342=document['getElementById']('save-user');_0x522faa['hidden']=!![],_0x33f299['hidden']=!![],state['editingUserId']=null,_0x2ac342&&(_0x2ac342['disabled']=![],_0x2ac342['textContent']='Save\x20User');}async function saveUser(){const _0xad6b48=document['getElementById']('user-form'),_0x2ba9b1=document['getElementById']('skip-password')?.['checked']||![];if(!_0x2ba9b1&&!_0xad6b48['checkValidity']()){_0xad6b48['reportValidity']();return;}const _0x53ffa7=document['getElementById']('form-error'),_0x4ddba6=document['getElementById']('save-user'),_0x18e61f=document['getElementById']('user-username')['value']['trim'](),_0x2ddb07=document['getElementById']('user-name')['value']['trim'](),_0x19d27e=document['getElementById']('user-email')['value']['trim'](),_0xfdfe12=document['getElementById']('user-password')['value'];if(!_0x18e61f||!_0x2ddb07||!_0x19d27e){_0x53ffa7['textContent']='Please\x20fill\x20in\x20all\x20required\x20fields',_0x53ffa7['hidden']=![],_0x53ffa7['scrollIntoView']({'behavior':'smooth','block':'nearest'});return;}_0x53ffa7['hidden']=!![];const _0x10843e=_0x4ddba6['textContent'];_0x4ddba6['disabled']=!![],_0x4ddba6['textContent']=state['editingUserId']?'Updating...':'Creating...';try{if(state['editingUserId']){const _0x28967e={'username':_0x18e61f,'name':_0x2ddb07,'email':_0x19d27e};_0xfdfe12&&(_0x28967e['password']=_0xfdfe12),await API['updateUser'](state['editingUserId'],_0x28967e),Utils['showToast']('User\x20updated\x20successfully','success'),await loadUsers(),hideUserModal();}else{const _0x51c01b={'username':_0x18e61f,'name':_0x2ddb07,'email':_0x19d27e};if(!_0x2ba9b1){if(!_0xfdfe12)throw new Error('Password\x20is\x20required\x20for\x20new\x20users');_0x51c01b['password']=_0xfdfe12;}const _0x146ebe=await API['createUser'](_0x51c01b),_0x5c6026=_0x146ebe['user'];if(_0x2ba9b1||!_0xfdfe12){const _0x102295=await API['createPasswordToken'](_0x5c6026['id'],'setup',![]);state['setupLinkData']={'username':_0x5c6026['username'],'email':_0x5c6026['email'],'url':_0x102295['token']['setupUrl'],'userId':_0x5c6026['id'],'type':'setup','emailSent':![]},await loadUsers(),hideUserModal(),showSetupLinkModal();}else Utils['showToast']('User\x20created\x20successfully','success'),await loadUsers(),hideUserModal();}}catch(_0x2df2c4){console['error']('Failed\x20to\x20save\x20user',_0x2df2c4),_0x53ffa7['textContent']=_0x2df2c4['message'],_0x53ffa7['hidden']=![],_0x53ffa7['scrollIntoView']({'behavior':'smooth','block':'nearest'}),_0x4ddba6['disabled']=![],_0x4ddba6['textContent']=_0x10843e;}}window['deleteUser']=function(_0x206d69){const _0x331c16=state['users']['find'](_0x3a1d98=>_0x3a1d98['id']===_0x206d69);if(!_0x331c16)return;state['deletingUserId']=_0x206d69;const _0xf48818=document['getElementById']('delete-modal'),_0x3829e3=document['getElementById']('delete-user-name');_0x3829e3['textContent']=_0x331c16['name']+'\x20('+_0x331c16['username']+')',_0xf48818['hidden']=![];};function hideDeleteModal(){const _0x3bf215=document['getElementById']('delete-modal');_0x3bf215['hidden']=!![],state['deletingUserId']=null;const _0x3c61e7=document['getElementById']('confirm-delete');_0x3c61e7&&(_0x3c61e7['disabled']=![],_0x3c61e7['textContent']='Delete\x20User');}async function confirmDeleteUser(){if(!state['deletingUserId'])return;const _0x1eee41=document['getElementById']('confirm-delete'),_0x493d84=_0x1eee41['textContent'];_0x1eee41['disabled']=!![],_0x1eee41['textContent']='Deleting...';try{await API['deleteUser'](state['deletingUserId']),Utils['showToast']('User\x20deleted\x20successfully','success'),await loadUsers(),hideDeleteModal();}catch(_0x5be5d8){console['error']('Failed\x20to\x20delete\x20user',_0x5be5d8),Utils['showToast']('Failed\x20to\x20delete\x20user:\x20'+_0x5be5d8['message'],'error'),_0x1eee41['disabled']=![],_0x1eee41['textContent']=_0x493d84;}}function handleSkipPasswordChange(_0x31ec78){const _0x498f96=document['getElementById']('user-password'),_0x5d9f5b=_0x31ec78['target']['checked'];_0x5d9f5b?(_0x498f96['required']=![],_0x498f96['disabled']=!![],_0x498f96['value']=''):(_0x498f96['required']=!![],_0x498f96['disabled']=![]);}function showSetupLinkModal(){if(!state['setupLinkData'])return;const _0x294cdb=document['getElementById']('setup-link-modal'),_0x54bad5=document['getElementById']('setup-link-username'),_0x1aafe4=document['getElementById']('setup-link-url'),_0x27b3da=document['getElementById']('email-setup-link'),_0x5cefad=document['getElementById']('email-button-text');_0x54bad5['textContent']=state['setupLinkData']['username'],_0x1aafe4['textContent']=state['setupLinkData']['url'],_0x27b3da&&_0x5cefad&&(_0x27b3da['disabled']=![],_0x5cefad['textContent']='Email\x20Link',state['emailConfigured']&&!state['setupLinkData']['emailSent']?_0x27b3da['style']['display']='inline-block':_0x27b3da['style']['display']='none'),_0x294cdb['hidden']=![];}function hideSetupLinkModal(){const _0x59994a=document['getElementById']('setup-link-modal');_0x59994a['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(_0x1dafbf){console['error']('Failed\x20to\x20copy\x20link',_0x1dafbf),Utils['showToast']('Failed\x20to\x20copy\x20link','error');}}async function emailSetupLink(){if(!state['setupLinkData'])return;const _0x40e153=document['getElementById']('email-setup-link'),_0x3c27fb=document['getElementById']('email-button-text');if(!_0x40e153||!_0x3c27fb)return;const _0x50cf07=_0x3c27fb['textContent'];_0x40e153['disabled']=!![],_0x3c27fb['textContent']='Sending...';try{const _0x12f729=await API['createPasswordToken'](state['setupLinkData']['userId'],state['setupLinkData']['type'],!![]);if(_0x12f729['emailSent'])Utils['showToast']('Email\x20sent\x20to\x20'+state['setupLinkData']['email'],'success'),state['setupLinkData']['emailSent']=!![],_0x40e153['style']['display']='none';else{const _0x300974=_0x12f729['emailError']||'Failed\x20to\x20send\x20email';Utils['showToast'](_0x300974,'error'),_0x40e153['disabled']=![],_0x3c27fb['textContent']=_0x50cf07;}}catch(_0x4ec51e){console['error']('Failed\x20to\x20email\x20setup\x20link',_0x4ec51e),Utils['showToast']('Failed\x20to\x20send\x20email:\x20'+_0x4ec51e['message'],'error'),_0x40e153['disabled']=![],_0x3c27fb['textContent']=_0x50cf07;}}window['resetPassword']=async function(_0x55468f){const _0x2b9ed3=state['users']['find'](_0xf1df2f=>_0xf1df2f['id']===_0x55468f);if(!_0x2b9ed3)return;const _0x103397=await ConfirmDialog['show']({'title':'Reset\x20Password','message':'Generate\x20a\x20password\x20reset\x20link\x20for\x20'+_0x2b9ed3['name']+'\x20('+_0x2b9ed3['username']+')?\x20This\x20will\x20create\x20a\x20link\x20that\x20they\x20can\x20use\x20to\x20set\x20a\x20new\x20password.','confirmText':'Generate\x20Link'});if(!_0x103397)return;try{const _0x22390e=await API['createPasswordToken'](_0x55468f,'reset',![]);state['setupLinkData']={'username':_0x2b9ed3['username'],'email':_0x2b9ed3['email'],'url':_0x22390e['token']['setupUrl'],'userId':_0x2b9ed3['id'],'type':'reset','emailSent':![]},showSetupLinkModal();}catch(_0x3b161c){console['error']('Failed\x20to\x20create\x20password\x20reset\x20link',_0x3b161c),Utils['showToast']('Failed\x20to\x20create\x20password\x20reset\x20link:\x20'+_0x3b161c['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(_0x359067={}){this['container']=null,this['onGroupChange']=_0x359067['onGroupChange']||(()=>{}),this['onAddExistingTask']=_0x359067['onAddExistingTask']||(()=>{}),this['tasks']=[],this['groupId']=_0x359067['groupId']||null,this['isOpen']=![];}['init'](_0x38d841,_0x1818c0,_0x45da21){this['container']=_0x38d841,this['tasks']=_0x1818c0,this['groupId']=_0x45da21,this['render'](),this['attachEventListeners']();}['updateTasks'](_0x4404a1){const _0x144f9e=new Map(_0x4404a1['map'](_0x274dfe=>[_0x274dfe['taskId'],_0x274dfe]));this['tasks']=this['tasks']['map'](_0x5edd8d=>{const _0x37457b=_0x144f9e['get'](_0x5edd8d['taskId']);return _0x37457b?_0x37457b:_0x5edd8d;});for(const _0x4eb12c of _0x4404a1){!this['tasks']['some'](_0x125cb8=>_0x125cb8['taskId']===_0x4eb12c['taskId'])&&this['tasks']['push'](_0x4eb12c);}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 _0x24f646=this['tasks']['filter'](_0x9ea750=>_0x9ea750['groupId']===this['groupId'])['sort']((_0x4e7f52,_0x241e94)=>(_0x4e7f52['groupIndex']??0x0)-(_0x241e94['groupIndex']??0x0)),_0x2b5be0=this['tasks']['filter'](_0x1ba4ca=>!_0x1ba4ca['groupId']||_0x1ba4ca['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>'+_0x24f646['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'+(_0x24f646['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20add\x20to\x20group</div>':_0x24f646['map']((_0x31977e,_0x36ee8b)=>this['renderVariantCard'](_0x31977e,_0x36ee8b,!![]))['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>'+_0x2b5be0['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'+(_0x2b5be0['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20remove\x20from\x20group</div>':_0x2b5be0['map']((_0x25de8e,_0xda4e49)=>this['renderVariantCard'](_0x25de8e,_0xda4e49,![]))['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'](_0x91574,_0x3e5a86,_0x369a5b){const _0x342696=_0x91574['envVars']?.['CODER_AGENT']||_0x91574['envVars']?.['default_agent']||'claude',_0x5b78aa=AGENT_ICONS[_0x342696['toLowerCase']()]||AGENT_ICONS['claude'],_0x697d07=STATUS_ICONS[_0x91574['status']]||'',_0x206045='status-'+(_0x91574['status']||'unknown'),_0x3a76e6=_0x91574['isWinner']?'<span\x20class=\x22vgm-badge\x20vgm-badge-winner\x22\x20title=\x22Winner\x22>★</span>':'',_0x4e6b2d=_0x91574['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'+_0x206045+'\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'+_0x91574['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-is-grouped=\x22'+_0x369a5b+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-index=\x22'+_0x3e5a86+'\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'+_0x342696['toLowerCase']()+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x5b78aa+'\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'](_0x91574['name']||'Task\x20'+_0x91574['taskId']['slice'](-0x6))+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-meta\x22>'+Utils['escapeHtml'](_0x342696)+'\x20·\x20'+(_0x91574['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'+_0x3a76e6+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x4e6b2d+'\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'+_0x206045+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x697d07+'\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'+(_0x369a5b?'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'+_0x91574['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-action=\x22'+(_0x369a5b?'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'+(_0x369a5b?'<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',_0x22fc9c=>{_0x22fc9c['target']['closest']('.vgm-close-btn')&&(this['close'](),this['onGroupChange'](this['tasks'])),_0x22fc9c['target']['closest']('.vgm-add-existing-btn')&&(this['close'](),this['onAddExistingTask'](this['groupId']));}),this['container']['addEventListener']('click',async _0x3efa2e=>{const _0x3bef49=_0x3efa2e['target']['closest']('.vgm-variant-remove-btn');if(!_0x3bef49)return;const _0x36f71f=_0x3bef49['dataset']['taskId'],_0x5665b3=_0x3bef49['dataset']['action'];try{_0x5665b3==='remove'?await this['removeFromGroup'](_0x36f71f):await this['addToGroup'](_0x36f71f);}catch(_0x415790){console['error']('Failed\x20to\x20update\x20group:',_0x415790),Utils['showToast'](_0x415790['message']||'Failed\x20to\x20update\x20group','error');}}),this['container']['addEventListener']('dragstart',_0x46f964=>this['handleDragStart'](_0x46f964)),this['container']['addEventListener']('dragend',_0x582de9=>this['handleDragEnd'](_0x582de9)),this['container']['addEventListener']('dragover',_0x12ecda=>this['handleDragOver'](_0x12ecda)),this['container']['addEventListener']('dragleave',_0x128cbd=>this['handleDragLeave'](_0x128cbd)),this['container']['addEventListener']('drop',_0x3aa086=>this['handleDrop'](_0x3aa086));}['handleDragStart'](_0x4e91d7){const _0x480d8a=_0x4e91d7['target']['closest']('.vgm-variant-card');if(!_0x480d8a)return;dragState['draggedTaskId']=_0x480d8a['dataset']['taskId'],dragState['draggedElement']=_0x480d8a,dragState['sourceGroupId']=_0x480d8a['dataset']['isGrouped']==='true'?this['groupId']:null,dragState['isDragging']=!![],_0x480d8a['classList']['add']('dragging'),_0x4e91d7['dataTransfer']['effectAllowed']='move',_0x4e91d7['dataTransfer']['setData']('text/plain',_0x480d8a['dataset']['taskId']),this['container']['classList']['add']('is-dragging');}['handleDragEnd'](_0x3b4979){const _0x1e2ab3=_0x3b4979['target']['closest']('.vgm-variant-card');_0x1e2ab3&&_0x1e2ab3['classList']['remove']('dragging'),this['container']['querySelectorAll']('.drag-over,\x20.drop-indicator')['forEach'](_0x703fa0=>{_0x703fa0['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'](_0x515047){_0x515047['preventDefault'](),_0x515047['dataTransfer']['dropEffect']='move';const _0x464860=_0x515047['target']['closest']('.vgm-drop-zone'),_0x332958=_0x515047['target']['closest']('.vgm-variant-card');this['container']['querySelectorAll']('.vgm-drop-zone')['forEach'](_0x2b3989=>{_0x2b3989['classList']['toggle']('drag-over',_0x2b3989===_0x464860);});if(_0x332958&&_0x332958!==dragState['draggedElement']){const _0xe747c6=_0x332958['getBoundingClientRect'](),_0xe50c6=_0xe747c6['top']+_0xe747c6['height']/0x2,_0x493c56=_0x515047['clientY']<_0xe50c6;this['container']['querySelectorAll']('.vgm-variant-card')['forEach'](_0x8b9e73=>{_0x8b9e73!==_0x332958&&_0x8b9e73['classList']['remove']('drop-before','drop-after');}),_0x332958['classList']['toggle']('drop-before',_0x493c56),_0x332958['classList']['toggle']('drop-after',!_0x493c56);}}['handleDragLeave'](_0x13e0ce){const _0x213fa5=_0x13e0ce['target']['closest']('.vgm-drop-zone');_0x213fa5&&!_0x213fa5['contains'](_0x13e0ce['relatedTarget'])&&_0x213fa5['classList']['remove']('drag-over');}async['handleDrop'](_0x417c0d){_0x417c0d['preventDefault']();const _0x1ca185=_0x417c0d['target']['closest']('.vgm-drop-zone'),_0x11777c=_0x417c0d['target']['closest']('.vgm-variant-card'),_0x311ff0=_0x417c0d['dataTransfer']['getData']('text/plain');if(!_0x1ca185||!_0x311ff0)return;this['container']['querySelectorAll']('.drag-over,\x20.drop-before,\x20.drop-after')['forEach'](_0x58981=>{_0x58981['classList']['remove']('drag-over','drop-before','drop-after');});const _0x526725=_0x1ca185['dataset']['zone'],_0x52e6cd=_0x526725==='grouped',_0x271c75=dragState['sourceGroupId']===this['groupId'];try{if(_0x52e6cd&&!_0x271c75){let _0x379b94=this['tasks']['filter'](_0x22646e=>_0x22646e['groupId']===this['groupId'])['length'];if(_0x11777c){const _0x4f7b72=_0x11777c['dataset']['taskId'],_0xe0df67=this['tasks']['find'](_0x10ae19=>_0x10ae19['taskId']===_0x4f7b72);if(_0xe0df67?.['groupIndex']!==undefined){const _0x140f10=_0x11777c['getBoundingClientRect'](),_0xe40f70=_0x417c0d['clientY']<_0x140f10['top']+_0x140f10['height']/0x2;_0x379b94=_0xe0df67['groupIndex']+(_0xe40f70?0x0:0x1);}}await this['addToGroup'](_0x311ff0,_0x379b94);}else{if(!_0x52e6cd&&_0x271c75)await this['removeFromGroup'](_0x311ff0);else _0x52e6cd&&_0x271c75&&_0x11777c&&await this['reorderInGroup'](_0x311ff0,_0x11777c,_0x417c0d['clientY']);}}catch(_0x1ee4e2){console['error']('Drop\x20operation\x20failed:',_0x1ee4e2),Utils['showToast'](_0x1ee4e2['message']||'Failed\x20to\x20move\x20variant','error');}}async['addToGroup'](_0x5a88f5,_0x58c625){const _0x2d9577=this['tasks']['find'](_0x590a28=>_0x590a28['taskId']===_0x5a88f5);if(!_0x2d9577)return;_0x58c625===undefined&&(_0x58c625=this['tasks']['filter'](_0x1dd46a=>_0x1dd46a['groupId']===this['groupId'])['length']),!this['groupId']&&(this['groupId']=API['generateGroupId'](),await API['createTaskGroup']({'groupId':this['groupId']})),await API['updateTaskGroup'](_0x5a88f5,this['groupId'],_0x58c625),_0x2d9577['groupId']=this['groupId'],_0x2d9577['groupIndex']=_0x58c625,this['render'](),this['onGroupChange'](this['tasks']);}async['removeFromGroup'](_0x4dac2d){const _0x4d2fe0=this['tasks']['find'](_0x1a552e=>_0x1a552e['taskId']===_0x4dac2d);if(!_0x4d2fe0)return;await API['removeTaskFromGroup'](_0x4dac2d),_0x4d2fe0['groupId']=null,_0x4d2fe0['groupIndex']=null,this['render'](),this['onGroupChange'](this['tasks']);}async['reorderInGroup'](_0xbdb21e,_0x582e8c,_0x32be87){const _0x3f616f=this['tasks']['find'](_0x1870f5=>_0x1870f5['taskId']===_0xbdb21e),_0xbce985=_0x582e8c['dataset']['taskId'],_0x10c2cf=this['tasks']['find'](_0x1efbd8=>_0x1efbd8['taskId']===_0xbce985);if(!_0x3f616f||!_0x10c2cf||_0x3f616f['taskId']===_0x10c2cf['taskId'])return;const _0x39f1a5=_0x582e8c['getBoundingClientRect'](),_0x54ac75=_0x32be87<_0x39f1a5['top']+_0x39f1a5['height']/0x2;let _0x45fcf6=_0x10c2cf['groupIndex']??0x0;if(!_0x54ac75)_0x45fcf6++;if((_0x3f616f['groupIndex']??0x0)<(_0x10c2cf['groupIndex']??0x0))_0x45fcf6--;if(_0x45fcf6===_0x3f616f['groupIndex'])return;await API['updateTaskGroup'](_0xbdb21e,this['groupId'],_0x45fcf6);const _0x181ee9=this['tasks']['filter'](_0x33754d=>_0x33754d['groupId']===this['groupId'])['sort']((_0x382915,_0x170cc9)=>(_0x382915['groupIndex']??0x0)-(_0x170cc9['groupIndex']??0x0)),_0x198cad=_0x181ee9['findIndex'](_0x18eff7=>_0x18eff7['taskId']===_0xbdb21e);_0x198cad!==-0x1&&_0x181ee9['splice'](_0x198cad,0x1),_0x181ee9['splice'](_0x45fcf6,0x0,_0x3f616f),_0x181ee9['forEach']((_0x32549a,_0x59ec23)=>{_0x32549a['groupIndex']=_0x59ec23;}),this['render'](),this['onGroupChange'](this['tasks']);}}export function initializeTabDragDrop(_0x1f910d,_0x2f8a25,_0xb5faa3,_0x36a79e={}){if(!_0x1f910d)return;const {onReorder:_0x41454c,onRemove:_0x4329ca}=_0x36a79e,_0x27e57f=_0x1f910d['querySelectorAll']('.task-tab');_0x27e57f['forEach']((_0x3469b9,_0x5f0ebf)=>{_0x3469b9['setAttribute']('draggable','true'),_0x3469b9['dataset']['index']=_0x5f0ebf,_0x3469b9['addEventListener']('dragstart',_0x1df7b5=>{_0x1df7b5['dataTransfer']['effectAllowed']='move',_0x1df7b5['dataTransfer']['setData']('text/plain',_0x3469b9['dataset']['taskId']),_0x3469b9['classList']['add']('dragging'),_0x1f910d['classList']['add']('is-dragging');}),_0x3469b9['addEventListener']('dragend',()=>{_0x3469b9['classList']['remove']('dragging'),_0x1f910d['classList']['remove']('is-dragging'),_0x1f910d['querySelectorAll']('.drop-indicator')['forEach'](_0x4d9ebb=>{_0x4d9ebb['classList']['remove']('drop-indicator','drop-before','drop-after');});}),_0x3469b9['addEventListener']('dragover',_0x176f9b=>{_0x176f9b['preventDefault'](),_0x176f9b['dataTransfer']['dropEffect']='move';if(_0x3469b9['classList']['contains']('dragging'))return;const _0x496024=_0x3469b9['getBoundingClientRect'](),_0x446f90=_0x496024['left']+_0x496024['width']/0x2,_0x2b56a8=_0x176f9b['clientX']<_0x446f90;_0x27e57f['forEach'](_0x54beef=>_0x54beef['classList']['remove']('drop-before','drop-after')),_0x3469b9['classList']['add'](_0x2b56a8?'drop-before':'drop-after');}),_0x3469b9['addEventListener']('dragleave',()=>{_0x3469b9['classList']['remove']('drop-before','drop-after');}),_0x3469b9['addEventListener']('drop',async _0x4adfea=>{_0x4adfea['preventDefault']();const _0x8790dc=_0x4adfea['dataTransfer']['getData']('text/plain'),_0x106112=_0x3469b9['dataset']['taskId'];if(_0x8790dc===_0x106112)return;const _0x243126=_0x3469b9['getBoundingClientRect'](),_0x596caa=_0x4adfea['clientX']<_0x243126['left']+_0x243126['width']/0x2;_0x3469b9['classList']['remove']('drop-before','drop-after'),_0x41454c&&await _0x41454c(_0x8790dc,_0x106112,_0x596caa);});});const _0xa24423=document['createElement']('div');return _0xa24423['className']='task-tab-remove-zone',_0xa24423['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',_0xa24423['style']['display']='none',_0xa24423['addEventListener']('dragover',_0x38eea0=>{_0x38eea0['preventDefault'](),_0xa24423['classList']['add']('drag-over');}),_0xa24423['addEventListener']('dragleave',()=>{_0xa24423['classList']['remove']('drag-over');}),_0xa24423['addEventListener']('drop',async _0x5b01d7=>{_0x5b01d7['preventDefault'](),_0xa24423['classList']['remove']('drag-over');const _0x3ed0cd=_0x5b01d7['dataTransfer']['getData']('text/plain');_0x4329ca&&await _0x4329ca(_0x3ed0cd);}),_0x1f910d['addEventListener']('dragstart',()=>{_0x2f8a25['length']>0x1&&(_0xa24423['style']['display']='flex');}),_0x1f910d['addEventListener']('dragend',()=>{_0xa24423['style']['display']='none';}),_0x1f910d['appendChild'](_0xa24423),{'destroy':()=>{_0xa24423['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(_0x4cc3a6={}){this['container']=null,this['onGroupChange']=_0x4cc3a6['onGroupChange']||(()=>{}),this['onAddExistingTask']=_0x4cc3a6['onAddExistingTask']||(()=>{}),this['tasks']=[],this['groupId']=_0x4cc3a6['groupId']||null,this['isOpen']=![];}['init'](_0x5774e9,_0x17f3f9,_0x4f9705){this['container']=_0x5774e9,this['tasks']=_0x17f3f9,this['groupId']=_0x4f9705,this['render'](),this['attachEventListeners']();}['updateTasks'](_0x111265){const _0x48c43a=new Map(_0x111265['map'](_0x581f2d=>[_0x581f2d['taskId'],_0x581f2d]));this['tasks']=this['tasks']['map'](_0x5a18cc=>{const _0xdb9880=_0x48c43a['get'](_0x5a18cc['taskId']);return _0xdb9880?_0xdb9880:_0x5a18cc;});for(const _0x448c5d of _0x111265){!this['tasks']['some'](_0x442ddb=>_0x442ddb['taskId']===_0x448c5d['taskId'])&&this['tasks']['push'](_0x448c5d);}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 _0x44a6d2=this['tasks']['filter'](_0x4db927=>_0x4db927['groupId']===this['groupId'])['sort']((_0x54a124,_0x43f589)=>(_0x54a124['groupIndex']??0x0)-(_0x43f589['groupIndex']??0x0)),_0x111206=this['tasks']['filter'](_0x4ce74d=>!_0x4ce74d['groupId']||_0x4ce74d['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>'+_0x44a6d2['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'+(_0x44a6d2['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20add\x20to\x20group</div>':_0x44a6d2['map']((_0x341ff8,_0x4740ee)=>this['renderVariantCard'](_0x341ff8,_0x4740ee,!![]))['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>'+_0x111206['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'+(_0x111206['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20remove\x20from\x20group</div>':_0x111206['map']((_0x45b06a,_0x48fde8)=>this['renderVariantCard'](_0x45b06a,_0x48fde8,![]))['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'](_0x524de8,_0x46ed72,_0x565e2c){const _0x2f3102=_0x524de8['envVars']?.['CODER_AGENT']||_0x524de8['envVars']?.['default_agent']||'claude',_0xecef2=AGENT_ICONS[_0x2f3102['toLowerCase']()]||AGENT_ICONS['claude'],_0x51f3c2=STATUS_ICONS[_0x524de8['status']]||'',_0x3d50bb='status-'+(_0x524de8['status']||'unknown'),_0x3a26f9=_0x524de8['isWinner']?'<span\x20class=\x22vgm-badge\x20vgm-badge-winner\x22\x20title=\x22Winner\x22>★</span>':'',_0x46e474=_0x524de8['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'+_0x3d50bb+'\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'+_0x524de8['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-is-grouped=\x22'+_0x565e2c+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-index=\x22'+_0x46ed72+'\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'+_0x2f3102['toLowerCase']()+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0xecef2+'\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'](_0x524de8['name']||'Task\x20'+_0x524de8['taskId']['slice'](-0x6))+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-meta\x22>'+Utils['escapeHtml'](_0x2f3102)+'\x20·\x20'+(_0x524de8['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'+_0x3a26f9+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x46e474+'\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'+_0x3d50bb+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x51f3c2+'\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'+(_0x565e2c?'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'+_0x524de8['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-action=\x22'+(_0x565e2c?'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'+(_0x565e2c?'<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',_0x14b2cf=>{_0x14b2cf['target']['closest']('.vgm-close-btn')&&(this['close'](),this['onGroupChange'](this['tasks'])),_0x14b2cf['target']['closest']('.vgm-add-existing-btn')&&(this['close'](),this['onAddExistingTask'](this['groupId']));}),this['container']['addEventListener']('click',async _0x27624f=>{const _0x43bf37=_0x27624f['target']['closest']('.vgm-variant-remove-btn');if(!_0x43bf37)return;const _0x502032=_0x43bf37['dataset']['taskId'],_0x4912f0=_0x43bf37['dataset']['action'];try{_0x4912f0==='remove'?await this['removeFromGroup'](_0x502032):await this['addToGroup'](_0x502032);}catch(_0x59458f){console['error']('Failed\x20to\x20update\x20group:',_0x59458f),Utils['showToast'](_0x59458f['message']||'Failed\x20to\x20update\x20group','error');}}),this['container']['addEventListener']('dragstart',_0x149e81=>this['handleDragStart'](_0x149e81)),this['container']['addEventListener']('dragend',_0x2aca7c=>this['handleDragEnd'](_0x2aca7c)),this['container']['addEventListener']('dragover',_0x547035=>this['handleDragOver'](_0x547035)),this['container']['addEventListener']('dragleave',_0x126fe3=>this['handleDragLeave'](_0x126fe3)),this['container']['addEventListener']('drop',_0x1cf3ed=>this['handleDrop'](_0x1cf3ed));}['handleDragStart'](_0x346d96){const _0x2e91a2=_0x346d96['target']['closest']('.vgm-variant-card');if(!_0x2e91a2)return;dragState['draggedTaskId']=_0x2e91a2['dataset']['taskId'],dragState['draggedElement']=_0x2e91a2,dragState['sourceGroupId']=_0x2e91a2['dataset']['isGrouped']==='true'?this['groupId']:null,dragState['isDragging']=!![],_0x2e91a2['classList']['add']('dragging'),_0x346d96['dataTransfer']['effectAllowed']='move',_0x346d96['dataTransfer']['setData']('text/plain',_0x2e91a2['dataset']['taskId']),this['container']['classList']['add']('is-dragging');}['handleDragEnd'](_0x87b001){const _0x2e6cf5=_0x87b001['target']['closest']('.vgm-variant-card');_0x2e6cf5&&_0x2e6cf5['classList']['remove']('dragging'),this['container']['querySelectorAll']('.drag-over,\x20.drop-indicator')['forEach'](_0x2be78d=>{_0x2be78d['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'](_0x2b52a5){_0x2b52a5['preventDefault'](),_0x2b52a5['dataTransfer']['dropEffect']='move';const _0x2b2f5f=_0x2b52a5['target']['closest']('.vgm-drop-zone'),_0x8f3803=_0x2b52a5['target']['closest']('.vgm-variant-card');this['container']['querySelectorAll']('.vgm-drop-zone')['forEach'](_0xc0b50a=>{_0xc0b50a['classList']['toggle']('drag-over',_0xc0b50a===_0x2b2f5f);});if(_0x8f3803&&_0x8f3803!==dragState['draggedElement']){const _0xbfc96c=_0x8f3803['getBoundingClientRect'](),_0x5e7178=_0xbfc96c['top']+_0xbfc96c['height']/0x2,_0x1a684c=_0x2b52a5['clientY']<_0x5e7178;this['container']['querySelectorAll']('.vgm-variant-card')['forEach'](_0x3e3147=>{_0x3e3147!==_0x8f3803&&_0x3e3147['classList']['remove']('drop-before','drop-after');}),_0x8f3803['classList']['toggle']('drop-before',_0x1a684c),_0x8f3803['classList']['toggle']('drop-after',!_0x1a684c);}}['handleDragLeave'](_0x561869){const _0x15b860=_0x561869['target']['closest']('.vgm-drop-zone');_0x15b860&&!_0x15b860['contains'](_0x561869['relatedTarget'])&&_0x15b860['classList']['remove']('drag-over');}async['handleDrop'](_0x1c882f){_0x1c882f['preventDefault']();const _0x5cb204=_0x1c882f['target']['closest']('.vgm-drop-zone'),_0x3d12fb=_0x1c882f['target']['closest']('.vgm-variant-card'),_0x205a3a=_0x1c882f['dataTransfer']['getData']('text/plain');if(!_0x5cb204||!_0x205a3a)return;this['container']['querySelectorAll']('.drag-over,\x20.drop-before,\x20.drop-after')['forEach'](_0x12dce6=>{_0x12dce6['classList']['remove']('drag-over','drop-before','drop-after');});const _0x6b9e46=_0x5cb204['dataset']['zone'],_0x3be871=_0x6b9e46==='grouped',_0x4f9407=dragState['sourceGroupId']===this['groupId'];try{if(_0x3be871&&!_0x4f9407){let _0x19ef5b=this['tasks']['filter'](_0x1a38cc=>_0x1a38cc['groupId']===this['groupId'])['length'];if(_0x3d12fb){const _0x489f56=_0x3d12fb['dataset']['taskId'],_0x1ea5de=this['tasks']['find'](_0x44ff7a=>_0x44ff7a['taskId']===_0x489f56);if(_0x1ea5de?.['groupIndex']!==undefined){const _0x243a27=_0x3d12fb['getBoundingClientRect'](),_0x19c483=_0x1c882f['clientY']<_0x243a27['top']+_0x243a27['height']/0x2;_0x19ef5b=_0x1ea5de['groupIndex']+(_0x19c483?0x0:0x1);}}await this['addToGroup'](_0x205a3a,_0x19ef5b);}else{if(!_0x3be871&&_0x4f9407)await this['removeFromGroup'](_0x205a3a);else _0x3be871&&_0x4f9407&&_0x3d12fb&&await this['reorderInGroup'](_0x205a3a,_0x3d12fb,_0x1c882f['clientY']);}}catch(_0x4b221d){console['error']('Drop\x20operation\x20failed:',_0x4b221d),Utils['showToast'](_0x4b221d['message']||'Failed\x20to\x20move\x20variant','error');}}async['addToGroup'](_0x304648,_0x4bfbb9){const _0x3e7474=this['tasks']['find'](_0x3e3e9d=>_0x3e3e9d['taskId']===_0x304648);if(!_0x3e7474)return;_0x4bfbb9===undefined&&(_0x4bfbb9=this['tasks']['filter'](_0x2af0d6=>_0x2af0d6['groupId']===this['groupId'])['length']),!this['groupId']&&(this['groupId']=API['generateGroupId'](),await API['createTaskGroup']({'groupId':this['groupId']})),await API['updateTaskGroup'](_0x304648,this['groupId'],_0x4bfbb9),_0x3e7474['groupId']=this['groupId'],_0x3e7474['groupIndex']=_0x4bfbb9,this['render'](),this['onGroupChange'](this['tasks']);}async['removeFromGroup'](_0x302bbc){const _0x2da2b4=this['tasks']['find'](_0x1596fa=>_0x1596fa['taskId']===_0x302bbc);if(!_0x2da2b4)return;await API['removeTaskFromGroup'](_0x302bbc),_0x2da2b4['groupId']=null,_0x2da2b4['groupIndex']=null,this['render'](),this['onGroupChange'](this['tasks']);}async['reorderInGroup'](_0x5c9a71,_0xffd6a,_0x512273){const _0x28ec8f=this['tasks']['find'](_0x5395de=>_0x5395de['taskId']===_0x5c9a71),_0x4ca16e=_0xffd6a['dataset']['taskId'],_0x56ef7d=this['tasks']['find'](_0x4e0587=>_0x4e0587['taskId']===_0x4ca16e);if(!_0x28ec8f||!_0x56ef7d||_0x28ec8f['taskId']===_0x56ef7d['taskId'])return;const _0xb6c36d=_0xffd6a['getBoundingClientRect'](),_0x46e905=_0x512273<_0xb6c36d['top']+_0xb6c36d['height']/0x2;let _0xb56b18=_0x56ef7d['groupIndex']??0x0;if(!_0x46e905)_0xb56b18++;if((_0x28ec8f['groupIndex']??0x0)<(_0x56ef7d['groupIndex']??0x0))_0xb56b18--;if(_0xb56b18===_0x28ec8f['groupIndex'])return;await API['updateTaskGroup'](_0x5c9a71,this['groupId'],_0xb56b18);const _0x2d399b=this['tasks']['filter'](_0x186916=>_0x186916['groupId']===this['groupId'])['sort']((_0x174af6,_0x35a43f)=>(_0x174af6['groupIndex']??0x0)-(_0x35a43f['groupIndex']??0x0)),_0x2ddf92=_0x2d399b['findIndex'](_0x3094b6=>_0x3094b6['taskId']===_0x5c9a71);_0x2ddf92!==-0x1&&_0x2d399b['splice'](_0x2ddf92,0x1),_0x2d399b['splice'](_0xb56b18,0x0,_0x28ec8f),_0x2d399b['forEach']((_0x37b0cd,_0x4f6c2c)=>{_0x37b0cd['groupIndex']=_0x4f6c2c;}),this['render'](),this['onGroupChange'](this['tasks']);}}export function initializeTabDragDrop(_0x4fbc7c,_0x46882d,_0x259fe9,_0x3cce13={}){if(!_0x4fbc7c)return;const {onReorder:_0x5e98f7,onRemove:_0x451a84}=_0x3cce13,_0x3a4a24=_0x4fbc7c['querySelectorAll']('.task-tab');_0x3a4a24['forEach']((_0x28d8b0,_0x9d45ae)=>{_0x28d8b0['setAttribute']('draggable','true'),_0x28d8b0['dataset']['index']=_0x9d45ae,_0x28d8b0['addEventListener']('dragstart',_0x4c57c1=>{_0x4c57c1['dataTransfer']['effectAllowed']='move',_0x4c57c1['dataTransfer']['setData']('text/plain',_0x28d8b0['dataset']['taskId']),_0x28d8b0['classList']['add']('dragging'),_0x4fbc7c['classList']['add']('is-dragging');}),_0x28d8b0['addEventListener']('dragend',()=>{_0x28d8b0['classList']['remove']('dragging'),_0x4fbc7c['classList']['remove']('is-dragging'),_0x4fbc7c['querySelectorAll']('.drop-indicator')['forEach'](_0x1fa4f3=>{_0x1fa4f3['classList']['remove']('drop-indicator','drop-before','drop-after');});}),_0x28d8b0['addEventListener']('dragover',_0x371448=>{_0x371448['preventDefault'](),_0x371448['dataTransfer']['dropEffect']='move';if(_0x28d8b0['classList']['contains']('dragging'))return;const _0x426a0a=_0x28d8b0['getBoundingClientRect'](),_0x38b8ae=_0x426a0a['left']+_0x426a0a['width']/0x2,_0x519512=_0x371448['clientX']<_0x38b8ae;_0x3a4a24['forEach'](_0x5ae6e8=>_0x5ae6e8['classList']['remove']('drop-before','drop-after')),_0x28d8b0['classList']['add'](_0x519512?'drop-before':'drop-after');}),_0x28d8b0['addEventListener']('dragleave',()=>{_0x28d8b0['classList']['remove']('drop-before','drop-after');}),_0x28d8b0['addEventListener']('drop',async _0x4f44b7=>{_0x4f44b7['preventDefault']();const _0x8b3fdc=_0x4f44b7['dataTransfer']['getData']('text/plain'),_0xab7d04=_0x28d8b0['dataset']['taskId'];if(_0x8b3fdc===_0xab7d04)return;const _0x35b9df=_0x28d8b0['getBoundingClientRect'](),_0x26ff2f=_0x4f44b7['clientX']<_0x35b9df['left']+_0x35b9df['width']/0x2;_0x28d8b0['classList']['remove']('drop-before','drop-after'),_0x5e98f7&&await _0x5e98f7(_0x8b3fdc,_0xab7d04,_0x26ff2f);});});const _0x18046e=document['createElement']('div');return _0x18046e['className']='task-tab-remove-zone',_0x18046e['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',_0x18046e['style']['display']='none',_0x18046e['addEventListener']('dragover',_0x3b1835=>{_0x3b1835['preventDefault'](),_0x18046e['classList']['add']('drag-over');}),_0x18046e['addEventListener']('dragleave',()=>{_0x18046e['classList']['remove']('drag-over');}),_0x18046e['addEventListener']('drop',async _0x4b4b28=>{_0x4b4b28['preventDefault'](),_0x18046e['classList']['remove']('drag-over');const _0xf4a463=_0x4b4b28['dataTransfer']['getData']('text/plain');_0x451a84&&await _0x451a84(_0xf4a463);}),_0x4fbc7c['addEventListener']('dragstart',()=>{_0x46882d['length']>0x1&&(_0x18046e['style']['display']='flex');}),_0x4fbc7c['addEventListener']('dragend',()=>{_0x18046e['style']['display']='none';}),_0x4fbc7c['appendChild'](_0x18046e),{'destroy':()=>{_0x18046e['remove']();}};}export default VariantGroupingManager;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@profoundlogic/coderflow-server",
3
- "version": "0.8.9",
3
+ "version": "0.9.0",
4
4
  "description": "AI Coder Server - Manages Docker containers for AI agent task execution",
5
5
  "main": "dist/start.js",
6
6
  "type": "module",