@profoundlogic/coderflow-server 0.8.6 → 0.8.7

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 (183) hide show
  1. package/dist/base-image/Dockerfile +3 -2
  2. package/dist/base-image/agent-wrapper.sh +7 -2
  3. package/dist/coder-server.js +1 -1
  4. package/dist/config.js +1 -1
  5. package/dist/lib/agent-keepalive.js +1 -1
  6. package/dist/lib/agent-models.js +1 -1
  7. package/dist/lib/api-keys.js +1 -1
  8. package/dist/lib/apiKeys.js +1 -1
  9. package/dist/lib/app-server-ports.js +1 -1
  10. package/dist/lib/auto-judge.js +1 -1
  11. package/dist/lib/automation-service.js +1 -1
  12. package/dist/lib/basic-auth.js +1 -1
  13. package/dist/lib/bindings.js +1 -1
  14. package/dist/lib/build-history.js +1 -1
  15. package/dist/lib/build-output-service.js +1 -1
  16. package/dist/lib/build-scheduler.js +1 -1
  17. package/dist/lib/build-service.js +1 -1
  18. package/dist/lib/ca-certificates.js +1 -1
  19. package/dist/lib/claude-oauth-refresh.js +1 -1
  20. package/dist/lib/cli/build.js +1 -1
  21. package/dist/lib/cli/cleanup-users.js +1 -1
  22. package/dist/lib/cli/config-command.js +1 -1
  23. package/dist/lib/cli/config.js +1 -1
  24. package/dist/lib/cli/create-user.js +1 -1
  25. package/dist/lib/cli/grant-admin.js +1 -1
  26. package/dist/lib/cli/init.js +1 -1
  27. package/dist/lib/cli/jira.js +1 -1
  28. package/dist/lib/cli/license.js +1 -1
  29. package/dist/lib/cli/list-roles.js +1 -1
  30. package/dist/lib/cli/list-users.js +1 -1
  31. package/dist/lib/cli/server-manager.js +1 -1
  32. package/dist/lib/cli/set-password.js +1 -1
  33. package/dist/lib/compression-filter.js +1 -1
  34. package/dist/lib/config-migration.js +1 -1
  35. package/dist/lib/container-credential-sync.js +1 -1
  36. package/dist/lib/container-tokens.js +1 -1
  37. package/dist/lib/data-dir.js +1 -1
  38. package/dist/lib/deployment-history.js +1 -1
  39. package/dist/lib/deployment-service.js +1 -1
  40. package/dist/lib/docker-utils.js +1 -1
  41. package/dist/lib/email.js +1 -1
  42. package/dist/lib/emailTemplates.js +1 -1
  43. package/dist/lib/entitlement.js +1 -1
  44. package/dist/lib/external-connections.js +1 -1
  45. package/dist/lib/fetch-utils.js +1 -1
  46. package/dist/lib/git-commit-details-route.js +1 -1
  47. package/dist/lib/git-history-diff-guardrails.js +1 -1
  48. package/dist/lib/git-provider-service.js +1 -1
  49. package/dist/lib/git-provider-setup/github-setup-handler.js +1 -1
  50. package/dist/lib/git-provider-setup/index.js +1 -1
  51. package/dist/lib/git-provider-setup/setup-factory.js +1 -1
  52. package/dist/lib/git-provider-setup/setup-interface.js +1 -1
  53. package/dist/lib/git-providers/azure-devops-provider.js +1 -1
  54. package/dist/lib/git-providers/github-app-provider.js +1 -1
  55. package/dist/lib/git-providers/index.js +1 -1
  56. package/dist/lib/git-providers/provider-factory.js +1 -1
  57. package/dist/lib/git-providers/provider-interface.js +1 -1
  58. package/dist/lib/github-urls.js +1 -1
  59. package/dist/lib/group-objective-linking.js +1 -1
  60. package/dist/lib/ibmi-sync.js +1 -1
  61. package/dist/lib/jira-client.js +1 -1
  62. package/dist/lib/judge-blinding.js +1 -1
  63. package/dist/lib/logger.js +1 -1
  64. package/dist/lib/memory-utils.js +1 -1
  65. package/dist/lib/migration-to-scoped-rbac.js +1 -1
  66. package/dist/lib/model-fetcher.js +1 -1
  67. package/dist/lib/notifications.js +1 -1
  68. package/dist/lib/objective-context.js +1 -1
  69. package/dist/lib/oidc-auth.js +1 -1
  70. package/dist/lib/oidc-device-flow.js +1 -1
  71. package/dist/lib/passwordTokens.js +1 -1
  72. package/dist/lib/permission-resolver.js +1 -1
  73. package/dist/lib/pin-cascade.js +1 -1
  74. package/dist/lib/provider-accounts.js +1 -1
  75. package/dist/lib/provider-oauth.js +1 -1
  76. package/dist/lib/provider-profile.js +1 -1
  77. package/dist/lib/provider-token-refresh.js +1 -1
  78. package/dist/lib/rbac-user-state.js +1 -1
  79. package/dist/lib/request-url.js +1 -1
  80. package/dist/lib/rewind.js +1 -1
  81. package/dist/lib/role-definitions.js +1 -1
  82. package/dist/lib/roles.js +1 -1
  83. package/dist/lib/secrets.js +1 -1
  84. package/dist/lib/setup-repo-git-auth.js +1 -1
  85. package/dist/lib/slack-service.js +1 -0
  86. package/dist/lib/state-capture.js +1 -1
  87. package/dist/lib/static-files.js +1 -1
  88. package/dist/lib/task-aliases.js +1 -1
  89. package/dist/lib/task-container-init.js +1 -1
  90. package/dist/lib/task-context-usage.js +1 -1
  91. package/dist/lib/task-name-format.js +1 -1
  92. package/dist/lib/task-name-generator.js +1 -1
  93. package/dist/lib/task-source-metadata.js +1 -1
  94. package/dist/lib/teams.js +1 -1
  95. package/dist/lib/user-git-oauth.js +1 -1
  96. package/dist/lib/user-git-tokens.js +1 -1
  97. package/dist/lib/users.js +1 -1
  98. package/dist/middleware/requireAuth.js +1 -1
  99. package/dist/middleware/requireInit.js +1 -1
  100. package/dist/middleware/requirePermission.js +1 -1
  101. package/dist/package.json +1 -1
  102. package/dist/playwright.config.js +1 -1
  103. package/dist/playwright.task-terminal.config.js +1 -1
  104. package/dist/routes/apiKeys.js +1 -1
  105. package/dist/routes/auth-oidc.js +1 -1
  106. package/dist/routes/auth.js +1 -1
  107. package/dist/routes/automations.js +1 -1
  108. package/dist/routes/bindings.js +1 -1
  109. package/dist/routes/build.js +1 -1
  110. package/dist/routes/containers.js +1 -1
  111. package/dist/routes/deploy-task.js +1 -1
  112. package/dist/routes/environment-management.js +1 -1
  113. package/dist/routes/environments.js +1 -1
  114. package/dist/routes/external-skills.js +1 -1
  115. package/dist/routes/git-credentials.js +1 -1
  116. package/dist/routes/git-oauth.js +1 -1
  117. package/dist/routes/git-provider-setup.js +1 -1
  118. package/dist/routes/health.js +1 -1
  119. package/dist/routes/jira.js +1 -1
  120. package/dist/routes/logs.js +1 -1
  121. package/dist/routes/objective-management.js +1 -1
  122. package/dist/routes/password.js +1 -1
  123. package/dist/routes/prompt.js +1 -1
  124. package/dist/routes/provider-auth.js +1 -1
  125. package/dist/routes/qa.js +1 -1
  126. package/dist/routes/roles.js +1 -1
  127. package/dist/routes/settings.js +1 -1
  128. package/dist/routes/skill-management.js +1 -1
  129. package/dist/routes/skills.js +1 -1
  130. package/dist/routes/slack.js +1 -0
  131. package/dist/routes/stats.js +1 -1
  132. package/dist/routes/tasks.js +1 -1
  133. package/dist/routes/teams.js +1 -1
  134. package/dist/routes/templates.js +1 -1
  135. package/dist/routes/test-task.js +1 -1
  136. package/dist/routes/test.js +1 -1
  137. package/dist/routes/users.js +1 -1
  138. package/dist/routes/visualizations.js +1 -1
  139. package/dist/scripts/create-user.js +1 -1
  140. package/dist/scripts/migrate-config-to-data-dir.js +1 -1
  141. package/dist/start.js +1 -1
  142. package/dist/web-ui/public/activity-detail-modal.js +1 -1
  143. package/dist/web-ui/public/activity-feed.js +1 -1
  144. package/dist/web-ui/public/activity-formatters.js +1 -1
  145. package/dist/web-ui/public/admin.js +1 -1
  146. package/dist/web-ui/public/agent-event-parser.js +1 -1
  147. package/dist/web-ui/public/app.js +1 -1
  148. package/dist/web-ui/public/approve-dialog.js +1 -1
  149. package/dist/web-ui/public/automation-links.js +1 -1
  150. package/dist/web-ui/public/automation-schedule.js +1 -1
  151. package/dist/web-ui/public/comments-widget.js +1 -1
  152. package/dist/web-ui/public/diff-utils.js +1 -1
  153. package/dist/web-ui/public/environments.js +1 -1
  154. package/dist/web-ui/public/feedback-widget.js +1 -1
  155. package/dist/web-ui/public/file-selection-tree.js +1 -1
  156. package/dist/web-ui/public/git-history-lazy-utils.js +1 -1
  157. package/dist/web-ui/public/git-history.js +1 -1
  158. package/dist/web-ui/public/git-status.js +1 -1
  159. package/dist/web-ui/public/ibmi-file-filter.js +1 -1
  160. package/dist/web-ui/public/index.js +1 -1
  161. package/dist/web-ui/public/login.js +1 -1
  162. package/dist/web-ui/public/markdown-editor.js +1 -1
  163. package/dist/web-ui/public/markdown-file-editor.js +1 -1
  164. package/dist/web-ui/public/modal-maximize.js +1 -1
  165. package/dist/web-ui/public/notifications.js +1 -1
  166. package/dist/web-ui/public/permissions.js +1 -1
  167. package/dist/web-ui/public/pr-dialog.js +1 -1
  168. package/dist/web-ui/public/roles.js +1 -1
  169. package/dist/web-ui/public/settings.html +146 -0
  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.js +1 -1
  173. package/dist/web-ui/public/sse-client.js +1 -1
  174. package/dist/web-ui/public/sse-client.transport-warning.js +1 -0
  175. package/dist/web-ui/public/sse-shared-worker.js +1 -1
  176. package/dist/web-ui/public/task-judging-helpers.js +1 -1
  177. package/dist/web-ui/public/task.js +1 -1
  178. package/dist/web-ui/public/teams.js +1 -1
  179. package/dist/web-ui/public/terminal.js +1 -1
  180. package/dist/web-ui/public/theme.js +1 -1
  181. package/dist/web-ui/public/users.js +1 -1
  182. package/dist/web-ui/public/variant-grouping.js +1 -1
  183. package/package.json +1 -1
