@profoundlogic/coderflow-server 0.8.4 → 0.8.5

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 (177) hide show
  1. package/dist/coder-server.js +1 -1
  2. package/dist/config.js +1 -1
  3. package/dist/lib/agent-keepalive.js +1 -1
  4. package/dist/lib/agent-models.js +1 -1
  5. package/dist/lib/api-keys.js +1 -1
  6. package/dist/lib/apiKeys.js +1 -1
  7. package/dist/lib/app-server-ports.js +1 -1
  8. package/dist/lib/auto-judge.js +1 -1
  9. package/dist/lib/automation-service.js +1 -1
  10. package/dist/lib/basic-auth.js +1 -1
  11. package/dist/lib/bindings.js +1 -1
  12. package/dist/lib/build-history.js +1 -1
  13. package/dist/lib/build-output-service.js +1 -1
  14. package/dist/lib/build-scheduler.js +1 -1
  15. package/dist/lib/build-service.js +1 -1
  16. package/dist/lib/ca-certificates.js +1 -1
  17. package/dist/lib/claude-oauth-refresh.js +1 -1
  18. package/dist/lib/cli/build.js +1 -1
  19. package/dist/lib/cli/cleanup-users.js +1 -1
  20. package/dist/lib/cli/config-command.js +1 -1
  21. package/dist/lib/cli/config.js +1 -1
  22. package/dist/lib/cli/create-user.js +1 -1
  23. package/dist/lib/cli/grant-admin.js +1 -1
  24. package/dist/lib/cli/init.js +1 -1
  25. package/dist/lib/cli/jira.js +1 -1
  26. package/dist/lib/cli/license.js +1 -1
  27. package/dist/lib/cli/list-roles.js +1 -1
  28. package/dist/lib/cli/list-users.js +1 -1
  29. package/dist/lib/cli/server-manager.js +1 -1
  30. package/dist/lib/cli/set-password.js +1 -1
  31. package/dist/lib/compression-filter.js +1 -1
  32. package/dist/lib/config-migration.js +1 -1
  33. package/dist/lib/container-credential-sync.js +1 -1
  34. package/dist/lib/container-tokens.js +1 -1
  35. package/dist/lib/data-dir.js +1 -1
  36. package/dist/lib/deployment-history.js +1 -1
  37. package/dist/lib/deployment-service.js +1 -1
  38. package/dist/lib/docker-utils.js +1 -1
  39. package/dist/lib/email.js +1 -1
  40. package/dist/lib/emailTemplates.js +1 -1
  41. package/dist/lib/entitlement.js +1 -1
  42. package/dist/lib/external-connections.js +1 -1
  43. package/dist/lib/fetch-utils.js +1 -1
  44. package/dist/lib/git-commit-details-route.js +1 -1
  45. package/dist/lib/git-history-diff-guardrails.js +1 -1
  46. package/dist/lib/git-provider-service.js +1 -1
  47. package/dist/lib/git-provider-setup/github-setup-handler.js +1 -1
  48. package/dist/lib/git-provider-setup/index.js +1 -1
  49. package/dist/lib/git-provider-setup/setup-factory.js +1 -1
  50. package/dist/lib/git-provider-setup/setup-interface.js +1 -1
  51. package/dist/lib/git-providers/azure-devops-provider.js +1 -1
  52. package/dist/lib/git-providers/github-app-provider.js +1 -1
  53. package/dist/lib/git-providers/index.js +1 -1
  54. package/dist/lib/git-providers/provider-factory.js +1 -1
  55. package/dist/lib/git-providers/provider-interface.js +1 -1
  56. package/dist/lib/github-urls.js +1 -1
  57. package/dist/lib/group-objective-linking.js +1 -1
  58. package/dist/lib/ibmi-sync.js +1 -1
  59. package/dist/lib/jira-client.js +1 -1
  60. package/dist/lib/judge-blinding.js +1 -1
  61. package/dist/lib/logger.js +1 -1
  62. package/dist/lib/memory-utils.js +1 -1
  63. package/dist/lib/migration-to-scoped-rbac.js +1 -1
  64. package/dist/lib/model-fetcher.js +1 -1
  65. package/dist/lib/notifications.js +1 -1
  66. package/dist/lib/objective-context.js +1 -1
  67. package/dist/lib/oidc-auth.js +1 -1
  68. package/dist/lib/oidc-device-flow.js +1 -1
  69. package/dist/lib/passwordTokens.js +1 -1
  70. package/dist/lib/permission-resolver.js +1 -1
  71. package/dist/lib/pin-cascade.js +1 -1
  72. package/dist/lib/provider-accounts.js +1 -1
  73. package/dist/lib/provider-oauth.js +1 -1
  74. package/dist/lib/provider-profile.js +1 -1
  75. package/dist/lib/provider-token-refresh.js +1 -1
  76. package/dist/lib/rbac-user-state.js +1 -1
  77. package/dist/lib/request-url.js +1 -1
  78. package/dist/lib/rewind.js +1 -1
  79. package/dist/lib/role-definitions.js +1 -1
  80. package/dist/lib/roles.js +1 -1
  81. package/dist/lib/secrets.js +1 -1
  82. package/dist/lib/setup-repo-git-auth.js +1 -1
  83. package/dist/lib/state-capture.js +1 -1
  84. package/dist/lib/static-files.js +1 -1
  85. package/dist/lib/task-aliases.js +1 -1
  86. package/dist/lib/task-container-init.js +1 -1
  87. package/dist/lib/task-context-usage.js +1 -1
  88. package/dist/lib/task-name-format.js +1 -1
  89. package/dist/lib/task-name-generator.js +1 -1
  90. package/dist/lib/task-source-metadata.js +1 -1
  91. package/dist/lib/teams.js +1 -1
  92. package/dist/lib/user-git-oauth.js +1 -1
  93. package/dist/lib/user-git-tokens.js +1 -1
  94. package/dist/lib/users.js +1 -1
  95. package/dist/middleware/requireAuth.js +1 -1
  96. package/dist/middleware/requireInit.js +1 -1
  97. package/dist/middleware/requirePermission.js +1 -1
  98. package/dist/package.json +1 -1
  99. package/dist/playwright.config.js +1 -1
  100. package/dist/playwright.task-terminal.config.js +1 -1
  101. package/dist/routes/apiKeys.js +1 -1
  102. package/dist/routes/auth-oidc.js +1 -1
  103. package/dist/routes/auth.js +1 -1
  104. package/dist/routes/automations.js +1 -1
  105. package/dist/routes/bindings.js +1 -1
  106. package/dist/routes/build.js +1 -1
  107. package/dist/routes/containers.js +1 -1
  108. package/dist/routes/deploy-task.js +1 -1
  109. package/dist/routes/environment-management.js +1 -1
  110. package/dist/routes/environments.js +1 -1
  111. package/dist/routes/external-skills.js +1 -1
  112. package/dist/routes/git-credentials.js +1 -1
  113. package/dist/routes/git-oauth.js +1 -1
  114. package/dist/routes/git-provider-setup.js +1 -1
  115. package/dist/routes/health.js +1 -1
  116. package/dist/routes/jira.js +1 -1
  117. package/dist/routes/logs.js +1 -1
  118. package/dist/routes/objective-management.js +1 -1
  119. package/dist/routes/password.js +1 -1
  120. package/dist/routes/prompt.js +1 -1
  121. package/dist/routes/provider-auth.js +1 -1
  122. package/dist/routes/qa.js +1 -1
  123. package/dist/routes/roles.js +1 -1
  124. package/dist/routes/settings.js +1 -1
  125. package/dist/routes/skill-management.js +1 -1
  126. package/dist/routes/skills.js +1 -1
  127. package/dist/routes/stats.js +1 -1
  128. package/dist/routes/tasks.js +1 -1
  129. package/dist/routes/teams.js +1 -1
  130. package/dist/routes/templates.js +1 -1
  131. package/dist/routes/test-task.js +1 -1
  132. package/dist/routes/test.js +1 -1
  133. package/dist/routes/users.js +1 -1
  134. package/dist/routes/visualizations.js +1 -1
  135. package/dist/scripts/create-user.js +1 -1
  136. package/dist/scripts/migrate-config-to-data-dir.js +1 -1
  137. package/dist/start.js +1 -1
  138. package/dist/web-ui/public/activity-detail-modal.js +1 -1
  139. package/dist/web-ui/public/activity-feed.js +1 -1
  140. package/dist/web-ui/public/activity-formatters.js +1 -1
  141. package/dist/web-ui/public/admin.js +1 -1
  142. package/dist/web-ui/public/agent-event-parser.js +1 -1
  143. package/dist/web-ui/public/app.js +1 -1
  144. package/dist/web-ui/public/approve-dialog.js +1 -1
  145. package/dist/web-ui/public/automation-links.js +1 -1
  146. package/dist/web-ui/public/automation-schedule.js +1 -1
  147. package/dist/web-ui/public/comments-widget.js +1 -1
  148. package/dist/web-ui/public/diff-utils.js +1 -1
  149. package/dist/web-ui/public/environments.js +1 -1
  150. package/dist/web-ui/public/feedback-widget.js +1 -1
  151. package/dist/web-ui/public/file-selection-tree.js +1 -1
  152. package/dist/web-ui/public/git-history-lazy-utils.js +1 -1
  153. package/dist/web-ui/public/git-history.js +1 -1
  154. package/dist/web-ui/public/git-status.js +1 -1
  155. package/dist/web-ui/public/ibmi-file-filter.js +1 -1
  156. package/dist/web-ui/public/index.js +1 -1
  157. package/dist/web-ui/public/login.js +1 -1
  158. package/dist/web-ui/public/markdown-editor.js +1 -1
  159. package/dist/web-ui/public/markdown-file-editor.js +1 -1
  160. package/dist/web-ui/public/modal-maximize.js +1 -1
  161. package/dist/web-ui/public/notifications.js +1 -1
  162. package/dist/web-ui/public/permissions.js +1 -1
  163. package/dist/web-ui/public/pr-dialog.js +1 -1
  164. package/dist/web-ui/public/roles.js +1 -1
  165. package/dist/web-ui/public/settings.js +1 -1
  166. package/dist/web-ui/public/setup-password.js +1 -1
  167. package/dist/web-ui/public/skills.js +1 -1
  168. package/dist/web-ui/public/sse-client.js +1 -1
  169. package/dist/web-ui/public/sse-shared-worker.js +1 -1
  170. package/dist/web-ui/public/task-judging-helpers.js +1 -1
  171. package/dist/web-ui/public/task.js +1 -1
  172. package/dist/web-ui/public/teams.js +1 -1
  173. package/dist/web-ui/public/terminal.js +1 -1
  174. package/dist/web-ui/public/theme.js +1 -1
  175. package/dist/web-ui/public/users.js +1 -1
  176. package/dist/web-ui/public/variant-grouping.js +1 -1
  177. package/package.json +1 -1
