@eturnity/eturnity_reusable_components 8.19.8-EPDM-6306.4 → 8.19.8-EPDM-14690.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +1 -1
- package/src/App.vue +3 -1
- package/src/DemoChart.vue +424 -0
- package/src/TestChart.vue +229 -0
- package/src/assets/theme.js +78 -0
- package/src/components/barchart/BottomFields.vue +126 -36
- package/src/components/barchart/composables/useAxisCalculations.js +1 -1
- package/src/components/barchart/composables/useChartData.js +1 -1
- package/src/components/barchart/composables/useTooltip.js +28 -3
- package/src/components/barchart/index.vue +58 -15
- package/src/components/barchart/styles/bottomFields.js +18 -4
- package/src/components/barchart/styles/chart.js +1 -0
- package/src/components/buttons/mainButton/index.vue +2 -0
- package/src/components/errorMessage/index.vue +1 -1
- package/src/components/icon/index.vue +4 -2
- package/src/components/infoCard/index.vue +15 -3
- package/src/components/infoCard/infoCard.spec.js +3 -3
- package/src/components/infoText/index.vue +36 -31
- package/src/components/inputs/inputNumber/index.vue +170 -77
- package/src/components/pageTitle/index.vue +0 -1
- package/src/components/tag/proTag/index.vue +19 -0
- package/src/helpers/numberConverter.js +1 -1
- package/dist/main.es.js +0 -7
- package/dist/main.es10.js +0 -10
- package/dist/main.es100.js +0 -23
- package/dist/main.es101.js +0 -23
- package/dist/main.es102.js +0 -20
- package/dist/main.es103.js +0 -20
- package/dist/main.es104.js +0 -20
- package/dist/main.es105.js +0 -37
- package/dist/main.es106.js +0 -28
- package/dist/main.es107.js +0 -32
- package/dist/main.es108.js +0 -18
- package/dist/main.es109.js +0 -33
- package/dist/main.es11.js +0 -2484
- package/dist/main.es110.js +0 -41
- package/dist/main.es111.js +0 -36
- package/dist/main.es112.js +0 -35
- package/dist/main.es113.js +0 -20
- package/dist/main.es114.js +0 -23
- package/dist/main.es115.js +0 -30
- package/dist/main.es116.js +0 -23
- package/dist/main.es117.js +0 -32
- package/dist/main.es118.js +0 -23
- package/dist/main.es119.js +0 -29
- package/dist/main.es12.js +0 -133
- package/dist/main.es120.js +0 -25
- package/dist/main.es121.js +0 -23
- package/dist/main.es122.js +0 -28
- package/dist/main.es123.js +0 -28
- package/dist/main.es124.js +0 -39
- package/dist/main.es125.js +0 -37
- package/dist/main.es126.js +0 -23
- package/dist/main.es127.js +0 -25
- package/dist/main.es128.js +0 -23
- package/dist/main.es129.js +0 -23
- package/dist/main.es13.js +0 -261
- package/dist/main.es130.js +0 -23
- package/dist/main.es131.js +0 -28
- package/dist/main.es132.js +0 -29
- package/dist/main.es133.js +0 -29
- package/dist/main.es134.js +0 -21
- package/dist/main.es135.js +0 -20
- package/dist/main.es136.js +0 -28
- package/dist/main.es137.js +0 -24
- package/dist/main.es138.js +0 -28
- package/dist/main.es139.js +0 -23
- package/dist/main.es14.js +0 -26
- package/dist/main.es140.js +0 -33
- package/dist/main.es141.js +0 -30
- package/dist/main.es142.js +0 -23
- package/dist/main.es143.js +0 -20
- package/dist/main.es144.js +0 -19
- package/dist/main.es145.js +0 -23
- package/dist/main.es146.js +0 -29
- package/dist/main.es147.js +0 -28
- package/dist/main.es148.js +0 -35
- package/dist/main.es149.js +0 -25
- package/dist/main.es15.js +0 -1058
- package/dist/main.es150.js +0 -25
- package/dist/main.es151.js +0 -23
- package/dist/main.es152.js +0 -41
- package/dist/main.es153.js +0 -41
- package/dist/main.es154.js +0 -25
- package/dist/main.es155.js +0 -23
- package/dist/main.es156.js +0 -23
- package/dist/main.es157.js +0 -25
- package/dist/main.es158.js +0 -23
- package/dist/main.es159.js +0 -23
- package/dist/main.es16.js +0 -692
- package/dist/main.es160.js +0 -23
- package/dist/main.es161.js +0 -23
- package/dist/main.es162.js +0 -23
- package/dist/main.es163.js +0 -23
- package/dist/main.es164.js +0 -20
- package/dist/main.es165.js +0 -28
- package/dist/main.es166.js +0 -28
- package/dist/main.es167.js +0 -28
- package/dist/main.es168.js +0 -28
- package/dist/main.es169.js +0 -25
- package/dist/main.es17.js +0 -95
- package/dist/main.es170.js +0 -23
- package/dist/main.es171.js +0 -23
- package/dist/main.es172.js +0 -20
- package/dist/main.es173.js +0 -20
- package/dist/main.es174.js +0 -23
- package/dist/main.es175.js +0 -18
- package/dist/main.es176.js +0 -23
- package/dist/main.es177.js +0 -20
- package/dist/main.es178.js +0 -25
- package/dist/main.es179.js +0 -25
- package/dist/main.es18.js +0 -78
- package/dist/main.es180.js +0 -23
- package/dist/main.es181.js +0 -23
- package/dist/main.es182.js +0 -20
- package/dist/main.es183.js +0 -23
- package/dist/main.es184.js +0 -23
- package/dist/main.es185.js +0 -32
- package/dist/main.es186.js +0 -23
- package/dist/main.es187.js +0 -32
- package/dist/main.es188.js +0 -37
- package/dist/main.es189.js +0 -32
- package/dist/main.es19.js +0 -143
- package/dist/main.es190.js +0 -39
- package/dist/main.es191.js +0 -28
- package/dist/main.es192.js +0 -20
- package/dist/main.es193.js +0 -20
- package/dist/main.es194.js +0 -25
- package/dist/main.es195.js +0 -23
- package/dist/main.es196.js +0 -40
- package/dist/main.es197.js +0 -23
- package/dist/main.es198.js +0 -21
- package/dist/main.es199.js +0 -19
- package/dist/main.es2.js +0 -34
- package/dist/main.es20.js +0 -152
- package/dist/main.es200.js +0 -20
- package/dist/main.es201.js +0 -20
- package/dist/main.es202.js +0 -33
- package/dist/main.es203.js +0 -23
- package/dist/main.es204.js +0 -23
- package/dist/main.es205.js +0 -28
- package/dist/main.es206.js +0 -23
- package/dist/main.es207.js +0 -23
- package/dist/main.es208.js +0 -21
- package/dist/main.es209.js +0 -23
- package/dist/main.es21.js +0 -108
- package/dist/main.es210.js +0 -28
- package/dist/main.es211.js +0 -23
- package/dist/main.es212.js +0 -23
- package/dist/main.es213.js +0 -23
- package/dist/main.es214.js +0 -28
- package/dist/main.es215.js +0 -28
- package/dist/main.es216.js +0 -20
- package/dist/main.es217.js +0 -23
- package/dist/main.es218.js +0 -35
- package/dist/main.es219.js +0 -28
- package/dist/main.es22.js +0 -4
- package/dist/main.es220.js +0 -29
- package/dist/main.es221.js +0 -24
- package/dist/main.es222.js +0 -23
- package/dist/main.es223.js +0 -28
- package/dist/main.es224.js +0 -25
- package/dist/main.es225.js +0 -23
- package/dist/main.es226.js +0 -23
- package/dist/main.es227.js +0 -20
- package/dist/main.es228.js +0 -20
- package/dist/main.es229.js +0 -23
- package/dist/main.es23.js +0 -169
- package/dist/main.es230.js +0 -23
- package/dist/main.es231.js +0 -25
- package/dist/main.es232.js +0 -38
- package/dist/main.es233.js +0 -30
- package/dist/main.es234.js +0 -28
- package/dist/main.es235.js +0 -23
- package/dist/main.es236.js +0 -22
- package/dist/main.es237.js +0 -28
- package/dist/main.es238.js +0 -23
- package/dist/main.es239.js +0 -18
- package/dist/main.es24.js +0 -201
- package/dist/main.es240.js +0 -23
- package/dist/main.es241.js +0 -25
- package/dist/main.es242.js +0 -23
- package/dist/main.es243.js +0 -23
- package/dist/main.es244.js +0 -23
- package/dist/main.es245.js +0 -23
- package/dist/main.es246.js +0 -23
- package/dist/main.es247.js +0 -23
- package/dist/main.es248.js +0 -23
- package/dist/main.es249.js +0 -23
- package/dist/main.es25.js +0 -55
- package/dist/main.es250.js +0 -30
- package/dist/main.es251.js +0 -23
- package/dist/main.es252.js +0 -23
- package/dist/main.es253.js +0 -28
- package/dist/main.es254.js +0 -23
- package/dist/main.es255.js +0 -23
- package/dist/main.es256.js +0 -28
- package/dist/main.es257.js +0 -33
- package/dist/main.es258.js +0 -28
- package/dist/main.es259.js +0 -28
- package/dist/main.es26.js +0 -12
- package/dist/main.es260.js +0 -23
- package/dist/main.es261.js +0 -25
- package/dist/main.es262.js +0 -28
- package/dist/main.es263.js +0 -30
- package/dist/main.es264.js +0 -23
- package/dist/main.es265.js +0 -23
- package/dist/main.es266.js +0 -23
- package/dist/main.es267.js +0 -23
- package/dist/main.es268.js +0 -28
- package/dist/main.es269.js +0 -252
- package/dist/main.es27.js +0 -6
- package/dist/main.es270.js +0 -22
- package/dist/main.es271.js +0 -25
- package/dist/main.es272.js +0 -7
- package/dist/main.es273.js +0 -383
- package/dist/main.es274.js +0 -54
- package/dist/main.es275.js +0 -15
- package/dist/main.es276.js +0 -64
- package/dist/main.es277.js +0 -4
- package/dist/main.es278.js +0 -4
- package/dist/main.es279.js +0 -4
- package/dist/main.es28.js +0 -103
- package/dist/main.es280.js +0 -4
- package/dist/main.es281.js +0 -4
- package/dist/main.es282.js +0 -4
- package/dist/main.es283.js +0 -4
- package/dist/main.es284.js +0 -4
- package/dist/main.es285.js +0 -4
- package/dist/main.es286.js +0 -4
- package/dist/main.es287.js +0 -4
- package/dist/main.es288.js +0 -4
- package/dist/main.es289.js +0 -4
- package/dist/main.es29.js +0 -62
- package/dist/main.es290.js +0 -4
- package/dist/main.es291.js +0 -4
- package/dist/main.es292.js +0 -4
- package/dist/main.es293.js +0 -4
- package/dist/main.es294.js +0 -4
- package/dist/main.es295.js +0 -4
- package/dist/main.es296.js +0 -4
- package/dist/main.es297.js +0 -4
- package/dist/main.es298.js +0 -4
- package/dist/main.es299.js +0 -4
- package/dist/main.es3.js +0 -70
- package/dist/main.es30.js +0 -69
- package/dist/main.es300.js +0 -4
- package/dist/main.es301.js +0 -4
- package/dist/main.es302.js +0 -4
- package/dist/main.es303.js +0 -4
- package/dist/main.es304.js +0 -4
- package/dist/main.es305.js +0 -4
- package/dist/main.es306.js +0 -4
- package/dist/main.es307.js +0 -4
- package/dist/main.es308.js +0 -4
- package/dist/main.es309.js +0 -4
- package/dist/main.es31.js +0 -801
- package/dist/main.es310.js +0 -4
- package/dist/main.es311.js +0 -4
- package/dist/main.es312.js +0 -4
- package/dist/main.es313.js +0 -4
- package/dist/main.es314.js +0 -4
- package/dist/main.es315.js +0 -4
- package/dist/main.es316.js +0 -4
- package/dist/main.es317.js +0 -4
- package/dist/main.es318.js +0 -4
- package/dist/main.es319.js +0 -4
- package/dist/main.es32.js +0 -127
- package/dist/main.es320.js +0 -4
- package/dist/main.es321.js +0 -4
- package/dist/main.es322.js +0 -4
- package/dist/main.es323.js +0 -4
- package/dist/main.es324.js +0 -4
- package/dist/main.es325.js +0 -4
- package/dist/main.es326.js +0 -4
- package/dist/main.es327.js +0 -4
- package/dist/main.es328.js +0 -4
- package/dist/main.es329.js +0 -4
- package/dist/main.es33.js +0 -4
- package/dist/main.es330.js +0 -4
- package/dist/main.es331.js +0 -4
- package/dist/main.es332.js +0 -4
- package/dist/main.es333.js +0 -4
- package/dist/main.es334.js +0 -4
- package/dist/main.es335.js +0 -4
- package/dist/main.es336.js +0 -4
- package/dist/main.es337.js +0 -4
- package/dist/main.es338.js +0 -4
- package/dist/main.es339.js +0 -4
- package/dist/main.es34.js +0 -29
- package/dist/main.es340.js +0 -4
- package/dist/main.es341.js +0 -4
- package/dist/main.es342.js +0 -4
- package/dist/main.es343.js +0 -4
- package/dist/main.es344.js +0 -4
- package/dist/main.es345.js +0 -4
- package/dist/main.es346.js +0 -4
- package/dist/main.es347.js +0 -4
- package/dist/main.es348.js +0 -4
- package/dist/main.es349.js +0 -4
- package/dist/main.es35.js +0 -34
- package/dist/main.es350.js +0 -4
- package/dist/main.es351.js +0 -4
- package/dist/main.es352.js +0 -4
- package/dist/main.es353.js +0 -4
- package/dist/main.es354.js +0 -4
- package/dist/main.es355.js +0 -4
- package/dist/main.es356.js +0 -4
- package/dist/main.es357.js +0 -4
- package/dist/main.es358.js +0 -4
- package/dist/main.es359.js +0 -4
- package/dist/main.es36.js +0 -36
- package/dist/main.es360.js +0 -4
- package/dist/main.es361.js +0 -4
- package/dist/main.es362.js +0 -4
- package/dist/main.es363.js +0 -4
- package/dist/main.es364.js +0 -4
- package/dist/main.es365.js +0 -4
- package/dist/main.es366.js +0 -4
- package/dist/main.es367.js +0 -4
- package/dist/main.es368.js +0 -4
- package/dist/main.es369.js +0 -4
- package/dist/main.es37.js +0 -41
- package/dist/main.es370.js +0 -4
- package/dist/main.es371.js +0 -4
- package/dist/main.es372.js +0 -4
- package/dist/main.es373.js +0 -4
- package/dist/main.es374.js +0 -4
- package/dist/main.es375.js +0 -4
- package/dist/main.es376.js +0 -4
- package/dist/main.es377.js +0 -4
- package/dist/main.es378.js +0 -4
- package/dist/main.es379.js +0 -4
- package/dist/main.es38.js +0 -35
- package/dist/main.es380.js +0 -4
- package/dist/main.es381.js +0 -4
- package/dist/main.es382.js +0 -4
- package/dist/main.es383.js +0 -4
- package/dist/main.es384.js +0 -4
- package/dist/main.es385.js +0 -4
- package/dist/main.es386.js +0 -4
- package/dist/main.es387.js +0 -4
- package/dist/main.es388.js +0 -4
- package/dist/main.es389.js +0 -4
- package/dist/main.es39.js +0 -20
- package/dist/main.es390.js +0 -4
- package/dist/main.es391.js +0 -4
- package/dist/main.es392.js +0 -4
- package/dist/main.es393.js +0 -4
- package/dist/main.es394.js +0 -4
- package/dist/main.es395.js +0 -4
- package/dist/main.es396.js +0 -4
- package/dist/main.es397.js +0 -4
- package/dist/main.es398.js +0 -4
- package/dist/main.es399.js +0 -4
- package/dist/main.es4.js +0 -19
- package/dist/main.es40.js +0 -20
- package/dist/main.es400.js +0 -4
- package/dist/main.es401.js +0 -4
- package/dist/main.es402.js +0 -4
- package/dist/main.es403.js +0 -4
- package/dist/main.es404.js +0 -4
- package/dist/main.es405.js +0 -4
- package/dist/main.es406.js +0 -4
- package/dist/main.es407.js +0 -4
- package/dist/main.es408.js +0 -4
- package/dist/main.es409.js +0 -4
- package/dist/main.es41.js +0 -25
- package/dist/main.es410.js +0 -4
- package/dist/main.es411.js +0 -4
- package/dist/main.es412.js +0 -4
- package/dist/main.es413.js +0 -4
- package/dist/main.es414.js +0 -4
- package/dist/main.es415.js +0 -4
- package/dist/main.es416.js +0 -4
- package/dist/main.es417.js +0 -4
- package/dist/main.es418.js +0 -4
- package/dist/main.es419.js +0 -4
- package/dist/main.es42.js +0 -28
- package/dist/main.es420.js +0 -4
- package/dist/main.es421.js +0 -4
- package/dist/main.es422.js +0 -4
- package/dist/main.es423.js +0 -4
- package/dist/main.es424.js +0 -4
- package/dist/main.es425.js +0 -4
- package/dist/main.es426.js +0 -4
- package/dist/main.es427.js +0 -4
- package/dist/main.es428.js +0 -4
- package/dist/main.es429.js +0 -4
- package/dist/main.es43.js +0 -23
- package/dist/main.es430.js +0 -4
- package/dist/main.es431.js +0 -4
- package/dist/main.es432.js +0 -4
- package/dist/main.es433.js +0 -4
- package/dist/main.es434.js +0 -4
- package/dist/main.es435.js +0 -4
- package/dist/main.es436.js +0 -4
- package/dist/main.es437.js +0 -4
- package/dist/main.es438.js +0 -4
- package/dist/main.es439.js +0 -4
- package/dist/main.es44.js +0 -44
- package/dist/main.es440.js +0 -4
- package/dist/main.es441.js +0 -4
- package/dist/main.es442.js +0 -4
- package/dist/main.es443.js +0 -4
- package/dist/main.es444.js +0 -4
- package/dist/main.es445.js +0 -4
- package/dist/main.es446.js +0 -4
- package/dist/main.es447.js +0 -4
- package/dist/main.es448.js +0 -4
- package/dist/main.es449.js +0 -4
- package/dist/main.es45.js +0 -38
- package/dist/main.es450.js +0 -4
- package/dist/main.es451.js +0 -4
- package/dist/main.es452.js +0 -4
- package/dist/main.es453.js +0 -4
- package/dist/main.es454.js +0 -4
- package/dist/main.es455.js +0 -4
- package/dist/main.es456.js +0 -4
- package/dist/main.es457.js +0 -4
- package/dist/main.es458.js +0 -4
- package/dist/main.es459.js +0 -4
- package/dist/main.es46.js +0 -23
- package/dist/main.es460.js +0 -4
- package/dist/main.es461.js +0 -4
- package/dist/main.es462.js +0 -4
- package/dist/main.es463.js +0 -4
- package/dist/main.es464.js +0 -4
- package/dist/main.es465.js +0 -4
- package/dist/main.es466.js +0 -4
- package/dist/main.es467.js +0 -4
- package/dist/main.es468.js +0 -4
- package/dist/main.es469.js +0 -4
- package/dist/main.es47.js +0 -23
- package/dist/main.es470.js +0 -4
- package/dist/main.es471.js +0 -4
- package/dist/main.es472.js +0 -4
- package/dist/main.es473.js +0 -4
- package/dist/main.es474.js +0 -4
- package/dist/main.es475.js +0 -4
- package/dist/main.es476.js +0 -4
- package/dist/main.es477.js +0 -4
- package/dist/main.es478.js +0 -4
- package/dist/main.es479.js +0 -4
- package/dist/main.es48.js +0 -24
- package/dist/main.es480.js +0 -4
- package/dist/main.es481.js +0 -4
- package/dist/main.es482.js +0 -4
- package/dist/main.es483.js +0 -4
- package/dist/main.es484.js +0 -4
- package/dist/main.es485.js +0 -4
- package/dist/main.es486.js +0 -4
- package/dist/main.es487.js +0 -4
- package/dist/main.es488.js +0 -4
- package/dist/main.es489.js +0 -4
- package/dist/main.es49.js +0 -35
- package/dist/main.es490.js +0 -4
- package/dist/main.es491.js +0 -4
- package/dist/main.es492.js +0 -4
- package/dist/main.es493.js +0 -4
- package/dist/main.es494.js +0 -4
- package/dist/main.es495.js +0 -4
- package/dist/main.es496.js +0 -4
- package/dist/main.es497.js +0 -4
- package/dist/main.es498.js +0 -4
- package/dist/main.es499.js +0 -4
- package/dist/main.es5.js +0 -586
- package/dist/main.es50.js +0 -30
- package/dist/main.es500.js +0 -4
- package/dist/main.es501.js +0 -4
- package/dist/main.es502.js +0 -4
- package/dist/main.es503.js +0 -4
- package/dist/main.es504.js +0 -4
- package/dist/main.es505.js +0 -4
- package/dist/main.es506.js +0 -4
- package/dist/main.es507.js +0 -4
- package/dist/main.es508.js +0 -4
- package/dist/main.es509.js +0 -4
- package/dist/main.es51.js +0 -34
- package/dist/main.es510.js +0 -4
- package/dist/main.es511.js +0 -88
- package/dist/main.es52.js +0 -20
- package/dist/main.es53.js +0 -20
- package/dist/main.es54.js +0 -23
- package/dist/main.es55.js +0 -28
- package/dist/main.es56.js +0 -28
- package/dist/main.es57.js +0 -23
- package/dist/main.es58.js +0 -25
- package/dist/main.es59.js +0 -24
- package/dist/main.es6.js +0 -5872
- package/dist/main.es60.js +0 -23
- package/dist/main.es61.js +0 -23
- package/dist/main.es62.js +0 -23
- package/dist/main.es63.js +0 -23
- package/dist/main.es64.js +0 -23
- package/dist/main.es65.js +0 -20
- package/dist/main.es66.js +0 -23
- package/dist/main.es67.js +0 -23
- package/dist/main.es68.js +0 -21
- package/dist/main.es69.js +0 -20
- package/dist/main.es7.js +0 -1904
- package/dist/main.es70.js +0 -23
- package/dist/main.es71.js +0 -28
- package/dist/main.es72.js +0 -28
- package/dist/main.es73.js +0 -23
- package/dist/main.es74.js +0 -23
- package/dist/main.es75.js +0 -23
- package/dist/main.es76.js +0 -23
- package/dist/main.es77.js +0 -31
- package/dist/main.es78.js +0 -23
- package/dist/main.es79.js +0 -33
- package/dist/main.es8.js +0 -42
- package/dist/main.es80.js +0 -30
- package/dist/main.es81.js +0 -23
- package/dist/main.es82.js +0 -22
- package/dist/main.es83.js +0 -25
- package/dist/main.es84.js +0 -28
- package/dist/main.es85.js +0 -35
- package/dist/main.es86.js +0 -23
- package/dist/main.es87.js +0 -23
- package/dist/main.es88.js +0 -33
- package/dist/main.es89.js +0 -20
- package/dist/main.es9.js +0 -4
- package/dist/main.es90.js +0 -28
- package/dist/main.es91.js +0 -28
- package/dist/main.es92.js +0 -23
- package/dist/main.es93.js +0 -23
- package/dist/main.es94.js +0 -24
- package/dist/main.es95.js +0 -28
- package/dist/main.es96.js +0 -28
- package/dist/main.es97.js +0 -23
- package/dist/main.es98.js +0 -23
- package/dist/main.es99.js +0 -28
- package/dist/style.css +0 -1
package/src/assets/theme.js
CHANGED
@@ -416,6 +416,30 @@ const theme = (() => {
|
|
416
416
|
},
|
417
417
|
},
|
418
418
|
},
|
419
|
+
protag: {
|
420
|
+
main: {
|
421
|
+
default: {
|
422
|
+
backgroundColor: semanticColors.yellow[300],
|
423
|
+
textColor: semanticColors.teal[800],
|
424
|
+
borderColor: 'transparent',
|
425
|
+
},
|
426
|
+
hover: {
|
427
|
+
backgroundColor: semanticColors.yellow[300],
|
428
|
+
textColor: semanticColors.teal[800],
|
429
|
+
borderColor: '',
|
430
|
+
},
|
431
|
+
active: {
|
432
|
+
backgroundColor: semanticColors.yellow[300],
|
433
|
+
textColor: semanticColors.teal[800],
|
434
|
+
borderColor: '',
|
435
|
+
},
|
436
|
+
disabled: {
|
437
|
+
backgroundColor: semanticColors.yellow[300],
|
438
|
+
textColor: semanticColors.teal[400],
|
439
|
+
borderColor: '',
|
440
|
+
},
|
441
|
+
},
|
442
|
+
},
|
419
443
|
filter: {
|
420
444
|
main: {
|
421
445
|
default: {
|
@@ -590,6 +614,55 @@ const theme = (() => {
|
|
590
614
|
},
|
591
615
|
},
|
592
616
|
},
|
617
|
+
tertiary: {
|
618
|
+
// type
|
619
|
+
main: {
|
620
|
+
// variant: this is the default variant
|
621
|
+
default: {
|
622
|
+
backgroundColor: 'transparent',
|
623
|
+
textColor: semanticColors.purple[50],
|
624
|
+
borderColor: semanticColors.teal[500],
|
625
|
+
},
|
626
|
+
hover: {
|
627
|
+
backgroundColor: semanticColors.teal[600],
|
628
|
+
textColor: semanticColors.purple[50],
|
629
|
+
borderColor: semanticColors.teal[400],
|
630
|
+
},
|
631
|
+
active: {
|
632
|
+
backgroundColor: semanticColors.teal[700],
|
633
|
+
textColor: semanticColors.purple[50],
|
634
|
+
borderColor: semanticColors.teal[300],
|
635
|
+
},
|
636
|
+
disabled: {
|
637
|
+
textColor: semanticColors.grey[600],
|
638
|
+
backgroundColor: semanticColors.grey[500],
|
639
|
+
borderColor: semanticColors.grey[800],
|
640
|
+
},
|
641
|
+
},
|
642
|
+
cancel: {
|
643
|
+
// variant
|
644
|
+
default: {
|
645
|
+
backgroundColor: semanticColors.teal[200],
|
646
|
+
textColor: semanticColors.red[400],
|
647
|
+
borderColor: semanticColors.teal[500],
|
648
|
+
},
|
649
|
+
hover: {
|
650
|
+
backgroundColor: semanticColors.red[700],
|
651
|
+
textColor: semanticColors.red[700],
|
652
|
+
borderColor: semanticColors.teal[400],
|
653
|
+
},
|
654
|
+
active: {
|
655
|
+
backgroundColor: semanticColors.red[600],
|
656
|
+
textColor: semanticColors.red[200],
|
657
|
+
borderColor: semanticColors.teal[300],
|
658
|
+
},
|
659
|
+
disabled: {
|
660
|
+
textColor: semanticColors.grey[600],
|
661
|
+
backgroundColor: semanticColors.grey[500],
|
662
|
+
borderColor: semanticColors.grey[800],
|
663
|
+
},
|
664
|
+
},
|
665
|
+
},
|
593
666
|
ghost: {
|
594
667
|
// type
|
595
668
|
main: {
|
@@ -680,6 +753,11 @@ const theme = (() => {
|
|
680
753
|
fontSize: '14px',
|
681
754
|
iconWidth: '26px',
|
682
755
|
},
|
756
|
+
tiny: {
|
757
|
+
padding: '2px 5px',
|
758
|
+
fontSize: '10px',
|
759
|
+
iconWidth: '18px',
|
760
|
+
},
|
683
761
|
},
|
684
762
|
},
|
685
763
|
}
|
@@ -1,14 +1,14 @@
|
|
1
1
|
<template>
|
2
2
|
<Container :is-chart-controls-shown-in-bottom="isChartControlsShownInBottom">
|
3
3
|
<LabelsColumn :width="yAxisWidth">
|
4
|
-
<LabelRow v-for="series in
|
4
|
+
<LabelRow v-for="series in seriesData" :key="series.name">
|
5
5
|
{{ series.name }}
|
6
6
|
</LabelRow>
|
7
|
-
<TotalRow v-if="
|
8
|
-
{{ $gettext ? $gettext('Total (%)
|
7
|
+
<TotalRow v-if="seriesData.length && fieldMode === 'percentage'">
|
8
|
+
{{ $gettext ? `${$gettext('Total')} (%)` : 'Total (%)' }}
|
9
9
|
</TotalRow>
|
10
|
-
<TotalRow v-if="
|
11
|
-
{{ $gettext ? $gettext('Total (kWh)
|
10
|
+
<TotalRow v-if="seriesData.length">
|
11
|
+
{{ $gettext ? `${$gettext('Total')} (kWh)` : 'Total (kWh)' }}
|
12
12
|
</TotalRow>
|
13
13
|
</LabelsColumn>
|
14
14
|
|
@@ -18,27 +18,36 @@
|
|
18
18
|
>
|
19
19
|
<FieldsWrapper>
|
20
20
|
<!-- For stacked bar chart -->
|
21
|
-
<template v-if="
|
21
|
+
<template v-if="seriesData.length">
|
22
22
|
<InputRow
|
23
|
-
v-for="series in
|
23
|
+
v-for="series in seriesData"
|
24
24
|
:key="series.name"
|
25
25
|
:data-series-name="series.name"
|
26
26
|
>
|
27
27
|
<InputGroup
|
28
28
|
v-for="(item, index) in props.data"
|
29
|
+
:key="index"
|
29
30
|
:bar-width="barWidth"
|
30
31
|
:is-scrollable="isScrollable"
|
31
|
-
:key="index"
|
32
32
|
>
|
33
33
|
<InputNumber
|
34
34
|
:allow-negative="false"
|
35
|
+
:disabled="isInputsDisabled"
|
35
36
|
input-height="36px"
|
36
|
-
:
|
37
|
+
:is-disabled-styled-only="true"
|
38
|
+
:is-info-border="
|
39
|
+
fieldMode === 'percentage'
|
40
|
+
? calculatePercentageTotal(item.label) !== 100
|
41
|
+
: false
|
42
|
+
"
|
37
43
|
:min-decimals="0"
|
44
|
+
:number-precision="fieldMode === 'percentage' ? 2 : 0"
|
38
45
|
text-align="center"
|
39
46
|
:unit-name="fieldMode === 'percentage' ? '%' : ''"
|
40
47
|
:value="getDisplayValue(series.data, item.label)"
|
41
|
-
@input-blur="
|
48
|
+
@input-blur="
|
49
|
+
handleInputBlur($event, series.name, item.label, series.data)
|
50
|
+
"
|
42
51
|
@input-focus="handleInputFocus(series.name, item.label)"
|
43
52
|
/>
|
44
53
|
</InputGroup>
|
@@ -47,16 +56,18 @@
|
|
47
56
|
<TotalInputRow v-if="fieldMode === 'percentage'">
|
48
57
|
<InputGroup
|
49
58
|
v-for="(item, index) in props.data"
|
59
|
+
:key="index"
|
50
60
|
:bar-width="barWidth"
|
51
61
|
:is-scrollable="isScrollable"
|
52
|
-
:key="index"
|
53
62
|
>
|
54
63
|
<InputNumber
|
55
64
|
:allow-negative="false"
|
65
|
+
:disabled="isInputsDisabled"
|
56
66
|
input-height="36px"
|
67
|
+
:is-disabled-styled-only="true"
|
57
68
|
:is-read-only="true"
|
58
|
-
:number-precision="0"
|
59
69
|
:min-decimals="0"
|
70
|
+
:number-precision="fieldMode === 'percentage' ? 2 : 0"
|
60
71
|
text-align="center"
|
61
72
|
:unit-name="fieldMode === 'percentage' ? '%' : ''"
|
62
73
|
:value="calculatePercentageTotal(item.label)"
|
@@ -67,17 +78,23 @@
|
|
67
78
|
<TotalInputRow>
|
68
79
|
<InputGroup
|
69
80
|
v-for="(item, index) in props.data"
|
81
|
+
:key="index"
|
70
82
|
:bar-width="barWidth"
|
71
83
|
:is-scrollable="isScrollable"
|
72
|
-
:key="index"
|
73
84
|
>
|
74
85
|
<InputNumber
|
75
86
|
input-height="36px"
|
87
|
+
:is-border-error-only="true"
|
88
|
+
:is-info-border="
|
89
|
+
fieldMode === 'percentage'
|
90
|
+
? calculatePercentageTotal(item.label) !== 100
|
91
|
+
: false
|
92
|
+
"
|
76
93
|
:is-read-only="true"
|
77
|
-
:number-precision="2"
|
78
94
|
:min-decimals="0"
|
95
|
+
:number-precision="0"
|
79
96
|
text-align="center"
|
80
|
-
:value="
|
97
|
+
:value="calculateTotalValue(item.label)"
|
81
98
|
/>
|
82
99
|
</InputGroup>
|
83
100
|
</TotalInputRow>
|
@@ -88,17 +105,20 @@
|
|
88
105
|
<InputRow>
|
89
106
|
<InputGroup
|
90
107
|
v-for="(item, index) in props.data"
|
108
|
+
:key="index"
|
91
109
|
:bar-width="barWidth"
|
92
110
|
:is-scrollable="isScrollable"
|
93
|
-
:key="index"
|
94
111
|
>
|
95
112
|
<InputNumber
|
113
|
+
:allow-negative="false"
|
114
|
+
:disabled="isInputsDisabled"
|
96
115
|
input-height="36px"
|
116
|
+
:is-disabled-styled-only="true"
|
97
117
|
:min-decimals="0"
|
98
|
-
:number-precision="
|
118
|
+
:number-precision="0"
|
99
119
|
text-align="center"
|
100
120
|
:value="item.value"
|
101
|
-
@input-blur="handleInputBlur($event, null, item.label)"
|
121
|
+
@input-blur="handleInputBlur($event, null, item.label, null)"
|
102
122
|
@input-focus="handleInputFocus(null, item.label)"
|
103
123
|
/>
|
104
124
|
</InputGroup>
|
@@ -107,11 +127,22 @@
|
|
107
127
|
</FieldsWrapper>
|
108
128
|
</FieldsContainer>
|
109
129
|
</Container>
|
130
|
+
<InfoCardContainer
|
131
|
+
v-if="hasAnySegmentNotTotatTo100Percent && fieldMode === 'percentage'"
|
132
|
+
:yAxisWidth="yAxisWidth"
|
133
|
+
>
|
134
|
+
<InfoCard align-items="center" type="info">
|
135
|
+
<InfoCardBody>
|
136
|
+
{{ percentageErrorMessage }}
|
137
|
+
</InfoCardBody>
|
138
|
+
</InfoCard>
|
139
|
+
</InfoCardContainer>
|
110
140
|
</template>
|
111
141
|
|
112
142
|
<script setup>
|
113
|
-
import { ref } from 'vue'
|
143
|
+
import { ref, computed, watchEffect } from 'vue'
|
114
144
|
import InputNumber from '../inputs/inputNumber'
|
145
|
+
import InfoCard from '../infoCard'
|
115
146
|
|
116
147
|
import {
|
117
148
|
Container,
|
@@ -123,6 +154,8 @@
|
|
123
154
|
InputRow,
|
124
155
|
TotalInputRow,
|
125
156
|
InputGroup,
|
157
|
+
InfoCardContainer,
|
158
|
+
InfoCardBody,
|
126
159
|
} from './styles/bottomFields'
|
127
160
|
|
128
161
|
const props = defineProps({
|
@@ -159,6 +192,51 @@
|
|
159
192
|
default: 'absolute',
|
160
193
|
validator: (value) => ['absolute', 'percentage'].includes(value),
|
161
194
|
},
|
195
|
+
isInputsDisabled: {
|
196
|
+
type: Boolean,
|
197
|
+
default: false,
|
198
|
+
},
|
199
|
+
percentageErrorMessage: {
|
200
|
+
type: String,
|
201
|
+
default: '',
|
202
|
+
},
|
203
|
+
})
|
204
|
+
|
205
|
+
const seriesData = ref([])
|
206
|
+
|
207
|
+
watchEffect(() => {
|
208
|
+
let isNewSetOfSeries = false
|
209
|
+
const seriesDataCopy = [...seriesData.value]
|
210
|
+
if (
|
211
|
+
!seriesDataCopy.length ||
|
212
|
+
!props.series.length ||
|
213
|
+
seriesDataCopy.length !== props.series.length ||
|
214
|
+
!seriesDataCopy.some((item) => {
|
215
|
+
return props.series.map((s) => s.name).includes(item.name)
|
216
|
+
})
|
217
|
+
) {
|
218
|
+
isNewSetOfSeries = true
|
219
|
+
}
|
220
|
+
const currentSeriesData = !isNewSetOfSeries ? seriesDataCopy : []
|
221
|
+
const newSeriesData = []
|
222
|
+
|
223
|
+
props.series.forEach((item, itemIndex) => {
|
224
|
+
const data = item.data.map((d, dIndex) => ({
|
225
|
+
label: d.label,
|
226
|
+
value: d.value,
|
227
|
+
percentage: d.percentage,
|
228
|
+
originalValue: currentSeriesData.length
|
229
|
+
? currentSeriesData[itemIndex].data[dIndex].originalValue
|
230
|
+
: d.value,
|
231
|
+
}))
|
232
|
+
|
233
|
+
newSeriesData.push({
|
234
|
+
name: item.name,
|
235
|
+
data,
|
236
|
+
})
|
237
|
+
})
|
238
|
+
|
239
|
+
seriesData.value = [...newSeriesData]
|
162
240
|
})
|
163
241
|
|
164
242
|
const emit = defineEmits([
|
@@ -175,11 +253,13 @@
|
|
175
253
|
emit('input-focus', { seriesName, label })
|
176
254
|
}
|
177
255
|
|
178
|
-
const
|
179
|
-
|
256
|
+
const calculateTotalValue = (label) => {
|
257
|
+
const total = seriesData.value.reduce((sum, series) => {
|
180
258
|
const value = series.data.find((d) => d.label === label)?.value || 0
|
181
259
|
return sum + value
|
182
260
|
}, 0)
|
261
|
+
|
262
|
+
return Math.round(total)
|
183
263
|
}
|
184
264
|
|
185
265
|
const syncScroll = (scrollLeft) => {
|
@@ -190,34 +270,38 @@
|
|
190
270
|
container.scrollLeft = scrollLeft
|
191
271
|
}
|
192
272
|
}
|
193
|
-
|
273
|
+
|
274
|
+
const getDisplayValue = (data, label, shouldRound = true) => {
|
194
275
|
if (props.fieldMode === 'absolute') {
|
195
|
-
return
|
276
|
+
return data.find((d) => d.label === label)?.value
|
196
277
|
}
|
197
278
|
|
198
|
-
|
199
|
-
const total = calculateTotal(label)
|
200
|
-
return total ? Number(((value / total) * 100).toFixed(0)) : 0
|
279
|
+
return data.find((d) => d.label === label)?.percentage
|
201
280
|
}
|
202
281
|
|
203
282
|
const calculatePercentageTotal = (label) => {
|
204
|
-
|
205
|
-
const
|
206
|
-
|
207
|
-
const percentage = total ? Number(((value / total) * 100).toFixed(0)) : 0
|
283
|
+
const percentageTotal = seriesData.value.reduce((sum, series) => {
|
284
|
+
const percentage =
|
285
|
+
series.data.find((d) => d.label === label)?.percentage || 0
|
208
286
|
return sum + percentage
|
209
287
|
}, 0)
|
288
|
+
|
289
|
+
return Math.round(percentageTotal)
|
210
290
|
}
|
211
291
|
|
212
292
|
const handleInputBlur = (_value, seriesName, label) => {
|
213
|
-
|
214
|
-
|
215
|
-
if (props.fieldMode === 'percentage') {
|
216
|
-
const total = calculateTotal(label)
|
217
|
-
value = (value / 100) * total
|
293
|
+
if (props.isInputsDisabled) {
|
294
|
+
return
|
218
295
|
}
|
296
|
+
let value = Number(_value)
|
219
297
|
|
220
|
-
const payload = seriesName
|
298
|
+
const payload = seriesName
|
299
|
+
? {
|
300
|
+
seriesName,
|
301
|
+
label,
|
302
|
+
value,
|
303
|
+
}
|
304
|
+
: { label, value }
|
221
305
|
emit('input-blur', payload)
|
222
306
|
focusedInput.value = null
|
223
307
|
|
@@ -243,6 +327,12 @@
|
|
243
327
|
}
|
244
328
|
}
|
245
329
|
|
330
|
+
const hasAnySegmentNotTotatTo100Percent = computed(() => {
|
331
|
+
return props.data.some((d) => {
|
332
|
+
return calculatePercentageTotal(d.label) !== 100
|
333
|
+
})
|
334
|
+
})
|
335
|
+
|
246
336
|
const handleFieldsScroll = (event) => {
|
247
337
|
emit('sync-scroll', event.target.scrollLeft)
|
248
338
|
}
|
@@ -84,7 +84,7 @@ export function useAxisCalculations(props, maxValue) {
|
|
84
84
|
})
|
85
85
|
|
86
86
|
const yAxisWidth = computed(() => {
|
87
|
-
return !!props.yAxisTitle || props.isBottomFieldsShown ? '
|
87
|
+
return !!props.yAxisTitle || props.isBottomFieldsShown ? '80px' : '60px'
|
88
88
|
})
|
89
89
|
|
90
90
|
const isChartControlsShown = (position) => {
|
@@ -66,7 +66,7 @@ export function useChartData(props, paddedMaxValue) {
|
|
66
66
|
let accumulated = 0
|
67
67
|
return {
|
68
68
|
label: item.label,
|
69
|
-
segments: [...props.series].
|
69
|
+
segments: [...props.series].map((series, index) => {
|
70
70
|
const value =
|
71
71
|
series.data.find((d) => d.label === item.label)?.value || 0
|
72
72
|
accumulated += value
|
@@ -16,7 +16,21 @@ export function useTooltip(chartId, normalizedData) {
|
|
16
16
|
if (!showTooltipContent.value) {
|
17
17
|
showTooltipContent.value = true
|
18
18
|
}
|
19
|
-
if (isObjectEqual(item, tooltipData.value))
|
19
|
+
if (isObjectEqual(item, tooltipData.value)) {
|
20
|
+
return
|
21
|
+
}
|
22
|
+
|
23
|
+
const totalValue = item.segments.reduce((acc, segment) => {
|
24
|
+
return acc + segment.value
|
25
|
+
}, 0)
|
26
|
+
|
27
|
+
const segments = item.segments.map((segment) => {
|
28
|
+
let valuePercentage = (segment.value / totalValue) * 100
|
29
|
+
segment.valuePercentage = Math.round(valuePercentage)
|
30
|
+
|
31
|
+
return segment
|
32
|
+
})
|
33
|
+
item.segments = segments
|
20
34
|
|
21
35
|
tooltipData.value = { ...item }
|
22
36
|
|
@@ -41,16 +55,27 @@ export function useTooltip(chartId, normalizedData) {
|
|
41
55
|
|
42
56
|
isInputFocused.value = true
|
43
57
|
const barData = normalizedData.value.find((item) => item.label === label)
|
44
|
-
|
45
58
|
if (!barData) return
|
59
|
+
|
60
|
+
const totalValue = barData.segments.reduce((acc, segment) => {
|
61
|
+
return acc + segment.value
|
62
|
+
}, 0)
|
63
|
+
const segments = barData.segments.map((segment) => {
|
64
|
+
let valuePercentage = (segment.value / totalValue) * 100
|
65
|
+
segment.valuePercentage = Math.round(valuePercentage)
|
66
|
+
|
67
|
+
return segment
|
68
|
+
})
|
69
|
+
barData.segments = segments
|
46
70
|
focusedBarData.value = barData
|
71
|
+
|
47
72
|
const barElement = document.querySelector(
|
48
73
|
`.barchart-${chartId} .bar-group:nth-child(${
|
49
74
|
normalizedData.value.indexOf(barData) + 1
|
50
75
|
})`
|
51
76
|
)
|
52
|
-
|
53
77
|
if (!barElement) return
|
78
|
+
|
54
79
|
// Get the last bar segment, samee as hover behavior
|
55
80
|
const targetElement = barElement.querySelector('.bar-segment:last-child')
|
56
81
|
const rect = targetElement.getBoundingClientRect()
|
@@ -17,7 +17,7 @@
|
|
17
17
|
/>
|
18
18
|
</ChartControlsWrapper>
|
19
19
|
<GraphSection :height="height" :width="width">
|
20
|
-
<YAxis :
|
20
|
+
<YAxis :height="height" :width="yAxisWidth">
|
21
21
|
<YAxisTitleWrapper v-if="yAxisTitle" :height="yAxisHeight">
|
22
22
|
{{ yAxisTitle }}
|
23
23
|
</YAxisTitleWrapper>
|
@@ -30,15 +30,15 @@
|
|
30
30
|
)
|
31
31
|
"
|
32
32
|
>
|
33
|
-
<YAxisLabel>{{ label }}</YAxisLabel>
|
33
|
+
<YAxisLabel>{{ getYAxisLabel(label) }}</YAxisLabel>
|
34
34
|
<YAxisLine :y-axis-width="yAxisWidth" />
|
35
35
|
</YAxisRow>
|
36
36
|
</YAxis>
|
37
37
|
|
38
38
|
<ScrollContainer
|
39
39
|
:class="`chart-scroll-container-${chartId}`"
|
40
|
-
:is-scrollable="isScrollable"
|
41
40
|
:height="height"
|
41
|
+
:is-scrollable="isScrollable"
|
42
42
|
@scroll="handleChartScroll"
|
43
43
|
>
|
44
44
|
<ChartContent
|
@@ -64,19 +64,19 @@
|
|
64
64
|
<BarsContainer>
|
65
65
|
<BarGroup
|
66
66
|
v-for="(item, index) in normalizedData"
|
67
|
+
:key="index"
|
67
68
|
:bar-width="barWidth"
|
68
69
|
class="bar-group"
|
69
70
|
:is-scrollable="isScrollable"
|
70
|
-
:key="index"
|
71
71
|
>
|
72
72
|
<BarWrapper>
|
73
73
|
<BarSegment
|
74
74
|
v-for="(segment, segIndex) in item.segments"
|
75
|
+
:key="segIndex"
|
75
76
|
class="bar-segment"
|
76
77
|
:gradient-from="getSegmentGradient(index, segment).from"
|
77
78
|
:gradient-to="getSegmentGradient(index, segment).to"
|
78
79
|
:height="`${segment.percentage}%`"
|
79
|
-
:key="segIndex"
|
80
80
|
:z-index="item.segments.length - segIndex"
|
81
81
|
@mouseenter="showTooltip(item, $event, series)"
|
82
82
|
@mouseleave="hideTooltip"
|
@@ -96,7 +96,7 @@
|
|
96
96
|
:left="tooltipStyle.left"
|
97
97
|
:top="tooltipStyle.top"
|
98
98
|
>
|
99
|
-
<slot :item="tooltipData" name="tooltip"
|
99
|
+
<slot :item="tooltipData" name="tooltip"></slot>
|
100
100
|
<TooltipTextWrapper v-if="!slots.tooltip && tooltipData">
|
101
101
|
<template v-if="!series.length">
|
102
102
|
<TooltipText font-weight="500">{{ tooltipData.label }}</TooltipText>
|
@@ -128,7 +128,11 @@
|
|
128
128
|
:gradient-to="segment.gradientTo"
|
129
129
|
/>
|
130
130
|
<TooltipText>
|
131
|
-
{{
|
131
|
+
{{
|
132
|
+
fieldMode === 'absolute' && showPercentageOnTooltip
|
133
|
+
? `${segment.valuePercentage}%`
|
134
|
+
: handleValueFormatter(segment.value)
|
135
|
+
}}
|
132
136
|
</TooltipText>
|
133
137
|
</TooltipRow>
|
134
138
|
</template>
|
@@ -159,7 +163,9 @@
|
|
159
163
|
:data="data"
|
160
164
|
:field-mode="fieldMode"
|
161
165
|
:is-chart-controls-shown-in-bottom="isChartControlsShown('bottom')"
|
166
|
+
:is-inputs-disabled="isLoading"
|
162
167
|
:is-scrollable="isScrollable"
|
168
|
+
:percentage-error-message="percentageErrorMessage"
|
163
169
|
:series="series"
|
164
170
|
:y-axis-width="yAxisWidth"
|
165
171
|
@input-blur="handleInputBlur"
|
@@ -171,12 +177,13 @@
|
|
171
177
|
</template>
|
172
178
|
|
173
179
|
<script setup>
|
174
|
-
import { useSlots, computed } from 'vue'
|
180
|
+
import { useSlots, computed, ref } from 'vue'
|
175
181
|
|
176
182
|
import ChartControls from './ChartControls'
|
177
183
|
import BottomFields from './BottomFields'
|
178
184
|
import SelectionBox from './SelectionBox'
|
179
185
|
import Spinner from '../spinner'
|
186
|
+
import { numberToString } from '../../helpers/numberConverter'
|
180
187
|
|
181
188
|
import {
|
182
189
|
useTooltip,
|
@@ -246,10 +253,6 @@
|
|
246
253
|
type: String,
|
247
254
|
default: '',
|
248
255
|
},
|
249
|
-
valueFormatter: {
|
250
|
-
type: Function,
|
251
|
-
default: null,
|
252
|
-
},
|
253
256
|
isLegendShown: {
|
254
257
|
type: Boolean,
|
255
258
|
default: false,
|
@@ -296,6 +299,14 @@
|
|
296
299
|
type: Boolean,
|
297
300
|
default: false,
|
298
301
|
},
|
302
|
+
showPercentageOnTooltip: {
|
303
|
+
type: Boolean,
|
304
|
+
default: false,
|
305
|
+
},
|
306
|
+
percentageErrorMessage: {
|
307
|
+
type: String,
|
308
|
+
default: '',
|
309
|
+
},
|
299
310
|
})
|
300
311
|
|
301
312
|
const generateChartId = () =>
|
@@ -378,8 +389,40 @@
|
|
378
389
|
}
|
379
390
|
|
380
391
|
const handleValueFormatter = (value) => {
|
381
|
-
|
382
|
-
|
383
|
-
|
392
|
+
let formattedValue = value
|
393
|
+
if (value < 1000) {
|
394
|
+
formattedValue = numberToString({
|
395
|
+
value: formattedValue,
|
396
|
+
numberPrecision: 0,
|
397
|
+
minDecimals: 0,
|
398
|
+
})
|
399
|
+
} else if (value < 1000000) {
|
400
|
+
formattedValue = numberToString({
|
401
|
+
value: Number(formattedValue / 1000),
|
402
|
+
numberPrecision: 2,
|
403
|
+
minDecimals: 2,
|
404
|
+
})
|
405
|
+
} else {
|
406
|
+
formattedValue = numberToString({
|
407
|
+
value: Number(formattedValue / 1000000),
|
408
|
+
numberPrecision: 2,
|
409
|
+
minDecimals: 2,
|
410
|
+
})
|
411
|
+
}
|
412
|
+
if (value < 1000) {
|
413
|
+
return `${formattedValue} kWh`
|
414
|
+
} else if (value < 1000000) {
|
415
|
+
return `${formattedValue} MWh`
|
416
|
+
} else {
|
417
|
+
return `${formattedValue} GWh`
|
418
|
+
}
|
419
|
+
}
|
420
|
+
|
421
|
+
const getYAxisLabel = (label) => {
|
422
|
+
return numberToString({
|
423
|
+
value: label,
|
424
|
+
numberPrecision: 0,
|
425
|
+
minDecimals: 0,
|
426
|
+
})
|
384
427
|
}
|
385
428
|
</script>
|
@@ -17,18 +17,18 @@ export const LabelsColumn = styled('div', { width: String })`
|
|
17
17
|
|
18
18
|
export const LabelRow = styled.div`
|
19
19
|
height: 32px;
|
20
|
+
padding-top: 5px;
|
20
21
|
font-size: 12px;
|
21
22
|
font-weight: 500;
|
22
23
|
color: ${(props) => props.theme.semanticColors.teal[600]};
|
23
24
|
display: flex;
|
24
|
-
align-items:
|
25
|
+
align-items: center;
|
25
26
|
`
|
26
27
|
|
27
28
|
export const TotalRow = styled(LabelRow)``
|
28
29
|
|
29
30
|
export const FieldsContainer = styled.div`
|
30
31
|
flex: 1;
|
31
|
-
overflow-x: auto;
|
32
32
|
scrollbar-width: none;
|
33
33
|
|
34
34
|
&::-webkit-scrollbar {
|
@@ -59,8 +59,22 @@ export const InputGroup = styled('div', {
|
|
59
59
|
barWidth: Number,
|
60
60
|
isScrollable: Boolean,
|
61
61
|
})`
|
62
|
-
${(props) => (props.isScrollable ? 'min-width' : 'width')}
|
63
|
-
props.barWidth}px;
|
62
|
+
${(props) => (props.isScrollable ? 'min-width' : 'width')}: 70px;
|
64
63
|
display: flex;
|
65
64
|
justify-content: center;
|
65
|
+
position: relative;
|
66
|
+
|
67
|
+
input[readonly] {
|
68
|
+
border: 1px solid ${(props) => props.theme.colors.grey4} !important;
|
69
|
+
}
|
70
|
+
`
|
71
|
+
|
72
|
+
export const InfoCardContainer = styled('div', { yAxisWidth: String })`
|
73
|
+
margin-left: ${(props) => props.yAxisWidth};
|
74
|
+
padding: 12px;
|
75
|
+
margin-top: 12px;
|
76
|
+
`
|
77
|
+
|
78
|
+
export const InfoCardBody = styled.div`
|
79
|
+
padding: 8px 0;
|
66
80
|
`
|