@profoundlogic/coderflow-server 0.8.2 → 0.8.3

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/coder-server.js +1 -1
  2. package/dist/config.js +1 -1
  3. package/dist/lib/agent-keepalive.js +1 -1
  4. package/dist/lib/agent-models.js +1 -1
  5. package/dist/lib/api-keys.js +1 -1
  6. package/dist/lib/apiKeys.js +1 -1
  7. package/dist/lib/app-server-ports.js +1 -1
  8. package/dist/lib/auto-judge.js +1 -1
  9. package/dist/lib/automation-service.js +1 -1
  10. package/dist/lib/basic-auth.js +1 -1
  11. package/dist/lib/bindings.js +1 -1
  12. package/dist/lib/build-history.js +1 -1
  13. package/dist/lib/build-output-service.js +1 -1
  14. package/dist/lib/build-scheduler.js +1 -1
  15. package/dist/lib/build-service.js +1 -1
  16. package/dist/lib/ca-certificates.js +1 -1
  17. package/dist/lib/claude-oauth-refresh.js +1 -1
  18. package/dist/lib/cli/build.js +1 -1
  19. package/dist/lib/cli/cleanup-users.js +1 -1
  20. package/dist/lib/cli/config-command.js +1 -1
  21. package/dist/lib/cli/config.js +1 -1
  22. package/dist/lib/cli/create-user.js +1 -1
  23. package/dist/lib/cli/grant-admin.js +1 -1
  24. package/dist/lib/cli/init.js +1 -1
  25. package/dist/lib/cli/jira.js +1 -1
  26. package/dist/lib/cli/license.js +1 -1
  27. package/dist/lib/cli/list-roles.js +1 -1
  28. package/dist/lib/cli/list-users.js +1 -1
  29. package/dist/lib/cli/server-manager.js +1 -1
  30. package/dist/lib/cli/set-password.js +1 -1
  31. package/dist/lib/compression-filter.js +1 -1
  32. package/dist/lib/config-migration.js +1 -1
  33. package/dist/lib/container-credential-sync.js +1 -1
  34. package/dist/lib/container-tokens.js +1 -1
  35. package/dist/lib/data-dir.js +1 -1
  36. package/dist/lib/deployment-history.js +1 -1
  37. package/dist/lib/deployment-service.js +1 -1
  38. package/dist/lib/docker-utils.js +1 -1
  39. package/dist/lib/email.js +1 -1
  40. package/dist/lib/emailTemplates.js +1 -1
  41. package/dist/lib/entitlement.js +1 -1
  42. package/dist/lib/external-connections.js +1 -1
  43. package/dist/lib/fetch-utils.js +1 -1
  44. package/dist/lib/git-commit-details-route.js +1 -1
  45. package/dist/lib/git-history-diff-guardrails.js +1 -1
  46. package/dist/lib/git-provider-service.js +1 -1
  47. package/dist/lib/git-provider-setup/github-setup-handler.js +1 -1
  48. package/dist/lib/git-provider-setup/index.js +1 -1
  49. package/dist/lib/git-provider-setup/setup-factory.js +1 -1
  50. package/dist/lib/git-provider-setup/setup-interface.js +1 -1
  51. package/dist/lib/git-providers/azure-devops-provider.js +1 -1
  52. package/dist/lib/git-providers/github-app-provider.js +1 -1
  53. package/dist/lib/git-providers/index.js +1 -1
  54. package/dist/lib/git-providers/provider-factory.js +1 -1
  55. package/dist/lib/git-providers/provider-interface.js +1 -1
  56. package/dist/lib/github-urls.js +1 -1
  57. package/dist/lib/group-objective-linking.js +1 -1
  58. package/dist/lib/ibmi-sync.js +1 -1
  59. package/dist/lib/jira-client.js +1 -1
  60. package/dist/lib/judge-blinding.js +1 -1
  61. package/dist/lib/logger.js +1 -1
  62. package/dist/lib/memory-utils.js +1 -1
  63. package/dist/lib/migration-to-scoped-rbac.js +1 -1
  64. package/dist/lib/model-fetcher.js +1 -1
  65. package/dist/lib/notifications.js +1 -1
  66. package/dist/lib/objective-context.js +1 -1
  67. package/dist/lib/oidc-auth.js +1 -1
  68. package/dist/lib/oidc-device-flow.js +1 -1
  69. package/dist/lib/passwordTokens.js +1 -1
  70. package/dist/lib/permission-resolver.js +1 -1
  71. package/dist/lib/pin-cascade.js +1 -1
  72. package/dist/lib/provider-accounts.js +1 -1
  73. package/dist/lib/provider-oauth.js +1 -1
  74. package/dist/lib/provider-profile.js +1 -1
  75. package/dist/lib/provider-token-refresh.js +1 -1
  76. package/dist/lib/rbac-user-state.js +1 -1
  77. package/dist/lib/request-url.js +1 -1
  78. package/dist/lib/rewind.js +1 -1
  79. package/dist/lib/role-definitions.js +1 -1
  80. package/dist/lib/roles.js +1 -1
  81. package/dist/lib/secrets.js +1 -1
  82. package/dist/lib/setup-repo-git-auth.js +1 -1
  83. package/dist/lib/state-capture.js +1 -1
  84. package/dist/lib/static-files.js +1 -1
  85. package/dist/lib/task-aliases.js +1 -1
  86. package/dist/lib/task-container-init.js +1 -1
  87. package/dist/lib/task-context-usage.js +1 -1
  88. package/dist/lib/task-name-format.js +1 -1
  89. package/dist/lib/task-name-generator.js +1 -1
  90. package/dist/lib/task-source-metadata.js +1 -1
  91. package/dist/lib/teams.js +1 -1
  92. package/dist/lib/user-git-oauth.js +1 -1
  93. package/dist/lib/user-git-tokens.js +1 -1
  94. package/dist/lib/users.js +1 -1
  95. package/dist/middleware/requireAuth.js +1 -1
  96. package/dist/middleware/requireInit.js +1 -1
  97. package/dist/middleware/requirePermission.js +1 -1
  98. package/dist/package.json +1 -1
  99. package/dist/playwright.config.js +1 -1
  100. package/dist/playwright.task-terminal.config.js +1 -1
  101. package/dist/routes/apiKeys.js +1 -1
  102. package/dist/routes/auth-oidc.js +1 -1
  103. package/dist/routes/auth.js +1 -1
  104. package/dist/routes/automations.js +1 -1
  105. package/dist/routes/bindings.js +1 -1
  106. package/dist/routes/build.js +1 -1
  107. package/dist/routes/containers.js +1 -1
  108. package/dist/routes/deploy-task.js +1 -1
  109. package/dist/routes/environment-management.js +1 -1
  110. package/dist/routes/environments.js +1 -1
  111. package/dist/routes/external-skills.js +1 -1
  112. package/dist/routes/git-credentials.js +1 -1
  113. package/dist/routes/git-oauth.js +1 -1
  114. package/dist/routes/git-provider-setup.js +1 -1
  115. package/dist/routes/health.js +1 -1
  116. package/dist/routes/jira.js +1 -1
  117. package/dist/routes/logs.js +1 -1
  118. package/dist/routes/objective-management.js +1 -1
  119. package/dist/routes/password.js +1 -1
  120. package/dist/routes/prompt.js +1 -1
  121. package/dist/routes/provider-auth.js +1 -1
  122. package/dist/routes/qa.js +1 -1
  123. package/dist/routes/roles.js +1 -1
  124. package/dist/routes/settings.js +1 -1
  125. package/dist/routes/skill-management.js +1 -1
  126. package/dist/routes/skills.js +1 -1
  127. package/dist/routes/stats.js +1 -1
  128. package/dist/routes/tasks.js +1 -1
  129. package/dist/routes/teams.js +1 -1
  130. package/dist/routes/templates.js +1 -1
  131. package/dist/routes/test-task.js +1 -1
  132. package/dist/routes/test.js +1 -1
  133. package/dist/routes/users.js +1 -1
  134. package/dist/routes/visualizations.js +1 -1
  135. package/dist/scripts/create-user.js +1 -1
  136. package/dist/scripts/migrate-config-to-data-dir.js +1 -1
  137. package/dist/start.js +1 -1
  138. package/dist/web-ui/public/activity-detail-modal.js +1 -1
  139. package/dist/web-ui/public/activity-feed.js +1 -1
  140. package/dist/web-ui/public/activity-formatters.js +1 -1
  141. package/dist/web-ui/public/admin.js +1 -1
  142. package/dist/web-ui/public/agent-event-parser.js +1 -1
  143. package/dist/web-ui/public/app.js +1 -1
  144. package/dist/web-ui/public/approve-dialog.js +1 -1
  145. package/dist/web-ui/public/automation-links.js +1 -1
  146. package/dist/web-ui/public/automation-schedule.js +1 -1
  147. package/dist/web-ui/public/comments-widget.js +1 -1
  148. package/dist/web-ui/public/diff-utils.js +1 -1
  149. package/dist/web-ui/public/environments.html +19 -0
  150. package/dist/web-ui/public/environments.js +1 -1
  151. package/dist/web-ui/public/feedback-widget.js +1 -1
  152. package/dist/web-ui/public/file-selection-tree.js +1 -1
  153. package/dist/web-ui/public/git-history-lazy-utils.js +1 -1
  154. package/dist/web-ui/public/git-history.js +1 -1
  155. package/dist/web-ui/public/git-status.js +1 -1
  156. package/dist/web-ui/public/ibmi-file-filter.js +1 -1
  157. package/dist/web-ui/public/index.js +1 -1
  158. package/dist/web-ui/public/login.js +1 -1
  159. package/dist/web-ui/public/markdown-editor.js +1 -1
  160. package/dist/web-ui/public/markdown-file-editor.js +1 -1
  161. package/dist/web-ui/public/modal-maximize.js +1 -1
  162. package/dist/web-ui/public/notifications.js +1 -1
  163. package/dist/web-ui/public/permissions.js +1 -1
  164. package/dist/web-ui/public/pr-dialog.js +1 -1
  165. package/dist/web-ui/public/roles.js +1 -1
  166. package/dist/web-ui/public/settings.js +1 -1
  167. package/dist/web-ui/public/setup-password.js +1 -1
  168. package/dist/web-ui/public/skills.js +1 -1
  169. package/dist/web-ui/public/sse-client.js +1 -1
  170. package/dist/web-ui/public/sse-shared-worker.js +1 -1
  171. package/dist/web-ui/public/styles.css +10 -0
  172. package/dist/web-ui/public/task-judging-helpers.js +1 -1
  173. package/dist/web-ui/public/task.js +1 -1
  174. package/dist/web-ui/public/teams.js +1 -1
  175. package/dist/web-ui/public/terminal.js +1 -1
  176. package/dist/web-ui/public/theme.js +1 -1
  177. package/dist/web-ui/public/users.js +1 -1
  178. package/dist/web-ui/public/variant-grouping.js +1 -1
  179. package/package.json +1 -1
