PowerApps – Function Component
data:image/s3,"s3://crabby-images/611b4/611b468a54fae2fac3bfaaaefe7d312a080b16b3" alt="custom properties"
This post is to describe how I solved a problem using a component. The problem was I wanted to have calculation I could reuse. In a more traditional programming environment I would write a function. Components are reusable so it kind of made sense to use one of them as a function component..
Calculation Details
The calculation I wanted to do was convert a decimal number to a hex number. PowerApps doesn’t have a function to do this so I worked out the calculation. I added a text input to take the decimal number and then a label to contain the calculation.
data:image/s3,"s3://crabby-images/ff075/ff0753f9719ebc4cffa91258f4c4a019bafb4444" alt="calculation details"
Create the Function Component
In my app I had already turned on components and added a new component. Shane Young does a great intro to components found here. I then added 2 custom properties. DEC is the decimal value as an input to my component like a parameter to a function and HEX as the returned value.
data:image/s3,"s3://crabby-images/3e756/3e756f867edd7d2a5821154f87d6644aa66ab212" alt="adding custom properties to function component"
I then clicked on the HEX Value to enter in a the formula as the following code.
With(
{
FirstBit:(DECtoHEX.DEC-Mod(
DECtoHEX.DEC,
16
))/16,
SecondBit: Mod(
DECtoHEX.DEC,
16
)
},
If(FirstBit>9,Char(55+FirstBit),FirstBit) &
If(SecondBit>9,Char(55+SecondBit),SecondBit)
)
Using the Function Component
Back on the screen of my app I can use the component using a slider value as the input. I can hide the component as it doesn’t need to be seen.
I needed a HEX value to use in some SVG for an image. In this example I used a slider to determine red value from 0 to 255. I add the component and pass in the slider value into the DEC. I then use the HEX in the SVG code I’m using in an image. See my Introduction to SVG to explain the SVG part.
data:image/s3,"s3://crabby-images/fcca1/fcca1a32b85f6da2474cacf61edacb2a95c59641" alt="Using HEX value calculated by function component in SVG"
I could then add a slider and component for green, blue and transparency to make my image fully adjustable.
Conclusion
Components as function opens many possibilities and as 2 of my favourite PowerApp builders Hiro and Brian Dang use them I’m going to explore them some more.
Update
Thanks to Brian Dang for giving me a tidier version of the calculation using nested WITH functions. So the calculation inside the component is now:
With(
{
CalcValue: Mod(DECtoHEX.DEC,16)
},
With(
{
FirstBit: (DECtoHEX.DEC-CalcValue)/16,
SecondBit: CalcValue
},
If(FirstBit>9,Char(55+FirstBit),FirstBit) &
If(SecondBit>9,Char(55+SecondBit),SecondBit)
)