何时将主题/插件切换到 `.gjs`?

我认为我们需要一种通用的方法来做到这一点,这种方法不依赖于特定的主题组件——就像我们现在一样。

我还有另一个使用这种技术的主题组件:

所以至少有我这边的两个,可能还有更多。

3 个赞

我同意。我构建了一个块组件集合,每个组件都是独立的,而不是捆绑在一个包中:https://gitlab.com/manuelkostka/discourse/blocks。

现在,我可以使用我的 Homepage Blocks 组件将这些块放在一个专用的主页上,就像我可以使用 Right Sidebar Blocks 或 Bars 一样。

我最近在 Central 主题上做了一个尝试,我需要一个自定义侧边栏布局。我可以轻松地为自定义侧边栏构建一个块框架,并将块组件放在上面:https://central.kostka.studio(只需通过名称引用,就可以将 Powered-by-discourse 组件放在侧边栏上)。

独立的块组件确实是我目前用于以灵活且可维护的方式构建客户端自定义的最有用的工具。很高兴能有一个通用的前进方向来支持这一点。

3 个赞

我想顶一下这个帖子,因为我正在尝试找出处理组件的最佳方法。目前我看到两个选项,它们都有很大的缺点:我可以为每个渲染块的主题组件创建一个注册表,但这在某种程度上违背了模块化的初衷。或者通过插件全局添加一个注册表,但这样我的组件就会依赖于该插件的安装。

因此,在核心中拥有一个全局块注册 API 似乎会非常有帮助。主题组件可以使用它来调用块渲染,也可以注册新块。

我喜欢使用块方法,因为它允许我在应用程序布局和组件内容之间分离关注点。块组件只负责渲染其内容,然后由应用程序中的另一个组件进行渲染。我可以从块组件中删除所有路由和出口逻辑,并且可以轻松地在布局中甚至在整个应用程序中多次重用同一个块。

我认为这使得一切都更精简、更具可重用性,并且总体上是一种优雅的方法。在 Discourse 中获得对这种模式的有力支持将是很好的。

4 个赞

David,是否可以有一个任意的 API 来注册“跨主题/插件”组件供另一个插件/组件使用?

这样可以避免注册所有内容,同时仍然提供明确实现此目的的灵活性。

2 个赞

我不确定是否应该为此提供一个通用的应用程序编程接口(API)。组件的使用方式太多了,它们对参数和加载时机都有不同的期望。

对于您的用例,一个特定于主题/插件的注册表是否可行?就像上面关于 right-sidebar-blocks 的模型一样?

如果不可行,提供一些具体的例子可能有助于我们弄清楚到底需要什么样的 API。所有由 CDCK 维护的主题和插件都已迁移到 gjs,除了像 right-sidebar-blocks 这样的特定情况外,我们没有遇到这个问题。

1 个赞

是的,实际上,仔细重读您在草稿 PR 上所写的内容,确实让我相信这是一个足够好的解决方案,特别是:

“此提交引入了一个专用的右侧边栏块组件列表,并允许其他主题/插件注册其他组件。”

我认为这是关键——能够远程注册为与另一个主题兼容,然后允许“主”主题合并远程注册的元素,这正是我想要的,所以我认为您已经证明了这是可行的。

1 个赞

太棒了!

在非常简单的情况下,您甚至可以尝试在“主”主题中添加一个 PluginOutlet,然后其他主题可以 renderInOutlet(或将文件放入 connectors/...)。

2 个赞

同样属实。但我真的很喜欢你的注册模式,非常棒。实际上,保留与 RSB 的兼容性会很好(Bars 已经使用相同的参数系统),这样整个系统就可以互操作(尽管有两个初始化器可能会是个挑战——或者如果我能关闭 RSB 布局层,可能就不需要额外的初始化器了,这样就可以简单地完全加载 RSB 并重复使用 :thinking:)。