@profoundlogic/coderflow-server 0.6.2 → 0.6.4

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 (179) hide show
  1. package/dist/base-image/Dockerfile +4 -2
  2. package/dist/base-image/agent-wrapper.sh +32 -4
  3. package/dist/base-image/entrypoint.sh +3 -0
  4. package/dist/coder-server.js +1 -1
  5. package/dist/config/cli-models.json +12 -0
  6. package/dist/config.js +1 -1
  7. package/dist/lib/agent-keepalive.js +1 -1
  8. package/dist/lib/agent-models.js +1 -1
  9. package/dist/lib/api-keys.js +1 -1
  10. package/dist/lib/apiKeys.js +1 -1
  11. package/dist/lib/app-server-ports.js +1 -1
  12. package/dist/lib/auto-judge.js +1 -1
  13. package/dist/lib/automation-service.js +1 -1
  14. package/dist/lib/basic-auth.js +1 -1
  15. package/dist/lib/bindings.js +1 -1
  16. package/dist/lib/build-history.js +1 -1
  17. package/dist/lib/build-output-service.js +1 -1
  18. package/dist/lib/build-scheduler.js +1 -1
  19. package/dist/lib/build-service.js +1 -1
  20. package/dist/lib/ca-certificates.js +1 -1
  21. package/dist/lib/claude-oauth-refresh.js +1 -1
  22. package/dist/lib/cli/build.js +1 -1
  23. package/dist/lib/cli/cleanup-users.js +1 -1
  24. package/dist/lib/cli/config-command.js +1 -1
  25. package/dist/lib/cli/config.js +1 -1
  26. package/dist/lib/cli/create-user.js +1 -1
  27. package/dist/lib/cli/grant-admin.js +1 -1
  28. package/dist/lib/cli/init.js +1 -1
  29. package/dist/lib/cli/jira.js +1 -1
  30. package/dist/lib/cli/license.js +1 -1
  31. package/dist/lib/cli/list-roles.js +1 -1
  32. package/dist/lib/cli/list-users.js +1 -1
  33. package/dist/lib/cli/server-manager.js +1 -1
  34. package/dist/lib/cli/set-password.js +1 -1
  35. package/dist/lib/config-migration.js +1 -1
  36. package/dist/lib/container-credential-sync.js +1 -1
  37. package/dist/lib/container-tokens.js +1 -1
  38. package/dist/lib/data-dir.js +1 -1
  39. package/dist/lib/deployment-history.js +1 -1
  40. package/dist/lib/deployment-service.js +1 -1
  41. package/dist/lib/docker-utils.js +1 -1
  42. package/dist/lib/email.js +1 -1
  43. package/dist/lib/emailTemplates.js +1 -1
  44. package/dist/lib/entitlement.js +1 -1
  45. package/dist/lib/external-connections.js +1 -1
  46. package/dist/lib/fetch-utils.js +1 -1
  47. package/dist/lib/git-commit-details-route.js +1 -1
  48. package/dist/lib/git-history-diff-guardrails.js +1 -1
  49. package/dist/lib/git-provider-service.js +1 -1
  50. package/dist/lib/git-provider-setup/github-setup-handler.js +1 -1
  51. package/dist/lib/git-provider-setup/index.js +1 -1
  52. package/dist/lib/git-provider-setup/setup-factory.js +1 -1
  53. package/dist/lib/git-provider-setup/setup-interface.js +1 -1
  54. package/dist/lib/git-providers/azure-devops-provider.js +1 -1
  55. package/dist/lib/git-providers/github-app-provider.js +1 -1
  56. package/dist/lib/git-providers/index.js +1 -1
  57. package/dist/lib/git-providers/provider-factory.js +1 -1
  58. package/dist/lib/git-providers/provider-interface.js +1 -1
  59. package/dist/lib/github-urls.js +1 -1
  60. package/dist/lib/group-objective-linking.js +1 -1
  61. package/dist/lib/ibmi-sync.js +1 -1
  62. package/dist/lib/jira-client.js +1 -1
  63. package/dist/lib/judge-blinding.js +1 -1
  64. package/dist/lib/logger.js +1 -1
  65. package/dist/lib/migration-to-scoped-rbac.js +1 -1
  66. package/dist/lib/model-fetcher.js +1 -1
  67. package/dist/lib/notifications.js +1 -1
  68. package/dist/lib/objective-context.js +1 -1
  69. package/dist/lib/oidc-auth.js +1 -1
  70. package/dist/lib/oidc-device-flow.js +1 -1
  71. package/dist/lib/passwordTokens.js +1 -1
  72. package/dist/lib/permission-resolver.js +1 -1
  73. package/dist/lib/pin-cascade.js +1 -1
  74. package/dist/lib/provider-accounts.js +1 -1
  75. package/dist/lib/provider-oauth.js +1 -1
  76. package/dist/lib/provider-profile.js +1 -1
  77. package/dist/lib/provider-token-refresh.js +1 -1
  78. package/dist/lib/rbac-user-state.js +1 -1
  79. package/dist/lib/request-url.js +1 -1
  80. package/dist/lib/rewind.js +1 -1
  81. package/dist/lib/role-definitions.js +1 -1
  82. package/dist/lib/roles.js +1 -1
  83. package/dist/lib/secrets.js +1 -1
  84. package/dist/lib/setup-repo-git-auth.js +1 -1
  85. package/dist/lib/state-capture.js +1 -1
  86. package/dist/lib/static-files.js +1 -1
  87. package/dist/lib/task-name-format.js +1 -1
  88. package/dist/lib/task-name-generator.js +1 -1
  89. package/dist/lib/task-source-metadata.js +1 -1
  90. package/dist/lib/teams.js +1 -1
  91. package/dist/lib/user-git-oauth.js +1 -1
  92. package/dist/lib/user-git-tokens.js +1 -1
  93. package/dist/lib/users.js +1 -1
  94. package/dist/middleware/requireAuth.js +1 -1
  95. package/dist/middleware/requireInit.js +1 -1
  96. package/dist/middleware/requirePermission.js +1 -1
  97. package/dist/package.json +1 -1
  98. package/dist/playwright.config.js +1 -1
  99. package/dist/playwright.task-terminal.config.js +1 -1
  100. package/dist/routes/apiKeys.js +1 -1
  101. package/dist/routes/auth-oidc.js +1 -1
  102. package/dist/routes/auth.js +1 -1
  103. package/dist/routes/automations.js +1 -1
  104. package/dist/routes/bindings.js +1 -1
  105. package/dist/routes/build.js +1 -1
  106. package/dist/routes/containers.js +1 -1
  107. package/dist/routes/deploy-task.js +1 -1
  108. package/dist/routes/environment-management.js +1 -1
  109. package/dist/routes/environments.js +1 -1
  110. package/dist/routes/external-skills.js +1 -1
  111. package/dist/routes/git-credentials.js +1 -1
  112. package/dist/routes/git-oauth.js +1 -1
  113. package/dist/routes/git-provider-setup.js +1 -1
  114. package/dist/routes/health.js +1 -1
  115. package/dist/routes/jira.js +1 -1
  116. package/dist/routes/objective-management.js +1 -1
  117. package/dist/routes/password.js +1 -1
  118. package/dist/routes/prompt.js +1 -1
  119. package/dist/routes/provider-auth.js +1 -1
  120. package/dist/routes/qa.js +1 -1
  121. package/dist/routes/roles.js +1 -1
  122. package/dist/routes/settings.js +1 -1
  123. package/dist/routes/skill-management.js +1 -1
  124. package/dist/routes/skills.js +1 -1
  125. package/dist/routes/tasks.js +1 -1
  126. package/dist/routes/teams.js +1 -1
  127. package/dist/routes/templates.js +1 -1
  128. package/dist/routes/test-task.js +1 -1
  129. package/dist/routes/test.js +1 -1
  130. package/dist/routes/users.js +1 -1
  131. package/dist/routes/visualizations.js +1 -1
  132. package/dist/scripts/create-user.js +1 -1
  133. package/dist/scripts/migrate-config-to-data-dir.js +1 -1
  134. package/dist/start.js +1 -1
  135. package/dist/web-ui/public/activity-detail-modal.js +1 -1
  136. package/dist/web-ui/public/activity-feed.js +1 -1
  137. package/dist/web-ui/public/activity-formatters.js +1 -1
  138. package/dist/web-ui/public/agent-event-parser.js +1 -1
  139. package/dist/web-ui/public/app.js +1 -1
  140. package/dist/web-ui/public/approve-dialog.js +1 -1
  141. package/dist/web-ui/public/automation-links.js +1 -1
  142. package/dist/web-ui/public/automation-schedule.js +1 -1
  143. package/dist/web-ui/public/comments-widget.js +1 -1
  144. package/dist/web-ui/public/diff-utils.js +1 -1
  145. package/dist/web-ui/public/environments.js +1 -1
  146. package/dist/web-ui/public/feedback-widget.js +1 -1
  147. package/dist/web-ui/public/file-selection-tree.js +1 -1
  148. package/dist/web-ui/public/git-history-lazy-utils.js +1 -1
  149. package/dist/web-ui/public/git-history.js +1 -1
  150. package/dist/web-ui/public/git-status.js +1 -1
  151. package/dist/web-ui/public/ibmi-file-filter.js +1 -1
  152. package/dist/web-ui/public/index.html +39 -0
  153. package/dist/web-ui/public/index.js +1 -1
  154. package/dist/web-ui/public/login.js +1 -1
  155. package/dist/web-ui/public/markdown-editor.js +1 -1
  156. package/dist/web-ui/public/markdown-file-editor.js +1 -1
  157. package/dist/web-ui/public/modal-maximize.js +1 -1
  158. package/dist/web-ui/public/notifications.js +1 -1
  159. package/dist/web-ui/public/permissions.js +1 -1
  160. package/dist/web-ui/public/pr-dialog.js +1 -1
  161. package/dist/web-ui/public/roles.js +1 -1
  162. package/dist/web-ui/public/server-health.js +1 -1
  163. package/dist/web-ui/public/settings.html +23 -0
  164. package/dist/web-ui/public/settings.js +1 -1
  165. package/dist/web-ui/public/setup-password.js +1 -1
  166. package/dist/web-ui/public/skills.js +1 -1
  167. package/dist/web-ui/public/sse-client.js +1 -1
  168. package/dist/web-ui/public/sse-shared-worker.js +1 -1
  169. package/dist/web-ui/public/styles.css +101 -1
  170. package/dist/web-ui/public/task.html +46 -1
  171. package/dist/web-ui/public/task.js +1 -1
  172. package/dist/web-ui/public/teams.js +1 -1
  173. package/dist/web-ui/public/terminal.js +1 -1
  174. package/dist/web-ui/public/theme.js +1 -1
  175. package/dist/web-ui/public/users.js +1 -1
  176. package/dist/web-ui/public/variant-grouping.js +1 -1
  177. package/package.json +1 -1
  178. package/dist/.claude/settings.local.json +0 -20
  179. package/dist/playwright-test-results/.last-run.json +0 -54
