modules_view.js 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. const { form, button, div, h2, p, section, table, tr, td, input, a, br, ul, li, span, strong } = require("../server/node_modules/hyperaxe");
  2. const { template, i18n } = require('./main_views');
  3. const { getConfig } = require('../configs/config-manager.js');
  4. const modulesView = () => {
  5. const config = getConfig().modules;
  6. const modules = [
  7. { name: 'agenda', label: i18n.modulesAgendaLabel, description: i18n.modulesAgendaDescription },
  8. { name: 'ai', label: i18n.modulesAILabel, description: i18n.modulesAIDescription },
  9. { name: 'audios', label: i18n.modulesAudiosLabel, description: i18n.modulesAudiosDescription },
  10. { name: 'bookmarks', label: i18n.modulesBookmarksLabel, description: i18n.modulesBookmarksDescription },
  11. { name: 'cipher', label: i18n.modulesCipherLabel, description: i18n.modulesCipherDescription },
  12. { name: 'docs', label: i18n.modulesDocsLabel, description: i18n.modulesDocsDescription },
  13. { name: 'events', label: i18n.modulesEventsLabel, description: i18n.modulesEventsDescription },
  14. { name: 'feed', label: i18n.modulesFeedLabel, description: i18n.modulesFeedDescription },
  15. { name: 'forum', label: i18n.modulesForumLabel, description: i18n.modulesForumDescription },
  16. { name: 'governance', label: i18n.modulesGovernanceLabel, description: i18n.modulesGovernanceDescription },
  17. { name: 'images', label: i18n.modulesImagesLabel, description: i18n.modulesImagesDescription },
  18. { name: 'invites', label: i18n.modulesInvitesLabel, description: i18n.modulesInvitesDescription },
  19. { name: 'legacy', label: i18n.modulesLegacyLabel, description: i18n.modulesLegacyDescription },
  20. { name: 'latest', label: i18n.modulesLatestLabel, description: i18n.modulesLatestDescription },
  21. { name: 'market', label: i18n.modulesMarketLabel, description: i18n.modulesMarketDescription },
  22. { name: 'multiverse', label: i18n.modulesMultiverseLabel, description: i18n.modulesMultiverseDescription },
  23. { name: 'opinions', label: i18n.modulesOpinionsLabel, description: i18n.modulesOpinionsDescription },
  24. { name: 'pixelia', label: i18n.modulesPixeliaLabel, description: i18n.modulesPixeliaDescription },
  25. { name: 'popular', label: i18n.modulesPopularLabel, description: i18n.modulesPopularDescription },
  26. { name: 'reports', label: i18n.modulesReportsLabel, description: i18n.modulesReportsDescription },
  27. { name: 'summaries', label: i18n.modulesSummariesLabel, description: i18n.modulesSummariesDescription },
  28. { name: 'tags', label: i18n.modulesTagsLabel, description: i18n.modulesTagsDescription },
  29. { name: 'tasks', label: i18n.modulesTasksLabel, description: i18n.modulesTasksDescription },
  30. { name: 'threads', label: i18n.modulesThreadsLabel, description: i18n.modulesThreadsDescription },
  31. { name: 'transfers', label: i18n.modulesTransfersLabel, description: i18n.modulesTransfersDescription },
  32. { name: 'trending', label: i18n.modulesTrendingLabel, description: i18n.modulesTrendingDescription },
  33. { name: 'tribes', label: i18n.modulesTribesLabel, description: i18n.modulesTribesDescription },
  34. { name: 'videos', label: i18n.modulesVideosLabel, description: i18n.modulesVideosDescription },
  35. { name: 'wallet', label: i18n.modulesWalletLabel, description: i18n.modulesWalletDescription },
  36. { name: 'topics', label: i18n.modulesTopicsLabel, description: i18n.modulesTopicsDescription }
  37. ];
  38. const moduleStates = modules.reduce((acc, mod) => {
  39. acc[`${mod.name}Mod`] = config[`${mod.name}Mod`] === 'on' ? 'on' : 'off';
  40. return acc;
  41. }, {});
  42. const activeModulesCount = modules.filter(mod => moduleStates[`${mod.name}Mod`] === 'on').length;
  43. const totalModulesCount = modules.length;
  44. const disabledModulesCount = totalModulesCount - activeModulesCount;
  45. const header = div({ class: 'tags-header' },
  46. h2(i18n.modulesViewTitle),
  47. p(i18n.modulesViewDescription),
  48. div({ style: 'margin-bottom:16px;' },
  49. `${i18n.modulesTotalModulesLabel}: `,
  50. strong({ style: 'color:#888;' }, totalModulesCount),
  51. ul({ style: 'list-style-type:none; padding:0; margin:0;' },
  52. li({ style: 'font-size:18px; color:#555; margin:8px 0;' },
  53. `${i18n.modulesEnabledModulesLabel}: `,
  54. span({ style: 'color:#888;' }, activeModulesCount)
  55. ),
  56. li({ style: 'font-size:18px; color:#555; margin:8px 0;' },
  57. `${i18n.modulesDisabledModulesLabel}: `,
  58. span({ style: 'color:#888;' }, disabledModulesCount)
  59. )
  60. )
  61. )
  62. );
  63. return template(
  64. i18n.modules,
  65. section(header),
  66. section(
  67. form(
  68. { action: "/save-modules", method: "post" },
  69. table(
  70. { class: "module-table" },
  71. tr(
  72. td(i18n.modulesModuleName),
  73. td(i18n.modulesModuleDescription),
  74. td({ style: 'text-align: center;' }, i18n.modulesModuleStatus)
  75. ),
  76. modules.map(mod =>
  77. tr(
  78. td(a({ href: `/${mod.name}` }, mod.label)),
  79. td(p(mod.description)),
  80. td(
  81. input({
  82. type: "checkbox",
  83. id: `${mod.name}Mod`,
  84. name: `${mod.name}Form`,
  85. class: "input-checkbox",
  86. value: 'on',
  87. checked: moduleStates[`${mod.name}Mod`] === 'on' ? true : undefined
  88. })
  89. )
  90. )
  91. )
  92. ),
  93. div(
  94. { class: "save-button-container", style: "margin-top: 20px; text-align: center;" },
  95. button({ type: "submit", class: "submit-button" }, i18n.saveSettings)
  96. )
  97. )
  98. )
  99. );
  100. };
  101. exports.modulesView = modulesView;