@profoundlogic/coderflow-server 0.8.0 → 0.8.1

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 (184) hide show
  1. package/dist/base-image/coder-git-credential-helper +16 -0
  2. package/dist/base-image/sync-repos.sh +30 -1
  3. package/dist/coder-server.js +1 -1
  4. package/dist/config.js +1 -1
  5. package/dist/lib/agent-keepalive.js +1 -1
  6. package/dist/lib/agent-models.js +1 -1
  7. package/dist/lib/api-keys.js +1 -1
  8. package/dist/lib/apiKeys.js +1 -1
  9. package/dist/lib/app-server-ports.js +1 -1
  10. package/dist/lib/auto-judge.js +1 -1
  11. package/dist/lib/automation-service.js +1 -1
  12. package/dist/lib/basic-auth.js +1 -1
  13. package/dist/lib/bindings.js +1 -1
  14. package/dist/lib/build-history.js +1 -1
  15. package/dist/lib/build-output-service.js +1 -1
  16. package/dist/lib/build-scheduler.js +1 -1
  17. package/dist/lib/build-service.js +1 -1
  18. package/dist/lib/ca-certificates.js +1 -1
  19. package/dist/lib/claude-oauth-refresh.js +1 -1
  20. package/dist/lib/cli/build.js +1 -1
  21. package/dist/lib/cli/cleanup-users.js +1 -1
  22. package/dist/lib/cli/config-command.js +1 -1
  23. package/dist/lib/cli/config.js +1 -1
  24. package/dist/lib/cli/create-user.js +1 -1
  25. package/dist/lib/cli/grant-admin.js +1 -1
  26. package/dist/lib/cli/init.js +1 -1
  27. package/dist/lib/cli/jira.js +1 -1
  28. package/dist/lib/cli/license.js +1 -1
  29. package/dist/lib/cli/list-roles.js +1 -1
  30. package/dist/lib/cli/list-users.js +1 -1
  31. package/dist/lib/cli/server-manager.js +1 -1
  32. package/dist/lib/cli/set-password.js +1 -1
  33. package/dist/lib/compression-filter.js +1 -1
  34. package/dist/lib/config-migration.js +1 -1
  35. package/dist/lib/container-credential-sync.js +1 -1
  36. package/dist/lib/container-tokens.js +1 -1
  37. package/dist/lib/data-dir.js +1 -1
  38. package/dist/lib/deployment-history.js +1 -1
  39. package/dist/lib/deployment-service.js +1 -1
  40. package/dist/lib/docker-utils.js +1 -1
  41. package/dist/lib/email.js +1 -1
  42. package/dist/lib/emailTemplates.js +1 -1
  43. package/dist/lib/entitlement.js +1 -1
  44. package/dist/lib/external-connections.js +1 -1
  45. package/dist/lib/fetch-utils.js +1 -1
  46. package/dist/lib/git-commit-details-route.js +1 -1
  47. package/dist/lib/git-history-diff-guardrails.js +1 -1
  48. package/dist/lib/git-provider-service.js +1 -1
  49. package/dist/lib/git-provider-setup/github-setup-handler.js +1 -1
  50. package/dist/lib/git-provider-setup/index.js +1 -1
  51. package/dist/lib/git-provider-setup/setup-factory.js +1 -1
  52. package/dist/lib/git-provider-setup/setup-interface.js +1 -1
  53. package/dist/lib/git-providers/azure-devops-provider.js +1 -1
  54. package/dist/lib/git-providers/github-app-provider.js +1 -1
  55. package/dist/lib/git-providers/index.js +1 -1
  56. package/dist/lib/git-providers/provider-factory.js +1 -1
  57. package/dist/lib/git-providers/provider-interface.js +1 -1
  58. package/dist/lib/github-urls.js +1 -1
  59. package/dist/lib/group-objective-linking.js +1 -1
  60. package/dist/lib/ibmi-sync.js +1 -1
  61. package/dist/lib/jira-client.js +1 -1
  62. package/dist/lib/judge-blinding.js +1 -1
  63. package/dist/lib/logger.js +1 -1
  64. package/dist/lib/memory-utils.js +1 -1
  65. package/dist/lib/migration-to-scoped-rbac.js +1 -1
  66. package/dist/lib/model-fetcher.js +1 -1
  67. package/dist/lib/notifications.js +1 -1
  68. package/dist/lib/objective-context.js +1 -1
  69. package/dist/lib/oidc-auth.js +1 -1
  70. package/dist/lib/oidc-device-flow.js +1 -1
  71. package/dist/lib/passwordTokens.js +1 -1
  72. package/dist/lib/permission-resolver.js +1 -1
  73. package/dist/lib/pin-cascade.js +1 -1
  74. package/dist/lib/provider-accounts.js +1 -1
  75. package/dist/lib/provider-oauth.js +1 -1
  76. package/dist/lib/provider-profile.js +1 -1
  77. package/dist/lib/provider-token-refresh.js +1 -1
  78. package/dist/lib/rbac-user-state.js +1 -1
  79. package/dist/lib/request-url.js +1 -1
  80. package/dist/lib/rewind.js +1 -1
  81. package/dist/lib/role-definitions.js +1 -1
  82. package/dist/lib/roles.js +1 -1
  83. package/dist/lib/secrets.js +1 -1
  84. package/dist/lib/setup-repo-git-auth.js +1 -1
  85. package/dist/lib/state-capture.js +1 -1
  86. package/dist/lib/static-files.js +1 -1
  87. package/dist/lib/task-aliases.js +1 -1
  88. package/dist/lib/task-container-init.js +1 -1
  89. package/dist/lib/task-context-usage.js +1 -1
  90. package/dist/lib/task-name-format.js +1 -1
  91. package/dist/lib/task-name-generator.js +1 -1
  92. package/dist/lib/task-source-metadata.js +1 -1
  93. package/dist/lib/teams.js +1 -1
  94. package/dist/lib/user-git-oauth.js +1 -1
  95. package/dist/lib/user-git-tokens.js +1 -1
  96. package/dist/lib/users.js +1 -1
  97. package/dist/middleware/requireAuth.js +1 -1
  98. package/dist/middleware/requireInit.js +1 -1
  99. package/dist/middleware/requirePermission.js +1 -1
  100. package/dist/package.json +1 -1
  101. package/dist/playwright.config.js +1 -1
  102. package/dist/playwright.task-terminal.config.js +1 -1
  103. package/dist/routes/apiKeys.js +1 -1
  104. package/dist/routes/auth-oidc.js +1 -1
  105. package/dist/routes/auth.js +1 -1
  106. package/dist/routes/automations.js +1 -1
  107. package/dist/routes/bindings.js +1 -1
  108. package/dist/routes/build.js +1 -1
  109. package/dist/routes/containers.js +1 -1
  110. package/dist/routes/deploy-task.js +1 -1
  111. package/dist/routes/environment-management.js +1 -1
  112. package/dist/routes/environments.js +1 -1
  113. package/dist/routes/external-skills.js +1 -1
  114. package/dist/routes/git-credentials.js +1 -1
  115. package/dist/routes/git-oauth.js +1 -1
  116. package/dist/routes/git-provider-setup.js +1 -1
  117. package/dist/routes/health.js +1 -1
  118. package/dist/routes/jira.js +1 -1
  119. package/dist/routes/logs.js +1 -1
  120. package/dist/routes/objective-management.js +1 -1
  121. package/dist/routes/password.js +1 -1
  122. package/dist/routes/prompt.js +1 -1
  123. package/dist/routes/provider-auth.js +1 -1
  124. package/dist/routes/qa.js +1 -1
  125. package/dist/routes/roles.js +1 -1
  126. package/dist/routes/settings.js +1 -1
  127. package/dist/routes/skill-management.js +1 -1
  128. package/dist/routes/skills.js +1 -1
  129. package/dist/routes/stats.js +1 -1
  130. package/dist/routes/tasks.js +1 -1
  131. package/dist/routes/teams.js +1 -1
  132. package/dist/routes/templates.js +1 -1
  133. package/dist/routes/test-task.js +1 -1
  134. package/dist/routes/test.js +1 -1
  135. package/dist/routes/users.js +1 -1
  136. package/dist/routes/visualizations.js +1 -1
  137. package/dist/scripts/create-user.js +1 -1
  138. package/dist/scripts/migrate-config-to-data-dir.js +1 -1
  139. package/dist/start.js +1 -1
  140. package/dist/web-ui/public/activity-detail-modal.js +1 -1
  141. package/dist/web-ui/public/activity-feed.js +1 -1
  142. package/dist/web-ui/public/activity-formatters.js +1 -1
  143. package/dist/web-ui/public/admin.css +95 -1
  144. package/dist/web-ui/public/admin.html +29 -1
  145. package/dist/web-ui/public/admin.js +1 -1
  146. package/dist/web-ui/public/agent-event-parser.js +1 -1
  147. package/dist/web-ui/public/app.js +1 -1
  148. package/dist/web-ui/public/approve-dialog.js +1 -1
  149. package/dist/web-ui/public/automation-links.js +1 -1
  150. package/dist/web-ui/public/automation-schedule.js +1 -1
  151. package/dist/web-ui/public/comments-widget.js +1 -1
  152. package/dist/web-ui/public/diff-utils.js +1 -1
  153. package/dist/web-ui/public/environments.js +1 -1
  154. package/dist/web-ui/public/feedback-widget.css +45 -0
  155. package/dist/web-ui/public/feedback-widget.js +1 -1
  156. package/dist/web-ui/public/file-selection-tree.js +1 -1
  157. package/dist/web-ui/public/git-history-lazy-utils.js +1 -1
  158. package/dist/web-ui/public/git-history.js +1 -1
  159. package/dist/web-ui/public/git-status.js +1 -1
  160. package/dist/web-ui/public/ibmi-file-filter.js +1 -1
  161. package/dist/web-ui/public/index.js +1 -1
  162. package/dist/web-ui/public/login.js +1 -1
  163. package/dist/web-ui/public/markdown-editor.js +1 -1
  164. package/dist/web-ui/public/markdown-file-editor.js +1 -1
  165. package/dist/web-ui/public/modal-maximize.js +1 -1
  166. package/dist/web-ui/public/notifications.js +1 -1
  167. package/dist/web-ui/public/permissions.js +1 -1
  168. package/dist/web-ui/public/pr-dialog.js +1 -1
  169. package/dist/web-ui/public/roles.js +1 -1
  170. package/dist/web-ui/public/settings.js +1 -1
  171. package/dist/web-ui/public/setup-password.js +1 -1
  172. package/dist/web-ui/public/skills.js +1 -1
  173. package/dist/web-ui/public/sse-client.js +1 -1
  174. package/dist/web-ui/public/sse-shared-worker.js +1 -1
  175. package/dist/web-ui/public/styles.css +45 -0
  176. package/dist/web-ui/public/task-judging-helpers.js +1 -1
  177. package/dist/web-ui/public/task.html +25 -2
  178. package/dist/web-ui/public/task.js +1 -1
  179. package/dist/web-ui/public/teams.js +1 -1
  180. package/dist/web-ui/public/terminal.js +1 -1
  181. package/dist/web-ui/public/theme.js +1 -1
  182. package/dist/web-ui/public/users.js +1 -1
  183. package/dist/web-ui/public/variant-grouping.js +1 -1
  184. 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 _0x27daf9=state['currentUser'];if(!Permissions['hasServerPermission'](_0x27daf9,'teams:view')&&!Permissions['hasTeamPermission'](_0x27daf9,'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'](_0x27daf9,'*')||Permissions['hasTeamPermission'](_0x27daf9,'teams:manage'))&&(document['getElementById']('create-team-btn')['hidden']=![]),bindEventListeners(),await Promise['all']([loadTeams(),loadUsers(),loadRoles(),loadEnvironments()]),renderTeams();});async function loadTeams(){const _0x33e1ec=document['getElementById']('teams-loading'),_0x3bb47c=document['getElementById']('teams-error'),_0x467e0c=document['getElementById']('teams-content');try{_0x33e1ec['hidden']=![],_0x3bb47c['hidden']=!![],_0x467e0c['hidden']=!![];const {teams:_0x366105}=await API['getTeams']();state['teams']=_0x366105||[],renderTeams(),_0x33e1ec['hidden']=!![],_0x467e0c['hidden']=![];}catch(_0x55e4f5){_0x33e1ec['hidden']=!![],_0x3bb47c['hidden']=![],document['getElementById']('teams-error-message')['textContent']=_0x55e4f5['message'];}}async function loadUsers(){try{const {users:_0xb48d6f}=await API['getUsers']();state['users']=_0xb48d6f||[];}catch{state['users']=[];}}async function loadRoles(){try{const {roles:_0x199d20}=await API['getRoleDefinitions']();state['roles']=_0x199d20||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x2855bf=await API['getEnvironments']();state['environments']=_0x2855bf['environments']||[];}catch{state['environments']=[];}}function renderTeams(){const _0x1a23f9=document['getElementById']('teams-table-body'),_0x5ebb70=document['getElementById']('team-count');if(!_0x1a23f9)return;_0x5ebb70&&(_0x5ebb70['textContent']=state['teams']['length']+'\x20team'+(state['teams']['length']===0x1?'':'s'));if(state['teams']['length']===0x0){_0x1a23f9['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 _0x16b75f=Permissions['hasServerPermission'](state['currentUser'],'*');_0x1a23f9['innerHTML']=state['teams']['map'](_0x1ae482=>{const _0x329829=_0x16b75f||_0x1ae482['canManageTeam'],_0x7c0c48=_0x16b75f||_0x1ae482['canManageMembers'],_0x165fd8=_0x329829||_0x7c0c48,_0x34c040=(_0x1ae482['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'](_0x1ae482['name'])+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x1ae482['description']?'<div\x20style=\x22font-size:\x200.8em;\x20color:\x20var(--color-text-secondary);\x20margin-top:\x200.15rem;\x22>'+Utils['escapeHtml'](_0x1ae482['description'])+'</div>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+_0x34c040+'</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'+(_0x165fd8?'<button\x20class=\x22btn-icon\x22\x20title=\x22Edit\x20team\x22\x20onclick=\x22window.openTeamModal(\x27'+_0x1ae482['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'+(_0x329829?'<button\x20class=\x22btn-icon\x22\x20title=\x22Access\x20bindings\x22\x20onclick=\x22window.openBindingsModal(\x27'+_0x1ae482['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'+(_0x329829?'<button\x20class=\x22btn-icon\x20btn-danger\x22\x20title=\x22Delete\x20team\x22\x20onclick=\x22window.deleteTeam(\x27'+_0x1ae482['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(_0x970885){const _0x50d12b=state['teams']['find'](_0x3241f6=>_0x3241f6['id']===_0x970885);if(!_0x50d12b)return;state['editingTeamId']=_0x970885;const _0x42755e=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x546e1c=_0x42755e||_0x50d12b['canManageTeam'],_0x54e7d8=_0x42755e||_0x50d12b['canManageMembers'],_0xc1f167=_0x546e1c,_0x3f9db8=_0x546e1c||_0x54e7d8,_0x2ffeb7=_0x50d12b['name'],_0x2f94df=_0x50d12b['description']||'';state['modalSnapshot']={'name':_0x2ffeb7,'description':_0x2f94df},document['getElementById']('team-modal-title')['textContent']=_0x2ffeb7,document['getElementById']('team-name')['value']=_0x2ffeb7,document['getElementById']('team-name')['disabled']=!_0xc1f167,document['getElementById']('team-description')['value']=_0x2f94df,document['getElementById']('team-description')['disabled']=!_0xc1f167,document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=![],document['getElementById']('save-team')['hidden']=!_0xc1f167,renderMembersList(_0x50d12b),updateMemberSelect(_0x50d12b),document['getElementById']('team-modal')['hidden']=![];};function isTeamModalDirty(){if(!state['modalSnapshot'])return![];const _0x24e8ae=document['getElementById']('team-name')['value']['trim'](),_0x3e0cb9=document['getElementById']('team-description')['value']['trim']();return _0x24e8ae!==state['modalSnapshot']['name']||_0x3e0cb9!==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(_0x4d652c){const _0x200c0d=state['teams']['find'](_0x1ab4ea=>_0x1ab4ea['id']===_0x4d652c);if(!_0x200c0d)return;state['bindingsTeamId']=_0x4d652c,document['getElementById']('bindings-modal-title')['textContent']='Access\x20Bindings\x20—\x20'+_0x200c0d['name'],document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('bindings-modal')['hidden']=![],loadTeamBindings(_0x4d652c);};function hideBindingsModal(){document['getElementById']('bindings-modal')['hidden']=!![],state['bindingsTeamId']=null;}function renderMembersList(_0x557667){const _0x136d12=Permissions['hasServerPermission'](state['currentUser'],'*'),_0xae321e=_0x136d12||_0x557667['canManageMembers']||_0x557667['canManageTeam'],_0x4ff7a5=_0x557667['members']||[],_0xcd8369=document['getElementById']('members-list');if(_0x4ff7a5['length']===0x0){_0xcd8369['innerHTML']='<p\x20style=\x22font-size:\x200.875rem;\x20color:\x20var(--color-text-secondary);\x20margin:\x200.25rem\x200;\x22>No\x20members\x20yet</p>';return;}_0xcd8369['innerHTML']=_0x4ff7a5['map'](_0x534059=>{const _0x5b91a5=state['users']['find'](_0x52e11c=>_0x52e11c['id']===_0x534059),_0x3d3a9d=_0x5b91a5?''+Utils['escapeHtml'](_0x5b91a5['username'])+(_0x5b91a5['name']?'\x20<span\x20style=\x22color:\x20var(--color-text-secondary);\x20font-size:\x200.85em;\x22>('+Utils['escapeHtml'](_0x5b91a5['name'])+')</span>':''):Utils['escapeHtml'](_0x534059);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'+_0x3d3a9d+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0xae321e?'<button\x20type=\x22button\x22\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.removeMemberClick(\x27'+_0x534059+'\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 _0x5b07d2=document['getElementById']('add-member-row');if(_0x5b07d2)_0x5b07d2['style']['display']=_0xae321e?'flex':'none';}function updateMemberSelect(_0x4142cc){const _0x3a6841=document['getElementById']('add-member-select');if(!_0x3a6841)return;const _0x43d141=new Set(_0x4142cc['members']||[]),_0x2f38a9=state['users']['filter'](_0x32b5ba=>!_0x43d141['has'](_0x32b5ba['id']));_0x3a6841['innerHTML']='<option\x20value=\x22\x22>Add\x20a\x20member…</option>'+_0x2f38a9['map'](_0x4c9f12=>'<option\x20value=\x22'+_0x4c9f12['id']+'\x22>'+Utils['escapeHtml'](_0x4c9f12['username'])+(_0x4c9f12['name']?'\x20('+Utils['escapeHtml'](_0x4c9f12['name'])+')':'')+'</option>')['join']('');}async function addMember(){const _0x40c715=document['getElementById']('add-member-select'),_0x28cae5=_0x40c715['value'];if(!_0x28cae5||!state['editingTeamId'])return;try{const {team:_0x3f5c8d}=await API['addTeamMember'](state['editingTeamId'],_0x28cae5);syncTeamInState(_0x3f5c8d),renderMembersList(_0x3f5c8d),updateMemberSelect(_0x3f5c8d),_0x40c715['value']='',Utils['showToast']('Member\x20added','success');}catch(_0x43ca65){Utils['showToast'](_0x43ca65['message'],'error');}}window['removeMemberClick']=async function(_0x179b4f){if(!state['editingTeamId'])return;try{const {team:_0x4aad07}=await API['removeTeamMember'](state['editingTeamId'],_0x179b4f);syncTeamInState(_0x4aad07),renderMembersList(_0x4aad07),updateMemberSelect(_0x4aad07),Utils['showToast']('Member\x20removed','success');}catch(_0x2598eb){Utils['showToast'](_0x2598eb['message'],'error');}};async function loadTeamBindings(_0x30332a){const _0x1b134d=document['getElementById']('bindings-loading'),_0x4e19f2=document['getElementById']('bindings-empty'),_0x558d8b=document['getElementById']('bindings-list-container'),_0x38b343=document['getElementById']('add-binding-btn');_0x1b134d['hidden']=![],_0x4e19f2['hidden']=!![],_0x558d8b['style']['display']='none',_0x38b343['hidden']=!![],document['getElementById']('add-binding-form')['hidden']=!![];try{const {bindings:_0x17eb8d}=await API['getBindings']({'subject_type':'team','subject_id':_0x30332a});state['teamBindings']=_0x17eb8d||[],_0x1b134d['hidden']=!![],state['teamBindings']['length']===0x0?_0x4e19f2['hidden']=![]:(_0x558d8b['style']['display']='',renderBindingsTable()),(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage'))&&(_0x38b343['hidden']=![]);}catch(_0x406d30){_0x1b134d['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x406d30['message'],'error');}}function renderBindingsTable(){const _0x4781d2=document['getElementById']('bindings-table-body');if(!_0x4781d2)return;const _0x3bc832=Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage');_0x4781d2['innerHTML']=state['teamBindings']['map'](_0x1a02e1=>{const _0x3cc8e8=_0x1a02e1['resource_type']==='server'?'Server':_0x1a02e1['resource_id']==='*'?'All\x20'+_0x1a02e1['resource_type']+'s':Utils['escapeHtml'](_0x1a02e1['resource_name']||_0x1a02e1['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x3cc8e8+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x1a02e1['role_name']||_0x1a02e1['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x3bc832?'<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteBindingClick(\x27'+_0x1a02e1['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 _0x39a09e=document['getElementById']('binding-resource-type');_0x39a09e['value']='environment',updateBindingFormForResourceType('environment');}function onBindingResourceTypeChange(){const _0x32feee=document['getElementById']('binding-resource-type')['value'];updateBindingFormForResourceType(_0x32feee);}function updateBindingFormForResourceType(_0x12e9e7){const _0x47ae42=document['getElementById']('binding-resource-container'),_0x41a7ff=document['getElementById']('binding-resource'),_0x335c80=document['getElementById']('binding-role');if(_0x12e9e7==='server')_0x47ae42['style']['display']='none';else{_0x47ae42['style']['display']='';if(_0x12e9e7==='environment'){const _0x359e3f=new Set(state['teamBindings']['filter'](_0x25e49f=>_0x25e49f['resource_type']==='environment')['map'](_0x934cd9=>_0x934cd9['resource_id'])),_0xab1fde=state['environments']['filter'](_0x4a53b6=>!_0x359e3f['has'](_0x4a53b6['name']));_0x41a7ff['innerHTML']=_0xab1fde['length']?_0xab1fde['map'](_0x49987a=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x49987a['name'])+'\x22>'+Utils['escapeHtml'](_0x49987a['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x12e9e7==='team'){const _0x24d878=new Set(state['teamBindings']['filter'](_0x2b9962=>_0x2b9962['resource_type']==='team')['map'](_0x6c77f8=>_0x6c77f8['resource_id'])),_0x52011a=state['teams']['filter'](_0x40faaf=>!_0x24d878['has'](_0x40faaf['id']));_0x41a7ff['innerHTML']=_0x52011a['length']?_0x52011a['map'](_0x429960=>'<option\x20value=\x22'+_0x429960['id']+'\x22>'+Utils['escapeHtml'](_0x429960['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x4a6f78=state['roles']['filter'](_0x169732=>_0x169732['resource_type']===_0x12e9e7);_0x335c80['innerHTML']=_0x4a6f78['length']?_0x4a6f78['filter'](_0x4d8647=>{const _0x20adeb=_0x12e9e7==='server'?undefined:_0x41a7ff['value'];return!state['teamBindings']['some'](_0x2e5f07=>_0x2e5f07['resource_type']===_0x12e9e7&&_0x2e5f07['role_id']===_0x4d8647['id']&&(_0x12e9e7==='server'||_0x2e5f07['resource_id']===_0x20adeb));})['map'](_0x4c3f07=>'<option\x20value=\x22'+_0x4c3f07['id']+'\x22>'+Utils['escapeHtml'](_0x4c3f07['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 _0x5c136d=document['getElementById']('binding-resource-type')['value'],_0x5a8636=document['getElementById']('binding-role')['value'];if(!_0x5a8636||!state['bindingsTeamId'])return;const _0x171305=_0x5c136d==='server'?undefined:document['getElementById']('binding-resource')['value'];if(_0x5c136d!=='server'&&!_0x171305)return;const _0x90a7ca=document['getElementById']('save-binding-btn');_0x90a7ca['disabled']=!![],_0x90a7ca['textContent']='Adding…';try{const _0x516117={'subject_type':'team','subject_id':state['bindingsTeamId'],'role_id':_0x5a8636,'resource_type':_0x5c136d};if(_0x171305)_0x516117['resource_id']=_0x171305;await API['createBinding'](_0x516117),Utils['showToast']('Binding\x20added','success'),document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![],await loadTeamBindings(state['bindingsTeamId']);}catch(_0x462796){Utils['showToast'](_0x462796['message'],'error');}finally{_0x90a7ca['disabled']=![],_0x90a7ca['textContent']='Add\x20Binding';}}window['deleteBindingClick']=async function(_0x10d389){try{await API['deleteBinding'](_0x10d389),Utils['showToast']('Binding\x20removed','success'),await loadTeamBindings(state['bindingsTeamId']);}catch(_0x5d5542){Utils['showToast'](_0x5d5542['message'],'error');}};async function saveTeam(){const _0x5438fe=document['getElementById']('team-name')['value']['trim'](),_0x227113=document['getElementById']('team-description')['value']['trim'](),_0x4362d9=document['getElementById']('team-form-error'),_0x393ad8=document['getElementById']('save-team');if(!_0x5438fe){_0x4362d9['textContent']='Team\x20name\x20is\x20required',_0x4362d9['hidden']=![];return;}_0x4362d9['hidden']=!![];const _0x36ea37=_0x393ad8['textContent'];_0x393ad8['disabled']=!![],_0x393ad8['textContent']=state['editingTeamId']?'Saving…':'Creating…';try{if(state['editingTeamId']){const {team:_0x26dda2}=await API['updateTeam'](state['editingTeamId'],{'name':_0x5438fe,'description':_0x227113});syncTeamInState(_0x26dda2),document['getElementById']('team-modal-title')['textContent']=_0x26dda2['name'],Utils['showToast']('Team\x20updated','success');}else await API['createTeam']({'name':_0x5438fe,'description':_0x227113}),Utils['showToast']('Team\x20created','success');_0x393ad8['disabled']=![],_0x393ad8['textContent']=_0x36ea37,hideTeamModal(),await loadTeams();}catch(_0x51d6f2){_0x4362d9['textContent']=_0x51d6f2['message'],_0x4362d9['hidden']=![],_0x393ad8['disabled']=![],_0x393ad8['textContent']=_0x36ea37;}}window['deleteTeam']=function(_0xace9f8){const _0x2bcc9a=state['teams']['find'](_0x42f90e=>_0x42f90e['id']===_0xace9f8);if(!_0x2bcc9a)return;state['deletingTeamId']=_0xace9f8,document['getElementById']('delete-team-name')['textContent']=_0x2bcc9a['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 _0x19365d=document['getElementById']('confirm-delete-team');_0x19365d['disabled']=!![],_0x19365d['textContent']='Deleting…';try{await API['deleteTeam'](state['deletingTeamId']),Utils['showToast']('Team\x20deleted','success'),_0x19365d['disabled']=![],_0x19365d['textContent']='Delete\x20Team',hideDeleteModal(),await loadTeams();}catch(_0x18a613){Utils['showToast']('Failed\x20to\x20delete\x20team:\x20'+_0x18a613['message'],'error'),_0x19365d['disabled']=![],_0x19365d['textContent']='Delete\x20Team';}}function syncTeamInState(_0x2dfc45){const _0x253f5b=state['teams']['findIndex'](_0x183dd4=>_0x183dd4['id']===_0x2dfc45['id']);if(_0x253f5b>=0x0)state['teams'][_0x253f5b]=_0x2dfc45;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 _0x5d8df3=state['currentUser'];if(!Permissions['hasServerPermission'](_0x5d8df3,'teams:view')&&!Permissions['hasTeamPermission'](_0x5d8df3,'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'](_0x5d8df3,'*')||Permissions['hasTeamPermission'](_0x5d8df3,'teams:manage'))&&(document['getElementById']('create-team-btn')['hidden']=![]),bindEventListeners(),await Promise['all']([loadTeams(),loadUsers(),loadRoles(),loadEnvironments()]),renderTeams();});async function loadTeams(){const _0x160620=document['getElementById']('teams-loading'),_0xa62a88=document['getElementById']('teams-error'),_0x3a3f44=document['getElementById']('teams-content');try{_0x160620['hidden']=![],_0xa62a88['hidden']=!![],_0x3a3f44['hidden']=!![];const {teams:_0xb62f30}=await API['getTeams']();state['teams']=_0xb62f30||[],renderTeams(),_0x160620['hidden']=!![],_0x3a3f44['hidden']=![];}catch(_0x3cb67b){_0x160620['hidden']=!![],_0xa62a88['hidden']=![],document['getElementById']('teams-error-message')['textContent']=_0x3cb67b['message'];}}async function loadUsers(){try{const {users:_0x2c0b31}=await API['getUsers']();state['users']=_0x2c0b31||[];}catch{state['users']=[];}}async function loadRoles(){try{const {roles:_0x4a5fa1}=await API['getRoleDefinitions']();state['roles']=_0x4a5fa1||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x2bf2ce=await API['getEnvironments']();state['environments']=_0x2bf2ce['environments']||[];}catch{state['environments']=[];}}function renderTeams(){const _0x4bbaca=document['getElementById']('teams-table-body'),_0x4ad6fd=document['getElementById']('team-count');if(!_0x4bbaca)return;_0x4ad6fd&&(_0x4ad6fd['textContent']=state['teams']['length']+'\x20team'+(state['teams']['length']===0x1?'':'s'));if(state['teams']['length']===0x0){_0x4bbaca['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 _0x2dd89d=Permissions['hasServerPermission'](state['currentUser'],'*');_0x4bbaca['innerHTML']=state['teams']['map'](_0x287287=>{const _0xda29a6=_0x2dd89d||_0x287287['canManageTeam'],_0x46c08f=_0x2dd89d||_0x287287['canManageMembers'],_0x3b2c59=_0xda29a6||_0x46c08f,_0xcf2221=(_0x287287['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'](_0x287287['name'])+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x287287['description']?'<div\x20style=\x22font-size:\x200.8em;\x20color:\x20var(--color-text-secondary);\x20margin-top:\x200.15rem;\x22>'+Utils['escapeHtml'](_0x287287['description'])+'</div>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+_0xcf2221+'</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'+(_0x3b2c59?'<button\x20class=\x22btn-icon\x22\x20title=\x22Edit\x20team\x22\x20onclick=\x22window.openTeamModal(\x27'+_0x287287['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'+(_0xda29a6?'<button\x20class=\x22btn-icon\x22\x20title=\x22Access\x20bindings\x22\x20onclick=\x22window.openBindingsModal(\x27'+_0x287287['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'+(_0xda29a6?'<button\x20class=\x22btn-icon\x20btn-danger\x22\x20title=\x22Delete\x20team\x22\x20onclick=\x22window.deleteTeam(\x27'+_0x287287['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(_0x2b68a8){const _0x4abd9f=state['teams']['find'](_0x23e125=>_0x23e125['id']===_0x2b68a8);if(!_0x4abd9f)return;state['editingTeamId']=_0x2b68a8;const _0x102264=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x1cb947=_0x102264||_0x4abd9f['canManageTeam'],_0x203c37=_0x102264||_0x4abd9f['canManageMembers'],_0x56c658=_0x1cb947,_0x298d7d=_0x1cb947||_0x203c37,_0xc79242=_0x4abd9f['name'],_0x34abe5=_0x4abd9f['description']||'';state['modalSnapshot']={'name':_0xc79242,'description':_0x34abe5},document['getElementById']('team-modal-title')['textContent']=_0xc79242,document['getElementById']('team-name')['value']=_0xc79242,document['getElementById']('team-name')['disabled']=!_0x56c658,document['getElementById']('team-description')['value']=_0x34abe5,document['getElementById']('team-description')['disabled']=!_0x56c658,document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=![],document['getElementById']('save-team')['hidden']=!_0x56c658,renderMembersList(_0x4abd9f),updateMemberSelect(_0x4abd9f),document['getElementById']('team-modal')['hidden']=![];};function isTeamModalDirty(){if(!state['modalSnapshot'])return![];const _0x171f7c=document['getElementById']('team-name')['value']['trim'](),_0x42484d=document['getElementById']('team-description')['value']['trim']();return _0x171f7c!==state['modalSnapshot']['name']||_0x42484d!==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(_0x4e9cfd){const _0x131c0e=state['teams']['find'](_0x2e1a5e=>_0x2e1a5e['id']===_0x4e9cfd);if(!_0x131c0e)return;state['bindingsTeamId']=_0x4e9cfd,document['getElementById']('bindings-modal-title')['textContent']='Access\x20Bindings\x20—\x20'+_0x131c0e['name'],document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('bindings-modal')['hidden']=![],loadTeamBindings(_0x4e9cfd);};function hideBindingsModal(){document['getElementById']('bindings-modal')['hidden']=!![],state['bindingsTeamId']=null;}function renderMembersList(_0xaa535f){const _0x56e961=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x519c8c=_0x56e961||_0xaa535f['canManageMembers']||_0xaa535f['canManageTeam'],_0x29df0c=_0xaa535f['members']||[],_0x36325b=document['getElementById']('members-list');if(_0x29df0c['length']===0x0){_0x36325b['innerHTML']='<p\x20style=\x22font-size:\x200.875rem;\x20color:\x20var(--color-text-secondary);\x20margin:\x200.25rem\x200;\x22>No\x20members\x20yet</p>';return;}_0x36325b['innerHTML']=_0x29df0c['map'](_0x2f91aa=>{const _0x25bd8e=state['users']['find'](_0x5354ad=>_0x5354ad['id']===_0x2f91aa),_0x4740c2=_0x25bd8e?''+Utils['escapeHtml'](_0x25bd8e['username'])+(_0x25bd8e['name']?'\x20<span\x20style=\x22color:\x20var(--color-text-secondary);\x20font-size:\x200.85em;\x22>('+Utils['escapeHtml'](_0x25bd8e['name'])+')</span>':''):Utils['escapeHtml'](_0x2f91aa);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'+_0x4740c2+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x519c8c?'<button\x20type=\x22button\x22\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.removeMemberClick(\x27'+_0x2f91aa+'\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 _0x47e313=document['getElementById']('add-member-row');if(_0x47e313)_0x47e313['style']['display']=_0x519c8c?'flex':'none';}function updateMemberSelect(_0x27b60d){const _0x247038=document['getElementById']('add-member-select');if(!_0x247038)return;const _0xeb0a77=new Set(_0x27b60d['members']||[]),_0xc3a99d=state['users']['filter'](_0x438290=>!_0xeb0a77['has'](_0x438290['id']));_0x247038['innerHTML']='<option\x20value=\x22\x22>Add\x20a\x20member…</option>'+_0xc3a99d['map'](_0x2428ab=>'<option\x20value=\x22'+_0x2428ab['id']+'\x22>'+Utils['escapeHtml'](_0x2428ab['username'])+(_0x2428ab['name']?'\x20('+Utils['escapeHtml'](_0x2428ab['name'])+')':'')+'</option>')['join']('');}async function addMember(){const _0x2ac2b7=document['getElementById']('add-member-select'),_0x156a1f=_0x2ac2b7['value'];if(!_0x156a1f||!state['editingTeamId'])return;try{const {team:_0x48a323}=await API['addTeamMember'](state['editingTeamId'],_0x156a1f);syncTeamInState(_0x48a323),renderMembersList(_0x48a323),updateMemberSelect(_0x48a323),_0x2ac2b7['value']='',Utils['showToast']('Member\x20added','success');}catch(_0x4646d6){Utils['showToast'](_0x4646d6['message'],'error');}}window['removeMemberClick']=async function(_0x402a61){if(!state['editingTeamId'])return;try{const {team:_0x10c9f6}=await API['removeTeamMember'](state['editingTeamId'],_0x402a61);syncTeamInState(_0x10c9f6),renderMembersList(_0x10c9f6),updateMemberSelect(_0x10c9f6),Utils['showToast']('Member\x20removed','success');}catch(_0x348394){Utils['showToast'](_0x348394['message'],'error');}};async function loadTeamBindings(_0x4c5013){const _0x4bb9c3=document['getElementById']('bindings-loading'),_0x4cd3c5=document['getElementById']('bindings-empty'),_0x7330a4=document['getElementById']('bindings-list-container'),_0x463832=document['getElementById']('add-binding-btn');_0x4bb9c3['hidden']=![],_0x4cd3c5['hidden']=!![],_0x7330a4['style']['display']='none',_0x463832['hidden']=!![],document['getElementById']('add-binding-form')['hidden']=!![];try{const {bindings:_0x1fc4db}=await API['getBindings']({'subject_type':'team','subject_id':_0x4c5013});state['teamBindings']=_0x1fc4db||[],_0x4bb9c3['hidden']=!![],state['teamBindings']['length']===0x0?_0x4cd3c5['hidden']=![]:(_0x7330a4['style']['display']='',renderBindingsTable()),(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage'))&&(_0x463832['hidden']=![]);}catch(_0x1f222b){_0x4bb9c3['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x1f222b['message'],'error');}}function renderBindingsTable(){const _0x5e713d=document['getElementById']('bindings-table-body');if(!_0x5e713d)return;const _0x26ff9c=Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage');_0x5e713d['innerHTML']=state['teamBindings']['map'](_0x2e2e97=>{const _0x4bac62=_0x2e2e97['resource_type']==='server'?'Server':_0x2e2e97['resource_id']==='*'?'All\x20'+_0x2e2e97['resource_type']+'s':Utils['escapeHtml'](_0x2e2e97['resource_name']||_0x2e2e97['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x4bac62+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x2e2e97['role_name']||_0x2e2e97['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x26ff9c?'<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteBindingClick(\x27'+_0x2e2e97['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 _0x54bfb0=document['getElementById']('binding-resource-type');_0x54bfb0['value']='environment',updateBindingFormForResourceType('environment');}function onBindingResourceTypeChange(){const _0x1f38ce=document['getElementById']('binding-resource-type')['value'];updateBindingFormForResourceType(_0x1f38ce);}function updateBindingFormForResourceType(_0x42b03e){const _0x218dcf=document['getElementById']('binding-resource-container'),_0x44038f=document['getElementById']('binding-resource'),_0x491338=document['getElementById']('binding-role');if(_0x42b03e==='server')_0x218dcf['style']['display']='none';else{_0x218dcf['style']['display']='';if(_0x42b03e==='environment'){const _0x111291=new Set(state['teamBindings']['filter'](_0x173c27=>_0x173c27['resource_type']==='environment')['map'](_0x23241b=>_0x23241b['resource_id'])),_0x30c7df=state['environments']['filter'](_0x45f78a=>!_0x111291['has'](_0x45f78a['name']));_0x44038f['innerHTML']=_0x30c7df['length']?_0x30c7df['map'](_0x5f1c62=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x5f1c62['name'])+'\x22>'+Utils['escapeHtml'](_0x5f1c62['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x42b03e==='team'){const _0x21a1c4=new Set(state['teamBindings']['filter'](_0x524cf8=>_0x524cf8['resource_type']==='team')['map'](_0x368df7=>_0x368df7['resource_id'])),_0x39c176=state['teams']['filter'](_0x1fbeaa=>!_0x21a1c4['has'](_0x1fbeaa['id']));_0x44038f['innerHTML']=_0x39c176['length']?_0x39c176['map'](_0x31dfcc=>'<option\x20value=\x22'+_0x31dfcc['id']+'\x22>'+Utils['escapeHtml'](_0x31dfcc['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x533641=state['roles']['filter'](_0x2cf5b1=>_0x2cf5b1['resource_type']===_0x42b03e);_0x491338['innerHTML']=_0x533641['length']?_0x533641['filter'](_0x94f16d=>{const _0x1fbf52=_0x42b03e==='server'?undefined:_0x44038f['value'];return!state['teamBindings']['some'](_0x2ad5c0=>_0x2ad5c0['resource_type']===_0x42b03e&&_0x2ad5c0['role_id']===_0x94f16d['id']&&(_0x42b03e==='server'||_0x2ad5c0['resource_id']===_0x1fbf52));})['map'](_0xc122fe=>'<option\x20value=\x22'+_0xc122fe['id']+'\x22>'+Utils['escapeHtml'](_0xc122fe['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 _0x193001=document['getElementById']('binding-resource-type')['value'],_0x3597b5=document['getElementById']('binding-role')['value'];if(!_0x3597b5||!state['bindingsTeamId'])return;const _0x96717d=_0x193001==='server'?undefined:document['getElementById']('binding-resource')['value'];if(_0x193001!=='server'&&!_0x96717d)return;const _0x50de2c=document['getElementById']('save-binding-btn');_0x50de2c['disabled']=!![],_0x50de2c['textContent']='Adding…';try{const _0x417743={'subject_type':'team','subject_id':state['bindingsTeamId'],'role_id':_0x3597b5,'resource_type':_0x193001};if(_0x96717d)_0x417743['resource_id']=_0x96717d;await API['createBinding'](_0x417743),Utils['showToast']('Binding\x20added','success'),document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![],await loadTeamBindings(state['bindingsTeamId']);}catch(_0x231f4d){Utils['showToast'](_0x231f4d['message'],'error');}finally{_0x50de2c['disabled']=![],_0x50de2c['textContent']='Add\x20Binding';}}window['deleteBindingClick']=async function(_0x3f4614){try{await API['deleteBinding'](_0x3f4614),Utils['showToast']('Binding\x20removed','success'),await loadTeamBindings(state['bindingsTeamId']);}catch(_0x5c82b1){Utils['showToast'](_0x5c82b1['message'],'error');}};async function saveTeam(){const _0x34399d=document['getElementById']('team-name')['value']['trim'](),_0x161083=document['getElementById']('team-description')['value']['trim'](),_0x5f037e=document['getElementById']('team-form-error'),_0x4813db=document['getElementById']('save-team');if(!_0x34399d){_0x5f037e['textContent']='Team\x20name\x20is\x20required',_0x5f037e['hidden']=![];return;}_0x5f037e['hidden']=!![];const _0x810a3f=_0x4813db['textContent'];_0x4813db['disabled']=!![],_0x4813db['textContent']=state['editingTeamId']?'Saving…':'Creating…';try{if(state['editingTeamId']){const {team:_0x32c721}=await API['updateTeam'](state['editingTeamId'],{'name':_0x34399d,'description':_0x161083});syncTeamInState(_0x32c721),document['getElementById']('team-modal-title')['textContent']=_0x32c721['name'],Utils['showToast']('Team\x20updated','success');}else await API['createTeam']({'name':_0x34399d,'description':_0x161083}),Utils['showToast']('Team\x20created','success');_0x4813db['disabled']=![],_0x4813db['textContent']=_0x810a3f,hideTeamModal(),await loadTeams();}catch(_0x470218){_0x5f037e['textContent']=_0x470218['message'],_0x5f037e['hidden']=![],_0x4813db['disabled']=![],_0x4813db['textContent']=_0x810a3f;}}window['deleteTeam']=function(_0x135d83){const _0x2bc3cc=state['teams']['find'](_0xb1a74f=>_0xb1a74f['id']===_0x135d83);if(!_0x2bc3cc)return;state['deletingTeamId']=_0x135d83,document['getElementById']('delete-team-name')['textContent']=_0x2bc3cc['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 _0x541ffb=document['getElementById']('confirm-delete-team');_0x541ffb['disabled']=!![],_0x541ffb['textContent']='Deleting…';try{await API['deleteTeam'](state['deletingTeamId']),Utils['showToast']('Team\x20deleted','success'),_0x541ffb['disabled']=![],_0x541ffb['textContent']='Delete\x20Team',hideDeleteModal(),await loadTeams();}catch(_0x5c6508){Utils['showToast']('Failed\x20to\x20delete\x20team:\x20'+_0x5c6508['message'],'error'),_0x541ffb['disabled']=![],_0x541ffb['textContent']='Delete\x20Team';}}function syncTeamInState(_0x55486d){const _0x928863=state['teams']['findIndex'](_0x2865fc=>_0x2865fc['id']===_0x55486d['id']);if(_0x928863>=0x0)state['teams'][_0x928863]=_0x55486d;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'](_0x353242=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':_0x353242}));});let commandSent=![],hasReceivedOutput=![];socket['addEventListener']('message',_0x50fe86=>{try{const _0x58cec9=JSON['parse'](_0x50fe86['data']);if(_0x58cec9['type']==='data'&&typeof _0x58cec9['data']==='string')term['write'](_0x58cec9['data']),!hasReceivedOutput&&_0x58cec9['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(_0x58cec9['type']==='status'&&_0x58cec9['status']){if(_0x58cec9['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'+_0x58cec9['status'],_0x58cec9['status']==='connected'?'success':'info');}else _0x58cec9['type']==='error'&&_0x58cec9['message']&&updateStatus(_0x58cec9['message'],'error');}}catch(_0x23c6ee){console['error']('Failed\x20to\x20parse\x20terminal\x20message',_0x23c6ee);}}),socket['addEventListener']('close',_0x5bdd42=>{const _0x26e745=_0x5bdd42['reason']||'Connection\x20closed';updateStatus(_0x26e745,_0x5bdd42['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',_0x4664bb=>{console['error']('Terminal\x20websocket\x20error',_0x4664bb),updateStatus('Connection\x20error','error');});function sendResize(){if(socket['readyState']!==WebSocket['OPEN'])return;const _0xfe15fb=term['cols'],_0x5958eb=term['rows'];socket['send'](JSON['stringify']({'type':'resize','cols':_0xfe15fb,'rows':_0x5958eb}));}function updateStatus(_0xccd499,_0x4bbb93='info'){if(!statusEl)return;statusEl['textContent']=_0xccd499,statusEl['dataset']['variant']=_0x4bbb93;}async function enrichContainerDetails(_0x2c1fbe){try{const _0x430025=await API['getContainer'](_0x2c1fbe);updateTerminalDetails(_0x430025);}catch{try{const _0x128b86=await API['getContainers'](),_0x5a2a9e=(_0x128b86['containers']||[])['find'](_0x10c9db=>_0x10c9db['containerId']===_0x2c1fbe||_0x10c9db['name']===_0x2c1fbe||_0x10c9db['fullContainerId']?.['startsWith'](_0x2c1fbe));if(_0x5a2a9e){updateTerminalDetails(_0x5a2a9e);return;}subtitleEl['textContent']='Container\x20'+_0x2c1fbe['substring'](0x0,0xc);}catch{subtitleEl['textContent']='Container\x20'+_0x2c1fbe['substring'](0x0,0xc);}}}function updateTerminalDetails(_0x3ac442){const _0x1ef1e4=_0x3ac442['containerId']||_0x3ac442['name']||_0x3ac442['fullContainerId']||containerId,_0x16cbee=_0x3ac442['environment']?'Environment\x20'+_0x3ac442['environment']:'Environment\x20unknown',_0xd8a5c7=_0x3ac442['defaultAgent']?'\x20·\x20Agent\x20'+_0x3ac442['defaultAgent']:'',_0x4d6f7e=_0x3ac442['createdAt']?'\x20·\x20Started\x20'+Utils['formatRelativeTime'](_0x3ac442['createdAt']):'';titleEl['textContent']='Terminal\x20·\x20'+_0x1ef1e4['substring'](0x0,0xc);const _0x43cce4=command?'\x20·\x20Command\x20'+command:'';subtitleEl['textContent']=''+_0x16cbee+_0xd8a5c7+_0x4d6f7e+_0x43cce4;}
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'](_0x34b042=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':_0x34b042}));});let commandSent=![],hasReceivedOutput=![];socket['addEventListener']('message',_0x56033d=>{try{const _0x2e2425=JSON['parse'](_0x56033d['data']);if(_0x2e2425['type']==='data'&&typeof _0x2e2425['data']==='string')term['write'](_0x2e2425['data']),!hasReceivedOutput&&_0x2e2425['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(_0x2e2425['type']==='status'&&_0x2e2425['status']){if(_0x2e2425['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'+_0x2e2425['status'],_0x2e2425['status']==='connected'?'success':'info');}else _0x2e2425['type']==='error'&&_0x2e2425['message']&&updateStatus(_0x2e2425['message'],'error');}}catch(_0x671c8){console['error']('Failed\x20to\x20parse\x20terminal\x20message',_0x671c8);}}),socket['addEventListener']('close',_0x1e1a2b=>{const _0x61eae7=_0x1e1a2b['reason']||'Connection\x20closed';updateStatus(_0x61eae7,_0x1e1a2b['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',_0x37d70e=>{console['error']('Terminal\x20websocket\x20error',_0x37d70e),updateStatus('Connection\x20error','error');});function sendResize(){if(socket['readyState']!==WebSocket['OPEN'])return;const _0x860802=term['cols'],_0x137629=term['rows'];socket['send'](JSON['stringify']({'type':'resize','cols':_0x860802,'rows':_0x137629}));}function updateStatus(_0x2f0d9a,_0x452408='info'){if(!statusEl)return;statusEl['textContent']=_0x2f0d9a,statusEl['dataset']['variant']=_0x452408;}async function enrichContainerDetails(_0x2ccccb){try{const _0x3527cc=await API['getContainer'](_0x2ccccb);updateTerminalDetails(_0x3527cc);}catch{try{const _0x34c2d0=await API['getContainers'](),_0xe036fd=(_0x34c2d0['containers']||[])['find'](_0xd626cd=>_0xd626cd['containerId']===_0x2ccccb||_0xd626cd['name']===_0x2ccccb||_0xd626cd['fullContainerId']?.['startsWith'](_0x2ccccb));if(_0xe036fd){updateTerminalDetails(_0xe036fd);return;}subtitleEl['textContent']='Container\x20'+_0x2ccccb['substring'](0x0,0xc);}catch{subtitleEl['textContent']='Container\x20'+_0x2ccccb['substring'](0x0,0xc);}}}function updateTerminalDetails(_0x38aa11){const _0x4243e=_0x38aa11['containerId']||_0x38aa11['name']||_0x38aa11['fullContainerId']||containerId,_0x2d0db6=_0x38aa11['environment']?'Environment\x20'+_0x38aa11['environment']:'Environment\x20unknown',_0x2eeb15=_0x38aa11['defaultAgent']?'\x20·\x20Agent\x20'+_0x38aa11['defaultAgent']:'',_0x59bed0=_0x38aa11['createdAt']?'\x20·\x20Started\x20'+Utils['formatRelativeTime'](_0x38aa11['createdAt']):'';titleEl['textContent']='Terminal\x20·\x20'+_0x4243e['substring'](0x0,0xc);const _0x1f4cf4=command?'\x20·\x20Command\x20'+command:'';subtitleEl['textContent']=''+_0x2d0db6+_0x2eeb15+_0x59bed0+_0x1f4cf4;}
@@ -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 _0x1913f1=localStorage['getItem'](THEME_STORAGE_KEY);if(_0x1913f1&&VALID_THEMES['has'](_0x1913f1))return _0x1913f1;}catch(_0x104d7a){console['warn']('[Theme]\x20Failed\x20to\x20read\x20stored\x20theme\x20preference:',_0x104d7a);}return null;}export function getPreferredTheme(){const _0x3f8717=readStoredTheme();if(_0x3f8717)return _0x3f8717;const _0x3e1eba=window['matchMedia']&&window['matchMedia']('(prefers-color-scheme:\x20dark)')['matches'];return _0x3e1eba?'dark':'light';}export function getCurrentTheme(){const _0x39ce3e=document['documentElement']['dataset']['theme'];if(_0x39ce3e&&VALID_THEMES['has'](_0x39ce3e))return _0x39ce3e;return getPreferredTheme();}export function applyTheme(_0x3ef976,{persist:persist=!![],emitEvent:emitEvent=!![]}={}){const _0x502b8c=VALID_THEMES['has'](_0x3ef976)?_0x3ef976:'light';document['documentElement']['dataset']['theme']=_0x502b8c,document['documentElement']['style']['colorScheme']=_0x502b8c==='dark'?'dark':'light';if(persist)try{localStorage['setItem'](THEME_STORAGE_KEY,_0x502b8c);}catch(_0x15fd38){console['warn']('[Theme]\x20Failed\x20to\x20persist\x20theme\x20preference:',_0x15fd38);}return emitEvent&&window['dispatchEvent'](new CustomEvent(THEME_CHANGE_EVENT,{'detail':{'theme':_0x502b8c}})),_0x502b8c;}export function initTheme(_0xeec41f={}){const {emitEvent:emitEvent=![]}=_0xeec41f;return applyTheme(getPreferredTheme(),{'persist':![],'emitEvent':emitEvent});}export function toggleTheme(){const _0x494042=getCurrentTheme()==='dark'?'light':'dark';return applyTheme(_0x494042);}export function onThemeChange(_0x42b97d,{runImmediately:runImmediately=![]}={}){const _0x37e286=_0x1a4331=>{_0x42b97d(_0x1a4331['detail']['theme']);};return window['addEventListener'](THEME_CHANGE_EVENT,_0x37e286),runImmediately&&_0x42b97d(getCurrentTheme()),()=>window['removeEventListener'](THEME_CHANGE_EVENT,_0x37e286);}export function mountThemeToggle(_0xa6b12a={}){const {targetSelectors:targetSelectors=DEFAULT_TARGET_SELECTORS}=_0xa6b12a,_0x4b0855=targetSelectors['map'](_0x1e698c=>document['querySelector'](_0x1e698c))['find'](Boolean),_0x209e8e=document['createElement']('button');_0x209e8e['type']='button',_0x209e8e['className']='btn-ghost\x20theme-toggle-btn',_0x209e8e['id']='theme-toggle-btn',_0x209e8e['setAttribute']('aria-pressed','false'),_0x209e8e['style']['padding']='8px',_0x209e8e['style']['lineHeight']='0',_0x209e8e['style']['width']='36px',_0x209e8e['style']['height']='36px',_0x209e8e['style']['display']='flex',_0x209e8e['style']['alignItems']='center',_0x209e8e['style']['justifyContent']='center';const _0x1f04cf=document['createElement']('span');_0x1f04cf['className']='theme-icon',_0x1f04cf['style']['display']='flex',_0x209e8e['append'](_0x1f04cf);const _0x3427d8='<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>',_0x399af5='<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>',_0x4bb4f4=_0x1be9f4=>{const _0x587bc6=_0x1be9f4==='dark';_0x1f04cf['innerHTML']=_0x587bc6?_0x3427d8:_0x399af5,_0x209e8e['title']=_0x587bc6?'Switch\x20to\x20light\x20mode':'Switch\x20to\x20dark\x20mode',_0x209e8e['dataset']['theme']=_0x1be9f4,_0x209e8e['setAttribute']('aria-pressed',String(_0x587bc6));};return _0x209e8e['addEventListener']('click',()=>{const _0x108c0d=getCurrentTheme()==='dark'?'light':'dark';applyTheme(_0x108c0d);}),_0x4b0855?_0x4b0855['appendChild'](_0x209e8e):(_0x209e8e['classList']['add']('theme-toggle-floating'),document['body']['appendChild'](_0x209e8e)),_0x4bb4f4(initTheme()),onThemeChange(_0x4bb4f4),_0x209e8e;}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 _0x1aac05=localStorage['getItem'](THEME_STORAGE_KEY);if(_0x1aac05&&VALID_THEMES['has'](_0x1aac05))return _0x1aac05;}catch(_0x1bb91a){console['warn']('[Theme]\x20Failed\x20to\x20read\x20stored\x20theme\x20preference:',_0x1bb91a);}return null;}export function getPreferredTheme(){const _0x5dd96b=readStoredTheme();if(_0x5dd96b)return _0x5dd96b;const _0x4697fb=window['matchMedia']&&window['matchMedia']('(prefers-color-scheme:\x20dark)')['matches'];return _0x4697fb?'dark':'light';}export function getCurrentTheme(){const _0x46c1ea=document['documentElement']['dataset']['theme'];if(_0x46c1ea&&VALID_THEMES['has'](_0x46c1ea))return _0x46c1ea;return getPreferredTheme();}export function applyTheme(_0x1c15ec,{persist:persist=!![],emitEvent:emitEvent=!![]}={}){const _0x535b06=VALID_THEMES['has'](_0x1c15ec)?_0x1c15ec:'light';document['documentElement']['dataset']['theme']=_0x535b06,document['documentElement']['style']['colorScheme']=_0x535b06==='dark'?'dark':'light';if(persist)try{localStorage['setItem'](THEME_STORAGE_KEY,_0x535b06);}catch(_0x2c1b1e){console['warn']('[Theme]\x20Failed\x20to\x20persist\x20theme\x20preference:',_0x2c1b1e);}return emitEvent&&window['dispatchEvent'](new CustomEvent(THEME_CHANGE_EVENT,{'detail':{'theme':_0x535b06}})),_0x535b06;}export function initTheme(_0x2a1865={}){const {emitEvent:emitEvent=![]}=_0x2a1865;return applyTheme(getPreferredTheme(),{'persist':![],'emitEvent':emitEvent});}export function toggleTheme(){const _0x14e05e=getCurrentTheme()==='dark'?'light':'dark';return applyTheme(_0x14e05e);}export function onThemeChange(_0x10c05c,{runImmediately:runImmediately=![]}={}){const _0x2f0a9f=_0x25bf7a=>{_0x10c05c(_0x25bf7a['detail']['theme']);};return window['addEventListener'](THEME_CHANGE_EVENT,_0x2f0a9f),runImmediately&&_0x10c05c(getCurrentTheme()),()=>window['removeEventListener'](THEME_CHANGE_EVENT,_0x2f0a9f);}export function mountThemeToggle(_0x1c36ba={}){const {targetSelectors:targetSelectors=DEFAULT_TARGET_SELECTORS}=_0x1c36ba,_0x12612b=targetSelectors['map'](_0x5038a1=>document['querySelector'](_0x5038a1))['find'](Boolean),_0x3ba55f=document['createElement']('button');_0x3ba55f['type']='button',_0x3ba55f['className']='btn-ghost\x20theme-toggle-btn',_0x3ba55f['id']='theme-toggle-btn',_0x3ba55f['setAttribute']('aria-pressed','false'),_0x3ba55f['style']['padding']='8px',_0x3ba55f['style']['lineHeight']='0',_0x3ba55f['style']['width']='36px',_0x3ba55f['style']['height']='36px',_0x3ba55f['style']['display']='flex',_0x3ba55f['style']['alignItems']='center',_0x3ba55f['style']['justifyContent']='center';const _0x59ff2e=document['createElement']('span');_0x59ff2e['className']='theme-icon',_0x59ff2e['style']['display']='flex',_0x3ba55f['append'](_0x59ff2e);const _0x279f41='<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>',_0x55bcff='<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>',_0x3e62fe=_0x23722a=>{const _0x1e8791=_0x23722a==='dark';_0x59ff2e['innerHTML']=_0x1e8791?_0x279f41:_0x55bcff,_0x3ba55f['title']=_0x1e8791?'Switch\x20to\x20light\x20mode':'Switch\x20to\x20dark\x20mode',_0x3ba55f['dataset']['theme']=_0x23722a,_0x3ba55f['setAttribute']('aria-pressed',String(_0x1e8791));};return _0x3ba55f['addEventListener']('click',()=>{const _0x186424=getCurrentTheme()==='dark'?'light':'dark';applyTheme(_0x186424);}),_0x12612b?_0x12612b['appendChild'](_0x3ba55f):(_0x3ba55f['classList']['add']('theme-toggle-floating'),document['body']['appendChild'](_0x3ba55f)),_0x3e62fe(initTheme()),onThemeChange(_0x3e62fe),_0x3ba55f;}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 _0x4c2929=await API['getCurrentUser']();state['currentUser']=_0x4c2929;if(!Permissions['hasServerPermission'](_0x4c2929,'*')&&!Permissions['hasServerPermission'](_0x4c2929,'users:create')){Utils['showToast']('Access\x20denied:\x20Server\x20admin\x20privileges\x20required','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}}catch(_0x50818f){window['location']['href']='login.html';}}async function checkEmailConfig(){try{const _0x1d7180=await API['getEmailConfig']();state['emailConfigured']=_0x1d7180['configured'];}catch(_0x1fd8d6){console['error']('Failed\x20to\x20check\x20email\x20config',_0x1fd8d6),state['emailConfigured']=![];}}async function loadRoles(){try{const {roles:_0x331bc1}=await API['getRoleDefinitions']();state['roles']=_0x331bc1||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x42e924=await API['getEnvironments']();state['environments']=_0x42e924['environments']||[];}catch{state['environments']=[];}}async function loadTeams(){try{const {teams:_0x26b4a4}=await API['getTeams']();state['teams']=_0x26b4a4||[];}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 _0x2239d1=document['getElementById']('users-loading'),_0x34511d=document['getElementById']('users-error'),_0x7f0a4c=document['getElementById']('users-content');try{_0x2239d1['hidden']=![],_0x34511d['hidden']=!![],_0x7f0a4c['hidden']=!![];const _0x21c616=await API['getUsers']();state['users']=_0x21c616['users']||[],renderUsers(),_0x2239d1['hidden']=!![],_0x7f0a4c['hidden']=![];}catch(_0x33a028){console['error']('Failed\x20to\x20load\x20users',_0x33a028),_0x2239d1['hidden']=!![],_0x34511d['hidden']=![],document['getElementById']('users-error-message')['textContent']=_0x33a028['message'];}}function renderUsers(){const _0x1de5f9=document['getElementById']('users-table-body'),_0x30eb5f=document['getElementById']('user-count');if(!_0x1de5f9)return;_0x30eb5f&&(_0x30eb5f['textContent']=state['users']['length']+'\x20user'+(state['users']['length']===0x1?'':'s'));const _0x4f7993=[...state['users']]['sort']((_0x2691eb,_0x3fc27f)=>{const _0x216f7b=new Date(_0x2691eb['created_at'])['getTime'](),_0x4e7345=new Date(_0x3fc27f['created_at'])['getTime']();return _0x4e7345-_0x216f7b;});_0x1de5f9['innerHTML']=_0x4f7993['map'](_0x58dd4d=>'\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'](_0x58dd4d['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'](_0x58dd4d['name'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x58dd4d['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'+(_0x58dd4d['isServerAdmin']?'<span\x20class=\x22role-badge\x20role-admin\x22>Server\x20Admin</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x58dd4d['hasUserBinding']?'<span\x20class=\x22role-badge\x20role-user-binding\x22>User\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x58dd4d['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'](_0x58dd4d['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'+_0x58dd4d['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'+_0x58dd4d['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'+_0x58dd4d['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'+_0x58dd4d['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(_0x36ee50){const _0x2fe342=state['users']['find'](_0x493e99=>_0x493e99['id']===_0x36ee50);if(!_0x2fe342)return;state['bindingsUserId']=_0x36ee50,state['bindingsDirty']=![];const _0x1120c3=document['getElementById']('bindings-modal'),_0x1d0801=document['getElementById']('bindings-modal-title');_0x1d0801['textContent']='Access\x20Bindings\x20—\x20'+_0x2fe342['name'],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],_0x1120c3['hidden']=![],loadUserBindings(_0x36ee50);};function hasUnsavedBindingChanges(){const _0x3ccb39=document['getElementById']('add-user-binding-form');return _0x3ccb39&&!_0x3ccb39['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 _0x107d33=document['getElementById']('bindings-modal');_0x107d33['hidden']=!![];const _0xd1bc6b=state['bindingsDirty'];state['bindingsUserId']=null,state['userBindings']=[],state['bindingsDirty']=![],_0xd1bc6b&&await loadUsers();}async function loadUserBindings(_0x1dd7d0){const _0x7c660d=document['getElementById']('user-bindings-loading'),_0x2699fd=document['getElementById']('user-bindings-empty'),_0x50dc8e=document['getElementById']('user-bindings-list-container'),_0x63fd8a=document['getElementById']('add-user-binding-btn'),_0xeb9d4a=document['getElementById']('user-team-bindings-note'),_0x389674=document['getElementById']('user-team-bindings-text');_0x7c660d['hidden']=![],_0x2699fd['hidden']=!![],_0x50dc8e['style']['display']='none',_0x63fd8a['hidden']=!![],_0xeb9d4a['hidden']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![];try{const [_0x2b69b9,_0x299196]=await Promise['all']([API['getBindings']({'subject_type':'user','subject_id':_0x1dd7d0}),API['getTeams']()]);state['userBindings']=_0x2b69b9['bindings']||[];const _0x44fe25=(_0x299196['teams']||[])['filter'](_0x47cca4=>(_0x47cca4['members']||[])['includes'](_0x1dd7d0)),_0x5eb465=[];if(_0x44fe25['length']>0x0){const _0x200e1a=await Promise['all'](_0x44fe25['map'](_0x294f69=>API['getBindings']({'subject_type':'team','subject_id':_0x294f69['id']})));for(let _0x144345=0x0;_0x144345<_0x44fe25['length'];_0x144345++){const _0x4f2140=_0x200e1a[_0x144345]['bindings']||[];_0x4f2140['length']>0x0&&_0x5eb465['push'](_0x44fe25[_0x144345]);}}_0x7c660d['hidden']=!![];state['userBindings']['length']===0x0?_0x2699fd['hidden']=![]:(_0x50dc8e['style']['display']='',renderUserBindingsTable());if(_0x5eb465['length']>0x0){const _0x5befbd=_0x5eb465['map'](_0xcf43cb=>_0xcf43cb['name']),_0x27da99=_0x5befbd['length']<=0x3?_0x5befbd['join'](',\x20'):_0x5befbd['slice'](0x0,0x3)['join'](',\x20')+(',\x20and\x20'+(_0x5befbd['length']-0x3)+'\x20more');_0x389674['textContent']='This\x20user\x20also\x20has\x20access\x20via\x20team\x20memberships\x20('+_0x27da99+').';}else _0x389674['textContent']='This\x20user\x20has\x20no\x20access\x20via\x20team\x20memberships.';_0xeb9d4a['hidden']=![],_0x63fd8a['hidden']=![];}catch(_0x4a32dd){_0x7c660d['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x4a32dd['message'],'error');}}function renderUserBindingsTable(){const _0x2f64d5=document['getElementById']('user-bindings-table-body');if(!_0x2f64d5)return;_0x2f64d5['innerHTML']=state['userBindings']['map'](_0x2a0e78=>{const _0x56fa5f=_0x2a0e78['resource_type']==='server'?'Server':_0x2a0e78['resource_id']==='*'?'All\x20'+_0x2a0e78['resource_type']+'s':Utils['escapeHtml'](_0x2a0e78['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x56fa5f+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x2a0e78['role_name']||_0x2a0e78['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'+_0x2a0e78['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 _0x1d9cf9=document['getElementById']('user-binding-resource-type');_0x1d9cf9['value']='environment',updateUserBindingFormForResourceType('environment');}function onUserBindingResourceTypeChange(){const _0x5f0e9b=document['getElementById']('user-binding-resource-type')['value'];updateUserBindingFormForResourceType(_0x5f0e9b);}function updateUserBindingFormForResourceType(_0x28a19d){const _0x559dec=document['getElementById']('user-binding-resource-container'),_0x47e20e=document['getElementById']('user-binding-resource'),_0x4f330d=document['getElementById']('user-binding-role');if(_0x28a19d==='server')_0x559dec['style']['display']='none';else{_0x559dec['style']['display']='';if(_0x28a19d==='environment'){const _0x5cdc1e=new Set(state['userBindings']['filter'](_0x350b46=>_0x350b46['resource_type']==='environment')['map'](_0x2f6f6e=>_0x2f6f6e['resource_id'])),_0x11b885=state['environments']['filter'](_0x70f58b=>!_0x5cdc1e['has'](_0x70f58b['name']));_0x47e20e['innerHTML']=_0x11b885['length']?_0x11b885['map'](_0x271563=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x271563['name'])+'\x22>'+Utils['escapeHtml'](_0x271563['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x28a19d==='team'){const _0x16de32=new Set(state['userBindings']['filter'](_0x437b27=>_0x437b27['resource_type']==='team')['map'](_0x44f95e=>_0x44f95e['resource_id'])),_0x24ca25=state['teams']['filter'](_0x180a10=>!_0x16de32['has'](_0x180a10['id']));_0x47e20e['innerHTML']=_0x24ca25['length']?_0x24ca25['map'](_0x26027d=>'<option\x20value=\x22'+_0x26027d['id']+'\x22>'+Utils['escapeHtml'](_0x26027d['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x4d6fd9=state['roles']['filter'](_0x2a1583=>_0x2a1583['resource_type']===_0x28a19d);_0x4f330d['innerHTML']=_0x4d6fd9['length']?_0x4d6fd9['filter'](_0x2d3f61=>{const _0x480daf=_0x28a19d==='server'?undefined:_0x47e20e['value'];return!state['userBindings']['some'](_0x340607=>_0x340607['resource_type']===_0x28a19d&&_0x340607['role_id']===_0x2d3f61['id']&&(_0x28a19d==='server'||_0x340607['resource_id']===_0x480daf));})['map'](_0x53b1d9=>'<option\x20value=\x22'+_0x53b1d9['id']+'\x22>'+Utils['escapeHtml'](_0x53b1d9['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 _0x2a7a25=document['getElementById']('user-binding-resource-type')['value'],_0x2ab580=document['getElementById']('user-binding-role')['value'];if(!_0x2ab580||!state['bindingsUserId'])return;const _0x2e7a76=_0x2a7a25==='server'?undefined:document['getElementById']('user-binding-resource')['value'];if(_0x2a7a25!=='server'&&!_0x2e7a76)return;const _0x522d9d=document['getElementById']('save-user-binding-btn');_0x522d9d['disabled']=!![],_0x522d9d['textContent']='Adding…';try{const _0x3827bc={'subject_type':'user','subject_id':state['bindingsUserId'],'role_id':_0x2ab580,'resource_type':_0x2a7a25};if(_0x2e7a76)_0x3827bc['resource_id']=_0x2e7a76;await API['createBinding'](_0x3827bc),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(_0x54fda0){Utils['showToast'](_0x54fda0['message'],'error');}finally{_0x522d9d['disabled']=![],_0x522d9d['textContent']='Add\x20Binding';}}window['deleteUserBindingClick']=async function(_0x579875){try{await API['deleteBinding'](_0x579875),Utils['showToast']('Binding\x20removed','success'),state['bindingsDirty']=!![],await loadUserBindings(state['bindingsUserId']);}catch(_0x3e8447){Utils['showToast'](_0x3e8447['message'],'error');}};function showCreateUserModal(){state['editingUserId']=null;const _0x23e99a=document['getElementById']('user-modal'),_0xf0290c=document['getElementById']('modal-title'),_0x1358b3=document['getElementById']('user-password'),_0x5d3aa4=document['getElementById']('password-required'),_0x40d06a=document['getElementById']('password-hint'),_0x1e8a4b=document['getElementById']('skip-password-container'),_0x5f4342=document['getElementById']('skip-password');_0xf0290c['textContent']='Create\x20User',document['getElementById']('user-form')['reset'](),_0x1358b3['required']=!![];if(_0x5d3aa4)_0x5d3aa4['textContent']='*';_0x1e8a4b&&(_0x1e8a4b['style']['display']='block',_0x5f4342['checked']=![]),_0x40d06a&&(_0x40d06a['textContent']='Minimum\x208\x20characters'),_0x23e99a['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);}window['editUser']=function(_0x17ae4f){const _0x3e6bc6=state['users']['find'](_0x138e39=>_0x138e39['id']===_0x17ae4f);if(!_0x3e6bc6)return;state['editingUserId']=_0x17ae4f;const _0xbb831=document['getElementById']('user-modal'),_0x3288f3=document['getElementById']('modal-title'),_0x39b4d1=document['getElementById']('user-password'),_0x1205a4=document['getElementById']('password-required'),_0x44aeee=document['getElementById']('password-hint'),_0x3e1a75=document['getElementById']('skip-password-container');_0x3288f3['textContent']='Edit\x20User',document['getElementById']('user-username')['value']=_0x3e6bc6['username'],document['getElementById']('user-name')['value']=_0x3e6bc6['name'],document['getElementById']('user-email')['value']=_0x3e6bc6['email'],_0x39b4d1['value']='',_0x39b4d1['required']=![];if(_0x1205a4)_0x1205a4['textContent']='';_0x3e1a75&&(_0x3e1a75['style']['display']='none'),_0x44aeee&&(_0x44aeee['textContent']='Leave\x20blank\x20to\x20keep\x20current\x20password'),_0xbb831['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);};function hideUserModal(){const _0x555ddc=document['getElementById']('user-modal'),_0x4bc19e=document['getElementById']('form-error'),_0x1b228e=document['getElementById']('save-user');_0x555ddc['hidden']=!![],_0x4bc19e['hidden']=!![],state['editingUserId']=null,_0x1b228e&&(_0x1b228e['disabled']=![],_0x1b228e['textContent']='Save\x20User');}async function saveUser(){const _0x4f326e=document['getElementById']('user-form'),_0x868ca8=document['getElementById']('skip-password')?.['checked']||![];if(!_0x868ca8&&!_0x4f326e['checkValidity']()){_0x4f326e['reportValidity']();return;}const _0x1e1b94=document['getElementById']('form-error'),_0x17c065=document['getElementById']('save-user'),_0x5b5081=document['getElementById']('user-username')['value']['trim'](),_0x5375f0=document['getElementById']('user-name')['value']['trim'](),_0x3e4f15=document['getElementById']('user-email')['value']['trim'](),_0x4c4aba=document['getElementById']('user-password')['value'];if(!_0x5b5081||!_0x5375f0||!_0x3e4f15){_0x1e1b94['textContent']='Please\x20fill\x20in\x20all\x20required\x20fields',_0x1e1b94['hidden']=![],_0x1e1b94['scrollIntoView']({'behavior':'smooth','block':'nearest'});return;}_0x1e1b94['hidden']=!![];const _0x40996e=_0x17c065['textContent'];_0x17c065['disabled']=!![],_0x17c065['textContent']=state['editingUserId']?'Updating...':'Creating...';try{if(state['editingUserId']){const _0x2995d2={'username':_0x5b5081,'name':_0x5375f0,'email':_0x3e4f15};_0x4c4aba&&(_0x2995d2['password']=_0x4c4aba),await API['updateUser'](state['editingUserId'],_0x2995d2),Utils['showToast']('User\x20updated\x20successfully','success'),await loadUsers(),hideUserModal();}else{const _0x3307eb={'username':_0x5b5081,'name':_0x5375f0,'email':_0x3e4f15};if(!_0x868ca8){if(!_0x4c4aba)throw new Error('Password\x20is\x20required\x20for\x20new\x20users');_0x3307eb['password']=_0x4c4aba;}const _0x476ccb=await API['createUser'](_0x3307eb),_0x3452c3=_0x476ccb['user'];if(_0x868ca8||!_0x4c4aba){const _0x4ddb84=await API['createPasswordToken'](_0x3452c3['id'],'setup',![]);state['setupLinkData']={'username':_0x3452c3['username'],'email':_0x3452c3['email'],'url':_0x4ddb84['token']['setupUrl'],'userId':_0x3452c3['id'],'type':'setup','emailSent':![]},await loadUsers(),hideUserModal(),showSetupLinkModal();}else Utils['showToast']('User\x20created\x20successfully','success'),await loadUsers(),hideUserModal();}}catch(_0x538809){console['error']('Failed\x20to\x20save\x20user',_0x538809),_0x1e1b94['textContent']=_0x538809['message'],_0x1e1b94['hidden']=![],_0x1e1b94['scrollIntoView']({'behavior':'smooth','block':'nearest'}),_0x17c065['disabled']=![],_0x17c065['textContent']=_0x40996e;}}window['deleteUser']=function(_0x2c6177){const _0x20c684=state['users']['find'](_0xad3fe8=>_0xad3fe8['id']===_0x2c6177);if(!_0x20c684)return;state['deletingUserId']=_0x2c6177;const _0x5176de=document['getElementById']('delete-modal'),_0x3047f8=document['getElementById']('delete-user-name');_0x3047f8['textContent']=_0x20c684['name']+'\x20('+_0x20c684['username']+')',_0x5176de['hidden']=![];};function hideDeleteModal(){const _0x295526=document['getElementById']('delete-modal');_0x295526['hidden']=!![],state['deletingUserId']=null;const _0x595b32=document['getElementById']('confirm-delete');_0x595b32&&(_0x595b32['disabled']=![],_0x595b32['textContent']='Delete\x20User');}async function confirmDeleteUser(){if(!state['deletingUserId'])return;const _0x59158b=document['getElementById']('confirm-delete'),_0x1f32d5=_0x59158b['textContent'];_0x59158b['disabled']=!![],_0x59158b['textContent']='Deleting...';try{await API['deleteUser'](state['deletingUserId']),Utils['showToast']('User\x20deleted\x20successfully','success'),await loadUsers(),hideDeleteModal();}catch(_0xc9040a){console['error']('Failed\x20to\x20delete\x20user',_0xc9040a),Utils['showToast']('Failed\x20to\x20delete\x20user:\x20'+_0xc9040a['message'],'error'),_0x59158b['disabled']=![],_0x59158b['textContent']=_0x1f32d5;}}function handleSkipPasswordChange(_0x522869){const _0x36496f=document['getElementById']('user-password'),_0x244d2c=_0x522869['target']['checked'];_0x244d2c?(_0x36496f['required']=![],_0x36496f['disabled']=!![],_0x36496f['value']=''):(_0x36496f['required']=!![],_0x36496f['disabled']=![]);}function showSetupLinkModal(){if(!state['setupLinkData'])return;const _0x44aa88=document['getElementById']('setup-link-modal'),_0xb34a7d=document['getElementById']('setup-link-username'),_0x5f4786=document['getElementById']('setup-link-url'),_0x53733e=document['getElementById']('email-setup-link'),_0x4c9fa5=document['getElementById']('email-button-text');_0xb34a7d['textContent']=state['setupLinkData']['username'],_0x5f4786['textContent']=state['setupLinkData']['url'],_0x53733e&&_0x4c9fa5&&(_0x53733e['disabled']=![],_0x4c9fa5['textContent']='Email\x20Link',state['emailConfigured']&&!state['setupLinkData']['emailSent']?_0x53733e['style']['display']='inline-block':_0x53733e['style']['display']='none'),_0x44aa88['hidden']=![];}function hideSetupLinkModal(){const _0x179208=document['getElementById']('setup-link-modal');_0x179208['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(_0x32efa3){console['error']('Failed\x20to\x20copy\x20link',_0x32efa3),Utils['showToast']('Failed\x20to\x20copy\x20link','error');}}async function emailSetupLink(){if(!state['setupLinkData'])return;const _0x376902=document['getElementById']('email-setup-link'),_0x1f8799=document['getElementById']('email-button-text');if(!_0x376902||!_0x1f8799)return;const _0x63226=_0x1f8799['textContent'];_0x376902['disabled']=!![],_0x1f8799['textContent']='Sending...';try{const _0xc77a8c=await API['createPasswordToken'](state['setupLinkData']['userId'],state['setupLinkData']['type'],!![]);if(_0xc77a8c['emailSent'])Utils['showToast']('Email\x20sent\x20to\x20'+state['setupLinkData']['email'],'success'),state['setupLinkData']['emailSent']=!![],_0x376902['style']['display']='none';else{const _0xdda6dd=_0xc77a8c['emailError']||'Failed\x20to\x20send\x20email';Utils['showToast'](_0xdda6dd,'error'),_0x376902['disabled']=![],_0x1f8799['textContent']=_0x63226;}}catch(_0x14155b){console['error']('Failed\x20to\x20email\x20setup\x20link',_0x14155b),Utils['showToast']('Failed\x20to\x20send\x20email:\x20'+_0x14155b['message'],'error'),_0x376902['disabled']=![],_0x1f8799['textContent']=_0x63226;}}window['resetPassword']=async function(_0x32ff26){const _0x7c000d=state['users']['find'](_0x2bb26e=>_0x2bb26e['id']===_0x32ff26);if(!_0x7c000d)return;const _0x6b5cef=await ConfirmDialog['show']({'title':'Reset\x20Password','message':'Generate\x20a\x20password\x20reset\x20link\x20for\x20'+_0x7c000d['name']+'\x20('+_0x7c000d['username']+')?\x20This\x20will\x20create\x20a\x20link\x20that\x20they\x20can\x20use\x20to\x20set\x20a\x20new\x20password.','confirmText':'Generate\x20Link'});if(!_0x6b5cef)return;try{const _0x3a87b5=await API['createPasswordToken'](_0x32ff26,'reset',![]);state['setupLinkData']={'username':_0x7c000d['username'],'email':_0x7c000d['email'],'url':_0x3a87b5['token']['setupUrl'],'userId':_0x7c000d['id'],'type':'reset','emailSent':![]},showSetupLinkModal();}catch(_0x14df32){console['error']('Failed\x20to\x20create\x20password\x20reset\x20link',_0x14df32),Utils['showToast']('Failed\x20to\x20create\x20password\x20reset\x20link:\x20'+_0x14df32['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 _0x3a0cb6=await API['getCurrentUser']();state['currentUser']=_0x3a0cb6;if(!Permissions['hasServerPermission'](_0x3a0cb6,'*')&&!Permissions['hasServerPermission'](_0x3a0cb6,'users:create')){Utils['showToast']('Access\x20denied:\x20Server\x20admin\x20privileges\x20required','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}}catch(_0x14a359){window['location']['href']='login.html';}}async function checkEmailConfig(){try{const _0x338897=await API['getEmailConfig']();state['emailConfigured']=_0x338897['configured'];}catch(_0x52ecac){console['error']('Failed\x20to\x20check\x20email\x20config',_0x52ecac),state['emailConfigured']=![];}}async function loadRoles(){try{const {roles:_0x174593}=await API['getRoleDefinitions']();state['roles']=_0x174593||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x39944c=await API['getEnvironments']();state['environments']=_0x39944c['environments']||[];}catch{state['environments']=[];}}async function loadTeams(){try{const {teams:_0x3e71bf}=await API['getTeams']();state['teams']=_0x3e71bf||[];}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 _0x325040=document['getElementById']('users-loading'),_0x3780da=document['getElementById']('users-error'),_0x40a9b7=document['getElementById']('users-content');try{_0x325040['hidden']=![],_0x3780da['hidden']=!![],_0x40a9b7['hidden']=!![];const _0x4baac9=await API['getUsers']();state['users']=_0x4baac9['users']||[],renderUsers(),_0x325040['hidden']=!![],_0x40a9b7['hidden']=![];}catch(_0x1312f9){console['error']('Failed\x20to\x20load\x20users',_0x1312f9),_0x325040['hidden']=!![],_0x3780da['hidden']=![],document['getElementById']('users-error-message')['textContent']=_0x1312f9['message'];}}function renderUsers(){const _0x35d6f4=document['getElementById']('users-table-body'),_0x2df1c5=document['getElementById']('user-count');if(!_0x35d6f4)return;_0x2df1c5&&(_0x2df1c5['textContent']=state['users']['length']+'\x20user'+(state['users']['length']===0x1?'':'s'));const _0x2ca78e=[...state['users']]['sort']((_0x40efec,_0x106ab0)=>{const _0x359eea=new Date(_0x40efec['created_at'])['getTime'](),_0x40df90=new Date(_0x106ab0['created_at'])['getTime']();return _0x40df90-_0x359eea;});_0x35d6f4['innerHTML']=_0x2ca78e['map'](_0x1bdae8=>'\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'](_0x1bdae8['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'](_0x1bdae8['name'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x1bdae8['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'+(_0x1bdae8['isServerAdmin']?'<span\x20class=\x22role-badge\x20role-admin\x22>Server\x20Admin</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x1bdae8['hasUserBinding']?'<span\x20class=\x22role-badge\x20role-user-binding\x22>User\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x1bdae8['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'](_0x1bdae8['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'+_0x1bdae8['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'+_0x1bdae8['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'+_0x1bdae8['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'+_0x1bdae8['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(_0x55f3f4){const _0xb762a=state['users']['find'](_0x2acf15=>_0x2acf15['id']===_0x55f3f4);if(!_0xb762a)return;state['bindingsUserId']=_0x55f3f4,state['bindingsDirty']=![];const _0x226089=document['getElementById']('bindings-modal'),_0x9c0550=document['getElementById']('bindings-modal-title');_0x9c0550['textContent']='Access\x20Bindings\x20—\x20'+_0xb762a['name'],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],_0x226089['hidden']=![],loadUserBindings(_0x55f3f4);};function hasUnsavedBindingChanges(){const _0x47ecfd=document['getElementById']('add-user-binding-form');return _0x47ecfd&&!_0x47ecfd['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 _0x333470=document['getElementById']('bindings-modal');_0x333470['hidden']=!![];const _0x3366b7=state['bindingsDirty'];state['bindingsUserId']=null,state['userBindings']=[],state['bindingsDirty']=![],_0x3366b7&&await loadUsers();}async function loadUserBindings(_0x5c94ef){const _0x57a605=document['getElementById']('user-bindings-loading'),_0x16fdc8=document['getElementById']('user-bindings-empty'),_0x51b5eb=document['getElementById']('user-bindings-list-container'),_0x4af213=document['getElementById']('add-user-binding-btn'),_0x4f173d=document['getElementById']('user-team-bindings-note'),_0x3bfdc1=document['getElementById']('user-team-bindings-text');_0x57a605['hidden']=![],_0x16fdc8['hidden']=!![],_0x51b5eb['style']['display']='none',_0x4af213['hidden']=!![],_0x4f173d['hidden']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![];try{const [_0x1c5d1e,_0x1ab348]=await Promise['all']([API['getBindings']({'subject_type':'user','subject_id':_0x5c94ef}),API['getTeams']()]);state['userBindings']=_0x1c5d1e['bindings']||[];const _0xcfec73=(_0x1ab348['teams']||[])['filter'](_0x2e7ead=>(_0x2e7ead['members']||[])['includes'](_0x5c94ef)),_0x2dc969=[];if(_0xcfec73['length']>0x0){const _0x16f926=await Promise['all'](_0xcfec73['map'](_0x1d6827=>API['getBindings']({'subject_type':'team','subject_id':_0x1d6827['id']})));for(let _0x3ec731=0x0;_0x3ec731<_0xcfec73['length'];_0x3ec731++){const _0x3d01ec=_0x16f926[_0x3ec731]['bindings']||[];_0x3d01ec['length']>0x0&&_0x2dc969['push'](_0xcfec73[_0x3ec731]);}}_0x57a605['hidden']=!![];state['userBindings']['length']===0x0?_0x16fdc8['hidden']=![]:(_0x51b5eb['style']['display']='',renderUserBindingsTable());if(_0x2dc969['length']>0x0){const _0x25a7e4=_0x2dc969['map'](_0x693d64=>_0x693d64['name']),_0x212a8d=_0x25a7e4['length']<=0x3?_0x25a7e4['join'](',\x20'):_0x25a7e4['slice'](0x0,0x3)['join'](',\x20')+(',\x20and\x20'+(_0x25a7e4['length']-0x3)+'\x20more');_0x3bfdc1['textContent']='This\x20user\x20also\x20has\x20access\x20via\x20team\x20memberships\x20('+_0x212a8d+').';}else _0x3bfdc1['textContent']='This\x20user\x20has\x20no\x20access\x20via\x20team\x20memberships.';_0x4f173d['hidden']=![],_0x4af213['hidden']=![];}catch(_0x4d220d){_0x57a605['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x4d220d['message'],'error');}}function renderUserBindingsTable(){const _0x4236d1=document['getElementById']('user-bindings-table-body');if(!_0x4236d1)return;_0x4236d1['innerHTML']=state['userBindings']['map'](_0xa4ffee=>{const _0x257caf=_0xa4ffee['resource_type']==='server'?'Server':_0xa4ffee['resource_id']==='*'?'All\x20'+_0xa4ffee['resource_type']+'s':Utils['escapeHtml'](_0xa4ffee['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x257caf+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0xa4ffee['role_name']||_0xa4ffee['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'+_0xa4ffee['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 _0x525ae2=document['getElementById']('user-binding-resource-type');_0x525ae2['value']='environment',updateUserBindingFormForResourceType('environment');}function onUserBindingResourceTypeChange(){const _0x1904da=document['getElementById']('user-binding-resource-type')['value'];updateUserBindingFormForResourceType(_0x1904da);}function updateUserBindingFormForResourceType(_0x4a1322){const _0x5077be=document['getElementById']('user-binding-resource-container'),_0x5e351c=document['getElementById']('user-binding-resource'),_0x44d297=document['getElementById']('user-binding-role');if(_0x4a1322==='server')_0x5077be['style']['display']='none';else{_0x5077be['style']['display']='';if(_0x4a1322==='environment'){const _0x352c2f=new Set(state['userBindings']['filter'](_0x104b5c=>_0x104b5c['resource_type']==='environment')['map'](_0x3eefe0=>_0x3eefe0['resource_id'])),_0x45dcd2=state['environments']['filter'](_0x473f69=>!_0x352c2f['has'](_0x473f69['name']));_0x5e351c['innerHTML']=_0x45dcd2['length']?_0x45dcd2['map'](_0x26dadb=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x26dadb['name'])+'\x22>'+Utils['escapeHtml'](_0x26dadb['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x4a1322==='team'){const _0x214960=new Set(state['userBindings']['filter'](_0x5cb262=>_0x5cb262['resource_type']==='team')['map'](_0x480f66=>_0x480f66['resource_id'])),_0x3d513f=state['teams']['filter'](_0x3bdfe0=>!_0x214960['has'](_0x3bdfe0['id']));_0x5e351c['innerHTML']=_0x3d513f['length']?_0x3d513f['map'](_0x32a042=>'<option\x20value=\x22'+_0x32a042['id']+'\x22>'+Utils['escapeHtml'](_0x32a042['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0xe3dc53=state['roles']['filter'](_0x3f8f63=>_0x3f8f63['resource_type']===_0x4a1322);_0x44d297['innerHTML']=_0xe3dc53['length']?_0xe3dc53['filter'](_0x869572=>{const _0x48144a=_0x4a1322==='server'?undefined:_0x5e351c['value'];return!state['userBindings']['some'](_0x41cc21=>_0x41cc21['resource_type']===_0x4a1322&&_0x41cc21['role_id']===_0x869572['id']&&(_0x4a1322==='server'||_0x41cc21['resource_id']===_0x48144a));})['map'](_0x2f1c31=>'<option\x20value=\x22'+_0x2f1c31['id']+'\x22>'+Utils['escapeHtml'](_0x2f1c31['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 _0x36481f=document['getElementById']('user-binding-resource-type')['value'],_0xd29104=document['getElementById']('user-binding-role')['value'];if(!_0xd29104||!state['bindingsUserId'])return;const _0x57a466=_0x36481f==='server'?undefined:document['getElementById']('user-binding-resource')['value'];if(_0x36481f!=='server'&&!_0x57a466)return;const _0x26cf48=document['getElementById']('save-user-binding-btn');_0x26cf48['disabled']=!![],_0x26cf48['textContent']='Adding…';try{const _0x10f4b7={'subject_type':'user','subject_id':state['bindingsUserId'],'role_id':_0xd29104,'resource_type':_0x36481f};if(_0x57a466)_0x10f4b7['resource_id']=_0x57a466;await API['createBinding'](_0x10f4b7),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(_0x362d7){Utils['showToast'](_0x362d7['message'],'error');}finally{_0x26cf48['disabled']=![],_0x26cf48['textContent']='Add\x20Binding';}}window['deleteUserBindingClick']=async function(_0x14ba72){try{await API['deleteBinding'](_0x14ba72),Utils['showToast']('Binding\x20removed','success'),state['bindingsDirty']=!![],await loadUserBindings(state['bindingsUserId']);}catch(_0x33c1b5){Utils['showToast'](_0x33c1b5['message'],'error');}};function showCreateUserModal(){state['editingUserId']=null;const _0x50a4d0=document['getElementById']('user-modal'),_0x9623c9=document['getElementById']('modal-title'),_0x205278=document['getElementById']('user-password'),_0xd05a9e=document['getElementById']('password-required'),_0x3becfe=document['getElementById']('password-hint'),_0x27f8fb=document['getElementById']('skip-password-container'),_0xec42f9=document['getElementById']('skip-password');_0x9623c9['textContent']='Create\x20User',document['getElementById']('user-form')['reset'](),_0x205278['required']=!![];if(_0xd05a9e)_0xd05a9e['textContent']='*';_0x27f8fb&&(_0x27f8fb['style']['display']='block',_0xec42f9['checked']=![]),_0x3becfe&&(_0x3becfe['textContent']='Minimum\x208\x20characters'),_0x50a4d0['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);}window['editUser']=function(_0x497649){const _0x361d09=state['users']['find'](_0x1eb537=>_0x1eb537['id']===_0x497649);if(!_0x361d09)return;state['editingUserId']=_0x497649;const _0xfe67ab=document['getElementById']('user-modal'),_0x27db56=document['getElementById']('modal-title'),_0x22c5ae=document['getElementById']('user-password'),_0x2eb92f=document['getElementById']('password-required'),_0x4e0672=document['getElementById']('password-hint'),_0x5a90f6=document['getElementById']('skip-password-container');_0x27db56['textContent']='Edit\x20User',document['getElementById']('user-username')['value']=_0x361d09['username'],document['getElementById']('user-name')['value']=_0x361d09['name'],document['getElementById']('user-email')['value']=_0x361d09['email'],_0x22c5ae['value']='',_0x22c5ae['required']=![];if(_0x2eb92f)_0x2eb92f['textContent']='';_0x5a90f6&&(_0x5a90f6['style']['display']='none'),_0x4e0672&&(_0x4e0672['textContent']='Leave\x20blank\x20to\x20keep\x20current\x20password'),_0xfe67ab['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);};function hideUserModal(){const _0x17f0a0=document['getElementById']('user-modal'),_0x2c4867=document['getElementById']('form-error'),_0x2e2044=document['getElementById']('save-user');_0x17f0a0['hidden']=!![],_0x2c4867['hidden']=!![],state['editingUserId']=null,_0x2e2044&&(_0x2e2044['disabled']=![],_0x2e2044['textContent']='Save\x20User');}async function saveUser(){const _0x3335d7=document['getElementById']('user-form'),_0x5aa8dc=document['getElementById']('skip-password')?.['checked']||![];if(!_0x5aa8dc&&!_0x3335d7['checkValidity']()){_0x3335d7['reportValidity']();return;}const _0x225129=document['getElementById']('form-error'),_0x38125d=document['getElementById']('save-user'),_0x3ac18b=document['getElementById']('user-username')['value']['trim'](),_0x45d8f0=document['getElementById']('user-name')['value']['trim'](),_0x3e6480=document['getElementById']('user-email')['value']['trim'](),_0xa3c4fe=document['getElementById']('user-password')['value'];if(!_0x3ac18b||!_0x45d8f0||!_0x3e6480){_0x225129['textContent']='Please\x20fill\x20in\x20all\x20required\x20fields',_0x225129['hidden']=![],_0x225129['scrollIntoView']({'behavior':'smooth','block':'nearest'});return;}_0x225129['hidden']=!![];const _0x2d0d4d=_0x38125d['textContent'];_0x38125d['disabled']=!![],_0x38125d['textContent']=state['editingUserId']?'Updating...':'Creating...';try{if(state['editingUserId']){const _0x58dfd0={'username':_0x3ac18b,'name':_0x45d8f0,'email':_0x3e6480};_0xa3c4fe&&(_0x58dfd0['password']=_0xa3c4fe),await API['updateUser'](state['editingUserId'],_0x58dfd0),Utils['showToast']('User\x20updated\x20successfully','success'),await loadUsers(),hideUserModal();}else{const _0x17c1ad={'username':_0x3ac18b,'name':_0x45d8f0,'email':_0x3e6480};if(!_0x5aa8dc){if(!_0xa3c4fe)throw new Error('Password\x20is\x20required\x20for\x20new\x20users');_0x17c1ad['password']=_0xa3c4fe;}const _0x59a4cf=await API['createUser'](_0x17c1ad),_0x936b5f=_0x59a4cf['user'];if(_0x5aa8dc||!_0xa3c4fe){const _0x56da12=await API['createPasswordToken'](_0x936b5f['id'],'setup',![]);state['setupLinkData']={'username':_0x936b5f['username'],'email':_0x936b5f['email'],'url':_0x56da12['token']['setupUrl'],'userId':_0x936b5f['id'],'type':'setup','emailSent':![]},await loadUsers(),hideUserModal(),showSetupLinkModal();}else Utils['showToast']('User\x20created\x20successfully','success'),await loadUsers(),hideUserModal();}}catch(_0x5ade56){console['error']('Failed\x20to\x20save\x20user',_0x5ade56),_0x225129['textContent']=_0x5ade56['message'],_0x225129['hidden']=![],_0x225129['scrollIntoView']({'behavior':'smooth','block':'nearest'}),_0x38125d['disabled']=![],_0x38125d['textContent']=_0x2d0d4d;}}window['deleteUser']=function(_0x1e2184){const _0x31dd47=state['users']['find'](_0x259ebc=>_0x259ebc['id']===_0x1e2184);if(!_0x31dd47)return;state['deletingUserId']=_0x1e2184;const _0x3cffd9=document['getElementById']('delete-modal'),_0x51e033=document['getElementById']('delete-user-name');_0x51e033['textContent']=_0x31dd47['name']+'\x20('+_0x31dd47['username']+')',_0x3cffd9['hidden']=![];};function hideDeleteModal(){const _0x3dee5e=document['getElementById']('delete-modal');_0x3dee5e['hidden']=!![],state['deletingUserId']=null;const _0x4567a3=document['getElementById']('confirm-delete');_0x4567a3&&(_0x4567a3['disabled']=![],_0x4567a3['textContent']='Delete\x20User');}async function confirmDeleteUser(){if(!state['deletingUserId'])return;const _0x361241=document['getElementById']('confirm-delete'),_0xf7594c=_0x361241['textContent'];_0x361241['disabled']=!![],_0x361241['textContent']='Deleting...';try{await API['deleteUser'](state['deletingUserId']),Utils['showToast']('User\x20deleted\x20successfully','success'),await loadUsers(),hideDeleteModal();}catch(_0x579223){console['error']('Failed\x20to\x20delete\x20user',_0x579223),Utils['showToast']('Failed\x20to\x20delete\x20user:\x20'+_0x579223['message'],'error'),_0x361241['disabled']=![],_0x361241['textContent']=_0xf7594c;}}function handleSkipPasswordChange(_0x5b4d7c){const _0x2914c3=document['getElementById']('user-password'),_0x4d7fcf=_0x5b4d7c['target']['checked'];_0x4d7fcf?(_0x2914c3['required']=![],_0x2914c3['disabled']=!![],_0x2914c3['value']=''):(_0x2914c3['required']=!![],_0x2914c3['disabled']=![]);}function showSetupLinkModal(){if(!state['setupLinkData'])return;const _0x5d968a=document['getElementById']('setup-link-modal'),_0x294023=document['getElementById']('setup-link-username'),_0x190e88=document['getElementById']('setup-link-url'),_0x412909=document['getElementById']('email-setup-link'),_0x44fdc0=document['getElementById']('email-button-text');_0x294023['textContent']=state['setupLinkData']['username'],_0x190e88['textContent']=state['setupLinkData']['url'],_0x412909&&_0x44fdc0&&(_0x412909['disabled']=![],_0x44fdc0['textContent']='Email\x20Link',state['emailConfigured']&&!state['setupLinkData']['emailSent']?_0x412909['style']['display']='inline-block':_0x412909['style']['display']='none'),_0x5d968a['hidden']=![];}function hideSetupLinkModal(){const _0x304d26=document['getElementById']('setup-link-modal');_0x304d26['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(_0x157c90){console['error']('Failed\x20to\x20copy\x20link',_0x157c90),Utils['showToast']('Failed\x20to\x20copy\x20link','error');}}async function emailSetupLink(){if(!state['setupLinkData'])return;const _0x1c853a=document['getElementById']('email-setup-link'),_0x385a1d=document['getElementById']('email-button-text');if(!_0x1c853a||!_0x385a1d)return;const _0x26045d=_0x385a1d['textContent'];_0x1c853a['disabled']=!![],_0x385a1d['textContent']='Sending...';try{const _0x11b5e3=await API['createPasswordToken'](state['setupLinkData']['userId'],state['setupLinkData']['type'],!![]);if(_0x11b5e3['emailSent'])Utils['showToast']('Email\x20sent\x20to\x20'+state['setupLinkData']['email'],'success'),state['setupLinkData']['emailSent']=!![],_0x1c853a['style']['display']='none';else{const _0x455b97=_0x11b5e3['emailError']||'Failed\x20to\x20send\x20email';Utils['showToast'](_0x455b97,'error'),_0x1c853a['disabled']=![],_0x385a1d['textContent']=_0x26045d;}}catch(_0x1604ed){console['error']('Failed\x20to\x20email\x20setup\x20link',_0x1604ed),Utils['showToast']('Failed\x20to\x20send\x20email:\x20'+_0x1604ed['message'],'error'),_0x1c853a['disabled']=![],_0x385a1d['textContent']=_0x26045d;}}window['resetPassword']=async function(_0x4e2396){const _0x173202=state['users']['find'](_0x403485=>_0x403485['id']===_0x4e2396);if(!_0x173202)return;const _0x3eee3a=await ConfirmDialog['show']({'title':'Reset\x20Password','message':'Generate\x20a\x20password\x20reset\x20link\x20for\x20'+_0x173202['name']+'\x20('+_0x173202['username']+')?\x20This\x20will\x20create\x20a\x20link\x20that\x20they\x20can\x20use\x20to\x20set\x20a\x20new\x20password.','confirmText':'Generate\x20Link'});if(!_0x3eee3a)return;try{const _0x208e61=await API['createPasswordToken'](_0x4e2396,'reset',![]);state['setupLinkData']={'username':_0x173202['username'],'email':_0x173202['email'],'url':_0x208e61['token']['setupUrl'],'userId':_0x173202['id'],'type':'reset','emailSent':![]},showSetupLinkModal();}catch(_0x4b080d){console['error']('Failed\x20to\x20create\x20password\x20reset\x20link',_0x4b080d),Utils['showToast']('Failed\x20to\x20create\x20password\x20reset\x20link:\x20'+_0x4b080d['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(_0x1b2efb={}){this['container']=null,this['onGroupChange']=_0x1b2efb['onGroupChange']||(()=>{}),this['onAddExistingTask']=_0x1b2efb['onAddExistingTask']||(()=>{}),this['tasks']=[],this['groupId']=_0x1b2efb['groupId']||null,this['isOpen']=![];}['init'](_0x524a70,_0x28f5d2,_0x3f449a){this['container']=_0x524a70,this['tasks']=_0x28f5d2,this['groupId']=_0x3f449a,this['render'](),this['attachEventListeners']();}['updateTasks'](_0xd8dba0){const _0x41d1f7=new Map(_0xd8dba0['map'](_0x3cfff9=>[_0x3cfff9['taskId'],_0x3cfff9]));this['tasks']=this['tasks']['map'](_0x13c9ca=>{const _0x277428=_0x41d1f7['get'](_0x13c9ca['taskId']);return _0x277428?_0x277428:_0x13c9ca;});for(const _0x5862ae of _0xd8dba0){!this['tasks']['some'](_0x36fc44=>_0x36fc44['taskId']===_0x5862ae['taskId'])&&this['tasks']['push'](_0x5862ae);}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 _0x4aaeef=this['tasks']['filter'](_0x2d6550=>_0x2d6550['groupId']===this['groupId'])['sort']((_0x5eb759,_0x138c7d)=>(_0x5eb759['groupIndex']??0x0)-(_0x138c7d['groupIndex']??0x0)),_0x945b7=this['tasks']['filter'](_0x40c548=>!_0x40c548['groupId']||_0x40c548['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>'+_0x4aaeef['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'+(_0x4aaeef['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20add\x20to\x20group</div>':_0x4aaeef['map']((_0x92136f,_0x510653)=>this['renderVariantCard'](_0x92136f,_0x510653,!![]))['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>'+_0x945b7['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'+(_0x945b7['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20remove\x20from\x20group</div>':_0x945b7['map']((_0x295759,_0x30f038)=>this['renderVariantCard'](_0x295759,_0x30f038,![]))['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'](_0x32df38,_0x3d022f,_0x11e84e){const _0x1c8f5d=_0x32df38['envVars']?.['CODER_AGENT']||_0x32df38['envVars']?.['default_agent']||'claude',_0x4ce594=AGENT_ICONS[_0x1c8f5d['toLowerCase']()]||AGENT_ICONS['claude'],_0x109003=STATUS_ICONS[_0x32df38['status']]||'',_0x13df31='status-'+(_0x32df38['status']||'unknown'),_0x31225b=_0x32df38['isWinner']?'<span\x20class=\x22vgm-badge\x20vgm-badge-winner\x22\x20title=\x22Winner\x22>★</span>':'',_0x33e6a1=_0x32df38['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'+_0x13df31+'\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'+_0x32df38['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-is-grouped=\x22'+_0x11e84e+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-index=\x22'+_0x3d022f+'\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'+_0x1c8f5d['toLowerCase']()+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x4ce594+'\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'](_0x32df38['name']||'Task\x20'+_0x32df38['taskId']['slice'](-0x6))+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-meta\x22>'+Utils['escapeHtml'](_0x1c8f5d)+'\x20·\x20'+(_0x32df38['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'+_0x31225b+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x33e6a1+'\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'+_0x13df31+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x109003+'\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'+(_0x11e84e?'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'+_0x32df38['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-action=\x22'+(_0x11e84e?'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'+(_0x11e84e?'<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',_0x5b1f93=>{_0x5b1f93['target']['closest']('.vgm-close-btn')&&(this['close'](),this['onGroupChange'](this['tasks'])),_0x5b1f93['target']['closest']('.vgm-add-existing-btn')&&(this['close'](),this['onAddExistingTask'](this['groupId']));}),this['container']['addEventListener']('click',async _0x2a22c6=>{const _0x4ed946=_0x2a22c6['target']['closest']('.vgm-variant-remove-btn');if(!_0x4ed946)return;const _0x5c92d=_0x4ed946['dataset']['taskId'],_0x103ed2=_0x4ed946['dataset']['action'];try{_0x103ed2==='remove'?await this['removeFromGroup'](_0x5c92d):await this['addToGroup'](_0x5c92d);}catch(_0x96fba7){console['error']('Failed\x20to\x20update\x20group:',_0x96fba7),Utils['showToast'](_0x96fba7['message']||'Failed\x20to\x20update\x20group','error');}}),this['container']['addEventListener']('dragstart',_0x304689=>this['handleDragStart'](_0x304689)),this['container']['addEventListener']('dragend',_0x493d68=>this['handleDragEnd'](_0x493d68)),this['container']['addEventListener']('dragover',_0x4342e5=>this['handleDragOver'](_0x4342e5)),this['container']['addEventListener']('dragleave',_0x5f3e0f=>this['handleDragLeave'](_0x5f3e0f)),this['container']['addEventListener']('drop',_0x40f38b=>this['handleDrop'](_0x40f38b));}['handleDragStart'](_0xcc2c03){const _0x182a12=_0xcc2c03['target']['closest']('.vgm-variant-card');if(!_0x182a12)return;dragState['draggedTaskId']=_0x182a12['dataset']['taskId'],dragState['draggedElement']=_0x182a12,dragState['sourceGroupId']=_0x182a12['dataset']['isGrouped']==='true'?this['groupId']:null,dragState['isDragging']=!![],_0x182a12['classList']['add']('dragging'),_0xcc2c03['dataTransfer']['effectAllowed']='move',_0xcc2c03['dataTransfer']['setData']('text/plain',_0x182a12['dataset']['taskId']),this['container']['classList']['add']('is-dragging');}['handleDragEnd'](_0x19f2f9){const _0x207b55=_0x19f2f9['target']['closest']('.vgm-variant-card');_0x207b55&&_0x207b55['classList']['remove']('dragging'),this['container']['querySelectorAll']('.drag-over,\x20.drop-indicator')['forEach'](_0x21485=>{_0x21485['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'](_0x3bf5ca){_0x3bf5ca['preventDefault'](),_0x3bf5ca['dataTransfer']['dropEffect']='move';const _0x4edbb7=_0x3bf5ca['target']['closest']('.vgm-drop-zone'),_0x441a0c=_0x3bf5ca['target']['closest']('.vgm-variant-card');this['container']['querySelectorAll']('.vgm-drop-zone')['forEach'](_0x2d3bdc=>{_0x2d3bdc['classList']['toggle']('drag-over',_0x2d3bdc===_0x4edbb7);});if(_0x441a0c&&_0x441a0c!==dragState['draggedElement']){const _0x1fd113=_0x441a0c['getBoundingClientRect'](),_0x2d6e0b=_0x1fd113['top']+_0x1fd113['height']/0x2,_0x4fbfd3=_0x3bf5ca['clientY']<_0x2d6e0b;this['container']['querySelectorAll']('.vgm-variant-card')['forEach'](_0x4072fb=>{_0x4072fb!==_0x441a0c&&_0x4072fb['classList']['remove']('drop-before','drop-after');}),_0x441a0c['classList']['toggle']('drop-before',_0x4fbfd3),_0x441a0c['classList']['toggle']('drop-after',!_0x4fbfd3);}}['handleDragLeave'](_0x42cfa0){const _0x263635=_0x42cfa0['target']['closest']('.vgm-drop-zone');_0x263635&&!_0x263635['contains'](_0x42cfa0['relatedTarget'])&&_0x263635['classList']['remove']('drag-over');}async['handleDrop'](_0x14098e){_0x14098e['preventDefault']();const _0x3006f3=_0x14098e['target']['closest']('.vgm-drop-zone'),_0x4fb2a4=_0x14098e['target']['closest']('.vgm-variant-card'),_0x90eb12=_0x14098e['dataTransfer']['getData']('text/plain');if(!_0x3006f3||!_0x90eb12)return;this['container']['querySelectorAll']('.drag-over,\x20.drop-before,\x20.drop-after')['forEach'](_0x10d8e0=>{_0x10d8e0['classList']['remove']('drag-over','drop-before','drop-after');});const _0x484a68=_0x3006f3['dataset']['zone'],_0x6b5436=_0x484a68==='grouped',_0x436d3b=dragState['sourceGroupId']===this['groupId'];try{if(_0x6b5436&&!_0x436d3b){let _0x5e1962=this['tasks']['filter'](_0x48e7ac=>_0x48e7ac['groupId']===this['groupId'])['length'];if(_0x4fb2a4){const _0x531cb3=_0x4fb2a4['dataset']['taskId'],_0x24e623=this['tasks']['find'](_0x361ff1=>_0x361ff1['taskId']===_0x531cb3);if(_0x24e623?.['groupIndex']!==undefined){const _0x306184=_0x4fb2a4['getBoundingClientRect'](),_0x5df2ed=_0x14098e['clientY']<_0x306184['top']+_0x306184['height']/0x2;_0x5e1962=_0x24e623['groupIndex']+(_0x5df2ed?0x0:0x1);}}await this['addToGroup'](_0x90eb12,_0x5e1962);}else{if(!_0x6b5436&&_0x436d3b)await this['removeFromGroup'](_0x90eb12);else _0x6b5436&&_0x436d3b&&_0x4fb2a4&&await this['reorderInGroup'](_0x90eb12,_0x4fb2a4,_0x14098e['clientY']);}}catch(_0x57d7b6){console['error']('Drop\x20operation\x20failed:',_0x57d7b6),Utils['showToast'](_0x57d7b6['message']||'Failed\x20to\x20move\x20variant','error');}}async['addToGroup'](_0x2e511b,_0x196a09){const _0x326c6e=this['tasks']['find'](_0x160bff=>_0x160bff['taskId']===_0x2e511b);if(!_0x326c6e)return;_0x196a09===undefined&&(_0x196a09=this['tasks']['filter'](_0x22a00d=>_0x22a00d['groupId']===this['groupId'])['length']),!this['groupId']&&(this['groupId']=API['generateGroupId'](),await API['createTaskGroup']({'groupId':this['groupId']})),await API['updateTaskGroup'](_0x2e511b,this['groupId'],_0x196a09),_0x326c6e['groupId']=this['groupId'],_0x326c6e['groupIndex']=_0x196a09,this['render'](),this['onGroupChange'](this['tasks']);}async['removeFromGroup'](_0x5ecf35){const _0x558adb=this['tasks']['find'](_0x279319=>_0x279319['taskId']===_0x5ecf35);if(!_0x558adb)return;await API['removeTaskFromGroup'](_0x5ecf35),_0x558adb['groupId']=null,_0x558adb['groupIndex']=null,this['render'](),this['onGroupChange'](this['tasks']);}async['reorderInGroup'](_0x24700d,_0x391a55,_0x35a091){const _0x5b15b0=this['tasks']['find'](_0x40a2bb=>_0x40a2bb['taskId']===_0x24700d),_0x2025d1=_0x391a55['dataset']['taskId'],_0x5c8d41=this['tasks']['find'](_0x82ca1a=>_0x82ca1a['taskId']===_0x2025d1);if(!_0x5b15b0||!_0x5c8d41||_0x5b15b0['taskId']===_0x5c8d41['taskId'])return;const _0x3a3639=_0x391a55['getBoundingClientRect'](),_0x5842cf=_0x35a091<_0x3a3639['top']+_0x3a3639['height']/0x2;let _0x313c90=_0x5c8d41['groupIndex']??0x0;if(!_0x5842cf)_0x313c90++;if((_0x5b15b0['groupIndex']??0x0)<(_0x5c8d41['groupIndex']??0x0))_0x313c90--;if(_0x313c90===_0x5b15b0['groupIndex'])return;await API['updateTaskGroup'](_0x24700d,this['groupId'],_0x313c90);const _0x268a81=this['tasks']['filter'](_0x4944f0=>_0x4944f0['groupId']===this['groupId'])['sort']((_0x93654b,_0x27c56f)=>(_0x93654b['groupIndex']??0x0)-(_0x27c56f['groupIndex']??0x0)),_0x45a3cb=_0x268a81['findIndex'](_0x4741b1=>_0x4741b1['taskId']===_0x24700d);_0x45a3cb!==-0x1&&_0x268a81['splice'](_0x45a3cb,0x1),_0x268a81['splice'](_0x313c90,0x0,_0x5b15b0),_0x268a81['forEach']((_0x417b18,_0x5ad283)=>{_0x417b18['groupIndex']=_0x5ad283;}),this['render'](),this['onGroupChange'](this['tasks']);}}export function initializeTabDragDrop(_0x343a69,_0x5a597d,_0x1a6252,_0x51f20e={}){if(!_0x343a69)return;const {onReorder:_0x2efe5b,onRemove:_0x549749}=_0x51f20e,_0x5c1c9e=_0x343a69['querySelectorAll']('.task-tab');_0x5c1c9e['forEach']((_0x209fc5,_0x5beebc)=>{_0x209fc5['setAttribute']('draggable','true'),_0x209fc5['dataset']['index']=_0x5beebc,_0x209fc5['addEventListener']('dragstart',_0x58eaa0=>{_0x58eaa0['dataTransfer']['effectAllowed']='move',_0x58eaa0['dataTransfer']['setData']('text/plain',_0x209fc5['dataset']['taskId']),_0x209fc5['classList']['add']('dragging'),_0x343a69['classList']['add']('is-dragging');}),_0x209fc5['addEventListener']('dragend',()=>{_0x209fc5['classList']['remove']('dragging'),_0x343a69['classList']['remove']('is-dragging'),_0x343a69['querySelectorAll']('.drop-indicator')['forEach'](_0x35c5b4=>{_0x35c5b4['classList']['remove']('drop-indicator','drop-before','drop-after');});}),_0x209fc5['addEventListener']('dragover',_0x3f20c0=>{_0x3f20c0['preventDefault'](),_0x3f20c0['dataTransfer']['dropEffect']='move';if(_0x209fc5['classList']['contains']('dragging'))return;const _0x444f97=_0x209fc5['getBoundingClientRect'](),_0xb8c2d2=_0x444f97['left']+_0x444f97['width']/0x2,_0x155cb5=_0x3f20c0['clientX']<_0xb8c2d2;_0x5c1c9e['forEach'](_0x317d4a=>_0x317d4a['classList']['remove']('drop-before','drop-after')),_0x209fc5['classList']['add'](_0x155cb5?'drop-before':'drop-after');}),_0x209fc5['addEventListener']('dragleave',()=>{_0x209fc5['classList']['remove']('drop-before','drop-after');}),_0x209fc5['addEventListener']('drop',async _0x3c9ab0=>{_0x3c9ab0['preventDefault']();const _0x2ca2d5=_0x3c9ab0['dataTransfer']['getData']('text/plain'),_0x5dcfbf=_0x209fc5['dataset']['taskId'];if(_0x2ca2d5===_0x5dcfbf)return;const _0x1f2528=_0x209fc5['getBoundingClientRect'](),_0x2903f3=_0x3c9ab0['clientX']<_0x1f2528['left']+_0x1f2528['width']/0x2;_0x209fc5['classList']['remove']('drop-before','drop-after'),_0x2efe5b&&await _0x2efe5b(_0x2ca2d5,_0x5dcfbf,_0x2903f3);});});const _0xdbebeb=document['createElement']('div');return _0xdbebeb['className']='task-tab-remove-zone',_0xdbebeb['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',_0xdbebeb['style']['display']='none',_0xdbebeb['addEventListener']('dragover',_0x1e7142=>{_0x1e7142['preventDefault'](),_0xdbebeb['classList']['add']('drag-over');}),_0xdbebeb['addEventListener']('dragleave',()=>{_0xdbebeb['classList']['remove']('drag-over');}),_0xdbebeb['addEventListener']('drop',async _0x2779c5=>{_0x2779c5['preventDefault'](),_0xdbebeb['classList']['remove']('drag-over');const _0x385c0d=_0x2779c5['dataTransfer']['getData']('text/plain');_0x549749&&await _0x549749(_0x385c0d);}),_0x343a69['addEventListener']('dragstart',()=>{_0x5a597d['length']>0x1&&(_0xdbebeb['style']['display']='flex');}),_0x343a69['addEventListener']('dragend',()=>{_0xdbebeb['style']['display']='none';}),_0x343a69['appendChild'](_0xdbebeb),{'destroy':()=>{_0xdbebeb['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(_0x2907d8={}){this['container']=null,this['onGroupChange']=_0x2907d8['onGroupChange']||(()=>{}),this['onAddExistingTask']=_0x2907d8['onAddExistingTask']||(()=>{}),this['tasks']=[],this['groupId']=_0x2907d8['groupId']||null,this['isOpen']=![];}['init'](_0x39f110,_0x1c7b62,_0x467c3f){this['container']=_0x39f110,this['tasks']=_0x1c7b62,this['groupId']=_0x467c3f,this['render'](),this['attachEventListeners']();}['updateTasks'](_0x2d5e95){const _0x32581f=new Map(_0x2d5e95['map'](_0x2c91e2=>[_0x2c91e2['taskId'],_0x2c91e2]));this['tasks']=this['tasks']['map'](_0x2f015e=>{const _0x1d9b76=_0x32581f['get'](_0x2f015e['taskId']);return _0x1d9b76?_0x1d9b76:_0x2f015e;});for(const _0x2d2305 of _0x2d5e95){!this['tasks']['some'](_0x2015a0=>_0x2015a0['taskId']===_0x2d2305['taskId'])&&this['tasks']['push'](_0x2d2305);}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 _0x4ae563=this['tasks']['filter'](_0x4324a4=>_0x4324a4['groupId']===this['groupId'])['sort']((_0x1fe17e,_0x4c9056)=>(_0x1fe17e['groupIndex']??0x0)-(_0x4c9056['groupIndex']??0x0)),_0x3c86f4=this['tasks']['filter'](_0x3d60ba=>!_0x3d60ba['groupId']||_0x3d60ba['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>'+_0x4ae563['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'+(_0x4ae563['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20add\x20to\x20group</div>':_0x4ae563['map']((_0x2d4f63,_0x536c61)=>this['renderVariantCard'](_0x2d4f63,_0x536c61,!![]))['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>'+_0x3c86f4['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'+(_0x3c86f4['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20remove\x20from\x20group</div>':_0x3c86f4['map']((_0x339584,_0x45fe4d)=>this['renderVariantCard'](_0x339584,_0x45fe4d,![]))['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'](_0x365f9b,_0x281d42,_0x4ea494){const _0x5c55cf=_0x365f9b['envVars']?.['CODER_AGENT']||_0x365f9b['envVars']?.['default_agent']||'claude',_0x2bbb58=AGENT_ICONS[_0x5c55cf['toLowerCase']()]||AGENT_ICONS['claude'],_0x29011c=STATUS_ICONS[_0x365f9b['status']]||'',_0x303fef='status-'+(_0x365f9b['status']||'unknown'),_0x46671e=_0x365f9b['isWinner']?'<span\x20class=\x22vgm-badge\x20vgm-badge-winner\x22\x20title=\x22Winner\x22>★</span>':'',_0x36507a=_0x365f9b['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'+_0x303fef+'\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'+_0x365f9b['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-is-grouped=\x22'+_0x4ea494+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-index=\x22'+_0x281d42+'\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'+_0x5c55cf['toLowerCase']()+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x2bbb58+'\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'](_0x365f9b['name']||'Task\x20'+_0x365f9b['taskId']['slice'](-0x6))+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-meta\x22>'+Utils['escapeHtml'](_0x5c55cf)+'\x20·\x20'+(_0x365f9b['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'+_0x46671e+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x36507a+'\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'+_0x303fef+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x29011c+'\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'+(_0x4ea494?'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'+_0x365f9b['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-action=\x22'+(_0x4ea494?'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'+(_0x4ea494?'<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',_0x27e2fe=>{_0x27e2fe['target']['closest']('.vgm-close-btn')&&(this['close'](),this['onGroupChange'](this['tasks'])),_0x27e2fe['target']['closest']('.vgm-add-existing-btn')&&(this['close'](),this['onAddExistingTask'](this['groupId']));}),this['container']['addEventListener']('click',async _0x56565b=>{const _0x4c4261=_0x56565b['target']['closest']('.vgm-variant-remove-btn');if(!_0x4c4261)return;const _0x1dfe96=_0x4c4261['dataset']['taskId'],_0x55e112=_0x4c4261['dataset']['action'];try{_0x55e112==='remove'?await this['removeFromGroup'](_0x1dfe96):await this['addToGroup'](_0x1dfe96);}catch(_0x797369){console['error']('Failed\x20to\x20update\x20group:',_0x797369),Utils['showToast'](_0x797369['message']||'Failed\x20to\x20update\x20group','error');}}),this['container']['addEventListener']('dragstart',_0x329329=>this['handleDragStart'](_0x329329)),this['container']['addEventListener']('dragend',_0x3af5a1=>this['handleDragEnd'](_0x3af5a1)),this['container']['addEventListener']('dragover',_0x5ec827=>this['handleDragOver'](_0x5ec827)),this['container']['addEventListener']('dragleave',_0x49b58b=>this['handleDragLeave'](_0x49b58b)),this['container']['addEventListener']('drop',_0x193775=>this['handleDrop'](_0x193775));}['handleDragStart'](_0x425800){const _0x552f28=_0x425800['target']['closest']('.vgm-variant-card');if(!_0x552f28)return;dragState['draggedTaskId']=_0x552f28['dataset']['taskId'],dragState['draggedElement']=_0x552f28,dragState['sourceGroupId']=_0x552f28['dataset']['isGrouped']==='true'?this['groupId']:null,dragState['isDragging']=!![],_0x552f28['classList']['add']('dragging'),_0x425800['dataTransfer']['effectAllowed']='move',_0x425800['dataTransfer']['setData']('text/plain',_0x552f28['dataset']['taskId']),this['container']['classList']['add']('is-dragging');}['handleDragEnd'](_0x2c0a85){const _0x395842=_0x2c0a85['target']['closest']('.vgm-variant-card');_0x395842&&_0x395842['classList']['remove']('dragging'),this['container']['querySelectorAll']('.drag-over,\x20.drop-indicator')['forEach'](_0x30c4f6=>{_0x30c4f6['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'](_0x3eea9a){_0x3eea9a['preventDefault'](),_0x3eea9a['dataTransfer']['dropEffect']='move';const _0x3d8f67=_0x3eea9a['target']['closest']('.vgm-drop-zone'),_0x4ef3ca=_0x3eea9a['target']['closest']('.vgm-variant-card');this['container']['querySelectorAll']('.vgm-drop-zone')['forEach'](_0xdec671=>{_0xdec671['classList']['toggle']('drag-over',_0xdec671===_0x3d8f67);});if(_0x4ef3ca&&_0x4ef3ca!==dragState['draggedElement']){const _0x270a5f=_0x4ef3ca['getBoundingClientRect'](),_0x8bb1f0=_0x270a5f['top']+_0x270a5f['height']/0x2,_0x47d6d1=_0x3eea9a['clientY']<_0x8bb1f0;this['container']['querySelectorAll']('.vgm-variant-card')['forEach'](_0x27e76c=>{_0x27e76c!==_0x4ef3ca&&_0x27e76c['classList']['remove']('drop-before','drop-after');}),_0x4ef3ca['classList']['toggle']('drop-before',_0x47d6d1),_0x4ef3ca['classList']['toggle']('drop-after',!_0x47d6d1);}}['handleDragLeave'](_0x5dee19){const _0x1b9227=_0x5dee19['target']['closest']('.vgm-drop-zone');_0x1b9227&&!_0x1b9227['contains'](_0x5dee19['relatedTarget'])&&_0x1b9227['classList']['remove']('drag-over');}async['handleDrop'](_0x1cccf2){_0x1cccf2['preventDefault']();const _0x1f221f=_0x1cccf2['target']['closest']('.vgm-drop-zone'),_0x26d4ff=_0x1cccf2['target']['closest']('.vgm-variant-card'),_0x29c15d=_0x1cccf2['dataTransfer']['getData']('text/plain');if(!_0x1f221f||!_0x29c15d)return;this['container']['querySelectorAll']('.drag-over,\x20.drop-before,\x20.drop-after')['forEach'](_0x4e83e3=>{_0x4e83e3['classList']['remove']('drag-over','drop-before','drop-after');});const _0x1bf861=_0x1f221f['dataset']['zone'],_0x3b1c0f=_0x1bf861==='grouped',_0x11483e=dragState['sourceGroupId']===this['groupId'];try{if(_0x3b1c0f&&!_0x11483e){let _0x190759=this['tasks']['filter'](_0x28edc9=>_0x28edc9['groupId']===this['groupId'])['length'];if(_0x26d4ff){const _0x4520e6=_0x26d4ff['dataset']['taskId'],_0x266dfe=this['tasks']['find'](_0x362483=>_0x362483['taskId']===_0x4520e6);if(_0x266dfe?.['groupIndex']!==undefined){const _0x3e5938=_0x26d4ff['getBoundingClientRect'](),_0x178875=_0x1cccf2['clientY']<_0x3e5938['top']+_0x3e5938['height']/0x2;_0x190759=_0x266dfe['groupIndex']+(_0x178875?0x0:0x1);}}await this['addToGroup'](_0x29c15d,_0x190759);}else{if(!_0x3b1c0f&&_0x11483e)await this['removeFromGroup'](_0x29c15d);else _0x3b1c0f&&_0x11483e&&_0x26d4ff&&await this['reorderInGroup'](_0x29c15d,_0x26d4ff,_0x1cccf2['clientY']);}}catch(_0x3b7712){console['error']('Drop\x20operation\x20failed:',_0x3b7712),Utils['showToast'](_0x3b7712['message']||'Failed\x20to\x20move\x20variant','error');}}async['addToGroup'](_0x4b5510,_0x4ad6a9){const _0x3c8de3=this['tasks']['find'](_0x7306c5=>_0x7306c5['taskId']===_0x4b5510);if(!_0x3c8de3)return;_0x4ad6a9===undefined&&(_0x4ad6a9=this['tasks']['filter'](_0x13bba6=>_0x13bba6['groupId']===this['groupId'])['length']),!this['groupId']&&(this['groupId']=API['generateGroupId'](),await API['createTaskGroup']({'groupId':this['groupId']})),await API['updateTaskGroup'](_0x4b5510,this['groupId'],_0x4ad6a9),_0x3c8de3['groupId']=this['groupId'],_0x3c8de3['groupIndex']=_0x4ad6a9,this['render'](),this['onGroupChange'](this['tasks']);}async['removeFromGroup'](_0x17bbf1){const _0x1d76ce=this['tasks']['find'](_0x206fce=>_0x206fce['taskId']===_0x17bbf1);if(!_0x1d76ce)return;await API['removeTaskFromGroup'](_0x17bbf1),_0x1d76ce['groupId']=null,_0x1d76ce['groupIndex']=null,this['render'](),this['onGroupChange'](this['tasks']);}async['reorderInGroup'](_0x2a29b8,_0x4e5177,_0xb0e3e6){const _0x129054=this['tasks']['find'](_0x419fc7=>_0x419fc7['taskId']===_0x2a29b8),_0x20b10d=_0x4e5177['dataset']['taskId'],_0x36b642=this['tasks']['find'](_0x2b946b=>_0x2b946b['taskId']===_0x20b10d);if(!_0x129054||!_0x36b642||_0x129054['taskId']===_0x36b642['taskId'])return;const _0xc5d875=_0x4e5177['getBoundingClientRect'](),_0x52eadd=_0xb0e3e6<_0xc5d875['top']+_0xc5d875['height']/0x2;let _0x28bbf4=_0x36b642['groupIndex']??0x0;if(!_0x52eadd)_0x28bbf4++;if((_0x129054['groupIndex']??0x0)<(_0x36b642['groupIndex']??0x0))_0x28bbf4--;if(_0x28bbf4===_0x129054['groupIndex'])return;await API['updateTaskGroup'](_0x2a29b8,this['groupId'],_0x28bbf4);const _0x57d2a4=this['tasks']['filter'](_0x57b14b=>_0x57b14b['groupId']===this['groupId'])['sort']((_0x58c213,_0x2e3bff)=>(_0x58c213['groupIndex']??0x0)-(_0x2e3bff['groupIndex']??0x0)),_0x309c44=_0x57d2a4['findIndex'](_0x5ed62a=>_0x5ed62a['taskId']===_0x2a29b8);_0x309c44!==-0x1&&_0x57d2a4['splice'](_0x309c44,0x1),_0x57d2a4['splice'](_0x28bbf4,0x0,_0x129054),_0x57d2a4['forEach']((_0x2087c0,_0x11b035)=>{_0x2087c0['groupIndex']=_0x11b035;}),this['render'](),this['onGroupChange'](this['tasks']);}}export function initializeTabDragDrop(_0x1a93b7,_0x1e1a47,_0x10caf2,_0xd93867={}){if(!_0x1a93b7)return;const {onReorder:_0x30383f,onRemove:_0x2ce90d}=_0xd93867,_0x48fda5=_0x1a93b7['querySelectorAll']('.task-tab');_0x48fda5['forEach']((_0x167516,_0x3b72e9)=>{_0x167516['setAttribute']('draggable','true'),_0x167516['dataset']['index']=_0x3b72e9,_0x167516['addEventListener']('dragstart',_0x4bf03e=>{_0x4bf03e['dataTransfer']['effectAllowed']='move',_0x4bf03e['dataTransfer']['setData']('text/plain',_0x167516['dataset']['taskId']),_0x167516['classList']['add']('dragging'),_0x1a93b7['classList']['add']('is-dragging');}),_0x167516['addEventListener']('dragend',()=>{_0x167516['classList']['remove']('dragging'),_0x1a93b7['classList']['remove']('is-dragging'),_0x1a93b7['querySelectorAll']('.drop-indicator')['forEach'](_0x227034=>{_0x227034['classList']['remove']('drop-indicator','drop-before','drop-after');});}),_0x167516['addEventListener']('dragover',_0x3b9ba7=>{_0x3b9ba7['preventDefault'](),_0x3b9ba7['dataTransfer']['dropEffect']='move';if(_0x167516['classList']['contains']('dragging'))return;const _0x804b47=_0x167516['getBoundingClientRect'](),_0x5426d2=_0x804b47['left']+_0x804b47['width']/0x2,_0x262224=_0x3b9ba7['clientX']<_0x5426d2;_0x48fda5['forEach'](_0x2d4066=>_0x2d4066['classList']['remove']('drop-before','drop-after')),_0x167516['classList']['add'](_0x262224?'drop-before':'drop-after');}),_0x167516['addEventListener']('dragleave',()=>{_0x167516['classList']['remove']('drop-before','drop-after');}),_0x167516['addEventListener']('drop',async _0x544079=>{_0x544079['preventDefault']();const _0x1f2a0e=_0x544079['dataTransfer']['getData']('text/plain'),_0x404401=_0x167516['dataset']['taskId'];if(_0x1f2a0e===_0x404401)return;const _0x58d26b=_0x167516['getBoundingClientRect'](),_0x27c4d2=_0x544079['clientX']<_0x58d26b['left']+_0x58d26b['width']/0x2;_0x167516['classList']['remove']('drop-before','drop-after'),_0x30383f&&await _0x30383f(_0x1f2a0e,_0x404401,_0x27c4d2);});});const _0x1d2421=document['createElement']('div');return _0x1d2421['className']='task-tab-remove-zone',_0x1d2421['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',_0x1d2421['style']['display']='none',_0x1d2421['addEventListener']('dragover',_0x309d57=>{_0x309d57['preventDefault'](),_0x1d2421['classList']['add']('drag-over');}),_0x1d2421['addEventListener']('dragleave',()=>{_0x1d2421['classList']['remove']('drag-over');}),_0x1d2421['addEventListener']('drop',async _0x5af8c8=>{_0x5af8c8['preventDefault'](),_0x1d2421['classList']['remove']('drag-over');const _0x2c0f0f=_0x5af8c8['dataTransfer']['getData']('text/plain');_0x2ce90d&&await _0x2ce90d(_0x2c0f0f);}),_0x1a93b7['addEventListener']('dragstart',()=>{_0x1e1a47['length']>0x1&&(_0x1d2421['style']['display']='flex');}),_0x1a93b7['addEventListener']('dragend',()=>{_0x1d2421['style']['display']='none';}),_0x1a93b7['appendChild'](_0x1d2421),{'destroy':()=>{_0x1d2421['remove']();}};}export default VariantGroupingManager;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@profoundlogic/coderflow-server",
3
- "version": "0.8.0",
3
+ "version": "0.8.1",
4
4
  "description": "AI Coder Server - Manages Docker containers for AI agent task execution",
5
5
  "main": "dist/start.js",
6
6
  "type": "module",