优维低代码:Theme Mode 页面主题和模式

2023-11-06 12:59

本文主要是介绍优维低代码:Theme Mode 页面主题和模式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

优维低代码技术专栏,是一个全新的、技术为主的专栏,由优维技术委员会成员执笔,基于优维7年低代码技术研发及运维成果,主要介绍低代码相关的技术原理及架构逻辑,目的是给广大运维人提供一个技术交流与学习的平台。


连载第三十一期

《高级指引:Theme & Mode 页面主题和模式》

⊙ NOTE

Brick Next 从 2.7.1 开始支持页面主题和模式。

Brick Next 支持两种主题:light 和 dark(默认为 light),以及两种模式:default 和 dashboard(默认为 default)。

在 dark 深色主题下,页面框架及构件将以深色背景样式显示。而在 dashboard 大屏模式下,系统的页面顶栏及侧栏将消失,同时配合 basic-bricks.micro-view 开启 dashboardMode: true 可以实现大屏效果。

目前主要在“大屏”场景下使用,注意该场景需要同时启用深色主题和大屏模式。

# 微应用编排:切换主题和模式

例如在 Storyboard 编排中,希望某个按钮点击后切换到“深色+大屏”场景,可以如下配置:

brick: "your-button"
events:click:- action: "theme.setDarkTheme"- action: "mode.setDashboardMode"

每当页面初始进入、或发生跳转并重新渲染前,系统将自动切回浅色主题和默认模式,但系统开放了一个窗口期 onBeforePageLoad,以支持页面可以设置初始化为深色主题及大屏模式。

例如假设我们希望 URL 中携带参数 mode=dashboard 时自动使用深色主题和大屏模式,可以如下配置:

brick: "basic-bricks.micro-view"
lifeCycle:onBeforePageLoad:- if: "<% QUERY.mode === 'dashboard' %>"action: "theme.setDarkTheme"- if: "<% QUERY.mode === 'dashboard' %>"action: "mode.setDashboardMode"
properties:dashboardMode: "<% QUERY.mode === 'dashboard' %>"

注意 basic-bricks.micro-view 构件在大屏模式下会多一个退出按钮,点击后将发出 mode.dashboard.exit 事件,需要用户自行配置退出大屏需要执行的动作。例如通常应添加如下事件配置:

brick: "basic-bricks.micro-view"
events:mode.dashboard.exit:- target: "_self"properties:dashboardMode: false- action: "theme.setLightTheme"- action: "mode.setDefaultMode"

不内置退出动作的原因是,用户可以通过其他方式退出大屏,例如通过 history.pushQuery 跳转重置 mode=dashboard 参数来实现退出大屏模式:

brick: "basic-bricks.micro-view"
events:mode.dashboard.exit:- action: "history.pushQuery"args:- mode: null

⊙ IMPORTANT

不要在编排中为构件配置固定的颜色值,而应使用系统预定义的 CSS custom properties,具体可以参考本文下一节内容。

# 构件开发:适配深色主题和大屏模式

系统通过定义一系列 CSS custom properties(又称 CSS variables)来实现主题样式的实时无缝切换,无论在编排或构件开发时应首先尝试使用这些属性。具体属性列表可以参考这里的源码。

系统当前的主题和模式反馈在<html>元素的 data-theme 及 data-mode 属性上,因此仅使用 css 即可完成大部分深色主题和大屏模式的适配。例如:

.your-class {color: black;
}html[data-theme="dark"] .your-class {color: white;
}

当使用系统预定义的 CSS custom properties 时,则无需额外配置 html[data-theme="dark"] 样式:

.your-class {color: var(--text-color-default);
}

有时候构件需要在 JavaScript 中判断当前主题或模式,例如图表类构件需要根据当前主题来生成不同的颜色列表,对此系统提供了 React Hooks useCurrentTheme 和 useCurrentMode 来获取当前的主题和模式,例如:

import { useCurrentTheme } from "@next-core/brick-kit";function YourComponent() {const theme = useCurrentTheme();const colors = theme === "dark" ? ["red", "green"] : ["blue", "orange"];return <YourChart colors={colors} />;
}

# 适配公共 UI 规范样式

使用 Less

Brick Next 的 UI 底层基于 Ant Design,在适配我们自己的 UI 规范相关的样式时,应结合 Ant Design 的底层技术 Less 的能力,尽量通过使用或覆盖已有的 Less 预定义变量值来实现样式更新,而不是使用固定的颜色值。例如:

// ✅ Good:
// In `packages/custom-antd-styles/src/var.less`:
@link-hover-color: #0071eb;// ❌ Bad:
// In `packages/custom-antd-styles/src/link.less`
a:hover {color: #0071eb;
}
// ✅ Good:
// In `bricks/your-brick/src/style.less`:
.your-class {color: @link-hover-color;
}// ❌ Bad:
// In `bricks/your-brick/src/style.less`
.your-class {color: #0071eb;
}

