fontastic 0.1.7 → 1.0.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 (455) hide show
  1. package/.editorconfig +16 -16
  2. package/.github/FUNDING.yml +3 -12
  3. package/.github/ISSUE_TEMPLATE/bug_report.yml +41 -0
  4. package/.github/ISSUE_TEMPLATE/feature_request.yml +29 -0
  5. package/.github/dependabot.yml +6 -6
  6. package/.github/pull_request_template.md +21 -21
  7. package/.github/workflows/claude-code-review.yml +45 -0
  8. package/.github/workflows/claude.yml +46 -0
  9. package/.github/workflows/macos.yml +77 -58
  10. package/.github/workflows/release.yml +165 -0
  11. package/.github/workflows/ubuntu.yml +87 -70
  12. package/.github/workflows/windows.yml +81 -64
  13. package/.husky/pre-commit +1 -0
  14. package/.lintstagedrc.json +6 -0
  15. package/.node-version +1 -1
  16. package/.postcssrc.json +5 -0
  17. package/.prettierignore +8 -0
  18. package/.prettierrc +18 -0
  19. package/.vscode/launch.json +42 -45
  20. package/.vscode/tasks.json +48 -48
  21. package/CODE_OF_CONDUCT.md +128 -45
  22. package/HOW_TO.md +39 -0
  23. package/LICENSE.md +7 -0
  24. package/README.md +103 -111
  25. package/angular.json +166 -202
  26. package/app/Application.js +39 -39
  27. package/app/Application.ts +38 -38
  28. package/app/config/alert.ts +31 -31
  29. package/app/config/database.js +194 -202
  30. package/app/config/database.ts +194 -202
  31. package/app/config/index.js +19 -19
  32. package/app/config/index.ts +2 -2
  33. package/app/config/mimes.js +48 -48
  34. package/app/config/mimes.ts +53 -53
  35. package/app/config/system.js +578 -496
  36. package/app/config/system.ts +580 -498
  37. package/app/config/themes.ts +38 -38
  38. package/app/core/AppLogger.js +30 -30
  39. package/app/core/AppLogger.ts +37 -37
  40. package/app/core/ConfigManager.js +129 -113
  41. package/app/core/ConfigManager.ts +150 -137
  42. package/app/core/ConnectionManager.js +93 -82
  43. package/app/core/ConnectionManager.ts +107 -95
  44. package/app/core/FontCatalog.js +32 -50
  45. package/app/core/FontCatalog.ts +20 -42
  46. package/app/core/FontFinder.js +72 -85
  47. package/app/core/FontFinder.ts +75 -96
  48. package/app/core/FontManager.js +128 -164
  49. package/app/core/FontManager.ts +136 -172
  50. package/app/core/FontObject.js +53 -53
  51. package/app/core/FontObject.ts +62 -62
  52. package/app/core/MessageHandler.js +270 -271
  53. package/app/core/MessageHandler.ts +330 -337
  54. package/app/core/SystemManager.js +132 -139
  55. package/app/core/SystemManager.ts +160 -171
  56. package/app/core/menu/Example.ts +279 -279
  57. package/app/core/menu/MenuBuilder.js +43 -44
  58. package/app/core/menu/MenuBuilder.ts +51 -53
  59. package/app/core/menu/templates/DarwinTemplate.js +124 -126
  60. package/app/core/menu/templates/DarwinTemplate.ts +144 -142
  61. package/app/core/menu/templates/SystemTemplate.js +121 -123
  62. package/app/core/menu/templates/SystemTemplate.ts +136 -139
  63. package/app/database/entity/Collection.schema.js +98 -98
  64. package/app/database/entity/Collection.schema.ts +68 -68
  65. package/app/database/entity/Logger.schema.js +49 -49
  66. package/app/database/entity/Logger.schema.ts +26 -26
  67. package/app/database/entity/Store.schema.js +159 -164
  68. package/app/database/entity/Store.schema.ts +110 -116
  69. package/app/database/entity/index.js +19 -19
  70. package/app/database/entity/index.ts +2 -2
  71. package/app/database/repository/Collection.repository.js +277 -180
  72. package/app/database/repository/Collection.repository.ts +291 -190
  73. package/app/database/repository/Logger.repository.js +24 -24
  74. package/app/database/repository/Logger.repository.ts +10 -10
  75. package/app/database/repository/Store.repository.js +324 -327
  76. package/app/database/repository/Store.repository.ts +349 -358
  77. package/app/database/repository/User.repository.js +11 -11
  78. package/app/database/repository/User.repository.ts +8 -8
  79. package/app/database/repository/index.js +19 -19
  80. package/app/database/repository/index.ts +2 -2
  81. package/app/enums/ChannelType.js +62 -61
  82. package/app/enums/ChannelType.ts +67 -65
  83. package/app/enums/StorageType.js +19 -18
  84. package/app/enums/{storageType.ts → StorageType.ts} +15 -14
  85. package/app/enums/index.js +18 -18
  86. package/app/enums/index.ts +2 -2
  87. package/app/helpers/command.js +27 -27
  88. package/app/helpers/command.ts +19 -19
  89. package/app/helpers/random.js +15 -15
  90. package/app/helpers/random.ts +12 -12
  91. package/app/main.js +97 -81
  92. package/app/main.ts +114 -94
  93. package/app/package-lock.json +2240 -2649
  94. package/app/package.json +23 -35
  95. package/app/types/AppAlert.js +2 -2
  96. package/app/types/AppAlert.ts +8 -8
  97. package/app/types/AuthUser.js +6 -6
  98. package/app/types/AuthUser.ts +5 -5
  99. package/app/types/Breadcrumb.js +2 -2
  100. package/app/types/Breadcrumb.ts +4 -4
  101. package/app/types/FontMetrics.ts +7 -0
  102. package/app/types/ImportOptions.js +6 -6
  103. package/app/types/ImportOptions.ts +3 -3
  104. package/app/types/QueryOptions.js +2 -2
  105. package/app/types/QueryOptions.ts +12 -12
  106. package/app/types/SystemConfig.js +2 -2
  107. package/app/types/SystemConfig.ts +127 -132
  108. package/app/types/SystemStats.js +2 -2
  109. package/app/types/SystemStats.ts +6 -7
  110. package/app/types/SystemTheme.js +2 -2
  111. package/app/types/SystemTheme.ts +5 -5
  112. package/app/types/index.js +24 -24
  113. package/app/types/index.ts +9 -8
  114. package/commitlint.config.mjs +3 -0
  115. package/e2e/main.spec.ts +57 -59
  116. package/e2e/playwright.config.ts +20 -19
  117. package/e2e/tsconfig.e2e.json +13 -13
  118. package/electron-builder.json +34 -71
  119. package/eslint.config.mjs +111 -0
  120. package/package.json +122 -123
  121. package/src/app/app.component.html +1 -2
  122. package/src/app/app.component.spec.ts +21 -0
  123. package/src/app/app.component.ts +40 -37
  124. package/src/app/core/core.module.ts +8 -11
  125. package/src/app/core/services/database/database.service.ts +410 -286
  126. package/src/app/core/services/electron/electron.service.spec.ts +12 -12
  127. package/src/app/core/services/electron/electron.service.ts +62 -62
  128. package/src/app/core/services/index.ts +5 -14
  129. package/src/app/core/services/message/message.service.ts +291 -289
  130. package/src/app/core/services/news/news.service.ts +52 -94
  131. package/src/app/core/services/presentation/presentation.service.ts +253 -341
  132. package/src/app/home/home.component.html +7 -0
  133. package/src/app/home/home.component.spec.ts +31 -0
  134. package/src/app/home/home.component.ts +15 -0
  135. package/src/app/layout/aside/aside.component.html +35 -9
  136. package/src/app/layout/aside/aside.component.ts +60 -26
  137. package/src/app/layout/footer/footer.component.html +5 -11
  138. package/src/app/layout/footer/footer.component.ts +13 -32
  139. package/src/app/layout/header/header.component.html +118 -35
  140. package/src/app/layout/header/header.component.ts +52 -229
  141. package/src/app/layout/layout.component.html +32 -14
  142. package/src/app/layout/layout.component.ts +19 -23
  143. package/src/app/layout/main/main.component.html +46 -0
  144. package/src/app/layout/main/main.component.ts +20 -0
  145. package/src/app/layout/navigation/library/library.component.ts +51 -0
  146. package/src/app/layout/navigation/navigation.component.html +126 -142
  147. package/src/app/layout/navigation/navigation.component.ts +372 -302
  148. package/src/app/layout/navigation/stats/stats.component.ts +56 -0
  149. package/src/app/settings/ai-keys/ai-keys.component.html +56 -0
  150. package/src/app/settings/ai-keys/ai-keys.component.ts +44 -0
  151. package/src/app/settings/danger-zone/danger-zone.component.html +22 -0
  152. package/src/app/settings/danger-zone/danger-zone.component.ts +37 -0
  153. package/src/app/settings/logs/logs.component.html +41 -0
  154. package/src/app/settings/logs/logs.component.ts +43 -0
  155. package/src/app/settings/news-api/news-api.component.html +40 -0
  156. package/src/app/settings/news-api/news-api.component.ts +57 -0
  157. package/src/app/settings/pages/general/general.component.html +7 -0
  158. package/src/app/settings/pages/general/general.component.ts +20 -0
  159. package/src/app/settings/pages/logs/logs.component.html +1 -0
  160. package/src/app/settings/pages/logs/logs.component.ts +10 -0
  161. package/src/app/settings/pages/system/system.component.html +1 -0
  162. package/src/app/settings/pages/system/system.component.ts +10 -0
  163. package/src/app/settings/quick-actions/quick-actions.component.html +49 -0
  164. package/src/app/settings/quick-actions/quick-actions.component.ts +40 -0
  165. package/src/app/settings/settings.component.html +47 -0
  166. package/src/app/settings/settings.component.ts +10 -0
  167. package/src/app/settings/system-info/system-info.component.html +21 -0
  168. package/src/app/settings/system-info/system-info.component.ts +42 -0
  169. package/src/app/settings/theme/theme.component.html +15 -0
  170. package/src/app/settings/theme/theme.component.ts +22 -0
  171. package/src/app/shared/components/collapsible-panel/collapsible-panel.component.ts +43 -0
  172. package/src/app/shared/components/context-menu/context-menu.component.ts +67 -0
  173. package/src/app/shared/components/datagrid/datagrid.component.html +96 -0
  174. package/src/app/shared/components/datagrid/datagrid.component.ts +49 -0
  175. package/src/app/shared/components/index.ts +11 -17
  176. package/src/app/shared/components/inspector/inspector.component.html +140 -0
  177. package/src/app/shared/components/inspector/inspector.component.ts +41 -0
  178. package/src/app/shared/components/page-not-found/page-not-found.component.html +1 -3
  179. package/src/app/shared/components/page-not-found/page-not-found.component.spec.ts +22 -0
  180. package/src/app/shared/components/page-not-found/page-not-found.component.ts +14 -12
  181. package/src/app/shared/components/panel/panel.component.html +5 -0
  182. package/src/app/shared/components/panel/panel.component.ts +8 -0
  183. package/src/app/shared/components/preview/preview.component.html +36 -0
  184. package/src/app/shared/components/preview/preview.component.ts +68 -0
  185. package/src/app/shared/components/prompt-dialog/prompt-dialog.component.html +36 -0
  186. package/src/app/shared/components/prompt-dialog/prompt-dialog.component.ts +39 -0
  187. package/src/app/shared/components/search/search.component.html +329 -54
  188. package/src/app/shared/components/search/search.component.ts +221 -77
  189. package/src/app/shared/components/spinner/spinner.component.ts +10 -26
  190. package/src/app/shared/components/toolbar/toolbar.component.html +207 -0
  191. package/src/app/shared/components/toolbar/toolbar.component.ts +99 -0
  192. package/src/app/shared/components/waterfall/waterfall.component.html +119 -0
  193. package/src/app/shared/components/waterfall/waterfall.component.ts +119 -0
  194. package/src/app/shared/directives/autofocus/autofocus.directive.ts +14 -0
  195. package/src/app/shared/directives/index.ts +2 -2
  196. package/src/app/shared/directives/webview/webview.directive.spec.ts +8 -0
  197. package/src/app/shared/directives/webview/webview.directive.ts +9 -8
  198. package/src/app/shared/shared.module.ts +13 -94
  199. package/src/assets/background.jpg +0 -0
  200. package/src/assets/fonts/md/MaterialIcons-Regular.woff2 +0 -0
  201. package/src/assets/fonts/md/MaterialSymbolsOutlined.woff2 +0 -0
  202. package/src/assets/i18n/en.json +12 -12
  203. package/src/assets/icons/electron.bmp +0 -0
  204. package/src/assets/icons/favicon.256x256.png +0 -0
  205. package/src/assets/icons/favicon.512x512.png +0 -0
  206. package/src/assets/icons/favicon.icns +0 -0
  207. package/src/assets/icons/favicon.ico +0 -0
  208. package/src/assets/icons/favicon.png +0 -0
  209. package/src/environments/environment.dev.ts +4 -4
  210. package/src/environments/environment.prod.ts +4 -4
  211. package/src/environments/environment.ts +4 -4
  212. package/src/favicon.ico +0 -0
  213. package/src/index.html +19 -13
  214. package/src/main.ts +65 -15
  215. package/src/styles/base/reset.css +41 -0
  216. package/src/styles/base/variables.css +356 -0
  217. package/src/styles/components/buttons.css +108 -0
  218. package/src/styles/components/cards.css +60 -0
  219. package/src/styles/components/forms.css +70 -0
  220. package/src/styles/components/navigation.css +24 -0
  221. package/src/styles/components/scrollbox.css +50 -0
  222. package/src/styles/components/spinner.css +7 -0
  223. package/src/styles/components/splash.css +47 -0
  224. package/src/styles/components/toolbar.css +92 -0
  225. package/src/styles/fonts/md.css +39 -0
  226. package/src/styles/themes/dashboard.scss +293 -294
  227. package/src/styles/themes/euphoria.scss +284 -283
  228. package/src/styles/themes/mellow.scss +281 -280
  229. package/src/styles/themes/midnight.scss +284 -283
  230. package/src/styles/themes/passion.scss +281 -280
  231. package/src/styles/themes/swiss.scss +284 -283
  232. package/src/styles.css +17 -0
  233. package/src/tsconfig.app.json +11 -20
  234. package/src/tsconfig.spec.json +10 -23
  235. package/src/typings.d.ts +9 -9
  236. package/src/vitest.d.ts +1 -0
  237. package/tsconfig.json +38 -44
  238. package/tsconfig.serve.json +27 -27
  239. package/.eslintrc.json +0 -54
  240. package/.github/ISSUE_TEMPLATE/bug_report.md +0 -29
  241. package/.github/ISSUE_TEMPLATE/feature_request.md +0 -20
  242. package/.github/stale.yml +0 -17
  243. package/CONTRIBUTING.md +0 -72
  244. package/LICENSE +0 -21
  245. package/angular.webpack.js +0 -35
  246. package/app/core/FontInstaller.js +0 -67
  247. package/app/core/FontInstaller.ts +0 -63
  248. package/docs/logo.png +0 -0
  249. package/docs/screenshots/readme.md +0 -7
  250. package/docs/screenshots/screen-grab1.png +0 -0
  251. package/docs/screenshots/screen-grab2.png +0 -0
  252. package/docs/screenshots/screen-grab3.png +0 -0
  253. package/src/app/app-routing.module.ts +0 -15
  254. package/src/app/app.component.scss +0 -0
  255. package/src/app/app.component.spec.ts.dist +0 -33
  256. package/src/app/app.module.ts +0 -63
  257. package/src/app/core/model/AuthUserModel.ts +0 -7
  258. package/src/app/core/model/CustomThemeModel.ts +0 -7
  259. package/src/app/core/model/DbConnectionModel.ts +0 -16
  260. package/src/app/core/model/ImportOptionsModel.ts +0 -5
  261. package/src/app/core/model/LatestNewsModel.ts +0 -7
  262. package/src/app/core/model/SearchFormModel.ts +0 -10
  263. package/src/app/core/model/index.ts +0 -6
  264. package/src/app/core/services/alert/alert.service.spec.ts +0 -22
  265. package/src/app/core/services/alert/alert.service.ts +0 -71
  266. package/src/app/core/services/auth/auth.service.ts +0 -30
  267. package/src/app/core/services/boot/boot.service.ts +0 -33
  268. package/src/app/core/services/breadcrumb/breadcrumb.service.spec.ts +0 -22
  269. package/src/app/core/services/breadcrumb/breadcrumb.service.ts +0 -30
  270. package/src/app/core/services/config/config.service.ts +0 -63
  271. package/src/app/core/services/font/font.service.ts +0 -79
  272. package/src/app/core/services/gravatar/gravatar.service.spec.ts +0 -16
  273. package/src/app/core/services/gravatar/gravatar.service.ts +0 -18
  274. package/src/app/core/services/modal/modal.service.spec.ts +0 -16
  275. package/src/app/core/services/modal/modal.service.ts +0 -34
  276. package/src/app/core/services/utils/utils.service.spec.ts +0 -12
  277. package/src/app/core/services/utils/utils.service.ts +0 -144
  278. package/src/app/layout/aside/aside.component.scss +0 -1
  279. package/src/app/layout/footer/footer.component.scss +0 -27
  280. package/src/app/layout/header/header.component.scss +0 -60
  281. package/src/app/layout/layout.component.scss +0 -119
  282. package/src/app/layout/layout.module.ts +0 -32
  283. package/src/app/layout/layout.service.ts +0 -13
  284. package/src/app/layout/navigation/navigation.component.scss +0 -0
  285. package/src/app/pages/main/grid/grid.component.html +0 -183
  286. package/src/app/pages/main/grid/grid.component.scss +0 -3
  287. package/src/app/pages/main/grid/grid.component.ts +0 -98
  288. package/src/app/pages/main/inspect/inspect.component.html +0 -7
  289. package/src/app/pages/main/inspect/inspect.component.scss +0 -3
  290. package/src/app/pages/main/inspect/inspect.component.ts +0 -66
  291. package/src/app/pages/main/main-routing.module.ts +0 -30
  292. package/src/app/pages/main/main.component.html +0 -6
  293. package/src/app/pages/main/main.component.scss +0 -191
  294. package/src/app/pages/main/main.component.ts +0 -35
  295. package/src/app/pages/main/main.module.ts +0 -28
  296. package/src/app/pages/main/preview/preview.component.html +0 -46
  297. package/src/app/pages/main/preview/preview.component.scss +0 -0
  298. package/src/app/pages/main/preview/preview.component.ts +0 -239
  299. package/src/app/pages/main/toolbar/toolbar.component.html +0 -78
  300. package/src/app/pages/main/toolbar/toolbar.component.scss +0 -3
  301. package/src/app/pages/main/toolbar/toolbar.component.ts +0 -132
  302. package/src/app/shared/components/alert/alert.component.html +0 -9
  303. package/src/app/shared/components/alert/alert.component.scss +0 -0
  304. package/src/app/shared/components/alert/alert.component.ts +0 -37
  305. package/src/app/shared/components/breadcrumbs/breadcrumbs.component.html +0 -14
  306. package/src/app/shared/components/breadcrumbs/breadcrumbs.component.scss +0 -0
  307. package/src/app/shared/components/breadcrumbs/breadcrumbs.component.ts +0 -36
  308. package/src/app/shared/components/button/button.component.html +0 -3
  309. package/src/app/shared/components/button/button.component.scss +0 -2
  310. package/src/app/shared/components/button/button.component.ts +0 -22
  311. package/src/app/shared/components/collection/create-collection/create-collection.component.html +0 -41
  312. package/src/app/shared/components/collection/create-collection/create-collection.component.scss +0 -0
  313. package/src/app/shared/components/collection/create-collection/create-collection.component.ts +0 -68
  314. package/src/app/shared/components/collection/form-collection/form-collection.component.html +0 -1
  315. package/src/app/shared/components/collection/form-collection/form-collection.component.scss +0 -0
  316. package/src/app/shared/components/collection/form-collection/form-collection.component.ts +0 -15
  317. package/src/app/shared/components/collection/update-collection/update-collection.component.html +0 -40
  318. package/src/app/shared/components/collection/update-collection/update-collection.component.scss +0 -0
  319. package/src/app/shared/components/collection/update-collection/update-collection.component.ts +0 -71
  320. package/src/app/shared/components/glyph-list/glyph-list.component.html +0 -40
  321. package/src/app/shared/components/glyph-list/glyph-list.component.scss +0 -1
  322. package/src/app/shared/components/glyph-list/glyph-list.component.ts +0 -165
  323. package/src/app/shared/components/glyph-view/glyph-view.component.html +0 -23
  324. package/src/app/shared/components/glyph-view/glyph-view.component.scss +0 -0
  325. package/src/app/shared/components/glyph-view/glyph-view.component.ts +0 -228
  326. package/src/app/shared/components/loading/loading.component.html +0 -1
  327. package/src/app/shared/components/loading/loading.component.scss +0 -0
  328. package/src/app/shared/components/loading/loading.component.ts +0 -26
  329. package/src/app/shared/components/modal/modal.component.html +0 -31
  330. package/src/app/shared/components/modal/modal.component.scss +0 -0
  331. package/src/app/shared/components/modal/modal.component.ts +0 -51
  332. package/src/app/shared/components/page-not-found/page-not-found.component.scss +0 -0
  333. package/src/app/shared/components/paginator/paginator.component.html +0 -21
  334. package/src/app/shared/components/paginator/paginator.component.scss +0 -3
  335. package/src/app/shared/components/paginator/paginator.component.ts +0 -133
  336. package/src/app/shared/components/pairing/pairing.component.html +0 -20
  337. package/src/app/shared/components/pairing/pairing.component.scss +0 -0
  338. package/src/app/shared/components/pairing/pairing.component.ts +0 -33
  339. package/src/app/shared/components/search/search.component.scss +0 -10
  340. package/src/app/shared/components/settings/database/database.component.html +0 -151
  341. package/src/app/shared/components/settings/database/database.component.scss +0 -0
  342. package/src/app/shared/components/settings/database/database.component.ts +0 -145
  343. package/src/app/shared/components/settings/general/general.component.html +0 -170
  344. package/src/app/shared/components/settings/general/general.component.scss +0 -0
  345. package/src/app/shared/components/settings/general/general.component.ts +0 -150
  346. package/src/app/shared/components/settings/logs/logs.component.html +0 -44
  347. package/src/app/shared/components/settings/logs/logs.component.scss +0 -0
  348. package/src/app/shared/components/settings/logs/logs.component.ts +0 -37
  349. package/src/app/shared/components/settings/news/news.component.html +0 -41
  350. package/src/app/shared/components/settings/news/news.component.scss +0 -0
  351. package/src/app/shared/components/settings/news/news.component.ts +0 -52
  352. package/src/app/shared/components/settings/settings.component.html +0 -46
  353. package/src/app/shared/components/settings/settings.component.scss +0 -0
  354. package/src/app/shared/components/settings/settings.component.ts +0 -23
  355. package/src/app/shared/components/settings/system/system.component.html +0 -30
  356. package/src/app/shared/components/settings/system/system.component.scss +0 -0
  357. package/src/app/shared/components/settings/system/system.component.ts +0 -43
  358. package/src/app/shared/components/settings/theme/theme.component.html +0 -22
  359. package/src/app/shared/components/settings/theme/theme.component.scss +0 -0
  360. package/src/app/shared/components/settings/theme/theme.component.ts +0 -50
  361. package/src/app/shared/components/spinner/spinner.component.html +0 -1
  362. package/src/app/shared/components/spinner/spinner.component.scss +0 -0
  363. package/src/app/shared/components/splash-screen/splash-screen.component.html +0 -5
  364. package/src/app/shared/components/splash-screen/splash-screen.component.scss +0 -31
  365. package/src/app/shared/components/splash-screen/splash-screen.component.ts +0 -17
  366. package/src/app/shared/components/store/store.component.html +0 -22
  367. package/src/app/shared/components/store/store.component.scss +0 -10
  368. package/src/app/shared/components/store/store.component.ts +0 -58
  369. package/src/app/shared/components/tables/tables.component.html +0 -47
  370. package/src/app/shared/components/tables/tables.component.scss +0 -10
  371. package/src/app/shared/components/tables/tables.component.ts +0 -81
  372. package/src/app/shared/components/typescale/typescale.component.html +0 -53
  373. package/src/app/shared/components/typescale/typescale.component.scss +0 -0
  374. package/src/app/shared/components/typescale/typescale.component.ts +0 -168
  375. package/src/app/shared/directives/gravatar/gravatar.directive.ts +0 -29
  376. package/src/app/shared/pipes/installable.pipe.ts +0 -10
  377. package/src/app/shared/pipes/prettybytes.pipe.ts +0 -10
  378. package/src/app/shared/pipes/safehtml.pipe.ts +0 -10
  379. package/src/assets/fonts/fa/fa-brands-400.eot +0 -0
  380. package/src/assets/fonts/fa/fa-brands-400.svg +0 -3535
  381. package/src/assets/fonts/fa/fa-brands-400.ttf +0 -0
  382. package/src/assets/fonts/fa/fa-brands-400.woff +0 -0
  383. package/src/assets/fonts/fa/fa-brands-400.woff2 +0 -0
  384. package/src/assets/fonts/fa/fa-regular-400.eot +0 -0
  385. package/src/assets/fonts/fa/fa-regular-400.svg +0 -803
  386. package/src/assets/fonts/fa/fa-regular-400.ttf +0 -0
  387. package/src/assets/fonts/fa/fa-regular-400.woff +0 -0
  388. package/src/assets/fonts/fa/fa-regular-400.woff2 +0 -0
  389. package/src/assets/fonts/fa/fa-solid-900.eot +0 -0
  390. package/src/assets/fonts/fa/fa-solid-900.svg +0 -4700
  391. package/src/assets/fonts/fa/fa-solid-900.ttf +0 -0
  392. package/src/assets/fonts/fa/fa-solid-900.woff +0 -0
  393. package/src/assets/fonts/fa/fa-solid-900.woff2 +0 -0
  394. package/src/assets/fonts/md/MaterialIcons-Regular.eot +0 -0
  395. package/src/assets/fonts/md/MaterialIcons-Regular.ijmap +0 -1
  396. package/src/assets/fonts/md/MaterialIcons-Regular.svg +0 -2373
  397. package/src/assets/fonts/md/MaterialIcons-Regular.ttf +0 -0
  398. package/src/assets/fonts/md/MaterialIcons-Regular.woff +0 -0
  399. package/src/assets/fonts/md/README.md +0 -9
  400. package/src/assets/fonts/md/codepoints +0 -932
  401. package/src/assets/fonts/md/material-icons.css +0 -36
  402. package/src/assets/fonts/octicon/octicon.eot +0 -0
  403. package/src/assets/fonts/octicon/octicon.svg +0 -378
  404. package/src/assets/fonts/octicon/octicon.ttf +0 -0
  405. package/src/assets/fonts/octicon/octicon.woff +0 -0
  406. package/src/assets/fonts/octicon/octicon.woff2 +0 -0
  407. package/src/assets/fonts/roboto/Roboto-Bold-webfont.eot +0 -0
  408. package/src/assets/fonts/roboto/Roboto-Bold-webfont.svg +0 -607
  409. package/src/assets/fonts/roboto/Roboto-Bold-webfont.ttf +0 -0
  410. package/src/assets/fonts/roboto/Roboto-Bold-webfont.woff +0 -0
  411. package/src/assets/fonts/roboto/Roboto-Medium-webfont.eot +0 -0
  412. package/src/assets/fonts/roboto/Roboto-Medium-webfont.svg +0 -607
  413. package/src/assets/fonts/roboto/Roboto-Medium-webfont.ttf +0 -0
  414. package/src/assets/fonts/roboto/Roboto-Medium-webfont.woff +0 -0
  415. package/src/assets/fonts/roboto/Roboto-Regular-webfont.eot +0 -0
  416. package/src/assets/fonts/roboto/Roboto-Regular-webfont.svg +0 -635
  417. package/src/assets/fonts/roboto/Roboto-Regular-webfont.ttf +0 -0
  418. package/src/assets/fonts/roboto/Roboto-Regular-webfont.woff +0 -0
  419. package/src/assets/icons/android-chrome-192x192.png +0 -0
  420. package/src/assets/icons/android-chrome-512x512.png +0 -0
  421. package/src/assets/icons/apple-touch-icon.png +0 -0
  422. package/src/assets/icons/favicon-16x16.png +0 -0
  423. package/src/assets/icons/favicon-32x32.png +0 -0
  424. package/src/assets/icons/site.webmanifest +0 -1
  425. package/src/assets/images/electron.bmp +0 -0
  426. package/src/bin/activator +0 -0
  427. package/src/bin/activator.exe +0 -0
  428. package/src/environments/environment.web.prod.ts +0 -4
  429. package/src/environments/environment.web.ts +0 -4
  430. package/src/karma.conf.js +0 -50
  431. package/src/polyfills-test.ts +0 -1
  432. package/src/polyfills.ts +0 -53
  433. package/src/styles/base/loading.scss +0 -87
  434. package/src/styles/base/reset.scss +0 -408
  435. package/src/styles/components/alert.scss +0 -54
  436. package/src/styles/components/buttons.scss +0 -93
  437. package/src/styles/components/forms.scss +0 -96
  438. package/src/styles/components/inputs.scss +0 -113
  439. package/src/styles/components/modal.scss +0 -52
  440. package/src/styles/components/paginator.scss +0 -108
  441. package/src/styles/components/scrollbox.scss +0 -71
  442. package/src/styles/components/spinner.scss +0 -11
  443. package/src/styles/components/tables.scss +0 -42
  444. package/src/styles/components/tabs.scss +0 -44
  445. package/src/styles/components/toolbar.scss +0 -130
  446. package/src/styles/fonts/md.scss +0 -54
  447. package/src/styles/fonts/octicons.scss +0 -1351
  448. package/src/styles/fonts/roboto.scss +0 -32
  449. package/src/styles/tools/_functions.scss +0 -5
  450. package/src/styles/tools/_mixins.scss +0 -159
  451. package/src/styles/tools/_placeholders.scss +0 -17
  452. package/src/styles/tools/_variables.scss +0 -67
  453. package/src/styles.scss +0 -37
  454. package/src/test.ts +0 -17
  455. package/tailwind.config.js +0 -67
