mirror of
https://github.com/ant-design/ant-design.git
synced 2024-11-27 20:49:53 +08:00
14a1e6bd51
* feat: tsconfig enable strict * feat: add no-explicit-any * feat: strict * feat: as THEME * feat: 优化 keys 类型写法 * feat: demo remove any * feat: as number * feat: this any * feat: add eslint * feat: cascader * feat: props any * feat: remove any * feat: remove any * feat: any 提示错误 * feat: remove any * feat: add eslint * feat: 允许 T = any 存在 * feat: color funciton * feat: 恢复 lint * feat: merge master * feat: as ReactElement * feat: type
30 lines
1.1 KiB
TypeScript
30 lines
1.1 KiB
TypeScript
/** converting camel-cased strings to be lowercase and link it with Separato */
|
|
export function toLowercaseSeparator(key: string) {
|
|
return key.replace(/([A-Z])/g, '-$1').toLowerCase();
|
|
}
|
|
|
|
export function getStyleStr(style: React.CSSProperties): string {
|
|
return Object.keys(style)
|
|
.map((key) => `${toLowercaseSeparator(key)}: ${style[key as keyof React.CSSProperties]};`)
|
|
.join(' ');
|
|
}
|
|
|
|
/** Returns the ratio of the device's physical pixel resolution to the css pixel resolution */
|
|
export function getPixelRatio() {
|
|
return window.devicePixelRatio || 1;
|
|
}
|
|
|
|
/** Whether to re-render the watermark */
|
|
export const reRendering = (mutation: MutationRecord, isWatermarkEle: (ele: Node) => boolean) => {
|
|
let flag = false;
|
|
// Whether to delete the watermark node
|
|
if (mutation.removedNodes.length) {
|
|
flag = Array.from<Node>(mutation.removedNodes).some((node) => isWatermarkEle(node));
|
|
}
|
|
// Whether the watermark dom property value has been modified
|
|
if (mutation.type === 'attributes' && isWatermarkEle(mutation.target)) {
|
|
flag = true;
|
|
}
|
|
return flag;
|
|
};
|