From 37a901ab680fcda2c2189db711191c9e0170f55a Mon Sep 17 00:00:00 2001 From: Imtanan Aziz Toor Date: Wed, 14 Feb 2024 21:18:20 +0500 Subject: [PATCH 1/5] font style property created and added in textDisplay component --- client/package.json | 1 + .../lowcoder/src/comps/comps/textComp.tsx | 9 +- .../src/comps/controls/styleControl.tsx | 471 +++++++++--------- .../comps/controls/styleControlConstants.tsx | 230 ++++----- .../packages/lowcoder/src/i18n/locales/en.ts | 1 + 5 files changed, 371 insertions(+), 341 deletions(-) diff --git a/client/package.json b/client/package.json index 2f49baf8c..6e1dff2dc 100644 --- a/client/package.json +++ b/client/package.json @@ -11,6 +11,7 @@ }, "scripts": { "start": "yarn workspace lowcoder start", + "start-win":"LOWCODER_API_SERVICE_URL=http://localhost:3000 yarn start", "start:ee": "REACT_APP_EDITION=enterprise yarn workspace lowcoder start", "start:ee-global": "REACT_APP_EDITION=enterprise-global yarn workspace lowcoder start", "build": "yarn node ./scripts/build.js", diff --git a/client/packages/lowcoder/src/comps/comps/textComp.tsx b/client/packages/lowcoder/src/comps/comps/textComp.tsx index 671e67354..4359166dd 100644 --- a/client/packages/lowcoder/src/comps/comps/textComp.tsx +++ b/client/packages/lowcoder/src/comps/comps/textComp.tsx @@ -29,6 +29,7 @@ const getStyle = (style: TextStyleType) => { font-size: ${style.textSize} !important; font-weight: ${style.textWeight} !important; font-family: ${style.fontFamily} !important; + font-style:${style.fontStyle} !important; background-color: ${style.background}; .markdown-body a { color: ${style.links}; @@ -111,7 +112,7 @@ const VerticalAlignmentOptions = [ ] as const; -let TextTmpComp = (function () { +let TextTmpComp = (function () { const childrenMap = { text: stringExposingStateControl( @@ -123,7 +124,7 @@ let TextTmpComp = (function () { horizontalAlignment: alignWithJustifyControl(), verticalAlignment: dropdownControl(VerticalAlignmentOptions, "center"), style: styleControl(TextStyle), - margin: MarginControl, + margin: MarginControl, padding: PaddingControl, }; return new UICompBuilder(childrenMap, (props) => { @@ -145,7 +146,7 @@ let TextTmpComp = (function () { .setPropertyViewFn((children) => { return ( <> - +
{children.type.propertyView({ label: trans("value"), @@ -160,7 +161,7 @@ let TextTmpComp = (function () { {hiddenPropertyView(children)}
)} - + {["layout", "both"].includes(useContext(EditorContext).editorModeStatus) && ( <>
diff --git a/client/packages/lowcoder/src/comps/controls/styleControl.tsx b/client/packages/lowcoder/src/comps/controls/styleControl.tsx index 669c450e3..7295a9783 100644 --- a/client/packages/lowcoder/src/comps/controls/styleControl.tsx +++ b/client/packages/lowcoder/src/comps/controls/styleControl.tsx @@ -36,6 +36,7 @@ import { TextSizeConfig, TextWeightConfig, FontFamilyConfig, + FontStyleConfig, BorderWidthConfig, BackgroundImageConfig, BackgroundImageRepeatConfig, @@ -136,13 +137,16 @@ function isTextWeightConfig(config: SingleColorConfig): config is TextWeightConf function isFontFamilyConfig(config: SingleColorConfig): config is FontFamilyConfig { return config.hasOwnProperty("fontFamily"); } +function isFontStyleConfig(config: SingleColorConfig): config is FontStyleConfig { + return config.hasOwnProperty("fontStyle"); +} -function isMarginConfig(config: SingleColorConfig): config is MarginConfig { - return config.hasOwnProperty("margin"); -} +function isMarginConfig(config: SingleColorConfig): config is MarginConfig { + return config.hasOwnProperty("margin"); +} -function isPaddingConfig(config: SingleColorConfig): config is PaddingConfig { - return config.hasOwnProperty("padding"); +function isPaddingConfig(config: SingleColorConfig): config is PaddingConfig { + return config.hasOwnProperty("padding"); } // function styleControl(colorConfig: Array) { @@ -215,12 +219,15 @@ function isEmptyTextWeight(textWeight: string) { function isEmptyFontFamily(fontFamily: string) { return _.isEmpty(fontFamily); } +function isEmptyFontStyle(fontStyle: string) { + return _.isEmpty(fontStyle); +} -function isEmptyMargin(margin: string) { - return _.isEmpty(margin); -} -function isEmptyPadding(padding: string) { - return _.isEmpty(padding); +function isEmptyMargin(margin: string) { + return _.isEmpty(margin); +} +function isEmptyPadding(padding: string) { + return _.isEmpty(padding); } /** @@ -237,93 +244,97 @@ function calcColors>( let res: Record = {}; colorConfigs.forEach((config) => { const name = config.name; - if (!isEmptyRadius(props[name]) && isRadiusConfig(config)) { - res[name] = props[name]; - return; - } - if (!isEmptyBorderWidth(props[name]) && isBorderWidthConfig(config)) { - res[name] = props[name]; - return; - } - if (!isEmptyBackgroundImageConfig(props[name]) && isBackgroundImageConfig(config)) { - res[name] = props[name]; - return; - } - if (!isEmptyBackgroundImageRepeatConfig(props[name]) && isBackgroundImageRepeatConfig(config)) { - res[name] = props[name]; - return; - } - if (!isEmptyBackgroundImageSizeConfig(props[name]) && isBackgroundImageSizeConfig(config)) { - res[name] = props[name]; - return; - } - if (!isEmptyBackgroundImagePositionConfig(props[name]) && isBackgroundImagePositionConfig(config)) { - res[name] = props[name]; - return; - } - if (!isEmptyBackgroundImageOriginConfig(props[name]) && isBackgroundImageOriginConfig(config)) { - res[name] = props[name]; - return; - } - if (!isEmptyHeaderBackgroundImageConfig(props[name]) && isHeaderBackgroundImageConfig(config)) { - res[name] = props[name]; - return; - } - if (!isEmptyHeaderBackgroundImageRepeatConfig(props[name]) && isHeaderBackgroundImageRepeatConfig(config)) { - res[name] = props[name]; - return; - } - if (!isEmptyHeaderBackgroundImageSizeConfig(props[name]) && isHeaderBackgroundImageSizeConfig(config)) { - res[name] = props[name]; - return; - } - if (!isEmptyHeaderBackgroundImagePositionConfig(props[name]) && isHeaderBackgroundImagePositionConfig(config)) { - res[name] = props[name]; - return; - } - if (!isEmptyHeaderBackgroundImageOriginConfig(props[name]) && isHeaderBackgroundImageOriginConfig(config)) { - res[name] = props[name]; - return; - } - if (!isEmptyFooterBackgroundImageConfig(props[name]) && isFooterBackgroundImageConfig(config)) { - res[name] = props[name]; - return; - } - if (!isEmptyFooterBackgroundImageRepeatConfig(props[name]) && isFooterBackgroundImageRepeatConfig(config)) { - res[name] = props[name]; - return; - } - if (!isEmptyFooterBackgroundImageSizeConfig(props[name]) && isFooterBackgroundImageSizeConfig(config)) { - res[name] = props[name]; - return; - } - if (!isEmptyFooterBackgroundImagePositionConfig(props[name]) && isFooterBackgroundImagePositionConfig(config)) { - res[name] = props[name]; - return; - } - if (!isEmptyFooterBackgroundImageOriginConfig(props[name]) && isFooterBackgroundImageOriginConfig(config)) { - res[name] = props[name]; - return; - } - if (!isEmptyTextSize(props[name]) && isTextSizeConfig(config)) { - res[name] = props[name]; - return; - } - if (!isEmptyTextWeight(props[name]) && isTextWeightConfig(config)) { - res[name] = props[name]; - return; - } - if (!isEmptyFontFamily(props[name]) && isFontFamilyConfig(config)) { - res[name] = props[name]; - return; - } - if (!isEmptyMargin(props[name]) && isMarginConfig(config)) { - res[name] = props[name]; - return; - } - if (!isEmptyPadding(props[name]) && isPaddingConfig(config)) { - res[name] = props[name]; - return; + if (!isEmptyRadius(props[name]) && isRadiusConfig(config)) { + res[name] = props[name]; + return; + } + if (!isEmptyBorderWidth(props[name]) && isBorderWidthConfig(config)) { + res[name] = props[name]; + return; + } + if (!isEmptyBackgroundImageConfig(props[name]) && isBackgroundImageConfig(config)) { + res[name] = props[name]; + return; + } + if (!isEmptyBackgroundImageRepeatConfig(props[name]) && isBackgroundImageRepeatConfig(config)) { + res[name] = props[name]; + return; + } + if (!isEmptyBackgroundImageSizeConfig(props[name]) && isBackgroundImageSizeConfig(config)) { + res[name] = props[name]; + return; + } + if (!isEmptyBackgroundImagePositionConfig(props[name]) && isBackgroundImagePositionConfig(config)) { + res[name] = props[name]; + return; + } + if (!isEmptyBackgroundImageOriginConfig(props[name]) && isBackgroundImageOriginConfig(config)) { + res[name] = props[name]; + return; + } + if (!isEmptyHeaderBackgroundImageConfig(props[name]) && isHeaderBackgroundImageConfig(config)) { + res[name] = props[name]; + return; + } + if (!isEmptyHeaderBackgroundImageRepeatConfig(props[name]) && isHeaderBackgroundImageRepeatConfig(config)) { + res[name] = props[name]; + return; + } + if (!isEmptyHeaderBackgroundImageSizeConfig(props[name]) && isHeaderBackgroundImageSizeConfig(config)) { + res[name] = props[name]; + return; + } + if (!isEmptyHeaderBackgroundImagePositionConfig(props[name]) && isHeaderBackgroundImagePositionConfig(config)) { + res[name] = props[name]; + return; + } + if (!isEmptyHeaderBackgroundImageOriginConfig(props[name]) && isHeaderBackgroundImageOriginConfig(config)) { + res[name] = props[name]; + return; + } + if (!isEmptyFooterBackgroundImageConfig(props[name]) && isFooterBackgroundImageConfig(config)) { + res[name] = props[name]; + return; + } + if (!isEmptyFooterBackgroundImageRepeatConfig(props[name]) && isFooterBackgroundImageRepeatConfig(config)) { + res[name] = props[name]; + return; + } + if (!isEmptyFooterBackgroundImageSizeConfig(props[name]) && isFooterBackgroundImageSizeConfig(config)) { + res[name] = props[name]; + return; + } + if (!isEmptyFooterBackgroundImagePositionConfig(props[name]) && isFooterBackgroundImagePositionConfig(config)) { + res[name] = props[name]; + return; + } + if (!isEmptyFooterBackgroundImageOriginConfig(props[name]) && isFooterBackgroundImageOriginConfig(config)) { + res[name] = props[name]; + return; + } + if (!isEmptyTextSize(props[name]) && isTextSizeConfig(config)) { + res[name] = props[name]; + return; + } + if (!isEmptyTextWeight(props[name]) && isTextWeightConfig(config)) { + res[name] = props[name]; + return; + } + if (!isEmptyFontFamily(props[name]) && isFontFamilyConfig(config)) { + res[name] = props[name]; + return; + } + if (!isEmptyFontStyle(props[name]) && isFontStyleConfig(config)) { + res[name] = props[name]; + return; + } + if (!isEmptyMargin(props[name]) && isMarginConfig(config)) { + res[name] = props[name]; + return; + } + if (!isEmptyPadding(props[name]) && isPaddingConfig(config)) { + res[name] = props[name]; + return; } if (!isEmptyColor(props[name])) { if (isThemeColorKey(props[name])) { @@ -398,11 +409,14 @@ function calcColors>( if (isFontFamilyConfig(config)) { res[name] = themeWithDefault[config.fontFamily] || 'sans-serif'; } - if (isMarginConfig(config)) { - res[name] = themeWithDefault[config.margin]; - } - if (isPaddingConfig(config)) { - res[name] = themeWithDefault[config.padding]; + if (isFontStyleConfig(config)) { + res[name] = themeWithDefault[config.fontStyle] || 'normal' + } + if (isMarginConfig(config)) { + res[name] = themeWithDefault[config.margin]; + } + if (isPaddingConfig(config)) { + res[name] = themeWithDefault[config.padding]; } }); // The second pass calculates dep @@ -509,7 +523,7 @@ const StyleContent = styled.div` const RadiusIcon = styled(IconRadius)` margin: 0 8px 0 -2px;`; const BorderIcon = styled(BorderWidthIcon)` margin: 0 8px 0 -3px; padding: 3px;`; -const MarginIcon = styled(ExpandIcon)` margin: 0 8px 0 2px;`; +const MarginIcon = styled(ExpandIcon)` margin: 0 8px 0 2px;`; const PaddingIcon = styled(CompressIcon)` margin: 0 8px 0 2px;`; const StyledTextSizeIcon = styled(TextSizeIcon)` margin: 0 8px 0 -3px; padding: 3px;`; const StyledFontFamilyIcon = styled(FontFamilyIcon)` margin: 0 8px 0 -3px; padding: 3px;`; @@ -527,13 +541,14 @@ export function styleControl(colorConfig const childrenMap: any = {}; colorConfigs.map((config) => { const name: Names = config.name; - if ( + if ( name === "radius" || name === "borderWidth" || name === "cardRadius" || - name === "textSize" || + name === "textSize" || name === "textWeight" || name === "fontFamily" || + name === "fontStyle" || name === "backgroundImage" || name === "backgroundImageRepeat" || name === "backgroundImageSize" || @@ -549,15 +564,15 @@ export function styleControl(colorConfig name === "footerBackgroundImageSize" || name === "footerBackgroundImagePosition" || name === "footerBackgroundImageOrigin" || - name === "margin" || - name === "padding" || - name === "containerheaderpadding" || - name === "containerfooterpadding" || + name === "margin" || + name === "padding" || + name === "containerheaderpadding" || + name === "containerfooterpadding" || name === "containerbodypadding" - ) { - childrenMap[name] = StringControl; - } else { - childrenMap[name] = ColorControl; + ) { + childrenMap[name] = StringControl; + } else { + childrenMap[name] = ColorControl; } }); // [K in Names]: new (params: CompParams) => ColorControl; @@ -593,12 +608,12 @@ export function styleControl(colorConfig onClick={() => { colorConfigs.map((item) => { const name: Names = item.name; - if ( - name === "radius" || - name === "margin" || + if ( + name === "radius" || + name === "margin" || name === "padding" || - name === "containerheaderpadding" || - name === "containerfooterpadding" || + name === "containerheaderpadding" || + name === "containerfooterpadding" || name === "containerbodypadding" || name === "borderWidth" || name === "backgroundImage" || @@ -653,115 +668,123 @@ export function styleControl(colorConfig } return controlItem( { filterText: config.label }, -
+
{(name === "radius" || - name === "gap" || - name === "cardRadius") - ? ( - children[name] as InstanceType - ).propertyView({ - label: config.label, - preInputNode: , - placeholder: props[name], - }) - : name === "borderWidth" - ? ( - children[name] as InstanceType - ).propertyView({ - label: config.label, - preInputNode: , - placeholder: props[name], - }) - : name === "margin" - ? ( - children[name] as InstanceType - ).propertyView({ - label: config.label, - preInputNode: , - placeholder: props[name], - }) - : (name === "padding" || - name === "containerheaderpadding" || - name === "containerfooterpadding" || - name === "containerbodypadding") - ? ( - children[name] as InstanceType - ).propertyView({ - label: config.label, - preInputNode: , - placeholder: props[name], - }) - : name === "textSize" - ? ( - children[name] as InstanceType - ).propertyView({ - label: config.label, - preInputNode: , - placeholder: props[name], - }) - : name === "textWeight" - ? ( - children[name] as InstanceType - ).propertyView({ - label: config.label, - preInputNode: , - placeholder: props[name], - }) - : name === "fontFamily" - ? ( - children[name] as InstanceType - ).propertyView({ + name === "gap" || + name === "cardRadius") + ? ( + children[name] as InstanceType + ).propertyView({ + label: config.label, + preInputNode: , + placeholder: props[name], + }) + : name === "borderWidth" + ? ( + children[name] as InstanceType + ).propertyView({ label: config.label, - preInputNode: , - placeholder: props[name], - }) - : name === "backgroundImage" || name === "headerBackgroundImage" || name === "footerBackgroundImage" - ? ( - children[name] as InstanceType - ).propertyView({ - label: config.label, - preInputNode: , - placeholder: props[name], - }) - : name === "backgroundImageRepeat" || name === "headerBackgroundImageRepeat" || name === "footerBackgroundImageRepeat" - ? ( - children[name] as InstanceType - ).propertyView({ - label: config.label, - preInputNode: , - placeholder: props[name], - }) - : name === "backgroundImageSize" || name === "headerBackgroundImageSize" || name === "footerBackgroundImageSize" - ? ( - children[name] as InstanceType - ).propertyView({ - label: config.label, - preInputNode: , - placeholder: props[name], + preInputNode: , + placeholder: props[name], }) - : name === "backgroundImagePosition" || name === "headerBackgroundImagePosition" || name === "footerBackgroundImagePosition" - ? ( - children[name] as InstanceType - ).propertyView({ - label: config.label, - preInputNode: , - placeholder: props[name], - }) - : name === "backgroundImageOrigin" || name === "headerBackgroundImageOrigin" || name === "footerBackgroundImageOrigin" - ? ( - children[name] as InstanceType - ).propertyView({ - label: config.label, - preInputNode: , - placeholder: props[name], - }) - : children[name].propertyView({ - label: config.label, - panelDefaultColor: props[name], - // isDep: isDepColorConfig(config), - isDep: true, - depMsg: depMsg, - })} + : name === "margin" + ? ( + children[name] as InstanceType + ).propertyView({ + label: config.label, + preInputNode: , + placeholder: props[name], + }) + : (name === "padding" || + name === "containerheaderpadding" || + name === "containerfooterpadding" || + name === "containerbodypadding") + ? ( + children[name] as InstanceType + ).propertyView({ + label: config.label, + preInputNode: , + placeholder: props[name], + }) + : name === "textSize" + ? ( + children[name] as InstanceType + ).propertyView({ + label: config.label, + preInputNode: , + placeholder: props[name], + }) + : name === "textWeight" + ? ( + children[name] as InstanceType + ).propertyView({ + label: config.label, + preInputNode: , + placeholder: props[name], + }) + : name === "fontFamily" + ? ( + children[name] as InstanceType + ).propertyView({ + label: config.label, + preInputNode: , + placeholder: props[name], + }) + : name === "fontStyle" + ? ( + children[name] as InstanceType + ).propertyView({ + label: config.label, + preInputNode: , + placeholder: props[name], + }) + : name === "backgroundImage" || name === "headerBackgroundImage" || name === "footerBackgroundImage" + ? ( + children[name] as InstanceType + ).propertyView({ + label: config.label, + preInputNode: , + placeholder: props[name], + }) + : name === "backgroundImageRepeat" || name === "headerBackgroundImageRepeat" || name === "footerBackgroundImageRepeat" + ? ( + children[name] as InstanceType + ).propertyView({ + label: config.label, + preInputNode: , + placeholder: props[name], + }) + : name === "backgroundImageSize" || name === "headerBackgroundImageSize" || name === "footerBackgroundImageSize" + ? ( + children[name] as InstanceType + ).propertyView({ + label: config.label, + preInputNode: , + placeholder: props[name], + }) + : name === "backgroundImagePosition" || name === "headerBackgroundImagePosition" || name === "footerBackgroundImagePosition" + ? ( + children[name] as InstanceType + ).propertyView({ + label: config.label, + preInputNode: , + placeholder: props[name], + }) + : name === "backgroundImageOrigin" || name === "headerBackgroundImageOrigin" || name === "footerBackgroundImageOrigin" + ? ( + children[name] as InstanceType + ).propertyView({ + label: config.label, + preInputNode: , + placeholder: props[name], + }) + : children[name].propertyView({ + label: config.label, + panelDefaultColor: props[name], + // isDep: isDepColorConfig(config), + isDep: true, + depMsg: depMsg, + })}
); })} diff --git a/client/packages/lowcoder/src/comps/controls/styleControlConstants.tsx b/client/packages/lowcoder/src/comps/controls/styleControlConstants.tsx index 5dea81d30..3df7ba687 100644 --- a/client/packages/lowcoder/src/comps/controls/styleControlConstants.tsx +++ b/client/packages/lowcoder/src/comps/controls/styleControlConstants.tsx @@ -1,7 +1,7 @@ import { ThemeDetail } from "api/commonSettingApi"; import { darkenColor, isDarkColor, lightenColor, toHex } from "lowcoder-design"; import { trans } from "i18n"; -import { StyleConfigType } from "./styleControl"; +import { StyleConfigType } from "./styleControl"; type SupportPlatform = "pc" | "mobile"; @@ -23,21 +23,21 @@ export type BorderWidthConfig = CommonColorConfig & { export type BackgroundImageConfig = CommonColorConfig & { readonly backgroundImage: string; }; export type BackgroundImageRepeatConfig = CommonColorConfig & { readonly backgroundImageRepeat: string; }; -export type BackgroundImageSizeConfig = CommonColorConfig & { readonly backgroundImageSize: string;}; +export type BackgroundImageSizeConfig = CommonColorConfig & { readonly backgroundImageSize: string; }; export type BackgroundImagePositionConfig = CommonColorConfig & { readonly backgroundImagePosition: string; }; -export type BackgroundImageOriginConfig = CommonColorConfig & { readonly backgroundImageOrigin: string;}; +export type BackgroundImageOriginConfig = CommonColorConfig & { readonly backgroundImageOrigin: string; }; export type HeaderBackgroundImageConfig = CommonColorConfig & { readonly headerBackgroundImage: string; }; export type HeaderBackgroundImageRepeatConfig = CommonColorConfig & { readonly headerBackgroundImageRepeat: string; }; -export type HeaderBackgroundImageSizeConfig = CommonColorConfig & { readonly headerBackgroundImageSize: string;}; +export type HeaderBackgroundImageSizeConfig = CommonColorConfig & { readonly headerBackgroundImageSize: string; }; export type HeaderBackgroundImagePositionConfig = CommonColorConfig & { readonly headerBackgroundImagePosition: string; }; -export type HeaderBackgroundImageOriginConfig = CommonColorConfig & { readonly headerBackgroundImageOrigin: string;}; +export type HeaderBackgroundImageOriginConfig = CommonColorConfig & { readonly headerBackgroundImageOrigin: string; }; export type FooterBackgroundImageConfig = CommonColorConfig & { readonly footerBackgroundImage: string; }; export type FooterBackgroundImageRepeatConfig = CommonColorConfig & { readonly footerBackgroundImageRepeat: string; }; -export type FooterBackgroundImageSizeConfig = CommonColorConfig & { readonly footerBackgroundImageSize: string;}; +export type FooterBackgroundImageSizeConfig = CommonColorConfig & { readonly footerBackgroundImageSize: string; }; export type FooterBackgroundImagePositionConfig = CommonColorConfig & { readonly footerBackgroundImagePosition: string; }; -export type FooterBackgroundImageOriginConfig = CommonColorConfig & { readonly footerBackgroundImageOrigin: string;}; +export type FooterBackgroundImageOriginConfig = CommonColorConfig & { readonly footerBackgroundImageOrigin: string; }; export type TextSizeConfig = CommonColorConfig & { readonly textSize: string; @@ -51,6 +51,10 @@ export type FontFamilyConfig = CommonColorConfig & { readonly fontFamily: string; }; +export type FontStyleConfig = CommonColorConfig & { + readonly fontStyle: string; +} + export type ContainerHeaderPaddigConfig = CommonColorConfig & { readonly containerheaderpadding: string; }; @@ -63,11 +67,11 @@ export type ContainerFooterPaddigConfig = CommonColorConfig & { readonly containerfooterpadding: string; }; -export type MarginConfig = CommonColorConfig & { - readonly margin: string; -}; -export type PaddingConfig = CommonColorConfig & { - readonly padding: string; +export type MarginConfig = CommonColorConfig & { + readonly margin: string; +}; +export type PaddingConfig = CommonColorConfig & { + readonly padding: string; }; export type DepColorConfig = CommonColorConfig & { @@ -76,7 +80,7 @@ export type DepColorConfig = CommonColorConfig & { readonly depType?: DEP_TYPE; transformer: (color: string, ...rest: string[]) => string; }; -export type SingleColorConfig = SimpleColorConfig | DepColorConfig | RadiusConfig | BorderWidthConfig | BackgroundImageConfig | BackgroundImageRepeatConfig | BackgroundImageSizeConfig | BackgroundImagePositionConfig | BackgroundImageOriginConfig | TextSizeConfig | TextWeightConfig | FontFamilyConfig | MarginConfig | PaddingConfig | ContainerHeaderPaddigConfig | ContainerFooterPaddigConfig | ContainerBodyPaddigConfig | HeaderBackgroundImageConfig | HeaderBackgroundImageRepeatConfig | HeaderBackgroundImageSizeConfig | HeaderBackgroundImagePositionConfig | HeaderBackgroundImageOriginConfig | FooterBackgroundImageConfig | FooterBackgroundImageRepeatConfig | FooterBackgroundImageSizeConfig | FooterBackgroundImagePositionConfig | FooterBackgroundImageOriginConfig; +export type SingleColorConfig = SimpleColorConfig | DepColorConfig | RadiusConfig | BorderWidthConfig | BackgroundImageConfig | BackgroundImageRepeatConfig | BackgroundImageSizeConfig | BackgroundImagePositionConfig | BackgroundImageOriginConfig | TextSizeConfig | TextWeightConfig | FontFamilyConfig | FontStyleConfig | MarginConfig | PaddingConfig | ContainerHeaderPaddigConfig | ContainerFooterPaddigConfig | ContainerBodyPaddigConfig | HeaderBackgroundImageConfig | HeaderBackgroundImageRepeatConfig | HeaderBackgroundImageSizeConfig | HeaderBackgroundImagePositionConfig | HeaderBackgroundImageOriginConfig | FooterBackgroundImageConfig | FooterBackgroundImageRepeatConfig | FooterBackgroundImageSizeConfig | FooterBackgroundImagePositionConfig | FooterBackgroundImageOriginConfig; export const defaultTheme: ThemeDetail = { primary: "#3377FF", @@ -85,7 +89,7 @@ export const defaultTheme: ThemeDetail = { canvas: "#F5F5F6", primarySurface: "#FFFFFF", borderRadius: "4px", - margin: "3px", + margin: "3px", padding: "3px", gridColumns: "24", textSize: "14px", @@ -322,61 +326,67 @@ const BACKGROUND_IMAGE_ORIGIN = { backgroundImageOrigin: "backgroundImageOrigin", } as const; -const MARGIN = { - name: "margin", - label: trans("style.margin"), - margin: "margin", -} as const; +const MARGIN = { + name: "margin", + label: trans("style.margin"), + margin: "margin", +} as const; -const PADDING = { - name: "padding", - label: trans("style.padding"), - padding: "padding", +const PADDING = { + name: "padding", + label: trans("style.padding"), + padding: "padding", } as const; -const TEXT_SIZE = { +const TEXT_SIZE = { name: "textSize", - label: trans("style.textSize"), - textSize: "textSize", + label: trans("style.textSize"), + textSize: "textSize", } as const; -const TEXT_WEIGHT = { +const TEXT_WEIGHT = { name: "textWeight", - label: trans("style.textWeight"), - textWeight: "textWeight", + label: trans("style.textWeight"), + textWeight: "textWeight", } as const; -const FONT_FAMILY = { +const FONT_FAMILY = { name: "fontFamily", - label: trans("style.fontFamily"), - fontFamily: "fontFamily", + label: trans("style.fontFamily"), + fontFamily: "fontFamily", } as const; -const CONTAINERHEADERPADDING = { - name: "containerheaderpadding", - label: trans("style.containerheaderpadding"), - containerheaderpadding: "padding", +const FONT_STYLE = { + name: "fontStyle", + label: trans("style.fontStyle"), + fontStyle: "fontStyle", +} as const + +const CONTAINERHEADERPADDING = { + name: "containerheaderpadding", + label: trans("style.containerheaderpadding"), + containerheaderpadding: "padding", } as const; -const CONTAINERFOOTERPADDING = { - name: "containerfooterpadding", - label: trans("style.containerfooterpadding"), - containerfooterpadding: "padding", +const CONTAINERFOOTERPADDING = { + name: "containerfooterpadding", + label: trans("style.containerfooterpadding"), + containerfooterpadding: "padding", } as const; -const CONTAINERBODYPADDING = { - name: "containerbodypadding", - label: trans("style.containerbodypadding"), - containerbodypadding: "padding", +const CONTAINERBODYPADDING = { + name: "containerbodypadding", + label: trans("style.containerbodypadding"), + containerbodypadding: "padding", } as const; const getStaticBorder = (color: string = SECOND_SURFACE_COLOR) => - ({ - name: "border", - label: trans("style.border"), - color, - } as const); +({ + name: "border", + label: trans("style.border"), + color, +} as const); const HEADER_BACKGROUND = { name: "headerBackground", @@ -439,13 +449,13 @@ function getStaticBackground(color: string) { } export const ButtonStyle = [ - ...getBgBorderRadiusByBg("primary"), + ...getBgBorderRadiusByBg("primary"), BORDER_WIDTH, - TEXT, + TEXT, TEXT_SIZE, TEXT_WEIGHT, FONT_FAMILY, - MARGIN, + MARGIN, PADDING ] as const; @@ -464,7 +474,7 @@ export const ToggleButtonStyle = [ TEXT_SIZE, TEXT_WEIGHT, FONT_FAMILY, - MARGIN, + MARGIN, PADDING, ] as const; @@ -480,8 +490,9 @@ export const TextStyle = [ TEXT_SIZE, TEXT_WEIGHT, FONT_FAMILY, + FONT_STYLE, BORDER, - MARGIN, + MARGIN, PADDING, { name: "links", @@ -491,16 +502,16 @@ export const TextStyle = [ transformer: toSelf, }, RADIUS, - BORDER_WIDTH + BORDER_WIDTH, ] as const; -export const MarginStyle = [ - { - name: "margin", - label: trans("style.margin"), - margin: "margin", - }, -]; +export const MarginStyle = [ + { + name: "margin", + label: trans("style.margin"), + margin: "margin", + }, +]; export const ContainerStyle = [ @@ -508,7 +519,7 @@ export const ContainerStyle = [ getStaticBorder(), RADIUS, BORDER_WIDTH, - MARGIN, + MARGIN, PADDING, { name: "background", @@ -567,7 +578,7 @@ export const ContainerHeaderStyle = [ label: trans("style.backgroundImagePosition"), headerBackgroundImagePosition: "headerBackgroundImagePosition", } - ,{ + , { name: "headerBackgroundImageOrigin", label: trans("style.backgroundImageOrigin"), headerBackgroundImageOrigin: "headerBackgroundImageOrigin", @@ -639,7 +650,7 @@ export const ContainerFooterStyle = [ label: trans("style.backgroundImagePosition"), footerBackgroundImagePosition: "footerBackgroundImagePosition", } - ,{ + , { name: "footerBackgroundImageOrigin", label: trans("style.backgroundImageOrigin"), footerBackgroundImageOrigin: "footerBackgroundImageOrigin", @@ -662,7 +673,7 @@ export const SliderStyle = [ color: SURFACE_COLOR, }, TRACK, - MARGIN, + MARGIN, PADDING, ] as const; @@ -674,7 +685,7 @@ export const InputLikeStyle = [ TEXT_SIZE, TEXT_WEIGHT, FONT_FAMILY, - MARGIN, + MARGIN, PADDING, ...ACCENT_VALIDATE, ] as const; @@ -691,7 +702,7 @@ export const RatingStyle = [ label: trans("style.unchecked"), color: SECOND_SURFACE_COLOR, }, - MARGIN, + MARGIN, PADDING, ] as const; @@ -715,7 +726,7 @@ export const SwitchStyle = [ depType: DEP_TYPE.SELF, transformer: toSelf, }, - MARGIN, + MARGIN, PADDING, ] as const; @@ -723,7 +734,7 @@ export const SelectStyle = [ LABEL, ...getStaticBgBorderRadiusByBg(SURFACE_COLOR, "pc"), TEXT, - MARGIN, + MARGIN, PADDING, ...ACCENT_VALIDATE, ] as const; @@ -732,7 +743,7 @@ const multiSelectCommon = [ LABEL, ...getStaticBgBorderRadiusByBg(SURFACE_COLOR, "pc"), TEXT, - MARGIN, + MARGIN, PADDING, { name: "tags", @@ -784,7 +795,7 @@ export const TabContainerStyle = [ export const ModalStyle = [ ...getBgBorderRadiusByBg(), BORDER_WIDTH, - MARGIN, + MARGIN, PADDING, BACKGROUND_IMAGE, BACKGROUND_IMAGE_REPEAT, @@ -798,7 +809,7 @@ export const CascaderStyle = [ ...getStaticBgBorderRadiusByBg(SURFACE_COLOR, "pc"), TEXT, ACCENT, - MARGIN, + MARGIN, PADDING, ] as const; @@ -838,7 +849,7 @@ export const CheckboxStyle = [ RADIUS, STATIC_TEXT, VALIDATE, - MARGIN, + MARGIN, PADDING, ] as const; @@ -854,7 +865,7 @@ export const RadioStyle = [ }, STATIC_TEXT, VALIDATE, - MARGIN, + MARGIN, PADDING, ] as const; @@ -880,7 +891,7 @@ export const SegmentStyle = [ }, RADIUS, VALIDATE, - MARGIN, + MARGIN, PADDING, ] as const; @@ -1001,7 +1012,7 @@ export const FileViewerStyle = [ getStaticBackground("#FFFFFF"), getStaticBorder("#00000000"), RADIUS, - MARGIN, + MARGIN, PADDING, BORDER_WIDTH ] as const; @@ -1012,7 +1023,7 @@ export const DateTimeStyle = [ LABEL, ...getStaticBgBorderRadiusByBg(SURFACE_COLOR), TEXT, - MARGIN, + MARGIN, PADDING, ...ACCENT_VALIDATE, ] as const; @@ -1027,7 +1038,7 @@ function handleToHoverLink(color: string) { export const LinkStyle = [ ...LinkTextStyle, - MARGIN, + MARGIN, PADDING, TEXT_SIZE ] as const; @@ -1039,7 +1050,7 @@ export const DividerStyle = [ color: lightenColor(SECOND_SURFACE_COLOR, 0.05), }, BORDER_WIDTH, - MARGIN, + MARGIN, PADDING, { name: "text", @@ -1063,7 +1074,7 @@ export const ProgressStyle = [ TRACK, FILL, SUCCESS, - MARGIN, + MARGIN, PADDING, ] as const; @@ -1078,7 +1089,7 @@ export const NavigationStyle = [ ACCENT, getStaticBackground("#FFFFFF00"), getStaticBorder("#FFFFFF00"), - MARGIN, + MARGIN, PADDING, ] as const; @@ -1095,7 +1106,7 @@ export const QRCodeStyle = [ label: trans("color"), color: "#000000", }, - MARGIN, + MARGIN, PADDING, BORDER, RADIUS, @@ -1119,7 +1130,7 @@ export const TimeLineStyle = [ label: trans("timeLine.subTitleColor"), color: "#848484", }, - MARGIN, + MARGIN, PADDING, RADIUS ] as const; @@ -1199,7 +1210,7 @@ export const SignatureStyle = [ label: trans("style.footerIcon"), color: "#222222", }, - MARGIN, + MARGIN, PADDING, BORDER_WIDTH ] as const; @@ -1213,7 +1224,7 @@ export const LottieStyle = [ depType: DEP_TYPE.SELF, transformer: toSelf, }, - MARGIN, + MARGIN, PADDING, ] as const; ///////////////////// @@ -1225,19 +1236,19 @@ export const CommentStyle = [ depType: DEP_TYPE.SELF, transformer: toSelf, }, - MARGIN, + MARGIN, PADDING, RADIUS, ] as const export const ResponsiveLayoutRowStyle = [ ...BG_STATIC_BORDER_RADIUS, - MARGIN, + MARGIN, PADDING, ] as const; export const ResponsiveLayoutColStyle = [ ...BG_STATIC_BORDER_RADIUS, - MARGIN, + MARGIN, PADDING, ] as const; @@ -1297,9 +1308,9 @@ export const NavLayoutItemActiveStyle = [ export const CarouselStyle = [getBackground("canvas")] as const; export const RichTextEditorStyle = [ - getStaticBorder(), - getBackground("primarySurface"), - RADIUS, + getStaticBorder(), + getBackground("primarySurface"), + RADIUS, BORDER_WIDTH ] as const; @@ -1354,43 +1365,36 @@ export type NavLayoutItemHoverStyleType = StyleConfigType; export function widthCalculator(margin: string) { - const marginArr = margin?.trim().replace(/\s+/g,' ').split(" ") || ""; + const marginArr = margin?.trim().replace(/\s+/g, ' ').split(" ") || ""; if (marginArr.length === 1) { - return `calc(100% - ${ - parseInt(margin.replace(/[^\d.]/g, "")) * 2 + + return `calc(100% - ${parseInt(margin.replace(/[^\d.]/g, "")) * 2 + (margin.replace(/[0-9]/g, "") || "px") - })`; + })`; } else if (marginArr.length === 2 || marginArr.length === 3) { - return `calc(100% - ${ - parseInt(marginArr[1].replace(/[^\d.]/g, "")) * 2 + + return `calc(100% - ${parseInt(marginArr[1].replace(/[^\d.]/g, "")) * 2 + (marginArr[1].replace(/[0-9]/g, "") || 'px') - })`; + })`; } else { - return `calc(100% - ${ - parseInt(marginArr[1]?.replace(/[^\d.]/g, "") || "0") + + return `calc(100% - ${parseInt(marginArr[1]?.replace(/[^\d.]/g, "") || "0") + (marginArr[1]?.replace(/[0-9]/g, "") || "px") - } - ${ - parseInt(marginArr[3]?.replace(/[^\d.]/g, "") || "0") + + } - ${parseInt(marginArr[3]?.replace(/[^\d.]/g, "") || "0") + (marginArr[3]?.replace(/[0-9]/g, "") || "px") - })`; + })`; } } export function heightCalculator(margin: string) { const marginArr = margin?.trim().split(" ") || ""; if (marginArr.length === 1 || marginArr.length === 2) { - return `calc(100% - ${ - parseInt(marginArr[0].replace(/[^\d.]/g, "")) * 2 + + return `calc(100% - ${parseInt(marginArr[0].replace(/[^\d.]/g, "")) * 2 + (marginArr[0].replace(/[0-9]/g, "") || 'px') - })`; - }else if(marginArr.length >2){ - return `calc(100% - ${ - parseInt(marginArr[0]?.replace(/[^\d.]/g, "") || "0") + + })`; + } else if (marginArr.length > 2) { + return `calc(100% - ${parseInt(marginArr[0]?.replace(/[^\d.]/g, "") || "0") + (marginArr[0]?.replace(/[0-9]/g, "") || "px") - } - ${ - parseInt(marginArr[2]?.replace(/[^\d.]/g, "") || "0") + + } - ${parseInt(marginArr[2]?.replace(/[^\d.]/g, "") || "0") + (marginArr[2]?.replace(/[0-9]/g, "") || "px") - })`; + })`; } } diff --git a/client/packages/lowcoder/src/i18n/locales/en.ts b/client/packages/lowcoder/src/i18n/locales/en.ts index 9cc91a970..fc05496d4 100644 --- a/client/packages/lowcoder/src/i18n/locales/en.ts +++ b/client/packages/lowcoder/src/i18n/locales/en.ts @@ -361,6 +361,7 @@ export const en = { "textSize": "Text Size", "textWeight": "Text Weight", "fontFamily": "Font Family", + "fontStyle":"Font Style", "backgroundImage": "BG Image", "backgroundImageRepeat": "BG Repeat", "backgroundImageSize": "BG Size", From 85926955f5e9cffc1d4baaba51e75f58a5f7f38f Mon Sep 17 00:00:00 2001 From: Imtanan Aziz Toor Date: Thu, 15 Feb 2024 19:32:08 +0500 Subject: [PATCH 2/5] text-area font syle added --- .../textInputComp/textInputConstants.tsx | 9 +- .../comps/controls/styleControlConstants.tsx | 1 + ....timestamp-1708005283355-9ba212c9a46a4.mjs | 331 ++++++++++++++++++ 3 files changed, 337 insertions(+), 4 deletions(-) create mode 100644 client/packages/lowcoder/vite.config.mts.timestamp-1708005283355-9ba212c9a46a4.mjs diff --git a/client/packages/lowcoder/src/comps/comps/textInputComp/textInputConstants.tsx b/client/packages/lowcoder/src/comps/comps/textInputComp/textInputConstants.tsx index 291c04077..5a2438245 100644 --- a/client/packages/lowcoder/src/comps/comps/textInputComp/textInputConstants.tsx +++ b/client/packages/lowcoder/src/comps/comps/textInputComp/textInputConstants.tsx @@ -229,6 +229,7 @@ export function getStyle(style: InputLikeStyleType) { font-size: ${style.textSize}; font-weight: ${style.textWeight}; font-family: ${style.fontFamily}; + font-style:${style.fontStyle}; background-color: ${style.background}; border-color: ${style.border}; @@ -275,10 +276,10 @@ export const inputRefMethods = [ ]; export function checkMentionListData(data: any) { - if(data === "") return {} - for(const key in data) { - check(data[key], ["array"], key,(node)=>{ - check(node, ["string"], ); + if (data === "") return {} + for (const key in data) { + check(data[key], ["array"], key, (node) => { + check(node, ["string"],); return node }) } diff --git a/client/packages/lowcoder/src/comps/controls/styleControlConstants.tsx b/client/packages/lowcoder/src/comps/controls/styleControlConstants.tsx index 3df7ba687..f8fa415a8 100644 --- a/client/packages/lowcoder/src/comps/controls/styleControlConstants.tsx +++ b/client/packages/lowcoder/src/comps/controls/styleControlConstants.tsx @@ -685,6 +685,7 @@ export const InputLikeStyle = [ TEXT_SIZE, TEXT_WEIGHT, FONT_FAMILY, + FONT_STYLE, MARGIN, PADDING, ...ACCENT_VALIDATE, diff --git a/client/packages/lowcoder/vite.config.mts.timestamp-1708005283355-9ba212c9a46a4.mjs b/client/packages/lowcoder/vite.config.mts.timestamp-1708005283355-9ba212c9a46a4.mjs new file mode 100644 index 000000000..8600472a2 --- /dev/null +++ b/client/packages/lowcoder/vite.config.mts.timestamp-1708005283355-9ba212c9a46a4.mjs @@ -0,0 +1,331 @@ +// vite.config.mts +import dotenv from "file:///C:/Projects/lowcoder/client/node_modules/dotenv/lib/main.js"; +import { defineConfig } from "file:///C:/Projects/lowcoder/client/node_modules/vite/dist/node/index.js"; +import react from "file:///C:/Projects/lowcoder/client/node_modules/@vitejs/plugin-react/dist/index.mjs"; +import viteTsconfigPaths from "file:///C:/Projects/lowcoder/client/node_modules/vite-tsconfig-paths/dist/index.mjs"; +import svgrPlugin from "file:///C:/Projects/lowcoder/client/node_modules/vite-plugin-svgr/dist/index.mjs"; +import checker from "file:///C:/Projects/lowcoder/client/node_modules/vite-plugin-checker/dist/esm/main.js"; +import { visualizer } from "file:///C:/Projects/lowcoder/client/node_modules/rollup-plugin-visualizer/dist/plugin/index.js"; +import path from "path"; +import chalk from "file:///C:/Projects/lowcoder/client/node_modules/chalk/source/index.js"; +import { createHtmlPlugin } from "file:///C:/Projects/lowcoder/client/node_modules/vite-plugin-html/dist/index.mjs"; + +// src/dev-utils/util.js +function ensureLastSlash(str) { + if (!str) { + return "/"; + } + if (!str.endsWith("/")) { + return `${str}/`; + } + return str; +} + +// src/dev-utils/buildVars.js +var buildVars = [ + { + name: "PUBLIC_URL", + defaultValue: "/" + }, + { + name: "REACT_APP_EDITION", + defaultValue: "community" + }, + { + name: "REACT_APP_LANGUAGES", + defaultValue: "" + }, + { + name: "REACT_APP_COMMIT_ID", + defaultValue: "00000" + }, + { + name: "REACT_APP_API_HOST", + defaultValue: "" + }, + { + name: "LOWCODER_NODE_SERVICE_URL", + defaultValue: "" + }, + { + name: "REACT_APP_ENV", + defaultValue: "production" + }, + { + name: "REACT_APP_BUILD_ID", + defaultValue: "" + }, + { + name: "REACT_APP_LOG_LEVEL", + defaultValue: "error" + }, + { + name: "REACT_APP_IMPORT_MAP", + defaultValue: "{}" + }, + { + name: "REACT_APP_SERVER_IPS", + defaultValue: "" + }, + { + name: "REACT_APP_BUNDLE_BUILTIN_PLUGIN", + defaultValue: "" + }, + { + name: "REACT_APP_BUNDLE_TYPE", + defaultValue: "app" + }, + { + name: "REACT_APP_DISABLE_JS_SANDBOX", + defaultValue: "" + } +]; + +// src/dev-utils/external.js +var libs = [ + "axios", + "redux", + "react-router", + "react-router-dom", + "react-redux", + "react", + "react-dom", + "lodash", + "history", + "antd", + "@dnd-kit/core", + "@dnd-kit/modifiers", + "@dnd-kit/sortable", + "@dnd-kit/utilities", + { + name: "moment", + extractDefault: true + }, + { + name: "dayjs", + extractDefault: true + }, + { + name: "lowcoder-sdk", + from: "./src/index.sdk.ts" + }, + { + name: "styled-components", + mergeDefaultAndNameExports: true + } +]; +var getLibGlobalVarName = (name) => { + return "$" + name.replace(/@/g, "$").replace(/[\/\-]/g, "_"); +}; +var libsImportCode = (exclude = []) => { + const importLines = []; + const assignLines = []; + libs.forEach((i) => { + let name = i; + let merge = false; + let from = name; + let extractDefault = false; + if (typeof i === "object") { + name = i.name; + merge = i.mergeDefaultAndNameExports ?? false; + from = i.from ?? name; + extractDefault = i.extractDefault ?? false; + } + if (exclude.includes(name)) { + return; + } + const varName = getLibGlobalVarName(name); + if (merge) { + importLines.push(`import * as ${varName}_named_exports from '${from}';`); + importLines.push(`import ${varName} from '${from}';`); + assignLines.push(`Object.assign(${varName}, ${varName}_named_exports);`); + } else if (extractDefault) { + importLines.push(`import ${varName} from '${from}';`); + } else { + importLines.push(`import * as ${varName} from '${from}';`); + } + assignLines.push(`window.${varName} = ${varName};`); + }); + return importLines.concat(assignLines).join("\n"); +}; + +// src/dev-utils/globalDepPlguin.js +function globalDepPlugin(exclude = []) { + const virtualModuleId = "virtual:globals"; + return { + name: "lowcoder-global-plugin", + resolveId(id) { + if (id === virtualModuleId) { + return id; + } + }, + load(id) { + if (id === virtualModuleId) { + return libsImportCode(exclude); + } + } + }; +} + +// vite.config.mts +var __vite_injected_original_dirname = "C:\\Projects\\lowcoder\\client\\packages\\lowcoder"; +dotenv.config(); +var apiProxyTarget = process.env.LOWCODER_API_SERVICE_URL; +var nodeServiceApiProxyTarget = process.env.NODE_SERVICE_API_PROXY_TARGET; +var nodeEnv = process.env.NODE_ENV ?? "development"; +var edition = process.env.REACT_APP_EDITION; +var isEEGlobal = edition === "enterprise-global"; +var isEE = edition === "enterprise" || isEEGlobal; +var isDev = nodeEnv === "development"; +var isVisualizerEnabled = !!process.env.ENABLE_VISUALIZER; +var browserCheckFileName = `browser-check.js`; +var base = ensureLastSlash(process.env.PUBLIC_URL); +if (!apiProxyTarget && isDev) { + console.log(); + console.log(chalk.red`LOWCODER_API_SERVICE_URL is required.\n`); + console.log(chalk.cyan`Start with command: LOWCODER_API_SERVICE_URL=\{backend-api-addr\} yarn start`); + console.log(); + process.exit(1); +} +var proxyConfig = { + "/api": { + target: apiProxyTarget, + changeOrigin: false + } +}; +if (nodeServiceApiProxyTarget) { + proxyConfig["/node-service"] = { + target: nodeServiceApiProxyTarget + }; +} +var define = {}; +buildVars.forEach(({ name, defaultValue }) => { + define[name] = JSON.stringify(process.env[name] || defaultValue); +}); +var viteConfig = { + define, + assetsInclude: ["**/*.md"], + resolve: { + extensions: [".mjs", ".js", ".ts", ".jsx", ".tsx", ".json"], + alias: { + "@lowcoder-ee": path.resolve( + __vite_injected_original_dirname, + isEE ? `../lowcoder/src/${isEEGlobal ? "ee-global" : "ee"}` : "../lowcoder/src" + ) + } + }, + base, + build: { + manifest: true, + target: "es2015", + cssTarget: "chrome63", + outDir: "build", + assetsDir: "static", + emptyOutDir: false, + rollupOptions: { + output: { + chunkFileNames: "[hash].js" + } + }, + commonjsOptions: { + defaultIsModuleExports: (id) => { + if (id.indexOf("antd/lib") !== -1) { + return false; + } + return "auto"; + } + } + }, + css: { + preprocessorOptions: { + less: { + modifyVars: { + "@primary-color": "#3377FF", + "@link-color": "#3377FF", + "@border-color-base": "#D7D9E0", + "@border-radius-base": "4px" + }, + javascriptEnabled: true + } + } + }, + server: { + open: true, + cors: true, + port: 8e3, + host: "0.0.0.0", + proxy: proxyConfig + }, + plugins: [ + checker({ + typescript: true, + eslint: { + lintCommand: 'eslint --quiet "./src/**/*.{ts,tsx}"', + dev: { + logLevel: ["error"] + } + } + }), + react({ + babel: { + parserOpts: { + plugins: ["decorators-legacy"] + } + } + }), + viteTsconfigPaths({ + projects: ["../lowcoder/tsconfig.json", "../lowcoder-design/tsconfig.json"] + }), + svgrPlugin({ + svgrOptions: { + exportType: "named", + prettier: false, + svgo: false, + titleProp: true, + ref: true + } + }), + globalDepPlugin(), + createHtmlPlugin({ + minify: true, + inject: { + data: { + browserCheckScript: isDev ? "" : `` + } + } + }), + isVisualizerEnabled && visualizer() + ].filter(Boolean) +}; +var browserCheckConfig = { + ...viteConfig, + define: { + ...viteConfig.define, + "process.env.NODE_ENV": JSON.stringify("production") + }, + build: { + ...viteConfig.build, + manifest: false, + copyPublicDir: false, + emptyOutDir: true, + lib: { + formats: ["iife"], + name: "BrowserCheck", + entry: "./src/browser-check.ts", + fileName: () => { + return browserCheckFileName; + } + } + } +}; +var buildTargets = { + main: viteConfig, + browserCheck: browserCheckConfig +}; +var buildTarget = buildTargets[process.env.BUILD_TARGET || "main"]; +var vite_config_default = defineConfig(buildTarget || viteConfig); +export { + vite_config_default as default, + viteConfig +}; +//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["vite.config.mts", "src/dev-utils/util.js", "src/dev-utils/buildVars.js", "src/dev-utils/external.js", "src/dev-utils/globalDepPlguin.js"],
  "sourcesContent": ["const __vite_injected_original_dirname = \"C:\\\\Projects\\\\lowcoder\\\\client\\\\packages\\\\lowcoder\";const __vite_injected_original_filename = \"C:\\\\Projects\\\\lowcoder\\\\client\\\\packages\\\\lowcoder\\\\vite.config.mts\";const __vite_injected_original_import_meta_url = \"file:///C:/Projects/lowcoder/client/packages/lowcoder/vite.config.mts\";import dotenv from \"dotenv\";\r\nimport { defineConfig, ServerOptions, UserConfig } from \"vite\";\r\nimport react from \"@vitejs/plugin-react\";\r\nimport viteTsconfigPaths from \"vite-tsconfig-paths\";\r\nimport svgrPlugin from \"vite-plugin-svgr\";\r\nimport checker from \"vite-plugin-checker\";\r\nimport { visualizer } from \"rollup-plugin-visualizer\";\r\nimport path from \"path\";\r\nimport chalk from \"chalk\";\r\nimport { createHtmlPlugin } from \"vite-plugin-html\";\r\nimport { ensureLastSlash } from \"./src/dev-utils/util\";\r\nimport { buildVars } from \"./src/dev-utils/buildVars\";\r\nimport { globalDepPlugin } from \"./src/dev-utils/globalDepPlguin\";\r\n\r\ndotenv.config();\r\n\r\nconst apiProxyTarget = process.env.LOWCODER_API_SERVICE_URL;\r\nconst nodeServiceApiProxyTarget = process.env.NODE_SERVICE_API_PROXY_TARGET;\r\nconst nodeEnv = process.env.NODE_ENV ?? \"development\";\r\nconst edition = process.env.REACT_APP_EDITION;\r\nconst isEEGlobal = edition === \"enterprise-global\";\r\nconst isEE = edition === \"enterprise\" || isEEGlobal;\r\nconst isDev = nodeEnv === \"development\";\r\nconst isVisualizerEnabled = !!process.env.ENABLE_VISUALIZER;\r\n// the file was never created\r\n// const browserCheckFileName = `browser-check-${process.env.REACT_APP_COMMIT_ID}.js`;\r\nconst browserCheckFileName = `browser-check.js`;\r\nconst base = ensureLastSlash(process.env.PUBLIC_URL);\r\n\r\nif (!apiProxyTarget && isDev) {\r\n  console.log();\r\n  console.log(chalk.red`LOWCODER_API_SERVICE_URL is required.\\n`);\r\n  console.log(chalk.cyan`Start with command: LOWCODER_API_SERVICE_URL=\\{backend-api-addr\\} yarn start`);\r\n  console.log();\r\n  process.exit(1);\r\n}\r\n\r\nconst proxyConfig: ServerOptions[\"proxy\"] = {\r\n  \"/api\": {\r\n    target: apiProxyTarget,\r\n    changeOrigin: false,\r\n  },\r\n};\r\n\r\nif (nodeServiceApiProxyTarget) {\r\n  proxyConfig[\"/node-service\"] = {\r\n    target: nodeServiceApiProxyTarget,\r\n  };\r\n}\r\n\r\nconst define = {};\r\nbuildVars.forEach(({ name, defaultValue }) => {\r\n  define[name] = JSON.stringify(process.env[name] || defaultValue);\r\n});\r\n\r\n// https://vitejs.dev/config/\r\nexport const viteConfig: UserConfig = {\r\n  define,\r\n  assetsInclude: [\"**/*.md\"],\r\n  resolve: {\r\n    extensions: [\".mjs\", \".js\", \".ts\", \".jsx\", \".tsx\", \".json\"],\r\n    alias: {\r\n      \"@lowcoder-ee\": path.resolve(\r\n        __dirname,\r\n        isEE ? `../lowcoder/src/${isEEGlobal ? \"ee-global\" : \"ee\"}` : \"../lowcoder/src\"\r\n      ),\r\n    },\r\n  },\r\n  base,\r\n  build: {\r\n    manifest: true,\r\n    target: \"es2015\",\r\n    cssTarget: \"chrome63\",\r\n    outDir: \"build\",\r\n    assetsDir: \"static\",\r\n    emptyOutDir: false,\r\n    rollupOptions: {\r\n      output: {\r\n        chunkFileNames: \"[hash].js\",\r\n      },\r\n    },\r\n    commonjsOptions: {\r\n      defaultIsModuleExports: (id) => {\r\n        if (id.indexOf(\"antd/lib\") !== -1) {\r\n          return false;\r\n        }\r\n        return \"auto\";\r\n      },\r\n    },\r\n  },\r\n  css: {\r\n    preprocessorOptions: {\r\n      less: {\r\n        modifyVars: {\r\n          \"@primary-color\": \"#3377FF\",\r\n          \"@link-color\": \"#3377FF\",\r\n          \"@border-color-base\": \"#D7D9E0\",\r\n          \"@border-radius-base\": \"4px\",\r\n        },\r\n        javascriptEnabled: true,\r\n      },\r\n    },\r\n  },\r\n  server: {\r\n    open: true,\r\n    cors: true,\r\n    port: 8000,\r\n    host: \"0.0.0.0\",\r\n    proxy: proxyConfig,\r\n  },\r\n  plugins: [\r\n    checker({\r\n      typescript: true,\r\n      eslint: {\r\n        lintCommand: 'eslint --quiet \"./src/**/*.{ts,tsx}\"',\r\n        dev: {\r\n          logLevel: [\"error\"],\r\n        },\r\n      },\r\n    }),\r\n    react({\r\n      babel: {\r\n        parserOpts: {\r\n          plugins: [\"decorators-legacy\"],\r\n        },\r\n      },\r\n    }),\r\n    viteTsconfigPaths({\r\n      projects: [\"../lowcoder/tsconfig.json\", \"../lowcoder-design/tsconfig.json\"],\r\n    }),\r\n    svgrPlugin({\r\n      svgrOptions: {\r\n        exportType: \"named\",\r\n        prettier: false,\r\n        svgo: false,\r\n        titleProp: true,\r\n        ref: true,\r\n      },\r\n    }),\r\n    globalDepPlugin(),\r\n    createHtmlPlugin({\r\n      minify: true,\r\n      inject: {\r\n        data: {\r\n          browserCheckScript: isDev ? \"\" : `<script src=\"${base}${browserCheckFileName}\"></script>`,\r\n        },\r\n      },\r\n    }),\r\n    isVisualizerEnabled && visualizer(),\r\n  ].filter(Boolean),\r\n};\r\n\r\nconst browserCheckConfig: UserConfig = {\r\n  ...viteConfig,\r\n  define: {\r\n    ...viteConfig.define,\r\n    \"process.env.NODE_ENV\": JSON.stringify(\"production\"),\r\n  },\r\n  build: {\r\n    ...viteConfig.build,\r\n    manifest: false,\r\n    copyPublicDir: false,\r\n    emptyOutDir: true,\r\n    lib: {\r\n      formats: [\"iife\"],\r\n      name: \"BrowserCheck\",\r\n      entry: \"./src/browser-check.ts\",\r\n      fileName: () => {\r\n        return browserCheckFileName;\r\n      },\r\n    },\r\n  },\r\n};\r\n\r\nconst buildTargets = {\r\n  main: viteConfig,\r\n  browserCheck: browserCheckConfig,\r\n};\r\n\r\nconst buildTarget = buildTargets[process.env.BUILD_TARGET || \"main\"];\r\n\r\nexport default defineConfig(buildTarget || viteConfig);\r\n", "const __vite_injected_original_dirname = \"C:\\\\Projects\\\\lowcoder\\\\client\\\\packages\\\\lowcoder\\\\src\\\\dev-utils\";const __vite_injected_original_filename = \"C:\\\\Projects\\\\lowcoder\\\\client\\\\packages\\\\lowcoder\\\\src\\\\dev-utils\\\\util.js\";const __vite_injected_original_import_meta_url = \"file:///C:/Projects/lowcoder/client/packages/lowcoder/src/dev-utils/util.js\";import fs from \"node:fs\";\r\nimport { dirname } from \"node:path\";\r\nimport { fileURLToPath } from \"node:url\";\r\n\r\nexport function stripLastSlash(str) {\r\n  if (str.endsWith(\"/\")) {\r\n    return str.slice(0, str.length - 1);\r\n  }\r\n  return str;\r\n}\r\n\r\nexport function ensureLastSlash(str) {\r\n  if (!str) {\r\n    return \"/\";\r\n  }\r\n  if (!str.endsWith(\"/\")) {\r\n    return `${str}/`;\r\n  }\r\n  return str;\r\n}\r\n\r\nexport function readJson(file) {\r\n  return JSON.parse(fs.readFileSync(file).toString());\r\n}\r\n\r\nexport function currentDirName(importMetaUrl) {\r\n  return dirname(fileURLToPath(importMetaUrl));\r\n}\r\n", "const __vite_injected_original_dirname = \"C:\\\\Projects\\\\lowcoder\\\\client\\\\packages\\\\lowcoder\\\\src\\\\dev-utils\";const __vite_injected_original_filename = \"C:\\\\Projects\\\\lowcoder\\\\client\\\\packages\\\\lowcoder\\\\src\\\\dev-utils\\\\buildVars.js\";const __vite_injected_original_import_meta_url = \"file:///C:/Projects/lowcoder/client/packages/lowcoder/src/dev-utils/buildVars.js\";export const buildVars = [\r\n  {\r\n    name: \"PUBLIC_URL\",\r\n    defaultValue: \"/\",\r\n  },\r\n  {\r\n    name: \"REACT_APP_EDITION\",\r\n    defaultValue: \"community\",\r\n  },\r\n  {\r\n    name: \"REACT_APP_LANGUAGES\",\r\n    defaultValue: \"\",\r\n  },\r\n  {\r\n    name: \"REACT_APP_COMMIT_ID\",\r\n    defaultValue: \"00000\",\r\n  },\r\n  {\r\n    name: \"REACT_APP_API_HOST\",\r\n    defaultValue: \"\",\r\n  },\r\n  {\r\n    name: \"LOWCODER_NODE_SERVICE_URL\",\r\n    defaultValue: \"\",\r\n  },\r\n  {\r\n    name: \"REACT_APP_ENV\",\r\n    defaultValue: \"production\",\r\n  },\r\n  {\r\n    name: \"REACT_APP_BUILD_ID\",\r\n    defaultValue: \"\",\r\n  },\r\n  {\r\n    name: \"REACT_APP_LOG_LEVEL\",\r\n    defaultValue: \"error\",\r\n  },\r\n  {\r\n    name: \"REACT_APP_IMPORT_MAP\",\r\n    defaultValue: \"{}\",\r\n  },\r\n  {\r\n    name: \"REACT_APP_SERVER_IPS\",\r\n    defaultValue: \"\",\r\n  },\r\n  {\r\n    name: \"REACT_APP_BUNDLE_BUILTIN_PLUGIN\",\r\n    defaultValue: \"\",\r\n  },\r\n  {\r\n    name: \"REACT_APP_BUNDLE_TYPE\",\r\n    defaultValue: \"app\",\r\n  },\r\n  {\r\n    name: \"REACT_APP_DISABLE_JS_SANDBOX\",\r\n    defaultValue: \"\",\r\n  },\r\n];\r\n", "const __vite_injected_original_dirname = \"C:\\\\Projects\\\\lowcoder\\\\client\\\\packages\\\\lowcoder\\\\src\\\\dev-utils\";const __vite_injected_original_filename = \"C:\\\\Projects\\\\lowcoder\\\\client\\\\packages\\\\lowcoder\\\\src\\\\dev-utils\\\\external.js\";const __vite_injected_original_import_meta_url = \"file:///C:/Projects/lowcoder/client/packages/lowcoder/src/dev-utils/external.js\";/**\r\n * libs to import as global var\r\n * name: module name\r\n * mergeDefaultAndNameExports: whether to merge default and named exports\r\n */\r\nexport const libs = [\r\n  \"axios\",\r\n  \"redux\",\r\n  \"react-router\",\r\n  \"react-router-dom\",\r\n  \"react-redux\",\r\n  \"react\",\r\n  \"react-dom\",\r\n  \"lodash\",\r\n  \"history\",\r\n  \"antd\",\r\n  \"@dnd-kit/core\",\r\n  \"@dnd-kit/modifiers\",\r\n  \"@dnd-kit/sortable\",\r\n  \"@dnd-kit/utilities\",\r\n  {\r\n    name: \"moment\",\r\n    extractDefault: true,\r\n  },\r\n  {\r\n    name: \"dayjs\",\r\n    extractDefault: true,\r\n  },\r\n  {\r\n    name: \"lowcoder-sdk\",\r\n    from: \"./src/index.sdk.ts\",\r\n  },\r\n  {\r\n    name: \"styled-components\",\r\n    mergeDefaultAndNameExports: true,\r\n  },\r\n];\r\n\r\n/**\r\n * get global var name from module name\r\n * @param {string} name\r\n * @returns\r\n */\r\nexport const getLibGlobalVarName = (name) => {\r\n  return \"$\" + name.replace(/@/g, \"$\").replace(/[\\/\\-]/g, \"_\");\r\n};\r\n\r\nexport const getLibNames = () => {\r\n  return libs.map((i) => {\r\n    if (typeof i === \"object\") {\r\n      return i.name;\r\n    }\r\n    return i;\r\n  });\r\n};\r\n\r\nexport const getAllLibGlobalVarNames = () => {\r\n  const ret = {};\r\n  libs.forEach((lib) => {\r\n    let name = lib;\r\n    if (typeof lib === \"object\") {\r\n      name = lib.name;\r\n    }\r\n    ret[name] = getLibGlobalVarName(name);\r\n  });\r\n  return ret;\r\n};\r\n\r\nexport const libsImportCode = (exclude = []) => {\r\n  const importLines = [];\r\n  const assignLines = [];\r\n  libs.forEach((i) => {\r\n    let name = i;\r\n    let merge = false;\r\n    let from = name;\r\n    let extractDefault = false;\r\n\r\n    if (typeof i === \"object\") {\r\n      name = i.name;\r\n      merge = i.mergeDefaultAndNameExports ?? false;\r\n      from = i.from ?? name;\r\n      extractDefault = i.extractDefault ?? false;\r\n    }\r\n\r\n    if (exclude.includes(name)) {\r\n      return;\r\n    }\r\n\r\n    const varName = getLibGlobalVarName(name);\r\n    if (merge) {\r\n      importLines.push(`import * as ${varName}_named_exports from '${from}';`);\r\n      importLines.push(`import ${varName} from '${from}';`);\r\n      assignLines.push(`Object.assign(${varName}, ${varName}_named_exports);`);\r\n    } else if (extractDefault) {\r\n      importLines.push(`import ${varName} from '${from}';`);\r\n    } else {\r\n      importLines.push(`import * as ${varName} from '${from}';`);\r\n    }\r\n    assignLines.push(`window.${varName} = ${varName};`);\r\n  });\r\n  return importLines.concat(assignLines).join(\"\\n\");\r\n};\r\n", "const __vite_injected_original_dirname = \"C:\\\\Projects\\\\lowcoder\\\\client\\\\packages\\\\lowcoder\\\\src\\\\dev-utils\";const __vite_injected_original_filename = \"C:\\\\Projects\\\\lowcoder\\\\client\\\\packages\\\\lowcoder\\\\src\\\\dev-utils\\\\globalDepPlguin.js\";const __vite_injected_original_import_meta_url = \"file:///C:/Projects/lowcoder/client/packages/lowcoder/src/dev-utils/globalDepPlguin.js\";import { libsImportCode } from \"./external.js\";\r\n\r\nexport function globalDepPlugin(exclude = []) {\r\n  const virtualModuleId = \"virtual:globals\";\r\n  return {\r\n    name: \"lowcoder-global-plugin\",\r\n    resolveId(id) {\r\n      if (id === virtualModuleId) {\r\n        return id;\r\n      }\r\n    },\r\n    load(id) {\r\n      if (id === virtualModuleId) {\r\n        return libsImportCode(exclude);\r\n      }\r\n    },\r\n  };\r\n}\r\n"],
  "mappings": "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",
  "names": []
}
 From 8fd726c954c6cb4de310639a11c65a781fe72159 Mon Sep 17 00:00:00 2001 From: Imtanan Aziz Toor Date: Thu, 15 Feb 2024 21:15:52 +0500 Subject: [PATCH 3/5] Text area font style added --- .../tableComp/column/tableColumnComp.tsx | 28 ++++++---- .../comps/comps/tableComp/tableCompView.tsx | 56 +++++++++++-------- .../src/comps/comps/tableComp/tableTypes.tsx | 2 +- .../src/comps/comps/tableComp/tableUtils.tsx | 2 + .../comps/controls/styleControlConstants.tsx | 8 ++- 5 files changed, 59 insertions(+), 37 deletions(-) diff --git a/client/packages/lowcoder/src/comps/comps/tableComp/column/tableColumnComp.tsx b/client/packages/lowcoder/src/comps/comps/tableComp/column/tableColumnComp.tsx index 39a392ad4..0de024795 100644 --- a/client/packages/lowcoder/src/comps/comps/tableComp/column/tableColumnComp.tsx +++ b/client/packages/lowcoder/src/comps/comps/tableComp/column/tableColumnComp.tsx @@ -108,6 +108,7 @@ export const columnChildrenMap = { textSize: withDefault(RadiusControl, ""), textWeight: withDefault(StringControl, "normal"), fontFamily: withDefault(StringControl, "sans-serif"), + fontStyle: withDefault(StringControl, 'normal'), cellColor: CellColorComp, textOverflow: withDefault(TextOverflowControl, "ellipsis"), linkColor: withDefault(ColorControl, "#3377ff"), @@ -155,10 +156,10 @@ export class ColumnComp extends ColumnInitComp { ) ); } - if(action.type === CompActionTypes.CHANGE_VALUE) { + if (action.type === CompActionTypes.CHANGE_VALUE) { const title = comp.children.title.unevaledValue; const dataIndex = comp.children.dataIndex.getView(); - if(!Boolean(title)) { + if (!Boolean(title)) { comp.children.title.dispatchChangeValueAction(dataIndex); } } @@ -223,10 +224,10 @@ export class ColumnComp extends ColumnInitComp { })} {this.children.autoWidth.getView() === "fixed" && this.children.width.propertyView({ label: trans("prop.width") })} - + {(columnType === 'link' || columnType === 'links') && ( <> - + {controlItem({}, (
{"Link Style"} @@ -243,10 +244,10 @@ export class ColumnComp extends ColumnInitComp { })} )} - + {controlItem({}, (
- {"Column Style"} + {"Column Style"}
))} {this.children.background.propertyView({ @@ -260,29 +261,34 @@ export class ColumnComp extends ColumnInitComp { })} {this.children.borderWidth.propertyView({ label: trans('style.borderWidth'), - preInputNode: , + preInputNode: , placeholder: '1px', })} {this.children.radius.propertyView({ label: trans('style.borderRadius'), - preInputNode: , + preInputNode: , placeholder: '3px', })} {this.children.textSize.propertyView({ label: trans('style.textSize'), - preInputNode: , + preInputNode: , placeholder: '14px', })} {this.children.textWeight.propertyView({ label: trans('style.textWeight'), - preInputNode: , + preInputNode: , placeholder: 'normal', })} {this.children.fontFamily.propertyView({ label: trans('style.fontFamily'), - preInputNode: , + preInputNode: , placeholder: 'sans-serif', })} + {this.children.fontStyle.propertyView({ + label: trans('style.fontStyle'), + preInputNode: , + placeholder: 'normal' + })} {this.children.textOverflow.getPropertyView()} {this.children.cellColor.getPropertyView()} diff --git a/client/packages/lowcoder/src/comps/comps/tableComp/tableCompView.tsx b/client/packages/lowcoder/src/comps/comps/tableComp/tableCompView.tsx index 729e8f6b9..f16db203e 100644 --- a/client/packages/lowcoder/src/comps/comps/tableComp/tableCompView.tsx +++ b/client/packages/lowcoder/src/comps/comps/tableComp/tableCompView.tsx @@ -51,7 +51,7 @@ const getStyle = ( style: TableStyleType, rowStyle: TableRowStyleType, headerStyle: TableHeaderStyleType, - toolbarStyle: TableToolbarStyleType + toolbarStyle: TableToolbarStyleType, ) => { const background = genLinerGradient(style.background); const selectedRowBackground = genLinerGradient(rowStyle.selectedRowBackground); @@ -140,7 +140,8 @@ const BackgroundWrapper = styled.div<{ background: ${(props) => props.$style.background} !important; border: ${(props) => `${props.$style.borderWidth} solid ${props.$style.border} !important`}; border-radius: ${(props) => props.$style.radius} !important; - padding: unset !important; + // padding: unset !important; + padding: ${(props) => props.$style.padding} !important margin: ${(props) => props.$style.margin} !important; overflow: scroll !important; ${(props) => props.$style} @@ -209,18 +210,19 @@ const TableWrapper = styled.div<{ > .ant-table-thead { > tr > th { background-color: ${(props) => props.$headerStyle.headerBackground}; + border-color: ${(props) => props.$headerStyle.border}; border-width: ${(props) => props.$headerStyle.borderWidth}; color: ${(props) => props.$headerStyle.headerText}; border-inline-end: ${(props) => `${props.$headerStyle.borderWidth} solid ${props.$headerStyle.border}`} !important; - ${(props) => - props.$fixedHeader && ` + ${(props) => + props.$fixedHeader && ` position: sticky; position: -webkit-sticky; top: ${props.$fixedToolbar ? '47px' : '0'}; z-index: 99; ` - } + } > div { margin: ${(props) => props.$headerStyle.margin}; @@ -229,6 +231,8 @@ const TableWrapper = styled.div<{ font-size: ${(props) => props.$headerStyle.textSize}; font-weight: ${(props) => props.$headerStyle.textWeight}; font-family: ${(props) => props.$headerStyle.fontFamily}; + font-style: ${(props) => props.$headerStyle.fontStyle}; + color:${(props) => props.$headerStyle.text} } } @@ -286,8 +290,8 @@ const TableWrapper = styled.div<{ // hide the bottom border of the last row ${(props) => - props.$toolbarPosition !== "below" && - ` + props.$toolbarPosition !== "below" && + ` tbody > tr:last-child > td { border-bottom: unset; } @@ -300,10 +304,10 @@ const TableWrapper = styled.div<{ } } - ${(props) => + ${(props) => props.$style && getStyle(props.$style, props.$rowStyle, props.$headerStyle, props.$toolbarStyle)} `; - + const TableTh = styled.th<{ width?: number }>` overflow: hidden; @@ -318,7 +322,7 @@ const TableTh = styled.th<{ width?: number }>` const TableTd = styled.td<{ $background: string; - $style: TableColumnStyleType & {rowHeight?: string}; + $style: TableColumnStyleType & { rowHeight?: string }; $defaultThemeDetail: ThemeDetail; $linkStyle?: TableColumnLinkStyleType; $isEditing: boolean; @@ -348,7 +352,8 @@ const TableTd = styled.td<{ ${(props) => props.$tableSize === 'small' && ` padding: 1px 8px; - font-size: ${props.$defaultThemeDetail.textSize == props.$style.textSize ? '14px !important' : props.$style.textSize + ' !important' }; + font-size: ${props.$defaultThemeDetail.textSize == props.$style.textSize ? '14px !important' : props.$style.textSize + ' !important'}; + font-style:${props.$style.fontStyle} !important; min-height: ${props.$style.rowHeight || '14px'}; line-height: 20px; ${!props.$autoHeight && ` @@ -358,7 +363,8 @@ const TableTd = styled.td<{ `}; ${(props) => props.$tableSize === 'middle' && ` padding: 8px 8px; - font-size: ${props.$defaultThemeDetail.textSize == props.$style.textSize ? '16px !important' : props.$style.textSize + ' !important' }; + font-size: ${props.$defaultThemeDetail.textSize == props.$style.textSize ? '16px !important' : props.$style.textSize + ' !important'}; + font-style:${props.$style.fontStyle} !important; min-height: ${props.$style.rowHeight || '24px'}; line-height: 24px; ${!props.$autoHeight && ` @@ -368,7 +374,8 @@ const TableTd = styled.td<{ `}; ${(props) => props.$tableSize === 'large' && ` padding: 16px 16px; - font-size: ${props.$defaultThemeDetail.textSize == props.$style.textSize ? '18px !important' : props.$style.textSize + ' !important' }; + font-size: ${props.$defaultThemeDetail.textSize == props.$style.textSize ? '18px !important' : props.$style.textSize + ' !important'}; + font-style:${props.$style.fontStyle} !important; min-height: ${props.$style.rowHeight || '48px'}; ${!props.$autoHeight && ` overflow-y: auto; @@ -444,7 +451,7 @@ const ResizeableTitle = (props: any) => { draggableOpts={{ enableUserSelectHack: false }} handle={(axis: ResizeHandleAxis, ref: ReactRef) => ( { e.preventDefault(); e.stopPropagation(); @@ -519,7 +526,7 @@ function TableCellView(props: { const cellColor = cellColorFn({ currentCell: record[title.toLowerCase()], }); - + const style = { background: cellColor || rowColor || columnStyle.background || columnsStyle.background, margin: columnStyle.margin || columnsStyle.margin, @@ -530,6 +537,7 @@ function TableCellView(props: { textSize: columnStyle.textSize || columnsStyle.textSize, textWeight: columnStyle.textWeight || columnsStyle.textWeight, fontFamily: columnStyle.fontFamily || columnsStyle.fontFamily, + fontStyle: columnStyle.fontStyle || columnsStyle.fontStyle, rowHeight: rowHeight, } let { background } = style; @@ -554,7 +562,7 @@ function TableCellView(props: { ); } - + return ( {tdView} @@ -804,7 +812,7 @@ export function TableCompView(props: { return ( - + {toolbar.position === "above" && toolbarView} { - if(expanded) { - handleChangeEvent('rowExpand') - } else { - handleChangeEvent('rowShrink') - } + if (expanded) { + handleChangeEvent('rowExpand') + } else { + handleChangeEvent('rowShrink') + } } }} rowColorFn={compChildren.rowColor.getView() as any} @@ -857,14 +865,14 @@ export function TableCompView(props: { compChildren.loading.getView() } /> - + {expansion.expandModalView} {toolbar.position === "below" && toolbarView} - + ); } diff --git a/client/packages/lowcoder/src/comps/comps/tableComp/tableTypes.tsx b/client/packages/lowcoder/src/comps/comps/tableComp/tableTypes.tsx index 90f5f0a6c..41a846c19 100644 --- a/client/packages/lowcoder/src/comps/comps/tableComp/tableTypes.tsx +++ b/client/packages/lowcoder/src/comps/comps/tableComp/tableTypes.tsx @@ -210,7 +210,7 @@ const tableChildrenMap = { toolbarStyle: styleControl(TableToolbarStyle), headerStyle: styleControl(TableHeaderStyle), searchText: StringControl, - columnsStyle: withDefault(styleControl(TableColumnStyle), {borderWidth: '1px', radius: '0px'}), + columnsStyle: withDefault(styleControl(TableColumnStyle), {borderWidth: '1px', radius: '0px',fontStyle:'italic'}), viewModeResizable: BoolControl, visibleResizables: BoolControl, // sample data for regenerating columns diff --git a/client/packages/lowcoder/src/comps/comps/tableComp/tableUtils.tsx b/client/packages/lowcoder/src/comps/comps/tableComp/tableUtils.tsx index 4532475c8..83bc941d7 100644 --- a/client/packages/lowcoder/src/comps/comps/tableComp/tableUtils.tsx +++ b/client/packages/lowcoder/src/comps/comps/tableComp/tableUtils.tsx @@ -311,6 +311,7 @@ export function columnsToAntdFormat( status: StatusType; }[]; const title = renderTitle({ title: column.title, editable: column.editable }); + return { title: column.showTitle ? title : '', titleText: column.title, @@ -326,6 +327,7 @@ export function columnsToAntdFormat( radius: column.radius, textSize: column.textSize, textWeight: column.textWeight, + fontStyle:column.fontStyle, fontFamily: column.fontFamily, borderWidth: column.borderWidth, }, diff --git a/client/packages/lowcoder/src/comps/controls/styleControlConstants.tsx b/client/packages/lowcoder/src/comps/controls/styleControlConstants.tsx index f8fa415a8..c01fc0d0b 100644 --- a/client/packages/lowcoder/src/comps/controls/styleControlConstants.tsx +++ b/client/packages/lowcoder/src/comps/controls/styleControlConstants.tsx @@ -920,6 +920,7 @@ const LinkTextStyle = [ export const TableStyle = [ MARGIN, + PADDING, ...BG_STATIC_BORDER_RADIUS, { name: "borderWidth", @@ -943,6 +944,10 @@ export const TableToolbarStyle = [ export const TableHeaderStyle = [ MARGIN, + PADDING, + FONT_FAMILY, + FONT_STYLE, + TEXT, { name: "headerBackground", label: trans("style.tableHeaderBackground"), @@ -1000,7 +1005,8 @@ export const TableColumnStyle = [ TEXT, TEXT_SIZE, TEXT_WEIGHT, - FONT_FAMILY + FONT_FAMILY, + FONT_STYLE, ] as const; export const TableColumnLinkStyle = [ From a603a57f2dc5791564a55d52611b4910fccc3f2a Mon Sep 17 00:00:00 2001 From: Imtanan Aziz Toor Date: Thu, 15 Feb 2024 21:17:50 +0500 Subject: [PATCH 4/5] Table column styles working --- .../lowcoder/src/comps/comps/tableComp/tableCompView.tsx | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/client/packages/lowcoder/src/comps/comps/tableComp/tableCompView.tsx b/client/packages/lowcoder/src/comps/comps/tableComp/tableCompView.tsx index f16db203e..fcf99b18a 100644 --- a/client/packages/lowcoder/src/comps/comps/tableComp/tableCompView.tsx +++ b/client/packages/lowcoder/src/comps/comps/tableComp/tableCompView.tsx @@ -535,9 +535,9 @@ function TableCellView(props: { radius: columnStyle.radius || columnsStyle.radius, borderWidth: columnStyle.borderWidth || columnsStyle.borderWidth, textSize: columnStyle.textSize || columnsStyle.textSize, - textWeight: columnStyle.textWeight || columnsStyle.textWeight, - fontFamily: columnStyle.fontFamily || columnsStyle.fontFamily, - fontStyle: columnStyle.fontStyle || columnsStyle.fontStyle, + textWeight: columnsStyle.textWeight || columnStyle.textWeight, + fontFamily: columnsStyle.fontFamily || columnStyle.fontFamily, + fontStyle: columnsStyle.fontStyle || columnStyle.fontStyle, rowHeight: rowHeight, } let { background } = style; From e3463a087010dc33e8b66b615ad7daa786bc66e7 Mon Sep 17 00:00:00 2001 From: imtananikhwa <156658165+imtananikhwa@users.noreply.github.com> Date: Sat, 17 Feb 2024 13:51:28 +0500 Subject: [PATCH 5/5] Delete client/packages/lowcoder/vite.config.mts.timestamp-1708005283355-9ba212c9a46a4.mjs junk file removed --- ....timestamp-1708005283355-9ba212c9a46a4.mjs | 331 ------------------ 1 file changed, 331 deletions(-) delete mode 100644 client/packages/lowcoder/vite.config.mts.timestamp-1708005283355-9ba212c9a46a4.mjs diff --git a/client/packages/lowcoder/vite.config.mts.timestamp-1708005283355-9ba212c9a46a4.mjs b/client/packages/lowcoder/vite.config.mts.timestamp-1708005283355-9ba212c9a46a4.mjs deleted file mode 100644 index 8600472a2..000000000 --- a/client/packages/lowcoder/vite.config.mts.timestamp-1708005283355-9ba212c9a46a4.mjs +++ /dev/null @@ -1,331 +0,0 @@ -// vite.config.mts -import dotenv from "file:///C:/Projects/lowcoder/client/node_modules/dotenv/lib/main.js"; -import { defineConfig } from "file:///C:/Projects/lowcoder/client/node_modules/vite/dist/node/index.js"; -import react from "file:///C:/Projects/lowcoder/client/node_modules/@vitejs/plugin-react/dist/index.mjs"; -import viteTsconfigPaths from "file:///C:/Projects/lowcoder/client/node_modules/vite-tsconfig-paths/dist/index.mjs"; -import svgrPlugin from "file:///C:/Projects/lowcoder/client/node_modules/vite-plugin-svgr/dist/index.mjs"; -import checker from "file:///C:/Projects/lowcoder/client/node_modules/vite-plugin-checker/dist/esm/main.js"; -import { visualizer } from "file:///C:/Projects/lowcoder/client/node_modules/rollup-plugin-visualizer/dist/plugin/index.js"; -import path from "path"; -import chalk from "file:///C:/Projects/lowcoder/client/node_modules/chalk/source/index.js"; -import { createHtmlPlugin } from "file:///C:/Projects/lowcoder/client/node_modules/vite-plugin-html/dist/index.mjs"; - -// src/dev-utils/util.js -function ensureLastSlash(str) { - if (!str) { - return "/"; - } - if (!str.endsWith("/")) { - return `${str}/`; - } - return str; -} - -// src/dev-utils/buildVars.js -var buildVars = [ - { - name: "PUBLIC_URL", - defaultValue: "/" - }, - { - name: "REACT_APP_EDITION", - defaultValue: "community" - }, - { - name: "REACT_APP_LANGUAGES", - defaultValue: "" - }, - { - name: "REACT_APP_COMMIT_ID", - defaultValue: "00000" - }, - { - name: "REACT_APP_API_HOST", - defaultValue: "" - }, - { - name: "LOWCODER_NODE_SERVICE_URL", - defaultValue: "" - }, - { - name: "REACT_APP_ENV", - defaultValue: "production" - }, - { - name: "REACT_APP_BUILD_ID", - defaultValue: "" - }, - { - name: "REACT_APP_LOG_LEVEL", - defaultValue: "error" - }, - { - name: "REACT_APP_IMPORT_MAP", - defaultValue: "{}" - }, - { - name: "REACT_APP_SERVER_IPS", - defaultValue: "" - }, - { - name: "REACT_APP_BUNDLE_BUILTIN_PLUGIN", - defaultValue: "" - }, - { - name: "REACT_APP_BUNDLE_TYPE", - defaultValue: "app" - }, - { - name: "REACT_APP_DISABLE_JS_SANDBOX", - defaultValue: "" - } -]; - -// src/dev-utils/external.js -var libs = [ - "axios", - "redux", - "react-router", - "react-router-dom", - "react-redux", - "react", - "react-dom", - "lodash", - "history", - "antd", - "@dnd-kit/core", - "@dnd-kit/modifiers", - "@dnd-kit/sortable", - "@dnd-kit/utilities", - { - name: "moment", - extractDefault: true - }, - { - name: "dayjs", - extractDefault: true - }, - { - name: "lowcoder-sdk", - from: "./src/index.sdk.ts" - }, - { - name: "styled-components", - mergeDefaultAndNameExports: true - } -]; -var getLibGlobalVarName = (name) => { - return "$" + name.replace(/@/g, "$").replace(/[\/\-]/g, "_"); -}; -var libsImportCode = (exclude = []) => { - const importLines = []; - const assignLines = []; - libs.forEach((i) => { - let name = i; - let merge = false; - let from = name; - let extractDefault = false; - if (typeof i === "object") { - name = i.name; - merge = i.mergeDefaultAndNameExports ?? false; - from = i.from ?? name; - extractDefault = i.extractDefault ?? false; - } - if (exclude.includes(name)) { - return; - } - const varName = getLibGlobalVarName(name); - if (merge) { - importLines.push(`import * as ${varName}_named_exports from '${from}';`); - importLines.push(`import ${varName} from '${from}';`); - assignLines.push(`Object.assign(${varName}, ${varName}_named_exports);`); - } else if (extractDefault) { - importLines.push(`import ${varName} from '${from}';`); - } else { - importLines.push(`import * as ${varName} from '${from}';`); - } - assignLines.push(`window.${varName} = ${varName};`); - }); - return importLines.concat(assignLines).join("\n"); -}; - -// src/dev-utils/globalDepPlguin.js -function globalDepPlugin(exclude = []) { - const virtualModuleId = "virtual:globals"; - return { - name: "lowcoder-global-plugin", - resolveId(id) { - if (id === virtualModuleId) { - return id; - } - }, - load(id) { - if (id === virtualModuleId) { - return libsImportCode(exclude); - } - } - }; -} - -// vite.config.mts -var __vite_injected_original_dirname = "C:\\Projects\\lowcoder\\client\\packages\\lowcoder"; -dotenv.config(); -var apiProxyTarget = process.env.LOWCODER_API_SERVICE_URL; -var nodeServiceApiProxyTarget = process.env.NODE_SERVICE_API_PROXY_TARGET; -var nodeEnv = process.env.NODE_ENV ?? "development"; -var edition = process.env.REACT_APP_EDITION; -var isEEGlobal = edition === "enterprise-global"; -var isEE = edition === "enterprise" || isEEGlobal; -var isDev = nodeEnv === "development"; -var isVisualizerEnabled = !!process.env.ENABLE_VISUALIZER; -var browserCheckFileName = `browser-check.js`; -var base = ensureLastSlash(process.env.PUBLIC_URL); -if (!apiProxyTarget && isDev) { - console.log(); - console.log(chalk.red`LOWCODER_API_SERVICE_URL is required.\n`); - console.log(chalk.cyan`Start with command: LOWCODER_API_SERVICE_URL=\{backend-api-addr\} yarn start`); - console.log(); - process.exit(1); -} -var proxyConfig = { - "/api": { - target: apiProxyTarget, - changeOrigin: false - } -}; -if (nodeServiceApiProxyTarget) { - proxyConfig["/node-service"] = { - target: nodeServiceApiProxyTarget - }; -} -var define = {}; -buildVars.forEach(({ name, defaultValue }) => { - define[name] = JSON.stringify(process.env[name] || defaultValue); -}); -var viteConfig = { - define, - assetsInclude: ["**/*.md"], - resolve: { - extensions: [".mjs", ".js", ".ts", ".jsx", ".tsx", ".json"], - alias: { - "@lowcoder-ee": path.resolve( - __vite_injected_original_dirname, - isEE ? `../lowcoder/src/${isEEGlobal ? "ee-global" : "ee"}` : "../lowcoder/src" - ) - } - }, - base, - build: { - manifest: true, - target: "es2015", - cssTarget: "chrome63", - outDir: "build", - assetsDir: "static", - emptyOutDir: false, - rollupOptions: { - output: { - chunkFileNames: "[hash].js" - } - }, - commonjsOptions: { - defaultIsModuleExports: (id) => { - if (id.indexOf("antd/lib") !== -1) { - return false; - } - return "auto"; - } - } - }, - css: { - preprocessorOptions: { - less: { - modifyVars: { - "@primary-color": "#3377FF", - "@link-color": "#3377FF", - "@border-color-base": "#D7D9E0", - "@border-radius-base": "4px" - }, - javascriptEnabled: true - } - } - }, - server: { - open: true, - cors: true, - port: 8e3, - host: "0.0.0.0", - proxy: proxyConfig - }, - plugins: [ - checker({ - typescript: true, - eslint: { - lintCommand: 'eslint --quiet "./src/**/*.{ts,tsx}"', - dev: { - logLevel: ["error"] - } - } - }), - react({ - babel: { - parserOpts: { - plugins: ["decorators-legacy"] - } - } - }), - viteTsconfigPaths({ - projects: ["../lowcoder/tsconfig.json", "../lowcoder-design/tsconfig.json"] - }), - svgrPlugin({ - svgrOptions: { - exportType: "named", - prettier: false, - svgo: false, - titleProp: true, - ref: true - } - }), - globalDepPlugin(), - createHtmlPlugin({ - minify: true, - inject: { - data: { - browserCheckScript: isDev ? "" : `` - } - } - }), - isVisualizerEnabled && visualizer() - ].filter(Boolean) -}; -var browserCheckConfig = { - ...viteConfig, - define: { - ...viteConfig.define, - "process.env.NODE_ENV": JSON.stringify("production") - }, - build: { - ...viteConfig.build, - manifest: false, - copyPublicDir: false, - emptyOutDir: true, - lib: { - formats: ["iife"], - name: "BrowserCheck", - entry: "./src/browser-check.ts", - fileName: () => { - return browserCheckFileName; - } - } - } -}; -var buildTargets = { - main: viteConfig, - browserCheck: browserCheckConfig -}; -var buildTarget = buildTargets[process.env.BUILD_TARGET || "main"]; -var vite_config_default = defineConfig(buildTarget || viteConfig); -export { - vite_config_default as default, - viteConfig -}; -//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["vite.config.mts", "src/dev-utils/util.js", "src/dev-utils/buildVars.js", "src/dev-utils/external.js", "src/dev-utils/globalDepPlguin.js"],
  "sourcesContent": ["const __vite_injected_original_dirname = \"C:\\\\Projects\\\\lowcoder\\\\client\\\\packages\\\\lowcoder\";const __vite_injected_original_filename = \"C:\\\\Projects\\\\lowcoder\\\\client\\\\packages\\\\lowcoder\\\\vite.config.mts\";const __vite_injected_original_import_meta_url = \"file:///C:/Projects/lowcoder/client/packages/lowcoder/vite.config.mts\";import dotenv from \"dotenv\";\r\nimport { defineConfig, ServerOptions, UserConfig } from \"vite\";\r\nimport react from \"@vitejs/plugin-react\";\r\nimport viteTsconfigPaths from \"vite-tsconfig-paths\";\r\nimport svgrPlugin from \"vite-plugin-svgr\";\r\nimport checker from \"vite-plugin-checker\";\r\nimport { visualizer } from \"rollup-plugin-visualizer\";\r\nimport path from \"path\";\r\nimport chalk from \"chalk\";\r\nimport { createHtmlPlugin } from \"vite-plugin-html\";\r\nimport { ensureLastSlash } from \"./src/dev-utils/util\";\r\nimport { buildVars } from \"./src/dev-utils/buildVars\";\r\nimport { globalDepPlugin } from \"./src/dev-utils/globalDepPlguin\";\r\n\r\ndotenv.config();\r\n\r\nconst apiProxyTarget = process.env.LOWCODER_API_SERVICE_URL;\r\nconst nodeServiceApiProxyTarget = process.env.NODE_SERVICE_API_PROXY_TARGET;\r\nconst nodeEnv = process.env.NODE_ENV ?? \"development\";\r\nconst edition = process.env.REACT_APP_EDITION;\r\nconst isEEGlobal = edition === \"enterprise-global\";\r\nconst isEE = edition === \"enterprise\" || isEEGlobal;\r\nconst isDev = nodeEnv === \"development\";\r\nconst isVisualizerEnabled = !!process.env.ENABLE_VISUALIZER;\r\n// the file was never created\r\n// const browserCheckFileName = `browser-check-${process.env.REACT_APP_COMMIT_ID}.js`;\r\nconst browserCheckFileName = `browser-check.js`;\r\nconst base = ensureLastSlash(process.env.PUBLIC_URL);\r\n\r\nif (!apiProxyTarget && isDev) {\r\n  console.log();\r\n  console.log(chalk.red`LOWCODER_API_SERVICE_URL is required.\\n`);\r\n  console.log(chalk.cyan`Start with command: LOWCODER_API_SERVICE_URL=\\{backend-api-addr\\} yarn start`);\r\n  console.log();\r\n  process.exit(1);\r\n}\r\n\r\nconst proxyConfig: ServerOptions[\"proxy\"] = {\r\n  \"/api\": {\r\n    target: apiProxyTarget,\r\n    changeOrigin: false,\r\n  },\r\n};\r\n\r\nif (nodeServiceApiProxyTarget) {\r\n  proxyConfig[\"/node-service\"] = {\r\n    target: nodeServiceApiProxyTarget,\r\n  };\r\n}\r\n\r\nconst define = {};\r\nbuildVars.forEach(({ name, defaultValue }) => {\r\n  define[name] = JSON.stringify(process.env[name] || defaultValue);\r\n});\r\n\r\n// https://vitejs.dev/config/\r\nexport const viteConfig: UserConfig = {\r\n  define,\r\n  assetsInclude: [\"**/*.md\"],\r\n  resolve: {\r\n    extensions: [\".mjs\", \".js\", \".ts\", \".jsx\", \".tsx\", \".json\"],\r\n    alias: {\r\n      \"@lowcoder-ee\": path.resolve(\r\n        __dirname,\r\n        isEE ? `../lowcoder/src/${isEEGlobal ? \"ee-global\" : \"ee\"}` : \"../lowcoder/src\"\r\n      ),\r\n    },\r\n  },\r\n  base,\r\n  build: {\r\n    manifest: true,\r\n    target: \"es2015\",\r\n    cssTarget: \"chrome63\",\r\n    outDir: \"build\",\r\n    assetsDir: \"static\",\r\n    emptyOutDir: false,\r\n    rollupOptions: {\r\n      output: {\r\n        chunkFileNames: \"[hash].js\",\r\n      },\r\n    },\r\n    commonjsOptions: {\r\n      defaultIsModuleExports: (id) => {\r\n        if (id.indexOf(\"antd/lib\") !== -1) {\r\n          return false;\r\n        }\r\n        return \"auto\";\r\n      },\r\n    },\r\n  },\r\n  css: {\r\n    preprocessorOptions: {\r\n      less: {\r\n        modifyVars: {\r\n          \"@primary-color\": \"#3377FF\",\r\n          \"@link-color\": \"#3377FF\",\r\n          \"@border-color-base\": \"#D7D9E0\",\r\n          \"@border-radius-base\": \"4px\",\r\n        },\r\n        javascriptEnabled: true,\r\n      },\r\n    },\r\n  },\r\n  server: {\r\n    open: true,\r\n    cors: true,\r\n    port: 8000,\r\n    host: \"0.0.0.0\",\r\n    proxy: proxyConfig,\r\n  },\r\n  plugins: [\r\n    checker({\r\n      typescript: true,\r\n      eslint: {\r\n        lintCommand: 'eslint --quiet \"./src/**/*.{ts,tsx}\"',\r\n        dev: {\r\n          logLevel: [\"error\"],\r\n        },\r\n      },\r\n    }),\r\n    react({\r\n      babel: {\r\n        parserOpts: {\r\n          plugins: [\"decorators-legacy\"],\r\n        },\r\n      },\r\n    }),\r\n    viteTsconfigPaths({\r\n      projects: [\"../lowcoder/tsconfig.json\", \"../lowcoder-design/tsconfig.json\"],\r\n    }),\r\n    svgrPlugin({\r\n      svgrOptions: {\r\n        exportType: \"named\",\r\n        prettier: false,\r\n        svgo: false,\r\n        titleProp: true,\r\n        ref: true,\r\n      },\r\n    }),\r\n    globalDepPlugin(),\r\n    createHtmlPlugin({\r\n      minify: true,\r\n      inject: {\r\n        data: {\r\n          browserCheckScript: isDev ? \"\" : `<script src=\"${base}${browserCheckFileName}\"></script>`,\r\n        },\r\n      },\r\n    }),\r\n    isVisualizerEnabled && visualizer(),\r\n  ].filter(Boolean),\r\n};\r\n\r\nconst browserCheckConfig: UserConfig = {\r\n  ...viteConfig,\r\n  define: {\r\n    ...viteConfig.define,\r\n    \"process.env.NODE_ENV\": JSON.stringify(\"production\"),\r\n  },\r\n  build: {\r\n    ...viteConfig.build,\r\n    manifest: false,\r\n    copyPublicDir: false,\r\n    emptyOutDir: true,\r\n    lib: {\r\n      formats: [\"iife\"],\r\n      name: \"BrowserCheck\",\r\n      entry: \"./src/browser-check.ts\",\r\n      fileName: () => {\r\n        return browserCheckFileName;\r\n      },\r\n    },\r\n  },\r\n};\r\n\r\nconst buildTargets = {\r\n  main: viteConfig,\r\n  browserCheck: browserCheckConfig,\r\n};\r\n\r\nconst buildTarget = buildTargets[process.env.BUILD_TARGET || \"main\"];\r\n\r\nexport default defineConfig(buildTarget || viteConfig);\r\n", "const __vite_injected_original_dirname = \"C:\\\\Projects\\\\lowcoder\\\\client\\\\packages\\\\lowcoder\\\\src\\\\dev-utils\";const __vite_injected_original_filename = \"C:\\\\Projects\\\\lowcoder\\\\client\\\\packages\\\\lowcoder\\\\src\\\\dev-utils\\\\util.js\";const __vite_injected_original_import_meta_url = \"file:///C:/Projects/lowcoder/client/packages/lowcoder/src/dev-utils/util.js\";import fs from \"node:fs\";\r\nimport { dirname } from \"node:path\";\r\nimport { fileURLToPath } from \"node:url\";\r\n\r\nexport function stripLastSlash(str) {\r\n  if (str.endsWith(\"/\")) {\r\n    return str.slice(0, str.length - 1);\r\n  }\r\n  return str;\r\n}\r\n\r\nexport function ensureLastSlash(str) {\r\n  if (!str) {\r\n    return \"/\";\r\n  }\r\n  if (!str.endsWith(\"/\")) {\r\n    return `${str}/`;\r\n  }\r\n  return str;\r\n}\r\n\r\nexport function readJson(file) {\r\n  return JSON.parse(fs.readFileSync(file).toString());\r\n}\r\n\r\nexport function currentDirName(importMetaUrl) {\r\n  return dirname(fileURLToPath(importMetaUrl));\r\n}\r\n", "const __vite_injected_original_dirname = \"C:\\\\Projects\\\\lowcoder\\\\client\\\\packages\\\\lowcoder\\\\src\\\\dev-utils\";const __vite_injected_original_filename = \"C:\\\\Projects\\\\lowcoder\\\\client\\\\packages\\\\lowcoder\\\\src\\\\dev-utils\\\\buildVars.js\";const __vite_injected_original_import_meta_url = \"file:///C:/Projects/lowcoder/client/packages/lowcoder/src/dev-utils/buildVars.js\";export const buildVars = [\r\n  {\r\n    name: \"PUBLIC_URL\",\r\n    defaultValue: \"/\",\r\n  },\r\n  {\r\n    name: \"REACT_APP_EDITION\",\r\n    defaultValue: \"community\",\r\n  },\r\n  {\r\n    name: \"REACT_APP_LANGUAGES\",\r\n    defaultValue: \"\",\r\n  },\r\n  {\r\n    name: \"REACT_APP_COMMIT_ID\",\r\n    defaultValue: \"00000\",\r\n  },\r\n  {\r\n    name: \"REACT_APP_API_HOST\",\r\n    defaultValue: \"\",\r\n  },\r\n  {\r\n    name: \"LOWCODER_NODE_SERVICE_URL\",\r\n    defaultValue: \"\",\r\n  },\r\n  {\r\n    name: \"REACT_APP_ENV\",\r\n    defaultValue: \"production\",\r\n  },\r\n  {\r\n    name: \"REACT_APP_BUILD_ID\",\r\n    defaultValue: \"\",\r\n  },\r\n  {\r\n    name: \"REACT_APP_LOG_LEVEL\",\r\n    defaultValue: \"error\",\r\n  },\r\n  {\r\n    name: \"REACT_APP_IMPORT_MAP\",\r\n    defaultValue: \"{}\",\r\n  },\r\n  {\r\n    name: \"REACT_APP_SERVER_IPS\",\r\n    defaultValue: \"\",\r\n  },\r\n  {\r\n    name: \"REACT_APP_BUNDLE_BUILTIN_PLUGIN\",\r\n    defaultValue: \"\",\r\n  },\r\n  {\r\n    name: \"REACT_APP_BUNDLE_TYPE\",\r\n    defaultValue: \"app\",\r\n  },\r\n  {\r\n    name: \"REACT_APP_DISABLE_JS_SANDBOX\",\r\n    defaultValue: \"\",\r\n  },\r\n];\r\n", "const __vite_injected_original_dirname = \"C:\\\\Projects\\\\lowcoder\\\\client\\\\packages\\\\lowcoder\\\\src\\\\dev-utils\";const __vite_injected_original_filename = \"C:\\\\Projects\\\\lowcoder\\\\client\\\\packages\\\\lowcoder\\\\src\\\\dev-utils\\\\external.js\";const __vite_injected_original_import_meta_url = \"file:///C:/Projects/lowcoder/client/packages/lowcoder/src/dev-utils/external.js\";/**\r\n * libs to import as global var\r\n * name: module name\r\n * mergeDefaultAndNameExports: whether to merge default and named exports\r\n */\r\nexport const libs = [\r\n  \"axios\",\r\n  \"redux\",\r\n  \"react-router\",\r\n  \"react-router-dom\",\r\n  \"react-redux\",\r\n  \"react\",\r\n  \"react-dom\",\r\n  \"lodash\",\r\n  \"history\",\r\n  \"antd\",\r\n  \"@dnd-kit/core\",\r\n  \"@dnd-kit/modifiers\",\r\n  \"@dnd-kit/sortable\",\r\n  \"@dnd-kit/utilities\",\r\n  {\r\n    name: \"moment\",\r\n    extractDefault: true,\r\n  },\r\n  {\r\n    name: \"dayjs\",\r\n    extractDefault: true,\r\n  },\r\n  {\r\n    name: \"lowcoder-sdk\",\r\n    from: \"./src/index.sdk.ts\",\r\n  },\r\n  {\r\n    name: \"styled-components\",\r\n    mergeDefaultAndNameExports: true,\r\n  },\r\n];\r\n\r\n/**\r\n * get global var name from module name\r\n * @param {string} name\r\n * @returns\r\n */\r\nexport const getLibGlobalVarName = (name) => {\r\n  return \"$\" + name.replace(/@/g, \"$\").replace(/[\\/\\-]/g, \"_\");\r\n};\r\n\r\nexport const getLibNames = () => {\r\n  return libs.map((i) => {\r\n    if (typeof i === \"object\") {\r\n      return i.name;\r\n    }\r\n    return i;\r\n  });\r\n};\r\n\r\nexport const getAllLibGlobalVarNames = () => {\r\n  const ret = {};\r\n  libs.forEach((lib) => {\r\n    let name = lib;\r\n    if (typeof lib === \"object\") {\r\n      name = lib.name;\r\n    }\r\n    ret[name] = getLibGlobalVarName(name);\r\n  });\r\n  return ret;\r\n};\r\n\r\nexport const libsImportCode = (exclude = []) => {\r\n  const importLines = [];\r\n  const assignLines = [];\r\n  libs.forEach((i) => {\r\n    let name = i;\r\n    let merge = false;\r\n    let from = name;\r\n    let extractDefault = false;\r\n\r\n    if (typeof i === \"object\") {\r\n      name = i.name;\r\n      merge = i.mergeDefaultAndNameExports ?? false;\r\n      from = i.from ?? name;\r\n      extractDefault = i.extractDefault ?? false;\r\n    }\r\n\r\n    if (exclude.includes(name)) {\r\n      return;\r\n    }\r\n\r\n    const varName = getLibGlobalVarName(name);\r\n    if (merge) {\r\n      importLines.push(`import * as ${varName}_named_exports from '${from}';`);\r\n      importLines.push(`import ${varName} from '${from}';`);\r\n      assignLines.push(`Object.assign(${varName}, ${varName}_named_exports);`);\r\n    } else if (extractDefault) {\r\n      importLines.push(`import ${varName} from '${from}';`);\r\n    } else {\r\n      importLines.push(`import * as ${varName} from '${from}';`);\r\n    }\r\n    assignLines.push(`window.${varName} = ${varName};`);\r\n  });\r\n  return importLines.concat(assignLines).join(\"\\n\");\r\n};\r\n", "const __vite_injected_original_dirname = \"C:\\\\Projects\\\\lowcoder\\\\client\\\\packages\\\\lowcoder\\\\src\\\\dev-utils\";const __vite_injected_original_filename = \"C:\\\\Projects\\\\lowcoder\\\\client\\\\packages\\\\lowcoder\\\\src\\\\dev-utils\\\\globalDepPlguin.js\";const __vite_injected_original_import_meta_url = \"file:///C:/Projects/lowcoder/client/packages/lowcoder/src/dev-utils/globalDepPlguin.js\";import { libsImportCode } from \"./external.js\";\r\n\r\nexport function globalDepPlugin(exclude = []) {\r\n  const virtualModuleId = \"virtual:globals\";\r\n  return {\r\n    name: \"lowcoder-global-plugin\",\r\n    resolveId(id) {\r\n      if (id === virtualModuleId) {\r\n        return id;\r\n      }\r\n    },\r\n    load(id) {\r\n      if (id === virtualModuleId) {\r\n        return libsImportCode(exclude);\r\n      }\r\n    },\r\n  };\r\n}\r\n"],
  "mappings": "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",
  "names": []
}