@@ -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 _0x52eed4=state['currentUser'];if(!Permissions['hasServerPermission'](_0x52eed4,'teams:view')&&!Permissions['hasTeamPermission'](_0x52eed4,'teams:manage')){Utils['showToast']('Access\x20denied:\x20You\x20do\x20not\x20have\x20permission\x20to\x20view\x20teams','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}(Permissions['hasServerPermission'](_0x52eed4,'*')||Permissions['hasTeamPermission'](_0x52eed4,'teams:manage'))&&(document['getElementById']('create-team-btn')['hidden']=![]),bindEventListeners(),await Promise['all']([loadTeams(),loadUsers(),loadRoles(),loadEnvironments()]),renderTeams();});async function loadTeams(){const _0x429504=document['getElementById']('teams-loading'),_0x2ac70d=document['getElementById']('teams-error'),_0x37d546=document['getElementById']('teams-content');try{_0x429504['hidden']=![],_0x2ac70d['hidden']=!![],_0x37d546['hidden']=!![];const {teams:_0x37d37f}=await API['getTeams']();state['teams']=_0x37d37f||[],renderTeams(),_0x429504['hidden']=!![],_0x37d546['hidden']=![];}catch(_0x41c53d){_0x429504['hidden']=!![],_0x2ac70d['hidden']=![],document['getElementById']('teams-error-message')['textContent']=_0x41c53d['message'];}}async function loadUsers(){try{const {users:_0x220998}=await API['getUsers']();state['users']=_0x220998||[];}catch{state['users']=[];}}async function loadRoles(){try{const {roles:_0x3eb534}=await API['getRoleDefinitions']();state['roles']=_0x3eb534||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x43d77c=await API['getEnvironments']();state['environments']=_0x43d77c['environments']||[];}catch{state['environments']=[];}}function renderTeams(){const _0x313d89=document['getElementById']('teams-table-body'),_0x225831=document['getElementById']('team-count');if(!_0x313d89)return;_0x225831&&(_0x225831['textContent']=state['teams']['length']+'\x20team'+(state['teams']['length']===0x1?'':'s'));if(state['teams']['length']===0x0){_0x313d89['innerHTML']='\x0a\x20\x20\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td\x20colspan=\x223\x22\x20style=\x22text-align:\x20center;\x20color:\x20var(--color-text-secondary);\x20padding:\x202rem;\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20No\x20teams\x20yet.\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage')?'Click\x20<strong>Create\x20Team</strong>\x20to\x20get\x20started.':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20</tr>';return;}const _0xd72fd3=Permissions['hasServerPermission'](state['currentUser'],'*');_0x313d89['innerHTML']=state['teams']['map'](_0x2bd739=>{const _0x3e0f0f=_0xd72fd3||_0x2bd739['canManageTeam'],_0xa5d552=_0xd72fd3||_0x2bd739['canManageMembers'],_0x47c64f=_0x3e0f0f||_0xa5d552,_0x3002e8=(_0x2bd739['members']||[])['length'];return'\x0a\x20\x20\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20style=\x22font-weight:\x20600;\x22>'+Utils['escapeHtml'](_0x2bd739['name'])+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x2bd739['description']?'<div\x20style=\x22font-size:\x200.8em;\x20color:\x20var(--color-text-secondary);\x20margin-top:\x200.15rem;\x22>'+Utils['escapeHtml'](_0x2bd739['description'])+'</div>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+_0x3002e8+'</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22user-actions\x22\x20style=\x22display:\x20flex;\x20gap:\x200.25rem;\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x47c64f?'<button\x20class=\x22btn-icon\x22\x20title=\x22Edit\x20team\x22\x20onclick=\x22window.openTeamModal(\x27'+_0x2bd739['id']+'\x27)\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2216\x22\x20height=\x2216\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M11\x204H4a2\x202\x200\x200\x200-2\x202v14a2\x202\x200\x200\x200\x202\x202h14a2\x202\x200\x200\x200\x202-2v-7\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M18.5\x202.5a2.121\x202.121\x200\x200\x201\x203\x203L12\x2015l-4\x201\x201-4\x209.5-9.5z\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x3e0f0f?'<button\x20class=\x22btn-icon\x22\x20title=\x22Access\x20bindings\x22\x20onclick=\x22window.openBindingsModal(\x27'+_0x2bd739['id']+'\x27)\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2216\x22\x20height=\x2216\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M12\x2022s8-4\x208-10V5l-8-3-8\x203v7c0\x206\x208\x2010\x208\x2010z\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x3e0f0f?'<button\x20class=\x22btn-icon\x20btn-danger\x22\x20title=\x22Delete\x20team\x22\x20onclick=\x22window.deleteTeam(\x27'+_0x2bd739['id']+'\x27)\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2216\x22\x20height=\x2216\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<polyline\x20points=\x223\x206\x205\x206\x2021\x206\x22></polyline>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M19\x206v14a2\x202\x200\x200\x201-2\x202H7a2\x202\x200\x200\x201-2-2V6m3\x200V4a2\x202\x200\x200\x201\x202-2h4a2\x202\x200\x200\x201\x202\x202v2\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20</tr>';})['join']('');}function bindEventListeners(){document['getElementById']('create-team-btn')?.['addEventListener']('click',showCreateTeamModal),document['getElementById']('retry-teams-btn')?.['addEventListener']('click',loadTeams),document['getElementById']('close-team-modal')?.['addEventListener']('click',requestHideTeamModal),document['getElementById']('cancel-team')?.['addEventListener']('click',requestHideTeamModal),document['getElementById']('save-team')?.['addEventListener']('click',saveTeam),document['querySelector']('#team-modal\x20.modal-overlay')?.['addEventListener']('click',requestHideTeamModal),document['getElementById']('add-member-btn')?.['addEventListener']('click',addMember),document['getElementById']('close-bindings-modal')?.['addEventListener']('click',hideBindingsModal),document['querySelector']('#bindings-modal\x20.modal-overlay')?.['addEventListener']('click',hideBindingsModal),document['getElementById']('add-binding-btn')?.['addEventListener']('click',()=>{document['getElementById']('add-binding-form')['hidden']=![],document['getElementById']('add-binding-btn')['hidden']=!![],populateBindingForm();}),document['getElementById']('cancel-binding-btn')?.['addEventListener']('click',()=>{document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![];}),document['getElementById']('save-binding-btn')?.['addEventListener']('click',saveBinding),document['getElementById']('binding-resource-type')?.['addEventListener']('change',onBindingResourceTypeChange),document['getElementById']('close-delete-team-modal')?.['addEventListener']('click',hideDeleteModal),document['getElementById']('cancel-delete-team')?.['addEventListener']('click',hideDeleteModal),document['getElementById']('confirm-delete-team')?.['addEventListener']('click',confirmDeleteTeam),document['querySelector']('#delete-team-modal\x20.modal-overlay')?.['addEventListener']('click',hideDeleteModal);}function showCreateTeamModal(){state['editingTeamId']=null,state['modalSnapshot']={'name':'','description':''},document['getElementById']('team-modal-title')['textContent']='Create\x20Team',document['getElementById']('team-name')['value']='',document['getElementById']('team-name')['disabled']=![],document['getElementById']('team-description')['value']='',document['getElementById']('team-description')['disabled']=![],document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=!![],document['getElementById']('save-team')['hidden']=![],document['getElementById']('team-modal-footer')['hidden']=![],document['getElementById']('team-modal')['hidden']=![],setTimeout(()=>document['getElementById']('team-name')['focus'](),0x64);}window['openTeamModal']=function(_0x20c9f0){const _0xe2f5d6=state['teams']['find'](_0x2cd115=>_0x2cd115['id']===_0x20c9f0);if(!_0xe2f5d6)return;state['editingTeamId']=_0x20c9f0;const _0x5e071f=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x148a42=_0x5e071f||_0xe2f5d6['canManageTeam'],_0x359143=_0x5e071f||_0xe2f5d6['canManageMembers'],_0x46aa53=_0x148a42,_0x872356=_0x148a42||_0x359143,_0x362b92=_0xe2f5d6['name'],_0x27862b=_0xe2f5d6['description']||'';state['modalSnapshot']={'name':_0x362b92,'description':_0x27862b},document['getElementById']('team-modal-title')['textContent']=_0x362b92,document['getElementById']('team-name')['value']=_0x362b92,document['getElementById']('team-name')['disabled']=!_0x46aa53,document['getElementById']('team-description')['value']=_0x27862b,document['getElementById']('team-description')['disabled']=!_0x46aa53,document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=![],document['getElementById']('save-team')['hidden']=!_0x46aa53,renderMembersList(_0xe2f5d6),updateMemberSelect(_0xe2f5d6),document['getElementById']('team-modal')['hidden']=![];};function isTeamModalDirty(){if(!state['modalSnapshot'])return![];const _0xa67cda=document['getElementById']('team-name')['value']['trim'](),_0x427acc=document['getElementById']('team-description')['value']['trim']();return _0xa67cda!==state['modalSnapshot']['name']||_0x427acc!==state['modalSnapshot']['description'];}function requestHideTeamModal(){if(isTeamModalDirty()){if(!confirm('You\x20have\x20unsaved\x20changes.\x20Discard\x20them?'))return;}hideTeamModal();}function hideTeamModal(){document['getElementById']('team-modal')['hidden']=!![],document['getElementById']('team-name')['disabled']=![],document['getElementById']('team-description')['disabled']=![],state['editingTeamId']=null,state['modalSnapshot']=null;}window['openBindingsModal']=function(_0x3e1f0e){const _0x3660e5=state['teams']['find'](_0x1fe7b4=>_0x1fe7b4['id']===_0x3e1f0e);if(!_0x3660e5)return;state['bindingsTeamId']=_0x3e1f0e,document['getElementById']('bindings-modal-title')['textContent']='Access\x20Bindings\x20—\x20'+_0x3660e5['name'],document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('bindings-modal')['hidden']=![],loadTeamBindings(_0x3e1f0e);};function hideBindingsModal(){document['getElementById']('bindings-modal')['hidden']=!![],state['bindingsTeamId']=null;}function renderMembersList(_0x2bf102){const _0x1d93d1=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x2ceb18=_0x1d93d1||_0x2bf102['canManageMembers']||_0x2bf102['canManageTeam'],_0x2c0253=_0x2bf102['members']||[],_0x136370=document['getElementById']('members-list');if(_0x2c0253['length']===0x0){_0x136370['innerHTML']='<p\x20style=\x22font-size:\x200.875rem;\x20color:\x20var(--color-text-secondary);\x20margin:\x200.25rem\x200;\x22>No\x20members\x20yet</p>';return;}_0x136370['innerHTML']=_0x2c0253['map'](_0xaca733=>{const _0x252b5c=state['users']['find'](_0x46442e=>_0x46442e['id']===_0xaca733),_0x38f535=_0x252b5c?''+Utils['escapeHtml'](_0x252b5c['username'])+(_0x252b5c['name']?'\x20<span\x20style=\x22color:\x20var(--color-text-secondary);\x20font-size:\x200.85em;\x22>('+Utils['escapeHtml'](_0x252b5c['name'])+')</span>':''):Utils['escapeHtml'](_0xaca733);return'\x0a\x20\x20\x20\x20\x20\x20<div\x20style=\x22display:\x20flex;\x20align-items:\x20center;\x20justify-content:\x20space-between;\x20padding:\x200.35rem\x200;\x20border-bottom:\x201px\x20solid\x20var(--color-border);\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<span\x20style=\x22font-size:\x200.875rem;\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x38f535+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x2ceb18?'<button\x20type=\x22button\x22\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.removeMemberClick(\x27'+_0xaca733+'\x27)\x22\x20style=\x22color:\x20var(--color-danger);\x20padding:\x200.15rem\x200.4rem;\x20font-size:\x200.8rem;\x22>Remove</button>':'')+'\x0a\x20\x20\x20\x20\x20\x20</div>';})['join']('');const _0x583f78=document['getElementById']('add-member-row');if(_0x583f78)_0x583f78['style']['display']=_0x2ceb18?'flex':'none';}function updateMemberSelect(_0x12fb94){const _0xeb9116=document['getElementById']('add-member-select');if(!_0xeb9116)return;const _0x322dbf=new Set(_0x12fb94['members']||[]),_0x4330c7=state['users']['filter'](_0x3dceb3=>!_0x322dbf['has'](_0x3dceb3['id']));_0xeb9116['innerHTML']='<option\x20value=\x22\x22>Add\x20a\x20member…</option>'+_0x4330c7['map'](_0x7849b9=>'<option\x20value=\x22'+_0x7849b9['id']+'\x22>'+Utils['escapeHtml'](_0x7849b9['username'])+(_0x7849b9['name']?'\x20('+Utils['escapeHtml'](_0x7849b9['name'])+')':'')+'</option>')['join']('');}async function addMember(){const _0x646431=document['getElementById']('add-member-select'),_0x4842b9=_0x646431['value'];if(!_0x4842b9||!state['editingTeamId'])return;try{const {team:_0xa29a94}=await API['addTeamMember'](state['editingTeamId'],_0x4842b9);syncTeamInState(_0xa29a94),renderMembersList(_0xa29a94),updateMemberSelect(_0xa29a94),_0x646431['value']='',Utils['showToast']('Member\x20added','success');}catch(_0x4bd818){Utils['showToast'](_0x4bd818['message'],'error');}}window['removeMemberClick']=async function(_0x3eea78){if(!state['editingTeamId'])return;try{const {team:_0x3141b4}=await API['removeTeamMember'](state['editingTeamId'],_0x3eea78);syncTeamInState(_0x3141b4),renderMembersList(_0x3141b4),updateMemberSelect(_0x3141b4),Utils['showToast']('Member\x20removed','success');}catch(_0x473e91){Utils['showToast'](_0x473e91['message'],'error');}};async function loadTeamBindings(_0x1aa8a9){const _0xc4f3a7=document['getElementById']('bindings-loading'),_0x22f722=document['getElementById']('bindings-empty'),_0x5869a6=document['getElementById']('bindings-list-container'),_0x404a97=document['getElementById']('add-binding-btn');_0xc4f3a7['hidden']=![],_0x22f722['hidden']=!![],_0x5869a6['style']['display']='none',_0x404a97['hidden']=!![],document['getElementById']('add-binding-form')['hidden']=!![];try{const {bindings:_0x34a254}=await API['getBindings']({'subject_type':'team','subject_id':_0x1aa8a9});state['teamBindings']=_0x34a254||[],_0xc4f3a7['hidden']=!![],state['teamBindings']['length']===0x0?_0x22f722['hidden']=![]:(_0x5869a6['style']['display']='',renderBindingsTable()),(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage'))&&(_0x404a97['hidden']=![]);}catch(_0x3477ad){_0xc4f3a7['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x3477ad['message'],'error');}}function renderBindingsTable(){const _0x364032=document['getElementById']('bindings-table-body');if(!_0x364032)return;const _0x3373ad=Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage');_0x364032['innerHTML']=state['teamBindings']['map'](_0x52a095=>{const _0x1b842b=_0x52a095['resource_type']==='server'?'Server':_0x52a095['resource_id']==='*'?'All\x20'+_0x52a095['resource_type']+'s':Utils['escapeHtml'](_0x52a095['resource_name']||_0x52a095['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x1b842b+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x52a095['role_name']||_0x52a095['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x3373ad?'<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteBindingClick(\x27'+_0x52a095['id']+'\x27)\x22\x20style=\x22color:\x20var(--color-danger);\x22>Remove</button>':'—')+'\x0a\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20</tr>';})['join']('');}function populateBindingForm(){const _0xd61e55=document['getElementById']('binding-resource-type');_0xd61e55['value']='environment',updateBindingFormForResourceType('environment');}function onBindingResourceTypeChange(){const _0x3b4140=document['getElementById']('binding-resource-type')['value'];updateBindingFormForResourceType(_0x3b4140);}function updateBindingFormForResourceType(_0x2f4f5a){const _0x542de7=document['getElementById']('binding-resource-container'),_0x545139=document['getElementById']('binding-resource'),_0x5b75aa=document['getElementById']('binding-role');if(_0x2f4f5a==='server')_0x542de7['style']['display']='none';else{_0x542de7['style']['display']='';if(_0x2f4f5a==='environment'){const _0x467f41=new Set(state['teamBindings']['filter'](_0x275679=>_0x275679['resource_type']==='environment')['map'](_0x53b4da=>_0x53b4da['resource_id'])),_0x3cbd6f=state['environments']['filter'](_0x496508=>!_0x467f41['has'](_0x496508['name']));_0x545139['innerHTML']=_0x3cbd6f['length']?_0x3cbd6f['map'](_0x1aeb85=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x1aeb85['name'])+'\x22>'+Utils['escapeHtml'](_0x1aeb85['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x2f4f5a==='team'){const _0x39c037=new Set(state['teamBindings']['filter'](_0x5294c2=>_0x5294c2['resource_type']==='team')['map'](_0x5992b7=>_0x5992b7['resource_id'])),_0x5d3ae1=state['teams']['filter'](_0x5f8ee6=>!_0x39c037['has'](_0x5f8ee6['id']));_0x545139['innerHTML']=_0x5d3ae1['length']?_0x5d3ae1['map'](_0x2212c5=>'<option\x20value=\x22'+_0x2212c5['id']+'\x22>'+Utils['escapeHtml'](_0x2212c5['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x4f4790=state['roles']['filter'](_0x40e67a=>_0x40e67a['resource_type']===_0x2f4f5a);_0x5b75aa['innerHTML']=_0x4f4790['length']?_0x4f4790['filter'](_0x2c4e74=>{const _0x417af9=_0x2f4f5a==='server'?undefined:_0x545139['value'];return!state['teamBindings']['some'](_0x278398=>_0x278398['resource_type']===_0x2f4f5a&&_0x278398['role_id']===_0x2c4e74['id']&&(_0x2f4f5a==='server'||_0x278398['resource_id']===_0x417af9));})['map'](_0x522f9e=>'<option\x20value=\x22'+_0x522f9e['id']+'\x22>'+Utils['escapeHtml'](_0x522f9e['name'])+'</option>')['join']('')||'<option\x20value=\x22\x22>No\x20available\x20roles</option>':'<option\x20value=\x22\x22>No\x20roles\x20for\x20this\x20resource\x20type</option>';}async function saveBinding(){const _0x4b8f20=document['getElementById']('binding-resource-type')['value'],_0x5d6071=document['getElementById']('binding-role')['value'];if(!_0x5d6071||!state['bindingsTeamId'])return;const _0x395045=_0x4b8f20==='server'?undefined:document['getElementById']('binding-resource')['value'];if(_0x4b8f20!=='server'&&!_0x395045)return;const _0x3c0b68=document['getElementById']('save-binding-btn');_0x3c0b68['disabled']=!![],_0x3c0b68['textContent']='Adding…';try{const _0xb7f05f={'subject_type':'team','subject_id':state['bindingsTeamId'],'role_id':_0x5d6071,'resource_type':_0x4b8f20};if(_0x395045)_0xb7f05f['resource_id']=_0x395045;await API['createBinding'](_0xb7f05f),Utils['showToast']('Binding\x20added','success'),document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![],await loadTeamBindings(state['bindingsTeamId']);}catch(_0x432807){Utils['showToast'](_0x432807['message'],'error');}finally{_0x3c0b68['disabled']=![],_0x3c0b68['textContent']='Add\x20Binding';}}window['deleteBindingClick']=async function(_0x11cf8d){try{await API['deleteBinding'](_0x11cf8d),Utils['showToast']('Binding\x20removed','success'),await loadTeamBindings(state['bindingsTeamId']);}catch(_0x50f8d8){Utils['showToast'](_0x50f8d8['message'],'error');}};async function saveTeam(){const _0x4c4956=document['getElementById']('team-name')['value']['trim'](),_0x54a85c=document['getElementById']('team-description')['value']['trim'](),_0x4c0506=document['getElementById']('team-form-error'),_0x346674=document['getElementById']('save-team');if(!_0x4c4956){_0x4c0506['textContent']='Team\x20name\x20is\x20required',_0x4c0506['hidden']=![];return;}_0x4c0506['hidden']=!![];const _0x5c18bf=_0x346674['textContent'];_0x346674['disabled']=!![],_0x346674['textContent']=state['editingTeamId']?'Saving…':'Creating…';try{if(state['editingTeamId']){const {team:_0x318209}=await API['updateTeam'](state['editingTeamId'],{'name':_0x4c4956,'description':_0x54a85c});syncTeamInState(_0x318209),document['getElementById']('team-modal-title')['textContent']=_0x318209['name'],Utils['showToast']('Team\x20updated','success');}else await API['createTeam']({'name':_0x4c4956,'description':_0x54a85c}),Utils['showToast']('Team\x20created','success');_0x346674['disabled']=![],_0x346674['textContent']=_0x5c18bf,hideTeamModal(),await loadTeams();}catch(_0x333571){_0x4c0506['textContent']=_0x333571['message'],_0x4c0506['hidden']=![],_0x346674['disabled']=![],_0x346674['textContent']=_0x5c18bf;}}window['deleteTeam']=function(_0x49db6c){const _0x50bcd6=state['teams']['find'](_0x524f4e=>_0x524f4e['id']===_0x49db6c);if(!_0x50bcd6)return;state['deletingTeamId']=_0x49db6c,document['getElementById']('delete-team-name')['textContent']=_0x50bcd6['name'],document['getElementById']('delete-team-modal')['hidden']=![];};function hideDeleteModal(){document['getElementById']('delete-team-modal')['hidden']=!![],state['deletingTeamId']=null;}async function confirmDeleteTeam(){if(!state['deletingTeamId'])return;const _0x486c6d=document['getElementById']('confirm-delete-team');_0x486c6d['disabled']=!![],_0x486c6d['textContent']='Deleting…';try{await API['deleteTeam'](state['deletingTeamId']),Utils['showToast']('Team\x20deleted','success'),_0x486c6d['disabled']=![],_0x486c6d['textContent']='Delete\x20Team',hideDeleteModal(),await loadTeams();}catch(_0x13e7fd){Utils['showToast']('Failed\x20to\x20delete\x20team:\x20'+_0x13e7fd['message'],'error'),_0x486c6d['disabled']=![],_0x486c6d['textContent']='Delete\x20Team';}}function syncTeamInState(_0xd3384f){const _0x33f370=state['teams']['findIndex'](_0x778522=>_0x778522['id']===_0xd3384f['id']);if(_0x33f370>=0x0)state['teams'][_0x33f370]=_0xd3384f;renderTeams();}
1
+ 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 _0x29322f=state['currentUser'];if(!Permissions['hasServerPermission'](_0x29322f,'teams:view')&&!Permissions['hasTeamPermission'](_0x29322f,'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'](_0x29322f,'*')||Permissions['hasTeamPermission'](_0x29322f,'teams:manage'))&&(document['getElementById']('create-team-btn')['hidden']=![]),bindEventListeners(),await Promise['all']([loadTeams(),loadUsers(),loadRoles(),loadEnvironments()]),renderTeams();});async function loadTeams(){const _0x713cc7=document['getElementById']('teams-loading'),_0x204b11=document['getElementById']('teams-error'),_0x1b3a31=document['getElementById']('teams-content');try{_0x713cc7['hidden']=![],_0x204b11['hidden']=!![],_0x1b3a31['hidden']=!![];const {teams:_0x10ac16}=await API['getTeams']();state['teams']=_0x10ac16||[],renderTeams(),_0x713cc7['hidden']=!![],_0x1b3a31['hidden']=![];}catch(_0x48ecaf){_0x713cc7['hidden']=!![],_0x204b11['hidden']=![],document['getElementById']('teams-error-message')['textContent']=_0x48ecaf['message'];}}async function loadUsers(){try{const {users:_0x3a7f9e}=await API['getUsers']();state['users']=_0x3a7f9e||[];}catch{state['users']=[];}}async function loadRoles(){try{const {roles:_0x510791}=await API['getRoleDefinitions']();state['roles']=_0x510791||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x4263bc=await API['getEnvironments']();state['environments']=_0x4263bc['environments']||[];}catch{state['environments']=[];}}function renderTeams(){const _0x5bcf9e=document['getElementById']('teams-table-body'),_0x5a1010=document['getElementById']('team-count');if(!_0x5bcf9e)return;_0x5a1010&&(_0x5a1010['textContent']=state['teams']['length']+'\x20team'+(state['teams']['length']===0x1?'':'s'));if(state['teams']['length']===0x0){_0x5bcf9e['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 _0x164663=Permissions['hasServerPermission'](state['currentUser'],'*');_0x5bcf9e['innerHTML']=state['teams']['map'](_0x113e24=>{const _0x5e36da=_0x164663||_0x113e24['canManageTeam'],_0x46312a=_0x164663||_0x113e24['canManageMembers'],_0x3ccbcb=_0x5e36da||_0x46312a,_0x43ce5a=(_0x113e24['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'](_0x113e24['name'])+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x113e24['description']?'<div\x20style=\x22font-size:\x200.8em;\x20color:\x20var(--color-text-secondary);\x20margin-top:\x200.15rem;\x22>'+Utils['escapeHtml'](_0x113e24['description'])+'</div>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+_0x43ce5a+'</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'+(_0x3ccbcb?'<button\x20class=\x22btn-icon\x22\x20title=\x22Edit\x20team\x22\x20onclick=\x22window.openTeamModal(\x27'+_0x113e24['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'+(_0x5e36da?'<button\x20class=\x22btn-icon\x22\x20title=\x22Access\x20bindings\x22\x20onclick=\x22window.openBindingsModal(\x27'+_0x113e24['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'+(_0x5e36da?'<button\x20class=\x22btn-icon\x20btn-danger\x22\x20title=\x22Delete\x20team\x22\x20onclick=\x22window.deleteTeam(\x27'+_0x113e24['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(_0x4f2c08){const _0x2b12c7=state['teams']['find'](_0x276d48=>_0x276d48['id']===_0x4f2c08);if(!_0x2b12c7)return;state['editingTeamId']=_0x4f2c08;const _0x208013=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x1c4db6=_0x208013||_0x2b12c7['canManageTeam'],_0x577f2d=_0x208013||_0x2b12c7['canManageMembers'],_0x19fab9=_0x1c4db6,_0x33bcba=_0x1c4db6||_0x577f2d,_0x41117c=_0x2b12c7['name'],_0x43f6ee=_0x2b12c7['description']||'';state['modalSnapshot']={'name':_0x41117c,'description':_0x43f6ee},document['getElementById']('team-modal-title')['textContent']=_0x41117c,document['getElementById']('team-name')['value']=_0x41117c,document['getElementById']('team-name')['disabled']=!_0x19fab9,document['getElementById']('team-description')['value']=_0x43f6ee,document['getElementById']('team-description')['disabled']=!_0x19fab9,document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=![],document['getElementById']('save-team')['hidden']=!_0x19fab9,renderMembersList(_0x2b12c7),updateMemberSelect(_0x2b12c7),document['getElementById']('team-modal')['hidden']=![];};function isTeamModalDirty(){if(!state['modalSnapshot'])return![];const _0x5e2825=document['getElementById']('team-name')['value']['trim'](),_0x32cdb7=document['getElementById']('team-description')['value']['trim']();return _0x5e2825!==state['modalSnapshot']['name']||_0x32cdb7!==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(_0x4c5d4e){const _0x5cfa12=state['teams']['find'](_0x2a7a91=>_0x2a7a91['id']===_0x4c5d4e);if(!_0x5cfa12)return;state['bindingsTeamId']=_0x4c5d4e,document['getElementById']('bindings-modal-title')['textContent']='Access\x20Bindings\x20—\x20'+_0x5cfa12['name'],document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('bindings-modal')['hidden']=![],loadTeamBindings(_0x4c5d4e);};function hideBindingsModal(){document['getElementById']('bindings-modal')['hidden']=!![],state['bindingsTeamId']=null;}function renderMembersList(_0x33e76a){const _0x3ba37a=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x5c7f99=_0x3ba37a||_0x33e76a['canManageMembers']||_0x33e76a['canManageTeam'],_0x9ef9df=_0x33e76a['members']||[],_0x372285=document['getElementById']('members-list');if(_0x9ef9df['length']===0x0){_0x372285['innerHTML']='<p\x20style=\x22font-size:\x200.875rem;\x20color:\x20var(--color-text-secondary);\x20margin:\x200.25rem\x200;\x22>No\x20members\x20yet</p>';return;}_0x372285['innerHTML']=_0x9ef9df['map'](_0x2d6ab1=>{const _0x119214=state['users']['find'](_0x212ef8=>_0x212ef8['id']===_0x2d6ab1),_0x432f=_0x119214?''+Utils['escapeHtml'](_0x119214['username'])+(_0x119214['name']?'\x20<span\x20style=\x22color:\x20var(--color-text-secondary);\x20font-size:\x200.85em;\x22>('+Utils['escapeHtml'](_0x119214['name'])+')</span>':''):Utils['escapeHtml'](_0x2d6ab1);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'+_0x432f+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x5c7f99?'<button\x20type=\x22button\x22\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.removeMemberClick(\x27'+_0x2d6ab1+'\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 _0x25721d=document['getElementById']('add-member-row');if(_0x25721d)_0x25721d['style']['display']=_0x5c7f99?'flex':'none';}function updateMemberSelect(_0x15c47f){const _0x644889=document['getElementById']('add-member-select');if(!_0x644889)return;const _0x22d138=new Set(_0x15c47f['members']||[]),_0x380948=state['users']['filter'](_0x57be4b=>!_0x22d138['has'](_0x57be4b['id']));_0x644889['innerHTML']='<option\x20value=\x22\x22>Add\x20a\x20member…</option>'+_0x380948['map'](_0x182d80=>'<option\x20value=\x22'+_0x182d80['id']+'\x22>'+Utils['escapeHtml'](_0x182d80['username'])+(_0x182d80['name']?'\x20('+Utils['escapeHtml'](_0x182d80['name'])+')':'')+'</option>')['join']('');}async function addMember(){const _0x457a43=document['getElementById']('add-member-select'),_0x33f31d=_0x457a43['value'];if(!_0x33f31d||!state['editingTeamId'])return;try{const {team:_0x5a59fb}=await API['addTeamMember'](state['editingTeamId'],_0x33f31d);syncTeamInState(_0x5a59fb),renderMembersList(_0x5a59fb),updateMemberSelect(_0x5a59fb),_0x457a43['value']='',Utils['showToast']('Member\x20added','success');}catch(_0x38508a){Utils['showToast'](_0x38508a['message'],'error');}}window['removeMemberClick']=async function(_0x283c2f){if(!state['editingTeamId'])return;try{const {team:_0x15f413}=await API['removeTeamMember'](state['editingTeamId'],_0x283c2f);syncTeamInState(_0x15f413),renderMembersList(_0x15f413),updateMemberSelect(_0x15f413),Utils['showToast']('Member\x20removed','success');}catch(_0x435f9c){Utils['showToast'](_0x435f9c['message'],'error');}};async function loadTeamBindings(_0x185c98){const _0x1e80ca=document['getElementById']('bindings-loading'),_0x44b32c=document['getElementById']('bindings-empty'),_0x14493a=document['getElementById']('bindings-list-container'),_0x20b2d1=document['getElementById']('add-binding-btn');_0x1e80ca['hidden']=![],_0x44b32c['hidden']=!![],_0x14493a['style']['display']='none',_0x20b2d1['hidden']=!![],document['getElementById']('add-binding-form')['hidden']=!![];try{const {bindings:_0x25fe4f}=await API['getBindings']({'subject_type':'team','subject_id':_0x185c98});state['teamBindings']=_0x25fe4f||[],_0x1e80ca['hidden']=!![],state['teamBindings']['length']===0x0?_0x44b32c['hidden']=![]:(_0x14493a['style']['display']='',renderBindingsTable()),(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage'))&&(_0x20b2d1['hidden']=![]);}catch(_0x4bfdbb){_0x1e80ca['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x4bfdbb['message'],'error');}}function renderBindingsTable(){const _0x512fa9=document['getElementById']('bindings-table-body');if(!_0x512fa9)return;const _0x954473=Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage');_0x512fa9['innerHTML']=state['teamBindings']['map'](_0x158f6c=>{const _0x5edeaa=_0x158f6c['resource_type']==='server'?'Server':_0x158f6c['resource_id']==='*'?'All\x20'+_0x158f6c['resource_type']+'s':Utils['escapeHtml'](_0x158f6c['resource_name']||_0x158f6c['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x5edeaa+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x158f6c['role_name']||_0x158f6c['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x954473?'<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteBindingClick(\x27'+_0x158f6c['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 _0x4bb5e4=document['getElementById']('binding-resource-type');_0x4bb5e4['value']='environment',updateBindingFormForResourceType('environment');}function onBindingResourceTypeChange(){const _0x23c7cd=document['getElementById']('binding-resource-type')['value'];updateBindingFormForResourceType(_0x23c7cd);}function updateBindingFormForResourceType(_0x3408da){const _0x4ab06f=document['getElementById']('binding-resource-container'),_0x12a0b7=document['getElementById']('binding-resource'),_0x2b05da=document['getElementById']('binding-role');if(_0x3408da==='server')_0x4ab06f['style']['display']='none';else{_0x4ab06f['style']['display']='';if(_0x3408da==='environment'){const _0x221ca2=new Set(state['teamBindings']['filter'](_0x2073bd=>_0x2073bd['resource_type']==='environment')['map'](_0x1b6f55=>_0x1b6f55['resource_id'])),_0x4b9505=state['environments']['filter'](_0x44c025=>!_0x221ca2['has'](_0x44c025['name']));_0x12a0b7['innerHTML']=_0x4b9505['length']?_0x4b9505['map'](_0x35ce42=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x35ce42['name'])+'\x22>'+Utils['escapeHtml'](_0x35ce42['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x3408da==='team'){const _0x5e5c65=new Set(state['teamBindings']['filter'](_0x470e74=>_0x470e74['resource_type']==='team')['map'](_0x4102c4=>_0x4102c4['resource_id'])),_0x4dc35c=state['teams']['filter'](_0x17f750=>!_0x5e5c65['has'](_0x17f750['id']));_0x12a0b7['innerHTML']=_0x4dc35c['length']?_0x4dc35c['map'](_0x2cd5d8=>'<option\x20value=\x22'+_0x2cd5d8['id']+'\x22>'+Utils['escapeHtml'](_0x2cd5d8['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x3816e8=state['roles']['filter'](_0x4963ae=>_0x4963ae['resource_type']===_0x3408da);_0x2b05da['innerHTML']=_0x3816e8['length']?_0x3816e8['filter'](_0x13ccac=>{const _0x1f1c2d=_0x3408da==='server'?undefined:_0x12a0b7['value'];return!state['teamBindings']['some'](_0x39f258=>_0x39f258['resource_type']===_0x3408da&&_0x39f258['role_id']===_0x13ccac['id']&&(_0x3408da==='server'||_0x39f258['resource_id']===_0x1f1c2d));})['map'](_0x24455b=>'<option\x20value=\x22'+_0x24455b['id']+'\x22>'+Utils['escapeHtml'](_0x24455b['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 _0x514483=document['getElementById']('binding-resource-type')['value'],_0xc6cbfd=document['getElementById']('binding-role')['value'];if(!_0xc6cbfd||!state['bindingsTeamId'])return;const _0xadcb3d=_0x514483==='server'?undefined:document['getElementById']('binding-resource')['value'];if(_0x514483!=='server'&&!_0xadcb3d)return;const _0x4b0361=document['getElementById']('save-binding-btn');_0x4b0361['disabled']=!![],_0x4b0361['textContent']='Adding…';try{const _0x510dd4={'subject_type':'team','subject_id':state['bindingsTeamId'],'role_id':_0xc6cbfd,'resource_type':_0x514483};if(_0xadcb3d)_0x510dd4['resource_id']=_0xadcb3d;await API['createBinding'](_0x510dd4),Utils['showToast']('Binding\x20added','success'),document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![],await loadTeamBindings(state['bindingsTeamId']);}catch(_0x42745a){Utils['showToast'](_0x42745a['message'],'error');}finally{_0x4b0361['disabled']=![],_0x4b0361['textContent']='Add\x20Binding';}}window['deleteBindingClick']=async function(_0x3db02b){try{await API['deleteBinding'](_0x3db02b),Utils['showToast']('Binding\x20removed','success'),await loadTeamBindings(state['bindingsTeamId']);}catch(_0x5df5f5){Utils['showToast'](_0x5df5f5['message'],'error');}};async function saveTeam(){const _0x184158=document['getElementById']('team-name')['value']['trim'](),_0x28889c=document['getElementById']('team-description')['value']['trim'](),_0x145baf=document['getElementById']('team-form-error'),_0x5893df=document['getElementById']('save-team');if(!_0x184158){_0x145baf['textContent']='Team\x20name\x20is\x20required',_0x145baf['hidden']=![];return;}_0x145baf['hidden']=!![];const _0x3b775d=_0x5893df['textContent'];_0x5893df['disabled']=!![],_0x5893df['textContent']=state['editingTeamId']?'Saving…':'Creating…';try{if(state['editingTeamId']){const {team:_0x54c2de}=await API['updateTeam'](state['editingTeamId'],{'name':_0x184158,'description':_0x28889c});syncTeamInState(_0x54c2de),document['getElementById']('team-modal-title')['textContent']=_0x54c2de['name'],Utils['showToast']('Team\x20updated','success');}else await API['createTeam']({'name':_0x184158,'description':_0x28889c}),Utils['showToast']('Team\x20created','success');_0x5893df['disabled']=![],_0x5893df['textContent']=_0x3b775d,hideTeamModal(),await loadTeams();}catch(_0x41a300){_0x145baf['textContent']=_0x41a300['message'],_0x145baf['hidden']=![],_0x5893df['disabled']=![],_0x5893df['textContent']=_0x3b775d;}}window['deleteTeam']=function(_0x4b47b4){const _0x199cb4=state['teams']['find'](_0x52df32=>_0x52df32['id']===_0x4b47b4);if(!_0x199cb4)return;state['deletingTeamId']=_0x4b47b4,document['getElementById']('delete-team-name')['textContent']=_0x199cb4['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 _0x41c2c3=document['getElementById']('confirm-delete-team');_0x41c2c3['disabled']=!![],_0x41c2c3['textContent']='Deleting…';try{await API['deleteTeam'](state['deletingTeamId']),Utils['showToast']('Team\x20deleted','success'),_0x41c2c3['disabled']=![],_0x41c2c3['textContent']='Delete\x20Team',hideDeleteModal(),await loadTeams();}catch(_0x826df0){Utils['showToast']('Failed\x20to\x20delete\x20team:\x20'+_0x826df0['message'],'error'),_0x41c2c3['disabled']=![],_0x41c2c3['textContent']='Delete\x20Team';}}function syncTeamInState(_0x458b76){const _0x37c7e9=state['teams']['findIndex'](_0x9654f=>_0x9654f['id']===_0x458b76['id']);if(_0x37c7e9>=0x0)state['teams'][_0x37c7e9]=_0x458b76;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'](_0x1d42fe=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':_0x1d42fe}));});let commandSent=![],hasReceivedOutput=![];socket['addEventListener']('message',_0x34f9ca=>{try{const _0x2fba9a=JSON['parse'](_0x34f9ca['data']);if(_0x2fba9a['type']==='data'&&typeof _0x2fba9a['data']==='string')term['write'](_0x2fba9a['data']),!hasReceivedOutput&&_0x2fba9a['data']['length']>0x0&&(hasReceivedOutput=!![],command&&!useServerExec&&!commandSent&&(commandSent=!![],setTimeout(()=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':command+'\x0d'}));},0xc8)));else{if(_0x2fba9a['type']==='status'&&_0x2fba9a['status']){if(_0x2fba9a['status']==='connected'){if(command&&useServerExec)updateStatus('Running:\x20'+command,'info');else command?updateStatus('Preparing:\x20'+command,'info'):updateStatus('Terminal\x20connected','success');doFit(),term['focus'](),command&&!useServerExec&&!commandSent&&setTimeout(()=>{!commandSent&&socket['readyState']===WebSocket['OPEN']&&(commandSent=!![],socket['send'](JSON['stringify']({'type':'data','data':command+'\x0d'})),updateStatus('Running:\x20'+command,'info'));},0x7d0);}else updateStatus('Session\x20'+_0x2fba9a['status'],_0x2fba9a['status']==='connected'?'success':'info');}else _0x2fba9a['type']==='error'&&_0x2fba9a['message']&&updateStatus(_0x2fba9a['message'],'error');}}catch(_0x477b9f){console['error']('Failed\x20to\x20parse\x20terminal\x20message',_0x477b9f);}}),socket['addEventListener']('close',_0x36f3bf=>{const _0x2a390a=_0x36f3bf['reason']||'Connection\x20closed';updateStatus(_0x2a390a,_0x36f3bf['wasClean']?'info':'error'),isEmbedded&&terminalTabId&&window['parent']&&window['parent']!==window&&window['parent']['postMessage']({'type':'coderflow-terminal-disconnected','tabId':terminalTabId},window['location']['origin']);}),socket['addEventListener']('error',_0x28a65f=>{console['error']('Terminal\x20websocket\x20error',_0x28a65f),updateStatus('Connection\x20error','error');});function sendResize(){if(socket['readyState']!==WebSocket['OPEN'])return;const _0x3293f1=term['cols'],_0x5a5530=term['rows'];socket['send'](JSON['stringify']({'type':'resize','cols':_0x3293f1,'rows':_0x5a5530}));}function updateStatus(_0x2ea623,_0x2bac3a='info'){if(!statusEl)return;statusEl['textContent']=_0x2ea623,statusEl['dataset']['variant']=_0x2bac3a;}async function enrichContainerDetails(_0xdadef2){try{const _0x2322a4=await API['getContainer'](_0xdadef2);updateTerminalDetails(_0x2322a4);}catch{try{const _0x3fd649=await API['getContainers'](),_0x160dd6=(_0x3fd649['containers']||[])['find'](_0x51bd64=>_0x51bd64['containerId']===_0xdadef2||_0x51bd64['name']===_0xdadef2||_0x51bd64['fullContainerId']?.['startsWith'](_0xdadef2));if(_0x160dd6){updateTerminalDetails(_0x160dd6);return;}subtitleEl['textContent']='Container\x20'+_0xdadef2['substring'](0x0,0xc);}catch{subtitleEl['textContent']='Container\x20'+_0xdadef2['substring'](0x0,0xc);}}}function updateTerminalDetails(_0x1be82b){const _0x557449=_0x1be82b['containerId']||_0x1be82b['name']||_0x1be82b['fullContainerId']||containerId,_0x9b5fc6=_0x1be82b['environment']?'Environment\x20'+_0x1be82b['environment']:'Environment\x20unknown',_0x3f35b5=_0x1be82b['defaultAgent']?'\x20·\x20Agent\x20'+_0x1be82b['defaultAgent']:'',_0xa6b8a5=_0x1be82b['createdAt']?'\x20·\x20Started\x20'+Utils['formatRelativeTime'](_0x1be82b['createdAt']):'';titleEl['textContent']='Terminal\x20·\x20'+_0x557449['substring'](0x0,0xc);const _0x4e65c2=command?'\x20·\x20Command\x20'+command:'';subtitleEl['textContent']=''+_0x9b5fc6+_0x3f35b5+_0xa6b8a5+_0x4e65c2;}
1
+ 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'](_0x12c61d=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':_0x12c61d}));});let commandSent=![],hasReceivedOutput=![];socket['addEventListener']('message',_0x567494=>{try{const _0x202fe7=JSON['parse'](_0x567494['data']);if(_0x202fe7['type']==='data'&&typeof _0x202fe7['data']==='string')term['write'](_0x202fe7['data']),!hasReceivedOutput&&_0x202fe7['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(_0x202fe7['type']==='status'&&_0x202fe7['status']){if(_0x202fe7['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'+_0x202fe7['status'],_0x202fe7['status']==='connected'?'success':'info');}else _0x202fe7['type']==='error'&&_0x202fe7['message']&&updateStatus(_0x202fe7['message'],'error');}}catch(_0x2e7b7f){console['error']('Failed\x20to\x20parse\x20terminal\x20message',_0x2e7b7f);}}),socket['addEventListener']('close',_0xbdb837=>{const _0x496046=_0xbdb837['reason']||'Connection\x20closed';updateStatus(_0x496046,_0xbdb837['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',_0x20b611=>{console['error']('Terminal\x20websocket\x20error',_0x20b611),updateStatus('Connection\x20error','error');});function sendResize(){if(socket['readyState']!==WebSocket['OPEN'])return;const _0x28eeaa=term['cols'],_0x102fb3=term['rows'];socket['send'](JSON['stringify']({'type':'resize','cols':_0x28eeaa,'rows':_0x102fb3}));}function updateStatus(_0x3d5a54,_0x415b0e='info'){if(!statusEl)return;statusEl['textContent']=_0x3d5a54,statusEl['dataset']['variant']=_0x415b0e;}async function enrichContainerDetails(_0x203233){try{const _0x3e19f4=await API['getContainer'](_0x203233);updateTerminalDetails(_0x3e19f4);}catch{try{const _0x56c3f3=await API['getContainers'](),_0x2b7a2e=(_0x56c3f3['containers']||[])['find'](_0x388b9d=>_0x388b9d['containerId']===_0x203233||_0x388b9d['name']===_0x203233||_0x388b9d['fullContainerId']?.['startsWith'](_0x203233));if(_0x2b7a2e){updateTerminalDetails(_0x2b7a2e);return;}subtitleEl['textContent']='Container\x20'+_0x203233['substring'](0x0,0xc);}catch{subtitleEl['textContent']='Container\x20'+_0x203233['substring'](0x0,0xc);}}}function updateTerminalDetails(_0x1e9188){const _0x1af8b4=_0x1e9188['containerId']||_0x1e9188['name']||_0x1e9188['fullContainerId']||containerId,_0x22367b=_0x1e9188['environment']?'Environment\x20'+_0x1e9188['environment']:'Environment\x20unknown',_0x5366dc=_0x1e9188['defaultAgent']?'\x20·\x20Agent\x20'+_0x1e9188['defaultAgent']:'',_0x8a07e0=_0x1e9188['createdAt']?'\x20·\x20Started\x20'+Utils['formatRelativeTime'](_0x1e9188['createdAt']):'';titleEl['textContent']='Terminal\x20·\x20'+_0x1af8b4['substring'](0x0,0xc);const _0x5f4693=command?'\x20·\x20Command\x20'+command:'';subtitleEl['textContent']=''+_0x22367b+_0x5366dc+_0x8a07e0+_0x5f4693;}
@@ -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 _0x4fbfc=localStorage['getItem'](THEME_STORAGE_KEY);if(_0x4fbfc&&VALID_THEMES['has'](_0x4fbfc))return _0x4fbfc;}catch(_0x1eef92){console['warn']('[Theme]\x20Failed\x20to\x20read\x20stored\x20theme\x20preference:',_0x1eef92);}return null;}export function getPreferredTheme(){const _0x690d1b=readStoredTheme();if(_0x690d1b)return _0x690d1b;const _0x4d6c87=window['matchMedia']&&window['matchMedia']('(prefers-color-scheme:\x20dark)')['matches'];return _0x4d6c87?'dark':'light';}export function getCurrentTheme(){const _0x121f71=document['documentElement']['dataset']['theme'];if(_0x121f71&&VALID_THEMES['has'](_0x121f71))return _0x121f71;return getPreferredTheme();}export function applyTheme(_0x24dfc2,{persist:persist=!![],emitEvent:emitEvent=!![]}={}){const _0xafe2d1=VALID_THEMES['has'](_0x24dfc2)?_0x24dfc2:'light';document['documentElement']['dataset']['theme']=_0xafe2d1,document['documentElement']['style']['colorScheme']=_0xafe2d1==='dark'?'dark':'light';if(persist)try{localStorage['setItem'](THEME_STORAGE_KEY,_0xafe2d1);}catch(_0x1213f7){console['warn']('[Theme]\x20Failed\x20to\x20persist\x20theme\x20preference:',_0x1213f7);}return emitEvent&&window['dispatchEvent'](new CustomEvent(THEME_CHANGE_EVENT,{'detail':{'theme':_0xafe2d1}})),_0xafe2d1;}export function initTheme(_0x200e4b={}){const {emitEvent:emitEvent=![]}=_0x200e4b;return applyTheme(getPreferredTheme(),{'persist':![],'emitEvent':emitEvent});}export function toggleTheme(){const _0x229bbb=getCurrentTheme()==='dark'?'light':'dark';return applyTheme(_0x229bbb);}export function onThemeChange(_0x11f802,{runImmediately:runImmediately=![]}={}){const _0x2ab37d=_0x321caf=>{_0x11f802(_0x321caf['detail']['theme']);};return window['addEventListener'](THEME_CHANGE_EVENT,_0x2ab37d),runImmediately&&_0x11f802(getCurrentTheme()),()=>window['removeEventListener'](THEME_CHANGE_EVENT,_0x2ab37d);}export function mountThemeToggle(_0x2d5fb5={}){const {targetSelectors:targetSelectors=DEFAULT_TARGET_SELECTORS}=_0x2d5fb5,_0x3c0aa5=targetSelectors['map'](_0x3a886e=>document['querySelector'](_0x3a886e))['find'](Boolean),_0x2443d3=document['createElement']('button');_0x2443d3['type']='button',_0x2443d3['className']='btn-ghost\x20theme-toggle-btn',_0x2443d3['id']='theme-toggle-btn',_0x2443d3['setAttribute']('aria-pressed','false'),_0x2443d3['style']['padding']='8px',_0x2443d3['style']['lineHeight']='0',_0x2443d3['style']['width']='36px',_0x2443d3['style']['height']='36px',_0x2443d3['style']['display']='flex',_0x2443d3['style']['alignItems']='center',_0x2443d3['style']['justifyContent']='center';const _0x252205=document['createElement']('span');_0x252205['className']='theme-icon',_0x252205['style']['display']='flex',_0x2443d3['append'](_0x252205);const _0x21c631='<svg\x20xmlns=\x22http://www.w3.org/2000/svg\x22\x20width=\x2220\x22\x20height=\x2220\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22><path\x20d=\x22M21\x2012.79A9\x209\x200\x201\x201\x2011.21\x203\x207\x207\x200\x200\x200\x2021\x2012.79z\x22></path></svg>',_0x532d0f='<svg\x20xmlns=\x22http://www.w3.org/2000/svg\x22\x20width=\x2220\x22\x20height=\x2220\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22><circle\x20cx=\x2212\x22\x20cy=\x2212\x22\x20r=\x225\x22></circle><line\x20x1=\x2212\x22\x20y1=\x221\x22\x20x2=\x2212\x22\x20y2=\x223\x22></line><line\x20x1=\x2212\x22\x20y1=\x2221\x22\x20x2=\x2212\x22\x20y2=\x2223\x22></line><line\x20x1=\x224.22\x22\x20y1=\x224.22\x22\x20x2=\x225.64\x22\x20y2=\x225.64\x22></line><line\x20x1=\x2218.36\x22\x20y1=\x2218.36\x22\x20x2=\x2219.78\x22\x20y2=\x2219.78\x22></line><line\x20x1=\x221\x22\x20y1=\x2212\x22\x20x2=\x223\x22\x20y2=\x2212\x22></line><line\x20x1=\x2221\x22\x20y1=\x2212\x22\x20x2=\x2223\x22\x20y2=\x2212\x22></line><line\x20x1=\x224.22\x22\x20y1=\x2219.78\x22\x20x2=\x225.64\x22\x20y2=\x2218.36\x22></line><line\x20x1=\x2218.36\x22\x20y1=\x225.64\x22\x20x2=\x2219.78\x22\x20y2=\x224.22\x22></line></svg>',_0x10a915=_0x3b40ed=>{const _0x5592ed=_0x3b40ed==='dark';_0x252205['innerHTML']=_0x5592ed?_0x21c631:_0x532d0f,_0x2443d3['title']=_0x5592ed?'Switch\x20to\x20light\x20mode':'Switch\x20to\x20dark\x20mode',_0x2443d3['dataset']['theme']=_0x3b40ed,_0x2443d3['setAttribute']('aria-pressed',String(_0x5592ed));};return _0x2443d3['addEventListener']('click',()=>{const _0x46d1a6=getCurrentTheme()==='dark'?'light':'dark';applyTheme(_0x46d1a6);}),_0x3c0aa5?_0x3c0aa5['appendChild'](_0x2443d3):(_0x2443d3['classList']['add']('theme-toggle-floating'),document['body']['appendChild'](_0x2443d3)),_0x10a915(initTheme()),onThemeChange(_0x10a915),_0x2443d3;}export{THEME_STORAGE_KEY,THEME_CHANGE_EVENT};
1
+ 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 _0x2db310=localStorage['getItem'](THEME_STORAGE_KEY);if(_0x2db310&&VALID_THEMES['has'](_0x2db310))return _0x2db310;}catch(_0x59f3f5){console['warn']('[Theme]\x20Failed\x20to\x20read\x20stored\x20theme\x20preference:',_0x59f3f5);}return null;}export function getPreferredTheme(){const _0x561d98=readStoredTheme();if(_0x561d98)return _0x561d98;const _0x37bab3=window['matchMedia']&&window['matchMedia']('(prefers-color-scheme:\x20dark)')['matches'];return _0x37bab3?'dark':'light';}export function getCurrentTheme(){const _0x178f0a=document['documentElement']['dataset']['theme'];if(_0x178f0a&&VALID_THEMES['has'](_0x178f0a))return _0x178f0a;return getPreferredTheme();}export function applyTheme(_0x59a58a,{persist:persist=!![],emitEvent:emitEvent=!![]}={}){const _0x3d7ee6=VALID_THEMES['has'](_0x59a58a)?_0x59a58a:'light';document['documentElement']['dataset']['theme']=_0x3d7ee6,document['documentElement']['style']['colorScheme']=_0x3d7ee6==='dark'?'dark':'light';if(persist)try{localStorage['setItem'](THEME_STORAGE_KEY,_0x3d7ee6);}catch(_0x54a623){console['warn']('[Theme]\x20Failed\x20to\x20persist\x20theme\x20preference:',_0x54a623);}return emitEvent&&window['dispatchEvent'](new CustomEvent(THEME_CHANGE_EVENT,{'detail':{'theme':_0x3d7ee6}})),_0x3d7ee6;}export function initTheme(_0x278a85={}){const {emitEvent:emitEvent=![]}=_0x278a85;return applyTheme(getPreferredTheme(),{'persist':![],'emitEvent':emitEvent});}export function toggleTheme(){const _0x2df76d=getCurrentTheme()==='dark'?'light':'dark';return applyTheme(_0x2df76d);}export function onThemeChange(_0xa0f2bb,{runImmediately:runImmediately=![]}={}){const _0x1bb241=_0x3125a7=>{_0xa0f2bb(_0x3125a7['detail']['theme']);};return window['addEventListener'](THEME_CHANGE_EVENT,_0x1bb241),runImmediately&&_0xa0f2bb(getCurrentTheme()),()=>window['removeEventListener'](THEME_CHANGE_EVENT,_0x1bb241);}export function mountThemeToggle(_0x3b9e74={}){const {targetSelectors:targetSelectors=DEFAULT_TARGET_SELECTORS}=_0x3b9e74,_0x594df4=targetSelectors['map'](_0x274e35=>document['querySelector'](_0x274e35))['find'](Boolean),_0x3b007a=document['createElement']('button');_0x3b007a['type']='button',_0x3b007a['className']='btn-ghost\x20theme-toggle-btn',_0x3b007a['id']='theme-toggle-btn',_0x3b007a['setAttribute']('aria-pressed','false'),_0x3b007a['style']['padding']='8px',_0x3b007a['style']['lineHeight']='0',_0x3b007a['style']['width']='36px',_0x3b007a['style']['height']='36px',_0x3b007a['style']['display']='flex',_0x3b007a['style']['alignItems']='center',_0x3b007a['style']['justifyContent']='center';const _0x508435=document['createElement']('span');_0x508435['className']='theme-icon',_0x508435['style']['display']='flex',_0x3b007a['append'](_0x508435);const _0x599ef2='<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>',_0x15cf10='<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>',_0x42523e=_0x32596d=>{const _0x598595=_0x32596d==='dark';_0x508435['innerHTML']=_0x598595?_0x599ef2:_0x15cf10,_0x3b007a['title']=_0x598595?'Switch\x20to\x20light\x20mode':'Switch\x20to\x20dark\x20mode',_0x3b007a['dataset']['theme']=_0x32596d,_0x3b007a['setAttribute']('aria-pressed',String(_0x598595));};return _0x3b007a['addEventListener']('click',()=>{const _0x5dd7de=getCurrentTheme()==='dark'?'light':'dark';applyTheme(_0x5dd7de);}),_0x594df4?_0x594df4['appendChild'](_0x3b007a):(_0x3b007a['classList']['add']('theme-toggle-floating'),document['body']['appendChild'](_0x3b007a)),_0x42523e(initTheme()),onThemeChange(_0x42523e),_0x3b007a;}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 _0xa8039a=await API['getCurrentUser']();state['currentUser']=_0xa8039a;if(!Permissions['hasServerPermission'](_0xa8039a,'*')&&!Permissions['hasServerPermission'](_0xa8039a,'users:create')){Utils['showToast']('Access\x20denied:\x20Server\x20admin\x20privileges\x20required','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}}catch(_0x55190d){window['location']['href']='login.html';}}async function checkEmailConfig(){try{const _0x348d5d=await API['getEmailConfig']();state['emailConfigured']=_0x348d5d['configured'];}catch(_0x4d5d1b){console['error']('Failed\x20to\x20check\x20email\x20config',_0x4d5d1b),state['emailConfigured']=![];}}async function loadRoles(){try{const {roles:_0x5dff49}=await API['getRoleDefinitions']();state['roles']=_0x5dff49||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x3c9959=await API['getEnvironments']();state['environments']=_0x3c9959['environments']||[];}catch{state['environments']=[];}}async function loadTeams(){try{const {teams:_0x432780}=await API['getTeams']();state['teams']=_0x432780||[];}catch{state['teams']=[];}}function bindEventListeners(){document['getElementById']('create-user-btn')?.['addEventListener']('click',showCreateUserModal),document['getElementById']('close-user-modal')?.['addEventListener']('click',hideUserModal),document['getElementById']('cancel-user')?.['addEventListener']('click',hideUserModal),document['getElementById']('save-user')?.['addEventListener']('click',saveUser),document['querySelector']('#user-modal\x20.modal-overlay')?.['addEventListener']('click',hideUserModal),document['getElementById']('close-delete-modal')?.['addEventListener']('click',hideDeleteModal),document['getElementById']('cancel-delete')?.['addEventListener']('click',hideDeleteModal),document['getElementById']('confirm-delete')?.['addEventListener']('click',confirmDeleteUser),document['querySelector']('#delete-modal\x20.modal-overlay')?.['addEventListener']('click',hideDeleteModal),document['getElementById']('close-setup-link-modal')?.['addEventListener']('click',hideSetupLinkModal),document['getElementById']('close-setup-link')?.['addEventListener']('click',hideSetupLinkModal),document['getElementById']('copy-setup-link')?.['addEventListener']('click',copySetupLink),document['getElementById']('email-setup-link')?.['addEventListener']('click',emailSetupLink),document['querySelector']('#setup-link-modal\x20.modal-overlay')?.['addEventListener']('click',hideSetupLinkModal),document['getElementById']('skip-password')?.['addEventListener']('change',handleSkipPasswordChange),document['getElementById']('retry-users-btn')?.['addEventListener']('click',loadUsers),document['getElementById']('close-bindings-modal')?.['addEventListener']('click',hideAccessBindingsModal),document['getElementById']('close-bindings-modal-footer')?.['addEventListener']('click',hideAccessBindingsModal),document['querySelector']('#bindings-modal\x20.modal-overlay')?.['addEventListener']('click',hideAccessBindingsModal),document['getElementById']('add-user-binding-btn')?.['addEventListener']('click',()=>{document['getElementById']('add-user-binding-form')['hidden']=![],document['getElementById']('add-user-binding-btn')['hidden']=!![],populateUserBindingForm();}),document['getElementById']('cancel-user-binding-btn')?.['addEventListener']('click',()=>{document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![];}),document['getElementById']('save-user-binding-btn')?.['addEventListener']('click',saveUserBinding),document['getElementById']('user-binding-resource-type')?.['addEventListener']('change',onUserBindingResourceTypeChange);}async function loadUsers(){const _0x3695f5=document['getElementById']('users-loading'),_0x2833ff=document['getElementById']('users-error'),_0x60b212=document['getElementById']('users-content');try{_0x3695f5['hidden']=![],_0x2833ff['hidden']=!![],_0x60b212['hidden']=!![];const _0x14ff5c=await API['getUsers']();state['users']=_0x14ff5c['users']||[],renderUsers(),_0x3695f5['hidden']=!![],_0x60b212['hidden']=![];}catch(_0x266704){console['error']('Failed\x20to\x20load\x20users',_0x266704),_0x3695f5['hidden']=!![],_0x2833ff['hidden']=![],document['getElementById']('users-error-message')['textContent']=_0x266704['message'];}}function renderUsers(){const _0x295823=document['getElementById']('users-table-body'),_0x598723=document['getElementById']('user-count');if(!_0x295823)return;_0x598723&&(_0x598723['textContent']=state['users']['length']+'\x20user'+(state['users']['length']===0x1?'':'s'));const _0x1bc13e=[...state['users']]['sort']((_0x4b320f,_0x40fccd)=>{const _0x2d261e=new Date(_0x4b320f['created_at'])['getTime'](),_0x194808=new Date(_0x40fccd['created_at'])['getTime']();return _0x194808-_0x2d261e;});_0x295823['innerHTML']=_0x1bc13e['map'](_0x5f5ae3=>'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22user-username\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+Utils['escapeHtml'](_0x5f5ae3['username'])+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x5f5ae3['name'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x5f5ae3['email'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22access-badges\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x5f5ae3['isServerAdmin']?'<span\x20class=\x22role-badge\x20role-admin\x22>Server\x20Admin</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x5f5ae3['hasUserBinding']?'<span\x20class=\x22role-badge\x20role-user-binding\x22>User\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x5f5ae3['hasTeamBinding']?'<span\x20class=\x22role-badge\x20role-team-binding\x22>Team\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['formatRelativeTime'](_0x5f5ae3['created_at'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22user-actions\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-icon\x20btn-small\x22\x20onclick=\x22window.editUser(\x27'+_0x5f5ae3['id']+'\x27)\x22\x20title=\x22Edit\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2214\x22\x20height=\x2214\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M11\x204H4a2\x202\x200\x200\x200-2\x202v14a2\x202\x200\x200\x200\x202\x202h14a2\x202\x200\x200\x200\x202-2v-7\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M18.5\x202.5a2.121\x202.121\x200\x200\x201\x203\x203L12\x2015l-4\x201\x201-4\x209.5-9.5z\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-icon\x20btn-small\x22\x20onclick=\x22window.showAccessBindings(\x27'+_0x5f5ae3['id']+'\x27)\x22\x20title=\x22Access\x20Bindings\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2214\x22\x20height=\x2214\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M12\x2022s8-4\x208-10V5l-8-3-8\x203v7c0\x206\x208\x2010\x208\x2010z\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-icon\x20btn-small\x20btn-danger\x22\x20onclick=\x22window.deleteUser(\x27'+_0x5f5ae3['id']+'\x27)\x22\x20title=\x22Delete\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2214\x22\x20height=\x2214\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<polyline\x20points=\x223\x206\x205\x206\x2021\x206\x22></polyline>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M19\x206v14a2\x202\x200\x200\x201-2\x202H7a2\x202\x200\x200\x201-2-2V6m3\x200V4a2\x202\x200\x200\x201\x202-2h4a2\x202\x200\x200\x201\x202\x202v2\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-secondary\x20btn-small\x22\x20onclick=\x22window.resetPassword(\x27'+_0x5f5ae3['id']+'\x27)\x22>Reset\x20Password</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20</tr>\x0a\x20\x20')['join']('');}window['showAccessBindings']=function(_0x43b5ad){const _0x21955d=state['users']['find'](_0x24680f=>_0x24680f['id']===_0x43b5ad);if(!_0x21955d)return;state['bindingsUserId']=_0x43b5ad,state['bindingsDirty']=![];const _0x3a6c26=document['getElementById']('bindings-modal'),_0x1b2c57=document['getElementById']('bindings-modal-title');_0x1b2c57['textContent']='Access\x20Bindings\x20—\x20'+_0x21955d['name'],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],_0x3a6c26['hidden']=![],loadUserBindings(_0x43b5ad);};function hasUnsavedBindingChanges(){const _0x530846=document['getElementById']('add-user-binding-form');return _0x530846&&!_0x530846['hidden'];}async function hideAccessBindingsModal(){if(hasUnsavedBindingChanges()){if(!confirm('You\x20have\x20an\x20unsaved\x20binding.\x20Discard\x20changes?'))return;document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![];}const _0x2da275=document['getElementById']('bindings-modal');_0x2da275['hidden']=!![];const _0x4c403b=state['bindingsDirty'];state['bindingsUserId']=null,state['userBindings']=[],state['bindingsDirty']=![],_0x4c403b&&await loadUsers();}async function loadUserBindings(_0xe3b620){const _0x5ed437=document['getElementById']('user-bindings-loading'),_0x12b0dd=document['getElementById']('user-bindings-empty'),_0x5137a1=document['getElementById']('user-bindings-list-container'),_0x227ad1=document['getElementById']('add-user-binding-btn'),_0x56153e=document['getElementById']('user-team-bindings-note'),_0x3f97be=document['getElementById']('user-team-bindings-text');_0x5ed437['hidden']=![],_0x12b0dd['hidden']=!![],_0x5137a1['style']['display']='none',_0x227ad1['hidden']=!![],_0x56153e['hidden']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![];try{const [_0x40c2f2,_0x4c554b]=await Promise['all']([API['getBindings']({'subject_type':'user','subject_id':_0xe3b620}),API['getTeams']()]);state['userBindings']=_0x40c2f2['bindings']||[];const _0x505cdb=(_0x4c554b['teams']||[])['filter'](_0x3eb8f3=>(_0x3eb8f3['members']||[])['includes'](_0xe3b620)),_0x79a122=[];if(_0x505cdb['length']>0x0){const _0x3ba52d=await Promise['all'](_0x505cdb['map'](_0x50f70b=>API['getBindings']({'subject_type':'team','subject_id':_0x50f70b['id']})));for(let _0xf9b0a3=0x0;_0xf9b0a3<_0x505cdb['length'];_0xf9b0a3++){const _0xf32468=_0x3ba52d[_0xf9b0a3]['bindings']||[];_0xf32468['length']>0x0&&_0x79a122['push'](_0x505cdb[_0xf9b0a3]);}}_0x5ed437['hidden']=!![];state['userBindings']['length']===0x0?_0x12b0dd['hidden']=![]:(_0x5137a1['style']['display']='',renderUserBindingsTable());if(_0x79a122['length']>0x0){const _0xbcf271=_0x79a122['map'](_0x45d814=>_0x45d814['name']),_0x207518=_0xbcf271['length']<=0x3?_0xbcf271['join'](',\x20'):_0xbcf271['slice'](0x0,0x3)['join'](',\x20')+(',\x20and\x20'+(_0xbcf271['length']-0x3)+'\x20more');_0x3f97be['textContent']='This\x20user\x20also\x20has\x20access\x20via\x20team\x20memberships\x20('+_0x207518+').';}else _0x3f97be['textContent']='This\x20user\x20has\x20no\x20access\x20via\x20team\x20memberships.';_0x56153e['hidden']=![],_0x227ad1['hidden']=![];}catch(_0x4ce0a2){_0x5ed437['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x4ce0a2['message'],'error');}}function renderUserBindingsTable(){const _0x91bfe1=document['getElementById']('user-bindings-table-body');if(!_0x91bfe1)return;_0x91bfe1['innerHTML']=state['userBindings']['map'](_0x248317=>{const _0x22604e=_0x248317['resource_type']==='server'?'Server':_0x248317['resource_id']==='*'?'All\x20'+_0x248317['resource_type']+'s':Utils['escapeHtml'](_0x248317['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x22604e+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x248317['role_name']||_0x248317['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteUserBindingClick(\x27'+_0x248317['id']+'\x27)\x22\x20style=\x22color:\x20var(--color-danger);\x22>Remove</button>\x0a\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20</tr>';})['join']('');}function populateUserBindingForm(){const _0x2e0874=document['getElementById']('user-binding-resource-type');_0x2e0874['value']='environment',updateUserBindingFormForResourceType('environment');}function onUserBindingResourceTypeChange(){const _0x290ac6=document['getElementById']('user-binding-resource-type')['value'];updateUserBindingFormForResourceType(_0x290ac6);}function updateUserBindingFormForResourceType(_0x24fcf4){const _0x118a34=document['getElementById']('user-binding-resource-container'),_0x356899=document['getElementById']('user-binding-resource'),_0x1f18f1=document['getElementById']('user-binding-role');if(_0x24fcf4==='server')_0x118a34['style']['display']='none';else{_0x118a34['style']['display']='';if(_0x24fcf4==='environment'){const _0x320919=new Set(state['userBindings']['filter'](_0x1ea084=>_0x1ea084['resource_type']==='environment')['map'](_0x2af3d9=>_0x2af3d9['resource_id'])),_0x5a8c59=state['environments']['filter'](_0x5ef658=>!_0x320919['has'](_0x5ef658['name']));_0x356899['innerHTML']=_0x5a8c59['length']?_0x5a8c59['map'](_0x4b1098=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x4b1098['name'])+'\x22>'+Utils['escapeHtml'](_0x4b1098['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x24fcf4==='team'){const _0xfc521b=new Set(state['userBindings']['filter'](_0x1f844d=>_0x1f844d['resource_type']==='team')['map'](_0x89fdc=>_0x89fdc['resource_id'])),_0x5391ed=state['teams']['filter'](_0x373561=>!_0xfc521b['has'](_0x373561['id']));_0x356899['innerHTML']=_0x5391ed['length']?_0x5391ed['map'](_0x5eed16=>'<option\x20value=\x22'+_0x5eed16['id']+'\x22>'+Utils['escapeHtml'](_0x5eed16['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x405b3a=state['roles']['filter'](_0x24483a=>_0x24483a['resource_type']===_0x24fcf4);_0x1f18f1['innerHTML']=_0x405b3a['length']?_0x405b3a['filter'](_0x3e9b4b=>{const _0x367672=_0x24fcf4==='server'?undefined:_0x356899['value'];return!state['userBindings']['some'](_0x24cdc8=>_0x24cdc8['resource_type']===_0x24fcf4&&_0x24cdc8['role_id']===_0x3e9b4b['id']&&(_0x24fcf4==='server'||_0x24cdc8['resource_id']===_0x367672));})['map'](_0x1916dc=>'<option\x20value=\x22'+_0x1916dc['id']+'\x22>'+Utils['escapeHtml'](_0x1916dc['name'])+'</option>')['join']('')||'<option\x20value=\x22\x22>No\x20available\x20roles</option>':'<option\x20value=\x22\x22>No\x20roles\x20for\x20this\x20resource\x20type</option>';}async function saveUserBinding(){const _0x59ce84=document['getElementById']('user-binding-resource-type')['value'],_0x33a69d=document['getElementById']('user-binding-role')['value'];if(!_0x33a69d||!state['bindingsUserId'])return;const _0x50d0ea=_0x59ce84==='server'?undefined:document['getElementById']('user-binding-resource')['value'];if(_0x59ce84!=='server'&&!_0x50d0ea)return;const _0x47ed84=document['getElementById']('save-user-binding-btn');_0x47ed84['disabled']=!![],_0x47ed84['textContent']='Adding…';try{const _0x56c490={'subject_type':'user','subject_id':state['bindingsUserId'],'role_id':_0x33a69d,'resource_type':_0x59ce84};if(_0x50d0ea)_0x56c490['resource_id']=_0x50d0ea;await API['createBinding'](_0x56c490),Utils['showToast']('Binding\x20added','success'),state['bindingsDirty']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],await loadUserBindings(state['bindingsUserId']);}catch(_0x3ad2ec){Utils['showToast'](_0x3ad2ec['message'],'error');}finally{_0x47ed84['disabled']=![],_0x47ed84['textContent']='Add\x20Binding';}}window['deleteUserBindingClick']=async function(_0x28cd10){try{await API['deleteBinding'](_0x28cd10),Utils['showToast']('Binding\x20removed','success'),state['bindingsDirty']=!![],await loadUserBindings(state['bindingsUserId']);}catch(_0x44962b){Utils['showToast'](_0x44962b['message'],'error');}};function showCreateUserModal(){state['editingUserId']=null;const _0x92043a=document['getElementById']('user-modal'),_0x32a255=document['getElementById']('modal-title'),_0x2b3df3=document['getElementById']('user-password'),_0x5c1224=document['getElementById']('password-required'),_0x281e60=document['getElementById']('password-hint'),_0x585a8e=document['getElementById']('skip-password-container'),_0x1e95e0=document['getElementById']('skip-password');_0x32a255['textContent']='Create\x20User',document['getElementById']('user-form')['reset'](),_0x2b3df3['required']=!![];if(_0x5c1224)_0x5c1224['textContent']='*';_0x585a8e&&(_0x585a8e['style']['display']='block',_0x1e95e0['checked']=![]),_0x281e60&&(_0x281e60['textContent']='Minimum\x208\x20characters'),_0x92043a['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);}window['editUser']=function(_0x3ff0fd){const _0x5b0582=state['users']['find'](_0x316a7b=>_0x316a7b['id']===_0x3ff0fd);if(!_0x5b0582)return;state['editingUserId']=_0x3ff0fd;const _0x5b871e=document['getElementById']('user-modal'),_0x22755c=document['getElementById']('modal-title'),_0x16fcc4=document['getElementById']('user-password'),_0xb033e2=document['getElementById']('password-required'),_0x3aef9d=document['getElementById']('password-hint'),_0x77f5c5=document['getElementById']('skip-password-container');_0x22755c['textContent']='Edit\x20User',document['getElementById']('user-username')['value']=_0x5b0582['username'],document['getElementById']('user-name')['value']=_0x5b0582['name'],document['getElementById']('user-email')['value']=_0x5b0582['email'],_0x16fcc4['value']='',_0x16fcc4['required']=![];if(_0xb033e2)_0xb033e2['textContent']='';_0x77f5c5&&(_0x77f5c5['style']['display']='none'),_0x3aef9d&&(_0x3aef9d['textContent']='Leave\x20blank\x20to\x20keep\x20current\x20password'),_0x5b871e['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);};function hideUserModal(){const _0x5b2fcd=document['getElementById']('user-modal'),_0x1daaac=document['getElementById']('form-error'),_0x27f0ed=document['getElementById']('save-user');_0x5b2fcd['hidden']=!![],_0x1daaac['hidden']=!![],state['editingUserId']=null,_0x27f0ed&&(_0x27f0ed['disabled']=![],_0x27f0ed['textContent']='Save\x20User');}async function saveUser(){const _0x49285a=document['getElementById']('user-form'),_0x13045f=document['getElementById']('skip-password')?.['checked']||![];if(!_0x13045f&&!_0x49285a['checkValidity']()){_0x49285a['reportValidity']();return;}const _0x3ab21f=document['getElementById']('form-error'),_0x40b088=document['getElementById']('save-user'),_0x56ba94=document['getElementById']('user-username')['value']['trim'](),_0x3e8bf0=document['getElementById']('user-name')['value']['trim'](),_0x3f674f=document['getElementById']('user-email')['value']['trim'](),_0x47c4f7=document['getElementById']('user-password')['value'];if(!_0x56ba94||!_0x3e8bf0||!_0x3f674f){_0x3ab21f['textContent']='Please\x20fill\x20in\x20all\x20required\x20fields',_0x3ab21f['hidden']=![],_0x3ab21f['scrollIntoView']({'behavior':'smooth','block':'nearest'});return;}_0x3ab21f['hidden']=!![];const _0x27dd8e=_0x40b088['textContent'];_0x40b088['disabled']=!![],_0x40b088['textContent']=state['editingUserId']?'Updating...':'Creating...';try{if(state['editingUserId']){const _0x35e43e={'username':_0x56ba94,'name':_0x3e8bf0,'email':_0x3f674f};_0x47c4f7&&(_0x35e43e['password']=_0x47c4f7),await API['updateUser'](state['editingUserId'],_0x35e43e),Utils['showToast']('User\x20updated\x20successfully','success'),await loadUsers(),hideUserModal();}else{const _0x18137e={'username':_0x56ba94,'name':_0x3e8bf0,'email':_0x3f674f};if(!_0x13045f){if(!_0x47c4f7)throw new Error('Password\x20is\x20required\x20for\x20new\x20users');_0x18137e['password']=_0x47c4f7;}const _0x378d6f=await API['createUser'](_0x18137e),_0x433726=_0x378d6f['user'];if(_0x13045f||!_0x47c4f7){const _0x1df77d=await API['createPasswordToken'](_0x433726['id'],'setup',![]);state['setupLinkData']={'username':_0x433726['username'],'email':_0x433726['email'],'url':_0x1df77d['token']['setupUrl'],'userId':_0x433726['id'],'type':'setup','emailSent':![]},await loadUsers(),hideUserModal(),showSetupLinkModal();}else Utils['showToast']('User\x20created\x20successfully','success'),await loadUsers(),hideUserModal();}}catch(_0x50bed7){console['error']('Failed\x20to\x20save\x20user',_0x50bed7),_0x3ab21f['textContent']=_0x50bed7['message'],_0x3ab21f['hidden']=![],_0x3ab21f['scrollIntoView']({'behavior':'smooth','block':'nearest'}),_0x40b088['disabled']=![],_0x40b088['textContent']=_0x27dd8e;}}window['deleteUser']=function(_0x2a06e0){const _0x872413=state['users']['find'](_0x27ed0a=>_0x27ed0a['id']===_0x2a06e0);if(!_0x872413)return;state['deletingUserId']=_0x2a06e0;const _0x433016=document['getElementById']('delete-modal'),_0x3ab430=document['getElementById']('delete-user-name');_0x3ab430['textContent']=_0x872413['name']+'\x20('+_0x872413['username']+')',_0x433016['hidden']=![];};function hideDeleteModal(){const _0x22e2da=document['getElementById']('delete-modal');_0x22e2da['hidden']=!![],state['deletingUserId']=null;const _0x24cafa=document['getElementById']('confirm-delete');_0x24cafa&&(_0x24cafa['disabled']=![],_0x24cafa['textContent']='Delete\x20User');}async function confirmDeleteUser(){if(!state['deletingUserId'])return;const _0x166933=document['getElementById']('confirm-delete'),_0x558e08=_0x166933['textContent'];_0x166933['disabled']=!![],_0x166933['textContent']='Deleting...';try{await API['deleteUser'](state['deletingUserId']),Utils['showToast']('User\x20deleted\x20successfully','success'),await loadUsers(),hideDeleteModal();}catch(_0x4d67eb){console['error']('Failed\x20to\x20delete\x20user',_0x4d67eb),Utils['showToast']('Failed\x20to\x20delete\x20user:\x20'+_0x4d67eb['message'],'error'),_0x166933['disabled']=![],_0x166933['textContent']=_0x558e08;}}function handleSkipPasswordChange(_0x54fdc9){const _0x271227=document['getElementById']('user-password'),_0x32e3a8=_0x54fdc9['target']['checked'];_0x32e3a8?(_0x271227['required']=![],_0x271227['disabled']=!![],_0x271227['value']=''):(_0x271227['required']=!![],_0x271227['disabled']=![]);}function showSetupLinkModal(){if(!state['setupLinkData'])return;const _0x157b7e=document['getElementById']('setup-link-modal'),_0x2fee86=document['getElementById']('setup-link-username'),_0xb582c5=document['getElementById']('setup-link-url'),_0x3c8d17=document['getElementById']('email-setup-link'),_0x257ab5=document['getElementById']('email-button-text');_0x2fee86['textContent']=state['setupLinkData']['username'],_0xb582c5['textContent']=state['setupLinkData']['url'],_0x3c8d17&&_0x257ab5&&(_0x3c8d17['disabled']=![],_0x257ab5['textContent']='Email\x20Link',state['emailConfigured']&&!state['setupLinkData']['emailSent']?_0x3c8d17['style']['display']='inline-block':_0x3c8d17['style']['display']='none'),_0x157b7e['hidden']=![];}function hideSetupLinkModal(){const _0x14ad41=document['getElementById']('setup-link-modal');_0x14ad41['hidden']=!![],state['setupLinkData']=null;}async function copySetupLink(){if(!state['setupLinkData'])return;try{await navigator['clipboard']['writeText'](state['setupLinkData']['url']),Utils['showToast']('Link\x20copied\x20to\x20clipboard','success');}catch(_0xc714d6){console['error']('Failed\x20to\x20copy\x20link',_0xc714d6),Utils['showToast']('Failed\x20to\x20copy\x20link','error');}}async function emailSetupLink(){if(!state['setupLinkData'])return;const _0x58117a=document['getElementById']('email-setup-link'),_0x9ff27f=document['getElementById']('email-button-text');if(!_0x58117a||!_0x9ff27f)return;const _0x2584bb=_0x9ff27f['textContent'];_0x58117a['disabled']=!![],_0x9ff27f['textContent']='Sending...';try{const _0x451c20=await API['createPasswordToken'](state['setupLinkData']['userId'],state['setupLinkData']['type'],!![]);if(_0x451c20['emailSent'])Utils['showToast']('Email\x20sent\x20to\x20'+state['setupLinkData']['email'],'success'),state['setupLinkData']['emailSent']=!![],_0x58117a['style']['display']='none';else{const _0x1decfd=_0x451c20['emailError']||'Failed\x20to\x20send\x20email';Utils['showToast'](_0x1decfd,'error'),_0x58117a['disabled']=![],_0x9ff27f['textContent']=_0x2584bb;}}catch(_0x31fa13){console['error']('Failed\x20to\x20email\x20setup\x20link',_0x31fa13),Utils['showToast']('Failed\x20to\x20send\x20email:\x20'+_0x31fa13['message'],'error'),_0x58117a['disabled']=![],_0x9ff27f['textContent']=_0x2584bb;}}window['resetPassword']=async function(_0x304238){const _0x46c365=state['users']['find'](_0x30c500=>_0x30c500['id']===_0x304238);if(!_0x46c365)return;const _0x1c41e7=await ConfirmDialog['show']({'title':'Reset\x20Password','message':'Generate\x20a\x20password\x20reset\x20link\x20for\x20'+_0x46c365['name']+'\x20('+_0x46c365['username']+')?\x20This\x20will\x20create\x20a\x20link\x20that\x20they\x20can\x20use\x20to\x20set\x20a\x20new\x20password.','confirmText':'Generate\x20Link'});if(!_0x1c41e7)return;try{const _0x1a2640=await API['createPasswordToken'](_0x304238,'reset',![]);state['setupLinkData']={'username':_0x46c365['username'],'email':_0x46c365['email'],'url':_0x1a2640['token']['setupUrl'],'userId':_0x46c365['id'],'type':'reset','emailSent':![]},showSetupLinkModal();}catch(_0x5f4247){console['error']('Failed\x20to\x20create\x20password\x20reset\x20link',_0x5f4247),Utils['showToast']('Failed\x20to\x20create\x20password\x20reset\x20link:\x20'+_0x5f4247['message'],'error');}};
1
+ 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 _0x81df9d=await API['getCurrentUser']();state['currentUser']=_0x81df9d;if(!Permissions['hasServerPermission'](_0x81df9d,'*')&&!Permissions['hasServerPermission'](_0x81df9d,'users:create')){Utils['showToast']('Access\x20denied:\x20Server\x20admin\x20privileges\x20required','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}}catch(_0x394066){window['location']['href']='login.html';}}async function checkEmailConfig(){try{const _0xe620=await API['getEmailConfig']();state['emailConfigured']=_0xe620['configured'];}catch(_0x2e7392){console['error']('Failed\x20to\x20check\x20email\x20config',_0x2e7392),state['emailConfigured']=![];}}async function loadRoles(){try{const {roles:_0x53a696}=await API['getRoleDefinitions']();state['roles']=_0x53a696||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x3b30e1=await API['getEnvironments']();state['environments']=_0x3b30e1['environments']||[];}catch{state['environments']=[];}}async function loadTeams(){try{const {teams:_0x4a51e3}=await API['getTeams']();state['teams']=_0x4a51e3||[];}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 _0x231302=document['getElementById']('users-loading'),_0x19771a=document['getElementById']('users-error'),_0x1c2a9c=document['getElementById']('users-content');try{_0x231302['hidden']=![],_0x19771a['hidden']=!![],_0x1c2a9c['hidden']=!![];const _0x285ce2=await API['getUsers']();state['users']=_0x285ce2['users']||[],renderUsers(),_0x231302['hidden']=!![],_0x1c2a9c['hidden']=![];}catch(_0x489c7b){console['error']('Failed\x20to\x20load\x20users',_0x489c7b),_0x231302['hidden']=!![],_0x19771a['hidden']=![],document['getElementById']('users-error-message')['textContent']=_0x489c7b['message'];}}function renderUsers(){const _0x433724=document['getElementById']('users-table-body'),_0x17f834=document['getElementById']('user-count');if(!_0x433724)return;_0x17f834&&(_0x17f834['textContent']=state['users']['length']+'\x20user'+(state['users']['length']===0x1?'':'s'));const _0x367f0e=[...state['users']]['sort']((_0x28b3d5,_0x53af26)=>{const _0x18ea6f=new Date(_0x28b3d5['created_at'])['getTime'](),_0x2f0507=new Date(_0x53af26['created_at'])['getTime']();return _0x2f0507-_0x18ea6f;});_0x433724['innerHTML']=_0x367f0e['map'](_0x3060da=>'\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'](_0x3060da['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'](_0x3060da['name'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x3060da['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'+(_0x3060da['isServerAdmin']?'<span\x20class=\x22role-badge\x20role-admin\x22>Server\x20Admin</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x3060da['hasUserBinding']?'<span\x20class=\x22role-badge\x20role-user-binding\x22>User\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x3060da['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'](_0x3060da['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'+_0x3060da['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'+_0x3060da['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'+_0x3060da['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'+_0x3060da['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(_0x40a3b5){const _0x2ec98c=state['users']['find'](_0x5edbfc=>_0x5edbfc['id']===_0x40a3b5);if(!_0x2ec98c)return;state['bindingsUserId']=_0x40a3b5,state['bindingsDirty']=![];const _0x4b155a=document['getElementById']('bindings-modal'),_0x524f7c=document['getElementById']('bindings-modal-title');_0x524f7c['textContent']='Access\x20Bindings\x20—\x20'+_0x2ec98c['name'],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],_0x4b155a['hidden']=![],loadUserBindings(_0x40a3b5);};function hasUnsavedBindingChanges(){const _0x2c1a10=document['getElementById']('add-user-binding-form');return _0x2c1a10&&!_0x2c1a10['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 _0x2d96c7=document['getElementById']('bindings-modal');_0x2d96c7['hidden']=!![];const _0x160695=state['bindingsDirty'];state['bindingsUserId']=null,state['userBindings']=[],state['bindingsDirty']=![],_0x160695&&await loadUsers();}async function loadUserBindings(_0x2fec81){const _0x1b5a48=document['getElementById']('user-bindings-loading'),_0xc91d0a=document['getElementById']('user-bindings-empty'),_0x7f245f=document['getElementById']('user-bindings-list-container'),_0x32bb2d=document['getElementById']('add-user-binding-btn'),_0x3159fe=document['getElementById']('user-team-bindings-note'),_0x5872d5=document['getElementById']('user-team-bindings-text');_0x1b5a48['hidden']=![],_0xc91d0a['hidden']=!![],_0x7f245f['style']['display']='none',_0x32bb2d['hidden']=!![],_0x3159fe['hidden']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![];try{const [_0x51d0fb,_0x53a9fb]=await Promise['all']([API['getBindings']({'subject_type':'user','subject_id':_0x2fec81}),API['getTeams']()]);state['userBindings']=_0x51d0fb['bindings']||[];const _0x2aa703=(_0x53a9fb['teams']||[])['filter'](_0x3ea036=>(_0x3ea036['members']||[])['includes'](_0x2fec81)),_0x56dc0a=[];if(_0x2aa703['length']>0x0){const _0x2a4886=await Promise['all'](_0x2aa703['map'](_0x32f22e=>API['getBindings']({'subject_type':'team','subject_id':_0x32f22e['id']})));for(let _0x59f590=0x0;_0x59f590<_0x2aa703['length'];_0x59f590++){const _0x374ba2=_0x2a4886[_0x59f590]['bindings']||[];_0x374ba2['length']>0x0&&_0x56dc0a['push'](_0x2aa703[_0x59f590]);}}_0x1b5a48['hidden']=!![];state['userBindings']['length']===0x0?_0xc91d0a['hidden']=![]:(_0x7f245f['style']['display']='',renderUserBindingsTable());if(_0x56dc0a['length']>0x0){const _0x5a018c=_0x56dc0a['map'](_0x3de435=>_0x3de435['name']),_0x310fb1=_0x5a018c['length']<=0x3?_0x5a018c['join'](',\x20'):_0x5a018c['slice'](0x0,0x3)['join'](',\x20')+(',\x20and\x20'+(_0x5a018c['length']-0x3)+'\x20more');_0x5872d5['textContent']='This\x20user\x20also\x20has\x20access\x20via\x20team\x20memberships\x20('+_0x310fb1+').';}else _0x5872d5['textContent']='This\x20user\x20has\x20no\x20access\x20via\x20team\x20memberships.';_0x3159fe['hidden']=![],_0x32bb2d['hidden']=![];}catch(_0x53826d){_0x1b5a48['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x53826d['message'],'error');}}function renderUserBindingsTable(){const _0x4c3595=document['getElementById']('user-bindings-table-body');if(!_0x4c3595)return;_0x4c3595['innerHTML']=state['userBindings']['map'](_0x1453d1=>{const _0x45decf=_0x1453d1['resource_type']==='server'?'Server':_0x1453d1['resource_id']==='*'?'All\x20'+_0x1453d1['resource_type']+'s':Utils['escapeHtml'](_0x1453d1['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x45decf+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x1453d1['role_name']||_0x1453d1['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'+_0x1453d1['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 _0x6d10c2=document['getElementById']('user-binding-resource-type');_0x6d10c2['value']='environment',updateUserBindingFormForResourceType('environment');}function onUserBindingResourceTypeChange(){const _0x1e8e96=document['getElementById']('user-binding-resource-type')['value'];updateUserBindingFormForResourceType(_0x1e8e96);}function updateUserBindingFormForResourceType(_0x37d6ee){const _0x439d8c=document['getElementById']('user-binding-resource-container'),_0x101be=document['getElementById']('user-binding-resource'),_0x10fafb=document['getElementById']('user-binding-role');if(_0x37d6ee==='server')_0x439d8c['style']['display']='none';else{_0x439d8c['style']['display']='';if(_0x37d6ee==='environment'){const _0x256c49=new Set(state['userBindings']['filter'](_0x1aa2d5=>_0x1aa2d5['resource_type']==='environment')['map'](_0xaaa65e=>_0xaaa65e['resource_id'])),_0x3eb081=state['environments']['filter'](_0x4ba164=>!_0x256c49['has'](_0x4ba164['name']));_0x101be['innerHTML']=_0x3eb081['length']?_0x3eb081['map'](_0x26a9fe=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x26a9fe['name'])+'\x22>'+Utils['escapeHtml'](_0x26a9fe['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x37d6ee==='team'){const _0x18b148=new Set(state['userBindings']['filter'](_0x4ff4be=>_0x4ff4be['resource_type']==='team')['map'](_0x257882=>_0x257882['resource_id'])),_0x279901=state['teams']['filter'](_0x329b63=>!_0x18b148['has'](_0x329b63['id']));_0x101be['innerHTML']=_0x279901['length']?_0x279901['map'](_0x5f4119=>'<option\x20value=\x22'+_0x5f4119['id']+'\x22>'+Utils['escapeHtml'](_0x5f4119['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x2f3455=state['roles']['filter'](_0x1d456a=>_0x1d456a['resource_type']===_0x37d6ee);_0x10fafb['innerHTML']=_0x2f3455['length']?_0x2f3455['filter'](_0x54c1e0=>{const _0x1781d2=_0x37d6ee==='server'?undefined:_0x101be['value'];return!state['userBindings']['some'](_0x1727ee=>_0x1727ee['resource_type']===_0x37d6ee&&_0x1727ee['role_id']===_0x54c1e0['id']&&(_0x37d6ee==='server'||_0x1727ee['resource_id']===_0x1781d2));})['map'](_0x4419d4=>'<option\x20value=\x22'+_0x4419d4['id']+'\x22>'+Utils['escapeHtml'](_0x4419d4['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 _0x2f4a7f=document['getElementById']('user-binding-resource-type')['value'],_0x268dbf=document['getElementById']('user-binding-role')['value'];if(!_0x268dbf||!state['bindingsUserId'])return;const _0x50debb=_0x2f4a7f==='server'?undefined:document['getElementById']('user-binding-resource')['value'];if(_0x2f4a7f!=='server'&&!_0x50debb)return;const _0x3cbe00=document['getElementById']('save-user-binding-btn');_0x3cbe00['disabled']=!![],_0x3cbe00['textContent']='Adding…';try{const _0x16c190={'subject_type':'user','subject_id':state['bindingsUserId'],'role_id':_0x268dbf,'resource_type':_0x2f4a7f};if(_0x50debb)_0x16c190['resource_id']=_0x50debb;await API['createBinding'](_0x16c190),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(_0x364da4){Utils['showToast'](_0x364da4['message'],'error');}finally{_0x3cbe00['disabled']=![],_0x3cbe00['textContent']='Add\x20Binding';}}window['deleteUserBindingClick']=async function(_0x27c4d5){try{await API['deleteBinding'](_0x27c4d5),Utils['showToast']('Binding\x20removed','success'),state['bindingsDirty']=!![],await loadUserBindings(state['bindingsUserId']);}catch(_0x8a97de){Utils['showToast'](_0x8a97de['message'],'error');}};function showCreateUserModal(){state['editingUserId']=null;const _0x51714f=document['getElementById']('user-modal'),_0x3f0eeb=document['getElementById']('modal-title'),_0x1e7c33=document['getElementById']('user-password'),_0x41aeb2=document['getElementById']('password-required'),_0x413d6a=document['getElementById']('password-hint'),_0x210768=document['getElementById']('skip-password-container'),_0x49a762=document['getElementById']('skip-password');_0x3f0eeb['textContent']='Create\x20User',document['getElementById']('user-form')['reset'](),_0x1e7c33['required']=!![];if(_0x41aeb2)_0x41aeb2['textContent']='*';_0x210768&&(_0x210768['style']['display']='block',_0x49a762['checked']=![]),_0x413d6a&&(_0x413d6a['textContent']='Minimum\x208\x20characters'),_0x51714f['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);}window['editUser']=function(_0x18568f){const _0x3b2873=state['users']['find'](_0x3fcea1=>_0x3fcea1['id']===_0x18568f);if(!_0x3b2873)return;state['editingUserId']=_0x18568f;const _0x231080=document['getElementById']('user-modal'),_0x4b75b2=document['getElementById']('modal-title'),_0x420b75=document['getElementById']('user-password'),_0x41bf07=document['getElementById']('password-required'),_0x5107c9=document['getElementById']('password-hint'),_0x3db8f1=document['getElementById']('skip-password-container');_0x4b75b2['textContent']='Edit\x20User',document['getElementById']('user-username')['value']=_0x3b2873['username'],document['getElementById']('user-name')['value']=_0x3b2873['name'],document['getElementById']('user-email')['value']=_0x3b2873['email'],_0x420b75['value']='',_0x420b75['required']=![];if(_0x41bf07)_0x41bf07['textContent']='';_0x3db8f1&&(_0x3db8f1['style']['display']='none'),_0x5107c9&&(_0x5107c9['textContent']='Leave\x20blank\x20to\x20keep\x20current\x20password'),_0x231080['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);};function hideUserModal(){const _0x3e0b02=document['getElementById']('user-modal'),_0x2389c9=document['getElementById']('form-error'),_0x1b108a=document['getElementById']('save-user');_0x3e0b02['hidden']=!![],_0x2389c9['hidden']=!![],state['editingUserId']=null,_0x1b108a&&(_0x1b108a['disabled']=![],_0x1b108a['textContent']='Save\x20User');}async function saveUser(){const _0x171af8=document['getElementById']('user-form'),_0x9021cc=document['getElementById']('skip-password')?.['checked']||![];if(!_0x9021cc&&!_0x171af8['checkValidity']()){_0x171af8['reportValidity']();return;}const _0x55f4ec=document['getElementById']('form-error'),_0x37c42d=document['getElementById']('save-user'),_0x7143ab=document['getElementById']('user-username')['value']['trim'](),_0x407893=document['getElementById']('user-name')['value']['trim'](),_0x8e925a=document['getElementById']('user-email')['value']['trim'](),_0x1dcae7=document['getElementById']('user-password')['value'];if(!_0x7143ab||!_0x407893||!_0x8e925a){_0x55f4ec['textContent']='Please\x20fill\x20in\x20all\x20required\x20fields',_0x55f4ec['hidden']=![],_0x55f4ec['scrollIntoView']({'behavior':'smooth','block':'nearest'});return;}_0x55f4ec['hidden']=!![];const _0x55f5d6=_0x37c42d['textContent'];_0x37c42d['disabled']=!![],_0x37c42d['textContent']=state['editingUserId']?'Updating...':'Creating...';try{if(state['editingUserId']){const _0x47b369={'username':_0x7143ab,'name':_0x407893,'email':_0x8e925a};_0x1dcae7&&(_0x47b369['password']=_0x1dcae7),await API['updateUser'](state['editingUserId'],_0x47b369),Utils['showToast']('User\x20updated\x20successfully','success'),await loadUsers(),hideUserModal();}else{const _0x273c5f={'username':_0x7143ab,'name':_0x407893,'email':_0x8e925a};if(!_0x9021cc){if(!_0x1dcae7)throw new Error('Password\x20is\x20required\x20for\x20new\x20users');_0x273c5f['password']=_0x1dcae7;}const _0x1fe084=await API['createUser'](_0x273c5f),_0x38fb57=_0x1fe084['user'];if(_0x9021cc||!_0x1dcae7){const _0x134a56=await API['createPasswordToken'](_0x38fb57['id'],'setup',![]);state['setupLinkData']={'username':_0x38fb57['username'],'email':_0x38fb57['email'],'url':_0x134a56['token']['setupUrl'],'userId':_0x38fb57['id'],'type':'setup','emailSent':![]},await loadUsers(),hideUserModal(),showSetupLinkModal();}else Utils['showToast']('User\x20created\x20successfully','success'),await loadUsers(),hideUserModal();}}catch(_0x52ddb4){console['error']('Failed\x20to\x20save\x20user',_0x52ddb4),_0x55f4ec['textContent']=_0x52ddb4['message'],_0x55f4ec['hidden']=![],_0x55f4ec['scrollIntoView']({'behavior':'smooth','block':'nearest'}),_0x37c42d['disabled']=![],_0x37c42d['textContent']=_0x55f5d6;}}window['deleteUser']=function(_0x22363a){const _0x3551f9=state['users']['find'](_0x662c42=>_0x662c42['id']===_0x22363a);if(!_0x3551f9)return;state['deletingUserId']=_0x22363a;const _0x423e7e=document['getElementById']('delete-modal'),_0x400db6=document['getElementById']('delete-user-name');_0x400db6['textContent']=_0x3551f9['name']+'\x20('+_0x3551f9['username']+')',_0x423e7e['hidden']=![];};function hideDeleteModal(){const _0x1e24d2=document['getElementById']('delete-modal');_0x1e24d2['hidden']=!![],state['deletingUserId']=null;const _0x4e92be=document['getElementById']('confirm-delete');_0x4e92be&&(_0x4e92be['disabled']=![],_0x4e92be['textContent']='Delete\x20User');}async function confirmDeleteUser(){if(!state['deletingUserId'])return;const _0x18e7f0=document['getElementById']('confirm-delete'),_0x3cc25b=_0x18e7f0['textContent'];_0x18e7f0['disabled']=!![],_0x18e7f0['textContent']='Deleting...';try{await API['deleteUser'](state['deletingUserId']),Utils['showToast']('User\x20deleted\x20successfully','success'),await loadUsers(),hideDeleteModal();}catch(_0x149936){console['error']('Failed\x20to\x20delete\x20user',_0x149936),Utils['showToast']('Failed\x20to\x20delete\x20user:\x20'+_0x149936['message'],'error'),_0x18e7f0['disabled']=![],_0x18e7f0['textContent']=_0x3cc25b;}}function handleSkipPasswordChange(_0x4f6f4f){const _0x37cec3=document['getElementById']('user-password'),_0x58cd91=_0x4f6f4f['target']['checked'];_0x58cd91?(_0x37cec3['required']=![],_0x37cec3['disabled']=!![],_0x37cec3['value']=''):(_0x37cec3['required']=!![],_0x37cec3['disabled']=![]);}function showSetupLinkModal(){if(!state['setupLinkData'])return;const _0x2f24a2=document['getElementById']('setup-link-modal'),_0x4dcfc9=document['getElementById']('setup-link-username'),_0x2cdfbb=document['getElementById']('setup-link-url'),_0x2f853c=document['getElementById']('email-setup-link'),_0x1d3cc0=document['getElementById']('email-button-text');_0x4dcfc9['textContent']=state['setupLinkData']['username'],_0x2cdfbb['textContent']=state['setupLinkData']['url'],_0x2f853c&&_0x1d3cc0&&(_0x2f853c['disabled']=![],_0x1d3cc0['textContent']='Email\x20Link',state['emailConfigured']&&!state['setupLinkData']['emailSent']?_0x2f853c['style']['display']='inline-block':_0x2f853c['style']['display']='none'),_0x2f24a2['hidden']=![];}function hideSetupLinkModal(){const _0x1bdbc8=document['getElementById']('setup-link-modal');_0x1bdbc8['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(_0x17ad5a){console['error']('Failed\x20to\x20copy\x20link',_0x17ad5a),Utils['showToast']('Failed\x20to\x20copy\x20link','error');}}async function emailSetupLink(){if(!state['setupLinkData'])return;const _0x3dedcd=document['getElementById']('email-setup-link'),_0x1588a2=document['getElementById']('email-button-text');if(!_0x3dedcd||!_0x1588a2)return;const _0x1c8843=_0x1588a2['textContent'];_0x3dedcd['disabled']=!![],_0x1588a2['textContent']='Sending...';try{const _0x1ccce7=await API['createPasswordToken'](state['setupLinkData']['userId'],state['setupLinkData']['type'],!![]);if(_0x1ccce7['emailSent'])Utils['showToast']('Email\x20sent\x20to\x20'+state['setupLinkData']['email'],'success'),state['setupLinkData']['emailSent']=!![],_0x3dedcd['style']['display']='none';else{const _0x32c08b=_0x1ccce7['emailError']||'Failed\x20to\x20send\x20email';Utils['showToast'](_0x32c08b,'error'),_0x3dedcd['disabled']=![],_0x1588a2['textContent']=_0x1c8843;}}catch(_0x5e34b8){console['error']('Failed\x20to\x20email\x20setup\x20link',_0x5e34b8),Utils['showToast']('Failed\x20to\x20send\x20email:\x20'+_0x5e34b8['message'],'error'),_0x3dedcd['disabled']=![],_0x1588a2['textContent']=_0x1c8843;}}window['resetPassword']=async function(_0x935c29){const _0x40c183=state['users']['find'](_0x1d5594=>_0x1d5594['id']===_0x935c29);if(!_0x40c183)return;const _0x14edce=await ConfirmDialog['show']({'title':'Reset\x20Password','message':'Generate\x20a\x20password\x20reset\x20link\x20for\x20'+_0x40c183['name']+'\x20('+_0x40c183['username']+')?\x20This\x20will\x20create\x20a\x20link\x20that\x20they\x20can\x20use\x20to\x20set\x20a\x20new\x20password.','confirmText':'Generate\x20Link'});if(!_0x14edce)return;try{const _0x3c01ca=await API['createPasswordToken'](_0x935c29,'reset',![]);state['setupLinkData']={'username':_0x40c183['username'],'email':_0x40c183['email'],'url':_0x3c01ca['token']['setupUrl'],'userId':_0x40c183['id'],'type':'reset','emailSent':![]},showSetupLinkModal();}catch(_0x3347ec){console['error']('Failed\x20to\x20create\x20password\x20reset\x20link',_0x3347ec),Utils['showToast']('Failed\x20to\x20create\x20password\x20reset\x20link:\x20'+_0x3347ec['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(_0x374a81={}){this['container']=null,this['onGroupChange']=_0x374a81['onGroupChange']||(()=>{}),this['onAddExistingTask']=_0x374a81['onAddExistingTask']||(()=>{}),this['tasks']=[],this['groupId']=_0x374a81['groupId']||null,this['isOpen']=![];}['init'](_0x503a79,_0x1469ba,_0x2aa071){this['container']=_0x503a79,this['tasks']=_0x1469ba,this['groupId']=_0x2aa071,this['render'](),this['attachEventListeners']();}['updateTasks'](_0x5a7386){const _0x37629b=new Map(_0x5a7386['map'](_0x28f67b=>[_0x28f67b['taskId'],_0x28f67b]));this['tasks']=this['tasks']['map'](_0x269b01=>{const _0x577a68=_0x37629b['get'](_0x269b01['taskId']);return _0x577a68?_0x577a68:_0x269b01;});for(const _0x853f81 of _0x5a7386){!this['tasks']['some'](_0x4a4734=>_0x4a4734['taskId']===_0x853f81['taskId'])&&this['tasks']['push'](_0x853f81);}this['isOpen']&&this['render']();}['open'](){this['isOpen']=!![],this['render'](),this['container']?.['classList']['add']('open');}['close'](){this['isOpen']=![],this['container']?.['classList']['remove']('open');}['render'](){if(!this['container'])return;const _0x1238b4=this['tasks']['filter'](_0x1fc892=>_0x1fc892['groupId']===this['groupId'])['sort']((_0x339f98,_0x35de0c)=>(_0x339f98['groupIndex']??0x0)-(_0x35de0c['groupIndex']??0x0)),_0x15937a=this['tasks']['filter'](_0xa7f465=>!_0xa7f465['groupId']||_0xa7f465['groupId']!==this['groupId']);this['container']['innerHTML']='\x0a\x20\x20\x20\x20\x20\x20<div\x20class=\x22variant-grouping-manager\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-header\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<h3>Manage\x20Task\x20Group</h3>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22vgm-close-btn\x22\x20title=\x22Close\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20width=\x2220\x22\x20height=\x2220\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M18\x206L6\x2018M6\x206l12\x2012\x22/>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-content\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-section\x20vgm-grouped\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-section-header\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-section-title\x22>Grouped\x20Variants</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-section-count\x22>'+_0x1238b4['length']+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-drop-zone\x20vgm-grouped-zone\x22\x20data-zone=\x22grouped\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x1238b4['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20add\x20to\x20group</div>':_0x1238b4['map']((_0x13c682,_0x4a2049)=>this['renderVariantCard'](_0x13c682,_0x4a2049,!![]))['join'](''))+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-divider\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-divider-line\x22></div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-divider-text\x22>Drag\x20to\x20move</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-divider-line\x22></div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-section\x20vgm-ungrouped\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-section-header\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-section-title\x22>Ungrouped\x20Tasks</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-section-count\x22>'+_0x15937a['length']+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-drop-zone\x20vgm-ungrouped-zone\x22\x20data-zone=\x22ungrouped\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x15937a['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20remove\x20from\x20group</div>':_0x15937a['map']((_0x23cdaf,_0x1136b5)=>this['renderVariantCard'](_0x23cdaf,_0x1136b5,![]))['join'](''))+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-actions\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22vgm-btn\x20vgm-btn-secondary\x20vgm-add-existing-btn\x22\x20title=\x22Add\x20an\x20existing\x20task\x20to\x20this\x20group\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M12\x205v14M5\x2012h14\x22/>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20Add\x20Existing\x20Task\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20';}['renderVariantCard'](_0x3d30ab,_0x2fe9ac,_0x547063){const _0x351f12=_0x3d30ab['envVars']?.['CODER_AGENT']||_0x3d30ab['envVars']?.['default_agent']||'claude',_0x3620de=AGENT_ICONS[_0x351f12['toLowerCase']()]||AGENT_ICONS['claude'],_0x40a002=STATUS_ICONS[_0x3d30ab['status']]||'',_0x2a1fc4='status-'+(_0x3d30ab['status']||'unknown'),_0x1fd7a4=_0x3d30ab['isWinner']?'<span\x20class=\x22vgm-badge\x20vgm-badge-winner\x22\x20title=\x22Winner\x22>★</span>':'',_0x545cdc=_0x3d30ab['approvedBy']?'<span\x20class=\x22vgm-badge\x20vgm-badge-approved\x22\x20title=\x22Approved\x22><svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22\x20width=\x2212\x22\x20height=\x2212\x22><path\x20d=\x22M14\x209V5a3\x203\x200\x200\x200-3-3l-4\x209v11h11.28a2\x202\x200\x200\x200\x202-1.7l1.38-9a2\x202\x200\x200\x200-2-2.3zM7\x2022H4a2\x202\x200\x200\x201-2-2v-7a2\x202\x200\x200\x201\x202-2h3\x22></path></svg></span>':'';return'\x0a\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-card\x20'+_0x2a1fc4+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20draggable=\x22true\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-task-id=\x22'+_0x3d30ab['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-is-grouped=\x22'+_0x547063+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-index=\x22'+_0x2fe9ac+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-drag-handle\x22\x20title=\x22Drag\x20to\x20reorder\x20or\x20move\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20fill=\x22currentColor\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M8\x206h2v2H8V6zm6\x200h2v2h-2V6zM8\x2011h2v2H8v-2zm6\x200h2v2h-2v-2zm-6\x205h2v2H8v-2zm6\x200h2v2h-2v-2z\x22/>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-icon\x22\x20data-agent=\x22'+_0x351f12['toLowerCase']()+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x3620de+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-info\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-name\x22>'+Utils['escapeHtml'](_0x3d30ab['name']||'Task\x20'+_0x3d30ab['taskId']['slice'](-0x6))+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-meta\x22>'+Utils['escapeHtml'](_0x351f12)+'\x20·\x20'+(_0x3d30ab['status']||'unknown')+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-badges\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x1fd7a4+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x545cdc+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-status\x20'+_0x2a1fc4+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x40a002+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22vgm-variant-remove-btn\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20title=\x22'+(_0x547063?'Remove\x20from\x20group':'Add\x20to\x20group')+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-task-id=\x22'+_0x3d30ab['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-action=\x22'+(_0x547063?'remove':'add')+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x547063?'<path\x20d=\x22M18\x206L6\x2018M6\x206l12\x2012\x22/>':'<path\x20d=\x22M12\x205v14M5\x2012h14\x22/>')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20';}['attachEventListeners'](){if(!this['container'])return;this['container']['addEventListener']('click',_0x112979=>{_0x112979['target']['closest']('.vgm-close-btn')&&(this['close'](),this['onGroupChange'](this['tasks'])),_0x112979['target']['closest']('.vgm-add-existing-btn')&&(this['close'](),this['onAddExistingTask'](this['groupId']));}),this['container']['addEventListener']('click',async _0x26a1fb=>{const _0x1b47b7=_0x26a1fb['target']['closest']('.vgm-variant-remove-btn');if(!_0x1b47b7)return;const _0x21ce8f=_0x1b47b7['dataset']['taskId'],_0x2ba49d=_0x1b47b7['dataset']['action'];try{_0x2ba49d==='remove'?await this['removeFromGroup'](_0x21ce8f):await this['addToGroup'](_0x21ce8f);}catch(_0x3cb2e4){console['error']('Failed\x20to\x20update\x20group:',_0x3cb2e4),Utils['showToast'](_0x3cb2e4['message']||'Failed\x20to\x20update\x20group','error');}}),this['container']['addEventListener']('dragstart',_0x1e08e9=>this['handleDragStart'](_0x1e08e9)),this['container']['addEventListener']('dragend',_0x2266d6=>this['handleDragEnd'](_0x2266d6)),this['container']['addEventListener']('dragover',_0x36c430=>this['handleDragOver'](_0x36c430)),this['container']['addEventListener']('dragleave',_0x39ec58=>this['handleDragLeave'](_0x39ec58)),this['container']['addEventListener']('drop',_0x1d8e03=>this['handleDrop'](_0x1d8e03));}['handleDragStart'](_0x3fde35){const _0x5c078e=_0x3fde35['target']['closest']('.vgm-variant-card');if(!_0x5c078e)return;dragState['draggedTaskId']=_0x5c078e['dataset']['taskId'],dragState['draggedElement']=_0x5c078e,dragState['sourceGroupId']=_0x5c078e['dataset']['isGrouped']==='true'?this['groupId']:null,dragState['isDragging']=!![],_0x5c078e['classList']['add']('dragging'),_0x3fde35['dataTransfer']['effectAllowed']='move',_0x3fde35['dataTransfer']['setData']('text/plain',_0x5c078e['dataset']['taskId']),this['container']['classList']['add']('is-dragging');}['handleDragEnd'](_0x4da670){const _0x242891=_0x4da670['target']['closest']('.vgm-variant-card');_0x242891&&_0x242891['classList']['remove']('dragging'),this['container']['querySelectorAll']('.drag-over,\x20.drop-indicator')['forEach'](_0xd2ff01=>{_0xd2ff01['classList']['remove']('drag-over','drop-indicator','drop-before','drop-after');}),this['container']['classList']['remove']('is-dragging'),dragState['isDragging']=![],dragState['draggedTaskId']=null,dragState['draggedElement']=null,dragState['sourceGroupId']=null;}['handleDragOver'](_0x2a35b8){_0x2a35b8['preventDefault'](),_0x2a35b8['dataTransfer']['dropEffect']='move';const _0x1f1605=_0x2a35b8['target']['closest']('.vgm-drop-zone'),_0xfb03ce=_0x2a35b8['target']['closest']('.vgm-variant-card');this['container']['querySelectorAll']('.vgm-drop-zone')['forEach'](_0x268172=>{_0x268172['classList']['toggle']('drag-over',_0x268172===_0x1f1605);});if(_0xfb03ce&&_0xfb03ce!==dragState['draggedElement']){const _0x55ec0e=_0xfb03ce['getBoundingClientRect'](),_0x133b30=_0x55ec0e['top']+_0x55ec0e['height']/0x2,_0x26308f=_0x2a35b8['clientY']<_0x133b30;this['container']['querySelectorAll']('.vgm-variant-card')['forEach'](_0x1bf46f=>{_0x1bf46f!==_0xfb03ce&&_0x1bf46f['classList']['remove']('drop-before','drop-after');}),_0xfb03ce['classList']['toggle']('drop-before',_0x26308f),_0xfb03ce['classList']['toggle']('drop-after',!_0x26308f);}}['handleDragLeave'](_0x5e2aa5){const _0xe597ac=_0x5e2aa5['target']['closest']('.vgm-drop-zone');_0xe597ac&&!_0xe597ac['contains'](_0x5e2aa5['relatedTarget'])&&_0xe597ac['classList']['remove']('drag-over');}async['handleDrop'](_0x445afa){_0x445afa['preventDefault']();const _0x12ec7c=_0x445afa['target']['closest']('.vgm-drop-zone'),_0x59cff7=_0x445afa['target']['closest']('.vgm-variant-card'),_0x59bfe0=_0x445afa['dataTransfer']['getData']('text/plain');if(!_0x12ec7c||!_0x59bfe0)return;this['container']['querySelectorAll']('.drag-over,\x20.drop-before,\x20.drop-after')['forEach'](_0x5c7246=>{_0x5c7246['classList']['remove']('drag-over','drop-before','drop-after');});const _0x380bd1=_0x12ec7c['dataset']['zone'],_0x1bc63a=_0x380bd1==='grouped',_0x32f897=dragState['sourceGroupId']===this['groupId'];try{if(_0x1bc63a&&!_0x32f897){let _0x113e56=this['tasks']['filter'](_0x2939de=>_0x2939de['groupId']===this['groupId'])['length'];if(_0x59cff7){const _0x46fc9d=_0x59cff7['dataset']['taskId'],_0x342406=this['tasks']['find'](_0x1b72fe=>_0x1b72fe['taskId']===_0x46fc9d);if(_0x342406?.['groupIndex']!==undefined){const _0xf12da0=_0x59cff7['getBoundingClientRect'](),_0x4cfb2c=_0x445afa['clientY']<_0xf12da0['top']+_0xf12da0['height']/0x2;_0x113e56=_0x342406['groupIndex']+(_0x4cfb2c?0x0:0x1);}}await this['addToGroup'](_0x59bfe0,_0x113e56);}else{if(!_0x1bc63a&&_0x32f897)await this['removeFromGroup'](_0x59bfe0);else _0x1bc63a&&_0x32f897&&_0x59cff7&&await this['reorderInGroup'](_0x59bfe0,_0x59cff7,_0x445afa['clientY']);}}catch(_0xa02aec){console['error']('Drop\x20operation\x20failed:',_0xa02aec),Utils['showToast'](_0xa02aec['message']||'Failed\x20to\x20move\x20variant','error');}}async['addToGroup'](_0x18a59c,_0x2fce5b){const _0x4afdd3=this['tasks']['find'](_0x3b257d=>_0x3b257d['taskId']===_0x18a59c);if(!_0x4afdd3)return;_0x2fce5b===undefined&&(_0x2fce5b=this['tasks']['filter'](_0x36f6a7=>_0x36f6a7['groupId']===this['groupId'])['length']),!this['groupId']&&(this['groupId']=API['generateGroupId'](),await API['createTaskGroup']({'groupId':this['groupId']})),await API['updateTaskGroup'](_0x18a59c,this['groupId'],_0x2fce5b),_0x4afdd3['groupId']=this['groupId'],_0x4afdd3['groupIndex']=_0x2fce5b,this['render'](),this['onGroupChange'](this['tasks']);}async['removeFromGroup'](_0x473b03){const _0x4f45f3=this['tasks']['find'](_0xef28df=>_0xef28df['taskId']===_0x473b03);if(!_0x4f45f3)return;await API['removeTaskFromGroup'](_0x473b03),_0x4f45f3['groupId']=null,_0x4f45f3['groupIndex']=null,this['render'](),this['onGroupChange'](this['tasks']);}async['reorderInGroup'](_0xbf3f78,_0x23283d,_0x11abee){const _0x1f82f9=this['tasks']['find'](_0x3b9c28=>_0x3b9c28['taskId']===_0xbf3f78),_0x377e0f=_0x23283d['dataset']['taskId'],_0x2e5681=this['tasks']['find'](_0x286729=>_0x286729['taskId']===_0x377e0f);if(!_0x1f82f9||!_0x2e5681||_0x1f82f9['taskId']===_0x2e5681['taskId'])return;const _0x3f4098=_0x23283d['getBoundingClientRect'](),_0x460d39=_0x11abee<_0x3f4098['top']+_0x3f4098['height']/0x2;let _0x326964=_0x2e5681['groupIndex']??0x0;if(!_0x460d39)_0x326964++;if((_0x1f82f9['groupIndex']??0x0)<(_0x2e5681['groupIndex']??0x0))_0x326964--;if(_0x326964===_0x1f82f9['groupIndex'])return;await API['updateTaskGroup'](_0xbf3f78,this['groupId'],_0x326964);const _0x4404b5=this['tasks']['filter'](_0x3d44eb=>_0x3d44eb['groupId']===this['groupId'])['sort']((_0xa02b29,_0x48f587)=>(_0xa02b29['groupIndex']??0x0)-(_0x48f587['groupIndex']??0x0)),_0x17f6f0=_0x4404b5['findIndex'](_0x5a6ba7=>_0x5a6ba7['taskId']===_0xbf3f78);_0x17f6f0!==-0x1&&_0x4404b5['splice'](_0x17f6f0,0x1),_0x4404b5['splice'](_0x326964,0x0,_0x1f82f9),_0x4404b5['forEach']((_0x1352a8,_0x15eb01)=>{_0x1352a8['groupIndex']=_0x15eb01;}),this['render'](),this['onGroupChange'](this['tasks']);}}export function initializeTabDragDrop(_0x141896,_0x5a9713,_0x6deda6,_0x4fe340={}){if(!_0x141896)return;const {onReorder:_0x25ff2a,onRemove:_0x87a6a9}=_0x4fe340,_0x34fc86=_0x141896['querySelectorAll']('.task-tab');_0x34fc86['forEach']((_0x4f2243,_0x1d4952)=>{_0x4f2243['setAttribute']('draggable','true'),_0x4f2243['dataset']['index']=_0x1d4952,_0x4f2243['addEventListener']('dragstart',_0x133392=>{_0x133392['dataTransfer']['effectAllowed']='move',_0x133392['dataTransfer']['setData']('text/plain',_0x4f2243['dataset']['taskId']),_0x4f2243['classList']['add']('dragging'),_0x141896['classList']['add']('is-dragging');}),_0x4f2243['addEventListener']('dragend',()=>{_0x4f2243['classList']['remove']('dragging'),_0x141896['classList']['remove']('is-dragging'),_0x141896['querySelectorAll']('.drop-indicator')['forEach'](_0x2065ac=>{_0x2065ac['classList']['remove']('drop-indicator','drop-before','drop-after');});}),_0x4f2243['addEventListener']('dragover',_0x580971=>{_0x580971['preventDefault'](),_0x580971['dataTransfer']['dropEffect']='move';if(_0x4f2243['classList']['contains']('dragging'))return;const _0x5b31c9=_0x4f2243['getBoundingClientRect'](),_0x21663a=_0x5b31c9['left']+_0x5b31c9['width']/0x2,_0x2d2143=_0x580971['clientX']<_0x21663a;_0x34fc86['forEach'](_0x5672b3=>_0x5672b3['classList']['remove']('drop-before','drop-after')),_0x4f2243['classList']['add'](_0x2d2143?'drop-before':'drop-after');}),_0x4f2243['addEventListener']('dragleave',()=>{_0x4f2243['classList']['remove']('drop-before','drop-after');}),_0x4f2243['addEventListener']('drop',async _0x4474dd=>{_0x4474dd['preventDefault']();const _0x45c7c8=_0x4474dd['dataTransfer']['getData']('text/plain'),_0x18f4a3=_0x4f2243['dataset']['taskId'];if(_0x45c7c8===_0x18f4a3)return;const _0x16240f=_0x4f2243['getBoundingClientRect'](),_0x415110=_0x4474dd['clientX']<_0x16240f['left']+_0x16240f['width']/0x2;_0x4f2243['classList']['remove']('drop-before','drop-after'),_0x25ff2a&&await _0x25ff2a(_0x45c7c8,_0x18f4a3,_0x415110);});});const _0x23b694=document['createElement']('div');return _0x23b694['className']='task-tab-remove-zone',_0x23b694['innerHTML']='\x0a\x20\x20\x20\x20<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20<path\x20d=\x22M18\x206L6\x2018M6\x206l12\x2012\x22/>\x0a\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20<span>Remove\x20from\x20group</span>\x0a\x20\x20',_0x23b694['style']['display']='none',_0x23b694['addEventListener']('dragover',_0x26d19e=>{_0x26d19e['preventDefault'](),_0x23b694['classList']['add']('drag-over');}),_0x23b694['addEventListener']('dragleave',()=>{_0x23b694['classList']['remove']('drag-over');}),_0x23b694['addEventListener']('drop',async _0x58ce5d=>{_0x58ce5d['preventDefault'](),_0x23b694['classList']['remove']('drag-over');const _0x26c569=_0x58ce5d['dataTransfer']['getData']('text/plain');_0x87a6a9&&await _0x87a6a9(_0x26c569);}),_0x141896['addEventListener']('dragstart',()=>{_0x5a9713['length']>0x1&&(_0x23b694['style']['display']='flex');}),_0x141896['addEventListener']('dragend',()=>{_0x23b694['style']['display']='none';}),_0x141896['appendChild'](_0x23b694),{'destroy':()=>{_0x23b694['remove']();}};}export default VariantGroupingManager;
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(_0x1ef811={}){this['container']=null,this['onGroupChange']=_0x1ef811['onGroupChange']||(()=>{}),this['onAddExistingTask']=_0x1ef811['onAddExistingTask']||(()=>{}),this['tasks']=[],this['groupId']=_0x1ef811['groupId']||null,this['isOpen']=![];}['init'](_0x375e59,_0x5cd857,_0x21251a){this['container']=_0x375e59,this['tasks']=_0x5cd857,this['groupId']=_0x21251a,this['render'](),this['attachEventListeners']();}['updateTasks'](_0x4ed2b3){const _0x3ad658=new Map(_0x4ed2b3['map'](_0x45c91b=>[_0x45c91b['taskId'],_0x45c91b]));this['tasks']=this['tasks']['map'](_0x33b690=>{const _0x4ff311=_0x3ad658['get'](_0x33b690['taskId']);return _0x4ff311?_0x4ff311:_0x33b690;});for(const _0x134513 of _0x4ed2b3){!this['tasks']['some'](_0x2e1727=>_0x2e1727['taskId']===_0x134513['taskId'])&&this['tasks']['push'](_0x134513);}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 _0x5269e4=this['tasks']['filter'](_0xc46e30=>_0xc46e30['groupId']===this['groupId'])['sort']((_0x30b6bb,_0x897237)=>(_0x30b6bb['groupIndex']??0x0)-(_0x897237['groupIndex']??0x0)),_0x3745fe=this['tasks']['filter'](_0x134edc=>!_0x134edc['groupId']||_0x134edc['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>'+_0x5269e4['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'+(_0x5269e4['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20add\x20to\x20group</div>':_0x5269e4['map']((_0x253a19,_0x272161)=>this['renderVariantCard'](_0x253a19,_0x272161,!![]))['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>'+_0x3745fe['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'+(_0x3745fe['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20remove\x20from\x20group</div>':_0x3745fe['map']((_0x450cc9,_0xac6559)=>this['renderVariantCard'](_0x450cc9,_0xac6559,![]))['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'](_0x57b101,_0x34bcaa,_0x17ffb5){const _0x4e8165=_0x57b101['envVars']?.['CODER_AGENT']||_0x57b101['envVars']?.['default_agent']||'claude',_0x55b0d0=AGENT_ICONS[_0x4e8165['toLowerCase']()]||AGENT_ICONS['claude'],_0x24b137=STATUS_ICONS[_0x57b101['status']]||'',_0xff27ad='status-'+(_0x57b101['status']||'unknown'),_0x235932=_0x57b101['isWinner']?'<span\x20class=\x22vgm-badge\x20vgm-badge-winner\x22\x20title=\x22Winner\x22>★</span>':'',_0x4d0fb7=_0x57b101['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'+_0xff27ad+'\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'+_0x57b101['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-is-grouped=\x22'+_0x17ffb5+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-index=\x22'+_0x34bcaa+'\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'+_0x4e8165['toLowerCase']()+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x55b0d0+'\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'](_0x57b101['name']||'Task\x20'+_0x57b101['taskId']['slice'](-0x6))+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-meta\x22>'+Utils['escapeHtml'](_0x4e8165)+'\x20·\x20'+(_0x57b101['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'+_0x235932+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x4d0fb7+'\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'+_0xff27ad+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x24b137+'\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'+(_0x17ffb5?'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'+_0x57b101['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-action=\x22'+(_0x17ffb5?'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'+(_0x17ffb5?'<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',_0x9c0796=>{_0x9c0796['target']['closest']('.vgm-close-btn')&&(this['close'](),this['onGroupChange'](this['tasks'])),_0x9c0796['target']['closest']('.vgm-add-existing-btn')&&(this['close'](),this['onAddExistingTask'](this['groupId']));}),this['container']['addEventListener']('click',async _0x471c1b=>{const _0x369180=_0x471c1b['target']['closest']('.vgm-variant-remove-btn');if(!_0x369180)return;const _0x52b929=_0x369180['dataset']['taskId'],_0x2628ce=_0x369180['dataset']['action'];try{_0x2628ce==='remove'?await this['removeFromGroup'](_0x52b929):await this['addToGroup'](_0x52b929);}catch(_0x27e500){console['error']('Failed\x20to\x20update\x20group:',_0x27e500),Utils['showToast'](_0x27e500['message']||'Failed\x20to\x20update\x20group','error');}}),this['container']['addEventListener']('dragstart',_0x37dacc=>this['handleDragStart'](_0x37dacc)),this['container']['addEventListener']('dragend',_0x52e360=>this['handleDragEnd'](_0x52e360)),this['container']['addEventListener']('dragover',_0x102003=>this['handleDragOver'](_0x102003)),this['container']['addEventListener']('dragleave',_0x8fab1f=>this['handleDragLeave'](_0x8fab1f)),this['container']['addEventListener']('drop',_0x461f5e=>this['handleDrop'](_0x461f5e));}['handleDragStart'](_0x3accd0){const _0x246357=_0x3accd0['target']['closest']('.vgm-variant-card');if(!_0x246357)return;dragState['draggedTaskId']=_0x246357['dataset']['taskId'],dragState['draggedElement']=_0x246357,dragState['sourceGroupId']=_0x246357['dataset']['isGrouped']==='true'?this['groupId']:null,dragState['isDragging']=!![],_0x246357['classList']['add']('dragging'),_0x3accd0['dataTransfer']['effectAllowed']='move',_0x3accd0['dataTransfer']['setData']('text/plain',_0x246357['dataset']['taskId']),this['container']['classList']['add']('is-dragging');}['handleDragEnd'](_0x38d4e1){const _0x1e4ed1=_0x38d4e1['target']['closest']('.vgm-variant-card');_0x1e4ed1&&_0x1e4ed1['classList']['remove']('dragging'),this['container']['querySelectorAll']('.drag-over,\x20.drop-indicator')['forEach'](_0x30a029=>{_0x30a029['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'](_0x3c2c57){_0x3c2c57['preventDefault'](),_0x3c2c57['dataTransfer']['dropEffect']='move';const _0x8ea90f=_0x3c2c57['target']['closest']('.vgm-drop-zone'),_0x5afc3c=_0x3c2c57['target']['closest']('.vgm-variant-card');this['container']['querySelectorAll']('.vgm-drop-zone')['forEach'](_0x4e9fb1=>{_0x4e9fb1['classList']['toggle']('drag-over',_0x4e9fb1===_0x8ea90f);});if(_0x5afc3c&&_0x5afc3c!==dragState['draggedElement']){const _0x511ba9=_0x5afc3c['getBoundingClientRect'](),_0x508100=_0x511ba9['top']+_0x511ba9['height']/0x2,_0x1b2e01=_0x3c2c57['clientY']<_0x508100;this['container']['querySelectorAll']('.vgm-variant-card')['forEach'](_0x2081b7=>{_0x2081b7!==_0x5afc3c&&_0x2081b7['classList']['remove']('drop-before','drop-after');}),_0x5afc3c['classList']['toggle']('drop-before',_0x1b2e01),_0x5afc3c['classList']['toggle']('drop-after',!_0x1b2e01);}}['handleDragLeave'](_0x5a4fb7){const _0x4c4741=_0x5a4fb7['target']['closest']('.vgm-drop-zone');_0x4c4741&&!_0x4c4741['contains'](_0x5a4fb7['relatedTarget'])&&_0x4c4741['classList']['remove']('drag-over');}async['handleDrop'](_0x4cf774){_0x4cf774['preventDefault']();const _0x201114=_0x4cf774['target']['closest']('.vgm-drop-zone'),_0x6ac878=_0x4cf774['target']['closest']('.vgm-variant-card'),_0x5ec760=_0x4cf774['dataTransfer']['getData']('text/plain');if(!_0x201114||!_0x5ec760)return;this['container']['querySelectorAll']('.drag-over,\x20.drop-before,\x20.drop-after')['forEach'](_0x2f5541=>{_0x2f5541['classList']['remove']('drag-over','drop-before','drop-after');});const _0x3d8f20=_0x201114['dataset']['zone'],_0x4fc5ef=_0x3d8f20==='grouped',_0x1f48d2=dragState['sourceGroupId']===this['groupId'];try{if(_0x4fc5ef&&!_0x1f48d2){let _0x5712d5=this['tasks']['filter'](_0x5df6bb=>_0x5df6bb['groupId']===this['groupId'])['length'];if(_0x6ac878){const _0x3b3b0d=_0x6ac878['dataset']['taskId'],_0x14959c=this['tasks']['find'](_0x300221=>_0x300221['taskId']===_0x3b3b0d);if(_0x14959c?.['groupIndex']!==undefined){const _0x18609e=_0x6ac878['getBoundingClientRect'](),_0x37fea6=_0x4cf774['clientY']<_0x18609e['top']+_0x18609e['height']/0x2;_0x5712d5=_0x14959c['groupIndex']+(_0x37fea6?0x0:0x1);}}await this['addToGroup'](_0x5ec760,_0x5712d5);}else{if(!_0x4fc5ef&&_0x1f48d2)await this['removeFromGroup'](_0x5ec760);else _0x4fc5ef&&_0x1f48d2&&_0x6ac878&&await this['reorderInGroup'](_0x5ec760,_0x6ac878,_0x4cf774['clientY']);}}catch(_0x412713){console['error']('Drop\x20operation\x20failed:',_0x412713),Utils['showToast'](_0x412713['message']||'Failed\x20to\x20move\x20variant','error');}}async['addToGroup'](_0x5ae32d,_0x91d6b1){const _0x2b8d63=this['tasks']['find'](_0x2adde2=>_0x2adde2['taskId']===_0x5ae32d);if(!_0x2b8d63)return;_0x91d6b1===undefined&&(_0x91d6b1=this['tasks']['filter'](_0x9c91e5=>_0x9c91e5['groupId']===this['groupId'])['length']),!this['groupId']&&(this['groupId']=API['generateGroupId'](),await API['createTaskGroup']({'groupId':this['groupId']})),await API['updateTaskGroup'](_0x5ae32d,this['groupId'],_0x91d6b1),_0x2b8d63['groupId']=this['groupId'],_0x2b8d63['groupIndex']=_0x91d6b1,this['render'](),this['onGroupChange'](this['tasks']);}async['removeFromGroup'](_0x1edc6f){const _0x5f16a8=this['tasks']['find'](_0x20549d=>_0x20549d['taskId']===_0x1edc6f);if(!_0x5f16a8)return;await API['removeTaskFromGroup'](_0x1edc6f),_0x5f16a8['groupId']=null,_0x5f16a8['groupIndex']=null,this['render'](),this['onGroupChange'](this['tasks']);}async['reorderInGroup'](_0x41a173,_0x3482d7,_0x3dfac9){const _0x11e016=this['tasks']['find'](_0x128125=>_0x128125['taskId']===_0x41a173),_0x243490=_0x3482d7['dataset']['taskId'],_0x351471=this['tasks']['find'](_0x3ac902=>_0x3ac902['taskId']===_0x243490);if(!_0x11e016||!_0x351471||_0x11e016['taskId']===_0x351471['taskId'])return;const _0x5dd43b=_0x3482d7['getBoundingClientRect'](),_0x4d0a6e=_0x3dfac9<_0x5dd43b['top']+_0x5dd43b['height']/0x2;let _0x3125ca=_0x351471['groupIndex']??0x0;if(!_0x4d0a6e)_0x3125ca++;if((_0x11e016['groupIndex']??0x0)<(_0x351471['groupIndex']??0x0))_0x3125ca--;if(_0x3125ca===_0x11e016['groupIndex'])return;await API['updateTaskGroup'](_0x41a173,this['groupId'],_0x3125ca);const _0x4b95cf=this['tasks']['filter'](_0x509ce4=>_0x509ce4['groupId']===this['groupId'])['sort']((_0x27a036,_0xa96d09)=>(_0x27a036['groupIndex']??0x0)-(_0xa96d09['groupIndex']??0x0)),_0x531c93=_0x4b95cf['findIndex'](_0x344052=>_0x344052['taskId']===_0x41a173);_0x531c93!==-0x1&&_0x4b95cf['splice'](_0x531c93,0x1),_0x4b95cf['splice'](_0x3125ca,0x0,_0x11e016),_0x4b95cf['forEach']((_0x2787d9,_0x2733cd)=>{_0x2787d9['groupIndex']=_0x2733cd;}),this['render'](),this['onGroupChange'](this['tasks']);}}export function initializeTabDragDrop(_0x19fa2a,_0x720ca1,_0x123e77,_0x507ec4={}){if(!_0x19fa2a)return;const {onReorder:_0x2100ed,onRemove:_0x1127b3}=_0x507ec4,_0x30f8aa=_0x19fa2a['querySelectorAll']('.task-tab');_0x30f8aa['forEach']((_0x1c1af8,_0x4766b3)=>{_0x1c1af8['setAttribute']('draggable','true'),_0x1c1af8['dataset']['index']=_0x4766b3,_0x1c1af8['addEventListener']('dragstart',_0x504bd0=>{_0x504bd0['dataTransfer']['effectAllowed']='move',_0x504bd0['dataTransfer']['setData']('text/plain',_0x1c1af8['dataset']['taskId']),_0x1c1af8['classList']['add']('dragging'),_0x19fa2a['classList']['add']('is-dragging');}),_0x1c1af8['addEventListener']('dragend',()=>{_0x1c1af8['classList']['remove']('dragging'),_0x19fa2a['classList']['remove']('is-dragging'),_0x19fa2a['querySelectorAll']('.drop-indicator')['forEach'](_0x42bbcd=>{_0x42bbcd['classList']['remove']('drop-indicator','drop-before','drop-after');});}),_0x1c1af8['addEventListener']('dragover',_0x1290fd=>{_0x1290fd['preventDefault'](),_0x1290fd['dataTransfer']['dropEffect']='move';if(_0x1c1af8['classList']['contains']('dragging'))return;const _0x4d4ae7=_0x1c1af8['getBoundingClientRect'](),_0x4a0082=_0x4d4ae7['left']+_0x4d4ae7['width']/0x2,_0x47ddb3=_0x1290fd['clientX']<_0x4a0082;_0x30f8aa['forEach'](_0x404d40=>_0x404d40['classList']['remove']('drop-before','drop-after')),_0x1c1af8['classList']['add'](_0x47ddb3?'drop-before':'drop-after');}),_0x1c1af8['addEventListener']('dragleave',()=>{_0x1c1af8['classList']['remove']('drop-before','drop-after');}),_0x1c1af8['addEventListener']('drop',async _0x373d90=>{_0x373d90['preventDefault']();const _0x2c62d9=_0x373d90['dataTransfer']['getData']('text/plain'),_0x47c88a=_0x1c1af8['dataset']['taskId'];if(_0x2c62d9===_0x47c88a)return;const _0x34e3ef=_0x1c1af8['getBoundingClientRect'](),_0x5d0393=_0x373d90['clientX']<_0x34e3ef['left']+_0x34e3ef['width']/0x2;_0x1c1af8['classList']['remove']('drop-before','drop-after'),_0x2100ed&&await _0x2100ed(_0x2c62d9,_0x47c88a,_0x5d0393);});});const _0x2e41d9=document['createElement']('div');return _0x2e41d9['className']='task-tab-remove-zone',_0x2e41d9['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',_0x2e41d9['style']['display']='none',_0x2e41d9['addEventListener']('dragover',_0x2cfe29=>{_0x2cfe29['preventDefault'](),_0x2e41d9['classList']['add']('drag-over');}),_0x2e41d9['addEventListener']('dragleave',()=>{_0x2e41d9['classList']['remove']('drag-over');}),_0x2e41d9['addEventListener']('drop',async _0x3d638d=>{_0x3d638d['preventDefault'](),_0x2e41d9['classList']['remove']('drag-over');const _0x49229e=_0x3d638d['dataTransfer']['getData']('text/plain');_0x1127b3&&await _0x1127b3(_0x49229e);}),_0x19fa2a['addEventListener']('dragstart',()=>{_0x720ca1['length']>0x1&&(_0x2e41d9['style']['display']='flex');}),_0x19fa2a['addEventListener']('dragend',()=>{_0x2e41d9['style']['display']='none';}),_0x19fa2a['appendChild'](_0x2e41d9),{'destroy':()=>{_0x2e41d9['remove']();}};}export default VariantGroupingManager;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@profoundlogic/coderflow-server",
3
- "version": "0.8.4",
3
+ "version": "0.8.5",
4
4
  "description": "AI Coder Server - Manages Docker containers for AI agent task execution",
5
5
  "main": "dist/start.js",
6
6
  "type": "module",