@configura/web-ui 1.5.0 → 1.6.0-alpha.0

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.
Files changed (95) hide show
  1. package/.postcssrc.json +8 -8
  2. package/LICENSE +201 -201
  3. package/README.md +1 -1
  4. package/dist/components/CanvasWrapper.d.ts +9 -9
  5. package/dist/components/CanvasWrapper.js +8 -8
  6. package/dist/components/CfgPriceView.d.ts +6 -6
  7. package/dist/components/CfgPriceView.js +13 -13
  8. package/dist/components/ConfigurationActionsButtonRow.d.ts +11 -11
  9. package/dist/components/ConfigurationActionsButtonRow.js +13 -13
  10. package/dist/components/Configurator.d.ts +12 -12
  11. package/dist/components/Configurator.js +15 -15
  12. package/dist/components/ConfiguratorWrapper.d.ts +8 -8
  13. package/dist/components/ConfiguratorWrapper.js +5 -5
  14. package/dist/components/CurrencyPrice.d.ts +9 -9
  15. package/dist/components/CurrencyPrice.js +7 -7
  16. package/dist/components/ExpandableHeadingRow.d.ts +15 -15
  17. package/dist/components/ExpandableHeadingRow.js +21 -21
  18. package/dist/components/Loading.d.ts +13 -13
  19. package/dist/components/Loading.js +20 -20
  20. package/dist/components/ProductInformation.d.ts +13 -13
  21. package/dist/components/ProductInformation.js +14 -14
  22. package/dist/components/TaskListView.d.ts +8 -8
  23. package/dist/components/TaskListView.js +54 -54
  24. package/dist/components/TaskStartView.d.ts +12 -12
  25. package/dist/components/TaskStartView.js +22 -22
  26. package/dist/components/icons/Checkmark.d.ts +6 -6
  27. package/dist/components/icons/Checkmark.js +12 -12
  28. package/dist/components/icons/Chevron.d.ts +7 -7
  29. package/dist/components/icons/Chevron.js +18 -18
  30. package/dist/components/icons/CircleXmarkIcon.d.ts +3 -3
  31. package/dist/components/icons/CircleXmarkIcon.js +8 -8
  32. package/dist/components/icons/DownloadIcon.d.ts +3 -3
  33. package/dist/components/icons/DownloadIcon.js +8 -8
  34. package/dist/components/icons/ErrorIcon.d.ts +3 -3
  35. package/dist/components/icons/ErrorIcon.js +8 -8
  36. package/dist/components/productConfiguration/CfgAdditionalProductView.d.ts +3 -3
  37. package/dist/components/productConfiguration/CfgAdditionalProductView.js +38 -38
  38. package/dist/components/productConfiguration/CfgCheckboxView.d.ts +19 -19
  39. package/dist/components/productConfiguration/CfgCheckboxView.js +22 -22
  40. package/dist/components/productConfiguration/CfgCheckboxesView.d.ts +13 -13
  41. package/dist/components/productConfiguration/CfgCheckboxesView.js +19 -19
  42. package/dist/components/productConfiguration/CfgDropdownOptionView.d.ts +19 -19
  43. package/dist/components/productConfiguration/CfgDropdownOptionView.js +36 -36
  44. package/dist/components/productConfiguration/CfgDropdownView.d.ts +13 -13
  45. package/dist/components/productConfiguration/CfgDropdownView.js +21 -21
  46. package/dist/components/productConfiguration/CfgFeatureView.d.ts +29 -29
  47. package/dist/components/productConfiguration/CfgFeatureView.js +36 -36
  48. package/dist/components/productConfiguration/CfgGroupView.d.ts +4 -4
  49. package/dist/components/productConfiguration/CfgGroupView.js +7 -7
  50. package/dist/components/productConfiguration/CfgOptionFeaturesView.d.ts +6 -6
  51. package/dist/components/productConfiguration/CfgOptionFeaturesView.js +13 -13
  52. package/dist/components/productConfiguration/CfgOptionNumericView.d.ts +27 -27
  53. package/dist/components/productConfiguration/CfgOptionNumericView.js +119 -119
  54. package/dist/components/productConfiguration/CfgOptionPriceView.d.ts +9 -9
  55. package/dist/components/productConfiguration/CfgOptionPriceView.js +29 -29
  56. package/dist/components/productConfiguration/CfgProductConfigurationView.d.ts +18 -18
  57. package/dist/components/productConfiguration/CfgProductConfigurationView.js +46 -46
  58. package/dist/css/web-ui.css.map +1 -1
  59. package/dist/index.d.ts +22 -22
  60. package/dist/index.js +22 -22
  61. package/dist/scss/_button.scss +36 -36
  62. package/dist/scss/_configurator.scss +87 -87
  63. package/dist/scss/_expandable.scss +37 -37
  64. package/dist/scss/_feature-item.scss +137 -137
  65. package/dist/scss/_forms.scss +42 -42
  66. package/dist/scss/_hr.scss +16 -16
  67. package/dist/scss/_loading.scss +98 -98
  68. package/dist/scss/_mixins.scss +56 -56
  69. package/dist/scss/_option-tree.scss +29 -29
  70. package/dist/scss/_product-information.scss +49 -49
  71. package/dist/scss/_range-view.scss +39 -39
  72. package/dist/scss/_slider.scss +70 -70
  73. package/dist/scss/_tasks.scss +72 -72
  74. package/dist/scss/_themed.scss +147 -147
  75. package/dist/scss/_utilities.scss +21 -21
  76. package/dist/scss/_variables.scss +6 -6
  77. package/dist/scss/icons/_checkmark.scss +46 -46
  78. package/dist/scss/icons/_chevron.scss +62 -62
  79. package/dist/scss/icons/_circle-xmark-icon.scss +24 -24
  80. package/dist/scss/icons/_download-icon.scss +24 -24
  81. package/dist/scss/icons/_error-icon.scss +24 -24
  82. package/dist/scss/web-ui.scss +11 -11
  83. package/dist/useObservable.d.ts +4 -4
  84. package/dist/useObservable.js +18 -18
  85. package/dist/useRerender.d.ts +1 -1
  86. package/dist/useRerender.js +5 -5
  87. package/dist/useResize.d.ts +6 -6
  88. package/dist/useResize.js +47 -47
  89. package/dist/useSelected.d.ts +2 -2
  90. package/dist/useSelected.js +13 -13
  91. package/dist/useUniqueId.d.ts +1 -1
  92. package/dist/useUniqueId.js +7 -7
  93. package/dist/utilities.d.ts +5 -5
  94. package/dist/utilities.js +1 -1
  95. package/package.json +3 -3
