@profoundlogic/coderflow-server 0.7.0 → 0.7.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 (172) hide show
  1. package/dist/base-image/standard-instructions/ibmi-exploratory-verification.md +2 -0
  2. package/dist/coder-server.js +1 -1
  3. package/dist/config.js +1 -1
  4. package/dist/lib/agent-keepalive.js +1 -1
  5. package/dist/lib/agent-models.js +1 -1
  6. package/dist/lib/api-keys.js +1 -1
  7. package/dist/lib/apiKeys.js +1 -1
  8. package/dist/lib/app-server-ports.js +1 -1
  9. package/dist/lib/auto-judge.js +1 -1
  10. package/dist/lib/automation-service.js +1 -1
  11. package/dist/lib/basic-auth.js +1 -1
  12. package/dist/lib/bindings.js +1 -1
  13. package/dist/lib/build-history.js +1 -1
  14. package/dist/lib/build-output-service.js +1 -1
  15. package/dist/lib/build-scheduler.js +1 -1
  16. package/dist/lib/build-service.js +1 -1
  17. package/dist/lib/ca-certificates.js +1 -1
  18. package/dist/lib/claude-oauth-refresh.js +1 -1
  19. package/dist/lib/cli/build.js +1 -1
  20. package/dist/lib/cli/cleanup-users.js +1 -1
  21. package/dist/lib/cli/config-command.js +1 -1
  22. package/dist/lib/cli/config.js +1 -1
  23. package/dist/lib/cli/create-user.js +1 -1
  24. package/dist/lib/cli/grant-admin.js +1 -1
  25. package/dist/lib/cli/init.js +1 -1
  26. package/dist/lib/cli/jira.js +1 -1
  27. package/dist/lib/cli/license.js +1 -1
  28. package/dist/lib/cli/list-roles.js +1 -1
  29. package/dist/lib/cli/list-users.js +1 -1
  30. package/dist/lib/cli/server-manager.js +1 -1
  31. package/dist/lib/cli/set-password.js +1 -1
  32. package/dist/lib/config-migration.js +1 -1
  33. package/dist/lib/container-credential-sync.js +1 -1
  34. package/dist/lib/container-tokens.js +1 -1
  35. package/dist/lib/data-dir.js +1 -1
  36. package/dist/lib/deployment-history.js +1 -1
  37. package/dist/lib/deployment-service.js +1 -1
  38. package/dist/lib/docker-utils.js +1 -1
  39. package/dist/lib/email.js +1 -1
  40. package/dist/lib/emailTemplates.js +1 -1
  41. package/dist/lib/entitlement.js +1 -1
  42. package/dist/lib/external-connections.js +1 -1
  43. package/dist/lib/fetch-utils.js +1 -1
  44. package/dist/lib/git-commit-details-route.js +1 -1
  45. package/dist/lib/git-history-diff-guardrails.js +1 -1
  46. package/dist/lib/git-provider-service.js +1 -1
  47. package/dist/lib/git-provider-setup/github-setup-handler.js +1 -1
  48. package/dist/lib/git-provider-setup/index.js +1 -1
  49. package/dist/lib/git-provider-setup/setup-factory.js +1 -1
  50. package/dist/lib/git-provider-setup/setup-interface.js +1 -1
  51. package/dist/lib/git-providers/azure-devops-provider.js +1 -1
  52. package/dist/lib/git-providers/github-app-provider.js +1 -1
  53. package/dist/lib/git-providers/index.js +1 -1
  54. package/dist/lib/git-providers/provider-factory.js +1 -1
  55. package/dist/lib/git-providers/provider-interface.js +1 -1
  56. package/dist/lib/github-urls.js +1 -1
  57. package/dist/lib/group-objective-linking.js +1 -1
  58. package/dist/lib/ibmi-sync.js +1 -1
  59. package/dist/lib/jira-client.js +1 -1
  60. package/dist/lib/judge-blinding.js +1 -1
  61. package/dist/lib/logger.js +1 -1
  62. package/dist/lib/migration-to-scoped-rbac.js +1 -1
  63. package/dist/lib/model-fetcher.js +1 -1
  64. package/dist/lib/notifications.js +1 -1
  65. package/dist/lib/objective-context.js +1 -1
  66. package/dist/lib/oidc-auth.js +1 -1
  67. package/dist/lib/oidc-device-flow.js +1 -1
  68. package/dist/lib/passwordTokens.js +1 -1
  69. package/dist/lib/permission-resolver.js +1 -1
  70. package/dist/lib/pin-cascade.js +1 -1
  71. package/dist/lib/provider-accounts.js +1 -1
  72. package/dist/lib/provider-oauth.js +1 -1
  73. package/dist/lib/provider-profile.js +1 -1
  74. package/dist/lib/provider-token-refresh.js +1 -1
  75. package/dist/lib/rbac-user-state.js +1 -1
  76. package/dist/lib/request-url.js +1 -1
  77. package/dist/lib/rewind.js +1 -1
  78. package/dist/lib/role-definitions.js +1 -1
  79. package/dist/lib/roles.js +1 -1
  80. package/dist/lib/secrets.js +1 -1
  81. package/dist/lib/setup-repo-git-auth.js +1 -1
  82. package/dist/lib/state-capture.js +1 -1
  83. package/dist/lib/static-files.js +1 -1
  84. package/dist/lib/task-aliases.js +1 -1
  85. package/dist/lib/task-name-format.js +1 -1
  86. package/dist/lib/task-name-generator.js +1 -1
  87. package/dist/lib/task-source-metadata.js +1 -1
  88. package/dist/lib/teams.js +1 -1
  89. package/dist/lib/user-git-oauth.js +1 -1
  90. package/dist/lib/user-git-tokens.js +1 -1
  91. package/dist/lib/users.js +1 -1
  92. package/dist/middleware/requireAuth.js +1 -1
  93. package/dist/middleware/requireInit.js +1 -1
  94. package/dist/middleware/requirePermission.js +1 -1
  95. package/dist/package.json +1 -1
  96. package/dist/playwright.config.js +1 -1
  97. package/dist/playwright.task-terminal.config.js +1 -1
  98. package/dist/routes/apiKeys.js +1 -1
  99. package/dist/routes/auth-oidc.js +1 -1
  100. package/dist/routes/auth.js +1 -1
  101. package/dist/routes/automations.js +1 -1
  102. package/dist/routes/bindings.js +1 -1
  103. package/dist/routes/build.js +1 -1
  104. package/dist/routes/containers.js +1 -1
  105. package/dist/routes/deploy-task.js +1 -1
  106. package/dist/routes/environment-management.js +1 -1
  107. package/dist/routes/environments.js +1 -1
  108. package/dist/routes/external-skills.js +1 -1
  109. package/dist/routes/git-credentials.js +1 -1
  110. package/dist/routes/git-oauth.js +1 -1
  111. package/dist/routes/git-provider-setup.js +1 -1
  112. package/dist/routes/health.js +1 -1
  113. package/dist/routes/jira.js +1 -1
  114. package/dist/routes/objective-management.js +1 -1
  115. package/dist/routes/password.js +1 -1
  116. package/dist/routes/prompt.js +1 -1
  117. package/dist/routes/provider-auth.js +1 -1
  118. package/dist/routes/qa.js +1 -1
  119. package/dist/routes/roles.js +1 -1
  120. package/dist/routes/settings.js +1 -1
  121. package/dist/routes/skill-management.js +1 -1
  122. package/dist/routes/skills.js +1 -1
  123. package/dist/routes/tasks.js +1 -1
  124. package/dist/routes/teams.js +1 -1
  125. package/dist/routes/templates.js +1 -1
  126. package/dist/routes/test-task.js +1 -1
  127. package/dist/routes/test.js +1 -1
  128. package/dist/routes/users.js +1 -1
  129. package/dist/routes/visualizations.js +1 -1
  130. package/dist/scripts/create-user.js +1 -1
  131. package/dist/scripts/migrate-config-to-data-dir.js +1 -1
  132. package/dist/start.js +1 -1
  133. package/dist/web-ui/public/activity-detail-modal.js +1 -1
  134. package/dist/web-ui/public/activity-feed.js +1 -1
  135. package/dist/web-ui/public/activity-formatters.js +1 -1
  136. package/dist/web-ui/public/agent-event-parser.js +1 -1
  137. package/dist/web-ui/public/app.js +1 -1
  138. package/dist/web-ui/public/approve-dialog.js +1 -1
  139. package/dist/web-ui/public/automation-links.js +1 -1
  140. package/dist/web-ui/public/automation-schedule.js +1 -1
  141. package/dist/web-ui/public/comments-widget.js +1 -1
  142. package/dist/web-ui/public/diff-utils.js +1 -1
  143. package/dist/web-ui/public/environments.js +1 -1
  144. package/dist/web-ui/public/feedback-widget.js +1 -1
  145. package/dist/web-ui/public/file-selection-tree.js +1 -1
  146. package/dist/web-ui/public/git-history-lazy-utils.js +1 -1
  147. package/dist/web-ui/public/git-history.js +1 -1
  148. package/dist/web-ui/public/git-status.js +1 -1
  149. package/dist/web-ui/public/ibmi-file-filter.js +1 -1
  150. package/dist/web-ui/public/index.js +1 -1
  151. package/dist/web-ui/public/login.js +1 -1
  152. package/dist/web-ui/public/markdown-editor.js +1 -1
  153. package/dist/web-ui/public/markdown-file-editor.js +1 -1
  154. package/dist/web-ui/public/modal-maximize.js +1 -1
  155. package/dist/web-ui/public/notifications.js +1 -1
  156. package/dist/web-ui/public/permissions.js +1 -1
  157. package/dist/web-ui/public/pr-dialog.js +1 -1
  158. package/dist/web-ui/public/roles.js +1 -1
  159. package/dist/web-ui/public/server-health.js +1 -1
  160. package/dist/web-ui/public/settings.js +1 -1
  161. package/dist/web-ui/public/setup-password.js +1 -1
  162. package/dist/web-ui/public/skills.js +1 -1
  163. package/dist/web-ui/public/sse-client.js +1 -1
  164. package/dist/web-ui/public/sse-shared-worker.js +1 -1
  165. package/dist/web-ui/public/task-judging-helpers.js +1 -1
  166. package/dist/web-ui/public/task.js +1 -1
  167. package/dist/web-ui/public/teams.js +1 -1
  168. package/dist/web-ui/public/terminal.js +1 -1
  169. package/dist/web-ui/public/theme.js +1 -1
  170. package/dist/web-ui/public/users.js +1 -1
  171. package/dist/web-ui/public/variant-grouping.js +1 -1
  172. 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 _0x2e1064=state['currentUser'];if(!Permissions['hasServerPermission'](_0x2e1064,'teams:view')&&!Permissions['hasTeamPermission'](_0x2e1064,'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'](_0x2e1064,'*')||Permissions['hasTeamPermission'](_0x2e1064,'teams:manage'))&&(document['getElementById']('create-team-btn')['hidden']=![]),bindEventListeners(),await Promise['all']([loadTeams(),loadUsers(),loadRoles(),loadEnvironments()]),renderTeams();});async function loadTeams(){const _0x4c6535=document['getElementById']('teams-loading'),_0x3ac650=document['getElementById']('teams-error'),_0x333cb8=document['getElementById']('teams-content');try{_0x4c6535['hidden']=![],_0x3ac650['hidden']=!![],_0x333cb8['hidden']=!![];const {teams:_0x4c3995}=await API['getTeams']();state['teams']=_0x4c3995||[],renderTeams(),_0x4c6535['hidden']=!![],_0x333cb8['hidden']=![];}catch(_0x524af4){_0x4c6535['hidden']=!![],_0x3ac650['hidden']=![],document['getElementById']('teams-error-message')['textContent']=_0x524af4['message'];}}async function loadUsers(){try{const {users:_0x38d99f}=await API['getUsers']();state['users']=_0x38d99f||[];}catch{state['users']=[];}}async function loadRoles(){try{const {roles:_0x3136a0}=await API['getRoleDefinitions']();state['roles']=_0x3136a0||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x50dad5=await API['getEnvironments']();state['environments']=_0x50dad5['environments']||[];}catch{state['environments']=[];}}function renderTeams(){const _0x36a26a=document['getElementById']('teams-table-body'),_0x242f6f=document['getElementById']('team-count');if(!_0x36a26a)return;_0x242f6f&&(_0x242f6f['textContent']=state['teams']['length']+'\x20team'+(state['teams']['length']===0x1?'':'s'));if(state['teams']['length']===0x0){_0x36a26a['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 _0x3bf5ff=Permissions['hasServerPermission'](state['currentUser'],'*');_0x36a26a['innerHTML']=state['teams']['map'](_0x42087d=>{const _0x1eb53b=_0x3bf5ff||_0x42087d['canManageTeam'],_0x251881=_0x3bf5ff||_0x42087d['canManageMembers'],_0x5ebd9d=_0x1eb53b||_0x251881,_0x13f6bb=(_0x42087d['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'](_0x42087d['name'])+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x42087d['description']?'<div\x20style=\x22font-size:\x200.8em;\x20color:\x20var(--color-text-secondary);\x20margin-top:\x200.15rem;\x22>'+Utils['escapeHtml'](_0x42087d['description'])+'</div>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+_0x13f6bb+'</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'+(_0x5ebd9d?'<button\x20class=\x22btn-icon\x22\x20title=\x22Edit\x20team\x22\x20onclick=\x22window.openTeamModal(\x27'+_0x42087d['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'+(_0x1eb53b?'<button\x20class=\x22btn-icon\x22\x20title=\x22Access\x20bindings\x22\x20onclick=\x22window.openBindingsModal(\x27'+_0x42087d['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'+(_0x1eb53b?'<button\x20class=\x22btn-icon\x20btn-danger\x22\x20title=\x22Delete\x20team\x22\x20onclick=\x22window.deleteTeam(\x27'+_0x42087d['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(_0x201226){const _0x80f006=state['teams']['find'](_0x29e796=>_0x29e796['id']===_0x201226);if(!_0x80f006)return;state['editingTeamId']=_0x201226;const _0x419d41=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x561488=_0x419d41||_0x80f006['canManageTeam'],_0x2bf38f=_0x419d41||_0x80f006['canManageMembers'],_0x1146d9=_0x561488,_0x330539=_0x561488||_0x2bf38f,_0x2377c3=_0x80f006['name'],_0x33e873=_0x80f006['description']||'';state['modalSnapshot']={'name':_0x2377c3,'description':_0x33e873},document['getElementById']('team-modal-title')['textContent']=_0x2377c3,document['getElementById']('team-name')['value']=_0x2377c3,document['getElementById']('team-name')['disabled']=!_0x1146d9,document['getElementById']('team-description')['value']=_0x33e873,document['getElementById']('team-description')['disabled']=!_0x1146d9,document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=![],document['getElementById']('save-team')['hidden']=!_0x1146d9,renderMembersList(_0x80f006),updateMemberSelect(_0x80f006),document['getElementById']('team-modal')['hidden']=![];};function isTeamModalDirty(){if(!state['modalSnapshot'])return![];const _0x2f1a1=document['getElementById']('team-name')['value']['trim'](),_0x4177c2=document['getElementById']('team-description')['value']['trim']();return _0x2f1a1!==state['modalSnapshot']['name']||_0x4177c2!==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(_0x221161){const _0xcb479c=state['teams']['find'](_0x2b5a78=>_0x2b5a78['id']===_0x221161);if(!_0xcb479c)return;state['bindingsTeamId']=_0x221161,document['getElementById']('bindings-modal-title')['textContent']='Access\x20Bindings\x20—\x20'+_0xcb479c['name'],document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('bindings-modal')['hidden']=![],loadTeamBindings(_0x221161);};function hideBindingsModal(){document['getElementById']('bindings-modal')['hidden']=!![],state['bindingsTeamId']=null;}function renderMembersList(_0xce3c7a){const _0x38a2fa=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x40783c=_0x38a2fa||_0xce3c7a['canManageMembers']||_0xce3c7a['canManageTeam'],_0x484c15=_0xce3c7a['members']||[],_0x5498d0=document['getElementById']('members-list');if(_0x484c15['length']===0x0){_0x5498d0['innerHTML']='<p\x20style=\x22font-size:\x200.875rem;\x20color:\x20var(--color-text-secondary);\x20margin:\x200.25rem\x200;\x22>No\x20members\x20yet</p>';return;}_0x5498d0['innerHTML']=_0x484c15['map'](_0x31ee90=>{const _0x513cf9=state['users']['find'](_0xc441f0=>_0xc441f0['id']===_0x31ee90),_0x3c9fc2=_0x513cf9?''+Utils['escapeHtml'](_0x513cf9['username'])+(_0x513cf9['name']?'\x20<span\x20style=\x22color:\x20var(--color-text-secondary);\x20font-size:\x200.85em;\x22>('+Utils['escapeHtml'](_0x513cf9['name'])+')</span>':''):Utils['escapeHtml'](_0x31ee90);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'+_0x3c9fc2+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x40783c?'<button\x20type=\x22button\x22\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.removeMemberClick(\x27'+_0x31ee90+'\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 _0x5d6def=document['getElementById']('add-member-row');if(_0x5d6def)_0x5d6def['style']['display']=_0x40783c?'flex':'none';}function updateMemberSelect(_0x292aec){const _0x30bcc9=document['getElementById']('add-member-select');if(!_0x30bcc9)return;const _0x1f254c=new Set(_0x292aec['members']||[]),_0x4e671a=state['users']['filter'](_0x197a29=>!_0x1f254c['has'](_0x197a29['id']));_0x30bcc9['innerHTML']='<option\x20value=\x22\x22>Add\x20a\x20member…</option>'+_0x4e671a['map'](_0x473aa1=>'<option\x20value=\x22'+_0x473aa1['id']+'\x22>'+Utils['escapeHtml'](_0x473aa1['username'])+(_0x473aa1['name']?'\x20('+Utils['escapeHtml'](_0x473aa1['name'])+')':'')+'</option>')['join']('');}async function addMember(){const _0x353001=document['getElementById']('add-member-select'),_0x303902=_0x353001['value'];if(!_0x303902||!state['editingTeamId'])return;try{const {team:_0x255bcb}=await API['addTeamMember'](state['editingTeamId'],_0x303902);syncTeamInState(_0x255bcb),renderMembersList(_0x255bcb),updateMemberSelect(_0x255bcb),_0x353001['value']='',Utils['showToast']('Member\x20added','success');}catch(_0x5e9e54){Utils['showToast'](_0x5e9e54['message'],'error');}}window['removeMemberClick']=async function(_0x22fce8){if(!state['editingTeamId'])return;try{const {team:_0x5444ac}=await API['removeTeamMember'](state['editingTeamId'],_0x22fce8);syncTeamInState(_0x5444ac),renderMembersList(_0x5444ac),updateMemberSelect(_0x5444ac),Utils['showToast']('Member\x20removed','success');}catch(_0x42f24f){Utils['showToast'](_0x42f24f['message'],'error');}};async function loadTeamBindings(_0x3aa9c4){const _0x4682aa=document['getElementById']('bindings-loading'),_0x4b8c3b=document['getElementById']('bindings-empty'),_0x19d5c6=document['getElementById']('bindings-list-container'),_0x4e001e=document['getElementById']('add-binding-btn');_0x4682aa['hidden']=![],_0x4b8c3b['hidden']=!![],_0x19d5c6['style']['display']='none',_0x4e001e['hidden']=!![],document['getElementById']('add-binding-form')['hidden']=!![];try{const {bindings:_0x57e947}=await API['getBindings']({'subject_type':'team','subject_id':_0x3aa9c4});state['teamBindings']=_0x57e947||[],_0x4682aa['hidden']=!![],state['teamBindings']['length']===0x0?_0x4b8c3b['hidden']=![]:(_0x19d5c6['style']['display']='',renderBindingsTable()),(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage'))&&(_0x4e001e['hidden']=![]);}catch(_0x20fb21){_0x4682aa['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x20fb21['message'],'error');}}function renderBindingsTable(){const _0x4159fa=document['getElementById']('bindings-table-body');if(!_0x4159fa)return;const _0x3a277a=Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage');_0x4159fa['innerHTML']=state['teamBindings']['map'](_0x52600d=>{const _0x4bba0a=_0x52600d['resource_type']==='server'?'Server':_0x52600d['resource_id']==='*'?'All\x20'+_0x52600d['resource_type']+'s':Utils['escapeHtml'](_0x52600d['resource_name']||_0x52600d['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x4bba0a+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x52600d['role_name']||_0x52600d['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x3a277a?'<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteBindingClick(\x27'+_0x52600d['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 _0x444d47=document['getElementById']('binding-resource-type');_0x444d47['value']='environment',updateBindingFormForResourceType('environment');}function onBindingResourceTypeChange(){const _0x16ae77=document['getElementById']('binding-resource-type')['value'];updateBindingFormForResourceType(_0x16ae77);}function updateBindingFormForResourceType(_0x55dca3){const _0x2bf797=document['getElementById']('binding-resource-container'),_0x4374d5=document['getElementById']('binding-resource'),_0x40548e=document['getElementById']('binding-role');if(_0x55dca3==='server')_0x2bf797['style']['display']='none';else{_0x2bf797['style']['display']='';if(_0x55dca3==='environment'){const _0x71be87=new Set(state['teamBindings']['filter'](_0x1c4d4f=>_0x1c4d4f['resource_type']==='environment')['map'](_0x19a657=>_0x19a657['resource_id'])),_0x532e71=state['environments']['filter'](_0x17e2a1=>!_0x71be87['has'](_0x17e2a1['name']));_0x4374d5['innerHTML']=_0x532e71['length']?_0x532e71['map'](_0x14482e=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x14482e['name'])+'\x22>'+Utils['escapeHtml'](_0x14482e['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x55dca3==='team'){const _0x4eb03a=new Set(state['teamBindings']['filter'](_0x1ca8db=>_0x1ca8db['resource_type']==='team')['map'](_0x412d7b=>_0x412d7b['resource_id'])),_0x4da0be=state['teams']['filter'](_0x246f9b=>!_0x4eb03a['has'](_0x246f9b['id']));_0x4374d5['innerHTML']=_0x4da0be['length']?_0x4da0be['map'](_0xcc525b=>'<option\x20value=\x22'+_0xcc525b['id']+'\x22>'+Utils['escapeHtml'](_0xcc525b['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x2dc39e=state['roles']['filter'](_0x4c5e33=>_0x4c5e33['resource_type']===_0x55dca3);_0x40548e['innerHTML']=_0x2dc39e['length']?_0x2dc39e['filter'](_0x346ac5=>{const _0x5c5ccd=_0x55dca3==='server'?undefined:_0x4374d5['value'];return!state['teamBindings']['some'](_0x10437d=>_0x10437d['resource_type']===_0x55dca3&&_0x10437d['role_id']===_0x346ac5['id']&&(_0x55dca3==='server'||_0x10437d['resource_id']===_0x5c5ccd));})['map'](_0x2ee438=>'<option\x20value=\x22'+_0x2ee438['id']+'\x22>'+Utils['escapeHtml'](_0x2ee438['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 _0x2f4fd5=document['getElementById']('binding-resource-type')['value'],_0x1081d2=document['getElementById']('binding-role')['value'];if(!_0x1081d2||!state['bindingsTeamId'])return;const _0x421ac1=_0x2f4fd5==='server'?undefined:document['getElementById']('binding-resource')['value'];if(_0x2f4fd5!=='server'&&!_0x421ac1)return;const _0x3dbd9d=document['getElementById']('save-binding-btn');_0x3dbd9d['disabled']=!![],_0x3dbd9d['textContent']='Adding…';try{const _0xcd15f={'subject_type':'team','subject_id':state['bindingsTeamId'],'role_id':_0x1081d2,'resource_type':_0x2f4fd5};if(_0x421ac1)_0xcd15f['resource_id']=_0x421ac1;await API['createBinding'](_0xcd15f),Utils['showToast']('Binding\x20added','success'),document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![],await loadTeamBindings(state['bindingsTeamId']);}catch(_0x4501ea){Utils['showToast'](_0x4501ea['message'],'error');}finally{_0x3dbd9d['disabled']=![],_0x3dbd9d['textContent']='Add\x20Binding';}}window['deleteBindingClick']=async function(_0x2cf49e){try{await API['deleteBinding'](_0x2cf49e),Utils['showToast']('Binding\x20removed','success'),await loadTeamBindings(state['bindingsTeamId']);}catch(_0x4a4610){Utils['showToast'](_0x4a4610['message'],'error');}};async function saveTeam(){const _0x2a52ac=document['getElementById']('team-name')['value']['trim'](),_0x111eef=document['getElementById']('team-description')['value']['trim'](),_0x367977=document['getElementById']('team-form-error'),_0x1012e4=document['getElementById']('save-team');if(!_0x2a52ac){_0x367977['textContent']='Team\x20name\x20is\x20required',_0x367977['hidden']=![];return;}_0x367977['hidden']=!![];const _0x18dd2f=_0x1012e4['textContent'];_0x1012e4['disabled']=!![],_0x1012e4['textContent']=state['editingTeamId']?'Saving…':'Creating…';try{if(state['editingTeamId']){const {team:_0x2de994}=await API['updateTeam'](state['editingTeamId'],{'name':_0x2a52ac,'description':_0x111eef});syncTeamInState(_0x2de994),document['getElementById']('team-modal-title')['textContent']=_0x2de994['name'],Utils['showToast']('Team\x20updated','success');}else await API['createTeam']({'name':_0x2a52ac,'description':_0x111eef}),Utils['showToast']('Team\x20created','success');_0x1012e4['disabled']=![],_0x1012e4['textContent']=_0x18dd2f,hideTeamModal(),await loadTeams();}catch(_0xb6bb40){_0x367977['textContent']=_0xb6bb40['message'],_0x367977['hidden']=![],_0x1012e4['disabled']=![],_0x1012e4['textContent']=_0x18dd2f;}}window['deleteTeam']=function(_0x573bb3){const _0x100456=state['teams']['find'](_0x361673=>_0x361673['id']===_0x573bb3);if(!_0x100456)return;state['deletingTeamId']=_0x573bb3,document['getElementById']('delete-team-name')['textContent']=_0x100456['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 _0x5d387f=document['getElementById']('confirm-delete-team');_0x5d387f['disabled']=!![],_0x5d387f['textContent']='Deleting…';try{await API['deleteTeam'](state['deletingTeamId']),Utils['showToast']('Team\x20deleted','success'),_0x5d387f['disabled']=![],_0x5d387f['textContent']='Delete\x20Team',hideDeleteModal(),await loadTeams();}catch(_0xae2935){Utils['showToast']('Failed\x20to\x20delete\x20team:\x20'+_0xae2935['message'],'error'),_0x5d387f['disabled']=![],_0x5d387f['textContent']='Delete\x20Team';}}function syncTeamInState(_0x21b503){const _0x41c375=state['teams']['findIndex'](_0x952bf5=>_0x952bf5['id']===_0x21b503['id']);if(_0x41c375>=0x0)state['teams'][_0x41c375]=_0x21b503;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 _0x2b9a5f=state['currentUser'];if(!Permissions['hasServerPermission'](_0x2b9a5f,'teams:view')&&!Permissions['hasTeamPermission'](_0x2b9a5f,'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'](_0x2b9a5f,'*')||Permissions['hasTeamPermission'](_0x2b9a5f,'teams:manage'))&&(document['getElementById']('create-team-btn')['hidden']=![]),bindEventListeners(),await Promise['all']([loadTeams(),loadUsers(),loadRoles(),loadEnvironments()]),renderTeams();});async function loadTeams(){const _0x548733=document['getElementById']('teams-loading'),_0x58b7d3=document['getElementById']('teams-error'),_0x2dba76=document['getElementById']('teams-content');try{_0x548733['hidden']=![],_0x58b7d3['hidden']=!![],_0x2dba76['hidden']=!![];const {teams:_0x4e098e}=await API['getTeams']();state['teams']=_0x4e098e||[],renderTeams(),_0x548733['hidden']=!![],_0x2dba76['hidden']=![];}catch(_0x25346e){_0x548733['hidden']=!![],_0x58b7d3['hidden']=![],document['getElementById']('teams-error-message')['textContent']=_0x25346e['message'];}}async function loadUsers(){try{const {users:_0x27f4f8}=await API['getUsers']();state['users']=_0x27f4f8||[];}catch{state['users']=[];}}async function loadRoles(){try{const {roles:_0x22085f}=await API['getRoleDefinitions']();state['roles']=_0x22085f||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x4b7d9c=await API['getEnvironments']();state['environments']=_0x4b7d9c['environments']||[];}catch{state['environments']=[];}}function renderTeams(){const _0x5e212b=document['getElementById']('teams-table-body'),_0xff1009=document['getElementById']('team-count');if(!_0x5e212b)return;_0xff1009&&(_0xff1009['textContent']=state['teams']['length']+'\x20team'+(state['teams']['length']===0x1?'':'s'));if(state['teams']['length']===0x0){_0x5e212b['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 _0x4bdcf4=Permissions['hasServerPermission'](state['currentUser'],'*');_0x5e212b['innerHTML']=state['teams']['map'](_0x133fc3=>{const _0x40d827=_0x4bdcf4||_0x133fc3['canManageTeam'],_0x412637=_0x4bdcf4||_0x133fc3['canManageMembers'],_0x4d682d=_0x40d827||_0x412637,_0x4f0423=(_0x133fc3['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'](_0x133fc3['name'])+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x133fc3['description']?'<div\x20style=\x22font-size:\x200.8em;\x20color:\x20var(--color-text-secondary);\x20margin-top:\x200.15rem;\x22>'+Utils['escapeHtml'](_0x133fc3['description'])+'</div>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+_0x4f0423+'</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'+(_0x4d682d?'<button\x20class=\x22btn-icon\x22\x20title=\x22Edit\x20team\x22\x20onclick=\x22window.openTeamModal(\x27'+_0x133fc3['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'+(_0x40d827?'<button\x20class=\x22btn-icon\x22\x20title=\x22Access\x20bindings\x22\x20onclick=\x22window.openBindingsModal(\x27'+_0x133fc3['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'+(_0x40d827?'<button\x20class=\x22btn-icon\x20btn-danger\x22\x20title=\x22Delete\x20team\x22\x20onclick=\x22window.deleteTeam(\x27'+_0x133fc3['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(_0x653091){const _0x52965e=state['teams']['find'](_0x2b10b2=>_0x2b10b2['id']===_0x653091);if(!_0x52965e)return;state['editingTeamId']=_0x653091;const _0x3d71e4=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x57a2ef=_0x3d71e4||_0x52965e['canManageTeam'],_0xa11a=_0x3d71e4||_0x52965e['canManageMembers'],_0x5c18da=_0x57a2ef,_0x5d535e=_0x57a2ef||_0xa11a,_0x5766c0=_0x52965e['name'],_0x79a4e2=_0x52965e['description']||'';state['modalSnapshot']={'name':_0x5766c0,'description':_0x79a4e2},document['getElementById']('team-modal-title')['textContent']=_0x5766c0,document['getElementById']('team-name')['value']=_0x5766c0,document['getElementById']('team-name')['disabled']=!_0x5c18da,document['getElementById']('team-description')['value']=_0x79a4e2,document['getElementById']('team-description')['disabled']=!_0x5c18da,document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=![],document['getElementById']('save-team')['hidden']=!_0x5c18da,renderMembersList(_0x52965e),updateMemberSelect(_0x52965e),document['getElementById']('team-modal')['hidden']=![];};function isTeamModalDirty(){if(!state['modalSnapshot'])return![];const _0x386f3f=document['getElementById']('team-name')['value']['trim'](),_0x5a6002=document['getElementById']('team-description')['value']['trim']();return _0x386f3f!==state['modalSnapshot']['name']||_0x5a6002!==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(_0x53b7f8){const _0x3a24af=state['teams']['find'](_0x2d8e5f=>_0x2d8e5f['id']===_0x53b7f8);if(!_0x3a24af)return;state['bindingsTeamId']=_0x53b7f8,document['getElementById']('bindings-modal-title')['textContent']='Access\x20Bindings\x20—\x20'+_0x3a24af['name'],document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('bindings-modal')['hidden']=![],loadTeamBindings(_0x53b7f8);};function hideBindingsModal(){document['getElementById']('bindings-modal')['hidden']=!![],state['bindingsTeamId']=null;}function renderMembersList(_0x11325d){const _0x2372bc=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x4584c8=_0x2372bc||_0x11325d['canManageMembers']||_0x11325d['canManageTeam'],_0x6b0284=_0x11325d['members']||[],_0x514a2b=document['getElementById']('members-list');if(_0x6b0284['length']===0x0){_0x514a2b['innerHTML']='<p\x20style=\x22font-size:\x200.875rem;\x20color:\x20var(--color-text-secondary);\x20margin:\x200.25rem\x200;\x22>No\x20members\x20yet</p>';return;}_0x514a2b['innerHTML']=_0x6b0284['map'](_0x288da7=>{const _0x12c1e4=state['users']['find'](_0x279a17=>_0x279a17['id']===_0x288da7),_0x2e7568=_0x12c1e4?''+Utils['escapeHtml'](_0x12c1e4['username'])+(_0x12c1e4['name']?'\x20<span\x20style=\x22color:\x20var(--color-text-secondary);\x20font-size:\x200.85em;\x22>('+Utils['escapeHtml'](_0x12c1e4['name'])+')</span>':''):Utils['escapeHtml'](_0x288da7);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'+_0x2e7568+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x4584c8?'<button\x20type=\x22button\x22\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.removeMemberClick(\x27'+_0x288da7+'\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 _0x565f7b=document['getElementById']('add-member-row');if(_0x565f7b)_0x565f7b['style']['display']=_0x4584c8?'flex':'none';}function updateMemberSelect(_0x4e730d){const _0x177fc6=document['getElementById']('add-member-select');if(!_0x177fc6)return;const _0x2ad6c7=new Set(_0x4e730d['members']||[]),_0xad8c53=state['users']['filter'](_0x1cb3aa=>!_0x2ad6c7['has'](_0x1cb3aa['id']));_0x177fc6['innerHTML']='<option\x20value=\x22\x22>Add\x20a\x20member…</option>'+_0xad8c53['map'](_0x961b2=>'<option\x20value=\x22'+_0x961b2['id']+'\x22>'+Utils['escapeHtml'](_0x961b2['username'])+(_0x961b2['name']?'\x20('+Utils['escapeHtml'](_0x961b2['name'])+')':'')+'</option>')['join']('');}async function addMember(){const _0x583bb3=document['getElementById']('add-member-select'),_0x28d3ab=_0x583bb3['value'];if(!_0x28d3ab||!state['editingTeamId'])return;try{const {team:_0x59ff81}=await API['addTeamMember'](state['editingTeamId'],_0x28d3ab);syncTeamInState(_0x59ff81),renderMembersList(_0x59ff81),updateMemberSelect(_0x59ff81),_0x583bb3['value']='',Utils['showToast']('Member\x20added','success');}catch(_0x504d8f){Utils['showToast'](_0x504d8f['message'],'error');}}window['removeMemberClick']=async function(_0xc23850){if(!state['editingTeamId'])return;try{const {team:_0x4e2467}=await API['removeTeamMember'](state['editingTeamId'],_0xc23850);syncTeamInState(_0x4e2467),renderMembersList(_0x4e2467),updateMemberSelect(_0x4e2467),Utils['showToast']('Member\x20removed','success');}catch(_0x1b1748){Utils['showToast'](_0x1b1748['message'],'error');}};async function loadTeamBindings(_0x3fcc1e){const _0x247c90=document['getElementById']('bindings-loading'),_0x59bd00=document['getElementById']('bindings-empty'),_0x2aeb76=document['getElementById']('bindings-list-container'),_0x103b50=document['getElementById']('add-binding-btn');_0x247c90['hidden']=![],_0x59bd00['hidden']=!![],_0x2aeb76['style']['display']='none',_0x103b50['hidden']=!![],document['getElementById']('add-binding-form')['hidden']=!![];try{const {bindings:_0x28e5e1}=await API['getBindings']({'subject_type':'team','subject_id':_0x3fcc1e});state['teamBindings']=_0x28e5e1||[],_0x247c90['hidden']=!![],state['teamBindings']['length']===0x0?_0x59bd00['hidden']=![]:(_0x2aeb76['style']['display']='',renderBindingsTable()),(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage'))&&(_0x103b50['hidden']=![]);}catch(_0x46ccbe){_0x247c90['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x46ccbe['message'],'error');}}function renderBindingsTable(){const _0x1d5421=document['getElementById']('bindings-table-body');if(!_0x1d5421)return;const _0x1545e6=Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage');_0x1d5421['innerHTML']=state['teamBindings']['map'](_0x354513=>{const _0x41e1e8=_0x354513['resource_type']==='server'?'Server':_0x354513['resource_id']==='*'?'All\x20'+_0x354513['resource_type']+'s':Utils['escapeHtml'](_0x354513['resource_name']||_0x354513['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x41e1e8+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x354513['role_name']||_0x354513['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x1545e6?'<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteBindingClick(\x27'+_0x354513['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 _0x588e0f=document['getElementById']('binding-resource-type');_0x588e0f['value']='environment',updateBindingFormForResourceType('environment');}function onBindingResourceTypeChange(){const _0x59a665=document['getElementById']('binding-resource-type')['value'];updateBindingFormForResourceType(_0x59a665);}function updateBindingFormForResourceType(_0x504e3e){const _0x4abd90=document['getElementById']('binding-resource-container'),_0x269dfe=document['getElementById']('binding-resource'),_0x3512e4=document['getElementById']('binding-role');if(_0x504e3e==='server')_0x4abd90['style']['display']='none';else{_0x4abd90['style']['display']='';if(_0x504e3e==='environment'){const _0x216aed=new Set(state['teamBindings']['filter'](_0x25a1cb=>_0x25a1cb['resource_type']==='environment')['map'](_0x5b6daf=>_0x5b6daf['resource_id'])),_0xe2a846=state['environments']['filter'](_0x58b7f4=>!_0x216aed['has'](_0x58b7f4['name']));_0x269dfe['innerHTML']=_0xe2a846['length']?_0xe2a846['map'](_0x235e04=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x235e04['name'])+'\x22>'+Utils['escapeHtml'](_0x235e04['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x504e3e==='team'){const _0x4a0557=new Set(state['teamBindings']['filter'](_0x328d5c=>_0x328d5c['resource_type']==='team')['map'](_0x44517f=>_0x44517f['resource_id'])),_0x1e0967=state['teams']['filter'](_0x4227d6=>!_0x4a0557['has'](_0x4227d6['id']));_0x269dfe['innerHTML']=_0x1e0967['length']?_0x1e0967['map'](_0x50b4ac=>'<option\x20value=\x22'+_0x50b4ac['id']+'\x22>'+Utils['escapeHtml'](_0x50b4ac['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x21ed8a=state['roles']['filter'](_0x3d671f=>_0x3d671f['resource_type']===_0x504e3e);_0x3512e4['innerHTML']=_0x21ed8a['length']?_0x21ed8a['filter'](_0x2bbb40=>{const _0x197625=_0x504e3e==='server'?undefined:_0x269dfe['value'];return!state['teamBindings']['some'](_0x577e6b=>_0x577e6b['resource_type']===_0x504e3e&&_0x577e6b['role_id']===_0x2bbb40['id']&&(_0x504e3e==='server'||_0x577e6b['resource_id']===_0x197625));})['map'](_0x36b94d=>'<option\x20value=\x22'+_0x36b94d['id']+'\x22>'+Utils['escapeHtml'](_0x36b94d['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 _0x13ebe4=document['getElementById']('binding-resource-type')['value'],_0x166314=document['getElementById']('binding-role')['value'];if(!_0x166314||!state['bindingsTeamId'])return;const _0x4fb354=_0x13ebe4==='server'?undefined:document['getElementById']('binding-resource')['value'];if(_0x13ebe4!=='server'&&!_0x4fb354)return;const _0x5047b8=document['getElementById']('save-binding-btn');_0x5047b8['disabled']=!![],_0x5047b8['textContent']='Adding…';try{const _0x2a8ad7={'subject_type':'team','subject_id':state['bindingsTeamId'],'role_id':_0x166314,'resource_type':_0x13ebe4};if(_0x4fb354)_0x2a8ad7['resource_id']=_0x4fb354;await API['createBinding'](_0x2a8ad7),Utils['showToast']('Binding\x20added','success'),document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![],await loadTeamBindings(state['bindingsTeamId']);}catch(_0x380747){Utils['showToast'](_0x380747['message'],'error');}finally{_0x5047b8['disabled']=![],_0x5047b8['textContent']='Add\x20Binding';}}window['deleteBindingClick']=async function(_0x4ebaf5){try{await API['deleteBinding'](_0x4ebaf5),Utils['showToast']('Binding\x20removed','success'),await loadTeamBindings(state['bindingsTeamId']);}catch(_0x5c617c){Utils['showToast'](_0x5c617c['message'],'error');}};async function saveTeam(){const _0x2e23eb=document['getElementById']('team-name')['value']['trim'](),_0x2354c4=document['getElementById']('team-description')['value']['trim'](),_0x230915=document['getElementById']('team-form-error'),_0x560c41=document['getElementById']('save-team');if(!_0x2e23eb){_0x230915['textContent']='Team\x20name\x20is\x20required',_0x230915['hidden']=![];return;}_0x230915['hidden']=!![];const _0x51c52b=_0x560c41['textContent'];_0x560c41['disabled']=!![],_0x560c41['textContent']=state['editingTeamId']?'Saving…':'Creating…';try{if(state['editingTeamId']){const {team:_0x5a70f9}=await API['updateTeam'](state['editingTeamId'],{'name':_0x2e23eb,'description':_0x2354c4});syncTeamInState(_0x5a70f9),document['getElementById']('team-modal-title')['textContent']=_0x5a70f9['name'],Utils['showToast']('Team\x20updated','success');}else await API['createTeam']({'name':_0x2e23eb,'description':_0x2354c4}),Utils['showToast']('Team\x20created','success');_0x560c41['disabled']=![],_0x560c41['textContent']=_0x51c52b,hideTeamModal(),await loadTeams();}catch(_0x1934b0){_0x230915['textContent']=_0x1934b0['message'],_0x230915['hidden']=![],_0x560c41['disabled']=![],_0x560c41['textContent']=_0x51c52b;}}window['deleteTeam']=function(_0x12f1f4){const _0x145e2b=state['teams']['find'](_0x5363bc=>_0x5363bc['id']===_0x12f1f4);if(!_0x145e2b)return;state['deletingTeamId']=_0x12f1f4,document['getElementById']('delete-team-name')['textContent']=_0x145e2b['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 _0x5ceb52=document['getElementById']('confirm-delete-team');_0x5ceb52['disabled']=!![],_0x5ceb52['textContent']='Deleting…';try{await API['deleteTeam'](state['deletingTeamId']),Utils['showToast']('Team\x20deleted','success'),_0x5ceb52['disabled']=![],_0x5ceb52['textContent']='Delete\x20Team',hideDeleteModal(),await loadTeams();}catch(_0x22be50){Utils['showToast']('Failed\x20to\x20delete\x20team:\x20'+_0x22be50['message'],'error'),_0x5ceb52['disabled']=![],_0x5ceb52['textContent']='Delete\x20Team';}}function syncTeamInState(_0xff1d9b){const _0x21b929=state['teams']['findIndex'](_0x1bd3c9=>_0x1bd3c9['id']===_0xff1d9b['id']);if(_0x21b929>=0x0)state['teams'][_0x21b929]=_0xff1d9b;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'](_0x1b041c=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':_0x1b041c}));});let commandSent=![],hasReceivedOutput=![];socket['addEventListener']('message',_0x92c3d6=>{try{const _0x1860df=JSON['parse'](_0x92c3d6['data']);if(_0x1860df['type']==='data'&&typeof _0x1860df['data']==='string')term['write'](_0x1860df['data']),!hasReceivedOutput&&_0x1860df['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(_0x1860df['type']==='status'&&_0x1860df['status']){if(_0x1860df['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'+_0x1860df['status'],_0x1860df['status']==='connected'?'success':'info');}else _0x1860df['type']==='error'&&_0x1860df['message']&&updateStatus(_0x1860df['message'],'error');}}catch(_0x58b552){console['error']('Failed\x20to\x20parse\x20terminal\x20message',_0x58b552);}}),socket['addEventListener']('close',_0x452709=>{const _0x1ccd6d=_0x452709['reason']||'Connection\x20closed';updateStatus(_0x1ccd6d,_0x452709['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',_0x32379b=>{console['error']('Terminal\x20websocket\x20error',_0x32379b),updateStatus('Connection\x20error','error');});function sendResize(){if(socket['readyState']!==WebSocket['OPEN'])return;const _0x3df380=term['cols'],_0x23fd49=term['rows'];socket['send'](JSON['stringify']({'type':'resize','cols':_0x3df380,'rows':_0x23fd49}));}function updateStatus(_0x11b9b7,_0x174ea5='info'){if(!statusEl)return;statusEl['textContent']=_0x11b9b7,statusEl['dataset']['variant']=_0x174ea5;}async function enrichContainerDetails(_0xc562d7){try{const _0x21f2a7=await API['getContainer'](_0xc562d7);updateTerminalDetails(_0x21f2a7);}catch{try{const _0x4446fe=await API['getContainers'](),_0x1edaae=(_0x4446fe['containers']||[])['find'](_0x579fee=>_0x579fee['containerId']===_0xc562d7||_0x579fee['name']===_0xc562d7||_0x579fee['fullContainerId']?.['startsWith'](_0xc562d7));if(_0x1edaae){updateTerminalDetails(_0x1edaae);return;}subtitleEl['textContent']='Container\x20'+_0xc562d7['substring'](0x0,0xc);}catch{subtitleEl['textContent']='Container\x20'+_0xc562d7['substring'](0x0,0xc);}}}function updateTerminalDetails(_0xe38c71){const _0x23dd2d=_0xe38c71['containerId']||_0xe38c71['name']||_0xe38c71['fullContainerId']||containerId,_0x5f5d4e=_0xe38c71['environment']?'Environment\x20'+_0xe38c71['environment']:'Environment\x20unknown',_0x10d134=_0xe38c71['defaultAgent']?'\x20·\x20Agent\x20'+_0xe38c71['defaultAgent']:'',_0x502fa2=_0xe38c71['createdAt']?'\x20·\x20Started\x20'+Utils['formatRelativeTime'](_0xe38c71['createdAt']):'';titleEl['textContent']='Terminal\x20·\x20'+_0x23dd2d['substring'](0x0,0xc);const _0x4961b9=command?'\x20·\x20Command\x20'+command:'';subtitleEl['textContent']=''+_0x5f5d4e+_0x10d134+_0x502fa2+_0x4961b9;}
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'](_0x18b3b6=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':_0x18b3b6}));});let commandSent=![],hasReceivedOutput=![];socket['addEventListener']('message',_0x48fc27=>{try{const _0x37d8c4=JSON['parse'](_0x48fc27['data']);if(_0x37d8c4['type']==='data'&&typeof _0x37d8c4['data']==='string')term['write'](_0x37d8c4['data']),!hasReceivedOutput&&_0x37d8c4['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(_0x37d8c4['type']==='status'&&_0x37d8c4['status']){if(_0x37d8c4['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'+_0x37d8c4['status'],_0x37d8c4['status']==='connected'?'success':'info');}else _0x37d8c4['type']==='error'&&_0x37d8c4['message']&&updateStatus(_0x37d8c4['message'],'error');}}catch(_0x5f2df2){console['error']('Failed\x20to\x20parse\x20terminal\x20message',_0x5f2df2);}}),socket['addEventListener']('close',_0x30bd94=>{const _0x5d191d=_0x30bd94['reason']||'Connection\x20closed';updateStatus(_0x5d191d,_0x30bd94['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',_0x3d4951=>{console['error']('Terminal\x20websocket\x20error',_0x3d4951),updateStatus('Connection\x20error','error');});function sendResize(){if(socket['readyState']!==WebSocket['OPEN'])return;const _0x48f120=term['cols'],_0x4e9198=term['rows'];socket['send'](JSON['stringify']({'type':'resize','cols':_0x48f120,'rows':_0x4e9198}));}function updateStatus(_0x31a80a,_0x2a7486='info'){if(!statusEl)return;statusEl['textContent']=_0x31a80a,statusEl['dataset']['variant']=_0x2a7486;}async function enrichContainerDetails(_0x187a5c){try{const _0x2869d4=await API['getContainer'](_0x187a5c);updateTerminalDetails(_0x2869d4);}catch{try{const _0x48c0b2=await API['getContainers'](),_0x5ae9c3=(_0x48c0b2['containers']||[])['find'](_0x3c9dd1=>_0x3c9dd1['containerId']===_0x187a5c||_0x3c9dd1['name']===_0x187a5c||_0x3c9dd1['fullContainerId']?.['startsWith'](_0x187a5c));if(_0x5ae9c3){updateTerminalDetails(_0x5ae9c3);return;}subtitleEl['textContent']='Container\x20'+_0x187a5c['substring'](0x0,0xc);}catch{subtitleEl['textContent']='Container\x20'+_0x187a5c['substring'](0x0,0xc);}}}function updateTerminalDetails(_0x4254dd){const _0x574211=_0x4254dd['containerId']||_0x4254dd['name']||_0x4254dd['fullContainerId']||containerId,_0x3e4dce=_0x4254dd['environment']?'Environment\x20'+_0x4254dd['environment']:'Environment\x20unknown',_0x3592cb=_0x4254dd['defaultAgent']?'\x20·\x20Agent\x20'+_0x4254dd['defaultAgent']:'',_0x46be9e=_0x4254dd['createdAt']?'\x20·\x20Started\x20'+Utils['formatRelativeTime'](_0x4254dd['createdAt']):'';titleEl['textContent']='Terminal\x20·\x20'+_0x574211['substring'](0x0,0xc);const _0x1fd739=command?'\x20·\x20Command\x20'+command:'';subtitleEl['textContent']=''+_0x3e4dce+_0x3592cb+_0x46be9e+_0x1fd739;}
@@ -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 _0x2a2e17=localStorage['getItem'](THEME_STORAGE_KEY);if(_0x2a2e17&&VALID_THEMES['has'](_0x2a2e17))return _0x2a2e17;}catch(_0x2221ef){console['warn']('[Theme]\x20Failed\x20to\x20read\x20stored\x20theme\x20preference:',_0x2221ef);}return null;}export function getPreferredTheme(){const _0x57c4b4=readStoredTheme();if(_0x57c4b4)return _0x57c4b4;const _0x1cb066=window['matchMedia']&&window['matchMedia']('(prefers-color-scheme:\x20dark)')['matches'];return _0x1cb066?'dark':'light';}export function getCurrentTheme(){const _0x14e5a8=document['documentElement']['dataset']['theme'];if(_0x14e5a8&&VALID_THEMES['has'](_0x14e5a8))return _0x14e5a8;return getPreferredTheme();}export function applyTheme(_0x613659,{persist:persist=!![],emitEvent:emitEvent=!![]}={}){const _0xa4876b=VALID_THEMES['has'](_0x613659)?_0x613659:'light';document['documentElement']['dataset']['theme']=_0xa4876b,document['documentElement']['style']['colorScheme']=_0xa4876b==='dark'?'dark':'light';if(persist)try{localStorage['setItem'](THEME_STORAGE_KEY,_0xa4876b);}catch(_0x2b7865){console['warn']('[Theme]\x20Failed\x20to\x20persist\x20theme\x20preference:',_0x2b7865);}return emitEvent&&window['dispatchEvent'](new CustomEvent(THEME_CHANGE_EVENT,{'detail':{'theme':_0xa4876b}})),_0xa4876b;}export function initTheme(_0x567ea5={}){const {emitEvent:emitEvent=![]}=_0x567ea5;return applyTheme(getPreferredTheme(),{'persist':![],'emitEvent':emitEvent});}export function toggleTheme(){const _0x2ded23=getCurrentTheme()==='dark'?'light':'dark';return applyTheme(_0x2ded23);}export function onThemeChange(_0x356f39,{runImmediately:runImmediately=![]}={}){const _0x476886=_0x5c77c0=>{_0x356f39(_0x5c77c0['detail']['theme']);};return window['addEventListener'](THEME_CHANGE_EVENT,_0x476886),runImmediately&&_0x356f39(getCurrentTheme()),()=>window['removeEventListener'](THEME_CHANGE_EVENT,_0x476886);}export function mountThemeToggle(_0x5659e0={}){const {targetSelectors:targetSelectors=DEFAULT_TARGET_SELECTORS}=_0x5659e0,_0x6bc322=targetSelectors['map'](_0x1f353d=>document['querySelector'](_0x1f353d))['find'](Boolean),_0x439485=document['createElement']('button');_0x439485['type']='button',_0x439485['className']='btn-ghost\x20theme-toggle-btn',_0x439485['id']='theme-toggle-btn',_0x439485['setAttribute']('aria-pressed','false'),_0x439485['style']['padding']='8px',_0x439485['style']['lineHeight']='0',_0x439485['style']['width']='36px',_0x439485['style']['height']='36px',_0x439485['style']['display']='flex',_0x439485['style']['alignItems']='center',_0x439485['style']['justifyContent']='center';const _0x5c9ef9=document['createElement']('span');_0x5c9ef9['className']='theme-icon',_0x5c9ef9['style']['display']='flex',_0x439485['append'](_0x5c9ef9);const _0x25cd4f='<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>',_0x2d47dc='<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>',_0x31b933=_0x4be17e=>{const _0x14083d=_0x4be17e==='dark';_0x5c9ef9['innerHTML']=_0x14083d?_0x25cd4f:_0x2d47dc,_0x439485['title']=_0x14083d?'Switch\x20to\x20light\x20mode':'Switch\x20to\x20dark\x20mode',_0x439485['dataset']['theme']=_0x4be17e,_0x439485['setAttribute']('aria-pressed',String(_0x14083d));};return _0x439485['addEventListener']('click',()=>{const _0x5784ed=getCurrentTheme()==='dark'?'light':'dark';applyTheme(_0x5784ed);}),_0x6bc322?_0x6bc322['appendChild'](_0x439485):(_0x439485['classList']['add']('theme-toggle-floating'),document['body']['appendChild'](_0x439485)),_0x31b933(initTheme()),onThemeChange(_0x31b933),_0x439485;}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 _0x6df6de=localStorage['getItem'](THEME_STORAGE_KEY);if(_0x6df6de&&VALID_THEMES['has'](_0x6df6de))return _0x6df6de;}catch(_0x5ac9db){console['warn']('[Theme]\x20Failed\x20to\x20read\x20stored\x20theme\x20preference:',_0x5ac9db);}return null;}export function getPreferredTheme(){const _0x34808b=readStoredTheme();if(_0x34808b)return _0x34808b;const _0x47f5f8=window['matchMedia']&&window['matchMedia']('(prefers-color-scheme:\x20dark)')['matches'];return _0x47f5f8?'dark':'light';}export function getCurrentTheme(){const _0x457ad4=document['documentElement']['dataset']['theme'];if(_0x457ad4&&VALID_THEMES['has'](_0x457ad4))return _0x457ad4;return getPreferredTheme();}export function applyTheme(_0xa65de0,{persist:persist=!![],emitEvent:emitEvent=!![]}={}){const _0x103ad2=VALID_THEMES['has'](_0xa65de0)?_0xa65de0:'light';document['documentElement']['dataset']['theme']=_0x103ad2,document['documentElement']['style']['colorScheme']=_0x103ad2==='dark'?'dark':'light';if(persist)try{localStorage['setItem'](THEME_STORAGE_KEY,_0x103ad2);}catch(_0x173883){console['warn']('[Theme]\x20Failed\x20to\x20persist\x20theme\x20preference:',_0x173883);}return emitEvent&&window['dispatchEvent'](new CustomEvent(THEME_CHANGE_EVENT,{'detail':{'theme':_0x103ad2}})),_0x103ad2;}export function initTheme(_0x11c040={}){const {emitEvent:emitEvent=![]}=_0x11c040;return applyTheme(getPreferredTheme(),{'persist':![],'emitEvent':emitEvent});}export function toggleTheme(){const _0x256bf9=getCurrentTheme()==='dark'?'light':'dark';return applyTheme(_0x256bf9);}export function onThemeChange(_0x291206,{runImmediately:runImmediately=![]}={}){const _0x3775c2=_0x148a52=>{_0x291206(_0x148a52['detail']['theme']);};return window['addEventListener'](THEME_CHANGE_EVENT,_0x3775c2),runImmediately&&_0x291206(getCurrentTheme()),()=>window['removeEventListener'](THEME_CHANGE_EVENT,_0x3775c2);}export function mountThemeToggle(_0x5772c2={}){const {targetSelectors:targetSelectors=DEFAULT_TARGET_SELECTORS}=_0x5772c2,_0x388a1f=targetSelectors['map'](_0x4f7509=>document['querySelector'](_0x4f7509))['find'](Boolean),_0x39113f=document['createElement']('button');_0x39113f['type']='button',_0x39113f['className']='btn-ghost\x20theme-toggle-btn',_0x39113f['id']='theme-toggle-btn',_0x39113f['setAttribute']('aria-pressed','false'),_0x39113f['style']['padding']='8px',_0x39113f['style']['lineHeight']='0',_0x39113f['style']['width']='36px',_0x39113f['style']['height']='36px',_0x39113f['style']['display']='flex',_0x39113f['style']['alignItems']='center',_0x39113f['style']['justifyContent']='center';const _0x45b61e=document['createElement']('span');_0x45b61e['className']='theme-icon',_0x45b61e['style']['display']='flex',_0x39113f['append'](_0x45b61e);const _0x50a94f='<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>',_0x5641d4='<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>',_0x4599c6=_0x18092b=>{const _0x4ea27b=_0x18092b==='dark';_0x45b61e['innerHTML']=_0x4ea27b?_0x50a94f:_0x5641d4,_0x39113f['title']=_0x4ea27b?'Switch\x20to\x20light\x20mode':'Switch\x20to\x20dark\x20mode',_0x39113f['dataset']['theme']=_0x18092b,_0x39113f['setAttribute']('aria-pressed',String(_0x4ea27b));};return _0x39113f['addEventListener']('click',()=>{const _0x4e99c1=getCurrentTheme()==='dark'?'light':'dark';applyTheme(_0x4e99c1);}),_0x388a1f?_0x388a1f['appendChild'](_0x39113f):(_0x39113f['classList']['add']('theme-toggle-floating'),document['body']['appendChild'](_0x39113f)),_0x4599c6(initTheme()),onThemeChange(_0x4599c6),_0x39113f;}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 _0x44c398=await API['getCurrentUser']();state['currentUser']=_0x44c398;if(!Permissions['hasServerPermission'](_0x44c398,'*')&&!Permissions['hasServerPermission'](_0x44c398,'users:create')){Utils['showToast']('Access\x20denied:\x20Server\x20admin\x20privileges\x20required','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}}catch(_0xc02c94){window['location']['href']='login.html';}}async function checkEmailConfig(){try{const _0x50f9ba=await API['getEmailConfig']();state['emailConfigured']=_0x50f9ba['configured'];}catch(_0x6dd071){console['error']('Failed\x20to\x20check\x20email\x20config',_0x6dd071),state['emailConfigured']=![];}}async function loadRoles(){try{const {roles:_0x44c84a}=await API['getRoleDefinitions']();state['roles']=_0x44c84a||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x54a885=await API['getEnvironments']();state['environments']=_0x54a885['environments']||[];}catch{state['environments']=[];}}async function loadTeams(){try{const {teams:_0x36f16e}=await API['getTeams']();state['teams']=_0x36f16e||[];}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 _0x21a99b=document['getElementById']('users-loading'),_0x3d1fdc=document['getElementById']('users-error'),_0x6f41e5=document['getElementById']('users-content');try{_0x21a99b['hidden']=![],_0x3d1fdc['hidden']=!![],_0x6f41e5['hidden']=!![];const _0x227620=await API['getUsers']();state['users']=_0x227620['users']||[],renderUsers(),_0x21a99b['hidden']=!![],_0x6f41e5['hidden']=![];}catch(_0x5a8d5c){console['error']('Failed\x20to\x20load\x20users',_0x5a8d5c),_0x21a99b['hidden']=!![],_0x3d1fdc['hidden']=![],document['getElementById']('users-error-message')['textContent']=_0x5a8d5c['message'];}}function renderUsers(){const _0x35e110=document['getElementById']('users-table-body'),_0x189b33=document['getElementById']('user-count');if(!_0x35e110)return;_0x189b33&&(_0x189b33['textContent']=state['users']['length']+'\x20user'+(state['users']['length']===0x1?'':'s'));const _0xb7e975=[...state['users']]['sort']((_0x49ab00,_0x42d51a)=>{const _0x5d61d0=new Date(_0x49ab00['created_at'])['getTime'](),_0x18a319=new Date(_0x42d51a['created_at'])['getTime']();return _0x18a319-_0x5d61d0;});_0x35e110['innerHTML']=_0xb7e975['map'](_0x1a2572=>'\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'](_0x1a2572['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'](_0x1a2572['name'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x1a2572['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'+(_0x1a2572['isServerAdmin']?'<span\x20class=\x22role-badge\x20role-admin\x22>Server\x20Admin</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x1a2572['hasUserBinding']?'<span\x20class=\x22role-badge\x20role-user-binding\x22>User\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x1a2572['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'](_0x1a2572['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'+_0x1a2572['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'+_0x1a2572['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'+_0x1a2572['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'+_0x1a2572['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(_0x1a53fe){const _0x163da3=state['users']['find'](_0x5a5c3a=>_0x5a5c3a['id']===_0x1a53fe);if(!_0x163da3)return;state['bindingsUserId']=_0x1a53fe,state['bindingsDirty']=![];const _0x5c72cb=document['getElementById']('bindings-modal'),_0x51a2b7=document['getElementById']('bindings-modal-title');_0x51a2b7['textContent']='Access\x20Bindings\x20—\x20'+_0x163da3['name'],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],_0x5c72cb['hidden']=![],loadUserBindings(_0x1a53fe);};function hasUnsavedBindingChanges(){const _0x16d869=document['getElementById']('add-user-binding-form');return _0x16d869&&!_0x16d869['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 _0x135ca9=document['getElementById']('bindings-modal');_0x135ca9['hidden']=!![];const _0x2b9f04=state['bindingsDirty'];state['bindingsUserId']=null,state['userBindings']=[],state['bindingsDirty']=![],_0x2b9f04&&await loadUsers();}async function loadUserBindings(_0x3c7c8f){const _0x1a1d96=document['getElementById']('user-bindings-loading'),_0x389c4c=document['getElementById']('user-bindings-empty'),_0x4d95a3=document['getElementById']('user-bindings-list-container'),_0x4fb005=document['getElementById']('add-user-binding-btn'),_0x15919a=document['getElementById']('user-team-bindings-note'),_0x416e6c=document['getElementById']('user-team-bindings-text');_0x1a1d96['hidden']=![],_0x389c4c['hidden']=!![],_0x4d95a3['style']['display']='none',_0x4fb005['hidden']=!![],_0x15919a['hidden']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![];try{const [_0x33b75e,_0x2ebae0]=await Promise['all']([API['getBindings']({'subject_type':'user','subject_id':_0x3c7c8f}),API['getTeams']()]);state['userBindings']=_0x33b75e['bindings']||[];const _0x2bcc25=(_0x2ebae0['teams']||[])['filter'](_0x5b0c99=>(_0x5b0c99['members']||[])['includes'](_0x3c7c8f)),_0xa92476=[];if(_0x2bcc25['length']>0x0){const _0x19f3d4=await Promise['all'](_0x2bcc25['map'](_0x3efee6=>API['getBindings']({'subject_type':'team','subject_id':_0x3efee6['id']})));for(let _0x1ebe7d=0x0;_0x1ebe7d<_0x2bcc25['length'];_0x1ebe7d++){const _0x43743f=_0x19f3d4[_0x1ebe7d]['bindings']||[];_0x43743f['length']>0x0&&_0xa92476['push'](_0x2bcc25[_0x1ebe7d]);}}_0x1a1d96['hidden']=!![];state['userBindings']['length']===0x0?_0x389c4c['hidden']=![]:(_0x4d95a3['style']['display']='',renderUserBindingsTable());if(_0xa92476['length']>0x0){const _0xa79638=_0xa92476['map'](_0x2aef3e=>_0x2aef3e['name']),_0x28de61=_0xa79638['length']<=0x3?_0xa79638['join'](',\x20'):_0xa79638['slice'](0x0,0x3)['join'](',\x20')+(',\x20and\x20'+(_0xa79638['length']-0x3)+'\x20more');_0x416e6c['textContent']='This\x20user\x20also\x20has\x20access\x20via\x20team\x20memberships\x20('+_0x28de61+').';}else _0x416e6c['textContent']='This\x20user\x20has\x20no\x20access\x20via\x20team\x20memberships.';_0x15919a['hidden']=![],_0x4fb005['hidden']=![];}catch(_0x2cabea){_0x1a1d96['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x2cabea['message'],'error');}}function renderUserBindingsTable(){const _0x186dbf=document['getElementById']('user-bindings-table-body');if(!_0x186dbf)return;_0x186dbf['innerHTML']=state['userBindings']['map'](_0x2d4332=>{const _0x10aeb5=_0x2d4332['resource_type']==='server'?'Server':_0x2d4332['resource_id']==='*'?'All\x20'+_0x2d4332['resource_type']+'s':Utils['escapeHtml'](_0x2d4332['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x10aeb5+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x2d4332['role_name']||_0x2d4332['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'+_0x2d4332['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 _0x370028=document['getElementById']('user-binding-resource-type');_0x370028['value']='environment',updateUserBindingFormForResourceType('environment');}function onUserBindingResourceTypeChange(){const _0x359494=document['getElementById']('user-binding-resource-type')['value'];updateUserBindingFormForResourceType(_0x359494);}function updateUserBindingFormForResourceType(_0x435a6b){const _0x55a73a=document['getElementById']('user-binding-resource-container'),_0x56480a=document['getElementById']('user-binding-resource'),_0x173d6d=document['getElementById']('user-binding-role');if(_0x435a6b==='server')_0x55a73a['style']['display']='none';else{_0x55a73a['style']['display']='';if(_0x435a6b==='environment'){const _0x42ea3f=new Set(state['userBindings']['filter'](_0x5d2fb2=>_0x5d2fb2['resource_type']==='environment')['map'](_0x10df45=>_0x10df45['resource_id'])),_0x354a41=state['environments']['filter'](_0x330796=>!_0x42ea3f['has'](_0x330796['name']));_0x56480a['innerHTML']=_0x354a41['length']?_0x354a41['map'](_0x3e6f9e=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x3e6f9e['name'])+'\x22>'+Utils['escapeHtml'](_0x3e6f9e['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x435a6b==='team'){const _0x34ef39=new Set(state['userBindings']['filter'](_0x1657fe=>_0x1657fe['resource_type']==='team')['map'](_0x1fb26d=>_0x1fb26d['resource_id'])),_0x27413a=state['teams']['filter'](_0x164582=>!_0x34ef39['has'](_0x164582['id']));_0x56480a['innerHTML']=_0x27413a['length']?_0x27413a['map'](_0x57e1ed=>'<option\x20value=\x22'+_0x57e1ed['id']+'\x22>'+Utils['escapeHtml'](_0x57e1ed['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x2c1d17=state['roles']['filter'](_0x512ee7=>_0x512ee7['resource_type']===_0x435a6b);_0x173d6d['innerHTML']=_0x2c1d17['length']?_0x2c1d17['filter'](_0x205a26=>{const _0x38587b=_0x435a6b==='server'?undefined:_0x56480a['value'];return!state['userBindings']['some'](_0x3f9315=>_0x3f9315['resource_type']===_0x435a6b&&_0x3f9315['role_id']===_0x205a26['id']&&(_0x435a6b==='server'||_0x3f9315['resource_id']===_0x38587b));})['map'](_0x5d0f6f=>'<option\x20value=\x22'+_0x5d0f6f['id']+'\x22>'+Utils['escapeHtml'](_0x5d0f6f['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 _0x587288=document['getElementById']('user-binding-resource-type')['value'],_0x33e567=document['getElementById']('user-binding-role')['value'];if(!_0x33e567||!state['bindingsUserId'])return;const _0x4a2291=_0x587288==='server'?undefined:document['getElementById']('user-binding-resource')['value'];if(_0x587288!=='server'&&!_0x4a2291)return;const _0x30f7d9=document['getElementById']('save-user-binding-btn');_0x30f7d9['disabled']=!![],_0x30f7d9['textContent']='Adding…';try{const _0x2d74bb={'subject_type':'user','subject_id':state['bindingsUserId'],'role_id':_0x33e567,'resource_type':_0x587288};if(_0x4a2291)_0x2d74bb['resource_id']=_0x4a2291;await API['createBinding'](_0x2d74bb),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(_0x1202b8){Utils['showToast'](_0x1202b8['message'],'error');}finally{_0x30f7d9['disabled']=![],_0x30f7d9['textContent']='Add\x20Binding';}}window['deleteUserBindingClick']=async function(_0x52456a){try{await API['deleteBinding'](_0x52456a),Utils['showToast']('Binding\x20removed','success'),state['bindingsDirty']=!![],await loadUserBindings(state['bindingsUserId']);}catch(_0x4786d4){Utils['showToast'](_0x4786d4['message'],'error');}};function showCreateUserModal(){state['editingUserId']=null;const _0x5c537e=document['getElementById']('user-modal'),_0x4ad158=document['getElementById']('modal-title'),_0x24d934=document['getElementById']('user-password'),_0x189919=document['getElementById']('password-required'),_0x31d04b=document['getElementById']('password-hint'),_0x2528cd=document['getElementById']('skip-password-container'),_0x41cbe0=document['getElementById']('skip-password');_0x4ad158['textContent']='Create\x20User',document['getElementById']('user-form')['reset'](),_0x24d934['required']=!![];if(_0x189919)_0x189919['textContent']='*';_0x2528cd&&(_0x2528cd['style']['display']='block',_0x41cbe0['checked']=![]),_0x31d04b&&(_0x31d04b['textContent']='Minimum\x208\x20characters'),_0x5c537e['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);}window['editUser']=function(_0x381571){const _0x65e989=state['users']['find'](_0x5e4e87=>_0x5e4e87['id']===_0x381571);if(!_0x65e989)return;state['editingUserId']=_0x381571;const _0x197a9f=document['getElementById']('user-modal'),_0x1534e3=document['getElementById']('modal-title'),_0x46178c=document['getElementById']('user-password'),_0x471c6d=document['getElementById']('password-required'),_0x248172=document['getElementById']('password-hint'),_0x33bb06=document['getElementById']('skip-password-container');_0x1534e3['textContent']='Edit\x20User',document['getElementById']('user-username')['value']=_0x65e989['username'],document['getElementById']('user-name')['value']=_0x65e989['name'],document['getElementById']('user-email')['value']=_0x65e989['email'],_0x46178c['value']='',_0x46178c['required']=![];if(_0x471c6d)_0x471c6d['textContent']='';_0x33bb06&&(_0x33bb06['style']['display']='none'),_0x248172&&(_0x248172['textContent']='Leave\x20blank\x20to\x20keep\x20current\x20password'),_0x197a9f['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);};function hideUserModal(){const _0x3f467c=document['getElementById']('user-modal'),_0x144f89=document['getElementById']('form-error'),_0x139cdd=document['getElementById']('save-user');_0x3f467c['hidden']=!![],_0x144f89['hidden']=!![],state['editingUserId']=null,_0x139cdd&&(_0x139cdd['disabled']=![],_0x139cdd['textContent']='Save\x20User');}async function saveUser(){const _0x570d26=document['getElementById']('user-form'),_0x47c9c3=document['getElementById']('skip-password')?.['checked']||![];if(!_0x47c9c3&&!_0x570d26['checkValidity']()){_0x570d26['reportValidity']();return;}const _0x4b36f4=document['getElementById']('form-error'),_0x193bc4=document['getElementById']('save-user'),_0x144235=document['getElementById']('user-username')['value']['trim'](),_0x15a9cb=document['getElementById']('user-name')['value']['trim'](),_0x19c82e=document['getElementById']('user-email')['value']['trim'](),_0x534df1=document['getElementById']('user-password')['value'];if(!_0x144235||!_0x15a9cb||!_0x19c82e){_0x4b36f4['textContent']='Please\x20fill\x20in\x20all\x20required\x20fields',_0x4b36f4['hidden']=![],_0x4b36f4['scrollIntoView']({'behavior':'smooth','block':'nearest'});return;}_0x4b36f4['hidden']=!![];const _0x52ab8e=_0x193bc4['textContent'];_0x193bc4['disabled']=!![],_0x193bc4['textContent']=state['editingUserId']?'Updating...':'Creating...';try{if(state['editingUserId']){const _0x167c19={'username':_0x144235,'name':_0x15a9cb,'email':_0x19c82e};_0x534df1&&(_0x167c19['password']=_0x534df1),await API['updateUser'](state['editingUserId'],_0x167c19),Utils['showToast']('User\x20updated\x20successfully','success'),await loadUsers(),hideUserModal();}else{const _0x99504b={'username':_0x144235,'name':_0x15a9cb,'email':_0x19c82e};if(!_0x47c9c3){if(!_0x534df1)throw new Error('Password\x20is\x20required\x20for\x20new\x20users');_0x99504b['password']=_0x534df1;}const _0x3138ec=await API['createUser'](_0x99504b),_0x4e5e7f=_0x3138ec['user'];if(_0x47c9c3||!_0x534df1){const _0x5c7444=await API['createPasswordToken'](_0x4e5e7f['id'],'setup',![]);state['setupLinkData']={'username':_0x4e5e7f['username'],'email':_0x4e5e7f['email'],'url':_0x5c7444['token']['setupUrl'],'userId':_0x4e5e7f['id'],'type':'setup','emailSent':![]},await loadUsers(),hideUserModal(),showSetupLinkModal();}else Utils['showToast']('User\x20created\x20successfully','success'),await loadUsers(),hideUserModal();}}catch(_0xbce9e7){console['error']('Failed\x20to\x20save\x20user',_0xbce9e7),_0x4b36f4['textContent']=_0xbce9e7['message'],_0x4b36f4['hidden']=![],_0x4b36f4['scrollIntoView']({'behavior':'smooth','block':'nearest'}),_0x193bc4['disabled']=![],_0x193bc4['textContent']=_0x52ab8e;}}window['deleteUser']=function(_0x562b47){const _0x198866=state['users']['find'](_0x114df1=>_0x114df1['id']===_0x562b47);if(!_0x198866)return;state['deletingUserId']=_0x562b47;const _0x5f1cb7=document['getElementById']('delete-modal'),_0xb98f56=document['getElementById']('delete-user-name');_0xb98f56['textContent']=_0x198866['name']+'\x20('+_0x198866['username']+')',_0x5f1cb7['hidden']=![];};function hideDeleteModal(){const _0x44f2a2=document['getElementById']('delete-modal');_0x44f2a2['hidden']=!![],state['deletingUserId']=null;const _0x37f896=document['getElementById']('confirm-delete');_0x37f896&&(_0x37f896['disabled']=![],_0x37f896['textContent']='Delete\x20User');}async function confirmDeleteUser(){if(!state['deletingUserId'])return;const _0x2449c8=document['getElementById']('confirm-delete'),_0x3e9e96=_0x2449c8['textContent'];_0x2449c8['disabled']=!![],_0x2449c8['textContent']='Deleting...';try{await API['deleteUser'](state['deletingUserId']),Utils['showToast']('User\x20deleted\x20successfully','success'),await loadUsers(),hideDeleteModal();}catch(_0x825919){console['error']('Failed\x20to\x20delete\x20user',_0x825919),Utils['showToast']('Failed\x20to\x20delete\x20user:\x20'+_0x825919['message'],'error'),_0x2449c8['disabled']=![],_0x2449c8['textContent']=_0x3e9e96;}}function handleSkipPasswordChange(_0x16a9d8){const _0x597e33=document['getElementById']('user-password'),_0x48a2ed=_0x16a9d8['target']['checked'];_0x48a2ed?(_0x597e33['required']=![],_0x597e33['disabled']=!![],_0x597e33['value']=''):(_0x597e33['required']=!![],_0x597e33['disabled']=![]);}function showSetupLinkModal(){if(!state['setupLinkData'])return;const _0xc9dbcb=document['getElementById']('setup-link-modal'),_0x42fbe2=document['getElementById']('setup-link-username'),_0x17c123=document['getElementById']('setup-link-url'),_0x5c9458=document['getElementById']('email-setup-link'),_0x5e973c=document['getElementById']('email-button-text');_0x42fbe2['textContent']=state['setupLinkData']['username'],_0x17c123['textContent']=state['setupLinkData']['url'],_0x5c9458&&_0x5e973c&&(_0x5c9458['disabled']=![],_0x5e973c['textContent']='Email\x20Link',state['emailConfigured']&&!state['setupLinkData']['emailSent']?_0x5c9458['style']['display']='inline-block':_0x5c9458['style']['display']='none'),_0xc9dbcb['hidden']=![];}function hideSetupLinkModal(){const _0x10d29b=document['getElementById']('setup-link-modal');_0x10d29b['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(_0x4dc949){console['error']('Failed\x20to\x20copy\x20link',_0x4dc949),Utils['showToast']('Failed\x20to\x20copy\x20link','error');}}async function emailSetupLink(){if(!state['setupLinkData'])return;const _0x3bb07c=document['getElementById']('email-setup-link'),_0x4862c1=document['getElementById']('email-button-text');if(!_0x3bb07c||!_0x4862c1)return;const _0x160f0d=_0x4862c1['textContent'];_0x3bb07c['disabled']=!![],_0x4862c1['textContent']='Sending...';try{const _0x6dbf43=await API['createPasswordToken'](state['setupLinkData']['userId'],state['setupLinkData']['type'],!![]);if(_0x6dbf43['emailSent'])Utils['showToast']('Email\x20sent\x20to\x20'+state['setupLinkData']['email'],'success'),state['setupLinkData']['emailSent']=!![],_0x3bb07c['style']['display']='none';else{const _0x363016=_0x6dbf43['emailError']||'Failed\x20to\x20send\x20email';Utils['showToast'](_0x363016,'error'),_0x3bb07c['disabled']=![],_0x4862c1['textContent']=_0x160f0d;}}catch(_0x16fd9f){console['error']('Failed\x20to\x20email\x20setup\x20link',_0x16fd9f),Utils['showToast']('Failed\x20to\x20send\x20email:\x20'+_0x16fd9f['message'],'error'),_0x3bb07c['disabled']=![],_0x4862c1['textContent']=_0x160f0d;}}window['resetPassword']=async function(_0x382ba3){const _0x347a0f=state['users']['find'](_0x2f134d=>_0x2f134d['id']===_0x382ba3);if(!_0x347a0f)return;const _0x139a4c=await ConfirmDialog['show']({'title':'Reset\x20Password','message':'Generate\x20a\x20password\x20reset\x20link\x20for\x20'+_0x347a0f['name']+'\x20('+_0x347a0f['username']+')?\x20This\x20will\x20create\x20a\x20link\x20that\x20they\x20can\x20use\x20to\x20set\x20a\x20new\x20password.','confirmText':'Generate\x20Link'});if(!_0x139a4c)return;try{const _0x4cfcf3=await API['createPasswordToken'](_0x382ba3,'reset',![]);state['setupLinkData']={'username':_0x347a0f['username'],'email':_0x347a0f['email'],'url':_0x4cfcf3['token']['setupUrl'],'userId':_0x347a0f['id'],'type':'reset','emailSent':![]},showSetupLinkModal();}catch(_0x4ba8a9){console['error']('Failed\x20to\x20create\x20password\x20reset\x20link',_0x4ba8a9),Utils['showToast']('Failed\x20to\x20create\x20password\x20reset\x20link:\x20'+_0x4ba8a9['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 _0x603677=await API['getCurrentUser']();state['currentUser']=_0x603677;if(!Permissions['hasServerPermission'](_0x603677,'*')&&!Permissions['hasServerPermission'](_0x603677,'users:create')){Utils['showToast']('Access\x20denied:\x20Server\x20admin\x20privileges\x20required','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}}catch(_0x4f933f){window['location']['href']='login.html';}}async function checkEmailConfig(){try{const _0x119c08=await API['getEmailConfig']();state['emailConfigured']=_0x119c08['configured'];}catch(_0x3e212f){console['error']('Failed\x20to\x20check\x20email\x20config',_0x3e212f),state['emailConfigured']=![];}}async function loadRoles(){try{const {roles:_0x5899d4}=await API['getRoleDefinitions']();state['roles']=_0x5899d4||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x208430=await API['getEnvironments']();state['environments']=_0x208430['environments']||[];}catch{state['environments']=[];}}async function loadTeams(){try{const {teams:_0x5a5f29}=await API['getTeams']();state['teams']=_0x5a5f29||[];}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 _0x5b7ffb=document['getElementById']('users-loading'),_0x460a4b=document['getElementById']('users-error'),_0x303673=document['getElementById']('users-content');try{_0x5b7ffb['hidden']=![],_0x460a4b['hidden']=!![],_0x303673['hidden']=!![];const _0x3ed3b5=await API['getUsers']();state['users']=_0x3ed3b5['users']||[],renderUsers(),_0x5b7ffb['hidden']=!![],_0x303673['hidden']=![];}catch(_0x45520c){console['error']('Failed\x20to\x20load\x20users',_0x45520c),_0x5b7ffb['hidden']=!![],_0x460a4b['hidden']=![],document['getElementById']('users-error-message')['textContent']=_0x45520c['message'];}}function renderUsers(){const _0x212cc4=document['getElementById']('users-table-body'),_0xcf5196=document['getElementById']('user-count');if(!_0x212cc4)return;_0xcf5196&&(_0xcf5196['textContent']=state['users']['length']+'\x20user'+(state['users']['length']===0x1?'':'s'));const _0x136999=[...state['users']]['sort']((_0x2a9e56,_0x4713f9)=>{const _0xe1478=new Date(_0x2a9e56['created_at'])['getTime'](),_0x400752=new Date(_0x4713f9['created_at'])['getTime']();return _0x400752-_0xe1478;});_0x212cc4['innerHTML']=_0x136999['map'](_0x2c9b22=>'\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'](_0x2c9b22['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'](_0x2c9b22['name'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x2c9b22['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'+(_0x2c9b22['isServerAdmin']?'<span\x20class=\x22role-badge\x20role-admin\x22>Server\x20Admin</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x2c9b22['hasUserBinding']?'<span\x20class=\x22role-badge\x20role-user-binding\x22>User\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x2c9b22['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'](_0x2c9b22['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'+_0x2c9b22['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'+_0x2c9b22['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'+_0x2c9b22['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'+_0x2c9b22['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(_0x49f52e){const _0x5d4be5=state['users']['find'](_0x475d62=>_0x475d62['id']===_0x49f52e);if(!_0x5d4be5)return;state['bindingsUserId']=_0x49f52e,state['bindingsDirty']=![];const _0x195db3=document['getElementById']('bindings-modal'),_0x157390=document['getElementById']('bindings-modal-title');_0x157390['textContent']='Access\x20Bindings\x20—\x20'+_0x5d4be5['name'],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],_0x195db3['hidden']=![],loadUserBindings(_0x49f52e);};function hasUnsavedBindingChanges(){const _0x528268=document['getElementById']('add-user-binding-form');return _0x528268&&!_0x528268['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 _0x35d79e=document['getElementById']('bindings-modal');_0x35d79e['hidden']=!![];const _0x5fad38=state['bindingsDirty'];state['bindingsUserId']=null,state['userBindings']=[],state['bindingsDirty']=![],_0x5fad38&&await loadUsers();}async function loadUserBindings(_0x111b1e){const _0x34ad19=document['getElementById']('user-bindings-loading'),_0x286d93=document['getElementById']('user-bindings-empty'),_0x3665e8=document['getElementById']('user-bindings-list-container'),_0x47ae61=document['getElementById']('add-user-binding-btn'),_0x17f19e=document['getElementById']('user-team-bindings-note'),_0x19d957=document['getElementById']('user-team-bindings-text');_0x34ad19['hidden']=![],_0x286d93['hidden']=!![],_0x3665e8['style']['display']='none',_0x47ae61['hidden']=!![],_0x17f19e['hidden']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![];try{const [_0x2e674b,_0x2420f8]=await Promise['all']([API['getBindings']({'subject_type':'user','subject_id':_0x111b1e}),API['getTeams']()]);state['userBindings']=_0x2e674b['bindings']||[];const _0x4b8340=(_0x2420f8['teams']||[])['filter'](_0x53cc49=>(_0x53cc49['members']||[])['includes'](_0x111b1e)),_0x4e1c23=[];if(_0x4b8340['length']>0x0){const _0x179751=await Promise['all'](_0x4b8340['map'](_0xdbdc4f=>API['getBindings']({'subject_type':'team','subject_id':_0xdbdc4f['id']})));for(let _0x2733e2=0x0;_0x2733e2<_0x4b8340['length'];_0x2733e2++){const _0x5d4536=_0x179751[_0x2733e2]['bindings']||[];_0x5d4536['length']>0x0&&_0x4e1c23['push'](_0x4b8340[_0x2733e2]);}}_0x34ad19['hidden']=!![];state['userBindings']['length']===0x0?_0x286d93['hidden']=![]:(_0x3665e8['style']['display']='',renderUserBindingsTable());if(_0x4e1c23['length']>0x0){const _0x18d8b8=_0x4e1c23['map'](_0x57f96f=>_0x57f96f['name']),_0x143e15=_0x18d8b8['length']<=0x3?_0x18d8b8['join'](',\x20'):_0x18d8b8['slice'](0x0,0x3)['join'](',\x20')+(',\x20and\x20'+(_0x18d8b8['length']-0x3)+'\x20more');_0x19d957['textContent']='This\x20user\x20also\x20has\x20access\x20via\x20team\x20memberships\x20('+_0x143e15+').';}else _0x19d957['textContent']='This\x20user\x20has\x20no\x20access\x20via\x20team\x20memberships.';_0x17f19e['hidden']=![],_0x47ae61['hidden']=![];}catch(_0x2d816){_0x34ad19['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x2d816['message'],'error');}}function renderUserBindingsTable(){const _0x5defc7=document['getElementById']('user-bindings-table-body');if(!_0x5defc7)return;_0x5defc7['innerHTML']=state['userBindings']['map'](_0x2e789b=>{const _0x28becb=_0x2e789b['resource_type']==='server'?'Server':_0x2e789b['resource_id']==='*'?'All\x20'+_0x2e789b['resource_type']+'s':Utils['escapeHtml'](_0x2e789b['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x28becb+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x2e789b['role_name']||_0x2e789b['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'+_0x2e789b['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 _0x41120e=document['getElementById']('user-binding-resource-type');_0x41120e['value']='environment',updateUserBindingFormForResourceType('environment');}function onUserBindingResourceTypeChange(){const _0x468ab4=document['getElementById']('user-binding-resource-type')['value'];updateUserBindingFormForResourceType(_0x468ab4);}function updateUserBindingFormForResourceType(_0x5db298){const _0x78bc76=document['getElementById']('user-binding-resource-container'),_0x28d989=document['getElementById']('user-binding-resource'),_0x301fcd=document['getElementById']('user-binding-role');if(_0x5db298==='server')_0x78bc76['style']['display']='none';else{_0x78bc76['style']['display']='';if(_0x5db298==='environment'){const _0x59e313=new Set(state['userBindings']['filter'](_0x255595=>_0x255595['resource_type']==='environment')['map'](_0x24ac5d=>_0x24ac5d['resource_id'])),_0x3ac5bc=state['environments']['filter'](_0xba2f7b=>!_0x59e313['has'](_0xba2f7b['name']));_0x28d989['innerHTML']=_0x3ac5bc['length']?_0x3ac5bc['map'](_0x135bd3=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x135bd3['name'])+'\x22>'+Utils['escapeHtml'](_0x135bd3['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x5db298==='team'){const _0x35ef47=new Set(state['userBindings']['filter'](_0x3d4eed=>_0x3d4eed['resource_type']==='team')['map'](_0x32645e=>_0x32645e['resource_id'])),_0x156a3=state['teams']['filter'](_0xde380b=>!_0x35ef47['has'](_0xde380b['id']));_0x28d989['innerHTML']=_0x156a3['length']?_0x156a3['map'](_0x300f0d=>'<option\x20value=\x22'+_0x300f0d['id']+'\x22>'+Utils['escapeHtml'](_0x300f0d['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x2d884b=state['roles']['filter'](_0x8fdd85=>_0x8fdd85['resource_type']===_0x5db298);_0x301fcd['innerHTML']=_0x2d884b['length']?_0x2d884b['filter'](_0x1cc522=>{const _0x574a67=_0x5db298==='server'?undefined:_0x28d989['value'];return!state['userBindings']['some'](_0x5f1d05=>_0x5f1d05['resource_type']===_0x5db298&&_0x5f1d05['role_id']===_0x1cc522['id']&&(_0x5db298==='server'||_0x5f1d05['resource_id']===_0x574a67));})['map'](_0x4465f9=>'<option\x20value=\x22'+_0x4465f9['id']+'\x22>'+Utils['escapeHtml'](_0x4465f9['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 _0xa08174=document['getElementById']('user-binding-resource-type')['value'],_0x57b933=document['getElementById']('user-binding-role')['value'];if(!_0x57b933||!state['bindingsUserId'])return;const _0x1c137a=_0xa08174==='server'?undefined:document['getElementById']('user-binding-resource')['value'];if(_0xa08174!=='server'&&!_0x1c137a)return;const _0x1115fa=document['getElementById']('save-user-binding-btn');_0x1115fa['disabled']=!![],_0x1115fa['textContent']='Adding…';try{const _0x87cde0={'subject_type':'user','subject_id':state['bindingsUserId'],'role_id':_0x57b933,'resource_type':_0xa08174};if(_0x1c137a)_0x87cde0['resource_id']=_0x1c137a;await API['createBinding'](_0x87cde0),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(_0x20029f){Utils['showToast'](_0x20029f['message'],'error');}finally{_0x1115fa['disabled']=![],_0x1115fa['textContent']='Add\x20Binding';}}window['deleteUserBindingClick']=async function(_0x5e0173){try{await API['deleteBinding'](_0x5e0173),Utils['showToast']('Binding\x20removed','success'),state['bindingsDirty']=!![],await loadUserBindings(state['bindingsUserId']);}catch(_0x313ad9){Utils['showToast'](_0x313ad9['message'],'error');}};function showCreateUserModal(){state['editingUserId']=null;const _0x1d62d4=document['getElementById']('user-modal'),_0x43e423=document['getElementById']('modal-title'),_0x478f6a=document['getElementById']('user-password'),_0x40f7ed=document['getElementById']('password-required'),_0x355be4=document['getElementById']('password-hint'),_0x21d7e0=document['getElementById']('skip-password-container'),_0x5aecee=document['getElementById']('skip-password');_0x43e423['textContent']='Create\x20User',document['getElementById']('user-form')['reset'](),_0x478f6a['required']=!![];if(_0x40f7ed)_0x40f7ed['textContent']='*';_0x21d7e0&&(_0x21d7e0['style']['display']='block',_0x5aecee['checked']=![]),_0x355be4&&(_0x355be4['textContent']='Minimum\x208\x20characters'),_0x1d62d4['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);}window['editUser']=function(_0x54f3b5){const _0x171aee=state['users']['find'](_0x54a059=>_0x54a059['id']===_0x54f3b5);if(!_0x171aee)return;state['editingUserId']=_0x54f3b5;const _0xe253e=document['getElementById']('user-modal'),_0x5bc85e=document['getElementById']('modal-title'),_0x10fd6f=document['getElementById']('user-password'),_0x1759ff=document['getElementById']('password-required'),_0x40040c=document['getElementById']('password-hint'),_0x500736=document['getElementById']('skip-password-container');_0x5bc85e['textContent']='Edit\x20User',document['getElementById']('user-username')['value']=_0x171aee['username'],document['getElementById']('user-name')['value']=_0x171aee['name'],document['getElementById']('user-email')['value']=_0x171aee['email'],_0x10fd6f['value']='',_0x10fd6f['required']=![];if(_0x1759ff)_0x1759ff['textContent']='';_0x500736&&(_0x500736['style']['display']='none'),_0x40040c&&(_0x40040c['textContent']='Leave\x20blank\x20to\x20keep\x20current\x20password'),_0xe253e['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);};function hideUserModal(){const _0x3ed951=document['getElementById']('user-modal'),_0x9a1d08=document['getElementById']('form-error'),_0x35dff8=document['getElementById']('save-user');_0x3ed951['hidden']=!![],_0x9a1d08['hidden']=!![],state['editingUserId']=null,_0x35dff8&&(_0x35dff8['disabled']=![],_0x35dff8['textContent']='Save\x20User');}async function saveUser(){const _0xbe4073=document['getElementById']('user-form'),_0x462d41=document['getElementById']('skip-password')?.['checked']||![];if(!_0x462d41&&!_0xbe4073['checkValidity']()){_0xbe4073['reportValidity']();return;}const _0x2c7841=document['getElementById']('form-error'),_0x10e6a7=document['getElementById']('save-user'),_0x18170c=document['getElementById']('user-username')['value']['trim'](),_0x3e2355=document['getElementById']('user-name')['value']['trim'](),_0x139952=document['getElementById']('user-email')['value']['trim'](),_0x27f03a=document['getElementById']('user-password')['value'];if(!_0x18170c||!_0x3e2355||!_0x139952){_0x2c7841['textContent']='Please\x20fill\x20in\x20all\x20required\x20fields',_0x2c7841['hidden']=![],_0x2c7841['scrollIntoView']({'behavior':'smooth','block':'nearest'});return;}_0x2c7841['hidden']=!![];const _0x5e8b7e=_0x10e6a7['textContent'];_0x10e6a7['disabled']=!![],_0x10e6a7['textContent']=state['editingUserId']?'Updating...':'Creating...';try{if(state['editingUserId']){const _0x295c40={'username':_0x18170c,'name':_0x3e2355,'email':_0x139952};_0x27f03a&&(_0x295c40['password']=_0x27f03a),await API['updateUser'](state['editingUserId'],_0x295c40),Utils['showToast']('User\x20updated\x20successfully','success'),await loadUsers(),hideUserModal();}else{const _0x1d9376={'username':_0x18170c,'name':_0x3e2355,'email':_0x139952};if(!_0x462d41){if(!_0x27f03a)throw new Error('Password\x20is\x20required\x20for\x20new\x20users');_0x1d9376['password']=_0x27f03a;}const _0x2fb666=await API['createUser'](_0x1d9376),_0x5b56b6=_0x2fb666['user'];if(_0x462d41||!_0x27f03a){const _0x3421bb=await API['createPasswordToken'](_0x5b56b6['id'],'setup',![]);state['setupLinkData']={'username':_0x5b56b6['username'],'email':_0x5b56b6['email'],'url':_0x3421bb['token']['setupUrl'],'userId':_0x5b56b6['id'],'type':'setup','emailSent':![]},await loadUsers(),hideUserModal(),showSetupLinkModal();}else Utils['showToast']('User\x20created\x20successfully','success'),await loadUsers(),hideUserModal();}}catch(_0xd2b2ac){console['error']('Failed\x20to\x20save\x20user',_0xd2b2ac),_0x2c7841['textContent']=_0xd2b2ac['message'],_0x2c7841['hidden']=![],_0x2c7841['scrollIntoView']({'behavior':'smooth','block':'nearest'}),_0x10e6a7['disabled']=![],_0x10e6a7['textContent']=_0x5e8b7e;}}window['deleteUser']=function(_0x5517bb){const _0x2e9946=state['users']['find'](_0x2a0872=>_0x2a0872['id']===_0x5517bb);if(!_0x2e9946)return;state['deletingUserId']=_0x5517bb;const _0x3f1077=document['getElementById']('delete-modal'),_0x2d308d=document['getElementById']('delete-user-name');_0x2d308d['textContent']=_0x2e9946['name']+'\x20('+_0x2e9946['username']+')',_0x3f1077['hidden']=![];};function hideDeleteModal(){const _0x4d6f48=document['getElementById']('delete-modal');_0x4d6f48['hidden']=!![],state['deletingUserId']=null;const _0x38c9de=document['getElementById']('confirm-delete');_0x38c9de&&(_0x38c9de['disabled']=![],_0x38c9de['textContent']='Delete\x20User');}async function confirmDeleteUser(){if(!state['deletingUserId'])return;const _0x139d5b=document['getElementById']('confirm-delete'),_0x1e7827=_0x139d5b['textContent'];_0x139d5b['disabled']=!![],_0x139d5b['textContent']='Deleting...';try{await API['deleteUser'](state['deletingUserId']),Utils['showToast']('User\x20deleted\x20successfully','success'),await loadUsers(),hideDeleteModal();}catch(_0x38cd71){console['error']('Failed\x20to\x20delete\x20user',_0x38cd71),Utils['showToast']('Failed\x20to\x20delete\x20user:\x20'+_0x38cd71['message'],'error'),_0x139d5b['disabled']=![],_0x139d5b['textContent']=_0x1e7827;}}function handleSkipPasswordChange(_0x3bff7f){const _0x318603=document['getElementById']('user-password'),_0x5f0b3a=_0x3bff7f['target']['checked'];_0x5f0b3a?(_0x318603['required']=![],_0x318603['disabled']=!![],_0x318603['value']=''):(_0x318603['required']=!![],_0x318603['disabled']=![]);}function showSetupLinkModal(){if(!state['setupLinkData'])return;const _0x4ede31=document['getElementById']('setup-link-modal'),_0x31e75b=document['getElementById']('setup-link-username'),_0x488e0f=document['getElementById']('setup-link-url'),_0x15be4b=document['getElementById']('email-setup-link'),_0x12559f=document['getElementById']('email-button-text');_0x31e75b['textContent']=state['setupLinkData']['username'],_0x488e0f['textContent']=state['setupLinkData']['url'],_0x15be4b&&_0x12559f&&(_0x15be4b['disabled']=![],_0x12559f['textContent']='Email\x20Link',state['emailConfigured']&&!state['setupLinkData']['emailSent']?_0x15be4b['style']['display']='inline-block':_0x15be4b['style']['display']='none'),_0x4ede31['hidden']=![];}function hideSetupLinkModal(){const _0x33fb2c=document['getElementById']('setup-link-modal');_0x33fb2c['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(_0x1a5592){console['error']('Failed\x20to\x20copy\x20link',_0x1a5592),Utils['showToast']('Failed\x20to\x20copy\x20link','error');}}async function emailSetupLink(){if(!state['setupLinkData'])return;const _0x168d26=document['getElementById']('email-setup-link'),_0x583a94=document['getElementById']('email-button-text');if(!_0x168d26||!_0x583a94)return;const _0x361007=_0x583a94['textContent'];_0x168d26['disabled']=!![],_0x583a94['textContent']='Sending...';try{const _0x50edd6=await API['createPasswordToken'](state['setupLinkData']['userId'],state['setupLinkData']['type'],!![]);if(_0x50edd6['emailSent'])Utils['showToast']('Email\x20sent\x20to\x20'+state['setupLinkData']['email'],'success'),state['setupLinkData']['emailSent']=!![],_0x168d26['style']['display']='none';else{const _0x5b9ed6=_0x50edd6['emailError']||'Failed\x20to\x20send\x20email';Utils['showToast'](_0x5b9ed6,'error'),_0x168d26['disabled']=![],_0x583a94['textContent']=_0x361007;}}catch(_0x2e4939){console['error']('Failed\x20to\x20email\x20setup\x20link',_0x2e4939),Utils['showToast']('Failed\x20to\x20send\x20email:\x20'+_0x2e4939['message'],'error'),_0x168d26['disabled']=![],_0x583a94['textContent']=_0x361007;}}window['resetPassword']=async function(_0x442605){const _0x5f7e19=state['users']['find'](_0xca9ca1=>_0xca9ca1['id']===_0x442605);if(!_0x5f7e19)return;const _0x5689e0=await ConfirmDialog['show']({'title':'Reset\x20Password','message':'Generate\x20a\x20password\x20reset\x20link\x20for\x20'+_0x5f7e19['name']+'\x20('+_0x5f7e19['username']+')?\x20This\x20will\x20create\x20a\x20link\x20that\x20they\x20can\x20use\x20to\x20set\x20a\x20new\x20password.','confirmText':'Generate\x20Link'});if(!_0x5689e0)return;try{const _0x40b82e=await API['createPasswordToken'](_0x442605,'reset',![]);state['setupLinkData']={'username':_0x5f7e19['username'],'email':_0x5f7e19['email'],'url':_0x40b82e['token']['setupUrl'],'userId':_0x5f7e19['id'],'type':'reset','emailSent':![]},showSetupLinkModal();}catch(_0x47ec4f){console['error']('Failed\x20to\x20create\x20password\x20reset\x20link',_0x47ec4f),Utils['showToast']('Failed\x20to\x20create\x20password\x20reset\x20link:\x20'+_0x47ec4f['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(_0x3296ce={}){this['container']=null,this['onGroupChange']=_0x3296ce['onGroupChange']||(()=>{}),this['onAddExistingTask']=_0x3296ce['onAddExistingTask']||(()=>{}),this['tasks']=[],this['groupId']=_0x3296ce['groupId']||null,this['isOpen']=![];}['init'](_0x3e055f,_0x1a4de4,_0x331b37){this['container']=_0x3e055f,this['tasks']=_0x1a4de4,this['groupId']=_0x331b37,this['render'](),this['attachEventListeners']();}['updateTasks'](_0x21b529){const _0x2b3508=new Map(_0x21b529['map'](_0x332878=>[_0x332878['taskId'],_0x332878]));this['tasks']=this['tasks']['map'](_0x418429=>{const _0x39578c=_0x2b3508['get'](_0x418429['taskId']);return _0x39578c?_0x39578c:_0x418429;});for(const _0x23599d of _0x21b529){!this['tasks']['some'](_0x132fcd=>_0x132fcd['taskId']===_0x23599d['taskId'])&&this['tasks']['push'](_0x23599d);}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 _0x49a785=this['tasks']['filter'](_0x4d9fc6=>_0x4d9fc6['groupId']===this['groupId'])['sort']((_0x1de614,_0x1e491e)=>(_0x1de614['groupIndex']??0x0)-(_0x1e491e['groupIndex']??0x0)),_0x4e3266=this['tasks']['filter'](_0x5d90ba=>!_0x5d90ba['groupId']||_0x5d90ba['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>'+_0x49a785['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'+(_0x49a785['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20add\x20to\x20group</div>':_0x49a785['map']((_0x3f9420,_0x1908e1)=>this['renderVariantCard'](_0x3f9420,_0x1908e1,!![]))['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>'+_0x4e3266['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'+(_0x4e3266['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20remove\x20from\x20group</div>':_0x4e3266['map']((_0x35feb9,_0x35ea71)=>this['renderVariantCard'](_0x35feb9,_0x35ea71,![]))['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'](_0x529c88,_0x2ca7be,_0x27d83c){const _0x4de7f9=_0x529c88['envVars']?.['CODER_AGENT']||_0x529c88['envVars']?.['default_agent']||'claude',_0x569196=AGENT_ICONS[_0x4de7f9['toLowerCase']()]||AGENT_ICONS['claude'],_0x1db70b=STATUS_ICONS[_0x529c88['status']]||'',_0xcdd4ac='status-'+(_0x529c88['status']||'unknown'),_0x9f0842=_0x529c88['isWinner']?'<span\x20class=\x22vgm-badge\x20vgm-badge-winner\x22\x20title=\x22Winner\x22>★</span>':'',_0x3200df=_0x529c88['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'+_0xcdd4ac+'\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'+_0x529c88['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-is-grouped=\x22'+_0x27d83c+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-index=\x22'+_0x2ca7be+'\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'+_0x4de7f9['toLowerCase']()+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x569196+'\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'](_0x529c88['name']||'Task\x20'+_0x529c88['taskId']['slice'](-0x6))+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-meta\x22>'+Utils['escapeHtml'](_0x4de7f9)+'\x20·\x20'+(_0x529c88['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'+_0x9f0842+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x3200df+'\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'+_0xcdd4ac+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x1db70b+'\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'+(_0x27d83c?'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'+_0x529c88['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-action=\x22'+(_0x27d83c?'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'+(_0x27d83c?'<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',_0x27ff92=>{_0x27ff92['target']['closest']('.vgm-close-btn')&&(this['close'](),this['onGroupChange'](this['tasks'])),_0x27ff92['target']['closest']('.vgm-add-existing-btn')&&(this['close'](),this['onAddExistingTask'](this['groupId']));}),this['container']['addEventListener']('click',async _0xa79499=>{const _0x5090c1=_0xa79499['target']['closest']('.vgm-variant-remove-btn');if(!_0x5090c1)return;const _0x439034=_0x5090c1['dataset']['taskId'],_0xe56a0=_0x5090c1['dataset']['action'];try{_0xe56a0==='remove'?await this['removeFromGroup'](_0x439034):await this['addToGroup'](_0x439034);}catch(_0x40c837){console['error']('Failed\x20to\x20update\x20group:',_0x40c837),Utils['showToast'](_0x40c837['message']||'Failed\x20to\x20update\x20group','error');}}),this['container']['addEventListener']('dragstart',_0x41bbd2=>this['handleDragStart'](_0x41bbd2)),this['container']['addEventListener']('dragend',_0x265a3b=>this['handleDragEnd'](_0x265a3b)),this['container']['addEventListener']('dragover',_0x5075c7=>this['handleDragOver'](_0x5075c7)),this['container']['addEventListener']('dragleave',_0xf57828=>this['handleDragLeave'](_0xf57828)),this['container']['addEventListener']('drop',_0x58f127=>this['handleDrop'](_0x58f127));}['handleDragStart'](_0x33f321){const _0x33203b=_0x33f321['target']['closest']('.vgm-variant-card');if(!_0x33203b)return;dragState['draggedTaskId']=_0x33203b['dataset']['taskId'],dragState['draggedElement']=_0x33203b,dragState['sourceGroupId']=_0x33203b['dataset']['isGrouped']==='true'?this['groupId']:null,dragState['isDragging']=!![],_0x33203b['classList']['add']('dragging'),_0x33f321['dataTransfer']['effectAllowed']='move',_0x33f321['dataTransfer']['setData']('text/plain',_0x33203b['dataset']['taskId']),this['container']['classList']['add']('is-dragging');}['handleDragEnd'](_0x19ab9e){const _0x2dcce9=_0x19ab9e['target']['closest']('.vgm-variant-card');_0x2dcce9&&_0x2dcce9['classList']['remove']('dragging'),this['container']['querySelectorAll']('.drag-over,\x20.drop-indicator')['forEach'](_0x56aa15=>{_0x56aa15['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'](_0x46f856){_0x46f856['preventDefault'](),_0x46f856['dataTransfer']['dropEffect']='move';const _0x515441=_0x46f856['target']['closest']('.vgm-drop-zone'),_0x3b2460=_0x46f856['target']['closest']('.vgm-variant-card');this['container']['querySelectorAll']('.vgm-drop-zone')['forEach'](_0x5087d4=>{_0x5087d4['classList']['toggle']('drag-over',_0x5087d4===_0x515441);});if(_0x3b2460&&_0x3b2460!==dragState['draggedElement']){const _0x2caea5=_0x3b2460['getBoundingClientRect'](),_0x5328c0=_0x2caea5['top']+_0x2caea5['height']/0x2,_0x29a345=_0x46f856['clientY']<_0x5328c0;this['container']['querySelectorAll']('.vgm-variant-card')['forEach'](_0x69bfdf=>{_0x69bfdf!==_0x3b2460&&_0x69bfdf['classList']['remove']('drop-before','drop-after');}),_0x3b2460['classList']['toggle']('drop-before',_0x29a345),_0x3b2460['classList']['toggle']('drop-after',!_0x29a345);}}['handleDragLeave'](_0x147a90){const _0x48b295=_0x147a90['target']['closest']('.vgm-drop-zone');_0x48b295&&!_0x48b295['contains'](_0x147a90['relatedTarget'])&&_0x48b295['classList']['remove']('drag-over');}async['handleDrop'](_0x432505){_0x432505['preventDefault']();const _0x2e399e=_0x432505['target']['closest']('.vgm-drop-zone'),_0x2b388b=_0x432505['target']['closest']('.vgm-variant-card'),_0x1d3407=_0x432505['dataTransfer']['getData']('text/plain');if(!_0x2e399e||!_0x1d3407)return;this['container']['querySelectorAll']('.drag-over,\x20.drop-before,\x20.drop-after')['forEach'](_0x4b1e62=>{_0x4b1e62['classList']['remove']('drag-over','drop-before','drop-after');});const _0x49bb9a=_0x2e399e['dataset']['zone'],_0x2c0efc=_0x49bb9a==='grouped',_0x524437=dragState['sourceGroupId']===this['groupId'];try{if(_0x2c0efc&&!_0x524437){let _0x3ff26f=this['tasks']['filter'](_0x3bcb27=>_0x3bcb27['groupId']===this['groupId'])['length'];if(_0x2b388b){const _0x1c6580=_0x2b388b['dataset']['taskId'],_0x1f862a=this['tasks']['find'](_0x225977=>_0x225977['taskId']===_0x1c6580);if(_0x1f862a?.['groupIndex']!==undefined){const _0x37e4ee=_0x2b388b['getBoundingClientRect'](),_0x191eb9=_0x432505['clientY']<_0x37e4ee['top']+_0x37e4ee['height']/0x2;_0x3ff26f=_0x1f862a['groupIndex']+(_0x191eb9?0x0:0x1);}}await this['addToGroup'](_0x1d3407,_0x3ff26f);}else{if(!_0x2c0efc&&_0x524437)await this['removeFromGroup'](_0x1d3407);else _0x2c0efc&&_0x524437&&_0x2b388b&&await this['reorderInGroup'](_0x1d3407,_0x2b388b,_0x432505['clientY']);}}catch(_0x4e7234){console['error']('Drop\x20operation\x20failed:',_0x4e7234),Utils['showToast'](_0x4e7234['message']||'Failed\x20to\x20move\x20variant','error');}}async['addToGroup'](_0x136e1a,_0x13413b){const _0x1a1ef8=this['tasks']['find'](_0x401b6b=>_0x401b6b['taskId']===_0x136e1a);if(!_0x1a1ef8)return;_0x13413b===undefined&&(_0x13413b=this['tasks']['filter'](_0x140436=>_0x140436['groupId']===this['groupId'])['length']),!this['groupId']&&(this['groupId']=API['generateGroupId'](),await API['createTaskGroup']({'groupId':this['groupId']})),await API['updateTaskGroup'](_0x136e1a,this['groupId'],_0x13413b),_0x1a1ef8['groupId']=this['groupId'],_0x1a1ef8['groupIndex']=_0x13413b,this['render'](),this['onGroupChange'](this['tasks']);}async['removeFromGroup'](_0x425da7){const _0x5ccf35=this['tasks']['find'](_0x29bc85=>_0x29bc85['taskId']===_0x425da7);if(!_0x5ccf35)return;await API['removeTaskFromGroup'](_0x425da7),_0x5ccf35['groupId']=null,_0x5ccf35['groupIndex']=null,this['render'](),this['onGroupChange'](this['tasks']);}async['reorderInGroup'](_0xc97895,_0x1b32e9,_0x2485be){const _0x2f96a2=this['tasks']['find'](_0x1f73a3=>_0x1f73a3['taskId']===_0xc97895),_0x2997ef=_0x1b32e9['dataset']['taskId'],_0x55687d=this['tasks']['find'](_0x45cbad=>_0x45cbad['taskId']===_0x2997ef);if(!_0x2f96a2||!_0x55687d||_0x2f96a2['taskId']===_0x55687d['taskId'])return;const _0x4a2055=_0x1b32e9['getBoundingClientRect'](),_0x1af333=_0x2485be<_0x4a2055['top']+_0x4a2055['height']/0x2;let _0x19f9de=_0x55687d['groupIndex']??0x0;if(!_0x1af333)_0x19f9de++;if((_0x2f96a2['groupIndex']??0x0)<(_0x55687d['groupIndex']??0x0))_0x19f9de--;if(_0x19f9de===_0x2f96a2['groupIndex'])return;await API['updateTaskGroup'](_0xc97895,this['groupId'],_0x19f9de);const _0x3b4ca5=this['tasks']['filter'](_0xbc59c6=>_0xbc59c6['groupId']===this['groupId'])['sort']((_0x2a4748,_0x41d587)=>(_0x2a4748['groupIndex']??0x0)-(_0x41d587['groupIndex']??0x0)),_0x21fd0d=_0x3b4ca5['findIndex'](_0x4893f4=>_0x4893f4['taskId']===_0xc97895);_0x21fd0d!==-0x1&&_0x3b4ca5['splice'](_0x21fd0d,0x1),_0x3b4ca5['splice'](_0x19f9de,0x0,_0x2f96a2),_0x3b4ca5['forEach']((_0x28c4d4,_0x42cef3)=>{_0x28c4d4['groupIndex']=_0x42cef3;}),this['render'](),this['onGroupChange'](this['tasks']);}}export function initializeTabDragDrop(_0x161adf,_0x5aa582,_0x5d0ae8,_0x31e4f2={}){if(!_0x161adf)return;const {onReorder:_0x296dd7,onRemove:_0x5d8d0c}=_0x31e4f2,_0x5801bf=_0x161adf['querySelectorAll']('.task-tab');_0x5801bf['forEach']((_0x289e76,_0x338837)=>{_0x289e76['setAttribute']('draggable','true'),_0x289e76['dataset']['index']=_0x338837,_0x289e76['addEventListener']('dragstart',_0x10ab9a=>{_0x10ab9a['dataTransfer']['effectAllowed']='move',_0x10ab9a['dataTransfer']['setData']('text/plain',_0x289e76['dataset']['taskId']),_0x289e76['classList']['add']('dragging'),_0x161adf['classList']['add']('is-dragging');}),_0x289e76['addEventListener']('dragend',()=>{_0x289e76['classList']['remove']('dragging'),_0x161adf['classList']['remove']('is-dragging'),_0x161adf['querySelectorAll']('.drop-indicator')['forEach'](_0x3ee021=>{_0x3ee021['classList']['remove']('drop-indicator','drop-before','drop-after');});}),_0x289e76['addEventListener']('dragover',_0x54ccc4=>{_0x54ccc4['preventDefault'](),_0x54ccc4['dataTransfer']['dropEffect']='move';if(_0x289e76['classList']['contains']('dragging'))return;const _0x449742=_0x289e76['getBoundingClientRect'](),_0x4d384d=_0x449742['left']+_0x449742['width']/0x2,_0xf34ae=_0x54ccc4['clientX']<_0x4d384d;_0x5801bf['forEach'](_0xd75976=>_0xd75976['classList']['remove']('drop-before','drop-after')),_0x289e76['classList']['add'](_0xf34ae?'drop-before':'drop-after');}),_0x289e76['addEventListener']('dragleave',()=>{_0x289e76['classList']['remove']('drop-before','drop-after');}),_0x289e76['addEventListener']('drop',async _0x546721=>{_0x546721['preventDefault']();const _0x252555=_0x546721['dataTransfer']['getData']('text/plain'),_0x31700e=_0x289e76['dataset']['taskId'];if(_0x252555===_0x31700e)return;const _0x1799d3=_0x289e76['getBoundingClientRect'](),_0x28fe2e=_0x546721['clientX']<_0x1799d3['left']+_0x1799d3['width']/0x2;_0x289e76['classList']['remove']('drop-before','drop-after'),_0x296dd7&&await _0x296dd7(_0x252555,_0x31700e,_0x28fe2e);});});const _0x17a054=document['createElement']('div');return _0x17a054['className']='task-tab-remove-zone',_0x17a054['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',_0x17a054['style']['display']='none',_0x17a054['addEventListener']('dragover',_0x3119c0=>{_0x3119c0['preventDefault'](),_0x17a054['classList']['add']('drag-over');}),_0x17a054['addEventListener']('dragleave',()=>{_0x17a054['classList']['remove']('drag-over');}),_0x17a054['addEventListener']('drop',async _0x1edc9c=>{_0x1edc9c['preventDefault'](),_0x17a054['classList']['remove']('drag-over');const _0x5d35b1=_0x1edc9c['dataTransfer']['getData']('text/plain');_0x5d8d0c&&await _0x5d8d0c(_0x5d35b1);}),_0x161adf['addEventListener']('dragstart',()=>{_0x5aa582['length']>0x1&&(_0x17a054['style']['display']='flex');}),_0x161adf['addEventListener']('dragend',()=>{_0x17a054['style']['display']='none';}),_0x161adf['appendChild'](_0x17a054),{'destroy':()=>{_0x17a054['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(_0x18e816={}){this['container']=null,this['onGroupChange']=_0x18e816['onGroupChange']||(()=>{}),this['onAddExistingTask']=_0x18e816['onAddExistingTask']||(()=>{}),this['tasks']=[],this['groupId']=_0x18e816['groupId']||null,this['isOpen']=![];}['init'](_0x44a113,_0x26d51c,_0xecb9a){this['container']=_0x44a113,this['tasks']=_0x26d51c,this['groupId']=_0xecb9a,this['render'](),this['attachEventListeners']();}['updateTasks'](_0x190abe){const _0x1e2011=new Map(_0x190abe['map'](_0x1908cb=>[_0x1908cb['taskId'],_0x1908cb]));this['tasks']=this['tasks']['map'](_0x565d0a=>{const _0x2ce359=_0x1e2011['get'](_0x565d0a['taskId']);return _0x2ce359?_0x2ce359:_0x565d0a;});for(const _0x1c3b7c of _0x190abe){!this['tasks']['some'](_0x5b4d54=>_0x5b4d54['taskId']===_0x1c3b7c['taskId'])&&this['tasks']['push'](_0x1c3b7c);}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 _0x39c8a2=this['tasks']['filter'](_0x143b30=>_0x143b30['groupId']===this['groupId'])['sort']((_0x11ac76,_0x37f7ad)=>(_0x11ac76['groupIndex']??0x0)-(_0x37f7ad['groupIndex']??0x0)),_0x5274c5=this['tasks']['filter'](_0x518afd=>!_0x518afd['groupId']||_0x518afd['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>'+_0x39c8a2['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'+(_0x39c8a2['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20add\x20to\x20group</div>':_0x39c8a2['map']((_0x2e5d4b,_0xb0b8b2)=>this['renderVariantCard'](_0x2e5d4b,_0xb0b8b2,!![]))['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>'+_0x5274c5['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'+(_0x5274c5['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20remove\x20from\x20group</div>':_0x5274c5['map']((_0x52e407,_0x32002c)=>this['renderVariantCard'](_0x52e407,_0x32002c,![]))['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'](_0x2b1474,_0x186276,_0x3429b4){const _0x43aa71=_0x2b1474['envVars']?.['CODER_AGENT']||_0x2b1474['envVars']?.['default_agent']||'claude',_0x43224c=AGENT_ICONS[_0x43aa71['toLowerCase']()]||AGENT_ICONS['claude'],_0x491b3b=STATUS_ICONS[_0x2b1474['status']]||'',_0x7e855e='status-'+(_0x2b1474['status']||'unknown'),_0x1455ec=_0x2b1474['isWinner']?'<span\x20class=\x22vgm-badge\x20vgm-badge-winner\x22\x20title=\x22Winner\x22>★</span>':'',_0x4904ff=_0x2b1474['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'+_0x7e855e+'\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'+_0x2b1474['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-is-grouped=\x22'+_0x3429b4+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-index=\x22'+_0x186276+'\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'+_0x43aa71['toLowerCase']()+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x43224c+'\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'](_0x2b1474['name']||'Task\x20'+_0x2b1474['taskId']['slice'](-0x6))+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-meta\x22>'+Utils['escapeHtml'](_0x43aa71)+'\x20·\x20'+(_0x2b1474['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'+_0x1455ec+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x4904ff+'\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'+_0x7e855e+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x491b3b+'\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'+(_0x3429b4?'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'+_0x2b1474['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-action=\x22'+(_0x3429b4?'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'+(_0x3429b4?'<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',_0x362b88=>{_0x362b88['target']['closest']('.vgm-close-btn')&&(this['close'](),this['onGroupChange'](this['tasks'])),_0x362b88['target']['closest']('.vgm-add-existing-btn')&&(this['close'](),this['onAddExistingTask'](this['groupId']));}),this['container']['addEventListener']('click',async _0x25b347=>{const _0x3b9994=_0x25b347['target']['closest']('.vgm-variant-remove-btn');if(!_0x3b9994)return;const _0x50695b=_0x3b9994['dataset']['taskId'],_0x5d723d=_0x3b9994['dataset']['action'];try{_0x5d723d==='remove'?await this['removeFromGroup'](_0x50695b):await this['addToGroup'](_0x50695b);}catch(_0x3cd6b3){console['error']('Failed\x20to\x20update\x20group:',_0x3cd6b3),Utils['showToast'](_0x3cd6b3['message']||'Failed\x20to\x20update\x20group','error');}}),this['container']['addEventListener']('dragstart',_0x5cfa83=>this['handleDragStart'](_0x5cfa83)),this['container']['addEventListener']('dragend',_0x24e6ae=>this['handleDragEnd'](_0x24e6ae)),this['container']['addEventListener']('dragover',_0x4a8651=>this['handleDragOver'](_0x4a8651)),this['container']['addEventListener']('dragleave',_0x44c894=>this['handleDragLeave'](_0x44c894)),this['container']['addEventListener']('drop',_0x3c7999=>this['handleDrop'](_0x3c7999));}['handleDragStart'](_0x596af5){const _0x3334e4=_0x596af5['target']['closest']('.vgm-variant-card');if(!_0x3334e4)return;dragState['draggedTaskId']=_0x3334e4['dataset']['taskId'],dragState['draggedElement']=_0x3334e4,dragState['sourceGroupId']=_0x3334e4['dataset']['isGrouped']==='true'?this['groupId']:null,dragState['isDragging']=!![],_0x3334e4['classList']['add']('dragging'),_0x596af5['dataTransfer']['effectAllowed']='move',_0x596af5['dataTransfer']['setData']('text/plain',_0x3334e4['dataset']['taskId']),this['container']['classList']['add']('is-dragging');}['handleDragEnd'](_0x537453){const _0x33d304=_0x537453['target']['closest']('.vgm-variant-card');_0x33d304&&_0x33d304['classList']['remove']('dragging'),this['container']['querySelectorAll']('.drag-over,\x20.drop-indicator')['forEach'](_0x47cb44=>{_0x47cb44['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'](_0x36c70b){_0x36c70b['preventDefault'](),_0x36c70b['dataTransfer']['dropEffect']='move';const _0x2ba36e=_0x36c70b['target']['closest']('.vgm-drop-zone'),_0x5f0bc7=_0x36c70b['target']['closest']('.vgm-variant-card');this['container']['querySelectorAll']('.vgm-drop-zone')['forEach'](_0x58ab5c=>{_0x58ab5c['classList']['toggle']('drag-over',_0x58ab5c===_0x2ba36e);});if(_0x5f0bc7&&_0x5f0bc7!==dragState['draggedElement']){const _0x33f7ae=_0x5f0bc7['getBoundingClientRect'](),_0x356c54=_0x33f7ae['top']+_0x33f7ae['height']/0x2,_0x1cfa82=_0x36c70b['clientY']<_0x356c54;this['container']['querySelectorAll']('.vgm-variant-card')['forEach'](_0x1537a6=>{_0x1537a6!==_0x5f0bc7&&_0x1537a6['classList']['remove']('drop-before','drop-after');}),_0x5f0bc7['classList']['toggle']('drop-before',_0x1cfa82),_0x5f0bc7['classList']['toggle']('drop-after',!_0x1cfa82);}}['handleDragLeave'](_0x5cfd4c){const _0x209541=_0x5cfd4c['target']['closest']('.vgm-drop-zone');_0x209541&&!_0x209541['contains'](_0x5cfd4c['relatedTarget'])&&_0x209541['classList']['remove']('drag-over');}async['handleDrop'](_0x46fe4c){_0x46fe4c['preventDefault']();const _0x18af62=_0x46fe4c['target']['closest']('.vgm-drop-zone'),_0x554bb7=_0x46fe4c['target']['closest']('.vgm-variant-card'),_0x280a5c=_0x46fe4c['dataTransfer']['getData']('text/plain');if(!_0x18af62||!_0x280a5c)return;this['container']['querySelectorAll']('.drag-over,\x20.drop-before,\x20.drop-after')['forEach'](_0x546d4b=>{_0x546d4b['classList']['remove']('drag-over','drop-before','drop-after');});const _0x1151c6=_0x18af62['dataset']['zone'],_0x5d05a7=_0x1151c6==='grouped',_0x2d54ec=dragState['sourceGroupId']===this['groupId'];try{if(_0x5d05a7&&!_0x2d54ec){let _0x16d278=this['tasks']['filter'](_0x26b717=>_0x26b717['groupId']===this['groupId'])['length'];if(_0x554bb7){const _0x220645=_0x554bb7['dataset']['taskId'],_0x4f035d=this['tasks']['find'](_0x34ae5b=>_0x34ae5b['taskId']===_0x220645);if(_0x4f035d?.['groupIndex']!==undefined){const _0x2e9686=_0x554bb7['getBoundingClientRect'](),_0x14dec0=_0x46fe4c['clientY']<_0x2e9686['top']+_0x2e9686['height']/0x2;_0x16d278=_0x4f035d['groupIndex']+(_0x14dec0?0x0:0x1);}}await this['addToGroup'](_0x280a5c,_0x16d278);}else{if(!_0x5d05a7&&_0x2d54ec)await this['removeFromGroup'](_0x280a5c);else _0x5d05a7&&_0x2d54ec&&_0x554bb7&&await this['reorderInGroup'](_0x280a5c,_0x554bb7,_0x46fe4c['clientY']);}}catch(_0xc8c84f){console['error']('Drop\x20operation\x20failed:',_0xc8c84f),Utils['showToast'](_0xc8c84f['message']||'Failed\x20to\x20move\x20variant','error');}}async['addToGroup'](_0x3fedc2,_0x1710e8){const _0x4db2fe=this['tasks']['find'](_0x212a1d=>_0x212a1d['taskId']===_0x3fedc2);if(!_0x4db2fe)return;_0x1710e8===undefined&&(_0x1710e8=this['tasks']['filter'](_0x2415b8=>_0x2415b8['groupId']===this['groupId'])['length']),!this['groupId']&&(this['groupId']=API['generateGroupId'](),await API['createTaskGroup']({'groupId':this['groupId']})),await API['updateTaskGroup'](_0x3fedc2,this['groupId'],_0x1710e8),_0x4db2fe['groupId']=this['groupId'],_0x4db2fe['groupIndex']=_0x1710e8,this['render'](),this['onGroupChange'](this['tasks']);}async['removeFromGroup'](_0x15ac70){const _0x4c39f0=this['tasks']['find'](_0x2da7b3=>_0x2da7b3['taskId']===_0x15ac70);if(!_0x4c39f0)return;await API['removeTaskFromGroup'](_0x15ac70),_0x4c39f0['groupId']=null,_0x4c39f0['groupIndex']=null,this['render'](),this['onGroupChange'](this['tasks']);}async['reorderInGroup'](_0x5f4f5c,_0x430108,_0x2d39ae){const _0x5718e8=this['tasks']['find'](_0x4b4ef8=>_0x4b4ef8['taskId']===_0x5f4f5c),_0x58cf31=_0x430108['dataset']['taskId'],_0xb2ed05=this['tasks']['find'](_0xd3a1c8=>_0xd3a1c8['taskId']===_0x58cf31);if(!_0x5718e8||!_0xb2ed05||_0x5718e8['taskId']===_0xb2ed05['taskId'])return;const _0x3e8b4e=_0x430108['getBoundingClientRect'](),_0x3a4e09=_0x2d39ae<_0x3e8b4e['top']+_0x3e8b4e['height']/0x2;let _0x45dd74=_0xb2ed05['groupIndex']??0x0;if(!_0x3a4e09)_0x45dd74++;if((_0x5718e8['groupIndex']??0x0)<(_0xb2ed05['groupIndex']??0x0))_0x45dd74--;if(_0x45dd74===_0x5718e8['groupIndex'])return;await API['updateTaskGroup'](_0x5f4f5c,this['groupId'],_0x45dd74);const _0x15d646=this['tasks']['filter'](_0x441e55=>_0x441e55['groupId']===this['groupId'])['sort']((_0x3503c7,_0x2d8b39)=>(_0x3503c7['groupIndex']??0x0)-(_0x2d8b39['groupIndex']??0x0)),_0x1d61e8=_0x15d646['findIndex'](_0x8c28ed=>_0x8c28ed['taskId']===_0x5f4f5c);_0x1d61e8!==-0x1&&_0x15d646['splice'](_0x1d61e8,0x1),_0x15d646['splice'](_0x45dd74,0x0,_0x5718e8),_0x15d646['forEach']((_0x5c033f,_0x268818)=>{_0x5c033f['groupIndex']=_0x268818;}),this['render'](),this['onGroupChange'](this['tasks']);}}export function initializeTabDragDrop(_0x21f234,_0x28c00d,_0x27ec5c,_0x51ca41={}){if(!_0x21f234)return;const {onReorder:_0x48fe56,onRemove:_0x1f49c7}=_0x51ca41,_0x289592=_0x21f234['querySelectorAll']('.task-tab');_0x289592['forEach']((_0x4ff813,_0x48bc58)=>{_0x4ff813['setAttribute']('draggable','true'),_0x4ff813['dataset']['index']=_0x48bc58,_0x4ff813['addEventListener']('dragstart',_0x48f378=>{_0x48f378['dataTransfer']['effectAllowed']='move',_0x48f378['dataTransfer']['setData']('text/plain',_0x4ff813['dataset']['taskId']),_0x4ff813['classList']['add']('dragging'),_0x21f234['classList']['add']('is-dragging');}),_0x4ff813['addEventListener']('dragend',()=>{_0x4ff813['classList']['remove']('dragging'),_0x21f234['classList']['remove']('is-dragging'),_0x21f234['querySelectorAll']('.drop-indicator')['forEach'](_0x3e8968=>{_0x3e8968['classList']['remove']('drop-indicator','drop-before','drop-after');});}),_0x4ff813['addEventListener']('dragover',_0xb9033b=>{_0xb9033b['preventDefault'](),_0xb9033b['dataTransfer']['dropEffect']='move';if(_0x4ff813['classList']['contains']('dragging'))return;const _0x25b744=_0x4ff813['getBoundingClientRect'](),_0x36169c=_0x25b744['left']+_0x25b744['width']/0x2,_0x1a7f73=_0xb9033b['clientX']<_0x36169c;_0x289592['forEach'](_0x433047=>_0x433047['classList']['remove']('drop-before','drop-after')),_0x4ff813['classList']['add'](_0x1a7f73?'drop-before':'drop-after');}),_0x4ff813['addEventListener']('dragleave',()=>{_0x4ff813['classList']['remove']('drop-before','drop-after');}),_0x4ff813['addEventListener']('drop',async _0x201192=>{_0x201192['preventDefault']();const _0x5a98e6=_0x201192['dataTransfer']['getData']('text/plain'),_0x4f9ee4=_0x4ff813['dataset']['taskId'];if(_0x5a98e6===_0x4f9ee4)return;const _0x32ede4=_0x4ff813['getBoundingClientRect'](),_0x24adc8=_0x201192['clientX']<_0x32ede4['left']+_0x32ede4['width']/0x2;_0x4ff813['classList']['remove']('drop-before','drop-after'),_0x48fe56&&await _0x48fe56(_0x5a98e6,_0x4f9ee4,_0x24adc8);});});const _0x268335=document['createElement']('div');return _0x268335['className']='task-tab-remove-zone',_0x268335['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',_0x268335['style']['display']='none',_0x268335['addEventListener']('dragover',_0x6ca9a7=>{_0x6ca9a7['preventDefault'](),_0x268335['classList']['add']('drag-over');}),_0x268335['addEventListener']('dragleave',()=>{_0x268335['classList']['remove']('drag-over');}),_0x268335['addEventListener']('drop',async _0x5a143b=>{_0x5a143b['preventDefault'](),_0x268335['classList']['remove']('drag-over');const _0xf60fcf=_0x5a143b['dataTransfer']['getData']('text/plain');_0x1f49c7&&await _0x1f49c7(_0xf60fcf);}),_0x21f234['addEventListener']('dragstart',()=>{_0x28c00d['length']>0x1&&(_0x268335['style']['display']='flex');}),_0x21f234['addEventListener']('dragend',()=>{_0x268335['style']['display']='none';}),_0x21f234['appendChild'](_0x268335),{'destroy':()=>{_0x268335['remove']();}};}export default VariantGroupingManager;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@profoundlogic/coderflow-server",
3
- "version": "0.7.0",
3
+ "version": "0.7.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",