figrecipe 0.6.0__py3-none-any.whl → 0.9.0__py3-none-any.whl

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 (269) hide show
  1. figrecipe/__init__.py +161 -1030
  2. figrecipe/__main__.py +12 -0
  3. figrecipe/_api/__init__.py +48 -0
  4. figrecipe/_api/_extract.py +108 -0
  5. figrecipe/_api/_notebook.py +61 -0
  6. figrecipe/_api/_panel.py +113 -0
  7. figrecipe/_api/_save.py +287 -0
  8. figrecipe/_api/_seaborn_proxy.py +34 -0
  9. figrecipe/_api/_style_manager.py +153 -0
  10. figrecipe/_api/_subplots.py +333 -0
  11. figrecipe/_api/_validate.py +82 -0
  12. figrecipe/_cli/__init__.py +7 -0
  13. figrecipe/_cli/_compose.py +87 -0
  14. figrecipe/_cli/_convert.py +117 -0
  15. figrecipe/_cli/_crop.py +82 -0
  16. figrecipe/_cli/_edit.py +70 -0
  17. figrecipe/_cli/_extract.py +128 -0
  18. figrecipe/_cli/_fonts.py +47 -0
  19. figrecipe/_cli/_info.py +67 -0
  20. figrecipe/_cli/_main.py +58 -0
  21. figrecipe/_cli/_reproduce.py +79 -0
  22. figrecipe/_cli/_style.py +77 -0
  23. figrecipe/_cli/_validate.py +66 -0
  24. figrecipe/_cli/_version.py +50 -0
  25. figrecipe/_composition/__init__.py +32 -0
  26. figrecipe/_composition/_alignment.py +452 -0
  27. figrecipe/_composition/_compose.py +179 -0
  28. figrecipe/_composition/_import_axes.py +127 -0
  29. figrecipe/_composition/_visibility.py +125 -0
  30. figrecipe/_dev/__init__.py +4 -93
  31. figrecipe/_dev/_plotters.py +76 -0
  32. figrecipe/_dev/_run_demos.py +56 -0
  33. figrecipe/_dev/browser/__init__.py +69 -0
  34. figrecipe/_dev/browser/_audio.py +240 -0
  35. figrecipe/_dev/browser/_caption.py +356 -0
  36. figrecipe/_dev/browser/_click_effect.py +146 -0
  37. figrecipe/_dev/browser/_cursor.py +196 -0
  38. figrecipe/_dev/browser/_highlight.py +105 -0
  39. figrecipe/_dev/browser/_narration.py +237 -0
  40. figrecipe/_dev/browser/_recorder.py +446 -0
  41. figrecipe/_dev/browser/_utils.py +178 -0
  42. figrecipe/_dev/browser/_video_trim/__init__.py +152 -0
  43. figrecipe/_dev/browser/_video_trim/_detection.py +223 -0
  44. figrecipe/_dev/browser/_video_trim/_markers.py +140 -0
  45. figrecipe/_dev/demo_plotters/__init__.py +35 -166
  46. figrecipe/_dev/demo_plotters/_categories.py +81 -0
  47. figrecipe/_dev/demo_plotters/_figure_creators.py +119 -0
  48. figrecipe/_dev/demo_plotters/_helpers.py +31 -0
  49. figrecipe/_dev/demo_plotters/_registry.py +50 -0
  50. figrecipe/_dev/demo_plotters/bar_categorical/__init__.py +4 -0
  51. figrecipe/_dev/demo_plotters/contour_surface/__init__.py +4 -0
  52. figrecipe/_dev/demo_plotters/distribution/__init__.py +4 -0
  53. figrecipe/_dev/demo_plotters/image_matrix/__init__.py +4 -0
  54. figrecipe/_dev/demo_plotters/line_curve/__init__.py +4 -0
  55. figrecipe/_dev/demo_plotters/{plot_plot.py → line_curve/plot_plot.py} +3 -2
  56. figrecipe/_dev/demo_plotters/scatter_points/__init__.py +4 -0
  57. figrecipe/_dev/demo_plotters/special/__init__.py +4 -0
  58. figrecipe/_dev/demo_plotters/{plot_pie.py → special/plot_pie.py} +5 -1
  59. figrecipe/_dev/demo_plotters/spectral_signal/__init__.py +4 -0
  60. figrecipe/_dev/demo_plotters/vector_flow/__init__.py +4 -0
  61. figrecipe/_editor/__init__.py +61 -13
  62. figrecipe/_editor/_bbox/__init__.py +43 -0
  63. figrecipe/_editor/_bbox/_collections.py +177 -0
  64. figrecipe/_editor/_bbox/_elements.py +159 -0
  65. figrecipe/_editor/_bbox/_extract.py +402 -0
  66. figrecipe/_editor/_bbox/_extract_axes.py +370 -0
  67. figrecipe/_editor/_bbox/_extract_text.py +466 -0
  68. figrecipe/_editor/_bbox/_lines.py +173 -0
  69. figrecipe/_editor/_bbox/_transforms.py +146 -0
  70. figrecipe/_editor/_call_overrides.py +183 -0
  71. figrecipe/_editor/_datatable_plot_handlers.py +249 -0
  72. figrecipe/_editor/_figure_layout.py +211 -0
  73. figrecipe/_editor/_flask_app.py +200 -1030
  74. figrecipe/_editor/_helpers.py +251 -0
  75. figrecipe/_editor/_hitmap/__init__.py +76 -0
  76. figrecipe/_editor/_hitmap/_artists/__init__.py +21 -0
  77. figrecipe/_editor/_hitmap/_artists/_collections.py +345 -0
  78. figrecipe/_editor/_hitmap/_artists/_images.py +68 -0
  79. figrecipe/_editor/_hitmap/_artists/_lines.py +107 -0
  80. figrecipe/_editor/_hitmap/_artists/_patches.py +163 -0
  81. figrecipe/_editor/_hitmap/_artists/_text.py +190 -0
  82. figrecipe/_editor/_hitmap/_colors.py +181 -0
  83. figrecipe/_editor/_hitmap/_detect.py +194 -0
  84. figrecipe/_editor/_hitmap/_restore.py +154 -0
  85. figrecipe/_editor/_hitmap_main.py +182 -0
  86. figrecipe/_editor/_overrides.py +4 -1
  87. figrecipe/_editor/_plot_types_registry.py +190 -0
  88. figrecipe/_editor/_preferences.py +135 -0
  89. figrecipe/_editor/_render_overrides.py +507 -0
  90. figrecipe/_editor/_renderer.py +81 -186
  91. figrecipe/_editor/_routes_annotation.py +114 -0
  92. figrecipe/_editor/_routes_axis.py +482 -0
  93. figrecipe/_editor/_routes_captions.py +130 -0
  94. figrecipe/_editor/_routes_composition.py +270 -0
  95. figrecipe/_editor/_routes_core.py +126 -0
  96. figrecipe/_editor/_routes_datatable.py +364 -0
  97. figrecipe/_editor/_routes_element.py +335 -0
  98. figrecipe/_editor/_routes_files.py +443 -0
  99. figrecipe/_editor/_routes_image.py +200 -0
  100. figrecipe/_editor/_routes_snapshot.py +94 -0
  101. figrecipe/_editor/_routes_style.py +243 -0
  102. figrecipe/_editor/_templates/__init__.py +116 -1
  103. figrecipe/_editor/_templates/_html.py +154 -64
  104. figrecipe/_editor/_templates/_html_components/__init__.py +13 -0
  105. figrecipe/_editor/_templates/_html_components/_composition_toolbar.py +79 -0
  106. figrecipe/_editor/_templates/_html_components/_file_browser.py +41 -0
  107. figrecipe/_editor/_templates/_html_datatable.py +92 -0
  108. figrecipe/_editor/_templates/_scripts/__init__.py +178 -0
  109. figrecipe/_editor/_templates/_scripts/_accordion.py +328 -0
  110. figrecipe/_editor/_templates/_scripts/_annotation_drag.py +504 -0
  111. figrecipe/_editor/_templates/_scripts/_api.py +228 -0
  112. figrecipe/_editor/_templates/_scripts/_canvas_context_menu.py +182 -0
  113. figrecipe/_editor/_templates/_scripts/_captions.py +231 -0
  114. figrecipe/_editor/_templates/_scripts/_colors.py +485 -0
  115. figrecipe/_editor/_templates/_scripts/_composition.py +283 -0
  116. figrecipe/_editor/_templates/_scripts/_core.py +493 -0
  117. figrecipe/_editor/_templates/_scripts/_datatable/__init__.py +59 -0
  118. figrecipe/_editor/_templates/_scripts/_datatable/_cell_edit.py +97 -0
  119. figrecipe/_editor/_templates/_scripts/_datatable/_clipboard.py +164 -0
  120. figrecipe/_editor/_templates/_scripts/_datatable/_context_menu.py +221 -0
  121. figrecipe/_editor/_templates/_scripts/_datatable/_core.py +150 -0
  122. figrecipe/_editor/_templates/_scripts/_datatable/_editable.py +511 -0
  123. figrecipe/_editor/_templates/_scripts/_datatable/_import.py +161 -0
  124. figrecipe/_editor/_templates/_scripts/_datatable/_plot.py +261 -0
  125. figrecipe/_editor/_templates/_scripts/_datatable/_selection.py +438 -0
  126. figrecipe/_editor/_templates/_scripts/_datatable/_table.py +256 -0
  127. figrecipe/_editor/_templates/_scripts/_datatable/_tabs.py +354 -0
  128. figrecipe/_editor/_templates/_scripts/_debug_snapshot.py +186 -0
  129. figrecipe/_editor/_templates/_scripts/_element_editor.py +325 -0
  130. figrecipe/_editor/_templates/_scripts/_files.py +429 -0
  131. figrecipe/_editor/_templates/_scripts/_files_context_menu.py +240 -0
  132. figrecipe/_editor/_templates/_scripts/_hitmap.py +512 -0
  133. figrecipe/_editor/_templates/_scripts/_image_drop.py +428 -0
  134. figrecipe/_editor/_templates/_scripts/_inspector.py +315 -0
  135. figrecipe/_editor/_templates/_scripts/_labels.py +464 -0
  136. figrecipe/_editor/_templates/_scripts/_legend_drag.py +270 -0
  137. figrecipe/_editor/_templates/_scripts/_modals.py +226 -0
  138. figrecipe/_editor/_templates/_scripts/_multi_select.py +198 -0
  139. figrecipe/_editor/_templates/_scripts/_overlays.py +292 -0
  140. figrecipe/_editor/_templates/_scripts/_panel_drag.py +505 -0
  141. figrecipe/_editor/_templates/_scripts/_panel_drag_snapshot.py +33 -0
  142. figrecipe/_editor/_templates/_scripts/_panel_position.py +463 -0
  143. figrecipe/_editor/_templates/_scripts/_panel_resize.py +230 -0
  144. figrecipe/_editor/_templates/_scripts/_panel_snap.py +307 -0
  145. figrecipe/_editor/_templates/_scripts/_region_select.py +255 -0
  146. figrecipe/_editor/_templates/_scripts/_selection.py +244 -0
  147. figrecipe/_editor/_templates/_scripts/_sync.py +242 -0
  148. figrecipe/_editor/_templates/_scripts/_tabs.py +89 -0
  149. figrecipe/_editor/_templates/_scripts/_undo_redo.py +348 -0
  150. figrecipe/_editor/_templates/_scripts/_view_mode.py +107 -0
  151. figrecipe/_editor/_templates/_scripts/_zoom.py +212 -0
  152. figrecipe/_editor/_templates/_styles/__init__.py +78 -0
  153. figrecipe/_editor/_templates/_styles/_base.py +111 -0
  154. figrecipe/_editor/_templates/_styles/_buttons.py +327 -0
  155. figrecipe/_editor/_templates/_styles/_color_input.py +123 -0
  156. figrecipe/_editor/_templates/_styles/_composition.py +87 -0
  157. figrecipe/_editor/_templates/_styles/_controls.py +430 -0
  158. figrecipe/_editor/_templates/_styles/_datatable/__init__.py +40 -0
  159. figrecipe/_editor/_templates/_styles/_datatable/_editable.py +203 -0
  160. figrecipe/_editor/_templates/_styles/_datatable/_panel.py +268 -0
  161. figrecipe/_editor/_templates/_styles/_datatable/_table.py +479 -0
  162. figrecipe/_editor/_templates/_styles/_datatable/_toolbar.py +384 -0
  163. figrecipe/_editor/_templates/_styles/_datatable/_vars.py +123 -0
  164. figrecipe/_editor/_templates/_styles/_dynamic_props.py +144 -0
  165. figrecipe/_editor/_templates/_styles/_file_browser.py +466 -0
  166. figrecipe/_editor/_templates/_styles/_forms.py +224 -0
  167. figrecipe/_editor/_templates/_styles/_hitmap.py +191 -0
  168. figrecipe/_editor/_templates/_styles/_inspector.py +90 -0
  169. figrecipe/_editor/_templates/_styles/_labels.py +118 -0
  170. figrecipe/_editor/_templates/_styles/_modals.py +127 -0
  171. figrecipe/_editor/_templates/_styles/_overlays.py +130 -0
  172. figrecipe/_editor/_templates/_styles/_preview.py +430 -0
  173. figrecipe/_editor/_templates/_styles/_selection.py +73 -0
  174. figrecipe/_editor/_templates/_styles/_spinner.py +117 -0
  175. figrecipe/_editor/static/audio/click.mp3 +0 -0
  176. figrecipe/_editor/static/click.mp3 +0 -0
  177. figrecipe/_editor/static/icons/favicon.ico +0 -0
  178. figrecipe/_integrations/__init__.py +17 -0
  179. figrecipe/_integrations/_scitex_stats.py +298 -0
  180. figrecipe/_params/_DECORATION_METHODS.py +8 -0
  181. figrecipe/_recorder.py +63 -109
  182. figrecipe/_recorder_utils.py +124 -0
  183. figrecipe/_reproducer/__init__.py +18 -0
  184. figrecipe/_reproducer/_core.py +509 -0
  185. figrecipe/_reproducer/_custom_plots.py +279 -0
  186. figrecipe/_reproducer/_seaborn.py +100 -0
  187. figrecipe/_reproducer/_violin.py +186 -0
  188. figrecipe/_signatures/_kwargs.py +273 -0
  189. figrecipe/_signatures/_loader.py +21 -423
  190. figrecipe/_signatures/_parsing.py +147 -0
  191. figrecipe/_utils/__init__.py +3 -0
  192. figrecipe/_utils/_bundle.py +205 -0
  193. figrecipe/_wrappers/_axes.py +252 -895
  194. figrecipe/_wrappers/_axes_helpers.py +136 -0
  195. figrecipe/_wrappers/_axes_plots.py +418 -0
  196. figrecipe/_wrappers/_axes_seaborn.py +157 -0
  197. figrecipe/_wrappers/_caption_generator.py +218 -0
  198. figrecipe/_wrappers/_figure.py +188 -1
  199. figrecipe/_wrappers/_panel_labels.py +127 -0
  200. figrecipe/_wrappers/_plot_helpers.py +143 -0
  201. figrecipe/_wrappers/_stat_annotation.py +274 -0
  202. figrecipe/_wrappers/_violin_helpers.py +180 -0
  203. figrecipe/styles/__init__.py +8 -6
  204. figrecipe/styles/_dotdict.py +72 -0
  205. figrecipe/styles/_finalize.py +134 -0
  206. figrecipe/styles/_fonts.py +77 -0
  207. figrecipe/styles/_kwargs_converter.py +178 -0
  208. figrecipe/styles/_plot_styles.py +209 -0
  209. figrecipe/styles/_style_applier.py +42 -480
  210. figrecipe/styles/_style_loader.py +16 -192
  211. figrecipe/styles/_themes.py +151 -0
  212. figrecipe/styles/presets/MATPLOTLIB.yaml +2 -1
  213. figrecipe/styles/presets/SCITEX.yaml +40 -28
  214. figrecipe-0.9.0.dist-info/METADATA +427 -0
  215. figrecipe-0.9.0.dist-info/RECORD +277 -0
  216. figrecipe-0.9.0.dist-info/entry_points.txt +2 -0
  217. figrecipe/_editor/_bbox.py +0 -978
  218. figrecipe/_editor/_hitmap.py +0 -937
  219. figrecipe/_editor/_templates/_scripts.py +0 -2778
  220. figrecipe/_editor/_templates/_styles.py +0 -1326
  221. figrecipe/_reproducer.py +0 -975
  222. figrecipe-0.6.0.dist-info/METADATA +0 -394
  223. figrecipe-0.6.0.dist-info/RECORD +0 -90
  224. /figrecipe/_dev/demo_plotters/{plot_bar.py → bar_categorical/plot_bar.py} +0 -0
  225. /figrecipe/_dev/demo_plotters/{plot_barh.py → bar_categorical/plot_barh.py} +0 -0
  226. /figrecipe/_dev/demo_plotters/{plot_contour.py → contour_surface/plot_contour.py} +0 -0
  227. /figrecipe/_dev/demo_plotters/{plot_contourf.py → contour_surface/plot_contourf.py} +0 -0
  228. /figrecipe/_dev/demo_plotters/{plot_tricontour.py → contour_surface/plot_tricontour.py} +0 -0
  229. /figrecipe/_dev/demo_plotters/{plot_tricontourf.py → contour_surface/plot_tricontourf.py} +0 -0
  230. /figrecipe/_dev/demo_plotters/{plot_tripcolor.py → contour_surface/plot_tripcolor.py} +0 -0
  231. /figrecipe/_dev/demo_plotters/{plot_triplot.py → contour_surface/plot_triplot.py} +0 -0
  232. /figrecipe/_dev/demo_plotters/{plot_boxplot.py → distribution/plot_boxplot.py} +0 -0
  233. /figrecipe/_dev/demo_plotters/{plot_ecdf.py → distribution/plot_ecdf.py} +0 -0
  234. /figrecipe/_dev/demo_plotters/{plot_hist.py → distribution/plot_hist.py} +0 -0
  235. /figrecipe/_dev/demo_plotters/{plot_hist2d.py → distribution/plot_hist2d.py} +0 -0
  236. /figrecipe/_dev/demo_plotters/{plot_violinplot.py → distribution/plot_violinplot.py} +0 -0
  237. /figrecipe/_dev/demo_plotters/{plot_hexbin.py → image_matrix/plot_hexbin.py} +0 -0
  238. /figrecipe/_dev/demo_plotters/{plot_imshow.py → image_matrix/plot_imshow.py} +0 -0
  239. /figrecipe/_dev/demo_plotters/{plot_matshow.py → image_matrix/plot_matshow.py} +0 -0
  240. /figrecipe/_dev/demo_plotters/{plot_pcolor.py → image_matrix/plot_pcolor.py} +0 -0
  241. /figrecipe/_dev/demo_plotters/{plot_pcolormesh.py → image_matrix/plot_pcolormesh.py} +0 -0
  242. /figrecipe/_dev/demo_plotters/{plot_spy.py → image_matrix/plot_spy.py} +0 -0
  243. /figrecipe/_dev/demo_plotters/{plot_errorbar.py → line_curve/plot_errorbar.py} +0 -0
  244. /figrecipe/_dev/demo_plotters/{plot_fill.py → line_curve/plot_fill.py} +0 -0
  245. /figrecipe/_dev/demo_plotters/{plot_fill_between.py → line_curve/plot_fill_between.py} +0 -0
  246. /figrecipe/_dev/demo_plotters/{plot_fill_betweenx.py → line_curve/plot_fill_betweenx.py} +0 -0
  247. /figrecipe/_dev/demo_plotters/{plot_stackplot.py → line_curve/plot_stackplot.py} +0 -0
  248. /figrecipe/_dev/demo_plotters/{plot_stairs.py → line_curve/plot_stairs.py} +0 -0
  249. /figrecipe/_dev/demo_plotters/{plot_step.py → line_curve/plot_step.py} +0 -0
  250. /figrecipe/_dev/demo_plotters/{plot_scatter.py → scatter_points/plot_scatter.py} +0 -0
  251. /figrecipe/_dev/demo_plotters/{plot_eventplot.py → special/plot_eventplot.py} +0 -0
  252. /figrecipe/_dev/demo_plotters/{plot_loglog.py → special/plot_loglog.py} +0 -0
  253. /figrecipe/_dev/demo_plotters/{plot_semilogx.py → special/plot_semilogx.py} +0 -0
  254. /figrecipe/_dev/demo_plotters/{plot_semilogy.py → special/plot_semilogy.py} +0 -0
  255. /figrecipe/_dev/demo_plotters/{plot_stem.py → special/plot_stem.py} +0 -0
  256. /figrecipe/_dev/demo_plotters/{plot_acorr.py → spectral_signal/plot_acorr.py} +0 -0
  257. /figrecipe/_dev/demo_plotters/{plot_angle_spectrum.py → spectral_signal/plot_angle_spectrum.py} +0 -0
  258. /figrecipe/_dev/demo_plotters/{plot_cohere.py → spectral_signal/plot_cohere.py} +0 -0
  259. /figrecipe/_dev/demo_plotters/{plot_csd.py → spectral_signal/plot_csd.py} +0 -0
  260. /figrecipe/_dev/demo_plotters/{plot_magnitude_spectrum.py → spectral_signal/plot_magnitude_spectrum.py} +0 -0
  261. /figrecipe/_dev/demo_plotters/{plot_phase_spectrum.py → spectral_signal/plot_phase_spectrum.py} +0 -0
  262. /figrecipe/_dev/demo_plotters/{plot_psd.py → spectral_signal/plot_psd.py} +0 -0
  263. /figrecipe/_dev/demo_plotters/{plot_specgram.py → spectral_signal/plot_specgram.py} +0 -0
  264. /figrecipe/_dev/demo_plotters/{plot_xcorr.py → spectral_signal/plot_xcorr.py} +0 -0
  265. /figrecipe/_dev/demo_plotters/{plot_barbs.py → vector_flow/plot_barbs.py} +0 -0
  266. /figrecipe/_dev/demo_plotters/{plot_quiver.py → vector_flow/plot_quiver.py} +0 -0
  267. /figrecipe/_dev/demo_plotters/{plot_streamplot.py → vector_flow/plot_streamplot.py} +0 -0
  268. {figrecipe-0.6.0.dist-info → figrecipe-0.9.0.dist-info}/WHEEL +0 -0
  269. {figrecipe-0.6.0.dist-info → figrecipe-0.9.0.dist-info}/licenses/LICENSE +0 -0
