@profoundlogic/coderflow-server 0.6.5 → 0.6.7

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 (178) hide show
  1. package/dist/base-image/agent-wrapper.sh +1 -1
  2. package/dist/base-image/sync-repos.sh +7 -1
  3. package/dist/coder-server.js +1 -1
  4. package/dist/config/cli-models.json +0 -12
  5. package/dist/config.js +1 -1
  6. package/dist/lib/agent-keepalive.js +1 -1
  7. package/dist/lib/agent-models.js +1 -1
  8. package/dist/lib/api-keys.js +1 -1
  9. package/dist/lib/apiKeys.js +1 -1
  10. package/dist/lib/app-server-ports.js +1 -1
  11. package/dist/lib/auto-judge.js +1 -1
  12. package/dist/lib/automation-service.js +1 -1
  13. package/dist/lib/basic-auth.js +1 -1
  14. package/dist/lib/bindings.js +1 -1
  15. package/dist/lib/build-history.js +1 -1
  16. package/dist/lib/build-output-service.js +1 -1
  17. package/dist/lib/build-scheduler.js +1 -1
  18. package/dist/lib/build-service.js +1 -1
  19. package/dist/lib/ca-certificates.js +1 -1
  20. package/dist/lib/claude-oauth-refresh.js +1 -1
  21. package/dist/lib/cli/build.js +1 -1
  22. package/dist/lib/cli/cleanup-users.js +1 -1
  23. package/dist/lib/cli/config-command.js +1 -1
  24. package/dist/lib/cli/config.js +1 -1
  25. package/dist/lib/cli/create-user.js +1 -1
  26. package/dist/lib/cli/grant-admin.js +1 -1
  27. package/dist/lib/cli/init.js +1 -1
  28. package/dist/lib/cli/jira.js +1 -1
  29. package/dist/lib/cli/license.js +1 -1
  30. package/dist/lib/cli/list-roles.js +1 -1
  31. package/dist/lib/cli/list-users.js +1 -1
  32. package/dist/lib/cli/server-manager.js +1 -1
  33. package/dist/lib/cli/set-password.js +1 -1
  34. package/dist/lib/config-migration.js +1 -1
  35. package/dist/lib/container-credential-sync.js +1 -1
  36. package/dist/lib/container-tokens.js +1 -1
  37. package/dist/lib/data-dir.js +1 -1
  38. package/dist/lib/deployment-history.js +1 -1
  39. package/dist/lib/deployment-service.js +1 -1
  40. package/dist/lib/docker-utils.js +1 -1
  41. package/dist/lib/email.js +1 -1
  42. package/dist/lib/emailTemplates.js +1 -1
  43. package/dist/lib/entitlement.js +1 -1
  44. package/dist/lib/external-connections.js +1 -1
  45. package/dist/lib/fetch-utils.js +1 -1
  46. package/dist/lib/git-commit-details-route.js +1 -1
  47. package/dist/lib/git-history-diff-guardrails.js +1 -1
  48. package/dist/lib/git-provider-service.js +1 -1
  49. package/dist/lib/git-provider-setup/github-setup-handler.js +1 -1
  50. package/dist/lib/git-provider-setup/index.js +1 -1
  51. package/dist/lib/git-provider-setup/setup-factory.js +1 -1
  52. package/dist/lib/git-provider-setup/setup-interface.js +1 -1
  53. package/dist/lib/git-providers/azure-devops-provider.js +1 -1
  54. package/dist/lib/git-providers/github-app-provider.js +1 -1
  55. package/dist/lib/git-providers/index.js +1 -1
  56. package/dist/lib/git-providers/provider-factory.js +1 -1
  57. package/dist/lib/git-providers/provider-interface.js +1 -1
  58. package/dist/lib/github-urls.js +1 -1
  59. package/dist/lib/group-objective-linking.js +1 -1
  60. package/dist/lib/ibmi-sync.js +1 -1
  61. package/dist/lib/jira-client.js +1 -1
  62. package/dist/lib/judge-blinding.js +1 -1
  63. package/dist/lib/logger.js +1 -1
  64. package/dist/lib/migration-to-scoped-rbac.js +1 -1
  65. package/dist/lib/model-fetcher.js +1 -1
  66. package/dist/lib/notifications.js +1 -1
  67. package/dist/lib/objective-context.js +1 -1
  68. package/dist/lib/oidc-auth.js +1 -1
  69. package/dist/lib/oidc-device-flow.js +1 -1
  70. package/dist/lib/passwordTokens.js +1 -1
  71. package/dist/lib/permission-resolver.js +1 -1
  72. package/dist/lib/pin-cascade.js +1 -1
  73. package/dist/lib/provider-accounts.js +1 -1
  74. package/dist/lib/provider-oauth.js +1 -1
  75. package/dist/lib/provider-profile.js +1 -1
  76. package/dist/lib/provider-token-refresh.js +1 -1
  77. package/dist/lib/rbac-user-state.js +1 -1
  78. package/dist/lib/request-url.js +1 -1
  79. package/dist/lib/rewind.js +1 -1
  80. package/dist/lib/role-definitions.js +1 -1
  81. package/dist/lib/roles.js +1 -1
  82. package/dist/lib/secrets.js +1 -1
  83. package/dist/lib/setup-repo-git-auth.js +1 -1
  84. package/dist/lib/state-capture.js +1 -1
  85. package/dist/lib/static-files.js +1 -1
  86. package/dist/lib/task-aliases.js +1 -0
  87. package/dist/lib/task-name-format.js +1 -1
  88. package/dist/lib/task-name-generator.js +1 -1
  89. package/dist/lib/task-source-metadata.js +1 -1
  90. package/dist/lib/teams.js +1 -1
  91. package/dist/lib/user-git-oauth.js +1 -1
  92. package/dist/lib/user-git-tokens.js +1 -1
  93. package/dist/lib/users.js +1 -1
  94. package/dist/middleware/requireAuth.js +1 -1
  95. package/dist/middleware/requireInit.js +1 -1
  96. package/dist/middleware/requirePermission.js +1 -1
  97. package/dist/package.json +1 -1
  98. package/dist/playwright.config.js +1 -1
  99. package/dist/playwright.task-terminal.config.js +1 -1
  100. package/dist/routes/apiKeys.js +1 -1
  101. package/dist/routes/auth-oidc.js +1 -1
  102. package/dist/routes/auth.js +1 -1
  103. package/dist/routes/automations.js +1 -1
  104. package/dist/routes/bindings.js +1 -1
  105. package/dist/routes/build.js +1 -1
  106. package/dist/routes/containers.js +1 -1
  107. package/dist/routes/deploy-task.js +1 -1
  108. package/dist/routes/environment-management.js +1 -1
  109. package/dist/routes/environments.js +1 -1
  110. package/dist/routes/external-skills.js +1 -1
  111. package/dist/routes/git-credentials.js +1 -1
  112. package/dist/routes/git-oauth.js +1 -1
  113. package/dist/routes/git-provider-setup.js +1 -1
  114. package/dist/routes/health.js +1 -1
  115. package/dist/routes/jira.js +1 -1
  116. package/dist/routes/objective-management.js +1 -1
  117. package/dist/routes/password.js +1 -1
  118. package/dist/routes/prompt.js +1 -1
  119. package/dist/routes/provider-auth.js +1 -1
  120. package/dist/routes/qa.js +1 -1
  121. package/dist/routes/roles.js +1 -1
  122. package/dist/routes/settings.js +1 -1
  123. package/dist/routes/skill-management.js +1 -1
  124. package/dist/routes/skills.js +1 -1
  125. package/dist/routes/tasks.js +1 -1
  126. package/dist/routes/teams.js +1 -1
  127. package/dist/routes/templates.js +1 -1
  128. package/dist/routes/test-task.js +1 -1
  129. package/dist/routes/test.js +1 -1
  130. package/dist/routes/users.js +1 -1
  131. package/dist/routes/visualizations.js +1 -1
  132. package/dist/scripts/create-user.js +1 -1
  133. package/dist/scripts/migrate-config-to-data-dir.js +1 -1
  134. package/dist/start.js +1 -1
  135. package/dist/web-ui/public/activity-detail-modal.js +1 -1
  136. package/dist/web-ui/public/activity-feed.js +1 -1
  137. package/dist/web-ui/public/activity-formatters.js +1 -1
  138. package/dist/web-ui/public/agent-event-parser.js +1 -1
  139. package/dist/web-ui/public/app.js +1 -1
  140. package/dist/web-ui/public/approve-dialog.js +1 -1
  141. package/dist/web-ui/public/automation-links.js +1 -1
  142. package/dist/web-ui/public/automation-schedule.js +1 -1
  143. package/dist/web-ui/public/comments-widget.js +1 -1
  144. package/dist/web-ui/public/diff-utils.js +1 -1
  145. package/dist/web-ui/public/environments.js +1 -1
  146. package/dist/web-ui/public/feedback-widget.css +39 -0
  147. package/dist/web-ui/public/feedback-widget.js +1 -1
  148. package/dist/web-ui/public/file-selection-tree.js +1 -1
  149. package/dist/web-ui/public/git-history-lazy-utils.js +1 -1
  150. package/dist/web-ui/public/git-history.js +1 -1
  151. package/dist/web-ui/public/git-status.js +1 -1
  152. package/dist/web-ui/public/ibmi-file-filter.js +1 -1
  153. package/dist/web-ui/public/index.js +1 -1
  154. package/dist/web-ui/public/login.js +1 -1
  155. package/dist/web-ui/public/markdown-editor.js +1 -1
  156. package/dist/web-ui/public/markdown-file-editor.js +1 -1
  157. package/dist/web-ui/public/modal-maximize.js +1 -1
  158. package/dist/web-ui/public/notifications.js +1 -1
  159. package/dist/web-ui/public/permissions.js +1 -1
  160. package/dist/web-ui/public/pr-dialog.js +1 -1
  161. package/dist/web-ui/public/roles.js +1 -1
  162. package/dist/web-ui/public/server-health.js +1 -1
  163. package/dist/web-ui/public/settings.html +0 -4
  164. package/dist/web-ui/public/settings.js +1 -1
  165. package/dist/web-ui/public/setup-password.js +1 -1
  166. package/dist/web-ui/public/skills.js +1 -1
  167. package/dist/web-ui/public/sse-client.js +1 -1
  168. package/dist/web-ui/public/sse-shared-worker.js +1 -1
  169. package/dist/web-ui/public/styles.css +34 -0
  170. package/dist/web-ui/public/task-judging-helpers.js +1 -0
  171. package/dist/web-ui/public/task.html +1 -0
  172. package/dist/web-ui/public/task.js +1 -1
  173. package/dist/web-ui/public/teams.js +1 -1
  174. package/dist/web-ui/public/terminal.js +1 -1
  175. package/dist/web-ui/public/theme.js +1 -1
  176. package/dist/web-ui/public/users.js +1 -1
  177. package/dist/web-ui/public/variant-grouping.js +1 -1
  178. 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 _0x48dd59=state['currentUser'];if(!Permissions['hasServerPermission'](_0x48dd59,'teams:view')&&!Permissions['hasTeamPermission'](_0x48dd59,'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'](_0x48dd59,'*')||Permissions['hasTeamPermission'](_0x48dd59,'teams:manage'))&&(document['getElementById']('create-team-btn')['hidden']=![]),bindEventListeners(),await Promise['all']([loadTeams(),loadUsers(),loadRoles(),loadEnvironments()]),renderTeams();});async function loadTeams(){const _0x288e37=document['getElementById']('teams-loading'),_0x24eeaa=document['getElementById']('teams-error'),_0x3c8187=document['getElementById']('teams-content');try{_0x288e37['hidden']=![],_0x24eeaa['hidden']=!![],_0x3c8187['hidden']=!![];const {teams:_0x803cbe}=await API['getTeams']();state['teams']=_0x803cbe||[],renderTeams(),_0x288e37['hidden']=!![],_0x3c8187['hidden']=![];}catch(_0x240bd8){_0x288e37['hidden']=!![],_0x24eeaa['hidden']=![],document['getElementById']('teams-error-message')['textContent']=_0x240bd8['message'];}}async function loadUsers(){try{const {users:_0x196ef2}=await API['getUsers']();state['users']=_0x196ef2||[];}catch{state['users']=[];}}async function loadRoles(){try{const {roles:_0x596b00}=await API['getRoleDefinitions']();state['roles']=_0x596b00||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x4672c3=await API['getEnvironments']();state['environments']=_0x4672c3['environments']||[];}catch{state['environments']=[];}}function renderTeams(){const _0x5e32be=document['getElementById']('teams-table-body'),_0x9735f4=document['getElementById']('team-count');if(!_0x5e32be)return;_0x9735f4&&(_0x9735f4['textContent']=state['teams']['length']+'\x20team'+(state['teams']['length']===0x1?'':'s'));if(state['teams']['length']===0x0){_0x5e32be['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 _0x45cac7=Permissions['hasServerPermission'](state['currentUser'],'*');_0x5e32be['innerHTML']=state['teams']['map'](_0x42cf1d=>{const _0x49dc8c=_0x45cac7||_0x42cf1d['canManageTeam'],_0x427cd1=_0x45cac7||_0x42cf1d['canManageMembers'],_0x26f8ad=_0x49dc8c||_0x427cd1,_0x55ae7a=(_0x42cf1d['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'](_0x42cf1d['name'])+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x42cf1d['description']?'<div\x20style=\x22font-size:\x200.8em;\x20color:\x20var(--color-text-secondary);\x20margin-top:\x200.15rem;\x22>'+Utils['escapeHtml'](_0x42cf1d['description'])+'</div>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+_0x55ae7a+'</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'+(_0x26f8ad?'<button\x20class=\x22btn-icon\x22\x20title=\x22Edit\x20team\x22\x20onclick=\x22window.openTeamModal(\x27'+_0x42cf1d['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'+(_0x49dc8c?'<button\x20class=\x22btn-icon\x22\x20title=\x22Access\x20bindings\x22\x20onclick=\x22window.openBindingsModal(\x27'+_0x42cf1d['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'+(_0x49dc8c?'<button\x20class=\x22btn-icon\x20btn-danger\x22\x20title=\x22Delete\x20team\x22\x20onclick=\x22window.deleteTeam(\x27'+_0x42cf1d['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(_0x514b2f){const _0x2c12e3=state['teams']['find'](_0x424211=>_0x424211['id']===_0x514b2f);if(!_0x2c12e3)return;state['editingTeamId']=_0x514b2f;const _0x3debfa=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x4c4f64=_0x3debfa||_0x2c12e3['canManageTeam'],_0x73d81b=_0x3debfa||_0x2c12e3['canManageMembers'],_0x3b4e44=_0x4c4f64,_0x5de3f0=_0x4c4f64||_0x73d81b,_0x7d7533=_0x2c12e3['name'],_0x1fc4c4=_0x2c12e3['description']||'';state['modalSnapshot']={'name':_0x7d7533,'description':_0x1fc4c4},document['getElementById']('team-modal-title')['textContent']=_0x7d7533,document['getElementById']('team-name')['value']=_0x7d7533,document['getElementById']('team-name')['disabled']=!_0x3b4e44,document['getElementById']('team-description')['value']=_0x1fc4c4,document['getElementById']('team-description')['disabled']=!_0x3b4e44,document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=![],document['getElementById']('save-team')['hidden']=!_0x3b4e44,renderMembersList(_0x2c12e3),updateMemberSelect(_0x2c12e3),document['getElementById']('team-modal')['hidden']=![];};function isTeamModalDirty(){if(!state['modalSnapshot'])return![];const _0x2fcacf=document['getElementById']('team-name')['value']['trim'](),_0x2a0f4d=document['getElementById']('team-description')['value']['trim']();return _0x2fcacf!==state['modalSnapshot']['name']||_0x2a0f4d!==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(_0x4de626){const _0x36fba7=state['teams']['find'](_0x37468f=>_0x37468f['id']===_0x4de626);if(!_0x36fba7)return;state['bindingsTeamId']=_0x4de626,document['getElementById']('bindings-modal-title')['textContent']='Access\x20Bindings\x20—\x20'+_0x36fba7['name'],document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('bindings-modal')['hidden']=![],loadTeamBindings(_0x4de626);};function hideBindingsModal(){document['getElementById']('bindings-modal')['hidden']=!![],state['bindingsTeamId']=null;}function renderMembersList(_0x492127){const _0x4c351c=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x58ba5a=_0x4c351c||_0x492127['canManageMembers']||_0x492127['canManageTeam'],_0x28821e=_0x492127['members']||[],_0x46cad8=document['getElementById']('members-list');if(_0x28821e['length']===0x0){_0x46cad8['innerHTML']='<p\x20style=\x22font-size:\x200.875rem;\x20color:\x20var(--color-text-secondary);\x20margin:\x200.25rem\x200;\x22>No\x20members\x20yet</p>';return;}_0x46cad8['innerHTML']=_0x28821e['map'](_0x33f5c0=>{const _0x4376d2=state['users']['find'](_0x422ec5=>_0x422ec5['id']===_0x33f5c0),_0x338ec2=_0x4376d2?''+Utils['escapeHtml'](_0x4376d2['username'])+(_0x4376d2['name']?'\x20<span\x20style=\x22color:\x20var(--color-text-secondary);\x20font-size:\x200.85em;\x22>('+Utils['escapeHtml'](_0x4376d2['name'])+')</span>':''):Utils['escapeHtml'](_0x33f5c0);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'+_0x338ec2+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x58ba5a?'<button\x20type=\x22button\x22\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.removeMemberClick(\x27'+_0x33f5c0+'\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 _0x370e71=document['getElementById']('add-member-row');if(_0x370e71)_0x370e71['style']['display']=_0x58ba5a?'flex':'none';}function updateMemberSelect(_0x594298){const _0x2f3212=document['getElementById']('add-member-select');if(!_0x2f3212)return;const _0x32d2c9=new Set(_0x594298['members']||[]),_0x5be5e0=state['users']['filter'](_0x35fee1=>!_0x32d2c9['has'](_0x35fee1['id']));_0x2f3212['innerHTML']='<option\x20value=\x22\x22>Add\x20a\x20member…</option>'+_0x5be5e0['map'](_0xf57593=>'<option\x20value=\x22'+_0xf57593['id']+'\x22>'+Utils['escapeHtml'](_0xf57593['username'])+(_0xf57593['name']?'\x20('+Utils['escapeHtml'](_0xf57593['name'])+')':'')+'</option>')['join']('');}async function addMember(){const _0x20c041=document['getElementById']('add-member-select'),_0x5a5d40=_0x20c041['value'];if(!_0x5a5d40||!state['editingTeamId'])return;try{const {team:_0x2dbaac}=await API['addTeamMember'](state['editingTeamId'],_0x5a5d40);syncTeamInState(_0x2dbaac),renderMembersList(_0x2dbaac),updateMemberSelect(_0x2dbaac),_0x20c041['value']='',Utils['showToast']('Member\x20added','success');}catch(_0x53badb){Utils['showToast'](_0x53badb['message'],'error');}}window['removeMemberClick']=async function(_0x5b61e4){if(!state['editingTeamId'])return;try{const {team:_0x17ab52}=await API['removeTeamMember'](state['editingTeamId'],_0x5b61e4);syncTeamInState(_0x17ab52),renderMembersList(_0x17ab52),updateMemberSelect(_0x17ab52),Utils['showToast']('Member\x20removed','success');}catch(_0x5647b4){Utils['showToast'](_0x5647b4['message'],'error');}};async function loadTeamBindings(_0x3772d0){const _0x1461bd=document['getElementById']('bindings-loading'),_0x119120=document['getElementById']('bindings-empty'),_0x5afbb7=document['getElementById']('bindings-list-container'),_0x5c506b=document['getElementById']('add-binding-btn');_0x1461bd['hidden']=![],_0x119120['hidden']=!![],_0x5afbb7['style']['display']='none',_0x5c506b['hidden']=!![],document['getElementById']('add-binding-form')['hidden']=!![];try{const {bindings:_0x334aa4}=await API['getBindings']({'subject_type':'team','subject_id':_0x3772d0});state['teamBindings']=_0x334aa4||[],_0x1461bd['hidden']=!![],state['teamBindings']['length']===0x0?_0x119120['hidden']=![]:(_0x5afbb7['style']['display']='',renderBindingsTable()),(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage'))&&(_0x5c506b['hidden']=![]);}catch(_0x2acbcd){_0x1461bd['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x2acbcd['message'],'error');}}function renderBindingsTable(){const _0x28e709=document['getElementById']('bindings-table-body');if(!_0x28e709)return;const _0x3e84bc=Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage');_0x28e709['innerHTML']=state['teamBindings']['map'](_0x162549=>{const _0x39d88d=_0x162549['resource_type']==='server'?'Server':_0x162549['resource_id']==='*'?'All\x20'+_0x162549['resource_type']+'s':Utils['escapeHtml'](_0x162549['resource_name']||_0x162549['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x39d88d+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x162549['role_name']||_0x162549['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x3e84bc?'<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteBindingClick(\x27'+_0x162549['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 _0x39b435=document['getElementById']('binding-resource-type');_0x39b435['value']='environment',updateBindingFormForResourceType('environment');}function onBindingResourceTypeChange(){const _0x2df58e=document['getElementById']('binding-resource-type')['value'];updateBindingFormForResourceType(_0x2df58e);}function updateBindingFormForResourceType(_0x2c749d){const _0xdde0d8=document['getElementById']('binding-resource-container'),_0x4872b3=document['getElementById']('binding-resource'),_0x3f89ed=document['getElementById']('binding-role');if(_0x2c749d==='server')_0xdde0d8['style']['display']='none';else{_0xdde0d8['style']['display']='';if(_0x2c749d==='environment'){const _0x1ca19e=new Set(state['teamBindings']['filter'](_0x279dd2=>_0x279dd2['resource_type']==='environment')['map'](_0x4f4a3b=>_0x4f4a3b['resource_id'])),_0x5c4159=state['environments']['filter'](_0x1365ea=>!_0x1ca19e['has'](_0x1365ea['name']));_0x4872b3['innerHTML']=_0x5c4159['length']?_0x5c4159['map'](_0x1215ff=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x1215ff['name'])+'\x22>'+Utils['escapeHtml'](_0x1215ff['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x2c749d==='team'){const _0x501e6a=new Set(state['teamBindings']['filter'](_0x765ff7=>_0x765ff7['resource_type']==='team')['map'](_0x3a5fdf=>_0x3a5fdf['resource_id'])),_0x4381bb=state['teams']['filter'](_0x1b6b6d=>!_0x501e6a['has'](_0x1b6b6d['id']));_0x4872b3['innerHTML']=_0x4381bb['length']?_0x4381bb['map'](_0x2aa99b=>'<option\x20value=\x22'+_0x2aa99b['id']+'\x22>'+Utils['escapeHtml'](_0x2aa99b['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x4b7edb=state['roles']['filter'](_0x354a51=>_0x354a51['resource_type']===_0x2c749d);_0x3f89ed['innerHTML']=_0x4b7edb['length']?_0x4b7edb['filter'](_0x55f0aa=>{const _0x2bb9bb=_0x2c749d==='server'?undefined:_0x4872b3['value'];return!state['teamBindings']['some'](_0x4960b3=>_0x4960b3['resource_type']===_0x2c749d&&_0x4960b3['role_id']===_0x55f0aa['id']&&(_0x2c749d==='server'||_0x4960b3['resource_id']===_0x2bb9bb));})['map'](_0xe85a48=>'<option\x20value=\x22'+_0xe85a48['id']+'\x22>'+Utils['escapeHtml'](_0xe85a48['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 _0x136ff9=document['getElementById']('binding-resource-type')['value'],_0x3d1cdc=document['getElementById']('binding-role')['value'];if(!_0x3d1cdc||!state['bindingsTeamId'])return;const _0x1adaa7=_0x136ff9==='server'?undefined:document['getElementById']('binding-resource')['value'];if(_0x136ff9!=='server'&&!_0x1adaa7)return;const _0x30098c=document['getElementById']('save-binding-btn');_0x30098c['disabled']=!![],_0x30098c['textContent']='Adding…';try{const _0xf433b0={'subject_type':'team','subject_id':state['bindingsTeamId'],'role_id':_0x3d1cdc,'resource_type':_0x136ff9};if(_0x1adaa7)_0xf433b0['resource_id']=_0x1adaa7;await API['createBinding'](_0xf433b0),Utils['showToast']('Binding\x20added','success'),document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![],await loadTeamBindings(state['bindingsTeamId']);}catch(_0x445094){Utils['showToast'](_0x445094['message'],'error');}finally{_0x30098c['disabled']=![],_0x30098c['textContent']='Add\x20Binding';}}window['deleteBindingClick']=async function(_0x7ecf7d){try{await API['deleteBinding'](_0x7ecf7d),Utils['showToast']('Binding\x20removed','success'),await loadTeamBindings(state['bindingsTeamId']);}catch(_0x2cadce){Utils['showToast'](_0x2cadce['message'],'error');}};async function saveTeam(){const _0xc2d027=document['getElementById']('team-name')['value']['trim'](),_0x2ca7b9=document['getElementById']('team-description')['value']['trim'](),_0x224ede=document['getElementById']('team-form-error'),_0x34255a=document['getElementById']('save-team');if(!_0xc2d027){_0x224ede['textContent']='Team\x20name\x20is\x20required',_0x224ede['hidden']=![];return;}_0x224ede['hidden']=!![];const _0x3d37df=_0x34255a['textContent'];_0x34255a['disabled']=!![],_0x34255a['textContent']=state['editingTeamId']?'Saving…':'Creating…';try{if(state['editingTeamId']){const {team:_0x5eebbb}=await API['updateTeam'](state['editingTeamId'],{'name':_0xc2d027,'description':_0x2ca7b9});syncTeamInState(_0x5eebbb),document['getElementById']('team-modal-title')['textContent']=_0x5eebbb['name'],Utils['showToast']('Team\x20updated','success');}else await API['createTeam']({'name':_0xc2d027,'description':_0x2ca7b9}),Utils['showToast']('Team\x20created','success');_0x34255a['disabled']=![],_0x34255a['textContent']=_0x3d37df,hideTeamModal(),await loadTeams();}catch(_0x2b6e37){_0x224ede['textContent']=_0x2b6e37['message'],_0x224ede['hidden']=![],_0x34255a['disabled']=![],_0x34255a['textContent']=_0x3d37df;}}window['deleteTeam']=function(_0x412f61){const _0x162ca9=state['teams']['find'](_0x18349e=>_0x18349e['id']===_0x412f61);if(!_0x162ca9)return;state['deletingTeamId']=_0x412f61,document['getElementById']('delete-team-name')['textContent']=_0x162ca9['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 _0x51d620=document['getElementById']('confirm-delete-team');_0x51d620['disabled']=!![],_0x51d620['textContent']='Deleting…';try{await API['deleteTeam'](state['deletingTeamId']),Utils['showToast']('Team\x20deleted','success'),_0x51d620['disabled']=![],_0x51d620['textContent']='Delete\x20Team',hideDeleteModal(),await loadTeams();}catch(_0xbda7a){Utils['showToast']('Failed\x20to\x20delete\x20team:\x20'+_0xbda7a['message'],'error'),_0x51d620['disabled']=![],_0x51d620['textContent']='Delete\x20Team';}}function syncTeamInState(_0x59ff34){const _0x29126f=state['teams']['findIndex'](_0x29e186=>_0x29e186['id']===_0x59ff34['id']);if(_0x29126f>=0x0)state['teams'][_0x29126f]=_0x59ff34;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 _0x5eb864=state['currentUser'];if(!Permissions['hasServerPermission'](_0x5eb864,'teams:view')&&!Permissions['hasTeamPermission'](_0x5eb864,'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'](_0x5eb864,'*')||Permissions['hasTeamPermission'](_0x5eb864,'teams:manage'))&&(document['getElementById']('create-team-btn')['hidden']=![]),bindEventListeners(),await Promise['all']([loadTeams(),loadUsers(),loadRoles(),loadEnvironments()]),renderTeams();});async function loadTeams(){const _0x55eb18=document['getElementById']('teams-loading'),_0x1ef2ae=document['getElementById']('teams-error'),_0x46846b=document['getElementById']('teams-content');try{_0x55eb18['hidden']=![],_0x1ef2ae['hidden']=!![],_0x46846b['hidden']=!![];const {teams:_0x17c97b}=await API['getTeams']();state['teams']=_0x17c97b||[],renderTeams(),_0x55eb18['hidden']=!![],_0x46846b['hidden']=![];}catch(_0x570824){_0x55eb18['hidden']=!![],_0x1ef2ae['hidden']=![],document['getElementById']('teams-error-message')['textContent']=_0x570824['message'];}}async function loadUsers(){try{const {users:_0x5f58c7}=await API['getUsers']();state['users']=_0x5f58c7||[];}catch{state['users']=[];}}async function loadRoles(){try{const {roles:_0x382a11}=await API['getRoleDefinitions']();state['roles']=_0x382a11||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x450658=await API['getEnvironments']();state['environments']=_0x450658['environments']||[];}catch{state['environments']=[];}}function renderTeams(){const _0xd43667=document['getElementById']('teams-table-body'),_0x3f3f39=document['getElementById']('team-count');if(!_0xd43667)return;_0x3f3f39&&(_0x3f3f39['textContent']=state['teams']['length']+'\x20team'+(state['teams']['length']===0x1?'':'s'));if(state['teams']['length']===0x0){_0xd43667['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 _0x190e52=Permissions['hasServerPermission'](state['currentUser'],'*');_0xd43667['innerHTML']=state['teams']['map'](_0x20e19d=>{const _0x1cd832=_0x190e52||_0x20e19d['canManageTeam'],_0x132e4d=_0x190e52||_0x20e19d['canManageMembers'],_0x2170f0=_0x1cd832||_0x132e4d,_0x405f9b=(_0x20e19d['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'](_0x20e19d['name'])+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x20e19d['description']?'<div\x20style=\x22font-size:\x200.8em;\x20color:\x20var(--color-text-secondary);\x20margin-top:\x200.15rem;\x22>'+Utils['escapeHtml'](_0x20e19d['description'])+'</div>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+_0x405f9b+'</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'+(_0x2170f0?'<button\x20class=\x22btn-icon\x22\x20title=\x22Edit\x20team\x22\x20onclick=\x22window.openTeamModal(\x27'+_0x20e19d['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'+(_0x1cd832?'<button\x20class=\x22btn-icon\x22\x20title=\x22Access\x20bindings\x22\x20onclick=\x22window.openBindingsModal(\x27'+_0x20e19d['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'+(_0x1cd832?'<button\x20class=\x22btn-icon\x20btn-danger\x22\x20title=\x22Delete\x20team\x22\x20onclick=\x22window.deleteTeam(\x27'+_0x20e19d['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(_0x260b1f){const _0x4faf4d=state['teams']['find'](_0x54614e=>_0x54614e['id']===_0x260b1f);if(!_0x4faf4d)return;state['editingTeamId']=_0x260b1f;const _0x188c64=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x4b0a76=_0x188c64||_0x4faf4d['canManageTeam'],_0x5e8612=_0x188c64||_0x4faf4d['canManageMembers'],_0x39058b=_0x4b0a76,_0x594464=_0x4b0a76||_0x5e8612,_0x3bcc65=_0x4faf4d['name'],_0x23050a=_0x4faf4d['description']||'';state['modalSnapshot']={'name':_0x3bcc65,'description':_0x23050a},document['getElementById']('team-modal-title')['textContent']=_0x3bcc65,document['getElementById']('team-name')['value']=_0x3bcc65,document['getElementById']('team-name')['disabled']=!_0x39058b,document['getElementById']('team-description')['value']=_0x23050a,document['getElementById']('team-description')['disabled']=!_0x39058b,document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=![],document['getElementById']('save-team')['hidden']=!_0x39058b,renderMembersList(_0x4faf4d),updateMemberSelect(_0x4faf4d),document['getElementById']('team-modal')['hidden']=![];};function isTeamModalDirty(){if(!state['modalSnapshot'])return![];const _0x171716=document['getElementById']('team-name')['value']['trim'](),_0x437ec2=document['getElementById']('team-description')['value']['trim']();return _0x171716!==state['modalSnapshot']['name']||_0x437ec2!==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(_0x4aff25){const _0x3cb4ec=state['teams']['find'](_0x34bf26=>_0x34bf26['id']===_0x4aff25);if(!_0x3cb4ec)return;state['bindingsTeamId']=_0x4aff25,document['getElementById']('bindings-modal-title')['textContent']='Access\x20Bindings\x20—\x20'+_0x3cb4ec['name'],document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('bindings-modal')['hidden']=![],loadTeamBindings(_0x4aff25);};function hideBindingsModal(){document['getElementById']('bindings-modal')['hidden']=!![],state['bindingsTeamId']=null;}function renderMembersList(_0x4e754a){const _0x517e01=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x19215e=_0x517e01||_0x4e754a['canManageMembers']||_0x4e754a['canManageTeam'],_0x133174=_0x4e754a['members']||[],_0x291c77=document['getElementById']('members-list');if(_0x133174['length']===0x0){_0x291c77['innerHTML']='<p\x20style=\x22font-size:\x200.875rem;\x20color:\x20var(--color-text-secondary);\x20margin:\x200.25rem\x200;\x22>No\x20members\x20yet</p>';return;}_0x291c77['innerHTML']=_0x133174['map'](_0x328c18=>{const _0x509ea5=state['users']['find'](_0x15e6a7=>_0x15e6a7['id']===_0x328c18),_0x156a23=_0x509ea5?''+Utils['escapeHtml'](_0x509ea5['username'])+(_0x509ea5['name']?'\x20<span\x20style=\x22color:\x20var(--color-text-secondary);\x20font-size:\x200.85em;\x22>('+Utils['escapeHtml'](_0x509ea5['name'])+')</span>':''):Utils['escapeHtml'](_0x328c18);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'+_0x156a23+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x19215e?'<button\x20type=\x22button\x22\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.removeMemberClick(\x27'+_0x328c18+'\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 _0x4811dc=document['getElementById']('add-member-row');if(_0x4811dc)_0x4811dc['style']['display']=_0x19215e?'flex':'none';}function updateMemberSelect(_0x339121){const _0x2c24f7=document['getElementById']('add-member-select');if(!_0x2c24f7)return;const _0x56126f=new Set(_0x339121['members']||[]),_0x4e9615=state['users']['filter'](_0x310421=>!_0x56126f['has'](_0x310421['id']));_0x2c24f7['innerHTML']='<option\x20value=\x22\x22>Add\x20a\x20member…</option>'+_0x4e9615['map'](_0x5901cd=>'<option\x20value=\x22'+_0x5901cd['id']+'\x22>'+Utils['escapeHtml'](_0x5901cd['username'])+(_0x5901cd['name']?'\x20('+Utils['escapeHtml'](_0x5901cd['name'])+')':'')+'</option>')['join']('');}async function addMember(){const _0x44715d=document['getElementById']('add-member-select'),_0xe60cc=_0x44715d['value'];if(!_0xe60cc||!state['editingTeamId'])return;try{const {team:_0x5e9e06}=await API['addTeamMember'](state['editingTeamId'],_0xe60cc);syncTeamInState(_0x5e9e06),renderMembersList(_0x5e9e06),updateMemberSelect(_0x5e9e06),_0x44715d['value']='',Utils['showToast']('Member\x20added','success');}catch(_0x446a1c){Utils['showToast'](_0x446a1c['message'],'error');}}window['removeMemberClick']=async function(_0x4b1d8a){if(!state['editingTeamId'])return;try{const {team:_0x5b98c1}=await API['removeTeamMember'](state['editingTeamId'],_0x4b1d8a);syncTeamInState(_0x5b98c1),renderMembersList(_0x5b98c1),updateMemberSelect(_0x5b98c1),Utils['showToast']('Member\x20removed','success');}catch(_0x2bdd23){Utils['showToast'](_0x2bdd23['message'],'error');}};async function loadTeamBindings(_0xb65336){const _0x25f5be=document['getElementById']('bindings-loading'),_0x390ec5=document['getElementById']('bindings-empty'),_0x2777d1=document['getElementById']('bindings-list-container'),_0x11b8eb=document['getElementById']('add-binding-btn');_0x25f5be['hidden']=![],_0x390ec5['hidden']=!![],_0x2777d1['style']['display']='none',_0x11b8eb['hidden']=!![],document['getElementById']('add-binding-form')['hidden']=!![];try{const {bindings:_0x3c3910}=await API['getBindings']({'subject_type':'team','subject_id':_0xb65336});state['teamBindings']=_0x3c3910||[],_0x25f5be['hidden']=!![],state['teamBindings']['length']===0x0?_0x390ec5['hidden']=![]:(_0x2777d1['style']['display']='',renderBindingsTable()),(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage'))&&(_0x11b8eb['hidden']=![]);}catch(_0x1a1088){_0x25f5be['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x1a1088['message'],'error');}}function renderBindingsTable(){const _0x154dd6=document['getElementById']('bindings-table-body');if(!_0x154dd6)return;const _0x1723e0=Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage');_0x154dd6['innerHTML']=state['teamBindings']['map'](_0x2a561e=>{const _0x5bc58e=_0x2a561e['resource_type']==='server'?'Server':_0x2a561e['resource_id']==='*'?'All\x20'+_0x2a561e['resource_type']+'s':Utils['escapeHtml'](_0x2a561e['resource_name']||_0x2a561e['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x5bc58e+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x2a561e['role_name']||_0x2a561e['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x1723e0?'<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteBindingClick(\x27'+_0x2a561e['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 _0x5d2e97=document['getElementById']('binding-resource-type');_0x5d2e97['value']='environment',updateBindingFormForResourceType('environment');}function onBindingResourceTypeChange(){const _0x321beb=document['getElementById']('binding-resource-type')['value'];updateBindingFormForResourceType(_0x321beb);}function updateBindingFormForResourceType(_0x3cf42b){const _0x4ad51c=document['getElementById']('binding-resource-container'),_0x2b45d3=document['getElementById']('binding-resource'),_0x10bc0a=document['getElementById']('binding-role');if(_0x3cf42b==='server')_0x4ad51c['style']['display']='none';else{_0x4ad51c['style']['display']='';if(_0x3cf42b==='environment'){const _0xba788b=new Set(state['teamBindings']['filter'](_0x4d7065=>_0x4d7065['resource_type']==='environment')['map'](_0x353886=>_0x353886['resource_id'])),_0x1f3e18=state['environments']['filter'](_0x305949=>!_0xba788b['has'](_0x305949['name']));_0x2b45d3['innerHTML']=_0x1f3e18['length']?_0x1f3e18['map'](_0x4b18b0=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x4b18b0['name'])+'\x22>'+Utils['escapeHtml'](_0x4b18b0['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x3cf42b==='team'){const _0x757575=new Set(state['teamBindings']['filter'](_0x18ebd=>_0x18ebd['resource_type']==='team')['map'](_0x4348fd=>_0x4348fd['resource_id'])),_0x271387=state['teams']['filter'](_0x14e6fd=>!_0x757575['has'](_0x14e6fd['id']));_0x2b45d3['innerHTML']=_0x271387['length']?_0x271387['map'](_0x264fb5=>'<option\x20value=\x22'+_0x264fb5['id']+'\x22>'+Utils['escapeHtml'](_0x264fb5['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x40fa9d=state['roles']['filter'](_0x4321fa=>_0x4321fa['resource_type']===_0x3cf42b);_0x10bc0a['innerHTML']=_0x40fa9d['length']?_0x40fa9d['filter'](_0x1fea75=>{const _0x1b8f24=_0x3cf42b==='server'?undefined:_0x2b45d3['value'];return!state['teamBindings']['some'](_0x33a37a=>_0x33a37a['resource_type']===_0x3cf42b&&_0x33a37a['role_id']===_0x1fea75['id']&&(_0x3cf42b==='server'||_0x33a37a['resource_id']===_0x1b8f24));})['map'](_0x2262da=>'<option\x20value=\x22'+_0x2262da['id']+'\x22>'+Utils['escapeHtml'](_0x2262da['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 _0x585d80=document['getElementById']('binding-resource-type')['value'],_0x45663d=document['getElementById']('binding-role')['value'];if(!_0x45663d||!state['bindingsTeamId'])return;const _0x31e796=_0x585d80==='server'?undefined:document['getElementById']('binding-resource')['value'];if(_0x585d80!=='server'&&!_0x31e796)return;const _0x1cc077=document['getElementById']('save-binding-btn');_0x1cc077['disabled']=!![],_0x1cc077['textContent']='Adding…';try{const _0x4f2a36={'subject_type':'team','subject_id':state['bindingsTeamId'],'role_id':_0x45663d,'resource_type':_0x585d80};if(_0x31e796)_0x4f2a36['resource_id']=_0x31e796;await API['createBinding'](_0x4f2a36),Utils['showToast']('Binding\x20added','success'),document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![],await loadTeamBindings(state['bindingsTeamId']);}catch(_0x34a532){Utils['showToast'](_0x34a532['message'],'error');}finally{_0x1cc077['disabled']=![],_0x1cc077['textContent']='Add\x20Binding';}}window['deleteBindingClick']=async function(_0x36f5b2){try{await API['deleteBinding'](_0x36f5b2),Utils['showToast']('Binding\x20removed','success'),await loadTeamBindings(state['bindingsTeamId']);}catch(_0x777663){Utils['showToast'](_0x777663['message'],'error');}};async function saveTeam(){const _0xc7a6b7=document['getElementById']('team-name')['value']['trim'](),_0x1a3c11=document['getElementById']('team-description')['value']['trim'](),_0x17ae3f=document['getElementById']('team-form-error'),_0x2d562f=document['getElementById']('save-team');if(!_0xc7a6b7){_0x17ae3f['textContent']='Team\x20name\x20is\x20required',_0x17ae3f['hidden']=![];return;}_0x17ae3f['hidden']=!![];const _0xe71b35=_0x2d562f['textContent'];_0x2d562f['disabled']=!![],_0x2d562f['textContent']=state['editingTeamId']?'Saving…':'Creating…';try{if(state['editingTeamId']){const {team:_0x2b98c4}=await API['updateTeam'](state['editingTeamId'],{'name':_0xc7a6b7,'description':_0x1a3c11});syncTeamInState(_0x2b98c4),document['getElementById']('team-modal-title')['textContent']=_0x2b98c4['name'],Utils['showToast']('Team\x20updated','success');}else await API['createTeam']({'name':_0xc7a6b7,'description':_0x1a3c11}),Utils['showToast']('Team\x20created','success');_0x2d562f['disabled']=![],_0x2d562f['textContent']=_0xe71b35,hideTeamModal(),await loadTeams();}catch(_0x2b30bd){_0x17ae3f['textContent']=_0x2b30bd['message'],_0x17ae3f['hidden']=![],_0x2d562f['disabled']=![],_0x2d562f['textContent']=_0xe71b35;}}window['deleteTeam']=function(_0x3d3f9f){const _0x32e6d7=state['teams']['find'](_0x3d8654=>_0x3d8654['id']===_0x3d3f9f);if(!_0x32e6d7)return;state['deletingTeamId']=_0x3d3f9f,document['getElementById']('delete-team-name')['textContent']=_0x32e6d7['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 _0x37b960=document['getElementById']('confirm-delete-team');_0x37b960['disabled']=!![],_0x37b960['textContent']='Deleting…';try{await API['deleteTeam'](state['deletingTeamId']),Utils['showToast']('Team\x20deleted','success'),_0x37b960['disabled']=![],_0x37b960['textContent']='Delete\x20Team',hideDeleteModal(),await loadTeams();}catch(_0x2aeece){Utils['showToast']('Failed\x20to\x20delete\x20team:\x20'+_0x2aeece['message'],'error'),_0x37b960['disabled']=![],_0x37b960['textContent']='Delete\x20Team';}}function syncTeamInState(_0x3957ce){const _0x10bee7=state['teams']['findIndex'](_0x5bfa52=>_0x5bfa52['id']===_0x3957ce['id']);if(_0x10bee7>=0x0)state['teams'][_0x10bee7]=_0x3957ce;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'](_0x4fcbb0=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':_0x4fcbb0}));});let commandSent=![],hasReceivedOutput=![];socket['addEventListener']('message',_0x21b5f4=>{try{const _0x27fe9c=JSON['parse'](_0x21b5f4['data']);if(_0x27fe9c['type']==='data'&&typeof _0x27fe9c['data']==='string')term['write'](_0x27fe9c['data']),!hasReceivedOutput&&_0x27fe9c['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(_0x27fe9c['type']==='status'&&_0x27fe9c['status']){if(_0x27fe9c['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'+_0x27fe9c['status'],_0x27fe9c['status']==='connected'?'success':'info');}else _0x27fe9c['type']==='error'&&_0x27fe9c['message']&&updateStatus(_0x27fe9c['message'],'error');}}catch(_0x197ff7){console['error']('Failed\x20to\x20parse\x20terminal\x20message',_0x197ff7);}}),socket['addEventListener']('close',_0x36fc36=>{const _0x2de0d6=_0x36fc36['reason']||'Connection\x20closed';updateStatus(_0x2de0d6,_0x36fc36['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',_0xdf4cb2=>{console['error']('Terminal\x20websocket\x20error',_0xdf4cb2),updateStatus('Connection\x20error','error');});function sendResize(){if(socket['readyState']!==WebSocket['OPEN'])return;const _0x5c1c71=term['cols'],_0x5d280f=term['rows'];socket['send'](JSON['stringify']({'type':'resize','cols':_0x5c1c71,'rows':_0x5d280f}));}function updateStatus(_0x42b596,_0x42bfc1='info'){if(!statusEl)return;statusEl['textContent']=_0x42b596,statusEl['dataset']['variant']=_0x42bfc1;}async function enrichContainerDetails(_0x266b3a){try{const _0x196916=await API['getContainer'](_0x266b3a);updateTerminalDetails(_0x196916);}catch{try{const _0x1bc36e=await API['getContainers'](),_0x2393f6=(_0x1bc36e['containers']||[])['find'](_0x3b0050=>_0x3b0050['containerId']===_0x266b3a||_0x3b0050['name']===_0x266b3a||_0x3b0050['fullContainerId']?.['startsWith'](_0x266b3a));if(_0x2393f6){updateTerminalDetails(_0x2393f6);return;}subtitleEl['textContent']='Container\x20'+_0x266b3a['substring'](0x0,0xc);}catch{subtitleEl['textContent']='Container\x20'+_0x266b3a['substring'](0x0,0xc);}}}function updateTerminalDetails(_0x32f1ca){const _0x4b8e4d=_0x32f1ca['containerId']||_0x32f1ca['name']||_0x32f1ca['fullContainerId']||containerId,_0x287310=_0x32f1ca['environment']?'Environment\x20'+_0x32f1ca['environment']:'Environment\x20unknown',_0x55d55f=_0x32f1ca['defaultAgent']?'\x20·\x20Agent\x20'+_0x32f1ca['defaultAgent']:'',_0x219281=_0x32f1ca['createdAt']?'\x20·\x20Started\x20'+Utils['formatRelativeTime'](_0x32f1ca['createdAt']):'';titleEl['textContent']='Terminal\x20·\x20'+_0x4b8e4d['substring'](0x0,0xc);const _0x3b70df=command?'\x20·\x20Command\x20'+command:'';subtitleEl['textContent']=''+_0x287310+_0x55d55f+_0x219281+_0x3b70df;}
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'](_0x461db8=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':_0x461db8}));});let commandSent=![],hasReceivedOutput=![];socket['addEventListener']('message',_0x1564d8=>{try{const _0x3d0d11=JSON['parse'](_0x1564d8['data']);if(_0x3d0d11['type']==='data'&&typeof _0x3d0d11['data']==='string')term['write'](_0x3d0d11['data']),!hasReceivedOutput&&_0x3d0d11['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(_0x3d0d11['type']==='status'&&_0x3d0d11['status']){if(_0x3d0d11['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'+_0x3d0d11['status'],_0x3d0d11['status']==='connected'?'success':'info');}else _0x3d0d11['type']==='error'&&_0x3d0d11['message']&&updateStatus(_0x3d0d11['message'],'error');}}catch(_0x805ecf){console['error']('Failed\x20to\x20parse\x20terminal\x20message',_0x805ecf);}}),socket['addEventListener']('close',_0x22b6ed=>{const _0x509895=_0x22b6ed['reason']||'Connection\x20closed';updateStatus(_0x509895,_0x22b6ed['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',_0x3bc1ae=>{console['error']('Terminal\x20websocket\x20error',_0x3bc1ae),updateStatus('Connection\x20error','error');});function sendResize(){if(socket['readyState']!==WebSocket['OPEN'])return;const _0x4ca124=term['cols'],_0x574f81=term['rows'];socket['send'](JSON['stringify']({'type':'resize','cols':_0x4ca124,'rows':_0x574f81}));}function updateStatus(_0x783164,_0x1257c2='info'){if(!statusEl)return;statusEl['textContent']=_0x783164,statusEl['dataset']['variant']=_0x1257c2;}async function enrichContainerDetails(_0x4df09c){try{const _0x29f476=await API['getContainer'](_0x4df09c);updateTerminalDetails(_0x29f476);}catch{try{const _0x1a8bbc=await API['getContainers'](),_0x38146f=(_0x1a8bbc['containers']||[])['find'](_0x36acea=>_0x36acea['containerId']===_0x4df09c||_0x36acea['name']===_0x4df09c||_0x36acea['fullContainerId']?.['startsWith'](_0x4df09c));if(_0x38146f){updateTerminalDetails(_0x38146f);return;}subtitleEl['textContent']='Container\x20'+_0x4df09c['substring'](0x0,0xc);}catch{subtitleEl['textContent']='Container\x20'+_0x4df09c['substring'](0x0,0xc);}}}function updateTerminalDetails(_0x237591){const _0x43f4e9=_0x237591['containerId']||_0x237591['name']||_0x237591['fullContainerId']||containerId,_0x12eea2=_0x237591['environment']?'Environment\x20'+_0x237591['environment']:'Environment\x20unknown',_0x4e73b4=_0x237591['defaultAgent']?'\x20·\x20Agent\x20'+_0x237591['defaultAgent']:'',_0x49a606=_0x237591['createdAt']?'\x20·\x20Started\x20'+Utils['formatRelativeTime'](_0x237591['createdAt']):'';titleEl['textContent']='Terminal\x20·\x20'+_0x43f4e9['substring'](0x0,0xc);const _0xa57261=command?'\x20·\x20Command\x20'+command:'';subtitleEl['textContent']=''+_0x12eea2+_0x4e73b4+_0x49a606+_0xa57261;}
@@ -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 _0x776c2c=localStorage['getItem'](THEME_STORAGE_KEY);if(_0x776c2c&&VALID_THEMES['has'](_0x776c2c))return _0x776c2c;}catch(_0x5c10e3){console['warn']('[Theme]\x20Failed\x20to\x20read\x20stored\x20theme\x20preference:',_0x5c10e3);}return null;}export function getPreferredTheme(){const _0x53a120=readStoredTheme();if(_0x53a120)return _0x53a120;const _0x4f839b=window['matchMedia']&&window['matchMedia']('(prefers-color-scheme:\x20dark)')['matches'];return _0x4f839b?'dark':'light';}export function getCurrentTheme(){const _0x56f3ae=document['documentElement']['dataset']['theme'];if(_0x56f3ae&&VALID_THEMES['has'](_0x56f3ae))return _0x56f3ae;return getPreferredTheme();}export function applyTheme(_0x7d8f98,{persist:persist=!![],emitEvent:emitEvent=!![]}={}){const _0x1dba59=VALID_THEMES['has'](_0x7d8f98)?_0x7d8f98:'light';document['documentElement']['dataset']['theme']=_0x1dba59,document['documentElement']['style']['colorScheme']=_0x1dba59==='dark'?'dark':'light';if(persist)try{localStorage['setItem'](THEME_STORAGE_KEY,_0x1dba59);}catch(_0x5d0b0c){console['warn']('[Theme]\x20Failed\x20to\x20persist\x20theme\x20preference:',_0x5d0b0c);}return emitEvent&&window['dispatchEvent'](new CustomEvent(THEME_CHANGE_EVENT,{'detail':{'theme':_0x1dba59}})),_0x1dba59;}export function initTheme(_0x5de642={}){const {emitEvent:emitEvent=![]}=_0x5de642;return applyTheme(getPreferredTheme(),{'persist':![],'emitEvent':emitEvent});}export function toggleTheme(){const _0x49c383=getCurrentTheme()==='dark'?'light':'dark';return applyTheme(_0x49c383);}export function onThemeChange(_0x127d02,{runImmediately:runImmediately=![]}={}){const _0x12a700=_0x451c37=>{_0x127d02(_0x451c37['detail']['theme']);};return window['addEventListener'](THEME_CHANGE_EVENT,_0x12a700),runImmediately&&_0x127d02(getCurrentTheme()),()=>window['removeEventListener'](THEME_CHANGE_EVENT,_0x12a700);}export function mountThemeToggle(_0x324343={}){const {targetSelectors:targetSelectors=DEFAULT_TARGET_SELECTORS}=_0x324343,_0x4ae2f2=targetSelectors['map'](_0x174c9b=>document['querySelector'](_0x174c9b))['find'](Boolean),_0x56a0da=document['createElement']('button');_0x56a0da['type']='button',_0x56a0da['className']='btn-ghost\x20theme-toggle-btn',_0x56a0da['id']='theme-toggle-btn',_0x56a0da['setAttribute']('aria-pressed','false'),_0x56a0da['style']['padding']='8px',_0x56a0da['style']['lineHeight']='0',_0x56a0da['style']['width']='36px',_0x56a0da['style']['height']='36px',_0x56a0da['style']['display']='flex',_0x56a0da['style']['alignItems']='center',_0x56a0da['style']['justifyContent']='center';const _0x349d83=document['createElement']('span');_0x349d83['className']='theme-icon',_0x349d83['style']['display']='flex',_0x56a0da['append'](_0x349d83);const _0x445c39='<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>',_0x1daf56='<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>',_0x317e95=_0x2f8416=>{const _0x3daac7=_0x2f8416==='dark';_0x349d83['innerHTML']=_0x3daac7?_0x445c39:_0x1daf56,_0x56a0da['title']=_0x3daac7?'Switch\x20to\x20light\x20mode':'Switch\x20to\x20dark\x20mode',_0x56a0da['dataset']['theme']=_0x2f8416,_0x56a0da['setAttribute']('aria-pressed',String(_0x3daac7));};return _0x56a0da['addEventListener']('click',()=>{const _0x159a52=getCurrentTheme()==='dark'?'light':'dark';applyTheme(_0x159a52);}),_0x4ae2f2?_0x4ae2f2['appendChild'](_0x56a0da):(_0x56a0da['classList']['add']('theme-toggle-floating'),document['body']['appendChild'](_0x56a0da)),_0x317e95(initTheme()),onThemeChange(_0x317e95),_0x56a0da;}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 _0x2c2290=localStorage['getItem'](THEME_STORAGE_KEY);if(_0x2c2290&&VALID_THEMES['has'](_0x2c2290))return _0x2c2290;}catch(_0x46d1ed){console['warn']('[Theme]\x20Failed\x20to\x20read\x20stored\x20theme\x20preference:',_0x46d1ed);}return null;}export function getPreferredTheme(){const _0x31f83d=readStoredTheme();if(_0x31f83d)return _0x31f83d;const _0xe18b6c=window['matchMedia']&&window['matchMedia']('(prefers-color-scheme:\x20dark)')['matches'];return _0xe18b6c?'dark':'light';}export function getCurrentTheme(){const _0x3bbac4=document['documentElement']['dataset']['theme'];if(_0x3bbac4&&VALID_THEMES['has'](_0x3bbac4))return _0x3bbac4;return getPreferredTheme();}export function applyTheme(_0x38fa77,{persist:persist=!![],emitEvent:emitEvent=!![]}={}){const _0x4e8350=VALID_THEMES['has'](_0x38fa77)?_0x38fa77:'light';document['documentElement']['dataset']['theme']=_0x4e8350,document['documentElement']['style']['colorScheme']=_0x4e8350==='dark'?'dark':'light';if(persist)try{localStorage['setItem'](THEME_STORAGE_KEY,_0x4e8350);}catch(_0x2157c2){console['warn']('[Theme]\x20Failed\x20to\x20persist\x20theme\x20preference:',_0x2157c2);}return emitEvent&&window['dispatchEvent'](new CustomEvent(THEME_CHANGE_EVENT,{'detail':{'theme':_0x4e8350}})),_0x4e8350;}export function initTheme(_0x510127={}){const {emitEvent:emitEvent=![]}=_0x510127;return applyTheme(getPreferredTheme(),{'persist':![],'emitEvent':emitEvent});}export function toggleTheme(){const _0x48ff93=getCurrentTheme()==='dark'?'light':'dark';return applyTheme(_0x48ff93);}export function onThemeChange(_0x52f3d1,{runImmediately:runImmediately=![]}={}){const _0x27eb71=_0x2ba99=>{_0x52f3d1(_0x2ba99['detail']['theme']);};return window['addEventListener'](THEME_CHANGE_EVENT,_0x27eb71),runImmediately&&_0x52f3d1(getCurrentTheme()),()=>window['removeEventListener'](THEME_CHANGE_EVENT,_0x27eb71);}export function mountThemeToggle(_0x98cfe2={}){const {targetSelectors:targetSelectors=DEFAULT_TARGET_SELECTORS}=_0x98cfe2,_0x5cb40b=targetSelectors['map'](_0xae66af=>document['querySelector'](_0xae66af))['find'](Boolean),_0x4c8209=document['createElement']('button');_0x4c8209['type']='button',_0x4c8209['className']='btn-ghost\x20theme-toggle-btn',_0x4c8209['id']='theme-toggle-btn',_0x4c8209['setAttribute']('aria-pressed','false'),_0x4c8209['style']['padding']='8px',_0x4c8209['style']['lineHeight']='0',_0x4c8209['style']['width']='36px',_0x4c8209['style']['height']='36px',_0x4c8209['style']['display']='flex',_0x4c8209['style']['alignItems']='center',_0x4c8209['style']['justifyContent']='center';const _0x2d994b=document['createElement']('span');_0x2d994b['className']='theme-icon',_0x2d994b['style']['display']='flex',_0x4c8209['append'](_0x2d994b);const _0x467a59='<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>',_0x44c575='<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>',_0x46e191=_0x5242c8=>{const _0x1c6fa7=_0x5242c8==='dark';_0x2d994b['innerHTML']=_0x1c6fa7?_0x467a59:_0x44c575,_0x4c8209['title']=_0x1c6fa7?'Switch\x20to\x20light\x20mode':'Switch\x20to\x20dark\x20mode',_0x4c8209['dataset']['theme']=_0x5242c8,_0x4c8209['setAttribute']('aria-pressed',String(_0x1c6fa7));};return _0x4c8209['addEventListener']('click',()=>{const _0x40179d=getCurrentTheme()==='dark'?'light':'dark';applyTheme(_0x40179d);}),_0x5cb40b?_0x5cb40b['appendChild'](_0x4c8209):(_0x4c8209['classList']['add']('theme-toggle-floating'),document['body']['appendChild'](_0x4c8209)),_0x46e191(initTheme()),onThemeChange(_0x46e191),_0x4c8209;}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 _0x20ee43=await API['getCurrentUser']();state['currentUser']=_0x20ee43;if(!Permissions['hasServerPermission'](_0x20ee43,'*')&&!Permissions['hasServerPermission'](_0x20ee43,'users:create')){Utils['showToast']('Access\x20denied:\x20Server\x20admin\x20privileges\x20required','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}}catch(_0xd7431f){window['location']['href']='login.html';}}async function checkEmailConfig(){try{const _0x3709de=await API['getEmailConfig']();state['emailConfigured']=_0x3709de['configured'];}catch(_0x1dbe84){console['error']('Failed\x20to\x20check\x20email\x20config',_0x1dbe84),state['emailConfigured']=![];}}async function loadRoles(){try{const {roles:_0xd2b201}=await API['getRoleDefinitions']();state['roles']=_0xd2b201||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0xed41e=await API['getEnvironments']();state['environments']=_0xed41e['environments']||[];}catch{state['environments']=[];}}async function loadTeams(){try{const {teams:_0x17e4b6}=await API['getTeams']();state['teams']=_0x17e4b6||[];}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 _0x468a5f=document['getElementById']('users-loading'),_0xd159b6=document['getElementById']('users-error'),_0x5f5619=document['getElementById']('users-content');try{_0x468a5f['hidden']=![],_0xd159b6['hidden']=!![],_0x5f5619['hidden']=!![];const _0x1e9fe6=await API['getUsers']();state['users']=_0x1e9fe6['users']||[],renderUsers(),_0x468a5f['hidden']=!![],_0x5f5619['hidden']=![];}catch(_0x3c2582){console['error']('Failed\x20to\x20load\x20users',_0x3c2582),_0x468a5f['hidden']=!![],_0xd159b6['hidden']=![],document['getElementById']('users-error-message')['textContent']=_0x3c2582['message'];}}function renderUsers(){const _0x109393=document['getElementById']('users-table-body'),_0x5e28b8=document['getElementById']('user-count');if(!_0x109393)return;_0x5e28b8&&(_0x5e28b8['textContent']=state['users']['length']+'\x20user'+(state['users']['length']===0x1?'':'s'));const _0x1d5dce=[...state['users']]['sort']((_0x526b0a,_0x4a1f94)=>{const _0x2c21c8=new Date(_0x526b0a['created_at'])['getTime'](),_0x35bf94=new Date(_0x4a1f94['created_at'])['getTime']();return _0x35bf94-_0x2c21c8;});_0x109393['innerHTML']=_0x1d5dce['map'](_0x20eb9e=>'\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'](_0x20eb9e['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'](_0x20eb9e['name'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x20eb9e['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'+(_0x20eb9e['isServerAdmin']?'<span\x20class=\x22role-badge\x20role-admin\x22>Server\x20Admin</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x20eb9e['hasUserBinding']?'<span\x20class=\x22role-badge\x20role-user-binding\x22>User\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x20eb9e['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'](_0x20eb9e['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'+_0x20eb9e['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'+_0x20eb9e['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'+_0x20eb9e['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'+_0x20eb9e['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(_0x3ea57d){const _0x267a53=state['users']['find'](_0x3fd095=>_0x3fd095['id']===_0x3ea57d);if(!_0x267a53)return;state['bindingsUserId']=_0x3ea57d,state['bindingsDirty']=![];const _0x3f5fbc=document['getElementById']('bindings-modal'),_0x36d103=document['getElementById']('bindings-modal-title');_0x36d103['textContent']='Access\x20Bindings\x20—\x20'+_0x267a53['name'],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],_0x3f5fbc['hidden']=![],loadUserBindings(_0x3ea57d);};function hasUnsavedBindingChanges(){const _0x8097f9=document['getElementById']('add-user-binding-form');return _0x8097f9&&!_0x8097f9['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 _0x525ced=document['getElementById']('bindings-modal');_0x525ced['hidden']=!![];const _0x4293fe=state['bindingsDirty'];state['bindingsUserId']=null,state['userBindings']=[],state['bindingsDirty']=![],_0x4293fe&&await loadUsers();}async function loadUserBindings(_0x277cc7){const _0x46f8c5=document['getElementById']('user-bindings-loading'),_0x17e499=document['getElementById']('user-bindings-empty'),_0x28b5b0=document['getElementById']('user-bindings-list-container'),_0x3fbe8e=document['getElementById']('add-user-binding-btn'),_0x43bd94=document['getElementById']('user-team-bindings-note'),_0x2a90f0=document['getElementById']('user-team-bindings-text');_0x46f8c5['hidden']=![],_0x17e499['hidden']=!![],_0x28b5b0['style']['display']='none',_0x3fbe8e['hidden']=!![],_0x43bd94['hidden']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![];try{const [_0x5477cd,_0x21faea]=await Promise['all']([API['getBindings']({'subject_type':'user','subject_id':_0x277cc7}),API['getTeams']()]);state['userBindings']=_0x5477cd['bindings']||[];const _0x18ee9b=(_0x21faea['teams']||[])['filter'](_0x2b662d=>(_0x2b662d['members']||[])['includes'](_0x277cc7)),_0x1b43f1=[];if(_0x18ee9b['length']>0x0){const _0x476e1b=await Promise['all'](_0x18ee9b['map'](_0xfa3701=>API['getBindings']({'subject_type':'team','subject_id':_0xfa3701['id']})));for(let _0x2d9163=0x0;_0x2d9163<_0x18ee9b['length'];_0x2d9163++){const _0x461710=_0x476e1b[_0x2d9163]['bindings']||[];_0x461710['length']>0x0&&_0x1b43f1['push'](_0x18ee9b[_0x2d9163]);}}_0x46f8c5['hidden']=!![];state['userBindings']['length']===0x0?_0x17e499['hidden']=![]:(_0x28b5b0['style']['display']='',renderUserBindingsTable());if(_0x1b43f1['length']>0x0){const _0x2fa603=_0x1b43f1['map'](_0x54d021=>_0x54d021['name']),_0x901458=_0x2fa603['length']<=0x3?_0x2fa603['join'](',\x20'):_0x2fa603['slice'](0x0,0x3)['join'](',\x20')+(',\x20and\x20'+(_0x2fa603['length']-0x3)+'\x20more');_0x2a90f0['textContent']='This\x20user\x20also\x20has\x20access\x20via\x20team\x20memberships\x20('+_0x901458+').';}else _0x2a90f0['textContent']='This\x20user\x20has\x20no\x20access\x20via\x20team\x20memberships.';_0x43bd94['hidden']=![],_0x3fbe8e['hidden']=![];}catch(_0x401720){_0x46f8c5['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x401720['message'],'error');}}function renderUserBindingsTable(){const _0x145480=document['getElementById']('user-bindings-table-body');if(!_0x145480)return;_0x145480['innerHTML']=state['userBindings']['map'](_0x85ea0a=>{const _0x4a68e5=_0x85ea0a['resource_type']==='server'?'Server':_0x85ea0a['resource_id']==='*'?'All\x20'+_0x85ea0a['resource_type']+'s':Utils['escapeHtml'](_0x85ea0a['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x4a68e5+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x85ea0a['role_name']||_0x85ea0a['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'+_0x85ea0a['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 _0x76e3=document['getElementById']('user-binding-resource-type');_0x76e3['value']='environment',updateUserBindingFormForResourceType('environment');}function onUserBindingResourceTypeChange(){const _0x3127a9=document['getElementById']('user-binding-resource-type')['value'];updateUserBindingFormForResourceType(_0x3127a9);}function updateUserBindingFormForResourceType(_0x47cf7e){const _0x270ec1=document['getElementById']('user-binding-resource-container'),_0x234fbd=document['getElementById']('user-binding-resource'),_0x4ca008=document['getElementById']('user-binding-role');if(_0x47cf7e==='server')_0x270ec1['style']['display']='none';else{_0x270ec1['style']['display']='';if(_0x47cf7e==='environment'){const _0x421232=new Set(state['userBindings']['filter'](_0x2f6b46=>_0x2f6b46['resource_type']==='environment')['map'](_0x580adc=>_0x580adc['resource_id'])),_0x3eb962=state['environments']['filter'](_0x312f3f=>!_0x421232['has'](_0x312f3f['name']));_0x234fbd['innerHTML']=_0x3eb962['length']?_0x3eb962['map'](_0x520f13=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x520f13['name'])+'\x22>'+Utils['escapeHtml'](_0x520f13['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x47cf7e==='team'){const _0xd21442=new Set(state['userBindings']['filter'](_0x22dda8=>_0x22dda8['resource_type']==='team')['map'](_0xd48419=>_0xd48419['resource_id'])),_0x2b13ed=state['teams']['filter'](_0x5e86d5=>!_0xd21442['has'](_0x5e86d5['id']));_0x234fbd['innerHTML']=_0x2b13ed['length']?_0x2b13ed['map'](_0x565880=>'<option\x20value=\x22'+_0x565880['id']+'\x22>'+Utils['escapeHtml'](_0x565880['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x5768ce=state['roles']['filter'](_0x526915=>_0x526915['resource_type']===_0x47cf7e);_0x4ca008['innerHTML']=_0x5768ce['length']?_0x5768ce['filter'](_0x41c8e7=>{const _0x4a1722=_0x47cf7e==='server'?undefined:_0x234fbd['value'];return!state['userBindings']['some'](_0x8e2a51=>_0x8e2a51['resource_type']===_0x47cf7e&&_0x8e2a51['role_id']===_0x41c8e7['id']&&(_0x47cf7e==='server'||_0x8e2a51['resource_id']===_0x4a1722));})['map'](_0x2634e0=>'<option\x20value=\x22'+_0x2634e0['id']+'\x22>'+Utils['escapeHtml'](_0x2634e0['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 _0x271b9e=document['getElementById']('user-binding-resource-type')['value'],_0x22ccf6=document['getElementById']('user-binding-role')['value'];if(!_0x22ccf6||!state['bindingsUserId'])return;const _0x19b9f6=_0x271b9e==='server'?undefined:document['getElementById']('user-binding-resource')['value'];if(_0x271b9e!=='server'&&!_0x19b9f6)return;const _0x252451=document['getElementById']('save-user-binding-btn');_0x252451['disabled']=!![],_0x252451['textContent']='Adding…';try{const _0xeb0b63={'subject_type':'user','subject_id':state['bindingsUserId'],'role_id':_0x22ccf6,'resource_type':_0x271b9e};if(_0x19b9f6)_0xeb0b63['resource_id']=_0x19b9f6;await API['createBinding'](_0xeb0b63),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(_0x2fa404){Utils['showToast'](_0x2fa404['message'],'error');}finally{_0x252451['disabled']=![],_0x252451['textContent']='Add\x20Binding';}}window['deleteUserBindingClick']=async function(_0x424a21){try{await API['deleteBinding'](_0x424a21),Utils['showToast']('Binding\x20removed','success'),state['bindingsDirty']=!![],await loadUserBindings(state['bindingsUserId']);}catch(_0xb52921){Utils['showToast'](_0xb52921['message'],'error');}};function showCreateUserModal(){state['editingUserId']=null;const _0x101bba=document['getElementById']('user-modal'),_0x311216=document['getElementById']('modal-title'),_0x390536=document['getElementById']('user-password'),_0x437058=document['getElementById']('password-required'),_0x24ca38=document['getElementById']('password-hint'),_0x416e63=document['getElementById']('skip-password-container'),_0x3bed6b=document['getElementById']('skip-password');_0x311216['textContent']='Create\x20User',document['getElementById']('user-form')['reset'](),_0x390536['required']=!![];if(_0x437058)_0x437058['textContent']='*';_0x416e63&&(_0x416e63['style']['display']='block',_0x3bed6b['checked']=![]),_0x24ca38&&(_0x24ca38['textContent']='Minimum\x208\x20characters'),_0x101bba['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);}window['editUser']=function(_0x341ef4){const _0x4dfd0c=state['users']['find'](_0x290762=>_0x290762['id']===_0x341ef4);if(!_0x4dfd0c)return;state['editingUserId']=_0x341ef4;const _0x3d28cb=document['getElementById']('user-modal'),_0x193e07=document['getElementById']('modal-title'),_0x2e1e0b=document['getElementById']('user-password'),_0x1e1b90=document['getElementById']('password-required'),_0x1e510a=document['getElementById']('password-hint'),_0x4b1042=document['getElementById']('skip-password-container');_0x193e07['textContent']='Edit\x20User',document['getElementById']('user-username')['value']=_0x4dfd0c['username'],document['getElementById']('user-name')['value']=_0x4dfd0c['name'],document['getElementById']('user-email')['value']=_0x4dfd0c['email'],_0x2e1e0b['value']='',_0x2e1e0b['required']=![];if(_0x1e1b90)_0x1e1b90['textContent']='';_0x4b1042&&(_0x4b1042['style']['display']='none'),_0x1e510a&&(_0x1e510a['textContent']='Leave\x20blank\x20to\x20keep\x20current\x20password'),_0x3d28cb['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);};function hideUserModal(){const _0x160153=document['getElementById']('user-modal'),_0x291370=document['getElementById']('form-error'),_0xc0d252=document['getElementById']('save-user');_0x160153['hidden']=!![],_0x291370['hidden']=!![],state['editingUserId']=null,_0xc0d252&&(_0xc0d252['disabled']=![],_0xc0d252['textContent']='Save\x20User');}async function saveUser(){const _0x198b0d=document['getElementById']('user-form'),_0x5558e1=document['getElementById']('skip-password')?.['checked']||![];if(!_0x5558e1&&!_0x198b0d['checkValidity']()){_0x198b0d['reportValidity']();return;}const _0x578b32=document['getElementById']('form-error'),_0x1c17eb=document['getElementById']('save-user'),_0xf6de8c=document['getElementById']('user-username')['value']['trim'](),_0x69bb97=document['getElementById']('user-name')['value']['trim'](),_0x4f850c=document['getElementById']('user-email')['value']['trim'](),_0x41ba8f=document['getElementById']('user-password')['value'];if(!_0xf6de8c||!_0x69bb97||!_0x4f850c){_0x578b32['textContent']='Please\x20fill\x20in\x20all\x20required\x20fields',_0x578b32['hidden']=![],_0x578b32['scrollIntoView']({'behavior':'smooth','block':'nearest'});return;}_0x578b32['hidden']=!![];const _0x226cd1=_0x1c17eb['textContent'];_0x1c17eb['disabled']=!![],_0x1c17eb['textContent']=state['editingUserId']?'Updating...':'Creating...';try{if(state['editingUserId']){const _0x15cc20={'username':_0xf6de8c,'name':_0x69bb97,'email':_0x4f850c};_0x41ba8f&&(_0x15cc20['password']=_0x41ba8f),await API['updateUser'](state['editingUserId'],_0x15cc20),Utils['showToast']('User\x20updated\x20successfully','success'),await loadUsers(),hideUserModal();}else{const _0xb57b46={'username':_0xf6de8c,'name':_0x69bb97,'email':_0x4f850c};if(!_0x5558e1){if(!_0x41ba8f)throw new Error('Password\x20is\x20required\x20for\x20new\x20users');_0xb57b46['password']=_0x41ba8f;}const _0x4d0b83=await API['createUser'](_0xb57b46),_0x464ea4=_0x4d0b83['user'];if(_0x5558e1||!_0x41ba8f){const _0x38cb5a=await API['createPasswordToken'](_0x464ea4['id'],'setup',![]);state['setupLinkData']={'username':_0x464ea4['username'],'email':_0x464ea4['email'],'url':_0x38cb5a['token']['setupUrl'],'userId':_0x464ea4['id'],'type':'setup','emailSent':![]},await loadUsers(),hideUserModal(),showSetupLinkModal();}else Utils['showToast']('User\x20created\x20successfully','success'),await loadUsers(),hideUserModal();}}catch(_0x20a61b){console['error']('Failed\x20to\x20save\x20user',_0x20a61b),_0x578b32['textContent']=_0x20a61b['message'],_0x578b32['hidden']=![],_0x578b32['scrollIntoView']({'behavior':'smooth','block':'nearest'}),_0x1c17eb['disabled']=![],_0x1c17eb['textContent']=_0x226cd1;}}window['deleteUser']=function(_0x2120d7){const _0x478715=state['users']['find'](_0x1bd008=>_0x1bd008['id']===_0x2120d7);if(!_0x478715)return;state['deletingUserId']=_0x2120d7;const _0x338fe9=document['getElementById']('delete-modal'),_0x546169=document['getElementById']('delete-user-name');_0x546169['textContent']=_0x478715['name']+'\x20('+_0x478715['username']+')',_0x338fe9['hidden']=![];};function hideDeleteModal(){const _0x1940ce=document['getElementById']('delete-modal');_0x1940ce['hidden']=!![],state['deletingUserId']=null;const _0x25dfe6=document['getElementById']('confirm-delete');_0x25dfe6&&(_0x25dfe6['disabled']=![],_0x25dfe6['textContent']='Delete\x20User');}async function confirmDeleteUser(){if(!state['deletingUserId'])return;const _0x118789=document['getElementById']('confirm-delete'),_0x143e19=_0x118789['textContent'];_0x118789['disabled']=!![],_0x118789['textContent']='Deleting...';try{await API['deleteUser'](state['deletingUserId']),Utils['showToast']('User\x20deleted\x20successfully','success'),await loadUsers(),hideDeleteModal();}catch(_0x4e11be){console['error']('Failed\x20to\x20delete\x20user',_0x4e11be),Utils['showToast']('Failed\x20to\x20delete\x20user:\x20'+_0x4e11be['message'],'error'),_0x118789['disabled']=![],_0x118789['textContent']=_0x143e19;}}function handleSkipPasswordChange(_0xd62a0){const _0x53d9b0=document['getElementById']('user-password'),_0x34a78b=_0xd62a0['target']['checked'];_0x34a78b?(_0x53d9b0['required']=![],_0x53d9b0['disabled']=!![],_0x53d9b0['value']=''):(_0x53d9b0['required']=!![],_0x53d9b0['disabled']=![]);}function showSetupLinkModal(){if(!state['setupLinkData'])return;const _0xa110a7=document['getElementById']('setup-link-modal'),_0x4f70e2=document['getElementById']('setup-link-username'),_0x5b47a0=document['getElementById']('setup-link-url'),_0x330457=document['getElementById']('email-setup-link'),_0x36e18e=document['getElementById']('email-button-text');_0x4f70e2['textContent']=state['setupLinkData']['username'],_0x5b47a0['textContent']=state['setupLinkData']['url'],_0x330457&&_0x36e18e&&(_0x330457['disabled']=![],_0x36e18e['textContent']='Email\x20Link',state['emailConfigured']&&!state['setupLinkData']['emailSent']?_0x330457['style']['display']='inline-block':_0x330457['style']['display']='none'),_0xa110a7['hidden']=![];}function hideSetupLinkModal(){const _0x4e9904=document['getElementById']('setup-link-modal');_0x4e9904['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(_0x290d7e){console['error']('Failed\x20to\x20copy\x20link',_0x290d7e),Utils['showToast']('Failed\x20to\x20copy\x20link','error');}}async function emailSetupLink(){if(!state['setupLinkData'])return;const _0x54e0f8=document['getElementById']('email-setup-link'),_0x18851e=document['getElementById']('email-button-text');if(!_0x54e0f8||!_0x18851e)return;const _0x5bec77=_0x18851e['textContent'];_0x54e0f8['disabled']=!![],_0x18851e['textContent']='Sending...';try{const _0x20e3fd=await API['createPasswordToken'](state['setupLinkData']['userId'],state['setupLinkData']['type'],!![]);if(_0x20e3fd['emailSent'])Utils['showToast']('Email\x20sent\x20to\x20'+state['setupLinkData']['email'],'success'),state['setupLinkData']['emailSent']=!![],_0x54e0f8['style']['display']='none';else{const _0x54ff33=_0x20e3fd['emailError']||'Failed\x20to\x20send\x20email';Utils['showToast'](_0x54ff33,'error'),_0x54e0f8['disabled']=![],_0x18851e['textContent']=_0x5bec77;}}catch(_0x13080d){console['error']('Failed\x20to\x20email\x20setup\x20link',_0x13080d),Utils['showToast']('Failed\x20to\x20send\x20email:\x20'+_0x13080d['message'],'error'),_0x54e0f8['disabled']=![],_0x18851e['textContent']=_0x5bec77;}}window['resetPassword']=async function(_0x31abf1){const _0xc3893c=state['users']['find'](_0x42ac68=>_0x42ac68['id']===_0x31abf1);if(!_0xc3893c)return;const _0xd7594f=await ConfirmDialog['show']({'title':'Reset\x20Password','message':'Generate\x20a\x20password\x20reset\x20link\x20for\x20'+_0xc3893c['name']+'\x20('+_0xc3893c['username']+')?\x20This\x20will\x20create\x20a\x20link\x20that\x20they\x20can\x20use\x20to\x20set\x20a\x20new\x20password.','confirmText':'Generate\x20Link'});if(!_0xd7594f)return;try{const _0x42e5d6=await API['createPasswordToken'](_0x31abf1,'reset',![]);state['setupLinkData']={'username':_0xc3893c['username'],'email':_0xc3893c['email'],'url':_0x42e5d6['token']['setupUrl'],'userId':_0xc3893c['id'],'type':'reset','emailSent':![]},showSetupLinkModal();}catch(_0x38b97d){console['error']('Failed\x20to\x20create\x20password\x20reset\x20link',_0x38b97d),Utils['showToast']('Failed\x20to\x20create\x20password\x20reset\x20link:\x20'+_0x38b97d['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 _0x7a0ebb=await API['getCurrentUser']();state['currentUser']=_0x7a0ebb;if(!Permissions['hasServerPermission'](_0x7a0ebb,'*')&&!Permissions['hasServerPermission'](_0x7a0ebb,'users:create')){Utils['showToast']('Access\x20denied:\x20Server\x20admin\x20privileges\x20required','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}}catch(_0x39c833){window['location']['href']='login.html';}}async function checkEmailConfig(){try{const _0x2cab47=await API['getEmailConfig']();state['emailConfigured']=_0x2cab47['configured'];}catch(_0x15ea79){console['error']('Failed\x20to\x20check\x20email\x20config',_0x15ea79),state['emailConfigured']=![];}}async function loadRoles(){try{const {roles:_0x5fba57}=await API['getRoleDefinitions']();state['roles']=_0x5fba57||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x535024=await API['getEnvironments']();state['environments']=_0x535024['environments']||[];}catch{state['environments']=[];}}async function loadTeams(){try{const {teams:_0xb92446}=await API['getTeams']();state['teams']=_0xb92446||[];}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 _0x4f9265=document['getElementById']('users-loading'),_0x46ec8a=document['getElementById']('users-error'),_0x8f6237=document['getElementById']('users-content');try{_0x4f9265['hidden']=![],_0x46ec8a['hidden']=!![],_0x8f6237['hidden']=!![];const _0xd9e6b0=await API['getUsers']();state['users']=_0xd9e6b0['users']||[],renderUsers(),_0x4f9265['hidden']=!![],_0x8f6237['hidden']=![];}catch(_0x4004b3){console['error']('Failed\x20to\x20load\x20users',_0x4004b3),_0x4f9265['hidden']=!![],_0x46ec8a['hidden']=![],document['getElementById']('users-error-message')['textContent']=_0x4004b3['message'];}}function renderUsers(){const _0x292793=document['getElementById']('users-table-body'),_0x46a7cb=document['getElementById']('user-count');if(!_0x292793)return;_0x46a7cb&&(_0x46a7cb['textContent']=state['users']['length']+'\x20user'+(state['users']['length']===0x1?'':'s'));const _0x918350=[...state['users']]['sort']((_0xd72426,_0x4c3fde)=>{const _0x56d838=new Date(_0xd72426['created_at'])['getTime'](),_0x33b2f1=new Date(_0x4c3fde['created_at'])['getTime']();return _0x33b2f1-_0x56d838;});_0x292793['innerHTML']=_0x918350['map'](_0x49e4fd=>'\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'](_0x49e4fd['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'](_0x49e4fd['name'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x49e4fd['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'+(_0x49e4fd['isServerAdmin']?'<span\x20class=\x22role-badge\x20role-admin\x22>Server\x20Admin</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x49e4fd['hasUserBinding']?'<span\x20class=\x22role-badge\x20role-user-binding\x22>User\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x49e4fd['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'](_0x49e4fd['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'+_0x49e4fd['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'+_0x49e4fd['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'+_0x49e4fd['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'+_0x49e4fd['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(_0x3edb94){const _0x4d0992=state['users']['find'](_0xa1cb93=>_0xa1cb93['id']===_0x3edb94);if(!_0x4d0992)return;state['bindingsUserId']=_0x3edb94,state['bindingsDirty']=![];const _0x59cc3c=document['getElementById']('bindings-modal'),_0x5e7934=document['getElementById']('bindings-modal-title');_0x5e7934['textContent']='Access\x20Bindings\x20—\x20'+_0x4d0992['name'],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],_0x59cc3c['hidden']=![],loadUserBindings(_0x3edb94);};function hasUnsavedBindingChanges(){const _0x5335f4=document['getElementById']('add-user-binding-form');return _0x5335f4&&!_0x5335f4['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 _0xafdca5=document['getElementById']('bindings-modal');_0xafdca5['hidden']=!![];const _0x56d994=state['bindingsDirty'];state['bindingsUserId']=null,state['userBindings']=[],state['bindingsDirty']=![],_0x56d994&&await loadUsers();}async function loadUserBindings(_0x1955f6){const _0x3d876a=document['getElementById']('user-bindings-loading'),_0x57dbcb=document['getElementById']('user-bindings-empty'),_0x3e6688=document['getElementById']('user-bindings-list-container'),_0x3a2b27=document['getElementById']('add-user-binding-btn'),_0x18cc0d=document['getElementById']('user-team-bindings-note'),_0x13e060=document['getElementById']('user-team-bindings-text');_0x3d876a['hidden']=![],_0x57dbcb['hidden']=!![],_0x3e6688['style']['display']='none',_0x3a2b27['hidden']=!![],_0x18cc0d['hidden']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![];try{const [_0x2d2c11,_0x162bad]=await Promise['all']([API['getBindings']({'subject_type':'user','subject_id':_0x1955f6}),API['getTeams']()]);state['userBindings']=_0x2d2c11['bindings']||[];const _0x21da36=(_0x162bad['teams']||[])['filter'](_0x140a47=>(_0x140a47['members']||[])['includes'](_0x1955f6)),_0x2ef0c6=[];if(_0x21da36['length']>0x0){const _0x2d2fd8=await Promise['all'](_0x21da36['map'](_0x186740=>API['getBindings']({'subject_type':'team','subject_id':_0x186740['id']})));for(let _0x1d1f33=0x0;_0x1d1f33<_0x21da36['length'];_0x1d1f33++){const _0x4e5364=_0x2d2fd8[_0x1d1f33]['bindings']||[];_0x4e5364['length']>0x0&&_0x2ef0c6['push'](_0x21da36[_0x1d1f33]);}}_0x3d876a['hidden']=!![];state['userBindings']['length']===0x0?_0x57dbcb['hidden']=![]:(_0x3e6688['style']['display']='',renderUserBindingsTable());if(_0x2ef0c6['length']>0x0){const _0xbdf561=_0x2ef0c6['map'](_0x3b27ed=>_0x3b27ed['name']),_0x13a3ed=_0xbdf561['length']<=0x3?_0xbdf561['join'](',\x20'):_0xbdf561['slice'](0x0,0x3)['join'](',\x20')+(',\x20and\x20'+(_0xbdf561['length']-0x3)+'\x20more');_0x13e060['textContent']='This\x20user\x20also\x20has\x20access\x20via\x20team\x20memberships\x20('+_0x13a3ed+').';}else _0x13e060['textContent']='This\x20user\x20has\x20no\x20access\x20via\x20team\x20memberships.';_0x18cc0d['hidden']=![],_0x3a2b27['hidden']=![];}catch(_0x404be2){_0x3d876a['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x404be2['message'],'error');}}function renderUserBindingsTable(){const _0x4feddc=document['getElementById']('user-bindings-table-body');if(!_0x4feddc)return;_0x4feddc['innerHTML']=state['userBindings']['map'](_0x68c236=>{const _0x2196a8=_0x68c236['resource_type']==='server'?'Server':_0x68c236['resource_id']==='*'?'All\x20'+_0x68c236['resource_type']+'s':Utils['escapeHtml'](_0x68c236['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x2196a8+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x68c236['role_name']||_0x68c236['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'+_0x68c236['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 _0x35f45f=document['getElementById']('user-binding-resource-type');_0x35f45f['value']='environment',updateUserBindingFormForResourceType('environment');}function onUserBindingResourceTypeChange(){const _0x418737=document['getElementById']('user-binding-resource-type')['value'];updateUserBindingFormForResourceType(_0x418737);}function updateUserBindingFormForResourceType(_0x5c3e75){const _0x5b321e=document['getElementById']('user-binding-resource-container'),_0x2b9ae9=document['getElementById']('user-binding-resource'),_0x7256c0=document['getElementById']('user-binding-role');if(_0x5c3e75==='server')_0x5b321e['style']['display']='none';else{_0x5b321e['style']['display']='';if(_0x5c3e75==='environment'){const _0x31e6f0=new Set(state['userBindings']['filter'](_0x3dc16f=>_0x3dc16f['resource_type']==='environment')['map'](_0x12c43=>_0x12c43['resource_id'])),_0x41908b=state['environments']['filter'](_0x25ecd1=>!_0x31e6f0['has'](_0x25ecd1['name']));_0x2b9ae9['innerHTML']=_0x41908b['length']?_0x41908b['map'](_0x5ed704=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x5ed704['name'])+'\x22>'+Utils['escapeHtml'](_0x5ed704['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x5c3e75==='team'){const _0x58e434=new Set(state['userBindings']['filter'](_0x3a8178=>_0x3a8178['resource_type']==='team')['map'](_0x3f2059=>_0x3f2059['resource_id'])),_0x41cadf=state['teams']['filter'](_0x5a7552=>!_0x58e434['has'](_0x5a7552['id']));_0x2b9ae9['innerHTML']=_0x41cadf['length']?_0x41cadf['map'](_0x18a35b=>'<option\x20value=\x22'+_0x18a35b['id']+'\x22>'+Utils['escapeHtml'](_0x18a35b['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x1fba70=state['roles']['filter'](_0x2f69ec=>_0x2f69ec['resource_type']===_0x5c3e75);_0x7256c0['innerHTML']=_0x1fba70['length']?_0x1fba70['filter'](_0xc9d3e2=>{const _0xf67884=_0x5c3e75==='server'?undefined:_0x2b9ae9['value'];return!state['userBindings']['some'](_0x23cff4=>_0x23cff4['resource_type']===_0x5c3e75&&_0x23cff4['role_id']===_0xc9d3e2['id']&&(_0x5c3e75==='server'||_0x23cff4['resource_id']===_0xf67884));})['map'](_0x1bd243=>'<option\x20value=\x22'+_0x1bd243['id']+'\x22>'+Utils['escapeHtml'](_0x1bd243['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 _0x1765e9=document['getElementById']('user-binding-resource-type')['value'],_0x441c08=document['getElementById']('user-binding-role')['value'];if(!_0x441c08||!state['bindingsUserId'])return;const _0x22b6fd=_0x1765e9==='server'?undefined:document['getElementById']('user-binding-resource')['value'];if(_0x1765e9!=='server'&&!_0x22b6fd)return;const _0x125d3a=document['getElementById']('save-user-binding-btn');_0x125d3a['disabled']=!![],_0x125d3a['textContent']='Adding…';try{const _0x34e4e5={'subject_type':'user','subject_id':state['bindingsUserId'],'role_id':_0x441c08,'resource_type':_0x1765e9};if(_0x22b6fd)_0x34e4e5['resource_id']=_0x22b6fd;await API['createBinding'](_0x34e4e5),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(_0x3a684e){Utils['showToast'](_0x3a684e['message'],'error');}finally{_0x125d3a['disabled']=![],_0x125d3a['textContent']='Add\x20Binding';}}window['deleteUserBindingClick']=async function(_0x3d27ee){try{await API['deleteBinding'](_0x3d27ee),Utils['showToast']('Binding\x20removed','success'),state['bindingsDirty']=!![],await loadUserBindings(state['bindingsUserId']);}catch(_0x3de7d1){Utils['showToast'](_0x3de7d1['message'],'error');}};function showCreateUserModal(){state['editingUserId']=null;const _0xa2286b=document['getElementById']('user-modal'),_0x2f84fc=document['getElementById']('modal-title'),_0x54f7fb=document['getElementById']('user-password'),_0x163ad9=document['getElementById']('password-required'),_0x4975ac=document['getElementById']('password-hint'),_0x341e16=document['getElementById']('skip-password-container'),_0x3f0e92=document['getElementById']('skip-password');_0x2f84fc['textContent']='Create\x20User',document['getElementById']('user-form')['reset'](),_0x54f7fb['required']=!![];if(_0x163ad9)_0x163ad9['textContent']='*';_0x341e16&&(_0x341e16['style']['display']='block',_0x3f0e92['checked']=![]),_0x4975ac&&(_0x4975ac['textContent']='Minimum\x208\x20characters'),_0xa2286b['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);}window['editUser']=function(_0x331b13){const _0x3f848a=state['users']['find'](_0x31010c=>_0x31010c['id']===_0x331b13);if(!_0x3f848a)return;state['editingUserId']=_0x331b13;const _0x815455=document['getElementById']('user-modal'),_0x8accd1=document['getElementById']('modal-title'),_0x282370=document['getElementById']('user-password'),_0x4be6fe=document['getElementById']('password-required'),_0x1d279a=document['getElementById']('password-hint'),_0x2932b5=document['getElementById']('skip-password-container');_0x8accd1['textContent']='Edit\x20User',document['getElementById']('user-username')['value']=_0x3f848a['username'],document['getElementById']('user-name')['value']=_0x3f848a['name'],document['getElementById']('user-email')['value']=_0x3f848a['email'],_0x282370['value']='',_0x282370['required']=![];if(_0x4be6fe)_0x4be6fe['textContent']='';_0x2932b5&&(_0x2932b5['style']['display']='none'),_0x1d279a&&(_0x1d279a['textContent']='Leave\x20blank\x20to\x20keep\x20current\x20password'),_0x815455['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);};function hideUserModal(){const _0x5b8be1=document['getElementById']('user-modal'),_0x266bf0=document['getElementById']('form-error'),_0x3dafaa=document['getElementById']('save-user');_0x5b8be1['hidden']=!![],_0x266bf0['hidden']=!![],state['editingUserId']=null,_0x3dafaa&&(_0x3dafaa['disabled']=![],_0x3dafaa['textContent']='Save\x20User');}async function saveUser(){const _0x1b72e0=document['getElementById']('user-form'),_0x3f963a=document['getElementById']('skip-password')?.['checked']||![];if(!_0x3f963a&&!_0x1b72e0['checkValidity']()){_0x1b72e0['reportValidity']();return;}const _0x2b7d60=document['getElementById']('form-error'),_0x5882e9=document['getElementById']('save-user'),_0xd9b0df=document['getElementById']('user-username')['value']['trim'](),_0x19bad1=document['getElementById']('user-name')['value']['trim'](),_0x2588eb=document['getElementById']('user-email')['value']['trim'](),_0x392838=document['getElementById']('user-password')['value'];if(!_0xd9b0df||!_0x19bad1||!_0x2588eb){_0x2b7d60['textContent']='Please\x20fill\x20in\x20all\x20required\x20fields',_0x2b7d60['hidden']=![],_0x2b7d60['scrollIntoView']({'behavior':'smooth','block':'nearest'});return;}_0x2b7d60['hidden']=!![];const _0x508fab=_0x5882e9['textContent'];_0x5882e9['disabled']=!![],_0x5882e9['textContent']=state['editingUserId']?'Updating...':'Creating...';try{if(state['editingUserId']){const _0x11a492={'username':_0xd9b0df,'name':_0x19bad1,'email':_0x2588eb};_0x392838&&(_0x11a492['password']=_0x392838),await API['updateUser'](state['editingUserId'],_0x11a492),Utils['showToast']('User\x20updated\x20successfully','success'),await loadUsers(),hideUserModal();}else{const _0x22855a={'username':_0xd9b0df,'name':_0x19bad1,'email':_0x2588eb};if(!_0x3f963a){if(!_0x392838)throw new Error('Password\x20is\x20required\x20for\x20new\x20users');_0x22855a['password']=_0x392838;}const _0x15913f=await API['createUser'](_0x22855a),_0x3099ec=_0x15913f['user'];if(_0x3f963a||!_0x392838){const _0x336d3c=await API['createPasswordToken'](_0x3099ec['id'],'setup',![]);state['setupLinkData']={'username':_0x3099ec['username'],'email':_0x3099ec['email'],'url':_0x336d3c['token']['setupUrl'],'userId':_0x3099ec['id'],'type':'setup','emailSent':![]},await loadUsers(),hideUserModal(),showSetupLinkModal();}else Utils['showToast']('User\x20created\x20successfully','success'),await loadUsers(),hideUserModal();}}catch(_0x3025bb){console['error']('Failed\x20to\x20save\x20user',_0x3025bb),_0x2b7d60['textContent']=_0x3025bb['message'],_0x2b7d60['hidden']=![],_0x2b7d60['scrollIntoView']({'behavior':'smooth','block':'nearest'}),_0x5882e9['disabled']=![],_0x5882e9['textContent']=_0x508fab;}}window['deleteUser']=function(_0x51cf99){const _0x4dfd42=state['users']['find'](_0x2312ad=>_0x2312ad['id']===_0x51cf99);if(!_0x4dfd42)return;state['deletingUserId']=_0x51cf99;const _0x3f6146=document['getElementById']('delete-modal'),_0x530eae=document['getElementById']('delete-user-name');_0x530eae['textContent']=_0x4dfd42['name']+'\x20('+_0x4dfd42['username']+')',_0x3f6146['hidden']=![];};function hideDeleteModal(){const _0xa57f9b=document['getElementById']('delete-modal');_0xa57f9b['hidden']=!![],state['deletingUserId']=null;const _0x3921dc=document['getElementById']('confirm-delete');_0x3921dc&&(_0x3921dc['disabled']=![],_0x3921dc['textContent']='Delete\x20User');}async function confirmDeleteUser(){if(!state['deletingUserId'])return;const _0x3a3b00=document['getElementById']('confirm-delete'),_0x2e0f6b=_0x3a3b00['textContent'];_0x3a3b00['disabled']=!![],_0x3a3b00['textContent']='Deleting...';try{await API['deleteUser'](state['deletingUserId']),Utils['showToast']('User\x20deleted\x20successfully','success'),await loadUsers(),hideDeleteModal();}catch(_0x2c9a13){console['error']('Failed\x20to\x20delete\x20user',_0x2c9a13),Utils['showToast']('Failed\x20to\x20delete\x20user:\x20'+_0x2c9a13['message'],'error'),_0x3a3b00['disabled']=![],_0x3a3b00['textContent']=_0x2e0f6b;}}function handleSkipPasswordChange(_0x4a383f){const _0x28d778=document['getElementById']('user-password'),_0x36b901=_0x4a383f['target']['checked'];_0x36b901?(_0x28d778['required']=![],_0x28d778['disabled']=!![],_0x28d778['value']=''):(_0x28d778['required']=!![],_0x28d778['disabled']=![]);}function showSetupLinkModal(){if(!state['setupLinkData'])return;const _0x590087=document['getElementById']('setup-link-modal'),_0x5f3a7a=document['getElementById']('setup-link-username'),_0x5aa535=document['getElementById']('setup-link-url'),_0x3759f5=document['getElementById']('email-setup-link'),_0x57390e=document['getElementById']('email-button-text');_0x5f3a7a['textContent']=state['setupLinkData']['username'],_0x5aa535['textContent']=state['setupLinkData']['url'],_0x3759f5&&_0x57390e&&(_0x3759f5['disabled']=![],_0x57390e['textContent']='Email\x20Link',state['emailConfigured']&&!state['setupLinkData']['emailSent']?_0x3759f5['style']['display']='inline-block':_0x3759f5['style']['display']='none'),_0x590087['hidden']=![];}function hideSetupLinkModal(){const _0xb46463=document['getElementById']('setup-link-modal');_0xb46463['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(_0x44c5ec){console['error']('Failed\x20to\x20copy\x20link',_0x44c5ec),Utils['showToast']('Failed\x20to\x20copy\x20link','error');}}async function emailSetupLink(){if(!state['setupLinkData'])return;const _0x82c2e0=document['getElementById']('email-setup-link'),_0x4ca2c3=document['getElementById']('email-button-text');if(!_0x82c2e0||!_0x4ca2c3)return;const _0x32fe26=_0x4ca2c3['textContent'];_0x82c2e0['disabled']=!![],_0x4ca2c3['textContent']='Sending...';try{const _0x4076fe=await API['createPasswordToken'](state['setupLinkData']['userId'],state['setupLinkData']['type'],!![]);if(_0x4076fe['emailSent'])Utils['showToast']('Email\x20sent\x20to\x20'+state['setupLinkData']['email'],'success'),state['setupLinkData']['emailSent']=!![],_0x82c2e0['style']['display']='none';else{const _0x32c218=_0x4076fe['emailError']||'Failed\x20to\x20send\x20email';Utils['showToast'](_0x32c218,'error'),_0x82c2e0['disabled']=![],_0x4ca2c3['textContent']=_0x32fe26;}}catch(_0x14581f){console['error']('Failed\x20to\x20email\x20setup\x20link',_0x14581f),Utils['showToast']('Failed\x20to\x20send\x20email:\x20'+_0x14581f['message'],'error'),_0x82c2e0['disabled']=![],_0x4ca2c3['textContent']=_0x32fe26;}}window['resetPassword']=async function(_0xc1b833){const _0x15dbc6=state['users']['find'](_0x5bd0c9=>_0x5bd0c9['id']===_0xc1b833);if(!_0x15dbc6)return;const _0x56a7dc=await ConfirmDialog['show']({'title':'Reset\x20Password','message':'Generate\x20a\x20password\x20reset\x20link\x20for\x20'+_0x15dbc6['name']+'\x20('+_0x15dbc6['username']+')?\x20This\x20will\x20create\x20a\x20link\x20that\x20they\x20can\x20use\x20to\x20set\x20a\x20new\x20password.','confirmText':'Generate\x20Link'});if(!_0x56a7dc)return;try{const _0x288e52=await API['createPasswordToken'](_0xc1b833,'reset',![]);state['setupLinkData']={'username':_0x15dbc6['username'],'email':_0x15dbc6['email'],'url':_0x288e52['token']['setupUrl'],'userId':_0x15dbc6['id'],'type':'reset','emailSent':![]},showSetupLinkModal();}catch(_0x5cf170){console['error']('Failed\x20to\x20create\x20password\x20reset\x20link',_0x5cf170),Utils['showToast']('Failed\x20to\x20create\x20password\x20reset\x20link:\x20'+_0x5cf170['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(_0x18259e={}){this['container']=null,this['onGroupChange']=_0x18259e['onGroupChange']||(()=>{}),this['onAddExistingTask']=_0x18259e['onAddExistingTask']||(()=>{}),this['tasks']=[],this['groupId']=_0x18259e['groupId']||null,this['isOpen']=![];}['init'](_0xdc7eeb,_0x45abc4,_0x51553c){this['container']=_0xdc7eeb,this['tasks']=_0x45abc4,this['groupId']=_0x51553c,this['render'](),this['attachEventListeners']();}['updateTasks'](_0x46e27f){const _0x20c451=new Map(_0x46e27f['map'](_0xdb7df6=>[_0xdb7df6['taskId'],_0xdb7df6]));this['tasks']=this['tasks']['map'](_0x36ec9c=>{const _0x4e9fb4=_0x20c451['get'](_0x36ec9c['taskId']);return _0x4e9fb4?_0x4e9fb4:_0x36ec9c;});for(const _0x529b8d of _0x46e27f){!this['tasks']['some'](_0x248bb3=>_0x248bb3['taskId']===_0x529b8d['taskId'])&&this['tasks']['push'](_0x529b8d);}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 _0x717640=this['tasks']['filter'](_0x38d4f9=>_0x38d4f9['groupId']===this['groupId'])['sort']((_0x2c690c,_0x81d648)=>(_0x2c690c['groupIndex']??0x0)-(_0x81d648['groupIndex']??0x0)),_0x593ff5=this['tasks']['filter'](_0x337ad4=>!_0x337ad4['groupId']||_0x337ad4['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>'+_0x717640['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'+(_0x717640['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20add\x20to\x20group</div>':_0x717640['map']((_0x2f476e,_0x29cedb)=>this['renderVariantCard'](_0x2f476e,_0x29cedb,!![]))['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>'+_0x593ff5['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'+(_0x593ff5['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20remove\x20from\x20group</div>':_0x593ff5['map']((_0x5dcff5,_0x14bf24)=>this['renderVariantCard'](_0x5dcff5,_0x14bf24,![]))['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'](_0x52b298,_0xb4ffad,_0x46902c){const _0x32b9e2=_0x52b298['envVars']?.['CODER_AGENT']||_0x52b298['envVars']?.['default_agent']||'claude',_0x5334f3=AGENT_ICONS[_0x32b9e2['toLowerCase']()]||AGENT_ICONS['claude'],_0x524d61=STATUS_ICONS[_0x52b298['status']]||'',_0x273b68='status-'+(_0x52b298['status']||'unknown'),_0xa3e5dd=_0x52b298['isWinner']?'<span\x20class=\x22vgm-badge\x20vgm-badge-winner\x22\x20title=\x22Winner\x22>★</span>':'',_0x46a500=_0x52b298['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'+_0x273b68+'\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'+_0x52b298['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-is-grouped=\x22'+_0x46902c+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-index=\x22'+_0xb4ffad+'\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'+_0x32b9e2['toLowerCase']()+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x5334f3+'\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'](_0x52b298['name']||'Task\x20'+_0x52b298['taskId']['slice'](-0x6))+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-meta\x22>'+Utils['escapeHtml'](_0x32b9e2)+'\x20·\x20'+(_0x52b298['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'+_0xa3e5dd+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x46a500+'\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'+_0x273b68+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x524d61+'\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'+(_0x46902c?'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'+_0x52b298['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-action=\x22'+(_0x46902c?'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'+(_0x46902c?'<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',_0x2f8bd8=>{_0x2f8bd8['target']['closest']('.vgm-close-btn')&&(this['close'](),this['onGroupChange'](this['tasks'])),_0x2f8bd8['target']['closest']('.vgm-add-existing-btn')&&(this['close'](),this['onAddExistingTask'](this['groupId']));}),this['container']['addEventListener']('click',async _0x857f48=>{const _0x4ce756=_0x857f48['target']['closest']('.vgm-variant-remove-btn');if(!_0x4ce756)return;const _0x24ec36=_0x4ce756['dataset']['taskId'],_0x5613c6=_0x4ce756['dataset']['action'];try{_0x5613c6==='remove'?await this['removeFromGroup'](_0x24ec36):await this['addToGroup'](_0x24ec36);}catch(_0xaabe7f){console['error']('Failed\x20to\x20update\x20group:',_0xaabe7f),Utils['showToast'](_0xaabe7f['message']||'Failed\x20to\x20update\x20group','error');}}),this['container']['addEventListener']('dragstart',_0x3865d0=>this['handleDragStart'](_0x3865d0)),this['container']['addEventListener']('dragend',_0x2d750c=>this['handleDragEnd'](_0x2d750c)),this['container']['addEventListener']('dragover',_0x382748=>this['handleDragOver'](_0x382748)),this['container']['addEventListener']('dragleave',_0x4d2411=>this['handleDragLeave'](_0x4d2411)),this['container']['addEventListener']('drop',_0x536c45=>this['handleDrop'](_0x536c45));}['handleDragStart'](_0x498e00){const _0x1d0c11=_0x498e00['target']['closest']('.vgm-variant-card');if(!_0x1d0c11)return;dragState['draggedTaskId']=_0x1d0c11['dataset']['taskId'],dragState['draggedElement']=_0x1d0c11,dragState['sourceGroupId']=_0x1d0c11['dataset']['isGrouped']==='true'?this['groupId']:null,dragState['isDragging']=!![],_0x1d0c11['classList']['add']('dragging'),_0x498e00['dataTransfer']['effectAllowed']='move',_0x498e00['dataTransfer']['setData']('text/plain',_0x1d0c11['dataset']['taskId']),this['container']['classList']['add']('is-dragging');}['handleDragEnd'](_0x255c79){const _0x4d885a=_0x255c79['target']['closest']('.vgm-variant-card');_0x4d885a&&_0x4d885a['classList']['remove']('dragging'),this['container']['querySelectorAll']('.drag-over,\x20.drop-indicator')['forEach'](_0x1a2f98=>{_0x1a2f98['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'](_0x2dc14c){_0x2dc14c['preventDefault'](),_0x2dc14c['dataTransfer']['dropEffect']='move';const _0x45294d=_0x2dc14c['target']['closest']('.vgm-drop-zone'),_0x3805f0=_0x2dc14c['target']['closest']('.vgm-variant-card');this['container']['querySelectorAll']('.vgm-drop-zone')['forEach'](_0x4a553a=>{_0x4a553a['classList']['toggle']('drag-over',_0x4a553a===_0x45294d);});if(_0x3805f0&&_0x3805f0!==dragState['draggedElement']){const _0x5a638d=_0x3805f0['getBoundingClientRect'](),_0x14fe35=_0x5a638d['top']+_0x5a638d['height']/0x2,_0x5c5e82=_0x2dc14c['clientY']<_0x14fe35;this['container']['querySelectorAll']('.vgm-variant-card')['forEach'](_0x160716=>{_0x160716!==_0x3805f0&&_0x160716['classList']['remove']('drop-before','drop-after');}),_0x3805f0['classList']['toggle']('drop-before',_0x5c5e82),_0x3805f0['classList']['toggle']('drop-after',!_0x5c5e82);}}['handleDragLeave'](_0x1e5491){const _0x345d3d=_0x1e5491['target']['closest']('.vgm-drop-zone');_0x345d3d&&!_0x345d3d['contains'](_0x1e5491['relatedTarget'])&&_0x345d3d['classList']['remove']('drag-over');}async['handleDrop'](_0x8474fa){_0x8474fa['preventDefault']();const _0x1fc0a4=_0x8474fa['target']['closest']('.vgm-drop-zone'),_0x31917f=_0x8474fa['target']['closest']('.vgm-variant-card'),_0x953129=_0x8474fa['dataTransfer']['getData']('text/plain');if(!_0x1fc0a4||!_0x953129)return;this['container']['querySelectorAll']('.drag-over,\x20.drop-before,\x20.drop-after')['forEach'](_0x217c6a=>{_0x217c6a['classList']['remove']('drag-over','drop-before','drop-after');});const _0x21bbe8=_0x1fc0a4['dataset']['zone'],_0x3fefda=_0x21bbe8==='grouped',_0x4afe48=dragState['sourceGroupId']===this['groupId'];try{if(_0x3fefda&&!_0x4afe48){let _0x23b9d3=this['tasks']['filter'](_0x454394=>_0x454394['groupId']===this['groupId'])['length'];if(_0x31917f){const _0x4bd414=_0x31917f['dataset']['taskId'],_0x3e11b8=this['tasks']['find'](_0x27065f=>_0x27065f['taskId']===_0x4bd414);if(_0x3e11b8?.['groupIndex']!==undefined){const _0x2d3657=_0x31917f['getBoundingClientRect'](),_0x52a8b4=_0x8474fa['clientY']<_0x2d3657['top']+_0x2d3657['height']/0x2;_0x23b9d3=_0x3e11b8['groupIndex']+(_0x52a8b4?0x0:0x1);}}await this['addToGroup'](_0x953129,_0x23b9d3);}else{if(!_0x3fefda&&_0x4afe48)await this['removeFromGroup'](_0x953129);else _0x3fefda&&_0x4afe48&&_0x31917f&&await this['reorderInGroup'](_0x953129,_0x31917f,_0x8474fa['clientY']);}}catch(_0x4ebcbf){console['error']('Drop\x20operation\x20failed:',_0x4ebcbf),Utils['showToast'](_0x4ebcbf['message']||'Failed\x20to\x20move\x20variant','error');}}async['addToGroup'](_0x2c74df,_0x265812){const _0x4672fd=this['tasks']['find'](_0x4b4129=>_0x4b4129['taskId']===_0x2c74df);if(!_0x4672fd)return;_0x265812===undefined&&(_0x265812=this['tasks']['filter'](_0x258290=>_0x258290['groupId']===this['groupId'])['length']),!this['groupId']&&(this['groupId']=API['generateGroupId'](),await API['createTaskGroup']({'groupId':this['groupId']})),await API['updateTaskGroup'](_0x2c74df,this['groupId'],_0x265812),_0x4672fd['groupId']=this['groupId'],_0x4672fd['groupIndex']=_0x265812,this['render'](),this['onGroupChange'](this['tasks']);}async['removeFromGroup'](_0x501c2c){const _0x1d4f02=this['tasks']['find'](_0x4e6cd1=>_0x4e6cd1['taskId']===_0x501c2c);if(!_0x1d4f02)return;await API['removeTaskFromGroup'](_0x501c2c),_0x1d4f02['groupId']=null,_0x1d4f02['groupIndex']=null,this['render'](),this['onGroupChange'](this['tasks']);}async['reorderInGroup'](_0x40e063,_0x16b4b7,_0x74cccf){const _0x13282e=this['tasks']['find'](_0x32f681=>_0x32f681['taskId']===_0x40e063),_0x1e6308=_0x16b4b7['dataset']['taskId'],_0x1b4007=this['tasks']['find'](_0x4ca2b9=>_0x4ca2b9['taskId']===_0x1e6308);if(!_0x13282e||!_0x1b4007||_0x13282e['taskId']===_0x1b4007['taskId'])return;const _0x3ef296=_0x16b4b7['getBoundingClientRect'](),_0x163f8a=_0x74cccf<_0x3ef296['top']+_0x3ef296['height']/0x2;let _0x110208=_0x1b4007['groupIndex']??0x0;if(!_0x163f8a)_0x110208++;if((_0x13282e['groupIndex']??0x0)<(_0x1b4007['groupIndex']??0x0))_0x110208--;if(_0x110208===_0x13282e['groupIndex'])return;await API['updateTaskGroup'](_0x40e063,this['groupId'],_0x110208);const _0x39ec6e=this['tasks']['filter'](_0x4835f7=>_0x4835f7['groupId']===this['groupId'])['sort']((_0x2c9402,_0x30f022)=>(_0x2c9402['groupIndex']??0x0)-(_0x30f022['groupIndex']??0x0)),_0x340fe9=_0x39ec6e['findIndex'](_0x500178=>_0x500178['taskId']===_0x40e063);_0x340fe9!==-0x1&&_0x39ec6e['splice'](_0x340fe9,0x1),_0x39ec6e['splice'](_0x110208,0x0,_0x13282e),_0x39ec6e['forEach']((_0x47ece8,_0x78efd4)=>{_0x47ece8['groupIndex']=_0x78efd4;}),this['render'](),this['onGroupChange'](this['tasks']);}}export function initializeTabDragDrop(_0x1ca501,_0x2f5747,_0x649208,_0x423315={}){if(!_0x1ca501)return;const {onReorder:_0x3af966,onRemove:_0x1349f8}=_0x423315,_0x47111e=_0x1ca501['querySelectorAll']('.task-tab');_0x47111e['forEach']((_0x1f6f9c,_0x6636a)=>{_0x1f6f9c['setAttribute']('draggable','true'),_0x1f6f9c['dataset']['index']=_0x6636a,_0x1f6f9c['addEventListener']('dragstart',_0x1fe5a0=>{_0x1fe5a0['dataTransfer']['effectAllowed']='move',_0x1fe5a0['dataTransfer']['setData']('text/plain',_0x1f6f9c['dataset']['taskId']),_0x1f6f9c['classList']['add']('dragging'),_0x1ca501['classList']['add']('is-dragging');}),_0x1f6f9c['addEventListener']('dragend',()=>{_0x1f6f9c['classList']['remove']('dragging'),_0x1ca501['classList']['remove']('is-dragging'),_0x1ca501['querySelectorAll']('.drop-indicator')['forEach'](_0x2f1539=>{_0x2f1539['classList']['remove']('drop-indicator','drop-before','drop-after');});}),_0x1f6f9c['addEventListener']('dragover',_0x5e56a4=>{_0x5e56a4['preventDefault'](),_0x5e56a4['dataTransfer']['dropEffect']='move';if(_0x1f6f9c['classList']['contains']('dragging'))return;const _0x5ddd9c=_0x1f6f9c['getBoundingClientRect'](),_0x38a266=_0x5ddd9c['left']+_0x5ddd9c['width']/0x2,_0x1b96ed=_0x5e56a4['clientX']<_0x38a266;_0x47111e['forEach'](_0x3fd96f=>_0x3fd96f['classList']['remove']('drop-before','drop-after')),_0x1f6f9c['classList']['add'](_0x1b96ed?'drop-before':'drop-after');}),_0x1f6f9c['addEventListener']('dragleave',()=>{_0x1f6f9c['classList']['remove']('drop-before','drop-after');}),_0x1f6f9c['addEventListener']('drop',async _0x1914cb=>{_0x1914cb['preventDefault']();const _0x1948e6=_0x1914cb['dataTransfer']['getData']('text/plain'),_0x51ff02=_0x1f6f9c['dataset']['taskId'];if(_0x1948e6===_0x51ff02)return;const _0x246779=_0x1f6f9c['getBoundingClientRect'](),_0x3b1a29=_0x1914cb['clientX']<_0x246779['left']+_0x246779['width']/0x2;_0x1f6f9c['classList']['remove']('drop-before','drop-after'),_0x3af966&&await _0x3af966(_0x1948e6,_0x51ff02,_0x3b1a29);});});const _0x13bc50=document['createElement']('div');return _0x13bc50['className']='task-tab-remove-zone',_0x13bc50['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',_0x13bc50['style']['display']='none',_0x13bc50['addEventListener']('dragover',_0x296414=>{_0x296414['preventDefault'](),_0x13bc50['classList']['add']('drag-over');}),_0x13bc50['addEventListener']('dragleave',()=>{_0x13bc50['classList']['remove']('drag-over');}),_0x13bc50['addEventListener']('drop',async _0x21e947=>{_0x21e947['preventDefault'](),_0x13bc50['classList']['remove']('drag-over');const _0x402546=_0x21e947['dataTransfer']['getData']('text/plain');_0x1349f8&&await _0x1349f8(_0x402546);}),_0x1ca501['addEventListener']('dragstart',()=>{_0x2f5747['length']>0x1&&(_0x13bc50['style']['display']='flex');}),_0x1ca501['addEventListener']('dragend',()=>{_0x13bc50['style']['display']='none';}),_0x1ca501['appendChild'](_0x13bc50),{'destroy':()=>{_0x13bc50['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(_0x4bfba7={}){this['container']=null,this['onGroupChange']=_0x4bfba7['onGroupChange']||(()=>{}),this['onAddExistingTask']=_0x4bfba7['onAddExistingTask']||(()=>{}),this['tasks']=[],this['groupId']=_0x4bfba7['groupId']||null,this['isOpen']=![];}['init'](_0x3bbe51,_0x4d3828,_0x5533cc){this['container']=_0x3bbe51,this['tasks']=_0x4d3828,this['groupId']=_0x5533cc,this['render'](),this['attachEventListeners']();}['updateTasks'](_0x289caa){const _0x41b9f6=new Map(_0x289caa['map'](_0xd7e520=>[_0xd7e520['taskId'],_0xd7e520]));this['tasks']=this['tasks']['map'](_0x396b2d=>{const _0x25a1e0=_0x41b9f6['get'](_0x396b2d['taskId']);return _0x25a1e0?_0x25a1e0:_0x396b2d;});for(const _0x23e5ed of _0x289caa){!this['tasks']['some'](_0x4078d6=>_0x4078d6['taskId']===_0x23e5ed['taskId'])&&this['tasks']['push'](_0x23e5ed);}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 _0x479aa5=this['tasks']['filter'](_0x33befb=>_0x33befb['groupId']===this['groupId'])['sort']((_0x44abae,_0x324eed)=>(_0x44abae['groupIndex']??0x0)-(_0x324eed['groupIndex']??0x0)),_0x2c2c9f=this['tasks']['filter'](_0x1b2344=>!_0x1b2344['groupId']||_0x1b2344['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>'+_0x479aa5['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'+(_0x479aa5['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20add\x20to\x20group</div>':_0x479aa5['map']((_0x2d1e8d,_0x3d6b53)=>this['renderVariantCard'](_0x2d1e8d,_0x3d6b53,!![]))['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>'+_0x2c2c9f['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'+(_0x2c2c9f['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20remove\x20from\x20group</div>':_0x2c2c9f['map']((_0x21e247,_0x4c1c54)=>this['renderVariantCard'](_0x21e247,_0x4c1c54,![]))['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'](_0x58fe08,_0x16b1ac,_0x4389e8){const _0x23afdd=_0x58fe08['envVars']?.['CODER_AGENT']||_0x58fe08['envVars']?.['default_agent']||'claude',_0x4d6033=AGENT_ICONS[_0x23afdd['toLowerCase']()]||AGENT_ICONS['claude'],_0x47d051=STATUS_ICONS[_0x58fe08['status']]||'',_0x2a41c4='status-'+(_0x58fe08['status']||'unknown'),_0x3ed939=_0x58fe08['isWinner']?'<span\x20class=\x22vgm-badge\x20vgm-badge-winner\x22\x20title=\x22Winner\x22>★</span>':'',_0x54914a=_0x58fe08['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'+_0x2a41c4+'\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'+_0x58fe08['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-is-grouped=\x22'+_0x4389e8+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-index=\x22'+_0x16b1ac+'\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'+_0x23afdd['toLowerCase']()+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x4d6033+'\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'](_0x58fe08['name']||'Task\x20'+_0x58fe08['taskId']['slice'](-0x6))+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-meta\x22>'+Utils['escapeHtml'](_0x23afdd)+'\x20·\x20'+(_0x58fe08['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'+_0x3ed939+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x54914a+'\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'+_0x2a41c4+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x47d051+'\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'+(_0x4389e8?'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'+_0x58fe08['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-action=\x22'+(_0x4389e8?'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'+(_0x4389e8?'<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',_0x409a53=>{_0x409a53['target']['closest']('.vgm-close-btn')&&(this['close'](),this['onGroupChange'](this['tasks'])),_0x409a53['target']['closest']('.vgm-add-existing-btn')&&(this['close'](),this['onAddExistingTask'](this['groupId']));}),this['container']['addEventListener']('click',async _0x47f929=>{const _0x36d1ce=_0x47f929['target']['closest']('.vgm-variant-remove-btn');if(!_0x36d1ce)return;const _0xb652ce=_0x36d1ce['dataset']['taskId'],_0x145321=_0x36d1ce['dataset']['action'];try{_0x145321==='remove'?await this['removeFromGroup'](_0xb652ce):await this['addToGroup'](_0xb652ce);}catch(_0x4c6c91){console['error']('Failed\x20to\x20update\x20group:',_0x4c6c91),Utils['showToast'](_0x4c6c91['message']||'Failed\x20to\x20update\x20group','error');}}),this['container']['addEventListener']('dragstart',_0x5c0290=>this['handleDragStart'](_0x5c0290)),this['container']['addEventListener']('dragend',_0x4a6873=>this['handleDragEnd'](_0x4a6873)),this['container']['addEventListener']('dragover',_0x4aa5a1=>this['handleDragOver'](_0x4aa5a1)),this['container']['addEventListener']('dragleave',_0x2765ad=>this['handleDragLeave'](_0x2765ad)),this['container']['addEventListener']('drop',_0xb99451=>this['handleDrop'](_0xb99451));}['handleDragStart'](_0x45f266){const _0x3cd784=_0x45f266['target']['closest']('.vgm-variant-card');if(!_0x3cd784)return;dragState['draggedTaskId']=_0x3cd784['dataset']['taskId'],dragState['draggedElement']=_0x3cd784,dragState['sourceGroupId']=_0x3cd784['dataset']['isGrouped']==='true'?this['groupId']:null,dragState['isDragging']=!![],_0x3cd784['classList']['add']('dragging'),_0x45f266['dataTransfer']['effectAllowed']='move',_0x45f266['dataTransfer']['setData']('text/plain',_0x3cd784['dataset']['taskId']),this['container']['classList']['add']('is-dragging');}['handleDragEnd'](_0x3dd612){const _0x47aa90=_0x3dd612['target']['closest']('.vgm-variant-card');_0x47aa90&&_0x47aa90['classList']['remove']('dragging'),this['container']['querySelectorAll']('.drag-over,\x20.drop-indicator')['forEach'](_0x4590a1=>{_0x4590a1['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'](_0x4e66cc){_0x4e66cc['preventDefault'](),_0x4e66cc['dataTransfer']['dropEffect']='move';const _0x2f03df=_0x4e66cc['target']['closest']('.vgm-drop-zone'),_0x195b70=_0x4e66cc['target']['closest']('.vgm-variant-card');this['container']['querySelectorAll']('.vgm-drop-zone')['forEach'](_0x3f629a=>{_0x3f629a['classList']['toggle']('drag-over',_0x3f629a===_0x2f03df);});if(_0x195b70&&_0x195b70!==dragState['draggedElement']){const _0x5e6df8=_0x195b70['getBoundingClientRect'](),_0x5371aa=_0x5e6df8['top']+_0x5e6df8['height']/0x2,_0x89b1b0=_0x4e66cc['clientY']<_0x5371aa;this['container']['querySelectorAll']('.vgm-variant-card')['forEach'](_0x223f33=>{_0x223f33!==_0x195b70&&_0x223f33['classList']['remove']('drop-before','drop-after');}),_0x195b70['classList']['toggle']('drop-before',_0x89b1b0),_0x195b70['classList']['toggle']('drop-after',!_0x89b1b0);}}['handleDragLeave'](_0x1174f6){const _0x2edfcc=_0x1174f6['target']['closest']('.vgm-drop-zone');_0x2edfcc&&!_0x2edfcc['contains'](_0x1174f6['relatedTarget'])&&_0x2edfcc['classList']['remove']('drag-over');}async['handleDrop'](_0x35bb6b){_0x35bb6b['preventDefault']();const _0x3ea4bf=_0x35bb6b['target']['closest']('.vgm-drop-zone'),_0x2227f2=_0x35bb6b['target']['closest']('.vgm-variant-card'),_0x16c81a=_0x35bb6b['dataTransfer']['getData']('text/plain');if(!_0x3ea4bf||!_0x16c81a)return;this['container']['querySelectorAll']('.drag-over,\x20.drop-before,\x20.drop-after')['forEach'](_0x568640=>{_0x568640['classList']['remove']('drag-over','drop-before','drop-after');});const _0x48f21e=_0x3ea4bf['dataset']['zone'],_0x3004dc=_0x48f21e==='grouped',_0x474748=dragState['sourceGroupId']===this['groupId'];try{if(_0x3004dc&&!_0x474748){let _0x51940a=this['tasks']['filter'](_0x1fc553=>_0x1fc553['groupId']===this['groupId'])['length'];if(_0x2227f2){const _0x523029=_0x2227f2['dataset']['taskId'],_0x1f31a6=this['tasks']['find'](_0x32bcd9=>_0x32bcd9['taskId']===_0x523029);if(_0x1f31a6?.['groupIndex']!==undefined){const _0x33ee45=_0x2227f2['getBoundingClientRect'](),_0xa8402a=_0x35bb6b['clientY']<_0x33ee45['top']+_0x33ee45['height']/0x2;_0x51940a=_0x1f31a6['groupIndex']+(_0xa8402a?0x0:0x1);}}await this['addToGroup'](_0x16c81a,_0x51940a);}else{if(!_0x3004dc&&_0x474748)await this['removeFromGroup'](_0x16c81a);else _0x3004dc&&_0x474748&&_0x2227f2&&await this['reorderInGroup'](_0x16c81a,_0x2227f2,_0x35bb6b['clientY']);}}catch(_0x171100){console['error']('Drop\x20operation\x20failed:',_0x171100),Utils['showToast'](_0x171100['message']||'Failed\x20to\x20move\x20variant','error');}}async['addToGroup'](_0x28e517,_0x58c338){const _0xe40524=this['tasks']['find'](_0x129466=>_0x129466['taskId']===_0x28e517);if(!_0xe40524)return;_0x58c338===undefined&&(_0x58c338=this['tasks']['filter'](_0x16d188=>_0x16d188['groupId']===this['groupId'])['length']),!this['groupId']&&(this['groupId']=API['generateGroupId'](),await API['createTaskGroup']({'groupId':this['groupId']})),await API['updateTaskGroup'](_0x28e517,this['groupId'],_0x58c338),_0xe40524['groupId']=this['groupId'],_0xe40524['groupIndex']=_0x58c338,this['render'](),this['onGroupChange'](this['tasks']);}async['removeFromGroup'](_0x418d30){const _0xc0aee6=this['tasks']['find'](_0x1c9823=>_0x1c9823['taskId']===_0x418d30);if(!_0xc0aee6)return;await API['removeTaskFromGroup'](_0x418d30),_0xc0aee6['groupId']=null,_0xc0aee6['groupIndex']=null,this['render'](),this['onGroupChange'](this['tasks']);}async['reorderInGroup'](_0x51d405,_0xa8c1d4,_0x149418){const _0x3d8b85=this['tasks']['find'](_0x28c678=>_0x28c678['taskId']===_0x51d405),_0x32ba7b=_0xa8c1d4['dataset']['taskId'],_0x3b3323=this['tasks']['find'](_0x20b4bc=>_0x20b4bc['taskId']===_0x32ba7b);if(!_0x3d8b85||!_0x3b3323||_0x3d8b85['taskId']===_0x3b3323['taskId'])return;const _0x33d509=_0xa8c1d4['getBoundingClientRect'](),_0xd4041d=_0x149418<_0x33d509['top']+_0x33d509['height']/0x2;let _0x5356ba=_0x3b3323['groupIndex']??0x0;if(!_0xd4041d)_0x5356ba++;if((_0x3d8b85['groupIndex']??0x0)<(_0x3b3323['groupIndex']??0x0))_0x5356ba--;if(_0x5356ba===_0x3d8b85['groupIndex'])return;await API['updateTaskGroup'](_0x51d405,this['groupId'],_0x5356ba);const _0x277e47=this['tasks']['filter'](_0x2b5b3c=>_0x2b5b3c['groupId']===this['groupId'])['sort']((_0x29a7b2,_0x365421)=>(_0x29a7b2['groupIndex']??0x0)-(_0x365421['groupIndex']??0x0)),_0x38da16=_0x277e47['findIndex'](_0x5a398f=>_0x5a398f['taskId']===_0x51d405);_0x38da16!==-0x1&&_0x277e47['splice'](_0x38da16,0x1),_0x277e47['splice'](_0x5356ba,0x0,_0x3d8b85),_0x277e47['forEach']((_0x48f71b,_0x23540b)=>{_0x48f71b['groupIndex']=_0x23540b;}),this['render'](),this['onGroupChange'](this['tasks']);}}export function initializeTabDragDrop(_0x4ed74,_0x17e989,_0x1a7901,_0xc4ece0={}){if(!_0x4ed74)return;const {onReorder:_0x2a2965,onRemove:_0x5b4904}=_0xc4ece0,_0x5052aa=_0x4ed74['querySelectorAll']('.task-tab');_0x5052aa['forEach']((_0xa4440a,_0x229bbd)=>{_0xa4440a['setAttribute']('draggable','true'),_0xa4440a['dataset']['index']=_0x229bbd,_0xa4440a['addEventListener']('dragstart',_0x3150a=>{_0x3150a['dataTransfer']['effectAllowed']='move',_0x3150a['dataTransfer']['setData']('text/plain',_0xa4440a['dataset']['taskId']),_0xa4440a['classList']['add']('dragging'),_0x4ed74['classList']['add']('is-dragging');}),_0xa4440a['addEventListener']('dragend',()=>{_0xa4440a['classList']['remove']('dragging'),_0x4ed74['classList']['remove']('is-dragging'),_0x4ed74['querySelectorAll']('.drop-indicator')['forEach'](_0x11544e=>{_0x11544e['classList']['remove']('drop-indicator','drop-before','drop-after');});}),_0xa4440a['addEventListener']('dragover',_0x1dae8c=>{_0x1dae8c['preventDefault'](),_0x1dae8c['dataTransfer']['dropEffect']='move';if(_0xa4440a['classList']['contains']('dragging'))return;const _0x280ccc=_0xa4440a['getBoundingClientRect'](),_0x274f9c=_0x280ccc['left']+_0x280ccc['width']/0x2,_0x59ca8a=_0x1dae8c['clientX']<_0x274f9c;_0x5052aa['forEach'](_0xd2f63c=>_0xd2f63c['classList']['remove']('drop-before','drop-after')),_0xa4440a['classList']['add'](_0x59ca8a?'drop-before':'drop-after');}),_0xa4440a['addEventListener']('dragleave',()=>{_0xa4440a['classList']['remove']('drop-before','drop-after');}),_0xa4440a['addEventListener']('drop',async _0xf15c1a=>{_0xf15c1a['preventDefault']();const _0x4401c7=_0xf15c1a['dataTransfer']['getData']('text/plain'),_0x302f4c=_0xa4440a['dataset']['taskId'];if(_0x4401c7===_0x302f4c)return;const _0x3b6008=_0xa4440a['getBoundingClientRect'](),_0x2b9b58=_0xf15c1a['clientX']<_0x3b6008['left']+_0x3b6008['width']/0x2;_0xa4440a['classList']['remove']('drop-before','drop-after'),_0x2a2965&&await _0x2a2965(_0x4401c7,_0x302f4c,_0x2b9b58);});});const _0x121984=document['createElement']('div');return _0x121984['className']='task-tab-remove-zone',_0x121984['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',_0x121984['style']['display']='none',_0x121984['addEventListener']('dragover',_0xae686b=>{_0xae686b['preventDefault'](),_0x121984['classList']['add']('drag-over');}),_0x121984['addEventListener']('dragleave',()=>{_0x121984['classList']['remove']('drag-over');}),_0x121984['addEventListener']('drop',async _0x231f92=>{_0x231f92['preventDefault'](),_0x121984['classList']['remove']('drag-over');const _0x2bc60e=_0x231f92['dataTransfer']['getData']('text/plain');_0x5b4904&&await _0x5b4904(_0x2bc60e);}),_0x4ed74['addEventListener']('dragstart',()=>{_0x17e989['length']>0x1&&(_0x121984['style']['display']='flex');}),_0x4ed74['addEventListener']('dragend',()=>{_0x121984['style']['display']='none';}),_0x4ed74['appendChild'](_0x121984),{'destroy':()=>{_0x121984['remove']();}};}export default VariantGroupingManager;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@profoundlogic/coderflow-server",
3
- "version": "0.6.5",
3
+ "version": "0.6.7",
4
4
  "description": "AI Coder Server - Manages Docker containers for AI agent task execution",
5
5
  "main": "dist/start.js",
6
6
  "type": "module",