@profoundlogic/coderflow-server 0.9.1 → 0.9.2

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 (186) hide show
  1. package/dist/coder-server.js +1 -1
  2. package/dist/config/skill-catalog.json +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/slack-service.js +1 -1
  85. package/dist/lib/state-capture.js +1 -1
  86. package/dist/lib/static-files.js +1 -1
  87. package/dist/lib/task-aliases.js +1 -1
  88. package/dist/lib/task-container-init.js +1 -1
  89. package/dist/lib/task-context-usage.js +1 -1
  90. package/dist/lib/task-git-auth-errors.js +1 -1
  91. package/dist/lib/task-name-format.js +1 -1
  92. package/dist/lib/task-name-generator.js +1 -1
  93. package/dist/lib/task-source-metadata.js +1 -1
  94. package/dist/lib/teams.js +1 -1
  95. package/dist/lib/user-git-oauth.js +1 -1
  96. package/dist/lib/user-git-tokens.js +1 -1
  97. package/dist/lib/users.js +1 -1
  98. package/dist/middleware/requireAuth.js +1 -1
  99. package/dist/middleware/requireInit.js +1 -1
  100. package/dist/middleware/requirePermission.js +1 -1
  101. package/dist/package.json +1 -1
  102. package/dist/playwright.config.js +1 -1
  103. package/dist/playwright.task-terminal.config.js +1 -1
  104. package/dist/routes/apiKeys.js +1 -1
  105. package/dist/routes/auth-oidc.js +1 -1
  106. package/dist/routes/auth.js +1 -1
  107. package/dist/routes/automations.js +1 -1
  108. package/dist/routes/bindings.js +1 -1
  109. package/dist/routes/build.js +1 -1
  110. package/dist/routes/containers.js +1 -1
  111. package/dist/routes/deploy-task.js +1 -1
  112. package/dist/routes/environment-management.js +1 -1
  113. package/dist/routes/environments.js +1 -1
  114. package/dist/routes/external-skills.js +1 -1
  115. package/dist/routes/git-credentials.js +1 -1
  116. package/dist/routes/git-oauth.js +1 -1
  117. package/dist/routes/git-provider-setup.js +1 -1
  118. package/dist/routes/health.js +1 -1
  119. package/dist/routes/jira.js +1 -1
  120. package/dist/routes/logs.js +1 -1
  121. package/dist/routes/objective-management.js +1 -1
  122. package/dist/routes/password.js +1 -1
  123. package/dist/routes/prompt.js +1 -1
  124. package/dist/routes/provider-auth.js +1 -1
  125. package/dist/routes/qa.js +1 -1
  126. package/dist/routes/roles.js +1 -1
  127. package/dist/routes/settings.js +1 -1
  128. package/dist/routes/skill-management.js +1 -1
  129. package/dist/routes/skills.js +1 -1
  130. package/dist/routes/slack.js +1 -1
  131. package/dist/routes/stats.js +1 -1
  132. package/dist/routes/tasks.js +1 -1
  133. package/dist/routes/teams.js +1 -1
  134. package/dist/routes/templates.js +1 -1
  135. package/dist/routes/test-task.js +1 -1
  136. package/dist/routes/test.js +1 -1
  137. package/dist/routes/users.js +1 -1
  138. package/dist/routes/visualizations.js +1 -1
  139. package/dist/scripts/create-user.js +1 -1
  140. package/dist/scripts/migrate-config-to-data-dir.js +1 -1
  141. package/dist/start.js +1 -1
  142. package/dist/web-ui/public/activity-detail-modal.js +1 -1
  143. package/dist/web-ui/public/activity-feed.js +1 -1
  144. package/dist/web-ui/public/activity-formatters.js +1 -1
  145. package/dist/web-ui/public/admin.js +1 -1
  146. package/dist/web-ui/public/agent-event-parser.js +1 -1
  147. package/dist/web-ui/public/app.js +1 -1
  148. package/dist/web-ui/public/approve-dialog.js +1 -1
  149. package/dist/web-ui/public/automation-links.js +1 -1
  150. package/dist/web-ui/public/automation-schedule.js +1 -1
  151. package/dist/web-ui/public/comments-widget.js +1 -1
  152. package/dist/web-ui/public/diff-utils.js +1 -1
  153. package/dist/web-ui/public/docs/admin/automations.md +2 -1
  154. package/dist/web-ui/public/docs/docsify-proxy-helper.js +1 -1
  155. package/dist/web-ui/public/environments.css +5 -0
  156. package/dist/web-ui/public/environments.html +4 -3
  157. package/dist/web-ui/public/environments.js +1 -1
  158. package/dist/web-ui/public/feedback-widget.js +1 -1
  159. package/dist/web-ui/public/file-selection-tree.js +1 -1
  160. package/dist/web-ui/public/git-history-lazy-utils.js +1 -1
  161. package/dist/web-ui/public/git-history.js +1 -1
  162. package/dist/web-ui/public/git-status.js +1 -1
  163. package/dist/web-ui/public/ibmi-file-filter.js +1 -1
  164. package/dist/web-ui/public/index.js +1 -1
  165. package/dist/web-ui/public/login.js +1 -1
  166. package/dist/web-ui/public/markdown-editor.js +1 -1
  167. package/dist/web-ui/public/markdown-file-editor.js +1 -1
  168. package/dist/web-ui/public/modal-maximize.js +1 -1
  169. package/dist/web-ui/public/notifications.js +1 -1
  170. package/dist/web-ui/public/permissions.js +1 -1
  171. package/dist/web-ui/public/pr-dialog.js +1 -1
  172. package/dist/web-ui/public/roles.js +1 -1
  173. package/dist/web-ui/public/settings.js +1 -1
  174. package/dist/web-ui/public/setup-password.js +1 -1
  175. package/dist/web-ui/public/skills.js +1 -1
  176. package/dist/web-ui/public/sse-client.js +1 -1
  177. package/dist/web-ui/public/sse-client.transport-warning.js +1 -1
  178. package/dist/web-ui/public/sse-shared-worker.js +1 -1
  179. package/dist/web-ui/public/task-judging-helpers.js +1 -1
  180. package/dist/web-ui/public/task.js +1 -1
  181. package/dist/web-ui/public/teams.js +1 -1
  182. package/dist/web-ui/public/terminal.js +1 -1
  183. package/dist/web-ui/public/theme.js +1 -1
  184. package/dist/web-ui/public/users.js +1 -1
  185. package/dist/web-ui/public/variant-grouping.js +1 -1
  186. 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 _0x842c23=state['currentUser'];if(!Permissions['hasServerPermission'](_0x842c23,'teams:view')&&!Permissions['hasTeamPermission'](_0x842c23,'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'](_0x842c23,'*')||Permissions['hasTeamPermission'](_0x842c23,'teams:manage'))&&(document['getElementById']('create-team-btn')['hidden']=![]),bindEventListeners(),await Promise['all']([loadTeams(),loadUsers(),loadRoles(),loadEnvironments()]),renderTeams();});async function loadTeams(){const _0xaac75d=document['getElementById']('teams-loading'),_0x5bb4f3=document['getElementById']('teams-error'),_0x44418e=document['getElementById']('teams-content');try{_0xaac75d['hidden']=![],_0x5bb4f3['hidden']=!![],_0x44418e['hidden']=!![];const {teams:_0x1c7591}=await API['getTeams']();state['teams']=_0x1c7591||[],renderTeams(),_0xaac75d['hidden']=!![],_0x44418e['hidden']=![];}catch(_0xdfd0a1){_0xaac75d['hidden']=!![],_0x5bb4f3['hidden']=![],document['getElementById']('teams-error-message')['textContent']=_0xdfd0a1['message'];}}async function loadUsers(){try{const {users:_0x235a36}=await API['getUsers']();state['users']=_0x235a36||[];}catch{state['users']=[];}}async function loadRoles(){try{const {roles:_0x3366cc}=await API['getRoleDefinitions']();state['roles']=_0x3366cc||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x36d53b=await API['getEnvironments']();state['environments']=_0x36d53b['environments']||[];}catch{state['environments']=[];}}function renderTeams(){const _0x27f904=document['getElementById']('teams-table-body'),_0x539e58=document['getElementById']('team-count');if(!_0x27f904)return;_0x539e58&&(_0x539e58['textContent']=state['teams']['length']+'\x20team'+(state['teams']['length']===0x1?'':'s'));if(state['teams']['length']===0x0){_0x27f904['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 _0xf3dd8f=Permissions['hasServerPermission'](state['currentUser'],'*');_0x27f904['innerHTML']=state['teams']['map'](_0x4f0b15=>{const _0x580607=_0xf3dd8f||_0x4f0b15['canManageTeam'],_0x574eaf=_0xf3dd8f||_0x4f0b15['canManageMembers'],_0x5bfb66=_0x580607||_0x574eaf,_0x507009=(_0x4f0b15['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'](_0x4f0b15['name'])+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x4f0b15['description']?'<div\x20style=\x22font-size:\x200.8em;\x20color:\x20var(--color-text-secondary);\x20margin-top:\x200.15rem;\x22>'+Utils['escapeHtml'](_0x4f0b15['description'])+'</div>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+_0x507009+'</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'+(_0x5bfb66?'<button\x20class=\x22btn-icon\x22\x20title=\x22Edit\x20team\x22\x20onclick=\x22window.openTeamModal(\x27'+_0x4f0b15['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'+(_0x580607?'<button\x20class=\x22btn-icon\x22\x20title=\x22Access\x20bindings\x22\x20onclick=\x22window.openBindingsModal(\x27'+_0x4f0b15['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'+(_0x580607?'<button\x20class=\x22btn-icon\x20btn-danger\x22\x20title=\x22Delete\x20team\x22\x20onclick=\x22window.deleteTeam(\x27'+_0x4f0b15['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(_0x36c694){const _0x110ce6=state['teams']['find'](_0x5c920a=>_0x5c920a['id']===_0x36c694);if(!_0x110ce6)return;state['editingTeamId']=_0x36c694;const _0x2811b1=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x21aa4b=_0x2811b1||_0x110ce6['canManageTeam'],_0x32fd6e=_0x2811b1||_0x110ce6['canManageMembers'],_0x200394=_0x21aa4b,_0x3f5283=_0x21aa4b||_0x32fd6e,_0x415279=_0x110ce6['name'],_0x498d87=_0x110ce6['description']||'';state['modalSnapshot']={'name':_0x415279,'description':_0x498d87},document['getElementById']('team-modal-title')['textContent']=_0x415279,document['getElementById']('team-name')['value']=_0x415279,document['getElementById']('team-name')['disabled']=!_0x200394,document['getElementById']('team-description')['value']=_0x498d87,document['getElementById']('team-description')['disabled']=!_0x200394,document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=![],document['getElementById']('save-team')['hidden']=!_0x200394,renderMembersList(_0x110ce6),updateMemberSelect(_0x110ce6),document['getElementById']('team-modal')['hidden']=![];};function isTeamModalDirty(){if(!state['modalSnapshot'])return![];const _0x3c6999=document['getElementById']('team-name')['value']['trim'](),_0x5c640c=document['getElementById']('team-description')['value']['trim']();return _0x3c6999!==state['modalSnapshot']['name']||_0x5c640c!==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(_0x28eb86){const _0x18e36c=state['teams']['find'](_0xa2085e=>_0xa2085e['id']===_0x28eb86);if(!_0x18e36c)return;state['bindingsTeamId']=_0x28eb86,document['getElementById']('bindings-modal-title')['textContent']='Access\x20Bindings\x20—\x20'+_0x18e36c['name'],document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('bindings-modal')['hidden']=![],loadTeamBindings(_0x28eb86);};function hideBindingsModal(){document['getElementById']('bindings-modal')['hidden']=!![],state['bindingsTeamId']=null;}function renderMembersList(_0x198be6){const _0x3525bf=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x396852=_0x3525bf||_0x198be6['canManageMembers']||_0x198be6['canManageTeam'],_0x13e343=_0x198be6['members']||[],_0x7471c9=document['getElementById']('members-list');if(_0x13e343['length']===0x0){_0x7471c9['innerHTML']='<p\x20style=\x22font-size:\x200.875rem;\x20color:\x20var(--color-text-secondary);\x20margin:\x200.25rem\x200;\x22>No\x20members\x20yet</p>';return;}_0x7471c9['innerHTML']=_0x13e343['map'](_0x379188=>{const _0x3d7e12=state['users']['find'](_0x1db81d=>_0x1db81d['id']===_0x379188),_0x1883d4=_0x3d7e12?''+Utils['escapeHtml'](_0x3d7e12['username'])+(_0x3d7e12['name']?'\x20<span\x20style=\x22color:\x20var(--color-text-secondary);\x20font-size:\x200.85em;\x22>('+Utils['escapeHtml'](_0x3d7e12['name'])+')</span>':''):Utils['escapeHtml'](_0x379188);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'+_0x1883d4+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x396852?'<button\x20type=\x22button\x22\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.removeMemberClick(\x27'+_0x379188+'\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 _0x20e0ab=document['getElementById']('add-member-row');if(_0x20e0ab)_0x20e0ab['style']['display']=_0x396852?'flex':'none';}function updateMemberSelect(_0x36ac07){const _0x4ae84b=document['getElementById']('add-member-select');if(!_0x4ae84b)return;const _0x24f52f=new Set(_0x36ac07['members']||[]),_0x2f7e57=state['users']['filter'](_0x4feae5=>!_0x24f52f['has'](_0x4feae5['id']));_0x4ae84b['innerHTML']='<option\x20value=\x22\x22>Add\x20a\x20member…</option>'+_0x2f7e57['map'](_0x21d9a5=>'<option\x20value=\x22'+_0x21d9a5['id']+'\x22>'+Utils['escapeHtml'](_0x21d9a5['username'])+(_0x21d9a5['name']?'\x20('+Utils['escapeHtml'](_0x21d9a5['name'])+')':'')+'</option>')['join']('');}async function addMember(){const _0x297773=document['getElementById']('add-member-select'),_0x36775c=_0x297773['value'];if(!_0x36775c||!state['editingTeamId'])return;try{const {team:_0x2d8060}=await API['addTeamMember'](state['editingTeamId'],_0x36775c);syncTeamInState(_0x2d8060),renderMembersList(_0x2d8060),updateMemberSelect(_0x2d8060),_0x297773['value']='',Utils['showToast']('Member\x20added','success');}catch(_0x487589){Utils['showToast'](_0x487589['message'],'error');}}window['removeMemberClick']=async function(_0x31d193){if(!state['editingTeamId'])return;try{const {team:_0x3a13ac}=await API['removeTeamMember'](state['editingTeamId'],_0x31d193);syncTeamInState(_0x3a13ac),renderMembersList(_0x3a13ac),updateMemberSelect(_0x3a13ac),Utils['showToast']('Member\x20removed','success');}catch(_0x59e887){Utils['showToast'](_0x59e887['message'],'error');}};async function loadTeamBindings(_0xe70225){const _0x49a7cd=document['getElementById']('bindings-loading'),_0x2c0aaa=document['getElementById']('bindings-empty'),_0x35b9a7=document['getElementById']('bindings-list-container'),_0x3cbd1f=document['getElementById']('add-binding-btn');_0x49a7cd['hidden']=![],_0x2c0aaa['hidden']=!![],_0x35b9a7['style']['display']='none',_0x3cbd1f['hidden']=!![],document['getElementById']('add-binding-form')['hidden']=!![];try{const {bindings:_0x4fe4f5}=await API['getBindings']({'subject_type':'team','subject_id':_0xe70225});state['teamBindings']=_0x4fe4f5||[],_0x49a7cd['hidden']=!![],state['teamBindings']['length']===0x0?_0x2c0aaa['hidden']=![]:(_0x35b9a7['style']['display']='',renderBindingsTable()),(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage'))&&(_0x3cbd1f['hidden']=![]);}catch(_0x444800){_0x49a7cd['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x444800['message'],'error');}}function renderBindingsTable(){const _0x48f6a0=document['getElementById']('bindings-table-body');if(!_0x48f6a0)return;const _0x4b04aa=Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage');_0x48f6a0['innerHTML']=state['teamBindings']['map'](_0x3e27ea=>{const _0x270491=_0x3e27ea['resource_type']==='server'?'Server':_0x3e27ea['resource_id']==='*'?'All\x20'+_0x3e27ea['resource_type']+'s':Utils['escapeHtml'](_0x3e27ea['resource_name']||_0x3e27ea['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x270491+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x3e27ea['role_name']||_0x3e27ea['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x4b04aa?'<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteBindingClick(\x27'+_0x3e27ea['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 _0x4e343a=document['getElementById']('binding-resource-type');_0x4e343a['value']='environment',updateBindingFormForResourceType('environment');}function onBindingResourceTypeChange(){const _0x5406ef=document['getElementById']('binding-resource-type')['value'];updateBindingFormForResourceType(_0x5406ef);}function updateBindingFormForResourceType(_0x1a44e1){const _0x5d2971=document['getElementById']('binding-resource-container'),_0x226ada=document['getElementById']('binding-resource'),_0x214d6e=document['getElementById']('binding-role');if(_0x1a44e1==='server')_0x5d2971['style']['display']='none';else{_0x5d2971['style']['display']='';if(_0x1a44e1==='environment'){const _0x2b18a6=new Set(state['teamBindings']['filter'](_0x5a6ab2=>_0x5a6ab2['resource_type']==='environment')['map'](_0xdbe42d=>_0xdbe42d['resource_id'])),_0x189b6e=state['environments']['filter'](_0x3e6005=>!_0x2b18a6['has'](_0x3e6005['name']));_0x226ada['innerHTML']=_0x189b6e['length']?_0x189b6e['map'](_0x3cefe4=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x3cefe4['name'])+'\x22>'+Utils['escapeHtml'](_0x3cefe4['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x1a44e1==='team'){const _0x1ae298=new Set(state['teamBindings']['filter'](_0x29e23f=>_0x29e23f['resource_type']==='team')['map'](_0xb131c=>_0xb131c['resource_id'])),_0x2ba614=state['teams']['filter'](_0x223a2a=>!_0x1ae298['has'](_0x223a2a['id']));_0x226ada['innerHTML']=_0x2ba614['length']?_0x2ba614['map'](_0x24f13e=>'<option\x20value=\x22'+_0x24f13e['id']+'\x22>'+Utils['escapeHtml'](_0x24f13e['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x5977c1=state['roles']['filter'](_0x9d4cbb=>_0x9d4cbb['resource_type']===_0x1a44e1);_0x214d6e['innerHTML']=_0x5977c1['length']?_0x5977c1['filter'](_0x254ab4=>{const _0x1d35f3=_0x1a44e1==='server'?undefined:_0x226ada['value'];return!state['teamBindings']['some'](_0x6f4285=>_0x6f4285['resource_type']===_0x1a44e1&&_0x6f4285['role_id']===_0x254ab4['id']&&(_0x1a44e1==='server'||_0x6f4285['resource_id']===_0x1d35f3));})['map'](_0x2dc173=>'<option\x20value=\x22'+_0x2dc173['id']+'\x22>'+Utils['escapeHtml'](_0x2dc173['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 _0x418ceb=document['getElementById']('binding-resource-type')['value'],_0x4af929=document['getElementById']('binding-role')['value'];if(!_0x4af929||!state['bindingsTeamId'])return;const _0x3e76bb=_0x418ceb==='server'?undefined:document['getElementById']('binding-resource')['value'];if(_0x418ceb!=='server'&&!_0x3e76bb)return;const _0x46c59f=document['getElementById']('save-binding-btn');_0x46c59f['disabled']=!![],_0x46c59f['textContent']='Adding…';try{const _0x4bd822={'subject_type':'team','subject_id':state['bindingsTeamId'],'role_id':_0x4af929,'resource_type':_0x418ceb};if(_0x3e76bb)_0x4bd822['resource_id']=_0x3e76bb;await API['createBinding'](_0x4bd822),Utils['showToast']('Binding\x20added','success'),document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![],await loadTeamBindings(state['bindingsTeamId']);}catch(_0x39fa1f){Utils['showToast'](_0x39fa1f['message'],'error');}finally{_0x46c59f['disabled']=![],_0x46c59f['textContent']='Add\x20Binding';}}window['deleteBindingClick']=async function(_0x3eb411){try{await API['deleteBinding'](_0x3eb411),Utils['showToast']('Binding\x20removed','success'),await loadTeamBindings(state['bindingsTeamId']);}catch(_0x1a0c47){Utils['showToast'](_0x1a0c47['message'],'error');}};async function saveTeam(){const _0x5d443d=document['getElementById']('team-name')['value']['trim'](),_0x291e89=document['getElementById']('team-description')['value']['trim'](),_0x1dcd84=document['getElementById']('team-form-error'),_0x2fffe3=document['getElementById']('save-team');if(!_0x5d443d){_0x1dcd84['textContent']='Team\x20name\x20is\x20required',_0x1dcd84['hidden']=![];return;}_0x1dcd84['hidden']=!![];const _0x2a2386=_0x2fffe3['textContent'];_0x2fffe3['disabled']=!![],_0x2fffe3['textContent']=state['editingTeamId']?'Saving…':'Creating…';try{if(state['editingTeamId']){const {team:_0x372d8b}=await API['updateTeam'](state['editingTeamId'],{'name':_0x5d443d,'description':_0x291e89});syncTeamInState(_0x372d8b),document['getElementById']('team-modal-title')['textContent']=_0x372d8b['name'],Utils['showToast']('Team\x20updated','success');}else await API['createTeam']({'name':_0x5d443d,'description':_0x291e89}),Utils['showToast']('Team\x20created','success');_0x2fffe3['disabled']=![],_0x2fffe3['textContent']=_0x2a2386,hideTeamModal(),await loadTeams();}catch(_0x74cf5c){_0x1dcd84['textContent']=_0x74cf5c['message'],_0x1dcd84['hidden']=![],_0x2fffe3['disabled']=![],_0x2fffe3['textContent']=_0x2a2386;}}window['deleteTeam']=function(_0x5bb6bf){const _0x5c65b0=state['teams']['find'](_0x5f5d7b=>_0x5f5d7b['id']===_0x5bb6bf);if(!_0x5c65b0)return;state['deletingTeamId']=_0x5bb6bf,document['getElementById']('delete-team-name')['textContent']=_0x5c65b0['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 _0xc2fa26=document['getElementById']('confirm-delete-team');_0xc2fa26['disabled']=!![],_0xc2fa26['textContent']='Deleting…';try{await API['deleteTeam'](state['deletingTeamId']),Utils['showToast']('Team\x20deleted','success'),_0xc2fa26['disabled']=![],_0xc2fa26['textContent']='Delete\x20Team',hideDeleteModal(),await loadTeams();}catch(_0x2a9479){Utils['showToast']('Failed\x20to\x20delete\x20team:\x20'+_0x2a9479['message'],'error'),_0xc2fa26['disabled']=![],_0xc2fa26['textContent']='Delete\x20Team';}}function syncTeamInState(_0x53697c){const _0x1f39d3=state['teams']['findIndex'](_0x1c514a=>_0x1c514a['id']===_0x53697c['id']);if(_0x1f39d3>=0x0)state['teams'][_0x1f39d3]=_0x53697c;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 _0x2dc8f5=state['currentUser'];if(!Permissions['hasServerPermission'](_0x2dc8f5,'teams:view')&&!Permissions['hasTeamPermission'](_0x2dc8f5,'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'](_0x2dc8f5,'*')||Permissions['hasTeamPermission'](_0x2dc8f5,'teams:manage'))&&(document['getElementById']('create-team-btn')['hidden']=![]),bindEventListeners(),await Promise['all']([loadTeams(),loadUsers(),loadRoles(),loadEnvironments()]),renderTeams();});async function loadTeams(){const _0x2b250b=document['getElementById']('teams-loading'),_0x3a75ca=document['getElementById']('teams-error'),_0x1a94d0=document['getElementById']('teams-content');try{_0x2b250b['hidden']=![],_0x3a75ca['hidden']=!![],_0x1a94d0['hidden']=!![];const {teams:_0x2d092e}=await API['getTeams']();state['teams']=_0x2d092e||[],renderTeams(),_0x2b250b['hidden']=!![],_0x1a94d0['hidden']=![];}catch(_0x5e458b){_0x2b250b['hidden']=!![],_0x3a75ca['hidden']=![],document['getElementById']('teams-error-message')['textContent']=_0x5e458b['message'];}}async function loadUsers(){try{const {users:_0x194c60}=await API['getUsers']();state['users']=_0x194c60||[];}catch{state['users']=[];}}async function loadRoles(){try{const {roles:_0x1bef6e}=await API['getRoleDefinitions']();state['roles']=_0x1bef6e||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x133298=await API['getEnvironments']();state['environments']=_0x133298['environments']||[];}catch{state['environments']=[];}}function renderTeams(){const _0x33b86b=document['getElementById']('teams-table-body'),_0x342996=document['getElementById']('team-count');if(!_0x33b86b)return;_0x342996&&(_0x342996['textContent']=state['teams']['length']+'\x20team'+(state['teams']['length']===0x1?'':'s'));if(state['teams']['length']===0x0){_0x33b86b['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 _0x25bfaa=Permissions['hasServerPermission'](state['currentUser'],'*');_0x33b86b['innerHTML']=state['teams']['map'](_0x2e96db=>{const _0x23b971=_0x25bfaa||_0x2e96db['canManageTeam'],_0x282f45=_0x25bfaa||_0x2e96db['canManageMembers'],_0x8d92e5=_0x23b971||_0x282f45,_0x2927ec=(_0x2e96db['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'](_0x2e96db['name'])+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x2e96db['description']?'<div\x20style=\x22font-size:\x200.8em;\x20color:\x20var(--color-text-secondary);\x20margin-top:\x200.15rem;\x22>'+Utils['escapeHtml'](_0x2e96db['description'])+'</div>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+_0x2927ec+'</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'+(_0x8d92e5?'<button\x20class=\x22btn-icon\x22\x20title=\x22Edit\x20team\x22\x20onclick=\x22window.openTeamModal(\x27'+_0x2e96db['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'+(_0x23b971?'<button\x20class=\x22btn-icon\x22\x20title=\x22Access\x20bindings\x22\x20onclick=\x22window.openBindingsModal(\x27'+_0x2e96db['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'+(_0x23b971?'<button\x20class=\x22btn-icon\x20btn-danger\x22\x20title=\x22Delete\x20team\x22\x20onclick=\x22window.deleteTeam(\x27'+_0x2e96db['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(_0x525a02){const _0x47641d=state['teams']['find'](_0x3a47e7=>_0x3a47e7['id']===_0x525a02);if(!_0x47641d)return;state['editingTeamId']=_0x525a02;const _0x3edd34=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x37b8e0=_0x3edd34||_0x47641d['canManageTeam'],_0x2cc4b9=_0x3edd34||_0x47641d['canManageMembers'],_0x18cb41=_0x37b8e0,_0x423359=_0x37b8e0||_0x2cc4b9,_0x4f1e4a=_0x47641d['name'],_0x5126fd=_0x47641d['description']||'';state['modalSnapshot']={'name':_0x4f1e4a,'description':_0x5126fd},document['getElementById']('team-modal-title')['textContent']=_0x4f1e4a,document['getElementById']('team-name')['value']=_0x4f1e4a,document['getElementById']('team-name')['disabled']=!_0x18cb41,document['getElementById']('team-description')['value']=_0x5126fd,document['getElementById']('team-description')['disabled']=!_0x18cb41,document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=![],document['getElementById']('save-team')['hidden']=!_0x18cb41,renderMembersList(_0x47641d),updateMemberSelect(_0x47641d),document['getElementById']('team-modal')['hidden']=![];};function isTeamModalDirty(){if(!state['modalSnapshot'])return![];const _0x3a1753=document['getElementById']('team-name')['value']['trim'](),_0x22912b=document['getElementById']('team-description')['value']['trim']();return _0x3a1753!==state['modalSnapshot']['name']||_0x22912b!==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(_0x9887d2){const _0x4b9b26=state['teams']['find'](_0x2932dc=>_0x2932dc['id']===_0x9887d2);if(!_0x4b9b26)return;state['bindingsTeamId']=_0x9887d2,document['getElementById']('bindings-modal-title')['textContent']='Access\x20Bindings\x20—\x20'+_0x4b9b26['name'],document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('bindings-modal')['hidden']=![],loadTeamBindings(_0x9887d2);};function hideBindingsModal(){document['getElementById']('bindings-modal')['hidden']=!![],state['bindingsTeamId']=null;}function renderMembersList(_0x4bef50){const _0x298745=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x12bcee=_0x298745||_0x4bef50['canManageMembers']||_0x4bef50['canManageTeam'],_0x16af3d=_0x4bef50['members']||[],_0xf2b0f4=document['getElementById']('members-list');if(_0x16af3d['length']===0x0){_0xf2b0f4['innerHTML']='<p\x20style=\x22font-size:\x200.875rem;\x20color:\x20var(--color-text-secondary);\x20margin:\x200.25rem\x200;\x22>No\x20members\x20yet</p>';return;}_0xf2b0f4['innerHTML']=_0x16af3d['map'](_0x436c40=>{const _0x460823=state['users']['find'](_0x3cd8e6=>_0x3cd8e6['id']===_0x436c40),_0x638961=_0x460823?''+Utils['escapeHtml'](_0x460823['username'])+(_0x460823['name']?'\x20<span\x20style=\x22color:\x20var(--color-text-secondary);\x20font-size:\x200.85em;\x22>('+Utils['escapeHtml'](_0x460823['name'])+')</span>':''):Utils['escapeHtml'](_0x436c40);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'+_0x638961+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x12bcee?'<button\x20type=\x22button\x22\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.removeMemberClick(\x27'+_0x436c40+'\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 _0x28b1d3=document['getElementById']('add-member-row');if(_0x28b1d3)_0x28b1d3['style']['display']=_0x12bcee?'flex':'none';}function updateMemberSelect(_0x27742c){const _0x3b09b7=document['getElementById']('add-member-select');if(!_0x3b09b7)return;const _0x3156e5=new Set(_0x27742c['members']||[]),_0x29e288=state['users']['filter'](_0x5e64de=>!_0x3156e5['has'](_0x5e64de['id']));_0x3b09b7['innerHTML']='<option\x20value=\x22\x22>Add\x20a\x20member…</option>'+_0x29e288['map'](_0x263d7d=>'<option\x20value=\x22'+_0x263d7d['id']+'\x22>'+Utils['escapeHtml'](_0x263d7d['username'])+(_0x263d7d['name']?'\x20('+Utils['escapeHtml'](_0x263d7d['name'])+')':'')+'</option>')['join']('');}async function addMember(){const _0x4173f1=document['getElementById']('add-member-select'),_0x481cd7=_0x4173f1['value'];if(!_0x481cd7||!state['editingTeamId'])return;try{const {team:_0x35f13a}=await API['addTeamMember'](state['editingTeamId'],_0x481cd7);syncTeamInState(_0x35f13a),renderMembersList(_0x35f13a),updateMemberSelect(_0x35f13a),_0x4173f1['value']='',Utils['showToast']('Member\x20added','success');}catch(_0x537a1e){Utils['showToast'](_0x537a1e['message'],'error');}}window['removeMemberClick']=async function(_0x11ff72){if(!state['editingTeamId'])return;try{const {team:_0x2b95b9}=await API['removeTeamMember'](state['editingTeamId'],_0x11ff72);syncTeamInState(_0x2b95b9),renderMembersList(_0x2b95b9),updateMemberSelect(_0x2b95b9),Utils['showToast']('Member\x20removed','success');}catch(_0x568ebf){Utils['showToast'](_0x568ebf['message'],'error');}};async function loadTeamBindings(_0x4340d3){const _0x2f7729=document['getElementById']('bindings-loading'),_0x18ffad=document['getElementById']('bindings-empty'),_0x1f8a15=document['getElementById']('bindings-list-container'),_0x51117a=document['getElementById']('add-binding-btn');_0x2f7729['hidden']=![],_0x18ffad['hidden']=!![],_0x1f8a15['style']['display']='none',_0x51117a['hidden']=!![],document['getElementById']('add-binding-form')['hidden']=!![];try{const {bindings:_0x2f6da4}=await API['getBindings']({'subject_type':'team','subject_id':_0x4340d3});state['teamBindings']=_0x2f6da4||[],_0x2f7729['hidden']=!![],state['teamBindings']['length']===0x0?_0x18ffad['hidden']=![]:(_0x1f8a15['style']['display']='',renderBindingsTable()),(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage'))&&(_0x51117a['hidden']=![]);}catch(_0x4d47a7){_0x2f7729['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x4d47a7['message'],'error');}}function renderBindingsTable(){const _0x997fb8=document['getElementById']('bindings-table-body');if(!_0x997fb8)return;const _0x32050=Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage');_0x997fb8['innerHTML']=state['teamBindings']['map'](_0x27ae63=>{const _0x511266=_0x27ae63['resource_type']==='server'?'Server':_0x27ae63['resource_id']==='*'?'All\x20'+_0x27ae63['resource_type']+'s':Utils['escapeHtml'](_0x27ae63['resource_name']||_0x27ae63['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x511266+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x27ae63['role_name']||_0x27ae63['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x32050?'<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteBindingClick(\x27'+_0x27ae63['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 _0x1189e3=document['getElementById']('binding-resource-type');_0x1189e3['value']='environment',updateBindingFormForResourceType('environment');}function onBindingResourceTypeChange(){const _0x414ba2=document['getElementById']('binding-resource-type')['value'];updateBindingFormForResourceType(_0x414ba2);}function updateBindingFormForResourceType(_0x481141){const _0x29838a=document['getElementById']('binding-resource-container'),_0xf7e80=document['getElementById']('binding-resource'),_0x59906c=document['getElementById']('binding-role');if(_0x481141==='server')_0x29838a['style']['display']='none';else{_0x29838a['style']['display']='';if(_0x481141==='environment'){const _0x4ff422=new Set(state['teamBindings']['filter'](_0x55ca95=>_0x55ca95['resource_type']==='environment')['map'](_0x3790ca=>_0x3790ca['resource_id'])),_0x192a22=state['environments']['filter'](_0x2b8780=>!_0x4ff422['has'](_0x2b8780['name']));_0xf7e80['innerHTML']=_0x192a22['length']?_0x192a22['map'](_0x27f1dd=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x27f1dd['name'])+'\x22>'+Utils['escapeHtml'](_0x27f1dd['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x481141==='team'){const _0x3546c3=new Set(state['teamBindings']['filter'](_0x1daaf4=>_0x1daaf4['resource_type']==='team')['map'](_0x2c650e=>_0x2c650e['resource_id'])),_0x2215b8=state['teams']['filter'](_0x3f12fb=>!_0x3546c3['has'](_0x3f12fb['id']));_0xf7e80['innerHTML']=_0x2215b8['length']?_0x2215b8['map'](_0x19ed94=>'<option\x20value=\x22'+_0x19ed94['id']+'\x22>'+Utils['escapeHtml'](_0x19ed94['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x20beb3=state['roles']['filter'](_0x6c26f0=>_0x6c26f0['resource_type']===_0x481141);_0x59906c['innerHTML']=_0x20beb3['length']?_0x20beb3['filter'](_0x1646af=>{const _0x36b800=_0x481141==='server'?undefined:_0xf7e80['value'];return!state['teamBindings']['some'](_0x3ab399=>_0x3ab399['resource_type']===_0x481141&&_0x3ab399['role_id']===_0x1646af['id']&&(_0x481141==='server'||_0x3ab399['resource_id']===_0x36b800));})['map'](_0x21eac6=>'<option\x20value=\x22'+_0x21eac6['id']+'\x22>'+Utils['escapeHtml'](_0x21eac6['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 _0x5010cd=document['getElementById']('binding-resource-type')['value'],_0x556446=document['getElementById']('binding-role')['value'];if(!_0x556446||!state['bindingsTeamId'])return;const _0x6032c6=_0x5010cd==='server'?undefined:document['getElementById']('binding-resource')['value'];if(_0x5010cd!=='server'&&!_0x6032c6)return;const _0x489eaf=document['getElementById']('save-binding-btn');_0x489eaf['disabled']=!![],_0x489eaf['textContent']='Adding…';try{const _0x29477a={'subject_type':'team','subject_id':state['bindingsTeamId'],'role_id':_0x556446,'resource_type':_0x5010cd};if(_0x6032c6)_0x29477a['resource_id']=_0x6032c6;await API['createBinding'](_0x29477a),Utils['showToast']('Binding\x20added','success'),document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![],await loadTeamBindings(state['bindingsTeamId']);}catch(_0xf48cdf){Utils['showToast'](_0xf48cdf['message'],'error');}finally{_0x489eaf['disabled']=![],_0x489eaf['textContent']='Add\x20Binding';}}window['deleteBindingClick']=async function(_0x56377e){try{await API['deleteBinding'](_0x56377e),Utils['showToast']('Binding\x20removed','success'),await loadTeamBindings(state['bindingsTeamId']);}catch(_0x304273){Utils['showToast'](_0x304273['message'],'error');}};async function saveTeam(){const _0x2587ff=document['getElementById']('team-name')['value']['trim'](),_0x4dad4c=document['getElementById']('team-description')['value']['trim'](),_0x4b4a1a=document['getElementById']('team-form-error'),_0x1011b5=document['getElementById']('save-team');if(!_0x2587ff){_0x4b4a1a['textContent']='Team\x20name\x20is\x20required',_0x4b4a1a['hidden']=![];return;}_0x4b4a1a['hidden']=!![];const _0x3bfac5=_0x1011b5['textContent'];_0x1011b5['disabled']=!![],_0x1011b5['textContent']=state['editingTeamId']?'Saving…':'Creating…';try{if(state['editingTeamId']){const {team:_0x4999c3}=await API['updateTeam'](state['editingTeamId'],{'name':_0x2587ff,'description':_0x4dad4c});syncTeamInState(_0x4999c3),document['getElementById']('team-modal-title')['textContent']=_0x4999c3['name'],Utils['showToast']('Team\x20updated','success');}else await API['createTeam']({'name':_0x2587ff,'description':_0x4dad4c}),Utils['showToast']('Team\x20created','success');_0x1011b5['disabled']=![],_0x1011b5['textContent']=_0x3bfac5,hideTeamModal(),await loadTeams();}catch(_0x142923){_0x4b4a1a['textContent']=_0x142923['message'],_0x4b4a1a['hidden']=![],_0x1011b5['disabled']=![],_0x1011b5['textContent']=_0x3bfac5;}}window['deleteTeam']=function(_0x21c555){const _0x3a5684=state['teams']['find'](_0x16ada4=>_0x16ada4['id']===_0x21c555);if(!_0x3a5684)return;state['deletingTeamId']=_0x21c555,document['getElementById']('delete-team-name')['textContent']=_0x3a5684['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 _0x5f31a6=document['getElementById']('confirm-delete-team');_0x5f31a6['disabled']=!![],_0x5f31a6['textContent']='Deleting…';try{await API['deleteTeam'](state['deletingTeamId']),Utils['showToast']('Team\x20deleted','success'),_0x5f31a6['disabled']=![],_0x5f31a6['textContent']='Delete\x20Team',hideDeleteModal(),await loadTeams();}catch(_0x4e6cb8){Utils['showToast']('Failed\x20to\x20delete\x20team:\x20'+_0x4e6cb8['message'],'error'),_0x5f31a6['disabled']=![],_0x5f31a6['textContent']='Delete\x20Team';}}function syncTeamInState(_0x19fe57){const _0x43a38a=state['teams']['findIndex'](_0x2b0ba6=>_0x2b0ba6['id']===_0x19fe57['id']);if(_0x43a38a>=0x0)state['teams'][_0x43a38a]=_0x19fe57;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'](_0xd2aca9=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':_0xd2aca9}));});let commandSent=![],hasReceivedOutput=![];socket['addEventListener']('message',_0x376c82=>{try{const _0xb441d=JSON['parse'](_0x376c82['data']);if(_0xb441d['type']==='data'&&typeof _0xb441d['data']==='string')term['write'](_0xb441d['data']),!hasReceivedOutput&&_0xb441d['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(_0xb441d['type']==='status'&&_0xb441d['status']){if(_0xb441d['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'+_0xb441d['status'],_0xb441d['status']==='connected'?'success':'info');}else _0xb441d['type']==='error'&&_0xb441d['message']&&updateStatus(_0xb441d['message'],'error');}}catch(_0x5d7db6){console['error']('Failed\x20to\x20parse\x20terminal\x20message',_0x5d7db6);}}),socket['addEventListener']('close',_0x56c184=>{const _0x1a7bf0=_0x56c184['reason']||'Connection\x20closed';updateStatus(_0x1a7bf0,_0x56c184['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',_0x2bfea0=>{console['error']('Terminal\x20websocket\x20error',_0x2bfea0),updateStatus('Connection\x20error','error');});function sendResize(){if(socket['readyState']!==WebSocket['OPEN'])return;const _0x47c635=term['cols'],_0x28f205=term['rows'];socket['send'](JSON['stringify']({'type':'resize','cols':_0x47c635,'rows':_0x28f205}));}function updateStatus(_0x31d6d6,_0x4e72d5='info'){if(!statusEl)return;statusEl['textContent']=_0x31d6d6,statusEl['dataset']['variant']=_0x4e72d5;}async function enrichContainerDetails(_0x451a58){try{const _0x5411e7=await API['getContainer'](_0x451a58);updateTerminalDetails(_0x5411e7);}catch{try{const _0x5045a8=await API['getContainers'](),_0x296f35=(_0x5045a8['containers']||[])['find'](_0x531dac=>_0x531dac['containerId']===_0x451a58||_0x531dac['name']===_0x451a58||_0x531dac['fullContainerId']?.['startsWith'](_0x451a58));if(_0x296f35){updateTerminalDetails(_0x296f35);return;}subtitleEl['textContent']='Container\x20'+_0x451a58['substring'](0x0,0xc);}catch{subtitleEl['textContent']='Container\x20'+_0x451a58['substring'](0x0,0xc);}}}function updateTerminalDetails(_0x113707){const _0x5a04ab=_0x113707['containerId']||_0x113707['name']||_0x113707['fullContainerId']||containerId,_0x4345b6=_0x113707['environment']?'Environment\x20'+_0x113707['environment']:'Environment\x20unknown',_0x3f0d07=_0x113707['defaultAgent']?'\x20·\x20Agent\x20'+_0x113707['defaultAgent']:'',_0x2c84ea=_0x113707['createdAt']?'\x20·\x20Started\x20'+Utils['formatRelativeTime'](_0x113707['createdAt']):'';titleEl['textContent']='Terminal\x20·\x20'+_0x5a04ab['substring'](0x0,0xc);const _0x15e51d=command?'\x20·\x20Command\x20'+command:'';subtitleEl['textContent']=''+_0x4345b6+_0x3f0d07+_0x2c84ea+_0x15e51d;}
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'](_0x177f32=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':_0x177f32}));});let commandSent=![],hasReceivedOutput=![];socket['addEventListener']('message',_0x4fdece=>{try{const _0x1149cd=JSON['parse'](_0x4fdece['data']);if(_0x1149cd['type']==='data'&&typeof _0x1149cd['data']==='string')term['write'](_0x1149cd['data']),!hasReceivedOutput&&_0x1149cd['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(_0x1149cd['type']==='status'&&_0x1149cd['status']){if(_0x1149cd['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'+_0x1149cd['status'],_0x1149cd['status']==='connected'?'success':'info');}else _0x1149cd['type']==='error'&&_0x1149cd['message']&&updateStatus(_0x1149cd['message'],'error');}}catch(_0x30102b){console['error']('Failed\x20to\x20parse\x20terminal\x20message',_0x30102b);}}),socket['addEventListener']('close',_0x2604d2=>{const _0x59be10=_0x2604d2['reason']||'Connection\x20closed';updateStatus(_0x59be10,_0x2604d2['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',_0x4e4f8b=>{console['error']('Terminal\x20websocket\x20error',_0x4e4f8b),updateStatus('Connection\x20error','error');});function sendResize(){if(socket['readyState']!==WebSocket['OPEN'])return;const _0x2674b1=term['cols'],_0x24e5a6=term['rows'];socket['send'](JSON['stringify']({'type':'resize','cols':_0x2674b1,'rows':_0x24e5a6}));}function updateStatus(_0x3b4ce2,_0x820670='info'){if(!statusEl)return;statusEl['textContent']=_0x3b4ce2,statusEl['dataset']['variant']=_0x820670;}async function enrichContainerDetails(_0x22e8d3){try{const _0x36e3fe=await API['getContainer'](_0x22e8d3);updateTerminalDetails(_0x36e3fe);}catch{try{const _0x9f2cd1=await API['getContainers'](),_0x59f375=(_0x9f2cd1['containers']||[])['find'](_0x1c00ed=>_0x1c00ed['containerId']===_0x22e8d3||_0x1c00ed['name']===_0x22e8d3||_0x1c00ed['fullContainerId']?.['startsWith'](_0x22e8d3));if(_0x59f375){updateTerminalDetails(_0x59f375);return;}subtitleEl['textContent']='Container\x20'+_0x22e8d3['substring'](0x0,0xc);}catch{subtitleEl['textContent']='Container\x20'+_0x22e8d3['substring'](0x0,0xc);}}}function updateTerminalDetails(_0x54cb5b){const _0x21f44a=_0x54cb5b['containerId']||_0x54cb5b['name']||_0x54cb5b['fullContainerId']||containerId,_0xf99e57=_0x54cb5b['environment']?'Environment\x20'+_0x54cb5b['environment']:'Environment\x20unknown',_0x2a0173=_0x54cb5b['defaultAgent']?'\x20·\x20Agent\x20'+_0x54cb5b['defaultAgent']:'',_0x479c95=_0x54cb5b['createdAt']?'\x20·\x20Started\x20'+Utils['formatRelativeTime'](_0x54cb5b['createdAt']):'';titleEl['textContent']='Terminal\x20·\x20'+_0x21f44a['substring'](0x0,0xc);const _0xf893ef=command?'\x20·\x20Command\x20'+command:'';subtitleEl['textContent']=''+_0xf99e57+_0x2a0173+_0x479c95+_0xf893ef;}
@@ -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 _0x120267=localStorage['getItem'](THEME_STORAGE_KEY);if(_0x120267&&VALID_THEMES['has'](_0x120267))return _0x120267;}catch(_0x303550){console['warn']('[Theme]\x20Failed\x20to\x20read\x20stored\x20theme\x20preference:',_0x303550);}return null;}export function getPreferredTheme(){const _0x1b2dc1=readStoredTheme();if(_0x1b2dc1)return _0x1b2dc1;const _0x3a376a=window['matchMedia']&&window['matchMedia']('(prefers-color-scheme:\x20dark)')['matches'];return _0x3a376a?'dark':'light';}export function getCurrentTheme(){const _0xfa0bda=document['documentElement']['dataset']['theme'];if(_0xfa0bda&&VALID_THEMES['has'](_0xfa0bda))return _0xfa0bda;return getPreferredTheme();}export function applyTheme(_0x350721,{persist:persist=!![],emitEvent:emitEvent=!![]}={}){const _0x26d544=VALID_THEMES['has'](_0x350721)?_0x350721:'light';document['documentElement']['dataset']['theme']=_0x26d544,document['documentElement']['style']['colorScheme']=_0x26d544==='dark'?'dark':'light';if(persist)try{localStorage['setItem'](THEME_STORAGE_KEY,_0x26d544);}catch(_0x1c2021){console['warn']('[Theme]\x20Failed\x20to\x20persist\x20theme\x20preference:',_0x1c2021);}return emitEvent&&window['dispatchEvent'](new CustomEvent(THEME_CHANGE_EVENT,{'detail':{'theme':_0x26d544}})),_0x26d544;}export function initTheme(_0x54410e={}){const {emitEvent:emitEvent=![]}=_0x54410e;return applyTheme(getPreferredTheme(),{'persist':![],'emitEvent':emitEvent});}export function toggleTheme(){const _0x2d87a5=getCurrentTheme()==='dark'?'light':'dark';return applyTheme(_0x2d87a5);}export function onThemeChange(_0x46efd0,{runImmediately:runImmediately=![]}={}){const _0x3f8c2c=_0x518c6e=>{_0x46efd0(_0x518c6e['detail']['theme']);};return window['addEventListener'](THEME_CHANGE_EVENT,_0x3f8c2c),runImmediately&&_0x46efd0(getCurrentTheme()),()=>window['removeEventListener'](THEME_CHANGE_EVENT,_0x3f8c2c);}export function mountThemeToggle(_0x19b705={}){const {targetSelectors:targetSelectors=DEFAULT_TARGET_SELECTORS}=_0x19b705,_0x8a5082=targetSelectors['map'](_0x4e58e1=>document['querySelector'](_0x4e58e1))['find'](Boolean),_0x183b49=document['createElement']('button');_0x183b49['type']='button',_0x183b49['className']='btn-ghost\x20theme-toggle-btn',_0x183b49['id']='theme-toggle-btn',_0x183b49['setAttribute']('aria-pressed','false'),_0x183b49['style']['padding']='8px',_0x183b49['style']['lineHeight']='0',_0x183b49['style']['width']='36px',_0x183b49['style']['height']='36px',_0x183b49['style']['display']='flex',_0x183b49['style']['alignItems']='center',_0x183b49['style']['justifyContent']='center';const _0x2b0fe2=document['createElement']('span');_0x2b0fe2['className']='theme-icon',_0x2b0fe2['style']['display']='flex',_0x183b49['append'](_0x2b0fe2);const _0x221daa='<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>',_0x1bb288='<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>',_0x3fbf11=_0x209ded=>{const _0x1074a6=_0x209ded==='dark';_0x2b0fe2['innerHTML']=_0x1074a6?_0x221daa:_0x1bb288,_0x183b49['title']=_0x1074a6?'Switch\x20to\x20light\x20mode':'Switch\x20to\x20dark\x20mode',_0x183b49['dataset']['theme']=_0x209ded,_0x183b49['setAttribute']('aria-pressed',String(_0x1074a6));};return _0x183b49['addEventListener']('click',()=>{const _0x351b64=getCurrentTheme()==='dark'?'light':'dark';applyTheme(_0x351b64);}),_0x8a5082?_0x8a5082['appendChild'](_0x183b49):(_0x183b49['classList']['add']('theme-toggle-floating'),document['body']['appendChild'](_0x183b49)),_0x3fbf11(initTheme()),onThemeChange(_0x3fbf11),_0x183b49;}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 _0x111ff6=localStorage['getItem'](THEME_STORAGE_KEY);if(_0x111ff6&&VALID_THEMES['has'](_0x111ff6))return _0x111ff6;}catch(_0x55f485){console['warn']('[Theme]\x20Failed\x20to\x20read\x20stored\x20theme\x20preference:',_0x55f485);}return null;}export function getPreferredTheme(){const _0x9c3eb7=readStoredTheme();if(_0x9c3eb7)return _0x9c3eb7;const _0x597ebc=window['matchMedia']&&window['matchMedia']('(prefers-color-scheme:\x20dark)')['matches'];return _0x597ebc?'dark':'light';}export function getCurrentTheme(){const _0x4c7cb1=document['documentElement']['dataset']['theme'];if(_0x4c7cb1&&VALID_THEMES['has'](_0x4c7cb1))return _0x4c7cb1;return getPreferredTheme();}export function applyTheme(_0x57e6fb,{persist:persist=!![],emitEvent:emitEvent=!![]}={}){const _0x5d99ad=VALID_THEMES['has'](_0x57e6fb)?_0x57e6fb:'light';document['documentElement']['dataset']['theme']=_0x5d99ad,document['documentElement']['style']['colorScheme']=_0x5d99ad==='dark'?'dark':'light';if(persist)try{localStorage['setItem'](THEME_STORAGE_KEY,_0x5d99ad);}catch(_0x26a156){console['warn']('[Theme]\x20Failed\x20to\x20persist\x20theme\x20preference:',_0x26a156);}return emitEvent&&window['dispatchEvent'](new CustomEvent(THEME_CHANGE_EVENT,{'detail':{'theme':_0x5d99ad}})),_0x5d99ad;}export function initTheme(_0xdef17b={}){const {emitEvent:emitEvent=![]}=_0xdef17b;return applyTheme(getPreferredTheme(),{'persist':![],'emitEvent':emitEvent});}export function toggleTheme(){const _0x7192b1=getCurrentTheme()==='dark'?'light':'dark';return applyTheme(_0x7192b1);}export function onThemeChange(_0x29088c,{runImmediately:runImmediately=![]}={}){const _0x385689=_0x39ddc3=>{_0x29088c(_0x39ddc3['detail']['theme']);};return window['addEventListener'](THEME_CHANGE_EVENT,_0x385689),runImmediately&&_0x29088c(getCurrentTheme()),()=>window['removeEventListener'](THEME_CHANGE_EVENT,_0x385689);}export function mountThemeToggle(_0xb788d4={}){const {targetSelectors:targetSelectors=DEFAULT_TARGET_SELECTORS}=_0xb788d4,_0x421e8c=targetSelectors['map'](_0x2c1ebd=>document['querySelector'](_0x2c1ebd))['find'](Boolean),_0x21a34d=document['createElement']('button');_0x21a34d['type']='button',_0x21a34d['className']='btn-ghost\x20theme-toggle-btn',_0x21a34d['id']='theme-toggle-btn',_0x21a34d['setAttribute']('aria-pressed','false'),_0x21a34d['style']['padding']='8px',_0x21a34d['style']['lineHeight']='0',_0x21a34d['style']['width']='36px',_0x21a34d['style']['height']='36px',_0x21a34d['style']['display']='flex',_0x21a34d['style']['alignItems']='center',_0x21a34d['style']['justifyContent']='center';const _0x57fdaf=document['createElement']('span');_0x57fdaf['className']='theme-icon',_0x57fdaf['style']['display']='flex',_0x21a34d['append'](_0x57fdaf);const _0x108ba6='<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>',_0x659b83='<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>',_0x23329a=_0x3a2306=>{const _0x1e6c9d=_0x3a2306==='dark';_0x57fdaf['innerHTML']=_0x1e6c9d?_0x108ba6:_0x659b83,_0x21a34d['title']=_0x1e6c9d?'Switch\x20to\x20light\x20mode':'Switch\x20to\x20dark\x20mode',_0x21a34d['dataset']['theme']=_0x3a2306,_0x21a34d['setAttribute']('aria-pressed',String(_0x1e6c9d));};return _0x21a34d['addEventListener']('click',()=>{const _0x4b5e08=getCurrentTheme()==='dark'?'light':'dark';applyTheme(_0x4b5e08);}),_0x421e8c?_0x421e8c['appendChild'](_0x21a34d):(_0x21a34d['classList']['add']('theme-toggle-floating'),document['body']['appendChild'](_0x21a34d)),_0x23329a(initTheme()),onThemeChange(_0x23329a),_0x21a34d;}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 _0x453d64=await API['getCurrentUser']();state['currentUser']=_0x453d64;if(!Permissions['hasServerPermission'](_0x453d64,'*')&&!Permissions['hasServerPermission'](_0x453d64,'users:create')){Utils['showToast']('Access\x20denied:\x20Server\x20admin\x20privileges\x20required','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}}catch(_0x140c1a){window['location']['href']='login.html';}}async function checkEmailConfig(){try{const _0x1f576b=await API['getEmailConfig']();state['emailConfigured']=_0x1f576b['configured'];}catch(_0x5c1515){console['error']('Failed\x20to\x20check\x20email\x20config',_0x5c1515),state['emailConfigured']=![];}}async function loadRoles(){try{const {roles:_0x5dbdf5}=await API['getRoleDefinitions']();state['roles']=_0x5dbdf5||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x540b89=await API['getEnvironments']();state['environments']=_0x540b89['environments']||[];}catch{state['environments']=[];}}async function loadTeams(){try{const {teams:_0x583c4a}=await API['getTeams']();state['teams']=_0x583c4a||[];}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 _0x118008=document['getElementById']('users-loading'),_0x59247f=document['getElementById']('users-error'),_0x470399=document['getElementById']('users-content');try{_0x118008['hidden']=![],_0x59247f['hidden']=!![],_0x470399['hidden']=!![];const _0x3cc86a=await API['getUsers']();state['users']=_0x3cc86a['users']||[],renderUsers(),_0x118008['hidden']=!![],_0x470399['hidden']=![];}catch(_0x3bb41a){console['error']('Failed\x20to\x20load\x20users',_0x3bb41a),_0x118008['hidden']=!![],_0x59247f['hidden']=![],document['getElementById']('users-error-message')['textContent']=_0x3bb41a['message'];}}function renderUsers(){const _0x102ab5=document['getElementById']('users-table-body'),_0xc290a5=document['getElementById']('user-count');if(!_0x102ab5)return;_0xc290a5&&(_0xc290a5['textContent']=state['users']['length']+'\x20user'+(state['users']['length']===0x1?'':'s'));const _0xfff11d=[...state['users']]['sort']((_0x4db115,_0x5912fe)=>{const _0x1a8dc0=new Date(_0x4db115['created_at'])['getTime'](),_0x5090ca=new Date(_0x5912fe['created_at'])['getTime']();return _0x5090ca-_0x1a8dc0;});_0x102ab5['innerHTML']=_0xfff11d['map'](_0x479c1e=>'\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'](_0x479c1e['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'](_0x479c1e['name'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x479c1e['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'+(_0x479c1e['isServerAdmin']?'<span\x20class=\x22role-badge\x20role-admin\x22>Server\x20Admin</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x479c1e['hasUserBinding']?'<span\x20class=\x22role-badge\x20role-user-binding\x22>User\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x479c1e['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'](_0x479c1e['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'+_0x479c1e['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'+_0x479c1e['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'+_0x479c1e['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'+_0x479c1e['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(_0x4a7a3e){const _0xae4aaf=state['users']['find'](_0x2baf85=>_0x2baf85['id']===_0x4a7a3e);if(!_0xae4aaf)return;state['bindingsUserId']=_0x4a7a3e,state['bindingsDirty']=![];const _0x5958ef=document['getElementById']('bindings-modal'),_0x17245b=document['getElementById']('bindings-modal-title');_0x17245b['textContent']='Access\x20Bindings\x20—\x20'+_0xae4aaf['name'],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],_0x5958ef['hidden']=![],loadUserBindings(_0x4a7a3e);};function hasUnsavedBindingChanges(){const _0x486c6d=document['getElementById']('add-user-binding-form');return _0x486c6d&&!_0x486c6d['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 _0x18cffd=document['getElementById']('bindings-modal');_0x18cffd['hidden']=!![];const _0x4885f5=state['bindingsDirty'];state['bindingsUserId']=null,state['userBindings']=[],state['bindingsDirty']=![],_0x4885f5&&await loadUsers();}async function loadUserBindings(_0x1e01ca){const _0x3660b3=document['getElementById']('user-bindings-loading'),_0x4120d2=document['getElementById']('user-bindings-empty'),_0x2ce5bf=document['getElementById']('user-bindings-list-container'),_0x5913f5=document['getElementById']('add-user-binding-btn'),_0x54241a=document['getElementById']('user-team-bindings-note'),_0x3cc8c2=document['getElementById']('user-team-bindings-text');_0x3660b3['hidden']=![],_0x4120d2['hidden']=!![],_0x2ce5bf['style']['display']='none',_0x5913f5['hidden']=!![],_0x54241a['hidden']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![];try{const [_0x1ac35d,_0x2af5d2]=await Promise['all']([API['getBindings']({'subject_type':'user','subject_id':_0x1e01ca}),API['getTeams']()]);state['userBindings']=_0x1ac35d['bindings']||[];const _0x5d647f=(_0x2af5d2['teams']||[])['filter'](_0xf39a11=>(_0xf39a11['members']||[])['includes'](_0x1e01ca)),_0x40c6b1=[];if(_0x5d647f['length']>0x0){const _0x40c562=await Promise['all'](_0x5d647f['map'](_0x2e19d0=>API['getBindings']({'subject_type':'team','subject_id':_0x2e19d0['id']})));for(let _0x3d0770=0x0;_0x3d0770<_0x5d647f['length'];_0x3d0770++){const _0x434199=_0x40c562[_0x3d0770]['bindings']||[];_0x434199['length']>0x0&&_0x40c6b1['push'](_0x5d647f[_0x3d0770]);}}_0x3660b3['hidden']=!![];state['userBindings']['length']===0x0?_0x4120d2['hidden']=![]:(_0x2ce5bf['style']['display']='',renderUserBindingsTable());if(_0x40c6b1['length']>0x0){const _0x1c30c8=_0x40c6b1['map'](_0x519867=>_0x519867['name']),_0x23151f=_0x1c30c8['length']<=0x3?_0x1c30c8['join'](',\x20'):_0x1c30c8['slice'](0x0,0x3)['join'](',\x20')+(',\x20and\x20'+(_0x1c30c8['length']-0x3)+'\x20more');_0x3cc8c2['textContent']='This\x20user\x20also\x20has\x20access\x20via\x20team\x20memberships\x20('+_0x23151f+').';}else _0x3cc8c2['textContent']='This\x20user\x20has\x20no\x20access\x20via\x20team\x20memberships.';_0x54241a['hidden']=![],_0x5913f5['hidden']=![];}catch(_0x26382f){_0x3660b3['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x26382f['message'],'error');}}function renderUserBindingsTable(){const _0x41c762=document['getElementById']('user-bindings-table-body');if(!_0x41c762)return;_0x41c762['innerHTML']=state['userBindings']['map'](_0x40a945=>{const _0xa3d9a=_0x40a945['resource_type']==='server'?'Server':_0x40a945['resource_id']==='*'?'All\x20'+_0x40a945['resource_type']+'s':Utils['escapeHtml'](_0x40a945['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0xa3d9a+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x40a945['role_name']||_0x40a945['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'+_0x40a945['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 _0x53d068=document['getElementById']('user-binding-resource-type');_0x53d068['value']='environment',updateUserBindingFormForResourceType('environment');}function onUserBindingResourceTypeChange(){const _0x4e67b7=document['getElementById']('user-binding-resource-type')['value'];updateUserBindingFormForResourceType(_0x4e67b7);}function updateUserBindingFormForResourceType(_0x42077d){const _0x4b6d7a=document['getElementById']('user-binding-resource-container'),_0x506cf2=document['getElementById']('user-binding-resource'),_0x4c9992=document['getElementById']('user-binding-role');if(_0x42077d==='server')_0x4b6d7a['style']['display']='none';else{_0x4b6d7a['style']['display']='';if(_0x42077d==='environment'){const _0xe0a755=new Set(state['userBindings']['filter'](_0x1dcfa6=>_0x1dcfa6['resource_type']==='environment')['map'](_0x108954=>_0x108954['resource_id'])),_0x55e526=state['environments']['filter'](_0x556544=>!_0xe0a755['has'](_0x556544['name']));_0x506cf2['innerHTML']=_0x55e526['length']?_0x55e526['map'](_0x521004=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x521004['name'])+'\x22>'+Utils['escapeHtml'](_0x521004['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x42077d==='team'){const _0x57f0eb=new Set(state['userBindings']['filter'](_0x693be0=>_0x693be0['resource_type']==='team')['map'](_0x25899f=>_0x25899f['resource_id'])),_0x1e81c9=state['teams']['filter'](_0x4670d4=>!_0x57f0eb['has'](_0x4670d4['id']));_0x506cf2['innerHTML']=_0x1e81c9['length']?_0x1e81c9['map'](_0x4b08d5=>'<option\x20value=\x22'+_0x4b08d5['id']+'\x22>'+Utils['escapeHtml'](_0x4b08d5['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x5bc07b=state['roles']['filter'](_0x3f0f5d=>_0x3f0f5d['resource_type']===_0x42077d);_0x4c9992['innerHTML']=_0x5bc07b['length']?_0x5bc07b['filter'](_0x5c2f93=>{const _0x4cb005=_0x42077d==='server'?undefined:_0x506cf2['value'];return!state['userBindings']['some'](_0x434a6a=>_0x434a6a['resource_type']===_0x42077d&&_0x434a6a['role_id']===_0x5c2f93['id']&&(_0x42077d==='server'||_0x434a6a['resource_id']===_0x4cb005));})['map'](_0x5e0275=>'<option\x20value=\x22'+_0x5e0275['id']+'\x22>'+Utils['escapeHtml'](_0x5e0275['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 _0xf26dd3=document['getElementById']('user-binding-resource-type')['value'],_0x4eb735=document['getElementById']('user-binding-role')['value'];if(!_0x4eb735||!state['bindingsUserId'])return;const _0x365e42=_0xf26dd3==='server'?undefined:document['getElementById']('user-binding-resource')['value'];if(_0xf26dd3!=='server'&&!_0x365e42)return;const _0xf5d5ed=document['getElementById']('save-user-binding-btn');_0xf5d5ed['disabled']=!![],_0xf5d5ed['textContent']='Adding…';try{const _0x5afa89={'subject_type':'user','subject_id':state['bindingsUserId'],'role_id':_0x4eb735,'resource_type':_0xf26dd3};if(_0x365e42)_0x5afa89['resource_id']=_0x365e42;await API['createBinding'](_0x5afa89),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(_0x6c834b){Utils['showToast'](_0x6c834b['message'],'error');}finally{_0xf5d5ed['disabled']=![],_0xf5d5ed['textContent']='Add\x20Binding';}}window['deleteUserBindingClick']=async function(_0x3a96cc){try{await API['deleteBinding'](_0x3a96cc),Utils['showToast']('Binding\x20removed','success'),state['bindingsDirty']=!![],await loadUserBindings(state['bindingsUserId']);}catch(_0x4cf718){Utils['showToast'](_0x4cf718['message'],'error');}};function showCreateUserModal(){state['editingUserId']=null;const _0x286b83=document['getElementById']('user-modal'),_0x543883=document['getElementById']('modal-title'),_0x1ec8ff=document['getElementById']('user-password'),_0x260d2d=document['getElementById']('password-required'),_0x3c49c6=document['getElementById']('password-hint'),_0x27ff2e=document['getElementById']('skip-password-container'),_0x4fbb1c=document['getElementById']('skip-password');_0x543883['textContent']='Create\x20User',document['getElementById']('user-form')['reset'](),_0x1ec8ff['required']=!![];if(_0x260d2d)_0x260d2d['textContent']='*';_0x27ff2e&&(_0x27ff2e['style']['display']='block',_0x4fbb1c['checked']=![]),_0x3c49c6&&(_0x3c49c6['textContent']='Minimum\x208\x20characters'),_0x286b83['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);}window['editUser']=function(_0x4f1b15){const _0x579c0f=state['users']['find'](_0x4b288d=>_0x4b288d['id']===_0x4f1b15);if(!_0x579c0f)return;state['editingUserId']=_0x4f1b15;const _0x10f2a9=document['getElementById']('user-modal'),_0x4b667d=document['getElementById']('modal-title'),_0x176e65=document['getElementById']('user-password'),_0xea6c4c=document['getElementById']('password-required'),_0x2787af=document['getElementById']('password-hint'),_0x773359=document['getElementById']('skip-password-container');_0x4b667d['textContent']='Edit\x20User',document['getElementById']('user-username')['value']=_0x579c0f['username'],document['getElementById']('user-name')['value']=_0x579c0f['name'],document['getElementById']('user-email')['value']=_0x579c0f['email'],_0x176e65['value']='',_0x176e65['required']=![];if(_0xea6c4c)_0xea6c4c['textContent']='';_0x773359&&(_0x773359['style']['display']='none'),_0x2787af&&(_0x2787af['textContent']='Leave\x20blank\x20to\x20keep\x20current\x20password'),_0x10f2a9['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);};function hideUserModal(){const _0x1c053a=document['getElementById']('user-modal'),_0x18737e=document['getElementById']('form-error'),_0x5284f8=document['getElementById']('save-user');_0x1c053a['hidden']=!![],_0x18737e['hidden']=!![],state['editingUserId']=null,_0x5284f8&&(_0x5284f8['disabled']=![],_0x5284f8['textContent']='Save\x20User');}async function saveUser(){const _0x4161f4=document['getElementById']('user-form'),_0x16ffea=document['getElementById']('skip-password')?.['checked']||![];if(!_0x16ffea&&!_0x4161f4['checkValidity']()){_0x4161f4['reportValidity']();return;}const _0x4549fa=document['getElementById']('form-error'),_0x5c438b=document['getElementById']('save-user'),_0x400729=document['getElementById']('user-username')['value']['trim'](),_0x12a866=document['getElementById']('user-name')['value']['trim'](),_0x5f0ba5=document['getElementById']('user-email')['value']['trim'](),_0x2e492a=document['getElementById']('user-password')['value'];if(!_0x400729||!_0x12a866||!_0x5f0ba5){_0x4549fa['textContent']='Please\x20fill\x20in\x20all\x20required\x20fields',_0x4549fa['hidden']=![],_0x4549fa['scrollIntoView']({'behavior':'smooth','block':'nearest'});return;}_0x4549fa['hidden']=!![];const _0x577816=_0x5c438b['textContent'];_0x5c438b['disabled']=!![],_0x5c438b['textContent']=state['editingUserId']?'Updating...':'Creating...';try{if(state['editingUserId']){const _0x1925e9={'username':_0x400729,'name':_0x12a866,'email':_0x5f0ba5};_0x2e492a&&(_0x1925e9['password']=_0x2e492a),await API['updateUser'](state['editingUserId'],_0x1925e9),Utils['showToast']('User\x20updated\x20successfully','success'),await loadUsers(),hideUserModal();}else{const _0x456873={'username':_0x400729,'name':_0x12a866,'email':_0x5f0ba5};if(!_0x16ffea){if(!_0x2e492a)throw new Error('Password\x20is\x20required\x20for\x20new\x20users');_0x456873['password']=_0x2e492a;}const _0x4c2784=await API['createUser'](_0x456873),_0x4e3bd4=_0x4c2784['user'];if(_0x16ffea||!_0x2e492a){const _0x2deacd=await API['createPasswordToken'](_0x4e3bd4['id'],'setup',![]);state['setupLinkData']={'username':_0x4e3bd4['username'],'email':_0x4e3bd4['email'],'url':_0x2deacd['token']['setupUrl'],'userId':_0x4e3bd4['id'],'type':'setup','emailSent':![]},await loadUsers(),hideUserModal(),showSetupLinkModal();}else Utils['showToast']('User\x20created\x20successfully','success'),await loadUsers(),hideUserModal();}}catch(_0x25d033){console['error']('Failed\x20to\x20save\x20user',_0x25d033),_0x4549fa['textContent']=_0x25d033['message'],_0x4549fa['hidden']=![],_0x4549fa['scrollIntoView']({'behavior':'smooth','block':'nearest'}),_0x5c438b['disabled']=![],_0x5c438b['textContent']=_0x577816;}}window['deleteUser']=function(_0x3dbc23){const _0x543034=state['users']['find'](_0x156d02=>_0x156d02['id']===_0x3dbc23);if(!_0x543034)return;state['deletingUserId']=_0x3dbc23;const _0x2ca9d4=document['getElementById']('delete-modal'),_0x541386=document['getElementById']('delete-user-name');_0x541386['textContent']=_0x543034['name']+'\x20('+_0x543034['username']+')',_0x2ca9d4['hidden']=![];};function hideDeleteModal(){const _0x503bd2=document['getElementById']('delete-modal');_0x503bd2['hidden']=!![],state['deletingUserId']=null;const _0x2177f1=document['getElementById']('confirm-delete');_0x2177f1&&(_0x2177f1['disabled']=![],_0x2177f1['textContent']='Delete\x20User');}async function confirmDeleteUser(){if(!state['deletingUserId'])return;const _0x559a54=document['getElementById']('confirm-delete'),_0x463413=_0x559a54['textContent'];_0x559a54['disabled']=!![],_0x559a54['textContent']='Deleting...';try{await API['deleteUser'](state['deletingUserId']),Utils['showToast']('User\x20deleted\x20successfully','success'),await loadUsers(),hideDeleteModal();}catch(_0x10c896){console['error']('Failed\x20to\x20delete\x20user',_0x10c896),Utils['showToast']('Failed\x20to\x20delete\x20user:\x20'+_0x10c896['message'],'error'),_0x559a54['disabled']=![],_0x559a54['textContent']=_0x463413;}}function handleSkipPasswordChange(_0x2701ae){const _0x336564=document['getElementById']('user-password'),_0x5c8fd1=_0x2701ae['target']['checked'];_0x5c8fd1?(_0x336564['required']=![],_0x336564['disabled']=!![],_0x336564['value']=''):(_0x336564['required']=!![],_0x336564['disabled']=![]);}function showSetupLinkModal(){if(!state['setupLinkData'])return;const _0x39a901=document['getElementById']('setup-link-modal'),_0x37fb96=document['getElementById']('setup-link-username'),_0x117cb0=document['getElementById']('setup-link-url'),_0x1dfa2d=document['getElementById']('email-setup-link'),_0x26b7bd=document['getElementById']('email-button-text');_0x37fb96['textContent']=state['setupLinkData']['username'],_0x117cb0['textContent']=state['setupLinkData']['url'],_0x1dfa2d&&_0x26b7bd&&(_0x1dfa2d['disabled']=![],_0x26b7bd['textContent']='Email\x20Link',state['emailConfigured']&&!state['setupLinkData']['emailSent']?_0x1dfa2d['style']['display']='inline-block':_0x1dfa2d['style']['display']='none'),_0x39a901['hidden']=![];}function hideSetupLinkModal(){const _0x24eedd=document['getElementById']('setup-link-modal');_0x24eedd['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(_0x34fa01){console['error']('Failed\x20to\x20copy\x20link',_0x34fa01),Utils['showToast']('Failed\x20to\x20copy\x20link','error');}}async function emailSetupLink(){if(!state['setupLinkData'])return;const _0x30f63b=document['getElementById']('email-setup-link'),_0x3400c7=document['getElementById']('email-button-text');if(!_0x30f63b||!_0x3400c7)return;const _0x474f50=_0x3400c7['textContent'];_0x30f63b['disabled']=!![],_0x3400c7['textContent']='Sending...';try{const _0x468130=await API['createPasswordToken'](state['setupLinkData']['userId'],state['setupLinkData']['type'],!![]);if(_0x468130['emailSent'])Utils['showToast']('Email\x20sent\x20to\x20'+state['setupLinkData']['email'],'success'),state['setupLinkData']['emailSent']=!![],_0x30f63b['style']['display']='none';else{const _0x52d48d=_0x468130['emailError']||'Failed\x20to\x20send\x20email';Utils['showToast'](_0x52d48d,'error'),_0x30f63b['disabled']=![],_0x3400c7['textContent']=_0x474f50;}}catch(_0x6f0724){console['error']('Failed\x20to\x20email\x20setup\x20link',_0x6f0724),Utils['showToast']('Failed\x20to\x20send\x20email:\x20'+_0x6f0724['message'],'error'),_0x30f63b['disabled']=![],_0x3400c7['textContent']=_0x474f50;}}window['resetPassword']=async function(_0x5c4469){const _0x27d839=state['users']['find'](_0x334809=>_0x334809['id']===_0x5c4469);if(!_0x27d839)return;const _0x3e4277=await ConfirmDialog['show']({'title':'Reset\x20Password','message':'Generate\x20a\x20password\x20reset\x20link\x20for\x20'+_0x27d839['name']+'\x20('+_0x27d839['username']+')?\x20This\x20will\x20create\x20a\x20link\x20that\x20they\x20can\x20use\x20to\x20set\x20a\x20new\x20password.','confirmText':'Generate\x20Link'});if(!_0x3e4277)return;try{const _0x2bc7fb=await API['createPasswordToken'](_0x5c4469,'reset',![]);state['setupLinkData']={'username':_0x27d839['username'],'email':_0x27d839['email'],'url':_0x2bc7fb['token']['setupUrl'],'userId':_0x27d839['id'],'type':'reset','emailSent':![]},showSetupLinkModal();}catch(_0x1c2c12){console['error']('Failed\x20to\x20create\x20password\x20reset\x20link',_0x1c2c12),Utils['showToast']('Failed\x20to\x20create\x20password\x20reset\x20link:\x20'+_0x1c2c12['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 _0x4b1e81=await API['getCurrentUser']();state['currentUser']=_0x4b1e81;if(!Permissions['hasServerPermission'](_0x4b1e81,'*')&&!Permissions['hasServerPermission'](_0x4b1e81,'users:create')){Utils['showToast']('Access\x20denied:\x20Server\x20admin\x20privileges\x20required','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}}catch(_0x6d66ce){window['location']['href']='login.html';}}async function checkEmailConfig(){try{const _0x1b8a74=await API['getEmailConfig']();state['emailConfigured']=_0x1b8a74['configured'];}catch(_0x34ebed){console['error']('Failed\x20to\x20check\x20email\x20config',_0x34ebed),state['emailConfigured']=![];}}async function loadRoles(){try{const {roles:_0x3319fa}=await API['getRoleDefinitions']();state['roles']=_0x3319fa||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x5da5e5=await API['getEnvironments']();state['environments']=_0x5da5e5['environments']||[];}catch{state['environments']=[];}}async function loadTeams(){try{const {teams:_0x389eda}=await API['getTeams']();state['teams']=_0x389eda||[];}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 _0x2fa41d=document['getElementById']('users-loading'),_0x2d3aae=document['getElementById']('users-error'),_0xdcced3=document['getElementById']('users-content');try{_0x2fa41d['hidden']=![],_0x2d3aae['hidden']=!![],_0xdcced3['hidden']=!![];const _0x1aa660=await API['getUsers']();state['users']=_0x1aa660['users']||[],renderUsers(),_0x2fa41d['hidden']=!![],_0xdcced3['hidden']=![];}catch(_0x4f7a9e){console['error']('Failed\x20to\x20load\x20users',_0x4f7a9e),_0x2fa41d['hidden']=!![],_0x2d3aae['hidden']=![],document['getElementById']('users-error-message')['textContent']=_0x4f7a9e['message'];}}function renderUsers(){const _0x1c4b7f=document['getElementById']('users-table-body'),_0x150ce2=document['getElementById']('user-count');if(!_0x1c4b7f)return;_0x150ce2&&(_0x150ce2['textContent']=state['users']['length']+'\x20user'+(state['users']['length']===0x1?'':'s'));const _0x1cc84b=[...state['users']]['sort']((_0x39ba58,_0x5a4490)=>{const _0x13cfa3=new Date(_0x39ba58['created_at'])['getTime'](),_0x49f019=new Date(_0x5a4490['created_at'])['getTime']();return _0x49f019-_0x13cfa3;});_0x1c4b7f['innerHTML']=_0x1cc84b['map'](_0x47aebc=>'\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'](_0x47aebc['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'](_0x47aebc['name'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x47aebc['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'+(_0x47aebc['isServerAdmin']?'<span\x20class=\x22role-badge\x20role-admin\x22>Server\x20Admin</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x47aebc['hasUserBinding']?'<span\x20class=\x22role-badge\x20role-user-binding\x22>User\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x47aebc['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'](_0x47aebc['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'+_0x47aebc['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'+_0x47aebc['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'+_0x47aebc['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'+_0x47aebc['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(_0x12988a){const _0x1b1202=state['users']['find'](_0x51d441=>_0x51d441['id']===_0x12988a);if(!_0x1b1202)return;state['bindingsUserId']=_0x12988a,state['bindingsDirty']=![];const _0x2994e8=document['getElementById']('bindings-modal'),_0x4a05ca=document['getElementById']('bindings-modal-title');_0x4a05ca['textContent']='Access\x20Bindings\x20—\x20'+_0x1b1202['name'],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],_0x2994e8['hidden']=![],loadUserBindings(_0x12988a);};function hasUnsavedBindingChanges(){const _0x49fbc1=document['getElementById']('add-user-binding-form');return _0x49fbc1&&!_0x49fbc1['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 _0x510ace=document['getElementById']('bindings-modal');_0x510ace['hidden']=!![];const _0x4a5434=state['bindingsDirty'];state['bindingsUserId']=null,state['userBindings']=[],state['bindingsDirty']=![],_0x4a5434&&await loadUsers();}async function loadUserBindings(_0x18687e){const _0x967da0=document['getElementById']('user-bindings-loading'),_0x1f7dec=document['getElementById']('user-bindings-empty'),_0x5f5195=document['getElementById']('user-bindings-list-container'),_0x51773b=document['getElementById']('add-user-binding-btn'),_0x3c3b83=document['getElementById']('user-team-bindings-note'),_0x2d1345=document['getElementById']('user-team-bindings-text');_0x967da0['hidden']=![],_0x1f7dec['hidden']=!![],_0x5f5195['style']['display']='none',_0x51773b['hidden']=!![],_0x3c3b83['hidden']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![];try{const [_0x29e3ee,_0x281b60]=await Promise['all']([API['getBindings']({'subject_type':'user','subject_id':_0x18687e}),API['getTeams']()]);state['userBindings']=_0x29e3ee['bindings']||[];const _0x5226f1=(_0x281b60['teams']||[])['filter'](_0x19b378=>(_0x19b378['members']||[])['includes'](_0x18687e)),_0x141bac=[];if(_0x5226f1['length']>0x0){const _0x4f6d97=await Promise['all'](_0x5226f1['map'](_0x47ab15=>API['getBindings']({'subject_type':'team','subject_id':_0x47ab15['id']})));for(let _0x176a5c=0x0;_0x176a5c<_0x5226f1['length'];_0x176a5c++){const _0x2344f6=_0x4f6d97[_0x176a5c]['bindings']||[];_0x2344f6['length']>0x0&&_0x141bac['push'](_0x5226f1[_0x176a5c]);}}_0x967da0['hidden']=!![];state['userBindings']['length']===0x0?_0x1f7dec['hidden']=![]:(_0x5f5195['style']['display']='',renderUserBindingsTable());if(_0x141bac['length']>0x0){const _0x17c8d4=_0x141bac['map'](_0x4221cc=>_0x4221cc['name']),_0x4ed6de=_0x17c8d4['length']<=0x3?_0x17c8d4['join'](',\x20'):_0x17c8d4['slice'](0x0,0x3)['join'](',\x20')+(',\x20and\x20'+(_0x17c8d4['length']-0x3)+'\x20more');_0x2d1345['textContent']='This\x20user\x20also\x20has\x20access\x20via\x20team\x20memberships\x20('+_0x4ed6de+').';}else _0x2d1345['textContent']='This\x20user\x20has\x20no\x20access\x20via\x20team\x20memberships.';_0x3c3b83['hidden']=![],_0x51773b['hidden']=![];}catch(_0x57b72b){_0x967da0['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x57b72b['message'],'error');}}function renderUserBindingsTable(){const _0x2ebfeb=document['getElementById']('user-bindings-table-body');if(!_0x2ebfeb)return;_0x2ebfeb['innerHTML']=state['userBindings']['map'](_0x4dface=>{const _0x379121=_0x4dface['resource_type']==='server'?'Server':_0x4dface['resource_id']==='*'?'All\x20'+_0x4dface['resource_type']+'s':Utils['escapeHtml'](_0x4dface['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x379121+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x4dface['role_name']||_0x4dface['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'+_0x4dface['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 _0x60f35a=document['getElementById']('user-binding-resource-type');_0x60f35a['value']='environment',updateUserBindingFormForResourceType('environment');}function onUserBindingResourceTypeChange(){const _0x31ad17=document['getElementById']('user-binding-resource-type')['value'];updateUserBindingFormForResourceType(_0x31ad17);}function updateUserBindingFormForResourceType(_0x21d5e6){const _0x5addc9=document['getElementById']('user-binding-resource-container'),_0x17b6c7=document['getElementById']('user-binding-resource'),_0xe644ae=document['getElementById']('user-binding-role');if(_0x21d5e6==='server')_0x5addc9['style']['display']='none';else{_0x5addc9['style']['display']='';if(_0x21d5e6==='environment'){const _0x3a3f2f=new Set(state['userBindings']['filter'](_0x550afd=>_0x550afd['resource_type']==='environment')['map'](_0x2e94bc=>_0x2e94bc['resource_id'])),_0xa98c6e=state['environments']['filter'](_0x1c3084=>!_0x3a3f2f['has'](_0x1c3084['name']));_0x17b6c7['innerHTML']=_0xa98c6e['length']?_0xa98c6e['map'](_0x28722d=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x28722d['name'])+'\x22>'+Utils['escapeHtml'](_0x28722d['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x21d5e6==='team'){const _0x12a4fc=new Set(state['userBindings']['filter'](_0x107e91=>_0x107e91['resource_type']==='team')['map'](_0x4006d6=>_0x4006d6['resource_id'])),_0x58075a=state['teams']['filter'](_0xc404de=>!_0x12a4fc['has'](_0xc404de['id']));_0x17b6c7['innerHTML']=_0x58075a['length']?_0x58075a['map'](_0x277607=>'<option\x20value=\x22'+_0x277607['id']+'\x22>'+Utils['escapeHtml'](_0x277607['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x2df118=state['roles']['filter'](_0x228c20=>_0x228c20['resource_type']===_0x21d5e6);_0xe644ae['innerHTML']=_0x2df118['length']?_0x2df118['filter'](_0x97681b=>{const _0x191db0=_0x21d5e6==='server'?undefined:_0x17b6c7['value'];return!state['userBindings']['some'](_0x45e10d=>_0x45e10d['resource_type']===_0x21d5e6&&_0x45e10d['role_id']===_0x97681b['id']&&(_0x21d5e6==='server'||_0x45e10d['resource_id']===_0x191db0));})['map'](_0x161630=>'<option\x20value=\x22'+_0x161630['id']+'\x22>'+Utils['escapeHtml'](_0x161630['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 _0x577318=document['getElementById']('user-binding-resource-type')['value'],_0x5d7428=document['getElementById']('user-binding-role')['value'];if(!_0x5d7428||!state['bindingsUserId'])return;const _0x33cbdd=_0x577318==='server'?undefined:document['getElementById']('user-binding-resource')['value'];if(_0x577318!=='server'&&!_0x33cbdd)return;const _0x573cb1=document['getElementById']('save-user-binding-btn');_0x573cb1['disabled']=!![],_0x573cb1['textContent']='Adding…';try{const _0x2aacaf={'subject_type':'user','subject_id':state['bindingsUserId'],'role_id':_0x5d7428,'resource_type':_0x577318};if(_0x33cbdd)_0x2aacaf['resource_id']=_0x33cbdd;await API['createBinding'](_0x2aacaf),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(_0x32ca41){Utils['showToast'](_0x32ca41['message'],'error');}finally{_0x573cb1['disabled']=![],_0x573cb1['textContent']='Add\x20Binding';}}window['deleteUserBindingClick']=async function(_0x3e8962){try{await API['deleteBinding'](_0x3e8962),Utils['showToast']('Binding\x20removed','success'),state['bindingsDirty']=!![],await loadUserBindings(state['bindingsUserId']);}catch(_0x1bee60){Utils['showToast'](_0x1bee60['message'],'error');}};function showCreateUserModal(){state['editingUserId']=null;const _0x32b840=document['getElementById']('user-modal'),_0x3fe7f4=document['getElementById']('modal-title'),_0x5612fa=document['getElementById']('user-password'),_0x5ce7f0=document['getElementById']('password-required'),_0x44e2d9=document['getElementById']('password-hint'),_0x2f9b91=document['getElementById']('skip-password-container'),_0xea6ceb=document['getElementById']('skip-password');_0x3fe7f4['textContent']='Create\x20User',document['getElementById']('user-form')['reset'](),_0x5612fa['required']=!![];if(_0x5ce7f0)_0x5ce7f0['textContent']='*';_0x2f9b91&&(_0x2f9b91['style']['display']='block',_0xea6ceb['checked']=![]),_0x44e2d9&&(_0x44e2d9['textContent']='Minimum\x208\x20characters'),_0x32b840['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);}window['editUser']=function(_0x4ced2f){const _0x29066b=state['users']['find'](_0x1acb70=>_0x1acb70['id']===_0x4ced2f);if(!_0x29066b)return;state['editingUserId']=_0x4ced2f;const _0x33d71a=document['getElementById']('user-modal'),_0x54b881=document['getElementById']('modal-title'),_0x43ea3f=document['getElementById']('user-password'),_0x1d3b44=document['getElementById']('password-required'),_0x4b59bd=document['getElementById']('password-hint'),_0x355217=document['getElementById']('skip-password-container');_0x54b881['textContent']='Edit\x20User',document['getElementById']('user-username')['value']=_0x29066b['username'],document['getElementById']('user-name')['value']=_0x29066b['name'],document['getElementById']('user-email')['value']=_0x29066b['email'],_0x43ea3f['value']='',_0x43ea3f['required']=![];if(_0x1d3b44)_0x1d3b44['textContent']='';_0x355217&&(_0x355217['style']['display']='none'),_0x4b59bd&&(_0x4b59bd['textContent']='Leave\x20blank\x20to\x20keep\x20current\x20password'),_0x33d71a['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);};function hideUserModal(){const _0xf004da=document['getElementById']('user-modal'),_0x5e962d=document['getElementById']('form-error'),_0x1be066=document['getElementById']('save-user');_0xf004da['hidden']=!![],_0x5e962d['hidden']=!![],state['editingUserId']=null,_0x1be066&&(_0x1be066['disabled']=![],_0x1be066['textContent']='Save\x20User');}async function saveUser(){const _0x1e95e2=document['getElementById']('user-form'),_0x399c44=document['getElementById']('skip-password')?.['checked']||![];if(!_0x399c44&&!_0x1e95e2['checkValidity']()){_0x1e95e2['reportValidity']();return;}const _0x1ed557=document['getElementById']('form-error'),_0x1de7dc=document['getElementById']('save-user'),_0x5e1334=document['getElementById']('user-username')['value']['trim'](),_0x581f6f=document['getElementById']('user-name')['value']['trim'](),_0x331799=document['getElementById']('user-email')['value']['trim'](),_0x449a8f=document['getElementById']('user-password')['value'];if(!_0x5e1334||!_0x581f6f||!_0x331799){_0x1ed557['textContent']='Please\x20fill\x20in\x20all\x20required\x20fields',_0x1ed557['hidden']=![],_0x1ed557['scrollIntoView']({'behavior':'smooth','block':'nearest'});return;}_0x1ed557['hidden']=!![];const _0x1fd5d0=_0x1de7dc['textContent'];_0x1de7dc['disabled']=!![],_0x1de7dc['textContent']=state['editingUserId']?'Updating...':'Creating...';try{if(state['editingUserId']){const _0x9f1ec2={'username':_0x5e1334,'name':_0x581f6f,'email':_0x331799};_0x449a8f&&(_0x9f1ec2['password']=_0x449a8f),await API['updateUser'](state['editingUserId'],_0x9f1ec2),Utils['showToast']('User\x20updated\x20successfully','success'),await loadUsers(),hideUserModal();}else{const _0x769311={'username':_0x5e1334,'name':_0x581f6f,'email':_0x331799};if(!_0x399c44){if(!_0x449a8f)throw new Error('Password\x20is\x20required\x20for\x20new\x20users');_0x769311['password']=_0x449a8f;}const _0xecc91e=await API['createUser'](_0x769311),_0x5aab47=_0xecc91e['user'];if(_0x399c44||!_0x449a8f){const _0x27db5d=await API['createPasswordToken'](_0x5aab47['id'],'setup',![]);state['setupLinkData']={'username':_0x5aab47['username'],'email':_0x5aab47['email'],'url':_0x27db5d['token']['setupUrl'],'userId':_0x5aab47['id'],'type':'setup','emailSent':![]},await loadUsers(),hideUserModal(),showSetupLinkModal();}else Utils['showToast']('User\x20created\x20successfully','success'),await loadUsers(),hideUserModal();}}catch(_0x468926){console['error']('Failed\x20to\x20save\x20user',_0x468926),_0x1ed557['textContent']=_0x468926['message'],_0x1ed557['hidden']=![],_0x1ed557['scrollIntoView']({'behavior':'smooth','block':'nearest'}),_0x1de7dc['disabled']=![],_0x1de7dc['textContent']=_0x1fd5d0;}}window['deleteUser']=function(_0x16bfc7){const _0x381aef=state['users']['find'](_0x4d3575=>_0x4d3575['id']===_0x16bfc7);if(!_0x381aef)return;state['deletingUserId']=_0x16bfc7;const _0x4b6985=document['getElementById']('delete-modal'),_0x13249b=document['getElementById']('delete-user-name');_0x13249b['textContent']=_0x381aef['name']+'\x20('+_0x381aef['username']+')',_0x4b6985['hidden']=![];};function hideDeleteModal(){const _0x526f49=document['getElementById']('delete-modal');_0x526f49['hidden']=!![],state['deletingUserId']=null;const _0x18a610=document['getElementById']('confirm-delete');_0x18a610&&(_0x18a610['disabled']=![],_0x18a610['textContent']='Delete\x20User');}async function confirmDeleteUser(){if(!state['deletingUserId'])return;const _0x1dc0c1=document['getElementById']('confirm-delete'),_0xd1ed4b=_0x1dc0c1['textContent'];_0x1dc0c1['disabled']=!![],_0x1dc0c1['textContent']='Deleting...';try{await API['deleteUser'](state['deletingUserId']),Utils['showToast']('User\x20deleted\x20successfully','success'),await loadUsers(),hideDeleteModal();}catch(_0x4fda9c){console['error']('Failed\x20to\x20delete\x20user',_0x4fda9c),Utils['showToast']('Failed\x20to\x20delete\x20user:\x20'+_0x4fda9c['message'],'error'),_0x1dc0c1['disabled']=![],_0x1dc0c1['textContent']=_0xd1ed4b;}}function handleSkipPasswordChange(_0x39a7bd){const _0x280781=document['getElementById']('user-password'),_0xad9105=_0x39a7bd['target']['checked'];_0xad9105?(_0x280781['required']=![],_0x280781['disabled']=!![],_0x280781['value']=''):(_0x280781['required']=!![],_0x280781['disabled']=![]);}function showSetupLinkModal(){if(!state['setupLinkData'])return;const _0x1778e5=document['getElementById']('setup-link-modal'),_0x33e918=document['getElementById']('setup-link-username'),_0xc6c82a=document['getElementById']('setup-link-url'),_0x494c50=document['getElementById']('email-setup-link'),_0x3d4dea=document['getElementById']('email-button-text');_0x33e918['textContent']=state['setupLinkData']['username'],_0xc6c82a['textContent']=state['setupLinkData']['url'],_0x494c50&&_0x3d4dea&&(_0x494c50['disabled']=![],_0x3d4dea['textContent']='Email\x20Link',state['emailConfigured']&&!state['setupLinkData']['emailSent']?_0x494c50['style']['display']='inline-block':_0x494c50['style']['display']='none'),_0x1778e5['hidden']=![];}function hideSetupLinkModal(){const _0x30db5d=document['getElementById']('setup-link-modal');_0x30db5d['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(_0x113a51){console['error']('Failed\x20to\x20copy\x20link',_0x113a51),Utils['showToast']('Failed\x20to\x20copy\x20link','error');}}async function emailSetupLink(){if(!state['setupLinkData'])return;const _0x14e2ef=document['getElementById']('email-setup-link'),_0x63b7b2=document['getElementById']('email-button-text');if(!_0x14e2ef||!_0x63b7b2)return;const _0x3f7085=_0x63b7b2['textContent'];_0x14e2ef['disabled']=!![],_0x63b7b2['textContent']='Sending...';try{const _0x28f186=await API['createPasswordToken'](state['setupLinkData']['userId'],state['setupLinkData']['type'],!![]);if(_0x28f186['emailSent'])Utils['showToast']('Email\x20sent\x20to\x20'+state['setupLinkData']['email'],'success'),state['setupLinkData']['emailSent']=!![],_0x14e2ef['style']['display']='none';else{const _0x38924d=_0x28f186['emailError']||'Failed\x20to\x20send\x20email';Utils['showToast'](_0x38924d,'error'),_0x14e2ef['disabled']=![],_0x63b7b2['textContent']=_0x3f7085;}}catch(_0x578950){console['error']('Failed\x20to\x20email\x20setup\x20link',_0x578950),Utils['showToast']('Failed\x20to\x20send\x20email:\x20'+_0x578950['message'],'error'),_0x14e2ef['disabled']=![],_0x63b7b2['textContent']=_0x3f7085;}}window['resetPassword']=async function(_0x5ec7bb){const _0x5dfd53=state['users']['find'](_0x5de716=>_0x5de716['id']===_0x5ec7bb);if(!_0x5dfd53)return;const _0x2376d7=await ConfirmDialog['show']({'title':'Reset\x20Password','message':'Generate\x20a\x20password\x20reset\x20link\x20for\x20'+_0x5dfd53['name']+'\x20('+_0x5dfd53['username']+')?\x20This\x20will\x20create\x20a\x20link\x20that\x20they\x20can\x20use\x20to\x20set\x20a\x20new\x20password.','confirmText':'Generate\x20Link'});if(!_0x2376d7)return;try{const _0x355afa=await API['createPasswordToken'](_0x5ec7bb,'reset',![]);state['setupLinkData']={'username':_0x5dfd53['username'],'email':_0x5dfd53['email'],'url':_0x355afa['token']['setupUrl'],'userId':_0x5dfd53['id'],'type':'reset','emailSent':![]},showSetupLinkModal();}catch(_0x494d0b){console['error']('Failed\x20to\x20create\x20password\x20reset\x20link',_0x494d0b),Utils['showToast']('Failed\x20to\x20create\x20password\x20reset\x20link:\x20'+_0x494d0b['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(_0x18ca8d={}){this['container']=null,this['onGroupChange']=_0x18ca8d['onGroupChange']||(()=>{}),this['onAddExistingTask']=_0x18ca8d['onAddExistingTask']||(()=>{}),this['tasks']=[],this['groupId']=_0x18ca8d['groupId']||null,this['isOpen']=![];}['init'](_0x517a0b,_0x329378,_0x4b2303){this['container']=_0x517a0b,this['tasks']=_0x329378,this['groupId']=_0x4b2303,this['render'](),this['attachEventListeners']();}['updateTasks'](_0x17de08){const _0x2b54e5=new Map(_0x17de08['map'](_0x28435e=>[_0x28435e['taskId'],_0x28435e]));this['tasks']=this['tasks']['map'](_0x497263=>{const _0x2278e4=_0x2b54e5['get'](_0x497263['taskId']);return _0x2278e4?_0x2278e4:_0x497263;});for(const _0x3608d2 of _0x17de08){!this['tasks']['some'](_0x432da9=>_0x432da9['taskId']===_0x3608d2['taskId'])&&this['tasks']['push'](_0x3608d2);}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 _0x20418f=this['tasks']['filter'](_0x340428=>_0x340428['groupId']===this['groupId'])['sort']((_0x47684c,_0x12fb2e)=>(_0x47684c['groupIndex']??0x0)-(_0x12fb2e['groupIndex']??0x0)),_0x17b0ca=this['tasks']['filter'](_0x242a92=>!_0x242a92['groupId']||_0x242a92['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>'+_0x20418f['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'+(_0x20418f['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20add\x20to\x20group</div>':_0x20418f['map']((_0x4081d5,_0x25266a)=>this['renderVariantCard'](_0x4081d5,_0x25266a,!![]))['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>'+_0x17b0ca['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'+(_0x17b0ca['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20remove\x20from\x20group</div>':_0x17b0ca['map']((_0x12accc,_0x2809e5)=>this['renderVariantCard'](_0x12accc,_0x2809e5,![]))['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'](_0xd80d36,_0x1e0f43,_0x3630aa){const _0x40a0be=_0xd80d36['envVars']?.['CODER_AGENT']||_0xd80d36['envVars']?.['default_agent']||'claude',_0xb339e=AGENT_ICONS[_0x40a0be['toLowerCase']()]||AGENT_ICONS['claude'],_0x389c31=STATUS_ICONS[_0xd80d36['status']]||'',_0x7d92e5='status-'+(_0xd80d36['status']||'unknown'),_0x597a77=_0xd80d36['isWinner']?'<span\x20class=\x22vgm-badge\x20vgm-badge-winner\x22\x20title=\x22Winner\x22>★</span>':'',_0x9a2fc=_0xd80d36['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'+_0x7d92e5+'\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'+_0xd80d36['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-is-grouped=\x22'+_0x3630aa+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-index=\x22'+_0x1e0f43+'\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'+_0x40a0be['toLowerCase']()+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0xb339e+'\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'](_0xd80d36['name']||'Task\x20'+_0xd80d36['taskId']['slice'](-0x6))+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-meta\x22>'+Utils['escapeHtml'](_0x40a0be)+'\x20·\x20'+(_0xd80d36['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'+_0x597a77+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x9a2fc+'\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'+_0x7d92e5+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x389c31+'\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'+(_0x3630aa?'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'+_0xd80d36['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-action=\x22'+(_0x3630aa?'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'+(_0x3630aa?'<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',_0x202c00=>{_0x202c00['target']['closest']('.vgm-close-btn')&&(this['close'](),this['onGroupChange'](this['tasks'])),_0x202c00['target']['closest']('.vgm-add-existing-btn')&&(this['close'](),this['onAddExistingTask'](this['groupId']));}),this['container']['addEventListener']('click',async _0x45af7b=>{const _0x38c262=_0x45af7b['target']['closest']('.vgm-variant-remove-btn');if(!_0x38c262)return;const _0x25d081=_0x38c262['dataset']['taskId'],_0x5752ee=_0x38c262['dataset']['action'];try{_0x5752ee==='remove'?await this['removeFromGroup'](_0x25d081):await this['addToGroup'](_0x25d081);}catch(_0x200907){console['error']('Failed\x20to\x20update\x20group:',_0x200907),Utils['showToast'](_0x200907['message']||'Failed\x20to\x20update\x20group','error');}}),this['container']['addEventListener']('dragstart',_0xf35242=>this['handleDragStart'](_0xf35242)),this['container']['addEventListener']('dragend',_0x472266=>this['handleDragEnd'](_0x472266)),this['container']['addEventListener']('dragover',_0x1cf6ab=>this['handleDragOver'](_0x1cf6ab)),this['container']['addEventListener']('dragleave',_0x20ea1c=>this['handleDragLeave'](_0x20ea1c)),this['container']['addEventListener']('drop',_0x101232=>this['handleDrop'](_0x101232));}['handleDragStart'](_0x328cbc){const _0x4715ff=_0x328cbc['target']['closest']('.vgm-variant-card');if(!_0x4715ff)return;dragState['draggedTaskId']=_0x4715ff['dataset']['taskId'],dragState['draggedElement']=_0x4715ff,dragState['sourceGroupId']=_0x4715ff['dataset']['isGrouped']==='true'?this['groupId']:null,dragState['isDragging']=!![],_0x4715ff['classList']['add']('dragging'),_0x328cbc['dataTransfer']['effectAllowed']='move',_0x328cbc['dataTransfer']['setData']('text/plain',_0x4715ff['dataset']['taskId']),this['container']['classList']['add']('is-dragging');}['handleDragEnd'](_0xb42461){const _0x1a6533=_0xb42461['target']['closest']('.vgm-variant-card');_0x1a6533&&_0x1a6533['classList']['remove']('dragging'),this['container']['querySelectorAll']('.drag-over,\x20.drop-indicator')['forEach'](_0x273883=>{_0x273883['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'](_0x104ffa){_0x104ffa['preventDefault'](),_0x104ffa['dataTransfer']['dropEffect']='move';const _0x134095=_0x104ffa['target']['closest']('.vgm-drop-zone'),_0x114816=_0x104ffa['target']['closest']('.vgm-variant-card');this['container']['querySelectorAll']('.vgm-drop-zone')['forEach'](_0x536919=>{_0x536919['classList']['toggle']('drag-over',_0x536919===_0x134095);});if(_0x114816&&_0x114816!==dragState['draggedElement']){const _0x2aafe2=_0x114816['getBoundingClientRect'](),_0x4abbb5=_0x2aafe2['top']+_0x2aafe2['height']/0x2,_0x31185e=_0x104ffa['clientY']<_0x4abbb5;this['container']['querySelectorAll']('.vgm-variant-card')['forEach'](_0x35e275=>{_0x35e275!==_0x114816&&_0x35e275['classList']['remove']('drop-before','drop-after');}),_0x114816['classList']['toggle']('drop-before',_0x31185e),_0x114816['classList']['toggle']('drop-after',!_0x31185e);}}['handleDragLeave'](_0x4b25ae){const _0x6b0162=_0x4b25ae['target']['closest']('.vgm-drop-zone');_0x6b0162&&!_0x6b0162['contains'](_0x4b25ae['relatedTarget'])&&_0x6b0162['classList']['remove']('drag-over');}async['handleDrop'](_0x103d6b){_0x103d6b['preventDefault']();const _0x3324dd=_0x103d6b['target']['closest']('.vgm-drop-zone'),_0x3ee0cd=_0x103d6b['target']['closest']('.vgm-variant-card'),_0x5c3b42=_0x103d6b['dataTransfer']['getData']('text/plain');if(!_0x3324dd||!_0x5c3b42)return;this['container']['querySelectorAll']('.drag-over,\x20.drop-before,\x20.drop-after')['forEach'](_0x570540=>{_0x570540['classList']['remove']('drag-over','drop-before','drop-after');});const _0x3a1178=_0x3324dd['dataset']['zone'],_0x4083a5=_0x3a1178==='grouped',_0x40e543=dragState['sourceGroupId']===this['groupId'];try{if(_0x4083a5&&!_0x40e543){let _0x110e2e=this['tasks']['filter'](_0x27e51a=>_0x27e51a['groupId']===this['groupId'])['length'];if(_0x3ee0cd){const _0x52c85b=_0x3ee0cd['dataset']['taskId'],_0x132237=this['tasks']['find'](_0x31beeb=>_0x31beeb['taskId']===_0x52c85b);if(_0x132237?.['groupIndex']!==undefined){const _0x5a58c6=_0x3ee0cd['getBoundingClientRect'](),_0x6b590f=_0x103d6b['clientY']<_0x5a58c6['top']+_0x5a58c6['height']/0x2;_0x110e2e=_0x132237['groupIndex']+(_0x6b590f?0x0:0x1);}}await this['addToGroup'](_0x5c3b42,_0x110e2e);}else{if(!_0x4083a5&&_0x40e543)await this['removeFromGroup'](_0x5c3b42);else _0x4083a5&&_0x40e543&&_0x3ee0cd&&await this['reorderInGroup'](_0x5c3b42,_0x3ee0cd,_0x103d6b['clientY']);}}catch(_0x2754b7){console['error']('Drop\x20operation\x20failed:',_0x2754b7),Utils['showToast'](_0x2754b7['message']||'Failed\x20to\x20move\x20variant','error');}}async['addToGroup'](_0x1d6163,_0x176b1a){const _0x1f0e9c=this['tasks']['find'](_0x599ef3=>_0x599ef3['taskId']===_0x1d6163);if(!_0x1f0e9c)return;_0x176b1a===undefined&&(_0x176b1a=this['tasks']['filter'](_0x3dd15a=>_0x3dd15a['groupId']===this['groupId'])['length']),!this['groupId']&&(this['groupId']=API['generateGroupId'](),await API['createTaskGroup']({'groupId':this['groupId']})),await API['updateTaskGroup'](_0x1d6163,this['groupId'],_0x176b1a),_0x1f0e9c['groupId']=this['groupId'],_0x1f0e9c['groupIndex']=_0x176b1a,this['render'](),this['onGroupChange'](this['tasks']);}async['removeFromGroup'](_0x5e9639){const _0x1f956e=this['tasks']['find'](_0x33dda2=>_0x33dda2['taskId']===_0x5e9639);if(!_0x1f956e)return;await API['removeTaskFromGroup'](_0x5e9639),_0x1f956e['groupId']=null,_0x1f956e['groupIndex']=null,this['render'](),this['onGroupChange'](this['tasks']);}async['reorderInGroup'](_0x399b2e,_0x664025,_0x31f314){const _0x2b1ed1=this['tasks']['find'](_0x1ff16d=>_0x1ff16d['taskId']===_0x399b2e),_0x3ec000=_0x664025['dataset']['taskId'],_0xca884c=this['tasks']['find'](_0x5c2483=>_0x5c2483['taskId']===_0x3ec000);if(!_0x2b1ed1||!_0xca884c||_0x2b1ed1['taskId']===_0xca884c['taskId'])return;const _0xae5539=_0x664025['getBoundingClientRect'](),_0xdba679=_0x31f314<_0xae5539['top']+_0xae5539['height']/0x2;let _0x526fcd=_0xca884c['groupIndex']??0x0;if(!_0xdba679)_0x526fcd++;if((_0x2b1ed1['groupIndex']??0x0)<(_0xca884c['groupIndex']??0x0))_0x526fcd--;if(_0x526fcd===_0x2b1ed1['groupIndex'])return;await API['updateTaskGroup'](_0x399b2e,this['groupId'],_0x526fcd);const _0x45c7a9=this['tasks']['filter'](_0x16b374=>_0x16b374['groupId']===this['groupId'])['sort']((_0xdb3405,_0x2a9ccf)=>(_0xdb3405['groupIndex']??0x0)-(_0x2a9ccf['groupIndex']??0x0)),_0x84377=_0x45c7a9['findIndex'](_0x301b79=>_0x301b79['taskId']===_0x399b2e);_0x84377!==-0x1&&_0x45c7a9['splice'](_0x84377,0x1),_0x45c7a9['splice'](_0x526fcd,0x0,_0x2b1ed1),_0x45c7a9['forEach']((_0x5345ab,_0x2a539d)=>{_0x5345ab['groupIndex']=_0x2a539d;}),this['render'](),this['onGroupChange'](this['tasks']);}}export function initializeTabDragDrop(_0x45382b,_0x4f815e,_0x23cb53,_0x2af259={}){if(!_0x45382b)return;const {onReorder:_0x1db26c,onRemove:_0x19fd63}=_0x2af259,_0x175861=_0x45382b['querySelectorAll']('.task-tab');_0x175861['forEach']((_0x55fdf9,_0x5eedca)=>{_0x55fdf9['setAttribute']('draggable','true'),_0x55fdf9['dataset']['index']=_0x5eedca,_0x55fdf9['addEventListener']('dragstart',_0x2bf722=>{_0x2bf722['dataTransfer']['effectAllowed']='move',_0x2bf722['dataTransfer']['setData']('text/plain',_0x55fdf9['dataset']['taskId']),_0x55fdf9['classList']['add']('dragging'),_0x45382b['classList']['add']('is-dragging');}),_0x55fdf9['addEventListener']('dragend',()=>{_0x55fdf9['classList']['remove']('dragging'),_0x45382b['classList']['remove']('is-dragging'),_0x45382b['querySelectorAll']('.drop-indicator')['forEach'](_0x2fb2f8=>{_0x2fb2f8['classList']['remove']('drop-indicator','drop-before','drop-after');});}),_0x55fdf9['addEventListener']('dragover',_0x399464=>{_0x399464['preventDefault'](),_0x399464['dataTransfer']['dropEffect']='move';if(_0x55fdf9['classList']['contains']('dragging'))return;const _0x17dd68=_0x55fdf9['getBoundingClientRect'](),_0x4610c2=_0x17dd68['left']+_0x17dd68['width']/0x2,_0x5db6f3=_0x399464['clientX']<_0x4610c2;_0x175861['forEach'](_0x3a6cac=>_0x3a6cac['classList']['remove']('drop-before','drop-after')),_0x55fdf9['classList']['add'](_0x5db6f3?'drop-before':'drop-after');}),_0x55fdf9['addEventListener']('dragleave',()=>{_0x55fdf9['classList']['remove']('drop-before','drop-after');}),_0x55fdf9['addEventListener']('drop',async _0x25331a=>{_0x25331a['preventDefault']();const _0x45d4ef=_0x25331a['dataTransfer']['getData']('text/plain'),_0x105359=_0x55fdf9['dataset']['taskId'];if(_0x45d4ef===_0x105359)return;const _0x34c147=_0x55fdf9['getBoundingClientRect'](),_0x39f3d4=_0x25331a['clientX']<_0x34c147['left']+_0x34c147['width']/0x2;_0x55fdf9['classList']['remove']('drop-before','drop-after'),_0x1db26c&&await _0x1db26c(_0x45d4ef,_0x105359,_0x39f3d4);});});const _0x30cf30=document['createElement']('div');return _0x30cf30['className']='task-tab-remove-zone',_0x30cf30['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',_0x30cf30['style']['display']='none',_0x30cf30['addEventListener']('dragover',_0x4e926e=>{_0x4e926e['preventDefault'](),_0x30cf30['classList']['add']('drag-over');}),_0x30cf30['addEventListener']('dragleave',()=>{_0x30cf30['classList']['remove']('drag-over');}),_0x30cf30['addEventListener']('drop',async _0x1e6445=>{_0x1e6445['preventDefault'](),_0x30cf30['classList']['remove']('drag-over');const _0x4a067d=_0x1e6445['dataTransfer']['getData']('text/plain');_0x19fd63&&await _0x19fd63(_0x4a067d);}),_0x45382b['addEventListener']('dragstart',()=>{_0x4f815e['length']>0x1&&(_0x30cf30['style']['display']='flex');}),_0x45382b['addEventListener']('dragend',()=>{_0x30cf30['style']['display']='none';}),_0x45382b['appendChild'](_0x30cf30),{'destroy':()=>{_0x30cf30['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(_0x27ed96={}){this['container']=null,this['onGroupChange']=_0x27ed96['onGroupChange']||(()=>{}),this['onAddExistingTask']=_0x27ed96['onAddExistingTask']||(()=>{}),this['tasks']=[],this['groupId']=_0x27ed96['groupId']||null,this['isOpen']=![];}['init'](_0x194627,_0x4e4075,_0x502df2){this['container']=_0x194627,this['tasks']=_0x4e4075,this['groupId']=_0x502df2,this['render'](),this['attachEventListeners']();}['updateTasks'](_0x3970c1){const _0x3434f9=new Map(_0x3970c1['map'](_0x3f2e6d=>[_0x3f2e6d['taskId'],_0x3f2e6d]));this['tasks']=this['tasks']['map'](_0x596cc1=>{const _0x322113=_0x3434f9['get'](_0x596cc1['taskId']);return _0x322113?_0x322113:_0x596cc1;});for(const _0x507c9b of _0x3970c1){!this['tasks']['some'](_0x114411=>_0x114411['taskId']===_0x507c9b['taskId'])&&this['tasks']['push'](_0x507c9b);}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 _0x3f25e7=this['tasks']['filter'](_0x470f30=>_0x470f30['groupId']===this['groupId'])['sort']((_0x425675,_0x5493ef)=>(_0x425675['groupIndex']??0x0)-(_0x5493ef['groupIndex']??0x0)),_0x328079=this['tasks']['filter'](_0x3fda36=>!_0x3fda36['groupId']||_0x3fda36['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>'+_0x3f25e7['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'+(_0x3f25e7['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20add\x20to\x20group</div>':_0x3f25e7['map']((_0x302f19,_0x52e6e4)=>this['renderVariantCard'](_0x302f19,_0x52e6e4,!![]))['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>'+_0x328079['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'+(_0x328079['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20remove\x20from\x20group</div>':_0x328079['map']((_0x5ece6e,_0x54f135)=>this['renderVariantCard'](_0x5ece6e,_0x54f135,![]))['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'](_0x4799c2,_0xfcd877,_0x26608b){const _0x53ade7=_0x4799c2['envVars']?.['CODER_AGENT']||_0x4799c2['envVars']?.['default_agent']||'claude',_0x23ec12=AGENT_ICONS[_0x53ade7['toLowerCase']()]||AGENT_ICONS['claude'],_0xc67b8b=STATUS_ICONS[_0x4799c2['status']]||'',_0x2bddf7='status-'+(_0x4799c2['status']||'unknown'),_0x4a76fd=_0x4799c2['isWinner']?'<span\x20class=\x22vgm-badge\x20vgm-badge-winner\x22\x20title=\x22Winner\x22>★</span>':'',_0x531375=_0x4799c2['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'+_0x2bddf7+'\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'+_0x4799c2['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-is-grouped=\x22'+_0x26608b+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-index=\x22'+_0xfcd877+'\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'+_0x53ade7['toLowerCase']()+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x23ec12+'\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'](_0x4799c2['name']||'Task\x20'+_0x4799c2['taskId']['slice'](-0x6))+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-meta\x22>'+Utils['escapeHtml'](_0x53ade7)+'\x20·\x20'+(_0x4799c2['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'+_0x4a76fd+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x531375+'\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'+_0x2bddf7+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0xc67b8b+'\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'+(_0x26608b?'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'+_0x4799c2['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-action=\x22'+(_0x26608b?'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'+(_0x26608b?'<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',_0x57daf5=>{_0x57daf5['target']['closest']('.vgm-close-btn')&&(this['close'](),this['onGroupChange'](this['tasks'])),_0x57daf5['target']['closest']('.vgm-add-existing-btn')&&(this['close'](),this['onAddExistingTask'](this['groupId']));}),this['container']['addEventListener']('click',async _0x12ca0d=>{const _0x5710bb=_0x12ca0d['target']['closest']('.vgm-variant-remove-btn');if(!_0x5710bb)return;const _0xd012b3=_0x5710bb['dataset']['taskId'],_0x4c5fcd=_0x5710bb['dataset']['action'];try{_0x4c5fcd==='remove'?await this['removeFromGroup'](_0xd012b3):await this['addToGroup'](_0xd012b3);}catch(_0x40df64){console['error']('Failed\x20to\x20update\x20group:',_0x40df64),Utils['showToast'](_0x40df64['message']||'Failed\x20to\x20update\x20group','error');}}),this['container']['addEventListener']('dragstart',_0x5c050d=>this['handleDragStart'](_0x5c050d)),this['container']['addEventListener']('dragend',_0x3bb9af=>this['handleDragEnd'](_0x3bb9af)),this['container']['addEventListener']('dragover',_0x114891=>this['handleDragOver'](_0x114891)),this['container']['addEventListener']('dragleave',_0x3037b1=>this['handleDragLeave'](_0x3037b1)),this['container']['addEventListener']('drop',_0x1ce55c=>this['handleDrop'](_0x1ce55c));}['handleDragStart'](_0x493c12){const _0x1598cf=_0x493c12['target']['closest']('.vgm-variant-card');if(!_0x1598cf)return;dragState['draggedTaskId']=_0x1598cf['dataset']['taskId'],dragState['draggedElement']=_0x1598cf,dragState['sourceGroupId']=_0x1598cf['dataset']['isGrouped']==='true'?this['groupId']:null,dragState['isDragging']=!![],_0x1598cf['classList']['add']('dragging'),_0x493c12['dataTransfer']['effectAllowed']='move',_0x493c12['dataTransfer']['setData']('text/plain',_0x1598cf['dataset']['taskId']),this['container']['classList']['add']('is-dragging');}['handleDragEnd'](_0x32547e){const _0x85b014=_0x32547e['target']['closest']('.vgm-variant-card');_0x85b014&&_0x85b014['classList']['remove']('dragging'),this['container']['querySelectorAll']('.drag-over,\x20.drop-indicator')['forEach'](_0x259046=>{_0x259046['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'](_0x132538){_0x132538['preventDefault'](),_0x132538['dataTransfer']['dropEffect']='move';const _0xa9fe72=_0x132538['target']['closest']('.vgm-drop-zone'),_0x5f1218=_0x132538['target']['closest']('.vgm-variant-card');this['container']['querySelectorAll']('.vgm-drop-zone')['forEach'](_0x459003=>{_0x459003['classList']['toggle']('drag-over',_0x459003===_0xa9fe72);});if(_0x5f1218&&_0x5f1218!==dragState['draggedElement']){const _0x56f5dc=_0x5f1218['getBoundingClientRect'](),_0x2bf75f=_0x56f5dc['top']+_0x56f5dc['height']/0x2,_0x175f3a=_0x132538['clientY']<_0x2bf75f;this['container']['querySelectorAll']('.vgm-variant-card')['forEach'](_0x21d1f1=>{_0x21d1f1!==_0x5f1218&&_0x21d1f1['classList']['remove']('drop-before','drop-after');}),_0x5f1218['classList']['toggle']('drop-before',_0x175f3a),_0x5f1218['classList']['toggle']('drop-after',!_0x175f3a);}}['handleDragLeave'](_0x5ca75c){const _0x1ecf98=_0x5ca75c['target']['closest']('.vgm-drop-zone');_0x1ecf98&&!_0x1ecf98['contains'](_0x5ca75c['relatedTarget'])&&_0x1ecf98['classList']['remove']('drag-over');}async['handleDrop'](_0x200cd2){_0x200cd2['preventDefault']();const _0x127777=_0x200cd2['target']['closest']('.vgm-drop-zone'),_0xfb6823=_0x200cd2['target']['closest']('.vgm-variant-card'),_0x5d6af0=_0x200cd2['dataTransfer']['getData']('text/plain');if(!_0x127777||!_0x5d6af0)return;this['container']['querySelectorAll']('.drag-over,\x20.drop-before,\x20.drop-after')['forEach'](_0x3da060=>{_0x3da060['classList']['remove']('drag-over','drop-before','drop-after');});const _0x3f44a8=_0x127777['dataset']['zone'],_0xd2db0=_0x3f44a8==='grouped',_0x26d905=dragState['sourceGroupId']===this['groupId'];try{if(_0xd2db0&&!_0x26d905){let _0xd735b6=this['tasks']['filter'](_0x531a2e=>_0x531a2e['groupId']===this['groupId'])['length'];if(_0xfb6823){const _0xf329b5=_0xfb6823['dataset']['taskId'],_0x473cb6=this['tasks']['find'](_0x2ecf69=>_0x2ecf69['taskId']===_0xf329b5);if(_0x473cb6?.['groupIndex']!==undefined){const _0x22a47b=_0xfb6823['getBoundingClientRect'](),_0x1bb8c2=_0x200cd2['clientY']<_0x22a47b['top']+_0x22a47b['height']/0x2;_0xd735b6=_0x473cb6['groupIndex']+(_0x1bb8c2?0x0:0x1);}}await this['addToGroup'](_0x5d6af0,_0xd735b6);}else{if(!_0xd2db0&&_0x26d905)await this['removeFromGroup'](_0x5d6af0);else _0xd2db0&&_0x26d905&&_0xfb6823&&await this['reorderInGroup'](_0x5d6af0,_0xfb6823,_0x200cd2['clientY']);}}catch(_0x1b8c08){console['error']('Drop\x20operation\x20failed:',_0x1b8c08),Utils['showToast'](_0x1b8c08['message']||'Failed\x20to\x20move\x20variant','error');}}async['addToGroup'](_0x368734,_0x2e2619){const _0x1ab94a=this['tasks']['find'](_0x39333b=>_0x39333b['taskId']===_0x368734);if(!_0x1ab94a)return;_0x2e2619===undefined&&(_0x2e2619=this['tasks']['filter'](_0x7e025d=>_0x7e025d['groupId']===this['groupId'])['length']),!this['groupId']&&(this['groupId']=API['generateGroupId'](),await API['createTaskGroup']({'groupId':this['groupId']})),await API['updateTaskGroup'](_0x368734,this['groupId'],_0x2e2619),_0x1ab94a['groupId']=this['groupId'],_0x1ab94a['groupIndex']=_0x2e2619,this['render'](),this['onGroupChange'](this['tasks']);}async['removeFromGroup'](_0x426c31){const _0x36fe60=this['tasks']['find'](_0x57a0da=>_0x57a0da['taskId']===_0x426c31);if(!_0x36fe60)return;await API['removeTaskFromGroup'](_0x426c31),_0x36fe60['groupId']=null,_0x36fe60['groupIndex']=null,this['render'](),this['onGroupChange'](this['tasks']);}async['reorderInGroup'](_0xf249b6,_0x4bd6da,_0x54a7a5){const _0x1a4a55=this['tasks']['find'](_0x371e3a=>_0x371e3a['taskId']===_0xf249b6),_0x4010eb=_0x4bd6da['dataset']['taskId'],_0x727a09=this['tasks']['find'](_0x3bbb66=>_0x3bbb66['taskId']===_0x4010eb);if(!_0x1a4a55||!_0x727a09||_0x1a4a55['taskId']===_0x727a09['taskId'])return;const _0x19edbb=_0x4bd6da['getBoundingClientRect'](),_0x7b47fd=_0x54a7a5<_0x19edbb['top']+_0x19edbb['height']/0x2;let _0x2978f5=_0x727a09['groupIndex']??0x0;if(!_0x7b47fd)_0x2978f5++;if((_0x1a4a55['groupIndex']??0x0)<(_0x727a09['groupIndex']??0x0))_0x2978f5--;if(_0x2978f5===_0x1a4a55['groupIndex'])return;await API['updateTaskGroup'](_0xf249b6,this['groupId'],_0x2978f5);const _0x45ebd9=this['tasks']['filter'](_0x909bd2=>_0x909bd2['groupId']===this['groupId'])['sort']((_0x5812c0,_0x8d610b)=>(_0x5812c0['groupIndex']??0x0)-(_0x8d610b['groupIndex']??0x0)),_0x44a99a=_0x45ebd9['findIndex'](_0x4a41ce=>_0x4a41ce['taskId']===_0xf249b6);_0x44a99a!==-0x1&&_0x45ebd9['splice'](_0x44a99a,0x1),_0x45ebd9['splice'](_0x2978f5,0x0,_0x1a4a55),_0x45ebd9['forEach']((_0x18e5c7,_0x2a2d88)=>{_0x18e5c7['groupIndex']=_0x2a2d88;}),this['render'](),this['onGroupChange'](this['tasks']);}}export function initializeTabDragDrop(_0x248ef7,_0x429910,_0x260f31,_0x1b5be8={}){if(!_0x248ef7)return;const {onReorder:_0x2bd9d5,onRemove:_0x4d6b24}=_0x1b5be8,_0x1f545e=_0x248ef7['querySelectorAll']('.task-tab');_0x1f545e['forEach']((_0x249766,_0x3a6c09)=>{_0x249766['setAttribute']('draggable','true'),_0x249766['dataset']['index']=_0x3a6c09,_0x249766['addEventListener']('dragstart',_0x58725b=>{_0x58725b['dataTransfer']['effectAllowed']='move',_0x58725b['dataTransfer']['setData']('text/plain',_0x249766['dataset']['taskId']),_0x249766['classList']['add']('dragging'),_0x248ef7['classList']['add']('is-dragging');}),_0x249766['addEventListener']('dragend',()=>{_0x249766['classList']['remove']('dragging'),_0x248ef7['classList']['remove']('is-dragging'),_0x248ef7['querySelectorAll']('.drop-indicator')['forEach'](_0x27705b=>{_0x27705b['classList']['remove']('drop-indicator','drop-before','drop-after');});}),_0x249766['addEventListener']('dragover',_0x3569de=>{_0x3569de['preventDefault'](),_0x3569de['dataTransfer']['dropEffect']='move';if(_0x249766['classList']['contains']('dragging'))return;const _0x43df00=_0x249766['getBoundingClientRect'](),_0x2f2ac5=_0x43df00['left']+_0x43df00['width']/0x2,_0x48485f=_0x3569de['clientX']<_0x2f2ac5;_0x1f545e['forEach'](_0x52ad0f=>_0x52ad0f['classList']['remove']('drop-before','drop-after')),_0x249766['classList']['add'](_0x48485f?'drop-before':'drop-after');}),_0x249766['addEventListener']('dragleave',()=>{_0x249766['classList']['remove']('drop-before','drop-after');}),_0x249766['addEventListener']('drop',async _0x21291e=>{_0x21291e['preventDefault']();const _0x475f46=_0x21291e['dataTransfer']['getData']('text/plain'),_0x328009=_0x249766['dataset']['taskId'];if(_0x475f46===_0x328009)return;const _0x534cbf=_0x249766['getBoundingClientRect'](),_0x1a0a99=_0x21291e['clientX']<_0x534cbf['left']+_0x534cbf['width']/0x2;_0x249766['classList']['remove']('drop-before','drop-after'),_0x2bd9d5&&await _0x2bd9d5(_0x475f46,_0x328009,_0x1a0a99);});});const _0x4855fc=document['createElement']('div');return _0x4855fc['className']='task-tab-remove-zone',_0x4855fc['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',_0x4855fc['style']['display']='none',_0x4855fc['addEventListener']('dragover',_0x3ec9ee=>{_0x3ec9ee['preventDefault'](),_0x4855fc['classList']['add']('drag-over');}),_0x4855fc['addEventListener']('dragleave',()=>{_0x4855fc['classList']['remove']('drag-over');}),_0x4855fc['addEventListener']('drop',async _0x565141=>{_0x565141['preventDefault'](),_0x4855fc['classList']['remove']('drag-over');const _0x32e3f0=_0x565141['dataTransfer']['getData']('text/plain');_0x4d6b24&&await _0x4d6b24(_0x32e3f0);}),_0x248ef7['addEventListener']('dragstart',()=>{_0x429910['length']>0x1&&(_0x4855fc['style']['display']='flex');}),_0x248ef7['addEventListener']('dragend',()=>{_0x4855fc['style']['display']='none';}),_0x248ef7['appendChild'](_0x4855fc),{'destroy':()=>{_0x4855fc['remove']();}};}export default VariantGroupingManager;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@profoundlogic/coderflow-server",
3
- "version": "0.9.1",
3
+ "version": "0.9.2",
4
4
  "description": "AI Coder Server - Manages Docker containers for AI agent task execution",
5
5
  "main": "dist/start.js",
6
6
  "type": "module",