@profoundlogic/coderflow-server 0.7.7 → 0.7.9

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 (187) hide show
  1. package/dist/coder-server.js +1 -1
  2. package/dist/config.js +1 -1
  3. package/dist/lib/agent-keepalive.js +1 -1
  4. package/dist/lib/agent-models.js +1 -1
  5. package/dist/lib/api-keys.js +1 -1
  6. package/dist/lib/apiKeys.js +1 -1
  7. package/dist/lib/app-server-ports.js +1 -1
  8. package/dist/lib/auto-judge.js +1 -1
  9. package/dist/lib/automation-service.js +1 -1
  10. package/dist/lib/basic-auth.js +1 -1
  11. package/dist/lib/bindings.js +1 -1
  12. package/dist/lib/build-history.js +1 -1
  13. package/dist/lib/build-output-service.js +1 -1
  14. package/dist/lib/build-scheduler.js +1 -1
  15. package/dist/lib/build-service.js +1 -1
  16. package/dist/lib/ca-certificates.js +1 -1
  17. package/dist/lib/claude-oauth-refresh.js +1 -1
  18. package/dist/lib/cli/build.js +1 -1
  19. package/dist/lib/cli/cleanup-users.js +1 -1
  20. package/dist/lib/cli/config-command.js +1 -1
  21. package/dist/lib/cli/config.js +1 -1
  22. package/dist/lib/cli/create-user.js +1 -1
  23. package/dist/lib/cli/grant-admin.js +1 -1
  24. package/dist/lib/cli/init.js +1 -1
  25. package/dist/lib/cli/jira.js +1 -1
  26. package/dist/lib/cli/license.js +1 -1
  27. package/dist/lib/cli/list-roles.js +1 -1
  28. package/dist/lib/cli/list-users.js +1 -1
  29. package/dist/lib/cli/server-manager.js +1 -1
  30. package/dist/lib/cli/set-password.js +1 -1
  31. package/dist/lib/compression-filter.js +1 -0
  32. package/dist/lib/config-migration.js +1 -1
  33. package/dist/lib/container-credential-sync.js +1 -1
  34. package/dist/lib/container-tokens.js +1 -1
  35. package/dist/lib/data-dir.js +1 -1
  36. package/dist/lib/deployment-history.js +1 -1
  37. package/dist/lib/deployment-service.js +1 -1
  38. package/dist/lib/docker-utils.js +1 -1
  39. package/dist/lib/email.js +1 -1
  40. package/dist/lib/emailTemplates.js +1 -1
  41. package/dist/lib/entitlement.js +1 -1
  42. package/dist/lib/external-connections.js +1 -1
  43. package/dist/lib/fetch-utils.js +1 -1
  44. package/dist/lib/git-commit-details-route.js +1 -1
  45. package/dist/lib/git-history-diff-guardrails.js +1 -1
  46. package/dist/lib/git-provider-service.js +1 -1
  47. package/dist/lib/git-provider-setup/github-setup-handler.js +1 -1
  48. package/dist/lib/git-provider-setup/index.js +1 -1
  49. package/dist/lib/git-provider-setup/setup-factory.js +1 -1
  50. package/dist/lib/git-provider-setup/setup-interface.js +1 -1
  51. package/dist/lib/git-providers/azure-devops-provider.js +1 -1
  52. package/dist/lib/git-providers/github-app-provider.js +1 -1
  53. package/dist/lib/git-providers/index.js +1 -1
  54. package/dist/lib/git-providers/provider-factory.js +1 -1
  55. package/dist/lib/git-providers/provider-interface.js +1 -1
  56. package/dist/lib/github-urls.js +1 -1
  57. package/dist/lib/group-objective-linking.js +1 -1
  58. package/dist/lib/ibmi-sync.js +1 -1
  59. package/dist/lib/jira-client.js +1 -1
  60. package/dist/lib/judge-blinding.js +1 -1
  61. package/dist/lib/logger.js +1 -1
  62. package/dist/lib/memory-utils.js +1 -1
  63. package/dist/lib/migration-to-scoped-rbac.js +1 -1
  64. package/dist/lib/model-fetcher.js +1 -1
  65. package/dist/lib/notifications.js +1 -1
  66. package/dist/lib/objective-context.js +1 -1
  67. package/dist/lib/oidc-auth.js +1 -1
  68. package/dist/lib/oidc-device-flow.js +1 -1
  69. package/dist/lib/passwordTokens.js +1 -1
  70. package/dist/lib/permission-resolver.js +1 -1
  71. package/dist/lib/pin-cascade.js +1 -1
  72. package/dist/lib/provider-accounts.js +1 -1
  73. package/dist/lib/provider-oauth.js +1 -1
  74. package/dist/lib/provider-profile.js +1 -1
  75. package/dist/lib/provider-token-refresh.js +1 -1
  76. package/dist/lib/rbac-user-state.js +1 -1
  77. package/dist/lib/request-url.js +1 -1
  78. package/dist/lib/rewind.js +1 -1
  79. package/dist/lib/role-definitions.js +1 -1
  80. package/dist/lib/roles.js +1 -1
  81. package/dist/lib/secrets.js +1 -1
  82. package/dist/lib/setup-repo-git-auth.js +1 -1
  83. package/dist/lib/state-capture.js +1 -1
  84. package/dist/lib/static-files.js +1 -1
  85. package/dist/lib/task-aliases.js +1 -1
  86. package/dist/lib/task-name-format.js +1 -1
  87. package/dist/lib/task-name-generator.js +1 -1
  88. package/dist/lib/task-source-metadata.js +1 -1
  89. package/dist/lib/teams.js +1 -1
  90. package/dist/lib/user-git-oauth.js +1 -1
  91. package/dist/lib/user-git-tokens.js +1 -1
  92. package/dist/lib/users.js +1 -1
  93. package/dist/middleware/requireAuth.js +1 -1
  94. package/dist/middleware/requireInit.js +1 -1
  95. package/dist/middleware/requirePermission.js +1 -1
  96. package/dist/package.json +1 -1
  97. package/dist/playwright.config.js +1 -1
  98. package/dist/playwright.task-terminal.config.js +1 -1
  99. package/dist/routes/apiKeys.js +1 -1
  100. package/dist/routes/auth-oidc.js +1 -1
  101. package/dist/routes/auth.js +1 -1
  102. package/dist/routes/automations.js +1 -1
  103. package/dist/routes/bindings.js +1 -1
  104. package/dist/routes/build.js +1 -1
  105. package/dist/routes/containers.js +1 -1
  106. package/dist/routes/deploy-task.js +1 -1
  107. package/dist/routes/environment-management.js +1 -1
  108. package/dist/routes/environments.js +1 -1
  109. package/dist/routes/external-skills.js +1 -1
  110. package/dist/routes/git-credentials.js +1 -1
  111. package/dist/routes/git-oauth.js +1 -1
  112. package/dist/routes/git-provider-setup.js +1 -1
  113. package/dist/routes/health.js +1 -1
  114. package/dist/routes/jira.js +1 -1
  115. package/dist/routes/logs.js +1 -0
  116. package/dist/routes/objective-management.js +1 -1
  117. package/dist/routes/password.js +1 -1
  118. package/dist/routes/prompt.js +1 -1
  119. package/dist/routes/provider-auth.js +1 -1
  120. package/dist/routes/qa.js +1 -1
  121. package/dist/routes/roles.js +1 -1
  122. package/dist/routes/settings.js +1 -1
  123. package/dist/routes/skill-management.js +1 -1
  124. package/dist/routes/skills.js +1 -1
  125. package/dist/routes/stats.js +1 -0
  126. package/dist/routes/tasks.js +1 -1
  127. package/dist/routes/teams.js +1 -1
  128. package/dist/routes/templates.js +1 -1
  129. package/dist/routes/test-task.js +1 -1
  130. package/dist/routes/test.js +1 -1
  131. package/dist/routes/users.js +1 -1
  132. package/dist/routes/visualizations.js +1 -1
  133. package/dist/scripts/create-user.js +1 -1
  134. package/dist/scripts/migrate-config-to-data-dir.js +1 -1
  135. package/dist/start.js +1 -1
  136. package/dist/web-ui/public/activity-detail-modal.js +1 -1
  137. package/dist/web-ui/public/activity-feed.js +1 -1
  138. package/dist/web-ui/public/activity-formatters.js +1 -1
  139. package/dist/web-ui/public/admin.css +682 -0
  140. package/dist/web-ui/public/admin.html +648 -0
  141. package/dist/web-ui/public/admin.js +1 -0
  142. package/dist/web-ui/public/agent-event-parser.js +1 -1
  143. package/dist/web-ui/public/app.js +1 -1
  144. package/dist/web-ui/public/approve-dialog.js +1 -1
  145. package/dist/web-ui/public/automation-links.js +1 -1
  146. package/dist/web-ui/public/automation-schedule.js +1 -1
  147. package/dist/web-ui/public/comments-widget.js +1 -1
  148. package/dist/web-ui/public/diff-utils.js +1 -1
  149. package/dist/web-ui/public/environments.html +3 -3
  150. package/dist/web-ui/public/environments.js +1 -1
  151. package/dist/web-ui/public/feedback-widget.js +1 -1
  152. package/dist/web-ui/public/file-selection-tree.js +1 -1
  153. package/dist/web-ui/public/git-history-lazy-utils.js +1 -1
  154. package/dist/web-ui/public/git-history.html +2 -2
  155. package/dist/web-ui/public/git-history.js +1 -1
  156. package/dist/web-ui/public/git-status.js +1 -1
  157. package/dist/web-ui/public/ibmi-file-filter.js +1 -1
  158. package/dist/web-ui/public/index.html +2 -170
  159. package/dist/web-ui/public/index.js +1 -1
  160. package/dist/web-ui/public/login.js +1 -1
  161. package/dist/web-ui/public/markdown-editor.js +1 -1
  162. package/dist/web-ui/public/markdown-file-editor.js +1 -1
  163. package/dist/web-ui/public/modal-maximize.js +1 -1
  164. package/dist/web-ui/public/notifications.js +1 -1
  165. package/dist/web-ui/public/permissions.js +1 -1
  166. package/dist/web-ui/public/pr-dialog.js +1 -1
  167. package/dist/web-ui/public/roles.html +2 -2
  168. package/dist/web-ui/public/roles.js +1 -1
  169. package/dist/web-ui/public/settings.html +66 -4
  170. package/dist/web-ui/public/settings.js +1 -1
  171. package/dist/web-ui/public/setup-password.js +1 -1
  172. package/dist/web-ui/public/skills.html +2 -2
  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 +10 -2
  177. package/dist/web-ui/public/task-judging-helpers.js +1 -1
  178. package/dist/web-ui/public/task.js +1 -1
  179. package/dist/web-ui/public/teams.html +2 -2
  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.html +2 -2
  184. package/dist/web-ui/public/users.js +1 -1
  185. package/dist/web-ui/public/variant-grouping.js +1 -1
  186. package/package.json +1 -1
  187. package/dist/web-ui/public/server-health.js +0 -1