@@ -0,0 +1,466 @@
1
+ #!/usr/bin/env python3
2
+ # -*- coding: utf-8 -*-
3
+ """File browser panel CSS styles for the figure editor.
4
+
5
+ This module contains CSS for:
6
+ - File browser panel and header
7
+ - File tree structure
8
+ - File items and icons
9
+ - Collapse/expand functionality
10
+ """
11
+
12
+ STYLES_FILE_BROWSER = """
13
+ /* File Browser Panel */
14
+ .file-browser-panel {
15
+ width: 200px;
16
+ min-width: 160px;
17
+ max-width: 280px;
18
+ display: flex;
19
+ flex-direction: column;
20
+ background: var(--bg-secondary);
21
+ border-right: 1px solid var(--border-color);
22
+ transition: width 0.2s ease-out;
23
+ position: relative;
24
+ }
25
+
26
+ .file-browser-panel.collapsed {
27
+ width: 36px;
28
+ min-width: 36px;
29
+ }
30
+
31
+ .file-browser-header {
32
+ display: flex;
33
+ align-items: center;
34
+ justify-content: space-between;
35
+ padding: 0 10px;
36
+ height: var(--panel-header-height);
37
+ min-height: var(--panel-header-height);
38
+ background: var(--panel-header-bg);
39
+ border-bottom: 1px solid var(--border-color);
40
+ font-size: 11px;
41
+ font-weight: 600;
42
+ text-transform: uppercase;
43
+ letter-spacing: 0.5px;
44
+ color: var(--text-secondary);
45
+ }
46
+
47
+ .file-browser-header .header-title {
48
+ display: flex;
49
+ align-items: center;
50
+ gap: 6px;
51
+ }
52
+
53
+ .file-browser-header .btn-collapse {
54
+ width: 24px;
55
+ height: 24px;
56
+ padding: 0;
57
+ border: none;
58
+ background: transparent;
59
+ color: var(--text-secondary);
60
+ cursor: pointer;
61
+ font-size: 14px;
62
+ display: flex;
63
+ align-items: center;
64
+ justify-content: center;
65
+ border-radius: 4px;
66
+ transition: all 0.2s;
67
+ }
68
+
69
+ .file-browser-header .btn-collapse:hover {
70
+ background: var(--bg-primary);
71
+ color: var(--text-primary);
72
+ }
73
+
74
+ .file-browser-panel.collapsed .file-browser-header {
75
+ padding: 10px 6px;
76
+ justify-content: center;
77
+ }
78
+
79
+ .file-browser-panel.collapsed .header-title {
80
+ justify-content: center;
81
+ }
82
+
83
+ .file-browser-panel.collapsed .header-title span {
84
+ display: none;
85
+ }
86
+
87
+ .file-browser-actions {
88
+ display: flex;
89
+ gap: 4px;
90
+ }
91
+
92
+ .file-browser-panel.collapsed .file-browser-actions {
93
+ display: flex;
94
+ }
95
+
96
+ .file-browser-panel.collapsed .file-browser-actions button:not(.btn-collapse) {
97
+ display: none;
98
+ }
99
+
100
+ /* Flip collapse button when collapsed (now points right to expand) */
101
+ .file-browser-panel.collapsed .btn-collapse {
102
+ display: flex;
103
+ transform: rotate(180deg);
104
+ }
105
+
106
+ .file-browser-actions button {
107
+ width: 24px;
108
+ height: 24px;
109
+ padding: 0;
110
+ font-size: 14px;
111
+ border: none;
112
+ border-radius: 4px;
113
+ background: transparent;
114
+ color: var(--text-secondary);
115
+ cursor: pointer;
116
+ display: flex;
117
+ align-items: center;
118
+ justify-content: center;
119
+ transition: all 0.2s;
120
+ }
121
+
122
+ .file-browser-actions button:hover {
123
+ background: var(--bg-primary);
124
+ color: var(--accent-color);
125
+ }
126
+
127
+ .file-browser-actions button.btn-new-file:hover {
128
+ color: var(--success-color);
129
+ }
130
+
131
+ /* File Tree Container */
132
+ .file-tree-container {
133
+ flex: 1;
134
+ overflow-y: auto;
135
+ overflow-x: hidden;
136
+ padding: 8px 0;
137
+ }
138
+
139
+ .file-browser-panel.collapsed .file-tree-container {
140
+ display: none;
141
+ }
142
+
143
+ /* File Tree */
144
+ .file-tree {
145
+ list-style: none;
146
+ margin: 0;
147
+ padding: 0;
148
+ }
149
+
150
+ .file-tree-item {
151
+ margin: 0;
152
+ padding: 0;
153
+ }
154
+
155
+ .file-tree-entry {
156
+ display: flex;
157
+ align-items: center;
158
+ gap: 8px;
159
+ padding: 7px 12px;
160
+ cursor: pointer;
161
+ color: var(--text-primary);
162
+ font-size: 12px;
163
+ border-left: 3px solid transparent;
164
+ transition: all 0.12s ease-out;
165
+ user-select: none;
166
+ }
167
+
168
+ .file-tree-entry:hover {
169
+ background: var(--bg-tertiary);
170
+ border-left-color: var(--border-color);
171
+ }
172
+
173
+ .file-tree-entry.selected {
174
+ background: var(--selection-color);
175
+ border-left-color: var(--accent-color);
176
+ }
177
+
178
+ .file-tree-entry.current {
179
+ background: var(--selection-color);
180
+ border-left-color: var(--accent-color);
181
+ font-weight: 600;
182
+ }
183
+
184
+ .file-tree-entry.current .file-tree-name {
185
+ color: var(--accent-color);
186
+ }
187
+
188
+ .file-tree-icon {
189
+ width: 16px;
190
+ height: 16px;
191
+ font-size: 14px;
192
+ flex-shrink: 0;
193
+ display: flex;
194
+ align-items: center;
195
+ justify-content: center;
196
+ }
197
+
198
+ .file-tree-name {
199
+ flex: 1;
200
+ overflow: hidden;
201
+ text-overflow: ellipsis;
202
+ white-space: nowrap;
203
+ }
204
+
205
+ .file-tree-badge {
206
+ font-size: 9px;
207
+ padding: 2px 5px;
208
+ border-radius: 3px;
209
+ background: var(--bg-tertiary);
210
+ color: var(--text-secondary);
211
+ flex-shrink: 0;
212
+ font-weight: 500;
213
+ letter-spacing: 0.3px;
214
+ }
215
+
216
+ .file-tree-entry.has-image .file-tree-badge {
217
+ background: var(--success-color);
218
+ color: white;
219
+ opacity: 0.9;
220
+ }
221
+
222
+ /* File action buttons (rename, delete) */
223
+ .file-tree-actions {
224
+ display: none;
225
+ gap: 2px;
226
+ margin-left: auto;
227
+ flex-shrink: 0;
228
+ }
229
+
230
+ .file-tree-entry:hover .file-tree-actions {
231
+ display: flex;
232
+ }
233
+
234
+ .file-action-btn {
235
+ width: 20px;
236
+ height: 20px;
237
+ padding: 0;
238
+ border: none;
239
+ background: transparent;
240
+ cursor: pointer;
241
+ font-size: 11px;
242
+ border-radius: 3px;
243
+ opacity: 0.6;
244
+ transition: all 0.15s;
245
+ display: flex;
246
+ align-items: center;
247
+ justify-content: center;
248
+ }
249
+
250
+ .file-action-btn:hover {
251
+ opacity: 1;
252
+ background: var(--bg-primary);
253
+ }
254
+
255
+ .file-action-btn.btn-delete:hover {
256
+ background: rgba(239, 68, 68, 0.2);
257
+ }
258
+
259
+ .file-action-btn.btn-rename:hover {
260
+ background: rgba(59, 130, 246, 0.2);
261
+ }
262
+
263
+ /* Folder items */
264
+ .file-tree-folder > .file-tree-entry {
265
+ font-weight: 500;
266
+ cursor: pointer;
267
+ }
268
+
269
+ .file-tree-folder > .file-tree-entry:hover {
270
+ background: var(--bg-tertiary);
271
+ }
272
+
273
+ /* Folder chevron indicator */
274
+ .file-tree-folder > .file-tree-entry .file-tree-icon {
275
+ position: relative;
276
+ }
277
+
278
+ .file-tree-folder > .file-tree-entry .file-tree-icon::before {
279
+ content: "";
280
+ display: inline-block;
281
+ width: 0;
282
+ height: 0;
283
+ border-left: 5px solid var(--text-secondary);
284
+ border-top: 4px solid transparent;
285
+ border-bottom: 4px solid transparent;
286
+ position: absolute;
287
+ left: -10px;
288
+ top: 50%;
289
+ transform: translateY(-50%);
290
+ transition: transform 0.15s ease;
291
+ }
292
+
293
+ .file-tree-folder.expanded > .file-tree-entry .file-tree-icon::before {
294
+ transform: translateY(-50%) rotate(90deg);
295
+ }
296
+
297
+ /* Folder badge (item count) */
298
+ .file-tree-badge.folder-badge {
299
+ background: var(--bg-primary);
300
+ color: var(--text-secondary);
301
+ font-size: 9px;
302
+ min-width: 16px;
303
+ text-align: center;
304
+ }
305
+
306
+ /* File tree children container */
307
+ .file-tree-children {
308
+ list-style: none;
309
+ margin: 0;
310
+ padding: 0;
311
+ display: none;
312
+ overflow: hidden;
313
+ transition: max-height 0.2s ease-out;
314
+ }
315
+
316
+ .file-tree-folder.expanded > .file-tree-children {
317
+ display: block;
318
+ }
319
+
320
+ /* Tree indentation guide lines */
321
+ .file-tree-folder > .file-tree-children {
322
+ position: relative;
323
+ }
324
+
325
+ .file-tree-folder > .file-tree-children::before {
326
+ content: "";
327
+ position: absolute;
328
+ left: 18px;
329
+ top: 0;
330
+ bottom: 8px;
331
+ width: 1px;
332
+ background: var(--border-color);
333
+ opacity: 0.5;
334
+ }
335
+
336
+ /* Empty state */
337
+ .file-tree-empty {
338
+ padding: 24px 16px;
339
+ text-align: center;
340
+ color: var(--text-secondary);
341
+ font-size: 11px;
342
+ line-height: 1.5;
343
+ }
344
+
345
+ .file-tree-empty p {
346
+ margin: 6px 0;
347
+ }
348
+
349
+ .file-tree-empty p:first-child {
350
+ font-size: 12px;
351
+ color: var(--text-primary);
352
+ opacity: 0.7;
353
+ }
354
+
355
+ /* Scrollbar styling */
356
+ .file-tree-container::-webkit-scrollbar {
357
+ width: 6px;
358
+ }
359
+
360
+ .file-tree-container::-webkit-scrollbar-track {
361
+ background: transparent;
362
+ }
363
+
364
+ .file-tree-container::-webkit-scrollbar-thumb {
365
+ background: var(--border-color);
366
+ border-radius: 3px;
367
+ }
368
+
369
+ .file-tree-container::-webkit-scrollbar-thumb:hover {
370
+ background: var(--text-secondary);
371
+ }
372
+
373
+ /* Resize handle */
374
+ .file-browser-resize {
375
+ width: 4px;
376
+ cursor: col-resize;
377
+ background: transparent;
378
+ position: absolute;
379
+ right: 0;
380
+ top: 0;
381
+ bottom: 0;
382
+ z-index: 10;
383
+ transition: background 0.2s;
384
+ }
385
+
386
+ .file-browser-resize:hover,
387
+ .file-browser-resize.resizing {
388
+ background: var(--accent-color);
389
+ }
390
+
391
+ /* File Browser Footer - Brand Info */
392
+ .file-browser-footer {
393
+ padding: 10px 12px;
394
+ border-top: 1px solid var(--border-color);
395
+ background: var(--bg-secondary);
396
+ }
397
+
398
+ .brand-link {
399
+ display: flex;
400
+ align-items: center;
401
+ gap: 8px;
402
+ text-decoration: none;
403
+ color: var(--text-secondary);
404
+ transition: all 0.15s;
405
+ padding: 4px;
406
+ border-radius: 4px;
407
+ margin: -4px;
408
+ }
409
+
410
+ .brand-link:hover {
411
+ background: var(--bg-tertiary);
412
+ color: var(--text-primary);
413
+ }
414
+
415
+ .brand-icon {
416
+ width: 28px;
417
+ height: 28px;
418
+ flex-shrink: 0;
419
+ opacity: 0.8;
420
+ }
421
+
422
+ .brand-link:hover .brand-icon {
423
+ opacity: 1;
424
+ }
425
+
426
+ .brand-info {
427
+ display: flex;
428
+ flex-direction: column;
429
+ gap: 1px;
430
+ overflow: hidden;
431
+ }
432
+
433
+ .brand-name {
434
+ font-size: 11px;
435
+ font-weight: 600;
436
+ color: var(--text-primary);
437
+ white-space: nowrap;
438
+ }
439
+
440
+ .brand-version {
441
+ font-size: 9px;
442
+ color: var(--text-secondary);
443
+ white-space: nowrap;
444
+ }
445
+
446
+ .brand-meta {
447
+ margin-top: 6px;
448
+ padding-top: 6px;
449
+ border-top: 1px solid var(--border-color);
450
+ }
451
+
452
+ .server-time {
453
+ font-size: 9px;
454
+ color: var(--text-tertiary);
455
+ font-family: monospace;
456
+ }
457
+
458
+ /* Hide footer when collapsed */
459
+ .file-browser-panel.collapsed .file-browser-footer {
460
+ display: none;
461
+ }
462
+ """
463
+
464
+ __all__ = ["STYLES_FILE_BROWSER"]
465
+
466
+ # EOF
@@ -0,0 +1,224 @@
1
+ #!/usr/bin/env python3
2
+ # -*- coding: utf-8 -*-
3
+ """Form elements CSS styles for the figure editor.
4
+
5
+ This module contains CSS for:
6
+ - Form rows and labels
7
+ - Input fields (number, text, checkbox, color, range)
8
+ - Override indicators for modified values
9
+ """
10
+
11
+ STYLES_FORMS = """
12
+ /* Form elements */
13
+ .subsection {
14
+ margin-bottom: 12px;
15
+ }
16
+
17
+ .subsection:last-child {
18
+ margin-bottom: 0;
19
+ }
20
+
21
+ .subsection h4 {
22
+ font-size: 12px;
23
+ font-weight: 600;
24
+ color: var(--text-secondary);
25
+ margin-bottom: 8px;
26
+ text-transform: uppercase;
27
+ letter-spacing: 0.5px;
28
+ }
29
+
30
+ .form-row {
31
+ display: flex;
32
+ align-items: center;
33
+ margin-bottom: 8px;
34
+ }
35
+
36
+ .form-row:last-child {
37
+ margin-bottom: 0;
38
+ }
39
+
40
+ .form-row label {
41
+ flex: 0 0 120px;
42
+ font-size: 13px;
43
+ color: var(--text-secondary);
44
+ }
45
+
46
+ .form-row input[type="number"],
47
+ .form-row input[type="text"],
48
+ .form-row select {
49
+ flex: 1;
50
+ padding: 6px 10px;
51
+ border: 1px solid var(--border-color);
52
+ border-radius: 4px;
53
+ background: var(--bg-primary);
54
+ color: var(--text-primary);
55
+ font-size: 13px;
56
+ min-width: 0; /* Allow shrinking below content size */
57
+ max-width: calc(100% - 130px); /* Leave space for label + margin */
58
+ }
59
+
60
+ .form-row input[type="number"]:focus,
61
+ .form-row input[type="text"]:focus,
62
+ .form-row select:focus {
63
+ outline: none;
64
+ border-color: var(--accent-color);
65
+ box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.2);
66
+ }
67
+
68
+ /* Override indicator for modified values */
69
+ .form-row.value-modified input,
70
+ .form-row.value-modified select {
71
+ border-color: #f59e0b;
72
+ background: rgba(245, 158, 11, 0.05);
73
+ }
74
+
75
+ .form-row.value-modified label::after {
76
+ content: '●';
77
+ color: #f59e0b;
78
+ margin-left: 4px;
79
+ font-weight: bold;
80
+ }
81
+
82
+ [data-theme="dark"] .form-row.value-modified input,
83
+ [data-theme="dark"] .form-row.value-modified select {
84
+ border-color: #f59e0b;
85
+ background: rgba(245, 158, 11, 0.1);
86
+ }
87
+
88
+ .form-row input[type="checkbox"] {
89
+ width: 18px;
90
+ height: 18px;
91
+ cursor: pointer;
92
+ }
93
+
94
+ .form-row input[type="color"] {
95
+ width: 50px;
96
+ height: 30px;
97
+ padding: 2px;
98
+ border: 1px solid var(--border-color);
99
+ border-radius: 4px;
100
+ cursor: pointer;
101
+ }
102
+
103
+ .form-row input[type="range"] {
104
+ flex: 1;
105
+ margin-right: 8px;
106
+ }
107
+
108
+ .form-row input[type="range"] + span {
109
+ min-width: 30px;
110
+ text-align: right;
111
+ font-size: 12px;
112
+ color: var(--text-secondary);
113
+ }
114
+
115
+ .form-grid {
116
+ display: grid;
117
+ grid-template-columns: 1fr 1fr;
118
+ gap: 8px;
119
+ }
120
+
121
+ .form-grid .form-row label {
122
+ flex: 0 0 60px;
123
+ }
124
+
125
+ /* Spine visibility grid - 2x2 layout */
126
+ .spine-visibility-grid {
127
+ display: grid;
128
+ grid-template-columns: 1fr 1fr;
129
+ gap: 4px 12px;
130
+ margin: 8px 0;
131
+ padding: 8px;
132
+ background: var(--bg-secondary);
133
+ border-radius: 6px;
134
+ }
135
+
136
+ .spine-visibility-grid .form-row {
137
+ margin-bottom: 0;
138
+ }
139
+
140
+ .spine-visibility-grid .form-row label {
141
+ flex: 0 0 80px;
142
+ font-size: 12px;
143
+ }
144
+
145
+ /* Caption textarea styling */
146
+ .caption-textarea {
147
+ flex: 1;
148
+ padding: 8px;
149
+ border: 1px solid var(--border-color);
150
+ border-radius: 4px;
151
+ background: var(--bg-primary);
152
+ color: var(--text-primary);
153
+ font-size: 12px;
154
+ font-family: inherit;
155
+ resize: vertical;
156
+ min-height: 40px;
157
+ }
158
+
159
+ .caption-textarea:focus {
160
+ outline: none;
161
+ border-color: var(--accent-color);
162
+ box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.1);
163
+ }
164
+
165
+ .caption-row {
166
+ align-items: flex-start !important;
167
+ }
168
+
169
+ .caption-row label {
170
+ padding-top: 8px;
171
+ }
172
+
173
+ .caption-preview {
174
+ font-size: 11px;
175
+ font-style: italic;
176
+ color: var(--text-secondary);
177
+ margin-top: 4px;
178
+ padding: 4px 8px;
179
+ background: var(--bg-secondary);
180
+ border-radius: 4px;
181
+ }
182
+
183
+ .caption-preview span {
184
+ color: var(--text-primary);
185
+ font-weight: 500;
186
+ }
187
+
188
+ /* Composed caption preview */
189
+ .composed-caption-preview {
190
+ margin-top: 12px;
191
+ padding: 10px;
192
+ background: var(--bg-secondary);
193
+ border: 1px solid var(--border-color);
194
+ border-radius: 6px;
195
+ }
196
+
197
+ .composed-caption-label {
198
+ font-size: 11px;
199
+ font-weight: 600;
200
+ color: var(--text-secondary);
201
+ margin-bottom: 6px;
202
+ text-transform: uppercase;
203
+ letter-spacing: 0.5px;
204
+ }
205
+
206
+ .composed-caption-text {
207
+ font-size: 12px;
208
+ line-height: 1.5;
209
+ color: var(--text-primary);
210
+ }
211
+
212
+ .composed-caption-text b {
213
+ font-weight: 600;
214
+ }
215
+
216
+ .composed-caption-text .panel-caption {
217
+ color: var(--text-secondary);
218
+ margin-left: 4px;
219
+ }
220
+ """
221
+
222
+ __all__ = ["STYLES_FORMS"]
223
+
224
+ # EOF