@@ -1 +1 @@
1
- let monacoLoadPromise=null;async function ensureMonacoLoaded(){if(typeof monaco!=='undefined')return;if(monacoLoadPromise)return monacoLoadPromise;const _0x30170e=document['querySelector']('script[src*=\x22monaco-editor\x22][src*=\x22loader.js\x22]');if(_0x30170e)return monacoLoadPromise=new Promise((_0x68ea31,_0x453eef)=>{const _0x1e2bb4=setInterval(()=>{typeof monaco!=='undefined'&&(clearInterval(_0x1e2bb4),_0x68ea31());},0x32);setTimeout(()=>{clearInterval(_0x1e2bb4),_0x453eef(new Error('Monaco\x20loading\x20timeout'));},0x2710);}),monacoLoadPromise;return monacoLoadPromise=new Promise((_0x47bf56,_0x17d044)=>{const _0x476653=document['createElement']('script');_0x476653['src']='/vendor/monaco-editor/0.45.0/min/vs/loader.js',_0x476653['onload']=()=>{require['config']({'paths':{'vs':'/vendor/monaco-editor/0.45.0/min/vs'}}),require(['vs/editor/editor.main'],()=>{_0x47bf56();});},_0x476653['onerror']=()=>_0x17d044(new Error('Failed\x20to\x20load\x20Monaco\x20Editor')),document['head']['appendChild'](_0x476653);}),monacoLoadPromise;}function getMonacoTheme(){const _0x3a9e52=document['documentElement']['getAttribute']('data-theme')==='dark';return _0x3a9e52?'vs-dark':'vs';}function isMarkdownFile(_0x58e0c9){if(!_0x58e0c9)return![];const _0x383c31=_0x58e0c9['split']('.')['pop']()['toLowerCase']();return _0x383c31==='md'||_0x383c31==='markdown';}function createMarkdownFileEditor(_0x1d0de4){const {container:_0x910a7,content:content='',readOnly:readOnly=![],height:height='400px',onChange:onChange=null,placeholder:placeholder='Enter\x20markdown\x20content...',enableModeToggle:enableModeToggle=!![],initialMode:initialMode='visual'}=_0x1d0de4;_0x910a7['innerHTML']='';const _0x55bc14=document['createElement']('div');_0x55bc14['className']='markdown-file-editor-wrapper',_0x55bc14['style']['height']=height,_0x55bc14['style']['display']='flex',_0x55bc14['style']['flexDirection']='column',_0x55bc14['style']['border']='1px\x20solid\x20var(--color-border)',_0x55bc14['style']['borderRadius']='var(--radius-small)',_0x55bc14['style']['overflow']='hidden';const _0xbe393a=document['createElement']('textarea');_0xbe393a['style']['display']='none',_0xbe393a['value']=content,_0x55bc14['appendChild'](_0xbe393a),_0x910a7['appendChild'](_0x55bc14);const _0x279a0e=new window['MarkdownEditor'](_0xbe393a,{'placeholder':placeholder,'editable':!readOnly,'minHeight':'100%','toolbar':!readOnly,'sourceToggle':!readOnly&&enableModeToggle!==![],'sourceLineNumbers':!![],'onChange':_0x8d87c5=>{onChange&&onChange(_0x8d87c5);}});_0x279a0e['container']&&(_0x279a0e['container']['style']['flex']='1',_0x279a0e['container']['style']['display']='flex',_0x279a0e['container']['style']['flexDirection']='column',_0x279a0e['container']['style']['overflow']='hidden');_0x279a0e['editor']&&(_0x279a0e['editor']['style']['flex']='1',_0x279a0e['editor']['style']['overflow']='auto',_0x279a0e['editor']['style']['minHeight']='0',_0x279a0e['editor']['style']['border']='none',_0x279a0e['editor']['style']['borderRadius']='0',_0x279a0e['editor']['style']['padding']='16px',_0x279a0e['editor']['style']['fontSize']='14px',_0x279a0e['editor']['style']['lineHeight']='1.6');_0x279a0e['toolbar']&&(_0x279a0e['toolbar']['style']['borderRadius']='0',_0x279a0e['toolbar']['style']['flexShrink']='0');content&&_0x279a0e['setMarkdown'](content);initialMode==='source'&&!readOnly&&enableModeToggle!==![]&&setTimeout(()=>_0x279a0e['setMode']('source'),0x0);const _0x19a4a9={'getValue':()=>_0x279a0e['getValue'](),'setValue':_0x41ee3e=>_0x279a0e['setValue'](_0x41ee3e||''),'focus':()=>_0x279a0e['focus'](),'setEditable':_0x3cc8d2=>_0x279a0e['setEditable'](_0x3cc8d2),'destroy':()=>{_0x279a0e['destroy'](),_0x910a7['innerHTML']='';},'getMode':()=>_0x279a0e['getMode'](),'setMode':_0x46cec0=>_0x279a0e['setMode'](_0x46cec0),'toggleMode':()=>_0x279a0e['toggleMode'](),'_visualEditor':_0x279a0e,'_getSourceEditor':()=>_0x279a0e['_monacoEditor'],'_container':_0x910a7,'_isMarkdownFileEditor':!![],'_hasModeToggle':enableModeToggle};return _0x19a4a9;}const markdownFileEditors=new Map();function getOrCreateMarkdownFileEditor(_0x2f22fb,_0x3d2e23,_0x4189fc=![],_0x5d639d='400px',_0x13ce53=null,_0xd28390={}){const _0xa22689=document['getElementById'](_0x2f22fb);if(!_0xa22689)return console['error']('Container\x20not\x20found:\x20'+_0x2f22fb),null;const _0x21698b=markdownFileEditors['get'](_0x2f22fb);if(_0x21698b){try{_0x21698b['destroy']();}catch(_0x2032b8){console['warn']('Failed\x20to\x20destroy\x20existing\x20markdown\x20editor:',_0x2032b8);}markdownFileEditors['delete'](_0x2f22fb);}const _0x7b1776=createMarkdownFileEditor({'container':_0xa22689,'content':_0x3d2e23,'readOnly':_0x4189fc,'height':_0x5d639d,'onChange':_0x13ce53,..._0xd28390});return markdownFileEditors['set'](_0x2f22fb,_0x7b1776),_0x7b1776;}function getMarkdownFileEditorValue(_0x297771){const _0x471f6e=markdownFileEditors['get'](_0x297771);if(!_0x471f6e)return null;return _0x471f6e['getValue']();}function setMarkdownFileEditorValue(_0x2eb01b,_0x513150){const _0x4e33c8=markdownFileEditors['get'](_0x2eb01b);_0x4e33c8&&_0x4e33c8['setValue'](_0x513150||'');}function disposeMarkdownFileEditor(_0x2ffe5b){const _0x528518=markdownFileEditors['get'](_0x2ffe5b);if(_0x528518){try{_0x528518['destroy']();}catch(_0x438915){console['warn']('Failed\x20to\x20dispose\x20markdown\x20editor:',_0x438915);}markdownFileEditors['delete'](_0x2ffe5b);}}function hasMarkdownFileEditor(_0x33ee5f){return markdownFileEditors['has'](_0x33ee5f);}function getMarkdownFileEditorMode(_0x4604d7){const _0x5c2dbe=markdownFileEditors['get'](_0x4604d7);if(!_0x5c2dbe||!_0x5c2dbe['getMode'])return null;return _0x5c2dbe['getMode']();}function setMarkdownFileEditorMode(_0xa9143a,_0x2988ed){const _0xb3b833=markdownFileEditors['get'](_0xa9143a);_0xb3b833&&_0xb3b833['setMode']&&_0xb3b833['setMode'](_0x2988ed);}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 _0x5be9ee=document['querySelector']('script[src*=\x22monaco-editor\x22][src*=\x22loader.js\x22]');if(_0x5be9ee)return monacoLoadPromise=new Promise((_0x2033b6,_0x296b5e)=>{const _0x2f7489=setInterval(()=>{typeof monaco!=='undefined'&&(clearInterval(_0x2f7489),_0x2033b6());},0x32);setTimeout(()=>{clearInterval(_0x2f7489),_0x296b5e(new Error('Monaco\x20loading\x20timeout'));},0x2710);}),monacoLoadPromise;return monacoLoadPromise=new Promise((_0x145378,_0x19591c)=>{const _0x2516aa=document['createElement']('script');_0x2516aa['src']='/vendor/monaco-editor/0.45.0/min/vs/loader.js',_0x2516aa['onload']=()=>{require['config']({'paths':{'vs':'/vendor/monaco-editor/0.45.0/min/vs'}}),require(['vs/editor/editor.main'],()=>{_0x145378();});},_0x2516aa['onerror']=()=>_0x19591c(new Error('Failed\x20to\x20load\x20Monaco\x20Editor')),document['head']['appendChild'](_0x2516aa);}),monacoLoadPromise;}function getMonacoTheme(){const _0x19271a=document['documentElement']['getAttribute']('data-theme')==='dark';return _0x19271a?'vs-dark':'vs';}function isMarkdownFile(_0x2d8e0e){if(!_0x2d8e0e)return![];const _0x289f46=_0x2d8e0e['split']('.')['pop']()['toLowerCase']();return _0x289f46==='md'||_0x289f46==='markdown';}function createMarkdownFileEditor(_0x56a26b){const {container:_0x34b444,content:content='',readOnly:readOnly=![],height:height='400px',onChange:onChange=null,placeholder:placeholder='Enter\x20markdown\x20content...',enableModeToggle:enableModeToggle=!![],initialMode:initialMode='visual'}=_0x56a26b;_0x34b444['innerHTML']='';const _0x5af252=document['createElement']('div');_0x5af252['className']='markdown-file-editor-wrapper',_0x5af252['style']['height']=height,_0x5af252['style']['display']='flex',_0x5af252['style']['flexDirection']='column',_0x5af252['style']['border']='1px\x20solid\x20var(--color-border)',_0x5af252['style']['borderRadius']='var(--radius-small)',_0x5af252['style']['overflow']='hidden';const _0x297a82=document['createElement']('textarea');_0x297a82['style']['display']='none',_0x297a82['value']=content,_0x5af252['appendChild'](_0x297a82),_0x34b444['appendChild'](_0x5af252);const _0x4f7b64=new window['MarkdownEditor'](_0x297a82,{'placeholder':placeholder,'editable':!readOnly,'minHeight':'100%','toolbar':!readOnly,'sourceToggle':!readOnly&&enableModeToggle!==![],'sourceLineNumbers':!![],'onChange':_0xdc7230=>{onChange&&onChange(_0xdc7230);}});_0x4f7b64['container']&&(_0x4f7b64['container']['style']['flex']='1',_0x4f7b64['container']['style']['display']='flex',_0x4f7b64['container']['style']['flexDirection']='column',_0x4f7b64['container']['style']['overflow']='hidden');_0x4f7b64['editor']&&(_0x4f7b64['editor']['style']['flex']='1',_0x4f7b64['editor']['style']['overflow']='auto',_0x4f7b64['editor']['style']['minHeight']='0',_0x4f7b64['editor']['style']['border']='none',_0x4f7b64['editor']['style']['borderRadius']='0',_0x4f7b64['editor']['style']['padding']='16px',_0x4f7b64['editor']['style']['fontSize']='14px',_0x4f7b64['editor']['style']['lineHeight']='1.6');_0x4f7b64['toolbar']&&(_0x4f7b64['toolbar']['style']['borderRadius']='0',_0x4f7b64['toolbar']['style']['flexShrink']='0');content&&_0x4f7b64['setMarkdown'](content);initialMode==='source'&&!readOnly&&enableModeToggle!==![]&&setTimeout(()=>_0x4f7b64['setMode']('source'),0x0);const _0x5d36eb={'getValue':()=>_0x4f7b64['getValue'](),'setValue':_0x52ff05=>_0x4f7b64['setValue'](_0x52ff05||''),'focus':()=>_0x4f7b64['focus'](),'setEditable':_0x2cfddc=>_0x4f7b64['setEditable'](_0x2cfddc),'destroy':()=>{_0x4f7b64['destroy'](),_0x34b444['innerHTML']='';},'getMode':()=>_0x4f7b64['getMode'](),'setMode':_0x16f641=>_0x4f7b64['setMode'](_0x16f641),'toggleMode':()=>_0x4f7b64['toggleMode'](),'_visualEditor':_0x4f7b64,'_getSourceEditor':()=>_0x4f7b64['_monacoEditor'],'_container':_0x34b444,'_isMarkdownFileEditor':!![],'_hasModeToggle':enableModeToggle};return _0x5d36eb;}const markdownFileEditors=new Map();function getOrCreateMarkdownFileEditor(_0x5df2e4,_0x5cfaaa,_0x23937b=![],_0x1c1491='400px',_0x2a583f=null,_0x1e8d74={}){const _0x324cca=document['getElementById'](_0x5df2e4);if(!_0x324cca)return console['error']('Container\x20not\x20found:\x20'+_0x5df2e4),null;const _0x15c2fa=markdownFileEditors['get'](_0x5df2e4);if(_0x15c2fa){try{_0x15c2fa['destroy']();}catch(_0x153d61){console['warn']('Failed\x20to\x20destroy\x20existing\x20markdown\x20editor:',_0x153d61);}markdownFileEditors['delete'](_0x5df2e4);}const _0x215436=createMarkdownFileEditor({'container':_0x324cca,'content':_0x5cfaaa,'readOnly':_0x23937b,'height':_0x1c1491,'onChange':_0x2a583f,..._0x1e8d74});return markdownFileEditors['set'](_0x5df2e4,_0x215436),_0x215436;}function getMarkdownFileEditorValue(_0x2a6e83){const _0x5d5042=markdownFileEditors['get'](_0x2a6e83);if(!_0x5d5042)return null;return _0x5d5042['getValue']();}function setMarkdownFileEditorValue(_0x3d50a1,_0x4dddf6){const _0x442f77=markdownFileEditors['get'](_0x3d50a1);_0x442f77&&_0x442f77['setValue'](_0x4dddf6||'');}function disposeMarkdownFileEditor(_0x5aaebc){const _0x26018b=markdownFileEditors['get'](_0x5aaebc);if(_0x26018b){try{_0x26018b['destroy']();}catch(_0x427a16){console['warn']('Failed\x20to\x20dispose\x20markdown\x20editor:',_0x427a16);}markdownFileEditors['delete'](_0x5aaebc);}}function hasMarkdownFileEditor(_0x5a31df){return markdownFileEditors['has'](_0x5a31df);}function getMarkdownFileEditorMode(_0x482be7){const _0x4db8f1=markdownFileEditors['get'](_0x482be7);if(!_0x4db8f1||!_0x4db8f1['getMode'])return null;return _0x4db8f1['getMode']();}function setMarkdownFileEditorMode(_0x560466,_0xec6a9){const _0x3d9fa5=markdownFileEditors['get'](_0x560466);_0x3d9fa5&&_0x3d9fa5['setMode']&&_0x3d9fa5['setMode'](_0xec6a9);}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(_0x2e2a25){if(!_0x2e2a25||typeof _0x2e2a25['getAnimations']!=='function')return;try{_0x2e2a25['getAnimations']()['forEach'](_0x140670=>_0x140670['cancel']());}catch{}}function animateRestoreFlip({contentEl:_0x35aaa1,fromRect:_0x2e4c1a,toRect:_0x33164e,durationMs:_0x307398}){if(!_0x35aaa1)return;if(!_0x2e4c1a||!_0x33164e)return;if(prefersReducedMotion())return;const _0x516b4c=_0x33164e['width']||0x0,_0x34238a=_0x33164e['height']||0x0,_0xa60a64=_0x2e4c1a['width']||0x0,_0x6f405f=_0x2e4c1a['height']||0x0;if(_0x516b4c<=0x0||_0x34238a<=0x0||_0xa60a64<=0x0||_0x6f405f<=0x0)return;const _0x4b991e=_0x2e4c1a['left']-_0x33164e['left'],_0x35b579=_0x2e4c1a['top']-_0x33164e['top'],_0x23d462=_0xa60a64/_0x516b4c,_0x4c3602=_0x6f405f/_0x34238a;if(!Number['isFinite'](_0x4b991e)||!Number['isFinite'](_0x35b579)||!Number['isFinite'](_0x23d462)||!Number['isFinite'](_0x4c3602))return;safeCancelAnimations(_0x35aaa1);const _0x18b968=_0x35aaa1['style']['transition'],_0xd406c1=_0x35aaa1['style']['transformOrigin'],_0x195d05=_0x35aaa1['style']['willChange'];_0x35aaa1['style']['transition']='none',_0x35aaa1['style']['transformOrigin']='top\x20left',_0x35aaa1['style']['willChange']='transform';const _0x244634='translate('+_0x4b991e+'px,\x20'+_0x35b579+'px)\x20scale('+_0x23d462+',\x20'+_0x4c3602+')',_0x3ea140=_0x35aaa1['animate']([{'transform':_0x244634},{'transform':'none'}],{'duration':_0x307398,'easing':'ease','fill':'both'}),_0x52f2e1=()=>{_0x35aaa1['style']['transition']=_0x18b968,_0x35aaa1['style']['transformOrigin']=_0xd406c1,_0x35aaa1['style']['willChange']=_0x195d05;};_0x3ea140['addEventListener']('finish',_0x52f2e1,{'once':!![]}),_0x3ea140['addEventListener']('cancel',_0x52f2e1,{'once':!![]});}export function toggleModalMaximize(_0x3d5c6b,_0x48865e={}){if(!_0x3d5c6b)return;const {storageKey:_0x226ba0,updateIcon:_0x56fb9d,onAfterToggle:_0x5a7650,durationMs:durationMs=DEFAULT_DURATION_MS}=_0x48865e,_0x57f5c2=_0x3d5c6b['querySelector']('.modal-content'),_0x1800a9=_0x3d5c6b['classList']['contains']('maximized'),_0x3d48db=!_0x1800a9;if(!_0x57f5c2){_0x3d5c6b['classList']['toggle']('maximized'),_0x56fb9d?.(_0x3d48db),_0x5a7650?.(_0x3d48db);if(_0x226ba0)try{localStorage['setItem'](_0x226ba0,String(_0x3d48db));}catch{}return;}if(_0x1800a9&&!prefersReducedMotion()){const _0x4c8634=_0x57f5c2['getBoundingClientRect']();_0x3d5c6b['classList']['remove']('maximized');const _0x1f9b30=_0x57f5c2['getBoundingClientRect']();animateRestoreFlip({'contentEl':_0x57f5c2,'fromRect':_0x4c8634,'toRect':_0x1f9b30,'durationMs':durationMs});}else _0x3d5c6b['classList']['toggle']('maximized');_0x56fb9d?.(_0x3d48db),_0x5a7650?.(_0x3d48db);if(_0x226ba0)try{localStorage['setItem'](_0x226ba0,String(_0x3d48db));}catch{}}
1
+ const DEFAULT_DURATION_MS=0xfa;function prefersReducedMotion(){try{return window['matchMedia']&&window['matchMedia']('(prefers-reduced-motion:\x20reduce)')['matches'];}catch{return![];}}function safeCancelAnimations(_0x452bf7){if(!_0x452bf7||typeof _0x452bf7['getAnimations']!=='function')return;try{_0x452bf7['getAnimations']()['forEach'](_0x1817cc=>_0x1817cc['cancel']());}catch{}}function animateRestoreFlip({contentEl:_0x25a2f4,fromRect:_0x897ad4,toRect:_0x1b34b3,durationMs:_0x34a8bf}){if(!_0x25a2f4)return;if(!_0x897ad4||!_0x1b34b3)return;if(prefersReducedMotion())return;const _0x1835bc=_0x1b34b3['width']||0x0,_0xf43d91=_0x1b34b3['height']||0x0,_0x5fe89e=_0x897ad4['width']||0x0,_0x781bbe=_0x897ad4['height']||0x0;if(_0x1835bc<=0x0||_0xf43d91<=0x0||_0x5fe89e<=0x0||_0x781bbe<=0x0)return;const _0x2a1176=_0x897ad4['left']-_0x1b34b3['left'],_0x4055ee=_0x897ad4['top']-_0x1b34b3['top'],_0x3a11f5=_0x5fe89e/_0x1835bc,_0x53a9d9=_0x781bbe/_0xf43d91;if(!Number['isFinite'](_0x2a1176)||!Number['isFinite'](_0x4055ee)||!Number['isFinite'](_0x3a11f5)||!Number['isFinite'](_0x53a9d9))return;safeCancelAnimations(_0x25a2f4);const _0x1d92e5=_0x25a2f4['style']['transition'],_0x42643f=_0x25a2f4['style']['transformOrigin'],_0x4cdf12=_0x25a2f4['style']['willChange'];_0x25a2f4['style']['transition']='none',_0x25a2f4['style']['transformOrigin']='top\x20left',_0x25a2f4['style']['willChange']='transform';const _0x2765ea='translate('+_0x2a1176+'px,\x20'+_0x4055ee+'px)\x20scale('+_0x3a11f5+',\x20'+_0x53a9d9+')',_0x4f8ee8=_0x25a2f4['animate']([{'transform':_0x2765ea},{'transform':'none'}],{'duration':_0x34a8bf,'easing':'ease','fill':'both'}),_0x541e0b=()=>{_0x25a2f4['style']['transition']=_0x1d92e5,_0x25a2f4['style']['transformOrigin']=_0x42643f,_0x25a2f4['style']['willChange']=_0x4cdf12;};_0x4f8ee8['addEventListener']('finish',_0x541e0b,{'once':!![]}),_0x4f8ee8['addEventListener']('cancel',_0x541e0b,{'once':!![]});}export function toggleModalMaximize(_0x2dee0d,_0x39580b={}){if(!_0x2dee0d)return;const {storageKey:_0x6ea135,updateIcon:_0x382e37,onAfterToggle:_0x3b76e8,durationMs:durationMs=DEFAULT_DURATION_MS}=_0x39580b,_0x6d554a=_0x2dee0d['querySelector']('.modal-content'),_0xbee4e8=_0x2dee0d['classList']['contains']('maximized'),_0xf0effe=!_0xbee4e8;if(!_0x6d554a){_0x2dee0d['classList']['toggle']('maximized'),_0x382e37?.(_0xf0effe),_0x3b76e8?.(_0xf0effe);if(_0x6ea135)try{localStorage['setItem'](_0x6ea135,String(_0xf0effe));}catch{}return;}if(_0xbee4e8&&!prefersReducedMotion()){const _0x16e4da=_0x6d554a['getBoundingClientRect']();_0x2dee0d['classList']['remove']('maximized');const _0x1a9e00=_0x6d554a['getBoundingClientRect']();animateRestoreFlip({'contentEl':_0x6d554a,'fromRect':_0x16e4da,'toRect':_0x1a9e00,'durationMs':durationMs});}else _0x2dee0d['classList']['toggle']('maximized');_0x382e37?.(_0xf0effe),_0x3b76e8?.(_0xf0effe);if(_0x6ea135)try{localStorage['setItem'](_0x6ea135,String(_0xf0effe));}catch{}}
@@ -1 +1 @@
1
- export const NotificationManager={'isSupported'(){return'Notification'in window;},'isEnabled'(){if(!this['isSupported']())return![];return localStorage['getItem']('notifications-enabled')==='true';},'setEnabled'(_0x38d38e){localStorage['setItem']('notifications-enabled',_0x38d38e?'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 _0x506cf7=await Notification['requestPermission']();return _0x506cf7;}catch(_0x2356d4){return console['error']('Failed\x20to\x20request\x20notification\x20permission:',_0x2356d4),'denied';}},async 'show'(_0x2f87b6,_0x40e38b={}){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 _0x3083bb=new Notification(_0x2f87b6,{'icon':_0x40e38b['icon']||'/favicon.ico','badge':_0x40e38b['badge']||'/favicon.ico','body':_0x40e38b['body']||'','tag':_0x40e38b['tag']||'','requireInteraction':_0x40e38b['requireInteraction']||![],'silent':_0x40e38b['silent']||![],'data':_0x40e38b['data']||{}});_0x40e38b['onClick']&&(_0x3083bb['onclick']=_0x45147d=>{_0x45147d['preventDefault'](),window['focus'](),_0x40e38b['onClick'](_0x45147d,_0x3083bb),_0x3083bb['close']();});if(!_0x40e38b['requireInteraction']){const _0x485685=_0x40e38b['duration']||0x1388;setTimeout(()=>{_0x3083bb['close']();},_0x485685);}return _0x3083bb;}catch(_0x13d77a){return console['error']('Failed\x20to\x20show\x20notification:',_0x13d77a),null;}},async 'notifyTaskComplete'(_0x2f0ca0){const _0x5f0928=_0x2f0ca0['exitCode']!==undefined?_0x2f0ca0['exitCode']:_0x2f0ca0['exit_code'],_0x3fd532=_0x2f0ca0['status']==='completed'&&_0x5f0928===0x0,_0x288ad2=_0x2f0ca0['status']==='interrupted',_0x14c847=_0x3fd532?'✅\x20Task\x20Completed\x20Successfully':_0x288ad2?'⏹️\x20Task\x20Interrupted':'❌\x20Task\x20Failed';let _0x1ea7f3;if(_0x2f0ca0['taskType']==='test'){const _0x37964c=_0x2f0ca0['testName']||'Test',_0x1ccc34=_0x2f0ca0['testDescription']||_0x2f0ca0['description']||'';if(_0x1ccc34&&_0x1ccc34['length']>0x0){let _0x15fdaa=_0x1ccc34;_0x1ccc34['length']>0x50&&(_0x15fdaa=_0x1ccc34['substring'](0x0,0x4d)+'...'),_0x1ea7f3='Test:\x20'+_0x37964c+'\x20-\x20'+_0x15fdaa;}else _0x1ea7f3='Test:\x20'+_0x37964c;}else{if(_0x2f0ca0['taskType']==='deploy'){const _0x4f8274=_0x2f0ca0['deployProfile']||'Deploy',_0x62a742=_0x2f0ca0['deployDescription']||_0x2f0ca0['description']||'';if(_0x62a742&&_0x62a742['length']>0x0){let _0x12333b=_0x62a742;_0x62a742['length']>0x50&&(_0x12333b=_0x62a742['substring'](0x0,0x4d)+'...'),_0x1ea7f3='Deploy:\x20'+_0x4f8274+'\x20-\x20'+_0x12333b;}else _0x1ea7f3='Deploy:\x20'+_0x4f8274;}else{const _0x104468=_0x2f0ca0['name']?_0x2f0ca0['name']['trim']():null,_0x2a9c08=_0x2f0ca0['envVars']?.['CODER_AGENT']||_0x2f0ca0['envVars']?.['default_agent']||'Unknown',_0x3d7052=_0x2a9c08['charAt'](0x0)['toUpperCase']()+_0x2a9c08['slice'](0x1);let _0x5e1ec1,_0x354882=![];if(_0x2f0ca0['followUpHistory']&&Array['isArray'](_0x2f0ca0['followUpHistory'])&&_0x2f0ca0['followUpHistory']['length']>0x0){const _0x4c0553=_0x2f0ca0['followUpHistory'][_0x2f0ca0['followUpHistory']['length']-0x1];_0x5e1ec1=_0x4c0553['instructions'],_0x354882=!![];}else _0x5e1ec1=_0x2f0ca0['description']||_0x2f0ca0['instructions']||_0x2f0ca0['taskId'];_0x5e1ec1['length']>0x64&&(_0x5e1ec1=_0x5e1ec1['substring'](0x0,0x61)+'...');const _0xe17f72=_0x354882?'[Follow-up]\x20':'';_0x104468?_0x1ea7f3=_0x104468+'\x0a'+_0x3d7052+':\x20'+_0xe17f72+_0x5e1ec1:_0x1ea7f3=_0x3d7052+':\x20'+_0xe17f72+_0x5e1ec1;}}return this['show'](_0x14c847,{'body':_0x1ea7f3,'tag':'task-'+_0x2f0ca0['taskId'],'requireInteraction':![],'duration':0x1f40,'data':{'taskId':_0x2f0ca0['taskId']},'onClick':(_0x3210c7,_0x1dd1f7)=>{window['open']('task.html?id='+_0x2f0ca0['taskId'],'_blank');}});},'shouldNotify'(_0x351f7b,_0x30a418){if(!this['isEnabled']())return![];if(_0x351f7b['status']!=='completed'&&_0x351f7b['status']!=='failed'&&_0x351f7b['status']!=='interrupted')return![];if(!_0x30a418['has'](_0x351f7b['taskId']))return![];const _0x45ea07='notified-'+_0x351f7b['taskId'];if(sessionStorage['getItem'](_0x45ea07)==='true')return![];return!![];},'markNotified'(_0x2c79a6){sessionStorage['setItem']('notified-'+_0x2c79a6,'true');},'clearNotificationHistory'(){const _0x5c6c95=[];for(let _0x4ae717=0x0;_0x4ae717<sessionStorage['length'];_0x4ae717++){const _0x456075=sessionStorage['key'](_0x4ae717);_0x456075['startsWith']('notified-')&&_0x5c6c95['push'](_0x456075);}_0x5c6c95['forEach'](_0x5bb217=>sessionStorage['removeItem'](_0x5bb217));}};
1
+ export const NotificationManager={'isSupported'(){return'Notification'in window;},'isEnabled'(){if(!this['isSupported']())return![];return localStorage['getItem']('notifications-enabled')==='true';},'setEnabled'(_0x1bf8f6){localStorage['setItem']('notifications-enabled',_0x1bf8f6?'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 _0x3eb9b5=await Notification['requestPermission']();return _0x3eb9b5;}catch(_0x27acd1){return console['error']('Failed\x20to\x20request\x20notification\x20permission:',_0x27acd1),'denied';}},async 'show'(_0x3bd45a,_0x3abc11={}){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 _0x58428f=new Notification(_0x3bd45a,{'icon':_0x3abc11['icon']||'/favicon.ico','badge':_0x3abc11['badge']||'/favicon.ico','body':_0x3abc11['body']||'','tag':_0x3abc11['tag']||'','requireInteraction':_0x3abc11['requireInteraction']||![],'silent':_0x3abc11['silent']||![],'data':_0x3abc11['data']||{}});_0x3abc11['onClick']&&(_0x58428f['onclick']=_0x3134ac=>{_0x3134ac['preventDefault'](),window['focus'](),_0x3abc11['onClick'](_0x3134ac,_0x58428f),_0x58428f['close']();});if(!_0x3abc11['requireInteraction']){const _0x25ad51=_0x3abc11['duration']||0x1388;setTimeout(()=>{_0x58428f['close']();},_0x25ad51);}return _0x58428f;}catch(_0x3c4042){return console['error']('Failed\x20to\x20show\x20notification:',_0x3c4042),null;}},async 'notifyTaskComplete'(_0x3464d7){const _0x494858=_0x3464d7['exitCode']!==undefined?_0x3464d7['exitCode']:_0x3464d7['exit_code'],_0x4f1245=_0x3464d7['status']==='completed'&&_0x494858===0x0,_0x20efb2=_0x3464d7['status']==='interrupted',_0x5bf561=_0x4f1245?'✅\x20Task\x20Completed\x20Successfully':_0x20efb2?'⏹️\x20Task\x20Interrupted':'❌\x20Task\x20Failed';let _0x57b207;if(_0x3464d7['taskType']==='test'){const _0x1cff30=_0x3464d7['testName']||'Test',_0x38a30d=_0x3464d7['testDescription']||_0x3464d7['description']||'';if(_0x38a30d&&_0x38a30d['length']>0x0){let _0x4f9438=_0x38a30d;_0x38a30d['length']>0x50&&(_0x4f9438=_0x38a30d['substring'](0x0,0x4d)+'...'),_0x57b207='Test:\x20'+_0x1cff30+'\x20-\x20'+_0x4f9438;}else _0x57b207='Test:\x20'+_0x1cff30;}else{if(_0x3464d7['taskType']==='deploy'){const _0x39db8d=_0x3464d7['deployProfile']||'Deploy',_0x175cae=_0x3464d7['deployDescription']||_0x3464d7['description']||'';if(_0x175cae&&_0x175cae['length']>0x0){let _0x364780=_0x175cae;_0x175cae['length']>0x50&&(_0x364780=_0x175cae['substring'](0x0,0x4d)+'...'),_0x57b207='Deploy:\x20'+_0x39db8d+'\x20-\x20'+_0x364780;}else _0x57b207='Deploy:\x20'+_0x39db8d;}else{const _0x88a0a6=_0x3464d7['name']?_0x3464d7['name']['trim']():null,_0x80c430=_0x3464d7['envVars']?.['CODER_AGENT']||_0x3464d7['envVars']?.['default_agent']||'Unknown',_0x3f4c12=_0x80c430['charAt'](0x0)['toUpperCase']()+_0x80c430['slice'](0x1);let _0x50f72d,_0x147f42=![];if(_0x3464d7['followUpHistory']&&Array['isArray'](_0x3464d7['followUpHistory'])&&_0x3464d7['followUpHistory']['length']>0x0){const _0x4b822e=_0x3464d7['followUpHistory'][_0x3464d7['followUpHistory']['length']-0x1];_0x50f72d=_0x4b822e['instructions'],_0x147f42=!![];}else _0x50f72d=_0x3464d7['description']||_0x3464d7['instructions']||_0x3464d7['taskId'];_0x50f72d['length']>0x64&&(_0x50f72d=_0x50f72d['substring'](0x0,0x61)+'...');const _0x3c592c=_0x147f42?'[Follow-up]\x20':'';_0x88a0a6?_0x57b207=_0x88a0a6+'\x0a'+_0x3f4c12+':\x20'+_0x3c592c+_0x50f72d:_0x57b207=_0x3f4c12+':\x20'+_0x3c592c+_0x50f72d;}}return this['show'](_0x5bf561,{'body':_0x57b207,'tag':'task-'+_0x3464d7['taskId'],'requireInteraction':![],'duration':0x1f40,'data':{'taskId':_0x3464d7['taskId']},'onClick':(_0x11909e,_0x50b307)=>{window['open']('task.html?id='+_0x3464d7['taskId'],'_blank');}});},'shouldNotify'(_0x26b543,_0x25b177){if(!this['isEnabled']())return![];if(_0x26b543['status']!=='completed'&&_0x26b543['status']!=='failed'&&_0x26b543['status']!=='interrupted')return![];if(!_0x25b177['has'](_0x26b543['taskId']))return![];const _0x311ef2='notified-'+_0x26b543['taskId'];if(sessionStorage['getItem'](_0x311ef2)==='true')return![];return!![];},'markNotified'(_0x46b99a){sessionStorage['setItem']('notified-'+_0x46b99a,'true');},'clearNotificationHistory'(){const _0x27e2aa=[];for(let _0x11bba7=0x0;_0x11bba7<sessionStorage['length'];_0x11bba7++){const _0xc4ff55=sessionStorage['key'](_0x11bba7);_0xc4ff55['startsWith']('notified-')&&_0x27e2aa['push'](_0xc4ff55);}_0x27e2aa['forEach'](_0x314d00=>sessionStorage['removeItem'](_0x314d00));}};
@@ -1 +1 @@
1
- function permissionInSet(_0xa1284a,_0x5b154c){if(!_0xa1284a||!_0x5b154c)return![];if(_0xa1284a['includes']('*'))return!![];if(_0xa1284a['includes'](_0x5b154c))return!![];const [_0xfb8c40]=_0x5b154c['split'](':');if(_0xa1284a['includes'](_0xfb8c40+':*'))return!![];return![];}function hasServerPermission(_0x1219de,_0x75d360){const _0x409d02=_0x1219de?.['permissions']?.['server'];if(!_0x409d02)return![];return permissionInSet(_0x409d02,_0x75d360);}function hasEnvPermission(_0x264746,_0x3beb19){if(hasServerPermission(_0x264746,'*'))return!![];const _0x49dab6=_0x264746?.['permissions']?.['environments'];if(!_0x49dab6)return![];for(const _0x5151f3 of Object['values'](_0x49dab6)){if(permissionInSet(_0x5151f3,_0x3beb19))return!![];}return![];}function hasEnvPermissionOn(_0x50dc02,_0x58ee80,_0x5c9b53){if(hasServerPermission(_0x50dc02,'*'))return!![];const _0x3fcd97=_0x50dc02?.['permissions']?.['environments']?.[_0x58ee80];if(!_0x3fcd97)return![];return permissionInSet(_0x3fcd97,_0x5c9b53);}function hasTeamPermission(_0x2c6fe7,_0x427b4a){if(hasServerPermission(_0x2c6fe7,'*'))return!![];const _0x25f0d0=_0x2c6fe7?.['permissions']?.['teams'];if(!_0x25f0d0)return![];for(const _0x277fbe of Object['values'](_0x25f0d0)){if(permissionInSet(_0x277fbe,_0x427b4a))return!![];}return![];}function hasAnyEnvironment(_0x5e15cd){if(hasServerPermission(_0x5e15cd,'*'))return!![];const _0x4dd159=_0x5e15cd?.['permissions']?.['environments'];return _0x4dd159!=null&&Object['keys'](_0x4dd159)['length']>0x0;}window['Permissions']={'hasServerPermission':hasServerPermission,'hasEnvPermission':hasEnvPermission,'hasEnvPermissionOn':hasEnvPermissionOn,'hasTeamPermission':hasTeamPermission,'hasAnyEnvironment':hasAnyEnvironment};
1
+ function permissionInSet(_0x1e2d7c,_0x37bc91){if(!_0x1e2d7c||!_0x37bc91)return![];if(_0x1e2d7c['includes']('*'))return!![];if(_0x1e2d7c['includes'](_0x37bc91))return!![];const [_0x447f6a]=_0x37bc91['split'](':');if(_0x1e2d7c['includes'](_0x447f6a+':*'))return!![];return![];}function hasServerPermission(_0x9f919c,_0x2cb391){const _0x4b2c42=_0x9f919c?.['permissions']?.['server'];if(!_0x4b2c42)return![];return permissionInSet(_0x4b2c42,_0x2cb391);}function hasEnvPermission(_0x2f3086,_0x2c73c4){if(hasServerPermission(_0x2f3086,'*'))return!![];const _0x611387=_0x2f3086?.['permissions']?.['environments'];if(!_0x611387)return![];for(const _0x1f88f6 of Object['values'](_0x611387)){if(permissionInSet(_0x1f88f6,_0x2c73c4))return!![];}return![];}function hasEnvPermissionOn(_0x24fc56,_0xb6f02,_0x2a84c4){if(hasServerPermission(_0x24fc56,'*'))return!![];const _0x5414e2=_0x24fc56?.['permissions']?.['environments']?.[_0xb6f02];if(!_0x5414e2)return![];return permissionInSet(_0x5414e2,_0x2a84c4);}function hasTeamPermission(_0x547e06,_0x5dd4fc){if(hasServerPermission(_0x547e06,'*'))return!![];const _0x2cf42f=_0x547e06?.['permissions']?.['teams'];if(!_0x2cf42f)return![];for(const _0x13ab73 of Object['values'](_0x2cf42f)){if(permissionInSet(_0x13ab73,_0x5dd4fc))return!![];}return![];}function hasAnyEnvironment(_0xb22e59){if(hasServerPermission(_0xb22e59,'*'))return!![];const _0x4f9bc2=_0xb22e59?.['permissions']?.['environments'];return _0x4f9bc2!=null&&Object['keys'](_0x4f9bc2)['length']>0x0;}window['Permissions']={'hasServerPermission':hasServerPermission,'hasEnvPermission':hasEnvPermission,'hasEnvPermissionOn':hasEnvPermissionOn,'hasTeamPermission':hasTeamPermission,'hasAnyEnvironment':hasAnyEnvironment};
@@ -1 +1 @@
1
- export function createPRDialogHTML(_0x4f4304='',_0x268373={}){const _0x33491f=_0x4f4304,_0x12ff0d=_0x268373['useTaskPageStyles']?'modal\x20profound-pr-modal':'profound-feedback-modal\x20profound-pr-modal',_0x5c8963=_0x268373['useTaskPageStyles']?'modal-warning':'pr-modal-warning',_0xe43f8=_0x268373['useTaskPageStyles']?'modal-error':'pr-modal-error';return'\x0a\x20\x20\x20\x20<div\x20id=\x22'+_0x33491f+'pr-modal\x22\x20class=\x22'+_0x12ff0d+'\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'+_0x33491f+'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'+_0x33491f+'pr-error\x22\x20class=\x22'+_0xe43f8+'\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'+_0x33491f+'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'+_0x33491f+'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'+_0x33491f+'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'+_0x33491f+'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'+_0x33491f+'pr-body\x22>Description:</label>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<textarea\x20id=\x22'+_0x33491f+'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'+_0x33491f+'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'+_0x33491f+'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'+_0x33491f+'cancel-pr\x22>Cancel</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-primary\x22\x20id=\x22'+_0x33491f+'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(_0x95f67e={}){this['prefix']=_0x95f67e['prefix']||'',this['onSubmit']=_0x95f67e['onSubmit'],this['onCancel']=_0x95f67e['onCancel'],this['showToast']=_0x95f67e['showToast']||(()=>{}),this['container']=_0x95f67e['container']||document['body'],this['useTaskPageStyles']=_0x95f67e['useTaskPageStyles']||![],this['baseUrl']=_0x95f67e['baseUrl']||'',this['prData']=null,this['initialized']=![],this['isSubmitting']=![];}['init'](){if(this['initialized'])return;const _0x28e542=document['createElement']('div');_0x28e542['innerHTML']=createPRDialogHTML(this['prefix'],{'useTaskPageStyles':this['useTaskPageStyles']}),this['container']['appendChild'](_0x28e542['firstElementChild']),this['_bindEvents'](),this['initialized']=!![];}['_el'](_0x212c3a){return document['getElementById'](''+this['prefix']+_0x212c3a);}['_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',_0x26db23=>{_0x26db23['target']['id']===this['prefix']+'pr-modal'&&this['hide']();}),document['addEventListener']('keydown',_0x5bc967=>{_0x5bc967['key']==='Escape'&&!this['_el']('pr-modal')['hidden']&&this['hide']();});}async['show'](_0xb7e315){if(!this['initialized'])this['init']();this['prData']=_0xb7e315;const {taskId:_0x420477,repos:_0x45405e,suggestedTitle:_0x12630d,suggestedBody:_0x6b3241}=_0xb7e315;return this['_el']('pr-title')['value']=_0x12630d||'',this['_el']('pr-body')['value']=_0x6b3241||'',this['_el']('pr-error')['hidden']=!![],await this['_renderRepoSelectors'](_0x45405e),this['_el']('pr-modal')['hidden']=![],new Promise(_0x167771=>{this['_dismissResolve']=_0x167771;});}async['_renderRepoSelectors'](_0x1f90a4){const _0x589b56=this['_el']('pr-repos-list');_0x589b56['innerHTML']='';for(const _0x220a5e of _0x1f90a4){if(!_0x220a5e['supportsPR'])continue;const _0x25bd0d=document['createElement']('div');_0x25bd0d['className']='pr-repo-selector';const _0x22e728=document['createElement']('span');_0x22e728['className']='pr-repo-name',_0x22e728['textContent']=_0x220a5e['name'];const _0x2c8f3e=document['createElement']('span');_0x2c8f3e['className']='pr-base-branch',_0x2c8f3e['textContent']=_0x220a5e['base']||_0x220a5e['defaultBranch']||'main',_0x2c8f3e['dataset']['repo']=_0x220a5e['name'],_0x2c8f3e['dataset']['base']=_0x220a5e['base']||_0x220a5e['defaultBranch']||'main';const _0x5ab4d5=document['createElement']('span');_0x5ab4d5['className']='pr-arrow',_0x5ab4d5['textContent']='←';const _0x1c1534=document['createElement']('span');_0x1c1534['className']='pr-source-branch',_0x1c1534['textContent']=_0x220a5e['head']||'(head\x20branch)',_0x25bd0d['appendChild'](_0x22e728),_0x25bd0d['appendChild'](_0x2c8f3e),_0x25bd0d['appendChild'](_0x5ab4d5),_0x25bd0d['appendChild'](_0x1c1534),_0x589b56['appendChild'](_0x25bd0d);}}['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 _0x1a7ca8=this['_el']('pr-title')['value']['trim'](),_0x31d7e4=this['_el']('pr-body')['value']['trim']();if(!_0x1a7ca8){this['_showError']('Pull\x20request\x20title\x20is\x20required');return;}const _0x491774=[],_0x55b1a4=this['_el']('pr-repos-list')['querySelectorAll']('.pr-base-branch');for(const _0x4e8bf5 of _0x55b1a4){const _0x6912b1=_0x4e8bf5['dataset']['repo'],_0x17aa16=_0x4e8bf5['dataset']['base'],_0x5196e2=this['prData']['repos']['find'](_0x4878f1=>_0x4878f1['name']===_0x6912b1);if(!_0x5196e2)continue;_0x491774['push']({'name':_0x6912b1,'title':_0x1a7ca8,'body':_0x31d7e4,'head':_0x5196e2['head'],'base':_0x17aa16});}if(_0x491774['length']===0x0){this['_showError']('No\x20repositories\x20selected');return;}this['isSubmitting']=!![],this['_el']('confirm-pr')['disabled']=!![],this['_el']('confirm-pr')['textContent']='Creating...';try{const _0x45a981=await this['onSubmit'](this['prData']['taskId'],_0x491774),_0x34a70c=_0x45a981['results']['every'](_0x56a918=>_0x56a918['success']),_0x597ba7=_0x45a981['results']['some'](_0x24108f=>_0x24108f['success']);if(_0x34a70c)this['showToast']('Pull\x20requests\x20created\x20successfully','success');else{if(_0x597ba7)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(_0x150ed7){console['error']('PR\x20creation\x20failed:',_0x150ed7),this['_showError'](_0x150ed7['message']||'Failed\x20to\x20create\x20pull\x20requests'),this['isSubmitting']=![],this['_el']('confirm-pr')['disabled']=![],this['_el']('confirm-pr')['textContent']='Create\x20Pull\x20Request';}}['_showError'](_0x34b335){this['_el']('pr-error-text')['textContent']=_0x34b335,this['_el']('pr-error')['hidden']=![];}static['checkOAuthRedirect'](_0x4b5b78){if(_0x4b5b78['get']('source')==='pr'&&_0x4b5b78['get']('git_connection')){const _0x1697cf=sessionStorage['getItem']('pendingPRData');if(_0x1697cf)try{const _0x438c83=JSON['parse'](_0x1697cf);if(Date['now']()-_0x438c83['timestamp']<0xa*0x3c*0x3e8)return sessionStorage['removeItem']('pendingPRData'),_0x438c83;}catch(_0x4ce16e){console['error']('Failed\x20to\x20parse\x20pending\x20PR\x20data:',_0x4ce16e);}}return null;}}
1
+ export function createPRDialogHTML(_0x4e514c='',_0x183816={}){const _0x6bbc4c=_0x4e514c,_0x894adb=_0x183816['useTaskPageStyles']?'modal\x20profound-pr-modal':'profound-feedback-modal\x20profound-pr-modal',_0x2882a0=_0x183816['useTaskPageStyles']?'modal-warning':'pr-modal-warning',_0x2445e0=_0x183816['useTaskPageStyles']?'modal-error':'pr-modal-error';return'\x0a\x20\x20\x20\x20<div\x20id=\x22'+_0x6bbc4c+'pr-modal\x22\x20class=\x22'+_0x894adb+'\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'+_0x6bbc4c+'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'+_0x6bbc4c+'pr-error\x22\x20class=\x22'+_0x2445e0+'\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'+_0x6bbc4c+'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'+_0x6bbc4c+'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'+_0x6bbc4c+'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'+_0x6bbc4c+'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'+_0x6bbc4c+'pr-body\x22>Description:</label>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<textarea\x20id=\x22'+_0x6bbc4c+'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'+_0x6bbc4c+'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'+_0x6bbc4c+'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'+_0x6bbc4c+'cancel-pr\x22>Cancel</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<button\x20class=\x22btn-primary\x22\x20id=\x22'+_0x6bbc4c+'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(_0x4ad735={}){this['prefix']=_0x4ad735['prefix']||'',this['onSubmit']=_0x4ad735['onSubmit'],this['onCancel']=_0x4ad735['onCancel'],this['showToast']=_0x4ad735['showToast']||(()=>{}),this['container']=_0x4ad735['container']||document['body'],this['useTaskPageStyles']=_0x4ad735['useTaskPageStyles']||![],this['baseUrl']=_0x4ad735['baseUrl']||'',this['prData']=null,this['initialized']=![],this['isSubmitting']=![];}['init'](){if(this['initialized'])return;const _0x263ac4=document['createElement']('div');_0x263ac4['innerHTML']=createPRDialogHTML(this['prefix'],{'useTaskPageStyles':this['useTaskPageStyles']}),this['container']['appendChild'](_0x263ac4['firstElementChild']),this['_bindEvents'](),this['initialized']=!![];}['_el'](_0x2b8282){return document['getElementById'](''+this['prefix']+_0x2b8282);}['_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',_0x12c43d=>{_0x12c43d['target']['id']===this['prefix']+'pr-modal'&&this['hide']();}),document['addEventListener']('keydown',_0x33d689=>{_0x33d689['key']==='Escape'&&!this['_el']('pr-modal')['hidden']&&this['hide']();});}async['show'](_0x1b1020){if(!this['initialized'])this['init']();this['prData']=_0x1b1020;const {taskId:_0x2f0087,repos:_0x50164b,suggestedTitle:_0x1a0bf5,suggestedBody:_0x7264d}=_0x1b1020;return this['_el']('pr-title')['value']=_0x1a0bf5||'',this['_el']('pr-body')['value']=_0x7264d||'',this['_el']('pr-error')['hidden']=!![],await this['_renderRepoSelectors'](_0x50164b),this['_el']('pr-modal')['hidden']=![],new Promise(_0x111974=>{this['_dismissResolve']=_0x111974;});}async['_renderRepoSelectors'](_0x4e8aef){const _0x1f4ebd=this['_el']('pr-repos-list');_0x1f4ebd['innerHTML']='';for(const _0x422d7d of _0x4e8aef){if(!_0x422d7d['supportsPR'])continue;const _0x11f03b=document['createElement']('div');_0x11f03b['className']='pr-repo-selector';const _0x5be27b=document['createElement']('span');_0x5be27b['className']='pr-repo-name',_0x5be27b['textContent']=_0x422d7d['name'];const _0x68c009=document['createElement']('span');_0x68c009['className']='pr-base-branch',_0x68c009['textContent']=_0x422d7d['base']||_0x422d7d['defaultBranch']||'main',_0x68c009['dataset']['repo']=_0x422d7d['name'],_0x68c009['dataset']['base']=_0x422d7d['base']||_0x422d7d['defaultBranch']||'main';const _0x5b831f=document['createElement']('span');_0x5b831f['className']='pr-arrow',_0x5b831f['textContent']='←';const _0x50b8f4=document['createElement']('span');_0x50b8f4['className']='pr-source-branch',_0x50b8f4['textContent']=_0x422d7d['head']||'(head\x20branch)',_0x11f03b['appendChild'](_0x5be27b),_0x11f03b['appendChild'](_0x68c009),_0x11f03b['appendChild'](_0x5b831f),_0x11f03b['appendChild'](_0x50b8f4),_0x1f4ebd['appendChild'](_0x11f03b);}}['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 _0x5a97b2=this['_el']('pr-title')['value']['trim'](),_0x296342=this['_el']('pr-body')['value']['trim']();if(!_0x5a97b2){this['_showError']('Pull\x20request\x20title\x20is\x20required');return;}const _0x545591=[],_0x432239=this['_el']('pr-repos-list')['querySelectorAll']('.pr-base-branch');for(const _0x49fb81 of _0x432239){const _0x62b442=_0x49fb81['dataset']['repo'],_0x25c56c=_0x49fb81['dataset']['base'],_0x5b29b5=this['prData']['repos']['find'](_0x2812a0=>_0x2812a0['name']===_0x62b442);if(!_0x5b29b5)continue;_0x545591['push']({'name':_0x62b442,'title':_0x5a97b2,'body':_0x296342,'head':_0x5b29b5['head'],'base':_0x25c56c});}if(_0x545591['length']===0x0){this['_showError']('No\x20repositories\x20selected');return;}this['isSubmitting']=!![],this['_el']('confirm-pr')['disabled']=!![],this['_el']('confirm-pr')['textContent']='Creating...';try{const _0x93b9f5=await this['onSubmit'](this['prData']['taskId'],_0x545591),_0x32c21f=_0x93b9f5['results']['every'](_0x2c1941=>_0x2c1941['success']),_0x111d76=_0x93b9f5['results']['some'](_0x137e69=>_0x137e69['success']);if(_0x32c21f)this['showToast']('Pull\x20requests\x20created\x20successfully','success');else{if(_0x111d76)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(_0x3d6deb){console['error']('PR\x20creation\x20failed:',_0x3d6deb),this['_showError'](_0x3d6deb['message']||'Failed\x20to\x20create\x20pull\x20requests'),this['isSubmitting']=![],this['_el']('confirm-pr')['disabled']=![],this['_el']('confirm-pr')['textContent']='Create\x20Pull\x20Request';}}['_showError'](_0x3ab200){this['_el']('pr-error-text')['textContent']=_0x3ab200,this['_el']('pr-error')['hidden']=![];}static['checkOAuthRedirect'](_0x2f8f05){if(_0x2f8f05['get']('source')==='pr'&&_0x2f8f05['get']('git_connection')){const _0x5a4c20=sessionStorage['getItem']('pendingPRData');if(_0x5a4c20)try{const _0x3300dc=JSON['parse'](_0x5a4c20);if(Date['now']()-_0x3300dc['timestamp']<0xa*0x3c*0x3e8)return sessionStorage['removeItem']('pendingPRData'),_0x3300dc;}catch(_0x214bd0){console['error']('Failed\x20to\x20parse\x20pending\x20PR\x20data:',_0x214bd0);}}return null;}}
@@ -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 _0x56a466=document['getElementById']('roles-loading'),_0x1d723c=document['getElementById']('roles-error'),_0x4b106a=document['getElementById']('roles-content');try{_0x56a466['hidden']=![],_0x1d723c['hidden']=!![],_0x4b106a['hidden']=!![];const {roles:_0x882125}=await API['getRoleDefinitions']();state['roles']=_0x882125||[],renderRoles(),_0x56a466['hidden']=!![],_0x4b106a['hidden']=![];}catch(_0x37cb33){_0x56a466['hidden']=!![],_0x1d723c['hidden']=![],document['getElementById']('roles-error-message')['textContent']=_0x37cb33['message'];}}async function loadAvailablePermissions(){try{const {permissions:_0x2a0e29}=await API['getAvailablePermissions']();state['availablePermissions']=_0x2a0e29||[];}catch{state['availablePermissions']=[];}}function getPermissionScopeMap(){const _0x1be1fd={};for(const _0xfed65a of state['availablePermissions']){_0xfed65a['scope']&&(_0x1be1fd[_0xfed65a['key']]=_0xfed65a['scope']);}return _0x1be1fd;}function getRoleScopeTags(_0x56c396){if(!_0x56c396||_0x56c396['length']===0x0)return'<span\x20style=\x22color:\x20var(--color-text-secondary);\x22>—</span>';if(_0x56c396['includes']('*'))return Object['values'](SCOPE_CONFIG)['map'](_0x517f61=>'<span\x20class=\x22tag\x22\x20style=\x22background:\x20'+_0x517f61['bg']+';\x20color:\x20'+_0x517f61['color']+';\x20font-size:\x200.75rem;\x20margin-right:\x200.25rem;\x22>'+_0x517f61['label']+'</span>')['join']('');const _0xd0bfbf=getPermissionScopeMap(),_0x343200=new Set();for(const _0x366215 of _0x56c396){const _0x33c435=_0xd0bfbf[_0x366215];if(_0x33c435)_0x343200['add'](_0x33c435);}if(_0x343200['size']===0x0)return'<span\x20style=\x22color:\x20var(--color-text-secondary);\x22>—</span>';const _0x435ea1=['environment','server','team','user'];return _0x435ea1['filter'](_0x58c05b=>_0x343200['has'](_0x58c05b))['map'](_0x2b2ba9=>{const _0x2756c2=SCOPE_CONFIG[_0x2b2ba9];return'<span\x20class=\x22tag\x22\x20style=\x22background:\x20'+_0x2756c2['bg']+';\x20color:\x20'+_0x2756c2['color']+';\x20font-size:\x200.75rem;\x20margin-right:\x200.25rem;\x22>'+_0x2756c2['label']+'</span>';})['join']('');}function renderRoles(){const _0xbb5425=document['getElementById']('roles-table-body'),_0x3724cd=document['getElementById']('role-count');if(!_0xbb5425)return;_0x3724cd&&(_0x3724cd['textContent']=state['roles']['length']+'\x20role'+(state['roles']['length']===0x1?'':'s'));const _0x25acce=Permissions['hasServerPermission'](state['currentUser'],'*');_0xbb5425['innerHTML']=state['roles']['map'](_0x46d5ef=>{const _0x410749=_0x46d5ef['permissions']?.['length']??0x0,_0x5128bb=_0x46d5ef['predefined']?'Predefined':'Custom',_0x57d07e=_0x46d5ef['predefined']?'background:\x20var(--color-surface);\x20color:\x20var(--color-text-secondary);':'background:\x20rgba(0,100,200,0.1);\x20color:\x20var(--color-primary);',_0x405461=getRoleScopeTags(_0x46d5ef['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'+_0x46d5ef['id']+'\x27)\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+Utils['escapeHtml'](_0x46d5ef['name'])+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x46d5ef['description']?'<div\x20style=\x22font-size:\x200.8em;\x20color:\x20var(--color-text-secondary);\x20margin-top:\x200.15rem;\x22>'+Utils['escapeHtml'](_0x46d5ef['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'+_0x57d07e+'\x22>'+_0x5128bb+'</span></td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+_0x405461+'</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+(_0x410749===0x1&&_0x46d5ef['permissions'][0x0]==='*'?'All\x20permissions':_0x410749+'\x20permission'+(_0x410749===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'+_0x46d5ef['id']+'\x27)\x22>View'+(_0x25acce?'/Edit':'')+'</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x25acce&&!_0x46d5ef['predefined']?'<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteRole(\x27'+_0x46d5ef['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(_0x376835){const _0x5f36d1=state['roles']['find'](_0x2fac1e=>_0x2fac1e['id']===_0x376835);if(!_0x5f36d1)return;const _0x2fc1d8=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x17f9d5=_0x2fc1d8&&!_0x5f36d1['predefined'];state['editingRoleId']=_0x376835,document['getElementById']('role-modal-title')['textContent']=_0x5f36d1['name'],document['getElementById']('role-name')['value']=_0x5f36d1['name'],document['getElementById']('role-name')['disabled']=!_0x17f9d5,document['getElementById']('role-description')['value']=_0x5f36d1['description']||'',document['getElementById']('role-description')['disabled']=!_0x17f9d5,document['getElementById']('role-form-error')['hidden']=!![],document['getElementById']('save-role')['hidden']=!_0x17f9d5;const _0x2826fd=document['getElementById']('role-readonly-notice');_0x2826fd['hidden']=_0x17f9d5,renderPermissionsChecklist('permissions-checklist',_0x5f36d1['permissions'],_0x17f9d5),_0x17f9d5?state['editModalSnapshot']={'name':_0x5f36d1['name'],'description':_0x5f36d1['description']||'','permissions':[..._0x5f36d1['permissions']||[]]['sort']()}:state['editModalSnapshot']=null,document['getElementById']('role-modal')['hidden']=![];};function isRoleModalDirty(){if(!state['editModalSnapshot'])return![];const _0x3f5b04=document['getElementById']('role-name')['value']['trim'](),_0x5bd644=document['getElementById']('role-description')['value']['trim'](),_0x1a1af2=getCheckedPermissions('permissions-checklist')['sort']();return _0x3f5b04!==state['editModalSnapshot']['name']||_0x5bd644!==state['editModalSnapshot']['description']||JSON['stringify'](_0x1a1af2)!==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 _0x2e57b2=document['getElementById']('save-role');_0x2e57b2['disabled']=![],_0x2e57b2['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 _0x5861ba=document['getElementById']('save-new-role');_0x5861ba['disabled']=![],_0x5861ba['textContent']='Create\x20Role';}function renderPermissionsChecklist(_0x5f5ce6,_0x2d385a,_0x13d982){const _0x41691a=document['getElementById'](_0x5f5ce6);if(!_0x41691a)return;const _0x324b7d=_0x2d385a['includes']('*');if(_0x324b7d){_0x41691a['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 _0x58af84=['environment','server','team','user'],_0x31fc50={'environment':'Environment-Scoped','server':'Server-Scoped','team':'Team-Scoped','user':'User-Scoped'},_0x4b24c4={'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.'},_0x52b066={};for(const _0x40084b of state['availablePermissions']){const _0x40f6a9=_0x40084b['scope']||'environment',_0x3546e1=_0x40084b['category']||_0x40084b['key']['split'](':')[0x0];if(!_0x52b066[_0x40f6a9])_0x52b066[_0x40f6a9]={};if(!_0x52b066[_0x40f6a9][_0x3546e1])_0x52b066[_0x40f6a9][_0x3546e1]=[];_0x52b066[_0x40f6a9][_0x3546e1]['push'](_0x40084b);}const _0xe072a9=new Set(_0x2d385a),_0x273acc='\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>',_0x48c3ed=_0x58af84['filter'](_0x1defa5=>_0x52b066[_0x1defa5])['map'](_0x3c8c47=>{const _0x2d40c0=_0x52b066[_0x3c8c47],_0x392d4f=SCOPE_CONFIG[_0x3c8c47],_0x274a78=Object['entries'](_0x2d40c0)['map'](([_0xf8b1bd,_0x4a70ef])=>{const _0x4cd047=PERMISSION_CATEGORIES[_0xf8b1bd]||_0xf8b1bd,_0x4502e2=_0x4a70ef['map'](_0x24652f=>{const _0x26ae6b=_0xe072a9['has'](_0x24652f['key'])?'checked':'',_0x29082a=_0x13d982?'':'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'+(_0x13d982?'pointer':'default')+';\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<input\x20type=\x22checkbox\x22\x20value=\x22'+_0x24652f['key']+'\x22\x20'+_0x26ae6b+'\x20'+_0x29082a+'\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'+_0x5f5ce6+'\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'](_0x24652f['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'](_0x24652f['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'](_0x4cd047)+'</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x4502e2+'\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'+_0x392d4f['color']+';\x22>'+_0x31fc50[_0x3c8c47]+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22tag\x22\x20style=\x22background:\x20'+_0x392d4f['bg']+';\x20color:\x20'+_0x392d4f['color']+';\x20font-size:\x200.65rem;\x22>'+_0x392d4f['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>'+_0x4b24c4[_0x3c8c47]+'</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20style=\x22border-left:\x202px\x20solid\x20'+_0x392d4f['color']+';\x20padding-left:\x200.75rem;\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x274a78+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>';})['join']('');_0x41691a['innerHTML']=_0x273acc+_0x48c3ed;}function getCheckedPermissions(_0x423144){const _0x221b06=document['getElementById'](_0x423144);if(!_0x221b06)return[];return Array['from'](_0x221b06['querySelectorAll']('.perm-checkbox:checked'))['map'](_0x1b6570=>_0x1b6570['value']);}async function saveRole(){const _0xb65672=document['getElementById']('role-name')['value']['trim'](),_0x1b4892=document['getElementById']('role-description')['value']['trim'](),_0x4c8e21=getCheckedPermissions('permissions-checklist'),_0x5b0af6=document['getElementById']('role-form-error'),_0x1481e4=document['getElementById']('save-role');if(!_0xb65672){_0x5b0af6['textContent']='Role\x20name\x20is\x20required',_0x5b0af6['hidden']=![];return;}if(_0x4c8e21['length']===0x0){_0x5b0af6['textContent']='Select\x20at\x20least\x20one\x20permission',_0x5b0af6['hidden']=![];return;}_0x5b0af6['hidden']=!![];const _0xcf83c6=_0x1481e4['textContent'];_0x1481e4['disabled']=!![],_0x1481e4['textContent']='Saving…';try{const {role:_0x4ba240}=await API['updateRoleDefinition'](state['editingRoleId'],{'name':_0xb65672,'description':_0x1b4892,'permissions':_0x4c8e21}),_0x3f0a1b=state['roles']['findIndex'](_0x28caaa=>_0x28caaa['id']===_0x4ba240['id']);if(_0x3f0a1b>=0x0)state['roles'][_0x3f0a1b]=_0x4ba240;renderRoles(),Utils['showToast']('Role\x20updated','success'),hideRoleModal();}catch(_0x4c87ee){_0x5b0af6['textContent']=_0x4c87ee['message'],_0x5b0af6['hidden']=![],_0x1481e4['disabled']=![],_0x1481e4['textContent']=_0xcf83c6;}}async function createRole(){const _0x385baf=document['getElementById']('new-role-name')['value']['trim'](),_0x40a0b2=document['getElementById']('new-role-description')['value']['trim'](),_0xbabf85=getCheckedPermissions('new-permissions-checklist'),_0x4dac13=document['getElementById']('create-role-error'),_0x11a20f=document['getElementById']('save-new-role');if(!_0x385baf){_0x4dac13['textContent']='Role\x20name\x20is\x20required',_0x4dac13['hidden']=![];return;}if(_0xbabf85['length']===0x0){_0x4dac13['textContent']='Select\x20at\x20least\x20one\x20permission',_0x4dac13['hidden']=![];return;}_0x4dac13['hidden']=!![];const _0x2e614c=_0x11a20f['textContent'];_0x11a20f['disabled']=!![],_0x11a20f['textContent']='Creating…';try{const {role:_0x3fcee8}=await API['createRoleDefinition']({'name':_0x385baf,'description':_0x40a0b2,'permissions':_0xbabf85});state['roles']['push'](_0x3fcee8),renderRoles(),Utils['showToast']('Role\x20created','success'),hideCreateRoleModal();}catch(_0x4ac9ad){_0x4dac13['textContent']=_0x4ac9ad['message'],_0x4dac13['hidden']=![],_0x11a20f['disabled']=![],_0x11a20f['textContent']=_0x2e614c;}}window['deleteRole']=function(_0x25e411){const _0x2a50fb=state['roles']['find'](_0x4dfdec=>_0x4dfdec['id']===_0x25e411);if(!_0x2a50fb)return;state['deletingRoleId']=_0x25e411,document['getElementById']('delete-role-name')['textContent']=_0x2a50fb['name'],document['getElementById']('delete-role-modal')['hidden']=![];};function hideDeleteRoleModal(){document['getElementById']('delete-role-modal')['hidden']=!![],state['deletingRoleId']=null;const _0x41b1f0=document['getElementById']('confirm-delete-role');_0x41b1f0['disabled']=![],_0x41b1f0['textContent']='Delete\x20Role';}async function confirmDeleteRole(){if(!state['deletingRoleId'])return;const _0x4f62d2=document['getElementById']('confirm-delete-role');_0x4f62d2['disabled']=!![],_0x4f62d2['textContent']='Deleting…';try{await API['deleteRoleDefinition'](state['deletingRoleId']),state['roles']=state['roles']['filter'](_0x2f2136=>_0x2f2136['id']!==state['deletingRoleId']),renderRoles(),Utils['showToast']('Role\x20deleted','success'),hideDeleteRoleModal();}catch(_0x34cd4e){Utils['showToast']('Failed\x20to\x20delete\x20role:\x20'+_0x34cd4e['message'],'error'),_0x4f62d2['disabled']=![],_0x4f62d2['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 _0x229892=document['getElementById']('roles-loading'),_0x14d882=document['getElementById']('roles-error'),_0x194788=document['getElementById']('roles-content');try{_0x229892['hidden']=![],_0x14d882['hidden']=!![],_0x194788['hidden']=!![];const {roles:_0xad33e3}=await API['getRoleDefinitions']();state['roles']=_0xad33e3||[],renderRoles(),_0x229892['hidden']=!![],_0x194788['hidden']=![];}catch(_0x58af32){_0x229892['hidden']=!![],_0x14d882['hidden']=![],document['getElementById']('roles-error-message')['textContent']=_0x58af32['message'];}}async function loadAvailablePermissions(){try{const {permissions:_0x4dfa1a}=await API['getAvailablePermissions']();state['availablePermissions']=_0x4dfa1a||[];}catch{state['availablePermissions']=[];}}function getPermissionScopeMap(){const _0x683bfe={};for(const _0x403bf8 of state['availablePermissions']){_0x403bf8['scope']&&(_0x683bfe[_0x403bf8['key']]=_0x403bf8['scope']);}return _0x683bfe;}function getRoleScopeTags(_0x3618a6){if(!_0x3618a6||_0x3618a6['length']===0x0)return'<span\x20style=\x22color:\x20var(--color-text-secondary);\x22>—</span>';if(_0x3618a6['includes']('*'))return Object['values'](SCOPE_CONFIG)['map'](_0x2c38ef=>'<span\x20class=\x22tag\x22\x20style=\x22background:\x20'+_0x2c38ef['bg']+';\x20color:\x20'+_0x2c38ef['color']+';\x20font-size:\x200.75rem;\x20margin-right:\x200.25rem;\x22>'+_0x2c38ef['label']+'</span>')['join']('');const _0x1a850c=getPermissionScopeMap(),_0x4f627e=new Set();for(const _0x1c70eb of _0x3618a6){const _0x197b91=_0x1a850c[_0x1c70eb];if(_0x197b91)_0x4f627e['add'](_0x197b91);}if(_0x4f627e['size']===0x0)return'<span\x20style=\x22color:\x20var(--color-text-secondary);\x22>—</span>';const _0xf903fc=['environment','server','team','user'];return _0xf903fc['filter'](_0x22982d=>_0x4f627e['has'](_0x22982d))['map'](_0xd34053=>{const _0x29b1b8=SCOPE_CONFIG[_0xd34053];return'<span\x20class=\x22tag\x22\x20style=\x22background:\x20'+_0x29b1b8['bg']+';\x20color:\x20'+_0x29b1b8['color']+';\x20font-size:\x200.75rem;\x20margin-right:\x200.25rem;\x22>'+_0x29b1b8['label']+'</span>';})['join']('');}function renderRoles(){const _0x4bf397=document['getElementById']('roles-table-body'),_0x3e43b7=document['getElementById']('role-count');if(!_0x4bf397)return;_0x3e43b7&&(_0x3e43b7['textContent']=state['roles']['length']+'\x20role'+(state['roles']['length']===0x1?'':'s'));const _0x9308d0=Permissions['hasServerPermission'](state['currentUser'],'*');_0x4bf397['innerHTML']=state['roles']['map'](_0x11085d=>{const _0x21024c=_0x11085d['permissions']?.['length']??0x0,_0x49b1fe=_0x11085d['predefined']?'Predefined':'Custom',_0x6d0991=_0x11085d['predefined']?'background:\x20var(--color-surface);\x20color:\x20var(--color-text-secondary);':'background:\x20rgba(0,100,200,0.1);\x20color:\x20var(--color-primary);',_0x32775a=getRoleScopeTags(_0x11085d['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'+_0x11085d['id']+'\x27)\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+Utils['escapeHtml'](_0x11085d['name'])+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x11085d['description']?'<div\x20style=\x22font-size:\x200.8em;\x20color:\x20var(--color-text-secondary);\x20margin-top:\x200.15rem;\x22>'+Utils['escapeHtml'](_0x11085d['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'+_0x6d0991+'\x22>'+_0x49b1fe+'</span></td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+_0x32775a+'</td>\x0a\x20\x20\x20\x20\x20\x20\x20\x20<td>'+(_0x21024c===0x1&&_0x11085d['permissions'][0x0]==='*'?'All\x20permissions':_0x21024c+'\x20permission'+(_0x21024c===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'+_0x11085d['id']+'\x27)\x22>View'+(_0x9308d0?'/Edit':'')+'</button>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+(_0x9308d0&&!_0x11085d['predefined']?'<button\x20class=\x22btn-ghost\x20btn-small\x22\x20onclick=\x22window.deleteRole(\x27'+_0x11085d['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(_0x516d9c){const _0x287d47=state['roles']['find'](_0x278964=>_0x278964['id']===_0x516d9c);if(!_0x287d47)return;const _0x37774b=Permissions['hasServerPermission'](state['currentUser'],'*'),_0x458f84=_0x37774b&&!_0x287d47['predefined'];state['editingRoleId']=_0x516d9c,document['getElementById']('role-modal-title')['textContent']=_0x287d47['name'],document['getElementById']('role-name')['value']=_0x287d47['name'],document['getElementById']('role-name')['disabled']=!_0x458f84,document['getElementById']('role-description')['value']=_0x287d47['description']||'',document['getElementById']('role-description')['disabled']=!_0x458f84,document['getElementById']('role-form-error')['hidden']=!![],document['getElementById']('save-role')['hidden']=!_0x458f84;const _0x1abbec=document['getElementById']('role-readonly-notice');_0x1abbec['hidden']=_0x458f84,renderPermissionsChecklist('permissions-checklist',_0x287d47['permissions'],_0x458f84),_0x458f84?state['editModalSnapshot']={'name':_0x287d47['name'],'description':_0x287d47['description']||'','permissions':[..._0x287d47['permissions']||[]]['sort']()}:state['editModalSnapshot']=null,document['getElementById']('role-modal')['hidden']=![];};function isRoleModalDirty(){if(!state['editModalSnapshot'])return![];const _0x3f4572=document['getElementById']('role-name')['value']['trim'](),_0x394508=document['getElementById']('role-description')['value']['trim'](),_0x4dc7ed=getCheckedPermissions('permissions-checklist')['sort']();return _0x3f4572!==state['editModalSnapshot']['name']||_0x394508!==state['editModalSnapshot']['description']||JSON['stringify'](_0x4dc7ed)!==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 _0x24f9a9=document['getElementById']('save-role');_0x24f9a9['disabled']=![],_0x24f9a9['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 _0x2c37fb=document['getElementById']('save-new-role');_0x2c37fb['disabled']=![],_0x2c37fb['textContent']='Create\x20Role';}function renderPermissionsChecklist(_0x13c082,_0x550618,_0x1ba82c){const _0x45f408=document['getElementById'](_0x13c082);if(!_0x45f408)return;const _0x79ace0=_0x550618['includes']('*');if(_0x79ace0){_0x45f408['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 _0x5779a1=['environment','server','team','user'],_0x32015f={'environment':'Environment-Scoped','server':'Server-Scoped','team':'Team-Scoped','user':'User-Scoped'},_0x553cde={'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.'},_0x516aec={};for(const _0xb63f5 of state['availablePermissions']){const _0xb0b776=_0xb63f5['scope']||'environment',_0x439f66=_0xb63f5['category']||_0xb63f5['key']['split'](':')[0x0];if(!_0x516aec[_0xb0b776])_0x516aec[_0xb0b776]={};if(!_0x516aec[_0xb0b776][_0x439f66])_0x516aec[_0xb0b776][_0x439f66]=[];_0x516aec[_0xb0b776][_0x439f66]['push'](_0xb63f5);}const _0x2554bf=new Set(_0x550618),_0x3fe07a='\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>',_0x57a708=_0x5779a1['filter'](_0x36783d=>_0x516aec[_0x36783d])['map'](_0x40ec0e=>{const _0x3d4188=_0x516aec[_0x40ec0e],_0x43a5db=SCOPE_CONFIG[_0x40ec0e],_0x17d4a3=Object['entries'](_0x3d4188)['map'](([_0x26d423,_0x30af4f])=>{const _0x3219ad=PERMISSION_CATEGORIES[_0x26d423]||_0x26d423,_0x4092e3=_0x30af4f['map'](_0x13be22=>{const _0x444943=_0x2554bf['has'](_0x13be22['key'])?'checked':'',_0x2b4996=_0x1ba82c?'':'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'+(_0x1ba82c?'pointer':'default')+';\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<input\x20type=\x22checkbox\x22\x20value=\x22'+_0x13be22['key']+'\x22\x20'+_0x444943+'\x20'+_0x2b4996+'\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'+_0x13c082+'\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'](_0x13be22['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'](_0x13be22['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'](_0x3219ad)+'</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x4092e3+'\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'+_0x43a5db['color']+';\x22>'+_0x32015f[_0x40ec0e]+'</span>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<span\x20class=\x22tag\x22\x20style=\x22background:\x20'+_0x43a5db['bg']+';\x20color:\x20'+_0x43a5db['color']+';\x20font-size:\x200.65rem;\x22>'+_0x43a5db['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>'+_0x553cde[_0x40ec0e]+'</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20style=\x22border-left:\x202px\x20solid\x20'+_0x43a5db['color']+';\x20padding-left:\x200.75rem;\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20'+_0x17d4a3+'\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20</div>';})['join']('');_0x45f408['innerHTML']=_0x3fe07a+_0x57a708;}function getCheckedPermissions(_0xc1a7d1){const _0x212a18=document['getElementById'](_0xc1a7d1);if(!_0x212a18)return[];return Array['from'](_0x212a18['querySelectorAll']('.perm-checkbox:checked'))['map'](_0x4311ac=>_0x4311ac['value']);}async function saveRole(){const _0x4fa448=document['getElementById']('role-name')['value']['trim'](),_0x515266=document['getElementById']('role-description')['value']['trim'](),_0x551cae=getCheckedPermissions('permissions-checklist'),_0x492a7e=document['getElementById']('role-form-error'),_0x54ee26=document['getElementById']('save-role');if(!_0x4fa448){_0x492a7e['textContent']='Role\x20name\x20is\x20required',_0x492a7e['hidden']=![];return;}if(_0x551cae['length']===0x0){_0x492a7e['textContent']='Select\x20at\x20least\x20one\x20permission',_0x492a7e['hidden']=![];return;}_0x492a7e['hidden']=!![];const _0xb91267=_0x54ee26['textContent'];_0x54ee26['disabled']=!![],_0x54ee26['textContent']='Saving…';try{const {role:_0x3befe2}=await API['updateRoleDefinition'](state['editingRoleId'],{'name':_0x4fa448,'description':_0x515266,'permissions':_0x551cae}),_0x8d027d=state['roles']['findIndex'](_0x2bcb62=>_0x2bcb62['id']===_0x3befe2['id']);if(_0x8d027d>=0x0)state['roles'][_0x8d027d]=_0x3befe2;renderRoles(),Utils['showToast']('Role\x20updated','success'),hideRoleModal();}catch(_0xfdaa4){_0x492a7e['textContent']=_0xfdaa4['message'],_0x492a7e['hidden']=![],_0x54ee26['disabled']=![],_0x54ee26['textContent']=_0xb91267;}}async function createRole(){const _0xc2b937=document['getElementById']('new-role-name')['value']['trim'](),_0x6cfa9e=document['getElementById']('new-role-description')['value']['trim'](),_0x575829=getCheckedPermissions('new-permissions-checklist'),_0x5afda7=document['getElementById']('create-role-error'),_0x3668c9=document['getElementById']('save-new-role');if(!_0xc2b937){_0x5afda7['textContent']='Role\x20name\x20is\x20required',_0x5afda7['hidden']=![];return;}if(_0x575829['length']===0x0){_0x5afda7['textContent']='Select\x20at\x20least\x20one\x20permission',_0x5afda7['hidden']=![];return;}_0x5afda7['hidden']=!![];const _0x1237f1=_0x3668c9['textContent'];_0x3668c9['disabled']=!![],_0x3668c9['textContent']='Creating…';try{const {role:_0x1e69d5}=await API['createRoleDefinition']({'name':_0xc2b937,'description':_0x6cfa9e,'permissions':_0x575829});state['roles']['push'](_0x1e69d5),renderRoles(),Utils['showToast']('Role\x20created','success'),hideCreateRoleModal();}catch(_0x31de9b){_0x5afda7['textContent']=_0x31de9b['message'],_0x5afda7['hidden']=![],_0x3668c9['disabled']=![],_0x3668c9['textContent']=_0x1237f1;}}window['deleteRole']=function(_0x4520ca){const _0xb836c1=state['roles']['find'](_0x5f488c=>_0x5f488c['id']===_0x4520ca);if(!_0xb836c1)return;state['deletingRoleId']=_0x4520ca,document['getElementById']('delete-role-name')['textContent']=_0xb836c1['name'],document['getElementById']('delete-role-modal')['hidden']=![];};function hideDeleteRoleModal(){document['getElementById']('delete-role-modal')['hidden']=!![],state['deletingRoleId']=null;const _0x5e7f5d=document['getElementById']('confirm-delete-role');_0x5e7f5d['disabled']=![],_0x5e7f5d['textContent']='Delete\x20Role';}async function confirmDeleteRole(){if(!state['deletingRoleId'])return;const _0x22cbd7=document['getElementById']('confirm-delete-role');_0x22cbd7['disabled']=!![],_0x22cbd7['textContent']='Deleting…';try{await API['deleteRoleDefinition'](state['deletingRoleId']),state['roles']=state['roles']['filter'](_0x42c8da=>_0x42c8da['id']!==state['deletingRoleId']),renderRoles(),Utils['showToast']('Role\x20deleted','success'),hideDeleteRoleModal();}catch(_0x4dd603){Utils['showToast']('Failed\x20to\x20delete\x20role:\x20'+_0x4dd603['message'],'error'),_0x22cbd7['disabled']=![],_0x22cbd7['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);}
@@ -179,6 +179,19 @@
179
179
  </svg>
180
180
  Email (SMTP)
181
181
  </button>
182
+ <button class="settings-nav-item" data-section="slack" role="tab">
183
+ <svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">
184
+ <path d="M14.5 10c-.83 0-1.5-.67-1.5-1.5v-5c0-.83.67-1.5 1.5-1.5s1.5.67 1.5 1.5v5c0 .83-.67 1.5-1.5 1.5z"></path>
185
+ <path d="M20.5 10H19V8.5c0-.83.67-1.5 1.5-1.5s1.5.67 1.5 1.5-.67 1.5-1.5 1.5z"></path>
186
+ <path d="M9.5 14c.83 0 1.5.67 1.5 1.5v5c0 .83-.67 1.5-1.5 1.5S8 21.33 8 20.5v-5c0-.83.67-1.5 1.5-1.5z"></path>
187
+ <path d="M3.5 14H5v1.5c0 .83-.67 1.5-1.5 1.5S2 16.33 2 15.5 2.67 14 3.5 14z"></path>
188
+ <path d="M14 14.5c0-.83.67-1.5 1.5-1.5h5c.83 0 1.5.67 1.5 1.5s-.67 1.5-1.5 1.5h-5c-.83 0-1.5-.67-1.5-1.5z"></path>
189
+ <path d="M15.5 19H14v1.5c0 .83.67 1.5 1.5 1.5s1.5-.67 1.5-1.5-.67-1.5-1.5-1.5z"></path>
190
+ <path d="M10 9.5C10 10.33 9.33 11 8.5 11h-5C2.67 11 2 10.33 2 9.5S2.67 8 3.5 8h5c.83 0 1.5.67 1.5 1.5z"></path>
191
+ <path d="M8.5 5H10V3.5C10 2.67 9.33 2 8.5 2S7 2.67 7 3.5 7.67 5 8.5 5z"></path>
192
+ </svg>
193
+ Slack
194
+ </button>
182
195
  <button class="settings-nav-item" data-section="git-providers" role="tab">
183
196
  <svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">
184
197
  <path d="M9 19c-5 1.5-5-2.5-7-3m14 6v-3.87a3.37 3.37 0 0 0-.94-2.61c3.14-.35 6.44-1.54 6.44-7A5.44 5.44 0 0 0 20 4.77 5.07 5.07 0 0 0 19.91 1S18.73.65 16 2.48a13.38 13.38 0 0 0-7 0C6.27.65 5.09 1 5.09 1A5.07 5.07 0 0 0 5 4.77a5.44 5.44 0 0 0-1.5 3.78c0 5.42 3.3 6.61 6.44 7A3.37 3.37 0 0 0 9 18.13V22"></path>
@@ -564,6 +577,139 @@
564
577
  </div>
565
578
  </div>
566
579
 
580
+ <!-- Slack Settings -->
581
+ <div id="section-slack" class="settings-panel" role="tabpanel" hidden>
582
+ <div class="content-card">
583
+ <div class="card-header">
584
+ <h3>Slack Integration</h3>
585
+ </div>
586
+ <div class="card-body">
587
+ <div id="slack-inline-message" class="inline-message" hidden></div>
588
+ <p class="text-muted" style="margin-bottom: 8px;">Connect a Slack bot so users can @mention CoderFlow to create tasks directly from Slack.</p>
589
+
590
+ <!-- App Manifest Helper -->
591
+ <details id="slack-manifest-details" style="margin-bottom: 16px; border: 1px solid var(--color-border); border-radius: 6px; padding: 0;">
592
+ <summary style="padding: 10px 14px; cursor: pointer; font-weight: 500; font-size: 13px; user-select: none; list-style: none; display: flex; align-items: center; gap: 8px;">
593
+ <svg width="14" height="14" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" style="flex-shrink: 0; transition: transform 0.2s;">
594
+ <polyline points="9 18 15 12 9 6"></polyline>
595
+ </svg>
596
+ Quick Setup: Create Slack App from Manifest
597
+ </summary>
598
+ <div style="padding: 0 14px 14px 14px; font-size: 13px;">
599
+ <ol style="margin: 8px 0 12px 0; padding-left: 20px; line-height: 1.8;">
600
+ <li>Go to <a href="https://api.slack.com/apps" target="_blank" rel="noopener">api.slack.com/apps</a> and click <strong>Create New App</strong> &rarr; <strong>From an app manifest</strong></li>
601
+ <li>Select your workspace, click <strong>Next</strong>, choose the <strong>JSON</strong> tab</li>
602
+ <li>Copy the manifest below and paste it in</li>
603
+ <li>Click <strong>Next</strong>, review, and <strong>Create</strong></li>
604
+ <li>Copy <strong>Signing Secret</strong> from Basic Information, and <strong>Bot Token</strong> from OAuth &amp; Permissions (install the app first)</li>
605
+ </ol>
606
+ <div style="position: relative;">
607
+ <pre id="slack-manifest-pre" style="background: var(--color-surface-muted); color: var(--color-text); border: 1px solid var(--color-border); padding: 12px; border-radius: 4px; font-size: 12px; line-height: 1.5; overflow-x: auto; margin: 0; white-space: pre;"></pre>
608
+ <button type="button" id="slack-copy-manifest-btn" style="position: absolute; top: 8px; right: 8px; padding: 4px 10px; font-size: 12px; border-radius: 4px; border: 1px solid var(--color-border); background: var(--color-surface); color: var(--color-text); cursor: pointer; opacity: 0.8; transition: opacity 0.15s;" title="Copy manifest to clipboard">Copy</button>
609
+ </div>
610
+ <p class="text-muted" style="margin-top: 8px; font-size: 12px;">The manifest uses the Task Link Base URL below as the server URL. Update that field first if needed.</p>
611
+ </div>
612
+ </details>
613
+ <div class="form-single-column">
614
+ <div class="form-row">
615
+ <label for="slack-enabled">Enabled</label>
616
+ <label class="toggle-switch">
617
+ <input type="checkbox" id="slack-enabled">
618
+ <span class="toggle-slider"></span>
619
+ </label>
620
+ </div>
621
+ <div class="form-row">
622
+ <label for="slack-bot-token">Bot Token</label>
623
+ <div class="apikey-input-group">
624
+ <input type="password" id="slack-bot-token" class="form-input" placeholder="xoxb-...">
625
+ <button type="button" class="btn-icon apikey-toggle-visibility" data-target="slack-bot-token" title="Toggle visibility">
626
+ <svg class="eye-open" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">
627
+ <path d="M1 12s4-8 11-8 11 8 11 8-4 8-11 8-11-8-11-8z"></path>
628
+ <circle cx="12" cy="12" r="3"></circle>
629
+ </svg>
630
+ <svg class="eye-closed" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" style="display: none;">
631
+ <path d="M17.94 17.94A10.07 10.07 0 0 1 12 20c-7 0-11-8-11-8a18.45 18.45 0 0 1 5.06-5.94M9.9 4.24A9.12 9.12 0 0 1 12 4c7 0 11 8 11 8a18.5 18.5 0 0 1-2.16 3.19m-6.72-1.07a3 3 0 1 1-4.24-4.24"></path>
632
+ <line x1="1" y1="1" x2="23" y2="23"></line>
633
+ </svg>
634
+ </button>
635
+ </div>
636
+ <span id="slack-bot-token-status" class="form-hint"></span>
637
+ </div>
638
+ <div class="form-row">
639
+ <label for="slack-signing-secret">Signing Secret</label>
640
+ <div class="apikey-input-group">
641
+ <input type="password" id="slack-signing-secret" class="form-input" placeholder="Enter signing secret">
642
+ <button type="button" class="btn-icon apikey-toggle-visibility" data-target="slack-signing-secret" title="Toggle visibility">
643
+ <svg class="eye-open" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">
644
+ <path d="M1 12s4-8 11-8 11 8 11 8-4 8-11 8-11-8-11-8z"></path>
645
+ <circle cx="12" cy="12" r="3"></circle>
646
+ </svg>
647
+ <svg class="eye-closed" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" style="display: none;">
648
+ <path d="M17.94 17.94A10.07 10.07 0 0 1 12 20c-7 0-11-8-11-8a18.45 18.45 0 0 1 5.06-5.94M9.9 4.24A9.12 9.12 0 0 1 12 4c7 0 11 8 11 8a18.5 18.5 0 0 1-2.16 3.19m-6.72-1.07a3 3 0 1 1-4.24-4.24"></path>
649
+ <line x1="1" y1="1" x2="23" y2="23"></line>
650
+ </svg>
651
+ </button>
652
+ </div>
653
+ <span id="slack-signing-secret-status" class="form-hint"></span>
654
+ </div>
655
+ <div class="form-row">
656
+ <label for="slack-app-id">App ID</label>
657
+ <input type="text" id="slack-app-id" class="form-input" placeholder="A0123456789" style="max-width: 200px;">
658
+ <span class="form-hint">Found in your Slack app's Basic Information page</span>
659
+ </div>
660
+ <div class="form-row">
661
+ <label for="slack-default-environment">Default Environment</label>
662
+ <select id="slack-default-environment" class="form-input" style="max-width: 300px;">
663
+ <option value="">None (require env: prefix or channel mapping)</option>
664
+ </select>
665
+ <span class="form-hint">Used when no channel mapping or env: prefix is specified</span>
666
+ </div>
667
+ <div class="form-row">
668
+ <label for="slack-task-link-base-url">Task Link Base URL</label>
669
+ <input type="text" id="slack-task-link-base-url" class="form-input" placeholder="https://coderflow.example.com">
670
+ <span class="form-hint">Base URL for task links posted in Slack (e.g., https://your-server.com)</span>
671
+ </div>
672
+ </div>
673
+
674
+ <!-- Channel Mappings -->
675
+ <div style="margin-top: 24px; padding-top: 16px; border-top: 1px solid var(--color-border);">
676
+ <div class="subsection-header" style="margin-bottom: 12px;">
677
+ <h4 style="margin: 0;">Channel Mappings</h4>
678
+ </div>
679
+ <p class="text-muted" style="margin-bottom: 12px;">Map Slack channels to specific environments. Messages in mapped channels auto-select the configured environment.</p>
680
+ <div id="slack-channel-mappings-container">
681
+ <!-- Dynamic rows inserted here -->
682
+ </div>
683
+ <button type="button" class="btn-secondary btn-small" id="slack-add-mapping-btn" style="margin-top: 8px;">
684
+ + Add Channel Mapping
685
+ </button>
686
+ </div>
687
+
688
+ <!-- Test Connection -->
689
+ <div style="margin-top: 24px; padding-top: 16px; border-top: 1px solid var(--color-border);">
690
+ <div class="subsection-header" style="margin-bottom: 12px;">
691
+ <h4 style="margin: 0;">Test Configuration</h4>
692
+ </div>
693
+ <div class="form-single-column">
694
+ <div class="form-row">
695
+ <label></label>
696
+ <button type="button" class="btn-secondary btn-small" id="slack-test-connection-btn">
697
+ Test Connection
698
+ </button>
699
+ </div>
700
+ <div class="form-row" id="slack-test-result-row" hidden>
701
+ <label></label>
702
+ <div id="slack-test-result" class="email-test-result"></div>
703
+ </div>
704
+ </div>
705
+ </div>
706
+ </div>
707
+ <div class="card-actions">
708
+ <button type="button" class="btn-primary" id="save-slack-btn">Save</button>
709
+ </div>
710
+ </div>
711
+ </div>
712
+
567
713
  <!-- Git Providers Settings -->
568
714
  <div id="section-git-providers" class="settings-panel" role="tabpanel" hidden>
569
715
  <div class="content-card">