@@ -1,46 +1,46 @@
1
- import { CfgProduct, CfgProductConfiguration } from "@configura/web-api";
2
- import React, { useEffect } from "react";
3
- import { useRerender } from "../../useRerender.js";
4
- import { CfgAdditionalProductView } from "./CfgAdditionalProductView.js";
5
- import { CfgFeatureViewMemo, forwardProps, } from "./CfgFeatureView.js";
6
- export var UpchargeDisplayMode;
7
- (function (UpchargeDisplayMode) {
8
- UpchargeDisplayMode[UpchargeDisplayMode["SelectionImpact"] = 0] = "SelectionImpact";
9
- UpchargeDisplayMode[UpchargeDisplayMode["None"] = 1] = "None";
10
- UpchargeDisplayMode[UpchargeDisplayMode["Price"] = 2] = "Price";
11
- })(UpchargeDisplayMode || (UpchargeDisplayMode = {}));
12
- export const CfgProductConfigurationView = React.memo((props) => {
13
- const { productOrConfiguration, permanentlyExpandedAdditionalProductLevels, additionalProductComponent, } = props;
14
- const configuration = productOrConfiguration instanceof CfgProduct
15
- ? productOrConfiguration.configuration
16
- : productOrConfiguration;
17
- const configurationVisible = productOrConfiguration instanceof CfgProductConfiguration || productOrConfiguration.visible;
18
- const features = configuration.features.reduce((agg, feature) => {
19
- // It is possible in Cat Creator to double add a Feature. This fills no known
20
- // purpose and React can not handle this, so we filter out the duplicates.
21
- const code = feature.code;
22
- if (agg.every((f) => f.code !== code)) {
23
- agg.push(feature);
24
- }
25
- return agg;
26
- }, []);
27
- const additionalProducts = productOrConfiguration instanceof CfgProduct
28
- ? productOrConfiguration.additionalProducts
29
- : undefined;
30
- const AdditionalProductComponent = additionalProductComponent || CfgAdditionalProductView;
31
- // Re-rendering is driven from the very top of the tree. However, when selecting an option
32
- // the change is not bubbled all the way to the top (and then down again) until after
33
- // validation has been done. This keeps the 3D-view from re-rendering until after validation
34
- // has been done. But it also makes the state of this GUI not update until after validate,
35
- // which does not look good. So we add this extra hook to make this rerender early.
36
- const rerender = useRerender();
37
- useEffect(() => {
38
- configuration.listenForChange(rerender);
39
- return () => {
40
- configuration.stopListenForChange(rerender);
41
- };
42
- }, [configuration, rerender]);
43
- return (React.createElement(React.Fragment, null,
44
- configurationVisible && (React.createElement("ul", { className: `cfgOptionTree cfgOptionTree--topLevel ${props.className || ""}`, style: props.style }, features.map((f) => (React.createElement(CfgFeatureViewMemo, Object.assign({ feature: f, key: f.key }, forwardProps(props))))))),
45
- additionalProducts !== undefined && (React.createElement("ul", { className: `cfgOptionTree cfgOptionTree--topLevel` }, additionalProducts.map((additionalProduct) => (React.createElement(AdditionalProductComponent, Object.assign({ key: additionalProduct.key }, forwardProps(props), { additionalProductComponent: AdditionalProductComponent, product: additionalProduct, permanentlyExpandedLevels: permanentlyExpandedAdditionalProductLevels !== null && permanentlyExpandedAdditionalProductLevels !== void 0 ? permanentlyExpandedAdditionalProductLevels : 0 }))))))));
46
- });
1
+ import { CfgProduct, CfgProductConfiguration } from "@configura/web-api";
2
+ import React, { useEffect } from "react";
3
+ import { useRerender } from "../../useRerender.js";
4
+ import { CfgAdditionalProductView } from "./CfgAdditionalProductView.js";
5
+ import { CfgFeatureViewMemo, forwardProps, } from "./CfgFeatureView.js";
6
+ export var UpchargeDisplayMode;
7
+ (function (UpchargeDisplayMode) {
8
+ UpchargeDisplayMode[UpchargeDisplayMode["SelectionImpact"] = 0] = "SelectionImpact";
9
+ UpchargeDisplayMode[UpchargeDisplayMode["None"] = 1] = "None";
10
+ UpchargeDisplayMode[UpchargeDisplayMode["Price"] = 2] = "Price";
11
+ })(UpchargeDisplayMode || (UpchargeDisplayMode = {}));
12
+ export const CfgProductConfigurationView = React.memo((props) => {
13
+ const { productOrConfiguration, permanentlyExpandedAdditionalProductLevels, additionalProductComponent, } = props;
14
+ const configuration = productOrConfiguration instanceof CfgProduct
15
+ ? productOrConfiguration.configuration
16
+ : productOrConfiguration;
17
+ const configurationVisible = productOrConfiguration instanceof CfgProductConfiguration || productOrConfiguration.visible;
18
+ const features = configuration.features.reduce((agg, feature) => {
19
+ // It is possible in Cat Creator to double add a Feature. This fills no known
20
+ // purpose and React can not handle this, so we filter out the duplicates.
21
+ const code = feature.code;
22
+ if (agg.every((f) => f.code !== code)) {
23
+ agg.push(feature);
24
+ }
25
+ return agg;
26
+ }, []);
27
+ const additionalProducts = productOrConfiguration instanceof CfgProduct
28
+ ? productOrConfiguration.additionalProducts
29
+ : undefined;
30
+ const AdditionalProductComponent = additionalProductComponent || CfgAdditionalProductView;
31
+ // Re-rendering is driven from the very top of the tree. However, when selecting an option
32
+ // the change is not bubbled all the way to the top (and then down again) until after
33
+ // validation has been done. This keeps the 3D-view from re-rendering until after validation
34
+ // has been done. But it also makes the state of this GUI not update until after validate,
35
+ // which does not look good. So we add this extra hook to make this rerender early.
36
+ const rerender = useRerender();
37
+ useEffect(() => {
38
+ configuration.listenForChange(rerender);
39
+ return () => {
40
+ configuration.stopListenForChange(rerender);
41
+ };
42
+ }, [configuration, rerender]);
43
+ return (React.createElement(React.Fragment, null,
44
+ configurationVisible && (React.createElement("ul", { className: `cfgOptionTree cfgOptionTree--topLevel ${props.className || ""}`, style: props.style }, features.map((f) => (React.createElement(CfgFeatureViewMemo, Object.assign({ feature: f, key: f.key }, forwardProps(props))))))),
45
+ additionalProducts !== undefined && (React.createElement("ul", { className: `cfgOptionTree cfgOptionTree--topLevel` }, additionalProducts.map((additionalProduct) => (React.createElement(AdditionalProductComponent, Object.assign({ key: additionalProduct.key }, forwardProps(props), { additionalProductComponent: AdditionalProductComponent, product: additionalProduct, permanentlyExpandedLevels: permanentlyExpandedAdditionalProductLevels !== null && permanentlyExpandedAdditionalProductLevels !== void 0 ? permanentlyExpandedAdditionalProductLevels : 0 }))))))));
46
+ });
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/scss/_utilities.scss","../../src/scss/web-ui.scss","../../src/scss/_themed.scss","../../src/scss/_button.scss","../../src/scss/_mixins.scss","../../src/scss/icons/_checkmark.scss","../../src/scss/icons/_chevron.scss","../../src/scss/icons/_circle-xmark-icon.scss","../../src/scss/_configurator.scss","../../src/scss/_variables.scss","../../src/scss/icons/_download-icon.scss","../../src/scss/_expandable.scss","../../src/scss/icons/_error-icon.scss","../../src/scss/_feature-item.scss","../../src/scss/_forms.scss","../../src/scss/_hr.scss","../../src/scss/_loading.scss","../../src/scss/_option-tree.scss","../../src/scss/_product-information.scss","../../src/scss/_range-view.scss","../../src/scss/_slider.scss","../../src/scss/_tasks.scss"],"names":[],"mappings":"AAIA,QACC,eCqBD,CDlBA,QACC,cCqBD,CDlBA,QACC,iBCqBD,CDlBA,iBACC,eAAA,CACA,sBAAA,CACA,kBCqBD,CC2DC,EACC,aDjDF,CE5BC,WCRA,qBAAA,CDRA,oBAAA,CACA,4BAAA,CACA,UD+FC,CC9FD,kBAAA,CACA,yBAAA,CACA,eAAA,CACA,eAAA,CACA,YAAA,CACA,iBFiDD,CGhDC,mCAEC,kBHiDF,CG1CC,aAVA,qBHuDD,CGtDC,qCAEC,kBHuDF,CExDC,iBCNA,4CHiED,CEjDC,cCZA,qBHiED,CGhEC,yCAEC,kBHiEF,CG1DC,gBAVA,qBHuED,CGtEC,2CAEC,kBHuEF,CE3DG,qCACC,eF6DJ,CIzFC,cDYA,qBAAA,CCNC,oBAAA,CACA,UAAA,CACA,WJ0FF,CGrFC,yCAEC,kBHsFF,CG/EC,gBAVA,qBH4FD,CG3FC,2CAEC,kBH4FF,CIjGE,yBACC,wBAAA,CACA,0BJmGH,CIhGE,oBACC,WH2FD,CG1FC,oBAAA,CACA,eAAA,CACA,0BAAA,CACA,mCJkGH,CI/FE,wBACC,WHmFD,CGlFC,yDJiGH,CI9FE,yBACC,WH8ED,CG7EC,0DJgGH,CI3FE,sBDDD,yBAAA,CAYA,kBH4FD,CIrGG,oDDJF,kBAAA,CAEA,YAAA,CACA,aAAA,CACA,YAAA,CACA,sBAAA,CACA,mBAAA,CACA,wBAAA,CAAA,gBAAA,CACA,WH6GD,CIjHG,8BDHF,sBAAA,CAYA,kBHwGD,CKtJC,YFYA,qBAAA,CENC,oBAAA,CACA,ULuJF,CGjJC,qCAEC,kBHkJF,CG3IC,cAVA,qBHwJD,CGvJC,uCAEC,kBHwJF,CK9JE,uBACC,wBLgKH,CK9JG,6BACC,0BLgKJ,CK7JG,2BACC,2BL+JJ,CK3JE,kBACC,oBAAA,CACA,eAAA,CACA,0BAAA,CACA,mCL6JH,CKxJG,6DACC,WL0JJ,CKxJG,+DACC,cL0JJ,CKrJG,4BACC,uBLuJJ,CKhJG,uDACC,wBLqJJ,CKlJG,2BACC,uBLoJJ,CMxMC,oBHYA,qBAAA,CGNC,oBAAA,CACA,UAAA,CACA,WNyMF,CGpMC,qDAEC,kBHqMF,CG9LC,sBAVA,qBH2MD,CG1MC,uDAEC,kBH2MF,CMhNE,oDAEC,cLmGiC,CKlGjC,oBAAA,CACA,qBAAA,CACA,gBNkNH,CO7NC,wBJQA,qBAAA,CINC,UN0G4C,CMzG5C,YAAA,CACA,WAAA,CACA,qBPgOF,CG5NC,6DAEC,kBH6NF,CGtNC,0BAVA,qBHmOD,CGlOC,+DAEC,kBHmOF,COvOE,0CAPD,wBAQE,kBP0OD,CACF,COxOE,sCACC,eAAA,CACA,eAAA,CACA,eP0OH,COxOG,qDACC,YP0OJ,COxOI,2DACC,UP0OL,COpOC,kBJlBA,qBAAA,CIoBC,iBAAA,CACA,YAAA,CACA,wBAAA,CAAA,gBAAA,CAEA,aAAA,CACA,ePsOF,CG9PC,iDAEC,kBH+PF,CGxPC,oBAVA,qBHqQD,CGpQC,mDAEC,kBHqQF,CO7OE,yBACC,YP+OH,CO5OE,0CAbD,kBAcE,WAAA,CACA,YP+OD,CACF,CO5OC,iBJrCA,qBAAA,CAgBA,iIAAA,CIwBC,cCnDa,CDoDb,UN2D4C,CM1D5C,WAAA,CAEA,WAAA,CACA,YAAA,CACA,qBAAA,CACA,YAAA,CACA,aP8OF,CG7RC,+CAEC,kBH8RF,CGvRC,mBAVA,qBHoSD,CGnSC,iDAEC,kBHoSF,COrPE,0CAbD,iBAcE,WAAA,CACA,YPwPD,CACF,COrPC,uBACC,gCAAA,CACA,yBAAA,CACA,iBPwPF,COtPE,gCACC,cPwPH,COpPC,qBACC,eAAA,CACA,eAAA,CACA,gCPuPF,CSxUC,iBNYA,qBAAA,CMNC,oBAAA,CACA,UAAA,CACA,WTyUF,CGpUC,+CAEC,kBHqUF,CG9TC,mBAVA,qBH2UD,CG1UC,iDAEC,kBH2UF,CShVE,8CAEC,cRqG6B,CQpG7B,oBAAA,CACA,qBAAA,CACA,gBTkVH,CUjWC,yBPYA,qBAAA,CAdA,uBAAA,CAAA,eAAA,CACA,mBAAA,CACA,iBAAA,CACA,aAAA,CACA,eAAA,CACA,WAAA,CACA,SAAA,CODC,mBAAA,CACA,YAAA,CACA,YAAA,CACA,SAAA,CACA,iBAAA,CACA,UV0WF,CGrWC,+DAEC,kBHsWF,CG/VC,2BAVA,qBH4WD,CG3WC,iEAEC,kBH4WF,CUjXE,qCACC,cVmXH,CUhXE,gCACC,kBAAA,CACA,YAAA,CACA,aAAA,CACA,eAAA,CACA,eAAA,CACA,0BVkXH,CU/WE,+BACC,kBAAA,CACA,YAAA,CACA,YAAA,CACA,sBAAA,CACA,eViXH,CW7YC,cRYA,qBAAA,CQNC,oBAAA,CACA,UAAA,CACA,WX8YF,CGzYC,yCAEC,kBH0YF,CGnYC,gBAVA,qBHgZD,CG/YC,2CAEC,kBHgZF,CWrZE,wCAEC,cVuG0B,CUtG1B,oBAAA,CACA,qBAAA,CACA,gBXuZH,CY1ZC,mBACC,kBAAA,CACA,oBAAA,CACA,UAAA,CACA,SZ6ZF,CY1ZC,yBACC,kBAAA,CACA,YAAA,CACA,cAAA,CACA,0BZ6ZF,CY1ZC,gBTdA,qBAAA,CSiBC,UZ6ZF,CG7aC,6CAEC,kBH8aF,CGvaC,kBAVA,qBHobD,CGnbC,+CAEC,kBHobF,CYpaE,0BTjCD,uBAAA,CAAA,eAAA,CACA,mBAAA,CACA,iBAAA,CACA,aAAA,CACA,eAAA,CACA,WAAA,CACA,SAAA,CS6BE,mBAAA,CACA,YAAA,CACA,YAAA,CACA,SAAA,CACA,iBAAA,CACA,UAAA,CACA,cZ4aH,CYzaE,0BACC,cZ2aH,CYxaE,6BACC,aAAA,CACA,SAAA,CACA,iBAAA,CACA,UZ0aH,CYvaE,uBTnBD,yBAAA,CAiBA,iBHqbD,CY/aE,iDTxBD,kBAAA,CAEA,YAAA,CACA,aAAA,CACA,YAAA,CACA,sBAAA,CACA,mBAAA,CACA,wBAAA,CAAA,gBAAA,CACA,WH2cD,CY3bE,0BTvBD,yBAAA,CAYA,kBHscD,CYrbE,uHTvDD,4CH+eD,CYnbE,4DTlCD,sBAAA,CAiBA,iBHgdD,CY5bE,2HTtCD,kBAAA,CAEA,YAAA,CACA,aAAA,CACA,YAAA,CACA,sBAAA,CACA,mBAAA,CACA,wBAAA,CAAA,gBAAA,CACA,WHseD,CYxcE,+DTrCD,sBAAA,CAYA,kBHieD,CYlcI,8FACC,eZucL,CYncG,yDACC,2BZqcJ,CYjcG,oFACC,mBZmcJ,CY9bC,0EAEC,aAAA,CACA,eZicF,CY9bC,4DAEC,eZicF,CY9bC,6BACC,eAAA,CACA,eAAA,CACA,UZicF,CY9bC,6CACC,YZicF,CYzbC,8CAJC,kBAAA,CACA,YZwcF,CYrcC,wBAGC,sBAAA,CACA,eZicF,CY/bE,gCACC,eAAA,CACA,eAAA,CACA,eAAA,CACA,SAAA,CACA,wBZicH,CarkBC,yBAEC,yBAAA,CACA,iBAAA,CACA,kBbwkBF,CarkBC,eAiBC,cAAA,CACA,iBbwjBF,CazkBE,sBACC,uBAAA,CAAA,eAAA,CACA,iBAAA,CACA,QAAA,CACA,UAAA,CAEA,4BAAA,CACA,mBAAA,CACA,iBAAA,CACA,mBAAA,CACA,cAAA,CACA,mBAAA,CACA,YAAA,CACA,Wb0kBH,CapkBE,qBACC,iBAAA,CACA,WAAA,CACA,OAAA,CACA,iBAAA,CACA,UAAA,CACA,SAAA,CACA,UAAA,CACA,wBZ4FqB,CY3FrB,0EAAA,CAAA,kEAAA,CACA,gBbskBH,CcjmBC,OXIA,qBAAA,CWXA,QAAA,CACA,gCAAA,CACA,SAAA,CACA,Qd6mBD,CGpmBC,2BAEC,kBHqmBF,CG9lBC,SAVA,qBH2mBD,CG1mBC,6BAEC,kBH2mBF,CehnBC,oBZEA,qBAAA,CYAC,kBAAA,CACA,YAAA,CACA,qBAAA,CACA,WAAA,CACA,sBAAA,CACA,UfmnBF,CGvnBC,qDAEC,kBHwnBF,CGjnBC,sBAVA,qBH8nBD,CG7nBC,uDAEC,kBH8nBF,CeznBC,mBZRA,qBAAA,CYWC,kBAAA,CACA,qBd2GA,Cc1GA,QAAA,CACA,YAAA,CACA,qBAAA,CACA,sBAAA,CACA,MAAA,CACA,iBAAA,CACA,OAAA,CACA,KAAA,CACA,Yf2nBF,CG/oBC,mDAEC,kBHgpBF,CGzoBC,qBAVA,qBHspBD,CGrpBC,qDAEC,kBHspBF,CeloBE,iCACC,4BAAA,CACA,mBfooBH,CeloBG,qDACC,qBAAA,CACA,kBAAA,CACA,qBdyFF,CcxFE,UAAA,CACA,iCfooBJ,CehoBE,+BACC,cAAA,CACA,YfkoBH,Ce9nBC,oBZ1CA,qBAAA,CAgBA,iIAAA,CY8BC,iBfgoBF,CG7qBC,qDAEC,kBH8qBF,CGvqBC,sBAVA,qBHorBD,CGnrBC,uDAEC,kBHorBF,CevoBE,0BACC,UdmED,CclEC,eAAA,CACA,eAAA,CACA,efyoBH,CeroBC,YZxDA,qBAAA,CY2DC,wCAAA,CACA,kBAAA,CAEA,iCduDA,CcvDA,wBduDA,CctDA,oBAAA,CACA,UAAA,CACA,SfuoBF,CGvsBC,qCAEC,kBHwsBF,CGjsBC,cAVA,qBH8sBD,CG7sBC,uCAEC,kBH8sBF,Ce9oBE,mBACC,iBAAA,CACA,UAAA,CACA,SfgpBH,CgB9tBC,ebQA,qBAAA,CaLC,eAAA,CACA,QAAA,CACA,ShBwuBF,CGpuBC,2CAEC,kBHquBF,CG9tBC,iBAVA,qBH2uBD,CG1uBC,6CAEC,kBH2uBF,CgB/uBE,yBACC,kBhBivBH,CgB9uBE,uBACC,iBhBgvBH,CgB7uBE,0BACC,iBhB+uBH,CiB9vBC,gBdOA,qBAAA,CcJC,UhB+HoC,CgB7HpC,YjB+vBF,CG5vBC,6CAEC,kBH6vBF,CGtvBC,kBAVA,qBHmwBD,CGlwBC,+CAEC,kBHmwBF,CiBtwBE,sBACC,aAAA,CACA,WAAA,CACA,ejBwwBH,CiBrwBE,uBACC,oBAAA,CACA,YAAA,CACA,qBAAA,CACA,aAAA,CACA,eAAA,CACA,oBAAA,CACA,WjBuwBH,CiBpwBE,sBACC,aAAA,CACA,eAAA,CACA,eAAA,CACA,gBAAA,CACA,QjBswBH,CiBnwBE,wBACC,eAAA,CACA,eAAA,CACA,gBAAA,CACA,QjBqwBH,CkB9yBE,sBACC,YAAA,CACA,kBlBizBH,CkB9yBE,4BACC,eAAA,CACA,WAAA,CACA,gBlBgzBH,CkB7yBE,0BACC,eAAA,CACA,gBlB+yBH,CkB5yBE,sCACC,eAAA,CACA,WlB8yBH,CkB3yBE,qBACC,YAAA,CACA,kBAAA,CAEA,cAAA,CACA,eAAA,CACA,alB4yBH,CkB1yBG,mCACC,mBAAA,CACA,YAAA,CACA,UlB4yBJ,CmBpzBC,WhBXA,qBAAA,CgBmBC,MAAA,CACA,QAAA,CACA,SAAA,CACA,gBA/Bc,CAgCd,sBAAA,CACA,YnBizBF,CGx0BC,mCAEC,kBHy0BF,CGl0BC,aAVA,qBH+0BD,CG90BC,qCAEC,kBH+0BF,CmBp0BE,4CAEC,uBnBq0BH,CmB3zBE,0CAhCD,qBAAA,CACA,WAAA,CACA,WANa,CAOb,enB81BD,CmB9zBE,6BAnCD,qBAAA,CACA,WAAA,CACA,WANa,CAOb,enBo2BD,CmBj0BE,sBAtCD,qBAAA,CACA,WAAA,CACA,WANa,CAOb,enB02BD,CmBn0BE,iCACC,iBAAA,CApCF,qBAAA,CACA,WAAA,CACA,WAZe,CAaf,YAbe,CAcf,iBAAA,CACA,elByHC,CkBxHD,mCnB02BD,CmBz0BE,6BAvCD,qBAAA,CACA,WAAA,CACA,WAZe,CAaf,YAbe,CAcf,iBAAA,CACA,elByHC,CkBxHD,mCnBm3BD,CmB/0BE,sBACC,YAAA,CA3CF,qBAAA,CACA,WAAA,CACA,WAZe,CAaf,YAbe,CAcf,iBAAA,CACA,elByHC,CkBxHD,mCnB63BD,CmBp1BE,wBACC,YnBs1BH,CoB94BE,gBACC,oBAAA,CACA,SAAA,CACA,cAAA,CACA,gCpBi5BH,CoB94BE,mBACC,uBAAA,CACA,iBAAA,CACA,YAAA,CACA,kBpBg5BH,CoB74BE,sBACC,yBAAA,CACA,iBAAA,CACA,WAtBa,CAuBb,YAvBa,CAwBb,apB+4BH,CoB74BG,0BACC,gBAAA,CACA,iBAAA,CACA,UAAA,CACA,SAAA,CACA,YAAA,CACA,apB+4BJ,CoB34BE,mBACC,aAAA,CACA,SAAA,CACA,UArCU,CAsCV,gBAAA,CACA,iBpB64BH,CoB34BG,oCACC,epB64BJ,CoBz4BE,qBACC,WAAA,CACA,epB24BH,CoBx4BE,oBjBpDD,aAAA,CiBuDE,SAtDU,CAuDV,UAvDU,CAwDV,apBg5BH,CoB74BE,0CjB/DD,uBAAA,CAAA,eAAA,CACA,mBAAA,CACA,iBAAA,CAEA,eAAA,CACA,WAAA,CACA,SAAA,CiBmDE,cpB+5BH,CoBz5BE,sBjB5DD,aAAA,CiB+DE,yBAAA,CACA,apBq5BH,CCt3BC,gBACC,aDy3BF,CEt8BC,yBCRA,qBAAA,CDRA,oBAAA,CACA,4BAAA,CACA,aD+FC,CC9FD,kBAAA,CACA,yBAAA,CACA,eAAA,CACA,eAAA,CACA,YAAA,CACA,iBF09BD,CGz9BC,+DAEC,kBH09BF,CGn9BC,2BAVA,qBHg+BD,CG/9BC,iEAEC,kBHg+BF,CEj+BC,+BCNA,+CH0+BD,CE19BC,4BCZA,qBHy+BD,CGx+BC,qEAEC,kBHy+BF,CGl+BC,8BAVA,qBH++BD,CG9+BC,uEAEC,kBH++BF,CEn+BG,mDACC,eFq+BJ,CIjgCC,4BDYA,qBAAA,CCNC,oBAAA,CACA,UAAA,CACA,WJigCF,CG5/BC,qEAEC,kBH6/BF,CGt/BC,8BAVA,qBHmgCD,CGlgCC,uEAEC,kBHmgCF,CIxgCE,uCACC,wBAAA,CACA,0BJ0gCH,CIvgCE,kCACC,WH2FD,CG1FC,oBAAA,CACA,eAAA,CACA,0BAAA,CACA,mCJygCH,CItgCE,sCACC,WHmFD,CGlFC,yDJwgCH,CIrgCE,uCACC,WH8ED,CG7EC,0DJugCH,CIlgCE,oCDDD,yBAAA,CAYA,kBHmgCD,CI5gCG,gFDJF,kBAAA,CAEA,YAAA,CACA,aAAA,CACA,YAAA,CACA,sBAAA,CACA,mBAAA,CACA,wBAAA,CAAA,gBAAA,CACA,WHohCD,CIxhCG,4CDHF,sBAAA,CAYA,kBH+gCD,CK7jCC,0BFYA,qBAAA,CENC,oBAAA,CACA,UL6jCF,CGvjCC,iEAEC,kBHwjCF,CGjjCC,4BAVA,qBH8jCD,CG7jCC,mEAEC,kBH8jCF,CKpkCE,qCACC,wBLskCH,CKpkCG,2CACC,0BLskCJ,CKnkCG,yCACC,2BLqkCJ,CKjkCE,gCACC,oBAAA,CACA,eAAA,CACA,0BAAA,CACA,mCLmkCH,CK9jCG,yFACC,WLgkCJ,CK9jCG,2FACC,cLgkCJ,CK3jCG,0CACC,uBL6jCJ,CKtjCG,mFACC,wBL2jCJ,CKxjCG,yCACC,uBL0jCJ,CM9mCC,kCHYA,qBAAA,CGNC,oBAAA,CACA,UAAA,CACA,WN8mCF,CGzmCC,iFAEC,kBH0mCF,CGnmCC,oCAVA,qBHgnCD,CG/mCC,mFAEC,kBHgnCF,CMrnCE,gFAEC,cLmGiC,CKlGjC,oBAAA,CACA,qBAAA,CACA,gBNunCH,COloCC,sCJQA,qBAAA,CINC,aN0G4C,CMzG5C,YAAA,CACA,WAAA,C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","file":"web-ui.css","sourcesContent":["/**\r\n * Web UI Utilities\r\n */\r\n\r\n.cfgMl1 {\r\n\tmargin-left: 1em;\r\n}\r\n\r\n.cfgMt1 {\r\n\tmargin-top: 1em;\r\n}\r\n\r\n.cfgMb1 {\r\n\tmargin-bottom: 1em;\r\n}\r\n\r\n.cfgTextOverflow {\r\n\toverflow: hidden;\r\n\ttext-overflow: ellipsis;\r\n\twhite-space: nowrap;\r\n}\r\n","/**\r\n* Web UI Styling\r\n*/\r\n\r\n@use \"themed\";\r\n\r\n@include themed.themed(themed.$lightTheme);\r\n\r\n.cfgDarkTheme {\r\n\t@include themed.themed(themed.$darkTheme);\r\n}\r\n","@use \"sass:map\";\r\n@use \"sass:color\";\r\n\r\n@use \"variables\" as v;\r\n\r\n// Components\r\n@use \"button\";\r\n@use \"forms\";\r\n\r\n@use \"configurator\";\r\n@use \"expandable\";\r\n@use \"feature-item\";\r\n@use \"hr\";\r\n@use \"loading\";\r\n@use \"option-tree\";\r\n@use \"product-information\";\r\n@use \"range-view\";\r\n@use \"slider\";\r\n@use \"tasks\";\r\n\r\n// Icons\r\n@use \"icons/checkmark\";\r\n@use \"icons/chevron\";\r\n@use \"icons/circle-xmark-icon\";\r\n@use \"icons/download-icon\";\r\n@use \"icons/error-icon\";\r\n\r\n// Utilities\r\n@use \"utilities\";\r\n\r\n/* Colors */\r\n\r\n$black: hsl(0, 0%, 0%) !default;\r\n$white: hsl(0, 0%, 100%) !default;\r\n$darkGrey: hsl(0, 0%, 15%) !default;\r\n\r\n/* Specific colors */\r\n\r\n$border: hsl(252, 5%, 79%) !default;\r\n$borderDark: hsl(0, 0%, 73%) !default;\r\n$icon: hsl(252, 5%, 50%) !default;\r\n$focusOutlineOuter: hsl(0, 0%, 13%) !default;\r\n$sliderTrack: #666 !default;\r\n$spinner2: hsla(0, 0%, 0%, 0.15);\r\n$grayText: hsl(0, 0%, 50%) !default;\r\n$text: hsl(0, 0%, 20%) !default;\r\n$link: hsl(209, 100%, 35%) !default;\r\n$error: hsl(10, 72%, 41%) !default;\r\n\r\n/* As convention we assume the default theme when naming colors,\r\n as attempts at generic naming often leads to confusion */\r\n$lightTheme: (\r\n\t\"black\": $black,\r\n\t\"border\": $border,\r\n\t\"borderDark\": $borderDark,\r\n\t\"checkButtonChecked\": $black,\r\n\t\"checkButtonUnchecked\": $border,\r\n\t\"chevronActive\": $black,\r\n\t\"chevronPassive\": $borderDark,\r\n\t\"divider\": $border,\r\n\t\"dividerDark\": $borderDark,\r\n\t\"error\": $error,\r\n\t\"focusOutlineInner\": $white,\r\n\t\"focusOutlineOuter\": $text,\r\n\t\"grayText\": $grayText,\r\n\t\"icon\": $icon,\r\n\t\"link\": $link,\r\n\t\"overlayBackground\": $white,\r\n\t\"sliderThumb\": $white,\r\n\t\"sliderThumbShadow\": $sliderTrack,\r\n\t\"sliderTrack\": $sliderTrack,\r\n\t\"spinner1\": $black,\r\n\t\"spinner2\": $spinner2,\r\n\t\"text\": $text,\r\n\t\"white\": $white,\r\n) !default;\r\n\r\n@function invertLightness($color) {\r\n\t@return color.change(\r\n\t\t$color,\r\n\t\t$lightness: 100 - color.lightness($color) * 0.8\r\n\t); // We scale with 80% to have a bit more contrast\r\n}\r\n\r\n@function invertLightnessList($list) {\r\n\t@each $key, $color in $list {\r\n\t\t$list: map.set($list, $key, invertLightness($color));\r\n\t}\r\n\t@return $list;\r\n}\r\n\r\n$darkTheme: invertLightnessList($lightTheme);\r\n\r\n$themes: (\r\n\t\"light\": $lightTheme,\r\n\t\"dark\": $darkTheme,\r\n);\r\n\r\n@mixin themed($ct, $baseFontSize: v.$baseFontSize, $overlayingZIndex: v.$overlayingZIndex) {\r\n\ta {\r\n\t\tcolor: map.get($ct, \"link\");\r\n\t}\r\n\r\n\t@include button.classes(\r\n\t\tmap.get($ct, \"text\"),\r\n\t\tmap.get($ct, \"borderDark\"),\r\n\t\tmap.get($ct, \"focusOutlineInner\"),\r\n\t\tmap.get($ct, \"focusOutlineOuter\")\r\n\t);\r\n\t@include checkmark.classes(\r\n\t\tmap.get($ct, \"checkButtonChecked\"),\r\n\t\tmap.get($ct, \"checkButtonUnchecked\")\r\n\t);\r\n\t@include chevron.classes(map.get($ct, \"chevronActive\"), map.get($ct, \"chevronPassive\"));\r\n\t@include circle-xmark-icon.classes(map.get($ct, \"icon\"));\r\n\t@include configurator.classes($baseFontSize, map.get($ct, \"text\"), map.get($ct, \"divider\"));\r\n\t@include download-icon.classes(map.get($ct, \"link\"));\r\n\t@include expandable.classes;\r\n\t@include error-icon.classes(map.get($ct, \"error\"));\r\n\t@include feature-item.classes(\r\n\t\tmap.get($ct, \"text\"),\r\n\t\tmap.get($ct, \"grayText\"),\r\n\t\tmap.get($ct, \"checkButtonUnchecked\"),\r\n\t\tmap.get($ct, \"checkButtonChecked\"),\r\n\t\tmap.get($ct, \"focusOutlineInner\"),\r\n\t\tmap.get($ct, \"focusOutlineOuter\"),\r\n\t\tmap.get($ct, \"dividerDark\")\r\n\t);\r\n\t@include forms.classes(map.get($ct, \"borderDark\"));\r\n\t@include hr.classes(map.get($ct, \"divider\"));\r\n\t@include loading.classes(\r\n\t\tmap.get($ct, \"black\"),\r\n\t\tmap.get($ct, \"spinner1\"),\r\n\t\tmap.get($ct, \"spinner2\"),\r\n\t\tmap.get($ct, \"overlayBackground\"),\r\n\t\t$overlayingZIndex\r\n\t);\r\n\t@include option-tree.classes;\r\n\t@include product-information.classes(map.get($ct, \"text\"));\r\n\t@include range-view.classes(map.get($ct, \"error\"));\r\n\t@include slider.classes(\r\n\t\tmap.get($ct, \"sliderTrack\"),\r\n\t\tmap.get($ct, \"sliderThumb\"),\r\n\t\tmap.get($ct, \"sliderThumbShadow\")\r\n\t);\r\n\t@include tasks.classes(map.get($ct, \"border\"), map.get($ct, \"link\"));\r\n}\r\n","/**\r\n * Web UI Product information\r\n */\r\n@use \"mixins\";\r\n\r\n@mixin styles($textColor, $borderColor, $focusOutlineInnerColor, $focusOutlineOuterColor) {\r\n\t@include mixins.cfgRootStyles;\r\n\tdisplay: inline-block;\r\n\tbackground-color: transparent;\r\n\tcolor: $textColor;\r\n\tborder-radius: 0.3em;\r\n\tborder: 0.1em solid $borderColor;\r\n\tfont-size: 1.3em;\r\n\tfont-weight: 500;\r\n\toutline: none;\r\n\tpadding: 0.4em 0.8em;\r\n\r\n\t&:focus {\r\n\t\t@include mixins.focusOutline($focusOutlineInnerColor, $focusOutlineOuterColor);\r\n\t}\r\n}\r\n\r\n@mixin classes($textColor, $borderColor, $focusOutlineInnerColor, $focusOutlineOuterColor) {\r\n\t.cfgButton {\r\n\t\t@include styles($textColor, $borderColor, $focusOutlineInnerColor, $focusOutlineOuterColor);\r\n\t}\r\n\r\n\t.cfgButtonRow {\r\n\t\t@include mixins.cfgRootStyles;\r\n\t\t&__button {\r\n\t\t\t&:nth-child(n + 2) {\r\n\t\t\t\tmargin-left: 1em;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n}\r\n","@mixin noButtonLook {\r\n\tappearance: none;\r\n\tfont-family: inherit;\r\n\tfont-size: inherit;\r\n\tcolor: inherit;\r\n\tbackground: none;\r\n\tborder: none;\r\n\tpadding: 0;\r\n}\r\n\r\n@mixin focusOutline($focusOutlineInnerColor, $focusOutlineOuterColor) {\r\n\tbox-shadow: 0 0 0 0.075em $focusOutlineInnerColor, 0 0 0 0.2em $focusOutlineOuterColor;\r\n}\r\n\r\n@mixin borderBox {\r\n\tbox-sizing: border-box;\r\n\t&:before,\r\n\t&:after {\r\n\t\tbox-sizing: inherit;\r\n\t}\r\n}\r\n\r\n@mixin cfgRootStyles {\r\n\t@include borderBox;\r\n\r\n\t* {\r\n\t\t@include borderBox;\r\n\t}\r\n}\r\n\r\n@mixin cfgDefaultFont {\r\n\tfont-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Helvetica, Arial, sans-serif,\r\n\t\t\"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";\r\n}\r\n\r\n@mixin cfgCheckAndRadio($color) {\r\n\talign-items: center;\r\n\tborder: 0.2em solid $color;\r\n\tdisplay: flex;\r\n\tflex: 0 0 auto;\r\n\theight: 2.2em;\r\n\tjustify-content: center;\r\n\tpointer-events: none;\r\n\tuser-select: none;\r\n\twidth: 2.2em;\r\n}\r\n\r\n@mixin cfgCheckbox($color) {\r\n\t@include cfgCheckAndRadio($color);\r\n\tborder-radius: 0.3em;\r\n}\r\n\r\n@mixin cfgRadio($color) {\r\n\t@include cfgCheckAndRadio($color);\r\n\tborder-radius: 50%;\r\n}\r\n","@use \"../mixins\";\r\n\r\n@mixin classes($colorActive, $colorPassive) {\r\n\t.cfgCheckmark {\r\n\t\t/* The distance-units inside the checkmark are px even though everything\r\n\t\t else is relative units. The SVG has its own coordinate space. */\r\n\r\n\t\t@include mixins.cfgRootStyles;\r\n\r\n\t\tdisplay: inline-block;\r\n\t\twidth: 100%;\r\n\t\theight: 100%;\r\n\r\n\t\t&__container {\r\n\t\t\ttransition: transform 0.4s;\r\n\t\t\ttransform: translateY(17px);\r\n\t\t}\r\n\r\n\t\t&__line {\r\n\t\t\tstroke: $colorActive;\r\n\t\t\tstroke-linecap: round;\r\n\t\t\tstroke-width: 12;\r\n\t\t\ttransform-origin: 50px 50px;\r\n\t\t\ttransition: transform 0.4s, stroke 0.4s;\r\n\t\t}\r\n\r\n\t\t&__lineLeft {\r\n\t\t\tstroke: $colorActive;\r\n\t\t\ttransform: rotate(40deg) translateY(24px) translateX(18px);\r\n\t\t}\r\n\r\n\t\t&__lineRight {\r\n\t\t\tstroke: $colorActive;\r\n\t\t\ttransform: rotate(-50deg) translateY(-2px) translateX(-3px);\r\n\t\t}\r\n\r\n\t\t@content;\r\n\r\n\t\t&__border {\r\n\t\t\t@include mixins.cfgCheckbox($colorPassive);\r\n\t\t\t&--active {\r\n\t\t\t\t@include mixins.cfgCheckbox($colorActive);\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n}\r\n","@use \"../mixins\";\r\n\r\n@mixin classes($activeColor, $passiveColor) {\r\n\t.cfgChevron {\r\n\t\t/* The distance-units inside the chevron are px even though everything\r\n\t\t else is relative units. The SVG has its own coordinate space. */\r\n\r\n\t\t@include mixins.cfgRootStyles;\r\n\r\n\t\tdisplay: inline-block;\r\n\t\twidth: 100%;\r\n\r\n\t\t&__container {\r\n\t\t\ttransition: transform 0.4s;\r\n\r\n\t\t\t&--down {\r\n\t\t\t\ttransform: translateY(13px);\r\n\t\t\t}\r\n\r\n\t\t\t&--up {\r\n\t\t\t\ttransform: translateY(-13px);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t&__line {\r\n\t\t\tstroke-linecap: round;\r\n\t\t\tstroke-width: 10;\r\n\t\t\ttransform-origin: 50px 50px;\r\n\t\t\ttransition: transform 0.4s, stroke 0.4s;\r\n\t\t}\r\n\r\n\t\t&__lineLeft,\r\n\t\t&__lineRight {\r\n\t\t\t&--active {\r\n\t\t\t\tstroke: $activeColor;\r\n\t\t\t}\r\n\t\t\t&--passive {\r\n\t\t\t\tstroke: $passiveColor;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t&__lineLeft {\r\n\t\t\t&--down {\r\n\t\t\t\ttransform: rotate(40deg);\r\n\t\t\t}\r\n\t\t\t&--up {\r\n\t\t\t\ttransform: rotate(-40deg);\r\n\t\t\t}\r\n\t\t}\r\n\t\t&__lineRight {\r\n\t\t\t&--down {\r\n\t\t\t\ttransform: rotate(-40deg);\r\n\t\t\t}\r\n\r\n\t\t\t&--up {\r\n\t\t\t\ttransform: rotate(40deg);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t@content;\r\n\t}\r\n}\r\n","@use \"../mixins\";\r\n\r\n@mixin classes($color) {\r\n\t.cfgCircleXmarkIcon {\r\n\t\t/* The distance-units inside the icon are px even though everything\r\n\t\t else is relative units. The SVG has its own coordinate space. */\r\n\r\n\t\t@include mixins.cfgRootStyles;\r\n\r\n\t\tdisplay: inline-block;\r\n\t\twidth: 100%;\r\n\t\theight: 100%;\r\n\r\n\t\tpath,\r\n\t\tcircle {\r\n\t\t\tstroke: $color;\r\n\t\t\tstroke-linecap: round;\r\n\t\t\tstroke-linejoin: round;\r\n\t\t\tstroke-width: 1.5;\r\n\t\t}\r\n\r\n\t\t@content;\r\n\t}\r\n}\r\n","/**\r\n * Web UI Configurator\r\n */\r\n\r\n@use \"mixins\";\r\n\r\n@mixin classes($fontSize, $textColor, $headerUnderlineColor) {\r\n\t.cfgConfiguratorWrapper {\r\n\t\t@include mixins.cfgRootStyles;\r\n\t\tcolor: $textColor;\r\n\t\tdisplay: flex;\r\n\t\theight: 85vh;\r\n\t\tflex-direction: column;\r\n\r\n\t\t@media screen and (orientation: landscape) {\r\n\t\t\tflex-direction: row;\r\n\t\t}\r\n\r\n\t\t.cfgTaskStart {\r\n\t\t\tmargin-top: 0.5em;\r\n\t\t\tfont-size: 1.2em;\r\n\t\t\tfont-weight: 500;\r\n\r\n\t\t\t.cfgFormSelect {\r\n\t\t\t\tpadding: 0.5em;\r\n\r\n\t\t\t\t&::after {\r\n\t\t\t\t\tright: 0.5em;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t.cfgCanvasWrapper {\r\n\t\t@include mixins.cfgRootStyles;\r\n\t\tposition: relative;\r\n\t\theight: 50rem;\r\n\t\tuser-select: none;\r\n\r\n\t\tflex: 1 1 auto;\r\n\t\toverflow: hidden;\r\n\r\n\t\t& canvas {\r\n\t\t\toutline: none;\r\n\t\t}\r\n\r\n\t\t@media screen and (orientation: landscape) {\r\n\t\t\theight: 100%;\r\n\t\t\tflex: 0 1 60%;\r\n\t\t}\r\n\t}\r\n\r\n\t.cfgConfigurator {\r\n\t\t@include mixins.cfgRootStyles;\r\n\t\t@include mixins.cfgDefaultFont;\r\n\t\tfont-size: $fontSize;\r\n\t\tcolor: $textColor;\r\n\t\tmin-width: 0;\r\n\r\n\t\theight: 100%;\r\n\t\tdisplay: flex;\r\n\t\tflex-direction: column;\r\n\t\tflex: 0 0 50%;\r\n\t\toverflow: auto;\r\n\r\n\t\t@media screen and (orientation: landscape) {\r\n\t\t\theight: 100%;\r\n\t\t\tflex: 0 1 40%;\r\n\t\t}\r\n\t}\r\n\r\n\t.cfgConfiguratorHeader {\r\n\t\tborder-bottom: 0.1em solid $headerUnderlineColor;\r\n\t\tpadding: 1.7em 1.7em 1.9em;\r\n\t\tposition: relative;\r\n\r\n\t\t&__actions {\r\n\t\t\tmargin-top: 1em;\r\n\t\t}\r\n\t}\r\n\r\n\t.cfgConfiguratorTree {\r\n\t\tpadding-top: 1em;\r\n\t\toverflow-y: auto;\r\n\t\t-webkit-overflow-scrolling: touch;\r\n\t}\r\n}\r\n","/**\r\n * Web UI Variables\r\n */\r\n\t\r\n$baseFontSize: 10px !default; // We use 10px for easy em conversion\r\n$overlayingZIndex: 1000 !default;\r\n","@use \"../mixins\";\r\n\r\n@mixin classes($color) {\r\n\t.cfgDownloadIcon {\r\n\t\t/* The distance-units inside the icon are px even though everything\r\n\t\t else is relative units. The SVG has its own coordinate space. */\r\n\r\n\t\t@include mixins.cfgRootStyles;\r\n\r\n\t\tdisplay: inline-block;\r\n\t\twidth: 100%;\r\n\t\theight: 100%;\r\n\r\n\t\tpath,\r\n\t\tcircle {\r\n\t\t\tstroke: $color;\r\n\t\t\tstroke-linecap: round;\r\n\t\t\tstroke-linejoin: round;\r\n\t\t\tstroke-width: 1.5;\r\n\t\t}\r\n\r\n\t\t@content;\r\n\t}\r\n}\r\n","@use \"mixins\";\r\n\r\n@mixin classes {\r\n\t.cfgExpandableHeadingRow {\r\n\t\t@include mixins.cfgRootStyles;\r\n\t\t@include mixins.noButtonLook;\r\n\t\talign-items: stretch;\r\n\t\tdisplay: flex;\r\n\t\theight: 3.9em;\r\n\t\toutline: 0;\r\n\t\tposition: relative;\r\n\t\twidth: 100%;\r\n\r\n\t\t&--expandable {\r\n\t\t\tcursor: pointer;\r\n\t\t}\r\n\r\n\t\t&__title {\r\n\t\t\talign-items: center;\r\n\t\t\tdisplay: flex;\r\n\t\t\tflex: 1 1 auto;\r\n\t\t\tfont-size: 1.5em;\r\n\t\t\tfont-weight: 500;\r\n\t\t\tjustify-content: flex-start;\r\n\t\t}\r\n\r\n\t\t&__icon {\r\n\t\t\talign-items: center;\r\n\t\t\tdisplay: flex;\r\n\t\t\tflex: 0 0 5em;\r\n\t\t\tjustify-content: center;\r\n\t\t\tpadding: 0 1.5em;\r\n\t\t}\r\n\r\n\t\t@content;\r\n\t}\r\n}\r\n","@use \"../mixins\";\r\n\r\n@mixin classes($color) {\r\n\t.cfgErrorIcon {\r\n\t\t/* The distance-units inside the icon are px even though everything\r\n\t\t else is relative units. The SVG has its own coordinate space. */\r\n\r\n\t\t@include mixins.cfgRootStyles;\r\n\r\n\t\tdisplay: inline-block;\r\n\t\twidth: 100%;\r\n\t\theight: 100%;\r\n\r\n\t\tpath,\r\n\t\tcircle {\r\n\t\t\tstroke: $color;\r\n\t\t\tstroke-linecap: round;\r\n\t\t\tstroke-linejoin: round;\r\n\t\t\tstroke-width: 1.5;\r\n\t\t}\r\n\r\n\t\t@content;\r\n\t}\r\n}\r\n","/**\r\n * Web UI Feature item\r\n */\r\n\r\n@use \"mixins\";\r\n\r\n@mixin classes(\r\n\t$textColor,\r\n\t$grayTextColor,\r\n\t$checkButtonUncheckedColor,\r\n\t$checkButtonCheckedColor,\r\n\t$focusOutlineInnerColor,\r\n\t$focusOutlineOuterColor,\r\n\t$dividerDark\r\n) {\r\n\t.cfgThumbnailImage {\r\n\t\tborder-radius: 0.7em;\r\n\t\tdisplay: inline-block;\r\n\t\theight: 3em;\r\n\t\twidth: 3em;\r\n\t}\r\n\r\n\t.cfgThumbnailPlaceholder {\r\n\t\talign-items: center;\r\n\t\tdisplay: flex;\r\n\t\tflex: 0 0 4.2em;\r\n\t\tjustify-content: flex-start;\r\n\t}\r\n\r\n\t.cfgFeatureItem {\r\n\t\t@include mixins.cfgRootStyles;\r\n\r\n\t\tcolor: $textColor;\r\n\r\n\t\t&__dropdown {\r\n\t\t\t@include mixins.noButtonLook;\r\n\t\t\talign-items: stretch;\r\n\t\t\tdisplay: flex;\r\n\t\t\theight: 3.9em;\r\n\t\t\toutline: 0;\r\n\t\t\tposition: relative;\r\n\t\t\twidth: 100%;\r\n\t\t\tcursor: pointer;\r\n\t\t}\r\n\r\n\t\t&--optional {\r\n\t\t\tmargin-top: 1em;\r\n\t\t}\r\n\r\n\t\t&__hiddenInput {\r\n\t\t\tleft: -99999px;\r\n\t\t\topacity: 0;\r\n\t\t\tposition: absolute;\r\n\t\t\tz-index: -1;\r\n\t\t}\r\n\r\n\t\t&__radio {\r\n\t\t\t@include mixins.cfgRadio($checkButtonUncheckedColor);\r\n\t\t}\r\n\r\n\t\t&__checkbox {\r\n\t\t\t@include mixins.cfgCheckbox($checkButtonUncheckedColor);\r\n\t\t}\r\n\r\n\t\t/* The &-syntax brings in the entire path, so the second part of this rule must be explicit */\r\n\r\n\t\t&__hiddenInput:focus ~ .cfgFeatureItem__radio,\r\n\t\t&__hiddenInput:focus ~ .cfgFeatureItem__checkbox {\r\n\t\t\t@include mixins.focusOutline($focusOutlineInnerColor, $focusOutlineOuterColor);\r\n\t\t}\r\n\r\n\t\t&__hiddenInput:checked ~ .cfgFeatureItem__radio {\r\n\t\t\t@include mixins.cfgRadio($checkButtonCheckedColor);\r\n\t\t}\r\n\t\t&__hiddenInput:checked ~ .cfgFeatureItem__checkbox {\r\n\t\t\t@include mixins.cfgCheckbox($checkButtonCheckedColor);\r\n\t\t}\r\n\r\n\t\t&.cfgAdditionalProduct {\r\n\t\t\t> .cfgExpandableHeadingRow {\r\n\t\t\t\t> .cfgExpandableHeadingRow__title {\r\n\t\t\t\t\tfont-weight: 600;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\r\n\t\t\t> .cfgFeatureItem__hr {\r\n\t\t\t\tborder-bottom-color: $dividerDark;\r\n\t\t\t}\r\n\r\n\t\t\t/* The last themathic break (hr) we move under the next thematic break so it appears as one */\r\n\t\t\t.cfgFeatureItem:last-child .cfgFeatureItem__hr {\r\n\t\t\t\tmargin-bottom: -0.1em;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t.cfgFeatureItemOptional__titleWrapper,\r\n\t.cfgFeatureItemOption__titleWrapper {\r\n\t\tflex: 1 1 auto;\r\n\t\tmargin-left: 1em;\r\n\t}\r\n\r\n\t.cfgFeatureItemOptional__title,\r\n\t.cfgFeatureItemOption__title {\r\n\t\tfont-size: 1.5em;\r\n\t}\r\n\r\n\t.cfgFeatureItemOption__price {\r\n\t\tfont-weight: 600;\r\n\t\tfont-size: 0.75em;\r\n\t\tcolor: $grayTextColor;\r\n\t}\r\n\r\n\t.cfgOptionTree--subLevel .cfgFeatureItem__hr {\r\n\t\tdisplay: none;\r\n\t}\r\n\r\n\t.cfgFeatureItemOption {\r\n\t\talign-items: center;\r\n\t\tdisplay: flex;\r\n\t}\r\n\r\n\t.cfgFeatureItemOptional {\r\n\t\talign-items: center;\r\n\t\tdisplay: flex;\r\n\t\tjustify-content: center;\r\n\t\tmargin-top: 0.5em;\r\n\r\n\t\t&__header {\r\n\t\t\tfont-size: 1.2em;\r\n\t\t\tfont-weight: 600;\r\n\t\t\tmargin: 0 0 0.3em 0;\r\n\t\t\tpadding: 0;\r\n\t\t\ttext-transform: uppercase;\r\n\t\t}\r\n\t}\r\n}\r\n","@mixin classes($borderColor) {\r\n\t.cfgInput,\r\n\t.cfgFormSelect {\r\n\t\tborder: 0.1em solid $borderColor;\r\n\t\tpadding: 0.3em 0.4em;\r\n\t\tborder-radius: 0.3em;\r\n\t}\r\n\r\n\t.cfgFormSelect {\r\n\t\tselect {\r\n\t\t\tappearance: none;\r\n\t\t\tpadding: 0 1em 0 0;\r\n\t\t\tmargin: 0;\r\n\t\t\twidth: 100%;\r\n\r\n\t\t\tbackground-color: transparent;\r\n\t\t\tfont-family: inherit;\r\n\t\t\tfont-size: inherit;\r\n\t\t\tfont-weight: inherit;\r\n\t\t\tcursor: inherit;\r\n\t\t\tline-height: inherit;\r\n\t\t\toutline: none;\r\n\t\t\tborder: none;\r\n\t\t}\r\n\r\n\t\tcursor: pointer;\r\n\t\tposition: relative;\r\n\r\n\t\t&::after {\r\n\t\t\tposition: absolute;\r\n\t\t\tright: 0.35em;\r\n\t\t\ttop: 50%;\r\n\t\t\tmargin-top: -0.55em;\r\n\t\t\tcontent: \"\";\r\n\t\t\twidth: 1em;\r\n\t\t\theight: 1em;\r\n\t\t\tbackground-color: $borderColor;\r\n\t\t\tclip-path: polygon(50% 80%, 90% 40%, 100% 50%, 50% 100%, 0 50%, 10% 40%);\r\n\t\t\tjustify-self: end;\r\n\t\t}\r\n\t}\r\n}\r\n","@use \"mixins\";\r\n\r\n@mixin styles($color) {\r\n\t@include mixins.cfgRootStyles;\r\n\tborder: 0;\r\n\tborder-bottom: 0.1em solid $color;\r\n\tpadding: 0;\r\n\tmargin: 0;\r\n}\r\n\r\n@mixin classes($color) {\r\n\t.cfgHr {\r\n\t\t@include styles($color);\r\n\t\t@content;\r\n\t}\r\n}\r\n","/**\r\n * Web UI Loading\r\n */\r\n\r\n@use \"mixins\";\r\n\r\n@mixin classes(\r\n\t$textColor,\r\n\t$spinnerColor1,\r\n\t$spinnerColor2,\r\n\t$overlayBackgroundColor,\r\n\t$overlayingZIndex\r\n) {\r\n\t.cfgCenteredLoading {\r\n\t\t@include mixins.cfgRootStyles;\r\n\t\talign-items: center;\r\n\t\tdisplay: flex;\r\n\t\tflex-direction: column;\r\n\t\theight: 100%;\r\n\t\tjustify-content: center;\r\n\t\twidth: 100%;\r\n\t}\r\n\r\n\t.cfgOverlayLoading {\r\n\t\t@include mixins.cfgRootStyles;\r\n\r\n\t\talign-items: center;\r\n\t\tbackground-color: $overlayBackgroundColor;\r\n\t\tbottom: 0;\r\n\t\tdisplay: flex;\r\n\t\tflex-direction: column;\r\n\t\tjustify-content: center;\r\n\t\tleft: 0;\r\n\t\tposition: absolute;\r\n\t\tright: 0;\r\n\t\ttop: 0;\r\n\t\tz-index: $overlayingZIndex;\r\n\r\n\t\t&--clickThrough {\r\n\t\t\tbackground-color: transparent;\r\n\t\t\tpointer-events: none;\r\n\r\n\t\t\t.cfgLoadingWithText {\r\n\t\t\t\tpadding: 2em 2em 1.8em;\r\n\t\t\t\tborder-radius: 0.8em;\r\n\t\t\t\tbackground-color: $overlayBackgroundColor;\r\n\t\t\t\topacity: 0.8;\r\n\t\t\t\tborder: 0.1em solid $spinnerColor2;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t&--fullWindow {\r\n\t\t\tposition: fixed;\r\n\t\t\tz-index: #{$overlayingZIndex + 1};\r\n\t\t}\r\n\t}\r\n\r\n\t.cfgLoadingWithText {\r\n\t\t@include mixins.cfgRootStyles;\r\n\t\t@include mixins.cfgDefaultFont;\r\n\r\n\t\ttext-align: center;\r\n\r\n\t\t&__text {\r\n\t\t\tcolor: $textColor;\r\n\t\t\tfont-weight: 600;\r\n\t\t\tmargin-top: 0.5em;\r\n\t\t\tfont-size: 1.6em;\r\n\t\t}\r\n\t}\r\n\r\n\t.cfgLoading {\r\n\t\t@include mixins.cfgRootStyles;\r\n\r\n\t\tanimation: rotate 1.1s linear 0s infinite;\r\n\t\tborder-radius: 100%;\r\n\t\tborder: 0.5em solid $spinnerColor2;\r\n\t\tborder-bottom-color: $spinnerColor1;\r\n\t\tdisplay: inline-block;\r\n\t\theight: 3em;\r\n\t\twidth: 3em;\r\n\r\n\t\t&--small {\r\n\t\t\tborder-width: 0.4em;\r\n\t\t\theight: 2em;\r\n\t\t\twidth: 2em;\r\n\t\t}\r\n\t}\r\n\r\n\t@keyframes rotate {\r\n\t\tfrom {\r\n\t\t\ttransform: rotate(0deg);\r\n\t\t}\r\n\t\tto {\r\n\t\t\ttransform: rotate(360deg);\r\n\t\t}\r\n\t}\r\n}\r\n","/**\r\n * Web UI Option tree\r\n */\r\n\r\n@use \"mixins\";\r\n\r\n@mixin classes {\r\n\t.cfgOptionTree {\r\n\t\t@include mixins.cfgRootStyles;\r\n\r\n\t\tlist-style: none;\r\n\t\tmargin: 0;\r\n\t\tpadding: 0;\r\n\r\n\t\t&--topLevel {\r\n\t\t\tpadding-left: 1.7em;\r\n\t\t}\r\n\r\n\t\t&--indent {\r\n\t\t\tmargin-left: 3.2em;\r\n\t\t}\r\n\r\n\t\t&--compThumb {\r\n\t\t\tmargin-left: 4.2em;\r\n\t\t}\r\n\r\n\t\t@content;\r\n\t}\r\n}\r\n","/**\r\n * Web UI Product information\r\n */\r\n\r\n@use \"sass:math\";\r\n@use \"mixins\";\r\n\r\n@mixin classes($textColor) {\r\n\t.cfgProductInfo {\r\n\t\t@include mixins.cfgRootStyles;\r\n\r\n\t\tcolor: $textColor;\r\n\r\n\t\tdisplay: flex;\r\n\r\n\t\t&__left {\r\n\t\t\tflex: 1 1 auto;\r\n\t\t\tmin-width: 0;\r\n\t\t\toverflow: hidden;\r\n\t\t}\r\n\r\n\t\t&__right {\r\n\t\t\talign-items: flex-end;\r\n\t\t\tdisplay: flex;\r\n\t\t\tflex-direction: column;\r\n\t\t\tflex: 1 0 auto;\r\n\t\t\tmargin-left: 1em;\r\n\t\t\tmax-width: 0.333333333;\r\n\t\t\tmin-width: 0;\r\n\t\t}\r\n\r\n\t\t&__name {\r\n\t\t\tdisplay: block;\r\n\t\t\tfont-size: 1.6em;\r\n\t\t\tfont-weight: 600;\r\n\t\t\tline-height: 1.33;\r\n\t\t\tmargin: 0;\r\n\t\t}\r\n\r\n\t\t&__number {\r\n\t\t\tfont-size: 1.3em;\r\n\t\t\tfont-weight: 400;\r\n\t\t\tline-height: 1.38;\r\n\t\t\tmargin: 0;\r\n\t\t}\r\n\r\n\t\t@content;\r\n\t}\r\n}\r\n","@mixin classes($errorColor) {\r\n\t.cfgRangeView {\r\n\t\t&__inputs {\r\n\t\t\tdisplay: flex;\r\n\t\t\talign-items: center;\r\n\t\t}\r\n\r\n\t\t&__number-input {\r\n\t\t\tfont-size: 1.5em;\r\n\t\t\tflex-grow: 1;\r\n\t\t\ttext-align: right;\r\n\t\t}\r\n\r\n\t\t&__unit-label {\r\n\t\t\tfont-size: 1.5em;\r\n\t\t\tmargin-left: 0.3em;\r\n\t\t}\r\n\r\n\t\t&__slider-input.cfgSlider {\r\n\t\t\tmargin-left: 1em;\r\n\t\t\tflex-grow: 3;\r\n\t\t}\r\n\r\n\t\t&__error {\r\n\t\t\tdisplay: flex;\r\n\t\t\talign-items: center;\r\n\r\n\t\t\tmargin-top: 1em;\r\n\t\t\tfont-size: 1.5em;\r\n\t\t\tcolor: $errorColor;\r\n\r\n\t\t\t.cfgErrorIcon {\r\n\t\t\t\tpadding-right: 0.25em;\r\n\t\t\t\twidth: 1.25em;\r\n\t\t\t\theight: 1em;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n}\r\n","@use \"mixins\";\r\n\r\n// The origins of this SCSS file is here:\r\n// https://css-tricks.com/sliding-nightmare-understanding-range-input/\r\n\r\n$trackHeight: 0.2em !default;\r\n$thumbDiameter: 2.8em !default;\r\n\r\n@mixin track($trackColor) {\r\n\tbox-sizing: border-box;\r\n\tborder: none;\r\n\theight: $trackHeight;\r\n\tbackground: $trackColor;\r\n}\r\n\r\n@mixin thumb($thumbColor, $thumbShadowColor) {\r\n\tbox-sizing: border-box;\r\n\tborder: none;\r\n\twidth: $thumbDiameter;\r\n\theight: $thumbDiameter;\r\n\tborder-radius: 50%;\r\n\tbackground: $thumbColor;\r\n\tbox-shadow: 0 0.15em 0.45em 0.05em $thumbShadowColor;\r\n}\r\n\r\n@mixin classes($trackColor, $thumbColor, $thumbShadowColor) {\r\n\t.cfgSlider {\r\n\t\t@include mixins.cfgRootStyles;\r\n\r\n\t\t&,\r\n\t\t&::-webkit-slider-thumb {\r\n\t\t\t-webkit-appearance: none;\r\n\t\t}\r\n\r\n\t\tflex: 1;\r\n\t\tmargin: 0;\r\n\t\tpadding: 0;\r\n\t\tmin-height: $thumbDiameter;\r\n\t\tbackground: transparent;\r\n\t\tfont: inherit;\r\n\r\n\t\t&::-webkit-slider-runnable-track {\r\n\t\t\t@include track($trackColor);\r\n\t\t}\r\n\t\t&::-moz-range-track {\r\n\t\t\t@include track($trackColor);\r\n\t\t}\r\n\t\t&::-ms-track {\r\n\t\t\t@include track($trackColor);\r\n\t\t}\r\n\r\n\t\t&::-webkit-slider-thumb {\r\n\t\t\tmargin-top: 0.5 * ($trackHeight - $thumbDiameter);\r\n\t\t\t@include thumb($thumbColor, $thumbShadowColor);\r\n\t\t}\r\n\t\t&::-moz-range-thumb {\r\n\t\t\t@include thumb($thumbColor, $thumbShadowColor);\r\n\t\t}\r\n\t\t&::-ms-thumb {\r\n\t\t\tmargin-top: 0;\r\n\t\t\t@include thumb($thumbColor, $thumbShadowColor);\r\n\t\t}\r\n\r\n\t\t&::-ms-tooltip {\r\n\t\t\tdisplay: none;\r\n\t\t}\r\n\r\n\t\t@content;\r\n\t}\r\n}\r\n","@use \"mixins\";\r\n\r\n@mixin classes($borderColor, $linkColor) {\r\n\t$preview-size: 4.8em;\r\n\t$line-width: 0.1em;\r\n\t$icon-size: 2em;\r\n\r\n\t.cfgTaskList {\r\n\t\tul {\r\n\t\t\tlist-style-type: none;\r\n\t\t\tpadding: 0;\r\n\t\t\tmargin: 1em 0 0 0;\r\n\t\t\tborder-bottom: 0.1em solid $borderColor;\r\n\t\t}\r\n\r\n\t\t&__item {\r\n\t\t\tpadding: 0 1.5em 0 1.7em;\r\n\t\t\tmargin-bottom: 1em;\r\n\t\t\tdisplay: flex;\r\n\t\t\talign-items: center;\r\n\t\t}\r\n\r\n\t\t&__preview {\r\n\t\t\tborder: 0.1em solid $borderColor;\r\n\t\t\tborder-radius: 10%;\r\n\t\t\twidth: $preview-size;\r\n\t\t\theight: $preview-size;\r\n\t\t\tflex-shrink: 0;\r\n\r\n\t\t\timg {\r\n\t\t\t\tobject-fit: cover;\r\n\t\t\t\tposition: relative;\r\n\t\t\t\tleft: 0.1 * $preview-size - $line-width;\r\n\t\t\t\ttop: 0.1 * $preview-size - $line-width;\r\n\t\t\t\twidth: 0.8 * $preview-size;\r\n\t\t\t\theight: 0.8 * $preview-size;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t&__icon {\r\n\t\t\tflex-shrink: 0;\r\n\t\t\twidth: $icon-size + 2em;\r\n\t\t\theight: $icon-size;\r\n\t\t\tpadding-left: 1em;\r\n\t\t\tpadding-right: 1em;\r\n\r\n\t\t\t.cfgLoadingSizer {\r\n\t\t\t\tfont-size: 0.75em;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t&__status {\r\n\t\t\tflex-grow: 1;\r\n\t\t\tfont-size: 1.5em;\r\n\t\t}\r\n\r\n\t\t&__abort {\r\n\t\t\t@include mixins.noButtonLook;\r\n\t\t\tcursor: pointer;\r\n\t\t\twidth: $icon-size;\r\n\t\t\theight: $icon-size;\r\n\t\t\tflex-shrink: 0;\r\n\t\t}\r\n\r\n\t\t&__restart {\r\n\t\t\t@include mixins.noButtonLook;\r\n\t\t\tcursor: pointer;\r\n\t\t\ttext-decoration: underline;\r\n\t\t\tcolor: $linkColor;\r\n\t\t}\r\n\t}\r\n}\r\n"]}
1
+ {"version":3,"sources":["../../src/scss/_utilities.scss","../../src/scss/web-ui.scss","../../src/scss/_themed.scss","../../src/scss/_button.scss","../../src/scss/_mixins.scss","../../src/scss/icons/_checkmark.scss","../../src/scss/icons/_chevron.scss","../../src/scss/icons/_circle-xmark-icon.scss","../../src/scss/_configurator.scss","../../src/scss/_variables.scss","../../src/scss/icons/_download-icon.scss","../../src/scss/_expandable.scss","../../src/scss/icons/_error-icon.scss","../../src/scss/_feature-item.scss","../../src/scss/_forms.scss","../../src/scss/_hr.scss","../../src/scss/_loading.scss","../../src/scss/_option-tree.scss","../../src/scss/_product-information.scss","../../src/scss/_range-view.scss","../../src/scss/_slider.scss","../../src/scss/_tasks.scss"],"names":[],"mappings":"AAIA,QACC,eCqBD,CDlBA,QACC,cCqBD,CDlBA,QACC,iBCqBD,CDlBA,iBACC,eAAA,CACA,sBAAA,CACA,kBCqBD,CC2DC,EACC,aDjDF,CE5BC,WCRA,qBAAA,CDRA,oBAAA,CACA,4BAAA,CACA,UD+FC,CC9FD,kBAAA,CACA,yBAAA,CACA,eAAA,CACA,eAAA,CACA,YAAA,CACA,iBFiDD,CGhDC,mCAEC,kBHiDF,CG1CC,aAVA,qBHuDD,CGtDC,qCAEC,kBHuDF,CExDC,iBCNA,4CHiED,CEjDC,cCZA,qBHiED,CGhEC,yCAEC,kBHiEF,CG1DC,gBAVA,qBHuED,CGtEC,2CAEC,kBHuEF,CE3DG,qCACC,eF6DJ,CIzFC,cDYA,qBAAA,CCNC,oBAAA,CACA,UAAA,CACA,WJ0FF,CGrFC,yCAEC,kBHsFF,CG/EC,gBAVA,qBH4FD,CG3FC,2CAEC,kBH4FF,CIjGE,yBACC,wBAAA,CACA,0BJmGH,CIhGE,oBACC,WH2FD,CG1FC,oBAAA,CACA,eAAA,CACA,0BAAA,CACA,mCJkGH,CI/FE,wBACC,WHmFD,CGlFC,yDJiGH,CI9FE,yBACC,WH8ED,CG7EC,0DJgGH,CI3FE,sBDDD,yBAAA,CAYA,kBH4FD,CIrGG,oDDJF,kBAAA,CAEA,YAAA,CACA,aAAA,CACA,YAAA,CACA,sBAAA,CACA,mBAAA,CACA,wBAAA,CAAA,gBAAA,CACA,WH6GD,CIjHG,8BDHF,sBAAA,CAYA,kBHwGD,CKtJC,YFYA,qBAAA,CENC,oBAAA,CACA,ULuJF,CGjJC,qCAEC,kBHkJF,CG3IC,cAVA,qBHwJD,CGvJC,uCAEC,kBHwJF,CK9JE,uBACC,wBLgKH,CK9JG,6BACC,0BLgKJ,CK7JG,2BACC,2BL+JJ,CK3JE,kBACC,oBAAA,CACA,eAAA,CACA,0BAAA,CACA,mCL6JH,CKxJG,6DACC,WL0JJ,CKxJG,+DACC,cL0JJ,CKrJG,4BACC,uBLuJJ,CKhJG,uDACC,wBLqJJ,CKlJG,2BACC,uBLoJJ,CMxMC,oBHYA,qBAAA,CGNC,oBAAA,CACA,UAAA,CACA,WNyMF,CGpMC,qDAEC,kBHqMF,CG9LC,sBAVA,qBH2MD,C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A,CACA,iBF09BD,CGz9BC,+DAEC,kBH09BF,CGn9BC,2BAVA,qBHg+BD,CG/9BC,iEAEC,kBHg+BF,CEj+BC,+BCNA,+CH0+BD,CE19BC,4BCZA,qBHy+BD,CGx+BC,qEAEC,kBHy+BF,CGl+BC,8BAVA,qBH++BD,CG9+BC,uEAEC,kBH++BF,CEn+BG,mDACC,eFq+BJ,CIjgCC,4BDYA,qBAAA,CCNC,oBAAA,CACA,UAAA,CACA,WJigCF,CG5/BC,qEAEC,kBH6/BF,CGt/BC,8BAVA,qBHmgCD,CGlgCC,uEAEC,kBHmgCF,CIxgCE,uCACC,wBAAA,CACA,0BJ0gCH,CIvgCE,kCACC,WH2FD,CG1FC,oBAAA,CACA,eAAA,CACA,0BAAA,CACA,mCJygCH,CItgCE,sCACC,WHmFD,CGlFC,yDJwgCH,CIrgCE,uCACC,WH8ED,CG7EC,0DJugCH,CIlgCE,oCDDD,yBAAA,CAYA,kBHmgCD,CI5gCG,gFDJF,kBAAA,CAEA,YAAA,CACA,aAAA,CACA,YAAA,CACA,sBAAA,CACA,mBAAA,CACA,wBAAA,CAAA,gBAAA,CACA,WHohCD,CIxhCG,4CDHF,sBAAA,CAYA,kBH+gCD,CK7jCC,0BFYA,qBAAA,CENC,oBAAA,CACA,UL6jCF,CGvjCC,iEAEC,kBHwjCF,CGjjCC,4BAVA,qBH8jCD,CG7jCC,mEAEC,kBH8jCF,CKpkCE,qCACC,wBLskCH,CKpkCG,2CACC,0BLskCJ,CKnkCG,yCACC,2BLqkCJ,CKjkCE,gCACC,oBAAA,CACA,eAAA,CACA,0BAAA,CACA,mCLmkCH,CK9jCG,yFACC,WLgkCJ,CK9jCG,2FACC,cLgkCJ,CK3jCG,0CACC,uBL6jCJ,CKtjCG,mFACC,wBL2jCJ,CKxjCG,yCACC,uBL0jCJ,CM9mCC,kCHYA,qBAAA,CGNC,oBAAA,CACA,UAAA,CACA,WN8mCF,CGzmCC,iFAEC,kBH0mCF,CGnmCC,oCAVA,qBHgnCD,CG/mCC,mFAEC,kBHgnCF,CMrnCE,gFAEC,cLmGiC,CKlGjC,oBAAA,CACA,qBAAA,CACA,gBNunCH,COloCC,sCJQA,qBAAA,CINC,aN0G4C,CMzG5C,YAAA,CACA,WAAA,C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","file":"web-ui.css","sourcesContent":["/**\n * Web UI Utilities\n */\n\n.cfgMl1 {\n\tmargin-left: 1em;\n}\n\n.cfgMt1 {\n\tmargin-top: 1em;\n}\n\n.cfgMb1 {\n\tmargin-bottom: 1em;\n}\n\n.cfgTextOverflow {\n\toverflow: hidden;\n\ttext-overflow: ellipsis;\n\twhite-space: nowrap;\n}\n","/**\n* Web UI Styling\n*/\n\n@use \"themed\";\n\n@include themed.themed(themed.$lightTheme);\n\n.cfgDarkTheme {\n\t@include themed.themed(themed.$darkTheme);\n}\n","@use \"sass:map\";\n@use \"sass:color\";\n\n@use \"variables\" as v;\n\n// Components\n@use \"button\";\n@use \"forms\";\n\n@use \"configurator\";\n@use \"expandable\";\n@use \"feature-item\";\n@use \"hr\";\n@use \"loading\";\n@use \"option-tree\";\n@use \"product-information\";\n@use \"range-view\";\n@use \"slider\";\n@use \"tasks\";\n\n// Icons\n@use \"icons/checkmark\";\n@use \"icons/chevron\";\n@use \"icons/circle-xmark-icon\";\n@use \"icons/download-icon\";\n@use \"icons/error-icon\";\n\n// Utilities\n@use \"utilities\";\n\n/* Colors */\n\n$black: hsl(0, 0%, 0%) !default;\n$white: hsl(0, 0%, 100%) !default;\n$darkGrey: hsl(0, 0%, 15%) !default;\n\n/* Specific colors */\n\n$border: hsl(252, 5%, 79%) !default;\n$borderDark: hsl(0, 0%, 73%) !default;\n$icon: hsl(252, 5%, 50%) !default;\n$focusOutlineOuter: hsl(0, 0%, 13%) !default;\n$sliderTrack: #666 !default;\n$spinner2: hsla(0, 0%, 0%, 0.15);\n$grayText: hsl(0, 0%, 50%) !default;\n$text: hsl(0, 0%, 20%) !default;\n$link: hsl(209, 100%, 35%) !default;\n$error: hsl(10, 72%, 41%) !default;\n\n/* As convention we assume the default theme when naming colors,\n as attempts at generic naming often leads to confusion */\n$lightTheme: (\n\t\"black\": $black,\n\t\"border\": $border,\n\t\"borderDark\": $borderDark,\n\t\"checkButtonChecked\": $black,\n\t\"checkButtonUnchecked\": $border,\n\t\"chevronActive\": $black,\n\t\"chevronPassive\": $borderDark,\n\t\"divider\": $border,\n\t\"dividerDark\": $borderDark,\n\t\"error\": $error,\n\t\"focusOutlineInner\": $white,\n\t\"focusOutlineOuter\": $text,\n\t\"grayText\": $grayText,\n\t\"icon\": $icon,\n\t\"link\": $link,\n\t\"overlayBackground\": $white,\n\t\"sliderThumb\": $white,\n\t\"sliderThumbShadow\": $sliderTrack,\n\t\"sliderTrack\": $sliderTrack,\n\t\"spinner1\": $black,\n\t\"spinner2\": $spinner2,\n\t\"text\": $text,\n\t\"white\": $white,\n) !default;\n\n@function invertLightness($color) {\n\t@return color.change(\n\t\t$color,\n\t\t$lightness: 100 - color.lightness($color) * 0.8\n\t); // We scale with 80% to have a bit more contrast\n}\n\n@function invertLightnessList($list) {\n\t@each $key, $color in $list {\n\t\t$list: map.set($list, $key, invertLightness($color));\n\t}\n\t@return $list;\n}\n\n$darkTheme: invertLightnessList($lightTheme);\n\n$themes: (\n\t\"light\": $lightTheme,\n\t\"dark\": $darkTheme,\n);\n\n@mixin themed($ct, $baseFontSize: v.$baseFontSize, $overlayingZIndex: v.$overlayingZIndex) {\n\ta {\n\t\tcolor: map.get($ct, \"link\");\n\t}\n\n\t@include button.classes(\n\t\tmap.get($ct, \"text\"),\n\t\tmap.get($ct, \"borderDark\"),\n\t\tmap.get($ct, \"focusOutlineInner\"),\n\t\tmap.get($ct, \"focusOutlineOuter\")\n\t);\n\t@include checkmark.classes(\n\t\tmap.get($ct, \"checkButtonChecked\"),\n\t\tmap.get($ct, \"checkButtonUnchecked\")\n\t);\n\t@include chevron.classes(map.get($ct, \"chevronActive\"), map.get($ct, \"chevronPassive\"));\n\t@include circle-xmark-icon.classes(map.get($ct, \"icon\"));\n\t@include configurator.classes($baseFontSize, map.get($ct, \"text\"), map.get($ct, \"divider\"));\n\t@include download-icon.classes(map.get($ct, \"link\"));\n\t@include expandable.classes;\n\t@include error-icon.classes(map.get($ct, \"error\"));\n\t@include feature-item.classes(\n\t\tmap.get($ct, \"text\"),\n\t\tmap.get($ct, \"grayText\"),\n\t\tmap.get($ct, \"checkButtonUnchecked\"),\n\t\tmap.get($ct, \"checkButtonChecked\"),\n\t\tmap.get($ct, \"focusOutlineInner\"),\n\t\tmap.get($ct, \"focusOutlineOuter\"),\n\t\tmap.get($ct, \"dividerDark\")\n\t);\n\t@include forms.classes(map.get($ct, \"borderDark\"));\n\t@include hr.classes(map.get($ct, \"divider\"));\n\t@include loading.classes(\n\t\tmap.get($ct, \"black\"),\n\t\tmap.get($ct, \"spinner1\"),\n\t\tmap.get($ct, \"spinner2\"),\n\t\tmap.get($ct, \"overlayBackground\"),\n\t\t$overlayingZIndex\n\t);\n\t@include option-tree.classes;\n\t@include product-information.classes(map.get($ct, \"text\"));\n\t@include range-view.classes(map.get($ct, \"error\"));\n\t@include slider.classes(\n\t\tmap.get($ct, \"sliderTrack\"),\n\t\tmap.get($ct, \"sliderThumb\"),\n\t\tmap.get($ct, \"sliderThumbShadow\")\n\t);\n\t@include tasks.classes(map.get($ct, \"border\"), map.get($ct, \"link\"));\n}\n","/**\n * Web UI Product information\n */\n@use \"mixins\";\n\n@mixin styles($textColor, $borderColor, $focusOutlineInnerColor, $focusOutlineOuterColor) {\n\t@include mixins.cfgRootStyles;\n\tdisplay: inline-block;\n\tbackground-color: transparent;\n\tcolor: $textColor;\n\tborder-radius: 0.3em;\n\tborder: 0.1em solid $borderColor;\n\tfont-size: 1.3em;\n\tfont-weight: 500;\n\toutline: none;\n\tpadding: 0.4em 0.8em;\n\n\t&:focus {\n\t\t@include mixins.focusOutline($focusOutlineInnerColor, $focusOutlineOuterColor);\n\t}\n}\n\n@mixin classes($textColor, $borderColor, $focusOutlineInnerColor, $focusOutlineOuterColor) {\n\t.cfgButton {\n\t\t@include styles($textColor, $borderColor, $focusOutlineInnerColor, $focusOutlineOuterColor);\n\t}\n\n\t.cfgButtonRow {\n\t\t@include mixins.cfgRootStyles;\n\t\t&__button {\n\t\t\t&:nth-child(n + 2) {\n\t\t\t\tmargin-left: 1em;\n\t\t\t}\n\t\t}\n\t}\n}\n","@mixin noButtonLook {\n\tappearance: none;\n\tfont-family: inherit;\n\tfont-size: inherit;\n\tcolor: inherit;\n\tbackground: none;\n\tborder: none;\n\tpadding: 0;\n}\n\n@mixin focusOutline($focusOutlineInnerColor, $focusOutlineOuterColor) {\n\tbox-shadow: 0 0 0 0.075em $focusOutlineInnerColor, 0 0 0 0.2em $focusOutlineOuterColor;\n}\n\n@mixin borderBox {\n\tbox-sizing: border-box;\n\t&:before,\n\t&:after {\n\t\tbox-sizing: inherit;\n\t}\n}\n\n@mixin cfgRootStyles {\n\t@include borderBox;\n\n\t* {\n\t\t@include borderBox;\n\t}\n}\n\n@mixin cfgDefaultFont {\n\tfont-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Helvetica, Arial, sans-serif,\n\t\t\"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";\n}\n\n@mixin cfgCheckAndRadio($color) {\n\talign-items: center;\n\tborder: 0.2em solid $color;\n\tdisplay: flex;\n\tflex: 0 0 auto;\n\theight: 2.2em;\n\tjustify-content: center;\n\tpointer-events: none;\n\tuser-select: none;\n\twidth: 2.2em;\n}\n\n@mixin cfgCheckbox($color) {\n\t@include cfgCheckAndRadio($color);\n\tborder-radius: 0.3em;\n}\n\n@mixin cfgRadio($color) {\n\t@include cfgCheckAndRadio($color);\n\tborder-radius: 50%;\n}\n","@use \"../mixins\";\n\n@mixin classes($colorActive, $colorPassive) {\n\t.cfgCheckmark {\n\t\t/* The distance-units inside the checkmark are px even though everything\n\t\t else is relative units. The SVG has its own coordinate space. */\n\n\t\t@include mixins.cfgRootStyles;\n\n\t\tdisplay: inline-block;\n\t\twidth: 100%;\n\t\theight: 100%;\n\n\t\t&__container {\n\t\t\ttransition: transform 0.4s;\n\t\t\ttransform: translateY(17px);\n\t\t}\n\n\t\t&__line {\n\t\t\tstroke: $colorActive;\n\t\t\tstroke-linecap: round;\n\t\t\tstroke-width: 12;\n\t\t\ttransform-origin: 50px 50px;\n\t\t\ttransition: transform 0.4s, stroke 0.4s;\n\t\t}\n\n\t\t&__lineLeft {\n\t\t\tstroke: $colorActive;\n\t\t\ttransform: rotate(40deg) translateY(24px) translateX(18px);\n\t\t}\n\n\t\t&__lineRight {\n\t\t\tstroke: $colorActive;\n\t\t\ttransform: rotate(-50deg) translateY(-2px) translateX(-3px);\n\t\t}\n\n\t\t@content;\n\n\t\t&__border {\n\t\t\t@include mixins.cfgCheckbox($colorPassive);\n\t\t\t&--active {\n\t\t\t\t@include mixins.cfgCheckbox($colorActive);\n\t\t\t}\n\t\t}\n\t}\n}\n","@use \"../mixins\";\n\n@mixin classes($activeColor, $passiveColor) {\n\t.cfgChevron {\n\t\t/* The distance-units inside the chevron are px even though everything\n\t\t else is relative units. The SVG has its own coordinate space. */\n\n\t\t@include mixins.cfgRootStyles;\n\n\t\tdisplay: inline-block;\n\t\twidth: 100%;\n\n\t\t&__container {\n\t\t\ttransition: transform 0.4s;\n\n\t\t\t&--down {\n\t\t\t\ttransform: translateY(13px);\n\t\t\t}\n\n\t\t\t&--up {\n\t\t\t\ttransform: translateY(-13px);\n\t\t\t}\n\t\t}\n\n\t\t&__line {\n\t\t\tstroke-linecap: round;\n\t\t\tstroke-width: 10;\n\t\t\ttransform-origin: 50px 50px;\n\t\t\ttransition: transform 0.4s, stroke 0.4s;\n\t\t}\n\n\t\t&__lineLeft,\n\t\t&__lineRight {\n\t\t\t&--active {\n\t\t\t\tstroke: $activeColor;\n\t\t\t}\n\t\t\t&--passive {\n\t\t\t\tstroke: $passiveColor;\n\t\t\t}\n\t\t}\n\n\t\t&__lineLeft {\n\t\t\t&--down {\n\t\t\t\ttransform: rotate(40deg);\n\t\t\t}\n\t\t\t&--up {\n\t\t\t\ttransform: rotate(-40deg);\n\t\t\t}\n\t\t}\n\t\t&__lineRight {\n\t\t\t&--down {\n\t\t\t\ttransform: rotate(-40deg);\n\t\t\t}\n\n\t\t\t&--up {\n\t\t\t\ttransform: rotate(40deg);\n\t\t\t}\n\t\t}\n\n\t\t@content;\n\t}\n}\n","@use \"../mixins\";\n\n@mixin classes($color) {\n\t.cfgCircleXmarkIcon {\n\t\t/* The distance-units inside the icon are px even though everything\n\t\t else is relative units. The SVG has its own coordinate space. */\n\n\t\t@include mixins.cfgRootStyles;\n\n\t\tdisplay: inline-block;\n\t\twidth: 100%;\n\t\theight: 100%;\n\n\t\tpath,\n\t\tcircle {\n\t\t\tstroke: $color;\n\t\t\tstroke-linecap: round;\n\t\t\tstroke-linejoin: round;\n\t\t\tstroke-width: 1.5;\n\t\t}\n\n\t\t@content;\n\t}\n}\n","/**\n * Web UI Configurator\n */\n\n@use \"mixins\";\n\n@mixin classes($fontSize, $textColor, $headerUnderlineColor) {\n\t.cfgConfiguratorWrapper {\n\t\t@include mixins.cfgRootStyles;\n\t\tcolor: $textColor;\n\t\tdisplay: flex;\n\t\theight: 85vh;\n\t\tflex-direction: column;\n\n\t\t@media screen and (orientation: landscape) {\n\t\t\tflex-direction: row;\n\t\t}\n\n\t\t.cfgTaskStart {\n\t\t\tmargin-top: 0.5em;\n\t\t\tfont-size: 1.2em;\n\t\t\tfont-weight: 500;\n\n\t\t\t.cfgFormSelect {\n\t\t\t\tpadding: 0.5em;\n\n\t\t\t\t&::after {\n\t\t\t\t\tright: 0.5em;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t.cfgCanvasWrapper {\n\t\t@include mixins.cfgRootStyles;\n\t\tposition: relative;\n\t\theight: 50rem;\n\t\tuser-select: none;\n\n\t\tflex: 1 1 auto;\n\t\toverflow: hidden;\n\n\t\t& canvas {\n\t\t\toutline: none;\n\t\t}\n\n\t\t@media screen and (orientation: landscape) {\n\t\t\theight: 100%;\n\t\t\tflex: 0 1 60%;\n\t\t}\n\t}\n\n\t.cfgConfigurator {\n\t\t@include mixins.cfgRootStyles;\n\t\t@include mixins.cfgDefaultFont;\n\t\tfont-size: $fontSize;\n\t\tcolor: $textColor;\n\t\tmin-width: 0;\n\n\t\theight: 100%;\n\t\tdisplay: flex;\n\t\tflex-direction: column;\n\t\tflex: 0 0 50%;\n\t\toverflow: auto;\n\n\t\t@media screen and (orientation: landscape) {\n\t\t\theight: 100%;\n\t\t\tflex: 0 1 40%;\n\t\t}\n\t}\n\n\t.cfgConfiguratorHeader {\n\t\tborder-bottom: 0.1em solid $headerUnderlineColor;\n\t\tpadding: 1.7em 1.7em 1.9em;\n\t\tposition: relative;\n\n\t\t&__actions {\n\t\t\tmargin-top: 1em;\n\t\t}\n\t}\n\n\t.cfgConfiguratorTree {\n\t\tpadding-top: 1em;\n\t\toverflow-y: auto;\n\t\t-webkit-overflow-scrolling: touch;\n\t}\n}\n","/**\n * Web UI Variables\n */\n\t\n$baseFontSize: 10px !default; // We use 10px for easy em conversion\n$overlayingZIndex: 1000 !default;\n","@use \"../mixins\";\n\n@mixin classes($color) {\n\t.cfgDownloadIcon {\n\t\t/* The distance-units inside the icon are px even though everything\n\t\t else is relative units. The SVG has its own coordinate space. */\n\n\t\t@include mixins.cfgRootStyles;\n\n\t\tdisplay: inline-block;\n\t\twidth: 100%;\n\t\theight: 100%;\n\n\t\tpath,\n\t\tcircle {\n\t\t\tstroke: $color;\n\t\t\tstroke-linecap: round;\n\t\t\tstroke-linejoin: round;\n\t\t\tstroke-width: 1.5;\n\t\t}\n\n\t\t@content;\n\t}\n}\n","@use \"mixins\";\n\n@mixin classes {\n\t.cfgExpandableHeadingRow {\n\t\t@include mixins.cfgRootStyles;\n\t\t@include mixins.noButtonLook;\n\t\talign-items: stretch;\n\t\tdisplay: flex;\n\t\theight: 3.9em;\n\t\toutline: 0;\n\t\tposition: relative;\n\t\twidth: 100%;\n\n\t\t&--expandable {\n\t\t\tcursor: pointer;\n\t\t}\n\n\t\t&__title {\n\t\t\talign-items: center;\n\t\t\tdisplay: flex;\n\t\t\tflex: 1 1 auto;\n\t\t\tfont-size: 1.5em;\n\t\t\tfont-weight: 500;\n\t\t\tjustify-content: flex-start;\n\t\t}\n\n\t\t&__icon {\n\t\t\talign-items: center;\n\t\t\tdisplay: flex;\n\t\t\tflex: 0 0 5em;\n\t\t\tjustify-content: center;\n\t\t\tpadding: 0 1.5em;\n\t\t}\n\n\t\t@content;\n\t}\n}\n","@use \"../mixins\";\n\n@mixin classes($color) {\n\t.cfgErrorIcon {\n\t\t/* The distance-units inside the icon are px even though everything\n\t\t else is relative units. The SVG has its own coordinate space. */\n\n\t\t@include mixins.cfgRootStyles;\n\n\t\tdisplay: inline-block;\n\t\twidth: 100%;\n\t\theight: 100%;\n\n\t\tpath,\n\t\tcircle {\n\t\t\tstroke: $color;\n\t\t\tstroke-linecap: round;\n\t\t\tstroke-linejoin: round;\n\t\t\tstroke-width: 1.5;\n\t\t}\n\n\t\t@content;\n\t}\n}\n","/**\n * Web UI Feature item\n */\n\n@use \"mixins\";\n\n@mixin classes(\n\t$textColor,\n\t$grayTextColor,\n\t$checkButtonUncheckedColor,\n\t$checkButtonCheckedColor,\n\t$focusOutlineInnerColor,\n\t$focusOutlineOuterColor,\n\t$dividerDark\n) {\n\t.cfgThumbnailImage {\n\t\tborder-radius: 0.7em;\n\t\tdisplay: inline-block;\n\t\theight: 3em;\n\t\twidth: 3em;\n\t}\n\n\t.cfgThumbnailPlaceholder {\n\t\talign-items: center;\n\t\tdisplay: flex;\n\t\tflex: 0 0 4.2em;\n\t\tjustify-content: flex-start;\n\t}\n\n\t.cfgFeatureItem {\n\t\t@include mixins.cfgRootStyles;\n\n\t\tcolor: $textColor;\n\n\t\t&__dropdown {\n\t\t\t@include mixins.noButtonLook;\n\t\t\talign-items: stretch;\n\t\t\tdisplay: flex;\n\t\t\theight: 3.9em;\n\t\t\toutline: 0;\n\t\t\tposition: relative;\n\t\t\twidth: 100%;\n\t\t\tcursor: pointer;\n\t\t}\n\n\t\t&--optional {\n\t\t\tmargin-top: 1em;\n\t\t}\n\n\t\t&__hiddenInput {\n\t\t\tleft: -99999px;\n\t\t\topacity: 0;\n\t\t\tposition: absolute;\n\t\t\tz-index: -1;\n\t\t}\n\n\t\t&__radio {\n\t\t\t@include mixins.cfgRadio($checkButtonUncheckedColor);\n\t\t}\n\n\t\t&__checkbox {\n\t\t\t@include mixins.cfgCheckbox($checkButtonUncheckedColor);\n\t\t}\n\n\t\t/* The &-syntax brings in the entire path, so the second part of this rule must be explicit */\n\n\t\t&__hiddenInput:focus ~ .cfgFeatureItem__radio,\n\t\t&__hiddenInput:focus ~ .cfgFeatureItem__checkbox {\n\t\t\t@include mixins.focusOutline($focusOutlineInnerColor, $focusOutlineOuterColor);\n\t\t}\n\n\t\t&__hiddenInput:checked ~ .cfgFeatureItem__radio {\n\t\t\t@include mixins.cfgRadio($checkButtonCheckedColor);\n\t\t}\n\t\t&__hiddenInput:checked ~ .cfgFeatureItem__checkbox {\n\t\t\t@include mixins.cfgCheckbox($checkButtonCheckedColor);\n\t\t}\n\n\t\t&.cfgAdditionalProduct {\n\t\t\t> .cfgExpandableHeadingRow {\n\t\t\t\t> .cfgExpandableHeadingRow__title {\n\t\t\t\t\tfont-weight: 600;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t> .cfgFeatureItem__hr {\n\t\t\t\tborder-bottom-color: $dividerDark;\n\t\t\t}\n\n\t\t\t/* The last themathic break (hr) we move under the next thematic break so it appears as one */\n\t\t\t.cfgFeatureItem:last-child .cfgFeatureItem__hr {\n\t\t\t\tmargin-bottom: -0.1em;\n\t\t\t}\n\t\t}\n\t}\n\n\t.cfgFeatureItemOptional__titleWrapper,\n\t.cfgFeatureItemOption__titleWrapper {\n\t\tflex: 1 1 auto;\n\t\tmargin-left: 1em;\n\t}\n\n\t.cfgFeatureItemOptional__title,\n\t.cfgFeatureItemOption__title {\n\t\tfont-size: 1.5em;\n\t}\n\n\t.cfgFeatureItemOption__price {\n\t\tfont-weight: 600;\n\t\tfont-size: 0.75em;\n\t\tcolor: $grayTextColor;\n\t}\n\n\t.cfgOptionTree--subLevel .cfgFeatureItem__hr {\n\t\tdisplay: none;\n\t}\n\n\t.cfgFeatureItemOption {\n\t\talign-items: center;\n\t\tdisplay: flex;\n\t}\n\n\t.cfgFeatureItemOptional {\n\t\talign-items: center;\n\t\tdisplay: flex;\n\t\tjustify-content: center;\n\t\tmargin-top: 0.5em;\n\n\t\t&__header {\n\t\t\tfont-size: 1.2em;\n\t\t\tfont-weight: 600;\n\t\t\tmargin: 0 0 0.3em 0;\n\t\t\tpadding: 0;\n\t\t\ttext-transform: uppercase;\n\t\t}\n\t}\n}\n","@mixin classes($borderColor) {\n\t.cfgInput,\n\t.cfgFormSelect {\n\t\tborder: 0.1em solid $borderColor;\n\t\tpadding: 0.3em 0.4em;\n\t\tborder-radius: 0.3em;\n\t}\n\n\t.cfgFormSelect {\n\t\tselect {\n\t\t\tappearance: none;\n\t\t\tpadding: 0 1em 0 0;\n\t\t\tmargin: 0;\n\t\t\twidth: 100%;\n\n\t\t\tbackground-color: transparent;\n\t\t\tfont-family: inherit;\n\t\t\tfont-size: inherit;\n\t\t\tfont-weight: inherit;\n\t\t\tcursor: inherit;\n\t\t\tline-height: inherit;\n\t\t\toutline: none;\n\t\t\tborder: none;\n\t\t}\n\n\t\tcursor: pointer;\n\t\tposition: relative;\n\n\t\t&::after {\n\t\t\tposition: absolute;\n\t\t\tright: 0.35em;\n\t\t\ttop: 50%;\n\t\t\tmargin-top: -0.55em;\n\t\t\tcontent: \"\";\n\t\t\twidth: 1em;\n\t\t\theight: 1em;\n\t\t\tbackground-color: $borderColor;\n\t\t\tclip-path: polygon(50% 80%, 90% 40%, 100% 50%, 50% 100%, 0 50%, 10% 40%);\n\t\t\tjustify-self: end;\n\t\t}\n\t}\n}\n","@use \"mixins\";\n\n@mixin styles($color) {\n\t@include mixins.cfgRootStyles;\n\tborder: 0;\n\tborder-bottom: 0.1em solid $color;\n\tpadding: 0;\n\tmargin: 0;\n}\n\n@mixin classes($color) {\n\t.cfgHr {\n\t\t@include styles($color);\n\t\t@content;\n\t}\n}\n","/**\n * Web UI Loading\n */\n\n@use \"mixins\";\n\n@mixin classes(\n\t$textColor,\n\t$spinnerColor1,\n\t$spinnerColor2,\n\t$overlayBackgroundColor,\n\t$overlayingZIndex\n) {\n\t.cfgCenteredLoading {\n\t\t@include mixins.cfgRootStyles;\n\t\talign-items: center;\n\t\tdisplay: flex;\n\t\tflex-direction: column;\n\t\theight: 100%;\n\t\tjustify-content: center;\n\t\twidth: 100%;\n\t}\n\n\t.cfgOverlayLoading {\n\t\t@include mixins.cfgRootStyles;\n\n\t\talign-items: center;\n\t\tbackground-color: $overlayBackgroundColor;\n\t\tbottom: 0;\n\t\tdisplay: flex;\n\t\tflex-direction: column;\n\t\tjustify-content: center;\n\t\tleft: 0;\n\t\tposition: absolute;\n\t\tright: 0;\n\t\ttop: 0;\n\t\tz-index: $overlayingZIndex;\n\n\t\t&--clickThrough {\n\t\t\tbackground-color: transparent;\n\t\t\tpointer-events: none;\n\n\t\t\t.cfgLoadingWithText {\n\t\t\t\tpadding: 2em 2em 1.8em;\n\t\t\t\tborder-radius: 0.8em;\n\t\t\t\tbackground-color: $overlayBackgroundColor;\n\t\t\t\topacity: 0.8;\n\t\t\t\tborder: 0.1em solid $spinnerColor2;\n\t\t\t}\n\t\t}\n\n\t\t&--fullWindow {\n\t\t\tposition: fixed;\n\t\t\tz-index: #{$overlayingZIndex + 1};\n\t\t}\n\t}\n\n\t.cfgLoadingWithText {\n\t\t@include mixins.cfgRootStyles;\n\t\t@include mixins.cfgDefaultFont;\n\n\t\ttext-align: center;\n\n\t\t&__text {\n\t\t\tcolor: $textColor;\n\t\t\tfont-weight: 600;\n\t\t\tmargin-top: 0.5em;\n\t\t\tfont-size: 1.6em;\n\t\t}\n\t}\n\n\t.cfgLoading {\n\t\t@include mixins.cfgRootStyles;\n\n\t\tanimation: rotate 1.1s linear 0s infinite;\n\t\tborder-radius: 100%;\n\t\tborder: 0.5em solid $spinnerColor2;\n\t\tborder-bottom-color: $spinnerColor1;\n\t\tdisplay: inline-block;\n\t\theight: 3em;\n\t\twidth: 3em;\n\n\t\t&--small {\n\t\t\tborder-width: 0.4em;\n\t\t\theight: 2em;\n\t\t\twidth: 2em;\n\t\t}\n\t}\n\n\t@keyframes rotate {\n\t\tfrom {\n\t\t\ttransform: rotate(0deg);\n\t\t}\n\t\tto {\n\t\t\ttransform: rotate(360deg);\n\t\t}\n\t}\n}\n","/**\n * Web UI Option tree\n */\n\n@use \"mixins\";\n\n@mixin classes {\n\t.cfgOptionTree {\n\t\t@include mixins.cfgRootStyles;\n\n\t\tlist-style: none;\n\t\tmargin: 0;\n\t\tpadding: 0;\n\n\t\t&--topLevel {\n\t\t\tpadding-left: 1.7em;\n\t\t}\n\n\t\t&--indent {\n\t\t\tmargin-left: 3.2em;\n\t\t}\n\n\t\t&--compThumb {\n\t\t\tmargin-left: 4.2em;\n\t\t}\n\n\t\t@content;\n\t}\n}\n","/**\n * Web UI Product information\n */\n\n@use \"sass:math\";\n@use \"mixins\";\n\n@mixin classes($textColor) {\n\t.cfgProductInfo {\n\t\t@include mixins.cfgRootStyles;\n\n\t\tcolor: $textColor;\n\n\t\tdisplay: flex;\n\n\t\t&__left {\n\t\t\tflex: 1 1 auto;\n\t\t\tmin-width: 0;\n\t\t\toverflow: hidden;\n\t\t}\n\n\t\t&__right {\n\t\t\talign-items: flex-end;\n\t\t\tdisplay: flex;\n\t\t\tflex-direction: column;\n\t\t\tflex: 1 0 auto;\n\t\t\tmargin-left: 1em;\n\t\t\tmax-width: 0.333333333;\n\t\t\tmin-width: 0;\n\t\t}\n\n\t\t&__name {\n\t\t\tdisplay: block;\n\t\t\tfont-size: 1.6em;\n\t\t\tfont-weight: 600;\n\t\t\tline-height: 1.33;\n\t\t\tmargin: 0;\n\t\t}\n\n\t\t&__number {\n\t\t\tfont-size: 1.3em;\n\t\t\tfont-weight: 400;\n\t\t\tline-height: 1.38;\n\t\t\tmargin: 0;\n\t\t}\n\n\t\t@content;\n\t}\n}\n","@mixin classes($errorColor) {\n\t.cfgRangeView {\n\t\t&__inputs {\n\t\t\tdisplay: flex;\n\t\t\talign-items: center;\n\t\t}\n\n\t\t&__number-input {\n\t\t\tfont-size: 1.5em;\n\t\t\tflex-grow: 1;\n\t\t\ttext-align: right;\n\t\t}\n\n\t\t&__unit-label {\n\t\t\tfont-size: 1.5em;\n\t\t\tmargin-left: 0.3em;\n\t\t}\n\n\t\t&__slider-input.cfgSlider {\n\t\t\tmargin-left: 1em;\n\t\t\tflex-grow: 3;\n\t\t}\n\n\t\t&__error {\n\t\t\tdisplay: flex;\n\t\t\talign-items: center;\n\n\t\t\tmargin-top: 1em;\n\t\t\tfont-size: 1.5em;\n\t\t\tcolor: $errorColor;\n\n\t\t\t.cfgErrorIcon {\n\t\t\t\tpadding-right: 0.25em;\n\t\t\t\twidth: 1.25em;\n\t\t\t\theight: 1em;\n\t\t\t}\n\t\t}\n\t}\n}\n","@use \"mixins\";\n\n// The origins of this SCSS file is here:\n// https://css-tricks.com/sliding-nightmare-understanding-range-input/\n\n$trackHeight: 0.2em !default;\n$thumbDiameter: 2.8em !default;\n\n@mixin track($trackColor) {\n\tbox-sizing: border-box;\n\tborder: none;\n\theight: $trackHeight;\n\tbackground: $trackColor;\n}\n\n@mixin thumb($thumbColor, $thumbShadowColor) {\n\tbox-sizing: border-box;\n\tborder: none;\n\twidth: $thumbDiameter;\n\theight: $thumbDiameter;\n\tborder-radius: 50%;\n\tbackground: $thumbColor;\n\tbox-shadow: 0 0.15em 0.45em 0.05em $thumbShadowColor;\n}\n\n@mixin classes($trackColor, $thumbColor, $thumbShadowColor) {\n\t.cfgSlider {\n\t\t@include mixins.cfgRootStyles;\n\n\t\t&,\n\t\t&::-webkit-slider-thumb {\n\t\t\t-webkit-appearance: none;\n\t\t}\n\n\t\tflex: 1;\n\t\tmargin: 0;\n\t\tpadding: 0;\n\t\tmin-height: $thumbDiameter;\n\t\tbackground: transparent;\n\t\tfont: inherit;\n\n\t\t&::-webkit-slider-runnable-track {\n\t\t\t@include track($trackColor);\n\t\t}\n\t\t&::-moz-range-track {\n\t\t\t@include track($trackColor);\n\t\t}\n\t\t&::-ms-track {\n\t\t\t@include track($trackColor);\n\t\t}\n\n\t\t&::-webkit-slider-thumb {\n\t\t\tmargin-top: 0.5 * ($trackHeight - $thumbDiameter);\n\t\t\t@include thumb($thumbColor, $thumbShadowColor);\n\t\t}\n\t\t&::-moz-range-thumb {\n\t\t\t@include thumb($thumbColor, $thumbShadowColor);\n\t\t}\n\t\t&::-ms-thumb {\n\t\t\tmargin-top: 0;\n\t\t\t@include thumb($thumbColor, $thumbShadowColor);\n\t\t}\n\n\t\t&::-ms-tooltip {\n\t\t\tdisplay: none;\n\t\t}\n\n\t\t@content;\n\t}\n}\n","@use \"mixins\";\n\n@mixin classes($borderColor, $linkColor) {\n\t$preview-size: 4.8em;\n\t$line-width: 0.1em;\n\t$icon-size: 2em;\n\n\t.cfgTaskList {\n\t\tul {\n\t\t\tlist-style-type: none;\n\t\t\tpadding: 0;\n\t\t\tmargin: 1em 0 0 0;\n\t\t\tborder-bottom: 0.1em solid $borderColor;\n\t\t}\n\n\t\t&__item {\n\t\t\tpadding: 0 1.5em 0 1.7em;\n\t\t\tmargin-bottom: 1em;\n\t\t\tdisplay: flex;\n\t\t\talign-items: center;\n\t\t}\n\n\t\t&__preview {\n\t\t\tborder: 0.1em solid $borderColor;\n\t\t\tborder-radius: 10%;\n\t\t\twidth: $preview-size;\n\t\t\theight: $preview-size;\n\t\t\tflex-shrink: 0;\n\n\t\t\timg {\n\t\t\t\tobject-fit: cover;\n\t\t\t\tposition: relative;\n\t\t\t\tleft: 0.1 * $preview-size - $line-width;\n\t\t\t\ttop: 0.1 * $preview-size - $line-width;\n\t\t\t\twidth: 0.8 * $preview-size;\n\t\t\t\theight: 0.8 * $preview-size;\n\t\t\t}\n\t\t}\n\n\t\t&__icon {\n\t\t\tflex-shrink: 0;\n\t\t\twidth: $icon-size + 2em;\n\t\t\theight: $icon-size;\n\t\t\tpadding-left: 1em;\n\t\t\tpadding-right: 1em;\n\n\t\t\t.cfgLoadingSizer {\n\t\t\t\tfont-size: 0.75em;\n\t\t\t}\n\t\t}\n\n\t\t&__status {\n\t\t\tflex-grow: 1;\n\t\t\tfont-size: 1.5em;\n\t\t}\n\n\t\t&__abort {\n\t\t\t@include mixins.noButtonLook;\n\t\t\tcursor: pointer;\n\t\t\twidth: $icon-size;\n\t\t\theight: $icon-size;\n\t\t\tflex-shrink: 0;\n\t\t}\n\n\t\t&__restart {\n\t\t\t@include mixins.noButtonLook;\n\t\t\tcursor: pointer;\n\t\t\ttext-decoration: underline;\n\t\t\tcolor: $linkColor;\n\t\t}\n\t}\n}\n"]}
package/dist/index.d.ts CHANGED
@@ -1,23 +1,23 @@
1
- export * from "./components/CanvasWrapper.js";
2
- export * from "./components/Configurator.js";
3
- export * from "./components/ConfiguratorWrapper.js";
4
- export * from "./components/CurrencyPrice.js";
5
- export * from "./components/ExpandableHeadingRow.js";
6
- export * from "./components/icons/Checkmark.js";
7
- export * from "./components/icons/Chevron.js";
8
- export * from "./components/Loading.js";
9
- export * from "./components/productConfiguration/CfgCheckboxesView.js";
10
- export * from "./components/productConfiguration/CfgCheckboxView.js";
11
- export * from "./components/productConfiguration/CfgDropdownOptionView.js";
12
- export * from "./components/productConfiguration/CfgDropdownView.js";
13
- export * from "./components/productConfiguration/CfgFeatureView.js";
14
- export * from "./components/productConfiguration/CfgGroupView.js";
15
- export * from "./components/productConfiguration/CfgProductConfigurationView.js";
16
- export * from "./components/ProductInformation.js";
17
- export * from "./components/TaskListView.js";
18
- export * from "./components/TaskStartView.js";
19
- export * from "./useObservable.js";
20
- export * from "./useRerender.js";
21
- export * from "./useResize.js";
22
- export * from "./useUniqueId.js";
1
+ export * from "./components/CanvasWrapper.js";
2
+ export * from "./components/Configurator.js";
3
+ export * from "./components/ConfiguratorWrapper.js";
4
+ export * from "./components/CurrencyPrice.js";
5
+ export * from "./components/ExpandableHeadingRow.js";
6
+ export * from "./components/icons/Checkmark.js";
7
+ export * from "./components/icons/Chevron.js";
8
+ export * from "./components/Loading.js";
9
+ export * from "./components/productConfiguration/CfgCheckboxesView.js";
10
+ export * from "./components/productConfiguration/CfgCheckboxView.js";
11
+ export * from "./components/productConfiguration/CfgDropdownOptionView.js";
12
+ export * from "./components/productConfiguration/CfgDropdownView.js";
13
+ export * from "./components/productConfiguration/CfgFeatureView.js";
14
+ export * from "./components/productConfiguration/CfgGroupView.js";
15
+ export * from "./components/productConfiguration/CfgProductConfigurationView.js";
16
+ export * from "./components/ProductInformation.js";
17
+ export * from "./components/TaskListView.js";
18
+ export * from "./components/TaskStartView.js";
19
+ export * from "./useObservable.js";
20
+ export * from "./useRerender.js";
21
+ export * from "./useResize.js";
22
+ export * from "./useUniqueId.js";
23
23
  //# sourceMappingURL=index.d.ts.map