@@ -1 +1 @@
1
- let monacoLoadPromise=null;async function ensureMonacoLoaded(){if(typeof monaco!=='undefined')return;if(monacoLoadPromise)return monacoLoadPromise;const _0x35351f=document['querySelector']('script[src*=\x22monaco-editor\x22][src*=\x22loader.js\x22]');if(_0x35351f)return monacoLoadPromise=new Promise((_0x33a0f3,_0x5a198b)=>{const _0x28d520=setInterval(()=>{typeof monaco!=='undefined'&&(clearInterval(_0x28d520),_0x33a0f3());},0x32);setTimeout(()=>{clearInterval(_0x28d520),_0x5a198b(new Error('Monaco\x20loading\x20timeout'));},0x2710);}),monacoLoadPromise;return monacoLoadPromise=new Promise((_0x26be08,_0x45bfb9)=>{const _0x5abbd8=document['createElement']('script');_0x5abbd8['src']='/vendor/monaco-editor/0.45.0/min/vs/loader.js',_0x5abbd8['onload']=()=>{require['config']({'paths':{'vs':'/vendor/monaco-editor/0.45.0/min/vs'}}),require(['vs/editor/editor.main'],()=>{_0x26be08();});},_0x5abbd8['onerror']=()=>_0x45bfb9(new Error('Failed\x20to\x20load\x20Monaco\x20Editor')),document['head']['appendChild'](_0x5abbd8);}),monacoLoadPromise;}function getMonacoTheme(){const _0xca9ab=document['documentElement']['getAttribute']('data-theme')==='dark';return _0xca9ab?'vs-dark':'vs';}function isMarkdownFile(_0x24d72c){if(!_0x24d72c)return![];const _0x37356e=_0x24d72c['split']('.')['pop']()['toLowerCase']();return _0x37356e==='md'||_0x37356e==='markdown';}function createMarkdownFileEditor(_0x10718d){const {container:_0xc36681,content:content='',readOnly:readOnly=![],height:height='400px',onChange:onChange=null,placeholder:placeholder='Enter\x20markdown\x20content...',enableModeToggle:enableModeToggle=!![],initialMode:initialMode='visual'}=_0x10718d;_0xc36681['innerHTML']='';const _0x22b451=document['createElement']('div');_0x22b451['className']='markdown-file-editor-wrapper',_0x22b451['style']['height']=height,_0x22b451['style']['display']='flex',_0x22b451['style']['flexDirection']='column',_0x22b451['style']['border']='1px\x20solid\x20var(--color-border)',_0x22b451['style']['borderRadius']='var(--radius-small)',_0x22b451['style']['overflow']='hidden';const _0x4d65a0=document['createElement']('textarea');_0x4d65a0['style']['display']='none',_0x4d65a0['value']=content,_0x22b451['appendChild'](_0x4d65a0),_0xc36681['appendChild'](_0x22b451);const _0x4a95da=new window['MarkdownEditor'](_0x4d65a0,{'placeholder':placeholder,'editable':!readOnly,'minHeight':'100%','toolbar':!readOnly,'sourceToggle':!readOnly&&enableModeToggle!==![],'sourceLineNumbers':!![],'onChange':_0xb0dea1=>{onChange&&onChange(_0xb0dea1);}});_0x4a95da['container']&&(_0x4a95da['container']['style']['flex']='1',_0x4a95da['container']['style']['display']='flex',_0x4a95da['container']['style']['flexDirection']='column',_0x4a95da['container']['style']['overflow']='hidden');_0x4a95da['editor']&&(_0x4a95da['editor']['style']['flex']='1',_0x4a95da['editor']['style']['overflow']='auto',_0x4a95da['editor']['style']['minHeight']='0',_0x4a95da['editor']['style']['border']='none',_0x4a95da['editor']['style']['borderRadius']='0',_0x4a95da['editor']['style']['padding']='16px',_0x4a95da['editor']['style']['fontSize']='14px',_0x4a95da['editor']['style']['lineHeight']='1.6');_0x4a95da['toolbar']&&(_0x4a95da['toolbar']['style']['borderRadius']='0',_0x4a95da['toolbar']['style']['flexShrink']='0');content&&_0x4a95da['setMarkdown'](content);initialMode==='source'&&!readOnly&&enableModeToggle!==![]&&setTimeout(()=>_0x4a95da['setMode']('source'),0x0);const _0x1d1a8a={'getValue':()=>_0x4a95da['getValue'](),'setValue':_0xa54d94=>_0x4a95da['setValue'](_0xa54d94||''),'focus':()=>_0x4a95da['focus'](),'setEditable':_0x35d66f=>_0x4a95da['setEditable'](_0x35d66f),'destroy':()=>{_0x4a95da['destroy'](),_0xc36681['innerHTML']='';},'getMode':()=>_0x4a95da['getMode'](),'setMode':_0x218b69=>_0x4a95da['setMode'](_0x218b69),'toggleMode':()=>_0x4a95da['toggleMode'](),'_visualEditor':_0x4a95da,'_getSourceEditor':()=>_0x4a95da['_monacoEditor'],'_container':_0xc36681,'_isMarkdownFileEditor':!![],'_hasModeToggle':enableModeToggle};return _0x1d1a8a;}const markdownFileEditors=new Map();function getOrCreateMarkdownFileEditor(_0x2a6142,_0x301a0e,_0x25b455=![],_0x5cc52b='400px',_0x3e22f5=null,_0x2a5cdc={}){const _0x37a4a6=document['getElementById'](_0x2a6142);if(!_0x37a4a6)return console['error']('Container\x20not\x20found:\x20'+_0x2a6142),null;const _0x37f198=markdownFileEditors['get'](_0x2a6142);if(_0x37f198){try{_0x37f198['destroy']();}catch(_0x19af6b){console['warn']('Failed\x20to\x20destroy\x20existing\x20markdown\x20editor:',_0x19af6b);}markdownFileEditors['delete'](_0x2a6142);}const _0x8335c5=createMarkdownFileEditor({'container':_0x37a4a6,'content':_0x301a0e,'readOnly':_0x25b455,'height':_0x5cc52b,'onChange':_0x3e22f5,..._0x2a5cdc});return markdownFileEditors['set'](_0x2a6142,_0x8335c5),_0x8335c5;}function getMarkdownFileEditorValue(_0x2130fb){const _0x4613c1=markdownFileEditors['get'](_0x2130fb);if(!_0x4613c1)return null;return _0x4613c1['getValue']();}function setMarkdownFileEditorValue(_0x1e907f,_0xff072){const _0x40990d=markdownFileEditors['get'](_0x1e907f);_0x40990d&&_0x40990d['setValue'](_0xff072||'');}function disposeMarkdownFileEditor(_0x326c60){const _0xc28ffa=markdownFileEditors['get'](_0x326c60);if(_0xc28ffa){try{_0xc28ffa['destroy']();}catch(_0x551c9d){console['warn']('Failed\x20to\x20dispose\x20markdown\x20editor:',_0x551c9d);}markdownFileEditors['delete'](_0x326c60);}}function hasMarkdownFileEditor(_0x1b47fd){return markdownFileEditors['has'](_0x1b47fd);}function getMarkdownFileEditorMode(_0x42948a){const _0x450188=markdownFileEditors['get'](_0x42948a);if(!_0x450188||!_0x450188['getMode'])return null;return _0x450188['getMode']();}function setMarkdownFileEditorMode(_0x1ac0b1,_0x32fbf2){const _0xec78ee=markdownFileEditors['get'](_0x1ac0b1);_0xec78ee&&_0xec78ee['setMode']&&_0xec78ee['setMode'](_0x32fbf2);}typeof window!=='undefined'&&(window['MarkdownFileEditor']={'isMarkdownFile':isMarkdownFile,'create':createMarkdownFileEditor,'getOrCreate':getOrCreateMarkdownFileEditor,'getValue':getMarkdownFileEditorValue,'setValue':setMarkdownFileEditorValue,'dispose':disposeMarkdownFileEditor,'has':hasMarkdownFileEditor,'getMode':getMarkdownFileEditorMode,'setMode':setMarkdownFileEditorMode,'editors':markdownFileEditors,'ensureMonacoLoaded':ensureMonacoLoaded});
1
+ let monacoLoadPromise=null;async function ensureMonacoLoaded(){if(typeof monaco!=='undefined')return;if(monacoLoadPromise)return monacoLoadPromise;const _0x3a4ac3=document['querySelector']('script[src*=\x22monaco-editor\x22][src*=\x22loader.js\x22]');if(_0x3a4ac3)return monacoLoadPromise=new Promise((_0x351881,_0x26165b)=>{const _0x41e49d=setInterval(()=>{typeof monaco!=='undefined'&&(clearInterval(_0x41e49d),_0x351881());},0x32);setTimeout(()=>{clearInterval(_0x41e49d),_0x26165b(new Error('Monaco\x20loading\x20timeout'));},0x2710);}),monacoLoadPromise;return monacoLoadPromise=new Promise((_0xe7d6f,_0x23a11e)=>{const _0x1bd0ec=document['createElement']('script');_0x1bd0ec['src']='/vendor/monaco-editor/0.45.0/min/vs/loader.js',_0x1bd0ec['onload']=()=>{require['config']({'paths':{'vs':'/vendor/monaco-editor/0.45.0/min/vs'}}),require(['vs/editor/editor.main'],()=>{_0xe7d6f();});},_0x1bd0ec['onerror']=()=>_0x23a11e(new Error('Failed\x20to\x20load\x20Monaco\x20Editor')),document['head']['appendChild'](_0x1bd0ec);}),monacoLoadPromise;}function getMonacoTheme(){const _0x544dac=document['documentElement']['getAttribute']('data-theme')==='dark';return _0x544dac?'vs-dark':'vs';}function isMarkdownFile(_0x22ce72){if(!_0x22ce72)return![];const _0x1c5e59=_0x22ce72['split']('.')['pop']()['toLowerCase']();return _0x1c5e59==='md'||_0x1c5e59==='markdown';}function createMarkdownFileEditor(_0x190c86){const {container:_0x591aef,content:content='',readOnly:readOnly=![],height:height='400px',onChange:onChange=null,placeholder:placeholder='Enter\x20markdown\x20content...',enableModeToggle:enableModeToggle=!![],initialMode:initialMode='visual'}=_0x190c86;_0x591aef['innerHTML']='';const _0x2ff62c=document['createElement']('div');_0x2ff62c['className']='markdown-file-editor-wrapper',_0x2ff62c['style']['height']=height,_0x2ff62c['style']['display']='flex',_0x2ff62c['style']['flexDirection']='column',_0x2ff62c['style']['border']='1px\x20solid\x20var(--color-border)',_0x2ff62c['style']['borderRadius']='var(--radius-small)',_0x2ff62c['style']['overflow']='hidden';const _0x39aa35=document['createElement']('textarea');_0x39aa35['style']['display']='none',_0x39aa35['value']=content,_0x2ff62c['appendChild'](_0x39aa35),_0x591aef['appendChild'](_0x2ff62c);const _0x3fdd98=new window['MarkdownEditor'](_0x39aa35,{'placeholder':placeholder,'editable':!readOnly,'minHeight':'100%','toolbar':!readOnly,'sourceToggle':!readOnly&&enableModeToggle!==![],'sourceLineNumbers':!![],'onChange':_0x8d961=>{onChange&&onChange(_0x8d961);}});_0x3fdd98['container']&&(_0x3fdd98['container']['style']['flex']='1',_0x3fdd98['container']['style']['display']='flex',_0x3fdd98['container']['style']['flexDirection']='column',_0x3fdd98['container']['style']['overflow']='hidden');_0x3fdd98['editor']&&(_0x3fdd98['editor']['style']['flex']='1',_0x3fdd98['editor']['style']['overflow']='auto',_0x3fdd98['editor']['style']['minHeight']='0',_0x3fdd98['editor']['style']['border']='none',_0x3fdd98['editor']['style']['borderRadius']='0',_0x3fdd98['editor']['style']['padding']='16px',_0x3fdd98['editor']['style']['fontSize']='14px',_0x3fdd98['editor']['style']['lineHeight']='1.6');_0x3fdd98['toolbar']&&(_0x3fdd98['toolbar']['style']['borderRadius']='0',_0x3fdd98['toolbar']['style']['flexShrink']='0');content&&_0x3fdd98['setMarkdown'](content);initialMode==='source'&&!readOnly&&enableModeToggle!==![]&&setTimeout(()=>_0x3fdd98['setMode']('source'),0x0);const _0xe11a0d={'getValue':()=>_0x3fdd98['getValue'](),'setValue':_0x2deb6a=>_0x3fdd98['setValue'](_0x2deb6a||''),'focus':()=>_0x3fdd98['focus'](),'setEditable':_0x5289d2=>_0x3fdd98['setEditable'](_0x5289d2),'destroy':()=>{_0x3fdd98['destroy'](),_0x591aef['innerHTML']='';},'getMode':()=>_0x3fdd98['getMode'](),'setMode':_0x2e84e2=>_0x3fdd98['setMode'](_0x2e84e2),'toggleMode':()=>_0x3fdd98['toggleMode'](),'_visualEditor':_0x3fdd98,'_getSourceEditor':()=>_0x3fdd98['_monacoEditor'],'_container':_0x591aef,'_isMarkdownFileEditor':!![],'_hasModeToggle':enableModeToggle};return _0xe11a0d;}const markdownFileEditors=new Map();function getOrCreateMarkdownFileEditor(_0x3e47bb,_0x163b84,_0x1c6975=![],_0x56d4f8='400px',_0x4079de=null,_0x5e0a18={}){const _0xdb52aa=document['getElementById'](_0x3e47bb);if(!_0xdb52aa)return console['error']('Container\x20not\x20found:\x20'+_0x3e47bb),null;const _0x1c19d5=markdownFileEditors['get'](_0x3e47bb);if(_0x1c19d5){try{_0x1c19d5['destroy']();}catch(_0x3554ae){console['warn']('Failed\x20to\x20destroy\x20existing\x20markdown\x20editor:',_0x3554ae);}markdownFileEditors['delete'](_0x3e47bb);}const _0x41fb4e=createMarkdownFileEditor({'container':_0xdb52aa,'content':_0x163b84,'readOnly':_0x1c6975,'height':_0x56d4f8,'onChange':_0x4079de,..._0x5e0a18});return markdownFileEditors['set'](_0x3e47bb,_0x41fb4e),_0x41fb4e;}function getMarkdownFileEditorValue(_0x142ad4){const _0x332baf=markdownFileEditors['get'](_0x142ad4);if(!_0x332baf)return null;return _0x332baf['getValue']();}function setMarkdownFileEditorValue(_0x49a257,_0x1898f6){const _0x1151b8=markdownFileEditors['get'](_0x49a257);_0x1151b8&&_0x1151b8['setValue'](_0x1898f6||'');}function disposeMarkdownFileEditor(_0x247aaa){const _0x2c0abe=markdownFileEditors['get'](_0x247aaa);if(_0x2c0abe){try{_0x2c0abe['destroy']();}catch(_0x23efab){console['warn']('Failed\x20to\x20dispose\x20markdown\x20editor:',_0x23efab);}markdownFileEditors['delete'](_0x247aaa);}}function hasMarkdownFileEditor(_0x81345f){return markdownFileEditors['has'](_0x81345f);}function getMarkdownFileEditorMode(_0x9f5ba2){const _0x2539c9=markdownFileEditors['get'](_0x9f5ba2);if(!_0x2539c9||!_0x2539c9['getMode'])return null;return _0x2539c9['getMode']();}function setMarkdownFileEditorMode(_0x50c405,_0x169261){const _0x55c247=markdownFileEditors['get'](_0x50c405);_0x55c247&&_0x55c247['setMode']&&_0x55c247['setMode'](_0x169261);}typeof window!=='undefined'&&(window['MarkdownFileEditor']={'isMarkdownFile':isMarkdownFile,'create':createMarkdownFileEditor,'getOrCreate':getOrCreateMarkdownFileEditor,'getValue':getMarkdownFileEditorValue,'setValue':setMarkdownFileEditorValue,'dispose':disposeMarkdownFileEditor,'has':hasMarkdownFileEditor,'getMode':getMarkdownFileEditorMode,'setMode':setMarkdownFileEditorMode,'editors':markdownFileEditors,'ensureMonacoLoaded':ensureMonacoLoaded});
@@ -1 +1 @@
1
- const DEFAULT_DURATION_MS=0xfa;function prefersReducedMotion(){try{return window['matchMedia']&&window['matchMedia']('(prefers-reduced-motion:\x20reduce)')['matches'];}catch{return![];}}function safeCancelAnimations(_0x36cacc){if(!_0x36cacc||typeof _0x36cacc['getAnimations']!=='function')return;try{_0x36cacc['getAnimations']()['forEach'](_0x46d44f=>_0x46d44f['cancel']());}catch{}}function animateRestoreFlip({contentEl:_0x51b0f6,fromRect:_0xaea80b,toRect:_0x11880a,durationMs:_0x2d422d}){if(!_0x51b0f6)return;if(!_0xaea80b||!_0x11880a)return;if(prefersReducedMotion())return;const _0x1dfa28=_0x11880a['width']||0x0,_0x261cab=_0x11880a['height']||0x0,_0x3f4f74=_0xaea80b['width']||0x0,_0x4c930e=_0xaea80b['height']||0x0;if(_0x1dfa28<=0x0||_0x261cab<=0x0||_0x3f4f74<=0x0||_0x4c930e<=0x0)return;const _0xd1f92f=_0xaea80b['left']-_0x11880a['left'],_0x35de53=_0xaea80b['top']-_0x11880a['top'],_0x1515b2=_0x3f4f74/_0x1dfa28,_0x19f086=_0x4c930e/_0x261cab;if(!Number['isFinite'](_0xd1f92f)||!Number['isFinite'](_0x35de53)||!Number['isFinite'](_0x1515b2)||!Number['isFinite'](_0x19f086))return;safeCancelAnimations(_0x51b0f6);const _0x36be2c=_0x51b0f6['style']['transition'],_0x59c820=_0x51b0f6['style']['transformOrigin'],_0x4c2a15=_0x51b0f6['style']['willChange'];_0x51b0f6['style']['transition']='none',_0x51b0f6['style']['transformOrigin']='top\x20left',_0x51b0f6['style']['willChange']='transform';const _0x5474c9='translate('+_0xd1f92f+'px,\x20'+_0x35de53+'px)\x20scale('+_0x1515b2+',\x20'+_0x19f086+')',_0x2d1263=_0x51b0f6['animate']([{'transform':_0x5474c9},{'transform':'none'}],{'duration':_0x2d422d,'easing':'ease','fill':'both'}),_0x888d96=()=>{_0x51b0f6['style']['transition']=_0x36be2c,_0x51b0f6['style']['transformOrigin']=_0x59c820,_0x51b0f6['style']['willChange']=_0x4c2a15;};_0x2d1263['addEventListener']('finish',_0x888d96,{'once':!![]}),_0x2d1263['addEventListener']('cancel',_0x888d96,{'once':!![]});}export function toggleModalMaximize(_0x2cfcc7,_0xe53915={}){if(!_0x2cfcc7)return;const {storageKey:_0x4e51c9,updateIcon:_0x18858b,onAfterToggle:_0x376811,durationMs:durationMs=DEFAULT_DURATION_MS}=_0xe53915,_0x1bd509=_0x2cfcc7['querySelector']('.modal-content'),_0x195f46=_0x2cfcc7['classList']['contains']('maximized'),_0x3e19f0=!_0x195f46;if(!_0x1bd509){_0x2cfcc7['classList']['toggle']('maximized'),_0x18858b?.(_0x3e19f0),_0x376811?.(_0x3e19f0);if(_0x4e51c9)try{localStorage['setItem'](_0x4e51c9,String(_0x3e19f0));}catch{}return;}if(_0x195f46&&!prefersReducedMotion()){const _0x1e4e32=_0x1bd509['getBoundingClientRect']();_0x2cfcc7['classList']['remove']('maximized');const _0x52a638=_0x1bd509['getBoundingClientRect']();animateRestoreFlip({'contentEl':_0x1bd509,'fromRect':_0x1e4e32,'toRect':_0x52a638,'durationMs':durationMs});}else _0x2cfcc7['classList']['toggle']('maximized');_0x18858b?.(_0x3e19f0),_0x376811?.(_0x3e19f0);if(_0x4e51c9)try{localStorage['setItem'](_0x4e51c9,String(_0x3e19f0));}catch{}}
1
+ const DEFAULT_DURATION_MS=0xfa;function prefersReducedMotion(){try{return window['matchMedia']&&window['matchMedia']('(prefers-reduced-motion:\x20reduce)')['matches'];}catch{return![];}}function safeCancelAnimations(_0x26d64d){if(!_0x26d64d||typeof _0x26d64d['getAnimations']!=='function')return;try{_0x26d64d['getAnimations']()['forEach'](_0x14e998=>_0x14e998['cancel']());}catch{}}function animateRestoreFlip({contentEl:_0x3cf7c8,fromRect:_0x5dd367,toRect:_0x244914,durationMs:_0x218c40}){if(!_0x3cf7c8)return;if(!_0x5dd367||!_0x244914)return;if(prefersReducedMotion())return;const _0x3ea7de=_0x244914['width']||0x0,_0x176d6f=_0x244914['height']||0x0,_0x435a58=_0x5dd367['width']||0x0,_0x7617b9=_0x5dd367['height']||0x0;if(_0x3ea7de<=0x0||_0x176d6f<=0x0||_0x435a58<=0x0||_0x7617b9<=0x0)return;const _0x54ab54=_0x5dd367['left']-_0x244914['left'],_0x43e1bb=_0x5dd367['top']-_0x244914['top'],_0x23198e=_0x435a58/_0x3ea7de,_0x3649a8=_0x7617b9/_0x176d6f;if(!Number['isFinite'](_0x54ab54)||!Number['isFinite'](_0x43e1bb)||!Number['isFinite'](_0x23198e)||!Number['isFinite'](_0x3649a8))return;safeCancelAnimations(_0x3cf7c8);const _0x1e206f=_0x3cf7c8['style']['transition'],_0x89d9c7=_0x3cf7c8['style']['transformOrigin'],_0x5222ec=_0x3cf7c8['style']['willChange'];_0x3cf7c8['style']['transition']='none',_0x3cf7c8['style']['transformOrigin']='top\x20left',_0x3cf7c8['style']['willChange']='transform';const _0x157ecc='translate('+_0x54ab54+'px,\x20'+_0x43e1bb+'px)\x20scale('+_0x23198e+',\x20'+_0x3649a8+')',_0x1aee6e=_0x3cf7c8['animate']([{'transform':_0x157ecc},{'transform':'none'}],{'duration':_0x218c40,'easing':'ease','fill':'both'}),_0x2d88d8=()=>{_0x3cf7c8['style']['transition']=_0x1e206f,_0x3cf7c8['style']['transformOrigin']=_0x89d9c7,_0x3cf7c8['style']['willChange']=_0x5222ec;};_0x1aee6e['addEventListener']('finish',_0x2d88d8,{'once':!![]}),_0x1aee6e['addEventListener']('cancel',_0x2d88d8,{'once':!![]});}export function toggleModalMaximize(_0x469bc6,_0x532889={}){if(!_0x469bc6)return;const {storageKey:_0x144918,updateIcon:_0x1e5d89,onAfterToggle:_0x2d3556,durationMs:durationMs=DEFAULT_DURATION_MS}=_0x532889,_0x5e87d2=_0x469bc6['querySelector']('.modal-content'),_0x34038d=_0x469bc6['classList']['contains']('maximized'),_0x274bad=!_0x34038d;if(!_0x5e87d2){_0x469bc6['classList']['toggle']('maximized'),_0x1e5d89?.(_0x274bad),_0x2d3556?.(_0x274bad);if(_0x144918)try{localStorage['setItem'](_0x144918,String(_0x274bad));}catch{}return;}if(_0x34038d&&!prefersReducedMotion()){const _0x362b19=_0x5e87d2['getBoundingClientRect']();_0x469bc6['classList']['remove']('maximized');const _0x572592=_0x5e87d2['getBoundingClientRect']();animateRestoreFlip({'contentEl':_0x5e87d2,'fromRect':_0x362b19,'toRect':_0x572592,'durationMs':durationMs});}else _0x469bc6['classList']['toggle']('maximized');_0x1e5d89?.(_0x274bad),_0x2d3556?.(_0x274bad);if(_0x144918)try{localStorage['setItem'](_0x144918,String(_0x274bad));}catch{}}
@@ -1 +1 @@
1
- export const NotificationManager={'isSupported'(){return'Notification'in window;},'isEnabled'(){if(!this['isSupported']())return![];return localStorage['getItem']('notifications-enabled')==='true';},'setEnabled'(_0x5ebf31){localStorage['setItem']('notifications-enabled',_0x5ebf31?'true':'false');},'getPermission'(){if(!this['isSupported']())return'unsupported';return Notification['permission'];},async 'requestPermission'(){if(!this['isSupported']())return'unsupported';if(Notification['permission']==='granted')return'granted';if(Notification['permission']==='denied')return'denied';try{const _0x253263=await Notification['requestPermission']();return _0x253263;}catch(_0x5824d4){return console['error']('Failed\x20to\x20request\x20notification\x20permission:',_0x5824d4),'denied';}},async 'show'(_0x12bd15,_0x59176f={}){if(!this['isEnabled']())return null;if(!this['isSupported']())return console['warn']('Notifications\x20are\x20not\x20supported\x20in\x20this\x20browser'),null;if(Notification['permission']!=='granted')return console['warn']('Notification\x20permission\x20not\x20granted'),null;try{const _0x22fb48=new Notification(_0x12bd15,{'icon':_0x59176f['icon']||'/favicon.ico','badge':_0x59176f['badge']||'/favicon.ico','body':_0x59176f['body']||'','tag':_0x59176f['tag']||'','requireInteraction':_0x59176f['requireInteraction']||![],'silent':_0x59176f['silent']||![],'data':_0x59176f['data']||{}});_0x59176f['onClick']&&(_0x22fb48['onclick']=_0x403dea=>{_0x403dea['preventDefault'](),window['focus'](),_0x59176f['onClick'](_0x403dea,_0x22fb48),_0x22fb48['close']();});if(!_0x59176f['requireInteraction']){const _0x3183cf=_0x59176f['duration']||0x1388;setTimeout(()=>{_0x22fb48['close']();},_0x3183cf);}return _0x22fb48;}catch(_0x219d2){return console['error']('Failed\x20to\x20show\x20notification:',_0x219d2),null;}},async 'notifyTaskComplete'(_0x98c2a2){const _0x2e434e=_0x98c2a2['exitCode']!==undefined?_0x98c2a2['exitCode']:_0x98c2a2['exit_code'],_0x2c80fb=_0x98c2a2['status']==='completed'&&_0x2e434e===0x0,_0x422ee2=_0x98c2a2['status']==='interrupted',_0x23eb70=_0x2c80fb?'✅\x20Task\x20Completed\x20Successfully':_0x422ee2?'⏹️\x20Task\x20Interrupted':'❌\x20Task\x20Failed';let _0x543cba;if(_0x98c2a2['taskType']==='test'){const _0x1c5ab7=_0x98c2a2['testName']||'Test',_0x55b6bf=_0x98c2a2['testDescription']||_0x98c2a2['description']||'';if(_0x55b6bf&&_0x55b6bf['length']>0x0){let _0x417b13=_0x55b6bf;_0x55b6bf['length']>0x50&&(_0x417b13=_0x55b6bf['substring'](0x0,0x4d)+'...'),_0x543cba='Test:\x20'+_0x1c5ab7+'\x20-\x20'+_0x417b13;}else _0x543cba='Test:\x20'+_0x1c5ab7;}else{if(_0x98c2a2['taskType']==='deploy'){const _0x5beebb=_0x98c2a2['deployProfile']||'Deploy',_0x18950f=_0x98c2a2['deployDescription']||_0x98c2a2['description']||'';if(_0x18950f&&_0x18950f['length']>0x0){let _0x4a7a11=_0x18950f;_0x18950f['length']>0x50&&(_0x4a7a11=_0x18950f['substring'](0x0,0x4d)+'...'),_0x543cba='Deploy:\x20'+_0x5beebb+'\x20-\x20'+_0x4a7a11;}else _0x543cba='Deploy:\x20'+_0x5beebb;}else{const _0x558b80=_0x98c2a2['name']?_0x98c2a2['name']['trim']():null,_0x1bcd3e=_0x98c2a2['envVars']?.['CODER_AGENT']||_0x98c2a2['envVars']?.['default_agent']||'Unknown',_0x495759=_0x1bcd3e['charAt'](0x0)['toUpperCase']()+_0x1bcd3e['slice'](0x1);let _0x230e0c,_0x4f8361=![];if(_0x98c2a2['followUpHistory']&&Array['isArray'](_0x98c2a2['followUpHistory'])&&_0x98c2a2['followUpHistory']['length']>0x0){const _0x5c12d8=_0x98c2a2['followUpHistory'][_0x98c2a2['followUpHistory']['length']-0x1];_0x230e0c=_0x5c12d8['instructions'],_0x4f8361=!![];}else _0x230e0c=_0x98c2a2['description']||_0x98c2a2['instructions']||_0x98c2a2['taskId'];_0x230e0c['length']>0x64&&(_0x230e0c=_0x230e0c['substring'](0x0,0x61)+'...');const _0x5d3df9=_0x4f8361?'[Follow-up]\x20':'';_0x558b80?_0x543cba=_0x558b80+'\x0a'+_0x495759+':\x20'+_0x5d3df9+_0x230e0c:_0x543cba=_0x495759+':\x20'+_0x5d3df9+_0x230e0c;}}return this['show'](_0x23eb70,{'body':_0x543cba,'tag':'task-'+_0x98c2a2['taskId'],'requireInteraction':![],'duration':0x1f40,'data':{'taskId':_0x98c2a2['taskId']},'onClick':(_0x5e4e52,_0x21b995)=>{window['open']('task.html?id='+_0x98c2a2['taskId'],'_blank');}});},'shouldNotify'(_0x1cc527,_0x5c3472){if(!this['isEnabled']())return![];if(_0x1cc527['status']!=='completed'&&_0x1cc527['status']!=='failed'&&_0x1cc527['status']!=='interrupted')return![];if(!_0x5c3472['has'](_0x1cc527['taskId']))return![];const _0x566f41='notified-'+_0x1cc527['taskId'];if(sessionStorage['getItem'](_0x566f41)==='true')return![];return!![];},'markNotified'(_0x4ef6f4){sessionStorage['setItem']('notified-'+_0x4ef6f4,'true');},'clearNotificationHistory'(){const _0x23ec14=[];for(let _0x41ba0e=0x0;_0x41ba0e<sessionStorage['length'];_0x41ba0e++){const _0x595fe3=sessionStorage['key'](_0x41ba0e);_0x595fe3['startsWith']('notified-')&&_0x23ec14['push'](_0x595fe3);}_0x23ec14['forEach'](_0x1522cb=>sessionStorage['removeItem'](_0x1522cb));}};
1
+ export const NotificationManager={'isSupported'(){return'Notification'in window;},'isEnabled'(){if(!this['isSupported']())return![];return localStorage['getItem']('notifications-enabled')==='true';},'setEnabled'(_0x1b828a){localStorage['setItem']('notifications-enabled',_0x1b828a?'true':'false');},'getPermission'(){if(!this['isSupported']())return'unsupported';return Notification['permission'];},async 'requestPermission'(){if(!this['isSupported']())return'unsupported';if(Notification['permission']==='granted')return'granted';if(Notification['permission']==='denied')return'denied';try{const _0x1e4f6b=await Notification['requestPermission']();return _0x1e4f6b;}catch(_0x3cbc77){return console['error']('Failed\x20to\x20request\x20notification\x20permission:',_0x3cbc77),'denied';}},async 'show'(_0x4c95b3,_0x34b143={}){if(!this['isEnabled']())return null;if(!this['isSupported']())return console['warn']('Notifications\x20are\x20not\x20supported\x20in\x20this\x20browser'),null;if(Notification['permission']!=='granted')return console['warn']('Notification\x20permission\x20not\x20granted'),null;try{const _0x371cc5=new Notification(_0x4c95b3,{'icon':_0x34b143['icon']||'/favicon.ico','badge':_0x34b143['badge']||'/favicon.ico','body':_0x34b143['body']||'','tag':_0x34b143['tag']||'','requireInteraction':_0x34b143['requireInteraction']||![],'silent':_0x34b143['silent']||![],'data':_0x34b143['data']||{}});_0x34b143['onClick']&&(_0x371cc5['onclick']=_0x2bd9f0=>{_0x2bd9f0['preventDefault'](),window['focus'](),_0x34b143['onClick'](_0x2bd9f0,_0x371cc5),_0x371cc5['close']();});if(!_0x34b143['requireInteraction']){const _0x52459e=_0x34b143['duration']||0x1388;setTimeout(()=>{_0x371cc5['close']();},_0x52459e);}return _0x371cc5;}catch(_0x2dc14f){return console['error']('Failed\x20to\x20show\x20notification:',_0x2dc14f),null;}},async 'notifyTaskComplete'(_0x3810f0){const _0x89e2b8=_0x3810f0['exitCode']!==undefined?_0x3810f0['exitCode']:_0x3810f0['exit_code'],_0x2823bd=_0x3810f0['status']==='completed'&&_0x89e2b8===0x0,_0x2a96b6=_0x3810f0['status']==='interrupted',_0x19e608=_0x2823bd?'✅\x20Task\x20Completed\x20Successfully':_0x2a96b6?'⏹️\x20Task\x20Interrupted':'❌\x20Task\x20Failed';let _0x334275;if(_0x3810f0['taskType']==='test'){const _0x3ff990=_0x3810f0['testName']||'Test',_0x3d5486=_0x3810f0['testDescription']||_0x3810f0['description']||'';if(_0x3d5486&&_0x3d5486['length']>0x0){let _0x2ce0cf=_0x3d5486;_0x3d5486['length']>0x50&&(_0x2ce0cf=_0x3d5486['substring'](0x0,0x4d)+'...'),_0x334275='Test:\x20'+_0x3ff990+'\x20-\x20'+_0x2ce0cf;}else _0x334275='Test:\x20'+_0x3ff990;}else{if(_0x3810f0['taskType']==='deploy'){const _0x4d6dab=_0x3810f0['deployProfile']||'Deploy',_0x28580a=_0x3810f0['deployDescription']||_0x3810f0['description']||'';if(_0x28580a&&_0x28580a['length']>0x0){let _0x3a5067=_0x28580a;_0x28580a['length']>0x50&&(_0x3a5067=_0x28580a['substring'](0x0,0x4d)+'...'),_0x334275='Deploy:\x20'+_0x4d6dab+'\x20-\x20'+_0x3a5067;}else _0x334275='Deploy:\x20'+_0x4d6dab;}else{const _0x50fb70=_0x3810f0['name']?_0x3810f0['name']['trim']():null,_0x1348f0=_0x3810f0['envVars']?.['CODER_AGENT']||_0x3810f0['envVars']?.['default_agent']||'Unknown',_0x11b31b=_0x1348f0['charAt'](0x0)['toUpperCase']()+_0x1348f0['slice'](0x1);let _0x3db438,_0x314141=![];if(_0x3810f0['followUpHistory']&&Array['isArray'](_0x3810f0['followUpHistory'])&&_0x3810f0['followUpHistory']['length']>0x0){const _0x4555e3=_0x3810f0['followUpHistory'][_0x3810f0['followUpHistory']['length']-0x1];_0x3db438=_0x4555e3['instructions'],_0x314141=!![];}else _0x3db438=_0x3810f0['description']||_0x3810f0['instructions']||_0x3810f0['taskId'];_0x3db438['length']>0x64&&(_0x3db438=_0x3db438['substring'](0x0,0x61)+'...');const _0x405ed4=_0x314141?'[Follow-up]\x20':'';_0x50fb70?_0x334275=_0x50fb70+'\x0a'+_0x11b31b+':\x20'+_0x405ed4+_0x3db438:_0x334275=_0x11b31b+':\x20'+_0x405ed4+_0x3db438;}}return this['show'](_0x19e608,{'body':_0x334275,'tag':'task-'+_0x3810f0['taskId'],'requireInteraction':![],'duration':0x1f40,'data':{'taskId':_0x3810f0['taskId']},'onClick':(_0xf61e5d,_0x2e8da6)=>{window['open']('task.html?id='+_0x3810f0['taskId'],'_blank');}});},'shouldNotify'(_0x1e1453,_0x5785db){if(!this['isEnabled']())return![];if(_0x1e1453['status']!=='completed'&&_0x1e1453['status']!=='failed'&&_0x1e1453['status']!=='interrupted')return![];if(!_0x5785db['has'](_0x1e1453['taskId']))return![];const _0x25d1fc='notified-'+_0x1e1453['taskId'];if(sessionStorage['getItem'](_0x25d1fc)==='true')return![];return!![];},'markNotified'(_0x3aad51){sessionStorage['setItem']('notified-'+_0x3aad51,'true');},'clearNotificationHistory'(){const _0x53b467=[];for(let _0x5c0664=0x0;_0x5c0664<sessionStorage['length'];_0x5c0664++){const _0x5e2bfd=sessionStorage['key'](_0x5c0664);_0x5e2bfd['startsWith']('notified-')&&_0x53b467['push'](_0x5e2bfd);}_0x53b467['forEach'](_0x540d62=>sessionStorage['removeItem'](_0x540d62));}};
@@ -1 +1 @@
1
- function permissionInSet(_0x57ded5,_0x7ebaa1){if(!_0x57ded5||!_0x7ebaa1)return![];if(_0x57ded5['includes']('*'))return!![];if(_0x57ded5['includes'](_0x7ebaa1))return!![];const [_0x1d309e]=_0x7ebaa1['split'](':');if(_0x57ded5['includes'](_0x1d309e+':*'))return!![];return![];}function hasServerPermission(_0x3b3cbd,_0x50ad76){const _0x4fb064=_0x3b3cbd?.['permissions']?.['server'];if(!_0x4fb064)return![];return permissionInSet(_0x4fb064,_0x50ad76);}function hasEnvPermission(_0x46bfe6,_0x2c8b78){if(hasServerPermission(_0x46bfe6,'*'))return!![];const _0x389019=_0x46bfe6?.['permissions']?.['environments'];if(!_0x389019)return![];for(const _0x1e5565 of Object['values'](_0x389019)){if(permissionInSet(_0x1e5565,_0x2c8b78))return!![];}return![];}function hasEnvPermissionOn(_0x44b3bd,_0xf455bf,_0x1b76a9){if(hasServerPermission(_0x44b3bd,'*'))return!![];const _0x3810f4=_0x44b3bd?.['permissions']?.['environments']?.[_0xf455bf];if(!_0x3810f4)return![];return permissionInSet(_0x3810f4,_0x1b76a9);}function hasTeamPermission(_0x4efdc6,_0x221402){if(hasServerPermission(_0x4efdc6,'*'))return!![];const _0x444024=_0x4efdc6?.['permissions']?.['teams'];if(!_0x444024)return![];for(const _0x42ac75 of Object['values'](_0x444024)){if(permissionInSet(_0x42ac75,_0x221402))return!![];}return![];}function hasAnyEnvironment(_0xa3b99a){if(hasServerPermission(_0xa3b99a,'*'))return!![];const _0x50534a=_0xa3b99a?.['permissions']?.['environments'];return _0x50534a!=null&&Object['keys'](_0x50534a)['length']>0x0;}window['Permissions']={'hasServerPermission':hasServerPermission,'hasEnvPermission':hasEnvPermission,'hasEnvPermissionOn':hasEnvPermissionOn,'hasTeamPermission':hasTeamPermission,'hasAnyEnvironment':hasAnyEnvironment};
1
+ function permissionInSet(_0x5f402c,_0x2b38e1){if(!_0x5f402c||!_0x2b38e1)return![];if(_0x5f402c['includes']('*'))return!![];if(_0x5f402c['includes'](_0x2b38e1))return!![];const [_0x4e2570]=_0x2b38e1['split'](':');if(_0x5f402c['includes'](_0x4e2570+':*'))return!![];return![];}function hasServerPermission(_0x45e609,_0x2a1f35){const _0x5ca277=_0x45e609?.['permissions']?.['server'];if(!_0x5ca277)return![];return permissionInSet(_0x5ca277,_0x2a1f35);}function hasEnvPermission(_0x103bf9,_0x2bf447){if(hasServerPermission(_0x103bf9,'*'))return!![];const _0x310f84=_0x103bf9?.['permissions']?.['environments'];if(!_0x310f84)return![];for(const _0x2170b3 of Object['values'](_0x310f84)){if(permissionInSet(_0x2170b3,_0x2bf447))return!![];}return![];}function hasEnvPermissionOn(_0x2f64d2,_0x2d5086,_0x3b9753){if(hasServerPermission(_0x2f64d2,'*'))return!![];const _0x161b6c=_0x2f64d2?.['permissions']?.['environments']?.[_0x2d5086];if(!_0x161b6c)return![];return permissionInSet(_0x161b6c,_0x3b9753);}function hasTeamPermission(_0x2e7cb9,_0x1fd79b){if(hasServerPermission(_0x2e7cb9,'*'))return!![];const _0x4de031=_0x2e7cb9?.['permissions']?.['teams'];if(!_0x4de031)return![];for(const _0x249f96 of Object['values'](_0x4de031)){if(permissionInSet(_0x249f96,_0x1fd79b))return!![];}return![];}function hasAnyEnvironment(_0x18a8f8){if(hasServerPermission(_0x18a8f8,'*'))return!![];const _0x5a210a=_0x18a8f8?.['permissions']?.['environments'];return _0x5a210a!=null&&Object['keys'](_0x5a210a)['length']>0x0;}window['Permissions']={'hasServerPermission':hasServerPermission,'hasEnvPermission':hasEnvPermission,'hasEnvPermissionOn':hasEnvPermissionOn,'hasTeamPermission':hasTeamPermission,'hasAnyEnvironment':hasAnyEnvironment};
@@ -1 +1 @@
1
- export function createPRDialogHTML(_0x187fba='',_0x4439bf={}){const _0x298602=_0x187fba,_0x579b0d=_0x4439bf['useTaskPageStyles']?'modal\x20profound-pr-modal':'profound-feedback-modal\x20profound-pr-modal',_0x2a178b=_0x4439bf['useTaskPageStyles']?'modal-warning':'pr-modal-warning',_0x2e5ecf=_0x4439bf['useTaskPageStyles']?'modal-error':'pr-modal-error';return'\x0a\x20\x20\x20\x20<div\x20id=\x22'+_0x298602+'pr-modal\x22\x20class=\x22'+_0x579b0d+'\x22\x20hidden>\x0a\x20\x20\x20\x20\x20\x20<div\x20class=\x22modal-overlay\x22></div>\x0a\x20\x20\x20\x20\x20\x20<div\x20class=\x22modal-content\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22modal-header\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<h2>Create\x20Pull\x20Request</h2>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22modal-close\x22\x20id=\x22'+_0x298602+'close-pr-modal\x22>&times;</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22modal-body\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20id=\x22'+_0x298602+'pr-error\x22\x20class=\x22'+_0x2e5ecf+'\x22\x20hidden>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22error-icon\x22>!</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20id=\x22'+_0x298602+'pr-error-text\x22></span>\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\x20id=\x22'+_0x298602+'pr-form-section\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22modal-section\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<label\x20for=\x22'+_0x298602+'pr-title\x22>Title:</label>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<input\x20type=\x22text\x22\x20id=\x22'+_0x298602+'pr-title\x22\x20class=\x22pr-title-input\x22\x20placeholder=\x22Enter\x20pull\x20request\x20title...\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22modal-section\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<label\x20for=\x22'+_0x298602+'pr-body\x22>Description:</label>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<textarea\x20id=\x22'+_0x298602+'pr-body\x22\x20class=\x22pr-body-input\x22\x20rows=\x226\x22\x20placeholder=\x22Enter\x20pull\x20request\x20description...\x22></textarea>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20id=\x22'+_0x298602+'pr-repos-section\x22\x20class=\x22modal-section\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<label>Target\x20Branches</label>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20id=\x22'+_0x298602+'pr-repos-list\x22\x20class=\x22pr-repos-list\x22></div>\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\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22modal-footer\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-ghost\x22\x20id=\x22'+_0x298602+'cancel-pr\x22>Cancel</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-primary\x22\x20id=\x22'+_0x298602+'confirm-pr\x22>Create\x20Pull\x20Request</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20</div>\x0a\x20\x20';}export class PRDialog{constructor(_0x10609d={}){this['prefix']=_0x10609d['prefix']||'',this['onSubmit']=_0x10609d['onSubmit'],this['onCancel']=_0x10609d['onCancel'],this['showToast']=_0x10609d['showToast']||(()=>{}),this['container']=_0x10609d['container']||document['body'],this['useTaskPageStyles']=_0x10609d['useTaskPageStyles']||![],this['baseUrl']=_0x10609d['baseUrl']||'',this['prData']=null,this['initialized']=![],this['isSubmitting']=![];}['init'](){if(this['initialized'])return;const _0x199aa7=document['createElement']('div');_0x199aa7['innerHTML']=createPRDialogHTML(this['prefix'],{'useTaskPageStyles':this['useTaskPageStyles']}),this['container']['appendChild'](_0x199aa7['firstElementChild']),this['_bindEvents'](),this['initialized']=!![];}['_el'](_0x2f8d00){return document['getElementById'](''+this['prefix']+_0x2f8d00);}['_bindEvents'](){this['_el']('close-pr-modal')?.['addEventListener']('click',()=>this['hide']()),this['_el']('cancel-pr')?.['addEventListener']('click',()=>this['hide']()),this['_el']('confirm-pr')?.['addEventListener']('click',()=>this['_handleSubmit']()),this['_el']('pr-modal')?.['addEventListener']('click',_0x25bff0=>{_0x25bff0['target']['id']===this['prefix']+'pr-modal'&&this['hide']();}),document['addEventListener']('keydown',_0x1f4c5d=>{_0x1f4c5d['key']==='Escape'&&!this['_el']('pr-modal')['hidden']&&this['hide']();});}async['show'](_0x50f7d2){if(!this['initialized'])this['init']();this['prData']=_0x50f7d2;const {taskId:_0x3b3614,repos:_0x542b3f,suggestedTitle:_0x590404,suggestedBody:_0x3f1e2d}=_0x50f7d2;return this['_el']('pr-title')['value']=_0x590404||'',this['_el']('pr-body')['value']=_0x3f1e2d||'',this['_el']('pr-error')['hidden']=!![],await this['_renderRepoSelectors'](_0x542b3f),this['_el']('pr-modal')['hidden']=![],new Promise(_0xa5eb8a=>{this['_dismissResolve']=_0xa5eb8a;});}async['_renderRepoSelectors'](_0x2e7d1e){const _0x211ee4=this['_el']('pr-repos-list');_0x211ee4['innerHTML']='';for(const _0x2a832b of _0x2e7d1e){if(!_0x2a832b['supportsPR'])continue;const _0xa04b5a=document['createElement']('div');_0xa04b5a['className']='pr-repo-selector';const _0x129ed4=document['createElement']('span');_0x129ed4['className']='pr-repo-name',_0x129ed4['textContent']=_0x2a832b['name'];const _0x5cad09=document['createElement']('span');_0x5cad09['className']='pr-base-branch',_0x5cad09['textContent']=_0x2a832b['base']||_0x2a832b['defaultBranch']||'main',_0x5cad09['dataset']['repo']=_0x2a832b['name'],_0x5cad09['dataset']['base']=_0x2a832b['base']||_0x2a832b['defaultBranch']||'main';const _0x2c214f=document['createElement']('span');_0x2c214f['className']='pr-arrow',_0x2c214f['textContent']='←';const _0x2119ec=document['createElement']('span');_0x2119ec['className']='pr-source-branch',_0x2119ec['textContent']=_0x2a832b['head']||'(head\x20branch)',_0xa04b5a['appendChild'](_0x129ed4),_0xa04b5a['appendChild'](_0x5cad09),_0xa04b5a['appendChild'](_0x2c214f),_0xa04b5a['appendChild'](_0x2119ec),_0x211ee4['appendChild'](_0xa04b5a);}}['hide'](){if(this['isSubmitting'])return;this['_el']('pr-modal')['hidden']=!![],this['onCancel']&&this['onCancel'](),this['_dismissResolve']&&(this['_dismissResolve'](),this['_dismissResolve']=null);}async['_handleSubmit'](){if(this['isSubmitting'])return;const _0x26190d=this['_el']('pr-title')['value']['trim'](),_0x2c766a=this['_el']('pr-body')['value']['trim']();if(!_0x26190d){this['_showError']('Pull\x20request\x20title\x20is\x20required');return;}const _0xd52324=[],_0x39af23=this['_el']('pr-repos-list')['querySelectorAll']('.pr-base-branch');for(const _0x4d6979 of _0x39af23){const _0x3d7185=_0x4d6979['dataset']['repo'],_0x205fcc=_0x4d6979['dataset']['base'],_0x278b09=this['prData']['repos']['find'](_0x4dea91=>_0x4dea91['name']===_0x3d7185);if(!_0x278b09)continue;_0xd52324['push']({'name':_0x3d7185,'title':_0x26190d,'body':_0x2c766a,'head':_0x278b09['head'],'base':_0x205fcc});}if(_0xd52324['length']===0x0){this['_showError']('No\x20repositories\x20selected');return;}this['isSubmitting']=!![],this['_el']('confirm-pr')['disabled']=!![],this['_el']('confirm-pr')['textContent']='Creating...';try{const _0x32073e=await this['onSubmit'](this['prData']['taskId'],_0xd52324),_0x4eda34=_0x32073e['results']['every'](_0x31b27c=>_0x31b27c['success']),_0x3ed316=_0x32073e['results']['some'](_0x5232ef=>_0x5232ef['success']);if(_0x4eda34)this['showToast']('Pull\x20requests\x20created\x20successfully','success');else{if(_0x3ed316)this['showToast']('Some\x20pull\x20requests\x20created\x20successfully','warning');else throw new Error('All\x20pull\x20request\x20creations\x20failed');}this['isSubmitting']=![],this['_el']('confirm-pr')['disabled']=![],this['_el']('confirm-pr')['textContent']='Create\x20Pull\x20Request',this['hide'](),window['refreshTask']&&window['refreshTask']({'withSpinner':![]});}catch(_0x355022){console['error']('PR\x20creation\x20failed:',_0x355022),this['_showError'](_0x355022['message']||'Failed\x20to\x20create\x20pull\x20requests'),this['isSubmitting']=![],this['_el']('confirm-pr')['disabled']=![],this['_el']('confirm-pr')['textContent']='Create\x20Pull\x20Request';}}['_showError'](_0x2903d1){this['_el']('pr-error-text')['textContent']=_0x2903d1,this['_el']('pr-error')['hidden']=![];}static['checkOAuthRedirect'](_0x5d0421){if(_0x5d0421['get']('source')==='pr'&&_0x5d0421['get']('git_connection')){const _0x3b8c96=sessionStorage['getItem']('pendingPRData');if(_0x3b8c96)try{const _0xd36c43=JSON['parse'](_0x3b8c96);if(Date['now']()-_0xd36c43['timestamp']<0xa*0x3c*0x3e8)return sessionStorage['removeItem']('pendingPRData'),_0xd36c43;}catch(_0x451dc7){console['error']('Failed\x20to\x20parse\x20pending\x20PR\x20data:',_0x451dc7);}}return null;}}
1
+ export function createPRDialogHTML(_0x154055='',_0x573ddf={}){const _0x229ffa=_0x154055,_0x8973d6=_0x573ddf['useTaskPageStyles']?'modal\x20profound-pr-modal':'profound-feedback-modal\x20profound-pr-modal',_0x339dca=_0x573ddf['useTaskPageStyles']?'modal-warning':'pr-modal-warning',_0x1db490=_0x573ddf['useTaskPageStyles']?'modal-error':'pr-modal-error';return'\x0a\x20\x20\x20\x20<div\x20id=\x22'+_0x229ffa+'pr-modal\x22\x20class=\x22'+_0x8973d6+'\x22\x20hidden>\x0a\x20\x20\x20\x20\x20\x20<div\x20class=\x22modal-overlay\x22></div>\x0a\x20\x20\x20\x20\x20\x20<div\x20class=\x22modal-content\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22modal-header\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<h2>Create\x20Pull\x20Request</h2>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22modal-close\x22\x20id=\x22'+_0x229ffa+'close-pr-modal\x22>&times;</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22modal-body\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20id=\x22'+_0x229ffa+'pr-error\x22\x20class=\x22'+_0x1db490+'\x22\x20hidden>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22error-icon\x22>!</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20id=\x22'+_0x229ffa+'pr-error-text\x22></span>\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\x20id=\x22'+_0x229ffa+'pr-form-section\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22modal-section\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<label\x20for=\x22'+_0x229ffa+'pr-title\x22>Title:</label>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<input\x20type=\x22text\x22\x20id=\x22'+_0x229ffa+'pr-title\x22\x20class=\x22pr-title-input\x22\x20placeholder=\x22Enter\x20pull\x20request\x20title...\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22modal-section\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<label\x20for=\x22'+_0x229ffa+'pr-body\x22>Description:</label>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<textarea\x20id=\x22'+_0x229ffa+'pr-body\x22\x20class=\x22pr-body-input\x22\x20rows=\x226\x22\x20placeholder=\x22Enter\x20pull\x20request\x20description...\x22></textarea>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20id=\x22'+_0x229ffa+'pr-repos-section\x22\x20class=\x22modal-section\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<label>Target\x20Branches</label>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20id=\x22'+_0x229ffa+'pr-repos-list\x22\x20class=\x22pr-repos-list\x22></div>\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\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22modal-footer\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-ghost\x22\x20id=\x22'+_0x229ffa+'cancel-pr\x22>Cancel</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-primary\x22\x20id=\x22'+_0x229ffa+'confirm-pr\x22>Create\x20Pull\x20Request</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20</div>\x0a\x20\x20';}export class PRDialog{constructor(_0x1ab46d={}){this['prefix']=_0x1ab46d['prefix']||'',this['onSubmit']=_0x1ab46d['onSubmit'],this['onCancel']=_0x1ab46d['onCancel'],this['showToast']=_0x1ab46d['showToast']||(()=>{}),this['container']=_0x1ab46d['container']||document['body'],this['useTaskPageStyles']=_0x1ab46d['useTaskPageStyles']||![],this['baseUrl']=_0x1ab46d['baseUrl']||'',this['prData']=null,this['initialized']=![],this['isSubmitting']=![];}['init'](){if(this['initialized'])return;const _0x2f1fad=document['createElement']('div');_0x2f1fad['innerHTML']=createPRDialogHTML(this['prefix'],{'useTaskPageStyles':this['useTaskPageStyles']}),this['container']['appendChild'](_0x2f1fad['firstElementChild']),this['_bindEvents'](),this['initialized']=!![];}['_el'](_0x41e741){return document['getElementById'](''+this['prefix']+_0x41e741);}['_bindEvents'](){this['_el']('close-pr-modal')?.['addEventListener']('click',()=>this['hide']()),this['_el']('cancel-pr')?.['addEventListener']('click',()=>this['hide']()),this['_el']('confirm-pr')?.['addEventListener']('click',()=>this['_handleSubmit']()),this['_el']('pr-modal')?.['addEventListener']('click',_0x347390=>{_0x347390['target']['id']===this['prefix']+'pr-modal'&&this['hide']();}),document['addEventListener']('keydown',_0x13ed5f=>{_0x13ed5f['key']==='Escape'&&!this['_el']('pr-modal')['hidden']&&this['hide']();});}async['show'](_0x31e0f5){if(!this['initialized'])this['init']();this['prData']=_0x31e0f5;const {taskId:_0x3eb609,repos:_0x5f28e1,suggestedTitle:_0x3c838d,suggestedBody:_0xa9bdf9}=_0x31e0f5;return this['_el']('pr-title')['value']=_0x3c838d||'',this['_el']('pr-body')['value']=_0xa9bdf9||'',this['_el']('pr-error')['hidden']=!![],await this['_renderRepoSelectors'](_0x5f28e1),this['_el']('pr-modal')['hidden']=![],new Promise(_0x24ed48=>{this['_dismissResolve']=_0x24ed48;});}async['_renderRepoSelectors'](_0x5ee53f){const _0x26c969=this['_el']('pr-repos-list');_0x26c969['innerHTML']='';for(const _0x959fe4 of _0x5ee53f){if(!_0x959fe4['supportsPR'])continue;const _0x237337=document['createElement']('div');_0x237337['className']='pr-repo-selector';const _0x5371dd=document['createElement']('span');_0x5371dd['className']='pr-repo-name',_0x5371dd['textContent']=_0x959fe4['name'];const _0x22ef9d=document['createElement']('span');_0x22ef9d['className']='pr-base-branch',_0x22ef9d['textContent']=_0x959fe4['base']||_0x959fe4['defaultBranch']||'main',_0x22ef9d['dataset']['repo']=_0x959fe4['name'],_0x22ef9d['dataset']['base']=_0x959fe4['base']||_0x959fe4['defaultBranch']||'main';const _0x24427c=document['createElement']('span');_0x24427c['className']='pr-arrow',_0x24427c['textContent']='←';const _0x41e45e=document['createElement']('span');_0x41e45e['className']='pr-source-branch',_0x41e45e['textContent']=_0x959fe4['head']||'(head\x20branch)',_0x237337['appendChild'](_0x5371dd),_0x237337['appendChild'](_0x22ef9d),_0x237337['appendChild'](_0x24427c),_0x237337['appendChild'](_0x41e45e),_0x26c969['appendChild'](_0x237337);}}['hide'](){if(this['isSubmitting'])return;this['_el']('pr-modal')['hidden']=!![],this['onCancel']&&this['onCancel'](),this['_dismissResolve']&&(this['_dismissResolve'](),this['_dismissResolve']=null);}async['_handleSubmit'](){if(this['isSubmitting'])return;const _0x3e60ff=this['_el']('pr-title')['value']['trim'](),_0x72646=this['_el']('pr-body')['value']['trim']();if(!_0x3e60ff){this['_showError']('Pull\x20request\x20title\x20is\x20required');return;}const _0x3c9af2=[],_0x48fd35=this['_el']('pr-repos-list')['querySelectorAll']('.pr-base-branch');for(const _0x219420 of _0x48fd35){const _0x50e26e=_0x219420['dataset']['repo'],_0x5db07c=_0x219420['dataset']['base'],_0x49713a=this['prData']['repos']['find'](_0x20322a=>_0x20322a['name']===_0x50e26e);if(!_0x49713a)continue;_0x3c9af2['push']({'name':_0x50e26e,'title':_0x3e60ff,'body':_0x72646,'head':_0x49713a['head'],'base':_0x5db07c});}if(_0x3c9af2['length']===0x0){this['_showError']('No\x20repositories\x20selected');return;}this['isSubmitting']=!![],this['_el']('confirm-pr')['disabled']=!![],this['_el']('confirm-pr')['textContent']='Creating...';try{const _0x544501=await this['onSubmit'](this['prData']['taskId'],_0x3c9af2),_0xb81f=_0x544501['results']['every'](_0x2c31a6=>_0x2c31a6['success']),_0xda3add=_0x544501['results']['some'](_0x2c9b87=>_0x2c9b87['success']);if(_0xb81f)this['showToast']('Pull\x20requests\x20created\x20successfully','success');else{if(_0xda3add)this['showToast']('Some\x20pull\x20requests\x20created\x20successfully','warning');else throw new Error('All\x20pull\x20request\x20creations\x20failed');}this['isSubmitting']=![],this['_el']('confirm-pr')['disabled']=![],this['_el']('confirm-pr')['textContent']='Create\x20Pull\x20Request',this['hide'](),window['refreshTask']&&window['refreshTask']({'withSpinner':![]});}catch(_0x149805){console['error']('PR\x20creation\x20failed:',_0x149805),this['_showError'](_0x149805['message']||'Failed\x20to\x20create\x20pull\x20requests'),this['isSubmitting']=![],this['_el']('confirm-pr')['disabled']=![],this['_el']('confirm-pr')['textContent']='Create\x20Pull\x20Request';}}['_showError'](_0x1bc7e7){this['_el']('pr-error-text')['textContent']=_0x1bc7e7,this['_el']('pr-error')['hidden']=![];}static['checkOAuthRedirect'](_0x170f6e){if(_0x170f6e['get']('source')==='pr'&&_0x170f6e['get']('git_connection')){const _0xb91199=sessionStorage['getItem']('pendingPRData');if(_0xb91199)try{const _0x2d1313=JSON['parse'](_0xb91199);if(Date['now']()-_0x2d1313['timestamp']<0xa*0x3c*0x3e8)return sessionStorage['removeItem']('pendingPRData'),_0x2d1313;}catch(_0x1dbb03){console['error']('Failed\x20to\x20parse\x20pending\x20PR\x20data:',_0x1dbb03);}}return null;}}
@@ -98,11 +98,11 @@
98
98
  </svg>
