@openc3/vue-common 6.10.2 → 6.10.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/dist/{ArrayWidget-ByKRAWXn.cjs → ArrayWidget-CIMbQsGW.cjs} +3 -3
- package/dist/{ArrayWidget-ByKRAWXn.cjs.map → ArrayWidget-CIMbQsGW.cjs.map} +1 -1
- package/dist/{ArrayWidget-CR7Wpw3N.js → ArrayWidget-DfiusKpM.js} +11 -11
- package/dist/{ArrayWidget-CR7Wpw3N.js.map → ArrayWidget-DfiusKpM.js.map} +1 -1
- package/dist/{ArrayplotWidget-Cty7KQ_h.cjs → ArrayplotWidget-DrrqqJEu.cjs} +2 -2
- package/dist/{ArrayplotWidget-Cty7KQ_h.cjs.map → ArrayplotWidget-DrrqqJEu.cjs.map} +1 -1
- package/dist/{ArrayplotWidget-DDEd-jRJ.js → ArrayplotWidget-DsvOovu9.js} +4 -4
- package/dist/{ArrayplotWidget-DDEd-jRJ.js.map → ArrayplotWidget-DsvOovu9.js.map} +1 -1
- package/dist/BarColumn-CWgcL5w1.cjs +2 -0
- package/dist/BarColumn-CWgcL5w1.cjs.map +1 -0
- package/dist/{BarColumn-XWs-3Cwb.js → BarColumn-DHHJBR3V.js} +11 -11
- package/dist/BarColumn-DHHJBR3V.js.map +1 -0
- package/dist/{BlockWidget-BDzoqpxO.cjs → BlockWidget-7Ecn_42c.cjs} +3 -3
- package/dist/{BlockWidget-BDzoqpxO.cjs.map → BlockWidget-7Ecn_42c.cjs.map} +1 -1
- package/dist/{BlockWidget-CfFgdNSv.js → BlockWidget-BdYXWS_0.js} +14 -14
- package/dist/{BlockWidget-CfFgdNSv.js.map → BlockWidget-BdYXWS_0.js.map} +1 -1
- package/dist/{ButtonWidget-BBMDS_YF.cjs → ButtonWidget-DFxBj0MG.cjs} +3 -3
- package/dist/ButtonWidget-DFxBj0MG.cjs.map +1 -0
- package/dist/{ButtonWidget-BaSvtElA.js → ButtonWidget-zpSJmiQT.js} +15 -15
- package/dist/ButtonWidget-zpSJmiQT.js.map +1 -0
- package/dist/{CanvasWidget-CFNpgqfW.cjs → CanvasWidget-C5-iZ-YT.cjs} +2 -2
- package/dist/{CanvasWidget-CFNpgqfW.cjs.map → CanvasWidget-C5-iZ-YT.cjs.map} +1 -1
- package/dist/{CanvasWidget-DcwDi5Zk.js → CanvasWidget-DaUB1G9X.js} +4 -4
- package/dist/{CanvasWidget-DcwDi5Zk.js.map → CanvasWidget-DaUB1G9X.js.map} +1 -1
- package/dist/{CanvasdotWidget--awMOWyz.js → CanvasdotWidget-C255aTVc.js} +3 -3
- package/dist/{CanvasdotWidget--awMOWyz.js.map → CanvasdotWidget-C255aTVc.js.map} +1 -1
- package/dist/{CanvasdotWidget-BZ9TrTvw.cjs → CanvasdotWidget-CCrgS1yO.cjs} +2 -2
- package/dist/{CanvasdotWidget-BZ9TrTvw.cjs.map → CanvasdotWidget-CCrgS1yO.cjs.map} +1 -1
- package/dist/CanvasimageWidget-B2Mm0dYq.cjs +2 -0
- package/dist/CanvasimageWidget-B2Mm0dYq.cjs.map +1 -0
- package/dist/{CanvasimageWidget-YP1pCtvb.js → CanvasimageWidget-CFlUUFqr.js} +8 -7
- package/dist/CanvasimageWidget-CFlUUFqr.js.map +1 -0
- package/dist/CanvasimagevalueWidget-B1xVa3FB.cjs +2 -0
- package/dist/CanvasimagevalueWidget-B1xVa3FB.cjs.map +1 -0
- package/dist/{CanvasimagevalueWidget-CjVHb2uj.js → CanvasimagevalueWidget-s4gR3fo5.js} +5 -4
- package/dist/CanvasimagevalueWidget-s4gR3fo5.js.map +1 -0
- package/dist/{CanvaslabelWidget-Dw1YmiY0.cjs → CanvaslabelWidget-CAtE3qq_.cjs} +2 -2
- package/dist/{CanvaslabelWidget-Dw1YmiY0.cjs.map → CanvaslabelWidget-CAtE3qq_.cjs.map} +1 -1
- package/dist/{CanvaslabelWidget-DoMplTTO.js → CanvaslabelWidget-CaOc-lTQ.js} +3 -3
- package/dist/{CanvaslabelWidget-DoMplTTO.js.map → CanvaslabelWidget-CaOc-lTQ.js.map} +1 -1
- package/dist/CanvaslabelvalueWidget-CvVMrZsu.cjs +2 -0
- package/dist/CanvaslabelvalueWidget-CvVMrZsu.cjs.map +1 -0
- package/dist/{CanvaslabelvalueWidget-Dyo_ogHn.js → CanvaslabelvalueWidget-hqJoPekq.js} +4 -3
- package/dist/CanvaslabelvalueWidget-hqJoPekq.js.map +1 -0
- package/dist/{CanvaslineWidget-tm194dw1.cjs → CanvaslineWidget-CjPnyDod.cjs} +2 -2
- package/dist/{CanvaslineWidget-tm194dw1.cjs.map → CanvaslineWidget-CjPnyDod.cjs.map} +1 -1
- package/dist/{CanvaslineWidget-D7W1TIxm.js → CanvaslineWidget-DebP2L43.js} +3 -3
- package/dist/{CanvaslineWidget-D7W1TIxm.js.map → CanvaslineWidget-DebP2L43.js.map} +1 -1
- package/dist/{CanvaslinevalueWidget-BOZyJuLE.js → CanvaslinevalueWidget-BkPG5Vtx.js} +11 -10
- package/dist/CanvaslinevalueWidget-BkPG5Vtx.js.map +1 -0
- package/dist/CanvaslinevalueWidget-Caadjtan.cjs +2 -0
- package/dist/CanvaslinevalueWidget-Caadjtan.cjs.map +1 -0
- package/dist/CheckbuttonWidget-CEOWZkt6.cjs +2 -0
- package/dist/{CheckbuttonWidget-BSvTWD3x.cjs.map → CheckbuttonWidget-CEOWZkt6.cjs.map} +1 -1
- package/dist/{CheckbuttonWidget-B1E4BC6v.js → CheckbuttonWidget-eQIcPATf.js} +6 -6
- package/dist/{CheckbuttonWidget-B1E4BC6v.js.map → CheckbuttonWidget-eQIcPATf.js.map} +1 -1
- package/dist/{ClassificationBanners-CzZoKcRy.cjs → ClassificationBanners--l3qMxLo.cjs} +2 -2
- package/dist/{ClassificationBanners-CzZoKcRy.cjs.map → ClassificationBanners--l3qMxLo.cjs.map} +1 -1
- package/dist/{ClassificationBanners-DQeVwmYp.js → ClassificationBanners-CFLQaZJ2.js} +2 -2
- package/dist/{ClassificationBanners-DQeVwmYp.js.map → ClassificationBanners-CFLQaZJ2.js.map} +1 -1
- package/dist/{ComboboxWidget-BExUBH57.js → ComboboxWidget-B5kzYxFk.js} +6 -6
- package/dist/{ComboboxWidget-BExUBH57.js.map → ComboboxWidget-B5kzYxFk.js.map} +1 -1
- package/dist/ComboboxWidget-BSs59QzI.cjs +2 -0
- package/dist/{ComboboxWidget-B_KAnIVB.cjs.map → ComboboxWidget-BSs59QzI.cjs.map} +1 -1
- package/dist/{CriticalCmdDialog-BtzhxuZi.js → CriticalCmdDialog-BYHZbX2w.js} +62 -52
- package/dist/CriticalCmdDialog-BYHZbX2w.js.map +1 -0
- package/dist/CriticalCmdDialog-BhjiJIo5.cjs +2 -0
- package/dist/CriticalCmdDialog-BhjiJIo5.cjs.map +1 -0
- package/dist/{CustomIcon-DTfsnDJn.js → CustomIcon-B9m73Gqm.js} +5 -4
- package/dist/{CustomIcon-DTfsnDJn.js.map → CustomIcon-B9m73Gqm.js.map} +1 -1
- package/dist/CustomIcon-CEc927h0.cjs +2 -0
- package/dist/{CustomIcon-eie3rPKh.cjs.map → CustomIcon-CEc927h0.cjs.map} +1 -1
- package/dist/{DateWidget-_ZmPsi2l.js → DateWidget-1IZOe50K.js} +3 -3
- package/dist/{DateWidget-_ZmPsi2l.js.map → DateWidget-1IZOe50K.js.map} +1 -1
- package/dist/{DateWidget-kTJBAHVp.cjs → DateWidget-DkVxE7Xj.cjs} +2 -2
- package/dist/{DateWidget-kTJBAHVp.cjs.map → DateWidget-DkVxE7Xj.cjs.map} +1 -1
- package/dist/{DetailsDialog-Bq7SS7bc.js → DetailsDialog-D-rjL4oc.js} +130 -100
- package/dist/DetailsDialog-D-rjL4oc.js.map +1 -0
- package/dist/DetailsDialog-lJG8eclU.cjs +2 -0
- package/dist/DetailsDialog-lJG8eclU.cjs.map +1 -0
- package/dist/DynamicWidget-C4V2H2VJ.cjs +2 -0
- package/dist/DynamicWidget-C4V2H2VJ.cjs.map +1 -0
- package/dist/{DynamicWidget-DHL7pbgW.js → DynamicWidget-DEHWYr8i.js} +7 -7
- package/dist/DynamicWidget-DEHWYr8i.js.map +1 -0
- package/dist/EventListDialog-5UXvnmNE.cjs +2 -0
- package/dist/EventListDialog-5UXvnmNE.cjs.map +1 -0
- package/dist/{EventListDialog-jdNF3szO.js → EventListDialog-Id3rEQKY.js} +242 -242
- package/dist/EventListDialog-Id3rEQKY.js.map +1 -0
- package/dist/FilechecksumWidget-D-5GSjyV.cjs +2 -0
- package/dist/FilechecksumWidget-D-5GSjyV.cjs.map +1 -0
- package/dist/FilechecksumWidget-F_FX1Kjx.js +158 -0
- package/dist/FilechecksumWidget-F_FX1Kjx.js.map +1 -0
- package/dist/FiledisplayWidget-BF3G22jF.js +114 -0
- package/dist/FiledisplayWidget-BF3G22jF.js.map +1 -0
- package/dist/FiledisplayWidget-BHLOY_cM.cjs +2 -0
- package/dist/FiledisplayWidget-BHLOY_cM.cjs.map +1 -0
- package/dist/{FormatvalueWidget-4C0vrL2i.js → FormatvalueWidget-BkF9iiHs.js} +4 -4
- package/dist/{FormatvalueWidget-4C0vrL2i.js.map → FormatvalueWidget-BkF9iiHs.js.map} +1 -1
- package/dist/{FormatvalueWidget-CVoJgFJA.cjs → FormatvalueWidget-DTsP7isW.cjs} +2 -2
- package/dist/{FormatvalueWidget-CVoJgFJA.cjs.map → FormatvalueWidget-DTsP7isW.cjs.map} +1 -1
- package/dist/{Graph-B7KPo9Ul.js → Graph-C-7C2Jq5.js} +194 -187
- package/dist/Graph-C-7C2Jq5.js.map +1 -0
- package/dist/Graph-YYieRGo0.cjs +2 -0
- package/dist/Graph-YYieRGo0.cjs.map +1 -0
- package/dist/{GraphWidget-D3HueIZi.cjs → GraphWidget-C7hqdqL-.cjs} +2 -2
- package/dist/{GraphWidget-D3HueIZi.cjs.map → GraphWidget-C7hqdqL-.cjs.map} +1 -1
- package/dist/{GraphWidget-BpkPpAbd.js → GraphWidget-DRkDn8za.js} +2 -2
- package/dist/{GraphWidget-BpkPpAbd.js.map → GraphWidget-DRkDn8za.js.map} +1 -1
- package/dist/HorizontalWidget-DB64wzZB.js +69 -0
- package/dist/HorizontalWidget-DB64wzZB.js.map +1 -0
- package/dist/HorizontalWidget-h-U8i3G-.cjs +2 -0
- package/dist/HorizontalWidget-h-U8i3G-.cjs.map +1 -0
- package/dist/{HorizontalboxWidget-CTomf_Iy.js → HorizontalboxWidget-BsHsGlvK.js} +6 -6
- package/dist/{HorizontalboxWidget-CTomf_Iy.js.map → HorizontalboxWidget-BsHsGlvK.js.map} +1 -1
- package/dist/{HorizontalboxWidget-ysq7slso.cjs → HorizontalboxWidget-E4LUf2eN.cjs} +2 -2
- package/dist/{HorizontalboxWidget-ysq7slso.cjs.map → HorizontalboxWidget-E4LUf2eN.cjs.map} +1 -1
- package/dist/{HorizontallineWidget-B7xx7ofY.js → HorizontallineWidget-CyiexzIu.js} +3 -3
- package/dist/{HorizontallineWidget-B7xx7ofY.js.map → HorizontallineWidget-CyiexzIu.js.map} +1 -1
- package/dist/{HorizontallineWidget-BgXZZymr.cjs → HorizontallineWidget-LibmHnAf.cjs} +2 -2
- package/dist/{HorizontallineWidget-BgXZZymr.cjs.map → HorizontallineWidget-LibmHnAf.cjs.map} +1 -1
- package/dist/{IframeWidget-DK7rbULe.js → IframeWidget-D9Vh0w2c.js} +3 -3
- package/dist/{IframeWidget-DK7rbULe.js.map → IframeWidget-D9Vh0w2c.js.map} +1 -1
- package/dist/{IframeWidget-fV9e-Nm1.cjs → IframeWidget-xeXTxP_G.cjs} +2 -2
- package/dist/{IframeWidget-fV9e-Nm1.cjs.map → IframeWidget-xeXTxP_G.cjs.map} +1 -1
- package/dist/{ImageLoader-C9rN_pSY.js → ImageLoader-B4iBPFyi.js} +2 -2
- package/dist/{ImageLoader-C9rN_pSY.js.map → ImageLoader-B4iBPFyi.js.map} +1 -1
- package/dist/{ImageLoader-CJxiBXAL.cjs → ImageLoader-Cc4-BNJv.cjs} +2 -2
- package/dist/{ImageLoader-CJxiBXAL.cjs.map → ImageLoader-Cc4-BNJv.cjs.map} +1 -1
- package/dist/{ImageviewerWidget-6d6Kl3W_.js → ImageviewerWidget-DqV4SClv.js} +10 -9
- package/dist/ImageviewerWidget-DqV4SClv.js.map +1 -0
- package/dist/ImageviewerWidget-KVt487SJ.cjs +2 -0
- package/dist/ImageviewerWidget-KVt487SJ.cjs.map +1 -0
- package/dist/{InterfacesTab-BCqTanhV.js → InterfacesTab-C310FRIP.js} +4 -4
- package/dist/{InterfacesTab-BCqTanhV.js.map → InterfacesTab-C310FRIP.js.map} +1 -1
- package/dist/{InterfacesTab-0pmK3KNu.cjs → InterfacesTab-nZwg-ByS.cjs} +2 -2
- package/dist/{InterfacesTab-0pmK3KNu.cjs.map → InterfacesTab-nZwg-ByS.cjs.map} +1 -1
- package/dist/{LabelWidget-D71FfOSw.js → LabelWidget-BDukcPet.js} +3 -3
- package/dist/{LabelWidget-D71FfOSw.js.map → LabelWidget-BDukcPet.js.map} +1 -1
- package/dist/{LabelWidget-DdZz2NWv.cjs → LabelWidget-DYfv4K8h.cjs} +2 -2
- package/dist/{LabelWidget-DdZz2NWv.cjs.map → LabelWidget-DYfv4K8h.cjs.map} +1 -1
- package/dist/{LabelledWidget-BZ319slb.cjs → LabelledWidget-Dl1x6b3p.cjs} +2 -2
- package/dist/{LabelledWidget-BZ319slb.cjs.map → LabelledWidget-Dl1x6b3p.cjs.map} +1 -1
- package/dist/{LabelledWidget-D2ir5kVU.js → LabelledWidget-tVHE426s.js} +6 -6
- package/dist/{LabelledWidget-D2ir5kVU.js.map → LabelledWidget-tVHE426s.js.map} +1 -1
- package/dist/{LabelprogressbarWidget-C4_YbROz.js → LabelprogressbarWidget-CjMDFUUv.js} +6 -6
- package/dist/{LabelprogressbarWidget-C4_YbROz.js.map → LabelprogressbarWidget-CjMDFUUv.js.map} +1 -1
- package/dist/{LabelprogressbarWidget-LyevJNuz.cjs → LabelprogressbarWidget-DcO0gRM4.cjs} +2 -2
- package/dist/{LabelprogressbarWidget-LyevJNuz.cjs.map → LabelprogressbarWidget-DcO0gRM4.cjs.map} +1 -1
- package/dist/LabelsparklineWidget-Cp2a-qlI.cjs +2 -0
- package/dist/LabelsparklineWidget-Cp2a-qlI.cjs.map +1 -0
- package/dist/{LabelsparklineWidget-CdZ_pM2B.js → LabelsparklineWidget-dZl3cGu0.js} +13 -13
- package/dist/LabelsparklineWidget-dZl3cGu0.js.map +1 -0
- package/dist/{LabelvalueWidget-DSHwAKma.cjs → LabelvalueWidget-CgP4mzP_.cjs} +2 -2
- package/dist/{LabelvalueWidget-DSHwAKma.cjs.map → LabelvalueWidget-CgP4mzP_.cjs.map} +1 -1
- package/dist/{LabelvalueWidget-BS0EPY5h.js → LabelvalueWidget-UcAc_2Ry.js} +6 -6
- package/dist/{LabelvalueWidget-BS0EPY5h.js.map → LabelvalueWidget-UcAc_2Ry.js.map} +1 -1
- package/dist/{LabelvaluedescWidget-3lwQxkKj.cjs → LabelvaluedescWidget-CXJ037Qs.cjs} +2 -2
- package/dist/{LabelvaluedescWidget-3lwQxkKj.cjs.map → LabelvaluedescWidget-CXJ037Qs.cjs.map} +1 -1
- package/dist/{LabelvaluedescWidget-Cpr8_Voq.js → LabelvaluedescWidget-Crb8udVe.js} +6 -6
- package/dist/{LabelvaluedescWidget-Cpr8_Voq.js.map → LabelvaluedescWidget-Crb8udVe.js.map} +1 -1
- package/dist/{LabelvaluelimitsbarWidget-DbO_Q5ex.cjs → LabelvaluelimitsbarWidget-B3cn7i50.cjs} +2 -2
- package/dist/LabelvaluelimitsbarWidget-B3cn7i50.cjs.map +1 -0
- package/dist/{LabelvaluelimitsbarWidget-DTcYbEQS.js → LabelvaluelimitsbarWidget-BZGUQrRt.js} +10 -10
- package/dist/LabelvaluelimitsbarWidget-BZGUQrRt.js.map +1 -0
- package/dist/LabelvaluelimitscolumnWidget-DbBOkQ8R.cjs +2 -0
- package/dist/LabelvaluelimitscolumnWidget-DbBOkQ8R.cjs.map +1 -0
- package/dist/{LabelvaluelimitscolumnWidget-D0ltQ9Ta.js → LabelvaluelimitscolumnWidget-NNYW2aMO.js} +12 -12
- package/dist/LabelvaluelimitscolumnWidget-NNYW2aMO.js.map +1 -0
- package/dist/{LabelvaluerangebarWidget-B6_alHq4.cjs → LabelvaluerangebarWidget-B81fLpK0.cjs} +2 -2
- package/dist/{LabelvaluerangebarWidget-B6_alHq4.cjs.map → LabelvaluerangebarWidget-B81fLpK0.cjs.map} +1 -1
- package/dist/{LabelvaluerangebarWidget-O8IHjvHs.js → LabelvaluerangebarWidget-CjkVDlVJ.js} +6 -6
- package/dist/{LabelvaluerangebarWidget-O8IHjvHs.js.map → LabelvaluerangebarWidget-CjkVDlVJ.js.map} +1 -1
- package/dist/Layout-FpBx3iic.js +36 -0
- package/dist/Layout-FpBx3iic.js.map +1 -0
- package/dist/Layout-K7_I6jMV.cjs +2 -0
- package/dist/Layout-K7_I6jMV.cjs.map +1 -0
- package/dist/{LedWidget-DUvJ2v8k.js → LedWidget-Bsp1aja-.js} +46 -39
- package/dist/LedWidget-Bsp1aja-.js.map +1 -0
- package/dist/LedWidget-C19KREVz.cjs +2 -0
- package/dist/LedWidget-C19KREVz.cjs.map +1 -0
- package/dist/LimitsBar-IVv8t4FE.js +134 -0
- package/dist/LimitsBar-IVv8t4FE.js.map +1 -0
- package/dist/LimitsBar-LRiUSWd7.cjs +2 -0
- package/dist/LimitsBar-LRiUSWd7.cjs.map +1 -0
- package/dist/LimitsbarWidget-BFjMhTbA.cjs +2 -0
- package/dist/LimitsbarWidget-BFjMhTbA.cjs.map +1 -0
- package/dist/LimitsbarWidget-Bo1JAoQp.js +65 -0
- package/dist/LimitsbarWidget-Bo1JAoQp.js.map +1 -0
- package/dist/LimitscolorWidget-D214kS86.cjs +2 -0
- package/dist/LimitscolorWidget-D214kS86.cjs.map +1 -0
- package/dist/{LimitscolorWidget-FXT0ZPPH.js → LimitscolorWidget-Doq8h_g1.js} +14 -13
- package/dist/LimitscolorWidget-Doq8h_g1.js.map +1 -0
- package/dist/{LimitscolumnWidget-C5yozwf0.cjs → LimitscolumnWidget-BREF_CBr.cjs} +2 -2
- package/dist/{LimitscolumnWidget-C5yozwf0.cjs.map → LimitscolumnWidget-BREF_CBr.cjs.map} +1 -1
- package/dist/{LimitscolumnWidget-CjBy-CCI.js → LimitscolumnWidget-qasXHN7m.js} +3 -3
- package/dist/{LimitscolumnWidget-CjBy-CCI.js.map → LimitscolumnWidget-qasXHN7m.js.map} +1 -1
- package/dist/{LinegraphWidget-lmu_tFKd.js → LinegraphWidget-BNMqcr_r.js} +5 -5
- package/dist/{LinegraphWidget-lmu_tFKd.js.map → LinegraphWidget-BNMqcr_r.js.map} +1 -1
- package/dist/{LinegraphWidget-dO_B0T3E.cjs → LinegraphWidget-BhpYKxnT.cjs} +2 -2
- package/dist/{LinegraphWidget-dO_B0T3E.cjs.map → LinegraphWidget-BhpYKxnT.cjs.map} +1 -1
- package/dist/MatrixbycolumnsWidget-BKXkhATe.cjs +2 -0
- package/dist/MatrixbycolumnsWidget-BKXkhATe.cjs.map +1 -0
- package/dist/MatrixbycolumnsWidget-BlF1CyIT.js +83 -0
- package/dist/MatrixbycolumnsWidget-BlF1CyIT.js.map +1 -0
- package/dist/MicroservicesTab-BWFwBSuf.cjs +2 -0
- package/dist/MicroservicesTab-BWFwBSuf.cjs.map +1 -0
- package/dist/MicroservicesTab-xpDXKoa-.js +203 -0
- package/dist/MicroservicesTab-xpDXKoa-.js.map +1 -0
- package/dist/OpenC3TimePicker-6pE8gGCO.cjs +2 -0
- package/dist/OpenC3TimePicker-6pE8gGCO.cjs.map +1 -0
- package/dist/OpenC3TimePicker-D-_qqySI.js +219 -0
- package/dist/OpenC3TimePicker-D-_qqySI.js.map +1 -0
- package/dist/{Openc3Screen-DcIIUO63.js → Openc3Screen-DYJHNotN.js} +730 -510
- package/dist/Openc3Screen-DYJHNotN.js.map +1 -0
- package/dist/Openc3Screen-Pu1ktpS8.cjs +6 -0
- package/dist/Openc3Screen-Pu1ktpS8.cjs.map +1 -0
- package/dist/OutputDialog-BwEWPQW9.cjs +2 -0
- package/dist/OutputDialog-BwEWPQW9.cjs.map +1 -0
- package/dist/{OutputDialog-CNH74LpJ.js → OutputDialog-x4QZFAWe.js} +24 -17
- package/dist/OutputDialog-x4QZFAWe.js.map +1 -0
- package/dist/{PackagesTab-PEPT4CQu.cjs → PackagesTab-CHwfaqdP.cjs} +2 -2
- package/dist/{PackagesTab-PEPT4CQu.cjs.map → PackagesTab-CHwfaqdP.cjs.map} +1 -1
- package/dist/{PackagesTab-BE6W7Aru.js → PackagesTab-rzc4hqOb.js} +4 -4
- package/dist/{PackagesTab-BE6W7Aru.js.map → PackagesTab-rzc4hqOb.js.map} +1 -1
- package/dist/{PluginsTab-DXf9zX0h.cjs → PluginsTab-C7gLbRQn.cjs} +2 -2
- package/dist/PluginsTab-C7gLbRQn.cjs.map +1 -0
- package/dist/{PluginsTab-B_Pf2A9c.js → PluginsTab-Dff_0j26.js} +8 -8
- package/dist/PluginsTab-Dff_0j26.js.map +1 -0
- package/dist/{ProgressbarWidget-B5WN658S.js → ProgressbarWidget-DQ80NANH.js} +7 -5
- package/dist/ProgressbarWidget-DQ80NANH.js.map +1 -0
- package/dist/ProgressbarWidget-cQAtX_Q7.cjs +2 -0
- package/dist/ProgressbarWidget-cQAtX_Q7.cjs.map +1 -0
- package/dist/RadiobuttonWidget-DFrUZRaV.cjs +2 -0
- package/dist/{RadiobuttonWidget-DkG9GtAy.cjs.map → RadiobuttonWidget-DFrUZRaV.cjs.map} +1 -1
- package/dist/{RadiobuttonWidget-B_3nys46.js → RadiobuttonWidget-LD18M4IQ.js} +11 -10
- package/dist/{RadiobuttonWidget-B_3nys46.js.map → RadiobuttonWidget-LD18M4IQ.js.map} +1 -1
- package/dist/{RadiogroupWidget-BiMIL9li.js → RadiogroupWidget-D_pt2MPz.js} +6 -6
- package/dist/{RadiogroupWidget-BiMIL9li.js.map → RadiogroupWidget-D_pt2MPz.js.map} +1 -1
- package/dist/{RadiogroupWidget-BnUjXU28.cjs → RadiogroupWidget-ljP05k3g.cjs} +2 -2
- package/dist/{RadiogroupWidget-BnUjXU28.cjs.map → RadiogroupWidget-ljP05k3g.cjs.map} +1 -1
- package/dist/RangebarWidget-BsLWXvTo.cjs +2 -0
- package/dist/RangebarWidget-BsLWXvTo.cjs.map +1 -0
- package/dist/{RangebarWidget-Dn0GASdi.js → RangebarWidget-DhaWpHjB.js} +12 -11
- package/dist/RangebarWidget-DhaWpHjB.js.map +1 -0
- package/dist/{RedisTab-BsKrL4fD.js → RedisTab-C3yjh0JX.js} +3 -3
- package/dist/{RedisTab-BsKrL4fD.js.map → RedisTab-C3yjh0JX.js.map} +1 -1
- package/dist/{RedisTab-C1yaDRSt.cjs → RedisTab-DEKMLop2.cjs} +2 -2
- package/dist/{RedisTab-C1yaDRSt.cjs.map → RedisTab-DEKMLop2.cjs.map} +1 -1
- package/dist/{RollupWidget-b62qcG5K.js → RollupWidget-CMU1-HwL.js} +15 -13
- package/dist/RollupWidget-CMU1-HwL.js.map +1 -0
- package/dist/RollupWidget-sXTyo7zH.cjs +2 -0
- package/dist/RollupWidget-sXTyo7zH.cjs.map +1 -0
- package/dist/{RoutersTab-EHz4wDCn.js → RoutersTab-DaWde6np.js} +4 -4
- package/dist/{RoutersTab-EHz4wDCn.js.map → RoutersTab-DaWde6np.js.map} +1 -1
- package/dist/{RoutersTab-8wGbiPCk.cjs → RoutersTab-IKuEHQeO.cjs} +2 -2
- package/dist/{RoutersTab-8wGbiPCk.cjs.map → RoutersTab-IKuEHQeO.cjs.map} +1 -1
- package/dist/ScriptChooser-BmyV6QQD.cjs +2 -0
- package/dist/ScriptChooser-BmyV6QQD.cjs.map +1 -0
- package/dist/{ScriptChooser-DMPY3m8a.js → ScriptChooser-DCjI5aeZ.js} +118 -93
- package/dist/ScriptChooser-DCjI5aeZ.js.map +1 -0
- package/dist/ScrollwindowWidget-BcLF_bhy.cjs +2 -0
- package/dist/ScrollwindowWidget-BcLF_bhy.cjs.map +1 -0
- package/dist/ScrollwindowWidget-D7Ln-QMq.js +69 -0
- package/dist/ScrollwindowWidget-D7Ln-QMq.js.map +1 -0
- package/dist/{SecretsTab-DSMFodJM.cjs → SecretsTab-BM9HIjT_.cjs} +2 -2
- package/dist/{SecretsTab-DSMFodJM.cjs.map → SecretsTab-BM9HIjT_.cjs.map} +1 -1
- package/dist/{SecretsTab-Cbt_r-1I.js → SecretsTab-Dhal1RCq.js} +3 -3
- package/dist/{SecretsTab-Cbt_r-1I.js.map → SecretsTab-Dhal1RCq.js.map} +1 -1
- package/dist/SettingsTab-BrSkK_Fs.cjs +3 -0
- package/dist/SettingsTab-BrSkK_Fs.cjs.map +1 -0
- package/dist/{SettingsTab-L5xbCAW_.js → SettingsTab-Dtj_AlEW.js} +319 -202
- package/dist/SettingsTab-Dtj_AlEW.js.map +1 -0
- package/dist/SignalWidget-DHwveppA.cjs +2 -0
- package/dist/SignalWidget-DHwveppA.cjs.map +1 -0
- package/dist/{SignalWidget-CLi6qask.js → SignalWidget-PreTg4Mt.js} +5 -3
- package/dist/SignalWidget-PreTg4Mt.js.map +1 -0
- package/dist/SimpleTextDialog-Bdw3jul4.cjs +2 -0
- package/dist/SimpleTextDialog-Bdw3jul4.cjs.map +1 -0
- package/dist/{SimpleTextDialog-8vDPDt6X.js → SimpleTextDialog-DDIm5Znf.js} +26 -19
- package/dist/SimpleTextDialog-DDIm5Znf.js.map +1 -0
- package/dist/{SpacerWidget-BCA3gdap.js → SpacerWidget-Chy1NO28.js} +3 -3
- package/dist/{SpacerWidget-BCA3gdap.js.map → SpacerWidget-Chy1NO28.js.map} +1 -1
- package/dist/{SpacerWidget-BJpqoaeP.cjs → SpacerWidget-Cj-j_MsG.cjs} +2 -2
- package/dist/{SpacerWidget-BJpqoaeP.cjs.map → SpacerWidget-Cj-j_MsG.cjs.map} +1 -1
- package/dist/SparklineWidget-BE1LieLF.cjs +2 -0
- package/dist/SparklineWidget-BE1LieLF.cjs.map +1 -0
- package/dist/{SparklineWidget-D8mb4zLt.js → SparklineWidget-Bb-gCNNt.js} +11 -11
- package/dist/SparklineWidget-Bb-gCNNt.js.map +1 -0
- package/dist/TabbookWidget-FNbiZpjn.cjs +2 -0
- package/dist/TabbookWidget-FNbiZpjn.cjs.map +1 -0
- package/dist/TabbookWidget-a-LsBhBE.js +96 -0
- package/dist/TabbookWidget-a-LsBhBE.js.map +1 -0
- package/dist/TargetPacketItemChooser-BPRByyfB.cjs +2 -0
- package/dist/TargetPacketItemChooser-BPRByyfB.cjs.map +1 -0
- package/dist/{TargetPacketItemChooser-DGcXvdTX.js → TargetPacketItemChooser-DDqBQTWC.js} +232 -183
- package/dist/TargetPacketItemChooser-DDqBQTWC.js.map +1 -0
- package/dist/{TargetsTab-c-qMsGHh.js → TargetsTab-C7Pn5-19.js} +4 -4
- package/dist/{TargetsTab-c-qMsGHh.js.map → TargetsTab-C7Pn5-19.js.map} +1 -1
- package/dist/{TargetsTab-C4tQ1auc.cjs → TargetsTab-dndajwC_.cjs} +2 -2
- package/dist/{TargetsTab-C4tQ1auc.cjs.map → TargetsTab-dndajwC_.cjs.map} +1 -1
- package/dist/{TextBoxDialog-Xs-gitZd.js → TextBoxDialog-CJHrE2Sh.js} +29 -22
- package/dist/TextBoxDialog-CJHrE2Sh.js.map +1 -0
- package/dist/TextBoxDialog-DzCvdsJj.cjs +2 -0
- package/dist/TextBoxDialog-DzCvdsJj.cjs.map +1 -0
- package/dist/{TextboxWidget-CR05wO-t.js → TextboxWidget-DIHEOldN.js} +19 -19
- package/dist/{TextboxWidget-CR05wO-t.js.map → TextboxWidget-DIHEOldN.js.map} +1 -1
- package/dist/{TextboxWidget-BcRfHcF6.cjs → TextboxWidget-DYTNipbi.cjs} +2 -2
- package/dist/{TextboxWidget-BcRfHcF6.cjs.map → TextboxWidget-DYTNipbi.cjs.map} +1 -1
- package/dist/{TextfieldWidget-Ct1hZr2M.cjs → TextfieldWidget-BE-HpIKs.cjs} +2 -2
- package/dist/{TextfieldWidget-Ct1hZr2M.cjs.map → TextfieldWidget-BE-HpIKs.cjs.map} +1 -1
- package/dist/{TextfieldWidget-Be_Pz2bF.js → TextfieldWidget-CIBo7Dau.js} +5 -5
- package/dist/{TextfieldWidget-Be_Pz2bF.js.map → TextfieldWidget-CIBo7Dau.js.map} +1 -1
- package/dist/TimeWidget-CLuOYfPP.js +43 -0
- package/dist/TimeWidget-CLuOYfPP.js.map +1 -0
- package/dist/TimeWidget-RYL7zDoC.cjs +2 -0
- package/dist/TimeWidget-RYL7zDoC.cjs.map +1 -0
- package/dist/{TitleWidget-BcmxUDzM.js → TitleWidget-BTHKLAsb.js} +3 -3
- package/dist/{TitleWidget-BcmxUDzM.js.map → TitleWidget-BTHKLAsb.js.map} +1 -1
- package/dist/{TitleWidget-C1qzja9l.cjs → TitleWidget-DVWOhZqJ.cjs} +2 -2
- package/dist/{TitleWidget-C1qzja9l.cjs.map → TitleWidget-DVWOhZqJ.cjs.map} +1 -1
- package/dist/{ToolsTab-CbY2K86w.cjs → ToolsTab-D4LFT4tV.cjs} +2 -2
- package/dist/{ToolsTab-CbY2K86w.cjs.map → ToolsTab-D4LFT4tV.cjs.map} +1 -1
- package/dist/{ToolsTab-Buklih4C.js → ToolsTab-D5yhjVM0.js} +4 -4
- package/dist/{ToolsTab-Buklih4C.js.map → ToolsTab-D5yhjVM0.js.map} +1 -1
- package/dist/{TopBar-HxaiWynT.cjs → TopBar-DUdrFsMv.cjs} +2 -2
- package/dist/{TopBar-HxaiWynT.cjs.map → TopBar-DUdrFsMv.cjs.map} +1 -1
- package/dist/{TopBar-D4C9DJcu.js → TopBar-DzxJ69Tt.js} +3 -3
- package/dist/{TopBar-D4C9DJcu.js.map → TopBar-DzxJ69Tt.js.map} +1 -1
- package/dist/{UpgradeToEnterpriseDialog-D0AGxldj.js → UpgradeToEnterpriseDialog-Bf6rEOgp.js} +16 -13
- package/dist/UpgradeToEnterpriseDialog-Bf6rEOgp.js.map +1 -0
- package/dist/UpgradeToEnterpriseDialog-CujyHt2o.cjs +2 -0
- package/dist/UpgradeToEnterpriseDialog-CujyHt2o.cjs.map +1 -0
- package/dist/{UpgradeToEnterpriseDialog.vue_vue_type_style_index_0_scoped_2c757408_lang-CP8T5W6m.cjs → UpgradeToEnterpriseDialog.vue_vue_type_style_index_0_scoped_dda5adfc_lang-Bjn8x8eE.cjs} +108 -108
- package/dist/{UpgradeToEnterpriseDialog.vue_vue_type_style_index_0_scoped_2c757408_lang-CP8T5W6m.cjs.map → UpgradeToEnterpriseDialog.vue_vue_type_style_index_0_scoped_dda5adfc_lang-Bjn8x8eE.cjs.map} +1 -1
- package/dist/{UpgradeToEnterpriseDialog.vue_vue_type_style_index_0_scoped_2c757408_lang-B8ikVCn7.js → UpgradeToEnterpriseDialog.vue_vue_type_style_index_0_scoped_dda5adfc_lang-NXWdTcR2.js} +5473 -5451
- package/dist/{UpgradeToEnterpriseDialog.vue_vue_type_style_index_0_scoped_2c757408_lang-B8ikVCn7.js.map → UpgradeToEnterpriseDialog.vue_vue_type_style_index_0_scoped_dda5adfc_lang-NXWdTcR2.js.map} +1 -1
- package/dist/{VWidget-CBmUpKSV.js → VWidget-BcwkHuIT.js} +3 -3
- package/dist/{VWidget-CBmUpKSV.js.map → VWidget-BcwkHuIT.js.map} +1 -1
- package/dist/{VWidget-DhGLFGS2.cjs → VWidget-CbdjSkP3.cjs} +2 -2
- package/dist/{VWidget-DhGLFGS2.cjs.map → VWidget-CbdjSkP3.cjs.map} +1 -1
- package/dist/ValueWidget-BubIamVx.js +138 -0
- package/dist/ValueWidget-BubIamVx.js.map +1 -0
- package/dist/ValueWidget-CgAl2Av2.cjs +2 -0
- package/dist/ValueWidget-CgAl2Av2.cjs.map +1 -0
- package/dist/{ValuelimitsbarWidget-BdY02gqc.js → ValuelimitsbarWidget-DKTrV1RT.js} +11 -11
- package/dist/{ValuelimitsbarWidget-BdY02gqc.js.map → ValuelimitsbarWidget-DKTrV1RT.js.map} +1 -1
- package/dist/{ValuelimitsbarWidget-KsFz7ipK.cjs → ValuelimitsbarWidget-Dn_sS0zt.cjs} +2 -2
- package/dist/{ValuelimitsbarWidget-KsFz7ipK.cjs.map → ValuelimitsbarWidget-Dn_sS0zt.cjs.map} +1 -1
- package/dist/ValuelimitscolumnWidget-CGhifOZI.cjs +2 -0
- package/dist/ValuelimitscolumnWidget-CGhifOZI.cjs.map +1 -0
- package/dist/{ValuelimitscolumnWidget-CuJ6rqtC.js → ValuelimitscolumnWidget-D8JIK4Zi.js} +11 -11
- package/dist/ValuelimitscolumnWidget-D8JIK4Zi.js.map +1 -0
- package/dist/{ValuerangebarWidget-C5rolGDi.js → ValuerangebarWidget-D8hVKp0l.js} +6 -6
- package/dist/{ValuerangebarWidget-C5rolGDi.js.map → ValuerangebarWidget-D8hVKp0l.js.map} +1 -1
- package/dist/{ValuerangebarWidget-CDJeamPr.cjs → ValuerangebarWidget-DPtR-Dla.cjs} +2 -2
- package/dist/{ValuerangebarWidget-CDJeamPr.cjs.map → ValuerangebarWidget-DPtR-Dla.cjs.map} +1 -1
- package/dist/VerticalWidget-DMp3DXGa.js +68 -0
- package/dist/VerticalWidget-DMp3DXGa.js.map +1 -0
- package/dist/VerticalWidget-DScGTfwX.cjs +2 -0
- package/dist/VerticalWidget-DScGTfwX.cjs.map +1 -0
- package/dist/{VerticalboxWidget-D-3H1PYU.cjs → VerticalboxWidget-CIJ1c7WU.cjs} +2 -2
- package/dist/{VerticalboxWidget-D-3H1PYU.cjs.map → VerticalboxWidget-CIJ1c7WU.cjs.map} +1 -1
- package/dist/{VerticalboxWidget-CzDgveBl.js → VerticalboxWidget-CVf1d_3_.js} +6 -6
- package/dist/{VerticalboxWidget-CzDgveBl.js.map → VerticalboxWidget-CVf1d_3_.js.map} +1 -1
- package/dist/Widget-Btu2EoLT.cjs +2 -0
- package/dist/Widget-Btu2EoLT.cjs.map +1 -0
- package/dist/{Widget-VCl8Ts8s.js → Widget-D4rzBHnr.js} +27 -19
- package/dist/Widget-D4rzBHnr.js.map +1 -0
- package/dist/components.cjs +3 -3
- package/dist/components.cjs.map +1 -1
- package/dist/components.js +421 -248
- package/dist/components.js.map +1 -1
- package/dist/icons.cjs +1 -1
- package/dist/icons.cjs.map +1 -1
- package/dist/icons.js +6 -4
- package/dist/icons.js.map +1 -1
- package/dist/plugins.cjs +2 -2
- package/dist/plugins.cjs.map +1 -1
- package/dist/plugins.js +23 -17
- package/dist/plugins.js.map +1 -1
- package/dist/{settings-sg_XHXQ-.cjs → settings-B9vbjzwV.cjs} +2 -2
- package/dist/{settings-sg_XHXQ-.cjs.map → settings-B9vbjzwV.cjs.map} +1 -1
- package/dist/{settings-DlX9yvJJ.js → settings-Ctcx_wMT.js} +2 -2
- package/dist/{settings-DlX9yvJJ.js.map → settings-Ctcx_wMT.js.map} +1 -1
- package/dist/tools/admin.cjs +4 -5
- package/dist/tools/admin.cjs.map +1 -1
- package/dist/tools/admin.js +954 -833
- package/dist/tools/admin.js.map +1 -1
- package/dist/tools/base.cjs +1 -1
- package/dist/tools/base.cjs.map +1 -1
- package/dist/tools/base.js +38 -37
- package/dist/tools/base.js.map +1 -1
- package/dist/tools/calendar.cjs +1 -1
- package/dist/tools/calendar.js +1 -1
- package/dist/tools/scriptrunner.cjs +8 -8
- package/dist/tools/scriptrunner.cjs.map +1 -1
- package/dist/tools/scriptrunner.js +1121 -1134
- package/dist/tools/scriptrunner.js.map +1 -1
- package/dist/useContainerHeight-BAw05dIa.js.map +1 -1
- package/dist/useContainerHeight-BEd4f2Lr.cjs.map +1 -1
- package/dist/vue-common.css +1 -1
- package/dist/widgets.cjs +1 -1
- package/dist/widgets.js +118 -116
- package/dist/widgets.js.map +1 -1
- package/package.json +6 -6
- package/dist/BarColumn-BZSUr33b.cjs +0 -2
- package/dist/BarColumn-BZSUr33b.cjs.map +0 -1
- package/dist/BarColumn-XWs-3Cwb.js.map +0 -1
- package/dist/ButtonWidget-BBMDS_YF.cjs.map +0 -1
- package/dist/ButtonWidget-BaSvtElA.js.map +0 -1
- package/dist/CanvasimageWidget-Dk15uRRu.cjs +0 -2
- package/dist/CanvasimageWidget-Dk15uRRu.cjs.map +0 -1
- package/dist/CanvasimageWidget-YP1pCtvb.js.map +0 -1
- package/dist/CanvasimagevalueWidget-BQHjJCuq.cjs +0 -2
- package/dist/CanvasimagevalueWidget-BQHjJCuq.cjs.map +0 -1
- package/dist/CanvasimagevalueWidget-CjVHb2uj.js.map +0 -1
- package/dist/CanvaslabelvalueWidget-BYmsu9r_.cjs +0 -2
- package/dist/CanvaslabelvalueWidget-BYmsu9r_.cjs.map +0 -1
- package/dist/CanvaslabelvalueWidget-Dyo_ogHn.js.map +0 -1
- package/dist/CanvaslinevalueWidget-BOZyJuLE.js.map +0 -1
- package/dist/CanvaslinevalueWidget-DM5c-ciY.cjs +0 -2
- package/dist/CanvaslinevalueWidget-DM5c-ciY.cjs.map +0 -1
- package/dist/CheckbuttonWidget-BSvTWD3x.cjs +0 -2
- package/dist/ComboboxWidget-B_KAnIVB.cjs +0 -2
- package/dist/CriticalCmdDialog-BtzhxuZi.js.map +0 -1
- package/dist/CriticalCmdDialog-CeohXoAG.cjs +0 -2
- package/dist/CriticalCmdDialog-CeohXoAG.cjs.map +0 -1
- package/dist/CustomIcon-eie3rPKh.cjs +0 -2
- package/dist/DetailsDialog-Bc_VEG95.cjs +0 -2
- package/dist/DetailsDialog-Bc_VEG95.cjs.map +0 -1
- package/dist/DetailsDialog-Bq7SS7bc.js.map +0 -1
- package/dist/DynamicWidget-BNfJRfR5.cjs +0 -2
- package/dist/DynamicWidget-BNfJRfR5.cjs.map +0 -1
- package/dist/DynamicWidget-DHL7pbgW.js.map +0 -1
- package/dist/EventListDialog-Dycx70tY.cjs +0 -2
- package/dist/EventListDialog-Dycx70tY.cjs.map +0 -1
- package/dist/EventListDialog-jdNF3szO.js.map +0 -1
- package/dist/Graph-B7KPo9Ul.js.map +0 -1
- package/dist/Graph-C9FS6KR3.cjs +0 -2
- package/dist/Graph-C9FS6KR3.cjs.map +0 -1
- package/dist/HorizontalWidget-CN6goWHY.cjs +0 -2
- package/dist/HorizontalWidget-CN6goWHY.cjs.map +0 -1
- package/dist/HorizontalWidget-DbEQYjFC.js +0 -41
- package/dist/HorizontalWidget-DbEQYjFC.js.map +0 -1
- package/dist/ImageviewerWidget-6d6Kl3W_.js.map +0 -1
- package/dist/ImageviewerWidget-CULuNsiD.cjs +0 -2
- package/dist/ImageviewerWidget-CULuNsiD.cjs.map +0 -1
- package/dist/LabelsparklineWidget-Cbug97Ne.cjs +0 -2
- package/dist/LabelsparklineWidget-Cbug97Ne.cjs.map +0 -1
- package/dist/LabelsparklineWidget-CdZ_pM2B.js.map +0 -1
- package/dist/LabelvaluelimitsbarWidget-DTcYbEQS.js.map +0 -1
- package/dist/LabelvaluelimitsbarWidget-DbO_Q5ex.cjs.map +0 -1
- package/dist/LabelvaluelimitscolumnWidget-BMSwK1Ys.cjs +0 -2
- package/dist/LabelvaluelimitscolumnWidget-BMSwK1Ys.cjs.map +0 -1
- package/dist/LabelvaluelimitscolumnWidget-D0ltQ9Ta.js.map +0 -1
- package/dist/Layout-DDewLzbI.cjs +0 -2
- package/dist/Layout-DDewLzbI.cjs.map +0 -1
- package/dist/Layout-DW5yNlp7.js +0 -14
- package/dist/Layout-DW5yNlp7.js.map +0 -1
- package/dist/LedWidget-Cif7vC7q.cjs +0 -2
- package/dist/LedWidget-Cif7vC7q.cjs.map +0 -1
- package/dist/LedWidget-DUvJ2v8k.js.map +0 -1
- package/dist/LimitsbarWidget-BehZv0-k.js +0 -72
- package/dist/LimitsbarWidget-BehZv0-k.js.map +0 -1
- package/dist/LimitsbarWidget-BodNPbuH.cjs +0 -2
- package/dist/LimitsbarWidget-BodNPbuH.cjs.map +0 -1
- package/dist/LimitscolorWidget-DPhymKgB.cjs +0 -2
- package/dist/LimitscolorWidget-DPhymKgB.cjs.map +0 -1
- package/dist/LimitscolorWidget-FXT0ZPPH.js.map +0 -1
- package/dist/MatrixbycolumnsWidget-BLkwvpMk.cjs +0 -2
- package/dist/MatrixbycolumnsWidget-BLkwvpMk.cjs.map +0 -1
- package/dist/MatrixbycolumnsWidget-CCF7rCkV.js +0 -56
- package/dist/MatrixbycolumnsWidget-CCF7rCkV.js.map +0 -1
- package/dist/MicroservicesTab-rxOATXLO.js +0 -219
- package/dist/MicroservicesTab-rxOATXLO.js.map +0 -1
- package/dist/MicroservicesTab-uesXuuM4.cjs +0 -2
- package/dist/MicroservicesTab-uesXuuM4.cjs.map +0 -1
- package/dist/Openc3Screen-CzD9BB0M.cjs +0 -6
- package/dist/Openc3Screen-CzD9BB0M.cjs.map +0 -1
- package/dist/Openc3Screen-DcIIUO63.js.map +0 -1
- package/dist/OutputDialog-CNH74LpJ.js.map +0 -1
- package/dist/OutputDialog-QIabyvK1.cjs +0 -2
- package/dist/OutputDialog-QIabyvK1.cjs.map +0 -1
- package/dist/PluginsTab-B_Pf2A9c.js.map +0 -1
- package/dist/PluginsTab-DXf9zX0h.cjs.map +0 -1
- package/dist/ProgressbarWidget-B5WN658S.js.map +0 -1
- package/dist/ProgressbarWidget-D2NHSJny.cjs +0 -2
- package/dist/ProgressbarWidget-D2NHSJny.cjs.map +0 -1
- package/dist/RadiobuttonWidget-DkG9GtAy.cjs +0 -2
- package/dist/RangebarWidget-CJgtAk5z.cjs +0 -2
- package/dist/RangebarWidget-CJgtAk5z.cjs.map +0 -1
- package/dist/RangebarWidget-Dn0GASdi.js.map +0 -1
- package/dist/RollupWidget-B2pGGoET.cjs +0 -2
- package/dist/RollupWidget-B2pGGoET.cjs.map +0 -1
- package/dist/RollupWidget-b62qcG5K.js.map +0 -1
- package/dist/ScriptChooser-CtV7dDJS.cjs +0 -2
- package/dist/ScriptChooser-CtV7dDJS.cjs.map +0 -1
- package/dist/ScriptChooser-DMPY3m8a.js.map +0 -1
- package/dist/ScrollwindowWidget-ByJRy528.cjs +0 -2
- package/dist/ScrollwindowWidget-ByJRy528.cjs.map +0 -1
- package/dist/ScrollwindowWidget-Dn29gs-U.js +0 -45
- package/dist/ScrollwindowWidget-Dn29gs-U.js.map +0 -1
- package/dist/SettingsTab-8Zeg3G0C.cjs +0 -3
- package/dist/SettingsTab-8Zeg3G0C.cjs.map +0 -1
- package/dist/SettingsTab-L5xbCAW_.js.map +0 -1
- package/dist/SignalWidget-CEmQymzQ.cjs +0 -2
- package/dist/SignalWidget-CEmQymzQ.cjs.map +0 -1
- package/dist/SignalWidget-CLi6qask.js.map +0 -1
- package/dist/SimpleTextDialog-8vDPDt6X.js.map +0 -1
- package/dist/SimpleTextDialog-CJ8pLBGz.cjs +0 -2
- package/dist/SimpleTextDialog-CJ8pLBGz.cjs.map +0 -1
- package/dist/SparklineWidget-CIkMm4O-.cjs +0 -2
- package/dist/SparklineWidget-CIkMm4O-.cjs.map +0 -1
- package/dist/SparklineWidget-D8mb4zLt.js.map +0 -1
- package/dist/TabbookWidget-Bkt4g02d.js +0 -66
- package/dist/TabbookWidget-Bkt4g02d.js.map +0 -1
- package/dist/TabbookWidget-DqcScWwW.cjs +0 -2
- package/dist/TabbookWidget-DqcScWwW.cjs.map +0 -1
- package/dist/TargetPacketItemChooser-Cm6mQvhI.cjs +0 -2
- package/dist/TargetPacketItemChooser-Cm6mQvhI.cjs.map +0 -1
- package/dist/TargetPacketItemChooser-DGcXvdTX.js.map +0 -1
- package/dist/TextBoxDialog-DXG7H7kQ.cjs +0 -2
- package/dist/TextBoxDialog-DXG7H7kQ.cjs.map +0 -1
- package/dist/TextBoxDialog-Xs-gitZd.js.map +0 -1
- package/dist/TimeWidget-3M7CQ893.cjs +0 -2
- package/dist/TimeWidget-3M7CQ893.cjs.map +0 -1
- package/dist/TimeWidget-Dy8zpkC6.js +0 -40
- package/dist/TimeWidget-Dy8zpkC6.js.map +0 -1
- package/dist/UpgradeToEnterpriseDialog-D0AGxldj.js.map +0 -1
- package/dist/UpgradeToEnterpriseDialog-D8BkzmVD.cjs +0 -2
- package/dist/UpgradeToEnterpriseDialog-D8BkzmVD.cjs.map +0 -1
- package/dist/ValueWidget-BxWrHkYY.js +0 -118
- package/dist/ValueWidget-BxWrHkYY.js.map +0 -1
- package/dist/ValueWidget-yuZ8tPzG.cjs +0 -2
- package/dist/ValueWidget-yuZ8tPzG.cjs.map +0 -1
- package/dist/ValuelimitscolumnWidget-B0HGnyS5.cjs +0 -2
- package/dist/ValuelimitscolumnWidget-B0HGnyS5.cjs.map +0 -1
- package/dist/ValuelimitscolumnWidget-CuJ6rqtC.js.map +0 -1
- package/dist/VerticalWidget-DsnEzKZ2.js +0 -40
- package/dist/VerticalWidget-DsnEzKZ2.js.map +0 -1
- package/dist/VerticalWidget-wuRCrd7Q.cjs +0 -2
- package/dist/VerticalWidget-wuRCrd7Q.cjs.map +0 -1
- package/dist/Widget-CKianvfR.cjs +0 -2
- package/dist/Widget-CKianvfR.cjs.map +0 -1
- package/dist/Widget-VCl8Ts8s.js.map +0 -1
package/dist/{LabelvaluerangebarWidget-O8IHjvHs.js.map → LabelvaluerangebarWidget-CjkVDlVJ.js.map}
RENAMED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"LabelvaluerangebarWidget-
|
|
1
|
+
{"version":3,"file":"LabelvaluerangebarWidget-CjkVDlVJ.js","sources":["../src/widgets/LabelvaluerangebarWidget.vue"],"sourcesContent":["<!--\n# Copyright 2022 Ball Aerospace & Technologies Corp.\n# All Rights Reserved.\n#\n# This program is free software; you can modify and/or redistribute it\n# under the terms of the GNU Affero General Public License\n# as published by the Free Software Foundation; version 3 with\n# attribution addendums as found in the LICENSE.txt\n#\n# This program is distributed in the hope that it will be useful,\n# but WITHOUT ANY WARRANTY; without even the implied warranty of\n# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n# GNU Affero General Public License for more details.\n\n# Modified by OpenC3, Inc.\n# All changes Copyright 2022, OpenC3, Inc.\n# All Rights Reserved\n#\n# This file may also be used under the terms of a commercial license\n# if purchased from OpenC3, Inc.\n-->\n\n<template>\n <div ref=\"container\" class=\"d-flex flex-row\" :style=\"computedStyle\">\n <labelvalue-widget\n v-bind=\"$attrs\"\n :parameters=\"labelValueParameters\"\n :settings=\"labelValueSettings\"\n :screen-values=\"screenValues\"\n :screen-time-zone=\"screenTimeZone\"\n />\n <rangebar-widget\n v-bind=\"$attrs\"\n :parameters=\"rangeBarParameters\"\n :settings=\"[...appliedSettings]\"\n :screen-values=\"screenValues\"\n :widget-index=\"2\"\n />\n </div>\n</template>\n\n<script>\nimport LabelvalueWidget from './LabelvalueWidget.vue'\nimport RangebarWidget from './RangebarWidget.vue'\nimport Widget from './Widget'\n\nexport default {\n components: {\n LabelvalueWidget,\n RangebarWidget,\n },\n mixins: [Widget],\n computed: {\n // Filter the settings to just the ones that apply to LABELVALUE.\n // Normally this is automatically handled by Widget.js computedStyle().\n // However, if someone tries to set an overall WIDTH\n // of the LABELVALUERANGEBAR, without filtering it will get\n // passed down to LABELVALUE and be set there as well.\n labelValueSettings() {\n return [\n // Get the screen setting\n ...this.settings.filter((x) => x[0] === '__SCREEN_ID__'),\n // Get all the setting that apply to labelvalue (0, 1 widgets)\n ...this.settings.filter(\n (x) => parseInt(x[0]) === 0 || parseInt(x[0]) === 1,\n ),\n ]\n },\n labelValueParameters() {\n return [\n this.parameters[0],\n this.parameters[1],\n this.parameters[2],\n // Skip 3,4 which is range min,max\n this.parameters[5],\n this.parameters[6], // num characters\n ]\n },\n rangeBarParameters() {\n return [\n this.parameters[0],\n this.parameters[1],\n this.parameters[2],\n this.parameters[3],\n this.parameters[4],\n this.parameters[5],\n // Skip 6 which is num chars\n this.parameters[7],\n this.parameters[8],\n ]\n },\n },\n}\n</script>\n"],"names":["_sfc_main","LabelvalueWidget","RangebarWidget","Widget","x","_createElementBlock","_ctx","_createVNode","_component_labelvalue_widget","_mergeProps","$options","_component_rangebar_widget"],"mappings":";;;;;AA8CA,MAAKA,IAAU;AAAA,EACb,YAAY;AAAA,IACV,kBAAAC;AAAA,IACA,gBAAAC;AAAA;EAEF,QAAQ,CAACC,CAAM;AAAA,EACf,UAAU;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAMR,qBAAqB;AACnB,aAAO;AAAA;AAAA,QAEL,GAAG,KAAK,SAAS,OAAO,CAACC,MAAMA,EAAE,CAAC,MAAM,eAAe;AAAA;AAAA,QAEvD,GAAG,KAAK,SAAS;AAAA,UACf,CAACA,MAAM,SAASA,EAAE,CAAC,CAAC,MAAM,KAAK,SAASA,EAAE,CAAC,CAAC,MAAM;AAAA;MAEtD;AAAA,IACF;AAAA,IACA,uBAAuB;AACrB,aAAO;AAAA,QACL,KAAK,WAAW,CAAC;AAAA,QACjB,KAAK,WAAW,CAAC;AAAA,QACjB,KAAK,WAAW,CAAC;AAAA;AAAA,QAEjB,KAAK,WAAW,CAAC;AAAA,QACjB,KAAK,WAAW,CAAC;AAAA;AAAA,MACnB;AAAA,IACF;AAAA,IACA,qBAAqB;AACnB,aAAO;AAAA,QACL,KAAK,WAAW,CAAC;AAAA,QACjB,KAAK,WAAW,CAAC;AAAA,QACjB,KAAK,WAAW,CAAC;AAAA,QACjB,KAAK,WAAW,CAAC;AAAA,QACjB,KAAK,WAAW,CAAC;AAAA,QACjB,KAAK,WAAW,CAAC;AAAA;AAAA,QAEjB,KAAK,WAAW,CAAC;AAAA,QACjB,KAAK,WAAW,CAAC;AAAA,MACnB;AAAA,IACF;AAAA;AAEJ;;;cArEEC,EAeM,OAAA;AAAA,IAfD,KAAI;AAAA,IAAY,OAAM;AAAA,IAAmB,SAAOC,EAAA,aAAa;AAAA;IAChEC,EAMEC,GANFC,EACUH,EAAA,QAAM;AAAA,MACb,YAAYI,EAAA;AAAA,MACZ,UAAUA,EAAA;AAAA,MACV,iBAAeJ,EAAA;AAAA,MACf,oBAAkBA,EAAA;AAAA;IAErBC,EAMEI,GANFF,EACUH,EAAA,QAAM;AAAA,MACb,YAAYI,EAAA;AAAA,MACZ,cAAcJ,EAAA,eAAe;AAAA,MAC7B,iBAAeA,EAAA;AAAA,MACf,gBAAc;AAAA;;;;"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { W as g } from "./Widget-D4rzBHnr.js";
|
|
2
|
+
const u = {
|
|
3
|
+
mixins: [g],
|
|
4
|
+
props: {
|
|
5
|
+
widgets: {
|
|
6
|
+
type: Array,
|
|
7
|
+
default: () => []
|
|
8
|
+
}
|
|
9
|
+
},
|
|
10
|
+
methods: {
|
|
11
|
+
getTooltipText(s) {
|
|
12
|
+
var e;
|
|
13
|
+
const t = (e = s.settings) == null ? void 0 : e.find((i) => i[0] === "TOOLTIP");
|
|
14
|
+
return t ? t[1] : null;
|
|
15
|
+
},
|
|
16
|
+
getTooltipDelay(s) {
|
|
17
|
+
var e;
|
|
18
|
+
const t = (e = s.settings) == null ? void 0 : e.find((i) => i[0] === "TOOLTIP");
|
|
19
|
+
return t && t[2] ? parseInt(t[2]) : 600;
|
|
20
|
+
},
|
|
21
|
+
getTooltipActivatorProps(s) {
|
|
22
|
+
var i;
|
|
23
|
+
const t = (i = s.settings) == null ? void 0 : i.some(
|
|
24
|
+
(r) => {
|
|
25
|
+
var o, a, n, p;
|
|
26
|
+
return r[0] === "WIDTH" || ((a = (o = r[0]) == null ? void 0 : o.startsWith) == null ? void 0 : a.call(o, "RAW")) && ((p = (n = r[1]) == null ? void 0 : n.toUpperCase) == null ? void 0 : p.call(n).includes("WIDTH"));
|
|
27
|
+
}
|
|
28
|
+
), e = s.type === "ValueWidget";
|
|
29
|
+
return t || e ? {} : { style: "flex: 1 1 auto" };
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
export {
|
|
34
|
+
u as L
|
|
35
|
+
};
|
|
36
|
+
//# sourceMappingURL=Layout-FpBx3iic.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Layout-FpBx3iic.js","sources":["../src/widgets/Layout.js"],"sourcesContent":["/*\n# Copyright 2022 Ball Aerospace & Technologies Corp.\n# All Rights Reserved.\n#\n# This program is free software; you can modify and/or redistribute it\n# under the terms of the GNU Affero General Public License\n# as published by the Free Software Foundation; version 3 with\n# attribution addendums as found in the LICENSE.txt\n#\n# This program is distributed in the hope that it will be useful,\n# but WITHOUT ANY WARRANTY; without even the implied warranty of\n# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n# GNU Affero General Public License for more details.\n\n# Modified by OpenC3, Inc.\n# All changes Copyright 2025, OpenC3, Inc.\n# All Rights Reserved\n#\n# This file may also be used under the terms of a commercial license\n# if purchased from OpenC3, Inc.\n*/\n\nimport Widget from './Widget'\nexport default {\n mixins: [Widget],\n props: {\n widgets: {\n type: Array,\n default: () => [],\n },\n },\n methods: {\n getTooltipText(widget) {\n const setting = widget.settings?.find((s) => s[0] === 'TOOLTIP')\n return setting ? setting[1] : null\n },\n getTooltipDelay(widget) {\n const setting = widget.settings?.find((s) => s[0] === 'TOOLTIP')\n return setting && setting[2] ? parseInt(setting[2]) : 600\n },\n getTooltipActivatorProps(widget) {\n // Check if widget has explicit width set - if so, don't apply flex grow\n const hasWidthSetting = widget.settings?.some(\n (s) =>\n s[0] === 'WIDTH' ||\n (s[0]?.startsWith?.('RAW') &&\n s[1]?.toUpperCase?.().includes('WIDTH')),\n )\n // VALUE widget always has a default width\n const isValueWidget = widget.type === 'ValueWidget'\n // Only apply flex: 1 1 auto if widget doesn't have explicit width\n return hasWidthSetting || isValueWidget ? {} : { style: 'flex: 1 1 auto' }\n },\n },\n}\n"],"names":["Layout","Widget","widget","setting","_a","s","hasWidthSetting","_b","_d","_c","isValueWidget"],"mappings":";AAuBA,MAAAA,IAAe;AAAA,EACb,QAAQ,CAACC,CAAM;AAAA,EACf,OAAO;AAAA,IACL,SAAS;AAAA,MACP,MAAM;AAAA,MACN,SAAS,MAAM,CAAA;AAAA,IACrB;AAAA,EACA;AAAA,EACE,SAAS;AAAA,IACP,eAAeC,GAAQ;;AACrB,YAAMC,KAAUC,IAAAF,EAAO,aAAP,gBAAAE,EAAiB,KAAK,CAACC,MAAMA,EAAE,CAAC,MAAM;AACtD,aAAOF,IAAUA,EAAQ,CAAC,IAAI;AAAA,IAChC;AAAA,IACA,gBAAgBD,GAAQ;;AACtB,YAAMC,KAAUC,IAAAF,EAAO,aAAP,gBAAAE,EAAiB,KAAK,CAACC,MAAMA,EAAE,CAAC,MAAM;AACtD,aAAOF,KAAWA,EAAQ,CAAC,IAAI,SAASA,EAAQ,CAAC,CAAC,IAAI;AAAA,IACxD;AAAA,IACA,yBAAyBD,GAAQ;;AAE/B,YAAMI,KAAkBF,IAAAF,EAAO,aAAP,gBAAAE,EAAiB;AAAA,QACvC,CAACC,MAAC;;AACA,iBAAAA,EAAE,CAAC,MAAM,aACRE,KAAAH,IAAAC,EAAE,CAAC,MAAH,gBAAAD,EAAM,eAAN,gBAAAG,EAAA,KAAAH,GAAmB,aAClBI,KAAAC,IAAAJ,EAAE,CAAC,MAAH,gBAAAI,EAAM,gBAAN,gBAAAD,EAAA,KAAAC,GAAsB,SAAS;AAAA;AAAA,SAG/BC,IAAgBR,EAAO,SAAS;AAEtC,aAAOI,KAAmBI,IAAgB,KAAK,EAAE,OAAO,iBAAgB;AAAA,IAC1E;AAAA,EACJ;AACA;"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";const u=require("./Widget-Btu2EoLT.cjs"),l={mixins:[u.Widget],props:{widgets:{type:Array,default:()=>[]}},methods:{getTooltipText(s){var e;const t=(e=s.settings)==null?void 0:e.find(i=>i[0]==="TOOLTIP");return t?t[1]:null},getTooltipDelay(s){var e;const t=(e=s.settings)==null?void 0:e.find(i=>i[0]==="TOOLTIP");return t&&t[2]?parseInt(t[2]):600},getTooltipActivatorProps(s){var i;const t=(i=s.settings)==null?void 0:i.some(r=>{var n,a,o,g;return r[0]==="WIDTH"||((a=(n=r[0])==null?void 0:n.startsWith)==null?void 0:a.call(n,"RAW"))&&((g=(o=r[1])==null?void 0:o.toUpperCase)==null?void 0:g.call(o).includes("WIDTH"))}),e=s.type==="ValueWidget";return t||e?{}:{style:"flex: 1 1 auto"}}}};exports.Layout=l;
|
|
2
|
+
//# sourceMappingURL=Layout-K7_I6jMV.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Layout-K7_I6jMV.cjs","sources":["../src/widgets/Layout.js"],"sourcesContent":["/*\n# Copyright 2022 Ball Aerospace & Technologies Corp.\n# All Rights Reserved.\n#\n# This program is free software; you can modify and/or redistribute it\n# under the terms of the GNU Affero General Public License\n# as published by the Free Software Foundation; version 3 with\n# attribution addendums as found in the LICENSE.txt\n#\n# This program is distributed in the hope that it will be useful,\n# but WITHOUT ANY WARRANTY; without even the implied warranty of\n# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n# GNU Affero General Public License for more details.\n\n# Modified by OpenC3, Inc.\n# All changes Copyright 2025, OpenC3, Inc.\n# All Rights Reserved\n#\n# This file may also be used under the terms of a commercial license\n# if purchased from OpenC3, Inc.\n*/\n\nimport Widget from './Widget'\nexport default {\n mixins: [Widget],\n props: {\n widgets: {\n type: Array,\n default: () => [],\n },\n },\n methods: {\n getTooltipText(widget) {\n const setting = widget.settings?.find((s) => s[0] === 'TOOLTIP')\n return setting ? setting[1] : null\n },\n getTooltipDelay(widget) {\n const setting = widget.settings?.find((s) => s[0] === 'TOOLTIP')\n return setting && setting[2] ? parseInt(setting[2]) : 600\n },\n getTooltipActivatorProps(widget) {\n // Check if widget has explicit width set - if so, don't apply flex grow\n const hasWidthSetting = widget.settings?.some(\n (s) =>\n s[0] === 'WIDTH' ||\n (s[0]?.startsWith?.('RAW') &&\n s[1]?.toUpperCase?.().includes('WIDTH')),\n )\n // VALUE widget always has a default width\n const isValueWidget = widget.type === 'ValueWidget'\n // Only apply flex: 1 1 auto if widget doesn't have explicit width\n return hasWidthSetting || isValueWidget ? {} : { style: 'flex: 1 1 auto' }\n },\n },\n}\n"],"names":["Layout","Widget","widget","setting","_a","s","hasWidthSetting","_b","_d","_c","isValueWidget"],"mappings":"sDAuBAA,EAAe,CACb,OAAQ,CAACC,EAAAA,MAAM,EACf,MAAO,CACL,QAAS,CACP,KAAM,MACN,QAAS,IAAM,CAAA,CACrB,CACA,EACE,QAAS,CACP,eAAeC,EAAQ,OACrB,MAAMC,GAAUC,EAAAF,EAAO,WAAP,YAAAE,EAAiB,KAAMC,GAAMA,EAAE,CAAC,IAAM,WACtD,OAAOF,EAAUA,EAAQ,CAAC,EAAI,IAChC,EACA,gBAAgBD,EAAQ,OACtB,MAAMC,GAAUC,EAAAF,EAAO,WAAP,YAAAE,EAAiB,KAAMC,GAAMA,EAAE,CAAC,IAAM,WACtD,OAAOF,GAAWA,EAAQ,CAAC,EAAI,SAASA,EAAQ,CAAC,CAAC,EAAI,GACxD,EACA,yBAAyBD,EAAQ,OAE/B,MAAMI,GAAkBF,EAAAF,EAAO,WAAP,YAAAE,EAAiB,KACtCC,GAAC,aACA,OAAAA,EAAE,CAAC,IAAM,WACRE,GAAAH,EAAAC,EAAE,CAAC,IAAH,YAAAD,EAAM,aAAN,YAAAG,EAAA,KAAAH,EAAmB,WAClBI,GAAAC,EAAAJ,EAAE,CAAC,IAAH,YAAAI,EAAM,cAAN,YAAAD,EAAA,KAAAC,GAAsB,SAAS,YAG/BC,EAAgBR,EAAO,OAAS,cAEtC,OAAOI,GAAmBI,EAAgB,GAAK,CAAE,MAAO,gBAAgB,CAC1E,CACJ,CACA"}
|
|
@@ -1,14 +1,15 @@
|
|
|
1
|
-
import "./UpgradeToEnterpriseDialog.
|
|
2
|
-
import { resolveComponent as
|
|
3
|
-
import { _ as
|
|
4
|
-
import { D as
|
|
1
|
+
import "./UpgradeToEnterpriseDialog.vue_vue_type_style_index_0_scoped_dda5adfc_lang-NXWdTcR2.js";
|
|
2
|
+
import { resolveComponent as l, createElementBlock as p, openBlock as i, createBlock as u, createVNode as r, withCtx as a, createElementVNode as d, toDisplayString as h, mergeProps as x, normalizeStyle as C, normalizeClass as I, Fragment as S, renderList as k, withModifiers as y, createTextVNode as M } from "vue";
|
|
3
|
+
import { _ as D } from "./CustomIcon-B9m73Gqm.js";
|
|
4
|
+
import { D as V } from "./DetailsDialog-D-rjL4oc.js";
|
|
5
5
|
import "single-spa";
|
|
6
|
-
import { W as
|
|
7
|
-
const
|
|
6
|
+
import { W as E } from "./Widget-D4rzBHnr.js";
|
|
7
|
+
const T = {
|
|
8
8
|
components: {
|
|
9
|
-
DetailsDialog:
|
|
9
|
+
DetailsDialog: V
|
|
10
10
|
},
|
|
11
|
-
mixins: [
|
|
11
|
+
mixins: [E],
|
|
12
|
+
emits: ["addItem", "deleteItem"],
|
|
12
13
|
data() {
|
|
13
14
|
return {
|
|
14
15
|
valueId: null,
|
|
@@ -83,43 +84,49 @@ const E = {
|
|
|
83
84
|
}
|
|
84
85
|
}
|
|
85
86
|
};
|
|
86
|
-
function
|
|
87
|
-
const
|
|
88
|
-
return
|
|
89
|
-
|
|
87
|
+
function N(e, t, L, R, o, n) {
|
|
88
|
+
const c = l("v-tooltip"), _ = l("v-list-item-title"), f = l("v-list-item"), v = l("v-list"), w = l("v-menu"), g = l("details-dialog");
|
|
89
|
+
return i(), p("div", null, [
|
|
90
|
+
e.tooltipText ? (i(), p("div", {
|
|
91
|
+
key: 1,
|
|
92
|
+
class: I(n.getClass),
|
|
93
|
+
style: C([n.cssProps, e.computedStyle]),
|
|
94
|
+
onContextmenu: t[1] || (t[1] = (...s) => n.showContextMenu && n.showContextMenu(...s))
|
|
95
|
+
}, null, 38)) : (i(), u(c, {
|
|
96
|
+
key: 0,
|
|
90
97
|
"open-delay": 600,
|
|
91
98
|
location: "top"
|
|
92
99
|
}, {
|
|
93
|
-
activator:
|
|
94
|
-
|
|
95
|
-
class:
|
|
96
|
-
style: [
|
|
100
|
+
activator: a(({ props: s }) => [
|
|
101
|
+
d("div", x({
|
|
102
|
+
class: n.getClass,
|
|
103
|
+
style: [n.cssProps, e.computedStyle]
|
|
97
104
|
}, s, {
|
|
98
|
-
onContextmenu: t[0] || (t[0] = (...
|
|
105
|
+
onContextmenu: t[0] || (t[0] = (...m) => n.showContextMenu && n.showContextMenu(...m))
|
|
99
106
|
}), null, 16)
|
|
100
107
|
]),
|
|
101
|
-
default:
|
|
102
|
-
|
|
108
|
+
default: a(() => [
|
|
109
|
+
d("span", null, h(n.fullName), 1)
|
|
103
110
|
]),
|
|
104
111
|
_: 1
|
|
105
|
-
}),
|
|
106
|
-
|
|
107
|
-
modelValue:
|
|
108
|
-
"onUpdate:modelValue": t[
|
|
109
|
-
target: [
|
|
112
|
+
})),
|
|
113
|
+
r(w, {
|
|
114
|
+
modelValue: o.contextMenuShown,
|
|
115
|
+
"onUpdate:modelValue": t[2] || (t[2] = (s) => o.contextMenuShown = s),
|
|
116
|
+
target: [o.x, o.y],
|
|
110
117
|
style: { "z-index": "3000" }
|
|
111
118
|
}, {
|
|
112
|
-
default:
|
|
113
|
-
|
|
114
|
-
default:
|
|
115
|
-
(
|
|
116
|
-
key:
|
|
117
|
-
onClick:
|
|
119
|
+
default: a(() => [
|
|
120
|
+
r(v, null, {
|
|
121
|
+
default: a(() => [
|
|
122
|
+
(i(!0), p(S, null, k(o.contextMenuOptions, (s, m) => (i(), u(f, {
|
|
123
|
+
key: m,
|
|
124
|
+
onClick: y(s.action, ["stop"])
|
|
118
125
|
}, {
|
|
119
|
-
default:
|
|
120
|
-
|
|
121
|
-
default:
|
|
122
|
-
|
|
126
|
+
default: a(() => [
|
|
127
|
+
r(_, null, {
|
|
128
|
+
default: a(() => [
|
|
129
|
+
M(h(s.title), 1)
|
|
123
130
|
]),
|
|
124
131
|
_: 2
|
|
125
132
|
}, 1024)
|
|
@@ -132,17 +139,17 @@ function y(e, t, N, T, n, a) {
|
|
|
132
139
|
]),
|
|
133
140
|
_: 1
|
|
134
141
|
}, 8, ["modelValue", "target"]),
|
|
135
|
-
|
|
136
|
-
modelValue:
|
|
137
|
-
"onUpdate:modelValue": t[
|
|
142
|
+
r(g, {
|
|
143
|
+
modelValue: o.viewDetails,
|
|
144
|
+
"onUpdate:modelValue": t[3] || (t[3] = (s) => o.viewDetails = s),
|
|
138
145
|
"target-name": e.parameters[0],
|
|
139
146
|
"packet-name": e.parameters[1],
|
|
140
147
|
"item-name": e.parameters[2]
|
|
141
148
|
}, null, 8, ["modelValue", "target-name", "packet-name", "item-name"])
|
|
142
149
|
]);
|
|
143
150
|
}
|
|
144
|
-
const A = /* @__PURE__ */
|
|
151
|
+
const A = /* @__PURE__ */ D(T, [["render", N], ["__scopeId", "data-v-2a39f3fe"]]);
|
|
145
152
|
export {
|
|
146
153
|
A as default
|
|
147
154
|
};
|
|
148
|
-
//# sourceMappingURL=LedWidget-
|
|
155
|
+
//# sourceMappingURL=LedWidget-Bsp1aja-.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LedWidget-Bsp1aja-.js","sources":["../src/widgets/LedWidget.vue"],"sourcesContent":["<!--\n# Copyright 2022 Ball Aerospace & Technologies Corp.\n# All Rights Reserved.\n#\n# This program is free software; you can modify and/or redistribute it\n# under the terms of the GNU Affero General Public License\n# as published by the Free Software Foundation; version 3 with\n# attribution addendums as found in the LICENSE.txt\n#\n# This program is distributed in the hope that it will be useful,\n# but WITHOUT ANY WARRANTY; without even the implied warranty of\n# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n# GNU Affero General Public License for more details.\n\n# Modified by OpenC3, Inc.\n# All changes Copyright 2025, OpenC3, Inc.\n# All Rights Reserved\n#\n# This file may also be used under the terms of a commercial license\n# if purchased from OpenC3, Inc.\n-->\n\n<template>\n <div>\n <v-tooltip v-if=\"!tooltipText\" :open-delay=\"600\" location=\"top\">\n <template #activator=\"{ props }\">\n <div\n :class=\"getClass\"\n :style=\"[cssProps, computedStyle]\"\n v-bind=\"props\"\n @contextmenu=\"showContextMenu\"\n ></div>\n </template>\n <span>{{ fullName }}</span>\n </v-tooltip>\n <div\n v-else\n :class=\"getClass\"\n :style=\"[cssProps, computedStyle]\"\n @contextmenu=\"showContextMenu\"\n ></div>\n\n <v-menu v-model=\"contextMenuShown\" :target=\"[x, y]\" style=\"z-index: 3000\">\n <v-list>\n <v-list-item\n v-for=\"(item, index) in contextMenuOptions\"\n :key=\"index\"\n @click.stop=\"item.action\"\n >\n <v-list-item-title>{{ item.title }}</v-list-item-title>\n </v-list-item>\n </v-list>\n </v-menu>\n\n <details-dialog\n v-model=\"viewDetails\"\n :target-name=\"parameters[0]\"\n :packet-name=\"parameters[1]\"\n :item-name=\"parameters[2]\"\n />\n </div>\n</template>\n\n<script>\nimport { DetailsDialog } from '@/components'\nimport Widget from './Widget'\nexport default {\n components: {\n DetailsDialog,\n },\n mixins: [Widget],\n emits: ['addItem', 'deleteItem'],\n data() {\n return {\n valueId: null,\n colors: {\n TRUE: 'openc3-green',\n FALSE: 'openc3-red',\n },\n viewDetails: false,\n contextMenuShown: false,\n x: 0,\n y: 0,\n contextMenuOptions: [\n {\n title: 'Details',\n action: () => {\n this.contextMenuShown = false\n this.viewDetails = true\n },\n },\n {\n title: 'Graph',\n action: () => {\n window.open(\n '/tools/tlmgrapher/' +\n encodeURIComponent(this.parameters[0]) +\n '/' +\n encodeURIComponent(this.parameters[1]) +\n '/' +\n encodeURIComponent(this.parameters[2]) +\n '/',\n '_blank',\n )\n },\n },\n ],\n }\n },\n computed: {\n width() {\n return this.parameters[4] ? parseInt(this.parameters[4]) : 20\n },\n height() {\n return this.parameters[5] ? parseInt(this.parameters[5]) : 20\n },\n cssProps() {\n let value = this.screenValues[this.valueId][0]\n let color = this.colors[value]\n if (!color) {\n color = this.colors.ANY\n }\n if (!color) {\n color = 'openc3-black'\n }\n return {\n '--color': color,\n }\n },\n fullName() {\n return (\n this.parameters[0] + ' ' + this.parameters[1] + ' ' + this.parameters[2]\n )\n },\n getClass() {\n let result = 'ledwidget mt-2'\n if (this.screenValues[this.valueId][1] === 'STALE') {\n result += ' stale'\n }\n return result\n },\n },\n // Note Vuejs still treats this synchronously, but this allows us to dispatch\n // the store mutation and return the array index.\n // What this means practically is that future lifecycle hooks may not have valueId set.\n created() {\n this.appliedSettings.forEach((setting) => {\n switch (setting[0]) {\n case 'LED_COLOR':\n this.colors[setting[1]] = setting[2]\n break\n }\n })\n // Throw width and height into the appliedSettings so they are set\n // and we don't get the default flex value\n this.appliedSettings.push(['WIDTH', this.width])\n this.appliedSettings.push(['HEIGHT', this.height])\n\n if (!this.parameters[3]) {\n this.parameters[3] = 'CONVERTED'\n }\n this.valueId = `${this.parameters[0]}__${this.parameters[1]}__${this.parameters[2]}__${this.parameters[3]}`\n this.$emit('addItem', this.valueId)\n },\n unmounted() {\n this.$emit('deleteItem', this.valueId)\n },\n methods: {\n showContextMenu(e) {\n e.preventDefault()\n this.contextMenuShown = false\n this.x = e.clientX\n this.y = e.clientY\n this.$nextTick(() => {\n this.contextMenuShown = true\n })\n },\n },\n}\n</script>\n\n<style scoped>\n.ledwidget {\n background-color: var(--color);\n border-radius: 50%;\n}\n.stale {\n filter: blur(2px) brightness(0.6);\n}\n</style>\n"],"names":["_sfc_main","DetailsDialog","Widget","value","color","result","setting","_createElementBlock","_ctx","$options","_normalizeStyle","args","_createBlock","_component_v_tooltip","_withCtx","props","_createElementVNode","_mergeProps","_createVNode","_component_v_menu","$data","$event","_component_v_list","_openBlock","_Fragment","_renderList","item","index","_component_v_list_item","_withModifiers","_component_v_list_item_title","_createTextVNode","_toDisplayString","_component_details_dialog"],"mappings":"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"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});require("./UpgradeToEnterpriseDialog.vue_vue_type_style_index_0_scoped_dda5adfc_lang-Bjn8x8eE.cjs");const e=require("vue"),d=require("./CustomIcon-CEc927h0.cjs"),h=require("./DetailsDialog-lJG8eclU.cjs");require("single-spa");const v=require("./Widget-Btu2EoLT.cjs"),C={components:{DetailsDialog:h.DetailsDialog},mixins:[v.Widget],emits:["addItem","deleteItem"],data(){return{valueId:null,colors:{TRUE:"openc3-green",FALSE:"openc3-red"},viewDetails:!1,contextMenuShown:!1,x:0,y:0,contextMenuOptions:[{title:"Details",action:()=>{this.contextMenuShown=!1,this.viewDetails=!0}},{title:"Graph",action:()=>{window.open("/tools/tlmgrapher/"+encodeURIComponent(this.parameters[0])+"/"+encodeURIComponent(this.parameters[1])+"/"+encodeURIComponent(this.parameters[2])+"/","_blank")}}]}},computed:{width(){return this.parameters[4]?parseInt(this.parameters[4]):20},height(){return this.parameters[5]?parseInt(this.parameters[5]):20},cssProps(){let t=this.screenValues[this.valueId][0],o=this.colors[t];return o||(o=this.colors.ANY),o||(o="openc3-black"),{"--color":o}},fullName(){return this.parameters[0]+" "+this.parameters[1]+" "+this.parameters[2]},getClass(){let t="ledwidget mt-2";return this.screenValues[this.valueId][1]==="STALE"&&(t+=" stale"),t}},created(){this.appliedSettings.forEach(t=>{switch(t[0]){case"LED_COLOR":this.colors[t[1]]=t[2];break}}),this.appliedSettings.push(["WIDTH",this.width]),this.appliedSettings.push(["HEIGHT",this.height]),this.parameters[3]||(this.parameters[3]="CONVERTED"),this.valueId=`${this.parameters[0]}__${this.parameters[1]}__${this.parameters[2]}__${this.parameters[3]}`,this.$emit("addItem",this.valueId)},unmounted(){this.$emit("deleteItem",this.valueId)},methods:{showContextMenu(t){t.preventDefault(),this.contextMenuShown=!1,this.x=t.clientX,this.y=t.clientY,this.$nextTick(()=>{this.contextMenuShown=!0})}}};function _(t,o,g,f,l,s){const r=e.resolveComponent("v-tooltip"),a=e.resolveComponent("v-list-item-title"),m=e.resolveComponent("v-list-item"),u=e.resolveComponent("v-list"),c=e.resolveComponent("v-menu"),p=e.resolveComponent("details-dialog");return e.openBlock(),e.createElementBlock("div",null,[t.tooltipText?(e.openBlock(),e.createElementBlock("div",{key:1,class:e.normalizeClass(s.getClass),style:e.normalizeStyle([s.cssProps,t.computedStyle]),onContextmenu:o[1]||(o[1]=(...n)=>s.showContextMenu&&s.showContextMenu(...n))},null,38)):(e.openBlock(),e.createBlock(r,{key:0,"open-delay":600,location:"top"},{activator:e.withCtx(({props:n})=>[e.createElementVNode("div",e.mergeProps({class:s.getClass,style:[s.cssProps,t.computedStyle]},n,{onContextmenu:o[0]||(o[0]=(...i)=>s.showContextMenu&&s.showContextMenu(...i))}),null,16)]),default:e.withCtx(()=>[e.createElementVNode("span",null,e.toDisplayString(s.fullName),1)]),_:1})),e.createVNode(c,{modelValue:l.contextMenuShown,"onUpdate:modelValue":o[2]||(o[2]=n=>l.contextMenuShown=n),target:[l.x,l.y],style:{"z-index":"3000"}},{default:e.withCtx(()=>[e.createVNode(u,null,{default:e.withCtx(()=>[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(l.contextMenuOptions,(n,i)=>(e.openBlock(),e.createBlock(m,{key:i,onClick:e.withModifiers(n.action,["stop"])},{default:e.withCtx(()=>[e.createVNode(a,null,{default:e.withCtx(()=>[e.createTextVNode(e.toDisplayString(n.title),1)]),_:2},1024)]),_:2},1032,["onClick"]))),128))]),_:1})]),_:1},8,["modelValue","target"]),e.createVNode(p,{modelValue:l.viewDetails,"onUpdate:modelValue":o[3]||(o[3]=n=>l.viewDetails=n),"target-name":t.parameters[0],"packet-name":t.parameters[1],"item-name":t.parameters[2]},null,8,["modelValue","target-name","packet-name","item-name"])])}const w=d._export_sfc(C,[["render",_],["__scopeId","data-v-2a39f3fe"]]);exports.default=w;
|
|
2
|
+
//# sourceMappingURL=LedWidget-C19KREVz.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LedWidget-C19KREVz.cjs","sources":["../src/widgets/LedWidget.vue"],"sourcesContent":["<!--\n# Copyright 2022 Ball Aerospace & Technologies Corp.\n# All Rights Reserved.\n#\n# This program is free software; you can modify and/or redistribute it\n# under the terms of the GNU Affero General Public License\n# as published by the Free Software Foundation; version 3 with\n# attribution addendums as found in the LICENSE.txt\n#\n# This program is distributed in the hope that it will be useful,\n# but WITHOUT ANY WARRANTY; without even the implied warranty of\n# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n# GNU Affero General Public License for more details.\n\n# Modified by OpenC3, Inc.\n# All changes Copyright 2025, OpenC3, Inc.\n# All Rights Reserved\n#\n# This file may also be used under the terms of a commercial license\n# if purchased from OpenC3, Inc.\n-->\n\n<template>\n <div>\n <v-tooltip v-if=\"!tooltipText\" :open-delay=\"600\" location=\"top\">\n <template #activator=\"{ props }\">\n <div\n :class=\"getClass\"\n :style=\"[cssProps, computedStyle]\"\n v-bind=\"props\"\n @contextmenu=\"showContextMenu\"\n ></div>\n </template>\n <span>{{ fullName }}</span>\n </v-tooltip>\n <div\n v-else\n :class=\"getClass\"\n :style=\"[cssProps, computedStyle]\"\n @contextmenu=\"showContextMenu\"\n ></div>\n\n <v-menu v-model=\"contextMenuShown\" :target=\"[x, y]\" style=\"z-index: 3000\">\n <v-list>\n <v-list-item\n v-for=\"(item, index) in contextMenuOptions\"\n :key=\"index\"\n @click.stop=\"item.action\"\n >\n <v-list-item-title>{{ item.title }}</v-list-item-title>\n </v-list-item>\n </v-list>\n </v-menu>\n\n <details-dialog\n v-model=\"viewDetails\"\n :target-name=\"parameters[0]\"\n :packet-name=\"parameters[1]\"\n :item-name=\"parameters[2]\"\n />\n </div>\n</template>\n\n<script>\nimport { DetailsDialog } from '@/components'\nimport Widget from './Widget'\nexport default {\n components: {\n DetailsDialog,\n },\n mixins: [Widget],\n emits: ['addItem', 'deleteItem'],\n data() {\n return {\n valueId: null,\n colors: {\n TRUE: 'openc3-green',\n FALSE: 'openc3-red',\n },\n viewDetails: false,\n contextMenuShown: false,\n x: 0,\n y: 0,\n contextMenuOptions: [\n {\n title: 'Details',\n action: () => {\n this.contextMenuShown = false\n this.viewDetails = true\n },\n },\n {\n title: 'Graph',\n action: () => {\n window.open(\n '/tools/tlmgrapher/' +\n encodeURIComponent(this.parameters[0]) +\n '/' +\n encodeURIComponent(this.parameters[1]) +\n '/' +\n encodeURIComponent(this.parameters[2]) +\n '/',\n '_blank',\n )\n },\n },\n ],\n }\n },\n computed: {\n width() {\n return this.parameters[4] ? parseInt(this.parameters[4]) : 20\n },\n height() {\n return this.parameters[5] ? parseInt(this.parameters[5]) : 20\n },\n cssProps() {\n let value = this.screenValues[this.valueId][0]\n let color = this.colors[value]\n if (!color) {\n color = this.colors.ANY\n }\n if (!color) {\n color = 'openc3-black'\n }\n return {\n '--color': color,\n }\n },\n fullName() {\n return (\n this.parameters[0] + ' ' + this.parameters[1] + ' ' + this.parameters[2]\n )\n },\n getClass() {\n let result = 'ledwidget mt-2'\n if (this.screenValues[this.valueId][1] === 'STALE') {\n result += ' stale'\n }\n return result\n },\n },\n // Note Vuejs still treats this synchronously, but this allows us to dispatch\n // the store mutation and return the array index.\n // What this means practically is that future lifecycle hooks may not have valueId set.\n created() {\n this.appliedSettings.forEach((setting) => {\n switch (setting[0]) {\n case 'LED_COLOR':\n this.colors[setting[1]] = setting[2]\n break\n }\n })\n // Throw width and height into the appliedSettings so they are set\n // and we don't get the default flex value\n this.appliedSettings.push(['WIDTH', this.width])\n this.appliedSettings.push(['HEIGHT', this.height])\n\n if (!this.parameters[3]) {\n this.parameters[3] = 'CONVERTED'\n }\n this.valueId = `${this.parameters[0]}__${this.parameters[1]}__${this.parameters[2]}__${this.parameters[3]}`\n this.$emit('addItem', this.valueId)\n },\n unmounted() {\n this.$emit('deleteItem', this.valueId)\n },\n methods: {\n showContextMenu(e) {\n e.preventDefault()\n this.contextMenuShown = false\n this.x = e.clientX\n this.y = e.clientY\n this.$nextTick(() => {\n this.contextMenuShown = true\n })\n },\n },\n}\n</script>\n\n<style scoped>\n.ledwidget {\n background-color: var(--color);\n border-radius: 50%;\n}\n.stale {\n filter: blur(2px) brightness(0.6);\n}\n</style>\n"],"names":["_sfc_main","DetailsDialog","Widget","value","color","result","setting","e","_createElementBlock","_ctx","$options","_normalizeStyle","args","_createBlock","_component_v_tooltip","_withCtx","props","_createElementVNode","_mergeProps","_createVNode","_component_v_menu","$data","$event","_component_v_list","_openBlock","_Fragment","_renderList","item","index","_component_v_list_item","_withModifiers","_component_v_list_item_title","_createTextVNode","_toDisplayString","_component_details_dialog"],"mappings":"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"}
|
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
import { resolveComponent as v, createBlock as c, createElementBlock as _, openBlock as u, withCtx as w, createElementVNode as e, toDisplayString as g, mergeProps as y, normalizeStyle as p, createStaticVNode as b } from "vue";
|
|
2
|
+
import "./UpgradeToEnterpriseDialog.vue_vue_type_style_index_0_scoped_dda5adfc_lang-NXWdTcR2.js";
|
|
3
|
+
import { _ as L } from "./CustomIcon-B9m73Gqm.js";
|
|
4
|
+
const H = {
|
|
5
|
+
props: {
|
|
6
|
+
redLow: {
|
|
7
|
+
type: Number,
|
|
8
|
+
required: !0
|
|
9
|
+
},
|
|
10
|
+
yellowLow: {
|
|
11
|
+
type: Number,
|
|
12
|
+
required: !0
|
|
13
|
+
},
|
|
14
|
+
yellowHigh: {
|
|
15
|
+
type: Number,
|
|
16
|
+
required: !0
|
|
17
|
+
},
|
|
18
|
+
redHigh: {
|
|
19
|
+
type: Number,
|
|
20
|
+
required: !0
|
|
21
|
+
},
|
|
22
|
+
greenLow: {
|
|
23
|
+
type: Number,
|
|
24
|
+
default: null
|
|
25
|
+
},
|
|
26
|
+
greenHigh: {
|
|
27
|
+
type: Number,
|
|
28
|
+
default: null
|
|
29
|
+
},
|
|
30
|
+
value: {
|
|
31
|
+
type: Number,
|
|
32
|
+
default: null
|
|
33
|
+
},
|
|
34
|
+
width: {
|
|
35
|
+
type: Number,
|
|
36
|
+
default: 160
|
|
37
|
+
},
|
|
38
|
+
height: {
|
|
39
|
+
type: Number,
|
|
40
|
+
default: 22
|
|
41
|
+
},
|
|
42
|
+
// Optional pre-computed style overrides (used by BarColumn for MIN_VALUE/MAX_VALUE support)
|
|
43
|
+
computedStyle: {
|
|
44
|
+
type: Object,
|
|
45
|
+
default: null
|
|
46
|
+
},
|
|
47
|
+
// Hide the built-in tooltip (used when parent provides a TOOLTIP setting)
|
|
48
|
+
hideTooltip: {
|
|
49
|
+
type: Boolean,
|
|
50
|
+
default: !1
|
|
51
|
+
}
|
|
52
|
+
},
|
|
53
|
+
computed: {
|
|
54
|
+
hasGreenLimits() {
|
|
55
|
+
return this.greenLow !== null && this.greenHigh !== null;
|
|
56
|
+
},
|
|
57
|
+
limitsTooltip() {
|
|
58
|
+
return this.hasGreenLimits ? `RL/${this.redLow} YL/${this.yellowLow} YH/${this.yellowHigh} RH/${this.redHigh} GL/${this.greenLow} GH/${this.greenHigh}` : `RL/${this.redLow} YL/${this.yellowLow} YH/${this.yellowHigh} RH/${this.redHigh}`;
|
|
59
|
+
},
|
|
60
|
+
barStyle() {
|
|
61
|
+
if (this.computedStyle)
|
|
62
|
+
return this.computedStyle;
|
|
63
|
+
const o = 10, i = 10, t = (this.redHigh - this.redLow) / 80, d = Math.round((this.yellowLow - this.redLow) / t), l = Math.round(
|
|
64
|
+
(this.redHigh - this.yellowHigh) / t
|
|
65
|
+
);
|
|
66
|
+
let s, r, h;
|
|
67
|
+
this.hasGreenLimits ? (s = Math.round((this.greenLow - this.yellowLow) / t), r = Math.round((this.yellowHigh - this.greenHigh) / t), h = Math.round(
|
|
68
|
+
100 - o - d - s - r - l - i
|
|
69
|
+
)) : (s = Math.round(
|
|
70
|
+
100 - o - d - l - i
|
|
71
|
+
), r = 0, h = 0);
|
|
72
|
+
let a = 50;
|
|
73
|
+
if (this.value !== null && !isNaN(this.value)) {
|
|
74
|
+
const m = this.redLow - 10 * t;
|
|
75
|
+
a = Math.round((this.value - m) / t), a > 100 && (a = 100), a < 0 && (a = 0);
|
|
76
|
+
}
|
|
77
|
+
return {
|
|
78
|
+
"--width": this.width + "px",
|
|
79
|
+
"--height": this.height + "px",
|
|
80
|
+
"--container-height": this.height - 5 + "px",
|
|
81
|
+
"--redlow-width": o + "%",
|
|
82
|
+
"--redhigh-width": i + "%",
|
|
83
|
+
"--yellowlow-width": d + "%",
|
|
84
|
+
"--yellowhigh-width": l + "%",
|
|
85
|
+
"--greenlow-width": s + "%",
|
|
86
|
+
"--greenhigh-width": r + "%",
|
|
87
|
+
"--blue-width": h + "%",
|
|
88
|
+
"--position": a + "%"
|
|
89
|
+
};
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
};
|
|
93
|
+
function f(o, i, n, t, d, l) {
|
|
94
|
+
const s = v("v-tooltip");
|
|
95
|
+
return n.hideTooltip ? (u(), _("div", {
|
|
96
|
+
key: 1,
|
|
97
|
+
class: "limitsbar",
|
|
98
|
+
style: p(l.barStyle)
|
|
99
|
+
}, [...i[1] || (i[1] = [
|
|
100
|
+
b('<div class="limitsbar__container" data-v-2e81a9e5><div class="limitsbar__redlow" data-v-2e81a9e5></div><div class="limitsbar__redhigh" data-v-2e81a9e5></div><div class="limitsbar__yellowlow" data-v-2e81a9e5></div><div class="limitsbar__yellowhigh" data-v-2e81a9e5></div><div class="limitsbar__greenlow" data-v-2e81a9e5></div><div class="limitsbar__greenhigh" data-v-2e81a9e5></div><div class="limitsbar__blue" data-v-2e81a9e5></div><div class="limitsbar__line" data-v-2e81a9e5></div><div class="limitsbar__arrow" data-v-2e81a9e5></div></div>', 1)
|
|
101
|
+
])], 4)) : (u(), c(s, {
|
|
102
|
+
key: 0,
|
|
103
|
+
"open-delay": 600,
|
|
104
|
+
location: "top"
|
|
105
|
+
}, {
|
|
106
|
+
activator: w(({ props: r }) => [
|
|
107
|
+
e("div", y({
|
|
108
|
+
class: "limitsbar",
|
|
109
|
+
style: l.barStyle
|
|
110
|
+
}, r), [...i[0] || (i[0] = [
|
|
111
|
+
e("div", { class: "limitsbar__container" }, [
|
|
112
|
+
e("div", { class: "limitsbar__redlow" }),
|
|
113
|
+
e("div", { class: "limitsbar__redhigh" }),
|
|
114
|
+
e("div", { class: "limitsbar__yellowlow" }),
|
|
115
|
+
e("div", { class: "limitsbar__yellowhigh" }),
|
|
116
|
+
e("div", { class: "limitsbar__greenlow" }),
|
|
117
|
+
e("div", { class: "limitsbar__greenhigh" }),
|
|
118
|
+
e("div", { class: "limitsbar__blue" }),
|
|
119
|
+
e("div", { class: "limitsbar__line" }),
|
|
120
|
+
e("div", { class: "limitsbar__arrow" })
|
|
121
|
+
], -1)
|
|
122
|
+
])], 16)
|
|
123
|
+
]),
|
|
124
|
+
default: w(() => [
|
|
125
|
+
e("span", null, g(l.limitsTooltip), 1)
|
|
126
|
+
]),
|
|
127
|
+
_: 1
|
|
128
|
+
}));
|
|
129
|
+
}
|
|
130
|
+
const x = /* @__PURE__ */ L(H, [["render", f], ["__scopeId", "data-v-2e81a9e5"]]);
|
|
131
|
+
export {
|
|
132
|
+
x as L
|
|
133
|
+
};
|
|
134
|
+
//# sourceMappingURL=LimitsBar-IVv8t4FE.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LimitsBar-IVv8t4FE.js","sources":["../src/components/LimitsBar.vue"],"sourcesContent":["<!--\n# Copyright 2025 OpenC3, Inc.\n# All Rights Reserved.\n#\n# This program is free software; you can modify and/or redistribute it\n# under the terms of the GNU Affero General Public License\n# as published by the Free Software Foundation; version 3 with\n# attribution addendums as found in the LICENSE.txt\n#\n# This program is distributed in the hope that it will be useful,\n# but WITHOUT ANY WARRANTY; without even the implied warranty of\n# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n# GNU Affero General Public License for more details.\n\n# This file may also be used under the terms of a commercial license\n# if purchased from OpenC3, Inc.\n-->\n\n<template>\n <v-tooltip v-if=\"!hideTooltip\" :open-delay=\"600\" location=\"top\">\n <template #activator=\"{ props }\">\n <div class=\"limitsbar\" :style=\"barStyle\" v-bind=\"props\">\n <div class=\"limitsbar__container\">\n <div class=\"limitsbar__redlow\" />\n <div class=\"limitsbar__redhigh\" />\n <div class=\"limitsbar__yellowlow\" />\n <div class=\"limitsbar__yellowhigh\" />\n <div class=\"limitsbar__greenlow\" />\n <div class=\"limitsbar__greenhigh\" />\n <div class=\"limitsbar__blue\" />\n <div class=\"limitsbar__line\" />\n <div class=\"limitsbar__arrow\" />\n </div>\n </div>\n </template>\n <span>{{ limitsTooltip }}</span>\n </v-tooltip>\n <div v-else class=\"limitsbar\" :style=\"barStyle\">\n <div class=\"limitsbar__container\">\n <div class=\"limitsbar__redlow\" />\n <div class=\"limitsbar__redhigh\" />\n <div class=\"limitsbar__yellowlow\" />\n <div class=\"limitsbar__yellowhigh\" />\n <div class=\"limitsbar__greenlow\" />\n <div class=\"limitsbar__greenhigh\" />\n <div class=\"limitsbar__blue\" />\n <div class=\"limitsbar__line\" />\n <div class=\"limitsbar__arrow\" />\n </div>\n </div>\n</template>\n\n<script>\nexport default {\n props: {\n redLow: {\n type: Number,\n required: true,\n },\n yellowLow: {\n type: Number,\n required: true,\n },\n yellowHigh: {\n type: Number,\n required: true,\n },\n redHigh: {\n type: Number,\n required: true,\n },\n greenLow: {\n type: Number,\n default: null,\n },\n greenHigh: {\n type: Number,\n default: null,\n },\n value: {\n type: Number,\n default: null,\n },\n width: {\n type: Number,\n default: 160,\n },\n height: {\n type: Number,\n default: 22,\n },\n // Optional pre-computed style overrides (used by BarColumn for MIN_VALUE/MAX_VALUE support)\n computedStyle: {\n type: Object,\n default: null,\n },\n // Hide the built-in tooltip (used when parent provides a TOOLTIP setting)\n hideTooltip: {\n type: Boolean,\n default: false,\n },\n },\n computed: {\n hasGreenLimits() {\n return this.greenLow !== null && this.greenHigh !== null\n },\n limitsTooltip() {\n if (this.hasGreenLimits) {\n return `RL/${this.redLow} YL/${this.yellowLow} YH/${this.yellowHigh} RH/${this.redHigh} GL/${this.greenLow} GH/${this.greenHigh}`\n } else {\n return `RL/${this.redLow} YL/${this.yellowLow} YH/${this.yellowHigh} RH/${this.redHigh}`\n }\n },\n barStyle() {\n // If pre-computed style is provided, use it (for BarColumn MIN_VALUE/MAX_VALUE support)\n if (this.computedStyle) {\n return this.computedStyle\n }\n\n // Red zones take 10% each by default\n const redLowWidth = 10\n const redHighWidth = 10\n const divisor = 80 // 100 - 10 - 10\n const scale = (this.redHigh - this.redLow) / divisor\n\n const yellowLowWidth = Math.round((this.yellowLow - this.redLow) / scale)\n const yellowHighWidth = Math.round(\n (this.redHigh - this.yellowHigh) / scale,\n )\n\n let greenLowWidth, greenHighWidth, blueWidth\n if (this.hasGreenLimits) {\n greenLowWidth = Math.round((this.greenLow - this.yellowLow) / scale)\n greenHighWidth = Math.round((this.yellowHigh - this.greenHigh) / scale)\n blueWidth = Math.round(\n 100 -\n redLowWidth -\n yellowLowWidth -\n greenLowWidth -\n greenHighWidth -\n yellowHighWidth -\n redHighWidth,\n )\n } else {\n greenLowWidth = Math.round(\n 100 - redLowWidth - yellowLowWidth - yellowHighWidth - redHighWidth,\n )\n greenHighWidth = 0\n blueWidth = 0\n }\n\n // Calculate position for current value\n let position = 50 // default to middle\n if (this.value !== null && !isNaN(this.value)) {\n const lowValue = this.redLow - 10 * scale\n position = Math.round((this.value - lowValue) / scale)\n if (position > 100) position = 100\n if (position < 0) position = 0\n }\n\n return {\n '--width': this.width + 'px',\n '--height': this.height + 'px',\n '--container-height': this.height - 5 + 'px',\n '--redlow-width': redLowWidth + '%',\n '--redhigh-width': redHighWidth + '%',\n '--yellowlow-width': yellowLowWidth + '%',\n '--yellowhigh-width': yellowHighWidth + '%',\n '--greenlow-width': greenLowWidth + '%',\n '--greenhigh-width': greenHighWidth + '%',\n '--blue-width': blueWidth + '%',\n '--position': position + '%',\n }\n },\n },\n}\n</script>\n\n<style lang=\"scss\" scoped>\n.limitsbar {\n cursor: default;\n display: flex;\n justify-content: center;\n align-items: center;\n margin-top: 6px;\n padding: 5px;\n width: var(--width);\n}\n.limitsbar__container {\n position: relative;\n flex: 1;\n height: var(--container-height);\n border: 1px solid black;\n background-color: white;\n}\n/* The background-colors match the values in LimitscolorWidget.vue */\n.limitsbar__redlow {\n position: absolute;\n top: -1px;\n left: 0px;\n width: var(--redlow-width);\n height: var(--container-height);\n background-color: rgb(255, 45, 45);\n}\n.limitsbar__redhigh {\n position: absolute;\n top: -1px;\n right: 0px;\n width: var(--redhigh-width);\n height: var(--container-height);\n background-color: rgb(255, 45, 45);\n}\n.limitsbar__yellowlow {\n position: absolute;\n top: -1px;\n left: var(--redlow-width);\n width: var(--yellowlow-width);\n height: var(--container-height);\n background-color: rgb(255, 220, 0);\n}\n.limitsbar__yellowhigh {\n position: absolute;\n top: -1px;\n right: var(--redhigh-width);\n width: var(--yellowhigh-width);\n height: var(--container-height);\n background-color: rgb(255, 220, 0);\n}\n.limitsbar__greenlow {\n position: absolute;\n top: -1px;\n left: calc(var(--redlow-width) + var(--yellowlow-width));\n width: var(--greenlow-width);\n height: var(--container-height);\n background-color: rgb(0, 200, 0);\n}\n.limitsbar__greenhigh {\n position: absolute;\n top: -1px;\n right: calc(var(--redhigh-width) + var(--yellowhigh-width));\n width: var(--greenhigh-width);\n height: var(--container-height);\n background-color: rgb(0, 200, 0);\n}\n.limitsbar__blue {\n position: absolute;\n top: -1px;\n left: calc(\n var(--redlow-width) + var(--yellowlow-width) + var(--greenlow-width)\n );\n width: var(--blue-width);\n height: var(--container-height);\n background-color: rgb(0, 153, 255);\n}\n.limitsbar__line {\n position: absolute;\n left: var(--position);\n width: 1px;\n height: var(--container-height);\n background-color: rgb(128, 128, 128);\n}\n$arrow-size: 5px;\n.limitsbar__arrow {\n position: absolute;\n top: -$arrow-size;\n left: var(--position);\n width: 0;\n height: 0;\n transform: translateX(-$arrow-size); // Transform so it sits over the line\n border-left: $arrow-size solid transparent;\n border-right: $arrow-size solid transparent;\n border-top: $arrow-size solid rgb(128, 128, 128);\n}\n</style>\n"],"names":["_sfc_main","redLowWidth","redHighWidth","scale","yellowLowWidth","yellowHighWidth","greenLowWidth","greenHighWidth","blueWidth","position","lowValue","$props","_createElementBlock","$options","_createBlock","_component_v_tooltip","_withCtx","props","_createElementVNode","_mergeProps","_cache"],"mappings":"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"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";const e=require("vue");require("./UpgradeToEnterpriseDialog.vue_vue_type_style_index_0_scoped_dda5adfc_lang-Bjn8x8eE.cjs");const u=require("./CustomIcon-CEc927h0.cjs"),m={props:{redLow:{type:Number,required:!0},yellowLow:{type:Number,required:!0},yellowHigh:{type:Number,required:!0},redHigh:{type:Number,required:!0},greenLow:{type:Number,default:null},greenHigh:{type:Number,default:null},value:{type:Number,default:null},width:{type:Number,default:160},height:{type:Number,default:22},computedStyle:{type:Object,default:null},hideTooltip:{type:Boolean,default:!1}},computed:{hasGreenLimits(){return this.greenLow!==null&&this.greenHigh!==null},limitsTooltip(){return this.hasGreenLimits?`RL/${this.redLow} YL/${this.yellowLow} YH/${this.yellowHigh} RH/${this.redHigh} GL/${this.greenLow} GH/${this.greenHigh}`:`RL/${this.redLow} YL/${this.yellowLow} YH/${this.yellowHigh} RH/${this.redHigh}`},barStyle(){if(this.computedStyle)return this.computedStyle;const o=10,t=10,i=(this.redHigh-this.redLow)/80,d=Math.round((this.yellowLow-this.redLow)/i),l=Math.round((this.redHigh-this.yellowHigh)/i);let r,s,h;this.hasGreenLimits?(r=Math.round((this.greenLow-this.yellowLow)/i),s=Math.round((this.yellowHigh-this.greenHigh)/i),h=Math.round(100-o-d-r-s-l-t)):(r=Math.round(100-o-d-l-t),s=0,h=0);let a=50;if(this.value!==null&&!isNaN(this.value)){const c=this.redLow-10*i;a=Math.round((this.value-c)/i),a>100&&(a=100),a<0&&(a=0)}return{"--width":this.width+"px","--height":this.height+"px","--container-height":this.height-5+"px","--redlow-width":o+"%","--redhigh-width":t+"%","--yellowlow-width":d+"%","--yellowhigh-width":l+"%","--greenlow-width":r+"%","--greenhigh-width":s+"%","--blue-width":h+"%","--position":a+"%"}}}};function w(o,t,n,i,d,l){const r=e.resolveComponent("v-tooltip");return n.hideTooltip?(e.openBlock(),e.createElementBlock("div",{key:1,class:"limitsbar",style:e.normalizeStyle(l.barStyle)},[...t[1]||(t[1]=[e.createStaticVNode('<div class="limitsbar__container" data-v-2e81a9e5><div class="limitsbar__redlow" data-v-2e81a9e5></div><div class="limitsbar__redhigh" data-v-2e81a9e5></div><div class="limitsbar__yellowlow" data-v-2e81a9e5></div><div class="limitsbar__yellowhigh" data-v-2e81a9e5></div><div class="limitsbar__greenlow" data-v-2e81a9e5></div><div class="limitsbar__greenhigh" data-v-2e81a9e5></div><div class="limitsbar__blue" data-v-2e81a9e5></div><div class="limitsbar__line" data-v-2e81a9e5></div><div class="limitsbar__arrow" data-v-2e81a9e5></div></div>',1)])],4)):(e.openBlock(),e.createBlock(r,{key:0,"open-delay":600,location:"top"},{activator:e.withCtx(({props:s})=>[e.createElementVNode("div",e.mergeProps({class:"limitsbar",style:l.barStyle},s),[...t[0]||(t[0]=[e.createElementVNode("div",{class:"limitsbar__container"},[e.createElementVNode("div",{class:"limitsbar__redlow"}),e.createElementVNode("div",{class:"limitsbar__redhigh"}),e.createElementVNode("div",{class:"limitsbar__yellowlow"}),e.createElementVNode("div",{class:"limitsbar__yellowhigh"}),e.createElementVNode("div",{class:"limitsbar__greenlow"}),e.createElementVNode("div",{class:"limitsbar__greenhigh"}),e.createElementVNode("div",{class:"limitsbar__blue"}),e.createElementVNode("div",{class:"limitsbar__line"}),e.createElementVNode("div",{class:"limitsbar__arrow"})],-1)])],16)]),default:e.withCtx(()=>[e.createElementVNode("span",null,e.toDisplayString(l.limitsTooltip),1)]),_:1}))}const v=u._export_sfc(m,[["render",w],["__scopeId","data-v-2e81a9e5"]]);exports.LimitsBar=v;
|
|
2
|
+
//# sourceMappingURL=LimitsBar-LRiUSWd7.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LimitsBar-LRiUSWd7.cjs","sources":["../src/components/LimitsBar.vue"],"sourcesContent":["<!--\n# Copyright 2025 OpenC3, Inc.\n# All Rights Reserved.\n#\n# This program is free software; you can modify and/or redistribute it\n# under the terms of the GNU Affero General Public License\n# as published by the Free Software Foundation; version 3 with\n# attribution addendums as found in the LICENSE.txt\n#\n# This program is distributed in the hope that it will be useful,\n# but WITHOUT ANY WARRANTY; without even the implied warranty of\n# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n# GNU Affero General Public License for more details.\n\n# This file may also be used under the terms of a commercial license\n# if purchased from OpenC3, Inc.\n-->\n\n<template>\n <v-tooltip v-if=\"!hideTooltip\" :open-delay=\"600\" location=\"top\">\n <template #activator=\"{ props }\">\n <div class=\"limitsbar\" :style=\"barStyle\" v-bind=\"props\">\n <div class=\"limitsbar__container\">\n <div class=\"limitsbar__redlow\" />\n <div class=\"limitsbar__redhigh\" />\n <div class=\"limitsbar__yellowlow\" />\n <div class=\"limitsbar__yellowhigh\" />\n <div class=\"limitsbar__greenlow\" />\n <div class=\"limitsbar__greenhigh\" />\n <div class=\"limitsbar__blue\" />\n <div class=\"limitsbar__line\" />\n <div class=\"limitsbar__arrow\" />\n </div>\n </div>\n </template>\n <span>{{ limitsTooltip }}</span>\n </v-tooltip>\n <div v-else class=\"limitsbar\" :style=\"barStyle\">\n <div class=\"limitsbar__container\">\n <div class=\"limitsbar__redlow\" />\n <div class=\"limitsbar__redhigh\" />\n <div class=\"limitsbar__yellowlow\" />\n <div class=\"limitsbar__yellowhigh\" />\n <div class=\"limitsbar__greenlow\" />\n <div class=\"limitsbar__greenhigh\" />\n <div class=\"limitsbar__blue\" />\n <div class=\"limitsbar__line\" />\n <div class=\"limitsbar__arrow\" />\n </div>\n </div>\n</template>\n\n<script>\nexport default {\n props: {\n redLow: {\n type: Number,\n required: true,\n },\n yellowLow: {\n type: Number,\n required: true,\n },\n yellowHigh: {\n type: Number,\n required: true,\n },\n redHigh: {\n type: Number,\n required: true,\n },\n greenLow: {\n type: Number,\n default: null,\n },\n greenHigh: {\n type: Number,\n default: null,\n },\n value: {\n type: Number,\n default: null,\n },\n width: {\n type: Number,\n default: 160,\n },\n height: {\n type: Number,\n default: 22,\n },\n // Optional pre-computed style overrides (used by BarColumn for MIN_VALUE/MAX_VALUE support)\n computedStyle: {\n type: Object,\n default: null,\n },\n // Hide the built-in tooltip (used when parent provides a TOOLTIP setting)\n hideTooltip: {\n type: Boolean,\n default: false,\n },\n },\n computed: {\n hasGreenLimits() {\n return this.greenLow !== null && this.greenHigh !== null\n },\n limitsTooltip() {\n if (this.hasGreenLimits) {\n return `RL/${this.redLow} YL/${this.yellowLow} YH/${this.yellowHigh} RH/${this.redHigh} GL/${this.greenLow} GH/${this.greenHigh}`\n } else {\n return `RL/${this.redLow} YL/${this.yellowLow} YH/${this.yellowHigh} RH/${this.redHigh}`\n }\n },\n barStyle() {\n // If pre-computed style is provided, use it (for BarColumn MIN_VALUE/MAX_VALUE support)\n if (this.computedStyle) {\n return this.computedStyle\n }\n\n // Red zones take 10% each by default\n const redLowWidth = 10\n const redHighWidth = 10\n const divisor = 80 // 100 - 10 - 10\n const scale = (this.redHigh - this.redLow) / divisor\n\n const yellowLowWidth = Math.round((this.yellowLow - this.redLow) / scale)\n const yellowHighWidth = Math.round(\n (this.redHigh - this.yellowHigh) / scale,\n )\n\n let greenLowWidth, greenHighWidth, blueWidth\n if (this.hasGreenLimits) {\n greenLowWidth = Math.round((this.greenLow - this.yellowLow) / scale)\n greenHighWidth = Math.round((this.yellowHigh - this.greenHigh) / scale)\n blueWidth = Math.round(\n 100 -\n redLowWidth -\n yellowLowWidth -\n greenLowWidth -\n greenHighWidth -\n yellowHighWidth -\n redHighWidth,\n )\n } else {\n greenLowWidth = Math.round(\n 100 - redLowWidth - yellowLowWidth - yellowHighWidth - redHighWidth,\n )\n greenHighWidth = 0\n blueWidth = 0\n }\n\n // Calculate position for current value\n let position = 50 // default to middle\n if (this.value !== null && !isNaN(this.value)) {\n const lowValue = this.redLow - 10 * scale\n position = Math.round((this.value - lowValue) / scale)\n if (position > 100) position = 100\n if (position < 0) position = 0\n }\n\n return {\n '--width': this.width + 'px',\n '--height': this.height + 'px',\n '--container-height': this.height - 5 + 'px',\n '--redlow-width': redLowWidth + '%',\n '--redhigh-width': redHighWidth + '%',\n '--yellowlow-width': yellowLowWidth + '%',\n '--yellowhigh-width': yellowHighWidth + '%',\n '--greenlow-width': greenLowWidth + '%',\n '--greenhigh-width': greenHighWidth + '%',\n '--blue-width': blueWidth + '%',\n '--position': position + '%',\n }\n },\n },\n}\n</script>\n\n<style lang=\"scss\" scoped>\n.limitsbar {\n cursor: default;\n display: flex;\n justify-content: center;\n align-items: center;\n margin-top: 6px;\n padding: 5px;\n width: var(--width);\n}\n.limitsbar__container {\n position: relative;\n flex: 1;\n height: var(--container-height);\n border: 1px solid black;\n background-color: white;\n}\n/* The background-colors match the values in LimitscolorWidget.vue */\n.limitsbar__redlow {\n position: absolute;\n top: -1px;\n left: 0px;\n width: var(--redlow-width);\n height: var(--container-height);\n background-color: rgb(255, 45, 45);\n}\n.limitsbar__redhigh {\n position: absolute;\n top: -1px;\n right: 0px;\n width: var(--redhigh-width);\n height: var(--container-height);\n background-color: rgb(255, 45, 45);\n}\n.limitsbar__yellowlow {\n position: absolute;\n top: -1px;\n left: var(--redlow-width);\n width: var(--yellowlow-width);\n height: var(--container-height);\n background-color: rgb(255, 220, 0);\n}\n.limitsbar__yellowhigh {\n position: absolute;\n top: -1px;\n right: var(--redhigh-width);\n width: var(--yellowhigh-width);\n height: var(--container-height);\n background-color: rgb(255, 220, 0);\n}\n.limitsbar__greenlow {\n position: absolute;\n top: -1px;\n left: calc(var(--redlow-width) + var(--yellowlow-width));\n width: var(--greenlow-width);\n height: var(--container-height);\n background-color: rgb(0, 200, 0);\n}\n.limitsbar__greenhigh {\n position: absolute;\n top: -1px;\n right: calc(var(--redhigh-width) + var(--yellowhigh-width));\n width: var(--greenhigh-width);\n height: var(--container-height);\n background-color: rgb(0, 200, 0);\n}\n.limitsbar__blue {\n position: absolute;\n top: -1px;\n left: calc(\n var(--redlow-width) + var(--yellowlow-width) + var(--greenlow-width)\n );\n width: var(--blue-width);\n height: var(--container-height);\n background-color: rgb(0, 153, 255);\n}\n.limitsbar__line {\n position: absolute;\n left: var(--position);\n width: 1px;\n height: var(--container-height);\n background-color: rgb(128, 128, 128);\n}\n$arrow-size: 5px;\n.limitsbar__arrow {\n position: absolute;\n top: -$arrow-size;\n left: var(--position);\n width: 0;\n height: 0;\n transform: translateX(-$arrow-size); // Transform so it sits over the line\n border-left: $arrow-size solid transparent;\n border-right: $arrow-size solid transparent;\n border-top: $arrow-size solid rgb(128, 128, 128);\n}\n</style>\n"],"names":["_sfc_main","redLowWidth","redHighWidth","scale","yellowLowWidth","yellowHighWidth","greenLowWidth","greenHighWidth","blueWidth","position","lowValue","$props","_createElementBlock","$options","_createBlock","_component_v_tooltip","_withCtx","props","_createElementVNode","_mergeProps","_cache"],"mappings":"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"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const l=require("./BarColumn-CWgcL5w1.cjs"),m=require("./LimitsBar-LRiUSWd7.cjs"),i=require("vue"),o=require("./CustomIcon-CEc927h0.cjs"),h={components:{LimitsBar:m.LimitsBar},mixins:[l.BarColumn],data(){return{width:160,height:22}},computed:{limits(){let t=this.limitsSettings[this.selectedLimitsSet];if(t)return t;throw{line:this.line,lineNumber:this.lineNumber,keyword:"LIMITSBAR",parameters:this.parameters,message:"Item has no limits settings",usage:"Only items with limits"}},mergedStyle(){return{...this.cssProps,...this.computedStyle}}},created(){this.verifyNumParams("LIMITSBAR",3,6,"LIMITSBAR <TARGET> <PACKET> <ITEM> <TYPE> <WIDTH> <HEIGHT>")}};function n(t,u,a,d,r,e){const s=i.resolveComponent("LimitsBar");return e.limits?(i.openBlock(),i.createBlock(s,{key:0,"red-low":e.limits[0],"yellow-low":e.limits[1],"yellow-high":e.limits[2],"red-high":e.limits[3],"green-low":e.limits[4],"green-high":e.limits[5],width:r.width,height:r.height,"computed-style":e.mergedStyle,"hide-tooltip":!!t.tooltipText},null,8,["red-low","yellow-low","yellow-high","red-high","green-low","green-high","width","height","computed-style","hide-tooltip"])):i.createCommentVNode("",!0)}const c=o._export_sfc(h,[["render",n]]);exports.default=c;
|
|
2
|
+
//# sourceMappingURL=LimitsbarWidget-BFjMhTbA.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LimitsbarWidget-BFjMhTbA.cjs","sources":["../src/widgets/LimitsbarWidget.vue"],"sourcesContent":["<!--\n# Copyright 2025 OpenC3, Inc.\n# All Rights Reserved.\n#\n# This program is free software; you can modify and/or redistribute it\n# under the terms of the GNU Affero General Public License\n# as published by the Free Software Foundation; version 3 with\n# attribution addendums as found in the LICENSE.txt\n#\n# This program is distributed in the hope that it will be useful,\n# but WITHOUT ANY WARRANTY; without even the implied warranty of\n# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n# GNU Affero General Public License for more details.\n\n# This file may also be used under the terms of a commercial license\n# if purchased from OpenC3, Inc.\n-->\n\n<template>\n <LimitsBar\n v-if=\"limits\"\n :red-low=\"limits[0]\"\n :yellow-low=\"limits[1]\"\n :yellow-high=\"limits[2]\"\n :red-high=\"limits[3]\"\n :green-low=\"limits[4]\"\n :green-high=\"limits[5]\"\n :width=\"width\"\n :height=\"height\"\n :computed-style=\"mergedStyle\"\n :hide-tooltip=\"!!tooltipText\"\n />\n</template>\n\n<script>\nimport BarColumn from './BarColumn'\nimport LimitsBar from '../components/LimitsBar.vue'\n\nexport default {\n components: {\n LimitsBar,\n },\n mixins: [BarColumn],\n data() {\n return {\n width: 160, // px\n height: 22, // px\n }\n },\n computed: {\n limits() {\n let values = this.limitsSettings[this.selectedLimitsSet]\n if (values) {\n return values\n } else {\n // See errorCaptured in Openc3Screen.vue for how this is parsed\n throw {\n line: this.line,\n lineNumber: this.lineNumber,\n keyword: 'LIMITSBAR',\n parameters: this.parameters,\n message: 'Item has no limits settings',\n usage: 'Only items with limits',\n }\n }\n },\n mergedStyle() {\n // Merge cssProps from BarColumn with computedStyle from Widget\n return { ...this.cssProps, ...this.computedStyle }\n },\n },\n created() {\n this.verifyNumParams(\n 'LIMITSBAR',\n 3,\n 6,\n 'LIMITSBAR <TARGET> <PACKET> <ITEM> <TYPE> <WIDTH> <HEIGHT>',\n )\n },\n}\n</script>\n"],"names":["_sfc_main","LimitsBar","BarColumn","values","$options","_createBlock","_component_LimitsBar","$data","_ctx"],"mappings":"0NAsCKA,EAAU,CACb,WAAY,CACV,UAAAC,EAAAA,WAEF,OAAQ,CAACC,EAAAA,SAAS,EAClB,MAAO,CACL,MAAO,CACL,MAAO,IACP,OAAQ,EACV,CACF,EACA,SAAU,CACR,QAAS,CACP,IAAIC,EAAS,KAAK,eAAe,KAAK,iBAAiB,EACvD,GAAIA,EACF,OAAOA,EAGP,KAAM,CACJ,KAAM,KAAK,KACX,WAAY,KAAK,WACjB,QAAS,YACT,WAAY,KAAK,WACjB,QAAS,8BACT,MAAO,wBACT,CAEJ,EACA,aAAc,CAEZ,MAAO,CAAE,GAAG,KAAK,SAAU,GAAG,KAAK,aAAY,CACjD,GAEF,SAAU,CACR,KAAK,gBACH,YACA,EACA,EACA,4DACF,CACF,CACF,yEA3DUC,EAAA,sBADRC,EAAAA,YAYEC,EAAA,OAVC,UAASF,EAAA,OAAM,CAAA,EACf,aAAYA,EAAA,OAAM,CAAA,EAClB,cAAaA,EAAA,OAAM,CAAA,EACnB,WAAUA,EAAA,OAAM,CAAA,EAChB,YAAWA,EAAA,OAAM,CAAA,EACjB,aAAYA,EAAA,OAAM,CAAA,EAClB,MAAOG,EAAA,MACP,OAAQA,EAAA,OACR,iBAAgBH,EAAA,YAChB,iBAAgBI,EAAA"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { B as s } from "./BarColumn-DHHJBR3V.js";
|
|
2
|
+
import { L as l } from "./LimitsBar-IVv8t4FE.js";
|
|
3
|
+
import { resolveComponent as m, createBlock as h, createCommentVNode as o, openBlock as n } from "vue";
|
|
4
|
+
import { _ as a } from "./CustomIcon-B9m73Gqm.js";
|
|
5
|
+
const d = {
|
|
6
|
+
components: {
|
|
7
|
+
LimitsBar: l
|
|
8
|
+
},
|
|
9
|
+
mixins: [s],
|
|
10
|
+
data() {
|
|
11
|
+
return {
|
|
12
|
+
width: 160,
|
|
13
|
+
// px
|
|
14
|
+
height: 22
|
|
15
|
+
// px
|
|
16
|
+
};
|
|
17
|
+
},
|
|
18
|
+
computed: {
|
|
19
|
+
limits() {
|
|
20
|
+
let t = this.limitsSettings[this.selectedLimitsSet];
|
|
21
|
+
if (t)
|
|
22
|
+
return t;
|
|
23
|
+
throw {
|
|
24
|
+
line: this.line,
|
|
25
|
+
lineNumber: this.lineNumber,
|
|
26
|
+
keyword: "LIMITSBAR",
|
|
27
|
+
parameters: this.parameters,
|
|
28
|
+
message: "Item has no limits settings",
|
|
29
|
+
usage: "Only items with limits"
|
|
30
|
+
};
|
|
31
|
+
},
|
|
32
|
+
mergedStyle() {
|
|
33
|
+
return { ...this.cssProps, ...this.computedStyle };
|
|
34
|
+
}
|
|
35
|
+
},
|
|
36
|
+
created() {
|
|
37
|
+
this.verifyNumParams(
|
|
38
|
+
"LIMITSBAR",
|
|
39
|
+
3,
|
|
40
|
+
6,
|
|
41
|
+
"LIMITSBAR <TARGET> <PACKET> <ITEM> <TYPE> <WIDTH> <HEIGHT>"
|
|
42
|
+
);
|
|
43
|
+
}
|
|
44
|
+
};
|
|
45
|
+
function c(t, g, u, w, i, e) {
|
|
46
|
+
const r = m("LimitsBar");
|
|
47
|
+
return e.limits ? (n(), h(r, {
|
|
48
|
+
key: 0,
|
|
49
|
+
"red-low": e.limits[0],
|
|
50
|
+
"yellow-low": e.limits[1],
|
|
51
|
+
"yellow-high": e.limits[2],
|
|
52
|
+
"red-high": e.limits[3],
|
|
53
|
+
"green-low": e.limits[4],
|
|
54
|
+
"green-high": e.limits[5],
|
|
55
|
+
width: i.width,
|
|
56
|
+
height: i.height,
|
|
57
|
+
"computed-style": e.mergedStyle,
|
|
58
|
+
"hide-tooltip": !!t.tooltipText
|
|
59
|
+
}, null, 8, ["red-low", "yellow-low", "yellow-high", "red-high", "green-low", "green-high", "width", "height", "computed-style", "hide-tooltip"])) : o("", !0);
|
|
60
|
+
}
|
|
61
|
+
const B = /* @__PURE__ */ a(d, [["render", c]]);
|
|
62
|
+
export {
|
|
63
|
+
B as default
|
|
64
|
+
};
|
|
65
|
+
//# sourceMappingURL=LimitsbarWidget-Bo1JAoQp.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LimitsbarWidget-Bo1JAoQp.js","sources":["../src/widgets/LimitsbarWidget.vue"],"sourcesContent":["<!--\n# Copyright 2025 OpenC3, Inc.\n# All Rights Reserved.\n#\n# This program is free software; you can modify and/or redistribute it\n# under the terms of the GNU Affero General Public License\n# as published by the Free Software Foundation; version 3 with\n# attribution addendums as found in the LICENSE.txt\n#\n# This program is distributed in the hope that it will be useful,\n# but WITHOUT ANY WARRANTY; without even the implied warranty of\n# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n# GNU Affero General Public License for more details.\n\n# This file may also be used under the terms of a commercial license\n# if purchased from OpenC3, Inc.\n-->\n\n<template>\n <LimitsBar\n v-if=\"limits\"\n :red-low=\"limits[0]\"\n :yellow-low=\"limits[1]\"\n :yellow-high=\"limits[2]\"\n :red-high=\"limits[3]\"\n :green-low=\"limits[4]\"\n :green-high=\"limits[5]\"\n :width=\"width\"\n :height=\"height\"\n :computed-style=\"mergedStyle\"\n :hide-tooltip=\"!!tooltipText\"\n />\n</template>\n\n<script>\nimport BarColumn from './BarColumn'\nimport LimitsBar from '../components/LimitsBar.vue'\n\nexport default {\n components: {\n LimitsBar,\n },\n mixins: [BarColumn],\n data() {\n return {\n width: 160, // px\n height: 22, // px\n }\n },\n computed: {\n limits() {\n let values = this.limitsSettings[this.selectedLimitsSet]\n if (values) {\n return values\n } else {\n // See errorCaptured in Openc3Screen.vue for how this is parsed\n throw {\n line: this.line,\n lineNumber: this.lineNumber,\n keyword: 'LIMITSBAR',\n parameters: this.parameters,\n message: 'Item has no limits settings',\n usage: 'Only items with limits',\n }\n }\n },\n mergedStyle() {\n // Merge cssProps from BarColumn with computedStyle from Widget\n return { ...this.cssProps, ...this.computedStyle }\n },\n },\n created() {\n this.verifyNumParams(\n 'LIMITSBAR',\n 3,\n 6,\n 'LIMITSBAR <TARGET> <PACKET> <ITEM> <TYPE> <WIDTH> <HEIGHT>',\n )\n },\n}\n</script>\n"],"names":["_sfc_main","LimitsBar","BarColumn","values","$options","_createBlock","_component_LimitsBar","$data","_ctx"],"mappings":";;;;AAsCA,MAAKA,IAAU;AAAA,EACb,YAAY;AAAA,IACV,WAAAC;AAAA;EAEF,QAAQ,CAACC,CAAS;AAAA,EAClB,OAAO;AACL,WAAO;AAAA,MACL,OAAO;AAAA;AAAA,MACP,QAAQ;AAAA;AAAA,IACV;AAAA,EACF;AAAA,EACA,UAAU;AAAA,IACR,SAAS;AACP,UAAIC,IAAS,KAAK,eAAe,KAAK,iBAAiB;AACvD,UAAIA;AACF,eAAOA;AAGP,YAAM;AAAA,QACJ,MAAM,KAAK;AAAA,QACX,YAAY,KAAK;AAAA,QACjB,SAAS;AAAA,QACT,YAAY,KAAK;AAAA,QACjB,SAAS;AAAA,QACT,OAAO;AAAA,MACT;AAAA,IAEJ;AAAA,IACA,cAAc;AAEZ,aAAO,EAAE,GAAG,KAAK,UAAU,GAAG,KAAK,cAAY;AAAA,IACjD;AAAA;EAEF,UAAU;AACR,SAAK;AAAA,MACH;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IACF;AAAA,EACF;AACF;;;SA3DUC,EAAA,eADRC,EAYEC,GAAA;AAAA;IAVC,WAASF,EAAA,OAAM,CAAA;AAAA,IACf,cAAYA,EAAA,OAAM,CAAA;AAAA,IAClB,eAAaA,EAAA,OAAM,CAAA;AAAA,IACnB,YAAUA,EAAA,OAAM,CAAA;AAAA,IAChB,aAAWA,EAAA,OAAM,CAAA;AAAA,IACjB,cAAYA,EAAA,OAAM,CAAA;AAAA,IAClB,OAAOG,EAAA;AAAA,IACP,QAAQA,EAAA;AAAA,IACR,kBAAgBH,EAAA;AAAA,IAChB,kBAAgBI,EAAA;AAAA;;;"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const l=require("./VWidget-CbdjSkP3.cjs"),e=require("vue"),i=require("./CustomIcon-CEc927h0.cjs"),o={mixins:[l.VWidget],data(){return{radius:15,fullLabelDisplay:!1,displayLabel:!0}},computed:{labelName(){return this.fullLabelDisplay?[this.parameters[0]+" "+this.parameters[1]+" "+this.parameters[2]]:[this.parameters[2]]},cssProps(){return{"--height":this.radius+"px","--width":this.radius+"px"}},myComputedStyle(){const t={...this.computedStyle};return delete t.flex,t}},created(){this.parameters[4]&&(this.radius=parseInt(this.parameters[4])),this.parameters[5]&&(this.parameters[5].toLowerCase()==="true"?this.fullLabelDisplay=!0:this.parameters[5].toLowerCase()==="nil"?this.displayLabel=!1:this.parameters[5].toLowerCase()==="none"&&(this.displayLabel=!1))},methods:{getType(){let t="CONVERTED";return this.parameters[3]&&(t=this.parameters[3]),t}}};function n(t,m,d,u,r,s){const a=e.resolveComponent("label-widget");return e.openBlock(),e.createElementBlock("div",{ref:"container",class:"d-flex flex-row",style:e.normalizeStyle(s.myComputedStyle)},[e.createElementVNode("div",{class:e.normalizeClass(`led align-self-center ${t.limitsColor}`),style:e.normalizeStyle(s.cssProps)},null,6),r.displayLabel?(e.openBlock(),e.createBlock(a,{key:0,parameters:s.labelName,settings:t.appliedSettings,style:e.normalizeStyle(t.computedStyle),"widget-index":1},null,8,["parameters","settings","style"])):e.createCommentVNode("",!0)],4)}const p=i._export_sfc(o,[["render",n],["__scopeId","data-v-2908b131"]]);exports.default=p;
|
|
2
|
+
//# sourceMappingURL=LimitscolorWidget-D214kS86.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LimitscolorWidget-D214kS86.cjs","sources":["../src/widgets/LimitscolorWidget.vue"],"sourcesContent":["<!--\n# Copyright 2022 Ball Aerospace & Technologies Corp.\n# All Rights Reserved.\n#\n# This program is free software; you can modify and/or redistribute it\n# under the terms of the GNU Affero General Public License\n# as published by the Free Software Foundation; version 3 with\n# attribution addendums as found in the LICENSE.txt\n#\n# This program is distributed in the hope that it will be useful,\n# but WITHOUT ANY WARRANTY; without even the implied warranty of\n# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n# GNU Affero General Public License for more details.\n\n# Modified by OpenC3, Inc.\n# All changes Copyright 2025, OpenC3, Inc.\n# All Rights Reserved\n#\n# This file may also be used under the terms of a commercial license\n# if purchased from OpenC3, Inc.\n-->\n\n<template>\n <div ref=\"container\" class=\"d-flex flex-row\" :style=\"myComputedStyle\">\n <div\n :class=\"`led align-self-center ${limitsColor}`\"\n :style=\"cssProps\"\n ></div>\n <label-widget\n v-if=\"displayLabel\"\n :parameters=\"labelName\"\n :settings=\"appliedSettings\"\n :style=\"computedStyle\"\n :widget-index=\"1\"\n />\n </div>\n</template>\n\n<script>\nimport VWidget from './VWidget'\nexport default {\n mixins: [VWidget],\n data() {\n return {\n radius: 15,\n fullLabelDisplay: false,\n displayLabel: true,\n }\n },\n computed: {\n labelName() {\n // LabelWidget uses index 0 from the parameters prop\n // so create an array with the label text in the first position\n if (this.fullLabelDisplay) {\n return [\n this.parameters[0] +\n ' ' +\n this.parameters[1] +\n ' ' +\n this.parameters[2],\n ]\n } else {\n return [this.parameters[2]]\n }\n },\n cssProps() {\n return {\n '--height': this.radius + 'px',\n '--width': this.radius + 'px',\n }\n },\n myComputedStyle() {\n // Remove the flex property from the computedStyle object\n // because if they choose not to display the label\n // the flex property makes it difficult to line up a custom LABEL widget\n const style = { ...this.computedStyle }\n delete style.flex\n return style\n },\n },\n created() {\n if (this.parameters[4]) {\n this.radius = parseInt(this.parameters[4])\n }\n if (this.parameters[5]) {\n if (this.parameters[5].toLowerCase() === 'true') {\n this.fullLabelDisplay = true\n } else if (this.parameters[5].toLowerCase() === 'nil') {\n this.displayLabel = false\n } else if (this.parameters[5].toLowerCase() === 'none') {\n this.displayLabel = false\n }\n }\n },\n methods: {\n getType() {\n let type = 'CONVERTED'\n if (this.parameters[3]) {\n type = this.parameters[3]\n }\n return type\n },\n },\n}\n</script>\n\n<style scoped>\n.led {\n height: var(--height);\n width: var(--width);\n background-color: var(--color);\n border-radius: 50%;\n}\n/* The background-colors match the values in LimitsbarWidget.vue */\n.red {\n background-color: rgb(255, 45, 45);\n}\n.yellow {\n background-color: rgb(255, 220, 0);\n}\n.green {\n background-color: rgb(0, 200, 0);\n}\n.blue {\n background-color: rgb(0, 153, 255);\n}\n</style>\n"],"names":["_sfc_main","VWidget","style","type","_createElementBlock","$options","_createElementVNode","_ctx","$data","_createBlock","_component_label_widget"],"mappings":"kLAwCKA,EAAU,CACb,OAAQ,CAACC,EAAAA,OAAO,EAChB,MAAO,CACL,MAAO,CACL,OAAQ,GACR,iBAAkB,GAClB,aAAc,EAChB,CACF,EACA,SAAU,CACR,WAAY,CAGV,OAAI,KAAK,iBACA,CACL,KAAK,WAAW,CAAC,EACf,IACA,KAAK,WAAW,CAAC,EACjB,IACA,KAAK,WAAW,CAAC,CACrB,EAEO,CAAC,KAAK,WAAW,CAAC,CAAC,CAE9B,EACA,UAAW,CACT,MAAO,CACL,WAAY,KAAK,OAAS,KAC1B,UAAW,KAAK,OAAS,IAC3B,CACF,EACA,iBAAkB,CAIhB,MAAMC,EAAQ,CAAE,GAAG,KAAK,aAAY,EACpC,cAAOA,EAAM,KACNA,CACT,GAEF,SAAU,CACJ,KAAK,WAAW,CAAC,IACnB,KAAK,OAAS,SAAS,KAAK,WAAW,CAAC,CAAC,GAEvC,KAAK,WAAW,CAAC,IACf,KAAK,WAAW,CAAC,EAAE,YAAW,IAAO,OACvC,KAAK,iBAAmB,GACf,KAAK,WAAW,CAAC,EAAE,YAAW,IAAO,MAC9C,KAAK,aAAe,GACX,KAAK,WAAW,CAAC,EAAE,YAAW,IAAO,SAC9C,KAAK,aAAe,IAG1B,EACA,QAAS,CACP,SAAU,CACR,IAAIC,EAAO,YACX,OAAI,KAAK,WAAW,CAAC,IACnBA,EAAO,KAAK,WAAW,CAAC,GAEnBA,CACT,EAEJ,0FAhFEC,EAAAA,mBAYM,MAAA,CAZD,IAAI,YAAY,MAAM,kBAAmB,uBAAOC,EAAA,eAAe,IAClEC,EAAAA,mBAGO,MAAA,CAFJ,gDAAgCC,EAAA,WAAW,EAAA,EAC3C,uBAAOF,EAAA,QAAQ,WAGVG,EAAA,4BADRC,EAAAA,YAMEC,EAAA,OAJC,WAAYL,EAAA,UACZ,SAAUE,EAAA,gBACV,uBAAOA,EAAA,aAAa,EACpB,eAAc"}
|