diff --git a/packages/amis-ui/scss/components/_spinner.scss b/packages/amis-ui/scss/components/_spinner.scss index 696f4c9d6c8f..08d8f13223b4 100644 --- a/packages/amis-ui/scss/components/_spinner.scss +++ b/packages/amis-ui/scss/components/_spinner.scss @@ -105,6 +105,12 @@ } } + .#{$ns}Spinner-icon--darkBg { + svg.icon path { + fill: var(--colors-neutral-text-11); + } + } + .#{$ns}Spinner-tip { margin: px2rem(12px) 0 0 0; word-break: keep-all; diff --git a/packages/amis-ui/src/components/Spinner.tsx b/packages/amis-ui/src/components/Spinner.tsx index 6d48183eb095..ef1db54fe2cc 100644 --- a/packages/amis-ui/src/components/Spinner.tsx +++ b/packages/amis-ui/src/components/Spinner.tsx @@ -104,7 +104,7 @@ const store = SpinnerSharedStore.create({}); export class Spinner extends React.Component< SpinnerProps, - {spinning: boolean; showMarker: boolean} + {spinning: boolean; showMarker: boolean; idDarkBg: boolean} > { static defaultProps = { show: true, @@ -122,7 +122,8 @@ export class Spinner extends React.Component< state = { spinning: false, - showMarker: true + showMarker: true, + idDarkBg: false }; parent: HTMLElement | null = null; @@ -159,6 +160,19 @@ export class Spinner extends React.Component< if (this.parent && this.state.showMarker) { this.setState({showMarker: false}); } + if (this.parent) { + const backgroundColor = getComputedStyle(this.parent).getPropertyValue( + 'background-color' + ); + const rgba = backgroundColor.match(/\d+/g)?.map(Number) || []; + + const brightness = (rgba[0] * 299 + rgba[1] * 587 + rgba[2] * 114) / 1000; + rgba[3] = rgba[3] ?? 1; // 没有设置颜色时取到的是 rgba(0, 0, 0, 0) + + if (brightness < 200 && rgba[3] > 0.4) { + this.setState({idDarkBg: true}); + } + } } componentWillUnmount() { @@ -250,7 +264,8 @@ export class Spinner extends React.Component< 'Spinner-icon--custom': isCustomIcon, 'Spinner-icon--disabled': disabled }, - spinnerClassName + spinnerClassName, + this.state.idDarkBg && 'Spinner-icon--darkBg' )} > {icon ? (