99
99
  <span class="option-text">Server Settings</span>
100
100
  </button>
101
- <button type="button" class="dropdown-item admin-menu-item" id="server-health-btn">
101
+ <button type="button" class="dropdown-item admin-menu-item" onclick="window.location.href='admin.html'">
102
102
  <svg class="option-icon icon-health" width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">
103
103
  <path d="M22 12h-4l-3 9L9 3l-3 9H2"></path>
104
104
  </svg>
105
- <span class="option-text">Server Health</span>
105
+ <span class="option-text">Server Administration</span>
106
106
  </button>
107
107
  <button type="button" class="dropdown-item admin-menu-item" onclick="window.location.href='git-history.html'">
108
108
  <svg class="option-icon icon-git-history" width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">
@@ -1 +1 @@
1
- import{API,Utils,initializeAdminMenu}from'./app.js';import{initTheme,mountThemeToggle}from'./theme.js';const PERMISSION_CATEGORIES={'tasks':'Tasks','environments':'Environments','objectives':'Objectives','users':'Users','settings':'Settings','server':'Server','deployments':'Deployments','apikeys':'API\x20Keys','skills':'Skills','bindings':'Access\x20Bindings','containers':'Containers','tests':'Tests','jira':'JIRA','git-oauth':'Git\x20OAuth','qa':'QA','visualizations':'Visualizations'},SCOPE_CONFIG={'environment':{'label':'Env','color':'#3b82f6','bg':'rgba(59,130,246,0.12)'},'server':{'label':'Server','color':'#f59e0b','bg':'rgba(245,158,11,0.12)'},'team':{'label':'Team','color':'#10b981','bg':'rgba(16,185,129,0.12)'},'user':{'label':'User','color':'#8b5cf6','bg':'rgba(139,92,246,0.12)'}},state={'roles':[],'availablePermissions':[],'currentUser':null,'editingRoleId':null,'deletingRoleId':null,'editModalSnapshot':null};document['addEventListener']('DOMContentLoaded',async()=>{initTheme(),mountThemeToggle();try{state['currentUser']=await API['getCurrentUser']();}catch{window['location']['href']='login.html';return;}await initializeAdminMenu(state['currentUser']);if(!Permissions['hasServerPermission'](state['currentUser'],'*')){window['location']['href']='index.html';return;}document['getElementById']('create-role-btn')['hidden']=![],bindEventListeners(),await loadAvailablePermissions(),await loadRoles();});async function loadRoles(){const _0x68a10d=document['getElementById']('roles-loading'),_0x24770c=document['getElementById']('roles-error'),_0x2d4f30=document['getElementById']('roles-content');try{_0x68a10d['hidden']=![],_0x24770c['hidden']=!![],_0x2d4f30['hidden']=!![];const {roles:_0xfe3141}=await API['getRoleDefinitions']();state['roles']=_0xfe3141||[],renderRoles(),_0x68a10d['hidden']=!![],_0x2d4f30['hidden']=![];}catch(_0x3296b8){_0x68a10d['hidden']=!![],_0x24770c['hidden']=![],document['getElementById']('roles-error-message')['textContent']=_0x3296b8['message'];}}async function loadAvailablePermissions(){try{const {permissions:_0x51fefd}=await API['getAvailablePermissions']();state['availablePermissions']=_0x51fefd||[];}catch{state['availablePermissions']=[];}}function getPermissionScopeMap(){const _0x4eebfe={};for(const _0x5baa98 of state['availablePermissions']){_0x5baa98['scope']&&(_0x4eebfe[_0x5baa98['key']]=_0x5baa98['scope']);}return _0x4eebfe;}function getRoleScopeTags(_0x4e7d8e){if(!_0x4e7d8e||_0x4e7d8e['length']===0x0)return'<span\x20style=\x22color:\x20var(--color-text-secondary);\x22>—</span>';if(_0x4e7d8e['includes']('*'))return Object['values'](SCOPE_CONFIG)['map'](_0x3a0dc2=>'<span\x20class=\x22tag\x22\x20style=\x22background:\x20'+_0x3a0dc2['bg']+';\x20color:\x20'+_0x3a0dc2['color']+';\x20font-size:\x200.75rem;\x20margin-right:\x200.25rem;\x22>'+_0x3a0dc2['label']+'</span>')['join']('');const _0x35ac32=getPermissionScopeMap(),_0x5335e9=new Set();for(const _0x46dfd9 of _0x4e7d8e){const _0x46a89c=_0x35ac32[_0x46dfd9];if(_0x46a89c)_0x5335e9['add'](_0x46a89c);}if(_0x5335e9['size']===0x0)return'<span\x20style=\x22color:\x20var(--color-text-secondary);\x22>—</span>';const _0x43d24b=['environment','server','team','user'];return _0x43d24b['filter'](_0x41c2eb=>_0x5335e9['has'](_0x41c2eb))['map'](_0x225542=>{const _0x368df7=SCOPE_CONFIG[_0x225542];return'<span\x20class=\x22tag\x22\x20style=\x22background:\x20'+_0x368df7['bg']+';\x20color:\x20'+_0x368df7['color']+';\x20font-size:\x200.75rem;\x20margin-right:\x200.25rem;\x22>'+_0x368df7['label']+'</span>';})['join']('');}function renderRoles(){const _0xe1c3c5=document['getElementById']('roles-table-body'),_0x4dc9ec=document['getElementById']('role-count');if(!_0xe1c3c5)return;_0x4dc9ec&&(_0x4dc9ec['textContent']=state['roles']['length']+'\x20role'+(state['roles']['length']===0x1?'':'s'));const _0x27bb66=Permissions['hasServerPermission'](state['currentUser'],'*');_0xe1c3c5['innerHTML']=state['roles']['map'](_0x3ec067=>{const _0x4da754=_0x3ec067['permissions']?.['length']??0x0,_0x3a0508=_0x3ec067['predefined']?'Predefined':'Custom',_0x50cb27=_0x3ec067['predefined']?'background:\x20var(--color-surface);\x20color:\x20var(--color-text-secondary);':'background:\x20rgba(0,100,200,0.1);\x20color:\x20var(--color-primary);',_0x25d335=getRoleScopeTags(_0x3ec067['permissions']);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<button\x20class=\x22btn-ghost\x20btn-small\x22\x20style=\x22font-weight:\x20600;\x20padding:\x200;\x20text-decoration:\x20underline;\x20text-decoration-style:\x20dotted;\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20onclick=\x22window.openRoleModal(\x27'+_0x3ec067['id']+'\x27)\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+Utils['escapeHtml'](_0x3ec067['name'])+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x3ec067['description']?'<div\x20style=\x22font-size:\x200.8em;\x20color:\x20var(--color-text-secondary);\x20margin-top:\x200.15rem;\x22>'+Utils['escapeHtml'](_0x3ec067['description'])+'</div>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td><span\x20class=\x22tag\x22\x20style=\x22'+_0x50cb27+'\x22>'+_0x3a0508+'</span></td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+_0x25d335+'</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+(_0x4da754===0x1&&_0x3ec067['permissions'][0x0]==='*'?'All\x20permissions':_0x4da754+'\x20permission'+(_0x4da754===0x1?'':'s'))+'</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>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-secondary\x20btn-small\x22\x20onclick=\x22window.openRoleModal(\x27'+_0x3ec067['id']+'\x27)\x22>View'+(_0x27bb66?'/Edit':'')+'</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x27bb66&&!_0x3ec067['predefined']?'<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteRole(\x27'+_0x3ec067['id']+'\x27)\x22>Delete</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']('');}window['openRoleModal']=function(_0x3207e8){const _0x5de2f9=state['roles']['find'](_0x2f1cd9=>_0x2f1cd9['id']===_0x3207e8);if(!_0x5de2f9)return;const _0x4aac1a=Permissions['hasServerPermission'](state['currentUser'],'*'),_0xcd2273=_0x4aac1a&&!_0x5de2f9['predefined'];state['editingRoleId']=_0x3207e8,document['getElementById']('role-modal-title')['textContent']=_0x5de2f9['name'],document['getElementById']('role-name')['value']=_0x5de2f9['name'],document['getElementById']('role-name')['disabled']=!_0xcd2273,document['getElementById']('role-description')['value']=_0x5de2f9['description']||'',document['getElementById']('role-description')['disabled']=!_0xcd2273,document['getElementById']('role-form-error')['hidden']=!![],document['getElementById']('save-role')['hidden']=!_0xcd2273;const _0x35b7ec=document['getElementById']('role-readonly-notice');_0x35b7ec['hidden']=_0xcd2273,renderPermissionsChecklist('permissions-checklist',_0x5de2f9['permissions'],_0xcd2273),_0xcd2273?state['editModalSnapshot']={'name':_0x5de2f9['name'],'description':_0x5de2f9['description']||'','permissions':[..._0x5de2f9['permissions']||[]]['sort']()}:state['editModalSnapshot']=null,document['getElementById']('role-modal')['hidden']=![];};function isRoleModalDirty(){if(!state['editModalSnapshot'])return![];const _0x23b011=document['getElementById']('role-name')['value']['trim'](),_0x45de42=document['getElementById']('role-description')['value']['trim'](),_0x59dc5e=getCheckedPermissions('permissions-checklist')['sort']();return _0x23b011!==state['editModalSnapshot']['name']||_0x45de42!==state['editModalSnapshot']['description']||JSON['stringify'](_0x59dc5e)!==JSON['stringify'](state['editModalSnapshot']['permissions']);}function requestHideRoleModal(){if(isRoleModalDirty()){if(!confirm('You\x20have\x20unsaved\x20changes.\x20Discard\x20them?'))return;}hideRoleModal();}function hideRoleModal(){document['getElementById']('role-modal')['hidden']=!![],state['editingRoleId']=null,state['editModalSnapshot']=null;const _0x3bde04=document['getElementById']('save-role');_0x3bde04['disabled']=![],_0x3bde04['textContent']='Save\x20Role';}function showCreateRoleModal(){document['getElementById']('new-role-name')['value']='',document['getElementById']('new-role-description')['value']='',document['getElementById']('create-role-error')['hidden']=!![],renderPermissionsChecklist('new-permissions-checklist',[],!![]),document['getElementById']('create-role-modal')['hidden']=![],setTimeout(()=>document['getElementById']('new-role-name')['focus'](),0x64);}function hideCreateRoleModal(){document['getElementById']('create-role-modal')['hidden']=!![];const _0x329f14=document['getElementById']('save-new-role');_0x329f14['disabled']=![],_0x329f14['textContent']='Create\x20Role';}function renderPermissionsChecklist(_0x375e10,_0x499f77,_0x10d77d){const _0x1cd9bc=document['getElementById'](_0x375e10);if(!_0x1cd9bc)return;const _0x4b55f3=_0x499f77['includes']('*');if(_0x4b55f3){_0x1cd9bc['innerHTML']='<p\x20style=\x22font-size:\x200.875rem;\x20color:\x20var(--color-text-secondary);\x22>This\x20role\x20has\x20<strong>all\x20permissions</strong>\x20(wildcard).</p>';return;}const _0x12c7a0=['environment','server','team','user'],_0x2d3d84={'environment':'Environment-Scoped','server':'Server-Scoped','team':'Team-Scoped','user':'User-Scoped'},_0x20fad0={'environment':'These\x20permissions\x20are\x20granted\x20via\x20bindings\x20and\x20apply\x20only\x20to\x20bound\x20environments.','server':'These\x20permissions\x20apply\x20server-wide\x20and\x20are\x20typically\x20for\x20admin\x20functions.','team':'These\x20permissions\x20apply\x20to\x20team\x20management.','user':'These\x20permissions\x20apply\x20to\x20the\x20user\x27s\x20own\x20resources\x20regardless\x20of\x20bindings.'},_0x5bd4a7={};for(const _0x6e68b6 of state['availablePermissions']){const _0x9b1cc2=_0x6e68b6['scope']||'environment',_0x269216=_0x6e68b6['category']||_0x6e68b6['key']['split'](':')[0x0];if(!_0x5bd4a7[_0x9b1cc2])_0x5bd4a7[_0x9b1cc2]={};if(!_0x5bd4a7[_0x9b1cc2][_0x269216])_0x5bd4a7[_0x9b1cc2][_0x269216]=[];_0x5bd4a7[_0x9b1cc2][_0x269216]['push'](_0x6e68b6);}const _0x23e6de=new Set(_0x499f77),_0x35c5c5='\x0a\x20\x20\x20\x20<div\x20style=\x22font-size:\x200.8rem;\x20color:\x20var(--color-text-secondary);\x20background:\x20var(--color-surface);\x20border:\x201px\x20solid\x20var(--color-border);\x20border-radius:\x206px;\x20padding:\x200.6rem\x200.75rem;\x20margin-bottom:\x201rem;\x22>\x0a\x20\x20\x20\x20\x20\x20<strong\x20style=\x22color:\x20var(--color-text);\x22>Scope\x20mixing:</strong>\x0a\x20\x20\x20\x20\x20\x20A\x20role\x20can\x20mix\x20permissions\x20of\x20each\x20scope\x20type—environment,\x20user,\x20server,\x20team—with\x20one\x20exception:\x20a\x20role\x20cannot\x20include\x20both\x20a\x20team\x20permission\x20and\x20an\x20environment\x20permission.\x0a\x20\x20\x20\x20</div>',_0x9e1685=_0x12c7a0['filter'](_0x16b7ef=>_0x5bd4a7[_0x16b7ef])['map'](_0x466a8e=>{const _0x3b007c=_0x5bd4a7[_0x466a8e],_0x41c1df=SCOPE_CONFIG[_0x466a8e],_0x2bcf7d=Object['entries'](_0x3b007c)['map'](([_0x42faa3,_0xf327bc])=>{const _0x4ce9a5=PERMISSION_CATEGORIES[_0x42faa3]||_0x42faa3,_0x42a371=_0xf327bc['map'](_0x132b0e=>{const _0x2c7b45=_0x23e6de['has'](_0x132b0e['key'])?'checked':'',_0x20c67a=_0x10d77d?'':'disabled';return'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<label\x20style=\x22display:\x20flex;\x20align-items:\x20flex-start;\x20gap:\x200.5rem;\x20padding:\x200.2rem\x200;\x20cursor:\x20'+(_0x10d77d?'pointer':'default')+';\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<input\x20type=\x22checkbox\x22\x20value=\x22'+_0x132b0e['key']+'\x22\x20'+_0x2c7b45+'\x20'+_0x20c67a+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20style=\x22margin-top:\x200.2rem;\x20flex-shrink:\x200;\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20class=\x22perm-checkbox\x22\x20data-container=\x22'+_0x375e10+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20style=\x22font-size:\x200.8rem;\x20font-family:\x20monospace;\x20color:\x20var(--color-primary);\x22>'+Utils['escapeHtml'](_0x132b0e['key'])+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20style=\x22font-size:\x200.78rem;\x20color:\x20var(--color-text-secondary);\x20margin-left:\x200.5rem;\x22>'+Utils['escapeHtml'](_0x132b0e['description'])+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</label>';})['join']('');return'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20style=\x22margin-bottom:\x200.75rem;\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20style=\x22font-size:\x200.75rem;\x20font-weight:\x20700;\x20text-transform:\x20uppercase;\x20letter-spacing:\x200.05em;\x20color:\x20var(--color-text-secondary);\x20margin-bottom:\x200.35rem;\x22>'+Utils['escapeHtml'](_0x4ce9a5)+'</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x42a371+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>';})['join']('');return'\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20style=\x22margin-bottom:\x201.25rem;\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20style=\x22display:\x20flex;\x20align-items:\x20center;\x20gap:\x200.5rem;\x20margin-bottom:\x200.15rem;\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20style=\x22font-size:\x200.8rem;\x20font-weight:\x20700;\x20color:\x20'+_0x41c1df['color']+';\x22>'+_0x2d3d84[_0x466a8e]+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22tag\x22\x20style=\x22background:\x20'+_0x41c1df['bg']+';\x20color:\x20'+_0x41c1df['color']+';\x20font-size:\x200.65rem;\x22>'+_0x41c1df['label']+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20style=\x22font-size:\x200.75rem;\x20color:\x20var(--color-text-secondary);\x20margin-bottom:\x200.5rem;\x22>'+_0x20fad0[_0x466a8e]+'</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20style=\x22border-left:\x202px\x20solid\x20'+_0x41c1df['color']+';\x20padding-left:\x200.75rem;\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x2bcf7d+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>';})['join']('');_0x1cd9bc['innerHTML']=_0x35c5c5+_0x9e1685;}function getCheckedPermissions(_0x4263fa){const _0x370b3c=document['getElementById'](_0x4263fa);if(!_0x370b3c)return[];return Array['from'](_0x370b3c['querySelectorAll']('.perm-checkbox:checked'))['map'](_0x241ff4=>_0x241ff4['value']);}async function saveRole(){const _0x830c8f=document['getElementById']('role-name')['value']['trim'](),_0x31c2a6=document['getElementById']('role-description')['value']['trim'](),_0x4b9da8=getCheckedPermissions('permissions-checklist'),_0x33a8d4=document['getElementById']('role-form-error'),_0x1c75ab=document['getElementById']('save-role');if(!_0x830c8f){_0x33a8d4['textContent']='Role\x20name\x20is\x20required',_0x33a8d4['hidden']=![];return;}if(_0x4b9da8['length']===0x0){_0x33a8d4['textContent']='Select\x20at\x20least\x20one\x20permission',_0x33a8d4['hidden']=![];return;}_0x33a8d4['hidden']=!![];const _0x2477a2=_0x1c75ab['textContent'];_0x1c75ab['disabled']=!![],_0x1c75ab['textContent']='Saving…';try{const {role:_0x56fcdd}=await API['updateRoleDefinition'](state['editingRoleId'],{'name':_0x830c8f,'description':_0x31c2a6,'permissions':_0x4b9da8}),_0x2aafae=state['roles']['findIndex'](_0x5d5f00=>_0x5d5f00['id']===_0x56fcdd['id']);if(_0x2aafae>=0x0)state['roles'][_0x2aafae]=_0x56fcdd;renderRoles(),Utils['showToast']('Role\x20updated','success'),hideRoleModal();}catch(_0x605fb2){_0x33a8d4['textContent']=_0x605fb2['message'],_0x33a8d4['hidden']=![],_0x1c75ab['disabled']=![],_0x1c75ab['textContent']=_0x2477a2;}}async function createRole(){const _0x512949=document['getElementById']('new-role-name')['value']['trim'](),_0x2da1e5=document['getElementById']('new-role-description')['value']['trim'](),_0xb4721d=getCheckedPermissions('new-permissions-checklist'),_0x3d2e8b=document['getElementById']('create-role-error'),_0x1fcbef=document['getElementById']('save-new-role');if(!_0x512949){_0x3d2e8b['textContent']='Role\x20name\x20is\x20required',_0x3d2e8b['hidden']=![];return;}if(_0xb4721d['length']===0x0){_0x3d2e8b['textContent']='Select\x20at\x20least\x20one\x20permission',_0x3d2e8b['hidden']=![];return;}_0x3d2e8b['hidden']=!![];const _0x5ef761=_0x1fcbef['textContent'];_0x1fcbef['disabled']=!![],_0x1fcbef['textContent']='Creating…';try{const {role:_0x593d10}=await API['createRoleDefinition']({'name':_0x512949,'description':_0x2da1e5,'permissions':_0xb4721d});state['roles']['push'](_0x593d10),renderRoles(),Utils['showToast']('Role\x20created','success'),hideCreateRoleModal();}catch(_0x2ba7f){_0x3d2e8b['textContent']=_0x2ba7f['message'],_0x3d2e8b['hidden']=![],_0x1fcbef['disabled']=![],_0x1fcbef['textContent']=_0x5ef761;}}window['deleteRole']=function(_0x3943f2){const _0x2bf045=state['roles']['find'](_0xa7c09f=>_0xa7c09f['id']===_0x3943f2);if(!_0x2bf045)return;state['deletingRoleId']=_0x3943f2,document['getElementById']('delete-role-name')['textContent']=_0x2bf045['name'],document['getElementById']('delete-role-modal')['hidden']=![];};function hideDeleteRoleModal(){document['getElementById']('delete-role-modal')['hidden']=!![],state['deletingRoleId']=null;const _0x519b51=document['getElementById']('confirm-delete-role');_0x519b51['disabled']=![],_0x519b51['textContent']='Delete\x20Role';}async function confirmDeleteRole(){if(!state['deletingRoleId'])return;const _0x3dba72=document['getElementById']('confirm-delete-role');_0x3dba72['disabled']=!![],_0x3dba72['textContent']='Deleting…';try{await API['deleteRoleDefinition'](state['deletingRoleId']),state['roles']=state['roles']['filter'](_0x13826d=>_0x13826d['id']!==state['deletingRoleId']),renderRoles(),Utils['showToast']('Role\x20deleted','success'),hideDeleteRoleModal();}catch(_0x1b01de){Utils['showToast']('Failed\x20to\x20delete\x20role:\x20'+_0x1b01de['message'],'error'),_0x3dba72['disabled']=![],_0x3dba72['textContent']='Delete\x20Role';}}function bindEventListeners(){document['getElementById']('create-role-btn')?.['addEventListener']('click',showCreateRoleModal),document['getElementById']('retry-roles-btn')?.['addEventListener']('click',loadRoles),document['getElementById']('close-role-modal')?.['addEventListener']('click',requestHideRoleModal),document['getElementById']('cancel-role')?.['addEventListener']('click',requestHideRoleModal),document['getElementById']('save-role')?.['addEventListener']('click',saveRole),document['querySelector']('#role-modal\x20.modal-overlay')?.['addEventListener']('click',requestHideRoleModal),document['getElementById']('close-create-role-modal')?.['addEventListener']('click',hideCreateRoleModal),document['getElementById']('cancel-create-role')?.['addEventListener']('click',hideCreateRoleModal),document['getElementById']('save-new-role')?.['addEventListener']('click',createRole),document['querySelector']('#create-role-modal\x20.modal-overlay')?.['addEventListener']('click',hideCreateRoleModal),document['getElementById']('close-delete-role-modal')?.['addEventListener']('click',hideDeleteRoleModal),document['getElementById']('cancel-delete-role')?.['addEventListener']('click',hideDeleteRoleModal),document['getElementById']('confirm-delete-role')?.['addEventListener']('click',confirmDeleteRole),document['querySelector']('#delete-role-modal\x20.modal-overlay')?.['addEventListener']('click',hideDeleteRoleModal);}
1
+ import{API,Utils,initializeAdminMenu}from'./app.js';import{initTheme,mountThemeToggle}from'./theme.js';const PERMISSION_CATEGORIES={'tasks':'Tasks','environments':'Environments','objectives':'Objectives','users':'Users','settings':'Settings','server':'Server','deployments':'Deployments','apikeys':'API\x20Keys','skills':'Skills','bindings':'Access\x20Bindings','containers':'Containers','tests':'Tests','jira':'JIRA','git-oauth':'Git\x20OAuth','qa':'QA','visualizations':'Visualizations'},SCOPE_CONFIG={'environment':{'label':'Env','color':'#3b82f6','bg':'rgba(59,130,246,0.12)'},'server':{'label':'Server','color':'#f59e0b','bg':'rgba(245,158,11,0.12)'},'team':{'label':'Team','color':'#10b981','bg':'rgba(16,185,129,0.12)'},'user':{'label':'User','color':'#8b5cf6','bg':'rgba(139,92,246,0.12)'}},state={'roles':[],'availablePermissions':[],'currentUser':null,'editingRoleId':null,'deletingRoleId':null,'editModalSnapshot':null};document['addEventListener']('DOMContentLoaded',async()=>{initTheme(),mountThemeToggle();try{state['currentUser']=await API['getCurrentUser']();}catch{window['location']['href']='login.html';return;}await initializeAdminMenu(state['currentUser']);if(!Permissions['hasServerPermission'](state['currentUser'],'*')){window['location']['href']='index.html';return;}document['getElementById']('create-role-btn')['hidden']=![],bindEventListeners(),await loadAvailablePermissions(),await loadRoles();});async function loadRoles(){const _0x406e73=document['getElementById']('roles-loading'),_0x19398d=document['getElementById']('roles-error'),_0x537cfc=document['getElementById']('roles-content');try{_0x406e73['hidden']=![],_0x19398d['hidden']=!![],_0x537cfc['hidden']=!![];const {roles:_0x495e66}=await API['getRoleDefinitions']();state['roles']=_0x495e66||[],renderRoles(),_0x406e73['hidden']=!![],_0x537cfc['hidden']=![];}catch(_0x1645cb){_0x406e73['hidden']=!![],_0x19398d['hidden']=![],document['getElementById']('roles-error-message')['textContent']=_0x1645cb['message'];}}async function loadAvailablePermissions(){try{const {permissions:_0x269d62}=await API['getAvailablePermissions']();state['availablePermissions']=_0x269d62||[];}catch{state['availablePermissions']=[];}}function getPermissionScopeMap(){const _0x1d012b={};for(const _0x4ac5e2 of state['availablePermissions']){_0x4ac5e2['scope']&&(_0x1d012b[_0x4ac5e2['key']]=_0x4ac5e2['scope']);}return _0x1d012b;}function getRoleScopeTags(_0xa58d11){if(!_0xa58d11||_0xa58d11['length']===0x0)return'<span\x20style=\x22color:\x20var(--color-text-secondary);\x22>—</span>';if(_0xa58d11['includes']('*'))return Object['values'](SCOPE_CONFIG)['map'](_0xad5d0b=>'<span\x20class=\x22tag\x22\x20style=\x22background:\x20'+_0xad5d0b['bg']+';\x20color:\x20'+_0xad5d0b['color']+';\x20font-size:\x200.75rem;\x20margin-right:\x200.25rem;\x22>'+_0xad5d0b['label']+'</span>')['join']('');const _0x48a5ce=getPermissionScopeMap(),_0x3305a9=new Set();for(const _0x1b8522 of _0xa58d11){const _0x3b4592=_0x48a5ce[_0x1b8522];if(_0x3b4592)_0x3305a9['add'](_0x3b4592);}if(_0x3305a9['size']===0x0)return'<span\x20style=\x22color:\x20var(--color-text-secondary);\x22>—</span>';const _0x37bc60=['environment','server','team','user'];return _0x37bc60['filter'](_0xea8a92=>_0x3305a9['has'](_0xea8a92))['map'](_0x34d790=>{const _0x5712cf=SCOPE_CONFIG[_0x34d790];return'<span\x20class=\x22tag\x22\x20style=\x22background:\x20'+_0x5712cf['bg']+';\x20color:\x20'+_0x5712cf['color']+';\x20font-size:\x200.75rem;\x20margin-right:\x200.25rem;\x22>'+_0x5712cf['label']+'</span>';})['join']('');}function renderRoles(){const _0x444514=document['getElementById']('roles-table-body'),_0x307504=document['getElementById']('role-count');if(!_0x444514)return;_0x307504&&(_0x307504['textContent']=state['roles']['length']+'\x20role'+(state['roles']['length']===0x1?'':'s'));const _0x3713f4=Permissions['hasServerPermission'](state['currentUser'],'*');_0x444514['innerHTML']=state['roles']['map'](_0x13954c=>{const _0x3d97d5=_0x13954c['permissions']?.['length']??0x0,_0x216184=_0x13954c['predefined']?'Predefined':'Custom',_0x43c9e0=_0x13954c['predefined']?'background:\x20var(--color-surface);\x20color:\x20var(--color-text-secondary);':'background:\x20rgba(0,100,200,0.1);\x20color:\x20var(--color-primary);',_0x244f28=getRoleScopeTags(_0x13954c['permissions']);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<button\x20class=\x22btn-ghost\x20btn-small\x22\x20style=\x22font-weight:\x20600;\x20padding:\x200;\x20text-decoration:\x20underline;\x20text-decoration-style:\x20dotted;\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20onclick=\x22window.openRoleModal(\x27'+_0x13954c['id']+'\x27)\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+Utils['escapeHtml'](_0x13954c['name'])+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x13954c['description']?'<div\x20style=\x22font-size:\x200.8em;\x20color:\x20var(--color-text-secondary);\x20margin-top:\x200.15rem;\x22>'+Utils['escapeHtml'](_0x13954c['description'])+'</div>':'')+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td><span\x20class=\x22tag\x22\x20style=\x22'+_0x43c9e0+'\x22>'+_0x216184+'</span></td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+_0x244f28+'</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+(_0x3d97d5===0x1&&_0x13954c['permissions'][0x0]==='*'?'All\x20permissions':_0x3d97d5+'\x20permission'+(_0x3d97d5===0x1?'':'s'))+'</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>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-secondary\x20btn-small\x22\x20onclick=\x22window.openRoleModal(\x27'+_0x13954c['id']+'\x27)\x22>View'+(_0x3713f4?'/Edit':'')+'</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x3713f4&&!_0x13954c['predefined']?'<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteRole(\x27'+_0x13954c['id']+'\x27)\x22>Delete</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']('');}window['openRoleModal']=function(_0x2bfc64){const _0x59bbac=state['roles']['find'](_0x2ff6b1=>_0x2ff6b1['id']===_0x2bfc64);if(!_0x59bbac)return;const _0x5b2d12=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x343705=_0x5b2d12&&!_0x59bbac['predefined'];state['editingRoleId']=_0x2bfc64,document['getElementById']('role-modal-title')['textContent']=_0x59bbac['name'],document['getElementById']('role-name')['value']=_0x59bbac['name'],document['getElementById']('role-name')['disabled']=!_0x343705,document['getElementById']('role-description')['value']=_0x59bbac['description']||'',document['getElementById']('role-description')['disabled']=!_0x343705,document['getElementById']('role-form-error')['hidden']=!![],document['getElementById']('save-role')['hidden']=!_0x343705;const _0x3941a4=document['getElementById']('role-readonly-notice');_0x3941a4['hidden']=_0x343705,renderPermissionsChecklist('permissions-checklist',_0x59bbac['permissions'],_0x343705),_0x343705?state['editModalSnapshot']={'name':_0x59bbac['name'],'description':_0x59bbac['description']||'','permissions':[..._0x59bbac['permissions']||[]]['sort']()}:state['editModalSnapshot']=null,document['getElementById']('role-modal')['hidden']=![];};function isRoleModalDirty(){if(!state['editModalSnapshot'])return![];const _0x979df4=document['getElementById']('role-name')['value']['trim'](),_0x31a4aa=document['getElementById']('role-description')['value']['trim'](),_0x1be035=getCheckedPermissions('permissions-checklist')['sort']();return _0x979df4!==state['editModalSnapshot']['name']||_0x31a4aa!==state['editModalSnapshot']['description']||JSON['stringify'](_0x1be035)!==JSON['stringify'](state['editModalSnapshot']['permissions']);}function requestHideRoleModal(){if(isRoleModalDirty()){if(!confirm('You\x20have\x20unsaved\x20changes.\x20Discard\x20them?'))return;}hideRoleModal();}function hideRoleModal(){document['getElementById']('role-modal')['hidden']=!![],state['editingRoleId']=null,state['editModalSnapshot']=null;const _0x4afbbe=document['getElementById']('save-role');_0x4afbbe['disabled']=![],_0x4afbbe['textContent']='Save\x20Role';}function showCreateRoleModal(){document['getElementById']('new-role-name')['value']='',document['getElementById']('new-role-description')['value']='',document['getElementById']('create-role-error')['hidden']=!![],renderPermissionsChecklist('new-permissions-checklist',[],!![]),document['getElementById']('create-role-modal')['hidden']=![],setTimeout(()=>document['getElementById']('new-role-name')['focus'](),0x64);}function hideCreateRoleModal(){document['getElementById']('create-role-modal')['hidden']=!![];const _0xff43a7=document['getElementById']('save-new-role');_0xff43a7['disabled']=![],_0xff43a7['textContent']='Create\x20Role';}function renderPermissionsChecklist(_0x55d3f4,_0x2d37d1,_0xd62a82){const _0x52361a=document['getElementById'](_0x55d3f4);if(!_0x52361a)return;const _0x3d89f5=_0x2d37d1['includes']('*');if(_0x3d89f5){_0x52361a['innerHTML']='<p\x20style=\x22font-size:\x200.875rem;\x20color:\x20var(--color-text-secondary);\x22>This\x20role\x20has\x20<strong>all\x20permissions</strong>\x20(wildcard).</p>';return;}const _0x2e408f=['environment','server','team','user'],_0x58162a={'environment':'Environment-Scoped','server':'Server-Scoped','team':'Team-Scoped','user':'User-Scoped'},_0x4a4a93={'environment':'These\x20permissions\x20are\x20granted\x20via\x20bindings\x20and\x20apply\x20only\x20to\x20bound\x20environments.','server':'These\x20permissions\x20apply\x20server-wide\x20and\x20are\x20typically\x20for\x20admin\x20functions.','team':'These\x20permissions\x20apply\x20to\x20team\x20management.','user':'These\x20permissions\x20apply\x20to\x20the\x20user\x27s\x20own\x20resources\x20regardless\x20of\x20bindings.'},_0xfde59={};for(const _0x1ade97 of state['availablePermissions']){const _0x11066f=_0x1ade97['scope']||'environment',_0x138be8=_0x1ade97['category']||_0x1ade97['key']['split'](':')[0x0];if(!_0xfde59[_0x11066f])_0xfde59[_0x11066f]={};if(!_0xfde59[_0x11066f][_0x138be8])_0xfde59[_0x11066f][_0x138be8]=[];_0xfde59[_0x11066f][_0x138be8]['push'](_0x1ade97);}const _0x31d39e=new Set(_0x2d37d1),_0x564c88='\x0a\x20\x20\x20\x20<div\x20style=\x22font-size:\x200.8rem;\x20color:\x20var(--color-text-secondary);\x20background:\x20var(--color-surface);\x20border:\x201px\x20solid\x20var(--color-border);\x20border-radius:\x206px;\x20padding:\x200.6rem\x200.75rem;\x20margin-bottom:\x201rem;\x22>\x0a\x20\x20\x20\x20\x20\x20<strong\x20style=\x22color:\x20var(--color-text);\x22>Scope\x20mixing:</strong>\x0a\x20\x20\x20\x20\x20\x20A\x20role\x20can\x20mix\x20permissions\x20of\x20each\x20scope\x20type—environment,\x20user,\x20server,\x20team—with\x20one\x20exception:\x20a\x20role\x20cannot\x20include\x20both\x20a\x20team\x20permission\x20and\x20an\x20environment\x20permission.\x0a\x20\x20\x20\x20</div>',_0x23b097=_0x2e408f['filter'](_0x5e2e1f=>_0xfde59[_0x5e2e1f])['map'](_0x489be8=>{const _0x26d232=_0xfde59[_0x489be8],_0x12f8c4=SCOPE_CONFIG[_0x489be8],_0x10dd5f=Object['entries'](_0x26d232)['map'](([_0xf90034,_0x37cf77])=>{const _0x12651e=PERMISSION_CATEGORIES[_0xf90034]||_0xf90034,_0x5c5407=_0x37cf77['map'](_0x4f36d0=>{const _0x325292=_0x31d39e['has'](_0x4f36d0['key'])?'checked':'',_0x44a19c=_0xd62a82?'':'disabled';return'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<label\x20style=\x22display:\x20flex;\x20align-items:\x20flex-start;\x20gap:\x200.5rem;\x20padding:\x200.2rem\x200;\x20cursor:\x20'+(_0xd62a82?'pointer':'default')+';\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<input\x20type=\x22checkbox\x22\x20value=\x22'+_0x4f36d0['key']+'\x22\x20'+_0x325292+'\x20'+_0x44a19c+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20style=\x22margin-top:\x200.2rem;\x20flex-shrink:\x200;\x22\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20class=\x22perm-checkbox\x22\x20data-container=\x22'+_0x55d3f4+'\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20style=\x22font-size:\x200.8rem;\x20font-family:\x20monospace;\x20color:\x20var(--color-primary);\x22>'+Utils['escapeHtml'](_0x4f36d0['key'])+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20style=\x22font-size:\x200.78rem;\x20color:\x20var(--color-text-secondary);\x20margin-left:\x200.5rem;\x22>'+Utils['escapeHtml'](_0x4f36d0['description'])+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</label>';})['join']('');return'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20style=\x22margin-bottom:\x200.75rem;\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20style=\x22font-size:\x200.75rem;\x20font-weight:\x20700;\x20text-transform:\x20uppercase;\x20letter-spacing:\x200.05em;\x20color:\x20var(--color-text-secondary);\x20margin-bottom:\x200.35rem;\x22>'+Utils['escapeHtml'](_0x12651e)+'</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x5c5407+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>';})['join']('');return'\x0a\x20\x20\x20\x20\x20\x20\x20\x20<div\x20style=\x22margin-bottom:\x201.25rem;\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20style=\x22display:\x20flex;\x20align-items:\x20center;\x20gap:\x200.5rem;\x20margin-bottom:\x200.15rem;\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20style=\x22font-size:\x200.8rem;\x20font-weight:\x20700;\x20color:\x20'+_0x12f8c4['color']+';\x22>'+_0x58162a[_0x489be8]+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22tag\x22\x20style=\x22background:\x20'+_0x12f8c4['bg']+';\x20color:\x20'+_0x12f8c4['color']+';\x20font-size:\x200.65rem;\x22>'+_0x12f8c4['label']+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20style=\x22font-size:\x200.75rem;\x20color:\x20var(--color-text-secondary);\x20margin-bottom:\x200.5rem;\x22>'+_0x4a4a93[_0x489be8]+'</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20style=\x22border-left:\x202px\x20solid\x20'+_0x12f8c4['color']+';\x20padding-left:\x200.75rem;\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x10dd5f+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>';})['join']('');_0x52361a['innerHTML']=_0x564c88+_0x23b097;}function getCheckedPermissions(_0x59838b){const _0x49dafd=document['getElementById'](_0x59838b);if(!_0x49dafd)return[];return Array['from'](_0x49dafd['querySelectorAll']('.perm-checkbox:checked'))['map'](_0x11b46a=>_0x11b46a['value']);}async function saveRole(){const _0xb7a5c3=document['getElementById']('role-name')['value']['trim'](),_0x58da4e=document['getElementById']('role-description')['value']['trim'](),_0x23914f=getCheckedPermissions('permissions-checklist'),_0x4a6458=document['getElementById']('role-form-error'),_0x1ed63e=document['getElementById']('save-role');if(!_0xb7a5c3){_0x4a6458['textContent']='Role\x20name\x20is\x20required',_0x4a6458['hidden']=![];return;}if(_0x23914f['length']===0x0){_0x4a6458['textContent']='Select\x20at\x20least\x20one\x20permission',_0x4a6458['hidden']=![];return;}_0x4a6458['hidden']=!![];const _0x2cb92d=_0x1ed63e['textContent'];_0x1ed63e['disabled']=!![],_0x1ed63e['textContent']='Saving…';try{const {role:_0x24d2a2}=await API['updateRoleDefinition'](state['editingRoleId'],{'name':_0xb7a5c3,'description':_0x58da4e,'permissions':_0x23914f}),_0x207b1a=state['roles']['findIndex'](_0x2a3e59=>_0x2a3e59['id']===_0x24d2a2['id']);if(_0x207b1a>=0x0)state['roles'][_0x207b1a]=_0x24d2a2;renderRoles(),Utils['showToast']('Role\x20updated','success'),hideRoleModal();}catch(_0x92e1c8){_0x4a6458['textContent']=_0x92e1c8['message'],_0x4a6458['hidden']=![],_0x1ed63e['disabled']=![],_0x1ed63e['textContent']=_0x2cb92d;}}async function createRole(){const _0x8d5d3e=document['getElementById']('new-role-name')['value']['trim'](),_0x39100b=document['getElementById']('new-role-description')['value']['trim'](),_0x3ee6cf=getCheckedPermissions('new-permissions-checklist'),_0x308daa=document['getElementById']('create-role-error'),_0x380b1d=document['getElementById']('save-new-role');if(!_0x8d5d3e){_0x308daa['textContent']='Role\x20name\x20is\x20required',_0x308daa['hidden']=![];return;}if(_0x3ee6cf['length']===0x0){_0x308daa['textContent']='Select\x20at\x20least\x20one\x20permission',_0x308daa['hidden']=![];return;}_0x308daa['hidden']=!![];const _0x2acb1c=_0x380b1d['textContent'];_0x380b1d['disabled']=!![],_0x380b1d['textContent']='Creating…';try{const {role:_0x1d34e7}=await API['createRoleDefinition']({'name':_0x8d5d3e,'description':_0x39100b,'permissions':_0x3ee6cf});state['roles']['push'](_0x1d34e7),renderRoles(),Utils['showToast']('Role\x20created','success'),hideCreateRoleModal();}catch(_0x22db96){_0x308daa['textContent']=_0x22db96['message'],_0x308daa['hidden']=![],_0x380b1d['disabled']=![],_0x380b1d['textContent']=_0x2acb1c;}}window['deleteRole']=function(_0x144099){const _0x46c68e=state['roles']['find'](_0x1a440c=>_0x1a440c['id']===_0x144099);if(!_0x46c68e)return;state['deletingRoleId']=_0x144099,document['getElementById']('delete-role-name')['textContent']=_0x46c68e['name'],document['getElementById']('delete-role-modal')['hidden']=![];};function hideDeleteRoleModal(){document['getElementById']('delete-role-modal')['hidden']=!![],state['deletingRoleId']=null;const _0x194708=document['getElementById']('confirm-delete-role');_0x194708['disabled']=![],_0x194708['textContent']='Delete\x20Role';}async function confirmDeleteRole(){if(!state['deletingRoleId'])return;const _0x1e8a0d=document['getElementById']('confirm-delete-role');_0x1e8a0d['disabled']=!![],_0x1e8a0d['textContent']='Deleting…';try{await API['deleteRoleDefinition'](state['deletingRoleId']),state['roles']=state['roles']['filter'](_0x26816d=>_0x26816d['id']!==state['deletingRoleId']),renderRoles(),Utils['showToast']('Role\x20deleted','success'),hideDeleteRoleModal();}catch(_0x511972){Utils['showToast']('Failed\x20to\x20delete\x20role:\x20'+_0x511972['message'],'error'),_0x1e8a0d['disabled']=![],_0x1e8a0d['textContent']='Delete\x20Role';}}function bindEventListeners(){document['getElementById']('create-role-btn')?.['addEventListener']('click',showCreateRoleModal),document['getElementById']('retry-roles-btn')?.['addEventListener']('click',loadRoles),document['getElementById']('close-role-modal')?.['addEventListener']('click',requestHideRoleModal),document['getElementById']('cancel-role')?.['addEventListener']('click',requestHideRoleModal),document['getElementById']('save-role')?.['addEventListener']('click',saveRole),document['querySelector']('#role-modal\x20.modal-overlay')?.['addEventListener']('click',requestHideRoleModal),document['getElementById']('close-create-role-modal')?.['addEventListener']('click',hideCreateRoleModal),document['getElementById']('cancel-create-role')?.['addEventListener']('click',hideCreateRoleModal),document['getElementById']('save-new-role')?.['addEventListener']('click',createRole),document['querySelector']('#create-role-modal\x20.modal-overlay')?.['addEventListener']('click',hideCreateRoleModal),document['getElementById']('close-delete-role-modal')?.['addEventListener']('click',hideDeleteRoleModal),document['getElementById']('cancel-delete-role')?.['addEventListener']('click',hideDeleteRoleModal),document['getElementById']('confirm-delete-role')?.['addEventListener']('click',confirmDeleteRole),document['querySelector']('#delete-role-modal\x20.modal-overlay')?.['addEventListener']('click',hideDeleteRoleModal);}
@@ -25,8 +25,8 @@
25
25
  <link rel="stylesheet" href="styles.css?v=85">
26
26
  <link rel="stylesheet" href="settings.css?v=8">
27
27
  <script src="permissions.js"></script>
28
- <script type="module" src="app.js?v=68"></script>
29
- <script type="module" src="settings.js?v=8"></script>
28
+ <script type="module" src="app.js?v=71"></script>
29
+ <script type="module" src="settings.js?v=9"></script>
30
30
  </head>
31
31
  <body>
32
32
  <main class="task-detail">
@@ -91,11 +91,11 @@
91
91
  </svg>
92
92
  <span class="option-text">Skills</span>
93
93
  </button>
94
- <button type="button" class="dropdown-item admin-menu-item" id="server-health-btn">
94
+ <button type="button" class="dropdown-item admin-menu-item" onclick="window.location.href='admin.html'">
95
95
  <svg class="option-icon icon-health" width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">
96
96
  <path d="M22 12h-4l-3 9L9 3l-3 9H2"></path>
97
97
  </svg>
98
- <span class="option-text">Server Health</span>
98
+ <span class="option-text">Server Administration</span>
99
99
  </button>
100
100
  <button type="button" class="dropdown-item admin-menu-item" onclick="window.location.href='git-history.html'">
101
101
  <svg class="option-icon icon-git-history" width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">
@@ -199,6 +199,14 @@
199
199
  </svg>
200
200
  CA Certificates
201
201
  </button>
202
+ <button class="settings-nav-item" data-section="updates" role="tab">
203
+ <svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">
204
+ <path d="M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4"></path>
205
+ <polyline points="7 10 12 15 17 10"></polyline>
206
+ <line x1="12" y1="15" x2="12" y2="3"></line>
207
+ </svg>
208
+ Updates
209
+ </button>
202
210
  </nav>
203
211
  </aside>
204
212
 
@@ -310,6 +318,24 @@
310
318
  <span id="keepalive-gemini-status">Loading status...</span>
311
319
  </div>
312
320
  </div>
321
+
322
+ <!-- Bob -->
323
+ <div class="keepalive-agent-section">
324
+ <div class="keepalive-agent-header">
325
+ <h4>Bob</h4>
326
+ <label class="toggle-switch">
327
+ <input type="checkbox" id="keepalive-bob-enabled">
328
+ <span class="toggle-slider"></span>
329
+ </label>
330
+ </div>
331
+ <div class="keepalive-agent-row">
332
+ <label for="keepalive-bob-interval">Refresh Interval (hours)</label>
333
+ <input type="number" id="keepalive-bob-interval" class="form-input" min="1" max="24" value="6">
334
+ </div>
335
+ <div class="keepalive-agent-status" id="keepalive-bob-status-row">
336
+ <span id="keepalive-bob-status">Loading status...</span>
337
+ </div>
338
+ </div>
313
339
  </div>
314
340
  </div>
315
341
  <div class="card-actions">
@@ -633,6 +659,42 @@
633
659
  </div>
634
660
  </div>
635
661
 
662
+ <div id="section-updates" class="settings-panel" role="tabpanel" hidden>
663
+ <div class="content-card">
664
+ <div class="card-header">
665
+ <h3>Update Management</h3>
666
+ </div>
667
+ <div class="card-body">
668
+ <div id="updates-inline-message" class="inline-message" hidden></div>
669
+ <p class="text-muted" style="margin-bottom: 20px;">Configure how the server can be updated and restarted from the Administration page.</p>
670
+
671
+ <div class="form-single-column">
672
+ <div class="form-row">
673
+ <label for="settings-updates-enabled">Enable Web Updates</label>
674
+ <label class="toggle-switch">
675
+ <input type="checkbox" id="settings-updates-enabled">
676
+ <span class="toggle-slider"></span>
677
+ </label>
678
+ <p class="field-hint">When enabled, admins can apply updates and restart the server from the Health tab on the Server Administration page.</p>
679
+ </div>
680
+ <div class="form-row">
681
+ <label for="settings-update-command">Update Command</label>
682
+ <input type="text" id="settings-update-command" class="form-input code-font" placeholder="npm install -g @profoundlogic/coderflow-server@{version}">
683
+ <p class="field-hint">Command to install a new version. Use <code>{version}</code> as a placeholder for the target version number.</p>
684
+ </div>
685
+ <div class="form-row">
686
+ <label for="settings-restart-command">Restart Command</label>
687
+ <input type="text" id="settings-restart-command" class="form-input code-font" placeholder="e.g., pm2 restart coderflow">
688
+ <p class="field-hint">Command to restart the server process after an update. Leave empty to use SIGTERM and rely on an external process manager to bring the service back up.</p>
689
+ </div>
690
+ </div>
691
+ </div>
692
+ <div class="card-actions">
693
+ <button type="button" class="btn-primary" id="save-updates-btn">Save</button>
694
+ </div>
695
+ </div>
696
+ </div>
697
+
636
698
  <!-- Single Sign-On Settings -->
637
699
  <div id="section-sso" class="settings-panel" role="tabpanel" hidden>
638
700
  <div class="content-card">