@profoundlogic/coderflow-server 0.7.9 → 0.8.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (185) hide show
  1. package/dist/base-image/coder-git-credential-helper +16 -0
  2. package/dist/base-image/entrypoint.sh +75 -5
  3. package/dist/base-image/sync-repos.sh +30 -1
  4. package/dist/coder-server.js +1 -1
  5. package/dist/config.js +1 -1
  6. package/dist/lib/agent-keepalive.js +1 -1
  7. package/dist/lib/agent-models.js +1 -1
  8. package/dist/lib/api-keys.js +1 -1
  9. package/dist/lib/apiKeys.js +1 -1
  10. package/dist/lib/app-server-ports.js +1 -1
  11. package/dist/lib/auto-judge.js +1 -1
  12. package/dist/lib/automation-service.js +1 -1
  13. package/dist/lib/basic-auth.js +1 -1
  14. package/dist/lib/bindings.js +1 -1
  15. package/dist/lib/build-history.js +1 -1
  16. package/dist/lib/build-output-service.js +1 -1
  17. package/dist/lib/build-scheduler.js +1 -1
  18. package/dist/lib/build-service.js +1 -1
  19. package/dist/lib/ca-certificates.js +1 -1
  20. package/dist/lib/claude-oauth-refresh.js +1 -1
  21. package/dist/lib/cli/build.js +1 -1
  22. package/dist/lib/cli/cleanup-users.js +1 -1
  23. package/dist/lib/cli/config-command.js +1 -1
  24. package/dist/lib/cli/config.js +1 -1
  25. package/dist/lib/cli/create-user.js +1 -1
  26. package/dist/lib/cli/grant-admin.js +1 -1
  27. package/dist/lib/cli/init.js +1 -1
  28. package/dist/lib/cli/jira.js +1 -1
  29. package/dist/lib/cli/license.js +1 -1
  30. package/dist/lib/cli/list-roles.js +1 -1
  31. package/dist/lib/cli/list-users.js +1 -1
  32. package/dist/lib/cli/server-manager.js +1 -1
  33. package/dist/lib/cli/set-password.js +1 -1
  34. package/dist/lib/compression-filter.js +1 -1
  35. package/dist/lib/config-migration.js +1 -1
  36. package/dist/lib/container-credential-sync.js +1 -1
  37. package/dist/lib/container-tokens.js +1 -1
  38. package/dist/lib/data-dir.js +1 -1
  39. package/dist/lib/deployment-history.js +1 -1
  40. package/dist/lib/deployment-service.js +1 -1
  41. package/dist/lib/docker-utils.js +1 -1
  42. package/dist/lib/email.js +1 -1
  43. package/dist/lib/emailTemplates.js +1 -1
  44. package/dist/lib/entitlement.js +1 -1
  45. package/dist/lib/external-connections.js +1 -1
  46. package/dist/lib/fetch-utils.js +1 -1
  47. package/dist/lib/git-commit-details-route.js +1 -1
  48. package/dist/lib/git-history-diff-guardrails.js +1 -1
  49. package/dist/lib/git-provider-service.js +1 -1
  50. package/dist/lib/git-provider-setup/github-setup-handler.js +1 -1
  51. package/dist/lib/git-provider-setup/index.js +1 -1
  52. package/dist/lib/git-provider-setup/setup-factory.js +1 -1
  53. package/dist/lib/git-provider-setup/setup-interface.js +1 -1
  54. package/dist/lib/git-providers/azure-devops-provider.js +1 -1
  55. package/dist/lib/git-providers/github-app-provider.js +1 -1
  56. package/dist/lib/git-providers/index.js +1 -1
  57. package/dist/lib/git-providers/provider-factory.js +1 -1
  58. package/dist/lib/git-providers/provider-interface.js +1 -1
  59. package/dist/lib/github-urls.js +1 -1
  60. package/dist/lib/group-objective-linking.js +1 -1
  61. package/dist/lib/ibmi-sync.js +1 -1
  62. package/dist/lib/jira-client.js +1 -1
  63. package/dist/lib/judge-blinding.js +1 -1
  64. package/dist/lib/logger.js +1 -1
  65. package/dist/lib/memory-utils.js +1 -1
  66. package/dist/lib/migration-to-scoped-rbac.js +1 -1
  67. package/dist/lib/model-fetcher.js +1 -1
  68. package/dist/lib/notifications.js +1 -1
  69. package/dist/lib/objective-context.js +1 -1
  70. package/dist/lib/oidc-auth.js +1 -1
  71. package/dist/lib/oidc-device-flow.js +1 -1
  72. package/dist/lib/passwordTokens.js +1 -1
  73. package/dist/lib/permission-resolver.js +1 -1
  74. package/dist/lib/pin-cascade.js +1 -1
  75. package/dist/lib/provider-accounts.js +1 -1
  76. package/dist/lib/provider-oauth.js +1 -1
  77. package/dist/lib/provider-profile.js +1 -1
  78. package/dist/lib/provider-token-refresh.js +1 -1
  79. package/dist/lib/rbac-user-state.js +1 -1
  80. package/dist/lib/request-url.js +1 -1
  81. package/dist/lib/rewind.js +1 -1
  82. package/dist/lib/role-definitions.js +1 -1
  83. package/dist/lib/roles.js +1 -1
  84. package/dist/lib/secrets.js +1 -1
  85. package/dist/lib/setup-repo-git-auth.js +1 -1
  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 -0
  90. package/dist/lib/task-context-usage.js +1 -0
  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/stats.js +1 -1
  131. package/dist/routes/tasks.js +1 -1
  132. package/dist/routes/teams.js +1 -1
  133. package/dist/routes/templates.js +1 -1
  134. package/dist/routes/test-task.js +1 -1
  135. package/dist/routes/test.js +1 -1
  136. package/dist/routes/users.js +1 -1
  137. package/dist/routes/visualizations.js +1 -1
  138. package/dist/scripts/create-user.js +1 -1
  139. package/dist/scripts/migrate-config-to-data-dir.js +1 -1
  140. package/dist/start.js +1 -1
  141. package/dist/web-ui/public/activity-detail-modal.js +1 -1
  142. package/dist/web-ui/public/activity-feed.js +1 -1
  143. package/dist/web-ui/public/activity-formatters.js +1 -1
  144. package/dist/web-ui/public/admin.css +95 -1
  145. package/dist/web-ui/public/admin.html +29 -1
  146. package/dist/web-ui/public/admin.js +1 -1
  147. package/dist/web-ui/public/agent-event-parser.js +1 -1
  148. package/dist/web-ui/public/app.js +1 -1
  149. package/dist/web-ui/public/approve-dialog.js +1 -1
  150. package/dist/web-ui/public/automation-links.js +1 -1
  151. package/dist/web-ui/public/automation-schedule.js +1 -1
  152. package/dist/web-ui/public/comments-widget.js +1 -1
  153. package/dist/web-ui/public/diff-utils.js +1 -1
  154. package/dist/web-ui/public/environments.js +1 -1
  155. package/dist/web-ui/public/feedback-widget.css +45 -0
  156. package/dist/web-ui/public/feedback-widget.js +1 -1
  157. package/dist/web-ui/public/file-selection-tree.js +1 -1
  158. package/dist/web-ui/public/git-history-lazy-utils.js +1 -1
  159. package/dist/web-ui/public/git-history.js +1 -1
  160. package/dist/web-ui/public/git-status.js +1 -1
  161. package/dist/web-ui/public/ibmi-file-filter.js +1 -1
  162. package/dist/web-ui/public/index.js +1 -1
  163. package/dist/web-ui/public/login.js +1 -1
  164. package/dist/web-ui/public/markdown-editor.js +1 -1
  165. package/dist/web-ui/public/markdown-file-editor.js +1 -1
  166. package/dist/web-ui/public/modal-maximize.js +1 -1
  167. package/dist/web-ui/public/notifications.js +1 -1
  168. package/dist/web-ui/public/permissions.js +1 -1
  169. package/dist/web-ui/public/pr-dialog.js +1 -1
  170. package/dist/web-ui/public/roles.js +1 -1
  171. package/dist/web-ui/public/settings.js +1 -1
  172. package/dist/web-ui/public/setup-password.js +1 -1
  173. package/dist/web-ui/public/skills.js +1 -1
  174. package/dist/web-ui/public/sse-client.js +1 -1
  175. package/dist/web-ui/public/sse-shared-worker.js +1 -1
  176. package/dist/web-ui/public/styles.css +81 -0
  177. package/dist/web-ui/public/task-judging-helpers.js +1 -1
  178. package/dist/web-ui/public/task.html +35 -1
  179. package/dist/web-ui/public/task.js +1 -1
  180. package/dist/web-ui/public/teams.js +1 -1
  181. package/dist/web-ui/public/terminal.js +1 -1
  182. package/dist/web-ui/public/theme.js +1 -1
  183. package/dist/web-ui/public/users.js +1 -1
  184. package/dist/web-ui/public/variant-grouping.js +1 -1
  185. package/package.json +1 -1
