@profoundlogic/coderflow-server 0.8.2 → 0.8.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (179) hide show
  1. package/dist/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 _0x52eed4=state['currentUser'];if(!Permissions['hasServerPermission'](_0x52eed4,'teams:view')&&!Permissions['hasTeamPermission'](_0x52eed4,'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'](_0x52eed4,'*')||Permissions['hasTeamPermission'](_0x52eed4,'teams:manage'))&&(document['getElementById']('create-team-btn')['hidden']=![]),bindEventListeners(),await Promise['all']([loadTeams(),loadUsers(),loadRoles(),loadEnvironments()]),renderTeams();});async function loadTeams(){const _0x429504=document['getElementById']('teams-loading'),_0x2ac70d=document['getElementById']('teams-error'),_0x37d546=document['getElementById']('teams-content');try{_0x429504['hidden']=![],_0x2ac70d['hidden']=!![],_0x37d546['hidden']=!![];const {teams:_0x37d37f}=await API['getTeams']();state['teams']=_0x37d37f||[],renderTeams(),_0x429504['hidden']=!![],_0x37d546['hidden']=![];}catch(_0x41c53d){_0x429504['hidden']=!![],_0x2ac70d['hidden']=![],document['getElementById']('teams-error-message')['textContent']=_0x41c53d['message'];}}async function loadUsers(){try{const {users:_0x220998}=await API['getUsers']();state['users']=_0x220998||[];}catch{state['users']=[];}}async function loadRoles(){try{const {roles:_0x3eb534}=await API['getRoleDefinitions']();state['roles']=_0x3eb534||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x43d77c=await API['getEnvironments']();state['environments']=_0x43d77c['environments']||[];}catch{state['environments']=[];}}function renderTeams(){const _0x313d89=document['getElementById']('teams-table-body'),_0x225831=document['getElementById']('team-count');if(!_0x313d89)return;_0x225831&&(_0x225831['textContent']=state['teams']['length']+'\x20team'+(state['teams']['length']===0x1?'':'s'));if(state['teams']['length']===0x0){_0x313d89['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 _0xd72fd3=Permissions['hasServerPermission'](state['currentUser'],'*');_0x313d89['innerHTML']=state['teams']['map'](_0x2bd739=>{const _0x3e0f0f=_0xd72fd3||_0x2bd739['canManageTeam'],_0xa5d552=_0xd72fd3||_0x2bd739['canManageMembers'],_0x47c64f=_0x3e0f0f||_0xa5d552,_0x3002e8=(_0x2bd739['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'](_0x2bd739['name'])+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x2bd739['description']?'<div\x20style=\x22font-size:\x200.8em;\x20color:\x20var(--color-text-secondary);\x20margin-top:\x200.15rem;\x22>'+Utils['escapeHtml'](_0x2bd739['description'])+'</div>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+_0x3002e8+'</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'+(_0x47c64f?'<button\x20class=\x22btn-icon\x22\x20title=\x22Edit\x20team\x22\x20onclick=\x22window.openTeamModal(\x27'+_0x2bd739['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'+(_0x3e0f0f?'<button\x20class=\x22btn-icon\x22\x20title=\x22Access\x20bindings\x22\x20onclick=\x22window.openBindingsModal(\x27'+_0x2bd739['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'+(_0x3e0f0f?'<button\x20class=\x22btn-icon\x20btn-danger\x22\x20title=\x22Delete\x20team\x22\x20onclick=\x22window.deleteTeam(\x27'+_0x2bd739['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(_0x20c9f0){const _0xe2f5d6=state['teams']['find'](_0x2cd115=>_0x2cd115['id']===_0x20c9f0);if(!_0xe2f5d6)return;state['editingTeamId']=_0x20c9f0;const _0x5e071f=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x148a42=_0x5e071f||_0xe2f5d6['canManageTeam'],_0x359143=_0x5e071f||_0xe2f5d6['canManageMembers'],_0x46aa53=_0x148a42,_0x872356=_0x148a42||_0x359143,_0x362b92=_0xe2f5d6['name'],_0x27862b=_0xe2f5d6['description']||'';state['modalSnapshot']={'name':_0x362b92,'description':_0x27862b},document['getElementById']('team-modal-title')['textContent']=_0x362b92,document['getElementById']('team-name')['value']=_0x362b92,document['getElementById']('team-name')['disabled']=!_0x46aa53,document['getElementById']('team-description')['value']=_0x27862b,document['getElementById']('team-description')['disabled']=!_0x46aa53,document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=![],document['getElementById']('save-team')['hidden']=!_0x46aa53,renderMembersList(_0xe2f5d6),updateMemberSelect(_0xe2f5d6),document['getElementById']('team-modal')['hidden']=![];};function isTeamModalDirty(){if(!state['modalSnapshot'])return![];const _0xa67cda=document['getElementById']('team-name')['value']['trim'](),_0x427acc=document['getElementById']('team-description')['value']['trim']();return _0xa67cda!==state['modalSnapshot']['name']||_0x427acc!==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(_0x3e1f0e){const _0x3660e5=state['teams']['find'](_0x1fe7b4=>_0x1fe7b4['id']===_0x3e1f0e);if(!_0x3660e5)return;state['bindingsTeamId']=_0x3e1f0e,document['getElementById']('bindings-modal-title')['textContent']='Access\x20Bindings\x20—\x20'+_0x3660e5['name'],document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('bindings-modal')['hidden']=![],loadTeamBindings(_0x3e1f0e);};function hideBindingsModal(){document['getElementById']('bindings-modal')['hidden']=!![],state['bindingsTeamId']=null;}function renderMembersList(_0x2bf102){const _0x1d93d1=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x2ceb18=_0x1d93d1||_0x2bf102['canManageMembers']||_0x2bf102['canManageTeam'],_0x2c0253=_0x2bf102['members']||[],_0x136370=document['getElementById']('members-list');if(_0x2c0253['length']===0x0){_0x136370['innerHTML']='<p\x20style=\x22font-size:\x200.875rem;\x20color:\x20var(--color-text-secondary);\x20margin:\x200.25rem\x200;\x22>No\x20members\x20yet</p>';return;}_0x136370['innerHTML']=_0x2c0253['map'](_0xaca733=>{const _0x252b5c=state['users']['find'](_0x46442e=>_0x46442e['id']===_0xaca733),_0x38f535=_0x252b5c?''+Utils['escapeHtml'](_0x252b5c['username'])+(_0x252b5c['name']?'\x20<span\x20style=\x22color:\x20var(--color-text-secondary);\x20font-size:\x200.85em;\x22>('+Utils['escapeHtml'](_0x252b5c['name'])+')</span>':''):Utils['escapeHtml'](_0xaca733);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'+_0x38f535+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x2ceb18?'<button\x20type=\x22button\x22\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.removeMemberClick(\x27'+_0xaca733+'\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 _0x583f78=document['getElementById']('add-member-row');if(_0x583f78)_0x583f78['style']['display']=_0x2ceb18?'flex':'none';}function updateMemberSelect(_0x12fb94){const _0xeb9116=document['getElementById']('add-member-select');if(!_0xeb9116)return;const _0x322dbf=new Set(_0x12fb94['members']||[]),_0x4330c7=state['users']['filter'](_0x3dceb3=>!_0x322dbf['has'](_0x3dceb3['id']));_0xeb9116['innerHTML']='<option\x20value=\x22\x22>Add\x20a\x20member…</option>'+_0x4330c7['map'](_0x7849b9=>'<option\x20value=\x22'+_0x7849b9['id']+'\x22>'+Utils['escapeHtml'](_0x7849b9['username'])+(_0x7849b9['name']?'\x20('+Utils['escapeHtml'](_0x7849b9['name'])+')':'')+'</option>')['join']('');}async function addMember(){const _0x646431=document['getElementById']('add-member-select'),_0x4842b9=_0x646431['value'];if(!_0x4842b9||!state['editingTeamId'])return;try{const {team:_0xa29a94}=await API['addTeamMember'](state['editingTeamId'],_0x4842b9);syncTeamInState(_0xa29a94),renderMembersList(_0xa29a94),updateMemberSelect(_0xa29a94),_0x646431['value']='',Utils['showToast']('Member\x20added','success');}catch(_0x4bd818){Utils['showToast'](_0x4bd818['message'],'error');}}window['removeMemberClick']=async function(_0x3eea78){if(!state['editingTeamId'])return;try{const {team:_0x3141b4}=await API['removeTeamMember'](state['editingTeamId'],_0x3eea78);syncTeamInState(_0x3141b4),renderMembersList(_0x3141b4),updateMemberSelect(_0x3141b4),Utils['showToast']('Member\x20removed','success');}catch(_0x473e91){Utils['showToast'](_0x473e91['message'],'error');}};async function loadTeamBindings(_0x1aa8a9){const _0xc4f3a7=document['getElementById']('bindings-loading'),_0x22f722=document['getElementById']('bindings-empty'),_0x5869a6=document['getElementById']('bindings-list-container'),_0x404a97=document['getElementById']('add-binding-btn');_0xc4f3a7['hidden']=![],_0x22f722['hidden']=!![],_0x5869a6['style']['display']='none',_0x404a97['hidden']=!![],document['getElementById']('add-binding-form')['hidden']=!![];try{const {bindings:_0x34a254}=await API['getBindings']({'subject_type':'team','subject_id':_0x1aa8a9});state['teamBindings']=_0x34a254||[],_0xc4f3a7['hidden']=!![],state['teamBindings']['length']===0x0?_0x22f722['hidden']=![]:(_0x5869a6['style']['display']='',renderBindingsTable()),(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage'))&&(_0x404a97['hidden']=![]);}catch(_0x3477ad){_0xc4f3a7['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x3477ad['message'],'error');}}function renderBindingsTable(){const _0x364032=document['getElementById']('bindings-table-body');if(!_0x364032)return;const _0x3373ad=Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage');_0x364032['innerHTML']=state['teamBindings']['map'](_0x52a095=>{const _0x1b842b=_0x52a095['resource_type']==='server'?'Server':_0x52a095['resource_id']==='*'?'All\x20'+_0x52a095['resource_type']+'s':Utils['escapeHtml'](_0x52a095['resource_name']||_0x52a095['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x1b842b+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x52a095['role_name']||_0x52a095['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x3373ad?'<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteBindingClick(\x27'+_0x52a095['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 _0xd61e55=document['getElementById']('binding-resource-type');_0xd61e55['value']='environment',updateBindingFormForResourceType('environment');}function onBindingResourceTypeChange(){const _0x3b4140=document['getElementById']('binding-resource-type')['value'];updateBindingFormForResourceType(_0x3b4140);}function updateBindingFormForResourceType(_0x2f4f5a){const _0x542de7=document['getElementById']('binding-resource-container'),_0x545139=document['getElementById']('binding-resource'),_0x5b75aa=document['getElementById']('binding-role');if(_0x2f4f5a==='server')_0x542de7['style']['display']='none';else{_0x542de7['style']['display']='';if(_0x2f4f5a==='environment'){const _0x467f41=new Set(state['teamBindings']['filter'](_0x275679=>_0x275679['resource_type']==='environment')['map'](_0x53b4da=>_0x53b4da['resource_id'])),_0x3cbd6f=state['environments']['filter'](_0x496508=>!_0x467f41['has'](_0x496508['name']));_0x545139['innerHTML']=_0x3cbd6f['length']?_0x3cbd6f['map'](_0x1aeb85=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x1aeb85['name'])+'\x22>'+Utils['escapeHtml'](_0x1aeb85['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x2f4f5a==='team'){const _0x39c037=new Set(state['teamBindings']['filter'](_0x5294c2=>_0x5294c2['resource_type']==='team')['map'](_0x5992b7=>_0x5992b7['resource_id'])),_0x5d3ae1=state['teams']['filter'](_0x5f8ee6=>!_0x39c037['has'](_0x5f8ee6['id']));_0x545139['innerHTML']=_0x5d3ae1['length']?_0x5d3ae1['map'](_0x2212c5=>'<option\x20value=\x22'+_0x2212c5['id']+'\x22>'+Utils['escapeHtml'](_0x2212c5['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x4f4790=state['roles']['filter'](_0x40e67a=>_0x40e67a['resource_type']===_0x2f4f5a);_0x5b75aa['innerHTML']=_0x4f4790['length']?_0x4f4790['filter'](_0x2c4e74=>{const _0x417af9=_0x2f4f5a==='server'?undefined:_0x545139['value'];return!state['teamBindings']['some'](_0x278398=>_0x278398['resource_type']===_0x2f4f5a&&_0x278398['role_id']===_0x2c4e74['id']&&(_0x2f4f5a==='server'||_0x278398['resource_id']===_0x417af9));})['map'](_0x522f9e=>'<option\x20value=\x22'+_0x522f9e['id']+'\x22>'+Utils['escapeHtml'](_0x522f9e['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 _0x4b8f20=document['getElementById']('binding-resource-type')['value'],_0x5d6071=document['getElementById']('binding-role')['value'];if(!_0x5d6071||!state['bindingsTeamId'])return;const _0x395045=_0x4b8f20==='server'?undefined:document['getElementById']('binding-resource')['value'];if(_0x4b8f20!=='server'&&!_0x395045)return;const _0x3c0b68=document['getElementById']('save-binding-btn');_0x3c0b68['disabled']=!![],_0x3c0b68['textContent']='Adding…';try{const _0xb7f05f={'subject_type':'team','subject_id':state['bindingsTeamId'],'role_id':_0x5d6071,'resource_type':_0x4b8f20};if(_0x395045)_0xb7f05f['resource_id']=_0x395045;await API['createBinding'](_0xb7f05f),Utils['showToast']('Binding\x20added','success'),document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![],await loadTeamBindings(state['bindingsTeamId']);}catch(_0x432807){Utils['showToast'](_0x432807['message'],'error');}finally{_0x3c0b68['disabled']=![],_0x3c0b68['textContent']='Add\x20Binding';}}window['deleteBindingClick']=async function(_0x11cf8d){try{await API['deleteBinding'](_0x11cf8d),Utils['showToast']('Binding\x20removed','success'),await loadTeamBindings(state['bindingsTeamId']);}catch(_0x50f8d8){Utils['showToast'](_0x50f8d8['message'],'error');}};async function saveTeam(){const _0x4c4956=document['getElementById']('team-name')['value']['trim'](),_0x54a85c=document['getElementById']('team-description')['value']['trim'](),_0x4c0506=document['getElementById']('team-form-error'),_0x346674=document['getElementById']('save-team');if(!_0x4c4956){_0x4c0506['textContent']='Team\x20name\x20is\x20required',_0x4c0506['hidden']=![];return;}_0x4c0506['hidden']=!![];const _0x5c18bf=_0x346674['textContent'];_0x346674['disabled']=!![],_0x346674['textContent']=state['editingTeamId']?'Saving…':'Creating…';try{if(state['editingTeamId']){const {team:_0x318209}=await API['updateTeam'](state['editingTeamId'],{'name':_0x4c4956,'description':_0x54a85c});syncTeamInState(_0x318209),document['getElementById']('team-modal-title')['textContent']=_0x318209['name'],Utils['showToast']('Team\x20updated','success');}else await API['createTeam']({'name':_0x4c4956,'description':_0x54a85c}),Utils['showToast']('Team\x20created','success');_0x346674['disabled']=![],_0x346674['textContent']=_0x5c18bf,hideTeamModal(),await loadTeams();}catch(_0x333571){_0x4c0506['textContent']=_0x333571['message'],_0x4c0506['hidden']=![],_0x346674['disabled']=![],_0x346674['textContent']=_0x5c18bf;}}window['deleteTeam']=function(_0x49db6c){const _0x50bcd6=state['teams']['find'](_0x524f4e=>_0x524f4e['id']===_0x49db6c);if(!_0x50bcd6)return;state['deletingTeamId']=_0x49db6c,document['getElementById']('delete-team-name')['textContent']=_0x50bcd6['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 _0x486c6d=document['getElementById']('confirm-delete-team');_0x486c6d['disabled']=!![],_0x486c6d['textContent']='Deleting…';try{await API['deleteTeam'](state['deletingTeamId']),Utils['showToast']('Team\x20deleted','success'),_0x486c6d['disabled']=![],_0x486c6d['textContent']='Delete\x20Team',hideDeleteModal(),await loadTeams();}catch(_0x13e7fd){Utils['showToast']('Failed\x20to\x20delete\x20team:\x20'+_0x13e7fd['message'],'error'),_0x486c6d['disabled']=![],_0x486c6d['textContent']='Delete\x20Team';}}function syncTeamInState(_0xd3384f){const _0x33f370=state['teams']['findIndex'](_0x778522=>_0x778522['id']===_0xd3384f['id']);if(_0x33f370>=0x0)state['teams'][_0x33f370]=_0xd3384f;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'](_0x1d42fe=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':_0x1d42fe}));});let commandSent=![],hasReceivedOutput=![];socket['addEventListener']('message',_0x34f9ca=>{try{const _0x2fba9a=JSON['parse'](_0x34f9ca['data']);if(_0x2fba9a['type']==='data'&&typeof _0x2fba9a['data']==='string')term['write'](_0x2fba9a['data']),!hasReceivedOutput&&_0x2fba9a['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(_0x2fba9a['type']==='status'&&_0x2fba9a['status']){if(_0x2fba9a['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'+_0x2fba9a['status'],_0x2fba9a['status']==='connected'?'success':'info');}else _0x2fba9a['type']==='error'&&_0x2fba9a['message']&&updateStatus(_0x2fba9a['message'],'error');}}catch(_0x477b9f){console['error']('Failed\x20to\x20parse\x20terminal\x20message',_0x477b9f);}}),socket['addEventListener']('close',_0x36f3bf=>{const _0x2a390a=_0x36f3bf['reason']||'Connection\x20closed';updateStatus(_0x2a390a,_0x36f3bf['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',_0x28a65f=>{console['error']('Terminal\x20websocket\x20error',_0x28a65f),updateStatus('Connection\x20error','error');});function sendResize(){if(socket['readyState']!==WebSocket['OPEN'])return;const _0x3293f1=term['cols'],_0x5a5530=term['rows'];socket['send'](JSON['stringify']({'type':'resize','cols':_0x3293f1,'rows':_0x5a5530}));}function updateStatus(_0x2ea623,_0x2bac3a='info'){if(!statusEl)return;statusEl['textContent']=_0x2ea623,statusEl['dataset']['variant']=_0x2bac3a;}async function enrichContainerDetails(_0xdadef2){try{const _0x2322a4=await API['getContainer'](_0xdadef2);updateTerminalDetails(_0x2322a4);}catch{try{const _0x3fd649=await API['getContainers'](),_0x160dd6=(_0x3fd649['containers']||[])['find'](_0x51bd64=>_0x51bd64['containerId']===_0xdadef2||_0x51bd64['name']===_0xdadef2||_0x51bd64['fullContainerId']?.['startsWith'](_0xdadef2));if(_0x160dd6){updateTerminalDetails(_0x160dd6);return;}subtitleEl['textContent']='Container\x20'+_0xdadef2['substring'](0x0,0xc);}catch{subtitleEl['textContent']='Container\x20'+_0xdadef2['substring'](0x0,0xc);}}}function updateTerminalDetails(_0x1be82b){const _0x557449=_0x1be82b['containerId']||_0x1be82b['name']||_0x1be82b['fullContainerId']||containerId,_0x9b5fc6=_0x1be82b['environment']?'Environment\x20'+_0x1be82b['environment']:'Environment\x20unknown',_0x3f35b5=_0x1be82b['defaultAgent']?'\x20·\x20Agent\x20'+_0x1be82b['defaultAgent']:'',_0xa6b8a5=_0x1be82b['createdAt']?'\x20·\x20Started\x20'+Utils['formatRelativeTime'](_0x1be82b['createdAt']):'';titleEl['textContent']='Terminal\x20·\x20'+_0x557449['substring'](0x0,0xc);const _0x4e65c2=command?'\x20·\x20Command\x20'+command:'';subtitleEl['textContent']=''+_0x9b5fc6+_0x3f35b5+_0xa6b8a5+_0x4e65c2;}
@@ -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 _0x4fbfc=localStorage['getItem'](THEME_STORAGE_KEY);if(_0x4fbfc&&VALID_THEMES['has'](_0x4fbfc))return _0x4fbfc;}catch(_0x1eef92){console['warn']('[Theme]\x20Failed\x20to\x20read\x20stored\x20theme\x20preference:',_0x1eef92);}return null;}export function getPreferredTheme(){const _0x690d1b=readStoredTheme();if(_0x690d1b)return _0x690d1b;const _0x4d6c87=window['matchMedia']&&window['matchMedia']('(prefers-color-scheme:\x20dark)')['matches'];return _0x4d6c87?'dark':'light';}export function getCurrentTheme(){const _0x121f71=document['documentElement']['dataset']['theme'];if(_0x121f71&&VALID_THEMES['has'](_0x121f71))return _0x121f71;return getPreferredTheme();}export function applyTheme(_0x24dfc2,{persist:persist=!![],emitEvent:emitEvent=!![]}={}){const _0xafe2d1=VALID_THEMES['has'](_0x24dfc2)?_0x24dfc2:'light';document['documentElement']['dataset']['theme']=_0xafe2d1,document['documentElement']['style']['colorScheme']=_0xafe2d1==='dark'?'dark':'light';if(persist)try{localStorage['setItem'](THEME_STORAGE_KEY,_0xafe2d1);}catch(_0x1213f7){console['warn']('[Theme]\x20Failed\x20to\x20persist\x20theme\x20preference:',_0x1213f7);}return emitEvent&&window['dispatchEvent'](new CustomEvent(THEME_CHANGE_EVENT,{'detail':{'theme':_0xafe2d1}})),_0xafe2d1;}export function initTheme(_0x200e4b={}){const {emitEvent:emitEvent=![]}=_0x200e4b;return applyTheme(getPreferredTheme(),{'persist':![],'emitEvent':emitEvent});}export function toggleTheme(){const _0x229bbb=getCurrentTheme()==='dark'?'light':'dark';return applyTheme(_0x229bbb);}export function onThemeChange(_0x11f802,{runImmediately:runImmediately=![]}={}){const _0x2ab37d=_0x321caf=>{_0x11f802(_0x321caf['detail']['theme']);};return window['addEventListener'](THEME_CHANGE_EVENT,_0x2ab37d),runImmediately&&_0x11f802(getCurrentTheme()),()=>window['removeEventListener'](THEME_CHANGE_EVENT,_0x2ab37d);}export function mountThemeToggle(_0x2d5fb5={}){const {targetSelectors:targetSelectors=DEFAULT_TARGET_SELECTORS}=_0x2d5fb5,_0x3c0aa5=targetSelectors['map'](_0x3a886e=>document['querySelector'](_0x3a886e))['find'](Boolean),_0x2443d3=document['createElement']('button');_0x2443d3['type']='button',_0x2443d3['className']='btn-ghost\x20theme-toggle-btn',_0x2443d3['id']='theme-toggle-btn',_0x2443d3['setAttribute']('aria-pressed','false'),_0x2443d3['style']['padding']='8px',_0x2443d3['style']['lineHeight']='0',_0x2443d3['style']['width']='36px',_0x2443d3['style']['height']='36px',_0x2443d3['style']['display']='flex',_0x2443d3['style']['alignItems']='center',_0x2443d3['style']['justifyContent']='center';const _0x252205=document['createElement']('span');_0x252205['className']='theme-icon',_0x252205['style']['display']='flex',_0x2443d3['append'](_0x252205);const _0x21c631='<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>',_0x532d0f='<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>',_0x10a915=_0x3b40ed=>{const _0x5592ed=_0x3b40ed==='dark';_0x252205['innerHTML']=_0x5592ed?_0x21c631:_0x532d0f,_0x2443d3['title']=_0x5592ed?'Switch\x20to\x20light\x20mode':'Switch\x20to\x20dark\x20mode',_0x2443d3['dataset']['theme']=_0x3b40ed,_0x2443d3['setAttribute']('aria-pressed',String(_0x5592ed));};return _0x2443d3['addEventListener']('click',()=>{const _0x46d1a6=getCurrentTheme()==='dark'?'light':'dark';applyTheme(_0x46d1a6);}),_0x3c0aa5?_0x3c0aa5['appendChild'](_0x2443d3):(_0x2443d3['classList']['add']('theme-toggle-floating'),document['body']['appendChild'](_0x2443d3)),_0x10a915(initTheme()),onThemeChange(_0x10a915),_0x2443d3;}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 _0xa8039a=await API['getCurrentUser']();state['currentUser']=_0xa8039a;if(!Permissions['hasServerPermission'](_0xa8039a,'*')&&!Permissions['hasServerPermission'](_0xa8039a,'users:create')){Utils['showToast']('Access\x20denied:\x20Server\x20admin\x20privileges\x20required','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}}catch(_0x55190d){window['location']['href']='login.html';}}async function checkEmailConfig(){try{const _0x348d5d=await API['getEmailConfig']();state['emailConfigured']=_0x348d5d['configured'];}catch(_0x4d5d1b){console['error']('Failed\x20to\x20check\x20email\x20config',_0x4d5d1b),state['emailConfigured']=![];}}async function loadRoles(){try{const {roles:_0x5dff49}=await API['getRoleDefinitions']();state['roles']=_0x5dff49||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x3c9959=await API['getEnvironments']();state['environments']=_0x3c9959['environments']||[];}catch{state['environments']=[];}}async function loadTeams(){try{const {teams:_0x432780}=await API['getTeams']();state['teams']=_0x432780||[];}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 _0x3695f5=document['getElementById']('users-loading'),_0x2833ff=document['getElementById']('users-error'),_0x60b212=document['getElementById']('users-content');try{_0x3695f5['hidden']=![],_0x2833ff['hidden']=!![],_0x60b212['hidden']=!![];const _0x14ff5c=await API['getUsers']();state['users']=_0x14ff5c['users']||[],renderUsers(),_0x3695f5['hidden']=!![],_0x60b212['hidden']=![];}catch(_0x266704){console['error']('Failed\x20to\x20load\x20users',_0x266704),_0x3695f5['hidden']=!![],_0x2833ff['hidden']=![],document['getElementById']('users-error-message')['textContent']=_0x266704['message'];}}function renderUsers(){const _0x295823=document['getElementById']('users-table-body'),_0x598723=document['getElementById']('user-count');if(!_0x295823)return;_0x598723&&(_0x598723['textContent']=state['users']['length']+'\x20user'+(state['users']['length']===0x1?'':'s'));const _0x1bc13e=[...state['users']]['sort']((_0x4b320f,_0x40fccd)=>{const _0x2d261e=new Date(_0x4b320f['created_at'])['getTime'](),_0x194808=new Date(_0x40fccd['created_at'])['getTime']();return _0x194808-_0x2d261e;});_0x295823['innerHTML']=_0x1bc13e['map'](_0x5f5ae3=>'\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'](_0x5f5ae3['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'](_0x5f5ae3['name'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x5f5ae3['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'+(_0x5f5ae3['isServerAdmin']?'<span\x20class=\x22role-badge\x20role-admin\x22>Server\x20Admin</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x5f5ae3['hasUserBinding']?'<span\x20class=\x22role-badge\x20role-user-binding\x22>User\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x5f5ae3['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'](_0x5f5ae3['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'+_0x5f5ae3['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'+_0x5f5ae3['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'+_0x5f5ae3['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'+_0x5f5ae3['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(_0x43b5ad){const _0x21955d=state['users']['find'](_0x24680f=>_0x24680f['id']===_0x43b5ad);if(!_0x21955d)return;state['bindingsUserId']=_0x43b5ad,state['bindingsDirty']=![];const _0x3a6c26=document['getElementById']('bindings-modal'),_0x1b2c57=document['getElementById']('bindings-modal-title');_0x1b2c57['textContent']='Access\x20Bindings\x20—\x20'+_0x21955d['name'],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],_0x3a6c26['hidden']=![],loadUserBindings(_0x43b5ad);};function hasUnsavedBindingChanges(){const _0x530846=document['getElementById']('add-user-binding-form');return _0x530846&&!_0x530846['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 _0x2da275=document['getElementById']('bindings-modal');_0x2da275['hidden']=!![];const _0x4c403b=state['bindingsDirty'];state['bindingsUserId']=null,state['userBindings']=[],state['bindingsDirty']=![],_0x4c403b&&await loadUsers();}async function loadUserBindings(_0xe3b620){const _0x5ed437=document['getElementById']('user-bindings-loading'),_0x12b0dd=document['getElementById']('user-bindings-empty'),_0x5137a1=document['getElementById']('user-bindings-list-container'),_0x227ad1=document['getElementById']('add-user-binding-btn'),_0x56153e=document['getElementById']('user-team-bindings-note'),_0x3f97be=document['getElementById']('user-team-bindings-text');_0x5ed437['hidden']=![],_0x12b0dd['hidden']=!![],_0x5137a1['style']['display']='none',_0x227ad1['hidden']=!![],_0x56153e['hidden']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![];try{const [_0x40c2f2,_0x4c554b]=await Promise['all']([API['getBindings']({'subject_type':'user','subject_id':_0xe3b620}),API['getTeams']()]);state['userBindings']=_0x40c2f2['bindings']||[];const _0x505cdb=(_0x4c554b['teams']||[])['filter'](_0x3eb8f3=>(_0x3eb8f3['members']||[])['includes'](_0xe3b620)),_0x79a122=[];if(_0x505cdb['length']>0x0){const _0x3ba52d=await Promise['all'](_0x505cdb['map'](_0x50f70b=>API['getBindings']({'subject_type':'team','subject_id':_0x50f70b['id']})));for(let _0xf9b0a3=0x0;_0xf9b0a3<_0x505cdb['length'];_0xf9b0a3++){const _0xf32468=_0x3ba52d[_0xf9b0a3]['bindings']||[];_0xf32468['length']>0x0&&_0x79a122['push'](_0x505cdb[_0xf9b0a3]);}}_0x5ed437['hidden']=!![];state['userBindings']['length']===0x0?_0x12b0dd['hidden']=![]:(_0x5137a1['style']['display']='',renderUserBindingsTable());if(_0x79a122['length']>0x0){const _0xbcf271=_0x79a122['map'](_0x45d814=>_0x45d814['name']),_0x207518=_0xbcf271['length']<=0x3?_0xbcf271['join'](',\x20'):_0xbcf271['slice'](0x0,0x3)['join'](',\x20')+(',\x20and\x20'+(_0xbcf271['length']-0x3)+'\x20more');_0x3f97be['textContent']='This\x20user\x20also\x20has\x20access\x20via\x20team\x20memberships\x20('+_0x207518+').';}else _0x3f97be['textContent']='This\x20user\x20has\x20no\x20access\x20via\x20team\x20memberships.';_0x56153e['hidden']=![],_0x227ad1['hidden']=![];}catch(_0x4ce0a2){_0x5ed437['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x4ce0a2['message'],'error');}}function renderUserBindingsTable(){const _0x91bfe1=document['getElementById']('user-bindings-table-body');if(!_0x91bfe1)return;_0x91bfe1['innerHTML']=state['userBindings']['map'](_0x248317=>{const _0x22604e=_0x248317['resource_type']==='server'?'Server':_0x248317['resource_id']==='*'?'All\x20'+_0x248317['resource_type']+'s':Utils['escapeHtml'](_0x248317['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x22604e+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x248317['role_name']||_0x248317['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'+_0x248317['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 _0x2e0874=document['getElementById']('user-binding-resource-type');_0x2e0874['value']='environment',updateUserBindingFormForResourceType('environment');}function onUserBindingResourceTypeChange(){const _0x290ac6=document['getElementById']('user-binding-resource-type')['value'];updateUserBindingFormForResourceType(_0x290ac6);}function updateUserBindingFormForResourceType(_0x24fcf4){const _0x118a34=document['getElementById']('user-binding-resource-container'),_0x356899=document['getElementById']('user-binding-resource'),_0x1f18f1=document['getElementById']('user-binding-role');if(_0x24fcf4==='server')_0x118a34['style']['display']='none';else{_0x118a34['style']['display']='';if(_0x24fcf4==='environment'){const _0x320919=new Set(state['userBindings']['filter'](_0x1ea084=>_0x1ea084['resource_type']==='environment')['map'](_0x2af3d9=>_0x2af3d9['resource_id'])),_0x5a8c59=state['environments']['filter'](_0x5ef658=>!_0x320919['has'](_0x5ef658['name']));_0x356899['innerHTML']=_0x5a8c59['length']?_0x5a8c59['map'](_0x4b1098=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x4b1098['name'])+'\x22>'+Utils['escapeHtml'](_0x4b1098['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x24fcf4==='team'){const _0xfc521b=new Set(state['userBindings']['filter'](_0x1f844d=>_0x1f844d['resource_type']==='team')['map'](_0x89fdc=>_0x89fdc['resource_id'])),_0x5391ed=state['teams']['filter'](_0x373561=>!_0xfc521b['has'](_0x373561['id']));_0x356899['innerHTML']=_0x5391ed['length']?_0x5391ed['map'](_0x5eed16=>'<option\x20value=\x22'+_0x5eed16['id']+'\x22>'+Utils['escapeHtml'](_0x5eed16['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x405b3a=state['roles']['filter'](_0x24483a=>_0x24483a['resource_type']===_0x24fcf4);_0x1f18f1['innerHTML']=_0x405b3a['length']?_0x405b3a['filter'](_0x3e9b4b=>{const _0x367672=_0x24fcf4==='server'?undefined:_0x356899['value'];return!state['userBindings']['some'](_0x24cdc8=>_0x24cdc8['resource_type']===_0x24fcf4&&_0x24cdc8['role_id']===_0x3e9b4b['id']&&(_0x24fcf4==='server'||_0x24cdc8['resource_id']===_0x367672));})['map'](_0x1916dc=>'<option\x20value=\x22'+_0x1916dc['id']+'\x22>'+Utils['escapeHtml'](_0x1916dc['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 _0x59ce84=document['getElementById']('user-binding-resource-type')['value'],_0x33a69d=document['getElementById']('user-binding-role')['value'];if(!_0x33a69d||!state['bindingsUserId'])return;const _0x50d0ea=_0x59ce84==='server'?undefined:document['getElementById']('user-binding-resource')['value'];if(_0x59ce84!=='server'&&!_0x50d0ea)return;const _0x47ed84=document['getElementById']('save-user-binding-btn');_0x47ed84['disabled']=!![],_0x47ed84['textContent']='Adding…';try{const _0x56c490={'subject_type':'user','subject_id':state['bindingsUserId'],'role_id':_0x33a69d,'resource_type':_0x59ce84};if(_0x50d0ea)_0x56c490['resource_id']=_0x50d0ea;await API['createBinding'](_0x56c490),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(_0x3ad2ec){Utils['showToast'](_0x3ad2ec['message'],'error');}finally{_0x47ed84['disabled']=![],_0x47ed84['textContent']='Add\x20Binding';}}window['deleteUserBindingClick']=async function(_0x28cd10){try{await API['deleteBinding'](_0x28cd10),Utils['showToast']('Binding\x20removed','success'),state['bindingsDirty']=!![],await loadUserBindings(state['bindingsUserId']);}catch(_0x44962b){Utils['showToast'](_0x44962b['message'],'error');}};function showCreateUserModal(){state['editingUserId']=null;const _0x92043a=document['getElementById']('user-modal'),_0x32a255=document['getElementById']('modal-title'),_0x2b3df3=document['getElementById']('user-password'),_0x5c1224=document['getElementById']('password-required'),_0x281e60=document['getElementById']('password-hint'),_0x585a8e=document['getElementById']('skip-password-container'),_0x1e95e0=document['getElementById']('skip-password');_0x32a255['textContent']='Create\x20User',document['getElementById']('user-form')['reset'](),_0x2b3df3['required']=!![];if(_0x5c1224)_0x5c1224['textContent']='*';_0x585a8e&&(_0x585a8e['style']['display']='block',_0x1e95e0['checked']=![]),_0x281e60&&(_0x281e60['textContent']='Minimum\x208\x20characters'),_0x92043a['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);}window['editUser']=function(_0x3ff0fd){const _0x5b0582=state['users']['find'](_0x316a7b=>_0x316a7b['id']===_0x3ff0fd);if(!_0x5b0582)return;state['editingUserId']=_0x3ff0fd;const _0x5b871e=document['getElementById']('user-modal'),_0x22755c=document['getElementById']('modal-title'),_0x16fcc4=document['getElementById']('user-password'),_0xb033e2=document['getElementById']('password-required'),_0x3aef9d=document['getElementById']('password-hint'),_0x77f5c5=document['getElementById']('skip-password-container');_0x22755c['textContent']='Edit\x20User',document['getElementById']('user-username')['value']=_0x5b0582['username'],document['getElementById']('user-name')['value']=_0x5b0582['name'],document['getElementById']('user-email')['value']=_0x5b0582['email'],_0x16fcc4['value']='',_0x16fcc4['required']=![];if(_0xb033e2)_0xb033e2['textContent']='';_0x77f5c5&&(_0x77f5c5['style']['display']='none'),_0x3aef9d&&(_0x3aef9d['textContent']='Leave\x20blank\x20to\x20keep\x20current\x20password'),_0x5b871e['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);};function hideUserModal(){const _0x5b2fcd=document['getElementById']('user-modal'),_0x1daaac=document['getElementById']('form-error'),_0x27f0ed=document['getElementById']('save-user');_0x5b2fcd['hidden']=!![],_0x1daaac['hidden']=!![],state['editingUserId']=null,_0x27f0ed&&(_0x27f0ed['disabled']=![],_0x27f0ed['textContent']='Save\x20User');}async function saveUser(){const _0x49285a=document['getElementById']('user-form'),_0x13045f=document['getElementById']('skip-password')?.['checked']||![];if(!_0x13045f&&!_0x49285a['checkValidity']()){_0x49285a['reportValidity']();return;}const _0x3ab21f=document['getElementById']('form-error'),_0x40b088=document['getElementById']('save-user'),_0x56ba94=document['getElementById']('user-username')['value']['trim'](),_0x3e8bf0=document['getElementById']('user-name')['value']['trim'](),_0x3f674f=document['getElementById']('user-email')['value']['trim'](),_0x47c4f7=document['getElementById']('user-password')['value'];if(!_0x56ba94||!_0x3e8bf0||!_0x3f674f){_0x3ab21f['textContent']='Please\x20fill\x20in\x20all\x20required\x20fields',_0x3ab21f['hidden']=![],_0x3ab21f['scrollIntoView']({'behavior':'smooth','block':'nearest'});return;}_0x3ab21f['hidden']=!![];const _0x27dd8e=_0x40b088['textContent'];_0x40b088['disabled']=!![],_0x40b088['textContent']=state['editingUserId']?'Updating...':'Creating...';try{if(state['editingUserId']){const _0x35e43e={'username':_0x56ba94,'name':_0x3e8bf0,'email':_0x3f674f};_0x47c4f7&&(_0x35e43e['password']=_0x47c4f7),await API['updateUser'](state['editingUserId'],_0x35e43e),Utils['showToast']('User\x20updated\x20successfully','success'),await loadUsers(),hideUserModal();}else{const _0x18137e={'username':_0x56ba94,'name':_0x3e8bf0,'email':_0x3f674f};if(!_0x13045f){if(!_0x47c4f7)throw new Error('Password\x20is\x20required\x20for\x20new\x20users');_0x18137e['password']=_0x47c4f7;}const _0x378d6f=await API['createUser'](_0x18137e),_0x433726=_0x378d6f['user'];if(_0x13045f||!_0x47c4f7){const _0x1df77d=await API['createPasswordToken'](_0x433726['id'],'setup',![]);state['setupLinkData']={'username':_0x433726['username'],'email':_0x433726['email'],'url':_0x1df77d['token']['setupUrl'],'userId':_0x433726['id'],'type':'setup','emailSent':![]},await loadUsers(),hideUserModal(),showSetupLinkModal();}else Utils['showToast']('User\x20created\x20successfully','success'),await loadUsers(),hideUserModal();}}catch(_0x50bed7){console['error']('Failed\x20to\x20save\x20user',_0x50bed7),_0x3ab21f['textContent']=_0x50bed7['message'],_0x3ab21f['hidden']=![],_0x3ab21f['scrollIntoView']({'behavior':'smooth','block':'nearest'}),_0x40b088['disabled']=![],_0x40b088['textContent']=_0x27dd8e;}}window['deleteUser']=function(_0x2a06e0){const _0x872413=state['users']['find'](_0x27ed0a=>_0x27ed0a['id']===_0x2a06e0);if(!_0x872413)return;state['deletingUserId']=_0x2a06e0;const _0x433016=document['getElementById']('delete-modal'),_0x3ab430=document['getElementById']('delete-user-name');_0x3ab430['textContent']=_0x872413['name']+'\x20('+_0x872413['username']+')',_0x433016['hidden']=![];};function hideDeleteModal(){const _0x22e2da=document['getElementById']('delete-modal');_0x22e2da['hidden']=!![],state['deletingUserId']=null;const _0x24cafa=document['getElementById']('confirm-delete');_0x24cafa&&(_0x24cafa['disabled']=![],_0x24cafa['textContent']='Delete\x20User');}async function confirmDeleteUser(){if(!state['deletingUserId'])return;const _0x166933=document['getElementById']('confirm-delete'),_0x558e08=_0x166933['textContent'];_0x166933['disabled']=!![],_0x166933['textContent']='Deleting...';try{await API['deleteUser'](state['deletingUserId']),Utils['showToast']('User\x20deleted\x20successfully','success'),await loadUsers(),hideDeleteModal();}catch(_0x4d67eb){console['error']('Failed\x20to\x20delete\x20user',_0x4d67eb),Utils['showToast']('Failed\x20to\x20delete\x20user:\x20'+_0x4d67eb['message'],'error'),_0x166933['disabled']=![],_0x166933['textContent']=_0x558e08;}}function handleSkipPasswordChange(_0x54fdc9){const _0x271227=document['getElementById']('user-password'),_0x32e3a8=_0x54fdc9['target']['checked'];_0x32e3a8?(_0x271227['required']=![],_0x271227['disabled']=!![],_0x271227['value']=''):(_0x271227['required']=!![],_0x271227['disabled']=![]);}function showSetupLinkModal(){if(!state['setupLinkData'])return;const _0x157b7e=document['getElementById']('setup-link-modal'),_0x2fee86=document['getElementById']('setup-link-username'),_0xb582c5=document['getElementById']('setup-link-url'),_0x3c8d17=document['getElementById']('email-setup-link'),_0x257ab5=document['getElementById']('email-button-text');_0x2fee86['textContent']=state['setupLinkData']['username'],_0xb582c5['textContent']=state['setupLinkData']['url'],_0x3c8d17&&_0x257ab5&&(_0x3c8d17['disabled']=![],_0x257ab5['textContent']='Email\x20Link',state['emailConfigured']&&!state['setupLinkData']['emailSent']?_0x3c8d17['style']['display']='inline-block':_0x3c8d17['style']['display']='none'),_0x157b7e['hidden']=![];}function hideSetupLinkModal(){const _0x14ad41=document['getElementById']('setup-link-modal');_0x14ad41['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(_0xc714d6){console['error']('Failed\x20to\x20copy\x20link',_0xc714d6),Utils['showToast']('Failed\x20to\x20copy\x20link','error');}}async function emailSetupLink(){if(!state['setupLinkData'])return;const _0x58117a=document['getElementById']('email-setup-link'),_0x9ff27f=document['getElementById']('email-button-text');if(!_0x58117a||!_0x9ff27f)return;const _0x2584bb=_0x9ff27f['textContent'];_0x58117a['disabled']=!![],_0x9ff27f['textContent']='Sending...';try{const _0x451c20=await API['createPasswordToken'](state['setupLinkData']['userId'],state['setupLinkData']['type'],!![]);if(_0x451c20['emailSent'])Utils['showToast']('Email\x20sent\x20to\x20'+state['setupLinkData']['email'],'success'),state['setupLinkData']['emailSent']=!![],_0x58117a['style']['display']='none';else{const _0x1decfd=_0x451c20['emailError']||'Failed\x20to\x20send\x20email';Utils['showToast'](_0x1decfd,'error'),_0x58117a['disabled']=![],_0x9ff27f['textContent']=_0x2584bb;}}catch(_0x31fa13){console['error']('Failed\x20to\x20email\x20setup\x20link',_0x31fa13),Utils['showToast']('Failed\x20to\x20send\x20email:\x20'+_0x31fa13['message'],'error'),_0x58117a['disabled']=![],_0x9ff27f['textContent']=_0x2584bb;}}window['resetPassword']=async function(_0x304238){const _0x46c365=state['users']['find'](_0x30c500=>_0x30c500['id']===_0x304238);if(!_0x46c365)return;const _0x1c41e7=await ConfirmDialog['show']({'title':'Reset\x20Password','message':'Generate\x20a\x20password\x20reset\x20link\x20for\x20'+_0x46c365['name']+'\x20('+_0x46c365['username']+')?\x20This\x20will\x20create\x20a\x20link\x20that\x20they\x20can\x20use\x20to\x20set\x20a\x20new\x20password.','confirmText':'Generate\x20Link'});if(!_0x1c41e7)return;try{const _0x1a2640=await API['createPasswordToken'](_0x304238,'reset',![]);state['setupLinkData']={'username':_0x46c365['username'],'email':_0x46c365['email'],'url':_0x1a2640['token']['setupUrl'],'userId':_0x46c365['id'],'type':'reset','emailSent':![]},showSetupLinkModal();}catch(_0x5f4247){console['error']('Failed\x20to\x20create\x20password\x20reset\x20link',_0x5f4247),Utils['showToast']('Failed\x20to\x20create\x20password\x20reset\x20link:\x20'+_0x5f4247['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(_0x374a81={}){this['container']=null,this['onGroupChange']=_0x374a81['onGroupChange']||(()=>{}),this['onAddExistingTask']=_0x374a81['onAddExistingTask']||(()=>{}),this['tasks']=[],this['groupId']=_0x374a81['groupId']||null,this['isOpen']=![];}['init'](_0x503a79,_0x1469ba,_0x2aa071){this['container']=_0x503a79,this['tasks']=_0x1469ba,this['groupId']=_0x2aa071,this['render'](),this['attachEventListeners']();}['updateTasks'](_0x5a7386){const _0x37629b=new Map(_0x5a7386['map'](_0x28f67b=>[_0x28f67b['taskId'],_0x28f67b]));this['tasks']=this['tasks']['map'](_0x269b01=>{const _0x577a68=_0x37629b['get'](_0x269b01['taskId']);return _0x577a68?_0x577a68:_0x269b01;});for(const _0x853f81 of _0x5a7386){!this['tasks']['some'](_0x4a4734=>_0x4a4734['taskId']===_0x853f81['taskId'])&&this['tasks']['push'](_0x853f81);}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 _0x1238b4=this['tasks']['filter'](_0x1fc892=>_0x1fc892['groupId']===this['groupId'])['sort']((_0x339f98,_0x35de0c)=>(_0x339f98['groupIndex']??0x0)-(_0x35de0c['groupIndex']??0x0)),_0x15937a=this['tasks']['filter'](_0xa7f465=>!_0xa7f465['groupId']||_0xa7f465['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>'+_0x1238b4['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'+(_0x1238b4['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20add\x20to\x20group</div>':_0x1238b4['map']((_0x13c682,_0x4a2049)=>this['renderVariantCard'](_0x13c682,_0x4a2049,!![]))['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>'+_0x15937a['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'+(_0x15937a['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20remove\x20from\x20group</div>':_0x15937a['map']((_0x23cdaf,_0x1136b5)=>this['renderVariantCard'](_0x23cdaf,_0x1136b5,![]))['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'](_0x3d30ab,_0x2fe9ac,_0x547063){const _0x351f12=_0x3d30ab['envVars']?.['CODER_AGENT']||_0x3d30ab['envVars']?.['default_agent']||'claude',_0x3620de=AGENT_ICONS[_0x351f12['toLowerCase']()]||AGENT_ICONS['claude'],_0x40a002=STATUS_ICONS[_0x3d30ab['status']]||'',_0x2a1fc4='status-'+(_0x3d30ab['status']||'unknown'),_0x1fd7a4=_0x3d30ab['isWinner']?'<span\x20class=\x22vgm-badge\x20vgm-badge-winner\x22\x20title=\x22Winner\x22>★</span>':'',_0x545cdc=_0x3d30ab['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'+_0x2a1fc4+'\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'+_0x3d30ab['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-is-grouped=\x22'+_0x547063+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-index=\x22'+_0x2fe9ac+'\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'+_0x351f12['toLowerCase']()+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x3620de+'\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'](_0x3d30ab['name']||'Task\x20'+_0x3d30ab['taskId']['slice'](-0x6))+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-meta\x22>'+Utils['escapeHtml'](_0x351f12)+'\x20·\x20'+(_0x3d30ab['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'+_0x1fd7a4+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x545cdc+'\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'+_0x2a1fc4+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x40a002+'\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'+(_0x547063?'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'+_0x3d30ab['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-action=\x22'+(_0x547063?'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'+(_0x547063?'<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',_0x112979=>{_0x112979['target']['closest']('.vgm-close-btn')&&(this['close'](),this['onGroupChange'](this['tasks'])),_0x112979['target']['closest']('.vgm-add-existing-btn')&&(this['close'](),this['onAddExistingTask'](this['groupId']));}),this['container']['addEventListener']('click',async _0x26a1fb=>{const _0x1b47b7=_0x26a1fb['target']['closest']('.vgm-variant-remove-btn');if(!_0x1b47b7)return;const _0x21ce8f=_0x1b47b7['dataset']['taskId'],_0x2ba49d=_0x1b47b7['dataset']['action'];try{_0x2ba49d==='remove'?await this['removeFromGroup'](_0x21ce8f):await this['addToGroup'](_0x21ce8f);}catch(_0x3cb2e4){console['error']('Failed\x20to\x20update\x20group:',_0x3cb2e4),Utils['showToast'](_0x3cb2e4['message']||'Failed\x20to\x20update\x20group','error');}}),this['container']['addEventListener']('dragstart',_0x1e08e9=>this['handleDragStart'](_0x1e08e9)),this['container']['addEventListener']('dragend',_0x2266d6=>this['handleDragEnd'](_0x2266d6)),this['container']['addEventListener']('dragover',_0x36c430=>this['handleDragOver'](_0x36c430)),this['container']['addEventListener']('dragleave',_0x39ec58=>this['handleDragLeave'](_0x39ec58)),this['container']['addEventListener']('drop',_0x1d8e03=>this['handleDrop'](_0x1d8e03));}['handleDragStart'](_0x3fde35){const _0x5c078e=_0x3fde35['target']['closest']('.vgm-variant-card');if(!_0x5c078e)return;dragState['draggedTaskId']=_0x5c078e['dataset']['taskId'],dragState['draggedElement']=_0x5c078e,dragState['sourceGroupId']=_0x5c078e['dataset']['isGrouped']==='true'?this['groupId']:null,dragState['isDragging']=!![],_0x5c078e['classList']['add']('dragging'),_0x3fde35['dataTransfer']['effectAllowed']='move',_0x3fde35['dataTransfer']['setData']('text/plain',_0x5c078e['dataset']['taskId']),this['container']['classList']['add']('is-dragging');}['handleDragEnd'](_0x4da670){const _0x242891=_0x4da670['target']['closest']('.vgm-variant-card');_0x242891&&_0x242891['classList']['remove']('dragging'),this['container']['querySelectorAll']('.drag-over,\x20.drop-indicator')['forEach'](_0xd2ff01=>{_0xd2ff01['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'](_0x2a35b8){_0x2a35b8['preventDefault'](),_0x2a35b8['dataTransfer']['dropEffect']='move';const _0x1f1605=_0x2a35b8['target']['closest']('.vgm-drop-zone'),_0xfb03ce=_0x2a35b8['target']['closest']('.vgm-variant-card');this['container']['querySelectorAll']('.vgm-drop-zone')['forEach'](_0x268172=>{_0x268172['classList']['toggle']('drag-over',_0x268172===_0x1f1605);});if(_0xfb03ce&&_0xfb03ce!==dragState['draggedElement']){const _0x55ec0e=_0xfb03ce['getBoundingClientRect'](),_0x133b30=_0x55ec0e['top']+_0x55ec0e['height']/0x2,_0x26308f=_0x2a35b8['clientY']<_0x133b30;this['container']['querySelectorAll']('.vgm-variant-card')['forEach'](_0x1bf46f=>{_0x1bf46f!==_0xfb03ce&&_0x1bf46f['classList']['remove']('drop-before','drop-after');}),_0xfb03ce['classList']['toggle']('drop-before',_0x26308f),_0xfb03ce['classList']['toggle']('drop-after',!_0x26308f);}}['handleDragLeave'](_0x5e2aa5){const _0xe597ac=_0x5e2aa5['target']['closest']('.vgm-drop-zone');_0xe597ac&&!_0xe597ac['contains'](_0x5e2aa5['relatedTarget'])&&_0xe597ac['classList']['remove']('drag-over');}async['handleDrop'](_0x445afa){_0x445afa['preventDefault']();const _0x12ec7c=_0x445afa['target']['closest']('.vgm-drop-zone'),_0x59cff7=_0x445afa['target']['closest']('.vgm-variant-card'),_0x59bfe0=_0x445afa['dataTransfer']['getData']('text/plain');if(!_0x12ec7c||!_0x59bfe0)return;this['container']['querySelectorAll']('.drag-over,\x20.drop-before,\x20.drop-after')['forEach'](_0x5c7246=>{_0x5c7246['classList']['remove']('drag-over','drop-before','drop-after');});const _0x380bd1=_0x12ec7c['dataset']['zone'],_0x1bc63a=_0x380bd1==='grouped',_0x32f897=dragState['sourceGroupId']===this['groupId'];try{if(_0x1bc63a&&!_0x32f897){let _0x113e56=this['tasks']['filter'](_0x2939de=>_0x2939de['groupId']===this['groupId'])['length'];if(_0x59cff7){const _0x46fc9d=_0x59cff7['dataset']['taskId'],_0x342406=this['tasks']['find'](_0x1b72fe=>_0x1b72fe['taskId']===_0x46fc9d);if(_0x342406?.['groupIndex']!==undefined){const _0xf12da0=_0x59cff7['getBoundingClientRect'](),_0x4cfb2c=_0x445afa['clientY']<_0xf12da0['top']+_0xf12da0['height']/0x2;_0x113e56=_0x342406['groupIndex']+(_0x4cfb2c?0x0:0x1);}}await this['addToGroup'](_0x59bfe0,_0x113e56);}else{if(!_0x1bc63a&&_0x32f897)await this['removeFromGroup'](_0x59bfe0);else _0x1bc63a&&_0x32f897&&_0x59cff7&&await this['reorderInGroup'](_0x59bfe0,_0x59cff7,_0x445afa['clientY']);}}catch(_0xa02aec){console['error']('Drop\x20operation\x20failed:',_0xa02aec),Utils['showToast'](_0xa02aec['message']||'Failed\x20to\x20move\x20variant','error');}}async['addToGroup'](_0x18a59c,_0x2fce5b){const _0x4afdd3=this['tasks']['find'](_0x3b257d=>_0x3b257d['taskId']===_0x18a59c);if(!_0x4afdd3)return;_0x2fce5b===undefined&&(_0x2fce5b=this['tasks']['filter'](_0x36f6a7=>_0x36f6a7['groupId']===this['groupId'])['length']),!this['groupId']&&(this['groupId']=API['generateGroupId'](),await API['createTaskGroup']({'groupId':this['groupId']})),await API['updateTaskGroup'](_0x18a59c,this['groupId'],_0x2fce5b),_0x4afdd3['groupId']=this['groupId'],_0x4afdd3['groupIndex']=_0x2fce5b,this['render'](),this['onGroupChange'](this['tasks']);}async['removeFromGroup'](_0x473b03){const _0x4f45f3=this['tasks']['find'](_0xef28df=>_0xef28df['taskId']===_0x473b03);if(!_0x4f45f3)return;await API['removeTaskFromGroup'](_0x473b03),_0x4f45f3['groupId']=null,_0x4f45f3['groupIndex']=null,this['render'](),this['onGroupChange'](this['tasks']);}async['reorderInGroup'](_0xbf3f78,_0x23283d,_0x11abee){const _0x1f82f9=this['tasks']['find'](_0x3b9c28=>_0x3b9c28['taskId']===_0xbf3f78),_0x377e0f=_0x23283d['dataset']['taskId'],_0x2e5681=this['tasks']['find'](_0x286729=>_0x286729['taskId']===_0x377e0f);if(!_0x1f82f9||!_0x2e5681||_0x1f82f9['taskId']===_0x2e5681['taskId'])return;const _0x3f4098=_0x23283d['getBoundingClientRect'](),_0x460d39=_0x11abee<_0x3f4098['top']+_0x3f4098['height']/0x2;let _0x326964=_0x2e5681['groupIndex']??0x0;if(!_0x460d39)_0x326964++;if((_0x1f82f9['groupIndex']??0x0)<(_0x2e5681['groupIndex']??0x0))_0x326964--;if(_0x326964===_0x1f82f9['groupIndex'])return;await API['updateTaskGroup'](_0xbf3f78,this['groupId'],_0x326964);const _0x4404b5=this['tasks']['filter'](_0x3d44eb=>_0x3d44eb['groupId']===this['groupId'])['sort']((_0xa02b29,_0x48f587)=>(_0xa02b29['groupIndex']??0x0)-(_0x48f587['groupIndex']??0x0)),_0x17f6f0=_0x4404b5['findIndex'](_0x5a6ba7=>_0x5a6ba7['taskId']===_0xbf3f78);_0x17f6f0!==-0x1&&_0x4404b5['splice'](_0x17f6f0,0x1),_0x4404b5['splice'](_0x326964,0x0,_0x1f82f9),_0x4404b5['forEach']((_0x1352a8,_0x15eb01)=>{_0x1352a8['groupIndex']=_0x15eb01;}),this['render'](),this['onGroupChange'](this['tasks']);}}export function initializeTabDragDrop(_0x141896,_0x5a9713,_0x6deda6,_0x4fe340={}){if(!_0x141896)return;const {onReorder:_0x25ff2a,onRemove:_0x87a6a9}=_0x4fe340,_0x34fc86=_0x141896['querySelectorAll']('.task-tab');_0x34fc86['forEach']((_0x4f2243,_0x1d4952)=>{_0x4f2243['setAttribute']('draggable','true'),_0x4f2243['dataset']['index']=_0x1d4952,_0x4f2243['addEventListener']('dragstart',_0x133392=>{_0x133392['dataTransfer']['effectAllowed']='move',_0x133392['dataTransfer']['setData']('text/plain',_0x4f2243['dataset']['taskId']),_0x4f2243['classList']['add']('dragging'),_0x141896['classList']['add']('is-dragging');}),_0x4f2243['addEventListener']('dragend',()=>{_0x4f2243['classList']['remove']('dragging'),_0x141896['classList']['remove']('is-dragging'),_0x141896['querySelectorAll']('.drop-indicator')['forEach'](_0x2065ac=>{_0x2065ac['classList']['remove']('drop-indicator','drop-before','drop-after');});}),_0x4f2243['addEventListener']('dragover',_0x580971=>{_0x580971['preventDefault'](),_0x580971['dataTransfer']['dropEffect']='move';if(_0x4f2243['classList']['contains']('dragging'))return;const _0x5b31c9=_0x4f2243['getBoundingClientRect'](),_0x21663a=_0x5b31c9['left']+_0x5b31c9['width']/0x2,_0x2d2143=_0x580971['clientX']<_0x21663a;_0x34fc86['forEach'](_0x5672b3=>_0x5672b3['classList']['remove']('drop-before','drop-after')),_0x4f2243['classList']['add'](_0x2d2143?'drop-before':'drop-after');}),_0x4f2243['addEventListener']('dragleave',()=>{_0x4f2243['classList']['remove']('drop-before','drop-after');}),_0x4f2243['addEventListener']('drop',async _0x4474dd=>{_0x4474dd['preventDefault']();const _0x45c7c8=_0x4474dd['dataTransfer']['getData']('text/plain'),_0x18f4a3=_0x4f2243['dataset']['taskId'];if(_0x45c7c8===_0x18f4a3)return;const _0x16240f=_0x4f2243['getBoundingClientRect'](),_0x415110=_0x4474dd['clientX']<_0x16240f['left']+_0x16240f['width']/0x2;_0x4f2243['classList']['remove']('drop-before','drop-after'),_0x25ff2a&&await _0x25ff2a(_0x45c7c8,_0x18f4a3,_0x415110);});});const _0x23b694=document['createElement']('div');return _0x23b694['className']='task-tab-remove-zone',_0x23b694['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',_0x23b694['style']['display']='none',_0x23b694['addEventListener']('dragover',_0x26d19e=>{_0x26d19e['preventDefault'](),_0x23b694['classList']['add']('drag-over');}),_0x23b694['addEventListener']('dragleave',()=>{_0x23b694['classList']['remove']('drag-over');}),_0x23b694['addEventListener']('drop',async _0x58ce5d=>{_0x58ce5d['preventDefault'](),_0x23b694['classList']['remove']('drag-over');const _0x26c569=_0x58ce5d['dataTransfer']['getData']('text/plain');_0x87a6a9&&await _0x87a6a9(_0x26c569);}),_0x141896['addEventListener']('dragstart',()=>{_0x5a9713['length']>0x1&&(_0x23b694['style']['display']='flex');}),_0x141896['addEventListener']('dragend',()=>{_0x23b694['style']['display']='none';}),_0x141896['appendChild'](_0x23b694),{'destroy':()=>{_0x23b694['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.4",
4
4
  "description": "AI Coder Server - Manages Docker containers for AI agent task execution",
5
5
  "main": "dist/start.js",
6
6
  "type": "module",