@aiderdesk/aiderdesk 0.61.0-dev → 0.61.0

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 (175) hide show
  1. package/out/renderer/assets/__vite-browser-external-2447137e-DYxpcVy9.js +4 -0
  2. package/out/renderer/assets/{_baseUniq-Z8t1Ab1g.js → _baseUniq-BPF2Herp.js} +21 -197
  3. package/out/renderer/assets/{arc-CwESpVYE.js → arc-DfPLteHF.js} +1 -1
  4. package/out/renderer/assets/{architectureDiagram-2XIMDMQ5-C490EQr5.js → architectureDiagram-Q4EWVU46-Bw0u-sSH.js} +34 -20
  5. package/out/renderer/assets/{blockDiagram-WCTKOSBZ-DbHssxrQ.js → blockDiagram-DXYQGD6D-CkfB9if8.js} +21 -8
  6. package/out/renderer/assets/{c4Diagram-IC4MRINW-BxE3GUKu.js → c4Diagram-AHTNJAMY-DweK9Liz.js} +31 -35
  7. package/out/renderer/assets/{channel-C9hJq_Xr.js → channel-C5wwrRof.js} +1 -1
  8. package/out/renderer/assets/{chunk-4BX2VUAB-ChcKNpL6.js → chunk-4BX2VUAB-0KM14cFd.js} +1 -1
  9. package/out/renderer/assets/{chunk-WL4C6EOR-vhby2fZi.js → chunk-4TB4RGXK-CmVtCVL4.js} +121 -82
  10. package/out/renderer/assets/{chunk-55IACEB6-oLT9lXTt.js → chunk-55IACEB6-BzVYZvBM.js} +1 -1
  11. package/out/renderer/assets/{chunk-KX2RTZJC-D32tV7H-.js → chunk-EDXVE4YY-BryQl5Kv.js} +1 -1
  12. package/out/renderer/assets/{chunk-FMBD7UC4-B5k8rETe.js → chunk-FMBD7UC4-CRiLea_e.js} +1 -1
  13. package/out/renderer/assets/{chunk-NQ4KR5QH-Bmqo2FpL.js → chunk-OYMX7WX6-Cpi4N3NO.js} +32 -15
  14. package/out/renderer/assets/{chunk-QZHKN3VN-8BpGifjS.js → chunk-QZHKN3VN-BT8kABWC.js} +1 -1
  15. package/out/renderer/assets/{chunk-JSJVCQXG-DtjSx6Cj.js → chunk-YZCP3GAM-OLZV_Sef.js} +1 -1
  16. package/out/renderer/assets/{classDiagram-VBA2DB6C-BxRSSb9e.js → classDiagram-6PBFFD2Q-VdE6G90i.js} +6 -6
  17. package/out/renderer/assets/{classDiagram-v2-RAHNMMFH-BxRSSb9e.js → classDiagram-v2-HSJHXN6E-VdE6G90i.js} +6 -6
  18. package/out/renderer/assets/{clone-D9a-uIZa.js → clone-DwQZ86nS.js} +1 -1
  19. package/out/renderer/assets/{cose-bilkent-S5V4N54A-CUqqQ-6R.js → cose-bilkent-S5V4N54A-BEcAKM9H.js} +1 -1
  20. package/out/renderer/assets/{dagre-KLK3FWXG-ORIwMMhq.js → dagre-KV5264BT-BcFQYL1M.js} +6 -6
  21. package/out/renderer/assets/diagram-5BDNPKRD-GrUNdC1u.js +171 -0
  22. package/out/renderer/assets/{diagram-E7M64L7V-bS9HcoDQ.js → diagram-G4DWMVQ6-CG4S-ov5.js} +15 -13
  23. package/out/renderer/assets/{diagram-IFDJBPK2-BRlTIR0J.js → diagram-MMDJMWI5-9ogY3MRC.js} +5 -6
  24. package/out/renderer/assets/{diagram-P4PSJMXO-jsjGwH-p.js → diagram-TYMM5635-Ck7mI1bS.js} +5 -6
  25. package/out/renderer/assets/{erDiagram-INFDFZHY-DGlgjHOQ.js → erDiagram-SMLLAGMA-Dvf_c-7M.js} +81 -35
  26. package/out/renderer/assets/{flowDiagram-PKNHOUZH-CzLC87bM.js → flowDiagram-DWJPFMVM-CPDjOXYp.js} +27 -45
  27. package/out/renderer/assets/{ganttDiagram-A5KZAMGK-BbDv36wT.js → ganttDiagram-T4ZO3ILL-B4dJrK-3.js} +17 -8
  28. package/out/renderer/assets/{gitGraphDiagram-K3NZZRJ6-CBQnBjEi.js → gitGraphDiagram-UUTBAWPF-De2eCfMN.js} +244 -67
  29. package/out/renderer/assets/{graph-Dl5N6maZ.js → graph-BFn23kR_.js} +175 -3
  30. package/out/renderer/assets/{index-MDHavDF9.js → index-BL-57WPa.js} +15877 -20787
  31. package/out/renderer/assets/{index-CDCy_DhA.css → index-BkntVzTm.css} +114 -301
  32. package/out/renderer/assets/{infoDiagram-LFFYTUFH-GtEDBEmz.js → infoDiagram-42DDH7IO-BIt9B6mQ.js} +5 -6
  33. package/out/renderer/assets/{ishikawaDiagram-PHBUUO56-Uj90gr3I.js → ishikawaDiagram-UXIWVN3A-CXZs0KGV.js} +3 -3
  34. package/out/renderer/assets/{journeyDiagram-4ABVD52K-DekFuOwS.js → journeyDiagram-VCZTEJTY-B-EXuj5b.js} +14 -13
  35. package/out/renderer/assets/{kanban-definition-K7BYSVSG-Hfz2L6NS.js → kanban-definition-6JOO6SKY-ByvN0qaD.js} +5 -2
  36. package/out/renderer/assets/{layout-B9K2VT39.js → layout-BpybWUv6.js} +117 -4
  37. package/out/renderer/assets/min-DB8ixvoT.js +41 -0
  38. package/out/renderer/assets/{mindmap-definition-YRQLILUH-DDcS7_GH.js → mindmap-definition-QFDTVHPH-Do-I-At8.js} +69 -13
  39. package/out/renderer/assets/{pieDiagram-SKSYHLDU-DwjEcJ0Q.js → pieDiagram-DEJITSTG-Cnpf6Gt6.js} +20 -13
  40. package/out/renderer/assets/{quadrantDiagram-337W2JSQ-CpGqN7vo.js → quadrantDiagram-34T5L4WZ-VcOb1qLd.js} +1 -1
  41. package/out/renderer/assets/{requirementDiagram-Z7DCOOCP-qDRUf1ip.js → requirementDiagram-MS252O5E-VJs9Hpaw.js} +42 -11
  42. package/out/renderer/assets/{sankeyDiagram-WA2Y5GQK-DRKS8C1H.js → sankeyDiagram-XADWPNL6-BoXxgLvi.js} +1 -1
  43. package/out/renderer/assets/{sequenceDiagram-2WXFIKYE-DhVN2ug2.js → sequenceDiagram-FGHM5R23-b69hQjSp.js} +446 -220
  44. package/out/renderer/assets/{stateDiagram-RAJIS63D-BpP4eSqu.js → stateDiagram-FHFEXIEX-BK7E-REm.js} +10 -9
  45. package/out/renderer/assets/{stateDiagram-v2-FVOUBMTO-B_qQJqra.js → stateDiagram-v2-QKLJ7IA2-Cd2wfCQu.js} +4 -4
  46. package/out/renderer/assets/{timeline-definition-YZTLITO2-UoWXE_76.js → timeline-definition-GMOUNBTQ-Bl-MTfK5.js} +445 -71
  47. package/out/renderer/assets/{vennDiagram-LZ73GAT5-Dp1FZ609.js → vennDiagram-DHZGUBPP-DNmr1k2L.js} +1 -1
  48. package/out/renderer/assets/{treemap-KZPCXAKY-W2a2L6ff.js → wardley-RL74JXVD-DTbxPMj9.js} +1474 -977
  49. package/out/renderer/assets/wardleyDiagram-NUSXRM2D-BWw08wtD.js +901 -0
  50. package/out/renderer/assets/{xychartDiagram-JWTSCODW-CTzYHTbD.js → xychartDiagram-5P7HB3ND-EEYPnLDT.js} +20 -4
  51. package/out/renderer/index.html +3 -3
  52. package/out/renderer/progress.html +212 -62
  53. package/out/resources/mcp-server/aider-desk-mcp-server.js +642 -402
  54. package/out/runner.js +976 -386
  55. package/package.json +2 -3
  56. package/out/renderer/assets/_basePickBy-BWoXHZ8Z.js +0 -161
  57. package/out/renderer/assets/apl-fqmucPXA.js +0 -140
  58. package/out/renderer/assets/asciiarmor-DucZyvP0.js +0 -56
  59. package/out/renderer/assets/asn1-BnOEsgAm.js +0 -144
  60. package/out/renderer/assets/asterisk-QAlztEwS.js +0 -345
  61. package/out/renderer/assets/brainfuck-DZVCuF_t.js +0 -53
  62. package/out/renderer/assets/clike-xqXYL6ge.js +0 -805
  63. package/out/renderer/assets/clojure-BhXMqnxz.js +0 -849
  64. package/out/renderer/assets/cmake-BGaNd9E7.js +0 -71
  65. package/out/renderer/assets/cobol-4yqQntpt.js +0 -120
  66. package/out/renderer/assets/coffeescript-D2dXvhEc.js +0 -308
  67. package/out/renderer/assets/commonlisp-CF_VNHQR.js +0 -130
  68. package/out/renderer/assets/crystal-DyuLTqLs.js +0 -398
  69. package/out/renderer/assets/css-c-jst79C.js +0 -1783
  70. package/out/renderer/assets/cypher-Dlu_3r4V.js +0 -121
  71. package/out/renderer/assets/d-UURgV0Ux.js +0 -179
  72. package/out/renderer/assets/diff-B_Bi2Crb.js +0 -25
  73. package/out/renderer/assets/dockerfile-Bvk733Ga.js +0 -201
  74. package/out/renderer/assets/dtd-Dy74G54E.js +0 -114
  75. package/out/renderer/assets/dylan-TSb-Nfix.js +0 -314
  76. package/out/renderer/assets/ebnf-4fKAGW3a.js +0 -140
  77. package/out/renderer/assets/ecl-B59qGGVg.js +0 -178
  78. package/out/renderer/assets/eiffel-Dze7nlu3.js +0 -134
  79. package/out/renderer/assets/elm-DG7jkhNZ.js +0 -176
  80. package/out/renderer/assets/erlang-BO6gOnGA.js +0 -674
  81. package/out/renderer/assets/factor-CMxFHDqz.js +0 -65
  82. package/out/renderer/assets/fcl-CDDUNjTj.js +0 -141
  83. package/out/renderer/assets/forth-B9D2JCeE.js +0 -116
  84. package/out/renderer/assets/fortran-CAG2BFbe.js +0 -467
  85. package/out/renderer/assets/gas-d3KEcW3x.js +0 -294
  86. package/out/renderer/assets/gherkin-DhZlEZiy.js +0 -115
  87. package/out/renderer/assets/groovy-CpwJiBl7.js +0 -223
  88. package/out/renderer/assets/haskell-ySd-OUo8.js +0 -459
  89. package/out/renderer/assets/haxe-7MlzfeYV.js +0 -514
  90. package/out/renderer/assets/http-BqypyemW.js +0 -79
  91. package/out/renderer/assets/idl-4HIGJlDI.js +0 -985
  92. package/out/renderer/assets/index-6qedlt0q.js +0 -689
  93. package/out/renderer/assets/index-86jDpUJn.js +0 -385
  94. package/out/renderer/assets/index-BRjO8ber.js +0 -332
  95. package/out/renderer/assets/index-BVgw7j0d.js +0 -312
  96. package/out/renderer/assets/index-BhkyI1q3.js +0 -642
  97. package/out/renderer/assets/index-BqrmLPkg.js +0 -82
  98. package/out/renderer/assets/index-BuPbw4xM.js +0 -178
  99. package/out/renderer/assets/index-CTO-LPBg.js +0 -311
  100. package/out/renderer/assets/index-CTO4SzlI.js +0 -97
  101. package/out/renderer/assets/index-CZ9IQK_0.js +0 -2488
  102. package/out/renderer/assets/index-CZxsVxBZ.js +0 -1765
  103. package/out/renderer/assets/index-DIXV-3Xn.js +0 -406
  104. package/out/renderer/assets/index-DNzOtZX5.js +0 -61
  105. package/out/renderer/assets/index-DZtJe7oC.js +0 -1019
  106. package/out/renderer/assets/index-DaWjZz_g.js +0 -291
  107. package/out/renderer/assets/index-De056HHR.js +0 -151
  108. package/out/renderer/assets/index-Dk3wSDSN.js +0 -117
  109. package/out/renderer/assets/index-Dy4VRsnA.js +0 -1041
  110. package/out/renderer/assets/index-FnnayPBc.js +0 -82
  111. package/out/renderer/assets/index-MZb_zy6R.js +0 -704
  112. package/out/renderer/assets/index-chzQl8rJ.js +0 -157
  113. package/out/renderer/assets/index-s-Owx3Pm.js +0 -327
  114. package/out/renderer/assets/javascript-C_OHM9hj.js +0 -994
  115. package/out/renderer/assets/julia-Bs6JJhYG.js +0 -407
  116. package/out/renderer/assets/livescript-DmzgM3Yt.js +0 -296
  117. package/out/renderer/assets/lua-8cJgIlqe.js +0 -256
  118. package/out/renderer/assets/mathematica-DNLOL9PQ.js +0 -110
  119. package/out/renderer/assets/mbox-Ga7d4MMN.js +0 -117
  120. package/out/renderer/assets/mirc-Dma3B8rS.js +0 -107
  121. package/out/renderer/assets/mllike-DHn7xckP.js +0 -334
  122. package/out/renderer/assets/modelica-0d55jYY0.js +0 -147
  123. package/out/renderer/assets/mscgen-DdqZYINH.js +0 -135
  124. package/out/renderer/assets/mumps-Btr8VblO.js +0 -93
  125. package/out/renderer/assets/nginx-DTDtBDVN.js +0 -141
  126. package/out/renderer/assets/nsis-3zG7tgur.js +0 -62
  127. package/out/renderer/assets/ntriples-CvgOYMpL.js +0 -153
  128. package/out/renderer/assets/octave-DYBj3-tl.js +0 -200
  129. package/out/renderer/assets/oz-R_e8WMIi.js +0 -231
  130. package/out/renderer/assets/pascal-GD8iposT.js +0 -105
  131. package/out/renderer/assets/perl-DL9mHpoi.js +0 -1105
  132. package/out/renderer/assets/pig-C_4T4YIV.js +0 -101
  133. package/out/renderer/assets/powershell-B0suO7Vd.js +0 -328
  134. package/out/renderer/assets/properties-BR-vP1aU.js +0 -58
  135. package/out/renderer/assets/protobuf-BxgpyhoW.js +0 -77
  136. package/out/renderer/assets/pug-CTXt1f8z.js +0 -405
  137. package/out/renderer/assets/puppet-Bdao66PW.js +0 -137
  138. package/out/renderer/assets/python-CvWbmiX4.js +0 -427
  139. package/out/renderer/assets/q-CrbCVq4a.js +0 -131
  140. package/out/renderer/assets/r-V7nswm59.js +0 -170
  141. package/out/renderer/assets/rpm-C-DLY-If.js +0 -109
  142. package/out/renderer/assets/ruby-JDKLJNK0.js +0 -330
  143. package/out/renderer/assets/sas-D2UG-yhZ.js +0 -207
  144. package/out/renderer/assets/scheme-BKzrkGJD.js +0 -222
  145. package/out/renderer/assets/shell-BlsXDxCn.js +0 -222
  146. package/out/renderer/assets/sieve-CjwBwOY5.js +0 -135
  147. package/out/renderer/assets/simple-mode-DMneyfDu.js +0 -130
  148. package/out/renderer/assets/smalltalk-BOIGQuhN.js +0 -121
  149. package/out/renderer/assets/solr-CwD7U71z.js +0 -69
  150. package/out/renderer/assets/sparql-DYskk2vE.js +0 -249
  151. package/out/renderer/assets/spreadsheet-Bgtt3oLP.js +0 -87
  152. package/out/renderer/assets/sql-BSrOzCRI.js +0 -354
  153. package/out/renderer/assets/stex-B6LNC55o.js +0 -231
  154. package/out/renderer/assets/stylus-BkS-boTH.js +0 -565
  155. package/out/renderer/assets/swift-FRZi1uvB.js +0 -291
  156. package/out/renderer/assets/tcl-CUcaCdmq.js +0 -114
  157. package/out/renderer/assets/textile-BnFpjsrl.js +0 -414
  158. package/out/renderer/assets/tiddlywiki-CjprD-Qp.js +0 -218
  159. package/out/renderer/assets/tiki-DK9DOeWn.js +0 -268
  160. package/out/renderer/assets/toml-BOuWGMcf.js +0 -76
  161. package/out/renderer/assets/troff-E1bJ0PPL.js +0 -61
  162. package/out/renderer/assets/ttcn-cfg-Dc39-fIP.js +0 -133
  163. package/out/renderer/assets/ttcn-tKd4HLu4.js +0 -192
  164. package/out/renderer/assets/turtle-Dq7-1WAf.js +0 -124
  165. package/out/renderer/assets/vb-Dp90gtsv.js +0 -196
  166. package/out/renderer/assets/vbscript-CI6_mxxU.js +0 -479
  167. package/out/renderer/assets/velocity-BwIZK1TH.js +0 -149
  168. package/out/renderer/assets/verilog-DDCYnHN8.js +0 -430
  169. package/out/renderer/assets/vhdl-DCkMIyT9.js +0 -158
  170. package/out/renderer/assets/webidl-BTLTThCm.js +0 -204
  171. package/out/renderer/assets/xquery-BrBUuxMR.js +0 -525
  172. package/out/renderer/assets/yacas-b5lAVEIl.js +0 -130
  173. package/out/renderer/assets/z80-BZV19vqv.js +0 -93
  174. package/scripts/download-uv.mjs +0 -147
  175. /package/patches/{ai+5.0.161.patch → ai+5.0.167.patch} +0 -0