@@ -1 +1 @@
1
- import{API,Utils,initializeAdminMenu}from'./app.js';import{initTheme,mountThemeToggle}from'./theme.js';const state={'teams':[],'users':[],'roles':[],'environments':[],'teamBindings':[],'currentUser':null,'editingTeamId':null,'bindingsTeamId':null,'deletingTeamId':null,'modalSnapshot':null};document['addEventListener']('DOMContentLoaded',async()=>{initTheme(),mountThemeToggle();try{state['currentUser']=await API['getCurrentUser']();}catch{window['location']['href']='login.html';return;}await initializeAdminMenu(state['currentUser']);const _0x172748=state['currentUser'];if(!Permissions['hasServerPermission'](_0x172748,'teams:view')&&!Permissions['hasTeamPermission'](_0x172748,'teams:manage')){Utils['showToast']('Access\x20denied:\x20You\x20do\x20not\x20have\x20permission\x20to\x20view\x20teams','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}(Permissions['hasServerPermission'](_0x172748,'*')||Permissions['hasTeamPermission'](_0x172748,'teams:manage'))&&(document['getElementById']('create-team-btn')['hidden']=![]),bindEventListeners(),await Promise['all']([loadTeams(),loadUsers(),loadRoles(),loadEnvironments()]),renderTeams();});async function loadTeams(){const _0x2c9448=document['getElementById']('teams-loading'),_0x6d72d7=document['getElementById']('teams-error'),_0x26bed3=document['getElementById']('teams-content');try{_0x2c9448['hidden']=![],_0x6d72d7['hidden']=!![],_0x26bed3['hidden']=!![];const {teams:_0x4bd078}=await API['getTeams']();state['teams']=_0x4bd078||[],renderTeams(),_0x2c9448['hidden']=!![],_0x26bed3['hidden']=![];}catch(_0x9b46b7){_0x2c9448['hidden']=!![],_0x6d72d7['hidden']=![],document['getElementById']('teams-error-message')['textContent']=_0x9b46b7['message'];}}async function loadUsers(){try{const {users:_0x5e3c4a}=await API['getUsers']();state['users']=_0x5e3c4a||[];}catch{state['users']=[];}}async function loadRoles(){try{const {roles:_0x18dc49}=await API['getRoleDefinitions']();state['roles']=_0x18dc49||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x1c5aa2=await API['getEnvironments']();state['environments']=_0x1c5aa2['environments']||[];}catch{state['environments']=[];}}function renderTeams(){const _0x32811f=document['getElementById']('teams-table-body'),_0x3cf92c=document['getElementById']('team-count');if(!_0x32811f)return;_0x3cf92c&&(_0x3cf92c['textContent']=state['teams']['length']+'\x20team'+(state['teams']['length']===0x1?'':'s'));if(state['teams']['length']===0x0){_0x32811f['innerHTML']='\x0a\x20\x20\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td\x20colspan=\x223\x22\x20style=\x22text-align:\x20center;\x20color:\x20var(--color-text-secondary);\x20padding:\x202rem;\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20No\x20teams\x20yet.\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage')?'Click\x20<strong>Create\x20Team</strong>\x20to\x20get\x20started.':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20</tr>';return;}const _0x58accc=Permissions['hasServerPermission'](state['currentUser'],'*');_0x32811f['innerHTML']=state['teams']['map'](_0x5b96ea=>{const _0x136350=_0x58accc||_0x5b96ea['canManageTeam'],_0x93bf9=_0x58accc||_0x5b96ea['canManageMembers'],_0x497e16=_0x136350||_0x93bf9,_0x12b79e=(_0x5b96ea['members']||[])['length'];return'\x0a\x20\x20\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20style=\x22font-weight:\x20600;\x22>'+Utils['escapeHtml'](_0x5b96ea['name'])+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x5b96ea['description']?'<div\x20style=\x22font-size:\x200.8em;\x20color:\x20var(--color-text-secondary);\x20margin-top:\x200.15rem;\x22>'+Utils['escapeHtml'](_0x5b96ea['description'])+'</div>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+_0x12b79e+'</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22user-actions\x22\x20style=\x22display:\x20flex;\x20gap:\x200.25rem;\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x497e16?'<button\x20class=\x22btn-icon\x22\x20title=\x22Edit\x20team\x22\x20onclick=\x22window.openTeamModal(\x27'+_0x5b96ea['id']+'\x27)\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2216\x22\x20height=\x2216\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M11\x204H4a2\x202\x200\x200\x200-2\x202v14a2\x202\x200\x200\x200\x202\x202h14a2\x202\x200\x200\x200\x202-2v-7\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M18.5\x202.5a2.121\x202.121\x200\x200\x201\x203\x203L12\x2015l-4\x201\x201-4\x209.5-9.5z\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x136350?'<button\x20class=\x22btn-icon\x22\x20title=\x22Access\x20bindings\x22\x20onclick=\x22window.openBindingsModal(\x27'+_0x5b96ea['id']+'\x27)\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2216\x22\x20height=\x2216\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M12\x2022s8-4\x208-10V5l-8-3-8\x203v7c0\x206\x208\x2010\x208\x2010z\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x136350?'<button\x20class=\x22btn-icon\x20btn-danger\x22\x20title=\x22Delete\x20team\x22\x20onclick=\x22window.deleteTeam(\x27'+_0x5b96ea['id']+'\x27)\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2216\x22\x20height=\x2216\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<polyline\x20points=\x223\x206\x205\x206\x2021\x206\x22></polyline>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M19\x206v14a2\x202\x200\x200\x201-2\x202H7a2\x202\x200\x200\x201-2-2V6m3\x200V4a2\x202\x200\x200\x201\x202-2h4a2\x202\x200\x200\x201\x202\x202v2\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20</tr>';})['join']('');}function bindEventListeners(){document['getElementById']('create-team-btn')?.['addEventListener']('click',showCreateTeamModal),document['getElementById']('retry-teams-btn')?.['addEventListener']('click',loadTeams),document['getElementById']('close-team-modal')?.['addEventListener']('click',requestHideTeamModal),document['getElementById']('cancel-team')?.['addEventListener']('click',requestHideTeamModal),document['getElementById']('save-team')?.['addEventListener']('click',saveTeam),document['querySelector']('#team-modal\x20.modal-overlay')?.['addEventListener']('click',requestHideTeamModal),document['getElementById']('add-member-btn')?.['addEventListener']('click',addMember),document['getElementById']('close-bindings-modal')?.['addEventListener']('click',hideBindingsModal),document['querySelector']('#bindings-modal\x20.modal-overlay')?.['addEventListener']('click',hideBindingsModal),document['getElementById']('add-binding-btn')?.['addEventListener']('click',()=>{document['getElementById']('add-binding-form')['hidden']=![],document['getElementById']('add-binding-btn')['hidden']=!![],populateBindingForm();}),document['getElementById']('cancel-binding-btn')?.['addEventListener']('click',()=>{document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![];}),document['getElementById']('save-binding-btn')?.['addEventListener']('click',saveBinding),document['getElementById']('binding-resource-type')?.['addEventListener']('change',onBindingResourceTypeChange),document['getElementById']('close-delete-team-modal')?.['addEventListener']('click',hideDeleteModal),document['getElementById']('cancel-delete-team')?.['addEventListener']('click',hideDeleteModal),document['getElementById']('confirm-delete-team')?.['addEventListener']('click',confirmDeleteTeam),document['querySelector']('#delete-team-modal\x20.modal-overlay')?.['addEventListener']('click',hideDeleteModal);}function showCreateTeamModal(){state['editingTeamId']=null,state['modalSnapshot']={'name':'','description':''},document['getElementById']('team-modal-title')['textContent']='Create\x20Team',document['getElementById']('team-name')['value']='',document['getElementById']('team-name')['disabled']=![],document['getElementById']('team-description')['value']='',document['getElementById']('team-description')['disabled']=![],document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=!![],document['getElementById']('save-team')['hidden']=![],document['getElementById']('team-modal-footer')['hidden']=![],document['getElementById']('team-modal')['hidden']=![],setTimeout(()=>document['getElementById']('team-name')['focus'](),0x64);}window['openTeamModal']=function(_0x276425){const _0x26e124=state['teams']['find'](_0x2e5a40=>_0x2e5a40['id']===_0x276425);if(!_0x26e124)return;state['editingTeamId']=_0x276425;const _0x116752=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x4fcf5f=_0x116752||_0x26e124['canManageTeam'],_0x5be77d=_0x116752||_0x26e124['canManageMembers'],_0xb96161=_0x4fcf5f,_0x398ecb=_0x4fcf5f||_0x5be77d,_0x25a286=_0x26e124['name'],_0x16f76c=_0x26e124['description']||'';state['modalSnapshot']={'name':_0x25a286,'description':_0x16f76c},document['getElementById']('team-modal-title')['textContent']=_0x25a286,document['getElementById']('team-name')['value']=_0x25a286,document['getElementById']('team-name')['disabled']=!_0xb96161,document['getElementById']('team-description')['value']=_0x16f76c,document['getElementById']('team-description')['disabled']=!_0xb96161,document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=![],document['getElementById']('save-team')['hidden']=!_0xb96161,renderMembersList(_0x26e124),updateMemberSelect(_0x26e124),document['getElementById']('team-modal')['hidden']=![];};function isTeamModalDirty(){if(!state['modalSnapshot'])return![];const _0x466dc9=document['getElementById']('team-name')['value']['trim'](),_0x1285c0=document['getElementById']('team-description')['value']['trim']();return _0x466dc9!==state['modalSnapshot']['name']||_0x1285c0!==state['modalSnapshot']['description'];}function requestHideTeamModal(){if(isTeamModalDirty()){if(!confirm('You\x20have\x20unsaved\x20changes.\x20Discard\x20them?'))return;}hideTeamModal();}function hideTeamModal(){document['getElementById']('team-modal')['hidden']=!![],document['getElementById']('team-name')['disabled']=![],document['getElementById']('team-description')['disabled']=![],state['editingTeamId']=null,state['modalSnapshot']=null;}window['openBindingsModal']=function(_0xa7d7a){const _0x350260=state['teams']['find'](_0x5d6a24=>_0x5d6a24['id']===_0xa7d7a);if(!_0x350260)return;state['bindingsTeamId']=_0xa7d7a,document['getElementById']('bindings-modal-title')['textContent']='Access\x20Bindings\x20—\x20'+_0x350260['name'],document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('bindings-modal')['hidden']=![],loadTeamBindings(_0xa7d7a);};function hideBindingsModal(){document['getElementById']('bindings-modal')['hidden']=!![],state['bindingsTeamId']=null;}function renderMembersList(_0xa1b274){const _0x24aa31=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x209747=_0x24aa31||_0xa1b274['canManageMembers']||_0xa1b274['canManageTeam'],_0x3a21a3=_0xa1b274['members']||[],_0x57b676=document['getElementById']('members-list');if(_0x3a21a3['length']===0x0){_0x57b676['innerHTML']='<p\x20style=\x22font-size:\x200.875rem;\x20color:\x20var(--color-text-secondary);\x20margin:\x200.25rem\x200;\x22>No\x20members\x20yet</p>';return;}_0x57b676['innerHTML']=_0x3a21a3['map'](_0x2e6482=>{const _0x4a98c1=state['users']['find'](_0x35aaa4=>_0x35aaa4['id']===_0x2e6482),_0x23b3b4=_0x4a98c1?''+Utils['escapeHtml'](_0x4a98c1['username'])+(_0x4a98c1['name']?'\x20<span\x20style=\x22color:\x20var(--color-text-secondary);\x20font-size:\x200.85em;\x22>('+Utils['escapeHtml'](_0x4a98c1['name'])+')</span>':''):Utils['escapeHtml'](_0x2e6482);return'\x0a\x20\x20\x20\x20\x20\x20<div\x20style=\x22display:\x20flex;\x20align-items:\x20center;\x20justify-content:\x20space-between;\x20padding:\x200.35rem\x200;\x20border-bottom:\x201px\x20solid\x20var(--color-border);\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<span\x20style=\x22font-size:\x200.875rem;\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x23b3b4+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x209747?'<button\x20type=\x22button\x22\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.removeMemberClick(\x27'+_0x2e6482+'\x27)\x22\x20style=\x22color:\x20var(--color-danger);\x20padding:\x200.15rem\x200.4rem;\x20font-size:\x200.8rem;\x22>Remove</button>':'')+'\x0a\x20\x20\x20\x20\x20\x20</div>';})['join']('');const _0xf84f55=document['getElementById']('add-member-row');if(_0xf84f55)_0xf84f55['style']['display']=_0x209747?'flex':'none';}function updateMemberSelect(_0x4cca33){const _0x84b371=document['getElementById']('add-member-select');if(!_0x84b371)return;const _0x2ebd18=new Set(_0x4cca33['members']||[]),_0x5ecca5=state['users']['filter'](_0x42a9d7=>!_0x2ebd18['has'](_0x42a9d7['id']));_0x84b371['innerHTML']='<option\x20value=\x22\x22>Add\x20a\x20member…</option>'+_0x5ecca5['map'](_0x47e3b1=>'<option\x20value=\x22'+_0x47e3b1['id']+'\x22>'+Utils['escapeHtml'](_0x47e3b1['username'])+(_0x47e3b1['name']?'\x20('+Utils['escapeHtml'](_0x47e3b1['name'])+')':'')+'</option>')['join']('');}async function addMember(){const _0x10c170=document['getElementById']('add-member-select'),_0xb7c5b3=_0x10c170['value'];if(!_0xb7c5b3||!state['editingTeamId'])return;try{const {team:_0x43d871}=await API['addTeamMember'](state['editingTeamId'],_0xb7c5b3);syncTeamInState(_0x43d871),renderMembersList(_0x43d871),updateMemberSelect(_0x43d871),_0x10c170['value']='',Utils['showToast']('Member\x20added','success');}catch(_0x39a95f){Utils['showToast'](_0x39a95f['message'],'error');}}window['removeMemberClick']=async function(_0x39d4b8){if(!state['editingTeamId'])return;try{const {team:_0x4c08c1}=await API['removeTeamMember'](state['editingTeamId'],_0x39d4b8);syncTeamInState(_0x4c08c1),renderMembersList(_0x4c08c1),updateMemberSelect(_0x4c08c1),Utils['showToast']('Member\x20removed','success');}catch(_0x21d99d){Utils['showToast'](_0x21d99d['message'],'error');}};async function loadTeamBindings(_0x2fb9d5){const _0x46a4d9=document['getElementById']('bindings-loading'),_0x3021b6=document['getElementById']('bindings-empty'),_0x28a6a5=document['getElementById']('bindings-list-container'),_0x2e1e70=document['getElementById']('add-binding-btn');_0x46a4d9['hidden']=![],_0x3021b6['hidden']=!![],_0x28a6a5['style']['display']='none',_0x2e1e70['hidden']=!![],document['getElementById']('add-binding-form')['hidden']=!![];try{const {bindings:_0x4013c5}=await API['getBindings']({'subject_type':'team','subject_id':_0x2fb9d5});state['teamBindings']=_0x4013c5||[],_0x46a4d9['hidden']=!![],state['teamBindings']['length']===0x0?_0x3021b6['hidden']=![]:(_0x28a6a5['style']['display']='',renderBindingsTable()),(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage'))&&(_0x2e1e70['hidden']=![]);}catch(_0x4ef3d9){_0x46a4d9['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x4ef3d9['message'],'error');}}function renderBindingsTable(){const _0x17ed27=document['getElementById']('bindings-table-body');if(!_0x17ed27)return;const _0x571b7a=Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage');_0x17ed27['innerHTML']=state['teamBindings']['map'](_0x88fd6c=>{const _0x5f32a4=_0x88fd6c['resource_type']==='server'?'Server':_0x88fd6c['resource_id']==='*'?'All\x20'+_0x88fd6c['resource_type']+'s':Utils['escapeHtml'](_0x88fd6c['resource_name']||_0x88fd6c['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x5f32a4+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x88fd6c['role_name']||_0x88fd6c['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x571b7a?'<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteBindingClick(\x27'+_0x88fd6c['id']+'\x27)\x22\x20style=\x22color:\x20var(--color-danger);\x22>Remove</button>':'—')+'\x0a\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20</tr>';})['join']('');}function populateBindingForm(){const _0x228cba=document['getElementById']('binding-resource-type');_0x228cba['value']='environment',updateBindingFormForResourceType('environment');}function onBindingResourceTypeChange(){const _0x50c4ac=document['getElementById']('binding-resource-type')['value'];updateBindingFormForResourceType(_0x50c4ac);}function updateBindingFormForResourceType(_0x1058ae){const _0x124b68=document['getElementById']('binding-resource-container'),_0x11b4fe=document['getElementById']('binding-resource'),_0x283eaa=document['getElementById']('binding-role');if(_0x1058ae==='server')_0x124b68['style']['display']='none';else{_0x124b68['style']['display']='';if(_0x1058ae==='environment'){const _0x519a03=new Set(state['teamBindings']['filter'](_0x526e95=>_0x526e95['resource_type']==='environment')['map'](_0x549868=>_0x549868['resource_id'])),_0x397a47=state['environments']['filter'](_0x58b88f=>!_0x519a03['has'](_0x58b88f['name']));_0x11b4fe['innerHTML']=_0x397a47['length']?_0x397a47['map'](_0x29755f=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x29755f['name'])+'\x22>'+Utils['escapeHtml'](_0x29755f['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x1058ae==='team'){const _0x2b494=new Set(state['teamBindings']['filter'](_0x3ff45e=>_0x3ff45e['resource_type']==='team')['map'](_0x554112=>_0x554112['resource_id'])),_0x1644c6=state['teams']['filter'](_0x2fc87b=>!_0x2b494['has'](_0x2fc87b['id']));_0x11b4fe['innerHTML']=_0x1644c6['length']?_0x1644c6['map'](_0x53cef9=>'<option\x20value=\x22'+_0x53cef9['id']+'\x22>'+Utils['escapeHtml'](_0x53cef9['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x19c740=state['roles']['filter'](_0x1966a9=>_0x1966a9['resource_type']===_0x1058ae);_0x283eaa['innerHTML']=_0x19c740['length']?_0x19c740['filter'](_0x38d600=>{const _0x4bbb1c=_0x1058ae==='server'?undefined:_0x11b4fe['value'];return!state['teamBindings']['some'](_0x89cfb1=>_0x89cfb1['resource_type']===_0x1058ae&&_0x89cfb1['role_id']===_0x38d600['id']&&(_0x1058ae==='server'||_0x89cfb1['resource_id']===_0x4bbb1c));})['map'](_0x323658=>'<option\x20value=\x22'+_0x323658['id']+'\x22>'+Utils['escapeHtml'](_0x323658['name'])+'</option>')['join']('')||'<option\x20value=\x22\x22>No\x20available\x20roles</option>':'<option\x20value=\x22\x22>No\x20roles\x20for\x20this\x20resource\x20type</option>';}async function saveBinding(){const _0x557b2e=document['getElementById']('binding-resource-type')['value'],_0x2f721e=document['getElementById']('binding-role')['value'];if(!_0x2f721e||!state['bindingsTeamId'])return;const _0x3a15c7=_0x557b2e==='server'?undefined:document['getElementById']('binding-resource')['value'];if(_0x557b2e!=='server'&&!_0x3a15c7)return;const _0x22de37=document['getElementById']('save-binding-btn');_0x22de37['disabled']=!![],_0x22de37['textContent']='Adding…';try{const _0x3041ec={'subject_type':'team','subject_id':state['bindingsTeamId'],'role_id':_0x2f721e,'resource_type':_0x557b2e};if(_0x3a15c7)_0x3041ec['resource_id']=_0x3a15c7;await API['createBinding'](_0x3041ec),Utils['showToast']('Binding\x20added','success'),document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![],await loadTeamBindings(state['bindingsTeamId']);}catch(_0x451a44){Utils['showToast'](_0x451a44['message'],'error');}finally{_0x22de37['disabled']=![],_0x22de37['textContent']='Add\x20Binding';}}window['deleteBindingClick']=async function(_0x470a0d){try{await API['deleteBinding'](_0x470a0d),Utils['showToast']('Binding\x20removed','success'),await loadTeamBindings(state['bindingsTeamId']);}catch(_0x49e27d){Utils['showToast'](_0x49e27d['message'],'error');}};async function saveTeam(){const _0x484621=document['getElementById']('team-name')['value']['trim'](),_0x454085=document['getElementById']('team-description')['value']['trim'](),_0xf28bdd=document['getElementById']('team-form-error'),_0x462826=document['getElementById']('save-team');if(!_0x484621){_0xf28bdd['textContent']='Team\x20name\x20is\x20required',_0xf28bdd['hidden']=![];return;}_0xf28bdd['hidden']=!![];const _0x3df4b7=_0x462826['textContent'];_0x462826['disabled']=!![],_0x462826['textContent']=state['editingTeamId']?'Saving…':'Creating…';try{if(state['editingTeamId']){const {team:_0x30efdc}=await API['updateTeam'](state['editingTeamId'],{'name':_0x484621,'description':_0x454085});syncTeamInState(_0x30efdc),document['getElementById']('team-modal-title')['textContent']=_0x30efdc['name'],Utils['showToast']('Team\x20updated','success');}else await API['createTeam']({'name':_0x484621,'description':_0x454085}),Utils['showToast']('Team\x20created','success');_0x462826['disabled']=![],_0x462826['textContent']=_0x3df4b7,hideTeamModal(),await loadTeams();}catch(_0x518dfd){_0xf28bdd['textContent']=_0x518dfd['message'],_0xf28bdd['hidden']=![],_0x462826['disabled']=![],_0x462826['textContent']=_0x3df4b7;}}window['deleteTeam']=function(_0x3e427a){const _0x563d3f=state['teams']['find'](_0x4a10d4=>_0x4a10d4['id']===_0x3e427a);if(!_0x563d3f)return;state['deletingTeamId']=_0x3e427a,document['getElementById']('delete-team-name')['textContent']=_0x563d3f['name'],document['getElementById']('delete-team-modal')['hidden']=![];};function hideDeleteModal(){document['getElementById']('delete-team-modal')['hidden']=!![],state['deletingTeamId']=null;}async function confirmDeleteTeam(){if(!state['deletingTeamId'])return;const _0x244fdf=document['getElementById']('confirm-delete-team');_0x244fdf['disabled']=!![],_0x244fdf['textContent']='Deleting…';try{await API['deleteTeam'](state['deletingTeamId']),Utils['showToast']('Team\x20deleted','success'),_0x244fdf['disabled']=![],_0x244fdf['textContent']='Delete\x20Team',hideDeleteModal(),await loadTeams();}catch(_0x411eaf){Utils['showToast']('Failed\x20to\x20delete\x20team:\x20'+_0x411eaf['message'],'error'),_0x244fdf['disabled']=![],_0x244fdf['textContent']='Delete\x20Team';}}function syncTeamInState(_0x8c3b21){const _0x5db37f=state['teams']['findIndex'](_0x1cc104=>_0x1cc104['id']===_0x8c3b21['id']);if(_0x5db37f>=0x0)state['teams'][_0x5db37f]=_0x8c3b21;renderTeams();}
1
+ import{API,Utils,initializeAdminMenu}from'./app.js';import{initTheme,mountThemeToggle}from'./theme.js';const state={'teams':[],'users':[],'roles':[],'environments':[],'teamBindings':[],'currentUser':null,'editingTeamId':null,'bindingsTeamId':null,'deletingTeamId':null,'modalSnapshot':null};document['addEventListener']('DOMContentLoaded',async()=>{initTheme(),mountThemeToggle();try{state['currentUser']=await API['getCurrentUser']();}catch{window['location']['href']='login.html';return;}await initializeAdminMenu(state['currentUser']);const _0x5d8df3=state['currentUser'];if(!Permissions['hasServerPermission'](_0x5d8df3,'teams:view')&&!Permissions['hasTeamPermission'](_0x5d8df3,'teams:manage')){Utils['showToast']('Access\x20denied:\x20You\x20do\x20not\x20have\x20permission\x20to\x20view\x20teams','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}(Permissions['hasServerPermission'](_0x5d8df3,'*')||Permissions['hasTeamPermission'](_0x5d8df3,'teams:manage'))&&(document['getElementById']('create-team-btn')['hidden']=![]),bindEventListeners(),await Promise['all']([loadTeams(),loadUsers(),loadRoles(),loadEnvironments()]),renderTeams();});async function loadTeams(){const _0x160620=document['getElementById']('teams-loading'),_0xa62a88=document['getElementById']('teams-error'),_0x3a3f44=document['getElementById']('teams-content');try{_0x160620['hidden']=![],_0xa62a88['hidden']=!![],_0x3a3f44['hidden']=!![];const {teams:_0xb62f30}=await API['getTeams']();state['teams']=_0xb62f30||[],renderTeams(),_0x160620['hidden']=!![],_0x3a3f44['hidden']=![];}catch(_0x3cb67b){_0x160620['hidden']=!![],_0xa62a88['hidden']=![],document['getElementById']('teams-error-message')['textContent']=_0x3cb67b['message'];}}async function loadUsers(){try{const {users:_0x2c0b31}=await API['getUsers']();state['users']=_0x2c0b31||[];}catch{state['users']=[];}}async function loadRoles(){try{const {roles:_0x4a5fa1}=await API['getRoleDefinitions']();state['roles']=_0x4a5fa1||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x2bf2ce=await API['getEnvironments']();state['environments']=_0x2bf2ce['environments']||[];}catch{state['environments']=[];}}function renderTeams(){const _0x4bbaca=document['getElementById']('teams-table-body'),_0x4ad6fd=document['getElementById']('team-count');if(!_0x4bbaca)return;_0x4ad6fd&&(_0x4ad6fd['textContent']=state['teams']['length']+'\x20team'+(state['teams']['length']===0x1?'':'s'));if(state['teams']['length']===0x0){_0x4bbaca['innerHTML']='\x0a\x20\x20\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td\x20colspan=\x223\x22\x20style=\x22text-align:\x20center;\x20color:\x20var(--color-text-secondary);\x20padding:\x202rem;\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20No\x20teams\x20yet.\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage')?'Click\x20<strong>Create\x20Team</strong>\x20to\x20get\x20started.':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20</tr>';return;}const _0x2dd89d=Permissions['hasServerPermission'](state['currentUser'],'*');_0x4bbaca['innerHTML']=state['teams']['map'](_0x287287=>{const _0xda29a6=_0x2dd89d||_0x287287['canManageTeam'],_0x46c08f=_0x2dd89d||_0x287287['canManageMembers'],_0x3b2c59=_0xda29a6||_0x46c08f,_0xcf2221=(_0x287287['members']||[])['length'];return'\x0a\x20\x20\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20style=\x22font-weight:\x20600;\x22>'+Utils['escapeHtml'](_0x287287['name'])+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x287287['description']?'<div\x20style=\x22font-size:\x200.8em;\x20color:\x20var(--color-text-secondary);\x20margin-top:\x200.15rem;\x22>'+Utils['escapeHtml'](_0x287287['description'])+'</div>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+_0xcf2221+'</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22user-actions\x22\x20style=\x22display:\x20flex;\x20gap:\x200.25rem;\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x3b2c59?'<button\x20class=\x22btn-icon\x22\x20title=\x22Edit\x20team\x22\x20onclick=\x22window.openTeamModal(\x27'+_0x287287['id']+'\x27)\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2216\x22\x20height=\x2216\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M11\x204H4a2\x202\x200\x200\x200-2\x202v14a2\x202\x200\x200\x200\x202\x202h14a2\x202\x200\x200\x200\x202-2v-7\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M18.5\x202.5a2.121\x202.121\x200\x200\x201\x203\x203L12\x2015l-4\x201\x201-4\x209.5-9.5z\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0xda29a6?'<button\x20class=\x22btn-icon\x22\x20title=\x22Access\x20bindings\x22\x20onclick=\x22window.openBindingsModal(\x27'+_0x287287['id']+'\x27)\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2216\x22\x20height=\x2216\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M12\x2022s8-4\x208-10V5l-8-3-8\x203v7c0\x206\x208\x2010\x208\x2010z\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0xda29a6?'<button\x20class=\x22btn-icon\x20btn-danger\x22\x20title=\x22Delete\x20team\x22\x20onclick=\x22window.deleteTeam(\x27'+_0x287287['id']+'\x27)\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2216\x22\x20height=\x2216\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<polyline\x20points=\x223\x206\x205\x206\x2021\x206\x22></polyline>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M19\x206v14a2\x202\x200\x200\x201-2\x202H7a2\x202\x200\x200\x201-2-2V6m3\x200V4a2\x202\x200\x200\x201\x202-2h4a2\x202\x200\x200\x201\x202\x202v2\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20</tr>';})['join']('');}function bindEventListeners(){document['getElementById']('create-team-btn')?.['addEventListener']('click',showCreateTeamModal),document['getElementById']('retry-teams-btn')?.['addEventListener']('click',loadTeams),document['getElementById']('close-team-modal')?.['addEventListener']('click',requestHideTeamModal),document['getElementById']('cancel-team')?.['addEventListener']('click',requestHideTeamModal),document['getElementById']('save-team')?.['addEventListener']('click',saveTeam),document['querySelector']('#team-modal\x20.modal-overlay')?.['addEventListener']('click',requestHideTeamModal),document['getElementById']('add-member-btn')?.['addEventListener']('click',addMember),document['getElementById']('close-bindings-modal')?.['addEventListener']('click',hideBindingsModal),document['querySelector']('#bindings-modal\x20.modal-overlay')?.['addEventListener']('click',hideBindingsModal),document['getElementById']('add-binding-btn')?.['addEventListener']('click',()=>{document['getElementById']('add-binding-form')['hidden']=![],document['getElementById']('add-binding-btn')['hidden']=!![],populateBindingForm();}),document['getElementById']('cancel-binding-btn')?.['addEventListener']('click',()=>{document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![];}),document['getElementById']('save-binding-btn')?.['addEventListener']('click',saveBinding),document['getElementById']('binding-resource-type')?.['addEventListener']('change',onBindingResourceTypeChange),document['getElementById']('close-delete-team-modal')?.['addEventListener']('click',hideDeleteModal),document['getElementById']('cancel-delete-team')?.['addEventListener']('click',hideDeleteModal),document['getElementById']('confirm-delete-team')?.['addEventListener']('click',confirmDeleteTeam),document['querySelector']('#delete-team-modal\x20.modal-overlay')?.['addEventListener']('click',hideDeleteModal);}function showCreateTeamModal(){state['editingTeamId']=null,state['modalSnapshot']={'name':'','description':''},document['getElementById']('team-modal-title')['textContent']='Create\x20Team',document['getElementById']('team-name')['value']='',document['getElementById']('team-name')['disabled']=![],document['getElementById']('team-description')['value']='',document['getElementById']('team-description')['disabled']=![],document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=!![],document['getElementById']('save-team')['hidden']=![],document['getElementById']('team-modal-footer')['hidden']=![],document['getElementById']('team-modal')['hidden']=![],setTimeout(()=>document['getElementById']('team-name')['focus'](),0x64);}window['openTeamModal']=function(_0x2b68a8){const _0x4abd9f=state['teams']['find'](_0x23e125=>_0x23e125['id']===_0x2b68a8);if(!_0x4abd9f)return;state['editingTeamId']=_0x2b68a8;const _0x102264=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x1cb947=_0x102264||_0x4abd9f['canManageTeam'],_0x203c37=_0x102264||_0x4abd9f['canManageMembers'],_0x56c658=_0x1cb947,_0x298d7d=_0x1cb947||_0x203c37,_0xc79242=_0x4abd9f['name'],_0x34abe5=_0x4abd9f['description']||'';state['modalSnapshot']={'name':_0xc79242,'description':_0x34abe5},document['getElementById']('team-modal-title')['textContent']=_0xc79242,document['getElementById']('team-name')['value']=_0xc79242,document['getElementById']('team-name')['disabled']=!_0x56c658,document['getElementById']('team-description')['value']=_0x34abe5,document['getElementById']('team-description')['disabled']=!_0x56c658,document['getElementById']('team-form-error')['hidden']=!![],document['getElementById']('members-section')['hidden']=![],document['getElementById']('save-team')['hidden']=!_0x56c658,renderMembersList(_0x4abd9f),updateMemberSelect(_0x4abd9f),document['getElementById']('team-modal')['hidden']=![];};function isTeamModalDirty(){if(!state['modalSnapshot'])return![];const _0x171f7c=document['getElementById']('team-name')['value']['trim'](),_0x42484d=document['getElementById']('team-description')['value']['trim']();return _0x171f7c!==state['modalSnapshot']['name']||_0x42484d!==state['modalSnapshot']['description'];}function requestHideTeamModal(){if(isTeamModalDirty()){if(!confirm('You\x20have\x20unsaved\x20changes.\x20Discard\x20them?'))return;}hideTeamModal();}function hideTeamModal(){document['getElementById']('team-modal')['hidden']=!![],document['getElementById']('team-name')['disabled']=![],document['getElementById']('team-description')['disabled']=![],state['editingTeamId']=null,state['modalSnapshot']=null;}window['openBindingsModal']=function(_0x4e9cfd){const _0x131c0e=state['teams']['find'](_0x2e1a5e=>_0x2e1a5e['id']===_0x4e9cfd);if(!_0x131c0e)return;state['bindingsTeamId']=_0x4e9cfd,document['getElementById']('bindings-modal-title')['textContent']='Access\x20Bindings\x20—\x20'+_0x131c0e['name'],document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('bindings-modal')['hidden']=![],loadTeamBindings(_0x4e9cfd);};function hideBindingsModal(){document['getElementById']('bindings-modal')['hidden']=!![],state['bindingsTeamId']=null;}function renderMembersList(_0xaa535f){const _0x56e961=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x519c8c=_0x56e961||_0xaa535f['canManageMembers']||_0xaa535f['canManageTeam'],_0x29df0c=_0xaa535f['members']||[],_0x36325b=document['getElementById']('members-list');if(_0x29df0c['length']===0x0){_0x36325b['innerHTML']='<p\x20style=\x22font-size:\x200.875rem;\x20color:\x20var(--color-text-secondary);\x20margin:\x200.25rem\x200;\x22>No\x20members\x20yet</p>';return;}_0x36325b['innerHTML']=_0x29df0c['map'](_0x2f91aa=>{const _0x25bd8e=state['users']['find'](_0x5354ad=>_0x5354ad['id']===_0x2f91aa),_0x4740c2=_0x25bd8e?''+Utils['escapeHtml'](_0x25bd8e['username'])+(_0x25bd8e['name']?'\x20<span\x20style=\x22color:\x20var(--color-text-secondary);\x20font-size:\x200.85em;\x22>('+Utils['escapeHtml'](_0x25bd8e['name'])+')</span>':''):Utils['escapeHtml'](_0x2f91aa);return'\x0a\x20\x20\x20\x20\x20\x20<div\x20style=\x22display:\x20flex;\x20align-items:\x20center;\x20justify-content:\x20space-between;\x20padding:\x200.35rem\x200;\x20border-bottom:\x201px\x20solid\x20var(--color-border);\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<span\x20style=\x22font-size:\x200.875rem;\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x4740c2+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x519c8c?'<button\x20type=\x22button\x22\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.removeMemberClick(\x27'+_0x2f91aa+'\x27)\x22\x20style=\x22color:\x20var(--color-danger);\x20padding:\x200.15rem\x200.4rem;\x20font-size:\x200.8rem;\x22>Remove</button>':'')+'\x0a\x20\x20\x20\x20\x20\x20</div>';})['join']('');const _0x47e313=document['getElementById']('add-member-row');if(_0x47e313)_0x47e313['style']['display']=_0x519c8c?'flex':'none';}function updateMemberSelect(_0x27b60d){const _0x247038=document['getElementById']('add-member-select');if(!_0x247038)return;const _0xeb0a77=new Set(_0x27b60d['members']||[]),_0xc3a99d=state['users']['filter'](_0x438290=>!_0xeb0a77['has'](_0x438290['id']));_0x247038['innerHTML']='<option\x20value=\x22\x22>Add\x20a\x20member…</option>'+_0xc3a99d['map'](_0x2428ab=>'<option\x20value=\x22'+_0x2428ab['id']+'\x22>'+Utils['escapeHtml'](_0x2428ab['username'])+(_0x2428ab['name']?'\x20('+Utils['escapeHtml'](_0x2428ab['name'])+')':'')+'</option>')['join']('');}async function addMember(){const _0x2ac2b7=document['getElementById']('add-member-select'),_0x156a1f=_0x2ac2b7['value'];if(!_0x156a1f||!state['editingTeamId'])return;try{const {team:_0x48a323}=await API['addTeamMember'](state['editingTeamId'],_0x156a1f);syncTeamInState(_0x48a323),renderMembersList(_0x48a323),updateMemberSelect(_0x48a323),_0x2ac2b7['value']='',Utils['showToast']('Member\x20added','success');}catch(_0x4646d6){Utils['showToast'](_0x4646d6['message'],'error');}}window['removeMemberClick']=async function(_0x402a61){if(!state['editingTeamId'])return;try{const {team:_0x10c9f6}=await API['removeTeamMember'](state['editingTeamId'],_0x402a61);syncTeamInState(_0x10c9f6),renderMembersList(_0x10c9f6),updateMemberSelect(_0x10c9f6),Utils['showToast']('Member\x20removed','success');}catch(_0x348394){Utils['showToast'](_0x348394['message'],'error');}};async function loadTeamBindings(_0x4c5013){const _0x4bb9c3=document['getElementById']('bindings-loading'),_0x4cd3c5=document['getElementById']('bindings-empty'),_0x7330a4=document['getElementById']('bindings-list-container'),_0x463832=document['getElementById']('add-binding-btn');_0x4bb9c3['hidden']=![],_0x4cd3c5['hidden']=!![],_0x7330a4['style']['display']='none',_0x463832['hidden']=!![],document['getElementById']('add-binding-form')['hidden']=!![];try{const {bindings:_0x1fc4db}=await API['getBindings']({'subject_type':'team','subject_id':_0x4c5013});state['teamBindings']=_0x1fc4db||[],_0x4bb9c3['hidden']=!![],state['teamBindings']['length']===0x0?_0x4cd3c5['hidden']=![]:(_0x7330a4['style']['display']='',renderBindingsTable()),(Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage'))&&(_0x463832['hidden']=![]);}catch(_0x1f222b){_0x4bb9c3['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x1f222b['message'],'error');}}function renderBindingsTable(){const _0x5e713d=document['getElementById']('bindings-table-body');if(!_0x5e713d)return;const _0x26ff9c=Permissions['hasServerPermission'](state['currentUser'],'*')||Permissions['hasTeamPermission'](state['currentUser'],'teams:manage');_0x5e713d['innerHTML']=state['teamBindings']['map'](_0x2e2e97=>{const _0x4bac62=_0x2e2e97['resource_type']==='server'?'Server':_0x2e2e97['resource_id']==='*'?'All\x20'+_0x2e2e97['resource_type']+'s':Utils['escapeHtml'](_0x2e2e97['resource_name']||_0x2e2e97['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x4bac62+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x2e2e97['role_name']||_0x2e2e97['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x26ff9c?'<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteBindingClick(\x27'+_0x2e2e97['id']+'\x27)\x22\x20style=\x22color:\x20var(--color-danger);\x22>Remove</button>':'—')+'\x0a\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20</tr>';})['join']('');}function populateBindingForm(){const _0x54bfb0=document['getElementById']('binding-resource-type');_0x54bfb0['value']='environment',updateBindingFormForResourceType('environment');}function onBindingResourceTypeChange(){const _0x1f38ce=document['getElementById']('binding-resource-type')['value'];updateBindingFormForResourceType(_0x1f38ce);}function updateBindingFormForResourceType(_0x42b03e){const _0x218dcf=document['getElementById']('binding-resource-container'),_0x44038f=document['getElementById']('binding-resource'),_0x491338=document['getElementById']('binding-role');if(_0x42b03e==='server')_0x218dcf['style']['display']='none';else{_0x218dcf['style']['display']='';if(_0x42b03e==='environment'){const _0x111291=new Set(state['teamBindings']['filter'](_0x173c27=>_0x173c27['resource_type']==='environment')['map'](_0x23241b=>_0x23241b['resource_id'])),_0x30c7df=state['environments']['filter'](_0x45f78a=>!_0x111291['has'](_0x45f78a['name']));_0x44038f['innerHTML']=_0x30c7df['length']?_0x30c7df['map'](_0x5f1c62=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x5f1c62['name'])+'\x22>'+Utils['escapeHtml'](_0x5f1c62['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x42b03e==='team'){const _0x21a1c4=new Set(state['teamBindings']['filter'](_0x524cf8=>_0x524cf8['resource_type']==='team')['map'](_0x368df7=>_0x368df7['resource_id'])),_0x39c176=state['teams']['filter'](_0x1fbeaa=>!_0x21a1c4['has'](_0x1fbeaa['id']));_0x44038f['innerHTML']=_0x39c176['length']?_0x39c176['map'](_0x31dfcc=>'<option\x20value=\x22'+_0x31dfcc['id']+'\x22>'+Utils['escapeHtml'](_0x31dfcc['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x533641=state['roles']['filter'](_0x2cf5b1=>_0x2cf5b1['resource_type']===_0x42b03e);_0x491338['innerHTML']=_0x533641['length']?_0x533641['filter'](_0x94f16d=>{const _0x1fbf52=_0x42b03e==='server'?undefined:_0x44038f['value'];return!state['teamBindings']['some'](_0x2ad5c0=>_0x2ad5c0['resource_type']===_0x42b03e&&_0x2ad5c0['role_id']===_0x94f16d['id']&&(_0x42b03e==='server'||_0x2ad5c0['resource_id']===_0x1fbf52));})['map'](_0xc122fe=>'<option\x20value=\x22'+_0xc122fe['id']+'\x22>'+Utils['escapeHtml'](_0xc122fe['name'])+'</option>')['join']('')||'<option\x20value=\x22\x22>No\x20available\x20roles</option>':'<option\x20value=\x22\x22>No\x20roles\x20for\x20this\x20resource\x20type</option>';}async function saveBinding(){const _0x193001=document['getElementById']('binding-resource-type')['value'],_0x3597b5=document['getElementById']('binding-role')['value'];if(!_0x3597b5||!state['bindingsTeamId'])return;const _0x96717d=_0x193001==='server'?undefined:document['getElementById']('binding-resource')['value'];if(_0x193001!=='server'&&!_0x96717d)return;const _0x50de2c=document['getElementById']('save-binding-btn');_0x50de2c['disabled']=!![],_0x50de2c['textContent']='Adding…';try{const _0x417743={'subject_type':'team','subject_id':state['bindingsTeamId'],'role_id':_0x3597b5,'resource_type':_0x193001};if(_0x96717d)_0x417743['resource_id']=_0x96717d;await API['createBinding'](_0x417743),Utils['showToast']('Binding\x20added','success'),document['getElementById']('add-binding-form')['hidden']=!![],document['getElementById']('add-binding-btn')['hidden']=![],await loadTeamBindings(state['bindingsTeamId']);}catch(_0x231f4d){Utils['showToast'](_0x231f4d['message'],'error');}finally{_0x50de2c['disabled']=![],_0x50de2c['textContent']='Add\x20Binding';}}window['deleteBindingClick']=async function(_0x3f4614){try{await API['deleteBinding'](_0x3f4614),Utils['showToast']('Binding\x20removed','success'),await loadTeamBindings(state['bindingsTeamId']);}catch(_0x5c82b1){Utils['showToast'](_0x5c82b1['message'],'error');}};async function saveTeam(){const _0x34399d=document['getElementById']('team-name')['value']['trim'](),_0x161083=document['getElementById']('team-description')['value']['trim'](),_0x5f037e=document['getElementById']('team-form-error'),_0x4813db=document['getElementById']('save-team');if(!_0x34399d){_0x5f037e['textContent']='Team\x20name\x20is\x20required',_0x5f037e['hidden']=![];return;}_0x5f037e['hidden']=!![];const _0x810a3f=_0x4813db['textContent'];_0x4813db['disabled']=!![],_0x4813db['textContent']=state['editingTeamId']?'Saving…':'Creating…';try{if(state['editingTeamId']){const {team:_0x32c721}=await API['updateTeam'](state['editingTeamId'],{'name':_0x34399d,'description':_0x161083});syncTeamInState(_0x32c721),document['getElementById']('team-modal-title')['textContent']=_0x32c721['name'],Utils['showToast']('Team\x20updated','success');}else await API['createTeam']({'name':_0x34399d,'description':_0x161083}),Utils['showToast']('Team\x20created','success');_0x4813db['disabled']=![],_0x4813db['textContent']=_0x810a3f,hideTeamModal(),await loadTeams();}catch(_0x470218){_0x5f037e['textContent']=_0x470218['message'],_0x5f037e['hidden']=![],_0x4813db['disabled']=![],_0x4813db['textContent']=_0x810a3f;}}window['deleteTeam']=function(_0x135d83){const _0x2bc3cc=state['teams']['find'](_0xb1a74f=>_0xb1a74f['id']===_0x135d83);if(!_0x2bc3cc)return;state['deletingTeamId']=_0x135d83,document['getElementById']('delete-team-name')['textContent']=_0x2bc3cc['name'],document['getElementById']('delete-team-modal')['hidden']=![];};function hideDeleteModal(){document['getElementById']('delete-team-modal')['hidden']=!![],state['deletingTeamId']=null;}async function confirmDeleteTeam(){if(!state['deletingTeamId'])return;const _0x541ffb=document['getElementById']('confirm-delete-team');_0x541ffb['disabled']=!![],_0x541ffb['textContent']='Deleting…';try{await API['deleteTeam'](state['deletingTeamId']),Utils['showToast']('Team\x20deleted','success'),_0x541ffb['disabled']=![],_0x541ffb['textContent']='Delete\x20Team',hideDeleteModal(),await loadTeams();}catch(_0x5c6508){Utils['showToast']('Failed\x20to\x20delete\x20team:\x20'+_0x5c6508['message'],'error'),_0x541ffb['disabled']=![],_0x541ffb['textContent']='Delete\x20Team';}}function syncTeamInState(_0x55486d){const _0x928863=state['teams']['findIndex'](_0x2865fc=>_0x2865fc['id']===_0x55486d['id']);if(_0x928863>=0x0)state['teams'][_0x928863]=_0x55486d;renderTeams();}
@@ -1 +1 @@
1
- import{API,Utils}from'./app.js';import{Terminal}from'/vendor/xterm/5.3.0/xterm.esm.js';import{FitAddon}from'/vendor/xterm-addon-fit/0.7.0/xterm-addon-fit.esm.js';import{getCurrentTheme,initTheme,mountThemeToggle,onThemeChange}from'./theme.js';const params=Utils['getQueryParams'](),containerId=params['container'],command=(params['cmd']||'')['trim'](),useServerExec=params['server_exec']==='true',isEmbedded=params['embedded']==='true',terminalTabId=params['tabId']||'',titleEl=document['getElementById']('terminal-title'),subtitleEl=document['getElementById']('terminal-subtitle'),statusEl=document['getElementById']('terminal-status'),terminalEl=document['getElementById']('terminal-container'),closeBtn=document['getElementById']('close-terminal');initTheme();isEmbedded?(document['documentElement']['classList']['add']('terminal-embedded'),document['body']['classList']['add']('terminal-embedded')):mountThemeToggle({'targetSelectors':['.terminal-actions']});const getXtermTheme=()=>{return{'background':'#0f172a','foreground':'#e2e8f0','cursor':'#e2e8f0','cursorAccent':'#0f172a'};};closeBtn&&closeBtn['addEventListener']('click',()=>{if(isEmbedded&&window['parent']&&window['parent']!==window){window['parent']['postMessage']({'type':'coderflow-terminal-close','tabId':terminalTabId},window['location']['origin']);return;}window['close']();});if(!containerId){updateStatus('Missing\x20container\x20identifier','error');throw new Error('container\x20parameter\x20is\x20required');}document['title']='Terminal\x20·\x20'+containerId['slice'](0x0,0xc),enrichContainerDetails(containerId)['catch'](()=>{subtitleEl['textContent']='Container\x20'+containerId['substring'](0x0,0xc);});const term=new Terminal({'convertEol':!![],'cursorBlink':!![],'fontFamily':'JetBrains\x20Mono,\x20SFMono-Regular,\x20Consolas,\x20monospace','fontSize':0x10,'theme':getXtermTheme()}),fitAddon=new FitAddon();term['loadAddon'](fitAddon),term['open'](terminalEl),term['focus']();let isFitting=![];const doFit=()=>{if(isFitting)return;isFitting=!![],fitAddon['fit'](),sendResize(),term['scrollToBottom'](),setTimeout(()=>{isFitting=![];},0x32);};window['addEventListener']('resize',()=>{requestAnimationFrame(()=>{!isFitting&&doFit();});});const resizeObserver=new ResizeObserver(()=>{requestAnimationFrame(()=>{!isFitting&&doFit();});});resizeObserver['observe'](terminalEl);const socketProtocol=window['location']['protocol']==='https:'?'wss':'ws',socketUrl=new URL('/ws/containers/'+encodeURIComponent(containerId),window['location']['href']);command&&useServerExec&&socketUrl['searchParams']['set']('cmd',command);socketUrl['protocol']=socketProtocol+':';const socket=new WebSocket(socketUrl['toString']());term['onData'](_0x1e2548=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':_0x1e2548}));});let commandSent=![],hasReceivedOutput=![];socket['addEventListener']('message',_0x1d535f=>{try{const _0x55b6bb=JSON['parse'](_0x1d535f['data']);if(_0x55b6bb['type']==='data'&&typeof _0x55b6bb['data']==='string')term['write'](_0x55b6bb['data']),!hasReceivedOutput&&_0x55b6bb['data']['length']>0x0&&(hasReceivedOutput=!![],command&&!useServerExec&&!commandSent&&(commandSent=!![],setTimeout(()=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':command+'\x0d'}));},0xc8)));else{if(_0x55b6bb['type']==='status'&&_0x55b6bb['status']){if(_0x55b6bb['status']==='connected'){if(command&&useServerExec)updateStatus('Running:\x20'+command,'info');else command?updateStatus('Preparing:\x20'+command,'info'):updateStatus('Terminal\x20connected','success');doFit(),term['focus'](),command&&!useServerExec&&!commandSent&&setTimeout(()=>{!commandSent&&socket['readyState']===WebSocket['OPEN']&&(commandSent=!![],socket['send'](JSON['stringify']({'type':'data','data':command+'\x0d'})),updateStatus('Running:\x20'+command,'info'));},0x7d0);}else updateStatus('Session\x20'+_0x55b6bb['status'],_0x55b6bb['status']==='connected'?'success':'info');}else _0x55b6bb['type']==='error'&&_0x55b6bb['message']&&updateStatus(_0x55b6bb['message'],'error');}}catch(_0x2cf499){console['error']('Failed\x20to\x20parse\x20terminal\x20message',_0x2cf499);}}),socket['addEventListener']('close',_0x29eec4=>{const _0x28bc9b=_0x29eec4['reason']||'Connection\x20closed';updateStatus(_0x28bc9b,_0x29eec4['wasClean']?'info':'error'),isEmbedded&&terminalTabId&&window['parent']&&window['parent']!==window&&window['parent']['postMessage']({'type':'coderflow-terminal-disconnected','tabId':terminalTabId},window['location']['origin']);}),socket['addEventListener']('error',_0x189304=>{console['error']('Terminal\x20websocket\x20error',_0x189304),updateStatus('Connection\x20error','error');});function sendResize(){if(socket['readyState']!==WebSocket['OPEN'])return;const _0x573168=term['cols'],_0x41a49f=term['rows'];socket['send'](JSON['stringify']({'type':'resize','cols':_0x573168,'rows':_0x41a49f}));}function updateStatus(_0x13bd4b,_0x2e507e='info'){if(!statusEl)return;statusEl['textContent']=_0x13bd4b,statusEl['dataset']['variant']=_0x2e507e;}async function enrichContainerDetails(_0x679381){try{const _0xb2c8fd=await API['getContainer'](_0x679381);updateTerminalDetails(_0xb2c8fd);}catch{try{const _0x55b339=await API['getContainers'](),_0x22ecd7=(_0x55b339['containers']||[])['find'](_0xf21691=>_0xf21691['containerId']===_0x679381||_0xf21691['name']===_0x679381||_0xf21691['fullContainerId']?.['startsWith'](_0x679381));if(_0x22ecd7){updateTerminalDetails(_0x22ecd7);return;}subtitleEl['textContent']='Container\x20'+_0x679381['substring'](0x0,0xc);}catch{subtitleEl['textContent']='Container\x20'+_0x679381['substring'](0x0,0xc);}}}function updateTerminalDetails(_0x28cf36){const _0x4df213=_0x28cf36['containerId']||_0x28cf36['name']||_0x28cf36['fullContainerId']||containerId,_0x247148=_0x28cf36['environment']?'Environment\x20'+_0x28cf36['environment']:'Environment\x20unknown',_0x19e36b=_0x28cf36['defaultAgent']?'\x20·\x20Agent\x20'+_0x28cf36['defaultAgent']:'',_0x364dad=_0x28cf36['createdAt']?'\x20·\x20Started\x20'+Utils['formatRelativeTime'](_0x28cf36['createdAt']):'';titleEl['textContent']='Terminal\x20·\x20'+_0x4df213['substring'](0x0,0xc);const _0x274af0=command?'\x20·\x20Command\x20'+command:'';subtitleEl['textContent']=''+_0x247148+_0x19e36b+_0x364dad+_0x274af0;}
1
+ import{API,Utils}from'./app.js';import{Terminal}from'/vendor/xterm/5.3.0/xterm.esm.js';import{FitAddon}from'/vendor/xterm-addon-fit/0.7.0/xterm-addon-fit.esm.js';import{getCurrentTheme,initTheme,mountThemeToggle,onThemeChange}from'./theme.js';const params=Utils['getQueryParams'](),containerId=params['container'],command=(params['cmd']||'')['trim'](),useServerExec=params['server_exec']==='true',isEmbedded=params['embedded']==='true',terminalTabId=params['tabId']||'',titleEl=document['getElementById']('terminal-title'),subtitleEl=document['getElementById']('terminal-subtitle'),statusEl=document['getElementById']('terminal-status'),terminalEl=document['getElementById']('terminal-container'),closeBtn=document['getElementById']('close-terminal');initTheme();isEmbedded?(document['documentElement']['classList']['add']('terminal-embedded'),document['body']['classList']['add']('terminal-embedded')):mountThemeToggle({'targetSelectors':['.terminal-actions']});const getXtermTheme=()=>{return{'background':'#0f172a','foreground':'#e2e8f0','cursor':'#e2e8f0','cursorAccent':'#0f172a'};};closeBtn&&closeBtn['addEventListener']('click',()=>{if(isEmbedded&&window['parent']&&window['parent']!==window){window['parent']['postMessage']({'type':'coderflow-terminal-close','tabId':terminalTabId},window['location']['origin']);return;}window['close']();});if(!containerId){updateStatus('Missing\x20container\x20identifier','error');throw new Error('container\x20parameter\x20is\x20required');}document['title']='Terminal\x20·\x20'+containerId['slice'](0x0,0xc),enrichContainerDetails(containerId)['catch'](()=>{subtitleEl['textContent']='Container\x20'+containerId['substring'](0x0,0xc);});const term=new Terminal({'convertEol':!![],'cursorBlink':!![],'fontFamily':'JetBrains\x20Mono,\x20SFMono-Regular,\x20Consolas,\x20monospace','fontSize':0x10,'theme':getXtermTheme()}),fitAddon=new FitAddon();term['loadAddon'](fitAddon),term['open'](terminalEl),term['focus']();let isFitting=![];const doFit=()=>{if(isFitting)return;isFitting=!![],fitAddon['fit'](),sendResize(),term['scrollToBottom'](),setTimeout(()=>{isFitting=![];},0x32);};window['addEventListener']('resize',()=>{requestAnimationFrame(()=>{!isFitting&&doFit();});});const resizeObserver=new ResizeObserver(()=>{requestAnimationFrame(()=>{!isFitting&&doFit();});});resizeObserver['observe'](terminalEl);const socketProtocol=window['location']['protocol']==='https:'?'wss':'ws',socketUrl=new URL('/ws/containers/'+encodeURIComponent(containerId),window['location']['href']);command&&useServerExec&&socketUrl['searchParams']['set']('cmd',command);socketUrl['protocol']=socketProtocol+':';const socket=new WebSocket(socketUrl['toString']());term['onData'](_0x34b042=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':_0x34b042}));});let commandSent=![],hasReceivedOutput=![];socket['addEventListener']('message',_0x56033d=>{try{const _0x2e2425=JSON['parse'](_0x56033d['data']);if(_0x2e2425['type']==='data'&&typeof _0x2e2425['data']==='string')term['write'](_0x2e2425['data']),!hasReceivedOutput&&_0x2e2425['data']['length']>0x0&&(hasReceivedOutput=!![],command&&!useServerExec&&!commandSent&&(commandSent=!![],setTimeout(()=>{socket['readyState']===WebSocket['OPEN']&&socket['send'](JSON['stringify']({'type':'data','data':command+'\x0d'}));},0xc8)));else{if(_0x2e2425['type']==='status'&&_0x2e2425['status']){if(_0x2e2425['status']==='connected'){if(command&&useServerExec)updateStatus('Running:\x20'+command,'info');else command?updateStatus('Preparing:\x20'+command,'info'):updateStatus('Terminal\x20connected','success');doFit(),term['focus'](),command&&!useServerExec&&!commandSent&&setTimeout(()=>{!commandSent&&socket['readyState']===WebSocket['OPEN']&&(commandSent=!![],socket['send'](JSON['stringify']({'type':'data','data':command+'\x0d'})),updateStatus('Running:\x20'+command,'info'));},0x7d0);}else updateStatus('Session\x20'+_0x2e2425['status'],_0x2e2425['status']==='connected'?'success':'info');}else _0x2e2425['type']==='error'&&_0x2e2425['message']&&updateStatus(_0x2e2425['message'],'error');}}catch(_0x671c8){console['error']('Failed\x20to\x20parse\x20terminal\x20message',_0x671c8);}}),socket['addEventListener']('close',_0x1e1a2b=>{const _0x61eae7=_0x1e1a2b['reason']||'Connection\x20closed';updateStatus(_0x61eae7,_0x1e1a2b['wasClean']?'info':'error'),isEmbedded&&terminalTabId&&window['parent']&&window['parent']!==window&&window['parent']['postMessage']({'type':'coderflow-terminal-disconnected','tabId':terminalTabId},window['location']['origin']);}),socket['addEventListener']('error',_0x37d70e=>{console['error']('Terminal\x20websocket\x20error',_0x37d70e),updateStatus('Connection\x20error','error');});function sendResize(){if(socket['readyState']!==WebSocket['OPEN'])return;const _0x860802=term['cols'],_0x137629=term['rows'];socket['send'](JSON['stringify']({'type':'resize','cols':_0x860802,'rows':_0x137629}));}function updateStatus(_0x2f0d9a,_0x452408='info'){if(!statusEl)return;statusEl['textContent']=_0x2f0d9a,statusEl['dataset']['variant']=_0x452408;}async function enrichContainerDetails(_0x2ccccb){try{const _0x3527cc=await API['getContainer'](_0x2ccccb);updateTerminalDetails(_0x3527cc);}catch{try{const _0x34c2d0=await API['getContainers'](),_0xe036fd=(_0x34c2d0['containers']||[])['find'](_0xd626cd=>_0xd626cd['containerId']===_0x2ccccb||_0xd626cd['name']===_0x2ccccb||_0xd626cd['fullContainerId']?.['startsWith'](_0x2ccccb));if(_0xe036fd){updateTerminalDetails(_0xe036fd);return;}subtitleEl['textContent']='Container\x20'+_0x2ccccb['substring'](0x0,0xc);}catch{subtitleEl['textContent']='Container\x20'+_0x2ccccb['substring'](0x0,0xc);}}}function updateTerminalDetails(_0x38aa11){const _0x4243e=_0x38aa11['containerId']||_0x38aa11['name']||_0x38aa11['fullContainerId']||containerId,_0x2d0db6=_0x38aa11['environment']?'Environment\x20'+_0x38aa11['environment']:'Environment\x20unknown',_0x2eeb15=_0x38aa11['defaultAgent']?'\x20·\x20Agent\x20'+_0x38aa11['defaultAgent']:'',_0x59bed0=_0x38aa11['createdAt']?'\x20·\x20Started\x20'+Utils['formatRelativeTime'](_0x38aa11['createdAt']):'';titleEl['textContent']='Terminal\x20·\x20'+_0x4243e['substring'](0x0,0xc);const _0x1f4cf4=command?'\x20·\x20Command\x20'+command:'';subtitleEl['textContent']=''+_0x2d0db6+_0x2eeb15+_0x59bed0+_0x1f4cf4;}
@@ -1 +1 @@
1
- const THEME_STORAGE_KEY='profound-coder-theme',THEME_CHANGE_EVENT='profound-theme-change',VALID_THEMES=new Set(['light','dark']),DEFAULT_TARGET_SELECTORS=['#theme-toggle-container','.header-actions','.status-actions','.terminal-actions','.top-bar'];function readStoredTheme(){try{const _0x57b9c6=localStorage['getItem'](THEME_STORAGE_KEY);if(_0x57b9c6&&VALID_THEMES['has'](_0x57b9c6))return _0x57b9c6;}catch(_0x4ce70d){console['warn']('[Theme]\x20Failed\x20to\x20read\x20stored\x20theme\x20preference:',_0x4ce70d);}return null;}export function getPreferredTheme(){const _0x5f1fd4=readStoredTheme();if(_0x5f1fd4)return _0x5f1fd4;const _0x485ce6=window['matchMedia']&&window['matchMedia']('(prefers-color-scheme:\x20dark)')['matches'];return _0x485ce6?'dark':'light';}export function getCurrentTheme(){const _0x1bf9bc=document['documentElement']['dataset']['theme'];if(_0x1bf9bc&&VALID_THEMES['has'](_0x1bf9bc))return _0x1bf9bc;return getPreferredTheme();}export function applyTheme(_0x38d347,{persist:persist=!![],emitEvent:emitEvent=!![]}={}){const _0x36fb02=VALID_THEMES['has'](_0x38d347)?_0x38d347:'light';document['documentElement']['dataset']['theme']=_0x36fb02,document['documentElement']['style']['colorScheme']=_0x36fb02==='dark'?'dark':'light';if(persist)try{localStorage['setItem'](THEME_STORAGE_KEY,_0x36fb02);}catch(_0x2819d1){console['warn']('[Theme]\x20Failed\x20to\x20persist\x20theme\x20preference:',_0x2819d1);}return emitEvent&&window['dispatchEvent'](new CustomEvent(THEME_CHANGE_EVENT,{'detail':{'theme':_0x36fb02}})),_0x36fb02;}export function initTheme(_0x15cfe1={}){const {emitEvent:emitEvent=![]}=_0x15cfe1;return applyTheme(getPreferredTheme(),{'persist':![],'emitEvent':emitEvent});}export function toggleTheme(){const _0x7eab8=getCurrentTheme()==='dark'?'light':'dark';return applyTheme(_0x7eab8);}export function onThemeChange(_0x4337d8,{runImmediately:runImmediately=![]}={}){const _0x2cb04b=_0x52c23d=>{_0x4337d8(_0x52c23d['detail']['theme']);};return window['addEventListener'](THEME_CHANGE_EVENT,_0x2cb04b),runImmediately&&_0x4337d8(getCurrentTheme()),()=>window['removeEventListener'](THEME_CHANGE_EVENT,_0x2cb04b);}export function mountThemeToggle(_0x2b214a={}){const {targetSelectors:targetSelectors=DEFAULT_TARGET_SELECTORS}=_0x2b214a,_0x361f33=targetSelectors['map'](_0xb5f737=>document['querySelector'](_0xb5f737))['find'](Boolean),_0xb21a12=document['createElement']('button');_0xb21a12['type']='button',_0xb21a12['className']='btn-ghost\x20theme-toggle-btn',_0xb21a12['id']='theme-toggle-btn',_0xb21a12['setAttribute']('aria-pressed','false'),_0xb21a12['style']['padding']='8px',_0xb21a12['style']['lineHeight']='0',_0xb21a12['style']['width']='36px',_0xb21a12['style']['height']='36px',_0xb21a12['style']['display']='flex',_0xb21a12['style']['alignItems']='center',_0xb21a12['style']['justifyContent']='center';const _0x5c14a2=document['createElement']('span');_0x5c14a2['className']='theme-icon',_0x5c14a2['style']['display']='flex',_0xb21a12['append'](_0x5c14a2);const _0x5b5d96='<svg\x20xmlns=\x22http://www.w3.org/2000/svg\x22\x20width=\x2220\x22\x20height=\x2220\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22><path\x20d=\x22M21\x2012.79A9\x209\x200\x201\x201\x2011.21\x203\x207\x207\x200\x200\x200\x2021\x2012.79z\x22></path></svg>',_0x2630ad='<svg\x20xmlns=\x22http://www.w3.org/2000/svg\x22\x20width=\x2220\x22\x20height=\x2220\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22><circle\x20cx=\x2212\x22\x20cy=\x2212\x22\x20r=\x225\x22></circle><line\x20x1=\x2212\x22\x20y1=\x221\x22\x20x2=\x2212\x22\x20y2=\x223\x22></line><line\x20x1=\x2212\x22\x20y1=\x2221\x22\x20x2=\x2212\x22\x20y2=\x2223\x22></line><line\x20x1=\x224.22\x22\x20y1=\x224.22\x22\x20x2=\x225.64\x22\x20y2=\x225.64\x22></line><line\x20x1=\x2218.36\x22\x20y1=\x2218.36\x22\x20x2=\x2219.78\x22\x20y2=\x2219.78\x22></line><line\x20x1=\x221\x22\x20y1=\x2212\x22\x20x2=\x223\x22\x20y2=\x2212\x22></line><line\x20x1=\x2221\x22\x20y1=\x2212\x22\x20x2=\x2223\x22\x20y2=\x2212\x22></line><line\x20x1=\x224.22\x22\x20y1=\x2219.78\x22\x20x2=\x225.64\x22\x20y2=\x2218.36\x22></line><line\x20x1=\x2218.36\x22\x20y1=\x225.64\x22\x20x2=\x2219.78\x22\x20y2=\x224.22\x22></line></svg>',_0x20f5c7=_0x5b8e47=>{const _0x173da0=_0x5b8e47==='dark';_0x5c14a2['innerHTML']=_0x173da0?_0x5b5d96:_0x2630ad,_0xb21a12['title']=_0x173da0?'Switch\x20to\x20light\x20mode':'Switch\x20to\x20dark\x20mode',_0xb21a12['dataset']['theme']=_0x5b8e47,_0xb21a12['setAttribute']('aria-pressed',String(_0x173da0));};return _0xb21a12['addEventListener']('click',()=>{const _0x149546=getCurrentTheme()==='dark'?'light':'dark';applyTheme(_0x149546);}),_0x361f33?_0x361f33['appendChild'](_0xb21a12):(_0xb21a12['classList']['add']('theme-toggle-floating'),document['body']['appendChild'](_0xb21a12)),_0x20f5c7(initTheme()),onThemeChange(_0x20f5c7),_0xb21a12;}export{THEME_STORAGE_KEY,THEME_CHANGE_EVENT};
1
+ const THEME_STORAGE_KEY='profound-coder-theme',THEME_CHANGE_EVENT='profound-theme-change',VALID_THEMES=new Set(['light','dark']),DEFAULT_TARGET_SELECTORS=['#theme-toggle-container','.header-actions','.status-actions','.terminal-actions','.top-bar'];function readStoredTheme(){try{const _0x1aac05=localStorage['getItem'](THEME_STORAGE_KEY);if(_0x1aac05&&VALID_THEMES['has'](_0x1aac05))return _0x1aac05;}catch(_0x1bb91a){console['warn']('[Theme]\x20Failed\x20to\x20read\x20stored\x20theme\x20preference:',_0x1bb91a);}return null;}export function getPreferredTheme(){const _0x5dd96b=readStoredTheme();if(_0x5dd96b)return _0x5dd96b;const _0x4697fb=window['matchMedia']&&window['matchMedia']('(prefers-color-scheme:\x20dark)')['matches'];return _0x4697fb?'dark':'light';}export function getCurrentTheme(){const _0x46c1ea=document['documentElement']['dataset']['theme'];if(_0x46c1ea&&VALID_THEMES['has'](_0x46c1ea))return _0x46c1ea;return getPreferredTheme();}export function applyTheme(_0x1c15ec,{persist:persist=!![],emitEvent:emitEvent=!![]}={}){const _0x535b06=VALID_THEMES['has'](_0x1c15ec)?_0x1c15ec:'light';document['documentElement']['dataset']['theme']=_0x535b06,document['documentElement']['style']['colorScheme']=_0x535b06==='dark'?'dark':'light';if(persist)try{localStorage['setItem'](THEME_STORAGE_KEY,_0x535b06);}catch(_0x2c1b1e){console['warn']('[Theme]\x20Failed\x20to\x20persist\x20theme\x20preference:',_0x2c1b1e);}return emitEvent&&window['dispatchEvent'](new CustomEvent(THEME_CHANGE_EVENT,{'detail':{'theme':_0x535b06}})),_0x535b06;}export function initTheme(_0x2a1865={}){const {emitEvent:emitEvent=![]}=_0x2a1865;return applyTheme(getPreferredTheme(),{'persist':![],'emitEvent':emitEvent});}export function toggleTheme(){const _0x14e05e=getCurrentTheme()==='dark'?'light':'dark';return applyTheme(_0x14e05e);}export function onThemeChange(_0x10c05c,{runImmediately:runImmediately=![]}={}){const _0x2f0a9f=_0x25bf7a=>{_0x10c05c(_0x25bf7a['detail']['theme']);};return window['addEventListener'](THEME_CHANGE_EVENT,_0x2f0a9f),runImmediately&&_0x10c05c(getCurrentTheme()),()=>window['removeEventListener'](THEME_CHANGE_EVENT,_0x2f0a9f);}export function mountThemeToggle(_0x1c36ba={}){const {targetSelectors:targetSelectors=DEFAULT_TARGET_SELECTORS}=_0x1c36ba,_0x12612b=targetSelectors['map'](_0x5038a1=>document['querySelector'](_0x5038a1))['find'](Boolean),_0x3ba55f=document['createElement']('button');_0x3ba55f['type']='button',_0x3ba55f['className']='btn-ghost\x20theme-toggle-btn',_0x3ba55f['id']='theme-toggle-btn',_0x3ba55f['setAttribute']('aria-pressed','false'),_0x3ba55f['style']['padding']='8px',_0x3ba55f['style']['lineHeight']='0',_0x3ba55f['style']['width']='36px',_0x3ba55f['style']['height']='36px',_0x3ba55f['style']['display']='flex',_0x3ba55f['style']['alignItems']='center',_0x3ba55f['style']['justifyContent']='center';const _0x59ff2e=document['createElement']('span');_0x59ff2e['className']='theme-icon',_0x59ff2e['style']['display']='flex',_0x3ba55f['append'](_0x59ff2e);const _0x279f41='<svg\x20xmlns=\x22http://www.w3.org/2000/svg\x22\x20width=\x2220\x22\x20height=\x2220\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22><path\x20d=\x22M21\x2012.79A9\x209\x200\x201\x201\x2011.21\x203\x207\x207\x200\x200\x200\x2021\x2012.79z\x22></path></svg>',_0x55bcff='<svg\x20xmlns=\x22http://www.w3.org/2000/svg\x22\x20width=\x2220\x22\x20height=\x2220\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22><circle\x20cx=\x2212\x22\x20cy=\x2212\x22\x20r=\x225\x22></circle><line\x20x1=\x2212\x22\x20y1=\x221\x22\x20x2=\x2212\x22\x20y2=\x223\x22></line><line\x20x1=\x2212\x22\x20y1=\x2221\x22\x20x2=\x2212\x22\x20y2=\x2223\x22></line><line\x20x1=\x224.22\x22\x20y1=\x224.22\x22\x20x2=\x225.64\x22\x20y2=\x225.64\x22></line><line\x20x1=\x2218.36\x22\x20y1=\x2218.36\x22\x20x2=\x2219.78\x22\x20y2=\x2219.78\x22></line><line\x20x1=\x221\x22\x20y1=\x2212\x22\x20x2=\x223\x22\x20y2=\x2212\x22></line><line\x20x1=\x2221\x22\x20y1=\x2212\x22\x20x2=\x2223\x22\x20y2=\x2212\x22></line><line\x20x1=\x224.22\x22\x20y1=\x2219.78\x22\x20x2=\x225.64\x22\x20y2=\x2218.36\x22></line><line\x20x1=\x2218.36\x22\x20y1=\x225.64\x22\x20x2=\x2219.78\x22\x20y2=\x224.22\x22></line></svg>',_0x3e62fe=_0x23722a=>{const _0x1e8791=_0x23722a==='dark';_0x59ff2e['innerHTML']=_0x1e8791?_0x279f41:_0x55bcff,_0x3ba55f['title']=_0x1e8791?'Switch\x20to\x20light\x20mode':'Switch\x20to\x20dark\x20mode',_0x3ba55f['dataset']['theme']=_0x23722a,_0x3ba55f['setAttribute']('aria-pressed',String(_0x1e8791));};return _0x3ba55f['addEventListener']('click',()=>{const _0x186424=getCurrentTheme()==='dark'?'light':'dark';applyTheme(_0x186424);}),_0x12612b?_0x12612b['appendChild'](_0x3ba55f):(_0x3ba55f['classList']['add']('theme-toggle-floating'),document['body']['appendChild'](_0x3ba55f)),_0x3e62fe(initTheme()),onThemeChange(_0x3e62fe),_0x3ba55f;}export{THEME_STORAGE_KEY,THEME_CHANGE_EVENT};
@@ -1 +1 @@
1
- import{API,Utils,ConfirmDialog,initializeAdminMenu}from'./app.js';import{initTheme,mountThemeToggle}from'./theme.js';const state={'users':[],'editingUserId':null,'bindingsUserId':null,'deletingUserId':null,'setupLinkData':null,'emailConfigured':![],'currentUser':null,'roles':[],'environments':[],'teams':[],'userBindings':[],'bindingsDirty':![]};document['addEventListener']('DOMContentLoaded',async()=>{initTheme(),mountThemeToggle(),await checkAdminAccess(),await initializeAdminMenu(state['currentUser']),await Promise['all']([checkEmailConfig(),loadRoles(),loadEnvironments(),loadTeams()]),bindEventListeners(),await loadUsers();});async function checkAdminAccess(){try{const _0x613256=await API['getCurrentUser']();state['currentUser']=_0x613256;if(!Permissions['hasServerPermission'](_0x613256,'*')&&!Permissions['hasServerPermission'](_0x613256,'users:create')){Utils['showToast']('Access\x20denied:\x20Server\x20admin\x20privileges\x20required','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}}catch(_0x192e5b){window['location']['href']='login.html';}}async function checkEmailConfig(){try{const _0x31b73c=await API['getEmailConfig']();state['emailConfigured']=_0x31b73c['configured'];}catch(_0x33db98){console['error']('Failed\x20to\x20check\x20email\x20config',_0x33db98),state['emailConfigured']=![];}}async function loadRoles(){try{const {roles:_0x41566c}=await API['getRoleDefinitions']();state['roles']=_0x41566c||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x2284f0=await API['getEnvironments']();state['environments']=_0x2284f0['environments']||[];}catch{state['environments']=[];}}async function loadTeams(){try{const {teams:_0x367f05}=await API['getTeams']();state['teams']=_0x367f05||[];}catch{state['teams']=[];}}function bindEventListeners(){document['getElementById']('create-user-btn')?.['addEventListener']('click',showCreateUserModal),document['getElementById']('close-user-modal')?.['addEventListener']('click',hideUserModal),document['getElementById']('cancel-user')?.['addEventListener']('click',hideUserModal),document['getElementById']('save-user')?.['addEventListener']('click',saveUser),document['querySelector']('#user-modal\x20.modal-overlay')?.['addEventListener']('click',hideUserModal),document['getElementById']('close-delete-modal')?.['addEventListener']('click',hideDeleteModal),document['getElementById']('cancel-delete')?.['addEventListener']('click',hideDeleteModal),document['getElementById']('confirm-delete')?.['addEventListener']('click',confirmDeleteUser),document['querySelector']('#delete-modal\x20.modal-overlay')?.['addEventListener']('click',hideDeleteModal),document['getElementById']('close-setup-link-modal')?.['addEventListener']('click',hideSetupLinkModal),document['getElementById']('close-setup-link')?.['addEventListener']('click',hideSetupLinkModal),document['getElementById']('copy-setup-link')?.['addEventListener']('click',copySetupLink),document['getElementById']('email-setup-link')?.['addEventListener']('click',emailSetupLink),document['querySelector']('#setup-link-modal\x20.modal-overlay')?.['addEventListener']('click',hideSetupLinkModal),document['getElementById']('skip-password')?.['addEventListener']('change',handleSkipPasswordChange),document['getElementById']('retry-users-btn')?.['addEventListener']('click',loadUsers),document['getElementById']('close-bindings-modal')?.['addEventListener']('click',hideAccessBindingsModal),document['getElementById']('close-bindings-modal-footer')?.['addEventListener']('click',hideAccessBindingsModal),document['querySelector']('#bindings-modal\x20.modal-overlay')?.['addEventListener']('click',hideAccessBindingsModal),document['getElementById']('add-user-binding-btn')?.['addEventListener']('click',()=>{document['getElementById']('add-user-binding-form')['hidden']=![],document['getElementById']('add-user-binding-btn')['hidden']=!![],populateUserBindingForm();}),document['getElementById']('cancel-user-binding-btn')?.['addEventListener']('click',()=>{document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![];}),document['getElementById']('save-user-binding-btn')?.['addEventListener']('click',saveUserBinding),document['getElementById']('user-binding-resource-type')?.['addEventListener']('change',onUserBindingResourceTypeChange);}async function loadUsers(){const _0x3d8a2e=document['getElementById']('users-loading'),_0x2c68aa=document['getElementById']('users-error'),_0x5669ac=document['getElementById']('users-content');try{_0x3d8a2e['hidden']=![],_0x2c68aa['hidden']=!![],_0x5669ac['hidden']=!![];const _0x454124=await API['getUsers']();state['users']=_0x454124['users']||[],renderUsers(),_0x3d8a2e['hidden']=!![],_0x5669ac['hidden']=![];}catch(_0x207180){console['error']('Failed\x20to\x20load\x20users',_0x207180),_0x3d8a2e['hidden']=!![],_0x2c68aa['hidden']=![],document['getElementById']('users-error-message')['textContent']=_0x207180['message'];}}function renderUsers(){const _0x54aa6f=document['getElementById']('users-table-body'),_0x11f089=document['getElementById']('user-count');if(!_0x54aa6f)return;_0x11f089&&(_0x11f089['textContent']=state['users']['length']+'\x20user'+(state['users']['length']===0x1?'':'s'));const _0x27dfb2=[...state['users']]['sort']((_0x5eeb30,_0x12c758)=>{const _0x8d028f=new Date(_0x5eeb30['created_at'])['getTime'](),_0x3ad3d5=new Date(_0x12c758['created_at'])['getTime']();return _0x3ad3d5-_0x8d028f;});_0x54aa6f['innerHTML']=_0x27dfb2['map'](_0x3881ce=>'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22user-username\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+Utils['escapeHtml'](_0x3881ce['username'])+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x3881ce['name'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x3881ce['email'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22access-badges\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x3881ce['isServerAdmin']?'<span\x20class=\x22role-badge\x20role-admin\x22>Server\x20Admin</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x3881ce['hasUserBinding']?'<span\x20class=\x22role-badge\x20role-user-binding\x22>User\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x3881ce['hasTeamBinding']?'<span\x20class=\x22role-badge\x20role-team-binding\x22>Team\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['formatRelativeTime'](_0x3881ce['created_at'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22user-actions\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-icon\x20btn-small\x22\x20onclick=\x22window.editUser(\x27'+_0x3881ce['id']+'\x27)\x22\x20title=\x22Edit\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2214\x22\x20height=\x2214\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M11\x204H4a2\x202\x200\x200\x200-2\x202v14a2\x202\x200\x200\x200\x202\x202h14a2\x202\x200\x200\x200\x202-2v-7\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M18.5\x202.5a2.121\x202.121\x200\x200\x201\x203\x203L12\x2015l-4\x201\x201-4\x209.5-9.5z\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-icon\x20btn-small\x22\x20onclick=\x22window.showAccessBindings(\x27'+_0x3881ce['id']+'\x27)\x22\x20title=\x22Access\x20Bindings\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2214\x22\x20height=\x2214\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M12\x2022s8-4\x208-10V5l-8-3-8\x203v7c0\x206\x208\x2010\x208\x2010z\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-icon\x20btn-small\x20btn-danger\x22\x20onclick=\x22window.deleteUser(\x27'+_0x3881ce['id']+'\x27)\x22\x20title=\x22Delete\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2214\x22\x20height=\x2214\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<polyline\x20points=\x223\x206\x205\x206\x2021\x206\x22></polyline>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M19\x206v14a2\x202\x200\x200\x201-2\x202H7a2\x202\x200\x200\x201-2-2V6m3\x200V4a2\x202\x200\x200\x201\x202-2h4a2\x202\x200\x200\x201\x202\x202v2\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-secondary\x20btn-small\x22\x20onclick=\x22window.resetPassword(\x27'+_0x3881ce['id']+'\x27)\x22>Reset\x20Password</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20</tr>\x0a\x20\x20')['join']('');}window['showAccessBindings']=function(_0x21e62a){const _0x28ba57=state['users']['find'](_0x57d734=>_0x57d734['id']===_0x21e62a);if(!_0x28ba57)return;state['bindingsUserId']=_0x21e62a,state['bindingsDirty']=![];const _0x3e9aa7=document['getElementById']('bindings-modal'),_0x12f9b0=document['getElementById']('bindings-modal-title');_0x12f9b0['textContent']='Access\x20Bindings\x20—\x20'+_0x28ba57['name'],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],_0x3e9aa7['hidden']=![],loadUserBindings(_0x21e62a);};function hasUnsavedBindingChanges(){const _0x31e849=document['getElementById']('add-user-binding-form');return _0x31e849&&!_0x31e849['hidden'];}async function hideAccessBindingsModal(){if(hasUnsavedBindingChanges()){if(!confirm('You\x20have\x20an\x20unsaved\x20binding.\x20Discard\x20changes?'))return;document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![];}const _0x7ccc00=document['getElementById']('bindings-modal');_0x7ccc00['hidden']=!![];const _0x2ea47=state['bindingsDirty'];state['bindingsUserId']=null,state['userBindings']=[],state['bindingsDirty']=![],_0x2ea47&&await loadUsers();}async function loadUserBindings(_0x51dbe4){const _0x9119fc=document['getElementById']('user-bindings-loading'),_0x3d332d=document['getElementById']('user-bindings-empty'),_0x268e3c=document['getElementById']('user-bindings-list-container'),_0x5ab7fc=document['getElementById']('add-user-binding-btn'),_0x46d580=document['getElementById']('user-team-bindings-note'),_0x32a131=document['getElementById']('user-team-bindings-text');_0x9119fc['hidden']=![],_0x3d332d['hidden']=!![],_0x268e3c['style']['display']='none',_0x5ab7fc['hidden']=!![],_0x46d580['hidden']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![];try{const [_0x403084,_0x189af9]=await Promise['all']([API['getBindings']({'subject_type':'user','subject_id':_0x51dbe4}),API['getTeams']()]);state['userBindings']=_0x403084['bindings']||[];const _0x7751cd=(_0x189af9['teams']||[])['filter'](_0x2a15f6=>(_0x2a15f6['members']||[])['includes'](_0x51dbe4)),_0x48d367=[];if(_0x7751cd['length']>0x0){const _0x2d9b9f=await Promise['all'](_0x7751cd['map'](_0x5da131=>API['getBindings']({'subject_type':'team','subject_id':_0x5da131['id']})));for(let _0x15f4e4=0x0;_0x15f4e4<_0x7751cd['length'];_0x15f4e4++){const _0x335c2b=_0x2d9b9f[_0x15f4e4]['bindings']||[];_0x335c2b['length']>0x0&&_0x48d367['push'](_0x7751cd[_0x15f4e4]);}}_0x9119fc['hidden']=!![];state['userBindings']['length']===0x0?_0x3d332d['hidden']=![]:(_0x268e3c['style']['display']='',renderUserBindingsTable());if(_0x48d367['length']>0x0){const _0xa7cedd=_0x48d367['map'](_0x323bcc=>_0x323bcc['name']),_0x251aa5=_0xa7cedd['length']<=0x3?_0xa7cedd['join'](',\x20'):_0xa7cedd['slice'](0x0,0x3)['join'](',\x20')+(',\x20and\x20'+(_0xa7cedd['length']-0x3)+'\x20more');_0x32a131['textContent']='This\x20user\x20also\x20has\x20access\x20via\x20team\x20memberships\x20('+_0x251aa5+').';}else _0x32a131['textContent']='This\x20user\x20has\x20no\x20access\x20via\x20team\x20memberships.';_0x46d580['hidden']=![],_0x5ab7fc['hidden']=![];}catch(_0x2b08e9){_0x9119fc['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x2b08e9['message'],'error');}}function renderUserBindingsTable(){const _0x5b48c8=document['getElementById']('user-bindings-table-body');if(!_0x5b48c8)return;_0x5b48c8['innerHTML']=state['userBindings']['map'](_0x35cb4e=>{const _0x2a565b=_0x35cb4e['resource_type']==='server'?'Server':_0x35cb4e['resource_id']==='*'?'All\x20'+_0x35cb4e['resource_type']+'s':Utils['escapeHtml'](_0x35cb4e['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x2a565b+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x35cb4e['role_name']||_0x35cb4e['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteUserBindingClick(\x27'+_0x35cb4e['id']+'\x27)\x22\x20style=\x22color:\x20var(--color-danger);\x22>Remove</button>\x0a\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20</tr>';})['join']('');}function populateUserBindingForm(){const _0x2c02dc=document['getElementById']('user-binding-resource-type');_0x2c02dc['value']='environment',updateUserBindingFormForResourceType('environment');}function onUserBindingResourceTypeChange(){const _0x178aee=document['getElementById']('user-binding-resource-type')['value'];updateUserBindingFormForResourceType(_0x178aee);}function updateUserBindingFormForResourceType(_0x9f8e9f){const _0x4f03e3=document['getElementById']('user-binding-resource-container'),_0x5ce406=document['getElementById']('user-binding-resource'),_0x4c8104=document['getElementById']('user-binding-role');if(_0x9f8e9f==='server')_0x4f03e3['style']['display']='none';else{_0x4f03e3['style']['display']='';if(_0x9f8e9f==='environment'){const _0x1f0552=new Set(state['userBindings']['filter'](_0x41b283=>_0x41b283['resource_type']==='environment')['map'](_0x58dd0c=>_0x58dd0c['resource_id'])),_0x143a9a=state['environments']['filter'](_0xc1cfe4=>!_0x1f0552['has'](_0xc1cfe4['name']));_0x5ce406['innerHTML']=_0x143a9a['length']?_0x143a9a['map'](_0x3e98a7=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x3e98a7['name'])+'\x22>'+Utils['escapeHtml'](_0x3e98a7['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x9f8e9f==='team'){const _0x1c9c5e=new Set(state['userBindings']['filter'](_0x122953=>_0x122953['resource_type']==='team')['map'](_0x1ac330=>_0x1ac330['resource_id'])),_0x498d44=state['teams']['filter'](_0x4e315c=>!_0x1c9c5e['has'](_0x4e315c['id']));_0x5ce406['innerHTML']=_0x498d44['length']?_0x498d44['map'](_0x5eb788=>'<option\x20value=\x22'+_0x5eb788['id']+'\x22>'+Utils['escapeHtml'](_0x5eb788['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0x452991=state['roles']['filter'](_0x1adf24=>_0x1adf24['resource_type']===_0x9f8e9f);_0x4c8104['innerHTML']=_0x452991['length']?_0x452991['filter'](_0x3a09d7=>{const _0x16e7f0=_0x9f8e9f==='server'?undefined:_0x5ce406['value'];return!state['userBindings']['some'](_0x524c3d=>_0x524c3d['resource_type']===_0x9f8e9f&&_0x524c3d['role_id']===_0x3a09d7['id']&&(_0x9f8e9f==='server'||_0x524c3d['resource_id']===_0x16e7f0));})['map'](_0x234e5e=>'<option\x20value=\x22'+_0x234e5e['id']+'\x22>'+Utils['escapeHtml'](_0x234e5e['name'])+'</option>')['join']('')||'<option\x20value=\x22\x22>No\x20available\x20roles</option>':'<option\x20value=\x22\x22>No\x20roles\x20for\x20this\x20resource\x20type</option>';}async function saveUserBinding(){const _0x189a06=document['getElementById']('user-binding-resource-type')['value'],_0x52a90d=document['getElementById']('user-binding-role')['value'];if(!_0x52a90d||!state['bindingsUserId'])return;const _0x1a1406=_0x189a06==='server'?undefined:document['getElementById']('user-binding-resource')['value'];if(_0x189a06!=='server'&&!_0x1a1406)return;const _0x4ec109=document['getElementById']('save-user-binding-btn');_0x4ec109['disabled']=!![],_0x4ec109['textContent']='Adding…';try{const _0x26b301={'subject_type':'user','subject_id':state['bindingsUserId'],'role_id':_0x52a90d,'resource_type':_0x189a06};if(_0x1a1406)_0x26b301['resource_id']=_0x1a1406;await API['createBinding'](_0x26b301),Utils['showToast']('Binding\x20added','success'),state['bindingsDirty']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],await loadUserBindings(state['bindingsUserId']);}catch(_0x3a3017){Utils['showToast'](_0x3a3017['message'],'error');}finally{_0x4ec109['disabled']=![],_0x4ec109['textContent']='Add\x20Binding';}}window['deleteUserBindingClick']=async function(_0x591a0d){try{await API['deleteBinding'](_0x591a0d),Utils['showToast']('Binding\x20removed','success'),state['bindingsDirty']=!![],await loadUserBindings(state['bindingsUserId']);}catch(_0x5d293b){Utils['showToast'](_0x5d293b['message'],'error');}};function showCreateUserModal(){state['editingUserId']=null;const _0x3ed8d9=document['getElementById']('user-modal'),_0x885f10=document['getElementById']('modal-title'),_0x48fd5a=document['getElementById']('user-password'),_0x3f8eb1=document['getElementById']('password-required'),_0x42f79f=document['getElementById']('password-hint'),_0x403e3c=document['getElementById']('skip-password-container'),_0xad9724=document['getElementById']('skip-password');_0x885f10['textContent']='Create\x20User',document['getElementById']('user-form')['reset'](),_0x48fd5a['required']=!![];if(_0x3f8eb1)_0x3f8eb1['textContent']='*';_0x403e3c&&(_0x403e3c['style']['display']='block',_0xad9724['checked']=![]),_0x42f79f&&(_0x42f79f['textContent']='Minimum\x208\x20characters'),_0x3ed8d9['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);}window['editUser']=function(_0x365166){const _0x362c1f=state['users']['find'](_0x277341=>_0x277341['id']===_0x365166);if(!_0x362c1f)return;state['editingUserId']=_0x365166;const _0x2ce4e9=document['getElementById']('user-modal'),_0x122295=document['getElementById']('modal-title'),_0x242fde=document['getElementById']('user-password'),_0x3aa22f=document['getElementById']('password-required'),_0x331241=document['getElementById']('password-hint'),_0x3bb1cf=document['getElementById']('skip-password-container');_0x122295['textContent']='Edit\x20User',document['getElementById']('user-username')['value']=_0x362c1f['username'],document['getElementById']('user-name')['value']=_0x362c1f['name'],document['getElementById']('user-email')['value']=_0x362c1f['email'],_0x242fde['value']='',_0x242fde['required']=![];if(_0x3aa22f)_0x3aa22f['textContent']='';_0x3bb1cf&&(_0x3bb1cf['style']['display']='none'),_0x331241&&(_0x331241['textContent']='Leave\x20blank\x20to\x20keep\x20current\x20password'),_0x2ce4e9['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);};function hideUserModal(){const _0x3153ee=document['getElementById']('user-modal'),_0x4b38d2=document['getElementById']('form-error'),_0x55fd26=document['getElementById']('save-user');_0x3153ee['hidden']=!![],_0x4b38d2['hidden']=!![],state['editingUserId']=null,_0x55fd26&&(_0x55fd26['disabled']=![],_0x55fd26['textContent']='Save\x20User');}async function saveUser(){const _0x501a35=document['getElementById']('user-form'),_0x8f0753=document['getElementById']('skip-password')?.['checked']||![];if(!_0x8f0753&&!_0x501a35['checkValidity']()){_0x501a35['reportValidity']();return;}const _0x20b735=document['getElementById']('form-error'),_0x382c80=document['getElementById']('save-user'),_0x51a8b1=document['getElementById']('user-username')['value']['trim'](),_0x345a7b=document['getElementById']('user-name')['value']['trim'](),_0x36a610=document['getElementById']('user-email')['value']['trim'](),_0x45e553=document['getElementById']('user-password')['value'];if(!_0x51a8b1||!_0x345a7b||!_0x36a610){_0x20b735['textContent']='Please\x20fill\x20in\x20all\x20required\x20fields',_0x20b735['hidden']=![],_0x20b735['scrollIntoView']({'behavior':'smooth','block':'nearest'});return;}_0x20b735['hidden']=!![];const _0x28e6dd=_0x382c80['textContent'];_0x382c80['disabled']=!![],_0x382c80['textContent']=state['editingUserId']?'Updating...':'Creating...';try{if(state['editingUserId']){const _0x573efd={'username':_0x51a8b1,'name':_0x345a7b,'email':_0x36a610};_0x45e553&&(_0x573efd['password']=_0x45e553),await API['updateUser'](state['editingUserId'],_0x573efd),Utils['showToast']('User\x20updated\x20successfully','success'),await loadUsers(),hideUserModal();}else{const _0x3b9a57={'username':_0x51a8b1,'name':_0x345a7b,'email':_0x36a610};if(!_0x8f0753){if(!_0x45e553)throw new Error('Password\x20is\x20required\x20for\x20new\x20users');_0x3b9a57['password']=_0x45e553;}const _0x5a98bd=await API['createUser'](_0x3b9a57),_0x10a220=_0x5a98bd['user'];if(_0x8f0753||!_0x45e553){const _0x4afb88=await API['createPasswordToken'](_0x10a220['id'],'setup',![]);state['setupLinkData']={'username':_0x10a220['username'],'email':_0x10a220['email'],'url':_0x4afb88['token']['setupUrl'],'userId':_0x10a220['id'],'type':'setup','emailSent':![]},await loadUsers(),hideUserModal(),showSetupLinkModal();}else Utils['showToast']('User\x20created\x20successfully','success'),await loadUsers(),hideUserModal();}}catch(_0x28934e){console['error']('Failed\x20to\x20save\x20user',_0x28934e),_0x20b735['textContent']=_0x28934e['message'],_0x20b735['hidden']=![],_0x20b735['scrollIntoView']({'behavior':'smooth','block':'nearest'}),_0x382c80['disabled']=![],_0x382c80['textContent']=_0x28e6dd;}}window['deleteUser']=function(_0x17f48a){const _0x417284=state['users']['find'](_0x4f4629=>_0x4f4629['id']===_0x17f48a);if(!_0x417284)return;state['deletingUserId']=_0x17f48a;const _0x38aed9=document['getElementById']('delete-modal'),_0x420860=document['getElementById']('delete-user-name');_0x420860['textContent']=_0x417284['name']+'\x20('+_0x417284['username']+')',_0x38aed9['hidden']=![];};function hideDeleteModal(){const _0x57577e=document['getElementById']('delete-modal');_0x57577e['hidden']=!![],state['deletingUserId']=null;const _0x24f57d=document['getElementById']('confirm-delete');_0x24f57d&&(_0x24f57d['disabled']=![],_0x24f57d['textContent']='Delete\x20User');}async function confirmDeleteUser(){if(!state['deletingUserId'])return;const _0x12c1d1=document['getElementById']('confirm-delete'),_0x3bde91=_0x12c1d1['textContent'];_0x12c1d1['disabled']=!![],_0x12c1d1['textContent']='Deleting...';try{await API['deleteUser'](state['deletingUserId']),Utils['showToast']('User\x20deleted\x20successfully','success'),await loadUsers(),hideDeleteModal();}catch(_0x26ed26){console['error']('Failed\x20to\x20delete\x20user',_0x26ed26),Utils['showToast']('Failed\x20to\x20delete\x20user:\x20'+_0x26ed26['message'],'error'),_0x12c1d1['disabled']=![],_0x12c1d1['textContent']=_0x3bde91;}}function handleSkipPasswordChange(_0xbfe1c5){const _0x127232=document['getElementById']('user-password'),_0x547d8a=_0xbfe1c5['target']['checked'];_0x547d8a?(_0x127232['required']=![],_0x127232['disabled']=!![],_0x127232['value']=''):(_0x127232['required']=!![],_0x127232['disabled']=![]);}function showSetupLinkModal(){if(!state['setupLinkData'])return;const _0x158992=document['getElementById']('setup-link-modal'),_0x1b285a=document['getElementById']('setup-link-username'),_0x347778=document['getElementById']('setup-link-url'),_0x3756bf=document['getElementById']('email-setup-link'),_0x5949c6=document['getElementById']('email-button-text');_0x1b285a['textContent']=state['setupLinkData']['username'],_0x347778['textContent']=state['setupLinkData']['url'],_0x3756bf&&_0x5949c6&&(_0x3756bf['disabled']=![],_0x5949c6['textContent']='Email\x20Link',state['emailConfigured']&&!state['setupLinkData']['emailSent']?_0x3756bf['style']['display']='inline-block':_0x3756bf['style']['display']='none'),_0x158992['hidden']=![];}function hideSetupLinkModal(){const _0x588d9a=document['getElementById']('setup-link-modal');_0x588d9a['hidden']=!![],state['setupLinkData']=null;}async function copySetupLink(){if(!state['setupLinkData'])return;try{await navigator['clipboard']['writeText'](state['setupLinkData']['url']),Utils['showToast']('Link\x20copied\x20to\x20clipboard','success');}catch(_0x316a4a){console['error']('Failed\x20to\x20copy\x20link',_0x316a4a),Utils['showToast']('Failed\x20to\x20copy\x20link','error');}}async function emailSetupLink(){if(!state['setupLinkData'])return;const _0x45d5ea=document['getElementById']('email-setup-link'),_0xcbb2d2=document['getElementById']('email-button-text');if(!_0x45d5ea||!_0xcbb2d2)return;const _0x34829f=_0xcbb2d2['textContent'];_0x45d5ea['disabled']=!![],_0xcbb2d2['textContent']='Sending...';try{const _0x1cd071=await API['createPasswordToken'](state['setupLinkData']['userId'],state['setupLinkData']['type'],!![]);if(_0x1cd071['emailSent'])Utils['showToast']('Email\x20sent\x20to\x20'+state['setupLinkData']['email'],'success'),state['setupLinkData']['emailSent']=!![],_0x45d5ea['style']['display']='none';else{const _0x2ced63=_0x1cd071['emailError']||'Failed\x20to\x20send\x20email';Utils['showToast'](_0x2ced63,'error'),_0x45d5ea['disabled']=![],_0xcbb2d2['textContent']=_0x34829f;}}catch(_0x465ba9){console['error']('Failed\x20to\x20email\x20setup\x20link',_0x465ba9),Utils['showToast']('Failed\x20to\x20send\x20email:\x20'+_0x465ba9['message'],'error'),_0x45d5ea['disabled']=![],_0xcbb2d2['textContent']=_0x34829f;}}window['resetPassword']=async function(_0x283030){const _0x578e12=state['users']['find'](_0x4c236=>_0x4c236['id']===_0x283030);if(!_0x578e12)return;const _0x336037=await ConfirmDialog['show']({'title':'Reset\x20Password','message':'Generate\x20a\x20password\x20reset\x20link\x20for\x20'+_0x578e12['name']+'\x20('+_0x578e12['username']+')?\x20This\x20will\x20create\x20a\x20link\x20that\x20they\x20can\x20use\x20to\x20set\x20a\x20new\x20password.','confirmText':'Generate\x20Link'});if(!_0x336037)return;try{const _0x39f962=await API['createPasswordToken'](_0x283030,'reset',![]);state['setupLinkData']={'username':_0x578e12['username'],'email':_0x578e12['email'],'url':_0x39f962['token']['setupUrl'],'userId':_0x578e12['id'],'type':'reset','emailSent':![]},showSetupLinkModal();}catch(_0x3edb85){console['error']('Failed\x20to\x20create\x20password\x20reset\x20link',_0x3edb85),Utils['showToast']('Failed\x20to\x20create\x20password\x20reset\x20link:\x20'+_0x3edb85['message'],'error');}};
1
+ import{API,Utils,ConfirmDialog,initializeAdminMenu}from'./app.js';import{initTheme,mountThemeToggle}from'./theme.js';const state={'users':[],'editingUserId':null,'bindingsUserId':null,'deletingUserId':null,'setupLinkData':null,'emailConfigured':![],'currentUser':null,'roles':[],'environments':[],'teams':[],'userBindings':[],'bindingsDirty':![]};document['addEventListener']('DOMContentLoaded',async()=>{initTheme(),mountThemeToggle(),await checkAdminAccess(),await initializeAdminMenu(state['currentUser']),await Promise['all']([checkEmailConfig(),loadRoles(),loadEnvironments(),loadTeams()]),bindEventListeners(),await loadUsers();});async function checkAdminAccess(){try{const _0x3a0cb6=await API['getCurrentUser']();state['currentUser']=_0x3a0cb6;if(!Permissions['hasServerPermission'](_0x3a0cb6,'*')&&!Permissions['hasServerPermission'](_0x3a0cb6,'users:create')){Utils['showToast']('Access\x20denied:\x20Server\x20admin\x20privileges\x20required','error'),setTimeout(()=>{window['location']['href']='index.html';},0x7d0);return;}}catch(_0x14a359){window['location']['href']='login.html';}}async function checkEmailConfig(){try{const _0x338897=await API['getEmailConfig']();state['emailConfigured']=_0x338897['configured'];}catch(_0x52ecac){console['error']('Failed\x20to\x20check\x20email\x20config',_0x52ecac),state['emailConfigured']=![];}}async function loadRoles(){try{const {roles:_0x174593}=await API['getRoleDefinitions']();state['roles']=_0x174593||[];}catch{state['roles']=[];}}async function loadEnvironments(){try{const _0x39944c=await API['getEnvironments']();state['environments']=_0x39944c['environments']||[];}catch{state['environments']=[];}}async function loadTeams(){try{const {teams:_0x3e71bf}=await API['getTeams']();state['teams']=_0x3e71bf||[];}catch{state['teams']=[];}}function bindEventListeners(){document['getElementById']('create-user-btn')?.['addEventListener']('click',showCreateUserModal),document['getElementById']('close-user-modal')?.['addEventListener']('click',hideUserModal),document['getElementById']('cancel-user')?.['addEventListener']('click',hideUserModal),document['getElementById']('save-user')?.['addEventListener']('click',saveUser),document['querySelector']('#user-modal\x20.modal-overlay')?.['addEventListener']('click',hideUserModal),document['getElementById']('close-delete-modal')?.['addEventListener']('click',hideDeleteModal),document['getElementById']('cancel-delete')?.['addEventListener']('click',hideDeleteModal),document['getElementById']('confirm-delete')?.['addEventListener']('click',confirmDeleteUser),document['querySelector']('#delete-modal\x20.modal-overlay')?.['addEventListener']('click',hideDeleteModal),document['getElementById']('close-setup-link-modal')?.['addEventListener']('click',hideSetupLinkModal),document['getElementById']('close-setup-link')?.['addEventListener']('click',hideSetupLinkModal),document['getElementById']('copy-setup-link')?.['addEventListener']('click',copySetupLink),document['getElementById']('email-setup-link')?.['addEventListener']('click',emailSetupLink),document['querySelector']('#setup-link-modal\x20.modal-overlay')?.['addEventListener']('click',hideSetupLinkModal),document['getElementById']('skip-password')?.['addEventListener']('change',handleSkipPasswordChange),document['getElementById']('retry-users-btn')?.['addEventListener']('click',loadUsers),document['getElementById']('close-bindings-modal')?.['addEventListener']('click',hideAccessBindingsModal),document['getElementById']('close-bindings-modal-footer')?.['addEventListener']('click',hideAccessBindingsModal),document['querySelector']('#bindings-modal\x20.modal-overlay')?.['addEventListener']('click',hideAccessBindingsModal),document['getElementById']('add-user-binding-btn')?.['addEventListener']('click',()=>{document['getElementById']('add-user-binding-form')['hidden']=![],document['getElementById']('add-user-binding-btn')['hidden']=!![],populateUserBindingForm();}),document['getElementById']('cancel-user-binding-btn')?.['addEventListener']('click',()=>{document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![];}),document['getElementById']('save-user-binding-btn')?.['addEventListener']('click',saveUserBinding),document['getElementById']('user-binding-resource-type')?.['addEventListener']('change',onUserBindingResourceTypeChange);}async function loadUsers(){const _0x325040=document['getElementById']('users-loading'),_0x3780da=document['getElementById']('users-error'),_0x40a9b7=document['getElementById']('users-content');try{_0x325040['hidden']=![],_0x3780da['hidden']=!![],_0x40a9b7['hidden']=!![];const _0x4baac9=await API['getUsers']();state['users']=_0x4baac9['users']||[],renderUsers(),_0x325040['hidden']=!![],_0x40a9b7['hidden']=![];}catch(_0x1312f9){console['error']('Failed\x20to\x20load\x20users',_0x1312f9),_0x325040['hidden']=!![],_0x3780da['hidden']=![],document['getElementById']('users-error-message')['textContent']=_0x1312f9['message'];}}function renderUsers(){const _0x35d6f4=document['getElementById']('users-table-body'),_0x2df1c5=document['getElementById']('user-count');if(!_0x35d6f4)return;_0x2df1c5&&(_0x2df1c5['textContent']=state['users']['length']+'\x20user'+(state['users']['length']===0x1?'':'s'));const _0x2ca78e=[...state['users']]['sort']((_0x40efec,_0x106ab0)=>{const _0x359eea=new Date(_0x40efec['created_at'])['getTime'](),_0x40df90=new Date(_0x106ab0['created_at'])['getTime']();return _0x40df90-_0x359eea;});_0x35d6f4['innerHTML']=_0x2ca78e['map'](_0x1bdae8=>'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22user-username\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+Utils['escapeHtml'](_0x1bdae8['username'])+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x1bdae8['name'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0x1bdae8['email'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22access-badges\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x1bdae8['isServerAdmin']?'<span\x20class=\x22role-badge\x20role-admin\x22>Server\x20Admin</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x1bdae8['hasUserBinding']?'<span\x20class=\x22role-badge\x20role-user-binding\x22>User\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x1bdae8['hasTeamBinding']?'<span\x20class=\x22role-badge\x20role-team-binding\x22>Team\x20Binding</span>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['formatRelativeTime'](_0x1bdae8['created_at'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22user-actions\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-icon\x20btn-small\x22\x20onclick=\x22window.editUser(\x27'+_0x1bdae8['id']+'\x27)\x22\x20title=\x22Edit\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2214\x22\x20height=\x2214\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M11\x204H4a2\x202\x200\x200\x200-2\x202v14a2\x202\x200\x200\x200\x202\x202h14a2\x202\x200\x200\x200\x202-2v-7\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M18.5\x202.5a2.121\x202.121\x200\x200\x201\x203\x203L12\x2015l-4\x201\x201-4\x209.5-9.5z\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-icon\x20btn-small\x22\x20onclick=\x22window.showAccessBindings(\x27'+_0x1bdae8['id']+'\x27)\x22\x20title=\x22Access\x20Bindings\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2214\x22\x20height=\x2214\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M12\x2022s8-4\x208-10V5l-8-3-8\x203v7c0\x206\x208\x2010\x208\x2010z\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-icon\x20btn-small\x20btn-danger\x22\x20onclick=\x22window.deleteUser(\x27'+_0x1bdae8['id']+'\x27)\x22\x20title=\x22Delete\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20width=\x2214\x22\x20height=\x2214\x22\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<polyline\x20points=\x223\x206\x205\x206\x2021\x206\x22></polyline>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M19\x206v14a2\x202\x200\x200\x201-2\x202H7a2\x202\x200\x200\x201-2-2V6m3\x200V4a2\x202\x200\x200\x201\x202-2h4a2\x202\x200\x200\x201\x202\x202v2\x22></path>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-secondary\x20btn-small\x22\x20onclick=\x22window.resetPassword(\x27'+_0x1bdae8['id']+'\x27)\x22>Reset\x20Password</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20</tr>\x0a\x20\x20')['join']('');}window['showAccessBindings']=function(_0x55f3f4){const _0xb762a=state['users']['find'](_0x2acf15=>_0x2acf15['id']===_0x55f3f4);if(!_0xb762a)return;state['bindingsUserId']=_0x55f3f4,state['bindingsDirty']=![];const _0x226089=document['getElementById']('bindings-modal'),_0x9c0550=document['getElementById']('bindings-modal-title');_0x9c0550['textContent']='Access\x20Bindings\x20—\x20'+_0xb762a['name'],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],_0x226089['hidden']=![],loadUserBindings(_0x55f3f4);};function hasUnsavedBindingChanges(){const _0x47ecfd=document['getElementById']('add-user-binding-form');return _0x47ecfd&&!_0x47ecfd['hidden'];}async function hideAccessBindingsModal(){if(hasUnsavedBindingChanges()){if(!confirm('You\x20have\x20an\x20unsaved\x20binding.\x20Discard\x20changes?'))return;document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![];}const _0x333470=document['getElementById']('bindings-modal');_0x333470['hidden']=!![];const _0x3366b7=state['bindingsDirty'];state['bindingsUserId']=null,state['userBindings']=[],state['bindingsDirty']=![],_0x3366b7&&await loadUsers();}async function loadUserBindings(_0x5c94ef){const _0x57a605=document['getElementById']('user-bindings-loading'),_0x16fdc8=document['getElementById']('user-bindings-empty'),_0x51b5eb=document['getElementById']('user-bindings-list-container'),_0x4af213=document['getElementById']('add-user-binding-btn'),_0x4f173d=document['getElementById']('user-team-bindings-note'),_0x3bfdc1=document['getElementById']('user-team-bindings-text');_0x57a605['hidden']=![],_0x16fdc8['hidden']=!![],_0x51b5eb['style']['display']='none',_0x4af213['hidden']=!![],_0x4f173d['hidden']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![];try{const [_0x1c5d1e,_0x1ab348]=await Promise['all']([API['getBindings']({'subject_type':'user','subject_id':_0x5c94ef}),API['getTeams']()]);state['userBindings']=_0x1c5d1e['bindings']||[];const _0xcfec73=(_0x1ab348['teams']||[])['filter'](_0x2e7ead=>(_0x2e7ead['members']||[])['includes'](_0x5c94ef)),_0x2dc969=[];if(_0xcfec73['length']>0x0){const _0x16f926=await Promise['all'](_0xcfec73['map'](_0x1d6827=>API['getBindings']({'subject_type':'team','subject_id':_0x1d6827['id']})));for(let _0x3ec731=0x0;_0x3ec731<_0xcfec73['length'];_0x3ec731++){const _0x3d01ec=_0x16f926[_0x3ec731]['bindings']||[];_0x3d01ec['length']>0x0&&_0x2dc969['push'](_0xcfec73[_0x3ec731]);}}_0x57a605['hidden']=!![];state['userBindings']['length']===0x0?_0x16fdc8['hidden']=![]:(_0x51b5eb['style']['display']='',renderUserBindingsTable());if(_0x2dc969['length']>0x0){const _0x25a7e4=_0x2dc969['map'](_0x693d64=>_0x693d64['name']),_0x212a8d=_0x25a7e4['length']<=0x3?_0x25a7e4['join'](',\x20'):_0x25a7e4['slice'](0x0,0x3)['join'](',\x20')+(',\x20and\x20'+(_0x25a7e4['length']-0x3)+'\x20more');_0x3bfdc1['textContent']='This\x20user\x20also\x20has\x20access\x20via\x20team\x20memberships\x20('+_0x212a8d+').';}else _0x3bfdc1['textContent']='This\x20user\x20has\x20no\x20access\x20via\x20team\x20memberships.';_0x4f173d['hidden']=![],_0x4af213['hidden']=![];}catch(_0x4d220d){_0x57a605['hidden']=!![],Utils['showToast']('Failed\x20to\x20load\x20bindings:\x20'+_0x4d220d['message'],'error');}}function renderUserBindingsTable(){const _0x4236d1=document['getElementById']('user-bindings-table-body');if(!_0x4236d1)return;_0x4236d1['innerHTML']=state['userBindings']['map'](_0xa4ffee=>{const _0x257caf=_0xa4ffee['resource_type']==='server'?'Server':_0xa4ffee['resource_id']==='*'?'All\x20'+_0xa4ffee['resource_type']+'s':Utils['escapeHtml'](_0xa4ffee['resource_id']||'');return'\x0a\x20\x20\x20\x20<tr>\x0a\x20\x20\x20\x20\x20\x20<td>'+_0x257caf+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>'+Utils['escapeHtml'](_0xa4ffee['role_name']||_0xa4ffee['role_id'])+'</td>\x0a\x20\x20\x20\x20\x20\x20<td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteUserBindingClick(\x27'+_0xa4ffee['id']+'\x27)\x22\x20style=\x22color:\x20var(--color-danger);\x22>Remove</button>\x0a\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20</tr>';})['join']('');}function populateUserBindingForm(){const _0x525ae2=document['getElementById']('user-binding-resource-type');_0x525ae2['value']='environment',updateUserBindingFormForResourceType('environment');}function onUserBindingResourceTypeChange(){const _0x1904da=document['getElementById']('user-binding-resource-type')['value'];updateUserBindingFormForResourceType(_0x1904da);}function updateUserBindingFormForResourceType(_0x4a1322){const _0x5077be=document['getElementById']('user-binding-resource-container'),_0x5e351c=document['getElementById']('user-binding-resource'),_0x44d297=document['getElementById']('user-binding-role');if(_0x4a1322==='server')_0x5077be['style']['display']='none';else{_0x5077be['style']['display']='';if(_0x4a1322==='environment'){const _0x352c2f=new Set(state['userBindings']['filter'](_0x104b5c=>_0x104b5c['resource_type']==='environment')['map'](_0x3eefe0=>_0x3eefe0['resource_id'])),_0x45dcd2=state['environments']['filter'](_0x473f69=>!_0x352c2f['has'](_0x473f69['name']));_0x5e351c['innerHTML']=_0x45dcd2['length']?_0x45dcd2['map'](_0x26dadb=>'<option\x20value=\x22'+Utils['escapeHtml'](_0x26dadb['name'])+'\x22>'+Utils['escapeHtml'](_0x26dadb['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20environments\x20already\x20bound</option>';}else{if(_0x4a1322==='team'){const _0x214960=new Set(state['userBindings']['filter'](_0x5cb262=>_0x5cb262['resource_type']==='team')['map'](_0x480f66=>_0x480f66['resource_id'])),_0x3d513f=state['teams']['filter'](_0x3bdfe0=>!_0x214960['has'](_0x3bdfe0['id']));_0x5e351c['innerHTML']=_0x3d513f['length']?_0x3d513f['map'](_0x32a042=>'<option\x20value=\x22'+_0x32a042['id']+'\x22>'+Utils['escapeHtml'](_0x32a042['name'])+'</option>')['join'](''):'<option\x20value=\x22\x22>All\x20teams\x20already\x20bound</option>';}}}const _0xe3dc53=state['roles']['filter'](_0x3f8f63=>_0x3f8f63['resource_type']===_0x4a1322);_0x44d297['innerHTML']=_0xe3dc53['length']?_0xe3dc53['filter'](_0x869572=>{const _0x48144a=_0x4a1322==='server'?undefined:_0x5e351c['value'];return!state['userBindings']['some'](_0x41cc21=>_0x41cc21['resource_type']===_0x4a1322&&_0x41cc21['role_id']===_0x869572['id']&&(_0x4a1322==='server'||_0x41cc21['resource_id']===_0x48144a));})['map'](_0x2f1c31=>'<option\x20value=\x22'+_0x2f1c31['id']+'\x22>'+Utils['escapeHtml'](_0x2f1c31['name'])+'</option>')['join']('')||'<option\x20value=\x22\x22>No\x20available\x20roles</option>':'<option\x20value=\x22\x22>No\x20roles\x20for\x20this\x20resource\x20type</option>';}async function saveUserBinding(){const _0x36481f=document['getElementById']('user-binding-resource-type')['value'],_0xd29104=document['getElementById']('user-binding-role')['value'];if(!_0xd29104||!state['bindingsUserId'])return;const _0x57a466=_0x36481f==='server'?undefined:document['getElementById']('user-binding-resource')['value'];if(_0x36481f!=='server'&&!_0x57a466)return;const _0x26cf48=document['getElementById']('save-user-binding-btn');_0x26cf48['disabled']=!![],_0x26cf48['textContent']='Adding…';try{const _0x10f4b7={'subject_type':'user','subject_id':state['bindingsUserId'],'role_id':_0xd29104,'resource_type':_0x36481f};if(_0x57a466)_0x10f4b7['resource_id']=_0x57a466;await API['createBinding'](_0x10f4b7),Utils['showToast']('Binding\x20added','success'),state['bindingsDirty']=!![],document['getElementById']('add-user-binding-form')['hidden']=!![],document['getElementById']('add-user-binding-btn')['hidden']=![],await loadUserBindings(state['bindingsUserId']);}catch(_0x362d7){Utils['showToast'](_0x362d7['message'],'error');}finally{_0x26cf48['disabled']=![],_0x26cf48['textContent']='Add\x20Binding';}}window['deleteUserBindingClick']=async function(_0x14ba72){try{await API['deleteBinding'](_0x14ba72),Utils['showToast']('Binding\x20removed','success'),state['bindingsDirty']=!![],await loadUserBindings(state['bindingsUserId']);}catch(_0x33c1b5){Utils['showToast'](_0x33c1b5['message'],'error');}};function showCreateUserModal(){state['editingUserId']=null;const _0x50a4d0=document['getElementById']('user-modal'),_0x9623c9=document['getElementById']('modal-title'),_0x205278=document['getElementById']('user-password'),_0xd05a9e=document['getElementById']('password-required'),_0x3becfe=document['getElementById']('password-hint'),_0x27f8fb=document['getElementById']('skip-password-container'),_0xec42f9=document['getElementById']('skip-password');_0x9623c9['textContent']='Create\x20User',document['getElementById']('user-form')['reset'](),_0x205278['required']=!![];if(_0xd05a9e)_0xd05a9e['textContent']='*';_0x27f8fb&&(_0x27f8fb['style']['display']='block',_0xec42f9['checked']=![]),_0x3becfe&&(_0x3becfe['textContent']='Minimum\x208\x20characters'),_0x50a4d0['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);}window['editUser']=function(_0x497649){const _0x361d09=state['users']['find'](_0x1eb537=>_0x1eb537['id']===_0x497649);if(!_0x361d09)return;state['editingUserId']=_0x497649;const _0xfe67ab=document['getElementById']('user-modal'),_0x27db56=document['getElementById']('modal-title'),_0x22c5ae=document['getElementById']('user-password'),_0x2eb92f=document['getElementById']('password-required'),_0x4e0672=document['getElementById']('password-hint'),_0x5a90f6=document['getElementById']('skip-password-container');_0x27db56['textContent']='Edit\x20User',document['getElementById']('user-username')['value']=_0x361d09['username'],document['getElementById']('user-name')['value']=_0x361d09['name'],document['getElementById']('user-email')['value']=_0x361d09['email'],_0x22c5ae['value']='',_0x22c5ae['required']=![];if(_0x2eb92f)_0x2eb92f['textContent']='';_0x5a90f6&&(_0x5a90f6['style']['display']='none'),_0x4e0672&&(_0x4e0672['textContent']='Leave\x20blank\x20to\x20keep\x20current\x20password'),_0xfe67ab['hidden']=![],setTimeout(()=>{document['getElementById']('user-username')['focus']();},0x64);};function hideUserModal(){const _0x17f0a0=document['getElementById']('user-modal'),_0x2c4867=document['getElementById']('form-error'),_0x2e2044=document['getElementById']('save-user');_0x17f0a0['hidden']=!![],_0x2c4867['hidden']=!![],state['editingUserId']=null,_0x2e2044&&(_0x2e2044['disabled']=![],_0x2e2044['textContent']='Save\x20User');}async function saveUser(){const _0x3335d7=document['getElementById']('user-form'),_0x5aa8dc=document['getElementById']('skip-password')?.['checked']||![];if(!_0x5aa8dc&&!_0x3335d7['checkValidity']()){_0x3335d7['reportValidity']();return;}const _0x225129=document['getElementById']('form-error'),_0x38125d=document['getElementById']('save-user'),_0x3ac18b=document['getElementById']('user-username')['value']['trim'](),_0x45d8f0=document['getElementById']('user-name')['value']['trim'](),_0x3e6480=document['getElementById']('user-email')['value']['trim'](),_0xa3c4fe=document['getElementById']('user-password')['value'];if(!_0x3ac18b||!_0x45d8f0||!_0x3e6480){_0x225129['textContent']='Please\x20fill\x20in\x20all\x20required\x20fields',_0x225129['hidden']=![],_0x225129['scrollIntoView']({'behavior':'smooth','block':'nearest'});return;}_0x225129['hidden']=!![];const _0x2d0d4d=_0x38125d['textContent'];_0x38125d['disabled']=!![],_0x38125d['textContent']=state['editingUserId']?'Updating...':'Creating...';try{if(state['editingUserId']){const _0x58dfd0={'username':_0x3ac18b,'name':_0x45d8f0,'email':_0x3e6480};_0xa3c4fe&&(_0x58dfd0['password']=_0xa3c4fe),await API['updateUser'](state['editingUserId'],_0x58dfd0),Utils['showToast']('User\x20updated\x20successfully','success'),await loadUsers(),hideUserModal();}else{const _0x17c1ad={'username':_0x3ac18b,'name':_0x45d8f0,'email':_0x3e6480};if(!_0x5aa8dc){if(!_0xa3c4fe)throw new Error('Password\x20is\x20required\x20for\x20new\x20users');_0x17c1ad['password']=_0xa3c4fe;}const _0x59a4cf=await API['createUser'](_0x17c1ad),_0x936b5f=_0x59a4cf['user'];if(_0x5aa8dc||!_0xa3c4fe){const _0x56da12=await API['createPasswordToken'](_0x936b5f['id'],'setup',![]);state['setupLinkData']={'username':_0x936b5f['username'],'email':_0x936b5f['email'],'url':_0x56da12['token']['setupUrl'],'userId':_0x936b5f['id'],'type':'setup','emailSent':![]},await loadUsers(),hideUserModal(),showSetupLinkModal();}else Utils['showToast']('User\x20created\x20successfully','success'),await loadUsers(),hideUserModal();}}catch(_0x5ade56){console['error']('Failed\x20to\x20save\x20user',_0x5ade56),_0x225129['textContent']=_0x5ade56['message'],_0x225129['hidden']=![],_0x225129['scrollIntoView']({'behavior':'smooth','block':'nearest'}),_0x38125d['disabled']=![],_0x38125d['textContent']=_0x2d0d4d;}}window['deleteUser']=function(_0x1e2184){const _0x31dd47=state['users']['find'](_0x259ebc=>_0x259ebc['id']===_0x1e2184);if(!_0x31dd47)return;state['deletingUserId']=_0x1e2184;const _0x3cffd9=document['getElementById']('delete-modal'),_0x51e033=document['getElementById']('delete-user-name');_0x51e033['textContent']=_0x31dd47['name']+'\x20('+_0x31dd47['username']+')',_0x3cffd9['hidden']=![];};function hideDeleteModal(){const _0x3dee5e=document['getElementById']('delete-modal');_0x3dee5e['hidden']=!![],state['deletingUserId']=null;const _0x4567a3=document['getElementById']('confirm-delete');_0x4567a3&&(_0x4567a3['disabled']=![],_0x4567a3['textContent']='Delete\x20User');}async function confirmDeleteUser(){if(!state['deletingUserId'])return;const _0x361241=document['getElementById']('confirm-delete'),_0xf7594c=_0x361241['textContent'];_0x361241['disabled']=!![],_0x361241['textContent']='Deleting...';try{await API['deleteUser'](state['deletingUserId']),Utils['showToast']('User\x20deleted\x20successfully','success'),await loadUsers(),hideDeleteModal();}catch(_0x579223){console['error']('Failed\x20to\x20delete\x20user',_0x579223),Utils['showToast']('Failed\x20to\x20delete\x20user:\x20'+_0x579223['message'],'error'),_0x361241['disabled']=![],_0x361241['textContent']=_0xf7594c;}}function handleSkipPasswordChange(_0x5b4d7c){const _0x2914c3=document['getElementById']('user-password'),_0x4d7fcf=_0x5b4d7c['target']['checked'];_0x4d7fcf?(_0x2914c3['required']=![],_0x2914c3['disabled']=!![],_0x2914c3['value']=''):(_0x2914c3['required']=!![],_0x2914c3['disabled']=![]);}function showSetupLinkModal(){if(!state['setupLinkData'])return;const _0x5d968a=document['getElementById']('setup-link-modal'),_0x294023=document['getElementById']('setup-link-username'),_0x190e88=document['getElementById']('setup-link-url'),_0x412909=document['getElementById']('email-setup-link'),_0x44fdc0=document['getElementById']('email-button-text');_0x294023['textContent']=state['setupLinkData']['username'],_0x190e88['textContent']=state['setupLinkData']['url'],_0x412909&&_0x44fdc0&&(_0x412909['disabled']=![],_0x44fdc0['textContent']='Email\x20Link',state['emailConfigured']&&!state['setupLinkData']['emailSent']?_0x412909['style']['display']='inline-block':_0x412909['style']['display']='none'),_0x5d968a['hidden']=![];}function hideSetupLinkModal(){const _0x304d26=document['getElementById']('setup-link-modal');_0x304d26['hidden']=!![],state['setupLinkData']=null;}async function copySetupLink(){if(!state['setupLinkData'])return;try{await navigator['clipboard']['writeText'](state['setupLinkData']['url']),Utils['showToast']('Link\x20copied\x20to\x20clipboard','success');}catch(_0x157c90){console['error']('Failed\x20to\x20copy\x20link',_0x157c90),Utils['showToast']('Failed\x20to\x20copy\x20link','error');}}async function emailSetupLink(){if(!state['setupLinkData'])return;const _0x1c853a=document['getElementById']('email-setup-link'),_0x385a1d=document['getElementById']('email-button-text');if(!_0x1c853a||!_0x385a1d)return;const _0x26045d=_0x385a1d['textContent'];_0x1c853a['disabled']=!![],_0x385a1d['textContent']='Sending...';try{const _0x11b5e3=await API['createPasswordToken'](state['setupLinkData']['userId'],state['setupLinkData']['type'],!![]);if(_0x11b5e3['emailSent'])Utils['showToast']('Email\x20sent\x20to\x20'+state['setupLinkData']['email'],'success'),state['setupLinkData']['emailSent']=!![],_0x1c853a['style']['display']='none';else{const _0x455b97=_0x11b5e3['emailError']||'Failed\x20to\x20send\x20email';Utils['showToast'](_0x455b97,'error'),_0x1c853a['disabled']=![],_0x385a1d['textContent']=_0x26045d;}}catch(_0x1604ed){console['error']('Failed\x20to\x20email\x20setup\x20link',_0x1604ed),Utils['showToast']('Failed\x20to\x20send\x20email:\x20'+_0x1604ed['message'],'error'),_0x1c853a['disabled']=![],_0x385a1d['textContent']=_0x26045d;}}window['resetPassword']=async function(_0x4e2396){const _0x173202=state['users']['find'](_0x403485=>_0x403485['id']===_0x4e2396);if(!_0x173202)return;const _0x3eee3a=await ConfirmDialog['show']({'title':'Reset\x20Password','message':'Generate\x20a\x20password\x20reset\x20link\x20for\x20'+_0x173202['name']+'\x20('+_0x173202['username']+')?\x20This\x20will\x20create\x20a\x20link\x20that\x20they\x20can\x20use\x20to\x20set\x20a\x20new\x20password.','confirmText':'Generate\x20Link'});if(!_0x3eee3a)return;try{const _0x208e61=await API['createPasswordToken'](_0x4e2396,'reset',![]);state['setupLinkData']={'username':_0x173202['username'],'email':_0x173202['email'],'url':_0x208e61['token']['setupUrl'],'userId':_0x173202['id'],'type':'reset','emailSent':![]},showSetupLinkModal();}catch(_0x4b080d){console['error']('Failed\x20to\x20create\x20password\x20reset\x20link',_0x4b080d),Utils['showToast']('Failed\x20to\x20create\x20password\x20reset\x20link:\x20'+_0x4b080d['message'],'error');}};
@@ -1 +1 @@
1
- import{API,Utils}from'./app.js';const dragState={'draggedTaskId':null,'draggedElement':null,'sourceGroupId':null,'isDragging':![]},AGENT_ICONS={'claude':'<svg\x20viewBox=\x220\x200\x2016\x2016\x22\x20fill=\x22currentColor\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20aria-hidden=\x22true\x22><path\x20d=\x22m3.127\x2010.604\x203.135-1.76.053-.153-.053-.085H6.11l-.525-.032-1.791-.048-1.554-.065-1.505-.08-.38-.081L0\x207.832l.036-.234.32-.214.455.04\x201.009.069\x201.513.105\x201.097.064\x201.626.17h.259l.036-.105-.089-.065-.068-.064-1.566-1.062-1.695-1.121-.887-.646-.48-.327-.243-.306-.104-.67.435-.48.585.04.15.04.593.456\x201.267.981\x201.654\x201.218.242.202.097-.068.012-.049-.109-.181-.9-1.626-.96-1.655-.428-.686-.113-.411a2\x202\x200\x200\x201-.068-.484l.496-.674L4.446\x200l.662.089.279.242.411.94.666\x201.48\x201.033\x202.014.302.597.162.553.06.17h.105v-.097l.085-1.134.157-1.392.154-1.792.052-.504.25-.605.497-.327.387.186.319.456-.045.294-.19\x201.23-.37\x201.93-.243\x201.29h.142l.161-.16.654-.868\x201.097-1.372.484-.545.565-.601.363-.287h.686l.505.751-.226.775-.707.895-.585.759-.839\x201.13-.524.904.048.072.125-.012\x201.897-.403\x201.024-.186\x201.223-.21.553.258.06.263-.218.536-1.307.323-1.533.307-2.284.54-.028.02.032.04\x201.029.098.44.024h1.077l2.005.15.525.346.315.424-.053.323-.807.411-3.631-.863-.872-.218h-.12v.073l.726.71\x201.331\x201.202\x201.667\x201.55.084.383-.214.302-.226-.032-1.464-1.101-.565-.497-1.28-1.077h-.084v.113l.295.432\x201.557\x202.34.08.718-.112.234-.404.141-.444-.08-.911-1.28-.94-1.44-.759-1.291-.093.053-.448\x204.821-.21.246-.484.186-.403-.307-.214-.496.214-.98.258-1.28.21-1.016.19-1.263.112-.42-.008-.028-.092.012-.953\x201.307-1.448\x201.957-1.146\x201.227-.274.109-.477-.247.045-.44.266-.39\x201.586-2.018.956-1.25.617-.723-.004-.105h-.036l-4.212\x204.212z\x22/></svg>','codex':'<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22currentColor\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20aria-hidden=\x22true\x22><path\x20d=\x22M22.2819\x209.8211a5.9847\x205.9847\x200\x200\x200-.5157-4.9108\x206.0462\x206.0462\x200\x200\x200-6.5098-2.9A6.0651\x206.0651\x200\x200\x200\x204.9807\x204.1818a5.9847\x205.9847\x200\x200\x200-3.9977\x202.9\x206.0462\x206.0462\x200\x200\x200\x20.7427\x207.0966\x205.98\x205.98\x200\x200\x200\x20.511\x204.9107\x206.051\x206.051\x200\x200\x200\x206.5146\x202.9001A5.9847\x205.9847\x200\x200\x200\x2013.2599\x2024a6.0557\x206.0557\x200\x200\x200\x205.7718-4.2058\x205.9894\x205.9894\x200\x200\x200\x203.9977-2.9001\x206.0557\x206.0557\x200\x200\x200-.7475-7.0729zm-9.022\x2012.6081a4.4755\x204.4755\x200\x200\x201-2.8764-1.0408l.1419-.0804\x204.7783-2.7582a.7948.7948\x200\x200\x200\x20.3927-.6813v-6.7369l2.02\x201.1686a.071.071\x200\x200\x201\x20.038.052v5.5826a4.504\x204.504\x200\x200\x201-4.4945\x204.4944zm-9.6607-4.1254a4.4708\x204.4708\x200\x200\x201-.5346-3.0137l.142.0852\x204.783\x202.7582a.7712.7712\x200\x200\x200\x20.7806\x200l5.8428-3.3685v2.3324a.0804.0804\x200\x200\x201-.0332.0615L9.74\x2019.9502a4.4992\x204.4992\x200\x200\x201-6.1408-1.6464zM2.3408\x207.8956a4.485\x204.485\x200\x200\x201\x202.3655-1.9728V11.6a.7664.7664\x200\x200\x200\x20.3879.6765l5.8144\x203.3543-2.0201\x201.1685a.0757.0757\x200\x200\x201-.071\x200l-4.8303-2.7865A4.504\x204.504\x200\x200\x201\x202.3408\x207.872zm16.5963\x203.8558L13.1038\x208.364\x2015.1192\x207.2a.0757.0757\x200\x200\x201\x20.071\x200l4.8303\x202.7913a4.4944\x204.4944\x200\x200\x201-.6765\x208.1042v-5.6772a.79.79\x200\x200\x200-.407-.667zm2.0107-3.0231l-.142-.0852-4.7735-2.7818a.7759.7759\x200\x200\x200-.7854\x200L9.409\x209.2297V6.8974a.0662.0662\x200\x200\x201\x20.0284-.0615l4.8303-2.7866a4.4992\x204.4992\x200\x200\x201\x206.6802\x204.66zM8.3065\x2012.863l-2.02-1.1638a.0804.0804\x200\x200\x201-.038-.0567V6.0742a4.4992\x204.4992\x200\x200\x201\x207.3757-3.4537l-.142.0805L8.704\x205.459a.7948.7948\x200\x200\x200-.3927.6813zm1.0976-2.3654l2.602-1.4998\x202.6069\x201.4998v2.9994l-2.5974\x201.4997-2.6067-1.4997Z\x22/></svg>','gemini':'<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20aria-hidden=\x22true\x22><path\x20d=\x22M12\x202L9.09\x209.09\x202\x2012l7.09\x202.91L12\x2022l2.91-7.09L22\x2012l-7.09-2.91z\x22></path></svg>','unknown':'<svg\x20viewBox=\x220\x200\x2020\x2020\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x221.6\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20aria-hidden=\x22true\x22><circle\x20cx=\x2210\x22\x20cy=\x2210\x22\x20r=\x228\x22\x20/><path\x20d=\x22M10\x206.5c-1.1\x200-2\x20.7-2\x201.6\x200\x20.9\x201\x201.3\x201.6\x201.7.7.4\x201\x20.8\x201\x201.5V12\x22\x20/><circle\x20cx=\x2210\x22\x20cy=\x2214\x22\x20r=\x220.8\x22\x20fill=\x22currentColor\x22\x20stroke=\x22none\x22\x20/></svg>'},STATUS_ICONS={'running':'<svg\x20class=\x22status-icon\x20spinning\x22\x20viewBox=\x220\x200\x2016\x2016\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222.5\x22\x20stroke-linecap=\x22round\x22><path\x20d=\x22M8\x202\x20A6\x206\x200\x200\x201\x2014\x208\x22/></svg>','completed':'<svg\x20class=\x22status-icon\x22\x20viewBox=\x220\x200\x2016\x2016\x22\x20fill=\x22currentColor\x22><path\x20d=\x22M8\x200a8\x208\x200\x201\x200\x200\x2016A8\x208\x200\x200\x200\x208\x200zm3.78\x206.28-4.5\x204.5a.75.75\x200\x200\x201-1.06\x200l-2-2a.75.75\x200\x201\x201\x201.06-1.06L6.75\x209.19l3.97-3.97a.75.75\x200\x201\x201\x201.06\x201.06z\x22/></svg>','failed':'<svg\x20class=\x22status-icon\x22\x20viewBox=\x220\x200\x2016\x2016\x22\x20fill=\x22currentColor\x22><path\x20d=\x22M8\x200a8\x208\x200\x201\x200\x200\x2016A8\x208\x200\x200\x200\x208\x200zm3.53\x2010.47a.75.75\x200\x201\x201-1.06\x201.06L8\x209.06l-2.47\x202.47a.75.75\x200\x200\x201-1.06-1.06L6.94\x208\x204.47\x205.53a.75.75\x200\x200\x201\x201.06-1.06L8\x206.94l2.47-2.47a.75.75\x200\x200\x201\x201.06\x201.06L9.06\x208l2.47\x202.47z\x22/></svg>','staged':'<svg\x20class=\x22status-icon\x22\x20viewBox=\x220\x200\x2016\x2016\x22\x20fill=\x22currentColor\x22><path\x20d=\x22M8\x200a8\x208\x200\x201\x200\x200\x2016A8\x208\x200\x200\x200\x208\x200zm0\x2012a.75.75\x200\x201\x201\x200-1.5.75.75\x200\x200\x201\x200\x201.5zm1-3.5a1\x201\x200\x200\x201-2\x200V5a1\x201\x200\x201\x201\x202\x200v3.5z\x22/></svg>','queued':'<svg\x20class=\x22status-icon\x22\x20viewBox=\x220\x200\x2016\x2016\x22\x20fill=\x22currentColor\x22><path\x20d=\x22M8\x200a8\x208\x200\x201\x200\x200\x2016A8\x208\x200\x200\x200\x208\x200zm0\x2014A6\x206\x200\x201\x201\x208\x202a6\x206\x200\x200\x201\x200\x2012zm1-6.5V4H7v4.5l3\x203\x201.5-1.5-2.5-2.5z\x22/></svg>'};export class VariantGroupingManager{constructor(_0x35bdd2={}){this['container']=null,this['onGroupChange']=_0x35bdd2['onGroupChange']||(()=>{}),this['onAddExistingTask']=_0x35bdd2['onAddExistingTask']||(()=>{}),this['tasks']=[],this['groupId']=_0x35bdd2['groupId']||null,this['isOpen']=![];}['init'](_0x3066d7,_0x57ef34,_0x2e5a29){this['container']=_0x3066d7,this['tasks']=_0x57ef34,this['groupId']=_0x2e5a29,this['render'](),this['attachEventListeners']();}['updateTasks'](_0x4dc357){const _0x931c1d=new Map(_0x4dc357['map'](_0x4126e8=>[_0x4126e8['taskId'],_0x4126e8]));this['tasks']=this['tasks']['map'](_0x213d9d=>{const _0x3ec8b1=_0x931c1d['get'](_0x213d9d['taskId']);return _0x3ec8b1?_0x3ec8b1:_0x213d9d;});for(const _0xbe89e4 of _0x4dc357){!this['tasks']['some'](_0x4f6156=>_0x4f6156['taskId']===_0xbe89e4['taskId'])&&this['tasks']['push'](_0xbe89e4);}this['isOpen']&&this['render']();}['open'](){this['isOpen']=!![],this['render'](),this['container']?.['classList']['add']('open');}['close'](){this['isOpen']=![],this['container']?.['classList']['remove']('open');}['render'](){if(!this['container'])return;const _0x10eebf=this['tasks']['filter'](_0x291673=>_0x291673['groupId']===this['groupId'])['sort']((_0x56fa58,_0x461f24)=>(_0x56fa58['groupIndex']??0x0)-(_0x461f24['groupIndex']??0x0)),_0x37e22c=this['tasks']['filter'](_0x471847=>!_0x471847['groupId']||_0x471847['groupId']!==this['groupId']);this['container']['innerHTML']='\x0a\x20\x20\x20\x20\x20\x20<div\x20class=\x22variant-grouping-manager\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-header\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<h3>Manage\x20Task\x20Group</h3>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22vgm-close-btn\x22\x20title=\x22Close\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20width=\x2220\x22\x20height=\x2220\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M18\x206L6\x2018M6\x206l12\x2012\x22/>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-content\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-section\x20vgm-grouped\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-section-header\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-section-title\x22>Grouped\x20Variants</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-section-count\x22>'+_0x10eebf['length']+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-drop-zone\x20vgm-grouped-zone\x22\x20data-zone=\x22grouped\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x10eebf['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20add\x20to\x20group</div>':_0x10eebf['map']((_0x5ba984,_0x3ac7ea)=>this['renderVariantCard'](_0x5ba984,_0x3ac7ea,!![]))['join'](''))+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-divider\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-divider-line\x22></div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-divider-text\x22>Drag\x20to\x20move</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-divider-line\x22></div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-section\x20vgm-ungrouped\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-section-header\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-section-title\x22>Ungrouped\x20Tasks</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-section-count\x22>'+_0x37e22c['length']+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-drop-zone\x20vgm-ungrouped-zone\x22\x20data-zone=\x22ungrouped\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x37e22c['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20remove\x20from\x20group</div>':_0x37e22c['map']((_0x40195a,_0x289880)=>this['renderVariantCard'](_0x40195a,_0x289880,![]))['join'](''))+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-actions\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22vgm-btn\x20vgm-btn-secondary\x20vgm-add-existing-btn\x22\x20title=\x22Add\x20an\x20existing\x20task\x20to\x20this\x20group\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M12\x205v14M5\x2012h14\x22/>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20Add\x20Existing\x20Task\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20';}['renderVariantCard'](_0x25a85e,_0xffe0af,_0x4c5b1f){const _0x31a50e=_0x25a85e['envVars']?.['CODER_AGENT']||_0x25a85e['envVars']?.['default_agent']||'claude',_0xbc39db=AGENT_ICONS[_0x31a50e['toLowerCase']()]||AGENT_ICONS['claude'],_0x2fcbfb=STATUS_ICONS[_0x25a85e['status']]||'',_0x53fb8c='status-'+(_0x25a85e['status']||'unknown'),_0x14216c=_0x25a85e['isWinner']?'<span\x20class=\x22vgm-badge\x20vgm-badge-winner\x22\x20title=\x22Winner\x22>★</span>':'',_0x5e02be=_0x25a85e['approvedBy']?'<span\x20class=\x22vgm-badge\x20vgm-badge-approved\x22\x20title=\x22Approved\x22><svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22\x20width=\x2212\x22\x20height=\x2212\x22><path\x20d=\x22M14\x209V5a3\x203\x200\x200\x200-3-3l-4\x209v11h11.28a2\x202\x200\x200\x200\x202-1.7l1.38-9a2\x202\x200\x200\x200-2-2.3zM7\x2022H4a2\x202\x200\x200\x201-2-2v-7a2\x202\x200\x200\x201\x202-2h3\x22></path></svg></span>':'';return'\x0a\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-card\x20'+_0x53fb8c+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20draggable=\x22true\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-task-id=\x22'+_0x25a85e['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-is-grouped=\x22'+_0x4c5b1f+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-index=\x22'+_0xffe0af+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-drag-handle\x22\x20title=\x22Drag\x20to\x20reorder\x20or\x20move\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20fill=\x22currentColor\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M8\x206h2v2H8V6zm6\x200h2v2h-2V6zM8\x2011h2v2H8v-2zm6\x200h2v2h-2v-2zm-6\x205h2v2H8v-2zm6\x200h2v2h-2v-2z\x22/>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-icon\x22\x20data-agent=\x22'+_0x31a50e['toLowerCase']()+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0xbc39db+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-info\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-name\x22>'+Utils['escapeHtml'](_0x25a85e['name']||'Task\x20'+_0x25a85e['taskId']['slice'](-0x6))+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-meta\x22>'+Utils['escapeHtml'](_0x31a50e)+'\x20·\x20'+(_0x25a85e['status']||'unknown')+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-badges\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x14216c+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x5e02be+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-status\x20'+_0x53fb8c+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x2fcbfb+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22vgm-variant-remove-btn\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20title=\x22'+(_0x4c5b1f?'Remove\x20from\x20group':'Add\x20to\x20group')+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-task-id=\x22'+_0x25a85e['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-action=\x22'+(_0x4c5b1f?'remove':'add')+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x4c5b1f?'<path\x20d=\x22M18\x206L6\x2018M6\x206l12\x2012\x22/>':'<path\x20d=\x22M12\x205v14M5\x2012h14\x22/>')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20';}['attachEventListeners'](){if(!this['container'])return;this['container']['addEventListener']('click',_0x6e3a14=>{_0x6e3a14['target']['closest']('.vgm-close-btn')&&(this['close'](),this['onGroupChange'](this['tasks'])),_0x6e3a14['target']['closest']('.vgm-add-existing-btn')&&(this['close'](),this['onAddExistingTask'](this['groupId']));}),this['container']['addEventListener']('click',async _0x4d78f9=>{const _0x34f8cf=_0x4d78f9['target']['closest']('.vgm-variant-remove-btn');if(!_0x34f8cf)return;const _0x53f75f=_0x34f8cf['dataset']['taskId'],_0x1068ae=_0x34f8cf['dataset']['action'];try{_0x1068ae==='remove'?await this['removeFromGroup'](_0x53f75f):await this['addToGroup'](_0x53f75f);}catch(_0x2d0f8b){console['error']('Failed\x20to\x20update\x20group:',_0x2d0f8b),Utils['showToast'](_0x2d0f8b['message']||'Failed\x20to\x20update\x20group','error');}}),this['container']['addEventListener']('dragstart',_0x511b9b=>this['handleDragStart'](_0x511b9b)),this['container']['addEventListener']('dragend',_0xf19861=>this['handleDragEnd'](_0xf19861)),this['container']['addEventListener']('dragover',_0x51a80d=>this['handleDragOver'](_0x51a80d)),this['container']['addEventListener']('dragleave',_0x4ae206=>this['handleDragLeave'](_0x4ae206)),this['container']['addEventListener']('drop',_0x371d3b=>this['handleDrop'](_0x371d3b));}['handleDragStart'](_0x5d7507){const _0x41a119=_0x5d7507['target']['closest']('.vgm-variant-card');if(!_0x41a119)return;dragState['draggedTaskId']=_0x41a119['dataset']['taskId'],dragState['draggedElement']=_0x41a119,dragState['sourceGroupId']=_0x41a119['dataset']['isGrouped']==='true'?this['groupId']:null,dragState['isDragging']=!![],_0x41a119['classList']['add']('dragging'),_0x5d7507['dataTransfer']['effectAllowed']='move',_0x5d7507['dataTransfer']['setData']('text/plain',_0x41a119['dataset']['taskId']),this['container']['classList']['add']('is-dragging');}['handleDragEnd'](_0x1bcc9d){const _0x2713be=_0x1bcc9d['target']['closest']('.vgm-variant-card');_0x2713be&&_0x2713be['classList']['remove']('dragging'),this['container']['querySelectorAll']('.drag-over,\x20.drop-indicator')['forEach'](_0x3798a9=>{_0x3798a9['classList']['remove']('drag-over','drop-indicator','drop-before','drop-after');}),this['container']['classList']['remove']('is-dragging'),dragState['isDragging']=![],dragState['draggedTaskId']=null,dragState['draggedElement']=null,dragState['sourceGroupId']=null;}['handleDragOver'](_0x43801d){_0x43801d['preventDefault'](),_0x43801d['dataTransfer']['dropEffect']='move';const _0x377bf9=_0x43801d['target']['closest']('.vgm-drop-zone'),_0x27c7ce=_0x43801d['target']['closest']('.vgm-variant-card');this['container']['querySelectorAll']('.vgm-drop-zone')['forEach'](_0xca1bab=>{_0xca1bab['classList']['toggle']('drag-over',_0xca1bab===_0x377bf9);});if(_0x27c7ce&&_0x27c7ce!==dragState['draggedElement']){const _0x49d09f=_0x27c7ce['getBoundingClientRect'](),_0x5f4b16=_0x49d09f['top']+_0x49d09f['height']/0x2,_0x3c4c4f=_0x43801d['clientY']<_0x5f4b16;this['container']['querySelectorAll']('.vgm-variant-card')['forEach'](_0x338042=>{_0x338042!==_0x27c7ce&&_0x338042['classList']['remove']('drop-before','drop-after');}),_0x27c7ce['classList']['toggle']('drop-before',_0x3c4c4f),_0x27c7ce['classList']['toggle']('drop-after',!_0x3c4c4f);}}['handleDragLeave'](_0x155c17){const _0x1be4d3=_0x155c17['target']['closest']('.vgm-drop-zone');_0x1be4d3&&!_0x1be4d3['contains'](_0x155c17['relatedTarget'])&&_0x1be4d3['classList']['remove']('drag-over');}async['handleDrop'](_0x96a491){_0x96a491['preventDefault']();const _0x67cd08=_0x96a491['target']['closest']('.vgm-drop-zone'),_0x139e7b=_0x96a491['target']['closest']('.vgm-variant-card'),_0x321010=_0x96a491['dataTransfer']['getData']('text/plain');if(!_0x67cd08||!_0x321010)return;this['container']['querySelectorAll']('.drag-over,\x20.drop-before,\x20.drop-after')['forEach'](_0x571630=>{_0x571630['classList']['remove']('drag-over','drop-before','drop-after');});const _0x484ed4=_0x67cd08['dataset']['zone'],_0x179cab=_0x484ed4==='grouped',_0x4c26f3=dragState['sourceGroupId']===this['groupId'];try{if(_0x179cab&&!_0x4c26f3){let _0x3dd5f3=this['tasks']['filter'](_0x4df321=>_0x4df321['groupId']===this['groupId'])['length'];if(_0x139e7b){const _0x404273=_0x139e7b['dataset']['taskId'],_0x4a7bae=this['tasks']['find'](_0x36b6c4=>_0x36b6c4['taskId']===_0x404273);if(_0x4a7bae?.['groupIndex']!==undefined){const _0x417c4d=_0x139e7b['getBoundingClientRect'](),_0x360309=_0x96a491['clientY']<_0x417c4d['top']+_0x417c4d['height']/0x2;_0x3dd5f3=_0x4a7bae['groupIndex']+(_0x360309?0x0:0x1);}}await this['addToGroup'](_0x321010,_0x3dd5f3);}else{if(!_0x179cab&&_0x4c26f3)await this['removeFromGroup'](_0x321010);else _0x179cab&&_0x4c26f3&&_0x139e7b&&await this['reorderInGroup'](_0x321010,_0x139e7b,_0x96a491['clientY']);}}catch(_0xceb218){console['error']('Drop\x20operation\x20failed:',_0xceb218),Utils['showToast'](_0xceb218['message']||'Failed\x20to\x20move\x20variant','error');}}async['addToGroup'](_0x56ebc6,_0x3fab32){const _0x4ca73e=this['tasks']['find'](_0x38f018=>_0x38f018['taskId']===_0x56ebc6);if(!_0x4ca73e)return;_0x3fab32===undefined&&(_0x3fab32=this['tasks']['filter'](_0x4bc5d5=>_0x4bc5d5['groupId']===this['groupId'])['length']),!this['groupId']&&(this['groupId']=API['generateGroupId'](),await API['createTaskGroup']({'groupId':this['groupId']})),await API['updateTaskGroup'](_0x56ebc6,this['groupId'],_0x3fab32),_0x4ca73e['groupId']=this['groupId'],_0x4ca73e['groupIndex']=_0x3fab32,this['render'](),this['onGroupChange'](this['tasks']);}async['removeFromGroup'](_0x1d8ee2){const _0x3400a8=this['tasks']['find'](_0x1f6b52=>_0x1f6b52['taskId']===_0x1d8ee2);if(!_0x3400a8)return;await API['removeTaskFromGroup'](_0x1d8ee2),_0x3400a8['groupId']=null,_0x3400a8['groupIndex']=null,this['render'](),this['onGroupChange'](this['tasks']);}async['reorderInGroup'](_0x32cbf8,_0x13814e,_0x27458f){const _0x4d042f=this['tasks']['find'](_0x4ecf73=>_0x4ecf73['taskId']===_0x32cbf8),_0x4b2bd7=_0x13814e['dataset']['taskId'],_0x50af1d=this['tasks']['find'](_0x3aafe0=>_0x3aafe0['taskId']===_0x4b2bd7);if(!_0x4d042f||!_0x50af1d||_0x4d042f['taskId']===_0x50af1d['taskId'])return;const _0x2eb901=_0x13814e['getBoundingClientRect'](),_0x33df62=_0x27458f<_0x2eb901['top']+_0x2eb901['height']/0x2;let _0x68c7a8=_0x50af1d['groupIndex']??0x0;if(!_0x33df62)_0x68c7a8++;if((_0x4d042f['groupIndex']??0x0)<(_0x50af1d['groupIndex']??0x0))_0x68c7a8--;if(_0x68c7a8===_0x4d042f['groupIndex'])return;await API['updateTaskGroup'](_0x32cbf8,this['groupId'],_0x68c7a8);const _0x1ff202=this['tasks']['filter'](_0x3e2b2f=>_0x3e2b2f['groupId']===this['groupId'])['sort']((_0x329890,_0x47f011)=>(_0x329890['groupIndex']??0x0)-(_0x47f011['groupIndex']??0x0)),_0x44b16a=_0x1ff202['findIndex'](_0x43a08a=>_0x43a08a['taskId']===_0x32cbf8);_0x44b16a!==-0x1&&_0x1ff202['splice'](_0x44b16a,0x1),_0x1ff202['splice'](_0x68c7a8,0x0,_0x4d042f),_0x1ff202['forEach']((_0x13ba5d,_0xe1953a)=>{_0x13ba5d['groupIndex']=_0xe1953a;}),this['render'](),this['onGroupChange'](this['tasks']);}}export function initializeTabDragDrop(_0xa50bcb,_0x602edf,_0x546a06,_0x4ac1f0={}){if(!_0xa50bcb)return;const {onReorder:_0x171b41,onRemove:_0x1ecfd5}=_0x4ac1f0,_0x386890=_0xa50bcb['querySelectorAll']('.task-tab');_0x386890['forEach']((_0x47afc6,_0x114ee8)=>{_0x47afc6['setAttribute']('draggable','true'),_0x47afc6['dataset']['index']=_0x114ee8,_0x47afc6['addEventListener']('dragstart',_0x276f46=>{_0x276f46['dataTransfer']['effectAllowed']='move',_0x276f46['dataTransfer']['setData']('text/plain',_0x47afc6['dataset']['taskId']),_0x47afc6['classList']['add']('dragging'),_0xa50bcb['classList']['add']('is-dragging');}),_0x47afc6['addEventListener']('dragend',()=>{_0x47afc6['classList']['remove']('dragging'),_0xa50bcb['classList']['remove']('is-dragging'),_0xa50bcb['querySelectorAll']('.drop-indicator')['forEach'](_0x25f3b4=>{_0x25f3b4['classList']['remove']('drop-indicator','drop-before','drop-after');});}),_0x47afc6['addEventListener']('dragover',_0x3c4aa9=>{_0x3c4aa9['preventDefault'](),_0x3c4aa9['dataTransfer']['dropEffect']='move';if(_0x47afc6['classList']['contains']('dragging'))return;const _0x3208a5=_0x47afc6['getBoundingClientRect'](),_0x432daf=_0x3208a5['left']+_0x3208a5['width']/0x2,_0x399b94=_0x3c4aa9['clientX']<_0x432daf;_0x386890['forEach'](_0xb79f52=>_0xb79f52['classList']['remove']('drop-before','drop-after')),_0x47afc6['classList']['add'](_0x399b94?'drop-before':'drop-after');}),_0x47afc6['addEventListener']('dragleave',()=>{_0x47afc6['classList']['remove']('drop-before','drop-after');}),_0x47afc6['addEventListener']('drop',async _0x32a734=>{_0x32a734['preventDefault']();const _0x4bf6ec=_0x32a734['dataTransfer']['getData']('text/plain'),_0x339bf3=_0x47afc6['dataset']['taskId'];if(_0x4bf6ec===_0x339bf3)return;const _0xa75005=_0x47afc6['getBoundingClientRect'](),_0x394a2f=_0x32a734['clientX']<_0xa75005['left']+_0xa75005['width']/0x2;_0x47afc6['classList']['remove']('drop-before','drop-after'),_0x171b41&&await _0x171b41(_0x4bf6ec,_0x339bf3,_0x394a2f);});});const _0x375990=document['createElement']('div');return _0x375990['className']='task-tab-remove-zone',_0x375990['innerHTML']='\x0a\x20\x20\x20\x20<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20<path\x20d=\x22M18\x206L6\x2018M6\x206l12\x2012\x22/>\x0a\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20<span>Remove\x20from\x20group</span>\x0a\x20\x20',_0x375990['style']['display']='none',_0x375990['addEventListener']('dragover',_0x2a9b01=>{_0x2a9b01['preventDefault'](),_0x375990['classList']['add']('drag-over');}),_0x375990['addEventListener']('dragleave',()=>{_0x375990['classList']['remove']('drag-over');}),_0x375990['addEventListener']('drop',async _0x2452fb=>{_0x2452fb['preventDefault'](),_0x375990['classList']['remove']('drag-over');const _0x2bcd6a=_0x2452fb['dataTransfer']['getData']('text/plain');_0x1ecfd5&&await _0x1ecfd5(_0x2bcd6a);}),_0xa50bcb['addEventListener']('dragstart',()=>{_0x602edf['length']>0x1&&(_0x375990['style']['display']='flex');}),_0xa50bcb['addEventListener']('dragend',()=>{_0x375990['style']['display']='none';}),_0xa50bcb['appendChild'](_0x375990),{'destroy':()=>{_0x375990['remove']();}};}export default VariantGroupingManager;
1
+ import{API,Utils}from'./app.js';const dragState={'draggedTaskId':null,'draggedElement':null,'sourceGroupId':null,'isDragging':![]},AGENT_ICONS={'claude':'<svg\x20viewBox=\x220\x200\x2016\x2016\x22\x20fill=\x22currentColor\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20aria-hidden=\x22true\x22><path\x20d=\x22m3.127\x2010.604\x203.135-1.76.053-.153-.053-.085H6.11l-.525-.032-1.791-.048-1.554-.065-1.505-.08-.38-.081L0\x207.832l.036-.234.32-.214.455.04\x201.009.069\x201.513.105\x201.097.064\x201.626.17h.259l.036-.105-.089-.065-.068-.064-1.566-1.062-1.695-1.121-.887-.646-.48-.327-.243-.306-.104-.67.435-.48.585.04.15.04.593.456\x201.267.981\x201.654\x201.218.242.202.097-.068.012-.049-.109-.181-.9-1.626-.96-1.655-.428-.686-.113-.411a2\x202\x200\x200\x201-.068-.484l.496-.674L4.446\x200l.662.089.279.242.411.94.666\x201.48\x201.033\x202.014.302.597.162.553.06.17h.105v-.097l.085-1.134.157-1.392.154-1.792.052-.504.25-.605.497-.327.387.186.319.456-.045.294-.19\x201.23-.37\x201.93-.243\x201.29h.142l.161-.16.654-.868\x201.097-1.372.484-.545.565-.601.363-.287h.686l.505.751-.226.775-.707.895-.585.759-.839\x201.13-.524.904.048.072.125-.012\x201.897-.403\x201.024-.186\x201.223-.21.553.258.06.263-.218.536-1.307.323-1.533.307-2.284.54-.028.02.032.04\x201.029.098.44.024h1.077l2.005.15.525.346.315.424-.053.323-.807.411-3.631-.863-.872-.218h-.12v.073l.726.71\x201.331\x201.202\x201.667\x201.55.084.383-.214.302-.226-.032-1.464-1.101-.565-.497-1.28-1.077h-.084v.113l.295.432\x201.557\x202.34.08.718-.112.234-.404.141-.444-.08-.911-1.28-.94-1.44-.759-1.291-.093.053-.448\x204.821-.21.246-.484.186-.403-.307-.214-.496.214-.98.258-1.28.21-1.016.19-1.263.112-.42-.008-.028-.092.012-.953\x201.307-1.448\x201.957-1.146\x201.227-.274.109-.477-.247.045-.44.266-.39\x201.586-2.018.956-1.25.617-.723-.004-.105h-.036l-4.212\x204.212z\x22/></svg>','codex':'<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22currentColor\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20aria-hidden=\x22true\x22><path\x20d=\x22M22.2819\x209.8211a5.9847\x205.9847\x200\x200\x200-.5157-4.9108\x206.0462\x206.0462\x200\x200\x200-6.5098-2.9A6.0651\x206.0651\x200\x200\x200\x204.9807\x204.1818a5.9847\x205.9847\x200\x200\x200-3.9977\x202.9\x206.0462\x206.0462\x200\x200\x200\x20.7427\x207.0966\x205.98\x205.98\x200\x200\x200\x20.511\x204.9107\x206.051\x206.051\x200\x200\x200\x206.5146\x202.9001A5.9847\x205.9847\x200\x200\x200\x2013.2599\x2024a6.0557\x206.0557\x200\x200\x200\x205.7718-4.2058\x205.9894\x205.9894\x200\x200\x200\x203.9977-2.9001\x206.0557\x206.0557\x200\x200\x200-.7475-7.0729zm-9.022\x2012.6081a4.4755\x204.4755\x200\x200\x201-2.8764-1.0408l.1419-.0804\x204.7783-2.7582a.7948.7948\x200\x200\x200\x20.3927-.6813v-6.7369l2.02\x201.1686a.071.071\x200\x200\x201\x20.038.052v5.5826a4.504\x204.504\x200\x200\x201-4.4945\x204.4944zm-9.6607-4.1254a4.4708\x204.4708\x200\x200\x201-.5346-3.0137l.142.0852\x204.783\x202.7582a.7712.7712\x200\x200\x200\x20.7806\x200l5.8428-3.3685v2.3324a.0804.0804\x200\x200\x201-.0332.0615L9.74\x2019.9502a4.4992\x204.4992\x200\x200\x201-6.1408-1.6464zM2.3408\x207.8956a4.485\x204.485\x200\x200\x201\x202.3655-1.9728V11.6a.7664.7664\x200\x200\x200\x20.3879.6765l5.8144\x203.3543-2.0201\x201.1685a.0757.0757\x200\x200\x201-.071\x200l-4.8303-2.7865A4.504\x204.504\x200\x200\x201\x202.3408\x207.872zm16.5963\x203.8558L13.1038\x208.364\x2015.1192\x207.2a.0757.0757\x200\x200\x201\x20.071\x200l4.8303\x202.7913a4.4944\x204.4944\x200\x200\x201-.6765\x208.1042v-5.6772a.79.79\x200\x200\x200-.407-.667zm2.0107-3.0231l-.142-.0852-4.7735-2.7818a.7759.7759\x200\x200\x200-.7854\x200L9.409\x209.2297V6.8974a.0662.0662\x200\x200\x201\x20.0284-.0615l4.8303-2.7866a4.4992\x204.4992\x200\x200\x201\x206.6802\x204.66zM8.3065\x2012.863l-2.02-1.1638a.0804.0804\x200\x200\x201-.038-.0567V6.0742a4.4992\x204.4992\x200\x200\x201\x207.3757-3.4537l-.142.0805L8.704\x205.459a.7948.7948\x200\x200\x200-.3927.6813zm1.0976-2.3654l2.602-1.4998\x202.6069\x201.4998v2.9994l-2.5974\x201.4997-2.6067-1.4997Z\x22/></svg>','gemini':'<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20aria-hidden=\x22true\x22><path\x20d=\x22M12\x202L9.09\x209.09\x202\x2012l7.09\x202.91L12\x2022l2.91-7.09L22\x2012l-7.09-2.91z\x22></path></svg>','unknown':'<svg\x20viewBox=\x220\x200\x2020\x2020\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x221.6\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20aria-hidden=\x22true\x22><circle\x20cx=\x2210\x22\x20cy=\x2210\x22\x20r=\x228\x22\x20/><path\x20d=\x22M10\x206.5c-1.1\x200-2\x20.7-2\x201.6\x200\x20.9\x201\x201.3\x201.6\x201.7.7.4\x201\x20.8\x201\x201.5V12\x22\x20/><circle\x20cx=\x2210\x22\x20cy=\x2214\x22\x20r=\x220.8\x22\x20fill=\x22currentColor\x22\x20stroke=\x22none\x22\x20/></svg>'},STATUS_ICONS={'running':'<svg\x20class=\x22status-icon\x20spinning\x22\x20viewBox=\x220\x200\x2016\x2016\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222.5\x22\x20stroke-linecap=\x22round\x22><path\x20d=\x22M8\x202\x20A6\x206\x200\x200\x201\x2014\x208\x22/></svg>','completed':'<svg\x20class=\x22status-icon\x22\x20viewBox=\x220\x200\x2016\x2016\x22\x20fill=\x22currentColor\x22><path\x20d=\x22M8\x200a8\x208\x200\x201\x200\x200\x2016A8\x208\x200\x200\x200\x208\x200zm3.78\x206.28-4.5\x204.5a.75.75\x200\x200\x201-1.06\x200l-2-2a.75.75\x200\x201\x201\x201.06-1.06L6.75\x209.19l3.97-3.97a.75.75\x200\x201\x201\x201.06\x201.06z\x22/></svg>','failed':'<svg\x20class=\x22status-icon\x22\x20viewBox=\x220\x200\x2016\x2016\x22\x20fill=\x22currentColor\x22><path\x20d=\x22M8\x200a8\x208\x200\x201\x200\x200\x2016A8\x208\x200\x200\x200\x208\x200zm3.53\x2010.47a.75.75\x200\x201\x201-1.06\x201.06L8\x209.06l-2.47\x202.47a.75.75\x200\x200\x201-1.06-1.06L6.94\x208\x204.47\x205.53a.75.75\x200\x200\x201\x201.06-1.06L8\x206.94l2.47-2.47a.75.75\x200\x200\x201\x201.06\x201.06L9.06\x208l2.47\x202.47z\x22/></svg>','staged':'<svg\x20class=\x22status-icon\x22\x20viewBox=\x220\x200\x2016\x2016\x22\x20fill=\x22currentColor\x22><path\x20d=\x22M8\x200a8\x208\x200\x201\x200\x200\x2016A8\x208\x200\x200\x200\x208\x200zm0\x2012a.75.75\x200\x201\x201\x200-1.5.75.75\x200\x200\x201\x200\x201.5zm1-3.5a1\x201\x200\x200\x201-2\x200V5a1\x201\x200\x201\x201\x202\x200v3.5z\x22/></svg>','queued':'<svg\x20class=\x22status-icon\x22\x20viewBox=\x220\x200\x2016\x2016\x22\x20fill=\x22currentColor\x22><path\x20d=\x22M8\x200a8\x208\x200\x201\x200\x200\x2016A8\x208\x200\x200\x200\x208\x200zm0\x2014A6\x206\x200\x201\x201\x208\x202a6\x206\x200\x200\x201\x200\x2012zm1-6.5V4H7v4.5l3\x203\x201.5-1.5-2.5-2.5z\x22/></svg>'};export class VariantGroupingManager{constructor(_0x2907d8={}){this['container']=null,this['onGroupChange']=_0x2907d8['onGroupChange']||(()=>{}),this['onAddExistingTask']=_0x2907d8['onAddExistingTask']||(()=>{}),this['tasks']=[],this['groupId']=_0x2907d8['groupId']||null,this['isOpen']=![];}['init'](_0x39f110,_0x1c7b62,_0x467c3f){this['container']=_0x39f110,this['tasks']=_0x1c7b62,this['groupId']=_0x467c3f,this['render'](),this['attachEventListeners']();}['updateTasks'](_0x2d5e95){const _0x32581f=new Map(_0x2d5e95['map'](_0x2c91e2=>[_0x2c91e2['taskId'],_0x2c91e2]));this['tasks']=this['tasks']['map'](_0x2f015e=>{const _0x1d9b76=_0x32581f['get'](_0x2f015e['taskId']);return _0x1d9b76?_0x1d9b76:_0x2f015e;});for(const _0x2d2305 of _0x2d5e95){!this['tasks']['some'](_0x2015a0=>_0x2015a0['taskId']===_0x2d2305['taskId'])&&this['tasks']['push'](_0x2d2305);}this['isOpen']&&this['render']();}['open'](){this['isOpen']=!![],this['render'](),this['container']?.['classList']['add']('open');}['close'](){this['isOpen']=![],this['container']?.['classList']['remove']('open');}['render'](){if(!this['container'])return;const _0x4ae563=this['tasks']['filter'](_0x4324a4=>_0x4324a4['groupId']===this['groupId'])['sort']((_0x1fe17e,_0x4c9056)=>(_0x1fe17e['groupIndex']??0x0)-(_0x4c9056['groupIndex']??0x0)),_0x3c86f4=this['tasks']['filter'](_0x3d60ba=>!_0x3d60ba['groupId']||_0x3d60ba['groupId']!==this['groupId']);this['container']['innerHTML']='\x0a\x20\x20\x20\x20\x20\x20<div\x20class=\x22variant-grouping-manager\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-header\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<h3>Manage\x20Task\x20Group</h3>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22vgm-close-btn\x22\x20title=\x22Close\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20width=\x2220\x22\x20height=\x2220\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M18\x206L6\x2018M6\x206l12\x2012\x22/>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-content\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-section\x20vgm-grouped\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-section-header\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-section-title\x22>Grouped\x20Variants</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-section-count\x22>'+_0x4ae563['length']+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-drop-zone\x20vgm-grouped-zone\x22\x20data-zone=\x22grouped\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x4ae563['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20add\x20to\x20group</div>':_0x4ae563['map']((_0x2d4f63,_0x536c61)=>this['renderVariantCard'](_0x2d4f63,_0x536c61,!![]))['join'](''))+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-divider\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-divider-line\x22></div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-divider-text\x22>Drag\x20to\x20move</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-divider-line\x22></div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-section\x20vgm-ungrouped\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-section-header\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-section-title\x22>Ungrouped\x20Tasks</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-section-count\x22>'+_0x3c86f4['length']+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-drop-zone\x20vgm-ungrouped-zone\x22\x20data-zone=\x22ungrouped\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x3c86f4['length']===0x0?'<div\x20class=\x22vgm-empty-hint\x22>Drag\x20variants\x20here\x20to\x20remove\x20from\x20group</div>':_0x3c86f4['map']((_0x339584,_0x45fe4d)=>this['renderVariantCard'](_0x339584,_0x45fe4d,![]))['join'](''))+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-actions\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22vgm-btn\x20vgm-btn-secondary\x20vgm-add-existing-btn\x22\x20title=\x22Add\x20an\x20existing\x20task\x20to\x20this\x20group\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M12\x205v14M5\x2012h14\x22/>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20Add\x20Existing\x20Task\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20';}['renderVariantCard'](_0x365f9b,_0x281d42,_0x4ea494){const _0x5c55cf=_0x365f9b['envVars']?.['CODER_AGENT']||_0x365f9b['envVars']?.['default_agent']||'claude',_0x2bbb58=AGENT_ICONS[_0x5c55cf['toLowerCase']()]||AGENT_ICONS['claude'],_0x29011c=STATUS_ICONS[_0x365f9b['status']]||'',_0x303fef='status-'+(_0x365f9b['status']||'unknown'),_0x46671e=_0x365f9b['isWinner']?'<span\x20class=\x22vgm-badge\x20vgm-badge-winner\x22\x20title=\x22Winner\x22>★</span>':'',_0x36507a=_0x365f9b['approvedBy']?'<span\x20class=\x22vgm-badge\x20vgm-badge-approved\x22\x20title=\x22Approved\x22><svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22\x20stroke-linecap=\x22round\x22\x20stroke-linejoin=\x22round\x22\x20width=\x2212\x22\x20height=\x2212\x22><path\x20d=\x22M14\x209V5a3\x203\x200\x200\x200-3-3l-4\x209v11h11.28a2\x202\x200\x200\x200\x202-1.7l1.38-9a2\x202\x200\x200\x200-2-2.3zM7\x2022H4a2\x202\x200\x200\x201-2-2v-7a2\x202\x200\x200\x201\x202-2h3\x22></path></svg></span>':'';return'\x0a\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-card\x20'+_0x303fef+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20draggable=\x22true\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-task-id=\x22'+_0x365f9b['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-is-grouped=\x22'+_0x4ea494+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-index=\x22'+_0x281d42+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-drag-handle\x22\x20title=\x22Drag\x20to\x20reorder\x20or\x20move\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20fill=\x22currentColor\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<path\x20d=\x22M8\x206h2v2H8V6zm6\x200h2v2h-2V6zM8\x2011h2v2H8v-2zm6\x200h2v2h-2v-2zm-6\x205h2v2H8v-2zm6\x200h2v2h-2v-2z\x22/>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-icon\x22\x20data-agent=\x22'+_0x5c55cf['toLowerCase']()+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x2bbb58+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-info\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-name\x22>'+Utils['escapeHtml'](_0x365f9b['name']||'Task\x20'+_0x365f9b['taskId']['slice'](-0x6))+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22vgm-variant-meta\x22>'+Utils['escapeHtml'](_0x5c55cf)+'\x20·\x20'+(_0x365f9b['status']||'unknown')+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-badges\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x46671e+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x36507a+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22vgm-variant-status\x20'+_0x303fef+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x29011c+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22vgm-variant-remove-btn\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20title=\x22'+(_0x4ea494?'Remove\x20from\x20group':'Add\x20to\x20group')+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-task-id=\x22'+_0x365f9b['taskId']+'\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20data-action=\x22'+(_0x4ea494?'remove':'add')+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x4ea494?'<path\x20d=\x22M18\x206L6\x2018M6\x206l12\x2012\x22/>':'<path\x20d=\x22M12\x205v14M5\x2012h14\x22/>')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20';}['attachEventListeners'](){if(!this['container'])return;this['container']['addEventListener']('click',_0x27e2fe=>{_0x27e2fe['target']['closest']('.vgm-close-btn')&&(this['close'](),this['onGroupChange'](this['tasks'])),_0x27e2fe['target']['closest']('.vgm-add-existing-btn')&&(this['close'](),this['onAddExistingTask'](this['groupId']));}),this['container']['addEventListener']('click',async _0x56565b=>{const _0x4c4261=_0x56565b['target']['closest']('.vgm-variant-remove-btn');if(!_0x4c4261)return;const _0x1dfe96=_0x4c4261['dataset']['taskId'],_0x55e112=_0x4c4261['dataset']['action'];try{_0x55e112==='remove'?await this['removeFromGroup'](_0x1dfe96):await this['addToGroup'](_0x1dfe96);}catch(_0x797369){console['error']('Failed\x20to\x20update\x20group:',_0x797369),Utils['showToast'](_0x797369['message']||'Failed\x20to\x20update\x20group','error');}}),this['container']['addEventListener']('dragstart',_0x329329=>this['handleDragStart'](_0x329329)),this['container']['addEventListener']('dragend',_0x3af5a1=>this['handleDragEnd'](_0x3af5a1)),this['container']['addEventListener']('dragover',_0x5ec827=>this['handleDragOver'](_0x5ec827)),this['container']['addEventListener']('dragleave',_0x49b58b=>this['handleDragLeave'](_0x49b58b)),this['container']['addEventListener']('drop',_0x193775=>this['handleDrop'](_0x193775));}['handleDragStart'](_0x425800){const _0x552f28=_0x425800['target']['closest']('.vgm-variant-card');if(!_0x552f28)return;dragState['draggedTaskId']=_0x552f28['dataset']['taskId'],dragState['draggedElement']=_0x552f28,dragState['sourceGroupId']=_0x552f28['dataset']['isGrouped']==='true'?this['groupId']:null,dragState['isDragging']=!![],_0x552f28['classList']['add']('dragging'),_0x425800['dataTransfer']['effectAllowed']='move',_0x425800['dataTransfer']['setData']('text/plain',_0x552f28['dataset']['taskId']),this['container']['classList']['add']('is-dragging');}['handleDragEnd'](_0x2c0a85){const _0x395842=_0x2c0a85['target']['closest']('.vgm-variant-card');_0x395842&&_0x395842['classList']['remove']('dragging'),this['container']['querySelectorAll']('.drag-over,\x20.drop-indicator')['forEach'](_0x30c4f6=>{_0x30c4f6['classList']['remove']('drag-over','drop-indicator','drop-before','drop-after');}),this['container']['classList']['remove']('is-dragging'),dragState['isDragging']=![],dragState['draggedTaskId']=null,dragState['draggedElement']=null,dragState['sourceGroupId']=null;}['handleDragOver'](_0x3eea9a){_0x3eea9a['preventDefault'](),_0x3eea9a['dataTransfer']['dropEffect']='move';const _0x3d8f67=_0x3eea9a['target']['closest']('.vgm-drop-zone'),_0x4ef3ca=_0x3eea9a['target']['closest']('.vgm-variant-card');this['container']['querySelectorAll']('.vgm-drop-zone')['forEach'](_0xdec671=>{_0xdec671['classList']['toggle']('drag-over',_0xdec671===_0x3d8f67);});if(_0x4ef3ca&&_0x4ef3ca!==dragState['draggedElement']){const _0x270a5f=_0x4ef3ca['getBoundingClientRect'](),_0x8bb1f0=_0x270a5f['top']+_0x270a5f['height']/0x2,_0x47d6d1=_0x3eea9a['clientY']<_0x8bb1f0;this['container']['querySelectorAll']('.vgm-variant-card')['forEach'](_0x27e76c=>{_0x27e76c!==_0x4ef3ca&&_0x27e76c['classList']['remove']('drop-before','drop-after');}),_0x4ef3ca['classList']['toggle']('drop-before',_0x47d6d1),_0x4ef3ca['classList']['toggle']('drop-after',!_0x47d6d1);}}['handleDragLeave'](_0x5dee19){const _0x1b9227=_0x5dee19['target']['closest']('.vgm-drop-zone');_0x1b9227&&!_0x1b9227['contains'](_0x5dee19['relatedTarget'])&&_0x1b9227['classList']['remove']('drag-over');}async['handleDrop'](_0x1cccf2){_0x1cccf2['preventDefault']();const _0x1f221f=_0x1cccf2['target']['closest']('.vgm-drop-zone'),_0x26d4ff=_0x1cccf2['target']['closest']('.vgm-variant-card'),_0x29c15d=_0x1cccf2['dataTransfer']['getData']('text/plain');if(!_0x1f221f||!_0x29c15d)return;this['container']['querySelectorAll']('.drag-over,\x20.drop-before,\x20.drop-after')['forEach'](_0x4e83e3=>{_0x4e83e3['classList']['remove']('drag-over','drop-before','drop-after');});const _0x1bf861=_0x1f221f['dataset']['zone'],_0x3b1c0f=_0x1bf861==='grouped',_0x11483e=dragState['sourceGroupId']===this['groupId'];try{if(_0x3b1c0f&&!_0x11483e){let _0x190759=this['tasks']['filter'](_0x28edc9=>_0x28edc9['groupId']===this['groupId'])['length'];if(_0x26d4ff){const _0x4520e6=_0x26d4ff['dataset']['taskId'],_0x266dfe=this['tasks']['find'](_0x362483=>_0x362483['taskId']===_0x4520e6);if(_0x266dfe?.['groupIndex']!==undefined){const _0x3e5938=_0x26d4ff['getBoundingClientRect'](),_0x178875=_0x1cccf2['clientY']<_0x3e5938['top']+_0x3e5938['height']/0x2;_0x190759=_0x266dfe['groupIndex']+(_0x178875?0x0:0x1);}}await this['addToGroup'](_0x29c15d,_0x190759);}else{if(!_0x3b1c0f&&_0x11483e)await this['removeFromGroup'](_0x29c15d);else _0x3b1c0f&&_0x11483e&&_0x26d4ff&&await this['reorderInGroup'](_0x29c15d,_0x26d4ff,_0x1cccf2['clientY']);}}catch(_0x3b7712){console['error']('Drop\x20operation\x20failed:',_0x3b7712),Utils['showToast'](_0x3b7712['message']||'Failed\x20to\x20move\x20variant','error');}}async['addToGroup'](_0x4b5510,_0x4ad6a9){const _0x3c8de3=this['tasks']['find'](_0x7306c5=>_0x7306c5['taskId']===_0x4b5510);if(!_0x3c8de3)return;_0x4ad6a9===undefined&&(_0x4ad6a9=this['tasks']['filter'](_0x13bba6=>_0x13bba6['groupId']===this['groupId'])['length']),!this['groupId']&&(this['groupId']=API['generateGroupId'](),await API['createTaskGroup']({'groupId':this['groupId']})),await API['updateTaskGroup'](_0x4b5510,this['groupId'],_0x4ad6a9),_0x3c8de3['groupId']=this['groupId'],_0x3c8de3['groupIndex']=_0x4ad6a9,this['render'](),this['onGroupChange'](this['tasks']);}async['removeFromGroup'](_0x17bbf1){const _0x1d76ce=this['tasks']['find'](_0x206fce=>_0x206fce['taskId']===_0x17bbf1);if(!_0x1d76ce)return;await API['removeTaskFromGroup'](_0x17bbf1),_0x1d76ce['groupId']=null,_0x1d76ce['groupIndex']=null,this['render'](),this['onGroupChange'](this['tasks']);}async['reorderInGroup'](_0x2a29b8,_0x4e5177,_0xb0e3e6){const _0x129054=this['tasks']['find'](_0x419fc7=>_0x419fc7['taskId']===_0x2a29b8),_0x20b10d=_0x4e5177['dataset']['taskId'],_0x36b642=this['tasks']['find'](_0x2b946b=>_0x2b946b['taskId']===_0x20b10d);if(!_0x129054||!_0x36b642||_0x129054['taskId']===_0x36b642['taskId'])return;const _0xc5d875=_0x4e5177['getBoundingClientRect'](),_0x52eadd=_0xb0e3e6<_0xc5d875['top']+_0xc5d875['height']/0x2;let _0x28bbf4=_0x36b642['groupIndex']??0x0;if(!_0x52eadd)_0x28bbf4++;if((_0x129054['groupIndex']??0x0)<(_0x36b642['groupIndex']??0x0))_0x28bbf4--;if(_0x28bbf4===_0x129054['groupIndex'])return;await API['updateTaskGroup'](_0x2a29b8,this['groupId'],_0x28bbf4);const _0x57d2a4=this['tasks']['filter'](_0x57b14b=>_0x57b14b['groupId']===this['groupId'])['sort']((_0x58c213,_0x2e3bff)=>(_0x58c213['groupIndex']??0x0)-(_0x2e3bff['groupIndex']??0x0)),_0x309c44=_0x57d2a4['findIndex'](_0x5ed62a=>_0x5ed62a['taskId']===_0x2a29b8);_0x309c44!==-0x1&&_0x57d2a4['splice'](_0x309c44,0x1),_0x57d2a4['splice'](_0x28bbf4,0x0,_0x129054),_0x57d2a4['forEach']((_0x2087c0,_0x11b035)=>{_0x2087c0['groupIndex']=_0x11b035;}),this['render'](),this['onGroupChange'](this['tasks']);}}export function initializeTabDragDrop(_0x1a93b7,_0x1e1a47,_0x10caf2,_0xd93867={}){if(!_0x1a93b7)return;const {onReorder:_0x30383f,onRemove:_0x2ce90d}=_0xd93867,_0x48fda5=_0x1a93b7['querySelectorAll']('.task-tab');_0x48fda5['forEach']((_0x167516,_0x3b72e9)=>{_0x167516['setAttribute']('draggable','true'),_0x167516['dataset']['index']=_0x3b72e9,_0x167516['addEventListener']('dragstart',_0x4bf03e=>{_0x4bf03e['dataTransfer']['effectAllowed']='move',_0x4bf03e['dataTransfer']['setData']('text/plain',_0x167516['dataset']['taskId']),_0x167516['classList']['add']('dragging'),_0x1a93b7['classList']['add']('is-dragging');}),_0x167516['addEventListener']('dragend',()=>{_0x167516['classList']['remove']('dragging'),_0x1a93b7['classList']['remove']('is-dragging'),_0x1a93b7['querySelectorAll']('.drop-indicator')['forEach'](_0x227034=>{_0x227034['classList']['remove']('drop-indicator','drop-before','drop-after');});}),_0x167516['addEventListener']('dragover',_0x3b9ba7=>{_0x3b9ba7['preventDefault'](),_0x3b9ba7['dataTransfer']['dropEffect']='move';if(_0x167516['classList']['contains']('dragging'))return;const _0x804b47=_0x167516['getBoundingClientRect'](),_0x5426d2=_0x804b47['left']+_0x804b47['width']/0x2,_0x262224=_0x3b9ba7['clientX']<_0x5426d2;_0x48fda5['forEach'](_0x2d4066=>_0x2d4066['classList']['remove']('drop-before','drop-after')),_0x167516['classList']['add'](_0x262224?'drop-before':'drop-after');}),_0x167516['addEventListener']('dragleave',()=>{_0x167516['classList']['remove']('drop-before','drop-after');}),_0x167516['addEventListener']('drop',async _0x544079=>{_0x544079['preventDefault']();const _0x1f2a0e=_0x544079['dataTransfer']['getData']('text/plain'),_0x404401=_0x167516['dataset']['taskId'];if(_0x1f2a0e===_0x404401)return;const _0x58d26b=_0x167516['getBoundingClientRect'](),_0x27c4d2=_0x544079['clientX']<_0x58d26b['left']+_0x58d26b['width']/0x2;_0x167516['classList']['remove']('drop-before','drop-after'),_0x30383f&&await _0x30383f(_0x1f2a0e,_0x404401,_0x27c4d2);});});const _0x1d2421=document['createElement']('div');return _0x1d2421['className']='task-tab-remove-zone',_0x1d2421['innerHTML']='\x0a\x20\x20\x20\x20<svg\x20viewBox=\x220\x200\x2024\x2024\x22\x20width=\x2216\x22\x20height=\x2216\x22\x20fill=\x22none\x22\x20stroke=\x22currentColor\x22\x20stroke-width=\x222\x22>\x0a\x20\x20\x20\x20\x20\x20<path\x20d=\x22M18\x206L6\x2018M6\x206l12\x2012\x22/>\x0a\x20\x20\x20\x20</svg>\x0a\x20\x20\x20\x20<span>Remove\x20from\x20group</span>\x0a\x20\x20',_0x1d2421['style']['display']='none',_0x1d2421['addEventListener']('dragover',_0x309d57=>{_0x309d57['preventDefault'](),_0x1d2421['classList']['add']('drag-over');}),_0x1d2421['addEventListener']('dragleave',()=>{_0x1d2421['classList']['remove']('drag-over');}),_0x1d2421['addEventListener']('drop',async _0x5af8c8=>{_0x5af8c8['preventDefault'](),_0x1d2421['classList']['remove']('drag-over');const _0x2c0f0f=_0x5af8c8['dataTransfer']['getData']('text/plain');_0x2ce90d&&await _0x2ce90d(_0x2c0f0f);}),_0x1a93b7['addEventListener']('dragstart',()=>{_0x1e1a47['length']>0x1&&(_0x1d2421['style']['display']='flex');}),_0x1a93b7['addEventListener']('dragend',()=>{_0x1d2421['style']['display']='none';}),_0x1a93b7['appendChild'](_0x1d2421),{'destroy':()=>{_0x1d2421['remove']();}};}export default VariantGroupingManager;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@profoundlogic/coderflow-server",
3
- "version": "0.7.9",
3
+ "version": "0.8.1",
4
4
  "description": "AI Coder Server - Manages Docker containers for AI agent task execution",
5
5
  "main": "dist/start.js",
6
6
  "type": "module",