@profoundlogic/coderflow-server 0.7.9 → 0.8.0

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 (180) hide show
  1. package/dist/base-image/entrypoint.sh +75 -5
  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/compression-filter.js +1 -1
  33. package/dist/lib/config-migration.js +1 -1
  34. package/dist/lib/container-credential-sync.js +1 -1
  35. package/dist/lib/container-tokens.js +1 -1
  36. package/dist/lib/data-dir.js +1 -1
  37. package/dist/lib/deployment-history.js +1 -1
  38. package/dist/lib/deployment-service.js +1 -1
  39. package/dist/lib/docker-utils.js +1 -1
  40. package/dist/lib/email.js +1 -1
  41. package/dist/lib/emailTemplates.js +1 -1
  42. package/dist/lib/entitlement.js +1 -1
  43. package/dist/lib/external-connections.js +1 -1
  44. package/dist/lib/fetch-utils.js +1 -1
  45. package/dist/lib/git-commit-details-route.js +1 -1
  46. package/dist/lib/git-history-diff-guardrails.js +1 -1
  47. package/dist/lib/git-provider-service.js +1 -1
  48. package/dist/lib/git-provider-setup/github-setup-handler.js +1 -1
  49. package/dist/lib/git-provider-setup/index.js +1 -1
  50. package/dist/lib/git-provider-setup/setup-factory.js +1 -1
  51. package/dist/lib/git-provider-setup/setup-interface.js +1 -1
  52. package/dist/lib/git-providers/azure-devops-provider.js +1 -1
  53. package/dist/lib/git-providers/github-app-provider.js +1 -1
  54. package/dist/lib/git-providers/index.js +1 -1
  55. package/dist/lib/git-providers/provider-factory.js +1 -1
  56. package/dist/lib/git-providers/provider-interface.js +1 -1
  57. package/dist/lib/github-urls.js +1 -1
  58. package/dist/lib/group-objective-linking.js +1 -1
  59. package/dist/lib/ibmi-sync.js +1 -1
  60. package/dist/lib/jira-client.js +1 -1
  61. package/dist/lib/judge-blinding.js +1 -1
  62. package/dist/lib/logger.js +1 -1
  63. package/dist/lib/memory-utils.js +1 -1
  64. package/dist/lib/migration-to-scoped-rbac.js +1 -1
  65. package/dist/lib/model-fetcher.js +1 -1
  66. package/dist/lib/notifications.js +1 -1
  67. package/dist/lib/objective-context.js +1 -1
  68. package/dist/lib/oidc-auth.js +1 -1
  69. package/dist/lib/oidc-device-flow.js +1 -1
  70. package/dist/lib/passwordTokens.js +1 -1
  71. package/dist/lib/permission-resolver.js +1 -1
  72. package/dist/lib/pin-cascade.js +1 -1
  73. package/dist/lib/provider-accounts.js +1 -1
  74. package/dist/lib/provider-oauth.js +1 -1
  75. package/dist/lib/provider-profile.js +1 -1
  76. package/dist/lib/provider-token-refresh.js +1 -1
  77. package/dist/lib/rbac-user-state.js +1 -1
  78. package/dist/lib/request-url.js +1 -1
  79. package/dist/lib/rewind.js +1 -1
  80. package/dist/lib/role-definitions.js +1 -1
  81. package/dist/lib/roles.js +1 -1
  82. package/dist/lib/secrets.js +1 -1
  83. package/dist/lib/setup-repo-git-auth.js +1 -1
  84. package/dist/lib/state-capture.js +1 -1
  85. package/dist/lib/static-files.js +1 -1
  86. package/dist/lib/task-aliases.js +1 -1
  87. package/dist/lib/task-container-init.js +1 -0
  88. package/dist/lib/task-context-usage.js +1 -0
  89. package/dist/lib/task-name-format.js +1 -1
  90. package/dist/lib/task-name-generator.js +1 -1
  91. package/dist/lib/task-source-metadata.js +1 -1
  92. package/dist/lib/teams.js +1 -1
  93. package/dist/lib/user-git-oauth.js +1 -1
  94. package/dist/lib/user-git-tokens.js +1 -1
  95. package/dist/lib/users.js +1 -1
  96. package/dist/middleware/requireAuth.js +1 -1
  97. package/dist/middleware/requireInit.js +1 -1
  98. package/dist/middleware/requirePermission.js +1 -1
  99. package/dist/package.json +1 -1
  100. package/dist/playwright.config.js +1 -1
  101. package/dist/playwright.task-terminal.config.js +1 -1
  102. package/dist/routes/apiKeys.js +1 -1
  103. package/dist/routes/auth-oidc.js +1 -1
  104. package/dist/routes/auth.js +1 -1
  105. package/dist/routes/automations.js +1 -1
  106. package/dist/routes/bindings.js +1 -1
  107. package/dist/routes/build.js +1 -1
  108. package/dist/routes/containers.js +1 -1
  109. package/dist/routes/deploy-task.js +1 -1
  110. package/dist/routes/environment-management.js +1 -1
  111. package/dist/routes/environments.js +1 -1
  112. package/dist/routes/external-skills.js +1 -1
  113. package/dist/routes/git-credentials.js +1 -1
  114. package/dist/routes/git-oauth.js +1 -1
  115. package/dist/routes/git-provider-setup.js +1 -1
  116. package/dist/routes/health.js +1 -1
  117. package/dist/routes/jira.js +1 -1
  118. package/dist/routes/logs.js +1 -1
  119. package/dist/routes/objective-management.js +1 -1
  120. package/dist/routes/password.js +1 -1
  121. package/dist/routes/prompt.js +1 -1
  122. package/dist/routes/provider-auth.js +1 -1
  123. package/dist/routes/qa.js +1 -1
  124. package/dist/routes/roles.js +1 -1
  125. package/dist/routes/settings.js +1 -1
  126. package/dist/routes/skill-management.js +1 -1
  127. package/dist/routes/skills.js +1 -1
  128. package/dist/routes/stats.js +1 -1
  129. package/dist/routes/tasks.js +1 -1
  130. package/dist/routes/teams.js +1 -1
  131. package/dist/routes/templates.js +1 -1
  132. package/dist/routes/test-task.js +1 -1
  133. package/dist/routes/test.js +1 -1
  134. package/dist/routes/users.js +1 -1
  135. package/dist/routes/visualizations.js +1 -1
  136. package/dist/scripts/create-user.js +1 -1
  137. package/dist/scripts/migrate-config-to-data-dir.js +1 -1
  138. package/dist/start.js +1 -1
  139. package/dist/web-ui/public/activity-detail-modal.js +1 -1
  140. package/dist/web-ui/public/activity-feed.js +1 -1
  141. package/dist/web-ui/public/activity-formatters.js +1 -1
  142. package/dist/web-ui/public/admin.js +1 -1
  143. package/dist/web-ui/public/agent-event-parser.js +1 -1
  144. package/dist/web-ui/public/app.js +1 -1
  145. package/dist/web-ui/public/approve-dialog.js +1 -1
  146. package/dist/web-ui/public/automation-links.js +1 -1
  147. package/dist/web-ui/public/automation-schedule.js +1 -1
  148. package/dist/web-ui/public/comments-widget.js +1 -1
  149. package/dist/web-ui/public/diff-utils.js +1 -1
  150. package/dist/web-ui/public/environments.js +1 -1
  151. package/dist/web-ui/public/feedback-widget.js +1 -1
  152. package/dist/web-ui/public/file-selection-tree.js +1 -1
  153. package/dist/web-ui/public/git-history-lazy-utils.js +1 -1
  154. package/dist/web-ui/public/git-history.js +1 -1
  155. package/dist/web-ui/public/git-status.js +1 -1
  156. package/dist/web-ui/public/ibmi-file-filter.js +1 -1
  157. package/dist/web-ui/public/index.js +1 -1
  158. package/dist/web-ui/public/login.js +1 -1
  159. package/dist/web-ui/public/markdown-editor.js +1 -1
  160. package/dist/web-ui/public/markdown-file-editor.js +1 -1
  161. package/dist/web-ui/public/modal-maximize.js +1 -1
  162. package/dist/web-ui/public/notifications.js +1 -1
  163. package/dist/web-ui/public/permissions.js +1 -1
  164. package/dist/web-ui/public/pr-dialog.js +1 -1
  165. package/dist/web-ui/public/roles.js +1 -1
  166. package/dist/web-ui/public/settings.js +1 -1
  167. package/dist/web-ui/public/setup-password.js +1 -1
  168. package/dist/web-ui/public/skills.js +1 -1
  169. package/dist/web-ui/public/sse-client.js +1 -1
  170. package/dist/web-ui/public/sse-shared-worker.js +1 -1
  171. package/dist/web-ui/public/styles.css +36 -0
  172. package/dist/web-ui/public/task-judging-helpers.js +1 -1
  173. package/dist/web-ui/public/task.html +11 -0
  174. package/dist/web-ui/public/task.js +1 -1
  175. package/dist/web-ui/public/teams.js +1 -1
  176. package/dist/web-ui/public/terminal.js +1 -1
  177. package/dist/web-ui/public/theme.js +1 -1
  178. package/dist/web-ui/public/users.js +1 -1
  179. package/dist/web-ui/public/variant-grouping.js +1 -1
  180. 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 _0x172748=state['currentUser'];if(!Permissions['hasServerPermission'](_0x172748,'teams:view')&&!Permissions['hasTeamPermission'](_0x172748,'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'](_0x172748,'*')||Permissions['hasTeamPermission'](_0x172748,'teams:manage'))&&(document['getElementById']('create-team-btn')['hidden']=![]),bindEventListeners(),await Promise['all']([loadTeams(),loadUsers(),loadRoles(),loadEnvironments()]),renderTeams();});async function loadTeams(){const _0x2c9448=document['getElementById']('teams-loading'),_0x6d72d7=document['getElementById']('teams-error'),_0x26bed3=document['getElementById']('teams-content');try{_0x2c9448['hidden']=![],_0x6d72d7['hidden']=!![],_0x26bed3['hidden']=!![];const {teams:_0x4bd078}=await API['getTeams']();state['teams']=_0x4bd078||[],renderTeams(),_0x2c9448['hidden']=!![],_0x26bed3['hidden']=![];}catch(_0x9b46b7){_0x2c9448['hidden']=!![],_0x6d72d7['hidden']=![],document['getElementById']('teams-error-message')['textContent']=_0x9b46b7['message'];}}async function loadUsers(){try{const {users:_0x5e3c4a}=await API['getUsers']();state['users']=_0x5e3c4a||[];}catch{state['users']=[];}}async function loadRoles(){try{const {roles:_0x18dc49}=await API['getRoleDefinitions']();state['roles']=_0x18dc49||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x1c5aa2=await API['getEnvironments']();state['environments']=_0x1c5aa2['environments']||[];}catch{state['environments']=[];}}function renderTeams(){const _0x32811f=document['getElementById']('teams-table-body'),_0x3cf92c=document['getElementById']('team-count');if(!_0x32811f)return;_0x3cf92c&&(_0x3cf92c['textContent']=state['teams']['length']+'\x20team'+(state['teams']['length']===0x1?'':'s'));if(state['teams']['length']===0x0){_0x32811f['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 _0x58accc=Permissions['hasServerPermission'](state['currentUser'],'*');_0x32811f['innerHTML']=state['teams']['map'](_0x5b96ea=>{const _0x136350=_0x58accc||_0x5b96ea['canManageTeam'],_0x93bf9=_0x58accc||_0x5b96ea['canManageMembers'],_0x497e16=_0x136350||_0x93bf9,_0x12b79e=(_0x5b96ea['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'](_0x5b96ea['name'])+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x5b96ea['description']?'<div\x20style=\x22font-size:\x200.8em;\x20color:\x20var(--color-text-secondary);\x20margin-top:\x200.15rem;\x22>'+Utils['escapeHtml'](_0x5b96ea['description'])+'</div>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+_0x12b79e+'</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'+(_0x497e16?'<button\x20class=\x22btn-icon\x22\x20title=\x22Edit\x20team\x22\x20onclick=\x22window.openTeamModal(\x27'+_0x5b96ea['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'+(_0x136350?'<button\x20class=\x22btn-icon\x22\x20title=\x22Access\x20bindings\x22\x20onclick=\x22window.openBindingsModal(\x27'+_0x5b96ea['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'+(_0x136350?'<button\x20class=\x22btn-icon\x20btn-danger\x22\x20title=\x22Delete\x20team\x22\x20onclick=\x22window.deleteTeam(\x27'+_0x5b96ea['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(_0x276425){const _0x26e124=state['teams']['find'](_0x2e5a40=>_0x2e5a40['id']===_0x276425);if(!_0x26e124)return;state['editingTeamId']=_0x276425;const _0x116752=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x4fcf5f=_0x116752||_0x26e124['canManageTeam'],_0x5be77d=_0x116752||_0x26e124['canManageMembers'],_0xb96161=_0x4fcf5f,_0x398ecb=_0x4fcf5f||_0x5be77d,_0x25a286=_0x26e124['name'],_0x16f76c=_0x26e124['description']||'';state['modalSnapshot']={'name':_0x25a286,'description':_0x16f76c},document['getElementById']('team-modal-title')['textContent']=_0x25a286,document['getElementById']('team-name')['value']=_0x25a286,document['getElementById']('team-name')['disabled']=!_0xb96161,document['getElementById']('team-description')['value']=_0x16f76c,document['getElementById']('team-description')['disabled']=!_0xb96161,document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=![],document['getElementById']('save-team')['hidden']=!_0xb96161,renderMembersList(_0x26e124),updateMemberSelect(_0x26e124),document['getElementById']('team-modal')['hidden']=![];};function isTeamModalDirty(){if(!state['modalSnapshot'])return![];const _0x466dc9=document['getElementById']('team-name')['value']['trim'](),_0x1285c0=document['getElementById']('team-description')['value']['trim']();return _0x466dc9!==state['modalSnapshot']['name']||_0x1285c0!==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(_0xa7d7a){const _0x350260=state['teams']['find'](_0x5d6a24=>_0x5d6a24['id']===_0xa7d7a);if(!_0x350260)return;state['bindingsTeamId']=_0xa7d7a,document['getElementById']('bindings-modal-title')['textContent']='Access\x20Bindings\x20—\x20'+_0x350260['name'],document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('bindings-modal')['hidden']=![],loadTeamBindings(_0xa7d7a);};function hideBindingsModal(){document['getElementById']('bindings-modal')['hidden']=!![],state['bindingsTeamId']=null;}function renderMembersList(_0xa1b274){const _0x24aa31=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x209747=_0x24aa31||_0xa1b274['canManageMembers']||_0xa1b274['canManageTeam'],_0x3a21a3=_0xa1b274['members']||[],_0x57b676=document['getElementById']('members-list');if(_0x3a21a3['length']===0x0){_0x57b676['innerHTML']='<p\x20style=\x22font-size:\x200.875rem;\x20color:\x20var(--color-text-secondary);\x20margin:\x200.25rem\x200;\x22>No\x20members\x20yet</p>';return;}_0x57b676['innerHTML']=_0x3a21a3['map'](_0x2e6482=>{const _0x4a98c1=state['users']['find'](_0x35aaa4=>_0x35aaa4['id']===_0x2e6482),_0x23b3b4=_0x4a98c1?''+Utils['escapeHtml'](_0x4a98c1['username'])+(_0x4a98c1['name']?'\x20<span\x20style=\x22color:\x20var(--color-text-secondary);\x20font-size:\x200.85em;\x22>('+Utils['escapeHtml'](_0x4a98c1['name'])+')</span>':''):Utils['escapeHtml'](_0x2e6482);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'+_0x23b3b4+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x209747?'<button\x20type=\x22button\x22\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.removeMemberClick(\x27'+_0x2e6482+'\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 _0xf84f55=document['getElementById']('add-member-row');if(_0xf84f55)_0xf84f55['style']['display']=_0x209747?'flex':'none';}function updateMemberSelect(_0x4cca33){const _0x84b371=document['getElementById']('add-member-select');if(!_0x84b371)return;const _0x2ebd18=new Set(_0x4cca33['members']||[]),_0x5ecca5=state['users']['filter'](_0x42a9d7=>!_0x2ebd18['has'](_0x42a9d7['id']));_0x84b371['innerHTML']='<option\x20value=\x22\x22>Add\x20a\x20member…</option>'+_0x5ecca5['map'](_0x47e3b1=>'<option\x20value=\x22'+_0x47e3b1['id']+'\x22>'+Utils['escapeHtml'](_0x47e3b1['username'])+(_0x47e3b1['name']?'\x20('+Utils['escapeHtml'](_0x47e3b1['name'])+')':'')+'</option>')['join']('');}async function addMember(){const _0x10c170=document['getElementById']('add-member-select'),_0xb7c5b3=_0x10c170['value'];if(!_0xb7c5b3||!state['editingTeamId'])return;try{const {team:_0x43d871}=await API['addTeamMember'](state['editingTeamId'],_0xb7c5b3);syncTeamInState(_0x43d871),renderMembersList(_0x43d871),updateMemberSelect(_0x43d871),_0x10c170['value']='',Utils['showToast']('Member\x20added','success');}catch(_0x39a95f){Utils['showToast'](_0x39a95f['message'],'error');}}window['removeMemberClick']=async function(_0x39d4b8){if(!state['editingTeamId'])return;try{const {team:_0x4c08c1}=await API['removeTeamMember'](state['editingTeamId'],_0x39d4b8);syncTeamInState(_0x4c08c1),renderMembersList(_0x4c08c1),updateMemberSelect(_0x4c08c1),Utils['showToast']('Member\x20removed','success');}catch(_0x21d99d){Utils['showToast'](_0x21d99d['message'],'error');}};async function loadTeamBindings(_0x2fb9d5){const _0x46a4d9=document['getElementById']('bindings-loading'),_0x3021b6=document['getElementById']('bindings-empty'),_0x28a6a5=document['getElementById']('bindings-list-container'),_0x2e1e70=document['getElementById']('add-binding-btn');_0x46a4d9['hidden']=![],_0x3021b6['hidden']=!![],_0x28a6a5['style']['display']='none',_0x2e1e70['hidden']=!![],document['getElementById']('add-binding-form')['hidden']=!![];try{const {bindings:_0x4013c5}=await API['getBindings']({'subject_type':'team','subject_id':_0x2fb9d5});state['teamBindings']=_0x4013c5||[],_0x46a4d9['hidden']=!![],state['teamBindings']['length']===0x0?_0x3021b6['hidden']=![]:(_0x28a6a5['style']['display']='',renderBindingsTable()),(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage'))&&(_0x2e1e70['hidden']=![]);}catch(_0x4ef3d9){_0x46a4d9['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x4ef3d9['message'],'error');}}function renderBindingsTable(){const _0x17ed27=document['getElementById']('bindings-table-body');if(!_0x17ed27)return;const _0x571b7a=Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage');_0x17ed27['innerHTML']=state['teamBindings']['map'](_0x88fd6c=>{const _0x5f32a4=_0x88fd6c['resource_type']==='server'?'Server':_0x88fd6c['resource_id']==='*'?'All\x20'+_0x88fd6c['resource_type']+'s':Utils['escapeHtml'](_0x88fd6c['resource_name']||_0x88fd6c['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x5f32a4+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x88fd6c['role_name']||_0x88fd6c['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x571b7a?'<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteBindingClick(\x27'+_0x88fd6c['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 _0x228cba=document['getElementById']('binding-resource-type');_0x228cba['value']='environment',updateBindingFormForResourceType('environment');}function onBindingResourceTypeChange(){const _0x50c4ac=document['getElementById']('binding-resource-type')['value'];updateBindingFormForResourceType(_0x50c4ac);}function updateBindingFormForResourceType(_0x1058ae){const _0x124b68=document['getElementById']('binding-resource-container'),_0x11b4fe=document['getElementById']('binding-resource'),_0x283eaa=document['getElementById']('binding-role');if(_0x1058ae==='server')_0x124b68['style']['display']='none';else{_0x124b68['style']['display']='';if(_0x1058ae==='environment'){const _0x519a03=new Set(state['teamBindings']['filter'](_0x526e95=>_0x526e95['resource_type']==='environment')['map'](_0x549868=>_0x549868['resource_id'])),_0x397a47=state['environments']['filter'](_0x58b88f=>!_0x519a03['has'](_0x58b88f['name']));_0x11b4fe['innerHTML']=_0x397a47['length']?_0x397a47['map'](_0x29755f=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x29755f['name'])+'\x22>'+Utils['escapeHtml'](_0x29755f['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x1058ae==='team'){const _0x2b494=new Set(state['teamBindings']['filter'](_0x3ff45e=>_0x3ff45e['resource_type']==='team')['map'](_0x554112=>_0x554112['resource_id'])),_0x1644c6=state['teams']['filter'](_0x2fc87b=>!_0x2b494['has'](_0x2fc87b['id']));_0x11b4fe['innerHTML']=_0x1644c6['length']?_0x1644c6['map'](_0x53cef9=>'<option\x20value=\x22'+_0x53cef9['id']+'\x22>'+Utils['escapeHtml'](_0x53cef9['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x19c740=state['roles']['filter'](_0x1966a9=>_0x1966a9['resource_type']===_0x1058ae);_0x283eaa['innerHTML']=_0x19c740['length']?_0x19c740['filter'](_0x38d600=>{const _0x4bbb1c=_0x1058ae==='server'?undefined:_0x11b4fe['value'];return!state['teamBindings']['some'](_0x89cfb1=>_0x89cfb1['resource_type']===_0x1058ae&&_0x89cfb1['role_id']===_0x38d600['id']&&(_0x1058ae==='server'||_0x89cfb1['resource_id']===_0x4bbb1c));})['map'](_0x323658=>'<option\x20value=\x22'+_0x323658['id']+'\x22>'+Utils['escapeHtml'](_0x323658['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 _0x557b2e=document['getElementById']('binding-resource-type')['value'],_0x2f721e=document['getElementById']('binding-role')['value'];if(!_0x2f721e||!state['bindingsTeamId'])return;const _0x3a15c7=_0x557b2e==='server'?undefined:document['getElementById']('binding-resource')['value'];if(_0x557b2e!=='server'&&!_0x3a15c7)return;const _0x22de37=document['getElementById']('save-binding-btn');_0x22de37['disabled']=!![],_0x22de37['textContent']='Adding…';try{const _0x3041ec={'subject_type':'team','subject_id':state['bindingsTeamId'],'role_id':_0x2f721e,'resource_type':_0x557b2e};if(_0x3a15c7)_0x3041ec['resource_id']=_0x3a15c7;await API['createBinding'](_0x3041ec),Utils['showToast']('Binding\x20added','success'),document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![],await loadTeamBindings(state['bindingsTeamId']);}catch(_0x451a44){Utils['showToast'](_0x451a44['message'],'error');}finally{_0x22de37['disabled']=![],_0x22de37['textContent']='Add\x20Binding';}}window['deleteBindingClick']=async function(_0x470a0d){try{await API['deleteBinding'](_0x470a0d),Utils['showToast']('Binding\x20removed','success'),await loadTeamBindings(state['bindingsTeamId']);}catch(_0x49e27d){Utils['showToast'](_0x49e27d['message'],'error');}};async function saveTeam(){const _0x484621=document['getElementById']('team-name')['value']['trim'](),_0x454085=document['getElementById']('team-description')['value']['trim'](),_0xf28bdd=document['getElementById']('team-form-error'),_0x462826=document['getElementById']('save-team');if(!_0x484621){_0xf28bdd['textContent']='Team\x20name\x20is\x20required',_0xf28bdd['hidden']=![];return;}_0xf28bdd['hidden']=!![];const _0x3df4b7=_0x462826['textContent'];_0x462826['disabled']=!![],_0x462826['textContent']=state['editingTeamId']?'Saving…':'Creating…';try{if(state['editingTeamId']){const {team:_0x30efdc}=await API['updateTeam'](state['editingTeamId'],{'name':_0x484621,'description':_0x454085});syncTeamInState(_0x30efdc),document['getElementById']('team-modal-title')['textContent']=_0x30efdc['name'],Utils['showToast']('Team\x20updated','success');}else await API['createTeam']({'name':_0x484621,'description':_0x454085}),Utils['showToast']('Team\x20created','success');_0x462826['disabled']=![],_0x462826['textContent']=_0x3df4b7,hideTeamModal(),await loadTeams();}catch(_0x518dfd){_0xf28bdd['textContent']=_0x518dfd['message'],_0xf28bdd['hidden']=![],_0x462826['disabled']=![],_0x462826['textContent']=_0x3df4b7;}}window['deleteTeam']=function(_0x3e427a){const _0x563d3f=state['teams']['find'](_0x4a10d4=>_0x4a10d4['id']===_0x3e427a);if(!_0x563d3f)return;state['deletingTeamId']=_0x3e427a,document['getElementById']('delete-team-name')['textContent']=_0x563d3f['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 _0x244fdf=document['getElementById']('confirm-delete-team');_0x244fdf['disabled']=!![],_0x244fdf['textContent']='Deleting…';try{await API['deleteTeam'](state['deletingTeamId']),Utils['showToast']('Team\x20deleted','success'),_0x244fdf['disabled']=![],_0x244fdf['textContent']='Delete\x20Team',hideDeleteModal(),await loadTeams();}catch(_0x411eaf){Utils['showToast']('Failed\x20to\x20delete\x20team:\x20'+_0x411eaf['message'],'error'),_0x244fdf['disabled']=![],_0x244fdf['textContent']='Delete\x20Team';}}function syncTeamInState(_0x8c3b21){const _0x5db37f=state['teams']['findIndex'](_0x1cc104=>_0x1cc104['id']===_0x8c3b21['id']);if(_0x5db37f>=0x0)state['teams'][_0x5db37f]=_0x8c3b21;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 _0x27daf9=state['currentUser'];if(!Permissions['hasServerPermission'](_0x27daf9,'teams:view')&&!Permissions['hasTeamPermission'](_0x27daf9,'teams:manage')){Utils['showToast']('Access\x20denied:\x20You\x20do\x20not\x20have\x20permission\x20to\x20view\x20teams','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}(Permissions['hasServerPermission'](_0x27daf9,'*')||Permissions['hasTeamPermission'](_0x27daf9,'teams:manage'))&&(document['getElementById']('create-team-btn')['hidden']=![]),bindEventListeners(),await Promise['all']([loadTeams(),loadUsers(),loadRoles(),loadEnvironments()]),renderTeams();});async function loadTeams(){const _0x33e1ec=document['getElementById']('teams-loading'),_0x3bb47c=document['getElementById']('teams-error'),_0x467e0c=document['getElementById']('teams-content');try{_0x33e1ec['hidden']=![],_0x3bb47c['hidden']=!![],_0x467e0c['hidden']=!![];const {teams:_0x366105}=await API['getTeams']();state['teams']=_0x366105||[],renderTeams(),_0x33e1ec['hidden']=!![],_0x467e0c['hidden']=![];}catch(_0x55e4f5){_0x33e1ec['hidden']=!![],_0x3bb47c['hidden']=![],document['getElementById']('teams-error-message')['textContent']=_0x55e4f5['message'];}}async function loadUsers(){try{const {users:_0xb48d6f}=await API['getUsers']();state['users']=_0xb48d6f||[];}catch{state['users']=[];}}async function loadRoles(){try{const {roles:_0x199d20}=await API['getRoleDefinitions']();state['roles']=_0x199d20||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x2855bf=await API['getEnvironments']();state['environments']=_0x2855bf['environments']||[];}catch{state['environments']=[];}}function renderTeams(){const _0x1a23f9=document['getElementById']('teams-table-body'),_0x5ebb70=document['getElementById']('team-count');if(!_0x1a23f9)return;_0x5ebb70&&(_0x5ebb70['textContent']=state['teams']['length']+'\x20team'+(state['teams']['length']===0x1?'':'s'));if(state['teams']['length']===0x0){_0x1a23f9['innerHTML']='\x0a\x20\x20\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td\x20colspan=\x223\x22\x20style=\x22text-align:\x20center;\x20color:\x20var(--color-text-secondary);\x20padding:\x202rem;\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20No\x20teams\x20yet.\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage')?'Click\x20<strong>Create\x20Team</strong>\x20to\x20get\x20started.':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20</tr>';return;}const _0x16b75f=Permissions['hasServerPermission'](state['currentUser'],'*');_0x1a23f9['innerHTML']=state['teams']['map'](_0x1ae482=>{const _0x329829=_0x16b75f||_0x1ae482['canManageTeam'],_0x7c0c48=_0x16b75f||_0x1ae482['canManageMembers'],_0x165fd8=_0x329829||_0x7c0c48,_0x34c040=(_0x1ae482['members']||[])['length'];return'\x0a\x20\x20\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20style=\x22font-weight:\x20600;\x22>'+Utils['escapeHtml'](_0x1ae482['name'])+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x1ae482['description']?'<div\x20style=\x22font-size:\x200.8em;\x20color:\x20var(--color-text-secondary);\x20margin-top:\x200.15rem;\x22>'+Utils['escapeHtml'](_0x1ae482['description'])+'</div>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+_0x34c040+'</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22user-actions\x22\x20style=\x22display:\x20flex;\x20gap:\x200.25rem;\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x165fd8?'<button\x20class=\x22btn-icon\x22\x20title=\x22Edit\x20team\x22\x20onclick=\x22window.openTeamModal(\x27'+_0x1ae482['id']+'\x27)\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2216\x22\x20height=\x2216\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M11\x204H4a2\x202\x200\x200\x200-2\x202v14a2\x202\x200\x200\x200\x202\x202h14a2\x202\x200\x200\x200\x202-2v-7\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M18.5\x202.5a2.121\x202.121\x200\x200\x201\x203\x203L12\x2015l-4\x201\x201-4\x209.5-9.5z\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x329829?'<button\x20class=\x22btn-icon\x22\x20title=\x22Access\x20bindings\x22\x20onclick=\x22window.openBindingsModal(\x27'+_0x1ae482['id']+'\x27)\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2216\x22\x20height=\x2216\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M12\x2022s8-4\x208-10V5l-8-3-8\x203v7c0\x206\x208\x2010\x208\x2010z\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x329829?'<button\x20class=\x22btn-icon\x20btn-danger\x22\x20title=\x22Delete\x20team\x22\x20onclick=\x22window.deleteTeam(\x27'+_0x1ae482['id']+'\x27)\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2216\x22\x20height=\x2216\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<polyline\x20points=\x223\x206\x205\x206\x2021\x206\x22></polyline>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M19\x206v14a2\x202\x200\x200\x201-2\x202H7a2\x202\x200\x200\x201-2-2V6m3\x200V4a2\x202\x200\x200\x201\x202-2h4a2\x202\x200\x200\x201\x202\x202v2\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20</tr>';})['join']('');}function bindEventListeners(){document['getElementById']('create-team-btn')?.['addEventListener']('click',showCreateTeamModal),document['getElementById']('retry-teams-btn')?.['addEventListener']('click',loadTeams),document['getElementById']('close-team-modal')?.['addEventListener']('click',requestHideTeamModal),document['getElementById']('cancel-team')?.['addEventListener']('click',requestHideTeamModal),document['getElementById']('save-team')?.['addEventListener']('click',saveTeam),document['querySelector']('#team-modal\x20.modal-overlay')?.['addEventListener']('click',requestHideTeamModal),document['getElementById']('add-member-btn')?.['addEventListener']('click',addMember),document['getElementById']('close-bindings-modal')?.['addEventListener']('click',hideBindingsModal),document['querySelector']('#bindings-modal\x20.modal-overlay')?.['addEventListener']('click',hideBindingsModal),document['getElementById']('add-binding-btn')?.['addEventListener']('click',()=>{document['getElementById']('add-binding-form')['hidden']=![],document['getElementById']('add-binding-btn')['hidden']=!![],populateBindingForm();}),document['getElementById']('cancel-binding-btn')?.['addEventListener']('click',()=>{document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![];}),document['getElementById']('save-binding-btn')?.['addEventListener']('click',saveBinding),document['getElementById']('binding-resource-type')?.['addEventListener']('change',onBindingResourceTypeChange),document['getElementById']('close-delete-team-modal')?.['addEventListener']('click',hideDeleteModal),document['getElementById']('cancel-delete-team')?.['addEventListener']('click',hideDeleteModal),document['getElementById']('confirm-delete-team')?.['addEventListener']('click',confirmDeleteTeam),document['querySelector']('#delete-team-modal\x20.modal-overlay')?.['addEventListener']('click',hideDeleteModal);}function showCreateTeamModal(){state['editingTeamId']=null,state['modalSnapshot']={'name':'','description':''},document['getElementById']('team-modal-title')['textContent']='Create\x20Team',document['getElementById']('team-name')['value']='',document['getElementById']('team-name')['disabled']=![],document['getElementById']('team-description')['value']='',document['getElementById']('team-description')['disabled']=![],document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=!![],document['getElementById']('save-team')['hidden']=![],document['getElementById']('team-modal-footer')['hidden']=![],document['getElementById']('team-modal')['hidden']=![],setTimeout(()=>document['getElementById']('team-name')['focus'](),0x64);}window['openTeamModal']=function(_0x970885){const _0x50d12b=state['teams']['find'](_0x3241f6=>_0x3241f6['id']===_0x970885);if(!_0x50d12b)return;state['editingTeamId']=_0x970885;const _0x42755e=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x546e1c=_0x42755e||_0x50d12b['canManageTeam'],_0x54e7d8=_0x42755e||_0x50d12b['canManageMembers'],_0xc1f167=_0x546e1c,_0x3f9db8=_0x546e1c||_0x54e7d8,_0x2ffeb7=_0x50d12b['name'],_0x2f94df=_0x50d12b['description']||'';state['modalSnapshot']={'name':_0x2ffeb7,'description':_0x2f94df},document['getElementById']('team-modal-title')['textContent']=_0x2ffeb7,document['getElementById']('team-name')['value']=_0x2ffeb7,document['getElementById']('team-name')['disabled']=!_0xc1f167,document['getElementById']('team-description')['value']=_0x2f94df,document['getElementById']('team-description')['disabled']=!_0xc1f167,document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=![],document['getElementById']('save-team')['hidden']=!_0xc1f167,renderMembersList(_0x50d12b),updateMemberSelect(_0x50d12b),document['getElementById']('team-modal')['hidden']=![];};function isTeamModalDirty(){if(!state['modalSnapshot'])return![];const _0x24e8ae=document['getElementById']('team-name')['value']['trim'](),_0x3e0cb9=document['getElementById']('team-description')['value']['trim']();return _0x24e8ae!==state['modalSnapshot']['name']||_0x3e0cb9!==state['modalSnapshot']['description'];}function requestHideTeamModal(){if(isTeamModalDirty()){if(!confirm('You\x20have\x20unsaved\x20changes.\x20Discard\x20them?'))return;}hideTeamModal();}function hideTeamModal(){document['getElementById']('team-modal')['hidden']=!![],document['getElementById']('team-name')['disabled']=![],document['getElementById']('team-description')['disabled']=![],state['editingTeamId']=null,state['modalSnapshot']=null;}window['openBindingsModal']=function(_0x4d652c){const _0x200c0d=state['teams']['find'](_0x1ab4ea=>_0x1ab4ea['id']===_0x4d652c);if(!_0x200c0d)return;state['bindingsTeamId']=_0x4d652c,document['getElementById']('bindings-modal-title')['textContent']='Access\x20Bindings\x20—\x20'+_0x200c0d['name'],document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('bindings-modal')['hidden']=![],loadTeamBindings(_0x4d652c);};function hideBindingsModal(){document['getElementById']('bindings-modal')['hidden']=!![],state['bindingsTeamId']=null;}function renderMembersList(_0x557667){const _0x136d12=Permissions['hasServerPermission'](state['currentUser'],'*'),_0xae321e=_0x136d12||_0x557667['canManageMembers']||_0x557667['canManageTeam'],_0x4ff7a5=_0x557667['members']||[],_0xcd8369=document['getElementById']('members-list');if(_0x4ff7a5['length']===0x0){_0xcd8369['innerHTML']='<p\x20style=\x22font-size:\x200.875rem;\x20color:\x20var(--color-text-secondary);\x20margin:\x200.25rem\x200;\x22>No\x20members\x20yet</p>';return;}_0xcd8369['innerHTML']=_0x4ff7a5['map'](_0x534059=>{const _0x5b91a5=state['users']['find'](_0x52e11c=>_0x52e11c['id']===_0x534059),_0x3d3a9d=_0x5b91a5?''+Utils['escapeHtml'](_0x5b91a5['username'])+(_0x5b91a5['name']?'\x20<span\x20style=\x22color:\x20var(--color-text-secondary);\x20font-size:\x200.85em;\x22>('+Utils['escapeHtml'](_0x5b91a5['name'])+')</span>':''):Utils['escapeHtml'](_0x534059);return'\x0a\x20\x20\x20\x20\x20\x20<div\x20style=\x22display:\x20flex;\x20align-items:\x20center;\x20justify-content:\x20space-between;\x20padding:\x200.35rem\x200;\x20border-bottom:\x201px\x20solid\x20var(--color-border);\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<span\x20style=\x22font-size:\x200.875rem;\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x3d3a9d+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0xae321e?'<button\x20type=\x22button\x22\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.removeMemberClick(\x27'+_0x534059+'\x27)\x22\x20style=\x22color:\x20var(--color-danger);\x20padding:\x200.15rem\x200.4rem;\x20font-size:\x200.8rem;\x22>Remove</button>':'')+'\x0a\x20\x20\x20\x20\x20\x20</div>';})['join']('');const _0x5b07d2=document['getElementById']('add-member-row');if(_0x5b07d2)_0x5b07d2['style']['display']=_0xae321e?'flex':'none';}function updateMemberSelect(_0x4142cc){const _0x3a6841=document['getElementById']('add-member-select');if(!_0x3a6841)return;const _0x43d141=new Set(_0x4142cc['members']||[]),_0x2f38a9=state['users']['filter'](_0x32b5ba=>!_0x43d141['has'](_0x32b5ba['id']));_0x3a6841['innerHTML']='<option\x20value=\x22\x22>Add\x20a\x20member…</option>'+_0x2f38a9['map'](_0x4c9f12=>'<option\x20value=\x22'+_0x4c9f12['id']+'\x22>'+Utils['escapeHtml'](_0x4c9f12['username'])+(_0x4c9f12['name']?'\x20('+Utils['escapeHtml'](_0x4c9f12['name'])+')':'')+'</option>')['join']('');}async function addMember(){const _0x40c715=document['getElementById']('add-member-select'),_0x28cae5=_0x40c715['value'];if(!_0x28cae5||!state['editingTeamId'])return;try{const {team:_0x3f5c8d}=await API['addTeamMember'](state['editingTeamId'],_0x28cae5);syncTeamInState(_0x3f5c8d),renderMembersList(_0x3f5c8d),updateMemberSelect(_0x3f5c8d),_0x40c715['value']='',Utils['showToast']('Member\x20added','success');}catch(_0x43ca65){Utils['showToast'](_0x43ca65['message'],'error');}}window['removeMemberClick']=async function(_0x179b4f){if(!state['editingTeamId'])return;try{const {team:_0x4aad07}=await API['removeTeamMember'](state['editingTeamId'],_0x179b4f);syncTeamInState(_0x4aad07),renderMembersList(_0x4aad07),updateMemberSelect(_0x4aad07),Utils['showToast']('Member\x20removed','success');}catch(_0x2598eb){Utils['showToast'](_0x2598eb['message'],'error');}};async function loadTeamBindings(_0x30332a){const _0x1b134d=document['getElementById']('bindings-loading'),_0x4e19f2=document['getElementById']('bindings-empty'),_0x558d8b=document['getElementById']('bindings-list-container'),_0x38b343=document['getElementById']('add-binding-btn');_0x1b134d['hidden']=![],_0x4e19f2['hidden']=!![],_0x558d8b['style']['display']='none',_0x38b343['hidden']=!![],document['getElementById']('add-binding-form')['hidden']=!![];try{const {bindings:_0x17eb8d}=await API['getBindings']({'subject_type':'team','subject_id':_0x30332a});state['teamBindings']=_0x17eb8d||[],_0x1b134d['hidden']=!![],state['teamBindings']['length']===0x0?_0x4e19f2['hidden']=![]:(_0x558d8b['style']['display']='',renderBindingsTable()),(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage'))&&(_0x38b343['hidden']=![]);}catch(_0x406d30){_0x1b134d['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x406d30['message'],'error');}}function renderBindingsTable(){const _0x4781d2=document['getElementById']('bindings-table-body');if(!_0x4781d2)return;const _0x3bc832=Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage');_0x4781d2['innerHTML']=state['teamBindings']['map'](_0x1a02e1=>{const _0x3cc8e8=_0x1a02e1['resource_type']==='server'?'Server':_0x1a02e1['resource_id']==='*'?'All\x20'+_0x1a02e1['resource_type']+'s':Utils['escapeHtml'](_0x1a02e1['resource_name']||_0x1a02e1['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x3cc8e8+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x1a02e1['role_name']||_0x1a02e1['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x3bc832?'<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteBindingClick(\x27'+_0x1a02e1['id']+'\x27)\x22\x20style=\x22color:\x20var(--color-danger);\x22>Remove</button>':'—')+'\x0a\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20</tr>';})['join']('');}function populateBindingForm(){const _0x39a09e=document['getElementById']('binding-resource-type');_0x39a09e['value']='environment',updateBindingFormForResourceType('environment');}function onBindingResourceTypeChange(){const _0x32feee=document['getElementById']('binding-resource-type')['value'];updateBindingFormForResourceType(_0x32feee);}function updateBindingFormForResourceType(_0x12e9e7){const _0x47ae42=document['getElementById']('binding-resource-container'),_0x41a7ff=document['getElementById']('binding-resource'),_0x335c80=document['getElementById']('binding-role');if(_0x12e9e7==='server')_0x47ae42['style']['display']='none';else{_0x47ae42['style']['display']='';if(_0x12e9e7==='environment'){const _0x359e3f=new Set(state['teamBindings']['filter'](_0x25e49f=>_0x25e49f['resource_type']==='environment')['map'](_0x934cd9=>_0x934cd9['resource_id'])),_0xab1fde=state['environments']['filter'](_0x4a53b6=>!_0x359e3f['has'](_0x4a53b6['name']));_0x41a7ff['innerHTML']=_0xab1fde['length']?_0xab1fde['map'](_0x49987a=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x49987a['name'])+'\x22>'+Utils['escapeHtml'](_0x49987a['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x12e9e7==='team'){const _0x24d878=new Set(state['teamBindings']['filter'](_0x2b9962=>_0x2b9962['resource_type']==='team')['map'](_0x6c77f8=>_0x6c77f8['resource_id'])),_0x52011a=state['teams']['filter'](_0x40faaf=>!_0x24d878['has'](_0x40faaf['id']));_0x41a7ff['innerHTML']=_0x52011a['length']?_0x52011a['map'](_0x429960=>'<option\x20value=\x22'+_0x429960['id']+'\x22>'+Utils['escapeHtml'](_0x429960['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x4a6f78=state['roles']['filter'](_0x169732=>_0x169732['resource_type']===_0x12e9e7);_0x335c80['innerHTML']=_0x4a6f78['length']?_0x4a6f78['filter'](_0x4d8647=>{const _0x20adeb=_0x12e9e7==='server'?undefined:_0x41a7ff['value'];return!state['teamBindings']['some'](_0x2e5f07=>_0x2e5f07['resource_type']===_0x12e9e7&&_0x2e5f07['role_id']===_0x4d8647['id']&&(_0x12e9e7==='server'||_0x2e5f07['resource_id']===_0x20adeb));})['map'](_0x4c3f07=>'<option\x20value=\x22'+_0x4c3f07['id']+'\x22>'+Utils['escapeHtml'](_0x4c3f07['name'])+'</option>')['join']('')||'<option\x20value=\x22\x22>No\x20available\x20roles</option>':'<option\x20value=\x22\x22>No\x20roles\x20for\x20this\x20resource\x20type</option>';}async function saveBinding(){const _0x5c136d=document['getElementById']('binding-resource-type')['value'],_0x5a8636=document['getElementById']('binding-role')['value'];if(!_0x5a8636||!state['bindingsTeamId'])return;const _0x171305=_0x5c136d==='server'?undefined:document['getElementById']('binding-resource')['value'];if(_0x5c136d!=='server'&&!_0x171305)return;const _0x90a7ca=document['getElementById']('save-binding-btn');_0x90a7ca['disabled']=!![],_0x90a7ca['textContent']='Adding…';try{const _0x516117={'subject_type':'team','subject_id':state['bindingsTeamId'],'role_id':_0x5a8636,'resource_type':_0x5c136d};if(_0x171305)_0x516117['resource_id']=_0x171305;await API['createBinding'](_0x516117),Utils['showToast']('Binding\x20added','success'),document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![],await loadTeamBindings(state['bindingsTeamId']);}catch(_0x462796){Utils['showToast'](_0x462796['message'],'error');}finally{_0x90a7ca['disabled']=![],_0x90a7ca['textContent']='Add\x20Binding';}}window['deleteBindingClick']=async function(_0x10d389){try{await API['deleteBinding'](_0x10d389),Utils['showToast']('Binding\x20removed','success'),await loadTeamBindings(state['bindingsTeamId']);}catch(_0x5d5542){Utils['showToast'](_0x5d5542['message'],'error');}};async function saveTeam(){const _0x5438fe=document['getElementById']('team-name')['value']['trim'](),_0x227113=document['getElementById']('team-description')['value']['trim'](),_0x4362d9=document['getElementById']('team-form-error'),_0x393ad8=document['getElementById']('save-team');if(!_0x5438fe){_0x4362d9['textContent']='Team\x20name\x20is\x20required',_0x4362d9['hidden']=![];return;}_0x4362d9['hidden']=!![];const _0x36ea37=_0x393ad8['textContent'];_0x393ad8['disabled']=!![],_0x393ad8['textContent']=state['editingTeamId']?'Saving…':'Creating…';try{if(state['editingTeamId']){const {team:_0x26dda2}=await API['updateTeam'](state['editingTeamId'],{'name':_0x5438fe,'description':_0x227113});syncTeamInState(_0x26dda2),document['getElementById']('team-modal-title')['textContent']=_0x26dda2['name'],Utils['showToast']('Team\x20updated','success');}else await API['createTeam']({'name':_0x5438fe,'description':_0x227113}),Utils['showToast']('Team\x20created','success');_0x393ad8['disabled']=![],_0x393ad8['textContent']=_0x36ea37,hideTeamModal(),await loadTeams();}catch(_0x51d6f2){_0x4362d9['textContent']=_0x51d6f2['message'],_0x4362d9['hidden']=![],_0x393ad8['disabled']=![],_0x393ad8['textContent']=_0x36ea37;}}window['deleteTeam']=function(_0xace9f8){const _0x2bcc9a=state['teams']['find'](_0x42f90e=>_0x42f90e['id']===_0xace9f8);if(!_0x2bcc9a)return;state['deletingTeamId']=_0xace9f8,document['getElementById']('delete-team-name')['textContent']=_0x2bcc9a['name'],document['getElementById']('delete-team-modal')['hidden']=![];};function hideDeleteModal(){document['getElementById']('delete-team-modal')['hidden']=!![],state['deletingTeamId']=null;}async function confirmDeleteTeam(){if(!state['deletingTeamId'])return;const _0x19365d=document['getElementById']('confirm-delete-team');_0x19365d['disabled']=!![],_0x19365d['textContent']='Deleting…';try{await API['deleteTeam'](state['deletingTeamId']),Utils['showToast']('Team\x20deleted','success'),_0x19365d['disabled']=![],_0x19365d['textContent']='Delete\x20Team',hideDeleteModal(),await loadTeams();}catch(_0x18a613){Utils['showToast']('Failed\x20to\x20delete\x20team:\x20'+_0x18a613['message'],'error'),_0x19365d['disabled']=![],_0x19365d['textContent']='Delete\x20Team';}}function syncTeamInState(_0x2dfc45){const _0x253f5b=state['teams']['findIndex'](_0x183dd4=>_0x183dd4['id']===_0x2dfc45['id']);if(_0x253f5b>=0x0)state['teams'][_0x253f5b]=_0x2dfc45;renderTeams();}
@@ -1 +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'](_0x1e2548=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':_0x1e2548}));});let commandSent=![],hasReceivedOutput=![];socket['addEventListener']('message',_0x1d535f=>{try{const _0x55b6bb=JSON['parse'](_0x1d535f['data']);if(_0x55b6bb['type']==='data'&&typeof _0x55b6bb['data']==='string')term['write'](_0x55b6bb['data']),!hasReceivedOutput&&_0x55b6bb['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(_0x55b6bb['type']==='status'&&_0x55b6bb['status']){if(_0x55b6bb['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'+_0x55b6bb['status'],_0x55b6bb['status']==='connected'?'success':'info');}else _0x55b6bb['type']==='error'&&_0x55b6bb['message']&&updateStatus(_0x55b6bb['message'],'error');}}catch(_0x2cf499){console['error']('Failed\x20to\x20parse\x20terminal\x20message',_0x2cf499);}}),socket['addEventListener']('close',_0x29eec4=>{const _0x28bc9b=_0x29eec4['reason']||'Connection\x20closed';updateStatus(_0x28bc9b,_0x29eec4['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',_0x189304=>{console['error']('Terminal\x20websocket\x20error',_0x189304),updateStatus('Connection\x20error','error');});function sendResize(){if(socket['readyState']!==WebSocket['OPEN'])return;const _0x573168=term['cols'],_0x41a49f=term['rows'];socket['send'](JSON['stringify']({'type':'resize','cols':_0x573168,'rows':_0x41a49f}));}function updateStatus(_0x13bd4b,_0x2e507e='info'){if(!statusEl)return;statusEl['textContent']=_0x13bd4b,statusEl['dataset']['variant']=_0x2e507e;}async function enrichContainerDetails(_0x679381){try{const _0xb2c8fd=await API['getContainer'](_0x679381);updateTerminalDetails(_0xb2c8fd);}catch{try{const _0x55b339=await API['getContainers'](),_0x22ecd7=(_0x55b339['containers']||[])['find'](_0xf21691=>_0xf21691['containerId']===_0x679381||_0xf21691['name']===_0x679381||_0xf21691['fullContainerId']?.['startsWith'](_0x679381));if(_0x22ecd7){updateTerminalDetails(_0x22ecd7);return;}subtitleEl['textContent']='Container\x20'+_0x679381['substring'](0x0,0xc);}catch{subtitleEl['textContent']='Container\x20'+_0x679381['substring'](0x0,0xc);}}}function updateTerminalDetails(_0x28cf36){const _0x4df213=_0x28cf36['containerId']||_0x28cf36['name']||_0x28cf36['fullContainerId']||containerId,_0x247148=_0x28cf36['environment']?'Environment\x20'+_0x28cf36['environment']:'Environment\x20unknown',_0x19e36b=_0x28cf36['defaultAgent']?'\x20·\x20Agent\x20'+_0x28cf36['defaultAgent']:'',_0x364dad=_0x28cf36['createdAt']?'\x20·\x20Started\x20'+Utils['formatRelativeTime'](_0x28cf36['createdAt']):'';titleEl['textContent']='Terminal\x20·\x20'+_0x4df213['substring'](0x0,0xc);const _0x274af0=command?'\x20·\x20Command\x20'+command:'';subtitleEl['textContent']=''+_0x247148+_0x19e36b+_0x364dad+_0x274af0;}
1
+ import{API,Utils}from'./app.js';import{Terminal}from'/vendor/xterm/5.3.0/xterm.esm.js';import{FitAddon}from'/vendor/xterm-addon-fit/0.7.0/xterm-addon-fit.esm.js';import{getCurrentTheme,initTheme,mountThemeToggle,onThemeChange}from'./theme.js';const params=Utils['getQueryParams'](),containerId=params['container'],command=(params['cmd']||'')['trim'](),useServerExec=params['server_exec']==='true',isEmbedded=params['embedded']==='true',terminalTabId=params['tabId']||'',titleEl=document['getElementById']('terminal-title'),subtitleEl=document['getElementById']('terminal-subtitle'),statusEl=document['getElementById']('terminal-status'),terminalEl=document['getElementById']('terminal-container'),closeBtn=document['getElementById']('close-terminal');initTheme();isEmbedded?(document['documentElement']['classList']['add']('terminal-embedded'),document['body']['classList']['add']('terminal-embedded')):mountThemeToggle({'targetSelectors':['.terminal-actions']});const getXtermTheme=()=>{return{'background':'#0f172a','foreground':'#e2e8f0','cursor':'#e2e8f0','cursorAccent':'#0f172a'};};closeBtn&&closeBtn['addEventListener']('click',()=>{if(isEmbedded&&window['parent']&&window['parent']!==window){window['parent']['postMessage']({'type':'coderflow-terminal-close','tabId':terminalTabId},window['location']['origin']);return;}window['close']();});if(!containerId){updateStatus('Missing\x20container\x20identifier','error');throw new Error('container\x20parameter\x20is\x20required');}document['title']='Terminal\x20·\x20'+containerId['slice'](0x0,0xc),enrichContainerDetails(containerId)['catch'](()=>{subtitleEl['textContent']='Container\x20'+containerId['substring'](0x0,0xc);});const term=new Terminal({'convertEol':!![],'cursorBlink':!![],'fontFamily':'JetBrains\x20Mono,\x20SFMono-Regular,\x20Consolas,\x20monospace','fontSize':0x10,'theme':getXtermTheme()}),fitAddon=new FitAddon();term['loadAddon'](fitAddon),term['open'](terminalEl),term['focus']();let isFitting=![];const doFit=()=>{if(isFitting)return;isFitting=!![],fitAddon['fit'](),sendResize(),term['scrollToBottom'](),setTimeout(()=>{isFitting=![];},0x32);};window['addEventListener']('resize',()=>{requestAnimationFrame(()=>{!isFitting&&doFit();});});const resizeObserver=new ResizeObserver(()=>{requestAnimationFrame(()=>{!isFitting&&doFit();});});resizeObserver['observe'](terminalEl);const socketProtocol=window['location']['protocol']==='https:'?'wss':'ws',socketUrl=new URL('/ws/containers/'+encodeURIComponent(containerId),window['location']['href']);command&&useServerExec&&socketUrl['searchParams']['set']('cmd',command);socketUrl['protocol']=socketProtocol+':';const socket=new WebSocket(socketUrl['toString']());term['onData'](_0x353242=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':_0x353242}));});let commandSent=![],hasReceivedOutput=![];socket['addEventListener']('message',_0x50fe86=>{try{const _0x58cec9=JSON['parse'](_0x50fe86['data']);if(_0x58cec9['type']==='data'&&typeof _0x58cec9['data']==='string')term['write'](_0x58cec9['data']),!hasReceivedOutput&&_0x58cec9['data']['length']>0x0&&(hasReceivedOutput=!![],command&&!useServerExec&&!commandSent&&(commandSent=!![],setTimeout(()=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':command+'\x0d'}));},0xc8)));else{if(_0x58cec9['type']==='status'&&_0x58cec9['status']){if(_0x58cec9['status']==='connected'){if(command&&useServerExec)updateStatus('Running:\x20'+command,'info');else command?updateStatus('Preparing:\x20'+command,'info'):updateStatus('Terminal\x20connected','success');doFit(),term['focus'](),command&&!useServerExec&&!commandSent&&setTimeout(()=>{!commandSent&&socket['readyState']===WebSocket['OPEN']&&(commandSent=!![],socket['send'](JSON['stringify']({'type':'data','data':command+'\x0d'})),updateStatus('Running:\x20'+command,'info'));},0x7d0);}else updateStatus('Session\x20'+_0x58cec9['status'],_0x58cec9['status']==='connected'?'success':'info');}else _0x58cec9['type']==='error'&&_0x58cec9['message']&&updateStatus(_0x58cec9['message'],'error');}}catch(_0x23c6ee){console['error']('Failed\x20to\x20parse\x20terminal\x20message',_0x23c6ee);}}),socket['addEventListener']('close',_0x5bdd42=>{const _0x26e745=_0x5bdd42['reason']||'Connection\x20closed';updateStatus(_0x26e745,_0x5bdd42['wasClean']?'info':'error'),isEmbedded&&terminalTabId&&window['parent']&&window['parent']!==window&&window['parent']['postMessage']({'type':'coderflow-terminal-disconnected','tabId':terminalTabId},window['location']['origin']);}),socket['addEventListener']('error',_0x4664bb=>{console['error']('Terminal\x20websocket\x20error',_0x4664bb),updateStatus('Connection\x20error','error');});function sendResize(){if(socket['readyState']!==WebSocket['OPEN'])return;const _0xfe15fb=term['cols'],_0x5958eb=term['rows'];socket['send'](JSON['stringify']({'type':'resize','cols':_0xfe15fb,'rows':_0x5958eb}));}function updateStatus(_0xccd499,_0x4bbb93='info'){if(!statusEl)return;statusEl['textContent']=_0xccd499,statusEl['dataset']['variant']=_0x4bbb93;}async function enrichContainerDetails(_0x2c1fbe){try{const _0x430025=await API['getContainer'](_0x2c1fbe);updateTerminalDetails(_0x430025);}catch{try{const _0x128b86=await API['getContainers'](),_0x5a2a9e=(_0x128b86['containers']||[])['find'](_0x10c9db=>_0x10c9db['containerId']===_0x2c1fbe||_0x10c9db['name']===_0x2c1fbe||_0x10c9db['fullContainerId']?.['startsWith'](_0x2c1fbe));if(_0x5a2a9e){updateTerminalDetails(_0x5a2a9e);return;}subtitleEl['textContent']='Container\x20'+_0x2c1fbe['substring'](0x0,0xc);}catch{subtitleEl['textContent']='Container\x20'+_0x2c1fbe['substring'](0x0,0xc);}}}function updateTerminalDetails(_0x3ac442){const _0x1ef1e4=_0x3ac442['containerId']||_0x3ac442['name']||_0x3ac442['fullContainerId']||containerId,_0x16cbee=_0x3ac442['environment']?'Environment\x20'+_0x3ac442['environment']:'Environment\x20unknown',_0xd8a5c7=_0x3ac442['defaultAgent']?'\x20·\x20Agent\x20'+_0x3ac442['defaultAgent']:'',_0x4d6f7e=_0x3ac442['createdAt']?'\x20·\x20Started\x20'+Utils['formatRelativeTime'](_0x3ac442['createdAt']):'';titleEl['textContent']='Terminal\x20·\x20'+_0x1ef1e4['substring'](0x0,0xc);const _0x43cce4=command?'\x20·\x20Command\x20'+command:'';subtitleEl['textContent']=''+_0x16cbee+_0xd8a5c7+_0x4d6f7e+_0x43cce4;}
@@ -1 +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 _0x57b9c6=localStorage['getItem'](THEME_STORAGE_KEY);if(_0x57b9c6&&VALID_THEMES['has'](_0x57b9c6))return _0x57b9c6;}catch(_0x4ce70d){console['warn']('[Theme]\x20Failed\x20to\x20read\x20stored\x20theme\x20preference:',_0x4ce70d);}return null;}export function getPreferredTheme(){const _0x5f1fd4=readStoredTheme();if(_0x5f1fd4)return _0x5f1fd4;const _0x485ce6=window['matchMedia']&&window['matchMedia']('(prefers-color-scheme:\x20dark)')['matches'];return _0x485ce6?'dark':'light';}export function getCurrentTheme(){const _0x1bf9bc=document['documentElement']['dataset']['theme'];if(_0x1bf9bc&&VALID_THEMES['has'](_0x1bf9bc))return _0x1bf9bc;return getPreferredTheme();}export function applyTheme(_0x38d347,{persist:persist=!![],emitEvent:emitEvent=!![]}={}){const _0x36fb02=VALID_THEMES['has'](_0x38d347)?_0x38d347:'light';document['documentElement']['dataset']['theme']=_0x36fb02,document['documentElement']['style']['colorScheme']=_0x36fb02==='dark'?'dark':'light';if(persist)try{localStorage['setItem'](THEME_STORAGE_KEY,_0x36fb02);}catch(_0x2819d1){console['warn']('[Theme]\x20Failed\x20to\x20persist\x20theme\x20preference:',_0x2819d1);}return emitEvent&&window['dispatchEvent'](new CustomEvent(THEME_CHANGE_EVENT,{'detail':{'theme':_0x36fb02}})),_0x36fb02;}export function initTheme(_0x15cfe1={}){const {emitEvent:emitEvent=![]}=_0x15cfe1;return applyTheme(getPreferredTheme(),{'persist':![],'emitEvent':emitEvent});}export function toggleTheme(){const _0x7eab8=getCurrentTheme()==='dark'?'light':'dark';return applyTheme(_0x7eab8);}export function onThemeChange(_0x4337d8,{runImmediately:runImmediately=![]}={}){const _0x2cb04b=_0x52c23d=>{_0x4337d8(_0x52c23d['detail']['theme']);};return window['addEventListener'](THEME_CHANGE_EVENT,_0x2cb04b),runImmediately&&_0x4337d8(getCurrentTheme()),()=>window['removeEventListener'](THEME_CHANGE_EVENT,_0x2cb04b);}export function mountThemeToggle(_0x2b214a={}){const {targetSelectors:targetSelectors=DEFAULT_TARGET_SELECTORS}=_0x2b214a,_0x361f33=targetSelectors['map'](_0xb5f737=>document['querySelector'](_0xb5f737))['find'](Boolean),_0xb21a12=document['createElement']('button');_0xb21a12['type']='button',_0xb21a12['className']='btn-ghost\x20theme-toggle-btn',_0xb21a12['id']='theme-toggle-btn',_0xb21a12['setAttribute']('aria-pressed','false'),_0xb21a12['style']['padding']='8px',_0xb21a12['style']['lineHeight']='0',_0xb21a12['style']['width']='36px',_0xb21a12['style']['height']='36px',_0xb21a12['style']['display']='flex',_0xb21a12['style']['alignItems']='center',_0xb21a12['style']['justifyContent']='center';const _0x5c14a2=document['createElement']('span');_0x5c14a2['className']='theme-icon',_0x5c14a2['style']['display']='flex',_0xb21a12['append'](_0x5c14a2);const _0x5b5d96='<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>',_0x2630ad='<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>',_0x20f5c7=_0x5b8e47=>{const _0x173da0=_0x5b8e47==='dark';_0x5c14a2['innerHTML']=_0x173da0?_0x5b5d96:_0x2630ad,_0xb21a12['title']=_0x173da0?'Switch\x20to\x20light\x20mode':'Switch\x20to\x20dark\x20mode',_0xb21a12['dataset']['theme']=_0x5b8e47,_0xb21a12['setAttribute']('aria-pressed',String(_0x173da0));};return _0xb21a12['addEventListener']('click',()=>{const _0x149546=getCurrentTheme()==='dark'?'light':'dark';applyTheme(_0x149546);}),_0x361f33?_0x361f33['appendChild'](_0xb21a12):(_0xb21a12['classList']['add']('theme-toggle-floating'),document['body']['appendChild'](_0xb21a12)),_0x20f5c7(initTheme()),onThemeChange(_0x20f5c7),_0xb21a12;}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 _0x1913f1=localStorage['getItem'](THEME_STORAGE_KEY);if(_0x1913f1&&VALID_THEMES['has'](_0x1913f1))return _0x1913f1;}catch(_0x104d7a){console['warn']('[Theme]\x20Failed\x20to\x20read\x20stored\x20theme\x20preference:',_0x104d7a);}return null;}export function getPreferredTheme(){const _0x3f8717=readStoredTheme();if(_0x3f8717)return _0x3f8717;const _0x3e1eba=window['matchMedia']&&window['matchMedia']('(prefers-color-scheme:\x20dark)')['matches'];return _0x3e1eba?'dark':'light';}export function getCurrentTheme(){const _0x39ce3e=document['documentElement']['dataset']['theme'];if(_0x39ce3e&&VALID_THEMES['has'](_0x39ce3e))return _0x39ce3e;return getPreferredTheme();}export function applyTheme(_0x3ef976,{persist:persist=!![],emitEvent:emitEvent=!![]}={}){const _0x502b8c=VALID_THEMES['has'](_0x3ef976)?_0x3ef976:'light';document['documentElement']['dataset']['theme']=_0x502b8c,document['documentElement']['style']['colorScheme']=_0x502b8c==='dark'?'dark':'light';if(persist)try{localStorage['setItem'](THEME_STORAGE_KEY,_0x502b8c);}catch(_0x15fd38){console['warn']('[Theme]\x20Failed\x20to\x20persist\x20theme\x20preference:',_0x15fd38);}return emitEvent&&window['dispatchEvent'](new CustomEvent(THEME_CHANGE_EVENT,{'detail':{'theme':_0x502b8c}})),_0x502b8c;}export function initTheme(_0xeec41f={}){const {emitEvent:emitEvent=![]}=_0xeec41f;return applyTheme(getPreferredTheme(),{'persist':![],'emitEvent':emitEvent});}export function toggleTheme(){const _0x494042=getCurrentTheme()==='dark'?'light':'dark';return applyTheme(_0x494042);}export function onThemeChange(_0x42b97d,{runImmediately:runImmediately=![]}={}){const _0x37e286=_0x1a4331=>{_0x42b97d(_0x1a4331['detail']['theme']);};return window['addEventListener'](THEME_CHANGE_EVENT,_0x37e286),runImmediately&&_0x42b97d(getCurrentTheme()),()=>window['removeEventListener'](THEME_CHANGE_EVENT,_0x37e286);}export function mountThemeToggle(_0xa6b12a={}){const {targetSelectors:targetSelectors=DEFAULT_TARGET_SELECTORS}=_0xa6b12a,_0x4b0855=targetSelectors['map'](_0x1e698c=>document['querySelector'](_0x1e698c))['find'](Boolean),_0x209e8e=document['createElement']('button');_0x209e8e['type']='button',_0x209e8e['className']='btn-ghost\x20theme-toggle-btn',_0x209e8e['id']='theme-toggle-btn',_0x209e8e['setAttribute']('aria-pressed','false'),_0x209e8e['style']['padding']='8px',_0x209e8e['style']['lineHeight']='0',_0x209e8e['style']['width']='36px',_0x209e8e['style']['height']='36px',_0x209e8e['style']['display']='flex',_0x209e8e['style']['alignItems']='center',_0x209e8e['style']['justifyContent']='center';const _0x1f04cf=document['createElement']('span');_0x1f04cf['className']='theme-icon',_0x1f04cf['style']['display']='flex',_0x209e8e['append'](_0x1f04cf);const _0x3427d8='<svg\x20xmlns=\x22http://www.w3.org/2000/svg\x22\x20width=\x2220\x22\x20height=\x2220\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22><path\x20d=\x22M21\x2012.79A9\x209\x200\x201\x201\x2011.21\x203\x207\x207\x200\x200\x200\x2021\x2012.79z\x22></path></svg>',_0x399af5='<svg\x20xmlns=\x22http://www.w3.org/2000/svg\x22\x20width=\x2220\x22\x20height=\x2220\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22><circle\x20cx=\x2212\x22\x20cy=\x2212\x22\x20r=\x225\x22></circle><line\x20x1=\x2212\x22\x20y1=\x221\x22\x20x2=\x2212\x22\x20y2=\x223\x22></line><line\x20x1=\x2212\x22\x20y1=\x2221\x22\x20x2=\x2212\x22\x20y2=\x2223\x22></line><line\x20x1=\x224.22\x22\x20y1=\x224.22\x22\x20x2=\x225.64\x22\x20y2=\x225.64\x22></line><line\x20x1=\x2218.36\x22\x20y1=\x2218.36\x22\x20x2=\x2219.78\x22\x20y2=\x2219.78\x22></line><line\x20x1=\x221\x22\x20y1=\x2212\x22\x20x2=\x223\x22\x20y2=\x2212\x22></line><line\x20x1=\x2221\x22\x20y1=\x2212\x22\x20x2=\x2223\x22\x20y2=\x2212\x22></line><line\x20x1=\x224.22\x22\x20y1=\x2219.78\x22\x20x2=\x225.64\x22\x20y2=\x2218.36\x22></line><line\x20x1=\x2218.36\x22\x20y1=\x225.64\x22\x20x2=\x2219.78\x22\x20y2=\x224.22\x22></line></svg>',_0x4bb4f4=_0x1be9f4=>{const _0x587bc6=_0x1be9f4==='dark';_0x1f04cf['innerHTML']=_0x587bc6?_0x3427d8:_0x399af5,_0x209e8e['title']=_0x587bc6?'Switch\x20to\x20light\x20mode':'Switch\x20to\x20dark\x20mode',_0x209e8e['dataset']['theme']=_0x1be9f4,_0x209e8e['setAttribute']('aria-pressed',String(_0x587bc6));};return _0x209e8e['addEventListener']('click',()=>{const _0x108c0d=getCurrentTheme()==='dark'?'light':'dark';applyTheme(_0x108c0d);}),_0x4b0855?_0x4b0855['appendChild'](_0x209e8e):(_0x209e8e['classList']['add']('theme-toggle-floating'),document['body']['appendChild'](_0x209e8e)),_0x4bb4f4(initTheme()),onThemeChange(_0x4bb4f4),_0x209e8e;}export{THEME_STORAGE_KEY,THEME_CHANGE_EVENT};
@@ -1 +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 _0x613256=await API['getCurrentUser']();state['currentUser']=_0x613256;if(!Permissions['hasServerPermission'](_0x613256,'*')&&!Permissions['hasServerPermission'](_0x613256,'users:create')){Utils['showToast']('Access\x20denied:\x20Server\x20admin\x20privileges\x20required','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}}catch(_0x192e5b){window['location']['href']='login.html';}}async function checkEmailConfig(){try{const _0x31b73c=await API['getEmailConfig']();state['emailConfigured']=_0x31b73c['configured'];}catch(_0x33db98){console['error']('Failed\x20to\x20check\x20email\x20config',_0x33db98),state['emailConfigured']=![];}}async function loadRoles(){try{const {roles:_0x41566c}=await API['getRoleDefinitions']();state['roles']=_0x41566c||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x2284f0=await API['getEnvironments']();state['environments']=_0x2284f0['environments']||[];}catch{state['environments']=[];}}async function loadTeams(){try{const {teams:_0x367f05}=await API['getTeams']();state['teams']=_0x367f05||[];}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 _0x3d8a2e=document['getElementById']('users-loading'),_0x2c68aa=document['getElementById']('users-error'),_0x5669ac=document['getElementById']('users-content');try{_0x3d8a2e['hidden']=![],_0x2c68aa['hidden']=!![],_0x5669ac['hidden']=!![];const _0x454124=await API['getUsers']();state['users']=_0x454124['users']||[],renderUsers(),_0x3d8a2e['hidden']=!![],_0x5669ac['hidden']=![];}catch(_0x207180){console['error']('Failed\x20to\x20load\x20users',_0x207180),_0x3d8a2e['hidden']=!![],_0x2c68aa['hidden']=![],document['getElementById']('users-error-message')['textContent']=_0x207180['message'];}}function renderUsers(){const _0x54aa6f=document['getElementById']('users-table-body'),_0x11f089=document['getElementById']('user-count');if(!_0x54aa6f)return;_0x11f089&&(_0x11f089['textContent']=state['users']['length']+'\x20user'+(state['users']['length']===0x1?'':'s'));const _0x27dfb2=[...state['users']]['sort']((_0x5eeb30,_0x12c758)=>{const _0x8d028f=new Date(_0x5eeb30['created_at'])['getTime'](),_0x3ad3d5=new Date(_0x12c758['created_at'])['getTime']();return _0x3ad3d5-_0x8d028f;});_0x54aa6f['innerHTML']=_0x27dfb2['map'](_0x3881ce=>'\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'](_0x3881ce['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'](_0x3881ce['name'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x3881ce['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'+(_0x3881ce['isServerAdmin']?'<span\x20class=\x22role-badge\x20role-admin\x22>Server\x20Admin</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x3881ce['hasUserBinding']?'<span\x20class=\x22role-badge\x20role-user-binding\x22>User\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x3881ce['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'](_0x3881ce['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'+_0x3881ce['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'+_0x3881ce['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'+_0x3881ce['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'+_0x3881ce['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(_0x21e62a){const _0x28ba57=state['users']['find'](_0x57d734=>_0x57d734['id']===_0x21e62a);if(!_0x28ba57)return;state['bindingsUserId']=_0x21e62a,state['bindingsDirty']=![];const _0x3e9aa7=document['getElementById']('bindings-modal'),_0x12f9b0=document['getElementById']('bindings-modal-title');_0x12f9b0['textContent']='Access\x20Bindings\x20—\x20'+_0x28ba57['name'],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],_0x3e9aa7['hidden']=![],loadUserBindings(_0x21e62a);};function hasUnsavedBindingChanges(){const _0x31e849=document['getElementById']('add-user-binding-form');return _0x31e849&&!_0x31e849['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 _0x7ccc00=document['getElementById']('bindings-modal');_0x7ccc00['hidden']=!![];const _0x2ea47=state['bindingsDirty'];state['bindingsUserId']=null,state['userBindings']=[],state['bindingsDirty']=![],_0x2ea47&&await loadUsers();}async function loadUserBindings(_0x51dbe4){const _0x9119fc=document['getElementById']('user-bindings-loading'),_0x3d332d=document['getElementById']('user-bindings-empty'),_0x268e3c=document['getElementById']('user-bindings-list-container'),_0x5ab7fc=document['getElementById']('add-user-binding-btn'),_0x46d580=document['getElementById']('user-team-bindings-note'),_0x32a131=document['getElementById']('user-team-bindings-text');_0x9119fc['hidden']=![],_0x3d332d['hidden']=!![],_0x268e3c['style']['display']='none',_0x5ab7fc['hidden']=!![],_0x46d580['hidden']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![];try{const [_0x403084,_0x189af9]=await Promise['all']([API['getBindings']({'subject_type':'user','subject_id':_0x51dbe4}),API['getTeams']()]);state['userBindings']=_0x403084['bindings']||[];const _0x7751cd=(_0x189af9['teams']||[])['filter'](_0x2a15f6=>(_0x2a15f6['members']||[])['includes'](_0x51dbe4)),_0x48d367=[];if(_0x7751cd['length']>0x0){const _0x2d9b9f=await Promise['all'](_0x7751cd['map'](_0x5da131=>API['getBindings']({'subject_type':'team','subject_id':_0x5da131['id']})));for(let _0x15f4e4=0x0;_0x15f4e4<_0x7751cd['length'];_0x15f4e4++){const _0x335c2b=_0x2d9b9f[_0x15f4e4]['bindings']||[];_0x335c2b['length']>0x0&&_0x48d367['push'](_0x7751cd[_0x15f4e4]);}}_0x9119fc['hidden']=!![];state['userBindings']['length']===0x0?_0x3d332d['hidden']=![]:(_0x268e3c['style']['display']='',renderUserBindingsTable());if(_0x48d367['length']>0x0){const _0xa7cedd=_0x48d367['map'](_0x323bcc=>_0x323bcc['name']),_0x251aa5=_0xa7cedd['length']<=0x3?_0xa7cedd['join'](',\x20'):_0xa7cedd['slice'](0x0,0x3)['join'](',\x20')+(',\x20and\x20'+(_0xa7cedd['length']-0x3)+'\x20more');_0x32a131['textContent']='This\x20user\x20also\x20has\x20access\x20via\x20team\x20memberships\x20('+_0x251aa5+').';}else _0x32a131['textContent']='This\x20user\x20has\x20no\x20access\x20via\x20team\x20memberships.';_0x46d580['hidden']=![],_0x5ab7fc['hidden']=![];}catch(_0x2b08e9){_0x9119fc['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x2b08e9['message'],'error');}}function renderUserBindingsTable(){const _0x5b48c8=document['getElementById']('user-bindings-table-body');if(!_0x5b48c8)return;_0x5b48c8['innerHTML']=state['userBindings']['map'](_0x35cb4e=>{const _0x2a565b=_0x35cb4e['resource_type']==='server'?'Server':_0x35cb4e['resource_id']==='*'?'All\x20'+_0x35cb4e['resource_type']+'s':Utils['escapeHtml'](_0x35cb4e['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x2a565b+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x35cb4e['role_name']||_0x35cb4e['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'+_0x35cb4e['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 _0x2c02dc=document['getElementById']('user-binding-resource-type');_0x2c02dc['value']='environment',updateUserBindingFormForResourceType('environment');}function onUserBindingResourceTypeChange(){const _0x178aee=document['getElementById']('user-binding-resource-type')['value'];updateUserBindingFormForResourceType(_0x178aee);}function updateUserBindingFormForResourceType(_0x9f8e9f){const _0x4f03e3=document['getElementById']('user-binding-resource-container'),_0x5ce406=document['getElementById']('user-binding-resource'),_0x4c8104=document['getElementById']('user-binding-role');if(_0x9f8e9f==='server')_0x4f03e3['style']['display']='none';else{_0x4f03e3['style']['display']='';if(_0x9f8e9f==='environment'){const _0x1f0552=new Set(state['userBindings']['filter'](_0x41b283=>_0x41b283['resource_type']==='environment')['map'](_0x58dd0c=>_0x58dd0c['resource_id'])),_0x143a9a=state['environments']['filter'](_0xc1cfe4=>!_0x1f0552['has'](_0xc1cfe4['name']));_0x5ce406['innerHTML']=_0x143a9a['length']?_0x143a9a['map'](_0x3e98a7=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x3e98a7['name'])+'\x22>'+Utils['escapeHtml'](_0x3e98a7['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x9f8e9f==='team'){const _0x1c9c5e=new Set(state['userBindings']['filter'](_0x122953=>_0x122953['resource_type']==='team')['map'](_0x1ac330=>_0x1ac330['resource_id'])),_0x498d44=state['teams']['filter'](_0x4e315c=>!_0x1c9c5e['has'](_0x4e315c['id']));_0x5ce406['innerHTML']=_0x498d44['length']?_0x498d44['map'](_0x5eb788=>'<option\x20value=\x22'+_0x5eb788['id']+'\x22>'+Utils['escapeHtml'](_0x5eb788['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x452991=state['roles']['filter'](_0x1adf24=>_0x1adf24['resource_type']===_0x9f8e9f);_0x4c8104['innerHTML']=_0x452991['length']?_0x452991['filter'](_0x3a09d7=>{const _0x16e7f0=_0x9f8e9f==='server'?undefined:_0x5ce406['value'];return!state['userBindings']['some'](_0x524c3d=>_0x524c3d['resource_type']===_0x9f8e9f&&_0x524c3d['role_id']===_0x3a09d7['id']&&(_0x9f8e9f==='server'||_0x524c3d['resource_id']===_0x16e7f0));})['map'](_0x234e5e=>'<option\x20value=\x22'+_0x234e5e['id']+'\x22>'+Utils['escapeHtml'](_0x234e5e['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 _0x189a06=document['getElementById']('user-binding-resource-type')['value'],_0x52a90d=document['getElementById']('user-binding-role')['value'];if(!_0x52a90d||!state['bindingsUserId'])return;const _0x1a1406=_0x189a06==='server'?undefined:document['getElementById']('user-binding-resource')['value'];if(_0x189a06!=='server'&&!_0x1a1406)return;const _0x4ec109=document['getElementById']('save-user-binding-btn');_0x4ec109['disabled']=!![],_0x4ec109['textContent']='Adding…';try{const _0x26b301={'subject_type':'user','subject_id':state['bindingsUserId'],'role_id':_0x52a90d,'resource_type':_0x189a06};if(_0x1a1406)_0x26b301['resource_id']=_0x1a1406;await API['createBinding'](_0x26b301),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(_0x3a3017){Utils['showToast'](_0x3a3017['message'],'error');}finally{_0x4ec109['disabled']=![],_0x4ec109['textContent']='Add\x20Binding';}}window['deleteUserBindingClick']=async function(_0x591a0d){try{await API['deleteBinding'](_0x591a0d),Utils['showToast']('Binding\x20removed','success'),state['bindingsDirty']=!![],await loadUserBindings(state['bindingsUserId']);}catch(_0x5d293b){Utils['showToast'](_0x5d293b['message'],'error');}};function showCreateUserModal(){state['editingUserId']=null;const _0x3ed8d9=document['getElementById']('user-modal'),_0x885f10=document['getElementById']('modal-title'),_0x48fd5a=document['getElementById']('user-password'),_0x3f8eb1=document['getElementById']('password-required'),_0x42f79f=document['getElementById']('password-hint'),_0x403e3c=document['getElementById']('skip-password-container'),_0xad9724=document['getElementById']('skip-password');_0x885f10['textContent']='Create\x20User',document['getElementById']('user-form')['reset'](),_0x48fd5a['required']=!![];if(_0x3f8eb1)_0x3f8eb1['textContent']='*';_0x403e3c&&(_0x403e3c['style']['display']='block',_0xad9724['checked']=![]),_0x42f79f&&(_0x42f79f['textContent']='Minimum\x208\x20characters'),_0x3ed8d9['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);}window['editUser']=function(_0x365166){const _0x362c1f=state['users']['find'](_0x277341=>_0x277341['id']===_0x365166);if(!_0x362c1f)return;state['editingUserId']=_0x365166;const _0x2ce4e9=document['getElementById']('user-modal'),_0x122295=document['getElementById']('modal-title'),_0x242fde=document['getElementById']('user-password'),_0x3aa22f=document['getElementById']('password-required'),_0x331241=document['getElementById']('password-hint'),_0x3bb1cf=document['getElementById']('skip-password-container');_0x122295['textContent']='Edit\x20User',document['getElementById']('user-username')['value']=_0x362c1f['username'],document['getElementById']('user-name')['value']=_0x362c1f['name'],document['getElementById']('user-email')['value']=_0x362c1f['email'],_0x242fde['value']='',_0x242fde['required']=![];if(_0x3aa22f)_0x3aa22f['textContent']='';_0x3bb1cf&&(_0x3bb1cf['style']['display']='none'),_0x331241&&(_0x331241['textContent']='Leave\x20blank\x20to\x20keep\x20current\x20password'),_0x2ce4e9['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);};function hideUserModal(){const _0x3153ee=document['getElementById']('user-modal'),_0x4b38d2=document['getElementById']('form-error'),_0x55fd26=document['getElementById']('save-user');_0x3153ee['hidden']=!![],_0x4b38d2['hidden']=!![],state['editingUserId']=null,_0x55fd26&&(_0x55fd26['disabled']=![],_0x55fd26['textContent']='Save\x20User');}async function saveUser(){const _0x501a35=document['getElementById']('user-form'),_0x8f0753=document['getElementById']('skip-password')?.['checked']||![];if(!_0x8f0753&&!_0x501a35['checkValidity']()){_0x501a35['reportValidity']();return;}const _0x20b735=document['getElementById']('form-error'),_0x382c80=document['getElementById']('save-user'),_0x51a8b1=document['getElementById']('user-username')['value']['trim'](),_0x345a7b=document['getElementById']('user-name')['value']['trim'](),_0x36a610=document['getElementById']('user-email')['value']['trim'](),_0x45e553=document['getElementById']('user-password')['value'];if(!_0x51a8b1||!_0x345a7b||!_0x36a610){_0x20b735['textContent']='Please\x20fill\x20in\x20all\x20required\x20fields',_0x20b735['hidden']=![],_0x20b735['scrollIntoView']({'behavior':'smooth','block':'nearest'});return;}_0x20b735['hidden']=!![];const _0x28e6dd=_0x382c80['textContent'];_0x382c80['disabled']=!![],_0x382c80['textContent']=state['editingUserId']?'Updating...':'Creating...';try{if(state['editingUserId']){const _0x573efd={'username':_0x51a8b1,'name':_0x345a7b,'email':_0x36a610};_0x45e553&&(_0x573efd['password']=_0x45e553),await API['updateUser'](state['editingUserId'],_0x573efd),Utils['showToast']('User\x20updated\x20successfully','success'),await loadUsers(),hideUserModal();}else{const _0x3b9a57={'username':_0x51a8b1,'name':_0x345a7b,'email':_0x36a610};if(!_0x8f0753){if(!_0x45e553)throw new Error('Password\x20is\x20required\x20for\x20new\x20users');_0x3b9a57['password']=_0x45e553;}const _0x5a98bd=await API['createUser'](_0x3b9a57),_0x10a220=_0x5a98bd['user'];if(_0x8f0753||!_0x45e553){const _0x4afb88=await API['createPasswordToken'](_0x10a220['id'],'setup',![]);state['setupLinkData']={'username':_0x10a220['username'],'email':_0x10a220['email'],'url':_0x4afb88['token']['setupUrl'],'userId':_0x10a220['id'],'type':'setup','emailSent':![]},await loadUsers(),hideUserModal(),showSetupLinkModal();}else Utils['showToast']('User\x20created\x20successfully','success'),await loadUsers(),hideUserModal();}}catch(_0x28934e){console['error']('Failed\x20to\x20save\x20user',_0x28934e),_0x20b735['textContent']=_0x28934e['message'],_0x20b735['hidden']=![],_0x20b735['scrollIntoView']({'behavior':'smooth','block':'nearest'}),_0x382c80['disabled']=![],_0x382c80['textContent']=_0x28e6dd;}}window['deleteUser']=function(_0x17f48a){const _0x417284=state['users']['find'](_0x4f4629=>_0x4f4629['id']===_0x17f48a);if(!_0x417284)return;state['deletingUserId']=_0x17f48a;const _0x38aed9=document['getElementById']('delete-modal'),_0x420860=document['getElementById']('delete-user-name');_0x420860['textContent']=_0x417284['name']+'\x20('+_0x417284['username']+')',_0x38aed9['hidden']=![];};function hideDeleteModal(){const _0x57577e=document['getElementById']('delete-modal');_0x57577e['hidden']=!![],state['deletingUserId']=null;const _0x24f57d=document['getElementById']('confirm-delete');_0x24f57d&&(_0x24f57d['disabled']=![],_0x24f57d['textContent']='Delete\x20User');}async function confirmDeleteUser(){if(!state['deletingUserId'])return;const _0x12c1d1=document['getElementById']('confirm-delete'),_0x3bde91=_0x12c1d1['textContent'];_0x12c1d1['disabled']=!![],_0x12c1d1['textContent']='Deleting...';try{await API['deleteUser'](state['deletingUserId']),Utils['showToast']('User\x20deleted\x20successfully','success'),await loadUsers(),hideDeleteModal();}catch(_0x26ed26){console['error']('Failed\x20to\x20delete\x20user',_0x26ed26),Utils['showToast']('Failed\x20to\x20delete\x20user:\x20'+_0x26ed26['message'],'error'),_0x12c1d1['disabled']=![],_0x12c1d1['textContent']=_0x3bde91;}}function handleSkipPasswordChange(_0xbfe1c5){const _0x127232=document['getElementById']('user-password'),_0x547d8a=_0xbfe1c5['target']['checked'];_0x547d8a?(_0x127232['required']=![],_0x127232['disabled']=!![],_0x127232['value']=''):(_0x127232['required']=!![],_0x127232['disabled']=![]);}function showSetupLinkModal(){if(!state['setupLinkData'])return;const _0x158992=document['getElementById']('setup-link-modal'),_0x1b285a=document['getElementById']('setup-link-username'),_0x347778=document['getElementById']('setup-link-url'),_0x3756bf=document['getElementById']('email-setup-link'),_0x5949c6=document['getElementById']('email-button-text');_0x1b285a['textContent']=state['setupLinkData']['username'],_0x347778['textContent']=state['setupLinkData']['url'],_0x3756bf&&_0x5949c6&&(_0x3756bf['disabled']=![],_0x5949c6['textContent']='Email\x20Link',state['emailConfigured']&&!state['setupLinkData']['emailSent']?_0x3756bf['style']['display']='inline-block':_0x3756bf['style']['display']='none'),_0x158992['hidden']=![];}function hideSetupLinkModal(){const _0x588d9a=document['getElementById']('setup-link-modal');_0x588d9a['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(_0x316a4a){console['error']('Failed\x20to\x20copy\x20link',_0x316a4a),Utils['showToast']('Failed\x20to\x20copy\x20link','error');}}async function emailSetupLink(){if(!state['setupLinkData'])return;const _0x45d5ea=document['getElementById']('email-setup-link'),_0xcbb2d2=document['getElementById']('email-button-text');if(!_0x45d5ea||!_0xcbb2d2)return;const _0x34829f=_0xcbb2d2['textContent'];_0x45d5ea['disabled']=!![],_0xcbb2d2['textContent']='Sending...';try{const _0x1cd071=await API['createPasswordToken'](state['setupLinkData']['userId'],state['setupLinkData']['type'],!![]);if(_0x1cd071['emailSent'])Utils['showToast']('Email\x20sent\x20to\x20'+state['setupLinkData']['email'],'success'),state['setupLinkData']['emailSent']=!![],_0x45d5ea['style']['display']='none';else{const _0x2ced63=_0x1cd071['emailError']||'Failed\x20to\x20send\x20email';Utils['showToast'](_0x2ced63,'error'),_0x45d5ea['disabled']=![],_0xcbb2d2['textContent']=_0x34829f;}}catch(_0x465ba9){console['error']('Failed\x20to\x20email\x20setup\x20link',_0x465ba9),Utils['showToast']('Failed\x20to\x20send\x20email:\x20'+_0x465ba9['message'],'error'),_0x45d5ea['disabled']=![],_0xcbb2d2['textContent']=_0x34829f;}}window['resetPassword']=async function(_0x283030){const _0x578e12=state['users']['find'](_0x4c236=>_0x4c236['id']===_0x283030);if(!_0x578e12)return;const _0x336037=await ConfirmDialog['show']({'title':'Reset\x20Password','message':'Generate\x20a\x20password\x20reset\x20link\x20for\x20'+_0x578e12['name']+'\x20('+_0x578e12['username']+')?\x20This\x20will\x20create\x20a\x20link\x20that\x20they\x20can\x20use\x20to\x20set\x20a\x20new\x20password.','confirmText':'Generate\x20Link'});if(!_0x336037)return;try{const _0x39f962=await API['createPasswordToken'](_0x283030,'reset',![]);state['setupLinkData']={'username':_0x578e12['username'],'email':_0x578e12['email'],'url':_0x39f962['token']['setupUrl'],'userId':_0x578e12['id'],'type':'reset','emailSent':![]},showSetupLinkModal();}catch(_0x3edb85){console['error']('Failed\x20to\x20create\x20password\x20reset\x20link',_0x3edb85),Utils['showToast']('Failed\x20to\x20create\x20password\x20reset\x20link:\x20'+_0x3edb85['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 _0x4c2929=await API['getCurrentUser']();state['currentUser']=_0x4c2929;if(!Permissions['hasServerPermission'](_0x4c2929,'*')&&!Permissions['hasServerPermission'](_0x4c2929,'users:create')){Utils['showToast']('Access\x20denied:\x20Server\x20admin\x20privileges\x20required','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}}catch(_0x50818f){window['location']['href']='login.html';}}async function checkEmailConfig(){try{const _0x1d7180=await API['getEmailConfig']();state['emailConfigured']=_0x1d7180['configured'];}catch(_0x1fd8d6){console['error']('Failed\x20to\x20check\x20email\x20config',_0x1fd8d6),state['emailConfigured']=![];}}async function loadRoles(){try{const {roles:_0x331bc1}=await API['getRoleDefinitions']();state['roles']=_0x331bc1||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x42e924=await API['getEnvironments']();state['environments']=_0x42e924['environments']||[];}catch{state['environments']=[];}}async function loadTeams(){try{const {teams:_0x26b4a4}=await API['getTeams']();state['teams']=_0x26b4a4||[];}catch{state['teams']=[];}}function bindEventListeners(){document['getElementById']('create-user-btn')?.['addEventListener']('click',showCreateUserModal),document['getElementById']('close-user-modal')?.['addEventListener']('click',hideUserModal),document['getElementById']('cancel-user')?.['addEventListener']('click',hideUserModal),document['getElementById']('save-user')?.['addEventListener']('click',saveUser),document['querySelector']('#user-modal\x20.modal-overlay')?.['addEventListener']('click',hideUserModal),document['getElementById']('close-delete-modal')?.['addEventListener']('click',hideDeleteModal),document['getElementById']('cancel-delete')?.['addEventListener']('click',hideDeleteModal),document['getElementById']('confirm-delete')?.['addEventListener']('click',confirmDeleteUser),document['querySelector']('#delete-modal\x20.modal-overlay')?.['addEventListener']('click',hideDeleteModal),document['getElementById']('close-setup-link-modal')?.['addEventListener']('click',hideSetupLinkModal),document['getElementById']('close-setup-link')?.['addEventListener']('click',hideSetupLinkModal),document['getElementById']('copy-setup-link')?.['addEventListener']('click',copySetupLink),document['getElementById']('email-setup-link')?.['addEventListener']('click',emailSetupLink),document['querySelector']('#setup-link-modal\x20.modal-overlay')?.['addEventListener']('click',hideSetupLinkModal),document['getElementById']('skip-password')?.['addEventListener']('change',handleSkipPasswordChange),document['getElementById']('retry-users-btn')?.['addEventListener']('click',loadUsers),document['getElementById']('close-bindings-modal')?.['addEventListener']('click',hideAccessBindingsModal),document['getElementById']('close-bindings-modal-footer')?.['addEventListener']('click',hideAccessBindingsModal),document['querySelector']('#bindings-modal\x20.modal-overlay')?.['addEventListener']('click',hideAccessBindingsModal),document['getElementById']('add-user-binding-btn')?.['addEventListener']('click',()=>{document['getElementById']('add-user-binding-form')['hidden']=![],document['getElementById']('add-user-binding-btn')['hidden']=!![],populateUserBindingForm();}),document['getElementById']('cancel-user-binding-btn')?.['addEventListener']('click',()=>{document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![];}),document['getElementById']('save-user-binding-btn')?.['addEventListener']('click',saveUserBinding),document['getElementById']('user-binding-resource-type')?.['addEventListener']('change',onUserBindingResourceTypeChange);}async function loadUsers(){const _0x2239d1=document['getElementById']('users-loading'),_0x34511d=document['getElementById']('users-error'),_0x7f0a4c=document['getElementById']('users-content');try{_0x2239d1['hidden']=![],_0x34511d['hidden']=!![],_0x7f0a4c['hidden']=!![];const _0x21c616=await API['getUsers']();state['users']=_0x21c616['users']||[],renderUsers(),_0x2239d1['hidden']=!![],_0x7f0a4c['hidden']=![];}catch(_0x33a028){console['error']('Failed\x20to\x20load\x20users',_0x33a028),_0x2239d1['hidden']=!![],_0x34511d['hidden']=![],document['getElementById']('users-error-message')['textContent']=_0x33a028['message'];}}function renderUsers(){const _0x1de5f9=document['getElementById']('users-table-body'),_0x30eb5f=document['getElementById']('user-count');if(!_0x1de5f9)return;_0x30eb5f&&(_0x30eb5f['textContent']=state['users']['length']+'\x20user'+(state['users']['length']===0x1?'':'s'));const _0x4f7993=[...state['users']]['sort']((_0x2691eb,_0x3fc27f)=>{const _0x216f7b=new Date(_0x2691eb['created_at'])['getTime'](),_0x4e7345=new Date(_0x3fc27f['created_at'])['getTime']();return _0x4e7345-_0x216f7b;});_0x1de5f9['innerHTML']=_0x4f7993['map'](_0x58dd4d=>'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22user-username\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+Utils['escapeHtml'](_0x58dd4d['username'])+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x58dd4d['name'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x58dd4d['email'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22access-badges\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x58dd4d['isServerAdmin']?'<span\x20class=\x22role-badge\x20role-admin\x22>Server\x20Admin</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x58dd4d['hasUserBinding']?'<span\x20class=\x22role-badge\x20role-user-binding\x22>User\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x58dd4d['hasTeamBinding']?'<span\x20class=\x22role-badge\x20role-team-binding\x22>Team\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['formatRelativeTime'](_0x58dd4d['created_at'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22user-actions\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-icon\x20btn-small\x22\x20onclick=\x22window.editUser(\x27'+_0x58dd4d['id']+'\x27)\x22\x20title=\x22Edit\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2214\x22\x20height=\x2214\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M11\x204H4a2\x202\x200\x200\x200-2\x202v14a2\x202\x200\x200\x200\x202\x202h14a2\x202\x200\x200\x200\x202-2v-7\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M18.5\x202.5a2.121\x202.121\x200\x200\x201\x203\x203L12\x2015l-4\x201\x201-4\x209.5-9.5z\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-icon\x20btn-small\x22\x20onclick=\x22window.showAccessBindings(\x27'+_0x58dd4d['id']+'\x27)\x22\x20title=\x22Access\x20Bindings\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2214\x22\x20height=\x2214\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M12\x2022s8-4\x208-10V5l-8-3-8\x203v7c0\x206\x208\x2010\x208\x2010z\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-icon\x20btn-small\x20btn-danger\x22\x20onclick=\x22window.deleteUser(\x27'+_0x58dd4d['id']+'\x27)\x22\x20title=\x22Delete\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2214\x22\x20height=\x2214\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<polyline\x20points=\x223\x206\x205\x206\x2021\x206\x22></polyline>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M19\x206v14a2\x202\x200\x200\x201-2\x202H7a2\x202\x200\x200\x201-2-2V6m3\x200V4a2\x202\x200\x200\x201\x202-2h4a2\x202\x200\x200\x201\x202\x202v2\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-secondary\x20btn-small\x22\x20onclick=\x22window.resetPassword(\x27'+_0x58dd4d['id']+'\x27)\x22>Reset\x20Password</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20</tr>\x0a\x20\x20')['join']('');}window['showAccessBindings']=function(_0x36ee50){const _0x2fe342=state['users']['find'](_0x493e99=>_0x493e99['id']===_0x36ee50);if(!_0x2fe342)return;state['bindingsUserId']=_0x36ee50,state['bindingsDirty']=![];const _0x1120c3=document['getElementById']('bindings-modal'),_0x1d0801=document['getElementById']('bindings-modal-title');_0x1d0801['textContent']='Access\x20Bindings\x20—\x20'+_0x2fe342['name'],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],_0x1120c3['hidden']=![],loadUserBindings(_0x36ee50);};function hasUnsavedBindingChanges(){const _0x3ccb39=document['getElementById']('add-user-binding-form');return _0x3ccb39&&!_0x3ccb39['hidden'];}async function hideAccessBindingsModal(){if(hasUnsavedBindingChanges()){if(!confirm('You\x20have\x20an\x20unsaved\x20binding.\x20Discard\x20changes?'))return;document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![];}const _0x107d33=document['getElementById']('bindings-modal');_0x107d33['hidden']=!![];const _0xd1bc6b=state['bindingsDirty'];state['bindingsUserId']=null,state['userBindings']=[],state['bindingsDirty']=![],_0xd1bc6b&&await loadUsers();}async function loadUserBindings(_0x1dd7d0){const _0x7c660d=document['getElementById']('user-bindings-loading'),_0x2699fd=document['getElementById']('user-bindings-empty'),_0x50dc8e=document['getElementById']('user-bindings-list-container'),_0x63fd8a=document['getElementById']('add-user-binding-btn'),_0xeb9d4a=document['getElementById']('user-team-bindings-note'),_0x389674=document['getElementById']('user-team-bindings-text');_0x7c660d['hidden']=![],_0x2699fd['hidden']=!![],_0x50dc8e['style']['display']='none',_0x63fd8a['hidden']=!![],_0xeb9d4a['hidden']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![];try{const [_0x2b69b9,_0x299196]=await Promise['all']([API['getBindings']({'subject_type':'user','subject_id':_0x1dd7d0}),API['getTeams']()]);state['userBindings']=_0x2b69b9['bindings']||[];const _0x44fe25=(_0x299196['teams']||[])['filter'](_0x47cca4=>(_0x47cca4['members']||[])['includes'](_0x1dd7d0)),_0x5eb465=[];if(_0x44fe25['length']>0x0){const _0x200e1a=await Promise['all'](_0x44fe25['map'](_0x294f69=>API['getBindings']({'subject_type':'team','subject_id':_0x294f69['id']})));for(let _0x144345=0x0;_0x144345<_0x44fe25['length'];_0x144345++){const _0x4f2140=_0x200e1a[_0x144345]['bindings']||[];_0x4f2140['length']>0x0&&_0x5eb465['push'](_0x44fe25[_0x144345]);}}_0x7c660d['hidden']=!![];state['userBindings']['length']===0x0?_0x2699fd['hidden']=![]:(_0x50dc8e['style']['display']='',renderUserBindingsTable());if(_0x5eb465['length']>0x0){const _0x5befbd=_0x5eb465['map'](_0xcf43cb=>_0xcf43cb['name']),_0x27da99=_0x5befbd['length']<=0x3?_0x5befbd['join'](',\x20'):_0x5befbd['slice'](0x0,0x3)['join'](',\x20')+(',\x20and\x20'+(_0x5befbd['length']-0x3)+'\x20more');_0x389674['textContent']='This\x20user\x20also\x20has\x20access\x20via\x20team\x20memberships\x20('+_0x27da99+').';}else _0x389674['textContent']='This\x20user\x20has\x20no\x20access\x20via\x20team\x20memberships.';_0xeb9d4a['hidden']=![],_0x63fd8a['hidden']=![];}catch(_0x4a32dd){_0x7c660d['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x4a32dd['message'],'error');}}function renderUserBindingsTable(){const _0x2f64d5=document['getElementById']('user-bindings-table-body');if(!_0x2f64d5)return;_0x2f64d5['innerHTML']=state['userBindings']['map'](_0x2a0e78=>{const _0x56fa5f=_0x2a0e78['resource_type']==='server'?'Server':_0x2a0e78['resource_id']==='*'?'All\x20'+_0x2a0e78['resource_type']+'s':Utils['escapeHtml'](_0x2a0e78['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x56fa5f+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x2a0e78['role_name']||_0x2a0e78['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteUserBindingClick(\x27'+_0x2a0e78['id']+'\x27)\x22\x20style=\x22color:\x20var(--color-danger);\x22>Remove</button>\x0a\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20</tr>';})['join']('');}function populateUserBindingForm(){const _0x1d9cf9=document['getElementById']('user-binding-resource-type');_0x1d9cf9['value']='environment',updateUserBindingFormForResourceType('environment');}function onUserBindingResourceTypeChange(){const _0x5f0e9b=document['getElementById']('user-binding-resource-type')['value'];updateUserBindingFormForResourceType(_0x5f0e9b);}function updateUserBindingFormForResourceType(_0x28a19d){const _0x559dec=document['getElementById']('user-binding-resource-container'),_0x47e20e=document['getElementById']('user-binding-resource'),_0x4f330d=document['getElementById']('user-binding-role');if(_0x28a19d==='server')_0x559dec['style']['display']='none';else{_0x559dec['style']['display']='';if(_0x28a19d==='environment'){const _0x5cdc1e=new Set(state['userBindings']['filter'](_0x350b46=>_0x350b46['resource_type']==='environment')['map'](_0x2f6f6e=>_0x2f6f6e['resource_id'])),_0x11b885=state['environments']['filter'](_0x70f58b=>!_0x5cdc1e['has'](_0x70f58b['name']));_0x47e20e['innerHTML']=_0x11b885['length']?_0x11b885['map'](_0x271563=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x271563['name'])+'\x22>'+Utils['escapeHtml'](_0x271563['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x28a19d==='team'){const _0x16de32=new Set(state['userBindings']['filter'](_0x437b27=>_0x437b27['resource_type']==='team')['map'](_0x44f95e=>_0x44f95e['resource_id'])),_0x24ca25=state['teams']['filter'](_0x180a10=>!_0x16de32['has'](_0x180a10['id']));_0x47e20e['innerHTML']=_0x24ca25['length']?_0x24ca25['map'](_0x26027d=>'<option\x20value=\x22'+_0x26027d['id']+'\x22>'+Utils['escapeHtml'](_0x26027d['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x4d6fd9=state['roles']['filter'](_0x2a1583=>_0x2a1583['resource_type']===_0x28a19d);_0x4f330d['innerHTML']=_0x4d6fd9['length']?_0x4d6fd9['filter'](_0x2d3f61=>{const _0x480daf=_0x28a19d==='server'?undefined:_0x47e20e['value'];return!state['userBindings']['some'](_0x340607=>_0x340607['resource_type']===_0x28a19d&&_0x340607['role_id']===_0x2d3f61['id']&&(_0x28a19d==='server'||_0x340607['resource_id']===_0x480daf));})['map'](_0x53b1d9=>'<option\x20value=\x22'+_0x53b1d9['id']+'\x22>'+Utils['escapeHtml'](_0x53b1d9['name'])+'</option>')['join']('')||'<option\x20value=\x22\x22>No\x20available\x20roles</option>':'<option\x20value=\x22\x22>No\x20roles\x20for\x20this\x20resource\x20type</option>';}async function saveUserBinding(){const _0x2a7a25=document['getElementById']('user-binding-resource-type')['value'],_0x2ab580=document['getElementById']('user-binding-role')['value'];if(!_0x2ab580||!state['bindingsUserId'])return;const _0x2e7a76=_0x2a7a25==='server'?undefined:document['getElementById']('user-binding-resource')['value'];if(_0x2a7a25!=='server'&&!_0x2e7a76)return;const _0x522d9d=document['getElementById']('save-user-binding-btn');_0x522d9d['disabled']=!![],_0x522d9d['textContent']='Adding…';try{const _0x3827bc={'subject_type':'user','subject_id':state['bindingsUserId'],'role_id':_0x2ab580,'resource_type':_0x2a7a25};if(_0x2e7a76)_0x3827bc['resource_id']=_0x2e7a76;await API['createBinding'](_0x3827bc),Utils['showToast']('Binding\x20added','success'),state['bindingsDirty']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],await loadUserBindings(state['bindingsUserId']);}catch(_0x54fda0){Utils['showToast'](_0x54fda0['message'],'error');}finally{_0x522d9d['disabled']=![],_0x522d9d['textContent']='Add\x20Binding';}}window['deleteUserBindingClick']=async function(_0x579875){try{await API['deleteBinding'](_0x579875),Utils['showToast']('Binding\x20removed','success'),state['bindingsDirty']=!![],await loadUserBindings(state['bindingsUserId']);}catch(_0x3e8447){Utils['showToast'](_0x3e8447['message'],'error');}};function showCreateUserModal(){state['editingUserId']=null;const _0x23e99a=document['getElementById']('user-modal'),_0xf0290c=document['getElementById']('modal-title'),_0x1358b3=document['getElementById']('user-password'),_0x5d3aa4=document['getElementById']('password-required'),_0x40d06a=document['getElementById']('password-hint'),_0x1e8a4b=document['getElementById']('skip-password-container'),_0x5f4342=document['getElementById']('skip-password');_0xf0290c['textContent']='Create\x20User',document['getElementById']('user-form')['reset'](),_0x1358b3['required']=!![];if(_0x5d3aa4)_0x5d3aa4['textContent']='*';_0x1e8a4b&&(_0x1e8a4b['style']['display']='block',_0x5f4342['checked']=![]),_0x40d06a&&(_0x40d06a['textContent']='Minimum\x208\x20characters'),_0x23e99a['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);}window['editUser']=function(_0x17ae4f){const _0x3e6bc6=state['users']['find'](_0x138e39=>_0x138e39['id']===_0x17ae4f);if(!_0x3e6bc6)return;state['editingUserId']=_0x17ae4f;const _0xbb831=document['getElementById']('user-modal'),_0x3288f3=document['getElementById']('modal-title'),_0x39b4d1=document['getElementById']('user-password'),_0x1205a4=document['getElementById']('password-required'),_0x44aeee=document['getElementById']('password-hint'),_0x3e1a75=document['getElementById']('skip-password-container');_0x3288f3['textContent']='Edit\x20User',document['getElementById']('user-username')['value']=_0x3e6bc6['username'],document['getElementById']('user-name')['value']=_0x3e6bc6['name'],document['getElementById']('user-email')['value']=_0x3e6bc6['email'],_0x39b4d1['value']='',_0x39b4d1['required']=![];if(_0x1205a4)_0x1205a4['textContent']='';_0x3e1a75&&(_0x3e1a75['style']['display']='none'),_0x44aeee&&(_0x44aeee['textContent']='Leave\x20blank\x20to\x20keep\x20current\x20password'),_0xbb831['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);};function hideUserModal(){const _0x555ddc=document['getElementById']('user-modal'),_0x4bc19e=document['getElementById']('form-error'),_0x1b228e=document['getElementById']('save-user');_0x555ddc['hidden']=!![],_0x4bc19e['hidden']=!![],state['editingUserId']=null,_0x1b228e&&(_0x1b228e['disabled']=![],_0x1b228e['textContent']='Save\x20User');}async function saveUser(){const _0x4f326e=document['getElementById']('user-form'),_0x868ca8=document['getElementById']('skip-password')?.['checked']||![];if(!_0x868ca8&&!_0x4f326e['checkValidity']()){_0x4f326e['reportValidity']();return;}const _0x1e1b94=document['getElementById']('form-error'),_0x17c065=document['getElementById']('save-user'),_0x5b5081=document['getElementById']('user-username')['value']['trim'](),_0x5375f0=document['getElementById']('user-name')['value']['trim'](),_0x3e4f15=document['getElementById']('user-email')['value']['trim'](),_0x4c4aba=document['getElementById']('user-password')['value'];if(!_0x5b5081||!_0x5375f0||!_0x3e4f15){_0x1e1b94['textContent']='Please\x20fill\x20in\x20all\x20required\x20fields',_0x1e1b94['hidden']=![],_0x1e1b94['scrollIntoView']({'behavior':'smooth','block':'nearest'});return;}_0x1e1b94['hidden']=!![];const _0x40996e=_0x17c065['textContent'];_0x17c065['disabled']=!![],_0x17c065['textContent']=state['editingUserId']?'Updating...':'Creating...';try{if(state['editingUserId']){const _0x2995d2={'username':_0x5b5081,'name':_0x5375f0,'email':_0x3e4f15};_0x4c4aba&&(_0x2995d2['password']=_0x4c4aba),await API['updateUser'](state['editingUserId'],_0x2995d2),Utils['showToast']('User\x20updated\x20successfully','success'),await loadUsers(),hideUserModal();}else{const _0x3307eb={'username':_0x5b5081,'name':_0x5375f0,'email':_0x3e4f15};if(!_0x868ca8){if(!_0x4c4aba)throw new Error('Password\x20is\x20required\x20for\x20new\x20users');_0x3307eb['password']=_0x4c4aba;}const _0x476ccb=await API['createUser'](_0x3307eb),_0x3452c3=_0x476ccb['user'];if(_0x868ca8||!_0x4c4aba){const _0x4ddb84=await API['createPasswordToken'](_0x3452c3['id'],'setup',![]);state['setupLinkData']={'username':_0x3452c3['username'],'email':_0x3452c3['email'],'url':_0x4ddb84['token']['setupUrl'],'userId':_0x3452c3['id'],'type':'setup','emailSent':![]},await loadUsers(),hideUserModal(),showSetupLinkModal();}else Utils['showToast']('User\x20created\x20successfully','success'),await loadUsers(),hideUserModal();}}catch(_0x538809){console['error']('Failed\x20to\x20save\x20user',_0x538809),_0x1e1b94['textContent']=_0x538809['message'],_0x1e1b94['hidden']=![],_0x1e1b94['scrollIntoView']({'behavior':'smooth','block':'nearest'}),_0x17c065['disabled']=![],_0x17c065['textContent']=_0x40996e;}}window['deleteUser']=function(_0x2c6177){const _0x20c684=state['users']['find'](_0xad3fe8=>_0xad3fe8['id']===_0x2c6177);if(!_0x20c684)return;state['deletingUserId']=_0x2c6177;const _0x5176de=document['getElementById']('delete-modal'),_0x3047f8=document['getElementById']('delete-user-name');_0x3047f8['textContent']=_0x20c684['name']+'\x20('+_0x20c684['username']+')',_0x5176de['hidden']=![];};function hideDeleteModal(){const _0x295526=document['getElementById']('delete-modal');_0x295526['hidden']=!![],state['deletingUserId']=null;const _0x595b32=document['getElementById']('confirm-delete');_0x595b32&&(_0x595b32['disabled']=![],_0x595b32['textContent']='Delete\x20User');}async function confirmDeleteUser(){if(!state['deletingUserId'])return;const _0x59158b=document['getElementById']('confirm-delete'),_0x1f32d5=_0x59158b['textContent'];_0x59158b['disabled']=!![],_0x59158b['textContent']='Deleting...';try{await API['deleteUser'](state['deletingUserId']),Utils['showToast']('User\x20deleted\x20successfully','success'),await loadUsers(),hideDeleteModal();}catch(_0xc9040a){console['error']('Failed\x20to\x20delete\x20user',_0xc9040a),Utils['showToast']('Failed\x20to\x20delete\x20user:\x20'+_0xc9040a['message'],'error'),_0x59158b['disabled']=![],_0x59158b['textContent']=_0x1f32d5;}}function handleSkipPasswordChange(_0x522869){const _0x36496f=document['getElementById']('user-password'),_0x244d2c=_0x522869['target']['checked'];_0x244d2c?(_0x36496f['required']=![],_0x36496f['disabled']=!![],_0x36496f['value']=''):(_0x36496f['required']=!![],_0x36496f['disabled']=![]);}function showSetupLinkModal(){if(!state['setupLinkData'])return;const _0x44aa88=document['getElementById']('setup-link-modal'),_0xb34a7d=document['getElementById']('setup-link-username'),_0x5f4786=document['getElementById']('setup-link-url'),_0x53733e=document['getElementById']('email-setup-link'),_0x4c9fa5=document['getElementById']('email-button-text');_0xb34a7d['textContent']=state['setupLinkData']['username'],_0x5f4786['textContent']=state['setupLinkData']['url'],_0x53733e&&_0x4c9fa5&&(_0x53733e['disabled']=![],_0x4c9fa5['textContent']='Email\x20Link',state['emailConfigured']&&!state['setupLinkData']['emailSent']?_0x53733e['style']['display']='inline-block':_0x53733e['style']['display']='none'),_0x44aa88['hidden']=![];}function hideSetupLinkModal(){const _0x179208=document['getElementById']('setup-link-modal');_0x179208['hidden']=!![],state['setupLinkData']=null;}async function copySetupLink(){if(!state['setupLinkData'])return;try{await navigator['clipboard']['writeText'](state['setupLinkData']['url']),Utils['showToast']('Link\x20copied\x20to\x20clipboard','success');}catch(_0x32efa3){console['error']('Failed\x20to\x20copy\x20link',_0x32efa3),Utils['showToast']('Failed\x20to\x20copy\x20link','error');}}async function emailSetupLink(){if(!state['setupLinkData'])return;const _0x376902=document['getElementById']('email-setup-link'),_0x1f8799=document['getElementById']('email-button-text');if(!_0x376902||!_0x1f8799)return;const _0x63226=_0x1f8799['textContent'];_0x376902['disabled']=!![],_0x1f8799['textContent']='Sending...';try{const _0xc77a8c=await API['createPasswordToken'](state['setupLinkData']['userId'],state['setupLinkData']['type'],!![]);if(_0xc77a8c['emailSent'])Utils['showToast']('Email\x20sent\x20to\x20'+state['setupLinkData']['email'],'success'),state['setupLinkData']['emailSent']=!![],_0x376902['style']['display']='none';else{const _0xdda6dd=_0xc77a8c['emailError']||'Failed\x20to\x20send\x20email';Utils['showToast'](_0xdda6dd,'error'),_0x376902['disabled']=![],_0x1f8799['textContent']=_0x63226;}}catch(_0x14155b){console['error']('Failed\x20to\x20email\x20setup\x20link',_0x14155b),Utils['showToast']('Failed\x20to\x20send\x20email:\x20'+_0x14155b['message'],'error'),_0x376902['disabled']=![],_0x1f8799['textContent']=_0x63226;}}window['resetPassword']=async function(_0x32ff26){const _0x7c000d=state['users']['find'](_0x2bb26e=>_0x2bb26e['id']===_0x32ff26);if(!_0x7c000d)return;const _0x6b5cef=await ConfirmDialog['show']({'title':'Reset\x20Password','message':'Generate\x20a\x20password\x20reset\x20link\x20for\x20'+_0x7c000d['name']+'\x20('+_0x7c000d['username']+')?\x20This\x20will\x20create\x20a\x20link\x20that\x20they\x20can\x20use\x20to\x20set\x20a\x20new\x20password.','confirmText':'Generate\x20Link'});if(!_0x6b5cef)return;try{const _0x3a87b5=await API['createPasswordToken'](_0x32ff26,'reset',![]);state['setupLinkData']={'username':_0x7c000d['username'],'email':_0x7c000d['email'],'url':_0x3a87b5['token']['setupUrl'],'userId':_0x7c000d['id'],'type':'reset','emailSent':![]},showSetupLinkModal();}catch(_0x14df32){console['error']('Failed\x20to\x20create\x20password\x20reset\x20link',_0x14df32),Utils['showToast']('Failed\x20to\x20create\x20password\x20reset\x20link:\x20'+_0x14df32['message'],'error');}};
@@ -1 +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(_0x35bdd2={}){this['container']=null,this['onGroupChange']=_0x35bdd2['onGroupChange']||(()=>{}),this['onAddExistingTask']=_0x35bdd2['onAddExistingTask']||(()=>{}),this['tasks']=[],this['groupId']=_0x35bdd2['groupId']||null,this['isOpen']=![];}['init'](_0x3066d7,_0x57ef34,_0x2e5a29){this['container']=_0x3066d7,this['tasks']=_0x57ef34,this['groupId']=_0x2e5a29,this['render'](),this['attachEventListeners']();}['updateTasks'](_0x4dc357){const _0x931c1d=new Map(_0x4dc357['map'](_0x4126e8=>[_0x4126e8['taskId'],_0x4126e8]));this['tasks']=this['tasks']['map'](_0x213d9d=>{const _0x3ec8b1=_0x931c1d['get'](_0x213d9d['taskId']);return _0x3ec8b1?_0x3ec8b1:_0x213d9d;});for(const _0xbe89e4 of _0x4dc357){!this['tasks']['some'](_0x4f6156=>_0x4f6156['taskId']===_0xbe89e4['taskId'])&&this['tasks']['push'](_0xbe89e4);}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 _0x10eebf=this['tasks']['filter'](_0x291673=>_0x291673['groupId']===this['groupId'])['sort']((_0x56fa58,_0x461f24)=>(_0x56fa58['groupIndex']??0x0)-(_0x461f24['groupIndex']??0x0)),_0x37e22c=this['tasks']['filter'](_0x471847=>!_0x471847['groupId']||_0x471847['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>'+_0x10eebf['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'+(_0x10eebf['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20add\x20to\x20group</div>':_0x10eebf['map']((_0x5ba984,_0x3ac7ea)=>this['renderVariantCard'](_0x5ba984,_0x3ac7ea,!![]))['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>'+_0x37e22c['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'+(_0x37e22c['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20remove\x20from\x20group</div>':_0x37e22c['map']((_0x40195a,_0x289880)=>this['renderVariantCard'](_0x40195a,_0x289880,![]))['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'](_0x25a85e,_0xffe0af,_0x4c5b1f){const _0x31a50e=_0x25a85e['envVars']?.['CODER_AGENT']||_0x25a85e['envVars']?.['default_agent']||'claude',_0xbc39db=AGENT_ICONS[_0x31a50e['toLowerCase']()]||AGENT_ICONS['claude'],_0x2fcbfb=STATUS_ICONS[_0x25a85e['status']]||'',_0x53fb8c='status-'+(_0x25a85e['status']||'unknown'),_0x14216c=_0x25a85e['isWinner']?'<span\x20class=\x22vgm-badge\x20vgm-badge-winner\x22\x20title=\x22Winner\x22>★</span>':'',_0x5e02be=_0x25a85e['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'+_0x53fb8c+'\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'+_0x25a85e['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-is-grouped=\x22'+_0x4c5b1f+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-index=\x22'+_0xffe0af+'\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'+_0x31a50e['toLowerCase']()+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0xbc39db+'\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'](_0x25a85e['name']||'Task\x20'+_0x25a85e['taskId']['slice'](-0x6))+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-meta\x22>'+Utils['escapeHtml'](_0x31a50e)+'\x20·\x20'+(_0x25a85e['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'+_0x14216c+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x5e02be+'\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'+_0x53fb8c+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x2fcbfb+'\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'+(_0x4c5b1f?'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'+_0x25a85e['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-action=\x22'+(_0x4c5b1f?'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'+(_0x4c5b1f?'<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',_0x6e3a14=>{_0x6e3a14['target']['closest']('.vgm-close-btn')&&(this['close'](),this['onGroupChange'](this['tasks'])),_0x6e3a14['target']['closest']('.vgm-add-existing-btn')&&(this['close'](),this['onAddExistingTask'](this['groupId']));}),this['container']['addEventListener']('click',async _0x4d78f9=>{const _0x34f8cf=_0x4d78f9['target']['closest']('.vgm-variant-remove-btn');if(!_0x34f8cf)return;const _0x53f75f=_0x34f8cf['dataset']['taskId'],_0x1068ae=_0x34f8cf['dataset']['action'];try{_0x1068ae==='remove'?await this['removeFromGroup'](_0x53f75f):await this['addToGroup'](_0x53f75f);}catch(_0x2d0f8b){console['error']('Failed\x20to\x20update\x20group:',_0x2d0f8b),Utils['showToast'](_0x2d0f8b['message']||'Failed\x20to\x20update\x20group','error');}}),this['container']['addEventListener']('dragstart',_0x511b9b=>this['handleDragStart'](_0x511b9b)),this['container']['addEventListener']('dragend',_0xf19861=>this['handleDragEnd'](_0xf19861)),this['container']['addEventListener']('dragover',_0x51a80d=>this['handleDragOver'](_0x51a80d)),this['container']['addEventListener']('dragleave',_0x4ae206=>this['handleDragLeave'](_0x4ae206)),this['container']['addEventListener']('drop',_0x371d3b=>this['handleDrop'](_0x371d3b));}['handleDragStart'](_0x5d7507){const _0x41a119=_0x5d7507['target']['closest']('.vgm-variant-card');if(!_0x41a119)return;dragState['draggedTaskId']=_0x41a119['dataset']['taskId'],dragState['draggedElement']=_0x41a119,dragState['sourceGroupId']=_0x41a119['dataset']['isGrouped']==='true'?this['groupId']:null,dragState['isDragging']=!![],_0x41a119['classList']['add']('dragging'),_0x5d7507['dataTransfer']['effectAllowed']='move',_0x5d7507['dataTransfer']['setData']('text/plain',_0x41a119['dataset']['taskId']),this['container']['classList']['add']('is-dragging');}['handleDragEnd'](_0x1bcc9d){const _0x2713be=_0x1bcc9d['target']['closest']('.vgm-variant-card');_0x2713be&&_0x2713be['classList']['remove']('dragging'),this['container']['querySelectorAll']('.drag-over,\x20.drop-indicator')['forEach'](_0x3798a9=>{_0x3798a9['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'](_0x43801d){_0x43801d['preventDefault'](),_0x43801d['dataTransfer']['dropEffect']='move';const _0x377bf9=_0x43801d['target']['closest']('.vgm-drop-zone'),_0x27c7ce=_0x43801d['target']['closest']('.vgm-variant-card');this['container']['querySelectorAll']('.vgm-drop-zone')['forEach'](_0xca1bab=>{_0xca1bab['classList']['toggle']('drag-over',_0xca1bab===_0x377bf9);});if(_0x27c7ce&&_0x27c7ce!==dragState['draggedElement']){const _0x49d09f=_0x27c7ce['getBoundingClientRect'](),_0x5f4b16=_0x49d09f['top']+_0x49d09f['height']/0x2,_0x3c4c4f=_0x43801d['clientY']<_0x5f4b16;this['container']['querySelectorAll']('.vgm-variant-card')['forEach'](_0x338042=>{_0x338042!==_0x27c7ce&&_0x338042['classList']['remove']('drop-before','drop-after');}),_0x27c7ce['classList']['toggle']('drop-before',_0x3c4c4f),_0x27c7ce['classList']['toggle']('drop-after',!_0x3c4c4f);}}['handleDragLeave'](_0x155c17){const _0x1be4d3=_0x155c17['target']['closest']('.vgm-drop-zone');_0x1be4d3&&!_0x1be4d3['contains'](_0x155c17['relatedTarget'])&&_0x1be4d3['classList']['remove']('drag-over');}async['handleDrop'](_0x96a491){_0x96a491['preventDefault']();const _0x67cd08=_0x96a491['target']['closest']('.vgm-drop-zone'),_0x139e7b=_0x96a491['target']['closest']('.vgm-variant-card'),_0x321010=_0x96a491['dataTransfer']['getData']('text/plain');if(!_0x67cd08||!_0x321010)return;this['container']['querySelectorAll']('.drag-over,\x20.drop-before,\x20.drop-after')['forEach'](_0x571630=>{_0x571630['classList']['remove']('drag-over','drop-before','drop-after');});const _0x484ed4=_0x67cd08['dataset']['zone'],_0x179cab=_0x484ed4==='grouped',_0x4c26f3=dragState['sourceGroupId']===this['groupId'];try{if(_0x179cab&&!_0x4c26f3){let _0x3dd5f3=this['tasks']['filter'](_0x4df321=>_0x4df321['groupId']===this['groupId'])['length'];if(_0x139e7b){const _0x404273=_0x139e7b['dataset']['taskId'],_0x4a7bae=this['tasks']['find'](_0x36b6c4=>_0x36b6c4['taskId']===_0x404273);if(_0x4a7bae?.['groupIndex']!==undefined){const _0x417c4d=_0x139e7b['getBoundingClientRect'](),_0x360309=_0x96a491['clientY']<_0x417c4d['top']+_0x417c4d['height']/0x2;_0x3dd5f3=_0x4a7bae['groupIndex']+(_0x360309?0x0:0x1);}}await this['addToGroup'](_0x321010,_0x3dd5f3);}else{if(!_0x179cab&&_0x4c26f3)await this['removeFromGroup'](_0x321010);else _0x179cab&&_0x4c26f3&&_0x139e7b&&await this['reorderInGroup'](_0x321010,_0x139e7b,_0x96a491['clientY']);}}catch(_0xceb218){console['error']('Drop\x20operation\x20failed:',_0xceb218),Utils['showToast'](_0xceb218['message']||'Failed\x20to\x20move\x20variant','error');}}async['addToGroup'](_0x56ebc6,_0x3fab32){const _0x4ca73e=this['tasks']['find'](_0x38f018=>_0x38f018['taskId']===_0x56ebc6);if(!_0x4ca73e)return;_0x3fab32===undefined&&(_0x3fab32=this['tasks']['filter'](_0x4bc5d5=>_0x4bc5d5['groupId']===this['groupId'])['length']),!this['groupId']&&(this['groupId']=API['generateGroupId'](),await API['createTaskGroup']({'groupId':this['groupId']})),await API['updateTaskGroup'](_0x56ebc6,this['groupId'],_0x3fab32),_0x4ca73e['groupId']=this['groupId'],_0x4ca73e['groupIndex']=_0x3fab32,this['render'](),this['onGroupChange'](this['tasks']);}async['removeFromGroup'](_0x1d8ee2){const _0x3400a8=this['tasks']['find'](_0x1f6b52=>_0x1f6b52['taskId']===_0x1d8ee2);if(!_0x3400a8)return;await API['removeTaskFromGroup'](_0x1d8ee2),_0x3400a8['groupId']=null,_0x3400a8['groupIndex']=null,this['render'](),this['onGroupChange'](this['tasks']);}async['reorderInGroup'](_0x32cbf8,_0x13814e,_0x27458f){const _0x4d042f=this['tasks']['find'](_0x4ecf73=>_0x4ecf73['taskId']===_0x32cbf8),_0x4b2bd7=_0x13814e['dataset']['taskId'],_0x50af1d=this['tasks']['find'](_0x3aafe0=>_0x3aafe0['taskId']===_0x4b2bd7);if(!_0x4d042f||!_0x50af1d||_0x4d042f['taskId']===_0x50af1d['taskId'])return;const _0x2eb901=_0x13814e['getBoundingClientRect'](),_0x33df62=_0x27458f<_0x2eb901['top']+_0x2eb901['height']/0x2;let _0x68c7a8=_0x50af1d['groupIndex']??0x0;if(!_0x33df62)_0x68c7a8++;if((_0x4d042f['groupIndex']??0x0)<(_0x50af1d['groupIndex']??0x0))_0x68c7a8--;if(_0x68c7a8===_0x4d042f['groupIndex'])return;await API['updateTaskGroup'](_0x32cbf8,this['groupId'],_0x68c7a8);const _0x1ff202=this['tasks']['filter'](_0x3e2b2f=>_0x3e2b2f['groupId']===this['groupId'])['sort']((_0x329890,_0x47f011)=>(_0x329890['groupIndex']??0x0)-(_0x47f011['groupIndex']??0x0)),_0x44b16a=_0x1ff202['findIndex'](_0x43a08a=>_0x43a08a['taskId']===_0x32cbf8);_0x44b16a!==-0x1&&_0x1ff202['splice'](_0x44b16a,0x1),_0x1ff202['splice'](_0x68c7a8,0x0,_0x4d042f),_0x1ff202['forEach']((_0x13ba5d,_0xe1953a)=>{_0x13ba5d['groupIndex']=_0xe1953a;}),this['render'](),this['onGroupChange'](this['tasks']);}}export function initializeTabDragDrop(_0xa50bcb,_0x602edf,_0x546a06,_0x4ac1f0={}){if(!_0xa50bcb)return;const {onReorder:_0x171b41,onRemove:_0x1ecfd5}=_0x4ac1f0,_0x386890=_0xa50bcb['querySelectorAll']('.task-tab');_0x386890['forEach']((_0x47afc6,_0x114ee8)=>{_0x47afc6['setAttribute']('draggable','true'),_0x47afc6['dataset']['index']=_0x114ee8,_0x47afc6['addEventListener']('dragstart',_0x276f46=>{_0x276f46['dataTransfer']['effectAllowed']='move',_0x276f46['dataTransfer']['setData']('text/plain',_0x47afc6['dataset']['taskId']),_0x47afc6['classList']['add']('dragging'),_0xa50bcb['classList']['add']('is-dragging');}),_0x47afc6['addEventListener']('dragend',()=>{_0x47afc6['classList']['remove']('dragging'),_0xa50bcb['classList']['remove']('is-dragging'),_0xa50bcb['querySelectorAll']('.drop-indicator')['forEach'](_0x25f3b4=>{_0x25f3b4['classList']['remove']('drop-indicator','drop-before','drop-after');});}),_0x47afc6['addEventListener']('dragover',_0x3c4aa9=>{_0x3c4aa9['preventDefault'](),_0x3c4aa9['dataTransfer']['dropEffect']='move';if(_0x47afc6['classList']['contains']('dragging'))return;const _0x3208a5=_0x47afc6['getBoundingClientRect'](),_0x432daf=_0x3208a5['left']+_0x3208a5['width']/0x2,_0x399b94=_0x3c4aa9['clientX']<_0x432daf;_0x386890['forEach'](_0xb79f52=>_0xb79f52['classList']['remove']('drop-before','drop-after')),_0x47afc6['classList']['add'](_0x399b94?'drop-before':'drop-after');}),_0x47afc6['addEventListener']('dragleave',()=>{_0x47afc6['classList']['remove']('drop-before','drop-after');}),_0x47afc6['addEventListener']('drop',async _0x32a734=>{_0x32a734['preventDefault']();const _0x4bf6ec=_0x32a734['dataTransfer']['getData']('text/plain'),_0x339bf3=_0x47afc6['dataset']['taskId'];if(_0x4bf6ec===_0x339bf3)return;const _0xa75005=_0x47afc6['getBoundingClientRect'](),_0x394a2f=_0x32a734['clientX']<_0xa75005['left']+_0xa75005['width']/0x2;_0x47afc6['classList']['remove']('drop-before','drop-after'),_0x171b41&&await _0x171b41(_0x4bf6ec,_0x339bf3,_0x394a2f);});});const _0x375990=document['createElement']('div');return _0x375990['className']='task-tab-remove-zone',_0x375990['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',_0x375990['style']['display']='none',_0x375990['addEventListener']('dragover',_0x2a9b01=>{_0x2a9b01['preventDefault'](),_0x375990['classList']['add']('drag-over');}),_0x375990['addEventListener']('dragleave',()=>{_0x375990['classList']['remove']('drag-over');}),_0x375990['addEventListener']('drop',async _0x2452fb=>{_0x2452fb['preventDefault'](),_0x375990['classList']['remove']('drag-over');const _0x2bcd6a=_0x2452fb['dataTransfer']['getData']('text/plain');_0x1ecfd5&&await _0x1ecfd5(_0x2bcd6a);}),_0xa50bcb['addEventListener']('dragstart',()=>{_0x602edf['length']>0x1&&(_0x375990['style']['display']='flex');}),_0xa50bcb['addEventListener']('dragend',()=>{_0x375990['style']['display']='none';}),_0xa50bcb['appendChild'](_0x375990),{'destroy':()=>{_0x375990['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(_0x1b2efb={}){this['container']=null,this['onGroupChange']=_0x1b2efb['onGroupChange']||(()=>{}),this['onAddExistingTask']=_0x1b2efb['onAddExistingTask']||(()=>{}),this['tasks']=[],this['groupId']=_0x1b2efb['groupId']||null,this['isOpen']=![];}['init'](_0x524a70,_0x28f5d2,_0x3f449a){this['container']=_0x524a70,this['tasks']=_0x28f5d2,this['groupId']=_0x3f449a,this['render'](),this['attachEventListeners']();}['updateTasks'](_0xd8dba0){const _0x41d1f7=new Map(_0xd8dba0['map'](_0x3cfff9=>[_0x3cfff9['taskId'],_0x3cfff9]));this['tasks']=this['tasks']['map'](_0x13c9ca=>{const _0x277428=_0x41d1f7['get'](_0x13c9ca['taskId']);return _0x277428?_0x277428:_0x13c9ca;});for(const _0x5862ae of _0xd8dba0){!this['tasks']['some'](_0x36fc44=>_0x36fc44['taskId']===_0x5862ae['taskId'])&&this['tasks']['push'](_0x5862ae);}this['isOpen']&&this['render']();}['open'](){this['isOpen']=!![],this['render'](),this['container']?.['classList']['add']('open');}['close'](){this['isOpen']=![],this['container']?.['classList']['remove']('open');}['render'](){if(!this['container'])return;const _0x4aaeef=this['tasks']['filter'](_0x2d6550=>_0x2d6550['groupId']===this['groupId'])['sort']((_0x5eb759,_0x138c7d)=>(_0x5eb759['groupIndex']??0x0)-(_0x138c7d['groupIndex']??0x0)),_0x945b7=this['tasks']['filter'](_0x40c548=>!_0x40c548['groupId']||_0x40c548['groupId']!==this['groupId']);this['container']['innerHTML']='\x0a\x20\x20\x20\x20\x20\x20<div\x20class=\x22variant-grouping-manager\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-header\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<h3>Manage\x20Task\x20Group</h3>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22vgm-close-btn\x22\x20title=\x22Close\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20width=\x2220\x22\x20height=\x2220\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M18\x206L6\x2018M6\x206l12\x2012\x22/>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-content\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-section\x20vgm-grouped\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-section-header\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-section-title\x22>Grouped\x20Variants</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-section-count\x22>'+_0x4aaeef['length']+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-drop-zone\x20vgm-grouped-zone\x22\x20data-zone=\x22grouped\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x4aaeef['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20add\x20to\x20group</div>':_0x4aaeef['map']((_0x92136f,_0x510653)=>this['renderVariantCard'](_0x92136f,_0x510653,!![]))['join'](''))+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-divider\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-divider-line\x22></div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-divider-text\x22>Drag\x20to\x20move</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-divider-line\x22></div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-section\x20vgm-ungrouped\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-section-header\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-section-title\x22>Ungrouped\x20Tasks</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-section-count\x22>'+_0x945b7['length']+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-drop-zone\x20vgm-ungrouped-zone\x22\x20data-zone=\x22ungrouped\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x945b7['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20remove\x20from\x20group</div>':_0x945b7['map']((_0x295759,_0x30f038)=>this['renderVariantCard'](_0x295759,_0x30f038,![]))['join'](''))+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-actions\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22vgm-btn\x20vgm-btn-secondary\x20vgm-add-existing-btn\x22\x20title=\x22Add\x20an\x20existing\x20task\x20to\x20this\x20group\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M12\x205v14M5\x2012h14\x22/>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20Add\x20Existing\x20Task\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20';}['renderVariantCard'](_0x32df38,_0x3d022f,_0x11e84e){const _0x1c8f5d=_0x32df38['envVars']?.['CODER_AGENT']||_0x32df38['envVars']?.['default_agent']||'claude',_0x4ce594=AGENT_ICONS[_0x1c8f5d['toLowerCase']()]||AGENT_ICONS['claude'],_0x109003=STATUS_ICONS[_0x32df38['status']]||'',_0x13df31='status-'+(_0x32df38['status']||'unknown'),_0x31225b=_0x32df38['isWinner']?'<span\x20class=\x22vgm-badge\x20vgm-badge-winner\x22\x20title=\x22Winner\x22>★</span>':'',_0x33e6a1=_0x32df38['approvedBy']?'<span\x20class=\x22vgm-badge\x20vgm-badge-approved\x22\x20title=\x22Approved\x22><svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22\x20width=\x2212\x22\x20height=\x2212\x22><path\x20d=\x22M14\x209V5a3\x203\x200\x200\x200-3-3l-4\x209v11h11.28a2\x202\x200\x200\x200\x202-1.7l1.38-9a2\x202\x200\x200\x200-2-2.3zM7\x2022H4a2\x202\x200\x200\x201-2-2v-7a2\x202\x200\x200\x201\x202-2h3\x22></path></svg></span>':'';return'\x0a\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-card\x20'+_0x13df31+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20draggable=\x22true\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-task-id=\x22'+_0x32df38['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-is-grouped=\x22'+_0x11e84e+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-index=\x22'+_0x3d022f+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-drag-handle\x22\x20title=\x22Drag\x20to\x20reorder\x20or\x20move\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20fill=\x22currentColor\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M8\x206h2v2H8V6zm6\x200h2v2h-2V6zM8\x2011h2v2H8v-2zm6\x200h2v2h-2v-2zm-6\x205h2v2H8v-2zm6\x200h2v2h-2v-2z\x22/>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-icon\x22\x20data-agent=\x22'+_0x1c8f5d['toLowerCase']()+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x4ce594+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-info\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-name\x22>'+Utils['escapeHtml'](_0x32df38['name']||'Task\x20'+_0x32df38['taskId']['slice'](-0x6))+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-meta\x22>'+Utils['escapeHtml'](_0x1c8f5d)+'\x20·\x20'+(_0x32df38['status']||'unknown')+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-badges\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x31225b+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x33e6a1+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-status\x20'+_0x13df31+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x109003+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22vgm-variant-remove-btn\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20title=\x22'+(_0x11e84e?'Remove\x20from\x20group':'Add\x20to\x20group')+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-task-id=\x22'+_0x32df38['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-action=\x22'+(_0x11e84e?'remove':'add')+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x11e84e?'<path\x20d=\x22M18\x206L6\x2018M6\x206l12\x2012\x22/>':'<path\x20d=\x22M12\x205v14M5\x2012h14\x22/>')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20';}['attachEventListeners'](){if(!this['container'])return;this['container']['addEventListener']('click',_0x5b1f93=>{_0x5b1f93['target']['closest']('.vgm-close-btn')&&(this['close'](),this['onGroupChange'](this['tasks'])),_0x5b1f93['target']['closest']('.vgm-add-existing-btn')&&(this['close'](),this['onAddExistingTask'](this['groupId']));}),this['container']['addEventListener']('click',async _0x2a22c6=>{const _0x4ed946=_0x2a22c6['target']['closest']('.vgm-variant-remove-btn');if(!_0x4ed946)return;const _0x5c92d=_0x4ed946['dataset']['taskId'],_0x103ed2=_0x4ed946['dataset']['action'];try{_0x103ed2==='remove'?await this['removeFromGroup'](_0x5c92d):await this['addToGroup'](_0x5c92d);}catch(_0x96fba7){console['error']('Failed\x20to\x20update\x20group:',_0x96fba7),Utils['showToast'](_0x96fba7['message']||'Failed\x20to\x20update\x20group','error');}}),this['container']['addEventListener']('dragstart',_0x304689=>this['handleDragStart'](_0x304689)),this['container']['addEventListener']('dragend',_0x493d68=>this['handleDragEnd'](_0x493d68)),this['container']['addEventListener']('dragover',_0x4342e5=>this['handleDragOver'](_0x4342e5)),this['container']['addEventListener']('dragleave',_0x5f3e0f=>this['handleDragLeave'](_0x5f3e0f)),this['container']['addEventListener']('drop',_0x40f38b=>this['handleDrop'](_0x40f38b));}['handleDragStart'](_0xcc2c03){const _0x182a12=_0xcc2c03['target']['closest']('.vgm-variant-card');if(!_0x182a12)return;dragState['draggedTaskId']=_0x182a12['dataset']['taskId'],dragState['draggedElement']=_0x182a12,dragState['sourceGroupId']=_0x182a12['dataset']['isGrouped']==='true'?this['groupId']:null,dragState['isDragging']=!![],_0x182a12['classList']['add']('dragging'),_0xcc2c03['dataTransfer']['effectAllowed']='move',_0xcc2c03['dataTransfer']['setData']('text/plain',_0x182a12['dataset']['taskId']),this['container']['classList']['add']('is-dragging');}['handleDragEnd'](_0x19f2f9){const _0x207b55=_0x19f2f9['target']['closest']('.vgm-variant-card');_0x207b55&&_0x207b55['classList']['remove']('dragging'),this['container']['querySelectorAll']('.drag-over,\x20.drop-indicator')['forEach'](_0x21485=>{_0x21485['classList']['remove']('drag-over','drop-indicator','drop-before','drop-after');}),this['container']['classList']['remove']('is-dragging'),dragState['isDragging']=![],dragState['draggedTaskId']=null,dragState['draggedElement']=null,dragState['sourceGroupId']=null;}['handleDragOver'](_0x3bf5ca){_0x3bf5ca['preventDefault'](),_0x3bf5ca['dataTransfer']['dropEffect']='move';const _0x4edbb7=_0x3bf5ca['target']['closest']('.vgm-drop-zone'),_0x441a0c=_0x3bf5ca['target']['closest']('.vgm-variant-card');this['container']['querySelectorAll']('.vgm-drop-zone')['forEach'](_0x2d3bdc=>{_0x2d3bdc['classList']['toggle']('drag-over',_0x2d3bdc===_0x4edbb7);});if(_0x441a0c&&_0x441a0c!==dragState['draggedElement']){const _0x1fd113=_0x441a0c['getBoundingClientRect'](),_0x2d6e0b=_0x1fd113['top']+_0x1fd113['height']/0x2,_0x4fbfd3=_0x3bf5ca['clientY']<_0x2d6e0b;this['container']['querySelectorAll']('.vgm-variant-card')['forEach'](_0x4072fb=>{_0x4072fb!==_0x441a0c&&_0x4072fb['classList']['remove']('drop-before','drop-after');}),_0x441a0c['classList']['toggle']('drop-before',_0x4fbfd3),_0x441a0c['classList']['toggle']('drop-after',!_0x4fbfd3);}}['handleDragLeave'](_0x42cfa0){const _0x263635=_0x42cfa0['target']['closest']('.vgm-drop-zone');_0x263635&&!_0x263635['contains'](_0x42cfa0['relatedTarget'])&&_0x263635['classList']['remove']('drag-over');}async['handleDrop'](_0x14098e){_0x14098e['preventDefault']();const _0x3006f3=_0x14098e['target']['closest']('.vgm-drop-zone'),_0x4fb2a4=_0x14098e['target']['closest']('.vgm-variant-card'),_0x90eb12=_0x14098e['dataTransfer']['getData']('text/plain');if(!_0x3006f3||!_0x90eb12)return;this['container']['querySelectorAll']('.drag-over,\x20.drop-before,\x20.drop-after')['forEach'](_0x10d8e0=>{_0x10d8e0['classList']['remove']('drag-over','drop-before','drop-after');});const _0x484a68=_0x3006f3['dataset']['zone'],_0x6b5436=_0x484a68==='grouped',_0x436d3b=dragState['sourceGroupId']===this['groupId'];try{if(_0x6b5436&&!_0x436d3b){let _0x5e1962=this['tasks']['filter'](_0x48e7ac=>_0x48e7ac['groupId']===this['groupId'])['length'];if(_0x4fb2a4){const _0x531cb3=_0x4fb2a4['dataset']['taskId'],_0x24e623=this['tasks']['find'](_0x361ff1=>_0x361ff1['taskId']===_0x531cb3);if(_0x24e623?.['groupIndex']!==undefined){const _0x306184=_0x4fb2a4['getBoundingClientRect'](),_0x5df2ed=_0x14098e['clientY']<_0x306184['top']+_0x306184['height']/0x2;_0x5e1962=_0x24e623['groupIndex']+(_0x5df2ed?0x0:0x1);}}await this['addToGroup'](_0x90eb12,_0x5e1962);}else{if(!_0x6b5436&&_0x436d3b)await this['removeFromGroup'](_0x90eb12);else _0x6b5436&&_0x436d3b&&_0x4fb2a4&&await this['reorderInGroup'](_0x90eb12,_0x4fb2a4,_0x14098e['clientY']);}}catch(_0x57d7b6){console['error']('Drop\x20operation\x20failed:',_0x57d7b6),Utils['showToast'](_0x57d7b6['message']||'Failed\x20to\x20move\x20variant','error');}}async['addToGroup'](_0x2e511b,_0x196a09){const _0x326c6e=this['tasks']['find'](_0x160bff=>_0x160bff['taskId']===_0x2e511b);if(!_0x326c6e)return;_0x196a09===undefined&&(_0x196a09=this['tasks']['filter'](_0x22a00d=>_0x22a00d['groupId']===this['groupId'])['length']),!this['groupId']&&(this['groupId']=API['generateGroupId'](),await API['createTaskGroup']({'groupId':this['groupId']})),await API['updateTaskGroup'](_0x2e511b,this['groupId'],_0x196a09),_0x326c6e['groupId']=this['groupId'],_0x326c6e['groupIndex']=_0x196a09,this['render'](),this['onGroupChange'](this['tasks']);}async['removeFromGroup'](_0x5ecf35){const _0x558adb=this['tasks']['find'](_0x279319=>_0x279319['taskId']===_0x5ecf35);if(!_0x558adb)return;await API['removeTaskFromGroup'](_0x5ecf35),_0x558adb['groupId']=null,_0x558adb['groupIndex']=null,this['render'](),this['onGroupChange'](this['tasks']);}async['reorderInGroup'](_0x24700d,_0x391a55,_0x35a091){const _0x5b15b0=this['tasks']['find'](_0x40a2bb=>_0x40a2bb['taskId']===_0x24700d),_0x2025d1=_0x391a55['dataset']['taskId'],_0x5c8d41=this['tasks']['find'](_0x82ca1a=>_0x82ca1a['taskId']===_0x2025d1);if(!_0x5b15b0||!_0x5c8d41||_0x5b15b0['taskId']===_0x5c8d41['taskId'])return;const _0x3a3639=_0x391a55['getBoundingClientRect'](),_0x5842cf=_0x35a091<_0x3a3639['top']+_0x3a3639['height']/0x2;let _0x313c90=_0x5c8d41['groupIndex']??0x0;if(!_0x5842cf)_0x313c90++;if((_0x5b15b0['groupIndex']??0x0)<(_0x5c8d41['groupIndex']??0x0))_0x313c90--;if(_0x313c90===_0x5b15b0['groupIndex'])return;await API['updateTaskGroup'](_0x24700d,this['groupId'],_0x313c90);const _0x268a81=this['tasks']['filter'](_0x4944f0=>_0x4944f0['groupId']===this['groupId'])['sort']((_0x93654b,_0x27c56f)=>(_0x93654b['groupIndex']??0x0)-(_0x27c56f['groupIndex']??0x0)),_0x45a3cb=_0x268a81['findIndex'](_0x4741b1=>_0x4741b1['taskId']===_0x24700d);_0x45a3cb!==-0x1&&_0x268a81['splice'](_0x45a3cb,0x1),_0x268a81['splice'](_0x313c90,0x0,_0x5b15b0),_0x268a81['forEach']((_0x417b18,_0x5ad283)=>{_0x417b18['groupIndex']=_0x5ad283;}),this['render'](),this['onGroupChange'](this['tasks']);}}export function initializeTabDragDrop(_0x343a69,_0x5a597d,_0x1a6252,_0x51f20e={}){if(!_0x343a69)return;const {onReorder:_0x2efe5b,onRemove:_0x549749}=_0x51f20e,_0x5c1c9e=_0x343a69['querySelectorAll']('.task-tab');_0x5c1c9e['forEach']((_0x209fc5,_0x5beebc)=>{_0x209fc5['setAttribute']('draggable','true'),_0x209fc5['dataset']['index']=_0x5beebc,_0x209fc5['addEventListener']('dragstart',_0x58eaa0=>{_0x58eaa0['dataTransfer']['effectAllowed']='move',_0x58eaa0['dataTransfer']['setData']('text/plain',_0x209fc5['dataset']['taskId']),_0x209fc5['classList']['add']('dragging'),_0x343a69['classList']['add']('is-dragging');}),_0x209fc5['addEventListener']('dragend',()=>{_0x209fc5['classList']['remove']('dragging'),_0x343a69['classList']['remove']('is-dragging'),_0x343a69['querySelectorAll']('.drop-indicator')['forEach'](_0x35c5b4=>{_0x35c5b4['classList']['remove']('drop-indicator','drop-before','drop-after');});}),_0x209fc5['addEventListener']('dragover',_0x3f20c0=>{_0x3f20c0['preventDefault'](),_0x3f20c0['dataTransfer']['dropEffect']='move';if(_0x209fc5['classList']['contains']('dragging'))return;const _0x444f97=_0x209fc5['getBoundingClientRect'](),_0xb8c2d2=_0x444f97['left']+_0x444f97['width']/0x2,_0x155cb5=_0x3f20c0['clientX']<_0xb8c2d2;_0x5c1c9e['forEach'](_0x317d4a=>_0x317d4a['classList']['remove']('drop-before','drop-after')),_0x209fc5['classList']['add'](_0x155cb5?'drop-before':'drop-after');}),_0x209fc5['addEventListener']('dragleave',()=>{_0x209fc5['classList']['remove']('drop-before','drop-after');}),_0x209fc5['addEventListener']('drop',async _0x3c9ab0=>{_0x3c9ab0['preventDefault']();const _0x2ca2d5=_0x3c9ab0['dataTransfer']['getData']('text/plain'),_0x5dcfbf=_0x209fc5['dataset']['taskId'];if(_0x2ca2d5===_0x5dcfbf)return;const _0x1f2528=_0x209fc5['getBoundingClientRect'](),_0x2903f3=_0x3c9ab0['clientX']<_0x1f2528['left']+_0x1f2528['width']/0x2;_0x209fc5['classList']['remove']('drop-before','drop-after'),_0x2efe5b&&await _0x2efe5b(_0x2ca2d5,_0x5dcfbf,_0x2903f3);});});const _0xdbebeb=document['createElement']('div');return _0xdbebeb['className']='task-tab-remove-zone',_0xdbebeb['innerHTML']='\x0a\x20\x20\x20\x20<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20<path\x20d=\x22M18\x206L6\x2018M6\x206l12\x2012\x22/>\x0a\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20<span>Remove\x20from\x20group</span>\x0a\x20\x20',_0xdbebeb['style']['display']='none',_0xdbebeb['addEventListener']('dragover',_0x1e7142=>{_0x1e7142['preventDefault'](),_0xdbebeb['classList']['add']('drag-over');}),_0xdbebeb['addEventListener']('dragleave',()=>{_0xdbebeb['classList']['remove']('drag-over');}),_0xdbebeb['addEventListener']('drop',async _0x2779c5=>{_0x2779c5['preventDefault'](),_0xdbebeb['classList']['remove']('drag-over');const _0x385c0d=_0x2779c5['dataTransfer']['getData']('text/plain');_0x549749&&await _0x549749(_0x385c0d);}),_0x343a69['addEventListener']('dragstart',()=>{_0x5a597d['length']>0x1&&(_0xdbebeb['style']['display']='flex');}),_0x343a69['addEventListener']('dragend',()=>{_0xdbebeb['style']['display']='none';}),_0x343a69['appendChild'](_0xdbebeb),{'destroy':()=>{_0xdbebeb['remove']();}};}export default VariantGroupingManager;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@profoundlogic/coderflow-server",
3
- "version": "0.7.9",
3
+ "version": "0.8.0",
4
4
  "description": "AI Coder Server - Manages Docker containers for AI agent task execution",
5
5
  "main": "dist/start.js",
6
6
  "type": "module",