@@ -1,4 +1,4 @@
1
- import { s as setAccDescription, g as getAccDescription, q as getDiagramTitle, p as setDiagramTitle, a as getAccTitle, b as setAccTitle, _ as __name, l as log, I as selectSvgElement, e as configureSvgSize, z as clear, G as getConfig, i as sanitizeText, E as cleanAndMerge, F as defaultConfig_default, L as getThemeVariables3, M as band, N as computeDimensionOfText, K as linear, O as line } from "./index-MDHavDF9.js";
1
+ import { s as setAccDescription, g as getAccDescription, q as getDiagramTitle, p as setDiagramTitle, a as getAccTitle, b as setAccTitle, _ as __name, l as log, I as selectSvgElement, e as configureSvgSize, z as clear, D as getConfig, i as sanitizeText, F as cleanAndMerge, G as defaultConfig_default, L as getThemeVariables3, M as band, N as computeDimensionOfText, K as linear, O as line } from "./index-BL-57WPa.js";
2
2
  var parser = (function() {
3
3
  var o = /* @__PURE__ */ __name(function(k, v, o2, l) {
4
4
  for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) ;
@@ -1785,14 +1785,16 @@ var draw = /* @__PURE__ */ __name((txt, id, _version, diagObj) => {
1785
1785
  case "rect":
1786
1786
  shapeGroup.selectAll("rect").data(shape.data).enter().append("rect").attr("x", (data) => data.x).attr("y", (data) => data.y).attr("width", (data) => data.width).attr("height", (data) => data.height).attr("fill", (data) => data.fill).attr("stroke", (data) => data.strokeFill).attr("stroke-width", (data) => data.strokeWidth);
1787
1787
  if (chartConfig.showDataLabel) {
1788
+ const showDataLabelOutsideBar = chartConfig.showDataLabelOutsideBar;
1788
1789
  if (chartConfig.chartOrientation === "horizontal") {
1789
1790
  let fitsHorizontally2 = function(item, fontSize) {
1790
1791
  const { data, label } = item;
1791
1792
  const textWidth = fontSize * label.length * charWidthFactor;
1792
- return textWidth <= data.width - 10;
1793
+ return textWidth <= data.width - rightMargin;
1793
1794
  };
1794
1795
  __name(fitsHorizontally2, "fitsHorizontally");
1795
1796
  const charWidthFactor = 0.7;
1797
+ const rightMargin = 10;
1796
1798
  const validItems = shape.data.map((d, i) => ({ data: d, label: labelData[i].toString() })).filter((item) => item.data.width > 0 && item.data.height > 0);
1797
1799
  const candidateFontSizes = validItems.map((item) => {
1798
1800
  const { data } = item;
@@ -1803,7 +1805,14 @@ var draw = /* @__PURE__ */ __name((txt, id, _version, diagObj) => {
1803
1805
  return fontSize;
1804
1806
  });
1805
1807
  const uniformFontSize = Math.floor(Math.min(...candidateFontSizes));
1806
- shapeGroup.selectAll("text").data(validItems).enter().append("text").attr("x", (item) => item.data.x + item.data.width - 10).attr("y", (item) => item.data.y + item.data.height / 2).attr("text-anchor", "end").attr("dominant-baseline", "middle").attr("fill", "black").attr("font-size", `${uniformFontSize}px`).text((item) => item.label);
1808
+ const determineLabelXPosition = /* @__PURE__ */ __name((item) => {
1809
+ if (showDataLabelOutsideBar) {
1810
+ return item.data.x + item.data.width + rightMargin;
1811
+ } else {
1812
+ return item.data.x + item.data.width - rightMargin;
1813
+ }
1814
+ }, "determineLabelXPosition");
1815
+ shapeGroup.selectAll("text").data(validItems).enter().append("text").attr("x", determineLabelXPosition).attr("y", (item) => item.data.y + item.data.height / 2).attr("text-anchor", showDataLabelOutsideBar ? "start" : "end").attr("dominant-baseline", "middle").attr("fill", themeConfig.dataLabelColor).attr("font-size", `${uniformFontSize}px`).text((item) => item.label);
1807
1816
  } else {
1808
1817
  let fitsInBar2 = function(item, fontSize, yOffset2) {
1809
1818
  const { data, label } = item;
@@ -1828,7 +1837,14 @@ var draw = /* @__PURE__ */ __name((txt, id, _version, diagObj) => {
1828
1837
  return fontSize;
1829
1838
  });
1830
1839
  const uniformFontSize = Math.floor(Math.min(...candidateFontSizes));
1831
- shapeGroup.selectAll("text").data(validItems).enter().append("text").attr("x", (item) => item.data.x + item.data.width / 2).attr("y", (item) => item.data.y + yOffset).attr("text-anchor", "middle").attr("dominant-baseline", "hanging").attr("fill", "black").attr("font-size", `${uniformFontSize}px`).text((item) => item.label);
1840
+ const determineLabelYPosition = /* @__PURE__ */ __name((item) => {
1841
+ if (showDataLabelOutsideBar) {
1842
+ return item.data.y - yOffset;
1843
+ } else {
1844
+ return item.data.y + yOffset;
1845
+ }
1846
+ }, "determineLabelYPosition");
1847
+ shapeGroup.selectAll("text").data(validItems).enter().append("text").attr("x", (item) => item.data.x + item.data.width / 2).attr("y", determineLabelYPosition).attr("text-anchor", "middle").attr("dominant-baseline", showDataLabelOutsideBar ? "auto" : "hanging").attr("fill", themeConfig.dataLabelColor).attr("font-size", `${uniformFontSize}px`).text((item) => item.label);
1832
1848
  }
1833
1849
  }
1834
1850
  break;
@@ -11,7 +11,7 @@
11
11
  <!-- https://developer.mozilla.org/en-US/docs/Web/HTTP/CSP -->
12
12
  <meta
13
13
  http-equiv="Content-Security-Policy"
14
- content="default-src 'self'; script-src 'self' blob: https://unpkg.com; style-src 'self' 'unsafe-inline' https://fonts.googleapis.com https://fonts.gstatic.com; img-src 'self' data: file: https:; font-src 'self' https://fonts.gstatic.com; connect-src 'self' http: https: ws: wss:; frame-src http: https:;"
14
+ content="default-src 'self'; script-src 'self' blob: 'unsafe-eval' https://unpkg.com; style-src 'self' 'unsafe-inline' https://fonts.googleapis.com https://fonts.gstatic.com; img-src 'self' data: file: https:; font-src 'self' https://fonts.gstatic.com; connect-src 'self' data: http: https: ws: wss:; frame-src http: https:;"
15
15
  />
16
16
  <link rel="icon" type="image/x-icon" href="./assets/favicon-D4IkgeLL.ico">
17
17
  <link rel="manifest" href="./manifest.json">
@@ -20,8 +20,8 @@
20
20
  <meta name="apple-mobile-web-app-status-bar-style" content="black-translucent">
21
21
  <meta name="apple-mobile-web-app-title" content="AiderDesk">
22
22
  <link rel="apple-touch-icon" href="/icon-192.png">
23
- <script type="module" crossorigin src="./assets/index-MDHavDF9.js"></script>
24
- <link rel="stylesheet" crossorigin href="./assets/index-CDCy_DhA.css">
23
+ <script type="module" crossorigin src="./assets/index-BL-57WPa.js"></script>
24
+ <link rel="stylesheet" crossorigin href="./assets/index-BkntVzTm.css">
25
25
  </head>
26
26
 
27
27
  <body>
@@ -3,111 +3,261 @@
3
3
  <head>
4
4
  <meta charset="UTF-8">
5
5
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
6
- <title>Starting AiderDesk...</title>
6
+ <title>Starting...</title>
7
7
  <style>
8
- body {
8
+ @font-face {
9
+ font-family: 'Sono';
10
+ src: url('./assets/Sono-FNnoYGUO.ttf') format('truetype');
11
+ font-weight: 400;
12
+ font-style: normal;
13
+ }
14
+ </style>
15
+ <style>
16
+ * {
9
17
  margin: 0;
10
- padding: 20px;
11
- background-color: #222431;
18
+ padding: 0;
19
+ box-sizing: border-box;
20
+ }
21
+
22
+ body {
23
+ padding: 32px;
24
+ background: transparent;
12
25
  color: #f1f3f5;
13
- font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
26
+ font-family: 'Sono', monospace;
14
27
  display: flex;
15
28
  flex-direction: column;
29
+ align-items: center;
30
+ justify-content: center;
16
31
  height: 100vh;
17
- box-sizing: border-box;
32
+ overflow: hidden;
33
+ position: relative;
34
+ -webkit-app-region: drag;
18
35
  }
19
- .text {
20
- font-size: 14px;
21
- font-weight: bold;
22
- margin-bottom: 8px;
36
+
37
+ .container {
38
+ position: relative;
39
+ background: #222431;
40
+ background-size: cover;
41
+ background-position: center;
42
+ background-repeat: no-repeat;
43
+ border: 1px solid #3d4166;
44
+ border-radius: 12px;
45
+ padding: 32px;
46
+ width: 100%;
47
+ box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
48
+ -webkit-app-region: no-drag;
23
49
  }
24
- .subtitle {
25
- font-size: 11px;
26
- color: #999ba3;
27
- margin-bottom: 4px;
28
- display: none;
50
+
51
+ .container::before {
52
+ content: '';
53
+ position: absolute;
54
+ inset: 0;
55
+ background: rgba(34, 36, 49, 0.7);
56
+ border-radius: 12px;
57
+ pointer-events: none;
58
+ z-index: 1;
29
59
  }
30
60
 
31
- .detail {
32
- font-size: 12px;
33
- color: #999ba3;
34
- margin-bottom: 16px;
61
+ #splash-video {
62
+ position: absolute;
63
+ inset: 0;
64
+ width: 100%;
65
+ height: 100%;
66
+ -o-object-fit: cover;
67
+ object-fit: cover;
68
+ border-radius: 12px;
69
+ z-index: 0;
70
+ }
71
+
72
+ .brand {
35
73
  display: flex;
74
+ flex-direction: column;
36
75
  align-items: center;
37
- gap: 8px;
76
+ gap: 16px;
77
+ margin-bottom: 32px;
78
+ position: relative;
79
+ z-index: 1;
80
+ }
81
+
82
+ .brand-icon {
83
+ width: 72px;
84
+ height: 72px;
85
+ border-radius: 14px;
86
+ }
87
+
88
+ .brand-name {
89
+ font-size: 20px;
90
+ font-weight: 600;
91
+ color: #f1f3f5;
92
+ letter-spacing: -0.3px;
38
93
  }
39
- .spinner {
40
- width: 14px;
41
- height: 14px;
42
- border: 2px solid rgba(88, 92, 117, 0.3);
43
- border-top-color: #585c75;
44
- border-radius: 50%;
45
- animation: spin 1s linear infinite;
46
- flex-shrink: 0;
47
- display: none;
94
+
95
+ .detail {
96
+ font-size: 13px;
97
+ font-weight: 400;
98
+ /*color: #999ba3;*/
99
+ text-align: center;
100
+ min-height: 20px;
101
+ margin-bottom: 28px;
102
+ position: relative;
103
+ z-index: 1;
48
104
  }
49
- @keyframes spin {
50
- to { transform: rotate(360deg); }
105
+
106
+ .detail-text {
107
+ opacity: 0;
108
+ animation: fadeIn 0.3s ease forwards;
109
+ }
110
+
111
+ @keyframes fadeIn {
112
+ to { opacity: 1; }
51
113
  }
114
+
115
+ .completed .detail {
116
+ color: #22c55edd;
117
+ }
118
+
52
119
  .progress-container {
53
- height: 16px;
54
- background-color: #191a22;
55
- border-radius: 2px;
120
+ width: 100%;
121
+ height: 2px;
122
+ background: #333652;
123
+ border-radius: 1px;
56
124
  overflow: hidden;
57
- margin-bottom: 8px;
125
+ margin-bottom: 20px;
126
+ position: relative;
127
+ z-index: 1;
58
128
  }
129
+
59
130
  .progress-bar {
131
+ position: absolute;
132
+ top: 0;
133
+ left: 0;
60
134
  height: 100%;
61
- width: 0;
62
- background-color: #3d4166;
63
- border-radius: 2px;
64
- transition: width 0.5s cubic-bezier(0.4, 0, 0.2, 1), background-color 0.3s ease;
135
+ background: #f1f3f588;
136
+ border-radius: 1px;
137
+ transition: width 0.3s ease;
138
+ }
139
+
140
+ .progress-indeterminate {
141
+ width: 40%;
142
+ animation: indeterminate-slide 1.8s cubic-bezier(0.4, 0, 0.2, 1) infinite;
143
+ }
144
+
145
+ @keyframes indeterminate-slide {
146
+ 0% {
147
+ left: -40%;
148
+ right: 100%;
149
+ }
150
+ 60% {
151
+ left: 100%;
152
+ right: -40%;
153
+ }
154
+ 100% {
155
+ left: 100%;
156
+ right: -40%;
157
+ }
65
158
  }
159
+
66
160
  .completed .progress-bar {
67
161
  width: 100% !important;
68
- background-color: #3b82f6;
162
+ animation: none;
163
+ background: #22c55e;
164
+ }
165
+
166
+ .log-line {
167
+ width: 100%;
168
+ font-size: 11px;
169
+ /*color: #7b7d86;*/
170
+ white-space: nowrap;
171
+ overflow: hidden;
172
+ text-overflow: ellipsis;
173
+ font-family: 'Sono', monospace;
174
+ text-align: center;
175
+ opacity: 0.8;
176
+ min-height: 16px;
177
+ transition: opacity 0.3s ease;
178
+ position: relative;
179
+ z-index: 1;
180
+ }
181
+
182
+ .log-line:not(:empty) {
183
+ opacity: 1;
184
+ animation: slideUp 0.3s ease;
185
+ }
186
+
187
+ @keyframes slideUp {
188
+ from {
189
+ transform: translateY(4px);
190
+ opacity: 0;
191
+ }
192
+ to {
193
+ transform: translateY(0);
194
+ opacity: 1;
195
+ }
196
+ }
197
+
198
+ .completed .detail {
199
+ color: #22c55e4c;
69
200
  }
70
201
  </style>
71
202
  </head>
72
203
  <body>
73
- <div class="text" id="text">Starting AiderDesk...</div>
74
- <div class="detail" id="detail">
75
- <span id="detail-text">Initializing...</span>
76
- <div class="spinner" id="spinner"></div>
77
- </div>
78
- <div class="subtitle" id="subtitle">This may take a while...</div>
79
- <div class="progress-container">
80
- <div class="progress-bar" id="progress-bar"></div>
204
+ <div class="container">
205
+ <video id="splash-video" autoplay muted loop></video>
206
+ <div class="brand">
207
+ <div class="brand-icon-wrapper">
208
+ <img class="brand-icon" id="brand-icon" src="" alt="AiderDesk">
209
+ </div>
210
+ <span class="brand-name">AiderDesk</span>
211
+ </div>
212
+
213
+ <div class="detail">
214
+ <span class="detail-text" id="detail-text">Initializing...</span>
215
+ </div>
216
+
217
+ <div class="progress-container">
218
+ <div class="progress-bar progress-indeterminate" id="progress-bar"></div>
219
+ </div>
220
+
221
+ <div class="log-line" id="log-line"></div>
81
222
  </div>
82
223
 
83
224
  <script>
84
225
  const { ipcRenderer } = require('electron');
85
226
 
86
- ipcRenderer.on('set-title', (_, title) => {
87
- document.getElementById('text').textContent = title;
227
+ ipcRenderer.on('set-icon-path', (_, iconPath) => {
228
+ document.getElementById('brand-icon').src = iconPath;
88
229
  });
89
230
 
90
- ipcRenderer.on('set-detail', (_, value, subtitle) => {
91
- const messageEl = document.getElementById('detail-text');
92
- const spinnerEl = document.getElementById('spinner');
93
- const infoEl = document.getElementById('subtitle');
231
+ ipcRenderer.on('set-splash-image', (_, imagePath) => {
232
+ const video = document.getElementById('splash-video');
233
+ video.src = imagePath;
234
+ });
235
+
236
+ ipcRenderer.on('set-title', (_, title) => {
237
+ // Title is no longer displayed, but keep handler for compatibility
238
+ });
94
239
 
95
- messageEl.textContent = value;
96
- const showSpinner = /installing|package|aider|connector|requirements|python|uv|venv/i.test(value.toLowerCase());
97
- spinnerEl.style.display = showSpinner ? 'block' : 'none';
240
+ ipcRenderer.on('set-detail', (_, value) => {
241
+ const detailTextEl = document.getElementById('detail-text');
98
242
 
99
- infoEl.textContent = subtitle || '';
100
- infoEl.style.display = subtitle ? 'block' : 'none';
243
+ // Trigger fade-in animation by removing and re-adding the element
244
+ detailTextEl.style.animation = 'none';
245
+ setTimeout(() => {
246
+ detailTextEl.textContent = value;
247
+ detailTextEl.style.animation = 'fadeIn 0.4s ease forwards';
248
+ }, 10);
101
249
  });
102
250
 
103
251
  ipcRenderer.on('set-completed', () => {
104
252
  document.body.classList.add('completed');
253
+ const progressBar = document.getElementById('progress-bar');
254
+ progressBar.classList.remove('progress-indeterminate');
105
255
  });
106
256
 
107
- const progressBar = document.getElementById('progress-bar');
257
+ const logLine = document.getElementById('log-line');
108
258
 
109
- ipcRenderer.on('set-progress', (_, progress) => {
110
- progressBar.style.width = `${Math.min(100, Math.max(0, progress))}%`;
259
+ ipcRenderer.on('add-log', (_, message) => {
260
+ logLine.textContent = message;
111
261
  });
112
262
  </script>
113
263
  </body>