@@ -0,0 +1,356 @@
1
+ @theme {
2
+ --font-sans: "Inter Variable", ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
3
+ --font-family-mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, "Liberation Mono", monospace;
4
+ }
5
+
6
+ /* ---------------------------------------------------------------------------
7
+ Light mode — warm stone neutrals
8
+ --------------------------------------------------------------------------- */
9
+
10
+ .light {
11
+ --surface-0: #FBFBF9;
12
+ --surface-1: #FFFFFF;
13
+ --surface-2: #F3F2EF;
14
+ --surface-3: #EAE8E4;
15
+
16
+ --border-subtle: #E9E7E2;
17
+ --border-default: #D8D5CE;
18
+
19
+ --text-primary: #1C1917;
20
+ --text-secondary: #57534E;
21
+ --text-muted: #A8A29E;
22
+
23
+ --accent: #92400E;
24
+ --accent-hover: #78350F;
25
+ --accent-text: #FFFFFF;
26
+ --accent-muted: rgba(146, 64, 14, 0.08);
27
+
28
+ --card-bg: linear-gradient(135deg, var(--surface-1) 0%, var(--surface-2) 100%);
29
+
30
+ --selected-bg: rgba(99, 102, 241, 0.06);
31
+ --selected-border: rgba(99, 102, 241, 0.25);
32
+ --hover-bg: rgba(0, 0, 0, 0.03);
33
+
34
+ --context-bg: #FFFFFF;
35
+ --context-border: #E5E3DE;
36
+ --context-shadow: 0 4px 24px rgba(0, 0, 0, 0.08), 0 1px 4px rgba(0, 0, 0, 0.04);
37
+
38
+ --input-bg: #FFFFFF;
39
+ --input-border: #D2CFC8;
40
+ --input-focus-border: #6366F1;
41
+
42
+ --slider-track: #E5E3DE;
43
+ --slider-thumb: #868076;
44
+ --slider-thumb-hover: #635E55;
45
+
46
+ --scrollbar-thumb-color: #D2CFC8;
47
+ --scrollbar-thumb-hover-color: #B0ABA3;
48
+ }
49
+
50
+ /* ---------------------------------------------------------------------------
51
+ Dark mode — deep cool zinc
52
+ --------------------------------------------------------------------------- */
53
+
54
+ .dark {
55
+ --surface-0: #0E0E11;
56
+ --surface-1: #161619;
57
+ --surface-2: #1E1E23;
58
+ --surface-3: #28282F;
59
+
60
+ --border-subtle: #232329;
61
+ --border-default: #2E2E36;
62
+
63
+ --text-primary: #EDEDF0;
64
+ --text-secondary: #A3A3B0;
65
+ --text-muted: #55555F;
66
+
67
+ --accent: #D97706;
68
+ --accent-hover: #B45309;
69
+ --accent-text: #FFFFFF;
70
+ --accent-muted: rgba(217, 119, 6, 0.10);
71
+
72
+ --card-bg: linear-gradient(135deg, var(--surface-1) 0%, var(--surface-2) 100%);
73
+
74
+ --selected-bg: rgba(129, 140, 248, 0.08);
75
+ --selected-border: rgba(129, 140, 248, 0.30);
76
+ --hover-bg: rgba(255, 255, 255, 0.04);
77
+
78
+ --context-bg: #1C1C21;
79
+ --context-border: #2E2E36;
80
+ --context-shadow: 0 4px 24px rgba(0, 0, 0, 0.32), 0 1px 4px rgba(0, 0, 0, 0.16);
81
+
82
+ --input-bg: #1C1C21;
83
+ --input-border: #3B3B44;
84
+ --input-focus-border: #818CF8;
85
+
86
+ --slider-track: #27272E;
87
+ --slider-thumb: #55555F;
88
+ --slider-thumb-hover: #7C7C88;
89
+
90
+ --scrollbar-thumb-color: #27272E;
91
+ --scrollbar-thumb-hover-color: #3B3B44;
92
+ }
93
+
94
+ /* ---------------------------------------------------------------------------
95
+ Dashboard — dark blue-green
96
+ --------------------------------------------------------------------------- */
97
+
98
+ .dashboard {
99
+ --surface-0: #14202b;
100
+ --surface-1: #1a2631;
101
+ --surface-2: #1e2d3a;
102
+ --surface-3: #2d3e50;
103
+
104
+ --border-subtle: #0e161f;
105
+ --border-default: #2d3e50;
106
+
107
+ --text-primary: #FFFFFF;
108
+ --text-secondary: #637785;
109
+ --text-muted: #3d5060;
110
+
111
+ --accent: #00a0be;
112
+ --accent-hover: #008da6;
113
+ --accent-text: #FFFFFF;
114
+ --accent-muted: rgba(0, 160, 190, 0.10);
115
+
116
+ --card-bg: linear-gradient(135deg, var(--surface-1) 0%, var(--surface-2) 100%);
117
+
118
+ --selected-bg: rgba(0, 160, 190, 0.10);
119
+ --selected-border: rgba(0, 160, 190, 0.30);
120
+ --hover-bg: rgba(255, 255, 255, 0.04);
121
+
122
+ --context-bg: #1a2631;
123
+ --context-border: #2d3e50;
124
+ --context-shadow: 0 4px 24px rgba(0, 0, 0, 0.32), 0 1px 4px rgba(0, 0, 0, 0.16);
125
+
126
+ --input-bg: #1a2631;
127
+ --input-border: #2d3e50;
128
+ --input-focus-border: #00a0be;
129
+
130
+ --slider-track: #0e161f;
131
+ --slider-thumb: #637785;
132
+ --slider-thumb-hover: #7a8f9e;
133
+
134
+ --scrollbar-thumb-color: #2d3e50;
135
+ --scrollbar-thumb-hover-color: #3d5060;
136
+ }
137
+
138
+ /* ---------------------------------------------------------------------------
139
+ Euphoria — dark purple with gold accents
140
+ --------------------------------------------------------------------------- */
141
+
142
+ .euphoria {
143
+ --surface-0: #23121c;
144
+ --surface-1: #2a1623;
145
+ --surface-2: #3a1f32;
146
+ --surface-3: #4a2942;
147
+
148
+ --border-subtle: #3a1f32;
149
+ --border-default: #4a2942;
150
+
151
+ --text-primary: #deb431;
152
+ --text-secondary: #943577;
153
+ --text-muted: #5a2a48;
154
+
155
+ --accent: #c10156;
156
+ --accent-hover: #a30148;
157
+ --accent-text: #FFFFFF;
158
+ --accent-muted: rgba(193, 1, 86, 0.10);
159
+
160
+ --card-bg: linear-gradient(135deg, var(--surface-1) 0%, var(--surface-2) 100%);
161
+
162
+ --selected-bg: rgba(222, 180, 49, 0.10);
163
+ --selected-border: rgba(222, 180, 49, 0.30);
164
+ --hover-bg: rgba(222, 180, 49, 0.05);
165
+
166
+ --context-bg: #2a1623;
167
+ --context-border: #4a2942;
168
+ --context-shadow: 0 4px 24px rgba(0, 0, 0, 0.32), 0 1px 4px rgba(0, 0, 0, 0.16);
169
+
170
+ --input-bg: #2a1623;
171
+ --input-border: #4a2942;
172
+ --input-focus-border: #deb431;
173
+
174
+ --slider-track: #3a1f32;
175
+ --slider-thumb: #943577;
176
+ --slider-thumb-hover: #deb431;
177
+
178
+ --scrollbar-thumb-color: #3a1f32;
179
+ --scrollbar-thumb-hover-color: #4a2942;
180
+ }
181
+
182
+ /* ---------------------------------------------------------------------------
183
+ Midnight — pure black
184
+ --------------------------------------------------------------------------- */
185
+
186
+ .midnight {
187
+ --surface-0: #000000;
188
+ --surface-1: #0a0a0a;
189
+ --surface-2: #111111;
190
+ --surface-3: #1a1a1a;
191
+
192
+ --border-subtle: #1a1a1a;
193
+ --border-default: #2e2e2e;
194
+
195
+ --text-primary: #FFFFFF;
196
+ --text-secondary: #999999;
197
+ --text-muted: #555555;
198
+
199
+ --accent: #777777;
200
+ --accent-hover: #999999;
201
+ --accent-text: #FFFFFF;
202
+ --accent-muted: rgba(119, 119, 119, 0.10);
203
+
204
+ --card-bg: linear-gradient(135deg, var(--surface-1) 0%, var(--surface-2) 100%);
205
+
206
+ --selected-bg: rgba(255, 255, 255, 0.06);
207
+ --selected-border: rgba(255, 255, 255, 0.20);
208
+ --hover-bg: rgba(255, 255, 255, 0.04);
209
+
210
+ --context-bg: #0a0a0a;
211
+ --context-border: #2e2e2e;
212
+ --context-shadow: 0 4px 24px rgba(0, 0, 0, 0.48), 0 1px 4px rgba(0, 0, 0, 0.24);
213
+
214
+ --input-bg: #0a0a0a;
215
+ --input-border: #2e2e2e;
216
+ --input-focus-border: #FFFFFF;
217
+
218
+ --slider-track: #1a1a1a;
219
+ --slider-thumb: #555555;
220
+ --slider-thumb-hover: #777777;
221
+
222
+ --scrollbar-thumb-color: #1a1a1a;
223
+ --scrollbar-thumb-hover-color: #2e2e2e;
224
+ }
225
+
226
+ /* ---------------------------------------------------------------------------
227
+ Mellow — bright yellow with dark text
228
+ --------------------------------------------------------------------------- */
229
+
230
+ .mellow {
231
+ --surface-0: #ffdf00;
232
+ --surface-1: #ffe52a;
233
+ --surface-2: #ddc000;
234
+ --surface-3: #ccb000;
235
+
236
+ --border-subtle: #ccb000;
237
+ --border-default: #252525;
238
+
239
+ --text-primary: #252525;
240
+ --text-secondary: #3e4245;
241
+ --text-muted: #777777;
242
+
243
+ --accent: #cc0000;
244
+ --accent-hover: #aa0000;
245
+ --accent-text: #FFFFFF;
246
+ --accent-muted: rgba(204, 0, 0, 0.08);
247
+
248
+ --card-bg: linear-gradient(135deg, var(--surface-1) 0%, var(--surface-2) 100%);
249
+
250
+ --selected-bg: rgba(37, 37, 37, 0.10);
251
+ --selected-border: rgba(37, 37, 37, 0.30);
252
+ --hover-bg: rgba(0, 0, 0, 0.06);
253
+
254
+ --context-bg: #ffe52a;
255
+ --context-border: #252525;
256
+ --context-shadow: 0 4px 24px rgba(0, 0, 0, 0.12), 0 1px 4px rgba(0, 0, 0, 0.06);
257
+
258
+ --input-bg: #ffe52a;
259
+ --input-border: #252525;
260
+ --input-focus-border: #cc0000;
261
+
262
+ --slider-track: #ccb000;
263
+ --slider-thumb: #252525;
264
+ --slider-thumb-hover: #3e4245;
265
+
266
+ --scrollbar-thumb-color: #252525;
267
+ --scrollbar-thumb-hover-color: #3e4245;
268
+ }
269
+
270
+ /* ---------------------------------------------------------------------------
271
+ Passion — deep purple with hot pink accents
272
+ --------------------------------------------------------------------------- */
273
+
274
+ .passion {
275
+ --surface-0: #620f72;
276
+ --surface-1: #69147a;
277
+ --surface-2: #7d0080;
278
+ --surface-3: #8a1090;
279
+
280
+ --border-subtle: #69147a;
281
+ --border-default: #fe1963;
282
+
283
+ --text-primary: #FFFFFF;
284
+ --text-secondary: #e0a0c0;
285
+ --text-muted: #9a5080;
286
+
287
+ --accent: #fe1963;
288
+ --accent-hover: #e01555;
289
+ --accent-text: #FFFFFF;
290
+ --accent-muted: rgba(254, 25, 99, 0.10);
291
+
292
+ --card-bg: linear-gradient(135deg, var(--surface-1) 0%, var(--surface-2) 100%);
293
+
294
+ --selected-bg: rgba(254, 25, 99, 0.12);
295
+ --selected-border: rgba(254, 25, 99, 0.35);
296
+ --hover-bg: rgba(255, 255, 255, 0.06);
297
+
298
+ --context-bg: #69147a;
299
+ --context-border: #fe1963;
300
+ --context-shadow: 0 4px 24px rgba(0, 0, 0, 0.32), 0 1px 4px rgba(0, 0, 0, 0.16);
301
+
302
+ --input-bg: #69147a;
303
+ --input-border: #fe1963;
304
+ --input-focus-border: #fe1963;
305
+
306
+ --slider-track: #69147a;
307
+ --slider-thumb: #fe1963;
308
+ --slider-thumb-hover: #ff4d88;
309
+
310
+ --scrollbar-thumb-color: #fe1963;
311
+ --scrollbar-thumb-hover-color: #ff4d88;
312
+ }
313
+
314
+ /* ---------------------------------------------------------------------------
315
+ Swiss — bold red with white text
316
+ --------------------------------------------------------------------------- */
317
+
318
+ .swiss {
319
+ --surface-0: #ed1b24;
320
+ --surface-1: #d61720;
321
+ --surface-2: #c01520;
322
+ --surface-3: #aa1018;
323
+
324
+ --border-subtle: #d61720;
325
+ --border-default: #ffcccc;
326
+
327
+ --text-primary: #FFFFFF;
328
+ --text-secondary: #ffcccc;
329
+ --text-muted: #ff9999;
330
+
331
+ --accent: #d61720;
332
+ --accent-hover: #b01018;
333
+ --accent-text: #FFFFFF;
334
+ --accent-muted: rgba(214, 23, 32, 0.10);
335
+
336
+ --card-bg: linear-gradient(135deg, var(--surface-1) 0%, var(--surface-2) 100%);
337
+
338
+ --selected-bg: rgba(255, 255, 255, 0.12);
339
+ --selected-border: rgba(255, 255, 255, 0.30);
340
+ --hover-bg: rgba(255, 255, 255, 0.08);
341
+
342
+ --context-bg: #d61720;
343
+ --context-border: #ffcccc;
344
+ --context-shadow: 0 4px 24px rgba(0, 0, 0, 0.24), 0 1px 4px rgba(0, 0, 0, 0.12);
345
+
346
+ --input-bg: #d61720;
347
+ --input-border: #ffcccc;
348
+ --input-focus-border: #FFFFFF;
349
+
350
+ --slider-track: #aa1018;
351
+ --slider-thumb: #ffcccc;
352
+ --slider-thumb-hover: #FFFFFF;
353
+
354
+ --scrollbar-thumb-color: #aa1018;
355
+ --scrollbar-thumb-hover-color: #ffcccc;
356
+ }
@@ -0,0 +1,108 @@
1
+ /* ==========================================================================
2
+ Buttons — Base
3
+ ========================================================================== */
4
+
5
+ .btn {
6
+ display: inline-flex;
7
+ align-items: center;
8
+ justify-content: center;
9
+ gap: 6px;
10
+ font-weight: 500;
11
+ border-radius: 4px;
12
+ border: 1px solid transparent;
13
+ cursor: pointer;
14
+ outline: none;
15
+ white-space: nowrap;
16
+ transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease;
17
+ }
18
+
19
+ .btn:disabled {
20
+ opacity: 0.5;
21
+ cursor: not-allowed;
22
+ }
23
+
24
+ /* ==========================================================================
25
+ Buttons — Sizes
26
+ ========================================================================== */
27
+
28
+ .btn-xs {
29
+ font-size: 11px;
30
+ padding: 2px 8px;
31
+ border-radius: 3px;
32
+ }
33
+
34
+ .btn-sm {
35
+ font-size: 12px;
36
+ padding: 4px 12px;
37
+ }
38
+
39
+ .btn-md {
40
+ font-size: 13px;
41
+ padding: 6px 16px;
42
+ }
43
+
44
+ .btn-lg {
45
+ font-size: 14px;
46
+ padding: 8px 20px;
47
+ }
48
+
49
+ .btn-xl {
50
+ font-size: 15px;
51
+ padding: 10px 24px;
52
+ border-radius: 6px;
53
+ }
54
+
55
+ /* ==========================================================================
56
+ Buttons — Variants
57
+ ========================================================================== */
58
+
59
+ .btn-theme {
60
+ background-color: var(--surface-3);
61
+ color: var(--text-primary);
62
+ border-color: var(--border-default);
63
+ }
64
+
65
+ .btn-theme:hover:not(:disabled) {
66
+ background-color: var(--border-default);
67
+ }
68
+
69
+ .btn-default {
70
+ background-color: var(--surface-2);
71
+ color: var(--text-secondary);
72
+ border-color: var(--border-default);
73
+ }
74
+
75
+ .btn-default:hover:not(:disabled) {
76
+ background-color: var(--surface-3);
77
+ color: var(--text-primary);
78
+ }
79
+
80
+ .btn-outline {
81
+ background-color: transparent;
82
+ color: var(--text-secondary);
83
+ border-color: var(--border-default);
84
+ }
85
+
86
+ .btn-outline:hover:not(:disabled) {
87
+ background-color: var(--surface-2);
88
+ color: var(--text-primary);
89
+ }
90
+
91
+ .btn-ghost {
92
+ background-color: transparent;
93
+ color: var(--text-secondary);
94
+ }
95
+
96
+ .btn-ghost:hover:not(:disabled) {
97
+ background-color: var(--hover-bg);
98
+ color: var(--text-primary);
99
+ }
100
+
101
+ .btn-danger {
102
+ background-color: #dc2626;
103
+ color: #ffffff;
104
+ }
105
+
106
+ .btn-danger:hover:not(:disabled) {
107
+ background-color: #b91c1c;
108
+ }
@@ -0,0 +1,60 @@
1
+ /* ==========================================================================
2
+ Cards
3
+ ========================================================================== */
4
+
5
+ .card {
6
+ background: var(--card-bg);
7
+ border: 1px solid var(--border-subtle);
8
+ border-radius: 8px;
9
+ box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06), 0 1px 2px rgba(0, 0, 0, 0.04);
10
+ margin-bottom: 2rem;
11
+ }
12
+
13
+ .card-header {
14
+ display: flex;
15
+ flex-direction: row;
16
+ align-items: stretch;
17
+ justify-content: space-between;
18
+ border-bottom: 1px solid var(--border-subtle);
19
+ min-height: 56px;
20
+ padding: 0.75rem 1.5rem;
21
+ }
22
+
23
+ .card-title {
24
+ display: flex;
25
+ align-items: center;
26
+ justify-content: flex-start;
27
+ gap: 1rem;
28
+ }
29
+
30
+ .card-title h2,
31
+ .card-title h3,
32
+ .card-title h4,
33
+ .card-title h5,
34
+ .card-title h6 {
35
+ font-size: 1rem;
36
+ font-weight: 700;
37
+ line-height: 1.25;
38
+ color: var(--text-primary);
39
+ }
40
+
41
+ .card-tools {
42
+ display: flex;
43
+ align-items: center;
44
+ justify-content: flex-end;
45
+ gap: 0.75rem;
46
+ }
47
+
48
+ .card-body {
49
+ padding: 1.5rem;
50
+ }
51
+
52
+ .card-footer {
53
+ display: flex;
54
+ flex-direction: row;
55
+ align-items: stretch;
56
+ justify-content: space-between;
57
+ padding: 0.75rem 1.5rem;
58
+ position: relative;
59
+ border-top: 1px solid var(--border-subtle);
60
+ }
@@ -0,0 +1,70 @@
1
+ /* ==========================================================================
2
+ Form Label
3
+ ========================================================================== */
4
+
5
+ .form-label {
6
+ display: block;
7
+ font-size: 12px;
8
+ font-weight: 600;
9
+ color: var(--text-secondary);
10
+ margin-bottom: 6px;
11
+ }
12
+
13
+ /* ==========================================================================
14
+ Form Input
15
+ ========================================================================== */
16
+
17
+ .form-input {
18
+ background-color: var(--input-bg);
19
+ border: 1px solid var(--input-border);
20
+ border-radius: 4px;
21
+ height: 28px;
22
+ padding: 4px 8px;
23
+ color: var(--text-primary);
24
+ font-size: 12px;
25
+ font-weight: normal;
26
+ line-height: 1.5;
27
+ outline: none;
28
+ box-shadow: none;
29
+ transition: border-color 0.15s ease, box-shadow 0.15s ease;
30
+ }
31
+
32
+ .form-input:focus {
33
+ border-color: var(--text-muted);
34
+ box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.05);
35
+ }
36
+
37
+ .form-input::placeholder {
38
+ color: var(--text-muted);
39
+ }
40
+
41
+ /* ==========================================================================
42
+ Form Select
43
+ ========================================================================== */
44
+
45
+ .form-select {
46
+ -webkit-appearance: none;
47
+ appearance: none;
48
+ background-color: var(--input-bg);
49
+ border: 1px solid var(--input-border);
50
+ border-radius: 4px;
51
+ height: 28px;
52
+ padding: 4px 28px 4px 8px;
53
+ color: var(--text-primary);
54
+ font-size: 12px;
55
+ font-weight: normal;
56
+ line-height: 1.5;
57
+ outline: none;
58
+ box-shadow: none;
59
+ cursor: pointer;
60
+ background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
61
+ background-repeat: no-repeat;
62
+ background-position: right 8px center;
63
+ background-size: 12px;
64
+ transition: border-color 0.15s ease, box-shadow 0.15s ease;
65
+ }
66
+
67
+ .form-select:focus {
68
+ border-color: var(--text-muted);
69
+ box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.05);
70
+ }
@@ -0,0 +1,24 @@
1
+ /* ==========================================================================
2
+ Settings Navigation
3
+ ========================================================================== */
4
+
5
+ .settings-nav-link {
6
+ display: block;
7
+ padding: 6px 12px;
8
+ font-size: 12px;
9
+ font-weight: 500;
10
+ color: var(--text-secondary);
11
+ border-radius: 4px;
12
+ text-decoration: none;
13
+ transition: background-color 0.15s ease, color 0.15s ease;
14
+ }
15
+
16
+ .settings-nav-link:hover {
17
+ background-color: var(--hover-bg);
18
+ color: var(--text-primary);
19
+ }
20
+
21
+ .settings-nav-link.active {
22
+ background-color: var(--surface-3);
23
+ color: var(--text-primary);
24
+ }
@@ -0,0 +1,50 @@
1
+ /* ==========================================================================
2
+ Scrollbox
3
+ ========================================================================== */
4
+
5
+ .scrollbox-x,
6
+ .scrollbox-y {
7
+ --scrollbar-thumb: var(--scrollbar-thumb-color);
8
+ --scrollbar-thumb-hover: var(--scrollbar-thumb-hover-color);
9
+ --scrollbar-track: transparent;
10
+ --scrollbar-size: 5px;
11
+ --scrollbar-radius: 3px;
12
+ }
13
+
14
+ .scrollbox-x {
15
+ overflow-x: overlay;
16
+ scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
17
+ scrollbar-width: thin;
18
+ }
19
+
20
+ .scrollbox-y {
21
+ overflow-y: overlay;
22
+ scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
23
+ scrollbar-width: thin;
24
+ }
25
+
26
+ /* Webkit track */
27
+ .scrollbox-x::-webkit-scrollbar {
28
+ height: var(--scrollbar-size);
29
+ }
30
+
31
+ .scrollbox-y::-webkit-scrollbar {
32
+ width: var(--scrollbar-size);
33
+ }
34
+
35
+ .scrollbox-x::-webkit-scrollbar-track,
36
+ .scrollbox-y::-webkit-scrollbar-track {
37
+ background: var(--scrollbar-track);
38
+ }
39
+
40
+ /* Webkit thumb */
41
+ .scrollbox-x::-webkit-scrollbar-thumb,
42
+ .scrollbox-y::-webkit-scrollbar-thumb {
43
+ background-color: var(--scrollbar-thumb);
44
+ border-radius: var(--scrollbar-radius);
45
+ }
46
+
47
+ .scrollbox-x::-webkit-scrollbar-thumb:hover,
48
+ .scrollbox-y::-webkit-scrollbar-thumb:hover {
49
+ background-color: var(--scrollbar-thumb-hover);
50
+ }
@@ -0,0 +1,7 @@
1
+ .app-spinner {
2
+ @apply relative block rounded-full w-[19px] h-[19px] m-0 p-0 opacity-0 overflow-hidden border-4 border-[#00a0be];
3
+ border-left: 4px solid #fff;
4
+ &.is-animating {
5
+ @apply opacity-100 animate-spin;
6
+ }
7
+ }