package/dist/index.js CHANGED
@@ -1,22 +1,22 @@
1
- export * from "./components/CanvasWrapper.js";
2
- export * from "./components/Configurator.js";
3
- export * from "./components/ConfiguratorWrapper.js";
4
- export * from "./components/CurrencyPrice.js";
5
- export * from "./components/ExpandableHeadingRow.js";
6
- export * from "./components/icons/Checkmark.js";
7
- export * from "./components/icons/Chevron.js";
8
- export * from "./components/Loading.js";
9
- export * from "./components/productConfiguration/CfgCheckboxesView.js";
10
- export * from "./components/productConfiguration/CfgCheckboxView.js";
11
- export * from "./components/productConfiguration/CfgDropdownOptionView.js";
12
- export * from "./components/productConfiguration/CfgDropdownView.js";
13
- export * from "./components/productConfiguration/CfgFeatureView.js";
14
- export * from "./components/productConfiguration/CfgGroupView.js";
15
- export * from "./components/productConfiguration/CfgProductConfigurationView.js";
16
- export * from "./components/ProductInformation.js";
17
- export * from "./components/TaskListView.js";
18
- export * from "./components/TaskStartView.js";
19
- export * from "./useObservable.js";
20
- export * from "./useRerender.js";
21
- export * from "./useResize.js";
22
- export * from "./useUniqueId.js";
1
+ export * from "./components/CanvasWrapper.js";
2
+ export * from "./components/Configurator.js";
3
+ export * from "./components/ConfiguratorWrapper.js";
4
+ export * from "./components/CurrencyPrice.js";
5
+ export * from "./components/ExpandableHeadingRow.js";
6
+ export * from "./components/icons/Checkmark.js";
7
+ export * from "./components/icons/Chevron.js";
8
+ export * from "./components/Loading.js";
9
+ export * from "./components/productConfiguration/CfgCheckboxesView.js";
10
+ export * from "./components/productConfiguration/CfgCheckboxView.js";
11
+ export * from "./components/productConfiguration/CfgDropdownOptionView.js";
12
+ export * from "./components/productConfiguration/CfgDropdownView.js";
13
+ export * from "./components/productConfiguration/CfgFeatureView.js";
14
+ export * from "./components/productConfiguration/CfgGroupView.js";
15
+ export * from "./components/productConfiguration/CfgProductConfigurationView.js";
16
+ export * from "./components/ProductInformation.js";
17
+ export * from "./components/TaskListView.js";
18
+ export * from "./components/TaskStartView.js";
19
+ export * from "./useObservable.js";
20
+ export * from "./useRerender.js";
21
+ export * from "./useResize.js";
22
+ export * from "./useUniqueId.js";
@@ -1,36 +1,36 @@
1
- /**
2
- * Web UI Product information
3
- */
4
- @use "mixins";
5
-
6
- @mixin styles($textColor, $borderColor, $focusOutlineInnerColor, $focusOutlineOuterColor) {
7
- @include mixins.cfgRootStyles;
8
- display: inline-block;
9
- background-color: transparent;
10
- color: $textColor;
11
- border-radius: 0.3em;
12
- border: 0.1em solid $borderColor;
13
- font-size: 1.3em;
14
- font-weight: 500;
15
- outline: none;
16
- padding: 0.4em 0.8em;
17
-
18
- &:focus {
19
- @include mixins.focusOutline($focusOutlineInnerColor, $focusOutlineOuterColor);
20
- }
21
- }
22
-
23
- @mixin classes($textColor, $borderColor, $focusOutlineInnerColor, $focusOutlineOuterColor) {
24
- .cfgButton {
25
- @include styles($textColor, $borderColor, $focusOutlineInnerColor, $focusOutlineOuterColor);
26
- }
27
-
28
- .cfgButtonRow {
29
- @include mixins.cfgRootStyles;
30
- &__button {
31
- &:nth-child(n + 2) {
32
- margin-left: 1em;
33
- }
34
- }
35
- }
36
- }
1
+ /**
2
+ * Web UI Product information
3
+ */
4
+ @use "mixins";
5
+
6
+ @mixin styles($textColor, $borderColor, $focusOutlineInnerColor, $focusOutlineOuterColor) {
7
+ @include mixins.cfgRootStyles;
8
+ display: inline-block;
9
+ background-color: transparent;
10
+ color: $textColor;
11
+ border-radius: 0.3em;
12
+ border: 0.1em solid $borderColor;
13
+ font-size: 1.3em;
14
+ font-weight: 500;
15
+ outline: none;
16
+ padding: 0.4em 0.8em;
17
+
18
+ &:focus {
19
+ @include mixins.focusOutline($focusOutlineInnerColor, $focusOutlineOuterColor);
20
+ }
21
+ }
22
+
23
+ @mixin classes($textColor, $borderColor, $focusOutlineInnerColor, $focusOutlineOuterColor) {
24
+ .cfgButton {
25
+ @include styles($textColor, $borderColor, $focusOutlineInnerColor, $focusOutlineOuterColor);
26
+ }
27
+
28
+ .cfgButtonRow {
29
+ @include mixins.cfgRootStyles;
30
+ &__button {
31
+ &:nth-child(n + 2) {
32
+ margin-left: 1em;
33
+ }
34
+ }
35
+ }
36
+ }
@@ -1,87 +1,87 @@
1
- /**
2
- * Web UI Configurator
3
- */
4
-
5
- @use "mixins";
6
-
7
- @mixin classes($fontSize, $textColor, $headerUnderlineColor) {
8
- .cfgConfiguratorWrapper {
9
- @include mixins.cfgRootStyles;
10
- color: $textColor;
11
- display: flex;
12
- height: 85vh;
13
- flex-direction: column;
14
-
15
- @media screen and (orientation: landscape) {
16
- flex-direction: row;
17
- }
18
-
19
- .cfgTaskStart {
20
- margin-top: 0.5em;
21
- font-size: 1.2em;
22
- font-weight: 500;
23
-
24
- .cfgFormSelect {
25
- padding: 0.5em;
26
-
27
- &::after {
28
- right: 0.5em;
29
- }
30
- }
31
- }
32
- }
33
-
34
- .cfgCanvasWrapper {
35
- @include mixins.cfgRootStyles;
36
- position: relative;
37
- height: 50rem;
38
- user-select: none;
39
-
40
- flex: 1 1 auto;
41
- overflow: hidden;
42
-
43
- & canvas {
44
- outline: none;
45
- }
46
-
47
- @media screen and (orientation: landscape) {
48
- height: 100%;
49
- flex: 0 1 60%;
50
- }
51
- }
52
-
53
- .cfgConfigurator {
54
- @include mixins.cfgRootStyles;
55
- @include mixins.cfgDefaultFont;
56
- font-size: $fontSize;
57
- color: $textColor;
58
- min-width: 0;
59
-
60
- height: 100%;
61
- display: flex;
62
- flex-direction: column;
63
- flex: 0 0 50%;
64
- overflow: auto;
65
-
66
- @media screen and (orientation: landscape) {
67
- height: 100%;
68
- flex: 0 1 40%;
69
- }
70
- }
71
-
72
- .cfgConfiguratorHeader {
73
- border-bottom: 0.1em solid $headerUnderlineColor;
74
- padding: 1.7em 1.7em 1.9em;
75
- position: relative;
76
-
77
- &__actions {
78
- margin-top: 1em;
79
- }
80
- }
81
-
82
- .cfgConfiguratorTree {
83
- padding-top: 1em;
84
- overflow-y: auto;
85
- -webkit-overflow-scrolling: touch;
86
- }
87
- }
1
+ /**
2
+ * Web UI Configurator
3
+ */
4
+
5
+ @use "mixins";
6
+
7
+ @mixin classes($fontSize, $textColor, $headerUnderlineColor) {
8
+ .cfgConfiguratorWrapper {
9
+ @include mixins.cfgRootStyles;
10
+ color: $textColor;
11
+ display: flex;
12
+ height: 85vh;
13
+ flex-direction: column;
14
+
15
+ @media screen and (orientation: landscape) {
16
+ flex-direction: row;
17
+ }
18
+
19
+ .cfgTaskStart {
20
+ margin-top: 0.5em;
21
+ font-size: 1.2em;
22
+ font-weight: 500;
23
+
24
+ .cfgFormSelect {
25
+ padding: 0.5em;
26
+
27
+ &::after {
28
+ right: 0.5em;
29
+ }
30
+ }
31
+ }
32
+ }
33
+
34
+ .cfgCanvasWrapper {
35
+ @include mixins.cfgRootStyles;
36
+ position: relative;
37
+ height: 50rem;
38
+ user-select: none;
39
+
40
+ flex: 1 1 auto;
41
+ overflow: hidden;
42
+
43
+ & canvas {
44
+ outline: none;
45
+ }
46
+
47
+ @media screen and (orientation: landscape) {
48
+ height: 100%;
49
+ flex: 0 1 60%;
50
+ }
51
+ }
52
+
53
+ .cfgConfigurator {
54
+ @include mixins.cfgRootStyles;
55
+ @include mixins.cfgDefaultFont;
56
+ font-size: $fontSize;
57
+ color: $textColor;
58
+ min-width: 0;
59
+
60
+ height: 100%;
61
+ display: flex;
62
+ flex-direction: column;
63
+ flex: 0 0 50%;
64
+ overflow: auto;
65
+
66
+ @media screen and (orientation: landscape) {
67
+ height: 100%;
68
+ flex: 0 1 40%;
69
+ }
70
+ }
71
+
72
+ .cfgConfiguratorHeader {
73
+ border-bottom: 0.1em solid $headerUnderlineColor;
74
+ padding: 1.7em 1.7em 1.9em;
75
+ position: relative;
76
+
77
+ &__actions {
78
+ margin-top: 1em;
79
+ }
80
+ }
81
+
82
+ .cfgConfiguratorTree {
83
+ padding-top: 1em;
84
+ overflow-y: auto;
85
+ -webkit-overflow-scrolling: touch;
86
+ }
87
+ }