@@ -1 +1 @@
1
- import{API,Utils,initializeAdminMenu}from'./app.js';import{initTheme,mountThemeToggle}from'./theme.js';const state={'teams':[],'users':[],'roles':[],'environments':[],'teamBindings':[],'currentUser':null,'editingTeamId':null,'bindingsTeamId':null,'deletingTeamId':null,'modalSnapshot':null};document['addEventListener']('DOMContentLoaded',async()=>{initTheme(),mountThemeToggle();try{state['currentUser']=await API['getCurrentUser']();}catch{window['location']['href']='login.html';return;}await initializeAdminMenu(state['currentUser']);const _0x6bb8cf=state['currentUser'];if(!Permissions['hasServerPermission'](_0x6bb8cf,'teams:view')&&!Permissions['hasTeamPermission'](_0x6bb8cf,'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'](_0x6bb8cf,'*')||Permissions['hasTeamPermission'](_0x6bb8cf,'teams:manage'))&&(document['getElementById']('create-team-btn')['hidden']=![]),bindEventListeners(),await Promise['all']([loadTeams(),loadUsers(),loadRoles(),loadEnvironments()]),renderTeams();});async function loadTeams(){const _0x29ac69=document['getElementById']('teams-loading'),_0x55930f=document['getElementById']('teams-error'),_0x340e37=document['getElementById']('teams-content');try{_0x29ac69['hidden']=![],_0x55930f['hidden']=!![],_0x340e37['hidden']=!![];const {teams:_0x290cd8}=await API['getTeams']();state['teams']=_0x290cd8||[],renderTeams(),_0x29ac69['hidden']=!![],_0x340e37['hidden']=![];}catch(_0x222efc){_0x29ac69['hidden']=!![],_0x55930f['hidden']=![],document['getElementById']('teams-error-message')['textContent']=_0x222efc['message'];}}async function loadUsers(){try{const {users:_0x2a25b8}=await API['getUsers']();state['users']=_0x2a25b8||[];}catch{state['users']=[];}}async function loadRoles(){try{const {roles:_0x2ac965}=await API['getRoleDefinitions']();state['roles']=_0x2ac965||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x11f0a7=await API['getEnvironments']();state['environments']=_0x11f0a7['environments']||[];}catch{state['environments']=[];}}function renderTeams(){const _0x47dfa4=document['getElementById']('teams-table-body'),_0x3c19f0=document['getElementById']('team-count');if(!_0x47dfa4)return;_0x3c19f0&&(_0x3c19f0['textContent']=state['teams']['length']+'\x20team'+(state['teams']['length']===0x1?'':'s'));if(state['teams']['length']===0x0){_0x47dfa4['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 _0x33de93=Permissions['hasServerPermission'](state['currentUser'],'*');_0x47dfa4['innerHTML']=state['teams']['map'](_0x1468d8=>{const _0x1970da=_0x33de93||_0x1468d8['canManageTeam'],_0x1fce9c=_0x33de93||_0x1468d8['canManageMembers'],_0x5d2f91=_0x1970da||_0x1fce9c,_0x44b237=(_0x1468d8['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'](_0x1468d8['name'])+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x1468d8['description']?'<div\x20style=\x22font-size:\x200.8em;\x20color:\x20var(--color-text-secondary);\x20margin-top:\x200.15rem;\x22>'+Utils['escapeHtml'](_0x1468d8['description'])+'</div>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+_0x44b237+'</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'+(_0x5d2f91?'<button\x20class=\x22btn-icon\x22\x20title=\x22Edit\x20team\x22\x20onclick=\x22window.openTeamModal(\x27'+_0x1468d8['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'+(_0x1970da?'<button\x20class=\x22btn-icon\x22\x20title=\x22Access\x20bindings\x22\x20onclick=\x22window.openBindingsModal(\x27'+_0x1468d8['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'+(_0x1970da?'<button\x20class=\x22btn-icon\x20btn-danger\x22\x20title=\x22Delete\x20team\x22\x20onclick=\x22window.deleteTeam(\x27'+_0x1468d8['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(_0x49190e){const _0x54d124=state['teams']['find'](_0x289546=>_0x289546['id']===_0x49190e);if(!_0x54d124)return;state['editingTeamId']=_0x49190e;const _0x1aece3=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x417fce=_0x1aece3||_0x54d124['canManageTeam'],_0x5d61e8=_0x1aece3||_0x54d124['canManageMembers'],_0x45a596=_0x417fce,_0xad548e=_0x417fce||_0x5d61e8,_0x191765=_0x54d124['name'],_0x60579b=_0x54d124['description']||'';state['modalSnapshot']={'name':_0x191765,'description':_0x60579b},document['getElementById']('team-modal-title')['textContent']=_0x191765,document['getElementById']('team-name')['value']=_0x191765,document['getElementById']('team-name')['disabled']=!_0x45a596,document['getElementById']('team-description')['value']=_0x60579b,document['getElementById']('team-description')['disabled']=!_0x45a596,document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=![],document['getElementById']('save-team')['hidden']=!_0x45a596,renderMembersList(_0x54d124),updateMemberSelect(_0x54d124),document['getElementById']('team-modal')['hidden']=![];};function isTeamModalDirty(){if(!state['modalSnapshot'])return![];const _0x3408e3=document['getElementById']('team-name')['value']['trim'](),_0x2bc502=document['getElementById']('team-description')['value']['trim']();return _0x3408e3!==state['modalSnapshot']['name']||_0x2bc502!==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(_0x43e25b){const _0x3c58b0=state['teams']['find'](_0x422de2=>_0x422de2['id']===_0x43e25b);if(!_0x3c58b0)return;state['bindingsTeamId']=_0x43e25b,document['getElementById']('bindings-modal-title')['textContent']='Access\x20Bindings\x20—\x20'+_0x3c58b0['name'],document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('bindings-modal')['hidden']=![],loadTeamBindings(_0x43e25b);};function hideBindingsModal(){document['getElementById']('bindings-modal')['hidden']=!![],state['bindingsTeamId']=null;}function renderMembersList(_0x330a10){const _0x670f09=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x3f8821=_0x670f09||_0x330a10['canManageMembers']||_0x330a10['canManageTeam'],_0x212fcf=_0x330a10['members']||[],_0x56b329=document['getElementById']('members-list');if(_0x212fcf['length']===0x0){_0x56b329['innerHTML']='<p\x20style=\x22font-size:\x200.875rem;\x20color:\x20var(--color-text-secondary);\x20margin:\x200.25rem\x200;\x22>No\x20members\x20yet</p>';return;}_0x56b329['innerHTML']=_0x212fcf['map'](_0x1ff199=>{const _0x34d920=state['users']['find'](_0x332996=>_0x332996['id']===_0x1ff199),_0x2c7f14=_0x34d920?''+Utils['escapeHtml'](_0x34d920['username'])+(_0x34d920['name']?'\x20<span\x20style=\x22color:\x20var(--color-text-secondary);\x20font-size:\x200.85em;\x22>('+Utils['escapeHtml'](_0x34d920['name'])+')</span>':''):Utils['escapeHtml'](_0x1ff199);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'+_0x2c7f14+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x3f8821?'<button\x20type=\x22button\x22\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.removeMemberClick(\x27'+_0x1ff199+'\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 _0x24f7af=document['getElementById']('add-member-row');if(_0x24f7af)_0x24f7af['style']['display']=_0x3f8821?'flex':'none';}function updateMemberSelect(_0x26bf3f){const _0x15e029=document['getElementById']('add-member-select');if(!_0x15e029)return;const _0x344fdf=new Set(_0x26bf3f['members']||[]),_0x4dbf8b=state['users']['filter'](_0x532503=>!_0x344fdf['has'](_0x532503['id']));_0x15e029['innerHTML']='<option\x20value=\x22\x22>Add\x20a\x20member…</option>'+_0x4dbf8b['map'](_0x302034=>'<option\x20value=\x22'+_0x302034['id']+'\x22>'+Utils['escapeHtml'](_0x302034['username'])+(_0x302034['name']?'\x20('+Utils['escapeHtml'](_0x302034['name'])+')':'')+'</option>')['join']('');}async function addMember(){const _0x10ee8e=document['getElementById']('add-member-select'),_0x42922e=_0x10ee8e['value'];if(!_0x42922e||!state['editingTeamId'])return;try{const {team:_0x1b3d96}=await API['addTeamMember'](state['editingTeamId'],_0x42922e);syncTeamInState(_0x1b3d96),renderMembersList(_0x1b3d96),updateMemberSelect(_0x1b3d96),_0x10ee8e['value']='',Utils['showToast']('Member\x20added','success');}catch(_0x49591e){Utils['showToast'](_0x49591e['message'],'error');}}window['removeMemberClick']=async function(_0x592a49){if(!state['editingTeamId'])return;try{const {team:_0x57b2f4}=await API['removeTeamMember'](state['editingTeamId'],_0x592a49);syncTeamInState(_0x57b2f4),renderMembersList(_0x57b2f4),updateMemberSelect(_0x57b2f4),Utils['showToast']('Member\x20removed','success');}catch(_0x475d58){Utils['showToast'](_0x475d58['message'],'error');}};async function loadTeamBindings(_0x1fc16a){const _0x56d2c4=document['getElementById']('bindings-loading'),_0x230a2f=document['getElementById']('bindings-empty'),_0x56bd88=document['getElementById']('bindings-list-container'),_0x5b645f=document['getElementById']('add-binding-btn');_0x56d2c4['hidden']=![],_0x230a2f['hidden']=!![],_0x56bd88['style']['display']='none',_0x5b645f['hidden']=!![],document['getElementById']('add-binding-form')['hidden']=!![];try{const {bindings:_0x1c1763}=await API['getBindings']({'subject_type':'team','subject_id':_0x1fc16a});state['teamBindings']=_0x1c1763||[],_0x56d2c4['hidden']=!![],state['teamBindings']['length']===0x0?_0x230a2f['hidden']=![]:(_0x56bd88['style']['display']='',renderBindingsTable()),(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage'))&&(_0x5b645f['hidden']=![]);}catch(_0x106a47){_0x56d2c4['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x106a47['message'],'error');}}function renderBindingsTable(){const _0x40c992=document['getElementById']('bindings-table-body');if(!_0x40c992)return;const _0x369211=Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage');_0x40c992['innerHTML']=state['teamBindings']['map'](_0x41a6be=>{const _0x43feb7=_0x41a6be['resource_type']==='server'?'Server':_0x41a6be['resource_id']==='*'?'All\x20'+_0x41a6be['resource_type']+'s':Utils['escapeHtml'](_0x41a6be['resource_name']||_0x41a6be['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x43feb7+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x41a6be['role_name']||_0x41a6be['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x369211?'<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteBindingClick(\x27'+_0x41a6be['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 _0x578062=document['getElementById']('binding-resource-type');_0x578062['value']='environment',updateBindingFormForResourceType('environment');}function onBindingResourceTypeChange(){const _0x305841=document['getElementById']('binding-resource-type')['value'];updateBindingFormForResourceType(_0x305841);}function updateBindingFormForResourceType(_0x24af9f){const _0x164098=document['getElementById']('binding-resource-container'),_0x2acc02=document['getElementById']('binding-resource'),_0x59364f=document['getElementById']('binding-role');if(_0x24af9f==='server')_0x164098['style']['display']='none';else{_0x164098['style']['display']='';if(_0x24af9f==='environment'){const _0x193a2d=new Set(state['teamBindings']['filter'](_0x2bbc87=>_0x2bbc87['resource_type']==='environment')['map'](_0x2ff3d1=>_0x2ff3d1['resource_id'])),_0x1faff6=state['environments']['filter'](_0x285e72=>!_0x193a2d['has'](_0x285e72['name']));_0x2acc02['innerHTML']=_0x1faff6['length']?_0x1faff6['map'](_0x4c3f0d=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x4c3f0d['name'])+'\x22>'+Utils['escapeHtml'](_0x4c3f0d['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x24af9f==='team'){const _0x3cc936=new Set(state['teamBindings']['filter'](_0x390c56=>_0x390c56['resource_type']==='team')['map'](_0x13a683=>_0x13a683['resource_id'])),_0x13fcfd=state['teams']['filter'](_0x1b6597=>!_0x3cc936['has'](_0x1b6597['id']));_0x2acc02['innerHTML']=_0x13fcfd['length']?_0x13fcfd['map'](_0x1eb816=>'<option\x20value=\x22'+_0x1eb816['id']+'\x22>'+Utils['escapeHtml'](_0x1eb816['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x58b70a=state['roles']['filter'](_0x1e4d21=>_0x1e4d21['resource_type']===_0x24af9f);_0x59364f['innerHTML']=_0x58b70a['length']?_0x58b70a['filter'](_0x314094=>{const _0x52c66d=_0x24af9f==='server'?undefined:_0x2acc02['value'];return!state['teamBindings']['some'](_0x2bcee8=>_0x2bcee8['resource_type']===_0x24af9f&&_0x2bcee8['role_id']===_0x314094['id']&&(_0x24af9f==='server'||_0x2bcee8['resource_id']===_0x52c66d));})['map'](_0x538567=>'<option\x20value=\x22'+_0x538567['id']+'\x22>'+Utils['escapeHtml'](_0x538567['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 _0x3b63a8=document['getElementById']('binding-resource-type')['value'],_0x5eebc4=document['getElementById']('binding-role')['value'];if(!_0x5eebc4||!state['bindingsTeamId'])return;const _0x1dae64=_0x3b63a8==='server'?undefined:document['getElementById']('binding-resource')['value'];if(_0x3b63a8!=='server'&&!_0x1dae64)return;const _0x5b29ba=document['getElementById']('save-binding-btn');_0x5b29ba['disabled']=!![],_0x5b29ba['textContent']='Adding…';try{const _0x57b2aa={'subject_type':'team','subject_id':state['bindingsTeamId'],'role_id':_0x5eebc4,'resource_type':_0x3b63a8};if(_0x1dae64)_0x57b2aa['resource_id']=_0x1dae64;await API['createBinding'](_0x57b2aa),Utils['showToast']('Binding\x20added','success'),document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![],await loadTeamBindings(state['bindingsTeamId']);}catch(_0x410920){Utils['showToast'](_0x410920['message'],'error');}finally{_0x5b29ba['disabled']=![],_0x5b29ba['textContent']='Add\x20Binding';}}window['deleteBindingClick']=async function(_0x25fdae){try{await API['deleteBinding'](_0x25fdae),Utils['showToast']('Binding\x20removed','success'),await loadTeamBindings(state['bindingsTeamId']);}catch(_0x2df3c7){Utils['showToast'](_0x2df3c7['message'],'error');}};async function saveTeam(){const _0x189b35=document['getElementById']('team-name')['value']['trim'](),_0x392377=document['getElementById']('team-description')['value']['trim'](),_0x24841e=document['getElementById']('team-form-error'),_0x21a5b4=document['getElementById']('save-team');if(!_0x189b35){_0x24841e['textContent']='Team\x20name\x20is\x20required',_0x24841e['hidden']=![];return;}_0x24841e['hidden']=!![];const _0x3161b6=_0x21a5b4['textContent'];_0x21a5b4['disabled']=!![],_0x21a5b4['textContent']=state['editingTeamId']?'Saving…':'Creating…';try{if(state['editingTeamId']){const {team:_0x3cdf1b}=await API['updateTeam'](state['editingTeamId'],{'name':_0x189b35,'description':_0x392377});syncTeamInState(_0x3cdf1b),document['getElementById']('team-modal-title')['textContent']=_0x3cdf1b['name'],Utils['showToast']('Team\x20updated','success');}else await API['createTeam']({'name':_0x189b35,'description':_0x392377}),Utils['showToast']('Team\x20created','success');_0x21a5b4['disabled']=![],_0x21a5b4['textContent']=_0x3161b6,hideTeamModal(),await loadTeams();}catch(_0x15365b){_0x24841e['textContent']=_0x15365b['message'],_0x24841e['hidden']=![],_0x21a5b4['disabled']=![],_0x21a5b4['textContent']=_0x3161b6;}}window['deleteTeam']=function(_0x51c284){const _0x4b7fbe=state['teams']['find'](_0x58316d=>_0x58316d['id']===_0x51c284);if(!_0x4b7fbe)return;state['deletingTeamId']=_0x51c284,document['getElementById']('delete-team-name')['textContent']=_0x4b7fbe['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 _0x6289d2=document['getElementById']('confirm-delete-team');_0x6289d2['disabled']=!![],_0x6289d2['textContent']='Deleting…';try{await API['deleteTeam'](state['deletingTeamId']),Utils['showToast']('Team\x20deleted','success'),_0x6289d2['disabled']=![],_0x6289d2['textContent']='Delete\x20Team',hideDeleteModal(),await loadTeams();}catch(_0x441809){Utils['showToast']('Failed\x20to\x20delete\x20team:\x20'+_0x441809['message'],'error'),_0x6289d2['disabled']=![],_0x6289d2['textContent']='Delete\x20Team';}}function syncTeamInState(_0x309926){const _0x815d5d=state['teams']['findIndex'](_0x47ffb8=>_0x47ffb8['id']===_0x309926['id']);if(_0x815d5d>=0x0)state['teams'][_0x815d5d]=_0x309926;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 _0x20abf6=state['currentUser'];if(!Permissions['hasServerPermission'](_0x20abf6,'teams:view')&&!Permissions['hasTeamPermission'](_0x20abf6,'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'](_0x20abf6,'*')||Permissions['hasTeamPermission'](_0x20abf6,'teams:manage'))&&(document['getElementById']('create-team-btn')['hidden']=![]),bindEventListeners(),await Promise['all']([loadTeams(),loadUsers(),loadRoles(),loadEnvironments()]),renderTeams();});async function loadTeams(){const _0x31172a=document['getElementById']('teams-loading'),_0x475382=document['getElementById']('teams-error'),_0x5f3b34=document['getElementById']('teams-content');try{_0x31172a['hidden']=![],_0x475382['hidden']=!![],_0x5f3b34['hidden']=!![];const {teams:_0x3f077d}=await API['getTeams']();state['teams']=_0x3f077d||[],renderTeams(),_0x31172a['hidden']=!![],_0x5f3b34['hidden']=![];}catch(_0x4d45cf){_0x31172a['hidden']=!![],_0x475382['hidden']=![],document['getElementById']('teams-error-message')['textContent']=_0x4d45cf['message'];}}async function loadUsers(){try{const {users:_0x562e2e}=await API['getUsers']();state['users']=_0x562e2e||[];}catch{state['users']=[];}}async function loadRoles(){try{const {roles:_0x531005}=await API['getRoleDefinitions']();state['roles']=_0x531005||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x1937a9=await API['getEnvironments']();state['environments']=_0x1937a9['environments']||[];}catch{state['environments']=[];}}function renderTeams(){const _0x42258a=document['getElementById']('teams-table-body'),_0x178ed3=document['getElementById']('team-count');if(!_0x42258a)return;_0x178ed3&&(_0x178ed3['textContent']=state['teams']['length']+'\x20team'+(state['teams']['length']===0x1?'':'s'));if(state['teams']['length']===0x0){_0x42258a['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 _0x4e98e1=Permissions['hasServerPermission'](state['currentUser'],'*');_0x42258a['innerHTML']=state['teams']['map'](_0xb4d659=>{const _0x424be7=_0x4e98e1||_0xb4d659['canManageTeam'],_0x349467=_0x4e98e1||_0xb4d659['canManageMembers'],_0xf84625=_0x424be7||_0x349467,_0x32613c=(_0xb4d659['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'](_0xb4d659['name'])+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0xb4d659['description']?'<div\x20style=\x22font-size:\x200.8em;\x20color:\x20var(--color-text-secondary);\x20margin-top:\x200.15rem;\x22>'+Utils['escapeHtml'](_0xb4d659['description'])+'</div>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+_0x32613c+'</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'+(_0xf84625?'<button\x20class=\x22btn-icon\x22\x20title=\x22Edit\x20team\x22\x20onclick=\x22window.openTeamModal(\x27'+_0xb4d659['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'+(_0x424be7?'<button\x20class=\x22btn-icon\x22\x20title=\x22Access\x20bindings\x22\x20onclick=\x22window.openBindingsModal(\x27'+_0xb4d659['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'+(_0x424be7?'<button\x20class=\x22btn-icon\x20btn-danger\x22\x20title=\x22Delete\x20team\x22\x20onclick=\x22window.deleteTeam(\x27'+_0xb4d659['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(_0x517cdc){const _0x159557=state['teams']['find'](_0x1fe932=>_0x1fe932['id']===_0x517cdc);if(!_0x159557)return;state['editingTeamId']=_0x517cdc;const _0x35a5ff=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x59152d=_0x35a5ff||_0x159557['canManageTeam'],_0x284031=_0x35a5ff||_0x159557['canManageMembers'],_0x1e3ba0=_0x59152d,_0x522ab4=_0x59152d||_0x284031,_0x5a96f1=_0x159557['name'],_0x264230=_0x159557['description']||'';state['modalSnapshot']={'name':_0x5a96f1,'description':_0x264230},document['getElementById']('team-modal-title')['textContent']=_0x5a96f1,document['getElementById']('team-name')['value']=_0x5a96f1,document['getElementById']('team-name')['disabled']=!_0x1e3ba0,document['getElementById']('team-description')['value']=_0x264230,document['getElementById']('team-description')['disabled']=!_0x1e3ba0,document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=![],document['getElementById']('save-team')['hidden']=!_0x1e3ba0,renderMembersList(_0x159557),updateMemberSelect(_0x159557),document['getElementById']('team-modal')['hidden']=![];};function isTeamModalDirty(){if(!state['modalSnapshot'])return![];const _0x1bd92e=document['getElementById']('team-name')['value']['trim'](),_0x2a6eef=document['getElementById']('team-description')['value']['trim']();return _0x1bd92e!==state['modalSnapshot']['name']||_0x2a6eef!==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(_0x1d812f){const _0x30d476=state['teams']['find'](_0x1f5b04=>_0x1f5b04['id']===_0x1d812f);if(!_0x30d476)return;state['bindingsTeamId']=_0x1d812f,document['getElementById']('bindings-modal-title')['textContent']='Access\x20Bindings\x20—\x20'+_0x30d476['name'],document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('bindings-modal')['hidden']=![],loadTeamBindings(_0x1d812f);};function hideBindingsModal(){document['getElementById']('bindings-modal')['hidden']=!![],state['bindingsTeamId']=null;}function renderMembersList(_0x5016d3){const _0x2a57f2=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x359499=_0x2a57f2||_0x5016d3['canManageMembers']||_0x5016d3['canManageTeam'],_0x513d8a=_0x5016d3['members']||[],_0x26cff9=document['getElementById']('members-list');if(_0x513d8a['length']===0x0){_0x26cff9['innerHTML']='<p\x20style=\x22font-size:\x200.875rem;\x20color:\x20var(--color-text-secondary);\x20margin:\x200.25rem\x200;\x22>No\x20members\x20yet</p>';return;}_0x26cff9['innerHTML']=_0x513d8a['map'](_0xab5156=>{const _0x58c615=state['users']['find'](_0x38ff1a=>_0x38ff1a['id']===_0xab5156),_0x4766f6=_0x58c615?''+Utils['escapeHtml'](_0x58c615['username'])+(_0x58c615['name']?'\x20<span\x20style=\x22color:\x20var(--color-text-secondary);\x20font-size:\x200.85em;\x22>('+Utils['escapeHtml'](_0x58c615['name'])+')</span>':''):Utils['escapeHtml'](_0xab5156);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'+_0x4766f6+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x359499?'<button\x20type=\x22button\x22\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.removeMemberClick(\x27'+_0xab5156+'\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 _0xf148aa=document['getElementById']('add-member-row');if(_0xf148aa)_0xf148aa['style']['display']=_0x359499?'flex':'none';}function updateMemberSelect(_0x3d3868){const _0x3e9635=document['getElementById']('add-member-select');if(!_0x3e9635)return;const _0x209752=new Set(_0x3d3868['members']||[]),_0x307dc5=state['users']['filter'](_0xb334f4=>!_0x209752['has'](_0xb334f4['id']));_0x3e9635['innerHTML']='<option\x20value=\x22\x22>Add\x20a\x20member…</option>'+_0x307dc5['map'](_0x2402d7=>'<option\x20value=\x22'+_0x2402d7['id']+'\x22>'+Utils['escapeHtml'](_0x2402d7['username'])+(_0x2402d7['name']?'\x20('+Utils['escapeHtml'](_0x2402d7['name'])+')':'')+'</option>')['join']('');}async function addMember(){const _0x57bee5=document['getElementById']('add-member-select'),_0x232617=_0x57bee5['value'];if(!_0x232617||!state['editingTeamId'])return;try{const {team:_0x23f888}=await API['addTeamMember'](state['editingTeamId'],_0x232617);syncTeamInState(_0x23f888),renderMembersList(_0x23f888),updateMemberSelect(_0x23f888),_0x57bee5['value']='',Utils['showToast']('Member\x20added','success');}catch(_0x10bf01){Utils['showToast'](_0x10bf01['message'],'error');}}window['removeMemberClick']=async function(_0xd0366c){if(!state['editingTeamId'])return;try{const {team:_0x4e8b65}=await API['removeTeamMember'](state['editingTeamId'],_0xd0366c);syncTeamInState(_0x4e8b65),renderMembersList(_0x4e8b65),updateMemberSelect(_0x4e8b65),Utils['showToast']('Member\x20removed','success');}catch(_0x111e76){Utils['showToast'](_0x111e76['message'],'error');}};async function loadTeamBindings(_0x195800){const _0x247e29=document['getElementById']('bindings-loading'),_0x43df41=document['getElementById']('bindings-empty'),_0x1ad50d=document['getElementById']('bindings-list-container'),_0x5d7b3c=document['getElementById']('add-binding-btn');_0x247e29['hidden']=![],_0x43df41['hidden']=!![],_0x1ad50d['style']['display']='none',_0x5d7b3c['hidden']=!![],document['getElementById']('add-binding-form')['hidden']=!![];try{const {bindings:_0x10a076}=await API['getBindings']({'subject_type':'team','subject_id':_0x195800});state['teamBindings']=_0x10a076||[],_0x247e29['hidden']=!![],state['teamBindings']['length']===0x0?_0x43df41['hidden']=![]:(_0x1ad50d['style']['display']='',renderBindingsTable()),(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage'))&&(_0x5d7b3c['hidden']=![]);}catch(_0x52bc95){_0x247e29['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x52bc95['message'],'error');}}function renderBindingsTable(){const _0x4fe21c=document['getElementById']('bindings-table-body');if(!_0x4fe21c)return;const _0x2c5ca1=Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage');_0x4fe21c['innerHTML']=state['teamBindings']['map'](_0x3666f7=>{const _0x15a06a=_0x3666f7['resource_type']==='server'?'Server':_0x3666f7['resource_id']==='*'?'All\x20'+_0x3666f7['resource_type']+'s':Utils['escapeHtml'](_0x3666f7['resource_name']||_0x3666f7['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x15a06a+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x3666f7['role_name']||_0x3666f7['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x2c5ca1?'<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteBindingClick(\x27'+_0x3666f7['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 _0x433b83=document['getElementById']('binding-resource-type');_0x433b83['value']='environment',updateBindingFormForResourceType('environment');}function onBindingResourceTypeChange(){const _0x3c1c0d=document['getElementById']('binding-resource-type')['value'];updateBindingFormForResourceType(_0x3c1c0d);}function updateBindingFormForResourceType(_0x200727){const _0x2168a9=document['getElementById']('binding-resource-container'),_0x1e422e=document['getElementById']('binding-resource'),_0x1c21bd=document['getElementById']('binding-role');if(_0x200727==='server')_0x2168a9['style']['display']='none';else{_0x2168a9['style']['display']='';if(_0x200727==='environment'){const _0x4f893b=new Set(state['teamBindings']['filter'](_0x2d3b00=>_0x2d3b00['resource_type']==='environment')['map'](_0x434a10=>_0x434a10['resource_id'])),_0x18612a=state['environments']['filter'](_0x283a9a=>!_0x4f893b['has'](_0x283a9a['name']));_0x1e422e['innerHTML']=_0x18612a['length']?_0x18612a['map'](_0x2e2e26=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x2e2e26['name'])+'\x22>'+Utils['escapeHtml'](_0x2e2e26['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x200727==='team'){const _0x22eed1=new Set(state['teamBindings']['filter'](_0x223386=>_0x223386['resource_type']==='team')['map'](_0x3afac4=>_0x3afac4['resource_id'])),_0x11f6be=state['teams']['filter'](_0xa48aff=>!_0x22eed1['has'](_0xa48aff['id']));_0x1e422e['innerHTML']=_0x11f6be['length']?_0x11f6be['map'](_0x1fd816=>'<option\x20value=\x22'+_0x1fd816['id']+'\x22>'+Utils['escapeHtml'](_0x1fd816['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x486243=state['roles']['filter'](_0x13e459=>_0x13e459['resource_type']===_0x200727);_0x1c21bd['innerHTML']=_0x486243['length']?_0x486243['filter'](_0x26f43d=>{const _0x12a845=_0x200727==='server'?undefined:_0x1e422e['value'];return!state['teamBindings']['some'](_0x23f81d=>_0x23f81d['resource_type']===_0x200727&&_0x23f81d['role_id']===_0x26f43d['id']&&(_0x200727==='server'||_0x23f81d['resource_id']===_0x12a845));})['map'](_0x33c6b7=>'<option\x20value=\x22'+_0x33c6b7['id']+'\x22>'+Utils['escapeHtml'](_0x33c6b7['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 _0x244dbd=document['getElementById']('binding-resource-type')['value'],_0x3d062d=document['getElementById']('binding-role')['value'];if(!_0x3d062d||!state['bindingsTeamId'])return;const _0x232c0f=_0x244dbd==='server'?undefined:document['getElementById']('binding-resource')['value'];if(_0x244dbd!=='server'&&!_0x232c0f)return;const _0x1995cd=document['getElementById']('save-binding-btn');_0x1995cd['disabled']=!![],_0x1995cd['textContent']='Adding…';try{const _0x5204be={'subject_type':'team','subject_id':state['bindingsTeamId'],'role_id':_0x3d062d,'resource_type':_0x244dbd};if(_0x232c0f)_0x5204be['resource_id']=_0x232c0f;await API['createBinding'](_0x5204be),Utils['showToast']('Binding\x20added','success'),document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![],await loadTeamBindings(state['bindingsTeamId']);}catch(_0x1d667b){Utils['showToast'](_0x1d667b['message'],'error');}finally{_0x1995cd['disabled']=![],_0x1995cd['textContent']='Add\x20Binding';}}window['deleteBindingClick']=async function(_0x1a40a5){try{await API['deleteBinding'](_0x1a40a5),Utils['showToast']('Binding\x20removed','success'),await loadTeamBindings(state['bindingsTeamId']);}catch(_0x359630){Utils['showToast'](_0x359630['message'],'error');}};async function saveTeam(){const _0x22d871=document['getElementById']('team-name')['value']['trim'](),_0x233bb3=document['getElementById']('team-description')['value']['trim'](),_0x2a3fe5=document['getElementById']('team-form-error'),_0x1e9922=document['getElementById']('save-team');if(!_0x22d871){_0x2a3fe5['textContent']='Team\x20name\x20is\x20required',_0x2a3fe5['hidden']=![];return;}_0x2a3fe5['hidden']=!![];const _0xc6d98d=_0x1e9922['textContent'];_0x1e9922['disabled']=!![],_0x1e9922['textContent']=state['editingTeamId']?'Saving…':'Creating…';try{if(state['editingTeamId']){const {team:_0x54444d}=await API['updateTeam'](state['editingTeamId'],{'name':_0x22d871,'description':_0x233bb3});syncTeamInState(_0x54444d),document['getElementById']('team-modal-title')['textContent']=_0x54444d['name'],Utils['showToast']('Team\x20updated','success');}else await API['createTeam']({'name':_0x22d871,'description':_0x233bb3}),Utils['showToast']('Team\x20created','success');_0x1e9922['disabled']=![],_0x1e9922['textContent']=_0xc6d98d,hideTeamModal(),await loadTeams();}catch(_0x370e78){_0x2a3fe5['textContent']=_0x370e78['message'],_0x2a3fe5['hidden']=![],_0x1e9922['disabled']=![],_0x1e9922['textContent']=_0xc6d98d;}}window['deleteTeam']=function(_0x9fe3f4){const _0x320f63=state['teams']['find'](_0x5bfbc9=>_0x5bfbc9['id']===_0x9fe3f4);if(!_0x320f63)return;state['deletingTeamId']=_0x9fe3f4,document['getElementById']('delete-team-name')['textContent']=_0x320f63['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 _0x18c4df=document['getElementById']('confirm-delete-team');_0x18c4df['disabled']=!![],_0x18c4df['textContent']='Deleting…';try{await API['deleteTeam'](state['deletingTeamId']),Utils['showToast']('Team\x20deleted','success'),_0x18c4df['disabled']=![],_0x18c4df['textContent']='Delete\x20Team',hideDeleteModal(),await loadTeams();}catch(_0x37f90a){Utils['showToast']('Failed\x20to\x20delete\x20team:\x20'+_0x37f90a['message'],'error'),_0x18c4df['disabled']=![],_0x18c4df['textContent']='Delete\x20Team';}}function syncTeamInState(_0x45f114){const _0x12198e=state['teams']['findIndex'](_0x214245=>_0x214245['id']===_0x45f114['id']);if(_0x12198e>=0x0)state['teams'][_0x12198e]=_0x45f114;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'](_0x5e82a4=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':_0x5e82a4}));});let commandSent=![],hasReceivedOutput=![];socket['addEventListener']('message',_0x35279e=>{try{const _0x14cd98=JSON['parse'](_0x35279e['data']);if(_0x14cd98['type']==='data'&&typeof _0x14cd98['data']==='string')term['write'](_0x14cd98['data']),!hasReceivedOutput&&_0x14cd98['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(_0x14cd98['type']==='status'&&_0x14cd98['status']){if(_0x14cd98['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'+_0x14cd98['status'],_0x14cd98['status']==='connected'?'success':'info');}else _0x14cd98['type']==='error'&&_0x14cd98['message']&&updateStatus(_0x14cd98['message'],'error');}}catch(_0x3433ba){console['error']('Failed\x20to\x20parse\x20terminal\x20message',_0x3433ba);}}),socket['addEventListener']('close',_0x5b8987=>{const _0x56bca6=_0x5b8987['reason']||'Connection\x20closed';updateStatus(_0x56bca6,_0x5b8987['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',_0x2741d9=>{console['error']('Terminal\x20websocket\x20error',_0x2741d9),updateStatus('Connection\x20error','error');});function sendResize(){if(socket['readyState']!==WebSocket['OPEN'])return;const _0xa248b5=term['cols'],_0x47d531=term['rows'];socket['send'](JSON['stringify']({'type':'resize','cols':_0xa248b5,'rows':_0x47d531}));}function updateStatus(_0x1b8a08,_0x1ccf96='info'){if(!statusEl)return;statusEl['textContent']=_0x1b8a08,statusEl['dataset']['variant']=_0x1ccf96;}async function enrichContainerDetails(_0x40f014){try{const _0x3d5010=await API['getContainer'](_0x40f014);updateTerminalDetails(_0x3d5010);}catch{try{const _0x5e1aeb=await API['getContainers'](),_0x34f5c2=(_0x5e1aeb['containers']||[])['find'](_0x11351a=>_0x11351a['containerId']===_0x40f014||_0x11351a['name']===_0x40f014||_0x11351a['fullContainerId']?.['startsWith'](_0x40f014));if(_0x34f5c2){updateTerminalDetails(_0x34f5c2);return;}subtitleEl['textContent']='Container\x20'+_0x40f014['substring'](0x0,0xc);}catch{subtitleEl['textContent']='Container\x20'+_0x40f014['substring'](0x0,0xc);}}}function updateTerminalDetails(_0x46d968){const _0x12c6da=_0x46d968['containerId']||_0x46d968['name']||_0x46d968['fullContainerId']||containerId,_0xbcc062=_0x46d968['environment']?'Environment\x20'+_0x46d968['environment']:'Environment\x20unknown',_0x3212fa=_0x46d968['defaultAgent']?'\x20·\x20Agent\x20'+_0x46d968['defaultAgent']:'',_0x8cfe12=_0x46d968['createdAt']?'\x20·\x20Started\x20'+Utils['formatRelativeTime'](_0x46d968['createdAt']):'';titleEl['textContent']='Terminal\x20·\x20'+_0x12c6da['substring'](0x0,0xc);const _0x2290e7=command?'\x20·\x20Command\x20'+command:'';subtitleEl['textContent']=''+_0xbcc062+_0x3212fa+_0x8cfe12+_0x2290e7;}
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'](_0x310e17=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':_0x310e17}));});let commandSent=![],hasReceivedOutput=![];socket['addEventListener']('message',_0x5b9662=>{try{const _0x2c02c3=JSON['parse'](_0x5b9662['data']);if(_0x2c02c3['type']==='data'&&typeof _0x2c02c3['data']==='string')term['write'](_0x2c02c3['data']),!hasReceivedOutput&&_0x2c02c3['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(_0x2c02c3['type']==='status'&&_0x2c02c3['status']){if(_0x2c02c3['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'+_0x2c02c3['status'],_0x2c02c3['status']==='connected'?'success':'info');}else _0x2c02c3['type']==='error'&&_0x2c02c3['message']&&updateStatus(_0x2c02c3['message'],'error');}}catch(_0x230679){console['error']('Failed\x20to\x20parse\x20terminal\x20message',_0x230679);}}),socket['addEventListener']('close',_0x19bf4a=>{const _0x3b7f0b=_0x19bf4a['reason']||'Connection\x20closed';updateStatus(_0x3b7f0b,_0x19bf4a['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',_0x4acaf4=>{console['error']('Terminal\x20websocket\x20error',_0x4acaf4),updateStatus('Connection\x20error','error');});function sendResize(){if(socket['readyState']!==WebSocket['OPEN'])return;const _0x1ded10=term['cols'],_0x2de60b=term['rows'];socket['send'](JSON['stringify']({'type':'resize','cols':_0x1ded10,'rows':_0x2de60b}));}function updateStatus(_0x373782,_0x52ebef='info'){if(!statusEl)return;statusEl['textContent']=_0x373782,statusEl['dataset']['variant']=_0x52ebef;}async function enrichContainerDetails(_0x461200){try{const _0x2357f0=await API['getContainer'](_0x461200);updateTerminalDetails(_0x2357f0);}catch{try{const _0x22b68e=await API['getContainers'](),_0x5cfda8=(_0x22b68e['containers']||[])['find'](_0x2f47d9=>_0x2f47d9['containerId']===_0x461200||_0x2f47d9['name']===_0x461200||_0x2f47d9['fullContainerId']?.['startsWith'](_0x461200));if(_0x5cfda8){updateTerminalDetails(_0x5cfda8);return;}subtitleEl['textContent']='Container\x20'+_0x461200['substring'](0x0,0xc);}catch{subtitleEl['textContent']='Container\x20'+_0x461200['substring'](0x0,0xc);}}}function updateTerminalDetails(_0x564d29){const _0x1bbb0e=_0x564d29['containerId']||_0x564d29['name']||_0x564d29['fullContainerId']||containerId,_0x34b2c3=_0x564d29['environment']?'Environment\x20'+_0x564d29['environment']:'Environment\x20unknown',_0x1535c3=_0x564d29['defaultAgent']?'\x20·\x20Agent\x20'+_0x564d29['defaultAgent']:'',_0x2a237a=_0x564d29['createdAt']?'\x20·\x20Started\x20'+Utils['formatRelativeTime'](_0x564d29['createdAt']):'';titleEl['textContent']='Terminal\x20·\x20'+_0x1bbb0e['substring'](0x0,0xc);const _0x43c3ff=command?'\x20·\x20Command\x20'+command:'';subtitleEl['textContent']=''+_0x34b2c3+_0x1535c3+_0x2a237a+_0x43c3ff;}
@@ -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 _0x3b1482=localStorage['getItem'](THEME_STORAGE_KEY);if(_0x3b1482&&VALID_THEMES['has'](_0x3b1482))return _0x3b1482;}catch(_0x4e1fd9){console['warn']('[Theme]\x20Failed\x20to\x20read\x20stored\x20theme\x20preference:',_0x4e1fd9);}return null;}export function getPreferredTheme(){const _0x1a0549=readStoredTheme();if(_0x1a0549)return _0x1a0549;const _0x4807ac=window['matchMedia']&&window['matchMedia']('(prefers-color-scheme:\x20dark)')['matches'];return _0x4807ac?'dark':'light';}export function getCurrentTheme(){const _0x162251=document['documentElement']['dataset']['theme'];if(_0x162251&&VALID_THEMES['has'](_0x162251))return _0x162251;return getPreferredTheme();}export function applyTheme(_0x19584b,{persist:persist=!![],emitEvent:emitEvent=!![]}={}){const _0x2eb4e4=VALID_THEMES['has'](_0x19584b)?_0x19584b:'light';document['documentElement']['dataset']['theme']=_0x2eb4e4,document['documentElement']['style']['colorScheme']=_0x2eb4e4==='dark'?'dark':'light';if(persist)try{localStorage['setItem'](THEME_STORAGE_KEY,_0x2eb4e4);}catch(_0x34f6ba){console['warn']('[Theme]\x20Failed\x20to\x20persist\x20theme\x20preference:',_0x34f6ba);}return emitEvent&&window['dispatchEvent'](new CustomEvent(THEME_CHANGE_EVENT,{'detail':{'theme':_0x2eb4e4}})),_0x2eb4e4;}export function initTheme(_0x2117c6={}){const {emitEvent:emitEvent=![]}=_0x2117c6;return applyTheme(getPreferredTheme(),{'persist':![],'emitEvent':emitEvent});}export function toggleTheme(){const _0xd40d1a=getCurrentTheme()==='dark'?'light':'dark';return applyTheme(_0xd40d1a);}export function onThemeChange(_0x54ab79,{runImmediately:runImmediately=![]}={}){const _0x316d8=_0x171844=>{_0x54ab79(_0x171844['detail']['theme']);};return window['addEventListener'](THEME_CHANGE_EVENT,_0x316d8),runImmediately&&_0x54ab79(getCurrentTheme()),()=>window['removeEventListener'](THEME_CHANGE_EVENT,_0x316d8);}export function mountThemeToggle(_0x4f79b2={}){const {targetSelectors:targetSelectors=DEFAULT_TARGET_SELECTORS}=_0x4f79b2,_0x1aefd8=targetSelectors['map'](_0x1451cf=>document['querySelector'](_0x1451cf))['find'](Boolean),_0x44e8cf=document['createElement']('button');_0x44e8cf['type']='button',_0x44e8cf['className']='btn-ghost\x20theme-toggle-btn',_0x44e8cf['id']='theme-toggle-btn',_0x44e8cf['setAttribute']('aria-pressed','false'),_0x44e8cf['style']['padding']='8px',_0x44e8cf['style']['lineHeight']='0',_0x44e8cf['style']['width']='36px',_0x44e8cf['style']['height']='36px',_0x44e8cf['style']['display']='flex',_0x44e8cf['style']['alignItems']='center',_0x44e8cf['style']['justifyContent']='center';const _0x22504a=document['createElement']('span');_0x22504a['className']='theme-icon',_0x22504a['style']['display']='flex',_0x44e8cf['append'](_0x22504a);const _0x3b0b4b='<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>',_0x3ec6cb='<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>',_0x2a06ae=_0x250b9e=>{const _0x5ede16=_0x250b9e==='dark';_0x22504a['innerHTML']=_0x5ede16?_0x3b0b4b:_0x3ec6cb,_0x44e8cf['title']=_0x5ede16?'Switch\x20to\x20light\x20mode':'Switch\x20to\x20dark\x20mode',_0x44e8cf['dataset']['theme']=_0x250b9e,_0x44e8cf['setAttribute']('aria-pressed',String(_0x5ede16));};return _0x44e8cf['addEventListener']('click',()=>{const _0x5f240b=getCurrentTheme()==='dark'?'light':'dark';applyTheme(_0x5f240b);}),_0x1aefd8?_0x1aefd8['appendChild'](_0x44e8cf):(_0x44e8cf['classList']['add']('theme-toggle-floating'),document['body']['appendChild'](_0x44e8cf)),_0x2a06ae(initTheme()),onThemeChange(_0x2a06ae),_0x44e8cf;}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 _0x3fb854=localStorage['getItem'](THEME_STORAGE_KEY);if(_0x3fb854&&VALID_THEMES['has'](_0x3fb854))return _0x3fb854;}catch(_0x50079a){console['warn']('[Theme]\x20Failed\x20to\x20read\x20stored\x20theme\x20preference:',_0x50079a);}return null;}export function getPreferredTheme(){const _0x3b5c9a=readStoredTheme();if(_0x3b5c9a)return _0x3b5c9a;const _0x23d529=window['matchMedia']&&window['matchMedia']('(prefers-color-scheme:\x20dark)')['matches'];return _0x23d529?'dark':'light';}export function getCurrentTheme(){const _0x474b0f=document['documentElement']['dataset']['theme'];if(_0x474b0f&&VALID_THEMES['has'](_0x474b0f))return _0x474b0f;return getPreferredTheme();}export function applyTheme(_0x4826c5,{persist:persist=!![],emitEvent:emitEvent=!![]}={}){const _0x239c19=VALID_THEMES['has'](_0x4826c5)?_0x4826c5:'light';document['documentElement']['dataset']['theme']=_0x239c19,document['documentElement']['style']['colorScheme']=_0x239c19==='dark'?'dark':'light';if(persist)try{localStorage['setItem'](THEME_STORAGE_KEY,_0x239c19);}catch(_0x318b37){console['warn']('[Theme]\x20Failed\x20to\x20persist\x20theme\x20preference:',_0x318b37);}return emitEvent&&window['dispatchEvent'](new CustomEvent(THEME_CHANGE_EVENT,{'detail':{'theme':_0x239c19}})),_0x239c19;}export function initTheme(_0x590d70={}){const {emitEvent:emitEvent=![]}=_0x590d70;return applyTheme(getPreferredTheme(),{'persist':![],'emitEvent':emitEvent});}export function toggleTheme(){const _0x3a003b=getCurrentTheme()==='dark'?'light':'dark';return applyTheme(_0x3a003b);}export function onThemeChange(_0x5e37c6,{runImmediately:runImmediately=![]}={}){const _0x4d2a5b=_0x44d164=>{_0x5e37c6(_0x44d164['detail']['theme']);};return window['addEventListener'](THEME_CHANGE_EVENT,_0x4d2a5b),runImmediately&&_0x5e37c6(getCurrentTheme()),()=>window['removeEventListener'](THEME_CHANGE_EVENT,_0x4d2a5b);}export function mountThemeToggle(_0x374c46={}){const {targetSelectors:targetSelectors=DEFAULT_TARGET_SELECTORS}=_0x374c46,_0x127779=targetSelectors['map'](_0x25612d=>document['querySelector'](_0x25612d))['find'](Boolean),_0x344638=document['createElement']('button');_0x344638['type']='button',_0x344638['className']='btn-ghost\x20theme-toggle-btn',_0x344638['id']='theme-toggle-btn',_0x344638['setAttribute']('aria-pressed','false'),_0x344638['style']['padding']='8px',_0x344638['style']['lineHeight']='0',_0x344638['style']['width']='36px',_0x344638['style']['height']='36px',_0x344638['style']['display']='flex',_0x344638['style']['alignItems']='center',_0x344638['style']['justifyContent']='center';const _0xac2aee=document['createElement']('span');_0xac2aee['className']='theme-icon',_0xac2aee['style']['display']='flex',_0x344638['append'](_0xac2aee);const _0x13a4e1='<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>',_0x57da1d='<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>',_0x2b2cd9=_0x3c374d=>{const _0x319a62=_0x3c374d==='dark';_0xac2aee['innerHTML']=_0x319a62?_0x13a4e1:_0x57da1d,_0x344638['title']=_0x319a62?'Switch\x20to\x20light\x20mode':'Switch\x20to\x20dark\x20mode',_0x344638['dataset']['theme']=_0x3c374d,_0x344638['setAttribute']('aria-pressed',String(_0x319a62));};return _0x344638['addEventListener']('click',()=>{const _0x3cd64f=getCurrentTheme()==='dark'?'light':'dark';applyTheme(_0x3cd64f);}),_0x127779?_0x127779['appendChild'](_0x344638):(_0x344638['classList']['add']('theme-toggle-floating'),document['body']['appendChild'](_0x344638)),_0x2b2cd9(initTheme()),onThemeChange(_0x2b2cd9),_0x344638;}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 _0x696b2c=await API['getCurrentUser']();state['currentUser']=_0x696b2c;if(!Permissions['hasServerPermission'](_0x696b2c,'*')&&!Permissions['hasServerPermission'](_0x696b2c,'users:create')){Utils['showToast']('Access\x20denied:\x20Server\x20admin\x20privileges\x20required','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}}catch(_0x7f35){window['location']['href']='login.html';}}async function checkEmailConfig(){try{const _0x4ea4d6=await API['getEmailConfig']();state['emailConfigured']=_0x4ea4d6['configured'];}catch(_0x231f7a){console['error']('Failed\x20to\x20check\x20email\x20config',_0x231f7a),state['emailConfigured']=![];}}async function loadRoles(){try{const {roles:_0x2239bb}=await API['getRoleDefinitions']();state['roles']=_0x2239bb||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x47f496=await API['getEnvironments']();state['environments']=_0x47f496['environments']||[];}catch{state['environments']=[];}}async function loadTeams(){try{const {teams:_0x139014}=await API['getTeams']();state['teams']=_0x139014||[];}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 _0x1f96cd=document['getElementById']('users-loading'),_0x3f36d1=document['getElementById']('users-error'),_0x111e9b=document['getElementById']('users-content');try{_0x1f96cd['hidden']=![],_0x3f36d1['hidden']=!![],_0x111e9b['hidden']=!![];const _0xa966c5=await API['getUsers']();state['users']=_0xa966c5['users']||[],renderUsers(),_0x1f96cd['hidden']=!![],_0x111e9b['hidden']=![];}catch(_0x501386){console['error']('Failed\x20to\x20load\x20users',_0x501386),_0x1f96cd['hidden']=!![],_0x3f36d1['hidden']=![],document['getElementById']('users-error-message')['textContent']=_0x501386['message'];}}function renderUsers(){const _0x4f95eb=document['getElementById']('users-table-body'),_0x5c86e0=document['getElementById']('user-count');if(!_0x4f95eb)return;_0x5c86e0&&(_0x5c86e0['textContent']=state['users']['length']+'\x20user'+(state['users']['length']===0x1?'':'s'));const _0x3fae69=[...state['users']]['sort']((_0x4f77fa,_0x55fedb)=>{const _0x1b1838=new Date(_0x4f77fa['created_at'])['getTime'](),_0x1e00e5=new Date(_0x55fedb['created_at'])['getTime']();return _0x1e00e5-_0x1b1838;});_0x4f95eb['innerHTML']=_0x3fae69['map'](_0x16d94b=>'\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'](_0x16d94b['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'](_0x16d94b['name'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x16d94b['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'+(_0x16d94b['isServerAdmin']?'<span\x20class=\x22role-badge\x20role-admin\x22>Server\x20Admin</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x16d94b['hasUserBinding']?'<span\x20class=\x22role-badge\x20role-user-binding\x22>User\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x16d94b['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'](_0x16d94b['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'+_0x16d94b['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'+_0x16d94b['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'+_0x16d94b['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'+_0x16d94b['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(_0x4c5c5f){const _0xc95f34=state['users']['find'](_0x516f46=>_0x516f46['id']===_0x4c5c5f);if(!_0xc95f34)return;state['bindingsUserId']=_0x4c5c5f,state['bindingsDirty']=![];const _0x2c9f0e=document['getElementById']('bindings-modal'),_0x4ae57f=document['getElementById']('bindings-modal-title');_0x4ae57f['textContent']='Access\x20Bindings\x20—\x20'+_0xc95f34['name'],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],_0x2c9f0e['hidden']=![],loadUserBindings(_0x4c5c5f);};function hasUnsavedBindingChanges(){const _0x34300e=document['getElementById']('add-user-binding-form');return _0x34300e&&!_0x34300e['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 _0x47f62c=document['getElementById']('bindings-modal');_0x47f62c['hidden']=!![];const _0x434f45=state['bindingsDirty'];state['bindingsUserId']=null,state['userBindings']=[],state['bindingsDirty']=![],_0x434f45&&await loadUsers();}async function loadUserBindings(_0x58c63c){const _0x3e8c44=document['getElementById']('user-bindings-loading'),_0x42da78=document['getElementById']('user-bindings-empty'),_0x294270=document['getElementById']('user-bindings-list-container'),_0xd66806=document['getElementById']('add-user-binding-btn'),_0xde04f7=document['getElementById']('user-team-bindings-note'),_0x3bebc9=document['getElementById']('user-team-bindings-text');_0x3e8c44['hidden']=![],_0x42da78['hidden']=!![],_0x294270['style']['display']='none',_0xd66806['hidden']=!![],_0xde04f7['hidden']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![];try{const [_0x373ab3,_0x184c93]=await Promise['all']([API['getBindings']({'subject_type':'user','subject_id':_0x58c63c}),API['getTeams']()]);state['userBindings']=_0x373ab3['bindings']||[];const _0x51c469=(_0x184c93['teams']||[])['filter'](_0x504a1b=>(_0x504a1b['members']||[])['includes'](_0x58c63c)),_0x4738a6=[];if(_0x51c469['length']>0x0){const _0x4e93de=await Promise['all'](_0x51c469['map'](_0x24985c=>API['getBindings']({'subject_type':'team','subject_id':_0x24985c['id']})));for(let _0x153715=0x0;_0x153715<_0x51c469['length'];_0x153715++){const _0x4f55da=_0x4e93de[_0x153715]['bindings']||[];_0x4f55da['length']>0x0&&_0x4738a6['push'](_0x51c469[_0x153715]);}}_0x3e8c44['hidden']=!![];state['userBindings']['length']===0x0?_0x42da78['hidden']=![]:(_0x294270['style']['display']='',renderUserBindingsTable());if(_0x4738a6['length']>0x0){const _0x47b204=_0x4738a6['map'](_0x14f5a3=>_0x14f5a3['name']),_0x34f5ac=_0x47b204['length']<=0x3?_0x47b204['join'](',\x20'):_0x47b204['slice'](0x0,0x3)['join'](',\x20')+(',\x20and\x20'+(_0x47b204['length']-0x3)+'\x20more');_0x3bebc9['textContent']='This\x20user\x20also\x20has\x20access\x20via\x20team\x20memberships\x20('+_0x34f5ac+').';}else _0x3bebc9['textContent']='This\x20user\x20has\x20no\x20access\x20via\x20team\x20memberships.';_0xde04f7['hidden']=![],_0xd66806['hidden']=![];}catch(_0x57b100){_0x3e8c44['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x57b100['message'],'error');}}function renderUserBindingsTable(){const _0x348804=document['getElementById']('user-bindings-table-body');if(!_0x348804)return;_0x348804['innerHTML']=state['userBindings']['map'](_0x187d40=>{const _0x1d2cbf=_0x187d40['resource_type']==='server'?'Server':_0x187d40['resource_id']==='*'?'All\x20'+_0x187d40['resource_type']+'s':Utils['escapeHtml'](_0x187d40['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x1d2cbf+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x187d40['role_name']||_0x187d40['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'+_0x187d40['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 _0x3a8fe9=document['getElementById']('user-binding-resource-type');_0x3a8fe9['value']='environment',updateUserBindingFormForResourceType('environment');}function onUserBindingResourceTypeChange(){const _0x2652a3=document['getElementById']('user-binding-resource-type')['value'];updateUserBindingFormForResourceType(_0x2652a3);}function updateUserBindingFormForResourceType(_0xc5f96b){const _0x430d3f=document['getElementById']('user-binding-resource-container'),_0x3a0bb8=document['getElementById']('user-binding-resource'),_0x5e73aa=document['getElementById']('user-binding-role');if(_0xc5f96b==='server')_0x430d3f['style']['display']='none';else{_0x430d3f['style']['display']='';if(_0xc5f96b==='environment'){const _0x195913=new Set(state['userBindings']['filter'](_0x383b03=>_0x383b03['resource_type']==='environment')['map'](_0x29e7f4=>_0x29e7f4['resource_id'])),_0x5164d1=state['environments']['filter'](_0x2d0323=>!_0x195913['has'](_0x2d0323['name']));_0x3a0bb8['innerHTML']=_0x5164d1['length']?_0x5164d1['map'](_0x4b7e37=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x4b7e37['name'])+'\x22>'+Utils['escapeHtml'](_0x4b7e37['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0xc5f96b==='team'){const _0x4b6788=new Set(state['userBindings']['filter'](_0x354c69=>_0x354c69['resource_type']==='team')['map'](_0x1f58c8=>_0x1f58c8['resource_id'])),_0x3d855f=state['teams']['filter'](_0x2af245=>!_0x4b6788['has'](_0x2af245['id']));_0x3a0bb8['innerHTML']=_0x3d855f['length']?_0x3d855f['map'](_0x4b8867=>'<option\x20value=\x22'+_0x4b8867['id']+'\x22>'+Utils['escapeHtml'](_0x4b8867['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x2c17e7=state['roles']['filter'](_0x3676b2=>_0x3676b2['resource_type']===_0xc5f96b);_0x5e73aa['innerHTML']=_0x2c17e7['length']?_0x2c17e7['filter'](_0x150683=>{const _0x35c325=_0xc5f96b==='server'?undefined:_0x3a0bb8['value'];return!state['userBindings']['some'](_0x5002bb=>_0x5002bb['resource_type']===_0xc5f96b&&_0x5002bb['role_id']===_0x150683['id']&&(_0xc5f96b==='server'||_0x5002bb['resource_id']===_0x35c325));})['map'](_0xda7814=>'<option\x20value=\x22'+_0xda7814['id']+'\x22>'+Utils['escapeHtml'](_0xda7814['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 _0x11502b=document['getElementById']('user-binding-resource-type')['value'],_0x5804d3=document['getElementById']('user-binding-role')['value'];if(!_0x5804d3||!state['bindingsUserId'])return;const _0x557485=_0x11502b==='server'?undefined:document['getElementById']('user-binding-resource')['value'];if(_0x11502b!=='server'&&!_0x557485)return;const _0x50193d=document['getElementById']('save-user-binding-btn');_0x50193d['disabled']=!![],_0x50193d['textContent']='Adding…';try{const _0x21a2e4={'subject_type':'user','subject_id':state['bindingsUserId'],'role_id':_0x5804d3,'resource_type':_0x11502b};if(_0x557485)_0x21a2e4['resource_id']=_0x557485;await API['createBinding'](_0x21a2e4),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(_0x2cae1b){Utils['showToast'](_0x2cae1b['message'],'error');}finally{_0x50193d['disabled']=![],_0x50193d['textContent']='Add\x20Binding';}}window['deleteUserBindingClick']=async function(_0x359a04){try{await API['deleteBinding'](_0x359a04),Utils['showToast']('Binding\x20removed','success'),state['bindingsDirty']=!![],await loadUserBindings(state['bindingsUserId']);}catch(_0x4de5ec){Utils['showToast'](_0x4de5ec['message'],'error');}};function showCreateUserModal(){state['editingUserId']=null;const _0x355215=document['getElementById']('user-modal'),_0x37ff24=document['getElementById']('modal-title'),_0x24007c=document['getElementById']('user-password'),_0x1be0dd=document['getElementById']('password-required'),_0x9b3acc=document['getElementById']('password-hint'),_0x36fbd9=document['getElementById']('skip-password-container'),_0x57a342=document['getElementById']('skip-password');_0x37ff24['textContent']='Create\x20User',document['getElementById']('user-form')['reset'](),_0x24007c['required']=!![];if(_0x1be0dd)_0x1be0dd['textContent']='*';_0x36fbd9&&(_0x36fbd9['style']['display']='block',_0x57a342['checked']=![]),_0x9b3acc&&(_0x9b3acc['textContent']='Minimum\x208\x20characters'),_0x355215['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);}window['editUser']=function(_0x514070){const _0x2772ba=state['users']['find'](_0x13d45b=>_0x13d45b['id']===_0x514070);if(!_0x2772ba)return;state['editingUserId']=_0x514070;const _0x5e913d=document['getElementById']('user-modal'),_0x27dea9=document['getElementById']('modal-title'),_0x1f1163=document['getElementById']('user-password'),_0x34e77f=document['getElementById']('password-required'),_0x1e30a9=document['getElementById']('password-hint'),_0x53dfd3=document['getElementById']('skip-password-container');_0x27dea9['textContent']='Edit\x20User',document['getElementById']('user-username')['value']=_0x2772ba['username'],document['getElementById']('user-name')['value']=_0x2772ba['name'],document['getElementById']('user-email')['value']=_0x2772ba['email'],_0x1f1163['value']='',_0x1f1163['required']=![];if(_0x34e77f)_0x34e77f['textContent']='';_0x53dfd3&&(_0x53dfd3['style']['display']='none'),_0x1e30a9&&(_0x1e30a9['textContent']='Leave\x20blank\x20to\x20keep\x20current\x20password'),_0x5e913d['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);};function hideUserModal(){const _0x3550c9=document['getElementById']('user-modal'),_0x1bd8bd=document['getElementById']('form-error'),_0xf5d892=document['getElementById']('save-user');_0x3550c9['hidden']=!![],_0x1bd8bd['hidden']=!![],state['editingUserId']=null,_0xf5d892&&(_0xf5d892['disabled']=![],_0xf5d892['textContent']='Save\x20User');}async function saveUser(){const _0x409568=document['getElementById']('user-form'),_0x2d92ea=document['getElementById']('skip-password')?.['checked']||![];if(!_0x2d92ea&&!_0x409568['checkValidity']()){_0x409568['reportValidity']();return;}const _0x4e2ad0=document['getElementById']('form-error'),_0x28196a=document['getElementById']('save-user'),_0x3210e6=document['getElementById']('user-username')['value']['trim'](),_0x43efb3=document['getElementById']('user-name')['value']['trim'](),_0x2896eb=document['getElementById']('user-email')['value']['trim'](),_0x2b5ea3=document['getElementById']('user-password')['value'];if(!_0x3210e6||!_0x43efb3||!_0x2896eb){_0x4e2ad0['textContent']='Please\x20fill\x20in\x20all\x20required\x20fields',_0x4e2ad0['hidden']=![],_0x4e2ad0['scrollIntoView']({'behavior':'smooth','block':'nearest'});return;}_0x4e2ad0['hidden']=!![];const _0x27a378=_0x28196a['textContent'];_0x28196a['disabled']=!![],_0x28196a['textContent']=state['editingUserId']?'Updating...':'Creating...';try{if(state['editingUserId']){const _0x367e73={'username':_0x3210e6,'name':_0x43efb3,'email':_0x2896eb};_0x2b5ea3&&(_0x367e73['password']=_0x2b5ea3),await API['updateUser'](state['editingUserId'],_0x367e73),Utils['showToast']('User\x20updated\x20successfully','success'),await loadUsers(),hideUserModal();}else{const _0xb7aaf7={'username':_0x3210e6,'name':_0x43efb3,'email':_0x2896eb};if(!_0x2d92ea){if(!_0x2b5ea3)throw new Error('Password\x20is\x20required\x20for\x20new\x20users');_0xb7aaf7['password']=_0x2b5ea3;}const _0x94ee17=await API['createUser'](_0xb7aaf7),_0x267e4c=_0x94ee17['user'];if(_0x2d92ea||!_0x2b5ea3){const _0x3e75dc=await API['createPasswordToken'](_0x267e4c['id'],'setup',![]);state['setupLinkData']={'username':_0x267e4c['username'],'email':_0x267e4c['email'],'url':_0x3e75dc['token']['setupUrl'],'userId':_0x267e4c['id'],'type':'setup','emailSent':![]},await loadUsers(),hideUserModal(),showSetupLinkModal();}else Utils['showToast']('User\x20created\x20successfully','success'),await loadUsers(),hideUserModal();}}catch(_0x2dc33b){console['error']('Failed\x20to\x20save\x20user',_0x2dc33b),_0x4e2ad0['textContent']=_0x2dc33b['message'],_0x4e2ad0['hidden']=![],_0x4e2ad0['scrollIntoView']({'behavior':'smooth','block':'nearest'}),_0x28196a['disabled']=![],_0x28196a['textContent']=_0x27a378;}}window['deleteUser']=function(_0x56cea1){const _0x3c3300=state['users']['find'](_0x42698d=>_0x42698d['id']===_0x56cea1);if(!_0x3c3300)return;state['deletingUserId']=_0x56cea1;const _0x5b7b2f=document['getElementById']('delete-modal'),_0x43ac2e=document['getElementById']('delete-user-name');_0x43ac2e['textContent']=_0x3c3300['name']+'\x20('+_0x3c3300['username']+')',_0x5b7b2f['hidden']=![];};function hideDeleteModal(){const _0x4d6dd3=document['getElementById']('delete-modal');_0x4d6dd3['hidden']=!![],state['deletingUserId']=null;const _0x417300=document['getElementById']('confirm-delete');_0x417300&&(_0x417300['disabled']=![],_0x417300['textContent']='Delete\x20User');}async function confirmDeleteUser(){if(!state['deletingUserId'])return;const _0x48fc69=document['getElementById']('confirm-delete'),_0x2b562e=_0x48fc69['textContent'];_0x48fc69['disabled']=!![],_0x48fc69['textContent']='Deleting...';try{await API['deleteUser'](state['deletingUserId']),Utils['showToast']('User\x20deleted\x20successfully','success'),await loadUsers(),hideDeleteModal();}catch(_0x52d067){console['error']('Failed\x20to\x20delete\x20user',_0x52d067),Utils['showToast']('Failed\x20to\x20delete\x20user:\x20'+_0x52d067['message'],'error'),_0x48fc69['disabled']=![],_0x48fc69['textContent']=_0x2b562e;}}function handleSkipPasswordChange(_0xc30075){const _0x36f1f8=document['getElementById']('user-password'),_0x29b247=_0xc30075['target']['checked'];_0x29b247?(_0x36f1f8['required']=![],_0x36f1f8['disabled']=!![],_0x36f1f8['value']=''):(_0x36f1f8['required']=!![],_0x36f1f8['disabled']=![]);}function showSetupLinkModal(){if(!state['setupLinkData'])return;const _0x49233d=document['getElementById']('setup-link-modal'),_0x5e6787=document['getElementById']('setup-link-username'),_0x4a5f3a=document['getElementById']('setup-link-url'),_0x1ba528=document['getElementById']('email-setup-link'),_0x3a577f=document['getElementById']('email-button-text');_0x5e6787['textContent']=state['setupLinkData']['username'],_0x4a5f3a['textContent']=state['setupLinkData']['url'],_0x1ba528&&_0x3a577f&&(_0x1ba528['disabled']=![],_0x3a577f['textContent']='Email\x20Link',state['emailConfigured']&&!state['setupLinkData']['emailSent']?_0x1ba528['style']['display']='inline-block':_0x1ba528['style']['display']='none'),_0x49233d['hidden']=![];}function hideSetupLinkModal(){const _0x166434=document['getElementById']('setup-link-modal');_0x166434['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(_0x378298){console['error']('Failed\x20to\x20copy\x20link',_0x378298),Utils['showToast']('Failed\x20to\x20copy\x20link','error');}}async function emailSetupLink(){if(!state['setupLinkData'])return;const _0x51e3cc=document['getElementById']('email-setup-link'),_0x37b4c2=document['getElementById']('email-button-text');if(!_0x51e3cc||!_0x37b4c2)return;const _0x121152=_0x37b4c2['textContent'];_0x51e3cc['disabled']=!![],_0x37b4c2['textContent']='Sending...';try{const _0x56b1a8=await API['createPasswordToken'](state['setupLinkData']['userId'],state['setupLinkData']['type'],!![]);if(_0x56b1a8['emailSent'])Utils['showToast']('Email\x20sent\x20to\x20'+state['setupLinkData']['email'],'success'),state['setupLinkData']['emailSent']=!![],_0x51e3cc['style']['display']='none';else{const _0x4d7fe5=_0x56b1a8['emailError']||'Failed\x20to\x20send\x20email';Utils['showToast'](_0x4d7fe5,'error'),_0x51e3cc['disabled']=![],_0x37b4c2['textContent']=_0x121152;}}catch(_0x1d8b1d){console['error']('Failed\x20to\x20email\x20setup\x20link',_0x1d8b1d),Utils['showToast']('Failed\x20to\x20send\x20email:\x20'+_0x1d8b1d['message'],'error'),_0x51e3cc['disabled']=![],_0x37b4c2['textContent']=_0x121152;}}window['resetPassword']=async function(_0x26598b){const _0x504b8d=state['users']['find'](_0x528524=>_0x528524['id']===_0x26598b);if(!_0x504b8d)return;const _0x44cf61=await ConfirmDialog['show']({'title':'Reset\x20Password','message':'Generate\x20a\x20password\x20reset\x20link\x20for\x20'+_0x504b8d['name']+'\x20('+_0x504b8d['username']+')?\x20This\x20will\x20create\x20a\x20link\x20that\x20they\x20can\x20use\x20to\x20set\x20a\x20new\x20password.','confirmText':'Generate\x20Link'});if(!_0x44cf61)return;try{const _0x53a1cb=await API['createPasswordToken'](_0x26598b,'reset',![]);state['setupLinkData']={'username':_0x504b8d['username'],'email':_0x504b8d['email'],'url':_0x53a1cb['token']['setupUrl'],'userId':_0x504b8d['id'],'type':'reset','emailSent':![]},showSetupLinkModal();}catch(_0x28a0cf){console['error']('Failed\x20to\x20create\x20password\x20reset\x20link',_0x28a0cf),Utils['showToast']('Failed\x20to\x20create\x20password\x20reset\x20link:\x20'+_0x28a0cf['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 _0x5243c1=await API['getCurrentUser']();state['currentUser']=_0x5243c1;if(!Permissions['hasServerPermission'](_0x5243c1,'*')&&!Permissions['hasServerPermission'](_0x5243c1,'users:create')){Utils['showToast']('Access\x20denied:\x20Server\x20admin\x20privileges\x20required','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}}catch(_0x372b00){window['location']['href']='login.html';}}async function checkEmailConfig(){try{const _0x4a25ec=await API['getEmailConfig']();state['emailConfigured']=_0x4a25ec['configured'];}catch(_0x142803){console['error']('Failed\x20to\x20check\x20email\x20config',_0x142803),state['emailConfigured']=![];}}async function loadRoles(){try{const {roles:_0x2ab620}=await API['getRoleDefinitions']();state['roles']=_0x2ab620||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x36bc7d=await API['getEnvironments']();state['environments']=_0x36bc7d['environments']||[];}catch{state['environments']=[];}}async function loadTeams(){try{const {teams:_0x361a94}=await API['getTeams']();state['teams']=_0x361a94||[];}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 _0x255d01=document['getElementById']('users-loading'),_0x53e18d=document['getElementById']('users-error'),_0x2b73ec=document['getElementById']('users-content');try{_0x255d01['hidden']=![],_0x53e18d['hidden']=!![],_0x2b73ec['hidden']=!![];const _0x1293eb=await API['getUsers']();state['users']=_0x1293eb['users']||[],renderUsers(),_0x255d01['hidden']=!![],_0x2b73ec['hidden']=![];}catch(_0x4d519b){console['error']('Failed\x20to\x20load\x20users',_0x4d519b),_0x255d01['hidden']=!![],_0x53e18d['hidden']=![],document['getElementById']('users-error-message')['textContent']=_0x4d519b['message'];}}function renderUsers(){const _0x5c9c2c=document['getElementById']('users-table-body'),_0x360883=document['getElementById']('user-count');if(!_0x5c9c2c)return;_0x360883&&(_0x360883['textContent']=state['users']['length']+'\x20user'+(state['users']['length']===0x1?'':'s'));const _0x350983=[...state['users']]['sort']((_0x42219e,_0x2a0e1)=>{const _0x15366f=new Date(_0x42219e['created_at'])['getTime'](),_0x415a90=new Date(_0x2a0e1['created_at'])['getTime']();return _0x415a90-_0x15366f;});_0x5c9c2c['innerHTML']=_0x350983['map'](_0x436b69=>'\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'](_0x436b69['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'](_0x436b69['name'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x436b69['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'+(_0x436b69['isServerAdmin']?'<span\x20class=\x22role-badge\x20role-admin\x22>Server\x20Admin</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x436b69['hasUserBinding']?'<span\x20class=\x22role-badge\x20role-user-binding\x22>User\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x436b69['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'](_0x436b69['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'+_0x436b69['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'+_0x436b69['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'+_0x436b69['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'+_0x436b69['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(_0xdaa249){const _0x3a311b=state['users']['find'](_0x6d3b06=>_0x6d3b06['id']===_0xdaa249);if(!_0x3a311b)return;state['bindingsUserId']=_0xdaa249,state['bindingsDirty']=![];const _0x2c7899=document['getElementById']('bindings-modal'),_0x44456f=document['getElementById']('bindings-modal-title');_0x44456f['textContent']='Access\x20Bindings\x20—\x20'+_0x3a311b['name'],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],_0x2c7899['hidden']=![],loadUserBindings(_0xdaa249);};function hasUnsavedBindingChanges(){const _0x28a1dd=document['getElementById']('add-user-binding-form');return _0x28a1dd&&!_0x28a1dd['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 _0x515807=document['getElementById']('bindings-modal');_0x515807['hidden']=!![];const _0x3a5706=state['bindingsDirty'];state['bindingsUserId']=null,state['userBindings']=[],state['bindingsDirty']=![],_0x3a5706&&await loadUsers();}async function loadUserBindings(_0xa8cbe2){const _0x5441d7=document['getElementById']('user-bindings-loading'),_0xc87b43=document['getElementById']('user-bindings-empty'),_0x255041=document['getElementById']('user-bindings-list-container'),_0x568271=document['getElementById']('add-user-binding-btn'),_0x556bd0=document['getElementById']('user-team-bindings-note'),_0x213545=document['getElementById']('user-team-bindings-text');_0x5441d7['hidden']=![],_0xc87b43['hidden']=!![],_0x255041['style']['display']='none',_0x568271['hidden']=!![],_0x556bd0['hidden']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![];try{const [_0x16c7a7,_0x4d46a0]=await Promise['all']([API['getBindings']({'subject_type':'user','subject_id':_0xa8cbe2}),API['getTeams']()]);state['userBindings']=_0x16c7a7['bindings']||[];const _0x1f528a=(_0x4d46a0['teams']||[])['filter'](_0x5f0e1f=>(_0x5f0e1f['members']||[])['includes'](_0xa8cbe2)),_0x2aeb83=[];if(_0x1f528a['length']>0x0){const _0x1510f5=await Promise['all'](_0x1f528a['map'](_0xe6d4d=>API['getBindings']({'subject_type':'team','subject_id':_0xe6d4d['id']})));for(let _0x401d21=0x0;_0x401d21<_0x1f528a['length'];_0x401d21++){const _0x240a83=_0x1510f5[_0x401d21]['bindings']||[];_0x240a83['length']>0x0&&_0x2aeb83['push'](_0x1f528a[_0x401d21]);}}_0x5441d7['hidden']=!![];state['userBindings']['length']===0x0?_0xc87b43['hidden']=![]:(_0x255041['style']['display']='',renderUserBindingsTable());if(_0x2aeb83['length']>0x0){const _0x374cde=_0x2aeb83['map'](_0x8bf811=>_0x8bf811['name']),_0x41005c=_0x374cde['length']<=0x3?_0x374cde['join'](',\x20'):_0x374cde['slice'](0x0,0x3)['join'](',\x20')+(',\x20and\x20'+(_0x374cde['length']-0x3)+'\x20more');_0x213545['textContent']='This\x20user\x20also\x20has\x20access\x20via\x20team\x20memberships\x20('+_0x41005c+').';}else _0x213545['textContent']='This\x20user\x20has\x20no\x20access\x20via\x20team\x20memberships.';_0x556bd0['hidden']=![],_0x568271['hidden']=![];}catch(_0x558456){_0x5441d7['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x558456['message'],'error');}}function renderUserBindingsTable(){const _0x24915f=document['getElementById']('user-bindings-table-body');if(!_0x24915f)return;_0x24915f['innerHTML']=state['userBindings']['map'](_0x3853c4=>{const _0x5ab7dc=_0x3853c4['resource_type']==='server'?'Server':_0x3853c4['resource_id']==='*'?'All\x20'+_0x3853c4['resource_type']+'s':Utils['escapeHtml'](_0x3853c4['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x5ab7dc+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x3853c4['role_name']||_0x3853c4['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'+_0x3853c4['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 _0x441175=document['getElementById']('user-binding-resource-type');_0x441175['value']='environment',updateUserBindingFormForResourceType('environment');}function onUserBindingResourceTypeChange(){const _0x43585b=document['getElementById']('user-binding-resource-type')['value'];updateUserBindingFormForResourceType(_0x43585b);}function updateUserBindingFormForResourceType(_0x584bc3){const _0x5866b7=document['getElementById']('user-binding-resource-container'),_0x3a44ac=document['getElementById']('user-binding-resource'),_0x3767f3=document['getElementById']('user-binding-role');if(_0x584bc3==='server')_0x5866b7['style']['display']='none';else{_0x5866b7['style']['display']='';if(_0x584bc3==='environment'){const _0x105f64=new Set(state['userBindings']['filter'](_0x350791=>_0x350791['resource_type']==='environment')['map'](_0xd02c5d=>_0xd02c5d['resource_id'])),_0x2cbbc9=state['environments']['filter'](_0x27ee46=>!_0x105f64['has'](_0x27ee46['name']));_0x3a44ac['innerHTML']=_0x2cbbc9['length']?_0x2cbbc9['map'](_0x5194a1=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x5194a1['name'])+'\x22>'+Utils['escapeHtml'](_0x5194a1['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x584bc3==='team'){const _0xe06873=new Set(state['userBindings']['filter'](_0x2d538e=>_0x2d538e['resource_type']==='team')['map'](_0x28bd19=>_0x28bd19['resource_id'])),_0xe2fd19=state['teams']['filter'](_0x442b94=>!_0xe06873['has'](_0x442b94['id']));_0x3a44ac['innerHTML']=_0xe2fd19['length']?_0xe2fd19['map'](_0x2b4868=>'<option\x20value=\x22'+_0x2b4868['id']+'\x22>'+Utils['escapeHtml'](_0x2b4868['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x4a473f=state['roles']['filter'](_0x2a8fc9=>_0x2a8fc9['resource_type']===_0x584bc3);_0x3767f3['innerHTML']=_0x4a473f['length']?_0x4a473f['filter'](_0x5533f4=>{const _0x1d4bf7=_0x584bc3==='server'?undefined:_0x3a44ac['value'];return!state['userBindings']['some'](_0x249cfb=>_0x249cfb['resource_type']===_0x584bc3&&_0x249cfb['role_id']===_0x5533f4['id']&&(_0x584bc3==='server'||_0x249cfb['resource_id']===_0x1d4bf7));})['map'](_0x5bb569=>'<option\x20value=\x22'+_0x5bb569['id']+'\x22>'+Utils['escapeHtml'](_0x5bb569['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 _0x29e7d0=document['getElementById']('user-binding-resource-type')['value'],_0x377982=document['getElementById']('user-binding-role')['value'];if(!_0x377982||!state['bindingsUserId'])return;const _0x17d4b6=_0x29e7d0==='server'?undefined:document['getElementById']('user-binding-resource')['value'];if(_0x29e7d0!=='server'&&!_0x17d4b6)return;const _0x2d1a1e=document['getElementById']('save-user-binding-btn');_0x2d1a1e['disabled']=!![],_0x2d1a1e['textContent']='Adding…';try{const _0x22bdc7={'subject_type':'user','subject_id':state['bindingsUserId'],'role_id':_0x377982,'resource_type':_0x29e7d0};if(_0x17d4b6)_0x22bdc7['resource_id']=_0x17d4b6;await API['createBinding'](_0x22bdc7),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(_0x4cffb0){Utils['showToast'](_0x4cffb0['message'],'error');}finally{_0x2d1a1e['disabled']=![],_0x2d1a1e['textContent']='Add\x20Binding';}}window['deleteUserBindingClick']=async function(_0x528ef8){try{await API['deleteBinding'](_0x528ef8),Utils['showToast']('Binding\x20removed','success'),state['bindingsDirty']=!![],await loadUserBindings(state['bindingsUserId']);}catch(_0xe96fe2){Utils['showToast'](_0xe96fe2['message'],'error');}};function showCreateUserModal(){state['editingUserId']=null;const _0x613049=document['getElementById']('user-modal'),_0xd2c5c=document['getElementById']('modal-title'),_0x537b6e=document['getElementById']('user-password'),_0x4ffeec=document['getElementById']('password-required'),_0x47e2d5=document['getElementById']('password-hint'),_0x5a24a1=document['getElementById']('skip-password-container'),_0x3ba6ff=document['getElementById']('skip-password');_0xd2c5c['textContent']='Create\x20User',document['getElementById']('user-form')['reset'](),_0x537b6e['required']=!![];if(_0x4ffeec)_0x4ffeec['textContent']='*';_0x5a24a1&&(_0x5a24a1['style']['display']='block',_0x3ba6ff['checked']=![]),_0x47e2d5&&(_0x47e2d5['textContent']='Minimum\x208\x20characters'),_0x613049['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);}window['editUser']=function(_0x4135f8){const _0x3a9c55=state['users']['find'](_0x19855f=>_0x19855f['id']===_0x4135f8);if(!_0x3a9c55)return;state['editingUserId']=_0x4135f8;const _0x1faf76=document['getElementById']('user-modal'),_0x1e7b3d=document['getElementById']('modal-title'),_0x82dcc4=document['getElementById']('user-password'),_0x5c979f=document['getElementById']('password-required'),_0x58f9a7=document['getElementById']('password-hint'),_0x34a0ad=document['getElementById']('skip-password-container');_0x1e7b3d['textContent']='Edit\x20User',document['getElementById']('user-username')['value']=_0x3a9c55['username'],document['getElementById']('user-name')['value']=_0x3a9c55['name'],document['getElementById']('user-email')['value']=_0x3a9c55['email'],_0x82dcc4['value']='',_0x82dcc4['required']=![];if(_0x5c979f)_0x5c979f['textContent']='';_0x34a0ad&&(_0x34a0ad['style']['display']='none'),_0x58f9a7&&(_0x58f9a7['textContent']='Leave\x20blank\x20to\x20keep\x20current\x20password'),_0x1faf76['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);};function hideUserModal(){const _0x1a4157=document['getElementById']('user-modal'),_0x161599=document['getElementById']('form-error'),_0x18c988=document['getElementById']('save-user');_0x1a4157['hidden']=!![],_0x161599['hidden']=!![],state['editingUserId']=null,_0x18c988&&(_0x18c988['disabled']=![],_0x18c988['textContent']='Save\x20User');}async function saveUser(){const _0x5c529e=document['getElementById']('user-form'),_0x3dc1ca=document['getElementById']('skip-password')?.['checked']||![];if(!_0x3dc1ca&&!_0x5c529e['checkValidity']()){_0x5c529e['reportValidity']();return;}const _0x137148=document['getElementById']('form-error'),_0x3e5a3b=document['getElementById']('save-user'),_0x58565c=document['getElementById']('user-username')['value']['trim'](),_0x21e91f=document['getElementById']('user-name')['value']['trim'](),_0x174b09=document['getElementById']('user-email')['value']['trim'](),_0xde3451=document['getElementById']('user-password')['value'];if(!_0x58565c||!_0x21e91f||!_0x174b09){_0x137148['textContent']='Please\x20fill\x20in\x20all\x20required\x20fields',_0x137148['hidden']=![],_0x137148['scrollIntoView']({'behavior':'smooth','block':'nearest'});return;}_0x137148['hidden']=!![];const _0x18829a=_0x3e5a3b['textContent'];_0x3e5a3b['disabled']=!![],_0x3e5a3b['textContent']=state['editingUserId']?'Updating...':'Creating...';try{if(state['editingUserId']){const _0x4f4c6a={'username':_0x58565c,'name':_0x21e91f,'email':_0x174b09};_0xde3451&&(_0x4f4c6a['password']=_0xde3451),await API['updateUser'](state['editingUserId'],_0x4f4c6a),Utils['showToast']('User\x20updated\x20successfully','success'),await loadUsers(),hideUserModal();}else{const _0x365f6c={'username':_0x58565c,'name':_0x21e91f,'email':_0x174b09};if(!_0x3dc1ca){if(!_0xde3451)throw new Error('Password\x20is\x20required\x20for\x20new\x20users');_0x365f6c['password']=_0xde3451;}const _0x5ef8f3=await API['createUser'](_0x365f6c),_0x558d5d=_0x5ef8f3['user'];if(_0x3dc1ca||!_0xde3451){const _0x54e5a1=await API['createPasswordToken'](_0x558d5d['id'],'setup',![]);state['setupLinkData']={'username':_0x558d5d['username'],'email':_0x558d5d['email'],'url':_0x54e5a1['token']['setupUrl'],'userId':_0x558d5d['id'],'type':'setup','emailSent':![]},await loadUsers(),hideUserModal(),showSetupLinkModal();}else Utils['showToast']('User\x20created\x20successfully','success'),await loadUsers(),hideUserModal();}}catch(_0x118355){console['error']('Failed\x20to\x20save\x20user',_0x118355),_0x137148['textContent']=_0x118355['message'],_0x137148['hidden']=![],_0x137148['scrollIntoView']({'behavior':'smooth','block':'nearest'}),_0x3e5a3b['disabled']=![],_0x3e5a3b['textContent']=_0x18829a;}}window['deleteUser']=function(_0x1f9bfa){const _0x3dded1=state['users']['find'](_0x29a0bb=>_0x29a0bb['id']===_0x1f9bfa);if(!_0x3dded1)return;state['deletingUserId']=_0x1f9bfa;const _0x4446ae=document['getElementById']('delete-modal'),_0xe109fb=document['getElementById']('delete-user-name');_0xe109fb['textContent']=_0x3dded1['name']+'\x20('+_0x3dded1['username']+')',_0x4446ae['hidden']=![];};function hideDeleteModal(){const _0x9aa9b6=document['getElementById']('delete-modal');_0x9aa9b6['hidden']=!![],state['deletingUserId']=null;const _0x3dfa04=document['getElementById']('confirm-delete');_0x3dfa04&&(_0x3dfa04['disabled']=![],_0x3dfa04['textContent']='Delete\x20User');}async function confirmDeleteUser(){if(!state['deletingUserId'])return;const _0x8908f9=document['getElementById']('confirm-delete'),_0x55eb55=_0x8908f9['textContent'];_0x8908f9['disabled']=!![],_0x8908f9['textContent']='Deleting...';try{await API['deleteUser'](state['deletingUserId']),Utils['showToast']('User\x20deleted\x20successfully','success'),await loadUsers(),hideDeleteModal();}catch(_0x1fd6ac){console['error']('Failed\x20to\x20delete\x20user',_0x1fd6ac),Utils['showToast']('Failed\x20to\x20delete\x20user:\x20'+_0x1fd6ac['message'],'error'),_0x8908f9['disabled']=![],_0x8908f9['textContent']=_0x55eb55;}}function handleSkipPasswordChange(_0x2f8083){const _0x561d43=document['getElementById']('user-password'),_0x5ae06c=_0x2f8083['target']['checked'];_0x5ae06c?(_0x561d43['required']=![],_0x561d43['disabled']=!![],_0x561d43['value']=''):(_0x561d43['required']=!![],_0x561d43['disabled']=![]);}function showSetupLinkModal(){if(!state['setupLinkData'])return;const _0x42a787=document['getElementById']('setup-link-modal'),_0x29862a=document['getElementById']('setup-link-username'),_0x3e0545=document['getElementById']('setup-link-url'),_0x236084=document['getElementById']('email-setup-link'),_0x14b6ec=document['getElementById']('email-button-text');_0x29862a['textContent']=state['setupLinkData']['username'],_0x3e0545['textContent']=state['setupLinkData']['url'],_0x236084&&_0x14b6ec&&(_0x236084['disabled']=![],_0x14b6ec['textContent']='Email\x20Link',state['emailConfigured']&&!state['setupLinkData']['emailSent']?_0x236084['style']['display']='inline-block':_0x236084['style']['display']='none'),_0x42a787['hidden']=![];}function hideSetupLinkModal(){const _0x5d1051=document['getElementById']('setup-link-modal');_0x5d1051['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(_0x269c8d){console['error']('Failed\x20to\x20copy\x20link',_0x269c8d),Utils['showToast']('Failed\x20to\x20copy\x20link','error');}}async function emailSetupLink(){if(!state['setupLinkData'])return;const _0x41dc6d=document['getElementById']('email-setup-link'),_0x4b4a6f=document['getElementById']('email-button-text');if(!_0x41dc6d||!_0x4b4a6f)return;const _0x5e665a=_0x4b4a6f['textContent'];_0x41dc6d['disabled']=!![],_0x4b4a6f['textContent']='Sending...';try{const _0x398a91=await API['createPasswordToken'](state['setupLinkData']['userId'],state['setupLinkData']['type'],!![]);if(_0x398a91['emailSent'])Utils['showToast']('Email\x20sent\x20to\x20'+state['setupLinkData']['email'],'success'),state['setupLinkData']['emailSent']=!![],_0x41dc6d['style']['display']='none';else{const _0x5c87a8=_0x398a91['emailError']||'Failed\x20to\x20send\x20email';Utils['showToast'](_0x5c87a8,'error'),_0x41dc6d['disabled']=![],_0x4b4a6f['textContent']=_0x5e665a;}}catch(_0x3bda45){console['error']('Failed\x20to\x20email\x20setup\x20link',_0x3bda45),Utils['showToast']('Failed\x20to\x20send\x20email:\x20'+_0x3bda45['message'],'error'),_0x41dc6d['disabled']=![],_0x4b4a6f['textContent']=_0x5e665a;}}window['resetPassword']=async function(_0xd2ceb1){const _0x25a749=state['users']['find'](_0x1169e8=>_0x1169e8['id']===_0xd2ceb1);if(!_0x25a749)return;const _0x4c2e08=await ConfirmDialog['show']({'title':'Reset\x20Password','message':'Generate\x20a\x20password\x20reset\x20link\x20for\x20'+_0x25a749['name']+'\x20('+_0x25a749['username']+')?\x20This\x20will\x20create\x20a\x20link\x20that\x20they\x20can\x20use\x20to\x20set\x20a\x20new\x20password.','confirmText':'Generate\x20Link'});if(!_0x4c2e08)return;try{const _0x774acc=await API['createPasswordToken'](_0xd2ceb1,'reset',![]);state['setupLinkData']={'username':_0x25a749['username'],'email':_0x25a749['email'],'url':_0x774acc['token']['setupUrl'],'userId':_0x25a749['id'],'type':'reset','emailSent':![]},showSetupLinkModal();}catch(_0x1bf7c7){console['error']('Failed\x20to\x20create\x20password\x20reset\x20link',_0x1bf7c7),Utils['showToast']('Failed\x20to\x20create\x20password\x20reset\x20link:\x20'+_0x1bf7c7['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(_0x39e3bf={}){this['container']=null,this['onGroupChange']=_0x39e3bf['onGroupChange']||(()=>{}),this['onAddExistingTask']=_0x39e3bf['onAddExistingTask']||(()=>{}),this['tasks']=[],this['groupId']=_0x39e3bf['groupId']||null,this['isOpen']=![];}['init'](_0x303cc4,_0x27b483,_0x1e2df8){this['container']=_0x303cc4,this['tasks']=_0x27b483,this['groupId']=_0x1e2df8,this['render'](),this['attachEventListeners']();}['updateTasks'](_0x472eaf){const _0x2f4224=new Map(_0x472eaf['map'](_0x3b4942=>[_0x3b4942['taskId'],_0x3b4942]));this['tasks']=this['tasks']['map'](_0x49f4dc=>{const _0x1b208d=_0x2f4224['get'](_0x49f4dc['taskId']);return _0x1b208d?_0x1b208d:_0x49f4dc;});for(const _0x539ba3 of _0x472eaf){!this['tasks']['some'](_0x2cffbe=>_0x2cffbe['taskId']===_0x539ba3['taskId'])&&this['tasks']['push'](_0x539ba3);}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 _0x33c8d4=this['tasks']['filter'](_0x5b49d8=>_0x5b49d8['groupId']===this['groupId'])['sort']((_0x28548e,_0x2c9fd4)=>(_0x28548e['groupIndex']??0x0)-(_0x2c9fd4['groupIndex']??0x0)),_0x50f503=this['tasks']['filter'](_0x3f5f62=>!_0x3f5f62['groupId']||_0x3f5f62['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>'+_0x33c8d4['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'+(_0x33c8d4['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20add\x20to\x20group</div>':_0x33c8d4['map']((_0x35373d,_0x2a38ba)=>this['renderVariantCard'](_0x35373d,_0x2a38ba,!![]))['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>'+_0x50f503['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'+(_0x50f503['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20remove\x20from\x20group</div>':_0x50f503['map']((_0x20f27c,_0x5d7e1f)=>this['renderVariantCard'](_0x20f27c,_0x5d7e1f,![]))['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'](_0x2ce611,_0x41ef03,_0x3b5e1f){const _0x4e64ee=_0x2ce611['envVars']?.['CODER_AGENT']||_0x2ce611['envVars']?.['default_agent']||'claude',_0x494e30=AGENT_ICONS[_0x4e64ee['toLowerCase']()]||AGENT_ICONS['claude'],_0x541ae3=STATUS_ICONS[_0x2ce611['status']]||'',_0x1a21c1='status-'+(_0x2ce611['status']||'unknown'),_0x353518=_0x2ce611['isWinner']?'<span\x20class=\x22vgm-badge\x20vgm-badge-winner\x22\x20title=\x22Winner\x22>★</span>':'',_0x3a2914=_0x2ce611['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'+_0x1a21c1+'\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'+_0x2ce611['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-is-grouped=\x22'+_0x3b5e1f+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-index=\x22'+_0x41ef03+'\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'+_0x4e64ee['toLowerCase']()+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x494e30+'\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'](_0x2ce611['name']||'Task\x20'+_0x2ce611['taskId']['slice'](-0x6))+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-meta\x22>'+Utils['escapeHtml'](_0x4e64ee)+'\x20·\x20'+(_0x2ce611['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'+_0x353518+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x3a2914+'\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'+_0x1a21c1+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x541ae3+'\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'+(_0x3b5e1f?'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'+_0x2ce611['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-action=\x22'+(_0x3b5e1f?'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'+(_0x3b5e1f?'<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',_0x237fa5=>{_0x237fa5['target']['closest']('.vgm-close-btn')&&(this['close'](),this['onGroupChange'](this['tasks'])),_0x237fa5['target']['closest']('.vgm-add-existing-btn')&&(this['close'](),this['onAddExistingTask'](this['groupId']));}),this['container']['addEventListener']('click',async _0x52df7c=>{const _0x4fc5de=_0x52df7c['target']['closest']('.vgm-variant-remove-btn');if(!_0x4fc5de)return;const _0x1ee31b=_0x4fc5de['dataset']['taskId'],_0x4c2b82=_0x4fc5de['dataset']['action'];try{_0x4c2b82==='remove'?await this['removeFromGroup'](_0x1ee31b):await this['addToGroup'](_0x1ee31b);}catch(_0x131bcf){console['error']('Failed\x20to\x20update\x20group:',_0x131bcf),Utils['showToast'](_0x131bcf['message']||'Failed\x20to\x20update\x20group','error');}}),this['container']['addEventListener']('dragstart',_0x3f0896=>this['handleDragStart'](_0x3f0896)),this['container']['addEventListener']('dragend',_0x326a5c=>this['handleDragEnd'](_0x326a5c)),this['container']['addEventListener']('dragover',_0x5f1f59=>this['handleDragOver'](_0x5f1f59)),this['container']['addEventListener']('dragleave',_0x37dbaa=>this['handleDragLeave'](_0x37dbaa)),this['container']['addEventListener']('drop',_0x1fb0ef=>this['handleDrop'](_0x1fb0ef));}['handleDragStart'](_0xa08011){const _0x254d3c=_0xa08011['target']['closest']('.vgm-variant-card');if(!_0x254d3c)return;dragState['draggedTaskId']=_0x254d3c['dataset']['taskId'],dragState['draggedElement']=_0x254d3c,dragState['sourceGroupId']=_0x254d3c['dataset']['isGrouped']==='true'?this['groupId']:null,dragState['isDragging']=!![],_0x254d3c['classList']['add']('dragging'),_0xa08011['dataTransfer']['effectAllowed']='move',_0xa08011['dataTransfer']['setData']('text/plain',_0x254d3c['dataset']['taskId']),this['container']['classList']['add']('is-dragging');}['handleDragEnd'](_0x36f8db){const _0x499d10=_0x36f8db['target']['closest']('.vgm-variant-card');_0x499d10&&_0x499d10['classList']['remove']('dragging'),this['container']['querySelectorAll']('.drag-over,\x20.drop-indicator')['forEach'](_0x522ac0=>{_0x522ac0['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'](_0x1d4ca1){_0x1d4ca1['preventDefault'](),_0x1d4ca1['dataTransfer']['dropEffect']='move';const _0xd35420=_0x1d4ca1['target']['closest']('.vgm-drop-zone'),_0x30ffc3=_0x1d4ca1['target']['closest']('.vgm-variant-card');this['container']['querySelectorAll']('.vgm-drop-zone')['forEach'](_0x20cac8=>{_0x20cac8['classList']['toggle']('drag-over',_0x20cac8===_0xd35420);});if(_0x30ffc3&&_0x30ffc3!==dragState['draggedElement']){const _0x2010ae=_0x30ffc3['getBoundingClientRect'](),_0x37d10d=_0x2010ae['top']+_0x2010ae['height']/0x2,_0x1694d1=_0x1d4ca1['clientY']<_0x37d10d;this['container']['querySelectorAll']('.vgm-variant-card')['forEach'](_0xfe6eed=>{_0xfe6eed!==_0x30ffc3&&_0xfe6eed['classList']['remove']('drop-before','drop-after');}),_0x30ffc3['classList']['toggle']('drop-before',_0x1694d1),_0x30ffc3['classList']['toggle']('drop-after',!_0x1694d1);}}['handleDragLeave'](_0x671cd1){const _0x2bb36b=_0x671cd1['target']['closest']('.vgm-drop-zone');_0x2bb36b&&!_0x2bb36b['contains'](_0x671cd1['relatedTarget'])&&_0x2bb36b['classList']['remove']('drag-over');}async['handleDrop'](_0x5c8ab8){_0x5c8ab8['preventDefault']();const _0x1c1fdb=_0x5c8ab8['target']['closest']('.vgm-drop-zone'),_0x46152d=_0x5c8ab8['target']['closest']('.vgm-variant-card'),_0x2ec1a4=_0x5c8ab8['dataTransfer']['getData']('text/plain');if(!_0x1c1fdb||!_0x2ec1a4)return;this['container']['querySelectorAll']('.drag-over,\x20.drop-before,\x20.drop-after')['forEach'](_0x3c4eff=>{_0x3c4eff['classList']['remove']('drag-over','drop-before','drop-after');});const _0x4c2e69=_0x1c1fdb['dataset']['zone'],_0x13a0cb=_0x4c2e69==='grouped',_0x15d720=dragState['sourceGroupId']===this['groupId'];try{if(_0x13a0cb&&!_0x15d720){let _0x1c20f5=this['tasks']['filter'](_0x195f40=>_0x195f40['groupId']===this['groupId'])['length'];if(_0x46152d){const _0x552054=_0x46152d['dataset']['taskId'],_0x30dc6b=this['tasks']['find'](_0x13f046=>_0x13f046['taskId']===_0x552054);if(_0x30dc6b?.['groupIndex']!==undefined){const _0x4f0684=_0x46152d['getBoundingClientRect'](),_0x17ca61=_0x5c8ab8['clientY']<_0x4f0684['top']+_0x4f0684['height']/0x2;_0x1c20f5=_0x30dc6b['groupIndex']+(_0x17ca61?0x0:0x1);}}await this['addToGroup'](_0x2ec1a4,_0x1c20f5);}else{if(!_0x13a0cb&&_0x15d720)await this['removeFromGroup'](_0x2ec1a4);else _0x13a0cb&&_0x15d720&&_0x46152d&&await this['reorderInGroup'](_0x2ec1a4,_0x46152d,_0x5c8ab8['clientY']);}}catch(_0xdb2284){console['error']('Drop\x20operation\x20failed:',_0xdb2284),Utils['showToast'](_0xdb2284['message']||'Failed\x20to\x20move\x20variant','error');}}async['addToGroup'](_0xddb304,_0x572e6a){const _0x15fd59=this['tasks']['find'](_0x21c5bd=>_0x21c5bd['taskId']===_0xddb304);if(!_0x15fd59)return;_0x572e6a===undefined&&(_0x572e6a=this['tasks']['filter'](_0x2ba266=>_0x2ba266['groupId']===this['groupId'])['length']),!this['groupId']&&(this['groupId']=API['generateGroupId'](),await API['createTaskGroup']({'groupId':this['groupId']})),await API['updateTaskGroup'](_0xddb304,this['groupId'],_0x572e6a),_0x15fd59['groupId']=this['groupId'],_0x15fd59['groupIndex']=_0x572e6a,this['render'](),this['onGroupChange'](this['tasks']);}async['removeFromGroup'](_0x2f9076){const _0x1dfde3=this['tasks']['find'](_0x12e2e0=>_0x12e2e0['taskId']===_0x2f9076);if(!_0x1dfde3)return;await API['removeTaskFromGroup'](_0x2f9076),_0x1dfde3['groupId']=null,_0x1dfde3['groupIndex']=null,this['render'](),this['onGroupChange'](this['tasks']);}async['reorderInGroup'](_0x184c07,_0x3554a1,_0x3a96f6){const _0x1492fd=this['tasks']['find'](_0x2dd80d=>_0x2dd80d['taskId']===_0x184c07),_0x1c5ef3=_0x3554a1['dataset']['taskId'],_0x1fa3d8=this['tasks']['find'](_0x5c650a=>_0x5c650a['taskId']===_0x1c5ef3);if(!_0x1492fd||!_0x1fa3d8||_0x1492fd['taskId']===_0x1fa3d8['taskId'])return;const _0x6270b4=_0x3554a1['getBoundingClientRect'](),_0x1f5449=_0x3a96f6<_0x6270b4['top']+_0x6270b4['height']/0x2;let _0x49e457=_0x1fa3d8['groupIndex']??0x0;if(!_0x1f5449)_0x49e457++;if((_0x1492fd['groupIndex']??0x0)<(_0x1fa3d8['groupIndex']??0x0))_0x49e457--;if(_0x49e457===_0x1492fd['groupIndex'])return;await API['updateTaskGroup'](_0x184c07,this['groupId'],_0x49e457);const _0x4310be=this['tasks']['filter'](_0x2b06dc=>_0x2b06dc['groupId']===this['groupId'])['sort']((_0x609241,_0x1b09b8)=>(_0x609241['groupIndex']??0x0)-(_0x1b09b8['groupIndex']??0x0)),_0x469ce9=_0x4310be['findIndex'](_0x173147=>_0x173147['taskId']===_0x184c07);_0x469ce9!==-0x1&&_0x4310be['splice'](_0x469ce9,0x1),_0x4310be['splice'](_0x49e457,0x0,_0x1492fd),_0x4310be['forEach']((_0x172c97,_0x24bfdb)=>{_0x172c97['groupIndex']=_0x24bfdb;}),this['render'](),this['onGroupChange'](this['tasks']);}}export function initializeTabDragDrop(_0x26a0f6,_0x1b8d7c,_0xaef632,_0x18fe96={}){if(!_0x26a0f6)return;const {onReorder:_0x291f7a,onRemove:_0x14730c}=_0x18fe96,_0x3b51e2=_0x26a0f6['querySelectorAll']('.task-tab');_0x3b51e2['forEach']((_0x12b0c5,_0x549c8f)=>{_0x12b0c5['setAttribute']('draggable','true'),_0x12b0c5['dataset']['index']=_0x549c8f,_0x12b0c5['addEventListener']('dragstart',_0x5cf54f=>{_0x5cf54f['dataTransfer']['effectAllowed']='move',_0x5cf54f['dataTransfer']['setData']('text/plain',_0x12b0c5['dataset']['taskId']),_0x12b0c5['classList']['add']('dragging'),_0x26a0f6['classList']['add']('is-dragging');}),_0x12b0c5['addEventListener']('dragend',()=>{_0x12b0c5['classList']['remove']('dragging'),_0x26a0f6['classList']['remove']('is-dragging'),_0x26a0f6['querySelectorAll']('.drop-indicator')['forEach'](_0x32e22b=>{_0x32e22b['classList']['remove']('drop-indicator','drop-before','drop-after');});}),_0x12b0c5['addEventListener']('dragover',_0x63af63=>{_0x63af63['preventDefault'](),_0x63af63['dataTransfer']['dropEffect']='move';if(_0x12b0c5['classList']['contains']('dragging'))return;const _0x725418=_0x12b0c5['getBoundingClientRect'](),_0x56a336=_0x725418['left']+_0x725418['width']/0x2,_0x1cff6b=_0x63af63['clientX']<_0x56a336;_0x3b51e2['forEach'](_0x2fc148=>_0x2fc148['classList']['remove']('drop-before','drop-after')),_0x12b0c5['classList']['add'](_0x1cff6b?'drop-before':'drop-after');}),_0x12b0c5['addEventListener']('dragleave',()=>{_0x12b0c5['classList']['remove']('drop-before','drop-after');}),_0x12b0c5['addEventListener']('drop',async _0x413675=>{_0x413675['preventDefault']();const _0x444447=_0x413675['dataTransfer']['getData']('text/plain'),_0xa07998=_0x12b0c5['dataset']['taskId'];if(_0x444447===_0xa07998)return;const _0x5b0e56=_0x12b0c5['getBoundingClientRect'](),_0x59d23c=_0x413675['clientX']<_0x5b0e56['left']+_0x5b0e56['width']/0x2;_0x12b0c5['classList']['remove']('drop-before','drop-after'),_0x291f7a&&await _0x291f7a(_0x444447,_0xa07998,_0x59d23c);});});const _0x55cd2a=document['createElement']('div');return _0x55cd2a['className']='task-tab-remove-zone',_0x55cd2a['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',_0x55cd2a['style']['display']='none',_0x55cd2a['addEventListener']('dragover',_0x3a9095=>{_0x3a9095['preventDefault'](),_0x55cd2a['classList']['add']('drag-over');}),_0x55cd2a['addEventListener']('dragleave',()=>{_0x55cd2a['classList']['remove']('drag-over');}),_0x55cd2a['addEventListener']('drop',async _0x49147f=>{_0x49147f['preventDefault'](),_0x55cd2a['classList']['remove']('drag-over');const _0x282e21=_0x49147f['dataTransfer']['getData']('text/plain');_0x14730c&&await _0x14730c(_0x282e21);}),_0x26a0f6['addEventListener']('dragstart',()=>{_0x1b8d7c['length']>0x1&&(_0x55cd2a['style']['display']='flex');}),_0x26a0f6['addEventListener']('dragend',()=>{_0x55cd2a['style']['display']='none';}),_0x26a0f6['appendChild'](_0x55cd2a),{'destroy':()=>{_0x55cd2a['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(_0x292493={}){this['container']=null,this['onGroupChange']=_0x292493['onGroupChange']||(()=>{}),this['onAddExistingTask']=_0x292493['onAddExistingTask']||(()=>{}),this['tasks']=[],this['groupId']=_0x292493['groupId']||null,this['isOpen']=![];}['init'](_0xb204,_0x1fad6e,_0x1fe06d){this['container']=_0xb204,this['tasks']=_0x1fad6e,this['groupId']=_0x1fe06d,this['render'](),this['attachEventListeners']();}['updateTasks'](_0x100e5d){const _0x281ac3=new Map(_0x100e5d['map'](_0x1e9bea=>[_0x1e9bea['taskId'],_0x1e9bea]));this['tasks']=this['tasks']['map'](_0xc9e246=>{const _0x322f1a=_0x281ac3['get'](_0xc9e246['taskId']);return _0x322f1a?_0x322f1a:_0xc9e246;});for(const _0xbc243c of _0x100e5d){!this['tasks']['some'](_0x2ade84=>_0x2ade84['taskId']===_0xbc243c['taskId'])&&this['tasks']['push'](_0xbc243c);}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 _0x36968f=this['tasks']['filter'](_0x11f8c0=>_0x11f8c0['groupId']===this['groupId'])['sort']((_0x4599d9,_0x53499f)=>(_0x4599d9['groupIndex']??0x0)-(_0x53499f['groupIndex']??0x0)),_0x104d5a=this['tasks']['filter'](_0x39946a=>!_0x39946a['groupId']||_0x39946a['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>'+_0x36968f['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'+(_0x36968f['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20add\x20to\x20group</div>':_0x36968f['map']((_0x409905,_0x2aa82c)=>this['renderVariantCard'](_0x409905,_0x2aa82c,!![]))['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>'+_0x104d5a['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'+(_0x104d5a['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20remove\x20from\x20group</div>':_0x104d5a['map']((_0x449eb6,_0x2af7c3)=>this['renderVariantCard'](_0x449eb6,_0x2af7c3,![]))['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'](_0x3b9d37,_0x3498da,_0x57ef8f){const _0x13f3c0=_0x3b9d37['envVars']?.['CODER_AGENT']||_0x3b9d37['envVars']?.['default_agent']||'claude',_0x3cba0c=AGENT_ICONS[_0x13f3c0['toLowerCase']()]||AGENT_ICONS['claude'],_0xf7be0e=STATUS_ICONS[_0x3b9d37['status']]||'',_0x4bd649='status-'+(_0x3b9d37['status']||'unknown'),_0x56713e=_0x3b9d37['isWinner']?'<span\x20class=\x22vgm-badge\x20vgm-badge-winner\x22\x20title=\x22Winner\x22>★</span>':'',_0x36117c=_0x3b9d37['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'+_0x4bd649+'\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'+_0x3b9d37['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-is-grouped=\x22'+_0x57ef8f+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-index=\x22'+_0x3498da+'\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'+_0x13f3c0['toLowerCase']()+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x3cba0c+'\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'](_0x3b9d37['name']||'Task\x20'+_0x3b9d37['taskId']['slice'](-0x6))+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-meta\x22>'+Utils['escapeHtml'](_0x13f3c0)+'\x20·\x20'+(_0x3b9d37['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'+_0x56713e+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x36117c+'\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'+_0x4bd649+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0xf7be0e+'\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'+(_0x57ef8f?'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'+_0x3b9d37['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-action=\x22'+(_0x57ef8f?'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'+(_0x57ef8f?'<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',_0x545bac=>{_0x545bac['target']['closest']('.vgm-close-btn')&&(this['close'](),this['onGroupChange'](this['tasks'])),_0x545bac['target']['closest']('.vgm-add-existing-btn')&&(this['close'](),this['onAddExistingTask'](this['groupId']));}),this['container']['addEventListener']('click',async _0x2fd3b2=>{const _0x38e943=_0x2fd3b2['target']['closest']('.vgm-variant-remove-btn');if(!_0x38e943)return;const _0x312abe=_0x38e943['dataset']['taskId'],_0x447b73=_0x38e943['dataset']['action'];try{_0x447b73==='remove'?await this['removeFromGroup'](_0x312abe):await this['addToGroup'](_0x312abe);}catch(_0x1f3623){console['error']('Failed\x20to\x20update\x20group:',_0x1f3623),Utils['showToast'](_0x1f3623['message']||'Failed\x20to\x20update\x20group','error');}}),this['container']['addEventListener']('dragstart',_0x27981c=>this['handleDragStart'](_0x27981c)),this['container']['addEventListener']('dragend',_0x22f431=>this['handleDragEnd'](_0x22f431)),this['container']['addEventListener']('dragover',_0x5e9425=>this['handleDragOver'](_0x5e9425)),this['container']['addEventListener']('dragleave',_0x2b5754=>this['handleDragLeave'](_0x2b5754)),this['container']['addEventListener']('drop',_0x2f62b6=>this['handleDrop'](_0x2f62b6));}['handleDragStart'](_0x1b0ba5){const _0x48e2f4=_0x1b0ba5['target']['closest']('.vgm-variant-card');if(!_0x48e2f4)return;dragState['draggedTaskId']=_0x48e2f4['dataset']['taskId'],dragState['draggedElement']=_0x48e2f4,dragState['sourceGroupId']=_0x48e2f4['dataset']['isGrouped']==='true'?this['groupId']:null,dragState['isDragging']=!![],_0x48e2f4['classList']['add']('dragging'),_0x1b0ba5['dataTransfer']['effectAllowed']='move',_0x1b0ba5['dataTransfer']['setData']('text/plain',_0x48e2f4['dataset']['taskId']),this['container']['classList']['add']('is-dragging');}['handleDragEnd'](_0x549f46){const _0x14fa8a=_0x549f46['target']['closest']('.vgm-variant-card');_0x14fa8a&&_0x14fa8a['classList']['remove']('dragging'),this['container']['querySelectorAll']('.drag-over,\x20.drop-indicator')['forEach'](_0x5b78c6=>{_0x5b78c6['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'](_0x2cb23e){_0x2cb23e['preventDefault'](),_0x2cb23e['dataTransfer']['dropEffect']='move';const _0x4afba5=_0x2cb23e['target']['closest']('.vgm-drop-zone'),_0xceaa19=_0x2cb23e['target']['closest']('.vgm-variant-card');this['container']['querySelectorAll']('.vgm-drop-zone')['forEach'](_0x4d04d1=>{_0x4d04d1['classList']['toggle']('drag-over',_0x4d04d1===_0x4afba5);});if(_0xceaa19&&_0xceaa19!==dragState['draggedElement']){const _0x48c160=_0xceaa19['getBoundingClientRect'](),_0x1e8875=_0x48c160['top']+_0x48c160['height']/0x2,_0x5a0c74=_0x2cb23e['clientY']<_0x1e8875;this['container']['querySelectorAll']('.vgm-variant-card')['forEach'](_0xc73e2b=>{_0xc73e2b!==_0xceaa19&&_0xc73e2b['classList']['remove']('drop-before','drop-after');}),_0xceaa19['classList']['toggle']('drop-before',_0x5a0c74),_0xceaa19['classList']['toggle']('drop-after',!_0x5a0c74);}}['handleDragLeave'](_0x4da6ad){const _0x5345fd=_0x4da6ad['target']['closest']('.vgm-drop-zone');_0x5345fd&&!_0x5345fd['contains'](_0x4da6ad['relatedTarget'])&&_0x5345fd['classList']['remove']('drag-over');}async['handleDrop'](_0x424571){_0x424571['preventDefault']();const _0x429f26=_0x424571['target']['closest']('.vgm-drop-zone'),_0x3f6eff=_0x424571['target']['closest']('.vgm-variant-card'),_0x3401ff=_0x424571['dataTransfer']['getData']('text/plain');if(!_0x429f26||!_0x3401ff)return;this['container']['querySelectorAll']('.drag-over,\x20.drop-before,\x20.drop-after')['forEach'](_0x14aa40=>{_0x14aa40['classList']['remove']('drag-over','drop-before','drop-after');});const _0x4db611=_0x429f26['dataset']['zone'],_0x144332=_0x4db611==='grouped',_0x567c2b=dragState['sourceGroupId']===this['groupId'];try{if(_0x144332&&!_0x567c2b){let _0x2684d6=this['tasks']['filter'](_0x48fa2c=>_0x48fa2c['groupId']===this['groupId'])['length'];if(_0x3f6eff){const _0x2e5cf6=_0x3f6eff['dataset']['taskId'],_0x430993=this['tasks']['find'](_0xc42050=>_0xc42050['taskId']===_0x2e5cf6);if(_0x430993?.['groupIndex']!==undefined){const _0x351988=_0x3f6eff['getBoundingClientRect'](),_0x529781=_0x424571['clientY']<_0x351988['top']+_0x351988['height']/0x2;_0x2684d6=_0x430993['groupIndex']+(_0x529781?0x0:0x1);}}await this['addToGroup'](_0x3401ff,_0x2684d6);}else{if(!_0x144332&&_0x567c2b)await this['removeFromGroup'](_0x3401ff);else _0x144332&&_0x567c2b&&_0x3f6eff&&await this['reorderInGroup'](_0x3401ff,_0x3f6eff,_0x424571['clientY']);}}catch(_0x437005){console['error']('Drop\x20operation\x20failed:',_0x437005),Utils['showToast'](_0x437005['message']||'Failed\x20to\x20move\x20variant','error');}}async['addToGroup'](_0x1cbb85,_0x134490){const _0x16437c=this['tasks']['find'](_0x5bb7ea=>_0x5bb7ea['taskId']===_0x1cbb85);if(!_0x16437c)return;_0x134490===undefined&&(_0x134490=this['tasks']['filter'](_0x363172=>_0x363172['groupId']===this['groupId'])['length']),!this['groupId']&&(this['groupId']=API['generateGroupId'](),await API['createTaskGroup']({'groupId':this['groupId']})),await API['updateTaskGroup'](_0x1cbb85,this['groupId'],_0x134490),_0x16437c['groupId']=this['groupId'],_0x16437c['groupIndex']=_0x134490,this['render'](),this['onGroupChange'](this['tasks']);}async['removeFromGroup'](_0x5b3c1d){const _0x93a92c=this['tasks']['find'](_0x47db36=>_0x47db36['taskId']===_0x5b3c1d);if(!_0x93a92c)return;await API['removeTaskFromGroup'](_0x5b3c1d),_0x93a92c['groupId']=null,_0x93a92c['groupIndex']=null,this['render'](),this['onGroupChange'](this['tasks']);}async['reorderInGroup'](_0x2dc0b0,_0x4236c1,_0x2c9471){const _0x303d6e=this['tasks']['find'](_0x8619e2=>_0x8619e2['taskId']===_0x2dc0b0),_0x39853f=_0x4236c1['dataset']['taskId'],_0x5115df=this['tasks']['find'](_0x5aa275=>_0x5aa275['taskId']===_0x39853f);if(!_0x303d6e||!_0x5115df||_0x303d6e['taskId']===_0x5115df['taskId'])return;const _0x4c4d0a=_0x4236c1['getBoundingClientRect'](),_0x458d76=_0x2c9471<_0x4c4d0a['top']+_0x4c4d0a['height']/0x2;let _0x2c9302=_0x5115df['groupIndex']??0x0;if(!_0x458d76)_0x2c9302++;if((_0x303d6e['groupIndex']??0x0)<(_0x5115df['groupIndex']??0x0))_0x2c9302--;if(_0x2c9302===_0x303d6e['groupIndex'])return;await API['updateTaskGroup'](_0x2dc0b0,this['groupId'],_0x2c9302);const _0x2e2741=this['tasks']['filter'](_0x2e89b8=>_0x2e89b8['groupId']===this['groupId'])['sort']((_0x36e02f,_0x5128df)=>(_0x36e02f['groupIndex']??0x0)-(_0x5128df['groupIndex']??0x0)),_0x499917=_0x2e2741['findIndex'](_0x1c7684=>_0x1c7684['taskId']===_0x2dc0b0);_0x499917!==-0x1&&_0x2e2741['splice'](_0x499917,0x1),_0x2e2741['splice'](_0x2c9302,0x0,_0x303d6e),_0x2e2741['forEach']((_0x219724,_0x3882f6)=>{_0x219724['groupIndex']=_0x3882f6;}),this['render'](),this['onGroupChange'](this['tasks']);}}export function initializeTabDragDrop(_0xfb9b92,_0xbbd7b2,_0x14bc4d,_0x2ccdab={}){if(!_0xfb9b92)return;const {onReorder:_0x1fe7f8,onRemove:_0x46f661}=_0x2ccdab,_0x122032=_0xfb9b92['querySelectorAll']('.task-tab');_0x122032['forEach']((_0x555c6c,_0x4032db)=>{_0x555c6c['setAttribute']('draggable','true'),_0x555c6c['dataset']['index']=_0x4032db,_0x555c6c['addEventListener']('dragstart',_0x429a46=>{_0x429a46['dataTransfer']['effectAllowed']='move',_0x429a46['dataTransfer']['setData']('text/plain',_0x555c6c['dataset']['taskId']),_0x555c6c['classList']['add']('dragging'),_0xfb9b92['classList']['add']('is-dragging');}),_0x555c6c['addEventListener']('dragend',()=>{_0x555c6c['classList']['remove']('dragging'),_0xfb9b92['classList']['remove']('is-dragging'),_0xfb9b92['querySelectorAll']('.drop-indicator')['forEach'](_0x4d6e42=>{_0x4d6e42['classList']['remove']('drop-indicator','drop-before','drop-after');});}),_0x555c6c['addEventListener']('dragover',_0x49688e=>{_0x49688e['preventDefault'](),_0x49688e['dataTransfer']['dropEffect']='move';if(_0x555c6c['classList']['contains']('dragging'))return;const _0x5dbe01=_0x555c6c['getBoundingClientRect'](),_0x2a034f=_0x5dbe01['left']+_0x5dbe01['width']/0x2,_0x38a6d2=_0x49688e['clientX']<_0x2a034f;_0x122032['forEach'](_0x28b1c7=>_0x28b1c7['classList']['remove']('drop-before','drop-after')),_0x555c6c['classList']['add'](_0x38a6d2?'drop-before':'drop-after');}),_0x555c6c['addEventListener']('dragleave',()=>{_0x555c6c['classList']['remove']('drop-before','drop-after');}),_0x555c6c['addEventListener']('drop',async _0x326c70=>{_0x326c70['preventDefault']();const _0x402099=_0x326c70['dataTransfer']['getData']('text/plain'),_0x123b8d=_0x555c6c['dataset']['taskId'];if(_0x402099===_0x123b8d)return;const _0x5af70f=_0x555c6c['getBoundingClientRect'](),_0x8974f6=_0x326c70['clientX']<_0x5af70f['left']+_0x5af70f['width']/0x2;_0x555c6c['classList']['remove']('drop-before','drop-after'),_0x1fe7f8&&await _0x1fe7f8(_0x402099,_0x123b8d,_0x8974f6);});});const _0x5c41ef=document['createElement']('div');return _0x5c41ef['className']='task-tab-remove-zone',_0x5c41ef['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',_0x5c41ef['style']['display']='none',_0x5c41ef['addEventListener']('dragover',_0x37fc03=>{_0x37fc03['preventDefault'](),_0x5c41ef['classList']['add']('drag-over');}),_0x5c41ef['addEventListener']('dragleave',()=>{_0x5c41ef['classList']['remove']('drag-over');}),_0x5c41ef['addEventListener']('drop',async _0x3de5c3=>{_0x3de5c3['preventDefault'](),_0x5c41ef['classList']['remove']('drag-over');const _0x54bc9c=_0x3de5c3['dataTransfer']['getData']('text/plain');_0x46f661&&await _0x46f661(_0x54bc9c);}),_0xfb9b92['addEventListener']('dragstart',()=>{_0xbbd7b2['length']>0x1&&(_0x5c41ef['style']['display']='flex');}),_0xfb9b92['addEventListener']('dragend',()=>{_0x5c41ef['style']['display']='none';}),_0xfb9b92['appendChild'](_0x5c41ef),{'destroy':()=>{_0x5c41ef['remove']();}};}export default VariantGroupingManager;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@profoundlogic/coderflow-server",
3
- "version": "0.8.2",
3
+ "version": "0.8.3",
4
4
  "description": "AI Coder Server - Manages Docker containers for AI agent task execution",
5
5
  "main": "dist/start.js",
6
6
  "type": "module",