Compound.Pill¶
Generates a pill SVG compound (rounded rectangle with text centered inside)
| Parameter | Type | Required | Description |
|---|---|---|---|
| x | INT64 | The x position of compound | |
| y | INT64 | The y position of compound | |
| width | INT64 | The width of the compound | |
| height | INT64 | The height of the compound | |
| paddingX | DOUBLE | The horizontal padding percentage (0.0-1.0, e.g., 0.1 = 10% padding) | |
| paddingY | DOUBLE | The vertical padding percentage (0.0-1.0, e.g., 0.1 = 10% padding) | |
| txt | STRING | The text to display | |
| color | STRING | The Hex color of the pill (e.g., "#01B8AA80") |
STRING A pill-shaped SVG element with rounded corners and centered text
function 'DaxLib.SVG.Compound.Pill' =
(
x: INT64,
y: INT64,
width: INT64,
height: INT64,
paddingX: DOUBLE,
paddingY: DOUBLE,
txt: STRING,
color: STRING
) =>
// Apply padding to dimensions
VAR _X = x + (width * (IF(ISBLANK(paddingX), 0, paddingX) / 2))
VAR _Y = y + (height * (IF(ISBLANK(paddingY), 0, paddingY) / 2))
VAR _Width = width * (1 - IF(ISBLANK(paddingX), 0, paddingX))
VAR _Height = height * (1 - IF(ISBLANK(paddingY), 0, paddingY))
VAR _Pill =
DaxLib.SVG.Element.Rect(
_X, // x
_Y, // y
_Width * 0.98, // width
_Height * 0.92, // height
10, // rx
10, // ry
DaxLib.SVG.Attr.Shapes(
color, // fill
0.2, // fillOpacity
BLANK(), // fillRule
color, // stroke
1, // strokeWidth
BLANK(), // strokeOpacity
BLANK() // opacity
), // attributes
BLANK() // transforms
)
VAR _TextElement =
DaxLib.SVG.Element.Txt(
_X + (_Width * 0.50), // x
_Y + (_Height * 0.58), // y
txt, // txt
0, // dx
0, // dy
DaxLib.SVG.Attr.Shapes(
color, // fill
BLANK(), // fillOpacity
BLANK(), // fillRule
BLANK(), // stroke
BLANK(), // strokeWidth
BLANK(), // strokeOpacity
BLANK() // opacity
) &
DaxLib.SVG.Attr.Txt(
"Segoe UI", // fontFamily
12, // fontSize
BLANK(), // fontWeight
BLANK(), // fontStyle
"middle", // textAnchor
"middle", // baseline
BLANK(), // textDecoration
BLANK(), // letterSpacing
BLANK() // wordSpacing
), // attributes
BLANK() // transforms
)
VAR _CombinedElements =
_Pill &
_TextElement
RETURN
IF( NOT ISBLANK( txt ), _CombinedElements )