Skip to content

Commit 1e3d6a6

Browse files
authoredSep 8, 2024
Merge pull request #1146 from lowcoder-org/update-loaders
Update loaders
2 parents 2569950 + ae1cb0e commit 1e3d6a6

File tree

16 files changed

+203
-73
lines changed

16 files changed

+203
-73
lines changed
 

‎client/packages/lowcoder-design/src/components/Loading.tsx

+10-2
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,6 @@
11
import styled, { css } from "styled-components";
22
import { CSSProperties } from "react";
3+
import { default as Skeleton } from "antd/es/skeleton";
34

45
type LoadingContainerProps = {
56
$backgroundColor: string;
@@ -12,6 +13,8 @@ const LoadingWrapper = styled.div`
1213
flex-direction: column;
1314
align-items: center;
1415
justify-content: center;
16+
width: 100%;
17+
height: 100%;
1518
`;
1619

1720
// Loading
@@ -61,6 +64,10 @@ const Load2 = styled.div<LoadingContainerProps>`
6164
linear-gradient(to right, ${(props) => props.$color}a3, ${(props) => props.$color}1a);
6265
`;
6366

67+
const StyledSkeleton = styled(Skeleton)`
68+
height: 100%;
69+
`;
70+
6471
type LoadingProps = {
6572
backgroundColor?: string;
6673
color?: string;
@@ -77,14 +84,15 @@ export const Loading = (props: LoadingProps) => {
7784
};
7885
return (
7986
<LoadingWrapper className={props.className} style={props.style}>
80-
<ContainerX {...loadingProps}>
87+
{/* <ContainerX {...loadingProps}>
8188
<Container {...loadingProps}>
8289
<Load1 {...loadingProps} />
8390
</Container>
8491
<Container {...loadingProps}>
8592
<Load2 {...loadingProps} />
8693
</Container>
87-
</ContainerX>
94+
</ContainerX> */}
95+
<StyledSkeleton active style={{height: '100%', animationDuration: '2s'}} />
8896
</LoadingWrapper>
8997
);
9098
};

‎client/packages/lowcoder-design/src/components/button.tsx

+5-3
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,6 @@
11
import Button, { ButtonProps } from "antd/es/button";
2+
import Spin from "antd/es/spin";
3+
import LoadingOutlined from "@ant-design/icons/LoadingOutlined"
24
import styled, { css } from "styled-components";
35
import { Loading } from "./Loading";
46
import * as React from "react";
@@ -206,10 +208,10 @@ const TacoButton = forwardRef(
206208
{props.icon}
207209
{props.children}
208210
</span>
209-
<Loading
211+
<Spin
212+
size="small"
213+
indicator={<LoadingOutlined spin style={{color: 'white'}} />}
210214
style={loadingStyle}
211-
backgroundColor={loadingBackground}
212-
color={loadingColor}
213215
/>
214216
</>
215217
) : (

‎client/packages/lowcoder/index.html

+2-26
Original file line numberDiff line numberDiff line change
@@ -57,32 +57,8 @@
5757
<noscript>You need to enable JavaScript to run this app.</noscript>
5858
<div id="loading">
5959
<div class="loading-content">
60-
<svg
61-
width="56px"
62-
height="56px"
63-
viewBox="0 0 64 64"
64-
version="1.1"
65-
xmlns="http://www.w3.org/2000/svg"
66-
xmlns:xlink="http://www.w3.org/1999/xlink"
67-
>
68-
<defs>
69-
<pattern id="pattern-1" width="100%" height="100%" patternUnits="objectBoundingBox">
70-
<use xlink:href="#image-2"></use>
71-
</pattern>
72-
<image
73-
id="image-2"
74-
width="64"
75-
height="64"
76-
xlink:href=""
77-
></image>
78-
</defs>
79-
<g stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
80-
<g fill="url(#pattern-1)" fill-rule="nonzero">
81-
<path
82-
d="M32,0 C49.673112,0 64,14.326888 64,32 C64,49.673112 49.673112,64 32,64 C14.326888,64 0,49.673112 0,32 C0,14.326888 14.326888,0 32,0 Z M32,10 C19.8497355,10 10,19.8497355 10,32 C10,44.1502645 19.8497355,54 32,54 C44.1502645,54 54,44.1502645 54,32 C54,19.8497355 44.1502645,10 32,10 Z"
83-
></path>
84-
</g>
85-
</g>
60+
<svg viewBox="0 0 1024 1024" focusable="false" data-icon="loading" width="3em" height="3em" fill="#1677FF" aria-hidden="true">
61+
<path d="M988 548c-19.9 0-36-16.1-36-36 0-59.4-11.6-117-34.6-171.3a440.45 440.45 0 00-94.3-139.9 437.71 437.71 0 00-139.9-94.3C629 83.6 571.4 72 512 72c-19.9 0-36-16.1-36-36s16.1-36 36-36c69.1 0 136.2 13.5 199.3 40.3C772.3 66 827 103 874 150c47 47 83.9 101.8 109.7 162.7 26.7 63.1 40.2 130.2 40.2 199.3.1 19.9-16 36-35.9 36z"></path>
8662
</svg>
8763
</div>
8864
</div>

‎client/packages/lowcoder/src/api/commonSettingApi.ts

+2
Original file line numberDiff line numberDiff line change
@@ -66,6 +66,8 @@ export interface ThemeDetail {
6666
boxShadowColor?: string;
6767
animationIterationCount?: string;
6868
components?: Record<string, JSONObject>;
69+
showComponentLoadingIndicators?: boolean;
70+
showDataLoadingIndicators?: boolean;
6971
}
7072

7173
export function getThemeDetailName(key: keyof ThemeDetail) {

‎client/packages/lowcoder/src/components/ThemeSettingsSelector.tsx

+66-10
Original file line numberDiff line numberDiff line change
@@ -4,7 +4,7 @@ import { ConfigItem, Radius, Margin, Padding, GridColumns, BorderWidth, BorderSt
44
import { isValidColor, toHex } from "components/colorSelect/colorUtils";
55
import { ColorSelect } from "components/colorSelect";
66
import { TacoInput } from "components/tacoInput";
7-
import { Slider } from "antd";
7+
import { Slider, Switch } from "antd";
88
import {
99
ExpandIcon,
1010
CompressIcon,
@@ -27,6 +27,8 @@ export type configChangeParams = {
2727
borderWidth?: string;
2828
fontFamily?: string;
2929
components?: Record<string, object>,
30+
showComponentLoadingIndicators?: boolean;
31+
showDataLoadingIndicators?: boolean;
3032
};
3133

3234
type ColorConfigProps = {
@@ -46,6 +48,8 @@ type ColorConfigProps = {
4648
margin?: string;
4749
padding?: string;
4850
gridColumns?: string; // Added By Aqib Mirza
51+
showComponentLoadingIndicators?: boolean;
52+
showDataLoadingIndicators?: boolean;
4953
};
5054

5155
export default function ThemeSettingsSelector(props: ColorConfigProps) {
@@ -63,7 +67,9 @@ export default function ThemeSettingsSelector(props: ColorConfigProps) {
6367
borderStyle: defaultBorderStyle,
6468
borderWidth: defaultBorderWidth,
6569
borderColor: defaultBorderColor,
66-
fontFamily: defaultFontFamily
70+
fontFamily: defaultFontFamily,
71+
showComponentLoadingIndicators: defaultShowComponentLoaders,
72+
showDataLoadingIndicators: defaultShowDataLoaders,
6773
} = props;
6874

6975
const configChangeWithDebounce = _.debounce(configChange, 0);
@@ -76,6 +82,8 @@ export default function ThemeSettingsSelector(props: ColorConfigProps) {
7682
const [borderWidth, setBorderWidth] = useState(defaultBorderWidth);
7783
const [borderColor, setBorderColor] = useState(defaultBorderColor);
7884
const [fontFamily, setFontFamily] = useState(defaultFontFamily);
85+
const [showComponentLoaders, setComponentLoaders] = useState(defaultShowComponentLoaders);
86+
const [showDataLoaders, setDataLoaders] = useState(defaultShowDataLoaders);
7987

8088
const varName = `(${themeSettingKey})`;
8189

@@ -229,22 +237,36 @@ export default function ThemeSettingsSelector(props: ColorConfigProps) {
229237
setFontFamily(defaultFontFamily);
230238
}, [defaultFontFamily]);
231239

240+
useEffect(() => {
241+
setComponentLoaders(defaultShowComponentLoaders);
242+
}, [defaultShowComponentLoaders]);
243+
244+
useEffect(() => {
245+
setDataLoaders(defaultShowDataLoaders);
246+
}, [defaultShowDataLoaders]);
247+
232248
return (
233249
<ConfigItem className={props.className}>
234-
<div className="text-desc">
235-
<div className="name">
236-
{name} {showVarName && <span>{varName}</span>}
250+
{themeSettingKey !== "showDataLoadingIndicators"
251+
&& themeSettingKey !== "showComponentLoadingIndicators"
252+
&& (
253+
<div className="text-desc">
254+
<div className="name">
255+
{name} {showVarName && <span>{varName}</span>}
256+
</div>
257+
<div className="desc">{desc}</div>
237258
</div>
238-
<div className="desc">{desc}</div>
239-
</div>
259+
)}
240260

241261
{themeSettingKey !== "radius" &&
242262
themeSettingKey !== "margin" &&
243263
themeSettingKey !== "padding" &&
244264
themeSettingKey !== "gridColumns" &&
245265
themeSettingKey !== "borderStyle" &&
246266
themeSettingKey !== "borderWidth" &&
247-
themeSettingKey !== "fontFamily" && (
267+
themeSettingKey !== "fontFamily" &&
268+
themeSettingKey !== "showComponentLoadingIndicators" &&
269+
themeSettingKey !== "showDataLoadingIndicators" && (
248270
<div className="config-input">
249271
<ColorSelect
250272
changeColor={_.debounce(setColor, 500, {
@@ -386,8 +408,6 @@ export default function ThemeSettingsSelector(props: ColorConfigProps) {
386408
</div>
387409
)}
388410

389-
390-
391411
{themeSettingKey === "fontFamily" && (
392412
<div className="config-input">
393413
<TacoInput
@@ -398,6 +418,42 @@ export default function ThemeSettingsSelector(props: ColorConfigProps) {
398418
/>
399419
</div>
400420
)}
421+
{themeSettingKey === "showComponentLoadingIndicators" && (
422+
<div style={{
423+
display: 'flex',
424+
gap: '6px',
425+
lineHeight: 'normal',
426+
}}>
427+
<Switch
428+
size="small"
429+
checked={showComponentLoaders}
430+
onChange={(value) => {
431+
debugger;
432+
setComponentLoaders(value)
433+
configChange({ themeSettingKey, showComponentLoadingIndicators: value});
434+
}}
435+
/>
436+
<span>{name}</span>
437+
</div>
438+
)}
439+
440+
{themeSettingKey === "showDataLoadingIndicators" && (
441+
<div style={{
442+
display: 'flex',
443+
gap: '6px',
444+
lineHeight: 'normal',
445+
}}>
446+
<Switch
447+
size="small"
448+
checked={showDataLoaders}
449+
onChange={(value) => {
450+
setDataLoaders(value)
451+
configChange({ themeSettingKey, showDataLoadingIndicators: value});
452+
}}
453+
/>
454+
<span>{name}</span>
455+
</div>
456+
)}
401457
</ConfigItem>
402458
);
403459
}

‎client/packages/lowcoder/src/comps/comps/appSettingsComp.tsx

-4
Original file line numberDiff line numberDiff line change
@@ -111,10 +111,6 @@ const DivStyled = styled.div`
111111
> div:first-child {
112112
margin-bottom: 6px;
113113
}
114-
115-
.tooltipLabel {
116-
white-space: nowrap;
117-
}
118114
119115
}
120116
// custom styles for icon selector

‎client/packages/lowcoder/src/comps/comps/lazyLoadComp/lazyLoadComp.tsx

+8-5
Original file line numberDiff line numberDiff line change
@@ -5,11 +5,12 @@ import { GreyTextColor } from "constants/style";
55
import log from "loglevel";
66
import { Comp, CompAction, CompConstructor, CompParams, customAction, isCustomAction } from "lowcoder-core";
77
import { WhiteLoading } from "lowcoder-design";
8-
import { useState } from "react";
8+
import { useContext, useState } from "react";
99
import { useMount } from "react-use";
1010
import styled from "styled-components";
11-
import { RemoteCompInfo, RemoteCompLoader } from "types/remoteComp";
11+
import { RemoteCompInfo } from "types/remoteComp";
1212
import { withErrorBoundary } from "comps/generators/withErrorBoundary";
13+
import { ThemeContext } from "@lowcoder-ee/comps/utils/themeContext";
1314

1415
const ViewError = styled.div`
1516
display: flex;
@@ -52,6 +53,8 @@ interface LazyCompViewProps {
5253
function LazyCompView(props: React.PropsWithChildren<LazyCompViewProps>) {
5354
const { loadComp, loadingElement, errorElement } = props;
5455
const [error, setError] = useState<any>("");
56+
const currentTheme = useContext(ThemeContext)?.theme;
57+
const showComponentLoadingIndicators = currentTheme?.showComponentLoadingIndicators;
5558

5659
useMount(() => {
5760
setError("");
@@ -71,14 +74,14 @@ function LazyCompView(props: React.PropsWithChildren<LazyCompViewProps>) {
7174
);
7275
}
7376

77+
if (!showComponentLoadingIndicators) return<></>;
78+
7479
if (loadingElement) {
7580
return <ViewLoadingWrapper>{loadingElement()}</ViewLoadingWrapper>;
7681
}
7782

7883
return (
79-
<ViewLoadingWrapper>
80-
<WhiteLoading />
81-
</ViewLoadingWrapper>
84+
<WhiteLoading />
8285
);
8386
}
8487

0 commit comments

Comments
 (0)