@profoundlogic/coderflow-server 0.8.6 → 0.8.8

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 (191) hide show
  1. package/dist/base-image/Dockerfile +3 -2
  2. package/dist/base-image/agent-wrapper.sh +7 -2
  3. package/dist/coder-server.js +1 -1
  4. package/dist/config.js +1 -1
  5. package/dist/lib/agent-keepalive.js +1 -1
  6. package/dist/lib/agent-models.js +1 -1
  7. package/dist/lib/api-keys.js +1 -1
  8. package/dist/lib/apiKeys.js +1 -1
  9. package/dist/lib/app-server-ports.js +1 -1
  10. package/dist/lib/auto-judge.js +1 -1
  11. package/dist/lib/automation-service.js +1 -1
  12. package/dist/lib/basic-auth.js +1 -1
  13. package/dist/lib/bindings.js +1 -1
  14. package/dist/lib/build-history.js +1 -1
  15. package/dist/lib/build-output-service.js +1 -1
  16. package/dist/lib/build-scheduler.js +1 -1
  17. package/dist/lib/build-service.js +1 -1
  18. package/dist/lib/ca-certificates.js +1 -1
  19. package/dist/lib/claude-oauth-refresh.js +1 -1
  20. package/dist/lib/cli/build.js +1 -1
  21. package/dist/lib/cli/cleanup-users.js +1 -1
  22. package/dist/lib/cli/config-command.js +1 -1
  23. package/dist/lib/cli/config.js +1 -1
  24. package/dist/lib/cli/create-user.js +1 -1
  25. package/dist/lib/cli/grant-admin.js +1 -1
  26. package/dist/lib/cli/init.js +1 -1
  27. package/dist/lib/cli/jira.js +1 -1
  28. package/dist/lib/cli/license.js +1 -1
  29. package/dist/lib/cli/list-roles.js +1 -1
  30. package/dist/lib/cli/list-users.js +1 -1
  31. package/dist/lib/cli/server-manager.js +1 -1
  32. package/dist/lib/cli/set-password.js +1 -1
  33. package/dist/lib/compression-filter.js +1 -1
  34. package/dist/lib/config-migration.js +1 -1
  35. package/dist/lib/container-credential-sync.js +1 -1
  36. package/dist/lib/container-tokens.js +1 -1
  37. package/dist/lib/data-dir.js +1 -1
  38. package/dist/lib/deployment-history.js +1 -1
  39. package/dist/lib/deployment-service.js +1 -1
  40. package/dist/lib/docker-utils.js +1 -1
  41. package/dist/lib/email.js +1 -1
  42. package/dist/lib/emailTemplates.js +1 -1
  43. package/dist/lib/entitlement.js +1 -1
  44. package/dist/lib/external-connections.js +1 -1
  45. package/dist/lib/fetch-utils.js +1 -1
  46. package/dist/lib/git-commit-details-route.js +1 -1
  47. package/dist/lib/git-history-diff-guardrails.js +1 -1
  48. package/dist/lib/git-provider-service.js +1 -1
  49. package/dist/lib/git-provider-setup/github-setup-handler.js +1 -1
  50. package/dist/lib/git-provider-setup/index.js +1 -1
  51. package/dist/lib/git-provider-setup/setup-factory.js +1 -1
  52. package/dist/lib/git-provider-setup/setup-interface.js +1 -1
  53. package/dist/lib/git-providers/azure-devops-provider.js +1 -1
  54. package/dist/lib/git-providers/github-app-provider.js +1 -1
  55. package/dist/lib/git-providers/index.js +1 -1
  56. package/dist/lib/git-providers/provider-factory.js +1 -1
  57. package/dist/lib/git-providers/provider-interface.js +1 -1
  58. package/dist/lib/github-urls.js +1 -1
  59. package/dist/lib/group-objective-linking.js +1 -1
  60. package/dist/lib/ibmi-sync.js +1 -1
  61. package/dist/lib/jira-client.js +1 -1
  62. package/dist/lib/judge-blinding.js +1 -1
  63. package/dist/lib/logger.js +1 -1
  64. package/dist/lib/memory-utils.js +1 -1
  65. package/dist/lib/migration-to-scoped-rbac.js +1 -1
  66. package/dist/lib/model-fetcher.js +1 -1
  67. package/dist/lib/notifications.js +1 -1
  68. package/dist/lib/objective-context.js +1 -1
  69. package/dist/lib/oidc-auth.js +1 -1
  70. package/dist/lib/oidc-device-flow.js +1 -1
  71. package/dist/lib/passwordTokens.js +1 -1
  72. package/dist/lib/permission-resolver.js +1 -1
  73. package/dist/lib/pin-cascade.js +1 -1
  74. package/dist/lib/provider-accounts.js +1 -1
  75. package/dist/lib/provider-oauth.js +1 -1
  76. package/dist/lib/provider-profile.js +1 -1
  77. package/dist/lib/provider-token-refresh.js +1 -1
  78. package/dist/lib/rbac-user-state.js +1 -1
  79. package/dist/lib/request-url.js +1 -1
  80. package/dist/lib/rewind.js +1 -1
  81. package/dist/lib/role-definitions.js +1 -1
  82. package/dist/lib/roles.js +1 -1
  83. package/dist/lib/secrets.js +1 -1
  84. package/dist/lib/setup-repo-git-auth.js +1 -1
  85. package/dist/lib/slack-service.js +1 -0
  86. package/dist/lib/state-capture.js +1 -1
  87. package/dist/lib/static-files.js +1 -1
  88. package/dist/lib/task-aliases.js +1 -1
  89. package/dist/lib/task-container-init.js +1 -1
  90. package/dist/lib/task-context-usage.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 -0
  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.css +476 -0
  146. package/dist/web-ui/public/admin.html +96 -17
  147. package/dist/web-ui/public/admin.js +1 -1
  148. package/dist/web-ui/public/agent-event-parser.js +1 -1
  149. package/dist/web-ui/public/app.js +1 -1
  150. package/dist/web-ui/public/approve-dialog.js +1 -1
  151. package/dist/web-ui/public/automation-links.js +1 -1
  152. package/dist/web-ui/public/automation-schedule.js +1 -1
  153. package/dist/web-ui/public/comments-widget.js +1 -1
  154. package/dist/web-ui/public/diff-utils.js +1 -1
  155. package/dist/web-ui/public/docs/_sidebar.md +1 -0
  156. package/dist/web-ui/public/docs/admin/container-lifecycle.md +102 -0
  157. package/dist/web-ui/public/docs/admin/jira.md +20 -3
  158. package/dist/web-ui/public/docs/docsify-proxy-helper.js +1 -0
  159. package/dist/web-ui/public/docs/index.html +25 -18
  160. package/dist/web-ui/public/environments.html +1 -0
  161. package/dist/web-ui/public/environments.js +1 -1
  162. package/dist/web-ui/public/feedback-widget.js +1 -1
  163. package/dist/web-ui/public/file-selection-tree.js +1 -1
  164. package/dist/web-ui/public/git-history-lazy-utils.js +1 -1
  165. package/dist/web-ui/public/git-history.js +1 -1
  166. package/dist/web-ui/public/git-status.js +1 -1
  167. package/dist/web-ui/public/ibmi-file-filter.js +1 -1
  168. package/dist/web-ui/public/index.js +1 -1
  169. package/dist/web-ui/public/login.js +1 -1
  170. package/dist/web-ui/public/markdown-editor.js +1 -1
  171. package/dist/web-ui/public/markdown-file-editor.js +1 -1
  172. package/dist/web-ui/public/modal-maximize.js +1 -1
  173. package/dist/web-ui/public/notifications.js +1 -1
  174. package/dist/web-ui/public/permissions.js +1 -1
  175. package/dist/web-ui/public/pr-dialog.js +1 -1
  176. package/dist/web-ui/public/roles.js +1 -1
  177. package/dist/web-ui/public/settings.html +245 -0
  178. package/dist/web-ui/public/settings.js +1 -1
  179. package/dist/web-ui/public/setup-password.js +1 -1
  180. package/dist/web-ui/public/skills.js +1 -1
  181. package/dist/web-ui/public/sse-client.js +1 -1
  182. package/dist/web-ui/public/sse-client.transport-warning.js +1 -0
  183. package/dist/web-ui/public/sse-shared-worker.js +1 -1
  184. package/dist/web-ui/public/task-judging-helpers.js +1 -1
  185. package/dist/web-ui/public/task.js +1 -1
  186. package/dist/web-ui/public/teams.js +1 -1
  187. package/dist/web-ui/public/terminal.js +1 -1
  188. package/dist/web-ui/public/theme.js +1 -1
  189. package/dist/web-ui/public/users.js +1 -1
  190. package/dist/web-ui/public/variant-grouping.js +1 -1
  191. 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 _0x36cb84=state['currentUser'];if(!Permissions['hasServerPermission'](_0x36cb84,'teams:view')&&!Permissions['hasTeamPermission'](_0x36cb84,'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'](_0x36cb84,'*')||Permissions['hasTeamPermission'](_0x36cb84,'teams:manage'))&&(document['getElementById']('create-team-btn')['hidden']=![]),bindEventListeners(),await Promise['all']([loadTeams(),loadUsers(),loadRoles(),loadEnvironments()]),renderTeams();});async function loadTeams(){const _0x3b8594=document['getElementById']('teams-loading'),_0xaa5c56=document['getElementById']('teams-error'),_0x3a366e=document['getElementById']('teams-content');try{_0x3b8594['hidden']=![],_0xaa5c56['hidden']=!![],_0x3a366e['hidden']=!![];const {teams:_0x4ce79e}=await API['getTeams']();state['teams']=_0x4ce79e||[],renderTeams(),_0x3b8594['hidden']=!![],_0x3a366e['hidden']=![];}catch(_0x892fb3){_0x3b8594['hidden']=!![],_0xaa5c56['hidden']=![],document['getElementById']('teams-error-message')['textContent']=_0x892fb3['message'];}}async function loadUsers(){try{const {users:_0x5658fc}=await API['getUsers']();state['users']=_0x5658fc||[];}catch{state['users']=[];}}async function loadRoles(){try{const {roles:_0x5816cf}=await API['getRoleDefinitions']();state['roles']=_0x5816cf||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x5d2b7a=await API['getEnvironments']();state['environments']=_0x5d2b7a['environments']||[];}catch{state['environments']=[];}}function renderTeams(){const _0x443d76=document['getElementById']('teams-table-body'),_0x5e7396=document['getElementById']('team-count');if(!_0x443d76)return;_0x5e7396&&(_0x5e7396['textContent']=state['teams']['length']+'\x20team'+(state['teams']['length']===0x1?'':'s'));if(state['teams']['length']===0x0){_0x443d76['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 _0x588420=Permissions['hasServerPermission'](state['currentUser'],'*');_0x443d76['innerHTML']=state['teams']['map'](_0x2b3ce9=>{const _0x144fb7=_0x588420||_0x2b3ce9['canManageTeam'],_0x1c647c=_0x588420||_0x2b3ce9['canManageMembers'],_0x367744=_0x144fb7||_0x1c647c,_0x27aee2=(_0x2b3ce9['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'](_0x2b3ce9['name'])+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x2b3ce9['description']?'<div\x20style=\x22font-size:\x200.8em;\x20color:\x20var(--color-text-secondary);\x20margin-top:\x200.15rem;\x22>'+Utils['escapeHtml'](_0x2b3ce9['description'])+'</div>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+_0x27aee2+'</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'+(_0x367744?'<button\x20class=\x22btn-icon\x22\x20title=\x22Edit\x20team\x22\x20onclick=\x22window.openTeamModal(\x27'+_0x2b3ce9['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'+(_0x144fb7?'<button\x20class=\x22btn-icon\x22\x20title=\x22Access\x20bindings\x22\x20onclick=\x22window.openBindingsModal(\x27'+_0x2b3ce9['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'+(_0x144fb7?'<button\x20class=\x22btn-icon\x20btn-danger\x22\x20title=\x22Delete\x20team\x22\x20onclick=\x22window.deleteTeam(\x27'+_0x2b3ce9['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(_0x42b441){const _0xe128eb=state['teams']['find'](_0x1474ba=>_0x1474ba['id']===_0x42b441);if(!_0xe128eb)return;state['editingTeamId']=_0x42b441;const _0x4b2eca=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x4a69cf=_0x4b2eca||_0xe128eb['canManageTeam'],_0x132f5a=_0x4b2eca||_0xe128eb['canManageMembers'],_0x1df9c5=_0x4a69cf,_0x4f9e31=_0x4a69cf||_0x132f5a,_0x41c4a7=_0xe128eb['name'],_0x31f945=_0xe128eb['description']||'';state['modalSnapshot']={'name':_0x41c4a7,'description':_0x31f945},document['getElementById']('team-modal-title')['textContent']=_0x41c4a7,document['getElementById']('team-name')['value']=_0x41c4a7,document['getElementById']('team-name')['disabled']=!_0x1df9c5,document['getElementById']('team-description')['value']=_0x31f945,document['getElementById']('team-description')['disabled']=!_0x1df9c5,document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=![],document['getElementById']('save-team')['hidden']=!_0x1df9c5,renderMembersList(_0xe128eb),updateMemberSelect(_0xe128eb),document['getElementById']('team-modal')['hidden']=![];};function isTeamModalDirty(){if(!state['modalSnapshot'])return![];const _0x1c6ba0=document['getElementById']('team-name')['value']['trim'](),_0x20d03d=document['getElementById']('team-description')['value']['trim']();return _0x1c6ba0!==state['modalSnapshot']['name']||_0x20d03d!==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(_0x6fc85f){const _0x389331=state['teams']['find'](_0x3acdc4=>_0x3acdc4['id']===_0x6fc85f);if(!_0x389331)return;state['bindingsTeamId']=_0x6fc85f,document['getElementById']('bindings-modal-title')['textContent']='Access\x20Bindings\x20—\x20'+_0x389331['name'],document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('bindings-modal')['hidden']=![],loadTeamBindings(_0x6fc85f);};function hideBindingsModal(){document['getElementById']('bindings-modal')['hidden']=!![],state['bindingsTeamId']=null;}function renderMembersList(_0x701679){const _0x4e2351=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x35d8ac=_0x4e2351||_0x701679['canManageMembers']||_0x701679['canManageTeam'],_0x53bc34=_0x701679['members']||[],_0x34d2ab=document['getElementById']('members-list');if(_0x53bc34['length']===0x0){_0x34d2ab['innerHTML']='<p\x20style=\x22font-size:\x200.875rem;\x20color:\x20var(--color-text-secondary);\x20margin:\x200.25rem\x200;\x22>No\x20members\x20yet</p>';return;}_0x34d2ab['innerHTML']=_0x53bc34['map'](_0x125a3d=>{const _0x4165c5=state['users']['find'](_0xa8820c=>_0xa8820c['id']===_0x125a3d),_0x28de8e=_0x4165c5?''+Utils['escapeHtml'](_0x4165c5['username'])+(_0x4165c5['name']?'\x20<span\x20style=\x22color:\x20var(--color-text-secondary);\x20font-size:\x200.85em;\x22>('+Utils['escapeHtml'](_0x4165c5['name'])+')</span>':''):Utils['escapeHtml'](_0x125a3d);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'+_0x28de8e+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x35d8ac?'<button\x20type=\x22button\x22\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.removeMemberClick(\x27'+_0x125a3d+'\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 _0x130a70=document['getElementById']('add-member-row');if(_0x130a70)_0x130a70['style']['display']=_0x35d8ac?'flex':'none';}function updateMemberSelect(_0x594101){const _0x4ba4ca=document['getElementById']('add-member-select');if(!_0x4ba4ca)return;const _0x61e14e=new Set(_0x594101['members']||[]),_0x54f969=state['users']['filter'](_0x1498f6=>!_0x61e14e['has'](_0x1498f6['id']));_0x4ba4ca['innerHTML']='<option\x20value=\x22\x22>Add\x20a\x20member…</option>'+_0x54f969['map'](_0x491d8c=>'<option\x20value=\x22'+_0x491d8c['id']+'\x22>'+Utils['escapeHtml'](_0x491d8c['username'])+(_0x491d8c['name']?'\x20('+Utils['escapeHtml'](_0x491d8c['name'])+')':'')+'</option>')['join']('');}async function addMember(){const _0x2e8da8=document['getElementById']('add-member-select'),_0x5a126d=_0x2e8da8['value'];if(!_0x5a126d||!state['editingTeamId'])return;try{const {team:_0x3e664a}=await API['addTeamMember'](state['editingTeamId'],_0x5a126d);syncTeamInState(_0x3e664a),renderMembersList(_0x3e664a),updateMemberSelect(_0x3e664a),_0x2e8da8['value']='',Utils['showToast']('Member\x20added','success');}catch(_0xab9e87){Utils['showToast'](_0xab9e87['message'],'error');}}window['removeMemberClick']=async function(_0xc3d956){if(!state['editingTeamId'])return;try{const {team:_0x42605a}=await API['removeTeamMember'](state['editingTeamId'],_0xc3d956);syncTeamInState(_0x42605a),renderMembersList(_0x42605a),updateMemberSelect(_0x42605a),Utils['showToast']('Member\x20removed','success');}catch(_0x18daca){Utils['showToast'](_0x18daca['message'],'error');}};async function loadTeamBindings(_0x568877){const _0x4422c3=document['getElementById']('bindings-loading'),_0x52b0b4=document['getElementById']('bindings-empty'),_0x37eedf=document['getElementById']('bindings-list-container'),_0x42c677=document['getElementById']('add-binding-btn');_0x4422c3['hidden']=![],_0x52b0b4['hidden']=!![],_0x37eedf['style']['display']='none',_0x42c677['hidden']=!![],document['getElementById']('add-binding-form')['hidden']=!![];try{const {bindings:_0x3f3b0b}=await API['getBindings']({'subject_type':'team','subject_id':_0x568877});state['teamBindings']=_0x3f3b0b||[],_0x4422c3['hidden']=!![],state['teamBindings']['length']===0x0?_0x52b0b4['hidden']=![]:(_0x37eedf['style']['display']='',renderBindingsTable()),(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage'))&&(_0x42c677['hidden']=![]);}catch(_0x294cab){_0x4422c3['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x294cab['message'],'error');}}function renderBindingsTable(){const _0x26cd16=document['getElementById']('bindings-table-body');if(!_0x26cd16)return;const _0x181000=Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage');_0x26cd16['innerHTML']=state['teamBindings']['map'](_0x58b8e5=>{const _0x8e8cde=_0x58b8e5['resource_type']==='server'?'Server':_0x58b8e5['resource_id']==='*'?'All\x20'+_0x58b8e5['resource_type']+'s':Utils['escapeHtml'](_0x58b8e5['resource_name']||_0x58b8e5['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x8e8cde+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x58b8e5['role_name']||_0x58b8e5['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x181000?'<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteBindingClick(\x27'+_0x58b8e5['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 _0xfb2ba0=document['getElementById']('binding-resource-type');_0xfb2ba0['value']='environment',updateBindingFormForResourceType('environment');}function onBindingResourceTypeChange(){const _0x1eea2c=document['getElementById']('binding-resource-type')['value'];updateBindingFormForResourceType(_0x1eea2c);}function updateBindingFormForResourceType(_0x454821){const _0x2be2f4=document['getElementById']('binding-resource-container'),_0x971ca7=document['getElementById']('binding-resource'),_0x22019f=document['getElementById']('binding-role');if(_0x454821==='server')_0x2be2f4['style']['display']='none';else{_0x2be2f4['style']['display']='';if(_0x454821==='environment'){const _0x1f9fe8=new Set(state['teamBindings']['filter'](_0x3ef62a=>_0x3ef62a['resource_type']==='environment')['map'](_0x24b299=>_0x24b299['resource_id'])),_0x55771c=state['environments']['filter'](_0x29d850=>!_0x1f9fe8['has'](_0x29d850['name']));_0x971ca7['innerHTML']=_0x55771c['length']?_0x55771c['map'](_0x5d1a64=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x5d1a64['name'])+'\x22>'+Utils['escapeHtml'](_0x5d1a64['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x454821==='team'){const _0x16a105=new Set(state['teamBindings']['filter'](_0x26b432=>_0x26b432['resource_type']==='team')['map'](_0x70a53d=>_0x70a53d['resource_id'])),_0x21d12a=state['teams']['filter'](_0x220fd5=>!_0x16a105['has'](_0x220fd5['id']));_0x971ca7['innerHTML']=_0x21d12a['length']?_0x21d12a['map'](_0x52294c=>'<option\x20value=\x22'+_0x52294c['id']+'\x22>'+Utils['escapeHtml'](_0x52294c['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x24f2ba=state['roles']['filter'](_0x33063f=>_0x33063f['resource_type']===_0x454821);_0x22019f['innerHTML']=_0x24f2ba['length']?_0x24f2ba['filter'](_0x2df24f=>{const _0xed9995=_0x454821==='server'?undefined:_0x971ca7['value'];return!state['teamBindings']['some'](_0x40bac1=>_0x40bac1['resource_type']===_0x454821&&_0x40bac1['role_id']===_0x2df24f['id']&&(_0x454821==='server'||_0x40bac1['resource_id']===_0xed9995));})['map'](_0x96e7d3=>'<option\x20value=\x22'+_0x96e7d3['id']+'\x22>'+Utils['escapeHtml'](_0x96e7d3['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 _0x369b12=document['getElementById']('binding-resource-type')['value'],_0x27c9ec=document['getElementById']('binding-role')['value'];if(!_0x27c9ec||!state['bindingsTeamId'])return;const _0x50447a=_0x369b12==='server'?undefined:document['getElementById']('binding-resource')['value'];if(_0x369b12!=='server'&&!_0x50447a)return;const _0x40ee66=document['getElementById']('save-binding-btn');_0x40ee66['disabled']=!![],_0x40ee66['textContent']='Adding…';try{const _0x39db68={'subject_type':'team','subject_id':state['bindingsTeamId'],'role_id':_0x27c9ec,'resource_type':_0x369b12};if(_0x50447a)_0x39db68['resource_id']=_0x50447a;await API['createBinding'](_0x39db68),Utils['showToast']('Binding\x20added','success'),document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![],await loadTeamBindings(state['bindingsTeamId']);}catch(_0x585b74){Utils['showToast'](_0x585b74['message'],'error');}finally{_0x40ee66['disabled']=![],_0x40ee66['textContent']='Add\x20Binding';}}window['deleteBindingClick']=async function(_0x3934cb){try{await API['deleteBinding'](_0x3934cb),Utils['showToast']('Binding\x20removed','success'),await loadTeamBindings(state['bindingsTeamId']);}catch(_0x5797df){Utils['showToast'](_0x5797df['message'],'error');}};async function saveTeam(){const _0x187f42=document['getElementById']('team-name')['value']['trim'](),_0x204e46=document['getElementById']('team-description')['value']['trim'](),_0x45cfa7=document['getElementById']('team-form-error'),_0x15188e=document['getElementById']('save-team');if(!_0x187f42){_0x45cfa7['textContent']='Team\x20name\x20is\x20required',_0x45cfa7['hidden']=![];return;}_0x45cfa7['hidden']=!![];const _0x410902=_0x15188e['textContent'];_0x15188e['disabled']=!![],_0x15188e['textContent']=state['editingTeamId']?'Saving…':'Creating…';try{if(state['editingTeamId']){const {team:_0x1b38ef}=await API['updateTeam'](state['editingTeamId'],{'name':_0x187f42,'description':_0x204e46});syncTeamInState(_0x1b38ef),document['getElementById']('team-modal-title')['textContent']=_0x1b38ef['name'],Utils['showToast']('Team\x20updated','success');}else await API['createTeam']({'name':_0x187f42,'description':_0x204e46}),Utils['showToast']('Team\x20created','success');_0x15188e['disabled']=![],_0x15188e['textContent']=_0x410902,hideTeamModal(),await loadTeams();}catch(_0x39d984){_0x45cfa7['textContent']=_0x39d984['message'],_0x45cfa7['hidden']=![],_0x15188e['disabled']=![],_0x15188e['textContent']=_0x410902;}}window['deleteTeam']=function(_0x272a16){const _0x5dcf46=state['teams']['find'](_0xa8605c=>_0xa8605c['id']===_0x272a16);if(!_0x5dcf46)return;state['deletingTeamId']=_0x272a16,document['getElementById']('delete-team-name')['textContent']=_0x5dcf46['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 _0x1a35c5=document['getElementById']('confirm-delete-team');_0x1a35c5['disabled']=!![],_0x1a35c5['textContent']='Deleting…';try{await API['deleteTeam'](state['deletingTeamId']),Utils['showToast']('Team\x20deleted','success'),_0x1a35c5['disabled']=![],_0x1a35c5['textContent']='Delete\x20Team',hideDeleteModal(),await loadTeams();}catch(_0x33c049){Utils['showToast']('Failed\x20to\x20delete\x20team:\x20'+_0x33c049['message'],'error'),_0x1a35c5['disabled']=![],_0x1a35c5['textContent']='Delete\x20Team';}}function syncTeamInState(_0x213791){const _0x42d442=state['teams']['findIndex'](_0x5acb46=>_0x5acb46['id']===_0x213791['id']);if(_0x42d442>=0x0)state['teams'][_0x42d442]=_0x213791;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 _0x48ac05=state['currentUser'];if(!Permissions['hasServerPermission'](_0x48ac05,'teams:view')&&!Permissions['hasTeamPermission'](_0x48ac05,'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'](_0x48ac05,'*')||Permissions['hasTeamPermission'](_0x48ac05,'teams:manage'))&&(document['getElementById']('create-team-btn')['hidden']=![]),bindEventListeners(),await Promise['all']([loadTeams(),loadUsers(),loadRoles(),loadEnvironments()]),renderTeams();});async function loadTeams(){const _0x22af61=document['getElementById']('teams-loading'),_0x92951a=document['getElementById']('teams-error'),_0x2c527a=document['getElementById']('teams-content');try{_0x22af61['hidden']=![],_0x92951a['hidden']=!![],_0x2c527a['hidden']=!![];const {teams:_0x15e8df}=await API['getTeams']();state['teams']=_0x15e8df||[],renderTeams(),_0x22af61['hidden']=!![],_0x2c527a['hidden']=![];}catch(_0x23da7d){_0x22af61['hidden']=!![],_0x92951a['hidden']=![],document['getElementById']('teams-error-message')['textContent']=_0x23da7d['message'];}}async function loadUsers(){try{const {users:_0x1faedf}=await API['getUsers']();state['users']=_0x1faedf||[];}catch{state['users']=[];}}async function loadRoles(){try{const {roles:_0x4e8ffc}=await API['getRoleDefinitions']();state['roles']=_0x4e8ffc||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x4a5161=await API['getEnvironments']();state['environments']=_0x4a5161['environments']||[];}catch{state['environments']=[];}}function renderTeams(){const _0x31548a=document['getElementById']('teams-table-body'),_0x46a841=document['getElementById']('team-count');if(!_0x31548a)return;_0x46a841&&(_0x46a841['textContent']=state['teams']['length']+'\x20team'+(state['teams']['length']===0x1?'':'s'));if(state['teams']['length']===0x0){_0x31548a['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 _0x539216=Permissions['hasServerPermission'](state['currentUser'],'*');_0x31548a['innerHTML']=state['teams']['map'](_0x1be4b0=>{const _0x5daed9=_0x539216||_0x1be4b0['canManageTeam'],_0x4909c5=_0x539216||_0x1be4b0['canManageMembers'],_0x5da86d=_0x5daed9||_0x4909c5,_0x3c535c=(_0x1be4b0['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'](_0x1be4b0['name'])+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x1be4b0['description']?'<div\x20style=\x22font-size:\x200.8em;\x20color:\x20var(--color-text-secondary);\x20margin-top:\x200.15rem;\x22>'+Utils['escapeHtml'](_0x1be4b0['description'])+'</div>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+_0x3c535c+'</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'+(_0x5da86d?'<button\x20class=\x22btn-icon\x22\x20title=\x22Edit\x20team\x22\x20onclick=\x22window.openTeamModal(\x27'+_0x1be4b0['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'+(_0x5daed9?'<button\x20class=\x22btn-icon\x22\x20title=\x22Access\x20bindings\x22\x20onclick=\x22window.openBindingsModal(\x27'+_0x1be4b0['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'+(_0x5daed9?'<button\x20class=\x22btn-icon\x20btn-danger\x22\x20title=\x22Delete\x20team\x22\x20onclick=\x22window.deleteTeam(\x27'+_0x1be4b0['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(_0x55e410){const _0x40ff65=state['teams']['find'](_0x1cd8e5=>_0x1cd8e5['id']===_0x55e410);if(!_0x40ff65)return;state['editingTeamId']=_0x55e410;const _0x91726e=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x550660=_0x91726e||_0x40ff65['canManageTeam'],_0x101113=_0x91726e||_0x40ff65['canManageMembers'],_0x16ac6a=_0x550660,_0x49a203=_0x550660||_0x101113,_0x30544c=_0x40ff65['name'],_0x32eb3c=_0x40ff65['description']||'';state['modalSnapshot']={'name':_0x30544c,'description':_0x32eb3c},document['getElementById']('team-modal-title')['textContent']=_0x30544c,document['getElementById']('team-name')['value']=_0x30544c,document['getElementById']('team-name')['disabled']=!_0x16ac6a,document['getElementById']('team-description')['value']=_0x32eb3c,document['getElementById']('team-description')['disabled']=!_0x16ac6a,document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=![],document['getElementById']('save-team')['hidden']=!_0x16ac6a,renderMembersList(_0x40ff65),updateMemberSelect(_0x40ff65),document['getElementById']('team-modal')['hidden']=![];};function isTeamModalDirty(){if(!state['modalSnapshot'])return![];const _0x4e715a=document['getElementById']('team-name')['value']['trim'](),_0x1d591e=document['getElementById']('team-description')['value']['trim']();return _0x4e715a!==state['modalSnapshot']['name']||_0x1d591e!==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(_0x500273){const _0x900ce0=state['teams']['find'](_0x117119=>_0x117119['id']===_0x500273);if(!_0x900ce0)return;state['bindingsTeamId']=_0x500273,document['getElementById']('bindings-modal-title')['textContent']='Access\x20Bindings\x20—\x20'+_0x900ce0['name'],document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('bindings-modal')['hidden']=![],loadTeamBindings(_0x500273);};function hideBindingsModal(){document['getElementById']('bindings-modal')['hidden']=!![],state['bindingsTeamId']=null;}function renderMembersList(_0x38aaa4){const _0x14f406=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x28e8b0=_0x14f406||_0x38aaa4['canManageMembers']||_0x38aaa4['canManageTeam'],_0x213102=_0x38aaa4['members']||[],_0x2e3ba9=document['getElementById']('members-list');if(_0x213102['length']===0x0){_0x2e3ba9['innerHTML']='<p\x20style=\x22font-size:\x200.875rem;\x20color:\x20var(--color-text-secondary);\x20margin:\x200.25rem\x200;\x22>No\x20members\x20yet</p>';return;}_0x2e3ba9['innerHTML']=_0x213102['map'](_0x2bfd10=>{const _0x29ab81=state['users']['find'](_0x4e15bd=>_0x4e15bd['id']===_0x2bfd10),_0x1e7675=_0x29ab81?''+Utils['escapeHtml'](_0x29ab81['username'])+(_0x29ab81['name']?'\x20<span\x20style=\x22color:\x20var(--color-text-secondary);\x20font-size:\x200.85em;\x22>('+Utils['escapeHtml'](_0x29ab81['name'])+')</span>':''):Utils['escapeHtml'](_0x2bfd10);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'+_0x1e7675+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x28e8b0?'<button\x20type=\x22button\x22\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.removeMemberClick(\x27'+_0x2bfd10+'\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 _0x4f1809=document['getElementById']('add-member-row');if(_0x4f1809)_0x4f1809['style']['display']=_0x28e8b0?'flex':'none';}function updateMemberSelect(_0x494b3f){const _0x777655=document['getElementById']('add-member-select');if(!_0x777655)return;const _0x26aee8=new Set(_0x494b3f['members']||[]),_0x4967ee=state['users']['filter'](_0x165ecc=>!_0x26aee8['has'](_0x165ecc['id']));_0x777655['innerHTML']='<option\x20value=\x22\x22>Add\x20a\x20member…</option>'+_0x4967ee['map'](_0x33dff1=>'<option\x20value=\x22'+_0x33dff1['id']+'\x22>'+Utils['escapeHtml'](_0x33dff1['username'])+(_0x33dff1['name']?'\x20('+Utils['escapeHtml'](_0x33dff1['name'])+')':'')+'</option>')['join']('');}async function addMember(){const _0xb1cf3b=document['getElementById']('add-member-select'),_0x55a57b=_0xb1cf3b['value'];if(!_0x55a57b||!state['editingTeamId'])return;try{const {team:_0x35063c}=await API['addTeamMember'](state['editingTeamId'],_0x55a57b);syncTeamInState(_0x35063c),renderMembersList(_0x35063c),updateMemberSelect(_0x35063c),_0xb1cf3b['value']='',Utils['showToast']('Member\x20added','success');}catch(_0x2892df){Utils['showToast'](_0x2892df['message'],'error');}}window['removeMemberClick']=async function(_0x331ced){if(!state['editingTeamId'])return;try{const {team:_0x390e92}=await API['removeTeamMember'](state['editingTeamId'],_0x331ced);syncTeamInState(_0x390e92),renderMembersList(_0x390e92),updateMemberSelect(_0x390e92),Utils['showToast']('Member\x20removed','success');}catch(_0x55b204){Utils['showToast'](_0x55b204['message'],'error');}};async function loadTeamBindings(_0x3b575e){const _0xdeea3c=document['getElementById']('bindings-loading'),_0x19b0e2=document['getElementById']('bindings-empty'),_0x1c538d=document['getElementById']('bindings-list-container'),_0x43ff93=document['getElementById']('add-binding-btn');_0xdeea3c['hidden']=![],_0x19b0e2['hidden']=!![],_0x1c538d['style']['display']='none',_0x43ff93['hidden']=!![],document['getElementById']('add-binding-form')['hidden']=!![];try{const {bindings:_0x2ab314}=await API['getBindings']({'subject_type':'team','subject_id':_0x3b575e});state['teamBindings']=_0x2ab314||[],_0xdeea3c['hidden']=!![],state['teamBindings']['length']===0x0?_0x19b0e2['hidden']=![]:(_0x1c538d['style']['display']='',renderBindingsTable()),(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage'))&&(_0x43ff93['hidden']=![]);}catch(_0x21068e){_0xdeea3c['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x21068e['message'],'error');}}function renderBindingsTable(){const _0x432808=document['getElementById']('bindings-table-body');if(!_0x432808)return;const _0x285df3=Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage');_0x432808['innerHTML']=state['teamBindings']['map'](_0x5d410e=>{const _0x4193ca=_0x5d410e['resource_type']==='server'?'Server':_0x5d410e['resource_id']==='*'?'All\x20'+_0x5d410e['resource_type']+'s':Utils['escapeHtml'](_0x5d410e['resource_name']||_0x5d410e['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x4193ca+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x5d410e['role_name']||_0x5d410e['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x285df3?'<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteBindingClick(\x27'+_0x5d410e['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 _0x1685f7=document['getElementById']('binding-resource-type');_0x1685f7['value']='environment',updateBindingFormForResourceType('environment');}function onBindingResourceTypeChange(){const _0x218052=document['getElementById']('binding-resource-type')['value'];updateBindingFormForResourceType(_0x218052);}function updateBindingFormForResourceType(_0x2c4aaa){const _0x484d25=document['getElementById']('binding-resource-container'),_0x3385e5=document['getElementById']('binding-resource'),_0x4c0901=document['getElementById']('binding-role');if(_0x2c4aaa==='server')_0x484d25['style']['display']='none';else{_0x484d25['style']['display']='';if(_0x2c4aaa==='environment'){const _0x2a4d26=new Set(state['teamBindings']['filter'](_0x1dd2cd=>_0x1dd2cd['resource_type']==='environment')['map'](_0x39a2e1=>_0x39a2e1['resource_id'])),_0x1ecbc7=state['environments']['filter'](_0x134a73=>!_0x2a4d26['has'](_0x134a73['name']));_0x3385e5['innerHTML']=_0x1ecbc7['length']?_0x1ecbc7['map'](_0xc6c2a2=>'<option\x20value=\x22'+Utils['escapeHtml'](_0xc6c2a2['name'])+'\x22>'+Utils['escapeHtml'](_0xc6c2a2['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x2c4aaa==='team'){const _0x4567bd=new Set(state['teamBindings']['filter'](_0x35df01=>_0x35df01['resource_type']==='team')['map'](_0x2a7cec=>_0x2a7cec['resource_id'])),_0x2aaf91=state['teams']['filter'](_0x32c906=>!_0x4567bd['has'](_0x32c906['id']));_0x3385e5['innerHTML']=_0x2aaf91['length']?_0x2aaf91['map'](_0x2eb27b=>'<option\x20value=\x22'+_0x2eb27b['id']+'\x22>'+Utils['escapeHtml'](_0x2eb27b['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x21bf18=state['roles']['filter'](_0x411531=>_0x411531['resource_type']===_0x2c4aaa);_0x4c0901['innerHTML']=_0x21bf18['length']?_0x21bf18['filter'](_0x312790=>{const _0x5b1273=_0x2c4aaa==='server'?undefined:_0x3385e5['value'];return!state['teamBindings']['some'](_0x348f57=>_0x348f57['resource_type']===_0x2c4aaa&&_0x348f57['role_id']===_0x312790['id']&&(_0x2c4aaa==='server'||_0x348f57['resource_id']===_0x5b1273));})['map'](_0x3ddaaf=>'<option\x20value=\x22'+_0x3ddaaf['id']+'\x22>'+Utils['escapeHtml'](_0x3ddaaf['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 _0x2615a7=document['getElementById']('binding-resource-type')['value'],_0xae2ffc=document['getElementById']('binding-role')['value'];if(!_0xae2ffc||!state['bindingsTeamId'])return;const _0x381602=_0x2615a7==='server'?undefined:document['getElementById']('binding-resource')['value'];if(_0x2615a7!=='server'&&!_0x381602)return;const _0x297b61=document['getElementById']('save-binding-btn');_0x297b61['disabled']=!![],_0x297b61['textContent']='Adding…';try{const _0x4f107b={'subject_type':'team','subject_id':state['bindingsTeamId'],'role_id':_0xae2ffc,'resource_type':_0x2615a7};if(_0x381602)_0x4f107b['resource_id']=_0x381602;await API['createBinding'](_0x4f107b),Utils['showToast']('Binding\x20added','success'),document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![],await loadTeamBindings(state['bindingsTeamId']);}catch(_0x2b8f3c){Utils['showToast'](_0x2b8f3c['message'],'error');}finally{_0x297b61['disabled']=![],_0x297b61['textContent']='Add\x20Binding';}}window['deleteBindingClick']=async function(_0x1fa032){try{await API['deleteBinding'](_0x1fa032),Utils['showToast']('Binding\x20removed','success'),await loadTeamBindings(state['bindingsTeamId']);}catch(_0x1510ea){Utils['showToast'](_0x1510ea['message'],'error');}};async function saveTeam(){const _0x7626fe=document['getElementById']('team-name')['value']['trim'](),_0x5ceb8b=document['getElementById']('team-description')['value']['trim'](),_0xbd4285=document['getElementById']('team-form-error'),_0x2402aa=document['getElementById']('save-team');if(!_0x7626fe){_0xbd4285['textContent']='Team\x20name\x20is\x20required',_0xbd4285['hidden']=![];return;}_0xbd4285['hidden']=!![];const _0x208c1a=_0x2402aa['textContent'];_0x2402aa['disabled']=!![],_0x2402aa['textContent']=state['editingTeamId']?'Saving…':'Creating…';try{if(state['editingTeamId']){const {team:_0xcb7971}=await API['updateTeam'](state['editingTeamId'],{'name':_0x7626fe,'description':_0x5ceb8b});syncTeamInState(_0xcb7971),document['getElementById']('team-modal-title')['textContent']=_0xcb7971['name'],Utils['showToast']('Team\x20updated','success');}else await API['createTeam']({'name':_0x7626fe,'description':_0x5ceb8b}),Utils['showToast']('Team\x20created','success');_0x2402aa['disabled']=![],_0x2402aa['textContent']=_0x208c1a,hideTeamModal(),await loadTeams();}catch(_0x34e0d9){_0xbd4285['textContent']=_0x34e0d9['message'],_0xbd4285['hidden']=![],_0x2402aa['disabled']=![],_0x2402aa['textContent']=_0x208c1a;}}window['deleteTeam']=function(_0x275c91){const _0x2be40c=state['teams']['find'](_0x1bb5c3=>_0x1bb5c3['id']===_0x275c91);if(!_0x2be40c)return;state['deletingTeamId']=_0x275c91,document['getElementById']('delete-team-name')['textContent']=_0x2be40c['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 _0x2da10e=document['getElementById']('confirm-delete-team');_0x2da10e['disabled']=!![],_0x2da10e['textContent']='Deleting…';try{await API['deleteTeam'](state['deletingTeamId']),Utils['showToast']('Team\x20deleted','success'),_0x2da10e['disabled']=![],_0x2da10e['textContent']='Delete\x20Team',hideDeleteModal(),await loadTeams();}catch(_0x4f0643){Utils['showToast']('Failed\x20to\x20delete\x20team:\x20'+_0x4f0643['message'],'error'),_0x2da10e['disabled']=![],_0x2da10e['textContent']='Delete\x20Team';}}function syncTeamInState(_0x227f16){const _0x1c9ed1=state['teams']['findIndex'](_0xa6f011=>_0xa6f011['id']===_0x227f16['id']);if(_0x1c9ed1>=0x0)state['teams'][_0x1c9ed1]=_0x227f16;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'](_0x40c928=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':_0x40c928}));});let commandSent=![],hasReceivedOutput=![];socket['addEventListener']('message',_0x37ea39=>{try{const _0x4832d0=JSON['parse'](_0x37ea39['data']);if(_0x4832d0['type']==='data'&&typeof _0x4832d0['data']==='string')term['write'](_0x4832d0['data']),!hasReceivedOutput&&_0x4832d0['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(_0x4832d0['type']==='status'&&_0x4832d0['status']){if(_0x4832d0['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'+_0x4832d0['status'],_0x4832d0['status']==='connected'?'success':'info');}else _0x4832d0['type']==='error'&&_0x4832d0['message']&&updateStatus(_0x4832d0['message'],'error');}}catch(_0xb88000){console['error']('Failed\x20to\x20parse\x20terminal\x20message',_0xb88000);}}),socket['addEventListener']('close',_0x2b8101=>{const _0x48866a=_0x2b8101['reason']||'Connection\x20closed';updateStatus(_0x48866a,_0x2b8101['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',_0x1ebce6=>{console['error']('Terminal\x20websocket\x20error',_0x1ebce6),updateStatus('Connection\x20error','error');});function sendResize(){if(socket['readyState']!==WebSocket['OPEN'])return;const _0x284a23=term['cols'],_0xa7d91c=term['rows'];socket['send'](JSON['stringify']({'type':'resize','cols':_0x284a23,'rows':_0xa7d91c}));}function updateStatus(_0x19009a,_0x596fd0='info'){if(!statusEl)return;statusEl['textContent']=_0x19009a,statusEl['dataset']['variant']=_0x596fd0;}async function enrichContainerDetails(_0x1493b6){try{const _0x5a1d2f=await API['getContainer'](_0x1493b6);updateTerminalDetails(_0x5a1d2f);}catch{try{const _0x3e0143=await API['getContainers'](),_0x1013f1=(_0x3e0143['containers']||[])['find'](_0x63e8dd=>_0x63e8dd['containerId']===_0x1493b6||_0x63e8dd['name']===_0x1493b6||_0x63e8dd['fullContainerId']?.['startsWith'](_0x1493b6));if(_0x1013f1){updateTerminalDetails(_0x1013f1);return;}subtitleEl['textContent']='Container\x20'+_0x1493b6['substring'](0x0,0xc);}catch{subtitleEl['textContent']='Container\x20'+_0x1493b6['substring'](0x0,0xc);}}}function updateTerminalDetails(_0x32abd3){const _0x5260ba=_0x32abd3['containerId']||_0x32abd3['name']||_0x32abd3['fullContainerId']||containerId,_0x401a04=_0x32abd3['environment']?'Environment\x20'+_0x32abd3['environment']:'Environment\x20unknown',_0x2957c7=_0x32abd3['defaultAgent']?'\x20·\x20Agent\x20'+_0x32abd3['defaultAgent']:'',_0x10d8ae=_0x32abd3['createdAt']?'\x20·\x20Started\x20'+Utils['formatRelativeTime'](_0x32abd3['createdAt']):'';titleEl['textContent']='Terminal\x20·\x20'+_0x5260ba['substring'](0x0,0xc);const _0x6ba46e=command?'\x20·\x20Command\x20'+command:'';subtitleEl['textContent']=''+_0x401a04+_0x2957c7+_0x10d8ae+_0x6ba46e;}
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'](_0x48e67d=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':_0x48e67d}));});let commandSent=![],hasReceivedOutput=![];socket['addEventListener']('message',_0x21256e=>{try{const _0xf12d=JSON['parse'](_0x21256e['data']);if(_0xf12d['type']==='data'&&typeof _0xf12d['data']==='string')term['write'](_0xf12d['data']),!hasReceivedOutput&&_0xf12d['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(_0xf12d['type']==='status'&&_0xf12d['status']){if(_0xf12d['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'+_0xf12d['status'],_0xf12d['status']==='connected'?'success':'info');}else _0xf12d['type']==='error'&&_0xf12d['message']&&updateStatus(_0xf12d['message'],'error');}}catch(_0x5b06e3){console['error']('Failed\x20to\x20parse\x20terminal\x20message',_0x5b06e3);}}),socket['addEventListener']('close',_0x354c5e=>{const _0x19d392=_0x354c5e['reason']||'Connection\x20closed';updateStatus(_0x19d392,_0x354c5e['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',_0x368d2c=>{console['error']('Terminal\x20websocket\x20error',_0x368d2c),updateStatus('Connection\x20error','error');});function sendResize(){if(socket['readyState']!==WebSocket['OPEN'])return;const _0x3c9be3=term['cols'],_0x418a42=term['rows'];socket['send'](JSON['stringify']({'type':'resize','cols':_0x3c9be3,'rows':_0x418a42}));}function updateStatus(_0x231e1d,_0x434916='info'){if(!statusEl)return;statusEl['textContent']=_0x231e1d,statusEl['dataset']['variant']=_0x434916;}async function enrichContainerDetails(_0x331b05){try{const _0x4387b4=await API['getContainer'](_0x331b05);updateTerminalDetails(_0x4387b4);}catch{try{const _0x1fd42a=await API['getContainers'](),_0x11ae28=(_0x1fd42a['containers']||[])['find'](_0x3e970d=>_0x3e970d['containerId']===_0x331b05||_0x3e970d['name']===_0x331b05||_0x3e970d['fullContainerId']?.['startsWith'](_0x331b05));if(_0x11ae28){updateTerminalDetails(_0x11ae28);return;}subtitleEl['textContent']='Container\x20'+_0x331b05['substring'](0x0,0xc);}catch{subtitleEl['textContent']='Container\x20'+_0x331b05['substring'](0x0,0xc);}}}function updateTerminalDetails(_0x31999d){const _0x58bee8=_0x31999d['containerId']||_0x31999d['name']||_0x31999d['fullContainerId']||containerId,_0xedcb1=_0x31999d['environment']?'Environment\x20'+_0x31999d['environment']:'Environment\x20unknown',_0x41eeea=_0x31999d['defaultAgent']?'\x20·\x20Agent\x20'+_0x31999d['defaultAgent']:'',_0x3dcd00=_0x31999d['createdAt']?'\x20·\x20Started\x20'+Utils['formatRelativeTime'](_0x31999d['createdAt']):'';titleEl['textContent']='Terminal\x20·\x20'+_0x58bee8['substring'](0x0,0xc);const _0xcdd3=command?'\x20·\x20Command\x20'+command:'';subtitleEl['textContent']=''+_0xedcb1+_0x41eeea+_0x3dcd00+_0xcdd3;}
@@ -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 _0xd2af38=localStorage['getItem'](THEME_STORAGE_KEY);if(_0xd2af38&&VALID_THEMES['has'](_0xd2af38))return _0xd2af38;}catch(_0x16fa18){console['warn']('[Theme]\x20Failed\x20to\x20read\x20stored\x20theme\x20preference:',_0x16fa18);}return null;}export function getPreferredTheme(){const _0x49e741=readStoredTheme();if(_0x49e741)return _0x49e741;const _0xedb4c=window['matchMedia']&&window['matchMedia']('(prefers-color-scheme:\x20dark)')['matches'];return _0xedb4c?'dark':'light';}export function getCurrentTheme(){const _0x24d3b3=document['documentElement']['dataset']['theme'];if(_0x24d3b3&&VALID_THEMES['has'](_0x24d3b3))return _0x24d3b3;return getPreferredTheme();}export function applyTheme(_0x4dd81e,{persist:persist=!![],emitEvent:emitEvent=!![]}={}){const _0x331967=VALID_THEMES['has'](_0x4dd81e)?_0x4dd81e:'light';document['documentElement']['dataset']['theme']=_0x331967,document['documentElement']['style']['colorScheme']=_0x331967==='dark'?'dark':'light';if(persist)try{localStorage['setItem'](THEME_STORAGE_KEY,_0x331967);}catch(_0xe196f5){console['warn']('[Theme]\x20Failed\x20to\x20persist\x20theme\x20preference:',_0xe196f5);}return emitEvent&&window['dispatchEvent'](new CustomEvent(THEME_CHANGE_EVENT,{'detail':{'theme':_0x331967}})),_0x331967;}export function initTheme(_0x48ca08={}){const {emitEvent:emitEvent=![]}=_0x48ca08;return applyTheme(getPreferredTheme(),{'persist':![],'emitEvent':emitEvent});}export function toggleTheme(){const _0xaf73c8=getCurrentTheme()==='dark'?'light':'dark';return applyTheme(_0xaf73c8);}export function onThemeChange(_0x20b834,{runImmediately:runImmediately=![]}={}){const _0x52881b=_0x50699e=>{_0x20b834(_0x50699e['detail']['theme']);};return window['addEventListener'](THEME_CHANGE_EVENT,_0x52881b),runImmediately&&_0x20b834(getCurrentTheme()),()=>window['removeEventListener'](THEME_CHANGE_EVENT,_0x52881b);}export function mountThemeToggle(_0x856a9f={}){const {targetSelectors:targetSelectors=DEFAULT_TARGET_SELECTORS}=_0x856a9f,_0xf332c6=targetSelectors['map'](_0x2e4fc4=>document['querySelector'](_0x2e4fc4))['find'](Boolean),_0x4b0f3a=document['createElement']('button');_0x4b0f3a['type']='button',_0x4b0f3a['className']='btn-ghost\x20theme-toggle-btn',_0x4b0f3a['id']='theme-toggle-btn',_0x4b0f3a['setAttribute']('aria-pressed','false'),_0x4b0f3a['style']['padding']='8px',_0x4b0f3a['style']['lineHeight']='0',_0x4b0f3a['style']['width']='36px',_0x4b0f3a['style']['height']='36px',_0x4b0f3a['style']['display']='flex',_0x4b0f3a['style']['alignItems']='center',_0x4b0f3a['style']['justifyContent']='center';const _0x2b5fdc=document['createElement']('span');_0x2b5fdc['className']='theme-icon',_0x2b5fdc['style']['display']='flex',_0x4b0f3a['append'](_0x2b5fdc);const _0x4ad16b='<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>',_0x512c3a='<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>',_0x1c5b2e=_0x1ce989=>{const _0x383242=_0x1ce989==='dark';_0x2b5fdc['innerHTML']=_0x383242?_0x4ad16b:_0x512c3a,_0x4b0f3a['title']=_0x383242?'Switch\x20to\x20light\x20mode':'Switch\x20to\x20dark\x20mode',_0x4b0f3a['dataset']['theme']=_0x1ce989,_0x4b0f3a['setAttribute']('aria-pressed',String(_0x383242));};return _0x4b0f3a['addEventListener']('click',()=>{const _0x38d3b1=getCurrentTheme()==='dark'?'light':'dark';applyTheme(_0x38d3b1);}),_0xf332c6?_0xf332c6['appendChild'](_0x4b0f3a):(_0x4b0f3a['classList']['add']('theme-toggle-floating'),document['body']['appendChild'](_0x4b0f3a)),_0x1c5b2e(initTheme()),onThemeChange(_0x1c5b2e),_0x4b0f3a;}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 _0x3525f9=localStorage['getItem'](THEME_STORAGE_KEY);if(_0x3525f9&&VALID_THEMES['has'](_0x3525f9))return _0x3525f9;}catch(_0xca7c31){console['warn']('[Theme]\x20Failed\x20to\x20read\x20stored\x20theme\x20preference:',_0xca7c31);}return null;}export function getPreferredTheme(){const _0x457f17=readStoredTheme();if(_0x457f17)return _0x457f17;const _0x48847c=window['matchMedia']&&window['matchMedia']('(prefers-color-scheme:\x20dark)')['matches'];return _0x48847c?'dark':'light';}export function getCurrentTheme(){const _0x412e93=document['documentElement']['dataset']['theme'];if(_0x412e93&&VALID_THEMES['has'](_0x412e93))return _0x412e93;return getPreferredTheme();}export function applyTheme(_0x23619c,{persist:persist=!![],emitEvent:emitEvent=!![]}={}){const _0x4afa31=VALID_THEMES['has'](_0x23619c)?_0x23619c:'light';document['documentElement']['dataset']['theme']=_0x4afa31,document['documentElement']['style']['colorScheme']=_0x4afa31==='dark'?'dark':'light';if(persist)try{localStorage['setItem'](THEME_STORAGE_KEY,_0x4afa31);}catch(_0x4f4819){console['warn']('[Theme]\x20Failed\x20to\x20persist\x20theme\x20preference:',_0x4f4819);}return emitEvent&&window['dispatchEvent'](new CustomEvent(THEME_CHANGE_EVENT,{'detail':{'theme':_0x4afa31}})),_0x4afa31;}export function initTheme(_0x4f87b2={}){const {emitEvent:emitEvent=![]}=_0x4f87b2;return applyTheme(getPreferredTheme(),{'persist':![],'emitEvent':emitEvent});}export function toggleTheme(){const _0x25b841=getCurrentTheme()==='dark'?'light':'dark';return applyTheme(_0x25b841);}export function onThemeChange(_0x32b322,{runImmediately:runImmediately=![]}={}){const _0x4d0941=_0x1aa3f2=>{_0x32b322(_0x1aa3f2['detail']['theme']);};return window['addEventListener'](THEME_CHANGE_EVENT,_0x4d0941),runImmediately&&_0x32b322(getCurrentTheme()),()=>window['removeEventListener'](THEME_CHANGE_EVENT,_0x4d0941);}export function mountThemeToggle(_0x11f113={}){const {targetSelectors:targetSelectors=DEFAULT_TARGET_SELECTORS}=_0x11f113,_0x3bb10f=targetSelectors['map'](_0x1c3dd5=>document['querySelector'](_0x1c3dd5))['find'](Boolean),_0x2a2834=document['createElement']('button');_0x2a2834['type']='button',_0x2a2834['className']='btn-ghost\x20theme-toggle-btn',_0x2a2834['id']='theme-toggle-btn',_0x2a2834['setAttribute']('aria-pressed','false'),_0x2a2834['style']['padding']='8px',_0x2a2834['style']['lineHeight']='0',_0x2a2834['style']['width']='36px',_0x2a2834['style']['height']='36px',_0x2a2834['style']['display']='flex',_0x2a2834['style']['alignItems']='center',_0x2a2834['style']['justifyContent']='center';const _0x1b8528=document['createElement']('span');_0x1b8528['className']='theme-icon',_0x1b8528['style']['display']='flex',_0x2a2834['append'](_0x1b8528);const _0x55fb1a='<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>',_0x5c4785='<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>',_0x4bfee7=_0x1cd2de=>{const _0x8de8a2=_0x1cd2de==='dark';_0x1b8528['innerHTML']=_0x8de8a2?_0x55fb1a:_0x5c4785,_0x2a2834['title']=_0x8de8a2?'Switch\x20to\x20light\x20mode':'Switch\x20to\x20dark\x20mode',_0x2a2834['dataset']['theme']=_0x1cd2de,_0x2a2834['setAttribute']('aria-pressed',String(_0x8de8a2));};return _0x2a2834['addEventListener']('click',()=>{const _0x1f2389=getCurrentTheme()==='dark'?'light':'dark';applyTheme(_0x1f2389);}),_0x3bb10f?_0x3bb10f['appendChild'](_0x2a2834):(_0x2a2834['classList']['add']('theme-toggle-floating'),document['body']['appendChild'](_0x2a2834)),_0x4bfee7(initTheme()),onThemeChange(_0x4bfee7),_0x2a2834;}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 _0x26f394=await API['getCurrentUser']();state['currentUser']=_0x26f394;if(!Permissions['hasServerPermission'](_0x26f394,'*')&&!Permissions['hasServerPermission'](_0x26f394,'users:create')){Utils['showToast']('Access\x20denied:\x20Server\x20admin\x20privileges\x20required','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}}catch(_0x1e4b66){window['location']['href']='login.html';}}async function checkEmailConfig(){try{const _0x364336=await API['getEmailConfig']();state['emailConfigured']=_0x364336['configured'];}catch(_0x3058dd){console['error']('Failed\x20to\x20check\x20email\x20config',_0x3058dd),state['emailConfigured']=![];}}async function loadRoles(){try{const {roles:_0x5e9c69}=await API['getRoleDefinitions']();state['roles']=_0x5e9c69||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x1400ad=await API['getEnvironments']();state['environments']=_0x1400ad['environments']||[];}catch{state['environments']=[];}}async function loadTeams(){try{const {teams:_0x519e21}=await API['getTeams']();state['teams']=_0x519e21||[];}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 _0x541627=document['getElementById']('users-loading'),_0x43f780=document['getElementById']('users-error'),_0x44bd82=document['getElementById']('users-content');try{_0x541627['hidden']=![],_0x43f780['hidden']=!![],_0x44bd82['hidden']=!![];const _0x6d4ec7=await API['getUsers']();state['users']=_0x6d4ec7['users']||[],renderUsers(),_0x541627['hidden']=!![],_0x44bd82['hidden']=![];}catch(_0x5f44c0){console['error']('Failed\x20to\x20load\x20users',_0x5f44c0),_0x541627['hidden']=!![],_0x43f780['hidden']=![],document['getElementById']('users-error-message')['textContent']=_0x5f44c0['message'];}}function renderUsers(){const _0x1c673f=document['getElementById']('users-table-body'),_0x57e614=document['getElementById']('user-count');if(!_0x1c673f)return;_0x57e614&&(_0x57e614['textContent']=state['users']['length']+'\x20user'+(state['users']['length']===0x1?'':'s'));const _0x4e1673=[...state['users']]['sort']((_0x24e6bc,_0xf478ba)=>{const _0x1309d8=new Date(_0x24e6bc['created_at'])['getTime'](),_0x2c513e=new Date(_0xf478ba['created_at'])['getTime']();return _0x2c513e-_0x1309d8;});_0x1c673f['innerHTML']=_0x4e1673['map'](_0x531795=>'\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'](_0x531795['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'](_0x531795['name'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x531795['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'+(_0x531795['isServerAdmin']?'<span\x20class=\x22role-badge\x20role-admin\x22>Server\x20Admin</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x531795['hasUserBinding']?'<span\x20class=\x22role-badge\x20role-user-binding\x22>User\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x531795['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'](_0x531795['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'+_0x531795['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'+_0x531795['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'+_0x531795['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'+_0x531795['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(_0x27c35c){const _0x5c4e03=state['users']['find'](_0x5a6034=>_0x5a6034['id']===_0x27c35c);if(!_0x5c4e03)return;state['bindingsUserId']=_0x27c35c,state['bindingsDirty']=![];const _0x45cd71=document['getElementById']('bindings-modal'),_0x4b82c6=document['getElementById']('bindings-modal-title');_0x4b82c6['textContent']='Access\x20Bindings\x20—\x20'+_0x5c4e03['name'],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],_0x45cd71['hidden']=![],loadUserBindings(_0x27c35c);};function hasUnsavedBindingChanges(){const _0x376d92=document['getElementById']('add-user-binding-form');return _0x376d92&&!_0x376d92['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 _0x5f1bb5=document['getElementById']('bindings-modal');_0x5f1bb5['hidden']=!![];const _0x2e1d04=state['bindingsDirty'];state['bindingsUserId']=null,state['userBindings']=[],state['bindingsDirty']=![],_0x2e1d04&&await loadUsers();}async function loadUserBindings(_0xae2bbe){const _0x2c22d8=document['getElementById']('user-bindings-loading'),_0x74b643=document['getElementById']('user-bindings-empty'),_0x58eccb=document['getElementById']('user-bindings-list-container'),_0x32eb20=document['getElementById']('add-user-binding-btn'),_0x197d7c=document['getElementById']('user-team-bindings-note'),_0x4512fd=document['getElementById']('user-team-bindings-text');_0x2c22d8['hidden']=![],_0x74b643['hidden']=!![],_0x58eccb['style']['display']='none',_0x32eb20['hidden']=!![],_0x197d7c['hidden']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![];try{const [_0x35dff4,_0x17a699]=await Promise['all']([API['getBindings']({'subject_type':'user','subject_id':_0xae2bbe}),API['getTeams']()]);state['userBindings']=_0x35dff4['bindings']||[];const _0x1cdbe1=(_0x17a699['teams']||[])['filter'](_0x58d7b6=>(_0x58d7b6['members']||[])['includes'](_0xae2bbe)),_0x3549f9=[];if(_0x1cdbe1['length']>0x0){const _0x57787c=await Promise['all'](_0x1cdbe1['map'](_0x51dd79=>API['getBindings']({'subject_type':'team','subject_id':_0x51dd79['id']})));for(let _0x144ab3=0x0;_0x144ab3<_0x1cdbe1['length'];_0x144ab3++){const _0x199693=_0x57787c[_0x144ab3]['bindings']||[];_0x199693['length']>0x0&&_0x3549f9['push'](_0x1cdbe1[_0x144ab3]);}}_0x2c22d8['hidden']=!![];state['userBindings']['length']===0x0?_0x74b643['hidden']=![]:(_0x58eccb['style']['display']='',renderUserBindingsTable());if(_0x3549f9['length']>0x0){const _0x3d3103=_0x3549f9['map'](_0x36a5f3=>_0x36a5f3['name']),_0x2003b7=_0x3d3103['length']<=0x3?_0x3d3103['join'](',\x20'):_0x3d3103['slice'](0x0,0x3)['join'](',\x20')+(',\x20and\x20'+(_0x3d3103['length']-0x3)+'\x20more');_0x4512fd['textContent']='This\x20user\x20also\x20has\x20access\x20via\x20team\x20memberships\x20('+_0x2003b7+').';}else _0x4512fd['textContent']='This\x20user\x20has\x20no\x20access\x20via\x20team\x20memberships.';_0x197d7c['hidden']=![],_0x32eb20['hidden']=![];}catch(_0x4a662a){_0x2c22d8['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x4a662a['message'],'error');}}function renderUserBindingsTable(){const _0x17c3de=document['getElementById']('user-bindings-table-body');if(!_0x17c3de)return;_0x17c3de['innerHTML']=state['userBindings']['map'](_0x53659f=>{const _0x42b215=_0x53659f['resource_type']==='server'?'Server':_0x53659f['resource_id']==='*'?'All\x20'+_0x53659f['resource_type']+'s':Utils['escapeHtml'](_0x53659f['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x42b215+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x53659f['role_name']||_0x53659f['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'+_0x53659f['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 _0x1278a8=document['getElementById']('user-binding-resource-type');_0x1278a8['value']='environment',updateUserBindingFormForResourceType('environment');}function onUserBindingResourceTypeChange(){const _0x119c4d=document['getElementById']('user-binding-resource-type')['value'];updateUserBindingFormForResourceType(_0x119c4d);}function updateUserBindingFormForResourceType(_0x1c4d9e){const _0x379155=document['getElementById']('user-binding-resource-container'),_0x181628=document['getElementById']('user-binding-resource'),_0xafa2df=document['getElementById']('user-binding-role');if(_0x1c4d9e==='server')_0x379155['style']['display']='none';else{_0x379155['style']['display']='';if(_0x1c4d9e==='environment'){const _0x526844=new Set(state['userBindings']['filter'](_0x9d8d85=>_0x9d8d85['resource_type']==='environment')['map'](_0xd28e9d=>_0xd28e9d['resource_id'])),_0x570053=state['environments']['filter'](_0x474cd0=>!_0x526844['has'](_0x474cd0['name']));_0x181628['innerHTML']=_0x570053['length']?_0x570053['map'](_0x363771=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x363771['name'])+'\x22>'+Utils['escapeHtml'](_0x363771['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x1c4d9e==='team'){const _0x1ab039=new Set(state['userBindings']['filter'](_0x3d1ce8=>_0x3d1ce8['resource_type']==='team')['map'](_0x4bcf97=>_0x4bcf97['resource_id'])),_0x229316=state['teams']['filter'](_0x483cfd=>!_0x1ab039['has'](_0x483cfd['id']));_0x181628['innerHTML']=_0x229316['length']?_0x229316['map'](_0x2bdeda=>'<option\x20value=\x22'+_0x2bdeda['id']+'\x22>'+Utils['escapeHtml'](_0x2bdeda['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x534772=state['roles']['filter'](_0x54fda1=>_0x54fda1['resource_type']===_0x1c4d9e);_0xafa2df['innerHTML']=_0x534772['length']?_0x534772['filter'](_0x275aac=>{const _0x55c6f=_0x1c4d9e==='server'?undefined:_0x181628['value'];return!state['userBindings']['some'](_0x21555b=>_0x21555b['resource_type']===_0x1c4d9e&&_0x21555b['role_id']===_0x275aac['id']&&(_0x1c4d9e==='server'||_0x21555b['resource_id']===_0x55c6f));})['map'](_0x1e30ad=>'<option\x20value=\x22'+_0x1e30ad['id']+'\x22>'+Utils['escapeHtml'](_0x1e30ad['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 _0x1384ea=document['getElementById']('user-binding-resource-type')['value'],_0x34bb0b=document['getElementById']('user-binding-role')['value'];if(!_0x34bb0b||!state['bindingsUserId'])return;const _0x2d2795=_0x1384ea==='server'?undefined:document['getElementById']('user-binding-resource')['value'];if(_0x1384ea!=='server'&&!_0x2d2795)return;const _0x15a7ce=document['getElementById']('save-user-binding-btn');_0x15a7ce['disabled']=!![],_0x15a7ce['textContent']='Adding…';try{const _0x1df4f0={'subject_type':'user','subject_id':state['bindingsUserId'],'role_id':_0x34bb0b,'resource_type':_0x1384ea};if(_0x2d2795)_0x1df4f0['resource_id']=_0x2d2795;await API['createBinding'](_0x1df4f0),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(_0x46ff12){Utils['showToast'](_0x46ff12['message'],'error');}finally{_0x15a7ce['disabled']=![],_0x15a7ce['textContent']='Add\x20Binding';}}window['deleteUserBindingClick']=async function(_0x4715d9){try{await API['deleteBinding'](_0x4715d9),Utils['showToast']('Binding\x20removed','success'),state['bindingsDirty']=!![],await loadUserBindings(state['bindingsUserId']);}catch(_0x24bc74){Utils['showToast'](_0x24bc74['message'],'error');}};function showCreateUserModal(){state['editingUserId']=null;const _0x4f065c=document['getElementById']('user-modal'),_0x2ec7ac=document['getElementById']('modal-title'),_0x5f4087=document['getElementById']('user-password'),_0x52d66a=document['getElementById']('password-required'),_0x48c292=document['getElementById']('password-hint'),_0x84f1b9=document['getElementById']('skip-password-container'),_0x584238=document['getElementById']('skip-password');_0x2ec7ac['textContent']='Create\x20User',document['getElementById']('user-form')['reset'](),_0x5f4087['required']=!![];if(_0x52d66a)_0x52d66a['textContent']='*';_0x84f1b9&&(_0x84f1b9['style']['display']='block',_0x584238['checked']=![]),_0x48c292&&(_0x48c292['textContent']='Minimum\x208\x20characters'),_0x4f065c['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);}window['editUser']=function(_0xad262f){const _0x1dee00=state['users']['find'](_0x260761=>_0x260761['id']===_0xad262f);if(!_0x1dee00)return;state['editingUserId']=_0xad262f;const _0x55ec5e=document['getElementById']('user-modal'),_0x5bb2e9=document['getElementById']('modal-title'),_0x386155=document['getElementById']('user-password'),_0x19c423=document['getElementById']('password-required'),_0x281438=document['getElementById']('password-hint'),_0x2c4c01=document['getElementById']('skip-password-container');_0x5bb2e9['textContent']='Edit\x20User',document['getElementById']('user-username')['value']=_0x1dee00['username'],document['getElementById']('user-name')['value']=_0x1dee00['name'],document['getElementById']('user-email')['value']=_0x1dee00['email'],_0x386155['value']='',_0x386155['required']=![];if(_0x19c423)_0x19c423['textContent']='';_0x2c4c01&&(_0x2c4c01['style']['display']='none'),_0x281438&&(_0x281438['textContent']='Leave\x20blank\x20to\x20keep\x20current\x20password'),_0x55ec5e['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);};function hideUserModal(){const _0x4ffbcf=document['getElementById']('user-modal'),_0x5f36ef=document['getElementById']('form-error'),_0x49ab88=document['getElementById']('save-user');_0x4ffbcf['hidden']=!![],_0x5f36ef['hidden']=!![],state['editingUserId']=null,_0x49ab88&&(_0x49ab88['disabled']=![],_0x49ab88['textContent']='Save\x20User');}async function saveUser(){const _0xb68b4c=document['getElementById']('user-form'),_0x3e1057=document['getElementById']('skip-password')?.['checked']||![];if(!_0x3e1057&&!_0xb68b4c['checkValidity']()){_0xb68b4c['reportValidity']();return;}const _0x70a5e8=document['getElementById']('form-error'),_0x85b967=document['getElementById']('save-user'),_0x4f4aaf=document['getElementById']('user-username')['value']['trim'](),_0x1030dd=document['getElementById']('user-name')['value']['trim'](),_0x12d169=document['getElementById']('user-email')['value']['trim'](),_0x31d00c=document['getElementById']('user-password')['value'];if(!_0x4f4aaf||!_0x1030dd||!_0x12d169){_0x70a5e8['textContent']='Please\x20fill\x20in\x20all\x20required\x20fields',_0x70a5e8['hidden']=![],_0x70a5e8['scrollIntoView']({'behavior':'smooth','block':'nearest'});return;}_0x70a5e8['hidden']=!![];const _0x7a0435=_0x85b967['textContent'];_0x85b967['disabled']=!![],_0x85b967['textContent']=state['editingUserId']?'Updating...':'Creating...';try{if(state['editingUserId']){const _0x574ee0={'username':_0x4f4aaf,'name':_0x1030dd,'email':_0x12d169};_0x31d00c&&(_0x574ee0['password']=_0x31d00c),await API['updateUser'](state['editingUserId'],_0x574ee0),Utils['showToast']('User\x20updated\x20successfully','success'),await loadUsers(),hideUserModal();}else{const _0x3ff8bd={'username':_0x4f4aaf,'name':_0x1030dd,'email':_0x12d169};if(!_0x3e1057){if(!_0x31d00c)throw new Error('Password\x20is\x20required\x20for\x20new\x20users');_0x3ff8bd['password']=_0x31d00c;}const _0x48e7f6=await API['createUser'](_0x3ff8bd),_0x3774c7=_0x48e7f6['user'];if(_0x3e1057||!_0x31d00c){const _0x2f274a=await API['createPasswordToken'](_0x3774c7['id'],'setup',![]);state['setupLinkData']={'username':_0x3774c7['username'],'email':_0x3774c7['email'],'url':_0x2f274a['token']['setupUrl'],'userId':_0x3774c7['id'],'type':'setup','emailSent':![]},await loadUsers(),hideUserModal(),showSetupLinkModal();}else Utils['showToast']('User\x20created\x20successfully','success'),await loadUsers(),hideUserModal();}}catch(_0x4407e6){console['error']('Failed\x20to\x20save\x20user',_0x4407e6),_0x70a5e8['textContent']=_0x4407e6['message'],_0x70a5e8['hidden']=![],_0x70a5e8['scrollIntoView']({'behavior':'smooth','block':'nearest'}),_0x85b967['disabled']=![],_0x85b967['textContent']=_0x7a0435;}}window['deleteUser']=function(_0x185a40){const _0x27005f=state['users']['find'](_0x2db38d=>_0x2db38d['id']===_0x185a40);if(!_0x27005f)return;state['deletingUserId']=_0x185a40;const _0x44f2d0=document['getElementById']('delete-modal'),_0x30d5ba=document['getElementById']('delete-user-name');_0x30d5ba['textContent']=_0x27005f['name']+'\x20('+_0x27005f['username']+')',_0x44f2d0['hidden']=![];};function hideDeleteModal(){const _0x58ff3d=document['getElementById']('delete-modal');_0x58ff3d['hidden']=!![],state['deletingUserId']=null;const _0x3e9105=document['getElementById']('confirm-delete');_0x3e9105&&(_0x3e9105['disabled']=![],_0x3e9105['textContent']='Delete\x20User');}async function confirmDeleteUser(){if(!state['deletingUserId'])return;const _0x4f6460=document['getElementById']('confirm-delete'),_0x324cef=_0x4f6460['textContent'];_0x4f6460['disabled']=!![],_0x4f6460['textContent']='Deleting...';try{await API['deleteUser'](state['deletingUserId']),Utils['showToast']('User\x20deleted\x20successfully','success'),await loadUsers(),hideDeleteModal();}catch(_0x2986a7){console['error']('Failed\x20to\x20delete\x20user',_0x2986a7),Utils['showToast']('Failed\x20to\x20delete\x20user:\x20'+_0x2986a7['message'],'error'),_0x4f6460['disabled']=![],_0x4f6460['textContent']=_0x324cef;}}function handleSkipPasswordChange(_0x365e20){const _0xc83918=document['getElementById']('user-password'),_0x1d99ff=_0x365e20['target']['checked'];_0x1d99ff?(_0xc83918['required']=![],_0xc83918['disabled']=!![],_0xc83918['value']=''):(_0xc83918['required']=!![],_0xc83918['disabled']=![]);}function showSetupLinkModal(){if(!state['setupLinkData'])return;const _0x14bfa0=document['getElementById']('setup-link-modal'),_0x1b623b=document['getElementById']('setup-link-username'),_0x5d5cfd=document['getElementById']('setup-link-url'),_0x565522=document['getElementById']('email-setup-link'),_0x514d27=document['getElementById']('email-button-text');_0x1b623b['textContent']=state['setupLinkData']['username'],_0x5d5cfd['textContent']=state['setupLinkData']['url'],_0x565522&&_0x514d27&&(_0x565522['disabled']=![],_0x514d27['textContent']='Email\x20Link',state['emailConfigured']&&!state['setupLinkData']['emailSent']?_0x565522['style']['display']='inline-block':_0x565522['style']['display']='none'),_0x14bfa0['hidden']=![];}function hideSetupLinkModal(){const _0x2ef380=document['getElementById']('setup-link-modal');_0x2ef380['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(_0x2af693){console['error']('Failed\x20to\x20copy\x20link',_0x2af693),Utils['showToast']('Failed\x20to\x20copy\x20link','error');}}async function emailSetupLink(){if(!state['setupLinkData'])return;const _0x27567f=document['getElementById']('email-setup-link'),_0x4add68=document['getElementById']('email-button-text');if(!_0x27567f||!_0x4add68)return;const _0x43c71c=_0x4add68['textContent'];_0x27567f['disabled']=!![],_0x4add68['textContent']='Sending...';try{const _0x54e53a=await API['createPasswordToken'](state['setupLinkData']['userId'],state['setupLinkData']['type'],!![]);if(_0x54e53a['emailSent'])Utils['showToast']('Email\x20sent\x20to\x20'+state['setupLinkData']['email'],'success'),state['setupLinkData']['emailSent']=!![],_0x27567f['style']['display']='none';else{const _0x527f16=_0x54e53a['emailError']||'Failed\x20to\x20send\x20email';Utils['showToast'](_0x527f16,'error'),_0x27567f['disabled']=![],_0x4add68['textContent']=_0x43c71c;}}catch(_0x4694c8){console['error']('Failed\x20to\x20email\x20setup\x20link',_0x4694c8),Utils['showToast']('Failed\x20to\x20send\x20email:\x20'+_0x4694c8['message'],'error'),_0x27567f['disabled']=![],_0x4add68['textContent']=_0x43c71c;}}window['resetPassword']=async function(_0x4b6f03){const _0xecc128=state['users']['find'](_0x1a7d80=>_0x1a7d80['id']===_0x4b6f03);if(!_0xecc128)return;const _0x12124d=await ConfirmDialog['show']({'title':'Reset\x20Password','message':'Generate\x20a\x20password\x20reset\x20link\x20for\x20'+_0xecc128['name']+'\x20('+_0xecc128['username']+')?\x20This\x20will\x20create\x20a\x20link\x20that\x20they\x20can\x20use\x20to\x20set\x20a\x20new\x20password.','confirmText':'Generate\x20Link'});if(!_0x12124d)return;try{const _0x2cb4e4=await API['createPasswordToken'](_0x4b6f03,'reset',![]);state['setupLinkData']={'username':_0xecc128['username'],'email':_0xecc128['email'],'url':_0x2cb4e4['token']['setupUrl'],'userId':_0xecc128['id'],'type':'reset','emailSent':![]},showSetupLinkModal();}catch(_0x2ee951){console['error']('Failed\x20to\x20create\x20password\x20reset\x20link',_0x2ee951),Utils['showToast']('Failed\x20to\x20create\x20password\x20reset\x20link:\x20'+_0x2ee951['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 _0x3954d4=await API['getCurrentUser']();state['currentUser']=_0x3954d4;if(!Permissions['hasServerPermission'](_0x3954d4,'*')&&!Permissions['hasServerPermission'](_0x3954d4,'users:create')){Utils['showToast']('Access\x20denied:\x20Server\x20admin\x20privileges\x20required','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}}catch(_0x27d0e2){window['location']['href']='login.html';}}async function checkEmailConfig(){try{const _0x425006=await API['getEmailConfig']();state['emailConfigured']=_0x425006['configured'];}catch(_0x47310b){console['error']('Failed\x20to\x20check\x20email\x20config',_0x47310b),state['emailConfigured']=![];}}async function loadRoles(){try{const {roles:_0x1b112e}=await API['getRoleDefinitions']();state['roles']=_0x1b112e||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x21f176=await API['getEnvironments']();state['environments']=_0x21f176['environments']||[];}catch{state['environments']=[];}}async function loadTeams(){try{const {teams:_0x5b292c}=await API['getTeams']();state['teams']=_0x5b292c||[];}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 _0x58bcb6=document['getElementById']('users-loading'),_0x18eb3d=document['getElementById']('users-error'),_0x12ea99=document['getElementById']('users-content');try{_0x58bcb6['hidden']=![],_0x18eb3d['hidden']=!![],_0x12ea99['hidden']=!![];const _0x202fae=await API['getUsers']();state['users']=_0x202fae['users']||[],renderUsers(),_0x58bcb6['hidden']=!![],_0x12ea99['hidden']=![];}catch(_0x24e5be){console['error']('Failed\x20to\x20load\x20users',_0x24e5be),_0x58bcb6['hidden']=!![],_0x18eb3d['hidden']=![],document['getElementById']('users-error-message')['textContent']=_0x24e5be['message'];}}function renderUsers(){const _0x2cfe21=document['getElementById']('users-table-body'),_0xec5a53=document['getElementById']('user-count');if(!_0x2cfe21)return;_0xec5a53&&(_0xec5a53['textContent']=state['users']['length']+'\x20user'+(state['users']['length']===0x1?'':'s'));const _0x16c6de=[...state['users']]['sort']((_0x3664d8,_0x13d758)=>{const _0x5aa7b6=new Date(_0x3664d8['created_at'])['getTime'](),_0x24e790=new Date(_0x13d758['created_at'])['getTime']();return _0x24e790-_0x5aa7b6;});_0x2cfe21['innerHTML']=_0x16c6de['map'](_0x291762=>'\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'](_0x291762['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'](_0x291762['name'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x291762['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'+(_0x291762['isServerAdmin']?'<span\x20class=\x22role-badge\x20role-admin\x22>Server\x20Admin</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x291762['hasUserBinding']?'<span\x20class=\x22role-badge\x20role-user-binding\x22>User\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x291762['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'](_0x291762['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'+_0x291762['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'+_0x291762['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'+_0x291762['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'+_0x291762['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(_0x2aea63){const _0x52d1a0=state['users']['find'](_0x31a8a3=>_0x31a8a3['id']===_0x2aea63);if(!_0x52d1a0)return;state['bindingsUserId']=_0x2aea63,state['bindingsDirty']=![];const _0x22bcd8=document['getElementById']('bindings-modal'),_0x571bdf=document['getElementById']('bindings-modal-title');_0x571bdf['textContent']='Access\x20Bindings\x20—\x20'+_0x52d1a0['name'],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],_0x22bcd8['hidden']=![],loadUserBindings(_0x2aea63);};function hasUnsavedBindingChanges(){const _0x403ad8=document['getElementById']('add-user-binding-form');return _0x403ad8&&!_0x403ad8['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 _0x7a85b5=document['getElementById']('bindings-modal');_0x7a85b5['hidden']=!![];const _0x3d5cb0=state['bindingsDirty'];state['bindingsUserId']=null,state['userBindings']=[],state['bindingsDirty']=![],_0x3d5cb0&&await loadUsers();}async function loadUserBindings(_0x3893c1){const _0x2d3326=document['getElementById']('user-bindings-loading'),_0x4636b6=document['getElementById']('user-bindings-empty'),_0x3c4cb1=document['getElementById']('user-bindings-list-container'),_0xb0d8a4=document['getElementById']('add-user-binding-btn'),_0x4ff0a1=document['getElementById']('user-team-bindings-note'),_0x56affa=document['getElementById']('user-team-bindings-text');_0x2d3326['hidden']=![],_0x4636b6['hidden']=!![],_0x3c4cb1['style']['display']='none',_0xb0d8a4['hidden']=!![],_0x4ff0a1['hidden']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![];try{const [_0x20d011,_0x5331a9]=await Promise['all']([API['getBindings']({'subject_type':'user','subject_id':_0x3893c1}),API['getTeams']()]);state['userBindings']=_0x20d011['bindings']||[];const _0x71eca9=(_0x5331a9['teams']||[])['filter'](_0x45e5eb=>(_0x45e5eb['members']||[])['includes'](_0x3893c1)),_0xa19f=[];if(_0x71eca9['length']>0x0){const _0xdb92c2=await Promise['all'](_0x71eca9['map'](_0x2012c7=>API['getBindings']({'subject_type':'team','subject_id':_0x2012c7['id']})));for(let _0x1b0de0=0x0;_0x1b0de0<_0x71eca9['length'];_0x1b0de0++){const _0x4793cf=_0xdb92c2[_0x1b0de0]['bindings']||[];_0x4793cf['length']>0x0&&_0xa19f['push'](_0x71eca9[_0x1b0de0]);}}_0x2d3326['hidden']=!![];state['userBindings']['length']===0x0?_0x4636b6['hidden']=![]:(_0x3c4cb1['style']['display']='',renderUserBindingsTable());if(_0xa19f['length']>0x0){const _0xb2292f=_0xa19f['map'](_0x4ec516=>_0x4ec516['name']),_0x280400=_0xb2292f['length']<=0x3?_0xb2292f['join'](',\x20'):_0xb2292f['slice'](0x0,0x3)['join'](',\x20')+(',\x20and\x20'+(_0xb2292f['length']-0x3)+'\x20more');_0x56affa['textContent']='This\x20user\x20also\x20has\x20access\x20via\x20team\x20memberships\x20('+_0x280400+').';}else _0x56affa['textContent']='This\x20user\x20has\x20no\x20access\x20via\x20team\x20memberships.';_0x4ff0a1['hidden']=![],_0xb0d8a4['hidden']=![];}catch(_0x75abcc){_0x2d3326['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x75abcc['message'],'error');}}function renderUserBindingsTable(){const _0x592e28=document['getElementById']('user-bindings-table-body');if(!_0x592e28)return;_0x592e28['innerHTML']=state['userBindings']['map'](_0x30b7f8=>{const _0x15c2e6=_0x30b7f8['resource_type']==='server'?'Server':_0x30b7f8['resource_id']==='*'?'All\x20'+_0x30b7f8['resource_type']+'s':Utils['escapeHtml'](_0x30b7f8['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x15c2e6+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x30b7f8['role_name']||_0x30b7f8['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'+_0x30b7f8['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 _0x3ba777=document['getElementById']('user-binding-resource-type');_0x3ba777['value']='environment',updateUserBindingFormForResourceType('environment');}function onUserBindingResourceTypeChange(){const _0x444691=document['getElementById']('user-binding-resource-type')['value'];updateUserBindingFormForResourceType(_0x444691);}function updateUserBindingFormForResourceType(_0x43c840){const _0x4790df=document['getElementById']('user-binding-resource-container'),_0x5ab6c4=document['getElementById']('user-binding-resource'),_0x27e3cf=document['getElementById']('user-binding-role');if(_0x43c840==='server')_0x4790df['style']['display']='none';else{_0x4790df['style']['display']='';if(_0x43c840==='environment'){const _0x4e5570=new Set(state['userBindings']['filter'](_0x134371=>_0x134371['resource_type']==='environment')['map'](_0x3d1d77=>_0x3d1d77['resource_id'])),_0x2e2564=state['environments']['filter'](_0x5f09a0=>!_0x4e5570['has'](_0x5f09a0['name']));_0x5ab6c4['innerHTML']=_0x2e2564['length']?_0x2e2564['map'](_0x5c1a73=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x5c1a73['name'])+'\x22>'+Utils['escapeHtml'](_0x5c1a73['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x43c840==='team'){const _0x4fbfab=new Set(state['userBindings']['filter'](_0x13e3ca=>_0x13e3ca['resource_type']==='team')['map'](_0x49b919=>_0x49b919['resource_id'])),_0x567aa4=state['teams']['filter'](_0x2fe519=>!_0x4fbfab['has'](_0x2fe519['id']));_0x5ab6c4['innerHTML']=_0x567aa4['length']?_0x567aa4['map'](_0xde511d=>'<option\x20value=\x22'+_0xde511d['id']+'\x22>'+Utils['escapeHtml'](_0xde511d['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x498617=state['roles']['filter'](_0x15f5d7=>_0x15f5d7['resource_type']===_0x43c840);_0x27e3cf['innerHTML']=_0x498617['length']?_0x498617['filter'](_0x54ccee=>{const _0x33831d=_0x43c840==='server'?undefined:_0x5ab6c4['value'];return!state['userBindings']['some'](_0x3e8dcf=>_0x3e8dcf['resource_type']===_0x43c840&&_0x3e8dcf['role_id']===_0x54ccee['id']&&(_0x43c840==='server'||_0x3e8dcf['resource_id']===_0x33831d));})['map'](_0x39bca0=>'<option\x20value=\x22'+_0x39bca0['id']+'\x22>'+Utils['escapeHtml'](_0x39bca0['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 _0x296430=document['getElementById']('user-binding-resource-type')['value'],_0x4458e4=document['getElementById']('user-binding-role')['value'];if(!_0x4458e4||!state['bindingsUserId'])return;const _0x4356f6=_0x296430==='server'?undefined:document['getElementById']('user-binding-resource')['value'];if(_0x296430!=='server'&&!_0x4356f6)return;const _0x4f6e22=document['getElementById']('save-user-binding-btn');_0x4f6e22['disabled']=!![],_0x4f6e22['textContent']='Adding…';try{const _0xd76ad8={'subject_type':'user','subject_id':state['bindingsUserId'],'role_id':_0x4458e4,'resource_type':_0x296430};if(_0x4356f6)_0xd76ad8['resource_id']=_0x4356f6;await API['createBinding'](_0xd76ad8),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(_0x51c88d){Utils['showToast'](_0x51c88d['message'],'error');}finally{_0x4f6e22['disabled']=![],_0x4f6e22['textContent']='Add\x20Binding';}}window['deleteUserBindingClick']=async function(_0x5b04af){try{await API['deleteBinding'](_0x5b04af),Utils['showToast']('Binding\x20removed','success'),state['bindingsDirty']=!![],await loadUserBindings(state['bindingsUserId']);}catch(_0x330817){Utils['showToast'](_0x330817['message'],'error');}};function showCreateUserModal(){state['editingUserId']=null;const _0x3b2c74=document['getElementById']('user-modal'),_0x2437c5=document['getElementById']('modal-title'),_0x99d518=document['getElementById']('user-password'),_0x33287e=document['getElementById']('password-required'),_0x1b620e=document['getElementById']('password-hint'),_0x24e8d0=document['getElementById']('skip-password-container'),_0x8bdee5=document['getElementById']('skip-password');_0x2437c5['textContent']='Create\x20User',document['getElementById']('user-form')['reset'](),_0x99d518['required']=!![];if(_0x33287e)_0x33287e['textContent']='*';_0x24e8d0&&(_0x24e8d0['style']['display']='block',_0x8bdee5['checked']=![]),_0x1b620e&&(_0x1b620e['textContent']='Minimum\x208\x20characters'),_0x3b2c74['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);}window['editUser']=function(_0x232a61){const _0x31b628=state['users']['find'](_0x3641b0=>_0x3641b0['id']===_0x232a61);if(!_0x31b628)return;state['editingUserId']=_0x232a61;const _0x3275cc=document['getElementById']('user-modal'),_0x47434d=document['getElementById']('modal-title'),_0xa424da=document['getElementById']('user-password'),_0x1f89c9=document['getElementById']('password-required'),_0xc8ca1e=document['getElementById']('password-hint'),_0x2f873e=document['getElementById']('skip-password-container');_0x47434d['textContent']='Edit\x20User',document['getElementById']('user-username')['value']=_0x31b628['username'],document['getElementById']('user-name')['value']=_0x31b628['name'],document['getElementById']('user-email')['value']=_0x31b628['email'],_0xa424da['value']='',_0xa424da['required']=![];if(_0x1f89c9)_0x1f89c9['textContent']='';_0x2f873e&&(_0x2f873e['style']['display']='none'),_0xc8ca1e&&(_0xc8ca1e['textContent']='Leave\x20blank\x20to\x20keep\x20current\x20password'),_0x3275cc['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);};function hideUserModal(){const _0x4539dc=document['getElementById']('user-modal'),_0x3e749c=document['getElementById']('form-error'),_0x30bf75=document['getElementById']('save-user');_0x4539dc['hidden']=!![],_0x3e749c['hidden']=!![],state['editingUserId']=null,_0x30bf75&&(_0x30bf75['disabled']=![],_0x30bf75['textContent']='Save\x20User');}async function saveUser(){const _0x38d80c=document['getElementById']('user-form'),_0x301448=document['getElementById']('skip-password')?.['checked']||![];if(!_0x301448&&!_0x38d80c['checkValidity']()){_0x38d80c['reportValidity']();return;}const _0x181498=document['getElementById']('form-error'),_0x24ec02=document['getElementById']('save-user'),_0x13bfbb=document['getElementById']('user-username')['value']['trim'](),_0x108474=document['getElementById']('user-name')['value']['trim'](),_0xac5b8c=document['getElementById']('user-email')['value']['trim'](),_0x119d61=document['getElementById']('user-password')['value'];if(!_0x13bfbb||!_0x108474||!_0xac5b8c){_0x181498['textContent']='Please\x20fill\x20in\x20all\x20required\x20fields',_0x181498['hidden']=![],_0x181498['scrollIntoView']({'behavior':'smooth','block':'nearest'});return;}_0x181498['hidden']=!![];const _0x9e883b=_0x24ec02['textContent'];_0x24ec02['disabled']=!![],_0x24ec02['textContent']=state['editingUserId']?'Updating...':'Creating...';try{if(state['editingUserId']){const _0x2ea723={'username':_0x13bfbb,'name':_0x108474,'email':_0xac5b8c};_0x119d61&&(_0x2ea723['password']=_0x119d61),await API['updateUser'](state['editingUserId'],_0x2ea723),Utils['showToast']('User\x20updated\x20successfully','success'),await loadUsers(),hideUserModal();}else{const _0x3e2e62={'username':_0x13bfbb,'name':_0x108474,'email':_0xac5b8c};if(!_0x301448){if(!_0x119d61)throw new Error('Password\x20is\x20required\x20for\x20new\x20users');_0x3e2e62['password']=_0x119d61;}const _0x6718f9=await API['createUser'](_0x3e2e62),_0x2d9e4d=_0x6718f9['user'];if(_0x301448||!_0x119d61){const _0xa58521=await API['createPasswordToken'](_0x2d9e4d['id'],'setup',![]);state['setupLinkData']={'username':_0x2d9e4d['username'],'email':_0x2d9e4d['email'],'url':_0xa58521['token']['setupUrl'],'userId':_0x2d9e4d['id'],'type':'setup','emailSent':![]},await loadUsers(),hideUserModal(),showSetupLinkModal();}else Utils['showToast']('User\x20created\x20successfully','success'),await loadUsers(),hideUserModal();}}catch(_0x4ca20c){console['error']('Failed\x20to\x20save\x20user',_0x4ca20c),_0x181498['textContent']=_0x4ca20c['message'],_0x181498['hidden']=![],_0x181498['scrollIntoView']({'behavior':'smooth','block':'nearest'}),_0x24ec02['disabled']=![],_0x24ec02['textContent']=_0x9e883b;}}window['deleteUser']=function(_0x241588){const _0x5e1582=state['users']['find'](_0x38e480=>_0x38e480['id']===_0x241588);if(!_0x5e1582)return;state['deletingUserId']=_0x241588;const _0x205388=document['getElementById']('delete-modal'),_0x1826fa=document['getElementById']('delete-user-name');_0x1826fa['textContent']=_0x5e1582['name']+'\x20('+_0x5e1582['username']+')',_0x205388['hidden']=![];};function hideDeleteModal(){const _0x1a8c33=document['getElementById']('delete-modal');_0x1a8c33['hidden']=!![],state['deletingUserId']=null;const _0x349907=document['getElementById']('confirm-delete');_0x349907&&(_0x349907['disabled']=![],_0x349907['textContent']='Delete\x20User');}async function confirmDeleteUser(){if(!state['deletingUserId'])return;const _0x178ce2=document['getElementById']('confirm-delete'),_0x240fe6=_0x178ce2['textContent'];_0x178ce2['disabled']=!![],_0x178ce2['textContent']='Deleting...';try{await API['deleteUser'](state['deletingUserId']),Utils['showToast']('User\x20deleted\x20successfully','success'),await loadUsers(),hideDeleteModal();}catch(_0x12b843){console['error']('Failed\x20to\x20delete\x20user',_0x12b843),Utils['showToast']('Failed\x20to\x20delete\x20user:\x20'+_0x12b843['message'],'error'),_0x178ce2['disabled']=![],_0x178ce2['textContent']=_0x240fe6;}}function handleSkipPasswordChange(_0x2e5129){const _0x55c01a=document['getElementById']('user-password'),_0x5f01da=_0x2e5129['target']['checked'];_0x5f01da?(_0x55c01a['required']=![],_0x55c01a['disabled']=!![],_0x55c01a['value']=''):(_0x55c01a['required']=!![],_0x55c01a['disabled']=![]);}function showSetupLinkModal(){if(!state['setupLinkData'])return;const _0x52dc3c=document['getElementById']('setup-link-modal'),_0x310dbd=document['getElementById']('setup-link-username'),_0xf6f136=document['getElementById']('setup-link-url'),_0x4e0fef=document['getElementById']('email-setup-link'),_0x4c4557=document['getElementById']('email-button-text');_0x310dbd['textContent']=state['setupLinkData']['username'],_0xf6f136['textContent']=state['setupLinkData']['url'],_0x4e0fef&&_0x4c4557&&(_0x4e0fef['disabled']=![],_0x4c4557['textContent']='Email\x20Link',state['emailConfigured']&&!state['setupLinkData']['emailSent']?_0x4e0fef['style']['display']='inline-block':_0x4e0fef['style']['display']='none'),_0x52dc3c['hidden']=![];}function hideSetupLinkModal(){const _0x3e27be=document['getElementById']('setup-link-modal');_0x3e27be['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(_0x58eb45){console['error']('Failed\x20to\x20copy\x20link',_0x58eb45),Utils['showToast']('Failed\x20to\x20copy\x20link','error');}}async function emailSetupLink(){if(!state['setupLinkData'])return;const _0x59ba16=document['getElementById']('email-setup-link'),_0x444a55=document['getElementById']('email-button-text');if(!_0x59ba16||!_0x444a55)return;const _0x414762=_0x444a55['textContent'];_0x59ba16['disabled']=!![],_0x444a55['textContent']='Sending...';try{const _0x573495=await API['createPasswordToken'](state['setupLinkData']['userId'],state['setupLinkData']['type'],!![]);if(_0x573495['emailSent'])Utils['showToast']('Email\x20sent\x20to\x20'+state['setupLinkData']['email'],'success'),state['setupLinkData']['emailSent']=!![],_0x59ba16['style']['display']='none';else{const _0x37ab49=_0x573495['emailError']||'Failed\x20to\x20send\x20email';Utils['showToast'](_0x37ab49,'error'),_0x59ba16['disabled']=![],_0x444a55['textContent']=_0x414762;}}catch(_0x2c0d15){console['error']('Failed\x20to\x20email\x20setup\x20link',_0x2c0d15),Utils['showToast']('Failed\x20to\x20send\x20email:\x20'+_0x2c0d15['message'],'error'),_0x59ba16['disabled']=![],_0x444a55['textContent']=_0x414762;}}window['resetPassword']=async function(_0x4bf673){const _0xeae307=state['users']['find'](_0x1ec65f=>_0x1ec65f['id']===_0x4bf673);if(!_0xeae307)return;const _0x595604=await ConfirmDialog['show']({'title':'Reset\x20Password','message':'Generate\x20a\x20password\x20reset\x20link\x20for\x20'+_0xeae307['name']+'\x20('+_0xeae307['username']+')?\x20This\x20will\x20create\x20a\x20link\x20that\x20they\x20can\x20use\x20to\x20set\x20a\x20new\x20password.','confirmText':'Generate\x20Link'});if(!_0x595604)return;try{const _0x34a1e8=await API['createPasswordToken'](_0x4bf673,'reset',![]);state['setupLinkData']={'username':_0xeae307['username'],'email':_0xeae307['email'],'url':_0x34a1e8['token']['setupUrl'],'userId':_0xeae307['id'],'type':'reset','emailSent':![]},showSetupLinkModal();}catch(_0x2f7ad7){console['error']('Failed\x20to\x20create\x20password\x20reset\x20link',_0x2f7ad7),Utils['showToast']('Failed\x20to\x20create\x20password\x20reset\x20link:\x20'+_0x2f7ad7['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(_0x4ca178={}){this['container']=null,this['onGroupChange']=_0x4ca178['onGroupChange']||(()=>{}),this['onAddExistingTask']=_0x4ca178['onAddExistingTask']||(()=>{}),this['tasks']=[],this['groupId']=_0x4ca178['groupId']||null,this['isOpen']=![];}['init'](_0x3fd46f,_0x24b25a,_0x29248c){this['container']=_0x3fd46f,this['tasks']=_0x24b25a,this['groupId']=_0x29248c,this['render'](),this['attachEventListeners']();}['updateTasks'](_0x106a18){const _0x15ca80=new Map(_0x106a18['map'](_0x3eb259=>[_0x3eb259['taskId'],_0x3eb259]));this['tasks']=this['tasks']['map'](_0x4865fb=>{const _0x1e7d0d=_0x15ca80['get'](_0x4865fb['taskId']);return _0x1e7d0d?_0x1e7d0d:_0x4865fb;});for(const _0x252f59 of _0x106a18){!this['tasks']['some'](_0x2ebe6b=>_0x2ebe6b['taskId']===_0x252f59['taskId'])&&this['tasks']['push'](_0x252f59);}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 _0x5d9975=this['tasks']['filter'](_0x106944=>_0x106944['groupId']===this['groupId'])['sort']((_0x206fbc,_0x56abb9)=>(_0x206fbc['groupIndex']??0x0)-(_0x56abb9['groupIndex']??0x0)),_0x513352=this['tasks']['filter'](_0x28e618=>!_0x28e618['groupId']||_0x28e618['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>'+_0x5d9975['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'+(_0x5d9975['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20add\x20to\x20group</div>':_0x5d9975['map']((_0x51387e,_0x3f489f)=>this['renderVariantCard'](_0x51387e,_0x3f489f,!![]))['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>'+_0x513352['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'+(_0x513352['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20remove\x20from\x20group</div>':_0x513352['map']((_0x2077cf,_0x3bd0aa)=>this['renderVariantCard'](_0x2077cf,_0x3bd0aa,![]))['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'](_0x43dacd,_0x9ab85b,_0x2c92ee){const _0x474e0e=_0x43dacd['envVars']?.['CODER_AGENT']||_0x43dacd['envVars']?.['default_agent']||'claude',_0x12b762=AGENT_ICONS[_0x474e0e['toLowerCase']()]||AGENT_ICONS['claude'],_0x5143cb=STATUS_ICONS[_0x43dacd['status']]||'',_0x513458='status-'+(_0x43dacd['status']||'unknown'),_0x29836e=_0x43dacd['isWinner']?'<span\x20class=\x22vgm-badge\x20vgm-badge-winner\x22\x20title=\x22Winner\x22>★</span>':'',_0x15347b=_0x43dacd['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'+_0x513458+'\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'+_0x43dacd['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-is-grouped=\x22'+_0x2c92ee+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-index=\x22'+_0x9ab85b+'\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'+_0x474e0e['toLowerCase']()+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x12b762+'\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'](_0x43dacd['name']||'Task\x20'+_0x43dacd['taskId']['slice'](-0x6))+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-meta\x22>'+Utils['escapeHtml'](_0x474e0e)+'\x20·\x20'+(_0x43dacd['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'+_0x29836e+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x15347b+'\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'+_0x513458+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x5143cb+'\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'+(_0x2c92ee?'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'+_0x43dacd['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-action=\x22'+(_0x2c92ee?'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'+(_0x2c92ee?'<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',_0x5e513d=>{_0x5e513d['target']['closest']('.vgm-close-btn')&&(this['close'](),this['onGroupChange'](this['tasks'])),_0x5e513d['target']['closest']('.vgm-add-existing-btn')&&(this['close'](),this['onAddExistingTask'](this['groupId']));}),this['container']['addEventListener']('click',async _0x21d793=>{const _0x14f1ef=_0x21d793['target']['closest']('.vgm-variant-remove-btn');if(!_0x14f1ef)return;const _0x3745ee=_0x14f1ef['dataset']['taskId'],_0x3550b7=_0x14f1ef['dataset']['action'];try{_0x3550b7==='remove'?await this['removeFromGroup'](_0x3745ee):await this['addToGroup'](_0x3745ee);}catch(_0x12afb4){console['error']('Failed\x20to\x20update\x20group:',_0x12afb4),Utils['showToast'](_0x12afb4['message']||'Failed\x20to\x20update\x20group','error');}}),this['container']['addEventListener']('dragstart',_0x275770=>this['handleDragStart'](_0x275770)),this['container']['addEventListener']('dragend',_0x405732=>this['handleDragEnd'](_0x405732)),this['container']['addEventListener']('dragover',_0x403f27=>this['handleDragOver'](_0x403f27)),this['container']['addEventListener']('dragleave',_0x1ca944=>this['handleDragLeave'](_0x1ca944)),this['container']['addEventListener']('drop',_0x56a06c=>this['handleDrop'](_0x56a06c));}['handleDragStart'](_0x5dfa29){const _0x3bb481=_0x5dfa29['target']['closest']('.vgm-variant-card');if(!_0x3bb481)return;dragState['draggedTaskId']=_0x3bb481['dataset']['taskId'],dragState['draggedElement']=_0x3bb481,dragState['sourceGroupId']=_0x3bb481['dataset']['isGrouped']==='true'?this['groupId']:null,dragState['isDragging']=!![],_0x3bb481['classList']['add']('dragging'),_0x5dfa29['dataTransfer']['effectAllowed']='move',_0x5dfa29['dataTransfer']['setData']('text/plain',_0x3bb481['dataset']['taskId']),this['container']['classList']['add']('is-dragging');}['handleDragEnd'](_0x2fb53d){const _0x511bfa=_0x2fb53d['target']['closest']('.vgm-variant-card');_0x511bfa&&_0x511bfa['classList']['remove']('dragging'),this['container']['querySelectorAll']('.drag-over,\x20.drop-indicator')['forEach'](_0x38f9df=>{_0x38f9df['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'](_0x5e89df){_0x5e89df['preventDefault'](),_0x5e89df['dataTransfer']['dropEffect']='move';const _0xaf8afc=_0x5e89df['target']['closest']('.vgm-drop-zone'),_0x228ad1=_0x5e89df['target']['closest']('.vgm-variant-card');this['container']['querySelectorAll']('.vgm-drop-zone')['forEach'](_0x1dd689=>{_0x1dd689['classList']['toggle']('drag-over',_0x1dd689===_0xaf8afc);});if(_0x228ad1&&_0x228ad1!==dragState['draggedElement']){const _0x39c140=_0x228ad1['getBoundingClientRect'](),_0x34077b=_0x39c140['top']+_0x39c140['height']/0x2,_0x1330ae=_0x5e89df['clientY']<_0x34077b;this['container']['querySelectorAll']('.vgm-variant-card')['forEach'](_0x5de4da=>{_0x5de4da!==_0x228ad1&&_0x5de4da['classList']['remove']('drop-before','drop-after');}),_0x228ad1['classList']['toggle']('drop-before',_0x1330ae),_0x228ad1['classList']['toggle']('drop-after',!_0x1330ae);}}['handleDragLeave'](_0x345341){const _0x5ed0be=_0x345341['target']['closest']('.vgm-drop-zone');_0x5ed0be&&!_0x5ed0be['contains'](_0x345341['relatedTarget'])&&_0x5ed0be['classList']['remove']('drag-over');}async['handleDrop'](_0x4b20fb){_0x4b20fb['preventDefault']();const _0x313c74=_0x4b20fb['target']['closest']('.vgm-drop-zone'),_0x36c344=_0x4b20fb['target']['closest']('.vgm-variant-card'),_0x215b40=_0x4b20fb['dataTransfer']['getData']('text/plain');if(!_0x313c74||!_0x215b40)return;this['container']['querySelectorAll']('.drag-over,\x20.drop-before,\x20.drop-after')['forEach'](_0x3fa967=>{_0x3fa967['classList']['remove']('drag-over','drop-before','drop-after');});const _0x4c7500=_0x313c74['dataset']['zone'],_0xa29a7e=_0x4c7500==='grouped',_0x474080=dragState['sourceGroupId']===this['groupId'];try{if(_0xa29a7e&&!_0x474080){let _0x27d9a5=this['tasks']['filter'](_0x1468fc=>_0x1468fc['groupId']===this['groupId'])['length'];if(_0x36c344){const _0x378997=_0x36c344['dataset']['taskId'],_0x29ebb7=this['tasks']['find'](_0x210af5=>_0x210af5['taskId']===_0x378997);if(_0x29ebb7?.['groupIndex']!==undefined){const _0x2e119e=_0x36c344['getBoundingClientRect'](),_0x1cc0ee=_0x4b20fb['clientY']<_0x2e119e['top']+_0x2e119e['height']/0x2;_0x27d9a5=_0x29ebb7['groupIndex']+(_0x1cc0ee?0x0:0x1);}}await this['addToGroup'](_0x215b40,_0x27d9a5);}else{if(!_0xa29a7e&&_0x474080)await this['removeFromGroup'](_0x215b40);else _0xa29a7e&&_0x474080&&_0x36c344&&await this['reorderInGroup'](_0x215b40,_0x36c344,_0x4b20fb['clientY']);}}catch(_0x58d3c1){console['error']('Drop\x20operation\x20failed:',_0x58d3c1),Utils['showToast'](_0x58d3c1['message']||'Failed\x20to\x20move\x20variant','error');}}async['addToGroup'](_0x51b249,_0x318552){const _0x422eef=this['tasks']['find'](_0x272ce7=>_0x272ce7['taskId']===_0x51b249);if(!_0x422eef)return;_0x318552===undefined&&(_0x318552=this['tasks']['filter'](_0x27162c=>_0x27162c['groupId']===this['groupId'])['length']),!this['groupId']&&(this['groupId']=API['generateGroupId'](),await API['createTaskGroup']({'groupId':this['groupId']})),await API['updateTaskGroup'](_0x51b249,this['groupId'],_0x318552),_0x422eef['groupId']=this['groupId'],_0x422eef['groupIndex']=_0x318552,this['render'](),this['onGroupChange'](this['tasks']);}async['removeFromGroup'](_0x256dce){const _0x1b282a=this['tasks']['find'](_0x302814=>_0x302814['taskId']===_0x256dce);if(!_0x1b282a)return;await API['removeTaskFromGroup'](_0x256dce),_0x1b282a['groupId']=null,_0x1b282a['groupIndex']=null,this['render'](),this['onGroupChange'](this['tasks']);}async['reorderInGroup'](_0xf84f9,_0x1dc708,_0x3f4338){const _0x371add=this['tasks']['find'](_0x47658d=>_0x47658d['taskId']===_0xf84f9),_0x3bc4b5=_0x1dc708['dataset']['taskId'],_0x584307=this['tasks']['find'](_0x75a66e=>_0x75a66e['taskId']===_0x3bc4b5);if(!_0x371add||!_0x584307||_0x371add['taskId']===_0x584307['taskId'])return;const _0x59b1d4=_0x1dc708['getBoundingClientRect'](),_0x253df0=_0x3f4338<_0x59b1d4['top']+_0x59b1d4['height']/0x2;let _0x37b1c0=_0x584307['groupIndex']??0x0;if(!_0x253df0)_0x37b1c0++;if((_0x371add['groupIndex']??0x0)<(_0x584307['groupIndex']??0x0))_0x37b1c0--;if(_0x37b1c0===_0x371add['groupIndex'])return;await API['updateTaskGroup'](_0xf84f9,this['groupId'],_0x37b1c0);const _0x4784a2=this['tasks']['filter'](_0x42584d=>_0x42584d['groupId']===this['groupId'])['sort']((_0x245788,_0x152789)=>(_0x245788['groupIndex']??0x0)-(_0x152789['groupIndex']??0x0)),_0x176697=_0x4784a2['findIndex'](_0x3a73e8=>_0x3a73e8['taskId']===_0xf84f9);_0x176697!==-0x1&&_0x4784a2['splice'](_0x176697,0x1),_0x4784a2['splice'](_0x37b1c0,0x0,_0x371add),_0x4784a2['forEach']((_0x4e28d8,_0x7f02c0)=>{_0x4e28d8['groupIndex']=_0x7f02c0;}),this['render'](),this['onGroupChange'](this['tasks']);}}export function initializeTabDragDrop(_0x2dba20,_0x12eae0,_0x15b714,_0x88c21b={}){if(!_0x2dba20)return;const {onReorder:_0x4279a5,onRemove:_0x22a7f3}=_0x88c21b,_0x1dd774=_0x2dba20['querySelectorAll']('.task-tab');_0x1dd774['forEach']((_0x22f2b7,_0x44762f)=>{_0x22f2b7['setAttribute']('draggable','true'),_0x22f2b7['dataset']['index']=_0x44762f,_0x22f2b7['addEventListener']('dragstart',_0x240cd7=>{_0x240cd7['dataTransfer']['effectAllowed']='move',_0x240cd7['dataTransfer']['setData']('text/plain',_0x22f2b7['dataset']['taskId']),_0x22f2b7['classList']['add']('dragging'),_0x2dba20['classList']['add']('is-dragging');}),_0x22f2b7['addEventListener']('dragend',()=>{_0x22f2b7['classList']['remove']('dragging'),_0x2dba20['classList']['remove']('is-dragging'),_0x2dba20['querySelectorAll']('.drop-indicator')['forEach'](_0x34a9c0=>{_0x34a9c0['classList']['remove']('drop-indicator','drop-before','drop-after');});}),_0x22f2b7['addEventListener']('dragover',_0x481556=>{_0x481556['preventDefault'](),_0x481556['dataTransfer']['dropEffect']='move';if(_0x22f2b7['classList']['contains']('dragging'))return;const _0x12fb5e=_0x22f2b7['getBoundingClientRect'](),_0x405f4e=_0x12fb5e['left']+_0x12fb5e['width']/0x2,_0x40e77a=_0x481556['clientX']<_0x405f4e;_0x1dd774['forEach'](_0x5872d5=>_0x5872d5['classList']['remove']('drop-before','drop-after')),_0x22f2b7['classList']['add'](_0x40e77a?'drop-before':'drop-after');}),_0x22f2b7['addEventListener']('dragleave',()=>{_0x22f2b7['classList']['remove']('drop-before','drop-after');}),_0x22f2b7['addEventListener']('drop',async _0x238b73=>{_0x238b73['preventDefault']();const _0x62626a=_0x238b73['dataTransfer']['getData']('text/plain'),_0xccb04a=_0x22f2b7['dataset']['taskId'];if(_0x62626a===_0xccb04a)return;const _0x51cc22=_0x22f2b7['getBoundingClientRect'](),_0x17ad8c=_0x238b73['clientX']<_0x51cc22['left']+_0x51cc22['width']/0x2;_0x22f2b7['classList']['remove']('drop-before','drop-after'),_0x4279a5&&await _0x4279a5(_0x62626a,_0xccb04a,_0x17ad8c);});});const _0x561ceb=document['createElement']('div');return _0x561ceb['className']='task-tab-remove-zone',_0x561ceb['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',_0x561ceb['style']['display']='none',_0x561ceb['addEventListener']('dragover',_0x294ac3=>{_0x294ac3['preventDefault'](),_0x561ceb['classList']['add']('drag-over');}),_0x561ceb['addEventListener']('dragleave',()=>{_0x561ceb['classList']['remove']('drag-over');}),_0x561ceb['addEventListener']('drop',async _0x22c0bc=>{_0x22c0bc['preventDefault'](),_0x561ceb['classList']['remove']('drag-over');const _0x35a80b=_0x22c0bc['dataTransfer']['getData']('text/plain');_0x22a7f3&&await _0x22a7f3(_0x35a80b);}),_0x2dba20['addEventListener']('dragstart',()=>{_0x12eae0['length']>0x1&&(_0x561ceb['style']['display']='flex');}),_0x2dba20['addEventListener']('dragend',()=>{_0x561ceb['style']['display']='none';}),_0x2dba20['appendChild'](_0x561ceb),{'destroy':()=>{_0x561ceb['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(_0x51e76f={}){this['container']=null,this['onGroupChange']=_0x51e76f['onGroupChange']||(()=>{}),this['onAddExistingTask']=_0x51e76f['onAddExistingTask']||(()=>{}),this['tasks']=[],this['groupId']=_0x51e76f['groupId']||null,this['isOpen']=![];}['init'](_0x5dc309,_0x35d564,_0x340959){this['container']=_0x5dc309,this['tasks']=_0x35d564,this['groupId']=_0x340959,this['render'](),this['attachEventListeners']();}['updateTasks'](_0x1b678b){const _0x2201fc=new Map(_0x1b678b['map'](_0x5ea929=>[_0x5ea929['taskId'],_0x5ea929]));this['tasks']=this['tasks']['map'](_0x592302=>{const _0x5c21d7=_0x2201fc['get'](_0x592302['taskId']);return _0x5c21d7?_0x5c21d7:_0x592302;});for(const _0x10314d of _0x1b678b){!this['tasks']['some'](_0x702fcd=>_0x702fcd['taskId']===_0x10314d['taskId'])&&this['tasks']['push'](_0x10314d);}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 _0x2f828d=this['tasks']['filter'](_0x4b0288=>_0x4b0288['groupId']===this['groupId'])['sort']((_0x6f4a6a,_0x264f87)=>(_0x6f4a6a['groupIndex']??0x0)-(_0x264f87['groupIndex']??0x0)),_0x2167a3=this['tasks']['filter'](_0x1128f9=>!_0x1128f9['groupId']||_0x1128f9['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>'+_0x2f828d['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'+(_0x2f828d['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20add\x20to\x20group</div>':_0x2f828d['map']((_0x4e7bfe,_0x285c13)=>this['renderVariantCard'](_0x4e7bfe,_0x285c13,!![]))['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>'+_0x2167a3['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'+(_0x2167a3['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20remove\x20from\x20group</div>':_0x2167a3['map']((_0x3daf3d,_0xddc0a3)=>this['renderVariantCard'](_0x3daf3d,_0xddc0a3,![]))['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'](_0x1d53be,_0x4e1f53,_0x18d58b){const _0x413869=_0x1d53be['envVars']?.['CODER_AGENT']||_0x1d53be['envVars']?.['default_agent']||'claude',_0x5e00bf=AGENT_ICONS[_0x413869['toLowerCase']()]||AGENT_ICONS['claude'],_0x1b57cc=STATUS_ICONS[_0x1d53be['status']]||'',_0x2ca9ab='status-'+(_0x1d53be['status']||'unknown'),_0x1a1c4a=_0x1d53be['isWinner']?'<span\x20class=\x22vgm-badge\x20vgm-badge-winner\x22\x20title=\x22Winner\x22>★</span>':'',_0x2cdab1=_0x1d53be['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'+_0x2ca9ab+'\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'+_0x1d53be['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-is-grouped=\x22'+_0x18d58b+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-index=\x22'+_0x4e1f53+'\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'+_0x413869['toLowerCase']()+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x5e00bf+'\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'](_0x1d53be['name']||'Task\x20'+_0x1d53be['taskId']['slice'](-0x6))+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-meta\x22>'+Utils['escapeHtml'](_0x413869)+'\x20·\x20'+(_0x1d53be['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'+_0x1a1c4a+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x2cdab1+'\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'+_0x2ca9ab+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x1b57cc+'\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'+(_0x18d58b?'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'+_0x1d53be['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-action=\x22'+(_0x18d58b?'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'+(_0x18d58b?'<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',_0x320860=>{_0x320860['target']['closest']('.vgm-close-btn')&&(this['close'](),this['onGroupChange'](this['tasks'])),_0x320860['target']['closest']('.vgm-add-existing-btn')&&(this['close'](),this['onAddExistingTask'](this['groupId']));}),this['container']['addEventListener']('click',async _0x9c7471=>{const _0xcf484c=_0x9c7471['target']['closest']('.vgm-variant-remove-btn');if(!_0xcf484c)return;const _0x442d89=_0xcf484c['dataset']['taskId'],_0x38cbf6=_0xcf484c['dataset']['action'];try{_0x38cbf6==='remove'?await this['removeFromGroup'](_0x442d89):await this['addToGroup'](_0x442d89);}catch(_0x408940){console['error']('Failed\x20to\x20update\x20group:',_0x408940),Utils['showToast'](_0x408940['message']||'Failed\x20to\x20update\x20group','error');}}),this['container']['addEventListener']('dragstart',_0x401386=>this['handleDragStart'](_0x401386)),this['container']['addEventListener']('dragend',_0x224770=>this['handleDragEnd'](_0x224770)),this['container']['addEventListener']('dragover',_0x231335=>this['handleDragOver'](_0x231335)),this['container']['addEventListener']('dragleave',_0x326605=>this['handleDragLeave'](_0x326605)),this['container']['addEventListener']('drop',_0x45f53c=>this['handleDrop'](_0x45f53c));}['handleDragStart'](_0x1dcbf2){const _0x56f544=_0x1dcbf2['target']['closest']('.vgm-variant-card');if(!_0x56f544)return;dragState['draggedTaskId']=_0x56f544['dataset']['taskId'],dragState['draggedElement']=_0x56f544,dragState['sourceGroupId']=_0x56f544['dataset']['isGrouped']==='true'?this['groupId']:null,dragState['isDragging']=!![],_0x56f544['classList']['add']('dragging'),_0x1dcbf2['dataTransfer']['effectAllowed']='move',_0x1dcbf2['dataTransfer']['setData']('text/plain',_0x56f544['dataset']['taskId']),this['container']['classList']['add']('is-dragging');}['handleDragEnd'](_0x3012c2){const _0x2c9c6b=_0x3012c2['target']['closest']('.vgm-variant-card');_0x2c9c6b&&_0x2c9c6b['classList']['remove']('dragging'),this['container']['querySelectorAll']('.drag-over,\x20.drop-indicator')['forEach'](_0x5b1297=>{_0x5b1297['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'](_0x405bcc){_0x405bcc['preventDefault'](),_0x405bcc['dataTransfer']['dropEffect']='move';const _0x2d4e6b=_0x405bcc['target']['closest']('.vgm-drop-zone'),_0x261c0a=_0x405bcc['target']['closest']('.vgm-variant-card');this['container']['querySelectorAll']('.vgm-drop-zone')['forEach'](_0x2c0585=>{_0x2c0585['classList']['toggle']('drag-over',_0x2c0585===_0x2d4e6b);});if(_0x261c0a&&_0x261c0a!==dragState['draggedElement']){const _0x1d5195=_0x261c0a['getBoundingClientRect'](),_0x5a4556=_0x1d5195['top']+_0x1d5195['height']/0x2,_0x440be3=_0x405bcc['clientY']<_0x5a4556;this['container']['querySelectorAll']('.vgm-variant-card')['forEach'](_0x278c5a=>{_0x278c5a!==_0x261c0a&&_0x278c5a['classList']['remove']('drop-before','drop-after');}),_0x261c0a['classList']['toggle']('drop-before',_0x440be3),_0x261c0a['classList']['toggle']('drop-after',!_0x440be3);}}['handleDragLeave'](_0x278142){const _0x4ee7ec=_0x278142['target']['closest']('.vgm-drop-zone');_0x4ee7ec&&!_0x4ee7ec['contains'](_0x278142['relatedTarget'])&&_0x4ee7ec['classList']['remove']('drag-over');}async['handleDrop'](_0x2bfef8){_0x2bfef8['preventDefault']();const _0x175066=_0x2bfef8['target']['closest']('.vgm-drop-zone'),_0x37fc90=_0x2bfef8['target']['closest']('.vgm-variant-card'),_0x3acc9a=_0x2bfef8['dataTransfer']['getData']('text/plain');if(!_0x175066||!_0x3acc9a)return;this['container']['querySelectorAll']('.drag-over,\x20.drop-before,\x20.drop-after')['forEach'](_0x57f91b=>{_0x57f91b['classList']['remove']('drag-over','drop-before','drop-after');});const _0x3da6c5=_0x175066['dataset']['zone'],_0x367a48=_0x3da6c5==='grouped',_0x14ae2e=dragState['sourceGroupId']===this['groupId'];try{if(_0x367a48&&!_0x14ae2e){let _0x38a1f3=this['tasks']['filter'](_0x18dcb4=>_0x18dcb4['groupId']===this['groupId'])['length'];if(_0x37fc90){const _0x5e0a4e=_0x37fc90['dataset']['taskId'],_0x3fda53=this['tasks']['find'](_0x264591=>_0x264591['taskId']===_0x5e0a4e);if(_0x3fda53?.['groupIndex']!==undefined){const _0x54a27d=_0x37fc90['getBoundingClientRect'](),_0x2027dc=_0x2bfef8['clientY']<_0x54a27d['top']+_0x54a27d['height']/0x2;_0x38a1f3=_0x3fda53['groupIndex']+(_0x2027dc?0x0:0x1);}}await this['addToGroup'](_0x3acc9a,_0x38a1f3);}else{if(!_0x367a48&&_0x14ae2e)await this['removeFromGroup'](_0x3acc9a);else _0x367a48&&_0x14ae2e&&_0x37fc90&&await this['reorderInGroup'](_0x3acc9a,_0x37fc90,_0x2bfef8['clientY']);}}catch(_0x3d18c4){console['error']('Drop\x20operation\x20failed:',_0x3d18c4),Utils['showToast'](_0x3d18c4['message']||'Failed\x20to\x20move\x20variant','error');}}async['addToGroup'](_0x375be0,_0x19a1cc){const _0x30d124=this['tasks']['find'](_0x5db3cc=>_0x5db3cc['taskId']===_0x375be0);if(!_0x30d124)return;_0x19a1cc===undefined&&(_0x19a1cc=this['tasks']['filter'](_0x551bd8=>_0x551bd8['groupId']===this['groupId'])['length']),!this['groupId']&&(this['groupId']=API['generateGroupId'](),await API['createTaskGroup']({'groupId':this['groupId']})),await API['updateTaskGroup'](_0x375be0,this['groupId'],_0x19a1cc),_0x30d124['groupId']=this['groupId'],_0x30d124['groupIndex']=_0x19a1cc,this['render'](),this['onGroupChange'](this['tasks']);}async['removeFromGroup'](_0xae07ce){const _0x19b278=this['tasks']['find'](_0x227929=>_0x227929['taskId']===_0xae07ce);if(!_0x19b278)return;await API['removeTaskFromGroup'](_0xae07ce),_0x19b278['groupId']=null,_0x19b278['groupIndex']=null,this['render'](),this['onGroupChange'](this['tasks']);}async['reorderInGroup'](_0x4b1038,_0x4595c2,_0x403e57){const _0x57a829=this['tasks']['find'](_0x3b36b2=>_0x3b36b2['taskId']===_0x4b1038),_0x24e35d=_0x4595c2['dataset']['taskId'],_0x1b610b=this['tasks']['find'](_0x53cd62=>_0x53cd62['taskId']===_0x24e35d);if(!_0x57a829||!_0x1b610b||_0x57a829['taskId']===_0x1b610b['taskId'])return;const _0xfc77f5=_0x4595c2['getBoundingClientRect'](),_0x1d1ccc=_0x403e57<_0xfc77f5['top']+_0xfc77f5['height']/0x2;let _0x5db9c6=_0x1b610b['groupIndex']??0x0;if(!_0x1d1ccc)_0x5db9c6++;if((_0x57a829['groupIndex']??0x0)<(_0x1b610b['groupIndex']??0x0))_0x5db9c6--;if(_0x5db9c6===_0x57a829['groupIndex'])return;await API['updateTaskGroup'](_0x4b1038,this['groupId'],_0x5db9c6);const _0x4f76ae=this['tasks']['filter'](_0x1271fd=>_0x1271fd['groupId']===this['groupId'])['sort']((_0x1ade1d,_0x5bee49)=>(_0x1ade1d['groupIndex']??0x0)-(_0x5bee49['groupIndex']??0x0)),_0xfa78d8=_0x4f76ae['findIndex'](_0x210476=>_0x210476['taskId']===_0x4b1038);_0xfa78d8!==-0x1&&_0x4f76ae['splice'](_0xfa78d8,0x1),_0x4f76ae['splice'](_0x5db9c6,0x0,_0x57a829),_0x4f76ae['forEach']((_0x40d95f,_0x5978ad)=>{_0x40d95f['groupIndex']=_0x5978ad;}),this['render'](),this['onGroupChange'](this['tasks']);}}export function initializeTabDragDrop(_0x2dabdb,_0x4952e4,_0x364cc8,_0x3e6b9a={}){if(!_0x2dabdb)return;const {onReorder:_0xda2700,onRemove:_0x3b0d5f}=_0x3e6b9a,_0x3a9bd8=_0x2dabdb['querySelectorAll']('.task-tab');_0x3a9bd8['forEach']((_0x34fbc9,_0x1d0de7)=>{_0x34fbc9['setAttribute']('draggable','true'),_0x34fbc9['dataset']['index']=_0x1d0de7,_0x34fbc9['addEventListener']('dragstart',_0x2506df=>{_0x2506df['dataTransfer']['effectAllowed']='move',_0x2506df['dataTransfer']['setData']('text/plain',_0x34fbc9['dataset']['taskId']),_0x34fbc9['classList']['add']('dragging'),_0x2dabdb['classList']['add']('is-dragging');}),_0x34fbc9['addEventListener']('dragend',()=>{_0x34fbc9['classList']['remove']('dragging'),_0x2dabdb['classList']['remove']('is-dragging'),_0x2dabdb['querySelectorAll']('.drop-indicator')['forEach'](_0x4986ad=>{_0x4986ad['classList']['remove']('drop-indicator','drop-before','drop-after');});}),_0x34fbc9['addEventListener']('dragover',_0x1cf22c=>{_0x1cf22c['preventDefault'](),_0x1cf22c['dataTransfer']['dropEffect']='move';if(_0x34fbc9['classList']['contains']('dragging'))return;const _0x317544=_0x34fbc9['getBoundingClientRect'](),_0x1510c5=_0x317544['left']+_0x317544['width']/0x2,_0x3f6893=_0x1cf22c['clientX']<_0x1510c5;_0x3a9bd8['forEach'](_0x61cfc=>_0x61cfc['classList']['remove']('drop-before','drop-after')),_0x34fbc9['classList']['add'](_0x3f6893?'drop-before':'drop-after');}),_0x34fbc9['addEventListener']('dragleave',()=>{_0x34fbc9['classList']['remove']('drop-before','drop-after');}),_0x34fbc9['addEventListener']('drop',async _0x4a34ea=>{_0x4a34ea['preventDefault']();const _0x41f8e7=_0x4a34ea['dataTransfer']['getData']('text/plain'),_0x2bbf45=_0x34fbc9['dataset']['taskId'];if(_0x41f8e7===_0x2bbf45)return;const _0xbc1112=_0x34fbc9['getBoundingClientRect'](),_0x3c3f69=_0x4a34ea['clientX']<_0xbc1112['left']+_0xbc1112['width']/0x2;_0x34fbc9['classList']['remove']('drop-before','drop-after'),_0xda2700&&await _0xda2700(_0x41f8e7,_0x2bbf45,_0x3c3f69);});});const _0x3f7d0a=document['createElement']('div');return _0x3f7d0a['className']='task-tab-remove-zone',_0x3f7d0a['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',_0x3f7d0a['style']['display']='none',_0x3f7d0a['addEventListener']('dragover',_0x3c5591=>{_0x3c5591['preventDefault'](),_0x3f7d0a['classList']['add']('drag-over');}),_0x3f7d0a['addEventListener']('dragleave',()=>{_0x3f7d0a['classList']['remove']('drag-over');}),_0x3f7d0a['addEventListener']('drop',async _0xa2ada3=>{_0xa2ada3['preventDefault'](),_0x3f7d0a['classList']['remove']('drag-over');const _0x41c5ab=_0xa2ada3['dataTransfer']['getData']('text/plain');_0x3b0d5f&&await _0x3b0d5f(_0x41c5ab);}),_0x2dabdb['addEventListener']('dragstart',()=>{_0x4952e4['length']>0x1&&(_0x3f7d0a['style']['display']='flex');}),_0x2dabdb['addEventListener']('dragend',()=>{_0x3f7d0a['style']['display']='none';}),_0x2dabdb['appendChild'](_0x3f7d0a),{'destroy':()=>{_0x3f7d0a['remove']();}};}export default VariantGroupingManager;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@profoundlogic/coderflow-server",
3
- "version": "0.8.6",
3
+ "version": "0.8.8",
4
4
  "description": "AI Coder Server - Manages Docker containers for AI agent task execution",
5
5
  "main": "dist/start.js",
6
6
  "type": "module",