@@ -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 _0x222075=state['currentUser'];if(!Permissions['hasServerPermission'](_0x222075,'*')&&!Permissions['hasTeamPermission'](_0x222075,'teams:manage')&&!Permissions['hasAnyEnvironment'](_0x222075)){Utils['showToast']('Access\x20denied:\x20You\x20do\x20not\x20have\x20permission\x20to\x20view\x20teams','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}(Permissions['hasServerPermission'](_0x222075,'*')||Permissions['hasTeamPermission'](_0x222075,'teams:manage'))&&(document['getElementById']('create-team-btn')['hidden']=![]),bindEventListeners(),await Promise['all']([loadTeams(),loadUsers(),loadRoles(),loadEnvironments()]),renderTeams();});async function loadTeams(){const _0x1eee36=document['getElementById']('teams-loading'),_0x12c716=document['getElementById']('teams-error'),_0x433c20=document['getElementById']('teams-content');try{_0x1eee36['hidden']=![],_0x12c716['hidden']=!![],_0x433c20['hidden']=!![];const {teams:_0x56e6be}=await API['getTeams']();state['teams']=_0x56e6be||[],renderTeams(),_0x1eee36['hidden']=!![],_0x433c20['hidden']=![];}catch(_0x4ee5ec){_0x1eee36['hidden']=!![],_0x12c716['hidden']=![],document['getElementById']('teams-error-message')['textContent']=_0x4ee5ec['message'];}}async function loadUsers(){try{const {users:_0x57a940}=await API['getUsers']();state['users']=_0x57a940||[];}catch{state['users']=[];}}async function loadRoles(){try{const {roles:_0xeefd4a}=await API['getRoleDefinitions']();state['roles']=_0xeefd4a||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x938b7=await API['getEnvironments']();state['environments']=_0x938b7['environments']||[];}catch{state['environments']=[];}}function renderTeams(){const _0x3e7d3b=document['getElementById']('teams-table-body'),_0x2e77dc=document['getElementById']('team-count');if(!_0x3e7d3b)return;_0x2e77dc&&(_0x2e77dc['textContent']=state['teams']['length']+'\x20team'+(state['teams']['length']===0x1?'':'s'));if(state['teams']['length']===0x0){_0x3e7d3b['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 _0x49fdd7=Permissions['hasServerPermission'](state['currentUser'],'*');_0x3e7d3b['innerHTML']=state['teams']['map'](_0x2f3688=>{const _0x48e1c5=_0x49fdd7||_0x2f3688['canManageTeam'],_0x10d95d=_0x49fdd7||_0x2f3688['canManageMembers'],_0x6367a1=_0x48e1c5||_0x10d95d,_0x4f2747=(_0x2f3688['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'](_0x2f3688['name'])+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x2f3688['description']?'<div\x20style=\x22font-size:\x200.8em;\x20color:\x20var(--color-text-secondary);\x20margin-top:\x200.15rem;\x22>'+Utils['escapeHtml'](_0x2f3688['description'])+'</div>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+_0x4f2747+'</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'+(_0x6367a1?'<button\x20class=\x22btn-icon\x22\x20title=\x22Edit\x20team\x22\x20onclick=\x22window.openTeamModal(\x27'+_0x2f3688['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'+(_0x48e1c5?'<button\x20class=\x22btn-icon\x22\x20title=\x22Access\x20bindings\x22\x20onclick=\x22window.openBindingsModal(\x27'+_0x2f3688['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'+(_0x48e1c5?'<button\x20class=\x22btn-icon\x20btn-danger\x22\x20title=\x22Delete\x20team\x22\x20onclick=\x22window.deleteTeam(\x27'+_0x2f3688['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(_0xcc9ed0){const _0xaa21e6=state['teams']['find'](_0x1fc287=>_0x1fc287['id']===_0xcc9ed0);if(!_0xaa21e6)return;state['editingTeamId']=_0xcc9ed0;const _0x407575=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x292b53=_0x407575||_0xaa21e6['canManageTeam'],_0xd1105e=_0x407575||_0xaa21e6['canManageMembers'],_0x4b6efa=_0x292b53,_0x205630=_0x292b53||_0xd1105e,_0x3b469=_0xaa21e6['name'],_0x3155cb=_0xaa21e6['description']||'';state['modalSnapshot']={'name':_0x3b469,'description':_0x3155cb},document['getElementById']('team-modal-title')['textContent']=_0x3b469,document['getElementById']('team-name')['value']=_0x3b469,document['getElementById']('team-name')['disabled']=!_0x4b6efa,document['getElementById']('team-description')['value']=_0x3155cb,document['getElementById']('team-description')['disabled']=!_0x4b6efa,document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=![],document['getElementById']('save-team')['hidden']=!_0x4b6efa,renderMembersList(_0xaa21e6),updateMemberSelect(_0xaa21e6),document['getElementById']('team-modal')['hidden']=![];};function isTeamModalDirty(){if(!state['modalSnapshot'])return![];const _0x5ea51f=document['getElementById']('team-name')['value']['trim'](),_0xbe1773=document['getElementById']('team-description')['value']['trim']();return _0x5ea51f!==state['modalSnapshot']['name']||_0xbe1773!==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(_0x35997a){const _0xce3d34=state['teams']['find'](_0xccac66=>_0xccac66['id']===_0x35997a);if(!_0xce3d34)return;state['bindingsTeamId']=_0x35997a,document['getElementById']('bindings-modal-title')['textContent']='Access\x20Bindings\x20—\x20'+_0xce3d34['name'],document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('bindings-modal')['hidden']=![],loadTeamBindings(_0x35997a);};function hideBindingsModal(){document['getElementById']('bindings-modal')['hidden']=!![],state['bindingsTeamId']=null;}function renderMembersList(_0x264c51){const _0x5e2c2a=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x511968=_0x5e2c2a||_0x264c51['canManageMembers']||_0x264c51['canManageTeam'],_0xeb22c5=_0x264c51['members']||[],_0xee660d=document['getElementById']('members-list');if(_0xeb22c5['length']===0x0){_0xee660d['innerHTML']='<p\x20style=\x22font-size:\x200.875rem;\x20color:\x20var(--color-text-secondary);\x20margin:\x200.25rem\x200;\x22>No\x20members\x20yet</p>';return;}_0xee660d['innerHTML']=_0xeb22c5['map'](_0x49e5c2=>{const _0x208085=state['users']['find'](_0x111bf6=>_0x111bf6['id']===_0x49e5c2),_0x1cfc43=_0x208085?''+Utils['escapeHtml'](_0x208085['username'])+(_0x208085['name']?'\x20<span\x20style=\x22color:\x20var(--color-text-secondary);\x20font-size:\x200.85em;\x22>('+Utils['escapeHtml'](_0x208085['name'])+')</span>':''):Utils['escapeHtml'](_0x49e5c2);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'+_0x1cfc43+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x511968?'<button\x20type=\x22button\x22\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.removeMemberClick(\x27'+_0x49e5c2+'\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 _0x218796=document['getElementById']('add-member-row');if(_0x218796)_0x218796['style']['display']=_0x511968?'flex':'none';}function updateMemberSelect(_0x46186e){const _0x4ae407=document['getElementById']('add-member-select');if(!_0x4ae407)return;const _0x4de453=new Set(_0x46186e['members']||[]),_0x443e32=state['users']['filter'](_0xf5c748=>!_0x4de453['has'](_0xf5c748['id']));_0x4ae407['innerHTML']='<option\x20value=\x22\x22>Add\x20a\x20member…</option>'+_0x443e32['map'](_0x50fe93=>'<option\x20value=\x22'+_0x50fe93['id']+'\x22>'+Utils['escapeHtml'](_0x50fe93['username'])+(_0x50fe93['name']?'\x20('+Utils['escapeHtml'](_0x50fe93['name'])+')':'')+'</option>')['join']('');}async function addMember(){const _0x50fc09=document['getElementById']('add-member-select'),_0x34ae95=_0x50fc09['value'];if(!_0x34ae95||!state['editingTeamId'])return;try{const {team:_0x3c8397}=await API['addTeamMember'](state['editingTeamId'],_0x34ae95);syncTeamInState(_0x3c8397),renderMembersList(_0x3c8397),updateMemberSelect(_0x3c8397),_0x50fc09['value']='',Utils['showToast']('Member\x20added','success');}catch(_0x2291b9){Utils['showToast'](_0x2291b9['message'],'error');}}window['removeMemberClick']=async function(_0x53a72b){if(!state['editingTeamId'])return;try{const {team:_0x1bbd9b}=await API['removeTeamMember'](state['editingTeamId'],_0x53a72b);syncTeamInState(_0x1bbd9b),renderMembersList(_0x1bbd9b),updateMemberSelect(_0x1bbd9b),Utils['showToast']('Member\x20removed','success');}catch(_0x255ff6){Utils['showToast'](_0x255ff6['message'],'error');}};async function loadTeamBindings(_0x827e6){const _0x68fb5f=document['getElementById']('bindings-loading'),_0x40aa3a=document['getElementById']('bindings-empty'),_0x39c1f2=document['getElementById']('bindings-list-container'),_0x18a07f=document['getElementById']('add-binding-btn');_0x68fb5f['hidden']=![],_0x40aa3a['hidden']=!![],_0x39c1f2['style']['display']='none',_0x18a07f['hidden']=!![],document['getElementById']('add-binding-form')['hidden']=!![];try{const {bindings:_0x507592}=await API['getBindings']({'subject_type':'team','subject_id':_0x827e6});state['teamBindings']=_0x507592||[],_0x68fb5f['hidden']=!![],state['teamBindings']['length']===0x0?_0x40aa3a['hidden']=![]:(_0x39c1f2['style']['display']='',renderBindingsTable()),(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage'))&&(_0x18a07f['hidden']=![]);}catch(_0x417cca){_0x68fb5f['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x417cca['message'],'error');}}function renderBindingsTable(){const _0x42a6ae=document['getElementById']('bindings-table-body');if(!_0x42a6ae)return;const _0x326a80=Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage');_0x42a6ae['innerHTML']=state['teamBindings']['map'](_0x150579=>{const _0x2f2c1c=_0x150579['resource_type']==='server'?'Server':_0x150579['resource_id']==='*'?'All\x20'+_0x150579['resource_type']+'s':Utils['escapeHtml'](_0x150579['resource_name']||_0x150579['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x2f2c1c+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x150579['role_name']||_0x150579['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x326a80?'<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteBindingClick(\x27'+_0x150579['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 _0x449b7a=document['getElementById']('binding-resource-type');_0x449b7a['value']='environment',updateBindingFormForResourceType('environment');}function onBindingResourceTypeChange(){const _0x535178=document['getElementById']('binding-resource-type')['value'];updateBindingFormForResourceType(_0x535178);}function updateBindingFormForResourceType(_0x7b0ce9){const _0x26052e=document['getElementById']('binding-resource-container'),_0x5e635b=document['getElementById']('binding-resource'),_0x49f90a=document['getElementById']('binding-role');if(_0x7b0ce9==='server')_0x26052e['style']['display']='none';else{_0x26052e['style']['display']='';if(_0x7b0ce9==='environment'){const _0x3ff9f8=new Set(state['teamBindings']['filter'](_0x1b0d6c=>_0x1b0d6c['resource_type']==='environment')['map'](_0x421038=>_0x421038['resource_id'])),_0x1b8515=state['environments']['filter'](_0x39b175=>!_0x3ff9f8['has'](_0x39b175['name']));_0x5e635b['innerHTML']=_0x1b8515['length']?_0x1b8515['map'](_0xa013d6=>'<option\x20value=\x22'+Utils['escapeHtml'](_0xa013d6['name'])+'\x22>'+Utils['escapeHtml'](_0xa013d6['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x7b0ce9==='team'){const _0x3577d9=new Set(state['teamBindings']['filter'](_0x3e992d=>_0x3e992d['resource_type']==='team')['map'](_0x5c74a0=>_0x5c74a0['resource_id'])),_0x3db155=state['teams']['filter'](_0x14becf=>!_0x3577d9['has'](_0x14becf['id']));_0x5e635b['innerHTML']=_0x3db155['length']?_0x3db155['map'](_0x481251=>'<option\x20value=\x22'+_0x481251['id']+'\x22>'+Utils['escapeHtml'](_0x481251['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x1fa98b=state['roles']['filter'](_0x3b8a56=>_0x3b8a56['resource_type']===_0x7b0ce9);_0x49f90a['innerHTML']=_0x1fa98b['length']?_0x1fa98b['filter'](_0x4278b4=>{const _0x3c818e=_0x7b0ce9==='server'?undefined:_0x5e635b['value'];return!state['teamBindings']['some'](_0x308d3f=>_0x308d3f['resource_type']===_0x7b0ce9&&_0x308d3f['role_id']===_0x4278b4['id']&&(_0x7b0ce9==='server'||_0x308d3f['resource_id']===_0x3c818e));})['map'](_0x4267f5=>'<option\x20value=\x22'+_0x4267f5['id']+'\x22>'+Utils['escapeHtml'](_0x4267f5['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 _0x114ade=document['getElementById']('binding-resource-type')['value'],_0x4ae97d=document['getElementById']('binding-role')['value'];if(!_0x4ae97d||!state['bindingsTeamId'])return;const _0x4f9bf6=_0x114ade==='server'?undefined:document['getElementById']('binding-resource')['value'];if(_0x114ade!=='server'&&!_0x4f9bf6)return;const _0x50cad7=document['getElementById']('save-binding-btn');_0x50cad7['disabled']=!![],_0x50cad7['textContent']='Adding…';try{const _0xe1723d={'subject_type':'team','subject_id':state['bindingsTeamId'],'role_id':_0x4ae97d,'resource_type':_0x114ade};if(_0x4f9bf6)_0xe1723d['resource_id']=_0x4f9bf6;await API['createBinding'](_0xe1723d),Utils['showToast']('Binding\x20added','success'),document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![],await loadTeamBindings(state['bindingsTeamId']);}catch(_0x26049f){Utils['showToast'](_0x26049f['message'],'error');}finally{_0x50cad7['disabled']=![],_0x50cad7['textContent']='Add\x20Binding';}}window['deleteBindingClick']=async function(_0x8b639c){try{await API['deleteBinding'](_0x8b639c),Utils['showToast']('Binding\x20removed','success'),await loadTeamBindings(state['bindingsTeamId']);}catch(_0x198171){Utils['showToast'](_0x198171['message'],'error');}};async function saveTeam(){const _0x55fdd8=document['getElementById']('team-name')['value']['trim'](),_0x3bf73d=document['getElementById']('team-description')['value']['trim'](),_0x5a1cc5=document['getElementById']('team-form-error'),_0x21fa9f=document['getElementById']('save-team');if(!_0x55fdd8){_0x5a1cc5['textContent']='Team\x20name\x20is\x20required',_0x5a1cc5['hidden']=![];return;}_0x5a1cc5['hidden']=!![];const _0x19cb08=_0x21fa9f['textContent'];_0x21fa9f['disabled']=!![],_0x21fa9f['textContent']=state['editingTeamId']?'Saving…':'Creating…';try{if(state['editingTeamId']){const {team:_0x3c4779}=await API['updateTeam'](state['editingTeamId'],{'name':_0x55fdd8,'description':_0x3bf73d});syncTeamInState(_0x3c4779),document['getElementById']('team-modal-title')['textContent']=_0x3c4779['name'],Utils['showToast']('Team\x20updated','success');}else await API['createTeam']({'name':_0x55fdd8,'description':_0x3bf73d}),Utils['showToast']('Team\x20created','success');_0x21fa9f['disabled']=![],_0x21fa9f['textContent']=_0x19cb08,hideTeamModal(),await loadTeams();}catch(_0x3dfc7a){_0x5a1cc5['textContent']=_0x3dfc7a['message'],_0x5a1cc5['hidden']=![],_0x21fa9f['disabled']=![],_0x21fa9f['textContent']=_0x19cb08;}}window['deleteTeam']=function(_0x5670f9){const _0x59da80=state['teams']['find'](_0x2c56af=>_0x2c56af['id']===_0x5670f9);if(!_0x59da80)return;state['deletingTeamId']=_0x5670f9,document['getElementById']('delete-team-name')['textContent']=_0x59da80['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 _0x28c434=document['getElementById']('confirm-delete-team');_0x28c434['disabled']=!![],_0x28c434['textContent']='Deleting…';try{await API['deleteTeam'](state['deletingTeamId']),Utils['showToast']('Team\x20deleted','success'),_0x28c434['disabled']=![],_0x28c434['textContent']='Delete\x20Team',hideDeleteModal(),await loadTeams();}catch(_0x3c7703){Utils['showToast']('Failed\x20to\x20delete\x20team:\x20'+_0x3c7703['message'],'error'),_0x28c434['disabled']=![],_0x28c434['textContent']='Delete\x20Team';}}function syncTeamInState(_0x213533){const _0x5e40ee=state['teams']['findIndex'](_0x201219=>_0x201219['id']===_0x213533['id']);if(_0x5e40ee>=0x0)state['teams'][_0x5e40ee]=_0x213533;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 _0x487b26=state['currentUser'];if(!Permissions['hasServerPermission'](_0x487b26,'teams:view')&&!Permissions['hasTeamPermission'](_0x487b26,'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'](_0x487b26,'*')||Permissions['hasTeamPermission'](_0x487b26,'teams:manage'))&&(document['getElementById']('create-team-btn')['hidden']=![]),bindEventListeners(),await Promise['all']([loadTeams(),loadUsers(),loadRoles(),loadEnvironments()]),renderTeams();});async function loadTeams(){const _0x8d07a1=document['getElementById']('teams-loading'),_0x4f8386=document['getElementById']('teams-error'),_0x5094eb=document['getElementById']('teams-content');try{_0x8d07a1['hidden']=![],_0x4f8386['hidden']=!![],_0x5094eb['hidden']=!![];const {teams:_0x49402d}=await API['getTeams']();state['teams']=_0x49402d||[],renderTeams(),_0x8d07a1['hidden']=!![],_0x5094eb['hidden']=![];}catch(_0x5e4140){_0x8d07a1['hidden']=!![],_0x4f8386['hidden']=![],document['getElementById']('teams-error-message')['textContent']=_0x5e4140['message'];}}async function loadUsers(){try{const {users:_0x31e1cd}=await API['getUsers']();state['users']=_0x31e1cd||[];}catch{state['users']=[];}}async function loadRoles(){try{const {roles:_0x712033}=await API['getRoleDefinitions']();state['roles']=_0x712033||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x1f5d94=await API['getEnvironments']();state['environments']=_0x1f5d94['environments']||[];}catch{state['environments']=[];}}function renderTeams(){const _0x319bc7=document['getElementById']('teams-table-body'),_0x388876=document['getElementById']('team-count');if(!_0x319bc7)return;_0x388876&&(_0x388876['textContent']=state['teams']['length']+'\x20team'+(state['teams']['length']===0x1?'':'s'));if(state['teams']['length']===0x0){_0x319bc7['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 _0x4d9e20=Permissions['hasServerPermission'](state['currentUser'],'*');_0x319bc7['innerHTML']=state['teams']['map'](_0x5e11bf=>{const _0xc206f0=_0x4d9e20||_0x5e11bf['canManageTeam'],_0x145fa8=_0x4d9e20||_0x5e11bf['canManageMembers'],_0xcacd38=_0xc206f0||_0x145fa8,_0x9b28e1=(_0x5e11bf['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'](_0x5e11bf['name'])+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x5e11bf['description']?'<div\x20style=\x22font-size:\x200.8em;\x20color:\x20var(--color-text-secondary);\x20margin-top:\x200.15rem;\x22>'+Utils['escapeHtml'](_0x5e11bf['description'])+'</div>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+_0x9b28e1+'</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'+(_0xcacd38?'<button\x20class=\x22btn-icon\x22\x20title=\x22Edit\x20team\x22\x20onclick=\x22window.openTeamModal(\x27'+_0x5e11bf['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'+(_0xc206f0?'<button\x20class=\x22btn-icon\x22\x20title=\x22Access\x20bindings\x22\x20onclick=\x22window.openBindingsModal(\x27'+_0x5e11bf['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'+(_0xc206f0?'<button\x20class=\x22btn-icon\x20btn-danger\x22\x20title=\x22Delete\x20team\x22\x20onclick=\x22window.deleteTeam(\x27'+_0x5e11bf['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(_0x5ca393){const _0x5d9a3a=state['teams']['find'](_0xbb6eb1=>_0xbb6eb1['id']===_0x5ca393);if(!_0x5d9a3a)return;state['editingTeamId']=_0x5ca393;const _0x40b54e=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x1f2af3=_0x40b54e||_0x5d9a3a['canManageTeam'],_0x48f161=_0x40b54e||_0x5d9a3a['canManageMembers'],_0x3e3cd6=_0x1f2af3,_0x1936eb=_0x1f2af3||_0x48f161,_0x1e7824=_0x5d9a3a['name'],_0x45e18b=_0x5d9a3a['description']||'';state['modalSnapshot']={'name':_0x1e7824,'description':_0x45e18b},document['getElementById']('team-modal-title')['textContent']=_0x1e7824,document['getElementById']('team-name')['value']=_0x1e7824,document['getElementById']('team-name')['disabled']=!_0x3e3cd6,document['getElementById']('team-description')['value']=_0x45e18b,document['getElementById']('team-description')['disabled']=!_0x3e3cd6,document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=![],document['getElementById']('save-team')['hidden']=!_0x3e3cd6,renderMembersList(_0x5d9a3a),updateMemberSelect(_0x5d9a3a),document['getElementById']('team-modal')['hidden']=![];};function isTeamModalDirty(){if(!state['modalSnapshot'])return![];const _0x212029=document['getElementById']('team-name')['value']['trim'](),_0x299dfb=document['getElementById']('team-description')['value']['trim']();return _0x212029!==state['modalSnapshot']['name']||_0x299dfb!==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(_0x360986){const _0x38a955=state['teams']['find'](_0x4a1104=>_0x4a1104['id']===_0x360986);if(!_0x38a955)return;state['bindingsTeamId']=_0x360986,document['getElementById']('bindings-modal-title')['textContent']='Access\x20Bindings\x20—\x20'+_0x38a955['name'],document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('bindings-modal')['hidden']=![],loadTeamBindings(_0x360986);};function hideBindingsModal(){document['getElementById']('bindings-modal')['hidden']=!![],state['bindingsTeamId']=null;}function renderMembersList(_0x130fde){const _0x35bc24=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x5a28ba=_0x35bc24||_0x130fde['canManageMembers']||_0x130fde['canManageTeam'],_0xe37b7e=_0x130fde['members']||[],_0xf48091=document['getElementById']('members-list');if(_0xe37b7e['length']===0x0){_0xf48091['innerHTML']='<p\x20style=\x22font-size:\x200.875rem;\x20color:\x20var(--color-text-secondary);\x20margin:\x200.25rem\x200;\x22>No\x20members\x20yet</p>';return;}_0xf48091['innerHTML']=_0xe37b7e['map'](_0x307fcd=>{const _0x547f2c=state['users']['find'](_0x1db1aa=>_0x1db1aa['id']===_0x307fcd),_0x426f17=_0x547f2c?''+Utils['escapeHtml'](_0x547f2c['username'])+(_0x547f2c['name']?'\x20<span\x20style=\x22color:\x20var(--color-text-secondary);\x20font-size:\x200.85em;\x22>('+Utils['escapeHtml'](_0x547f2c['name'])+')</span>':''):Utils['escapeHtml'](_0x307fcd);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'+_0x426f17+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x5a28ba?'<button\x20type=\x22button\x22\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.removeMemberClick(\x27'+_0x307fcd+'\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 _0x50d6ba=document['getElementById']('add-member-row');if(_0x50d6ba)_0x50d6ba['style']['display']=_0x5a28ba?'flex':'none';}function updateMemberSelect(_0x5eebfb){const _0x533772=document['getElementById']('add-member-select');if(!_0x533772)return;const _0x1267cd=new Set(_0x5eebfb['members']||[]),_0xc02870=state['users']['filter'](_0x334319=>!_0x1267cd['has'](_0x334319['id']));_0x533772['innerHTML']='<option\x20value=\x22\x22>Add\x20a\x20member…</option>'+_0xc02870['map'](_0x3e83b8=>'<option\x20value=\x22'+_0x3e83b8['id']+'\x22>'+Utils['escapeHtml'](_0x3e83b8['username'])+(_0x3e83b8['name']?'\x20('+Utils['escapeHtml'](_0x3e83b8['name'])+')':'')+'</option>')['join']('');}async function addMember(){const _0x1e5c49=document['getElementById']('add-member-select'),_0x454185=_0x1e5c49['value'];if(!_0x454185||!state['editingTeamId'])return;try{const {team:_0x2d81fa}=await API['addTeamMember'](state['editingTeamId'],_0x454185);syncTeamInState(_0x2d81fa),renderMembersList(_0x2d81fa),updateMemberSelect(_0x2d81fa),_0x1e5c49['value']='',Utils['showToast']('Member\x20added','success');}catch(_0x556ff5){Utils['showToast'](_0x556ff5['message'],'error');}}window['removeMemberClick']=async function(_0x2edc2d){if(!state['editingTeamId'])return;try{const {team:_0x3225fd}=await API['removeTeamMember'](state['editingTeamId'],_0x2edc2d);syncTeamInState(_0x3225fd),renderMembersList(_0x3225fd),updateMemberSelect(_0x3225fd),Utils['showToast']('Member\x20removed','success');}catch(_0x5cdd84){Utils['showToast'](_0x5cdd84['message'],'error');}};async function loadTeamBindings(_0x3ef039){const _0x1f8911=document['getElementById']('bindings-loading'),_0x34e2c3=document['getElementById']('bindings-empty'),_0x50378f=document['getElementById']('bindings-list-container'),_0x41acbc=document['getElementById']('add-binding-btn');_0x1f8911['hidden']=![],_0x34e2c3['hidden']=!![],_0x50378f['style']['display']='none',_0x41acbc['hidden']=!![],document['getElementById']('add-binding-form')['hidden']=!![];try{const {bindings:_0x4cbc92}=await API['getBindings']({'subject_type':'team','subject_id':_0x3ef039});state['teamBindings']=_0x4cbc92||[],_0x1f8911['hidden']=!![],state['teamBindings']['length']===0x0?_0x34e2c3['hidden']=![]:(_0x50378f['style']['display']='',renderBindingsTable()),(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage'))&&(_0x41acbc['hidden']=![]);}catch(_0x1b1483){_0x1f8911['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x1b1483['message'],'error');}}function renderBindingsTable(){const _0x69cf67=document['getElementById']('bindings-table-body');if(!_0x69cf67)return;const _0x323d03=Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage');_0x69cf67['innerHTML']=state['teamBindings']['map'](_0x5f4cb9=>{const _0x1638ae=_0x5f4cb9['resource_type']==='server'?'Server':_0x5f4cb9['resource_id']==='*'?'All\x20'+_0x5f4cb9['resource_type']+'s':Utils['escapeHtml'](_0x5f4cb9['resource_name']||_0x5f4cb9['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x1638ae+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x5f4cb9['role_name']||_0x5f4cb9['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x323d03?'<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteBindingClick(\x27'+_0x5f4cb9['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 _0x28cb02=document['getElementById']('binding-resource-type');_0x28cb02['value']='environment',updateBindingFormForResourceType('environment');}function onBindingResourceTypeChange(){const _0x1e2a20=document['getElementById']('binding-resource-type')['value'];updateBindingFormForResourceType(_0x1e2a20);}function updateBindingFormForResourceType(_0x3a62c9){const _0x399a68=document['getElementById']('binding-resource-container'),_0x216a80=document['getElementById']('binding-resource'),_0x2c9d2f=document['getElementById']('binding-role');if(_0x3a62c9==='server')_0x399a68['style']['display']='none';else{_0x399a68['style']['display']='';if(_0x3a62c9==='environment'){const _0x192e80=new Set(state['teamBindings']['filter'](_0x5ccb42=>_0x5ccb42['resource_type']==='environment')['map'](_0x592091=>_0x592091['resource_id'])),_0x25355a=state['environments']['filter'](_0x25d992=>!_0x192e80['has'](_0x25d992['name']));_0x216a80['innerHTML']=_0x25355a['length']?_0x25355a['map'](_0x11ceae=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x11ceae['name'])+'\x22>'+Utils['escapeHtml'](_0x11ceae['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x3a62c9==='team'){const _0x40f8e1=new Set(state['teamBindings']['filter'](_0x1e7c6a=>_0x1e7c6a['resource_type']==='team')['map'](_0x5f29b3=>_0x5f29b3['resource_id'])),_0x4a485b=state['teams']['filter'](_0x3cb72f=>!_0x40f8e1['has'](_0x3cb72f['id']));_0x216a80['innerHTML']=_0x4a485b['length']?_0x4a485b['map'](_0x1213a1=>'<option\x20value=\x22'+_0x1213a1['id']+'\x22>'+Utils['escapeHtml'](_0x1213a1['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x25d982=state['roles']['filter'](_0x48b59c=>_0x48b59c['resource_type']===_0x3a62c9);_0x2c9d2f['innerHTML']=_0x25d982['length']?_0x25d982['filter'](_0x1c03bf=>{const _0x30a5e7=_0x3a62c9==='server'?undefined:_0x216a80['value'];return!state['teamBindings']['some'](_0xafafc9=>_0xafafc9['resource_type']===_0x3a62c9&&_0xafafc9['role_id']===_0x1c03bf['id']&&(_0x3a62c9==='server'||_0xafafc9['resource_id']===_0x30a5e7));})['map'](_0x464da0=>'<option\x20value=\x22'+_0x464da0['id']+'\x22>'+Utils['escapeHtml'](_0x464da0['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 _0x2f11a4=document['getElementById']('binding-resource-type')['value'],_0x504de1=document['getElementById']('binding-role')['value'];if(!_0x504de1||!state['bindingsTeamId'])return;const _0xf03a4=_0x2f11a4==='server'?undefined:document['getElementById']('binding-resource')['value'];if(_0x2f11a4!=='server'&&!_0xf03a4)return;const _0x2d0e11=document['getElementById']('save-binding-btn');_0x2d0e11['disabled']=!![],_0x2d0e11['textContent']='Adding…';try{const _0x1b1b80={'subject_type':'team','subject_id':state['bindingsTeamId'],'role_id':_0x504de1,'resource_type':_0x2f11a4};if(_0xf03a4)_0x1b1b80['resource_id']=_0xf03a4;await API['createBinding'](_0x1b1b80),Utils['showToast']('Binding\x20added','success'),document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![],await loadTeamBindings(state['bindingsTeamId']);}catch(_0x54cb53){Utils['showToast'](_0x54cb53['message'],'error');}finally{_0x2d0e11['disabled']=![],_0x2d0e11['textContent']='Add\x20Binding';}}window['deleteBindingClick']=async function(_0x20847d){try{await API['deleteBinding'](_0x20847d),Utils['showToast']('Binding\x20removed','success'),await loadTeamBindings(state['bindingsTeamId']);}catch(_0x204741){Utils['showToast'](_0x204741['message'],'error');}};async function saveTeam(){const _0x41c95f=document['getElementById']('team-name')['value']['trim'](),_0x52fafb=document['getElementById']('team-description')['value']['trim'](),_0x362aec=document['getElementById']('team-form-error'),_0x21c541=document['getElementById']('save-team');if(!_0x41c95f){_0x362aec['textContent']='Team\x20name\x20is\x20required',_0x362aec['hidden']=![];return;}_0x362aec['hidden']=!![];const _0x2da4cd=_0x21c541['textContent'];_0x21c541['disabled']=!![],_0x21c541['textContent']=state['editingTeamId']?'Saving…':'Creating…';try{if(state['editingTeamId']){const {team:_0x8e9e48}=await API['updateTeam'](state['editingTeamId'],{'name':_0x41c95f,'description':_0x52fafb});syncTeamInState(_0x8e9e48),document['getElementById']('team-modal-title')['textContent']=_0x8e9e48['name'],Utils['showToast']('Team\x20updated','success');}else await API['createTeam']({'name':_0x41c95f,'description':_0x52fafb}),Utils['showToast']('Team\x20created','success');_0x21c541['disabled']=![],_0x21c541['textContent']=_0x2da4cd,hideTeamModal(),await loadTeams();}catch(_0x1f6a3b){_0x362aec['textContent']=_0x1f6a3b['message'],_0x362aec['hidden']=![],_0x21c541['disabled']=![],_0x21c541['textContent']=_0x2da4cd;}}window['deleteTeam']=function(_0x2fe43b){const _0x47c41b=state['teams']['find'](_0x4c8030=>_0x4c8030['id']===_0x2fe43b);if(!_0x47c41b)return;state['deletingTeamId']=_0x2fe43b,document['getElementById']('delete-team-name')['textContent']=_0x47c41b['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 _0x2f5635=document['getElementById']('confirm-delete-team');_0x2f5635['disabled']=!![],_0x2f5635['textContent']='Deleting…';try{await API['deleteTeam'](state['deletingTeamId']),Utils['showToast']('Team\x20deleted','success'),_0x2f5635['disabled']=![],_0x2f5635['textContent']='Delete\x20Team',hideDeleteModal(),await loadTeams();}catch(_0x281606){Utils['showToast']('Failed\x20to\x20delete\x20team:\x20'+_0x281606['message'],'error'),_0x2f5635['disabled']=![],_0x2f5635['textContent']='Delete\x20Team';}}function syncTeamInState(_0x43df06){const _0x5610ec=state['teams']['findIndex'](_0x1f1ea0=>_0x1f1ea0['id']===_0x43df06['id']);if(_0x5610ec>=0x0)state['teams'][_0x5610ec]=_0x43df06;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'](_0x12b98f=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':_0x12b98f}));});let commandSent=![],hasReceivedOutput=![];socket['addEventListener']('message',_0x436656=>{try{const _0x369f77=JSON['parse'](_0x436656['data']);if(_0x369f77['type']==='data'&&typeof _0x369f77['data']==='string')term['write'](_0x369f77['data']),!hasReceivedOutput&&_0x369f77['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(_0x369f77['type']==='status'&&_0x369f77['status']){if(_0x369f77['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'+_0x369f77['status'],_0x369f77['status']==='connected'?'success':'info');}else _0x369f77['type']==='error'&&_0x369f77['message']&&updateStatus(_0x369f77['message'],'error');}}catch(_0x5321f4){console['error']('Failed\x20to\x20parse\x20terminal\x20message',_0x5321f4);}}),socket['addEventListener']('close',_0x4ed60c=>{const _0x46c084=_0x4ed60c['reason']||'Connection\x20closed';updateStatus(_0x46c084,_0x4ed60c['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',_0x5cff03=>{console['error']('Terminal\x20websocket\x20error',_0x5cff03),updateStatus('Connection\x20error','error');});function sendResize(){if(socket['readyState']!==WebSocket['OPEN'])return;const _0x1df6be=term['cols'],_0x48b031=term['rows'];socket['send'](JSON['stringify']({'type':'resize','cols':_0x1df6be,'rows':_0x48b031}));}function updateStatus(_0x3508cb,_0x2fa6d4='info'){if(!statusEl)return;statusEl['textContent']=_0x3508cb,statusEl['dataset']['variant']=_0x2fa6d4;}async function enrichContainerDetails(_0x9f0b9d){try{const _0x4d770f=await API['getContainer'](_0x9f0b9d);updateTerminalDetails(_0x4d770f);}catch{try{const _0xbeeba4=await API['getContainers'](),_0x2b272b=(_0xbeeba4['containers']||[])['find'](_0x38a1e9=>_0x38a1e9['containerId']===_0x9f0b9d||_0x38a1e9['name']===_0x9f0b9d||_0x38a1e9['fullContainerId']?.['startsWith'](_0x9f0b9d));if(_0x2b272b){updateTerminalDetails(_0x2b272b);return;}subtitleEl['textContent']='Container\x20'+_0x9f0b9d['substring'](0x0,0xc);}catch{subtitleEl['textContent']='Container\x20'+_0x9f0b9d['substring'](0x0,0xc);}}}function updateTerminalDetails(_0x39cf35){const _0x3a7dde=_0x39cf35['containerId']||_0x39cf35['name']||_0x39cf35['fullContainerId']||containerId,_0x25e97c=_0x39cf35['environment']?'Environment\x20'+_0x39cf35['environment']:'Environment\x20unknown',_0x3dbb82=_0x39cf35['defaultAgent']?'\x20·\x20Agent\x20'+_0x39cf35['defaultAgent']:'',_0x4f7f5b=_0x39cf35['createdAt']?'\x20·\x20Started\x20'+Utils['formatRelativeTime'](_0x39cf35['createdAt']):'';titleEl['textContent']='Terminal\x20·\x20'+_0x3a7dde['substring'](0x0,0xc);const _0x45a5e2=command?'\x20·\x20Command\x20'+command:'';subtitleEl['textContent']=''+_0x25e97c+_0x3dbb82+_0x4f7f5b+_0x45a5e2;}
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'](_0x2df4c9=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':_0x2df4c9}));});let commandSent=![],hasReceivedOutput=![];socket['addEventListener']('message',_0x399aeb=>{try{const _0xf2b85f=JSON['parse'](_0x399aeb['data']);if(_0xf2b85f['type']==='data'&&typeof _0xf2b85f['data']==='string')term['write'](_0xf2b85f['data']),!hasReceivedOutput&&_0xf2b85f['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(_0xf2b85f['type']==='status'&&_0xf2b85f['status']){if(_0xf2b85f['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'+_0xf2b85f['status'],_0xf2b85f['status']==='connected'?'success':'info');}else _0xf2b85f['type']==='error'&&_0xf2b85f['message']&&updateStatus(_0xf2b85f['message'],'error');}}catch(_0x22b4a5){console['error']('Failed\x20to\x20parse\x20terminal\x20message',_0x22b4a5);}}),socket['addEventListener']('close',_0x37e901=>{const _0x19db46=_0x37e901['reason']||'Connection\x20closed';updateStatus(_0x19db46,_0x37e901['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',_0x288468=>{console['error']('Terminal\x20websocket\x20error',_0x288468),updateStatus('Connection\x20error','error');});function sendResize(){if(socket['readyState']!==WebSocket['OPEN'])return;const _0x4221cc=term['cols'],_0x6e20eb=term['rows'];socket['send'](JSON['stringify']({'type':'resize','cols':_0x4221cc,'rows':_0x6e20eb}));}function updateStatus(_0x16ecb8,_0x1d39d3='info'){if(!statusEl)return;statusEl['textContent']=_0x16ecb8,statusEl['dataset']['variant']=_0x1d39d3;}async function enrichContainerDetails(_0x1575bf){try{const _0x4bec63=await API['getContainer'](_0x1575bf);updateTerminalDetails(_0x4bec63);}catch{try{const _0x3eda8c=await API['getContainers'](),_0x57ede7=(_0x3eda8c['containers']||[])['find'](_0x38cdd7=>_0x38cdd7['containerId']===_0x1575bf||_0x38cdd7['name']===_0x1575bf||_0x38cdd7['fullContainerId']?.['startsWith'](_0x1575bf));if(_0x57ede7){updateTerminalDetails(_0x57ede7);return;}subtitleEl['textContent']='Container\x20'+_0x1575bf['substring'](0x0,0xc);}catch{subtitleEl['textContent']='Container\x20'+_0x1575bf['substring'](0x0,0xc);}}}function updateTerminalDetails(_0x3de113){const _0x341c6e=_0x3de113['containerId']||_0x3de113['name']||_0x3de113['fullContainerId']||containerId,_0x1563c9=_0x3de113['environment']?'Environment\x20'+_0x3de113['environment']:'Environment\x20unknown',_0x29eaf5=_0x3de113['defaultAgent']?'\x20·\x20Agent\x20'+_0x3de113['defaultAgent']:'',_0x5039a2=_0x3de113['createdAt']?'\x20·\x20Started\x20'+Utils['formatRelativeTime'](_0x3de113['createdAt']):'';titleEl['textContent']='Terminal\x20·\x20'+_0x341c6e['substring'](0x0,0xc);const _0x40adf4=command?'\x20·\x20Command\x20'+command:'';subtitleEl['textContent']=''+_0x1563c9+_0x29eaf5+_0x5039a2+_0x40adf4;}
@@ -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 _0x5aa487=localStorage['getItem'](THEME_STORAGE_KEY);if(_0x5aa487&&VALID_THEMES['has'](_0x5aa487))return _0x5aa487;}catch(_0x17a96c){console['warn']('[Theme]\x20Failed\x20to\x20read\x20stored\x20theme\x20preference:',_0x17a96c);}return null;}export function getPreferredTheme(){const _0x5ebd91=readStoredTheme();if(_0x5ebd91)return _0x5ebd91;const _0x3c1779=window['matchMedia']&&window['matchMedia']('(prefers-color-scheme:\x20dark)')['matches'];return _0x3c1779?'dark':'light';}export function getCurrentTheme(){const _0x52999f=document['documentElement']['dataset']['theme'];if(_0x52999f&&VALID_THEMES['has'](_0x52999f))return _0x52999f;return getPreferredTheme();}export function applyTheme(_0x16cc70,{persist:persist=!![],emitEvent:emitEvent=!![]}={}){const _0x20b0a3=VALID_THEMES['has'](_0x16cc70)?_0x16cc70:'light';document['documentElement']['dataset']['theme']=_0x20b0a3,document['documentElement']['style']['colorScheme']=_0x20b0a3==='dark'?'dark':'light';if(persist)try{localStorage['setItem'](THEME_STORAGE_KEY,_0x20b0a3);}catch(_0x48cc4b){console['warn']('[Theme]\x20Failed\x20to\x20persist\x20theme\x20preference:',_0x48cc4b);}return emitEvent&&window['dispatchEvent'](new CustomEvent(THEME_CHANGE_EVENT,{'detail':{'theme':_0x20b0a3}})),_0x20b0a3;}export function initTheme(_0x41b201={}){const {emitEvent:emitEvent=![]}=_0x41b201;return applyTheme(getPreferredTheme(),{'persist':![],'emitEvent':emitEvent});}export function toggleTheme(){const _0x34f7d1=getCurrentTheme()==='dark'?'light':'dark';return applyTheme(_0x34f7d1);}export function onThemeChange(_0x4271ae,{runImmediately:runImmediately=![]}={}){const _0x2462ab=_0x2c65c3=>{_0x4271ae(_0x2c65c3['detail']['theme']);};return window['addEventListener'](THEME_CHANGE_EVENT,_0x2462ab),runImmediately&&_0x4271ae(getCurrentTheme()),()=>window['removeEventListener'](THEME_CHANGE_EVENT,_0x2462ab);}export function mountThemeToggle(_0x277a70={}){const {targetSelectors:targetSelectors=DEFAULT_TARGET_SELECTORS}=_0x277a70,_0x5bdd39=targetSelectors['map'](_0x3e5b22=>document['querySelector'](_0x3e5b22))['find'](Boolean),_0x2e52a7=document['createElement']('button');_0x2e52a7['type']='button',_0x2e52a7['className']='btn-ghost\x20theme-toggle-btn',_0x2e52a7['id']='theme-toggle-btn',_0x2e52a7['setAttribute']('aria-pressed','false'),_0x2e52a7['style']['padding']='8px',_0x2e52a7['style']['lineHeight']='0',_0x2e52a7['style']['width']='36px',_0x2e52a7['style']['height']='36px',_0x2e52a7['style']['display']='flex',_0x2e52a7['style']['alignItems']='center',_0x2e52a7['style']['justifyContent']='center';const _0x2ea3cb=document['createElement']('span');_0x2ea3cb['className']='theme-icon',_0x2ea3cb['style']['display']='flex',_0x2e52a7['append'](_0x2ea3cb);const _0x13b3e8='<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>',_0x1dcbc1='<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>',_0x4af3d9=_0x5b1231=>{const _0x3f6dfd=_0x5b1231==='dark';_0x2ea3cb['innerHTML']=_0x3f6dfd?_0x13b3e8:_0x1dcbc1,_0x2e52a7['title']=_0x3f6dfd?'Switch\x20to\x20light\x20mode':'Switch\x20to\x20dark\x20mode',_0x2e52a7['dataset']['theme']=_0x5b1231,_0x2e52a7['setAttribute']('aria-pressed',String(_0x3f6dfd));};return _0x2e52a7['addEventListener']('click',()=>{const _0x1b150e=getCurrentTheme()==='dark'?'light':'dark';applyTheme(_0x1b150e);}),_0x5bdd39?_0x5bdd39['appendChild'](_0x2e52a7):(_0x2e52a7['classList']['add']('theme-toggle-floating'),document['body']['appendChild'](_0x2e52a7)),_0x4af3d9(initTheme()),onThemeChange(_0x4af3d9),_0x2e52a7;}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 _0x4ed6b1=localStorage['getItem'](THEME_STORAGE_KEY);if(_0x4ed6b1&&VALID_THEMES['has'](_0x4ed6b1))return _0x4ed6b1;}catch(_0x5e233a){console['warn']('[Theme]\x20Failed\x20to\x20read\x20stored\x20theme\x20preference:',_0x5e233a);}return null;}export function getPreferredTheme(){const _0x2c4bc3=readStoredTheme();if(_0x2c4bc3)return _0x2c4bc3;const _0x90241=window['matchMedia']&&window['matchMedia']('(prefers-color-scheme:\x20dark)')['matches'];return _0x90241?'dark':'light';}export function getCurrentTheme(){const _0x4edb43=document['documentElement']['dataset']['theme'];if(_0x4edb43&&VALID_THEMES['has'](_0x4edb43))return _0x4edb43;return getPreferredTheme();}export function applyTheme(_0x212149,{persist:persist=!![],emitEvent:emitEvent=!![]}={}){const _0x583f79=VALID_THEMES['has'](_0x212149)?_0x212149:'light';document['documentElement']['dataset']['theme']=_0x583f79,document['documentElement']['style']['colorScheme']=_0x583f79==='dark'?'dark':'light';if(persist)try{localStorage['setItem'](THEME_STORAGE_KEY,_0x583f79);}catch(_0x27ef28){console['warn']('[Theme]\x20Failed\x20to\x20persist\x20theme\x20preference:',_0x27ef28);}return emitEvent&&window['dispatchEvent'](new CustomEvent(THEME_CHANGE_EVENT,{'detail':{'theme':_0x583f79}})),_0x583f79;}export function initTheme(_0x86ea1d={}){const {emitEvent:emitEvent=![]}=_0x86ea1d;return applyTheme(getPreferredTheme(),{'persist':![],'emitEvent':emitEvent});}export function toggleTheme(){const _0x59dfce=getCurrentTheme()==='dark'?'light':'dark';return applyTheme(_0x59dfce);}export function onThemeChange(_0x3408f3,{runImmediately:runImmediately=![]}={}){const _0x365d0c=_0x30b216=>{_0x3408f3(_0x30b216['detail']['theme']);};return window['addEventListener'](THEME_CHANGE_EVENT,_0x365d0c),runImmediately&&_0x3408f3(getCurrentTheme()),()=>window['removeEventListener'](THEME_CHANGE_EVENT,_0x365d0c);}export function mountThemeToggle(_0x4513fb={}){const {targetSelectors:targetSelectors=DEFAULT_TARGET_SELECTORS}=_0x4513fb,_0xb1b56e=targetSelectors['map'](_0x492994=>document['querySelector'](_0x492994))['find'](Boolean),_0x783bbf=document['createElement']('button');_0x783bbf['type']='button',_0x783bbf['className']='btn-ghost\x20theme-toggle-btn',_0x783bbf['id']='theme-toggle-btn',_0x783bbf['setAttribute']('aria-pressed','false'),_0x783bbf['style']['padding']='8px',_0x783bbf['style']['lineHeight']='0',_0x783bbf['style']['width']='36px',_0x783bbf['style']['height']='36px',_0x783bbf['style']['display']='flex',_0x783bbf['style']['alignItems']='center',_0x783bbf['style']['justifyContent']='center';const _0x366ae4=document['createElement']('span');_0x366ae4['className']='theme-icon',_0x366ae4['style']['display']='flex',_0x783bbf['append'](_0x366ae4);const _0x196729='<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>',_0x813fb0='<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>',_0x1542b9=_0x48e642=>{const _0x2a0ff4=_0x48e642==='dark';_0x366ae4['innerHTML']=_0x2a0ff4?_0x196729:_0x813fb0,_0x783bbf['title']=_0x2a0ff4?'Switch\x20to\x20light\x20mode':'Switch\x20to\x20dark\x20mode',_0x783bbf['dataset']['theme']=_0x48e642,_0x783bbf['setAttribute']('aria-pressed',String(_0x2a0ff4));};return _0x783bbf['addEventListener']('click',()=>{const _0x397c35=getCurrentTheme()==='dark'?'light':'dark';applyTheme(_0x397c35);}),_0xb1b56e?_0xb1b56e['appendChild'](_0x783bbf):(_0x783bbf['classList']['add']('theme-toggle-floating'),document['body']['appendChild'](_0x783bbf)),_0x1542b9(initTheme()),onThemeChange(_0x1542b9),_0x783bbf;}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 _0x39c8eb=await API['getCurrentUser']();state['currentUser']=_0x39c8eb;if(!Permissions['hasServerPermission'](_0x39c8eb,'*')&&!Permissions['hasServerPermission'](_0x39c8eb,'users:create')){Utils['showToast']('Access\x20denied:\x20Server\x20admin\x20privileges\x20required','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}}catch(_0x4dab14){window['location']['href']='login.html';}}async function checkEmailConfig(){try{const _0x9e6cef=await API['getEmailConfig']();state['emailConfigured']=_0x9e6cef['configured'];}catch(_0x3553e0){console['error']('Failed\x20to\x20check\x20email\x20config',_0x3553e0),state['emailConfigured']=![];}}async function loadRoles(){try{const {roles:_0x137489}=await API['getRoleDefinitions']();state['roles']=_0x137489||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x34edb7=await API['getEnvironments']();state['environments']=_0x34edb7['environments']||[];}catch{state['environments']=[];}}async function loadTeams(){try{const {teams:_0x3d7149}=await API['getTeams']();state['teams']=_0x3d7149||[];}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 _0xda59d8=document['getElementById']('users-loading'),_0xe03650=document['getElementById']('users-error'),_0x5b655d=document['getElementById']('users-content');try{_0xda59d8['hidden']=![],_0xe03650['hidden']=!![],_0x5b655d['hidden']=!![];const _0x3946b7=await API['getUsers']();state['users']=_0x3946b7['users']||[],renderUsers(),_0xda59d8['hidden']=!![],_0x5b655d['hidden']=![];}catch(_0x550132){console['error']('Failed\x20to\x20load\x20users',_0x550132),_0xda59d8['hidden']=!![],_0xe03650['hidden']=![],document['getElementById']('users-error-message')['textContent']=_0x550132['message'];}}function renderUsers(){const _0x371ee5=document['getElementById']('users-table-body'),_0x1c6b13=document['getElementById']('user-count');if(!_0x371ee5)return;_0x1c6b13&&(_0x1c6b13['textContent']=state['users']['length']+'\x20user'+(state['users']['length']===0x1?'':'s'));const _0x2d4577=[...state['users']]['sort']((_0x33d2c4,_0x29a4fd)=>{const _0x113ed0=new Date(_0x33d2c4['created_at'])['getTime'](),_0x34b357=new Date(_0x29a4fd['created_at'])['getTime']();return _0x34b357-_0x113ed0;});_0x371ee5['innerHTML']=_0x2d4577['map'](_0x187a6f=>'\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'](_0x187a6f['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'](_0x187a6f['name'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x187a6f['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'+(_0x187a6f['isServerAdmin']?'<span\x20class=\x22role-badge\x20role-admin\x22>Server\x20Admin</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x187a6f['hasUserBinding']?'<span\x20class=\x22role-badge\x20role-user-binding\x22>User\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x187a6f['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'](_0x187a6f['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'+_0x187a6f['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'+_0x187a6f['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'+_0x187a6f['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'+_0x187a6f['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(_0x5d1bd5){const _0x403836=state['users']['find'](_0x24f55b=>_0x24f55b['id']===_0x5d1bd5);if(!_0x403836)return;state['bindingsUserId']=_0x5d1bd5,state['bindingsDirty']=![];const _0x163f04=document['getElementById']('bindings-modal'),_0x175435=document['getElementById']('bindings-modal-title');_0x175435['textContent']='Access\x20Bindings\x20—\x20'+_0x403836['name'],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],_0x163f04['hidden']=![],loadUserBindings(_0x5d1bd5);};function hasUnsavedBindingChanges(){const _0x4abaf5=document['getElementById']('add-user-binding-form');return _0x4abaf5&&!_0x4abaf5['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 _0x222d78=document['getElementById']('bindings-modal');_0x222d78['hidden']=!![];const _0x1483a9=state['bindingsDirty'];state['bindingsUserId']=null,state['userBindings']=[],state['bindingsDirty']=![],_0x1483a9&&await loadUsers();}async function loadUserBindings(_0x2c6c5f){const _0x3c2607=document['getElementById']('user-bindings-loading'),_0x20daa4=document['getElementById']('user-bindings-empty'),_0x5b745f=document['getElementById']('user-bindings-list-container'),_0xd19a00=document['getElementById']('add-user-binding-btn'),_0x1b608e=document['getElementById']('user-team-bindings-note'),_0x1ccfdd=document['getElementById']('user-team-bindings-text');_0x3c2607['hidden']=![],_0x20daa4['hidden']=!![],_0x5b745f['style']['display']='none',_0xd19a00['hidden']=!![],_0x1b608e['hidden']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![];try{const [_0x5a8432,_0xdc0886]=await Promise['all']([API['getBindings']({'subject_type':'user','subject_id':_0x2c6c5f}),API['getTeams']()]);state['userBindings']=_0x5a8432['bindings']||[];const _0x3df93a=(_0xdc0886['teams']||[])['filter'](_0x5e5481=>(_0x5e5481['members']||[])['includes'](_0x2c6c5f)),_0x21e45a=[];if(_0x3df93a['length']>0x0){const _0x417aeb=await Promise['all'](_0x3df93a['map'](_0x588403=>API['getBindings']({'subject_type':'team','subject_id':_0x588403['id']})));for(let _0xfd8811=0x0;_0xfd8811<_0x3df93a['length'];_0xfd8811++){const _0x535aa7=_0x417aeb[_0xfd8811]['bindings']||[];_0x535aa7['length']>0x0&&_0x21e45a['push'](_0x3df93a[_0xfd8811]);}}_0x3c2607['hidden']=!![];state['userBindings']['length']===0x0?_0x20daa4['hidden']=![]:(_0x5b745f['style']['display']='',renderUserBindingsTable());if(_0x21e45a['length']>0x0){const _0x86e5d7=_0x21e45a['map'](_0xa4eb09=>_0xa4eb09['name']),_0x5f41f2=_0x86e5d7['length']<=0x3?_0x86e5d7['join'](',\x20'):_0x86e5d7['slice'](0x0,0x3)['join'](',\x20')+(',\x20and\x20'+(_0x86e5d7['length']-0x3)+'\x20more');_0x1ccfdd['textContent']='This\x20user\x20also\x20has\x20access\x20via\x20team\x20memberships\x20('+_0x5f41f2+').';}else _0x1ccfdd['textContent']='This\x20user\x20has\x20no\x20access\x20via\x20team\x20memberships.';_0x1b608e['hidden']=![],_0xd19a00['hidden']=![];}catch(_0x23ef04){_0x3c2607['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x23ef04['message'],'error');}}function renderUserBindingsTable(){const _0x300e7c=document['getElementById']('user-bindings-table-body');if(!_0x300e7c)return;_0x300e7c['innerHTML']=state['userBindings']['map'](_0x59f66e=>{const _0x3d3fbe=_0x59f66e['resource_type']==='server'?'Server':_0x59f66e['resource_id']==='*'?'All\x20'+_0x59f66e['resource_type']+'s':Utils['escapeHtml'](_0x59f66e['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x3d3fbe+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x59f66e['role_name']||_0x59f66e['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'+_0x59f66e['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 _0x462ccc=document['getElementById']('user-binding-resource-type');_0x462ccc['value']='environment',updateUserBindingFormForResourceType('environment');}function onUserBindingResourceTypeChange(){const _0x53ea7a=document['getElementById']('user-binding-resource-type')['value'];updateUserBindingFormForResourceType(_0x53ea7a);}function updateUserBindingFormForResourceType(_0x3c625d){const _0x5c9743=document['getElementById']('user-binding-resource-container'),_0x4d6772=document['getElementById']('user-binding-resource'),_0x12cb93=document['getElementById']('user-binding-role');if(_0x3c625d==='server')_0x5c9743['style']['display']='none';else{_0x5c9743['style']['display']='';if(_0x3c625d==='environment'){const _0x3c1544=new Set(state['userBindings']['filter'](_0x3c3ef6=>_0x3c3ef6['resource_type']==='environment')['map'](_0x3d8d45=>_0x3d8d45['resource_id'])),_0x506fb1=state['environments']['filter'](_0x454523=>!_0x3c1544['has'](_0x454523['name']));_0x4d6772['innerHTML']=_0x506fb1['length']?_0x506fb1['map'](_0x56374a=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x56374a['name'])+'\x22>'+Utils['escapeHtml'](_0x56374a['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x3c625d==='team'){const _0x28a54a=new Set(state['userBindings']['filter'](_0x2dea29=>_0x2dea29['resource_type']==='team')['map'](_0x149ae7=>_0x149ae7['resource_id'])),_0x231121=state['teams']['filter'](_0x1f85ee=>!_0x28a54a['has'](_0x1f85ee['id']));_0x4d6772['innerHTML']=_0x231121['length']?_0x231121['map'](_0xdab3d5=>'<option\x20value=\x22'+_0xdab3d5['id']+'\x22>'+Utils['escapeHtml'](_0xdab3d5['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x14c066=state['roles']['filter'](_0x1ccaa5=>_0x1ccaa5['resource_type']===_0x3c625d);_0x12cb93['innerHTML']=_0x14c066['length']?_0x14c066['filter'](_0x41d6cd=>{const _0xfd40b=_0x3c625d==='server'?undefined:_0x4d6772['value'];return!state['userBindings']['some'](_0x8ec949=>_0x8ec949['resource_type']===_0x3c625d&&_0x8ec949['role_id']===_0x41d6cd['id']&&(_0x3c625d==='server'||_0x8ec949['resource_id']===_0xfd40b));})['map'](_0x5b3ba4=>'<option\x20value=\x22'+_0x5b3ba4['id']+'\x22>'+Utils['escapeHtml'](_0x5b3ba4['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 _0x72a00d=document['getElementById']('user-binding-resource-type')['value'],_0x397f2c=document['getElementById']('user-binding-role')['value'];if(!_0x397f2c||!state['bindingsUserId'])return;const _0x49f480=_0x72a00d==='server'?undefined:document['getElementById']('user-binding-resource')['value'];if(_0x72a00d!=='server'&&!_0x49f480)return;const _0x4333f9=document['getElementById']('save-user-binding-btn');_0x4333f9['disabled']=!![],_0x4333f9['textContent']='Adding…';try{const _0x2e41f9={'subject_type':'user','subject_id':state['bindingsUserId'],'role_id':_0x397f2c,'resource_type':_0x72a00d};if(_0x49f480)_0x2e41f9['resource_id']=_0x49f480;await API['createBinding'](_0x2e41f9),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(_0x4bac8e){Utils['showToast'](_0x4bac8e['message'],'error');}finally{_0x4333f9['disabled']=![],_0x4333f9['textContent']='Add\x20Binding';}}window['deleteUserBindingClick']=async function(_0x4c2411){try{await API['deleteBinding'](_0x4c2411),Utils['showToast']('Binding\x20removed','success'),state['bindingsDirty']=!![],await loadUserBindings(state['bindingsUserId']);}catch(_0x102a24){Utils['showToast'](_0x102a24['message'],'error');}};function showCreateUserModal(){state['editingUserId']=null;const _0x5b5359=document['getElementById']('user-modal'),_0x33ccb5=document['getElementById']('modal-title'),_0x2d03c2=document['getElementById']('user-password'),_0x3b5c7b=document['getElementById']('password-required'),_0x54d724=document['getElementById']('password-hint'),_0x53f245=document['getElementById']('skip-password-container'),_0x3f6d66=document['getElementById']('skip-password');_0x33ccb5['textContent']='Create\x20User',document['getElementById']('user-form')['reset'](),_0x2d03c2['required']=!![];if(_0x3b5c7b)_0x3b5c7b['textContent']='*';_0x53f245&&(_0x53f245['style']['display']='block',_0x3f6d66['checked']=![]),_0x54d724&&(_0x54d724['textContent']='Minimum\x208\x20characters'),_0x5b5359['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);}window['editUser']=function(_0x51a7aa){const _0x23f392=state['users']['find'](_0x33f600=>_0x33f600['id']===_0x51a7aa);if(!_0x23f392)return;state['editingUserId']=_0x51a7aa;const _0x1e6bb9=document['getElementById']('user-modal'),_0x4a5113=document['getElementById']('modal-title'),_0x36dae7=document['getElementById']('user-password'),_0x4e4e7f=document['getElementById']('password-required'),_0xa55f96=document['getElementById']('password-hint'),_0xb019c3=document['getElementById']('skip-password-container');_0x4a5113['textContent']='Edit\x20User',document['getElementById']('user-username')['value']=_0x23f392['username'],document['getElementById']('user-name')['value']=_0x23f392['name'],document['getElementById']('user-email')['value']=_0x23f392['email'],_0x36dae7['value']='',_0x36dae7['required']=![];if(_0x4e4e7f)_0x4e4e7f['textContent']='';_0xb019c3&&(_0xb019c3['style']['display']='none'),_0xa55f96&&(_0xa55f96['textContent']='Leave\x20blank\x20to\x20keep\x20current\x20password'),_0x1e6bb9['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);};function hideUserModal(){const _0x1b6e96=document['getElementById']('user-modal'),_0x6d1d02=document['getElementById']('form-error'),_0x1583a6=document['getElementById']('save-user');_0x1b6e96['hidden']=!![],_0x6d1d02['hidden']=!![],state['editingUserId']=null,_0x1583a6&&(_0x1583a6['disabled']=![],_0x1583a6['textContent']='Save\x20User');}async function saveUser(){const _0x453a70=document['getElementById']('user-form'),_0x3c2c90=document['getElementById']('skip-password')?.['checked']||![];if(!_0x3c2c90&&!_0x453a70['checkValidity']()){_0x453a70['reportValidity']();return;}const _0x4b164e=document['getElementById']('form-error'),_0x404231=document['getElementById']('save-user'),_0x542ac9=document['getElementById']('user-username')['value']['trim'](),_0x3aac7f=document['getElementById']('user-name')['value']['trim'](),_0x3e6156=document['getElementById']('user-email')['value']['trim'](),_0x415d99=document['getElementById']('user-password')['value'];if(!_0x542ac9||!_0x3aac7f||!_0x3e6156){_0x4b164e['textContent']='Please\x20fill\x20in\x20all\x20required\x20fields',_0x4b164e['hidden']=![],_0x4b164e['scrollIntoView']({'behavior':'smooth','block':'nearest'});return;}_0x4b164e['hidden']=!![];const _0x3b8eff=_0x404231['textContent'];_0x404231['disabled']=!![],_0x404231['textContent']=state['editingUserId']?'Updating...':'Creating...';try{if(state['editingUserId']){const _0x3d2aff={'username':_0x542ac9,'name':_0x3aac7f,'email':_0x3e6156};_0x415d99&&(_0x3d2aff['password']=_0x415d99),await API['updateUser'](state['editingUserId'],_0x3d2aff),Utils['showToast']('User\x20updated\x20successfully','success'),await loadUsers(),hideUserModal();}else{const _0x1b0ef8={'username':_0x542ac9,'name':_0x3aac7f,'email':_0x3e6156};if(!_0x3c2c90){if(!_0x415d99)throw new Error('Password\x20is\x20required\x20for\x20new\x20users');_0x1b0ef8['password']=_0x415d99;}const _0x40e5f2=await API['createUser'](_0x1b0ef8),_0x237509=_0x40e5f2['user'];if(_0x3c2c90||!_0x415d99){const _0xe1ab45=await API['createPasswordToken'](_0x237509['id'],'setup',![]);state['setupLinkData']={'username':_0x237509['username'],'email':_0x237509['email'],'url':_0xe1ab45['token']['setupUrl'],'userId':_0x237509['id'],'type':'setup','emailSent':![]},await loadUsers(),hideUserModal(),showSetupLinkModal();}else Utils['showToast']('User\x20created\x20successfully','success'),await loadUsers(),hideUserModal();}}catch(_0xde623e){console['error']('Failed\x20to\x20save\x20user',_0xde623e),_0x4b164e['textContent']=_0xde623e['message'],_0x4b164e['hidden']=![],_0x4b164e['scrollIntoView']({'behavior':'smooth','block':'nearest'}),_0x404231['disabled']=![],_0x404231['textContent']=_0x3b8eff;}}window['deleteUser']=function(_0x452966){const _0x1938ac=state['users']['find'](_0x5556a0=>_0x5556a0['id']===_0x452966);if(!_0x1938ac)return;state['deletingUserId']=_0x452966;const _0x3c4377=document['getElementById']('delete-modal'),_0x5346c5=document['getElementById']('delete-user-name');_0x5346c5['textContent']=_0x1938ac['name']+'\x20('+_0x1938ac['username']+')',_0x3c4377['hidden']=![];};function hideDeleteModal(){const _0x70f4c=document['getElementById']('delete-modal');_0x70f4c['hidden']=!![],state['deletingUserId']=null;const _0x156e3c=document['getElementById']('confirm-delete');_0x156e3c&&(_0x156e3c['disabled']=![],_0x156e3c['textContent']='Delete\x20User');}async function confirmDeleteUser(){if(!state['deletingUserId'])return;const _0x4aee75=document['getElementById']('confirm-delete'),_0x469e15=_0x4aee75['textContent'];_0x4aee75['disabled']=!![],_0x4aee75['textContent']='Deleting...';try{await API['deleteUser'](state['deletingUserId']),Utils['showToast']('User\x20deleted\x20successfully','success'),await loadUsers(),hideDeleteModal();}catch(_0x376c89){console['error']('Failed\x20to\x20delete\x20user',_0x376c89),Utils['showToast']('Failed\x20to\x20delete\x20user:\x20'+_0x376c89['message'],'error'),_0x4aee75['disabled']=![],_0x4aee75['textContent']=_0x469e15;}}function handleSkipPasswordChange(_0x5d11e4){const _0x7235a2=document['getElementById']('user-password'),_0x277e3b=_0x5d11e4['target']['checked'];_0x277e3b?(_0x7235a2['required']=![],_0x7235a2['disabled']=!![],_0x7235a2['value']=''):(_0x7235a2['required']=!![],_0x7235a2['disabled']=![]);}function showSetupLinkModal(){if(!state['setupLinkData'])return;const _0xcdcb85=document['getElementById']('setup-link-modal'),_0x40e1e9=document['getElementById']('setup-link-username'),_0x43ea32=document['getElementById']('setup-link-url'),_0x50b4d4=document['getElementById']('email-setup-link'),_0x1d332a=document['getElementById']('email-button-text');_0x40e1e9['textContent']=state['setupLinkData']['username'],_0x43ea32['textContent']=state['setupLinkData']['url'],_0x50b4d4&&_0x1d332a&&(_0x50b4d4['disabled']=![],_0x1d332a['textContent']='Email\x20Link',state['emailConfigured']&&!state['setupLinkData']['emailSent']?_0x50b4d4['style']['display']='inline-block':_0x50b4d4['style']['display']='none'),_0xcdcb85['hidden']=![];}function hideSetupLinkModal(){const _0x45d4f4=document['getElementById']('setup-link-modal');_0x45d4f4['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(_0x37af55){console['error']('Failed\x20to\x20copy\x20link',_0x37af55),Utils['showToast']('Failed\x20to\x20copy\x20link','error');}}async function emailSetupLink(){if(!state['setupLinkData'])return;const _0x15debd=document['getElementById']('email-setup-link'),_0x26a193=document['getElementById']('email-button-text');if(!_0x15debd||!_0x26a193)return;const _0x467670=_0x26a193['textContent'];_0x15debd['disabled']=!![],_0x26a193['textContent']='Sending...';try{const _0x12004a=await API['createPasswordToken'](state['setupLinkData']['userId'],state['setupLinkData']['type'],!![]);if(_0x12004a['emailSent'])Utils['showToast']('Email\x20sent\x20to\x20'+state['setupLinkData']['email'],'success'),state['setupLinkData']['emailSent']=!![],_0x15debd['style']['display']='none';else{const _0x3f3df4=_0x12004a['emailError']||'Failed\x20to\x20send\x20email';Utils['showToast'](_0x3f3df4,'error'),_0x15debd['disabled']=![],_0x26a193['textContent']=_0x467670;}}catch(_0x59396f){console['error']('Failed\x20to\x20email\x20setup\x20link',_0x59396f),Utils['showToast']('Failed\x20to\x20send\x20email:\x20'+_0x59396f['message'],'error'),_0x15debd['disabled']=![],_0x26a193['textContent']=_0x467670;}}window['resetPassword']=async function(_0x2a4419){const _0x52875b=state['users']['find'](_0xec3f47=>_0xec3f47['id']===_0x2a4419);if(!_0x52875b)return;const _0x51f25f=await ConfirmDialog['show']({'title':'Reset\x20Password','message':'Generate\x20a\x20password\x20reset\x20link\x20for\x20'+_0x52875b['name']+'\x20('+_0x52875b['username']+')?\x20This\x20will\x20create\x20a\x20link\x20that\x20they\x20can\x20use\x20to\x20set\x20a\x20new\x20password.','confirmText':'Generate\x20Link'});if(!_0x51f25f)return;try{const _0x52e1ba=await API['createPasswordToken'](_0x2a4419,'reset',![]);state['setupLinkData']={'username':_0x52875b['username'],'email':_0x52875b['email'],'url':_0x52e1ba['token']['setupUrl'],'userId':_0x52875b['id'],'type':'reset','emailSent':![]},showSetupLinkModal();}catch(_0x538b2b){console['error']('Failed\x20to\x20create\x20password\x20reset\x20link',_0x538b2b),Utils['showToast']('Failed\x20to\x20create\x20password\x20reset\x20link:\x20'+_0x538b2b['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 _0x3c1676=await API['getCurrentUser']();state['currentUser']=_0x3c1676;if(!Permissions['hasServerPermission'](_0x3c1676,'*')&&!Permissions['hasServerPermission'](_0x3c1676,'users:create')){Utils['showToast']('Access\x20denied:\x20Server\x20admin\x20privileges\x20required','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}}catch(_0x2549d9){window['location']['href']='login.html';}}async function checkEmailConfig(){try{const _0x13a18c=await API['getEmailConfig']();state['emailConfigured']=_0x13a18c['configured'];}catch(_0x11a76b){console['error']('Failed\x20to\x20check\x20email\x20config',_0x11a76b),state['emailConfigured']=![];}}async function loadRoles(){try{const {roles:_0x37f7ff}=await API['getRoleDefinitions']();state['roles']=_0x37f7ff||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x100f9c=await API['getEnvironments']();state['environments']=_0x100f9c['environments']||[];}catch{state['environments']=[];}}async function loadTeams(){try{const {teams:_0x19751e}=await API['getTeams']();state['teams']=_0x19751e||[];}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 _0x2bdeb1=document['getElementById']('users-loading'),_0x16d0da=document['getElementById']('users-error'),_0x517232=document['getElementById']('users-content');try{_0x2bdeb1['hidden']=![],_0x16d0da['hidden']=!![],_0x517232['hidden']=!![];const _0x30009a=await API['getUsers']();state['users']=_0x30009a['users']||[],renderUsers(),_0x2bdeb1['hidden']=!![],_0x517232['hidden']=![];}catch(_0x299b74){console['error']('Failed\x20to\x20load\x20users',_0x299b74),_0x2bdeb1['hidden']=!![],_0x16d0da['hidden']=![],document['getElementById']('users-error-message')['textContent']=_0x299b74['message'];}}function renderUsers(){const _0x53e439=document['getElementById']('users-table-body'),_0x2c9ee2=document['getElementById']('user-count');if(!_0x53e439)return;_0x2c9ee2&&(_0x2c9ee2['textContent']=state['users']['length']+'\x20user'+(state['users']['length']===0x1?'':'s'));const _0x5a403b=[...state['users']]['sort']((_0x114e25,_0xa71e3e)=>{const _0x182d99=new Date(_0x114e25['created_at'])['getTime'](),_0x21b0aa=new Date(_0xa71e3e['created_at'])['getTime']();return _0x21b0aa-_0x182d99;});_0x53e439['innerHTML']=_0x5a403b['map'](_0x5e0538=>'\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'](_0x5e0538['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'](_0x5e0538['name'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x5e0538['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'+(_0x5e0538['isServerAdmin']?'<span\x20class=\x22role-badge\x20role-admin\x22>Server\x20Admin</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x5e0538['hasUserBinding']?'<span\x20class=\x22role-badge\x20role-user-binding\x22>User\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x5e0538['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'](_0x5e0538['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'+_0x5e0538['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'+_0x5e0538['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'+_0x5e0538['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'+_0x5e0538['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(_0x55767d){const _0x268d7b=state['users']['find'](_0x336853=>_0x336853['id']===_0x55767d);if(!_0x268d7b)return;state['bindingsUserId']=_0x55767d,state['bindingsDirty']=![];const _0x108917=document['getElementById']('bindings-modal'),_0x4eade3=document['getElementById']('bindings-modal-title');_0x4eade3['textContent']='Access\x20Bindings\x20—\x20'+_0x268d7b['name'],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],_0x108917['hidden']=![],loadUserBindings(_0x55767d);};function hasUnsavedBindingChanges(){const _0x199908=document['getElementById']('add-user-binding-form');return _0x199908&&!_0x199908['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 _0x450096=document['getElementById']('bindings-modal');_0x450096['hidden']=!![];const _0x3c6e39=state['bindingsDirty'];state['bindingsUserId']=null,state['userBindings']=[],state['bindingsDirty']=![],_0x3c6e39&&await loadUsers();}async function loadUserBindings(_0x1f32e1){const _0x4c34e1=document['getElementById']('user-bindings-loading'),_0x1db89b=document['getElementById']('user-bindings-empty'),_0x1953db=document['getElementById']('user-bindings-list-container'),_0x4da988=document['getElementById']('add-user-binding-btn'),_0x56ad7a=document['getElementById']('user-team-bindings-note'),_0x5aedf2=document['getElementById']('user-team-bindings-text');_0x4c34e1['hidden']=![],_0x1db89b['hidden']=!![],_0x1953db['style']['display']='none',_0x4da988['hidden']=!![],_0x56ad7a['hidden']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![];try{const [_0x492577,_0x336061]=await Promise['all']([API['getBindings']({'subject_type':'user','subject_id':_0x1f32e1}),API['getTeams']()]);state['userBindings']=_0x492577['bindings']||[];const _0x3f7ea6=(_0x336061['teams']||[])['filter'](_0x159f6b=>(_0x159f6b['members']||[])['includes'](_0x1f32e1)),_0x23cbae=[];if(_0x3f7ea6['length']>0x0){const _0x1ad60c=await Promise['all'](_0x3f7ea6['map'](_0x2a6772=>API['getBindings']({'subject_type':'team','subject_id':_0x2a6772['id']})));for(let _0x135147=0x0;_0x135147<_0x3f7ea6['length'];_0x135147++){const _0x3fa555=_0x1ad60c[_0x135147]['bindings']||[];_0x3fa555['length']>0x0&&_0x23cbae['push'](_0x3f7ea6[_0x135147]);}}_0x4c34e1['hidden']=!![];state['userBindings']['length']===0x0?_0x1db89b['hidden']=![]:(_0x1953db['style']['display']='',renderUserBindingsTable());if(_0x23cbae['length']>0x0){const _0x530eb1=_0x23cbae['map'](_0x2287c9=>_0x2287c9['name']),_0x172c61=_0x530eb1['length']<=0x3?_0x530eb1['join'](',\x20'):_0x530eb1['slice'](0x0,0x3)['join'](',\x20')+(',\x20and\x20'+(_0x530eb1['length']-0x3)+'\x20more');_0x5aedf2['textContent']='This\x20user\x20also\x20has\x20access\x20via\x20team\x20memberships\x20('+_0x172c61+').';}else _0x5aedf2['textContent']='This\x20user\x20has\x20no\x20access\x20via\x20team\x20memberships.';_0x56ad7a['hidden']=![],_0x4da988['hidden']=![];}catch(_0x3de3fb){_0x4c34e1['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x3de3fb['message'],'error');}}function renderUserBindingsTable(){const _0x3023ed=document['getElementById']('user-bindings-table-body');if(!_0x3023ed)return;_0x3023ed['innerHTML']=state['userBindings']['map'](_0x164d6d=>{const _0x22121a=_0x164d6d['resource_type']==='server'?'Server':_0x164d6d['resource_id']==='*'?'All\x20'+_0x164d6d['resource_type']+'s':Utils['escapeHtml'](_0x164d6d['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x22121a+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x164d6d['role_name']||_0x164d6d['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'+_0x164d6d['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 _0x5605e9=document['getElementById']('user-binding-resource-type');_0x5605e9['value']='environment',updateUserBindingFormForResourceType('environment');}function onUserBindingResourceTypeChange(){const _0x144ea4=document['getElementById']('user-binding-resource-type')['value'];updateUserBindingFormForResourceType(_0x144ea4);}function updateUserBindingFormForResourceType(_0x5909bd){const _0x1e6a19=document['getElementById']('user-binding-resource-container'),_0x35ee57=document['getElementById']('user-binding-resource'),_0x56d666=document['getElementById']('user-binding-role');if(_0x5909bd==='server')_0x1e6a19['style']['display']='none';else{_0x1e6a19['style']['display']='';if(_0x5909bd==='environment'){const _0x21d352=new Set(state['userBindings']['filter'](_0x1cf4df=>_0x1cf4df['resource_type']==='environment')['map'](_0x2ea438=>_0x2ea438['resource_id'])),_0x3ee229=state['environments']['filter'](_0x4f5bca=>!_0x21d352['has'](_0x4f5bca['name']));_0x35ee57['innerHTML']=_0x3ee229['length']?_0x3ee229['map'](_0x518792=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x518792['name'])+'\x22>'+Utils['escapeHtml'](_0x518792['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x5909bd==='team'){const _0x475036=new Set(state['userBindings']['filter'](_0x5d2a7e=>_0x5d2a7e['resource_type']==='team')['map'](_0x2da99e=>_0x2da99e['resource_id'])),_0x17bb02=state['teams']['filter'](_0x369392=>!_0x475036['has'](_0x369392['id']));_0x35ee57['innerHTML']=_0x17bb02['length']?_0x17bb02['map'](_0x712c4c=>'<option\x20value=\x22'+_0x712c4c['id']+'\x22>'+Utils['escapeHtml'](_0x712c4c['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x4df259=state['roles']['filter'](_0x4fc390=>_0x4fc390['resource_type']===_0x5909bd);_0x56d666['innerHTML']=_0x4df259['length']?_0x4df259['filter'](_0x1dac0d=>{const _0x17c438=_0x5909bd==='server'?undefined:_0x35ee57['value'];return!state['userBindings']['some'](_0x329426=>_0x329426['resource_type']===_0x5909bd&&_0x329426['role_id']===_0x1dac0d['id']&&(_0x5909bd==='server'||_0x329426['resource_id']===_0x17c438));})['map'](_0x254aa9=>'<option\x20value=\x22'+_0x254aa9['id']+'\x22>'+Utils['escapeHtml'](_0x254aa9['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 _0x43fcd7=document['getElementById']('user-binding-resource-type')['value'],_0xa4b775=document['getElementById']('user-binding-role')['value'];if(!_0xa4b775||!state['bindingsUserId'])return;const _0x24a88b=_0x43fcd7==='server'?undefined:document['getElementById']('user-binding-resource')['value'];if(_0x43fcd7!=='server'&&!_0x24a88b)return;const _0x1aaa35=document['getElementById']('save-user-binding-btn');_0x1aaa35['disabled']=!![],_0x1aaa35['textContent']='Adding…';try{const _0x20ec71={'subject_type':'user','subject_id':state['bindingsUserId'],'role_id':_0xa4b775,'resource_type':_0x43fcd7};if(_0x24a88b)_0x20ec71['resource_id']=_0x24a88b;await API['createBinding'](_0x20ec71),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(_0x563fdb){Utils['showToast'](_0x563fdb['message'],'error');}finally{_0x1aaa35['disabled']=![],_0x1aaa35['textContent']='Add\x20Binding';}}window['deleteUserBindingClick']=async function(_0x13420c){try{await API['deleteBinding'](_0x13420c),Utils['showToast']('Binding\x20removed','success'),state['bindingsDirty']=!![],await loadUserBindings(state['bindingsUserId']);}catch(_0x3f75c6){Utils['showToast'](_0x3f75c6['message'],'error');}};function showCreateUserModal(){state['editingUserId']=null;const _0x1cf9b9=document['getElementById']('user-modal'),_0x322fd7=document['getElementById']('modal-title'),_0x5868b7=document['getElementById']('user-password'),_0x20c9b1=document['getElementById']('password-required'),_0xd7340c=document['getElementById']('password-hint'),_0x497555=document['getElementById']('skip-password-container'),_0x46afe2=document['getElementById']('skip-password');_0x322fd7['textContent']='Create\x20User',document['getElementById']('user-form')['reset'](),_0x5868b7['required']=!![];if(_0x20c9b1)_0x20c9b1['textContent']='*';_0x497555&&(_0x497555['style']['display']='block',_0x46afe2['checked']=![]),_0xd7340c&&(_0xd7340c['textContent']='Minimum\x208\x20characters'),_0x1cf9b9['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);}window['editUser']=function(_0x47abcd){const _0x480517=state['users']['find'](_0x5521ed=>_0x5521ed['id']===_0x47abcd);if(!_0x480517)return;state['editingUserId']=_0x47abcd;const _0x17a0c6=document['getElementById']('user-modal'),_0x302a4e=document['getElementById']('modal-title'),_0x5461be=document['getElementById']('user-password'),_0x39102d=document['getElementById']('password-required'),_0x40645e=document['getElementById']('password-hint'),_0x3e3f1b=document['getElementById']('skip-password-container');_0x302a4e['textContent']='Edit\x20User',document['getElementById']('user-username')['value']=_0x480517['username'],document['getElementById']('user-name')['value']=_0x480517['name'],document['getElementById']('user-email')['value']=_0x480517['email'],_0x5461be['value']='',_0x5461be['required']=![];if(_0x39102d)_0x39102d['textContent']='';_0x3e3f1b&&(_0x3e3f1b['style']['display']='none'),_0x40645e&&(_0x40645e['textContent']='Leave\x20blank\x20to\x20keep\x20current\x20password'),_0x17a0c6['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);};function hideUserModal(){const _0x4e7629=document['getElementById']('user-modal'),_0x254b93=document['getElementById']('form-error'),_0x1edc20=document['getElementById']('save-user');_0x4e7629['hidden']=!![],_0x254b93['hidden']=!![],state['editingUserId']=null,_0x1edc20&&(_0x1edc20['disabled']=![],_0x1edc20['textContent']='Save\x20User');}async function saveUser(){const _0x417d6a=document['getElementById']('user-form'),_0x12d447=document['getElementById']('skip-password')?.['checked']||![];if(!_0x12d447&&!_0x417d6a['checkValidity']()){_0x417d6a['reportValidity']();return;}const _0x237e27=document['getElementById']('form-error'),_0x705d18=document['getElementById']('save-user'),_0x581be6=document['getElementById']('user-username')['value']['trim'](),_0x493295=document['getElementById']('user-name')['value']['trim'](),_0x46ed7c=document['getElementById']('user-email')['value']['trim'](),_0x5567f6=document['getElementById']('user-password')['value'];if(!_0x581be6||!_0x493295||!_0x46ed7c){_0x237e27['textContent']='Please\x20fill\x20in\x20all\x20required\x20fields',_0x237e27['hidden']=![],_0x237e27['scrollIntoView']({'behavior':'smooth','block':'nearest'});return;}_0x237e27['hidden']=!![];const _0x4c927d=_0x705d18['textContent'];_0x705d18['disabled']=!![],_0x705d18['textContent']=state['editingUserId']?'Updating...':'Creating...';try{if(state['editingUserId']){const _0x608084={'username':_0x581be6,'name':_0x493295,'email':_0x46ed7c};_0x5567f6&&(_0x608084['password']=_0x5567f6),await API['updateUser'](state['editingUserId'],_0x608084),Utils['showToast']('User\x20updated\x20successfully','success'),await loadUsers(),hideUserModal();}else{const _0x426313={'username':_0x581be6,'name':_0x493295,'email':_0x46ed7c};if(!_0x12d447){if(!_0x5567f6)throw new Error('Password\x20is\x20required\x20for\x20new\x20users');_0x426313['password']=_0x5567f6;}const _0x25a2cd=await API['createUser'](_0x426313),_0x463195=_0x25a2cd['user'];if(_0x12d447||!_0x5567f6){const _0x14a946=await API['createPasswordToken'](_0x463195['id'],'setup',![]);state['setupLinkData']={'username':_0x463195['username'],'email':_0x463195['email'],'url':_0x14a946['token']['setupUrl'],'userId':_0x463195['id'],'type':'setup','emailSent':![]},await loadUsers(),hideUserModal(),showSetupLinkModal();}else Utils['showToast']('User\x20created\x20successfully','success'),await loadUsers(),hideUserModal();}}catch(_0x4a4237){console['error']('Failed\x20to\x20save\x20user',_0x4a4237),_0x237e27['textContent']=_0x4a4237['message'],_0x237e27['hidden']=![],_0x237e27['scrollIntoView']({'behavior':'smooth','block':'nearest'}),_0x705d18['disabled']=![],_0x705d18['textContent']=_0x4c927d;}}window['deleteUser']=function(_0x1a3599){const _0x52f167=state['users']['find'](_0x43d839=>_0x43d839['id']===_0x1a3599);if(!_0x52f167)return;state['deletingUserId']=_0x1a3599;const _0xa89a3f=document['getElementById']('delete-modal'),_0x37e1d3=document['getElementById']('delete-user-name');_0x37e1d3['textContent']=_0x52f167['name']+'\x20('+_0x52f167['username']+')',_0xa89a3f['hidden']=![];};function hideDeleteModal(){const _0x1c1fd5=document['getElementById']('delete-modal');_0x1c1fd5['hidden']=!![],state['deletingUserId']=null;const _0x2fc267=document['getElementById']('confirm-delete');_0x2fc267&&(_0x2fc267['disabled']=![],_0x2fc267['textContent']='Delete\x20User');}async function confirmDeleteUser(){if(!state['deletingUserId'])return;const _0x5f37e8=document['getElementById']('confirm-delete'),_0x56a136=_0x5f37e8['textContent'];_0x5f37e8['disabled']=!![],_0x5f37e8['textContent']='Deleting...';try{await API['deleteUser'](state['deletingUserId']),Utils['showToast']('User\x20deleted\x20successfully','success'),await loadUsers(),hideDeleteModal();}catch(_0x25e710){console['error']('Failed\x20to\x20delete\x20user',_0x25e710),Utils['showToast']('Failed\x20to\x20delete\x20user:\x20'+_0x25e710['message'],'error'),_0x5f37e8['disabled']=![],_0x5f37e8['textContent']=_0x56a136;}}function handleSkipPasswordChange(_0x3fec0e){const _0xa3d23f=document['getElementById']('user-password'),_0x2a7f1f=_0x3fec0e['target']['checked'];_0x2a7f1f?(_0xa3d23f['required']=![],_0xa3d23f['disabled']=!![],_0xa3d23f['value']=''):(_0xa3d23f['required']=!![],_0xa3d23f['disabled']=![]);}function showSetupLinkModal(){if(!state['setupLinkData'])return;const _0x359b59=document['getElementById']('setup-link-modal'),_0x4383a5=document['getElementById']('setup-link-username'),_0x36d332=document['getElementById']('setup-link-url'),_0x5454e6=document['getElementById']('email-setup-link'),_0x3db893=document['getElementById']('email-button-text');_0x4383a5['textContent']=state['setupLinkData']['username'],_0x36d332['textContent']=state['setupLinkData']['url'],_0x5454e6&&_0x3db893&&(_0x5454e6['disabled']=![],_0x3db893['textContent']='Email\x20Link',state['emailConfigured']&&!state['setupLinkData']['emailSent']?_0x5454e6['style']['display']='inline-block':_0x5454e6['style']['display']='none'),_0x359b59['hidden']=![];}function hideSetupLinkModal(){const _0x738947=document['getElementById']('setup-link-modal');_0x738947['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(_0x23ca27){console['error']('Failed\x20to\x20copy\x20link',_0x23ca27),Utils['showToast']('Failed\x20to\x20copy\x20link','error');}}async function emailSetupLink(){if(!state['setupLinkData'])return;const _0x3b44a4=document['getElementById']('email-setup-link'),_0x5abf91=document['getElementById']('email-button-text');if(!_0x3b44a4||!_0x5abf91)return;const _0x256dd6=_0x5abf91['textContent'];_0x3b44a4['disabled']=!![],_0x5abf91['textContent']='Sending...';try{const _0x4ef14b=await API['createPasswordToken'](state['setupLinkData']['userId'],state['setupLinkData']['type'],!![]);if(_0x4ef14b['emailSent'])Utils['showToast']('Email\x20sent\x20to\x20'+state['setupLinkData']['email'],'success'),state['setupLinkData']['emailSent']=!![],_0x3b44a4['style']['display']='none';else{const _0x3778d0=_0x4ef14b['emailError']||'Failed\x20to\x20send\x20email';Utils['showToast'](_0x3778d0,'error'),_0x3b44a4['disabled']=![],_0x5abf91['textContent']=_0x256dd6;}}catch(_0x468d18){console['error']('Failed\x20to\x20email\x20setup\x20link',_0x468d18),Utils['showToast']('Failed\x20to\x20send\x20email:\x20'+_0x468d18['message'],'error'),_0x3b44a4['disabled']=![],_0x5abf91['textContent']=_0x256dd6;}}window['resetPassword']=async function(_0x3e1307){const _0x2d4185=state['users']['find'](_0x157222=>_0x157222['id']===_0x3e1307);if(!_0x2d4185)return;const _0x59dd8f=await ConfirmDialog['show']({'title':'Reset\x20Password','message':'Generate\x20a\x20password\x20reset\x20link\x20for\x20'+_0x2d4185['name']+'\x20('+_0x2d4185['username']+')?\x20This\x20will\x20create\x20a\x20link\x20that\x20they\x20can\x20use\x20to\x20set\x20a\x20new\x20password.','confirmText':'Generate\x20Link'});if(!_0x59dd8f)return;try{const _0x528bcf=await API['createPasswordToken'](_0x3e1307,'reset',![]);state['setupLinkData']={'username':_0x2d4185['username'],'email':_0x2d4185['email'],'url':_0x528bcf['token']['setupUrl'],'userId':_0x2d4185['id'],'type':'reset','emailSent':![]},showSetupLinkModal();}catch(_0x38d02c){console['error']('Failed\x20to\x20create\x20password\x20reset\x20link',_0x38d02c),Utils['showToast']('Failed\x20to\x20create\x20password\x20reset\x20link:\x20'+_0x38d02c['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(_0x357891={}){this['container']=null,this['onGroupChange']=_0x357891['onGroupChange']||(()=>{}),this['onAddExistingTask']=_0x357891['onAddExistingTask']||(()=>{}),this['tasks']=[],this['groupId']=_0x357891['groupId']||null,this['isOpen']=![];}['init'](_0x525f58,_0x4381a0,_0x111f47){this['container']=_0x525f58,this['tasks']=_0x4381a0,this['groupId']=_0x111f47,this['render'](),this['attachEventListeners']();}['updateTasks'](_0x1d9631){const _0x54fa0d=new Map(_0x1d9631['map'](_0x45bbbb=>[_0x45bbbb['taskId'],_0x45bbbb]));this['tasks']=this['tasks']['map'](_0x7046f9=>{const _0x1745a5=_0x54fa0d['get'](_0x7046f9['taskId']);return _0x1745a5?_0x1745a5:_0x7046f9;});for(const _0x1ca414 of _0x1d9631){!this['tasks']['some'](_0x3424ba=>_0x3424ba['taskId']===_0x1ca414['taskId'])&&this['tasks']['push'](_0x1ca414);}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 _0x27b042=this['tasks']['filter'](_0x3b8b6e=>_0x3b8b6e['groupId']===this['groupId'])['sort']((_0x3bd68e,_0x2b2de0)=>(_0x3bd68e['groupIndex']??0x0)-(_0x2b2de0['groupIndex']??0x0)),_0x3de912=this['tasks']['filter'](_0x442520=>!_0x442520['groupId']||_0x442520['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>'+_0x27b042['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'+(_0x27b042['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20add\x20to\x20group</div>':_0x27b042['map']((_0x443f92,_0x40304b)=>this['renderVariantCard'](_0x443f92,_0x40304b,!![]))['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>'+_0x3de912['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'+(_0x3de912['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20remove\x20from\x20group</div>':_0x3de912['map']((_0x1dd919,_0x249bbf)=>this['renderVariantCard'](_0x1dd919,_0x249bbf,![]))['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'](_0x55bee8,_0x28c0b1,_0x3f64f0){const _0x38d9ed=_0x55bee8['envVars']?.['CODER_AGENT']||_0x55bee8['envVars']?.['default_agent']||'claude',_0x2242ba=AGENT_ICONS[_0x38d9ed['toLowerCase']()]||AGENT_ICONS['claude'],_0x4017e4=STATUS_ICONS[_0x55bee8['status']]||'',_0x507475='status-'+(_0x55bee8['status']||'unknown'),_0x2277bb=_0x55bee8['isWinner']?'<span\x20class=\x22vgm-badge\x20vgm-badge-winner\x22\x20title=\x22Winner\x22>★</span>':'',_0x181e48=_0x55bee8['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'+_0x507475+'\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'+_0x55bee8['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-is-grouped=\x22'+_0x3f64f0+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-index=\x22'+_0x28c0b1+'\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'+_0x38d9ed['toLowerCase']()+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x2242ba+'\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'](_0x55bee8['name']||'Task\x20'+_0x55bee8['taskId']['slice'](-0x6))+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-meta\x22>'+Utils['escapeHtml'](_0x38d9ed)+'\x20·\x20'+(_0x55bee8['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'+_0x2277bb+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x181e48+'\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'+_0x507475+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x4017e4+'\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'+(_0x3f64f0?'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'+_0x55bee8['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-action=\x22'+(_0x3f64f0?'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'+(_0x3f64f0?'<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',_0x4901dd=>{_0x4901dd['target']['closest']('.vgm-close-btn')&&(this['close'](),this['onGroupChange'](this['tasks'])),_0x4901dd['target']['closest']('.vgm-add-existing-btn')&&(this['close'](),this['onAddExistingTask'](this['groupId']));}),this['container']['addEventListener']('click',async _0x5b2576=>{const _0x542ae5=_0x5b2576['target']['closest']('.vgm-variant-remove-btn');if(!_0x542ae5)return;const _0x326abf=_0x542ae5['dataset']['taskId'],_0x573795=_0x542ae5['dataset']['action'];try{_0x573795==='remove'?await this['removeFromGroup'](_0x326abf):await this['addToGroup'](_0x326abf);}catch(_0x494a37){console['error']('Failed\x20to\x20update\x20group:',_0x494a37),Utils['showToast'](_0x494a37['message']||'Failed\x20to\x20update\x20group','error');}}),this['container']['addEventListener']('dragstart',_0x345207=>this['handleDragStart'](_0x345207)),this['container']['addEventListener']('dragend',_0x46d934=>this['handleDragEnd'](_0x46d934)),this['container']['addEventListener']('dragover',_0x3a3229=>this['handleDragOver'](_0x3a3229)),this['container']['addEventListener']('dragleave',_0x66bde6=>this['handleDragLeave'](_0x66bde6)),this['container']['addEventListener']('drop',_0x5dd0ac=>this['handleDrop'](_0x5dd0ac));}['handleDragStart'](_0x3b859b){const _0x286df8=_0x3b859b['target']['closest']('.vgm-variant-card');if(!_0x286df8)return;dragState['draggedTaskId']=_0x286df8['dataset']['taskId'],dragState['draggedElement']=_0x286df8,dragState['sourceGroupId']=_0x286df8['dataset']['isGrouped']==='true'?this['groupId']:null,dragState['isDragging']=!![],_0x286df8['classList']['add']('dragging'),_0x3b859b['dataTransfer']['effectAllowed']='move',_0x3b859b['dataTransfer']['setData']('text/plain',_0x286df8['dataset']['taskId']),this['container']['classList']['add']('is-dragging');}['handleDragEnd'](_0x5aedfe){const _0x2f7ce8=_0x5aedfe['target']['closest']('.vgm-variant-card');_0x2f7ce8&&_0x2f7ce8['classList']['remove']('dragging'),this['container']['querySelectorAll']('.drag-over,\x20.drop-indicator')['forEach'](_0x296d5e=>{_0x296d5e['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'](_0x14f9af){_0x14f9af['preventDefault'](),_0x14f9af['dataTransfer']['dropEffect']='move';const _0xb11c5e=_0x14f9af['target']['closest']('.vgm-drop-zone'),_0x4a36a2=_0x14f9af['target']['closest']('.vgm-variant-card');this['container']['querySelectorAll']('.vgm-drop-zone')['forEach'](_0x21c012=>{_0x21c012['classList']['toggle']('drag-over',_0x21c012===_0xb11c5e);});if(_0x4a36a2&&_0x4a36a2!==dragState['draggedElement']){const _0x23c14c=_0x4a36a2['getBoundingClientRect'](),_0x4990a2=_0x23c14c['top']+_0x23c14c['height']/0x2,_0x388f55=_0x14f9af['clientY']<_0x4990a2;this['container']['querySelectorAll']('.vgm-variant-card')['forEach'](_0x25878f=>{_0x25878f!==_0x4a36a2&&_0x25878f['classList']['remove']('drop-before','drop-after');}),_0x4a36a2['classList']['toggle']('drop-before',_0x388f55),_0x4a36a2['classList']['toggle']('drop-after',!_0x388f55);}}['handleDragLeave'](_0x2b55d8){const _0x27b1ea=_0x2b55d8['target']['closest']('.vgm-drop-zone');_0x27b1ea&&!_0x27b1ea['contains'](_0x2b55d8['relatedTarget'])&&_0x27b1ea['classList']['remove']('drag-over');}async['handleDrop'](_0x1b9153){_0x1b9153['preventDefault']();const _0x38be8c=_0x1b9153['target']['closest']('.vgm-drop-zone'),_0x44ece7=_0x1b9153['target']['closest']('.vgm-variant-card'),_0x395acc=_0x1b9153['dataTransfer']['getData']('text/plain');if(!_0x38be8c||!_0x395acc)return;this['container']['querySelectorAll']('.drag-over,\x20.drop-before,\x20.drop-after')['forEach'](_0x83a734=>{_0x83a734['classList']['remove']('drag-over','drop-before','drop-after');});const _0x52d27a=_0x38be8c['dataset']['zone'],_0x37a7dc=_0x52d27a==='grouped',_0x44eefe=dragState['sourceGroupId']===this['groupId'];try{if(_0x37a7dc&&!_0x44eefe){let _0xb5f404=this['tasks']['filter'](_0xb800a4=>_0xb800a4['groupId']===this['groupId'])['length'];if(_0x44ece7){const _0x1611e4=_0x44ece7['dataset']['taskId'],_0x4dcdd1=this['tasks']['find'](_0xb484d4=>_0xb484d4['taskId']===_0x1611e4);if(_0x4dcdd1?.['groupIndex']!==undefined){const _0x272bf9=_0x44ece7['getBoundingClientRect'](),_0x437fb8=_0x1b9153['clientY']<_0x272bf9['top']+_0x272bf9['height']/0x2;_0xb5f404=_0x4dcdd1['groupIndex']+(_0x437fb8?0x0:0x1);}}await this['addToGroup'](_0x395acc,_0xb5f404);}else{if(!_0x37a7dc&&_0x44eefe)await this['removeFromGroup'](_0x395acc);else _0x37a7dc&&_0x44eefe&&_0x44ece7&&await this['reorderInGroup'](_0x395acc,_0x44ece7,_0x1b9153['clientY']);}}catch(_0x377c9a){console['error']('Drop\x20operation\x20failed:',_0x377c9a),Utils['showToast'](_0x377c9a['message']||'Failed\x20to\x20move\x20variant','error');}}async['addToGroup'](_0x5b559e,_0x2cdaff){const _0x131253=this['tasks']['find'](_0x476136=>_0x476136['taskId']===_0x5b559e);if(!_0x131253)return;_0x2cdaff===undefined&&(_0x2cdaff=this['tasks']['filter'](_0x2381f5=>_0x2381f5['groupId']===this['groupId'])['length']),!this['groupId']&&(this['groupId']=API['generateGroupId'](),await API['createTaskGroup']({'groupId':this['groupId']})),await API['updateTaskGroup'](_0x5b559e,this['groupId'],_0x2cdaff),_0x131253['groupId']=this['groupId'],_0x131253['groupIndex']=_0x2cdaff,this['render'](),this['onGroupChange'](this['tasks']);}async['removeFromGroup'](_0x46c9c4){const _0x120964=this['tasks']['find'](_0x287735=>_0x287735['taskId']===_0x46c9c4);if(!_0x120964)return;await API['removeTaskFromGroup'](_0x46c9c4),_0x120964['groupId']=null,_0x120964['groupIndex']=null,this['render'](),this['onGroupChange'](this['tasks']);}async['reorderInGroup'](_0x1c534c,_0x114059,_0x2ee343){const _0x3545c4=this['tasks']['find'](_0x1f1508=>_0x1f1508['taskId']===_0x1c534c),_0x3b1d59=_0x114059['dataset']['taskId'],_0x2a0361=this['tasks']['find'](_0x11ae92=>_0x11ae92['taskId']===_0x3b1d59);if(!_0x3545c4||!_0x2a0361||_0x3545c4['taskId']===_0x2a0361['taskId'])return;const _0xab2565=_0x114059['getBoundingClientRect'](),_0x10bed5=_0x2ee343<_0xab2565['top']+_0xab2565['height']/0x2;let _0x5216c1=_0x2a0361['groupIndex']??0x0;if(!_0x10bed5)_0x5216c1++;if((_0x3545c4['groupIndex']??0x0)<(_0x2a0361['groupIndex']??0x0))_0x5216c1--;if(_0x5216c1===_0x3545c4['groupIndex'])return;await API['updateTaskGroup'](_0x1c534c,this['groupId'],_0x5216c1);const _0x1d9374=this['tasks']['filter'](_0x4a0769=>_0x4a0769['groupId']===this['groupId'])['sort']((_0x4262c7,_0x5408eb)=>(_0x4262c7['groupIndex']??0x0)-(_0x5408eb['groupIndex']??0x0)),_0x37a592=_0x1d9374['findIndex'](_0x469fd9=>_0x469fd9['taskId']===_0x1c534c);_0x37a592!==-0x1&&_0x1d9374['splice'](_0x37a592,0x1),_0x1d9374['splice'](_0x5216c1,0x0,_0x3545c4),_0x1d9374['forEach']((_0x232251,_0x200906)=>{_0x232251['groupIndex']=_0x200906;}),this['render'](),this['onGroupChange'](this['tasks']);}}export function initializeTabDragDrop(_0x57cc45,_0x205667,_0x27d49c,_0x58bb3f={}){if(!_0x57cc45)return;const {onReorder:_0x43bb59,onRemove:_0x355f3}=_0x58bb3f,_0x1715fd=_0x57cc45['querySelectorAll']('.task-tab');_0x1715fd['forEach']((_0x3dcbd3,_0x46dc9b)=>{_0x3dcbd3['setAttribute']('draggable','true'),_0x3dcbd3['dataset']['index']=_0x46dc9b,_0x3dcbd3['addEventListener']('dragstart',_0x679525=>{_0x679525['dataTransfer']['effectAllowed']='move',_0x679525['dataTransfer']['setData']('text/plain',_0x3dcbd3['dataset']['taskId']),_0x3dcbd3['classList']['add']('dragging'),_0x57cc45['classList']['add']('is-dragging');}),_0x3dcbd3['addEventListener']('dragend',()=>{_0x3dcbd3['classList']['remove']('dragging'),_0x57cc45['classList']['remove']('is-dragging'),_0x57cc45['querySelectorAll']('.drop-indicator')['forEach'](_0x35d833=>{_0x35d833['classList']['remove']('drop-indicator','drop-before','drop-after');});}),_0x3dcbd3['addEventListener']('dragover',_0x452f30=>{_0x452f30['preventDefault'](),_0x452f30['dataTransfer']['dropEffect']='move';if(_0x3dcbd3['classList']['contains']('dragging'))return;const _0x3b3951=_0x3dcbd3['getBoundingClientRect'](),_0x2a87a9=_0x3b3951['left']+_0x3b3951['width']/0x2,_0x35b423=_0x452f30['clientX']<_0x2a87a9;_0x1715fd['forEach'](_0x38e5a9=>_0x38e5a9['classList']['remove']('drop-before','drop-after')),_0x3dcbd3['classList']['add'](_0x35b423?'drop-before':'drop-after');}),_0x3dcbd3['addEventListener']('dragleave',()=>{_0x3dcbd3['classList']['remove']('drop-before','drop-after');}),_0x3dcbd3['addEventListener']('drop',async _0x4223cf=>{_0x4223cf['preventDefault']();const _0x16b1cb=_0x4223cf['dataTransfer']['getData']('text/plain'),_0xe86299=_0x3dcbd3['dataset']['taskId'];if(_0x16b1cb===_0xe86299)return;const _0x1e4930=_0x3dcbd3['getBoundingClientRect'](),_0x2278b4=_0x4223cf['clientX']<_0x1e4930['left']+_0x1e4930['width']/0x2;_0x3dcbd3['classList']['remove']('drop-before','drop-after'),_0x43bb59&&await _0x43bb59(_0x16b1cb,_0xe86299,_0x2278b4);});});const _0xe4785d=document['createElement']('div');return _0xe4785d['className']='task-tab-remove-zone',_0xe4785d['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',_0xe4785d['style']['display']='none',_0xe4785d['addEventListener']('dragover',_0x4c8ef0=>{_0x4c8ef0['preventDefault'](),_0xe4785d['classList']['add']('drag-over');}),_0xe4785d['addEventListener']('dragleave',()=>{_0xe4785d['classList']['remove']('drag-over');}),_0xe4785d['addEventListener']('drop',async _0x28c1e2=>{_0x28c1e2['preventDefault'](),_0xe4785d['classList']['remove']('drag-over');const _0x2609a0=_0x28c1e2['dataTransfer']['getData']('text/plain');_0x355f3&&await _0x355f3(_0x2609a0);}),_0x57cc45['addEventListener']('dragstart',()=>{_0x205667['length']>0x1&&(_0xe4785d['style']['display']='flex');}),_0x57cc45['addEventListener']('dragend',()=>{_0xe4785d['style']['display']='none';}),_0x57cc45['appendChild'](_0xe4785d),{'destroy':()=>{_0xe4785d['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(_0x79a632={}){this['container']=null,this['onGroupChange']=_0x79a632['onGroupChange']||(()=>{}),this['onAddExistingTask']=_0x79a632['onAddExistingTask']||(()=>{}),this['tasks']=[],this['groupId']=_0x79a632['groupId']||null,this['isOpen']=![];}['init'](_0x434435,_0x113c83,_0x4bdda2){this['container']=_0x434435,this['tasks']=_0x113c83,this['groupId']=_0x4bdda2,this['render'](),this['attachEventListeners']();}['updateTasks'](_0x2d7310){const _0x3ea3c8=new Map(_0x2d7310['map'](_0x595f2e=>[_0x595f2e['taskId'],_0x595f2e]));this['tasks']=this['tasks']['map'](_0x5aa98=>{const _0xc036d0=_0x3ea3c8['get'](_0x5aa98['taskId']);return _0xc036d0?_0xc036d0:_0x5aa98;});for(const _0x2b24d3 of _0x2d7310){!this['tasks']['some'](_0x5d03f7=>_0x5d03f7['taskId']===_0x2b24d3['taskId'])&&this['tasks']['push'](_0x2b24d3);}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 _0x29b05e=this['tasks']['filter'](_0x5493ab=>_0x5493ab['groupId']===this['groupId'])['sort']((_0x5cc50c,_0x366738)=>(_0x5cc50c['groupIndex']??0x0)-(_0x366738['groupIndex']??0x0)),_0xcee400=this['tasks']['filter'](_0x3769ec=>!_0x3769ec['groupId']||_0x3769ec['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>'+_0x29b05e['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'+(_0x29b05e['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20add\x20to\x20group</div>':_0x29b05e['map']((_0x4f8b34,_0x3aec77)=>this['renderVariantCard'](_0x4f8b34,_0x3aec77,!![]))['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>'+_0xcee400['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'+(_0xcee400['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20remove\x20from\x20group</div>':_0xcee400['map']((_0x5f2b32,_0x6cfceb)=>this['renderVariantCard'](_0x5f2b32,_0x6cfceb,![]))['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'](_0x24775a,_0x40c203,_0x4c6878){const _0x266e95=_0x24775a['envVars']?.['CODER_AGENT']||_0x24775a['envVars']?.['default_agent']||'claude',_0x224bb7=AGENT_ICONS[_0x266e95['toLowerCase']()]||AGENT_ICONS['claude'],_0x3b06fe=STATUS_ICONS[_0x24775a['status']]||'',_0x15799c='status-'+(_0x24775a['status']||'unknown'),_0x5ebebc=_0x24775a['isWinner']?'<span\x20class=\x22vgm-badge\x20vgm-badge-winner\x22\x20title=\x22Winner\x22>★</span>':'',_0x18843f=_0x24775a['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'+_0x15799c+'\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'+_0x24775a['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-is-grouped=\x22'+_0x4c6878+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-index=\x22'+_0x40c203+'\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'+_0x266e95['toLowerCase']()+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x224bb7+'\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'](_0x24775a['name']||'Task\x20'+_0x24775a['taskId']['slice'](-0x6))+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-meta\x22>'+Utils['escapeHtml'](_0x266e95)+'\x20·\x20'+(_0x24775a['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'+_0x5ebebc+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x18843f+'\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'+_0x15799c+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x3b06fe+'\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'+(_0x4c6878?'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'+_0x24775a['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-action=\x22'+(_0x4c6878?'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'+(_0x4c6878?'<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',_0x25f67a=>{_0x25f67a['target']['closest']('.vgm-close-btn')&&(this['close'](),this['onGroupChange'](this['tasks'])),_0x25f67a['target']['closest']('.vgm-add-existing-btn')&&(this['close'](),this['onAddExistingTask'](this['groupId']));}),this['container']['addEventListener']('click',async _0x519d5f=>{const _0x34be39=_0x519d5f['target']['closest']('.vgm-variant-remove-btn');if(!_0x34be39)return;const _0xfdc062=_0x34be39['dataset']['taskId'],_0x279844=_0x34be39['dataset']['action'];try{_0x279844==='remove'?await this['removeFromGroup'](_0xfdc062):await this['addToGroup'](_0xfdc062);}catch(_0x405fec){console['error']('Failed\x20to\x20update\x20group:',_0x405fec),Utils['showToast'](_0x405fec['message']||'Failed\x20to\x20update\x20group','error');}}),this['container']['addEventListener']('dragstart',_0x23196b=>this['handleDragStart'](_0x23196b)),this['container']['addEventListener']('dragend',_0x59e37b=>this['handleDragEnd'](_0x59e37b)),this['container']['addEventListener']('dragover',_0x2a6bed=>this['handleDragOver'](_0x2a6bed)),this['container']['addEventListener']('dragleave',_0x4321ff=>this['handleDragLeave'](_0x4321ff)),this['container']['addEventListener']('drop',_0x3c41c5=>this['handleDrop'](_0x3c41c5));}['handleDragStart'](_0x4771dd){const _0x4fa1bd=_0x4771dd['target']['closest']('.vgm-variant-card');if(!_0x4fa1bd)return;dragState['draggedTaskId']=_0x4fa1bd['dataset']['taskId'],dragState['draggedElement']=_0x4fa1bd,dragState['sourceGroupId']=_0x4fa1bd['dataset']['isGrouped']==='true'?this['groupId']:null,dragState['isDragging']=!![],_0x4fa1bd['classList']['add']('dragging'),_0x4771dd['dataTransfer']['effectAllowed']='move',_0x4771dd['dataTransfer']['setData']('text/plain',_0x4fa1bd['dataset']['taskId']),this['container']['classList']['add']('is-dragging');}['handleDragEnd'](_0x590143){const _0x328a28=_0x590143['target']['closest']('.vgm-variant-card');_0x328a28&&_0x328a28['classList']['remove']('dragging'),this['container']['querySelectorAll']('.drag-over,\x20.drop-indicator')['forEach'](_0x4b4187=>{_0x4b4187['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'](_0x2106ee){_0x2106ee['preventDefault'](),_0x2106ee['dataTransfer']['dropEffect']='move';const _0x53ce0a=_0x2106ee['target']['closest']('.vgm-drop-zone'),_0x345e96=_0x2106ee['target']['closest']('.vgm-variant-card');this['container']['querySelectorAll']('.vgm-drop-zone')['forEach'](_0x5b5d96=>{_0x5b5d96['classList']['toggle']('drag-over',_0x5b5d96===_0x53ce0a);});if(_0x345e96&&_0x345e96!==dragState['draggedElement']){const _0x12d135=_0x345e96['getBoundingClientRect'](),_0x261b4c=_0x12d135['top']+_0x12d135['height']/0x2,_0x4b558b=_0x2106ee['clientY']<_0x261b4c;this['container']['querySelectorAll']('.vgm-variant-card')['forEach'](_0x273e3f=>{_0x273e3f!==_0x345e96&&_0x273e3f['classList']['remove']('drop-before','drop-after');}),_0x345e96['classList']['toggle']('drop-before',_0x4b558b),_0x345e96['classList']['toggle']('drop-after',!_0x4b558b);}}['handleDragLeave'](_0x3b25cc){const _0xb134d3=_0x3b25cc['target']['closest']('.vgm-drop-zone');_0xb134d3&&!_0xb134d3['contains'](_0x3b25cc['relatedTarget'])&&_0xb134d3['classList']['remove']('drag-over');}async['handleDrop'](_0x55496e){_0x55496e['preventDefault']();const _0x1e39ab=_0x55496e['target']['closest']('.vgm-drop-zone'),_0x359cfb=_0x55496e['target']['closest']('.vgm-variant-card'),_0x262d07=_0x55496e['dataTransfer']['getData']('text/plain');if(!_0x1e39ab||!_0x262d07)return;this['container']['querySelectorAll']('.drag-over,\x20.drop-before,\x20.drop-after')['forEach'](_0x582775=>{_0x582775['classList']['remove']('drag-over','drop-before','drop-after');});const _0x176e3a=_0x1e39ab['dataset']['zone'],_0x1dfda8=_0x176e3a==='grouped',_0x37cf93=dragState['sourceGroupId']===this['groupId'];try{if(_0x1dfda8&&!_0x37cf93){let _0x53b357=this['tasks']['filter'](_0x23514a=>_0x23514a['groupId']===this['groupId'])['length'];if(_0x359cfb){const _0x4e4f56=_0x359cfb['dataset']['taskId'],_0x31afeb=this['tasks']['find'](_0x538ade=>_0x538ade['taskId']===_0x4e4f56);if(_0x31afeb?.['groupIndex']!==undefined){const _0x3396cc=_0x359cfb['getBoundingClientRect'](),_0x292444=_0x55496e['clientY']<_0x3396cc['top']+_0x3396cc['height']/0x2;_0x53b357=_0x31afeb['groupIndex']+(_0x292444?0x0:0x1);}}await this['addToGroup'](_0x262d07,_0x53b357);}else{if(!_0x1dfda8&&_0x37cf93)await this['removeFromGroup'](_0x262d07);else _0x1dfda8&&_0x37cf93&&_0x359cfb&&await this['reorderInGroup'](_0x262d07,_0x359cfb,_0x55496e['clientY']);}}catch(_0x1ce053){console['error']('Drop\x20operation\x20failed:',_0x1ce053),Utils['showToast'](_0x1ce053['message']||'Failed\x20to\x20move\x20variant','error');}}async['addToGroup'](_0x40f074,_0x1819b5){const _0x1bb080=this['tasks']['find'](_0x149a02=>_0x149a02['taskId']===_0x40f074);if(!_0x1bb080)return;_0x1819b5===undefined&&(_0x1819b5=this['tasks']['filter'](_0x237f5e=>_0x237f5e['groupId']===this['groupId'])['length']),!this['groupId']&&(this['groupId']=API['generateGroupId'](),await API['createTaskGroup']({'groupId':this['groupId']})),await API['updateTaskGroup'](_0x40f074,this['groupId'],_0x1819b5),_0x1bb080['groupId']=this['groupId'],_0x1bb080['groupIndex']=_0x1819b5,this['render'](),this['onGroupChange'](this['tasks']);}async['removeFromGroup'](_0x35f211){const _0x2c3374=this['tasks']['find'](_0x2d0f80=>_0x2d0f80['taskId']===_0x35f211);if(!_0x2c3374)return;await API['removeTaskFromGroup'](_0x35f211),_0x2c3374['groupId']=null,_0x2c3374['groupIndex']=null,this['render'](),this['onGroupChange'](this['tasks']);}async['reorderInGroup'](_0x20cb03,_0x34c50c,_0x582974){const _0x548852=this['tasks']['find'](_0x1bd396=>_0x1bd396['taskId']===_0x20cb03),_0x373740=_0x34c50c['dataset']['taskId'],_0x35d523=this['tasks']['find'](_0x137ccf=>_0x137ccf['taskId']===_0x373740);if(!_0x548852||!_0x35d523||_0x548852['taskId']===_0x35d523['taskId'])return;const _0x2bd69f=_0x34c50c['getBoundingClientRect'](),_0x2bf515=_0x582974<_0x2bd69f['top']+_0x2bd69f['height']/0x2;let _0x48526a=_0x35d523['groupIndex']??0x0;if(!_0x2bf515)_0x48526a++;if((_0x548852['groupIndex']??0x0)<(_0x35d523['groupIndex']??0x0))_0x48526a--;if(_0x48526a===_0x548852['groupIndex'])return;await API['updateTaskGroup'](_0x20cb03,this['groupId'],_0x48526a);const _0x26e292=this['tasks']['filter'](_0x25ac71=>_0x25ac71['groupId']===this['groupId'])['sort']((_0x313164,_0xc3fbfb)=>(_0x313164['groupIndex']??0x0)-(_0xc3fbfb['groupIndex']??0x0)),_0x36c8f2=_0x26e292['findIndex'](_0x1f6254=>_0x1f6254['taskId']===_0x20cb03);_0x36c8f2!==-0x1&&_0x26e292['splice'](_0x36c8f2,0x1),_0x26e292['splice'](_0x48526a,0x0,_0x548852),_0x26e292['forEach']((_0x25d1fe,_0x28b11c)=>{_0x25d1fe['groupIndex']=_0x28b11c;}),this['render'](),this['onGroupChange'](this['tasks']);}}export function initializeTabDragDrop(_0x37c2d5,_0x2a59b0,_0x547318,_0xb4dcdc={}){if(!_0x37c2d5)return;const {onReorder:_0x140c7f,onRemove:_0x4ee092}=_0xb4dcdc,_0x3e942a=_0x37c2d5['querySelectorAll']('.task-tab');_0x3e942a['forEach']((_0xbe2881,_0x3fa3ae)=>{_0xbe2881['setAttribute']('draggable','true'),_0xbe2881['dataset']['index']=_0x3fa3ae,_0xbe2881['addEventListener']('dragstart',_0x8b51be=>{_0x8b51be['dataTransfer']['effectAllowed']='move',_0x8b51be['dataTransfer']['setData']('text/plain',_0xbe2881['dataset']['taskId']),_0xbe2881['classList']['add']('dragging'),_0x37c2d5['classList']['add']('is-dragging');}),_0xbe2881['addEventListener']('dragend',()=>{_0xbe2881['classList']['remove']('dragging'),_0x37c2d5['classList']['remove']('is-dragging'),_0x37c2d5['querySelectorAll']('.drop-indicator')['forEach'](_0x5a875d=>{_0x5a875d['classList']['remove']('drop-indicator','drop-before','drop-after');});}),_0xbe2881['addEventListener']('dragover',_0x5ecf5c=>{_0x5ecf5c['preventDefault'](),_0x5ecf5c['dataTransfer']['dropEffect']='move';if(_0xbe2881['classList']['contains']('dragging'))return;const _0x3d4bf6=_0xbe2881['getBoundingClientRect'](),_0x194d5c=_0x3d4bf6['left']+_0x3d4bf6['width']/0x2,_0x17fc35=_0x5ecf5c['clientX']<_0x194d5c;_0x3e942a['forEach'](_0xb97f39=>_0xb97f39['classList']['remove']('drop-before','drop-after')),_0xbe2881['classList']['add'](_0x17fc35?'drop-before':'drop-after');}),_0xbe2881['addEventListener']('dragleave',()=>{_0xbe2881['classList']['remove']('drop-before','drop-after');}),_0xbe2881['addEventListener']('drop',async _0x4fa8e6=>{_0x4fa8e6['preventDefault']();const _0x5a6327=_0x4fa8e6['dataTransfer']['getData']('text/plain'),_0x207395=_0xbe2881['dataset']['taskId'];if(_0x5a6327===_0x207395)return;const _0x7e4110=_0xbe2881['getBoundingClientRect'](),_0xd13325=_0x4fa8e6['clientX']<_0x7e4110['left']+_0x7e4110['width']/0x2;_0xbe2881['classList']['remove']('drop-before','drop-after'),_0x140c7f&&await _0x140c7f(_0x5a6327,_0x207395,_0xd13325);});});const _0x5215f6=document['createElement']('div');return _0x5215f6['className']='task-tab-remove-zone',_0x5215f6['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',_0x5215f6['style']['display']='none',_0x5215f6['addEventListener']('dragover',_0x46483c=>{_0x46483c['preventDefault'](),_0x5215f6['classList']['add']('drag-over');}),_0x5215f6['addEventListener']('dragleave',()=>{_0x5215f6['classList']['remove']('drag-over');}),_0x5215f6['addEventListener']('drop',async _0x4dc7f6=>{_0x4dc7f6['preventDefault'](),_0x5215f6['classList']['remove']('drag-over');const _0x49f188=_0x4dc7f6['dataTransfer']['getData']('text/plain');_0x4ee092&&await _0x4ee092(_0x49f188);}),_0x37c2d5['addEventListener']('dragstart',()=>{_0x2a59b0['length']>0x1&&(_0x5215f6['style']['display']='flex');}),_0x37c2d5['addEventListener']('dragend',()=>{_0x5215f6['style']['display']='none';}),_0x37c2d5['appendChild'](_0x5215f6),{'destroy':()=>{_0x5215f6['remove']();}};}export default VariantGroupingManager;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@profoundlogic/coderflow-server",
3
- "version": "0.6.2",
3
+ "version": "0.6.4",
4
4
  "description": "AI Coder Server - Manages Docker containers for AI agent task execution",
5
5
  "main": "dist/start.js",
6
6
  "type": "module",
@@ -1,20 +0,0 @@
1
- {
2
- "permissions": {
3
- "allow": [
4
- "Bash(curl:*)",
5
- "Bash(docker run:*)",
6
- "Bash(docker stop:*)",
7
- "Bash(docker logs:*)",
8
- "Bash(docker rm:*)",
9
- "Bash(docker inspect:*)",
10
- "Bash(npm run dev:*)",
11
- "Bash(docker ps:*)",
12
- "Bash(git log:*)",
13
- "Bash(tree:*)",
14
- "Bash(find:*)",
15
- "Bash(grep:*)"
16
- ],
17
- "deny": [],
18
- "ask": []
19
- }
20
- }