Brick Next 的 Antd Less 变量统一管理在 next-core 仓库的
packages/custom-antd-styles/src/var.less 中。

# 使用 CSS Variables

由于 Less 的处理发生在编译阶段,无法在运行时提供切换变量的能力,因此为了实现运行时深色主题的自由切换,我们还需要结合使用 CSS custom properties(又称 CSS variables)。

对于色值一类的样式(例如 color: #fff)通常需要为默认主题和深色主题配置不同的色值,此时,我们可以将 Antd 中对应的 Less 变量设置为 CSS variables,并针对不同主题分别设置不同的色值。例如:

// In `packages/custom-antd-styles/src/var.less`:
@text-color: var(--antd-text-color);
/* In `packages/brick-container/src/styles/variables.css`: */
:root {--antd-text-color: rgba(0, 0, 0, 0.85);
}html[data-theme="dark"] {--antd-text-color: #c6cfd9;
}

⊙ NOTE

注意我们统一使用 --antd- 作为前缀加上对应的 Antd Less 变量名作为 Antd 相关的 CSS variable name。

Brick Next 的 CSS variables 统一管理在 next-core 仓库的
packages/brick-container/src/styles/variables.css 中。

# 处理 Less 编译报错

由于 Antd 大量使用了色值计算(例如 darken(...) lighten(...) 等),这些计算无法兼容 CSS variable,因此有时当我们使用 CSS variable 作为 Less 的变量值时,构建 Less 可能会报错,对此的解决方案是使用我们自定义的 LessReplacer 插件,将这些报错的色值计算代码进行替换。

例如:

// In `packages/less-plugin-css-variables/src/LessReplacer.js`:
const rawStringMap = {"darken(@item-active-bg, 2%)": "var(--antd-item-active-bg-darken-2)",
};

以上配置将把 Antd Less 文件中所有的 darken(@item-active-bg, 2%) 替换为 var(
--antd-item-active-bg-darken-2),注意变量命名方法为「--antd- 前缀 + Antd Less 变量名 + 方法名 + 参数值」。

又例如:

// In `packages/less-plugin-css-variables/src/LessReplacer.js`:
const variableMap = {"table-header-sort-active-bg": true,
};

以上配置将把 Antd Less 文件中所有的 @
table-header-sort-active-bg: **;(假设 ** 为包含色值计算等导致 Less 编译报错的代码)的定义替换为 @
table-header-sort-active-bg: var(--antd-table-header-sort-active-bg)。

注意这些新增的 --antd-* 需要在
packages/brick-container/src/styles/variables.css 中写好定义。

这篇关于优维低代码:Theme Mode 页面主题和模式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/356768

相关文章

如何在页面调用utility bar并传递参数至lwc组件

1.在app的utility item中添加lwc组件: 2.调用utility bar api的方式有两种: 方法一,通过lwc调用: import {LightningElement,api ,wire } from 'lwc';import { publish, MessageContext } from 'lightning/messageService';import Ca

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

代码随想录冲冲冲 Day39 动态规划Part7

198. 打家劫舍 dp数组的意义是在第i位的时候偷的最大钱数是多少 如果nums的size为0 总价值当然就是0 如果nums的size为1 总价值是nums[0] 遍历顺序就是从小到大遍历 之后是递推公式 对于dp[i]的最大价值来说有两种可能 1.偷第i个 那么最大价值就是dp[i-2]+nums[i] 2.不偷第i个 那么价值就是dp[i-1] 之后取这两个的最大值就是d

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

D4代码AC集

贪心问题解决的步骤: (局部贪心能导致全局贪心)    1.确定贪心策略    2.验证贪心策略是否正确 排队接水 #include<bits/stdc++.h>using namespace std;int main(){int w,n,a[32000];cin>>w>>n;for(int i=1;i<=n;i++){cin>>a[i];}sort(a+1,a+n+1);int i=1

模版方法模式template method

学习笔记,原文链接 https://refactoringguru.cn/design-patterns/template-method 超类中定义了一个算法的框架, 允许子类在不修改结构的情况下重写算法的特定步骤。 上层接口有默认实现的方法和子类需要自己实现的方法

【iOS】MVC模式

MVC模式 MVC模式MVC模式demo MVC模式 MVC模式全称为model(模型)view(视图)controller(控制器),他分为三个不同的层分别负责不同的职责。 View:该层用于存放视图,该层中我们可以对页面及控件进行布局。Model:模型一般都拥有很好的可复用性,在该层中,我们可以统一管理一些数据。Controlller:该层充当一个CPU的功能,即该应用程序