@itwin/editor-frontend 4.5.0-dev.7 → 4.5.0-dev.8

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 (32) hide show
  1. package/lib/cjs/CreateElementTool.js.map +1 -1
  2. package/lib/cjs/DeleteElementsTool.js.map +1 -1
  3. package/lib/cjs/EditTool.js.map +1 -1
  4. package/lib/cjs/EditToolIpc.js.map +1 -1
  5. package/lib/cjs/ElementGeometryTool.js.map +1 -1
  6. package/lib/cjs/ModifyCurveTools.js.map +1 -1
  7. package/lib/cjs/ModifyElementTool.js.map +1 -1
  8. package/lib/cjs/ProjectLocation/ProjectExtentsDecoration.js.map +1 -1
  9. package/lib/cjs/ProjectLocation/ProjectGeolocation.js.map +1 -1
  10. package/lib/cjs/SketchTools.js.map +1 -1
  11. package/lib/cjs/SolidModelingTools.js.map +1 -1
  12. package/lib/cjs/SolidPrimitiveTools.js.map +1 -1
  13. package/lib/cjs/TransformElementsTool.js.map +1 -1
  14. package/lib/cjs/UndoRedoTool.js.map +1 -1
  15. package/lib/cjs/editor-frontend.js.map +1 -1
  16. package/lib/esm/CreateElementTool.js.map +1 -1
  17. package/lib/esm/DeleteElementsTool.js.map +1 -1
  18. package/lib/esm/EditTool.js.map +1 -1
  19. package/lib/esm/EditToolIpc.js.map +1 -1
  20. package/lib/esm/ElementGeometryTool.js.map +1 -1
  21. package/lib/esm/ModifyCurveTools.js.map +1 -1
  22. package/lib/esm/ModifyElementTool.js.map +1 -1
  23. package/lib/esm/ProjectLocation/ProjectExtentsDecoration.js.map +1 -1
  24. package/lib/esm/ProjectLocation/ProjectGeolocation.js.map +1 -1
  25. package/lib/esm/SketchTools.js.map +1 -1
  26. package/lib/esm/SolidModelingTools.js.map +1 -1
  27. package/lib/esm/SolidPrimitiveTools.js.map +1 -1
  28. package/lib/esm/TransformElementsTool.js.map +1 -1
  29. package/lib/esm/UndoRedoTool.js.map +1 -1
  30. package/lib/esm/editor-frontend.js.map +1 -1
  31. package/lib/public/locales/en/Editor.json +490 -490
  32. package/package.json +14 -14
@@ -1 +1 @@
1
- {"version":3,"file":"ModifyCurveTools.js","sourceRoot":"","sources":["../../src/ModifyCurveTools.ts"],"names":[],"mappings":";AAAA;;;+FAG+F;;;AAE/F,0DAAyI;AACzI,sDAAoE;AACpE,oDAG4B;AAC5B,wDAG8B;AAC9B,wDAG8B;AAC9B,wDAA2D;AAC3D,yCAAuC;AACvC,+CAAqD;AACrD,2DAAoE;AAEpE,aAAa;AACb,MAAa,SAAS;IAKpB,YAAY,KAA4B,EAAE,MAAsB,EAAE,IAAsC;QACtG,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IACnB,CAAC;CACF;AAVD,8BAUC;AAED,mEAAmE;AACnE,MAAsB,eAAgB,SAAQ,iDAA6B;IAI/D,KAAK,CAAC,YAAY;QAC1B,IAAI,SAAS,KAAK,IAAI,CAAC,WAAW;YAChC,OAAO,IAAI,CAAC,WAAW,CAAC;QAC1B,OAAO,oBAAS,CAAC,YAAY,CAAS,EAAE,SAAS,EAAE,mCAAmB,CAAC,oBAAoB,EAAE,SAAS,EAAE,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,CAAC;IAC7H,CAAC;IAEM,MAAM,CAAC,aAAa,CAAC,IAAyB;QACnD,MAAM,EAAE,GAAG,IAAI,6BAAe,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAC9C,EAAE,CAAC,uBAAuB,EAAE,CAAC;QAE7B,KAAK,MAAM,KAAK,IAAI,EAAE,EAAE;YACtB,MAAM,IAAI,GAAG,KAAK,CAAC,eAAe,EAAE,CAAC;YACrC,IAAI,SAAS,KAAK,IAAI;gBACpB,OAAO;YAET,IAAI,gBAAgB,KAAK,IAAI,CAAC,gBAAgB,EAAE;gBAC9C,OAAO,EAAE,KAAK,EAAE,IAAsB,EAAE,MAAM,EAAE,KAAK,CAAC,UAAU,EAAE,CAAC;aACpE;iBAAM,IAAI,iBAAiB,KAAK,IAAI,CAAC,gBAAgB,EAAE;gBACtD,OAAO,EAAE,KAAK,EAAE,IAAuB,EAAE,MAAM,EAAE,KAAK,CAAC,UAAU,EAAE,CAAC;aACrE;YAED,MAAM;SACP;QAED,OAAO;IACT,CAAC;IAEM,MAAM,CAAC,SAAS,CAAC,KAAuC,EAAE,KAAmC;QAClG,IAAI,gBAAgB,KAAK,KAAK,CAAC,gBAAgB;YAC7C,OAAO,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QAEhC,IAAI,CAAC,KAAK,CAAC,QAAQ;YACjB,OAAO,KAAK,CAAC;QAEf,KAAK,MAAM,KAAK,IAAI,KAAK,CAAC,QAAQ,EAAE;YAClC,IAAI,KAAK,YAAY,8BAAc,EAAE;gBACnC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC;oBACzB,OAAO,KAAK,CAAC;aAChB;iBAAM,IAAI,KAAK,YAAY,+BAAe,EAAE;gBAC3C,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,KAAK,CAAC;oBAC/B,OAAO,KAAK,CAAC;aAChB;SACF;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAES,WAAW,CAAC,MAAwC,IAAa,OAAO,IAAI,CAAC,CAAC,CAAC;IAC/E,WAAW,CAAC,GAAkB,EAAE,SAAkB,IAA+B,OAAO,SAAS,CAAC,CAAC,CAAC;IAEpG,KAAK,CAAC,YAAY,CAAC,EAAc;QACzC,IAAI;YACF,IAAI,CAAC,WAAW,GAAG,MAAM,IAAI,CAAC,YAAY,EAAE,CAAC;YAC7C,MAAM,MAAM,GAA4B,CAAC,mCAAqB,CAAC,QAAQ,EAAE,mCAAqB,CAAC,cAAc,EAAE,mCAAqB,CAAC,cAAc,EAAE,mCAAqB,CAAC,IAAI,CAAC,CAAC;YACjL,MAAM,IAAI,GAAG,MAAM,kCAAoB,CAAC,sBAAsB,CAAC,EAAE,EAAE,EAAE,cAAc,EAAE,CAAC,EAAE,MAAM,EAAE,QAAQ,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;YAC7J,IAAI,SAAS,KAAK,IAAI;gBACpB,OAAO,SAAS,CAAC;YAEnB,MAAM,IAAI,GAAG,eAAe,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;YACjD,IAAI,SAAS,KAAK,IAAI;gBACpB,OAAO,SAAS,CAAC;YAEnB,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC;gBAC/B,OAAO,SAAS,CAAC;YAEnB,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE,CAA0B,CAAC;YAChF,IAAI,SAAS,KAAK,KAAK;gBACrB,OAAO,SAAS,CAAC;YAEnB,OAAO,IAAI,SAAS,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;SACtD;QAAC,OAAO,GAAG,EAAE;YACZ,yBAAS,CAAC,aAAa,CAAC,aAAa,CAAC,IAAI,oCAAoB,CAAC,qCAAqB,CAAC,KAAK,EAAE,0BAAY,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YAChI,OAAO,SAAS,CAAC;SAClB;IACH,CAAC;IAEkB,KAAK,CAAC,2BAA2B,CAAC,EAAc;QACjE,OAAO,CAAC,SAAS,KAAK,MAAM,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAAC;IACrD,CAAC;IAEkB,KAAK,CAAC,gBAAgB;QACvC,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO;YACrB,OAAO;QAET,MAAM,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QACxD,IAAI,CAAC,SAAS,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC;IAC/C,CAAC;IAEkB,aAAa;QAC9B,MAAM,KAAK,GAAG,IAAI,mCAAmB,EAAE,CAAC;QAExC,KAAK,CAAC,mBAAmB,GAAG,IAAI,CAAC;QACjC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IACzB,CAAC;IAES,gBAAgB,CAAC,EAAiB,EAAE,QAAiB;QAC7D,IAAI,SAAS,KAAK,IAAI,CAAC,SAAS;YAC9B,OAAO;QAET,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,EAAE,EAAE,QAAQ,CAAC,CAAC;QAC5C,IAAI,SAAS,KAAK,IAAI;YACpB,OAAO;QAET,MAAM,OAAO,GAAG,IAAI,6BAAe,CAAC,OAAO,EAAE,CAAC;QAC9C,OAAO,CAAC,4BAA4B,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,SAAU,CAAC,CAAC;QAEtE,IAAI,CAAC,OAAO,CAAC,0BAA0B,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC;YAC5D,OAAO;QAET,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC,IAAI,CAAC;YACpC,OAAO;QAET,OAAO,EAAE,MAAM,EAAE,YAAY,EAAE,IAAI,EAAE,OAAO,CAAC,OAAO,EAAE,CAAC;IACzD,CAAC;IAES,eAAe,CAAC,EAAiB;QACzC,IAAI,SAAS,KAAK,IAAI,CAAC,SAAS;YAC9B,OAAO;QAET,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE;YAC5B,2EAA2E;YAC3E,MAAM,aAAa,GAAG,CAAC,EAAE,CAAC,QAAQ,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,wBAAwB,CAAC,CAAC,CAAC,wBAAwB,CAAC,CAAC;YACvG,OAAO,EAAE,aAAa,EAAE,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,EAAE,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,QAAQ,EAAE,IAAI,EAAE,kBAAI,CAAC,WAAW,EAAE,EAAE,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,SAAS,EAAE,CAAC;SAC3K;QAED,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC;IAC9B,CAAC;IAEkB,KAAK,CAAC,eAAe,CAAC,SAAgC;QACvE,IAAI;YACF,IAAI,CAAC,WAAW,GAAG,MAAM,IAAI,CAAC,YAAY,EAAE,CAAC;YAC7C,IAAI,SAAS,KAAK,SAAS,CAAC,EAAE,EAAE;gBAC9B,MAAM,eAAe,GAAG,IAAI,CAAC,8BAA8B,CAAC;gBAC5D,IAAI,eAAe;oBACjB,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;gBAEtB,MAAM,KAAK,GAAG,MAAM,kCAAoB,CAAC,sBAAsB,CAAC,SAAS,CAAC,CAAC;gBAE3E,IAAI,eAAe,IAAI,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC;oBAC3C,MAAM,IAAI,CAAC,gBAAgB,EAAE,CAAC;aACjC;iBAAM;gBACL,MAAM,kCAAoB,CAAC,sBAAsB,CAAC,SAAS,CAAC,CAAC;aAC9D;YACD,OAAO,IAAI,CAAC;SACb;QAAC,OAAO,GAAG,EAAE;YACZ,yBAAS,CAAC,aAAa,CAAC,aAAa,CAAC,IAAI,oCAAoB,CAAC,qCAAqB,CAAC,KAAK,EAAE,0BAAY,CAAC,eAAe,CAAC,GAAG,CAAC,IAAI,4BAA4B,CAAC,CAAC,CAAC;YAChK,OAAO,KAAK,CAAC;SACd;IACH,CAAC;IAED,IAAc,kBAAkB,KAAc,OAAO,IAAI,CAAC,CAAC,CAAC;IAC5D,IAAc,8BAA8B,KAAc,OAAO,KAAK,CAAC,CAAC,CAAC;IAEzD,KAAK,CAAC,iBAAiB;QACrC,yEAAyE;QACzE,IAAI,IAAI,CAAC,8BAA8B,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,SAAS,KAAK,IAAI,CAAC,SAAS;YAC7F,OAAO;QACT,OAAO,KAAK,CAAC,iBAAiB,EAAE,CAAC;IACnC,CAAC;CACF;AApKD,0CAoKC;AAED,6DAA6D;AAC7D,MAAa,eAAgB,SAAQ,eAAe;IAKlD,IAAW,mBAAmB;QAC5B,IAAI,CAAC,IAAI,CAAC,oBAAoB;YAC5B,IAAI,CAAC,oBAAoB,GAAG,IAAI,+BAAc,CAAU,0CAAyB,CAAC,4BAA4B,CAAC,mBAAmB,CAAC,EAAE,KAAK,CAAC,CAAC;QAC9I,OAAO,IAAI,CAAC,oBAAoB,CAAC;IACnC,CAAC;IAED,IAAW,WAAW,KAAc,OAAO,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC,CAAC;IAC5E,IAAW,WAAW,CAAC,KAAc,IAAI,IAAI,CAAC,mBAAmB,CAAC,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC;IAGlF,IAAW,gBAAgB;QACzB,IAAI,CAAC,IAAI,CAAC,iBAAiB;YACzB,IAAI,CAAC,iBAAiB,GAAG,IAAI,+BAAc,CAAS,IAAI,iCAAiB,CAAC,gBAAgB,EAAE,oBAAS,CAAC,SAAS,CAAC,4BAA4B,CAAC,CAAC,EAAE,GAAG,EAAE,SAAS,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACrL,OAAO,IAAI,CAAC,iBAAiB,CAAC;IAChC,CAAC;IAED,IAAW,QAAQ,KAAa,OAAO,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC,CAAC;IACrE,IAAW,QAAQ,CAAC,KAAa,IAAI,IAAI,CAAC,gBAAgB,CAAC,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC;IAG3E,IAAW,gBAAgB;QACzB,IAAI,CAAC,IAAI,CAAC,iBAAiB;YACzB,IAAI,CAAC,iBAAiB,GAAG,IAAI,+BAAc,CACzC,0CAAyB,CAAC,sBAAsB,CAAC,YAAY,EAAE,oBAAS,CAAC,SAAS,CAAC,4BAA4B,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC;QAC9H,OAAO,IAAI,CAAC,iBAAiB,CAAC;IAChC,CAAC;IAED,IAAW,QAAQ,KAAc,OAAO,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC,CAAC;IACtE,IAAW,QAAQ,CAAC,KAAc,IAAI,IAAI,CAAC,gBAAgB,CAAC,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC;IAEzD,4BAA4B,CAAC,QAA6B;QAC3E,OAAO,CAAC,QAAQ,KAAK,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;IACrF,CAAC;IAEe,KAAK,CAAC,8BAA8B,CAAC,YAAoC;QACvF,OAAO,IAAI,CAAC,8BAA8B,CAAC,YAAY,CAAC,CAAC;IAC3D,CAAC;IAEe,4BAA4B;QAC1C,IAAI,CAAC,mCAAmC,CAAC,CAAC,IAAI,CAAC,gBAAgB,EAAE,IAAI,CAAC,mBAAmB,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC;QAEnH,MAAM,YAAY,GAAG,IAAI,KAAK,EAAc,CAAC;QAE7C,4EAA4E;QAC5E,IAAI,CAAC,gBAAgB,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC;QACrD,MAAM,eAAe,GAAG,IAAI,CAAC,mBAAmB,CAAC,YAAY,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,CAAC,CAAC;QAClG,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,EAAE,eAAe,CAAC,CAAC,CAAC;QAC3G,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAE1F,OAAO,YAAY,CAAC;IACtB,CAAC;IAEkB,WAAW,CAAC,KAAuC;QACpE,IAAI,gBAAgB,KAAK,KAAK,CAAC,gBAAgB;YAC7C,OAAO,IAAI,CAAC;QAEd,OAAO,CAAC,KAAK,CAAC,UAAU,IAAI,KAAK,CAAC,YAAY,CAAC,CAAC;IAClD,CAAC;IAEkB,WAAW,CAAC,EAAiB,EAAE,QAAiB;QACjE,IAAI,SAAS,KAAK,EAAE,CAAC,QAAQ;YAC3B,OAAO,SAAS,CAAC;QAEnB,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC;QAClC,IAAI,SAAS,KAAK,IAAI;YACpB,OAAO,SAAS,CAAC;QAEnB,MAAM,MAAM,GAAG,mCAAmB,CAAC,kBAAkB,CAAC,EAAE,CAAC,QAAQ,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;QAC/E,MAAM,YAAY,GAAG,4BAAY,CAAC,sBAAsB,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;QACrF,IAAI,SAAS,KAAK,YAAY;YAC5B,OAAO,SAAS,CAAC;QAEnB,MAAM,YAAY,GAAG,YAAY,CAAC,OAAO,EAAE,CAAC;QAC5C,IAAI,SAAS,KAAK,YAAY;YAC5B,OAAO,SAAS,CAAC;QAEnB,MAAM,MAAM,GAAG,CAAC,CAAC,IAAI,YAAY,8BAAc,CAAC,CAAC,CAAC,CAAC,oBAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,gBAAgB,CAAC,YAAY,CAAC,CAAC;QAC5G,IAAI,SAAS,KAAK,MAAM;YACtB,OAAO,SAAS,CAAC;QAEnB,MAAM,UAAU,GAAG,mCAAmB,CAAC,yBAAyB,CAAC,EAAE,CAAC,KAAK,EAAE,YAAY,CAAC,SAAS,EAAE,EAAE,YAAY,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,QAAQ,CAAC,CAAC;QACpJ,IAAI,SAAS,KAAK,UAAU;YAC1B,OAAO,SAAS,CAAC;QAEnB,YAAY,CAAC,eAAe,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC;QACrD,UAAU,CAAC,CAAC,GAAG,GAAG,CAAC;QAEnB,MAAM,WAAW,GAAG,MAAM,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC;QACpD,IAAI,SAAS,KAAK,WAAW,EAAE,KAAK;YAClC,OAAO,SAAS,CAAC;QAEnB,MAAM,KAAK,GAAG,wBAAQ,CAAC,KAAK,EAAE,CAAC;QAC/B,MAAM,KAAK,GAAG,WAAW,CAAC,KAAK,CAAC,6BAA6B,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC;QAC9F,MAAM,KAAK,GAAG,KAAK,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;QAE5C,IAAI,SAAS,KAAK,KAAK;YACrB,OAAO,SAAS,CAAC;QAEnB,IAAI,QAAQ,GAAG,WAAW,CAAC,KAAK,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC;QACtD,MAAM,MAAM,GAAG,wBAAQ,CAAC,cAAc,CAAC,WAAW,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC;QAEtE,IAAI,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,GAAG,GAAG;YAChC,QAAQ,GAAG,CAAC,QAAQ,CAAC;QAEvB,IAAI,MAAM,GAAG,GAAG,CAAC;QAEjB,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC;YACvB,IAAI,CAAC,MAAM,GAAG,GAAG,IAAI,QAAQ,GAAG,GAAG,CAAC,IAAI,CAAC,MAAM,GAAG,GAAG,IAAI,QAAQ,GAAG,GAAG,CAAC;gBACtE,MAAM,GAAG,CAAC,MAAM,CAAC;SACpB;aAAM;YACL,MAAM,GAAG,QAAQ,CAAC;SACnB;QAED,IAAI,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,wBAAQ,CAAC,mBAAmB;YACjD,OAAO,SAAS,CAAC;QAEnB,IAAI,MAAM,KAAK,IAAI,CAAC,QAAQ,EAAE;YAC5B,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC;YACvB,IAAI,CAAC,4BAA4B,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;YACzD,IAAI,QAAQ;gBACV,IAAI,CAAC,4BAA4B,CAAC,IAAI,CAAC,gBAAgB,EAAE,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,CAAC;SACnG;QAED,MAAM,YAAY,GAAG,IAAI,4BAAY,CAAC,MAAM,CAAC,CAAC;QAC9C,YAAY,CAAC,sBAAsB,GAAG,IAAI,CAAC;QAE3C,MAAM,UAAU,GAAG,yBAAS,CAAC,sBAAsB,CAAC,MAAqB,EAAE,YAAY,CAAC,CAAC;QACzF,IAAI,SAAS,KAAK,UAAU;YAC1B,OAAO,SAAS,CAAC;QAEnB,IAAI,CAAC,UAAU,CAAC,mBAAmB,CAAC,YAAY,CAAC;YAC/C,OAAO,SAAS,CAAC;QAEnB,IAAI,IAAI,YAAY,8BAAc,IAAI,UAAU,YAAY,oBAAI,IAAI,CAAC,KAAK,UAAU,CAAC,QAAQ,CAAC,MAAM;YAClG,OAAO,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,uDAAuD;QAExF,OAAO,UAAU,CAAC;IACpB,CAAC;IAED,IAAuB,kBAAkB;QACvC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC;IACxB,CAAC;IAED,IAAuB,8BAA8B;QACnD,OAAO,CAAC,IAAI,CAAC,kBAAkB,CAAC;IAClC,CAAC;IAEkB,aAAa;QAC9B,MAAM,KAAK,GAAG,IAAI,mCAAmB,EAAE,CAAC;QAExC,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE;YACvB,KAAK,CAAC,mBAAmB,GAAG,IAAI,CAAC;SAClC;aAAM,IAAI,SAAS,KAAK,IAAI,CAAC,WAAW,IAAI,SAAS,KAAK,IAAI,CAAC,UAAU,EAAE;YAC1E,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC;YAClC,MAAM,WAAW,GAAG,CAAC,IAAI,YAAY,8BAAc,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YAEzI,IAAI,SAAS,KAAK,WAAW,EAAE,KAAK,EAAE;gBACpC,MAAM,KAAK,GAAG,WAAW,CAAC,KAAK,CAAC,6BAA6B,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC;gBAE9F,IAAI,SAAS,KAAK,KAAK,EAAE;oBACvB,MAAM,MAAM,GAAG,mCAAmB,CAAC,kBAAkB,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;oBACnF,MAAM,YAAY,GAAG,4BAAY,CAAC,sBAAsB,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;oBAErF,IAAI,SAAS,KAAK,YAAY,EAAE;wBAC9B,MAAM,KAAK,GAAG,YAAY,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;wBAC/C,MAAM,KAAK,GAAG,wBAAQ,CAAC,sBAAsB,CAAC,KAAK,EAAE,KAAK,EAAE,yBAAS,CAAC,GAAG,CAAC,CAAC;wBAE3E,IAAI,SAAS,KAAK,KAAK,EAAE;4BACvB,KAAK,CAAC,SAAS,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;4BACnC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;yBACxB;qBACF;iBACF;aACF;SACF;QAED,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IACzB,CAAC;IAEkB,qBAAqB,CAAC,cAAuB,EAAE,gBAA8C;QAC9G,IAAI,OAAO,CAAC;QACZ,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO;YACtB,OAAO,GAAG,oBAAS,CAAC,SAAS,CAAC,kCAAkC,CAAC,CAAC;QACpE,KAAK,CAAC,qBAAqB,CAAC,OAAO,CAAC,CAAC;IACvC,CAAC;IAEM,KAAK,CAAC,aAAa;QACxB,MAAM,IAAI,GAAG,IAAI,eAAe,EAAE,CAAC;QACnC,IAAI,CAAC,MAAM,IAAI,CAAC,GAAG,EAAE;YACnB,OAAO,IAAI,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;;AAnMsB,sBAAM,GAAG,aAAa,CAAC;AACvB,wBAAQ,GAAG,YAAY,CAAC,CAAC,sBAAsB;AAF3D,0CAAe;AAuM5B,yDAAyD;AACzD,MAAa,cAAe,SAAQ,eAAe;IAAnD;;QAMY,mBAAc,GAAG,IAAI,CAAC;IA0IlC,CAAC;IAxIC,IAAuB,YAAY,KAAc,OAAO,KAAK,CAAC,CAAC,CAAC;IAChE,IAAuB,kBAAkB,KAAc,OAAO,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC;IAEjE,WAAW,CAAC,KAAuC;QACpE,IAAI,gBAAgB,KAAK,KAAK,CAAC,gBAAgB;YAC7C,OAAO,IAAI,CAAC;QAEd,OAAO,CAAC,KAAK,CAAC,UAAU,IAAI,KAAK,CAAC,YAAY,CAAC,CAAC;IAClD,CAAC;IAES,YAAY,CAAC,EAAiB;QACtC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;QAExC,IAAI,SAAS,KAAK,EAAE,CAAC,QAAQ;YAC3B,OAAO;QAET,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC;QAClC,IAAI,SAAS,KAAK,IAAI;YACpB,OAAO;QAET,MAAM,WAAW,GAAG,CAAC,IAAI,YAAY,8BAAc,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC;QACxH,IAAI,SAAS,KAAK,WAAW,EAAE,KAAK;YAClC,OAAO;QAET,MAAM,aAAa,GAAG,CAAC,WAAW,CAAC,QAAQ,IAAI,wBAAQ,CAAC,aAAa,CAAC,CAAC;QACvE,MAAM,WAAW,GAAG,CAAC,WAAW,CAAC,QAAQ,IAAI,CAAC,GAAG,GAAG,wBAAQ,CAAC,aAAa,CAAC,CAAC,CAAC;QAE7E,IAAI,IAAI,YAAY,8BAAc,EAAE;YAClC,IAAI,aAAa,IAAI,WAAW;gBAC9B,OAAO,CAAC,oBAAoB;YAE9B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,iBAAiB,CAAC,GAAG,EAAE,WAAW,CAAC,QAAQ,CAAC,CAAC;YACjE,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;YACjE,OAAO;SACR;aAAM,IAAI,IAAI,YAAY,oBAAI,EAAE;YAC/B,MAAM,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;YACpC,MAAM,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;YAE1D,IAAI,CAAC,WAAW,CAAC,KAAK,KAAK,UAAU,IAAI,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,KAAK,SAAS,IAAI,WAAW,CAAC;gBACzG,OAAO,CAAC,oBAAoB;YAE9B,IAAI,WAAW,GAAG,IAAI,CAAC;YACvB,MAAM,OAAO,GAAG,oBAAI,CAAC,MAAM,EAAE,CAAC;YAC9B,MAAM,OAAO,GAAG,oBAAI,CAAC,MAAM,EAAE,CAAC;YAE9B,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjC,IAAI,KAAK,KAAK,WAAW,CAAC,KAAK,EAAE;oBAC/B,IAAI,aAAa,EAAE;wBACjB,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC;qBACtC;yBAAM,IAAI,WAAW,EAAE;wBACtB,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC;qBACtC;yBAAM;wBACL,MAAM,MAAM,GAAG,KAAK,CAAC,iBAAiB,CAAC,GAAG,EAAE,WAAW,CAAC,QAAQ,CAAC,CAAC;wBAClE,IAAI,SAAS,KAAK,MAAM;4BACtB,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;wBAEhC,MAAM,MAAM,GAAG,KAAK,CAAC,iBAAiB,CAAC,WAAW,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;wBAClE,IAAI,SAAS,KAAK,MAAM;4BACtB,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;qBACjC;oBACD,WAAW,GAAG,KAAK,CAAC;iBACrB;qBAAM;oBACL,IAAI,WAAW;wBACb,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC;;wBAErC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC;iBACxC;aACF;YAED,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;YACvB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;SACxB;aAAM,IAAI,IAAI,YAAY,oBAAI,EAAE;YAC/B,MAAM,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,KAAK,WAAW,CAAC,KAAK,CAAC,CAAC;YACnF,IAAI,CAAC,CAAC,KAAK,UAAU;gBACnB,OAAO;YAET,MAAM,QAAQ,GAAG,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC;YACnD,MAAM,OAAO,GAAG,oBAAI,CAAC,MAAM,EAAE,CAAC,CAAC,oCAAoC;YAEnE,IAAI,aAAa,EAAE;gBACjB,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC;aAClD;iBAAM,IAAI,CAAC,WAAW,EAAE;gBACvB,MAAM,MAAM,GAAG,WAAW,CAAC,KAAK,CAAC,iBAAiB,CAAC,WAAW,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;gBAC9E,IAAI,SAAS,KAAK,MAAM;oBACtB,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;aACjC;YAED,KAAK,IAAI,KAAK,GAAG,UAAU,EAAE,KAAK,GAAG,QAAQ,EAAE,EAAE,KAAK,EAAE;gBACtD,MAAM,KAAK,GAAG,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC;gBAC/C,IAAI,SAAS,KAAK,KAAK,IAAI,KAAK,KAAK,WAAW,CAAC,KAAK;oBACpD,SAAS;gBAEX,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC;aACtC;YAED,IAAI,WAAW,EAAE;gBACf,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC;aAClD;iBAAM,IAAI,CAAC,aAAa,EAAE;gBACzB,MAAM,MAAM,GAAG,WAAW,CAAC,KAAK,CAAC,iBAAiB,CAAC,GAAG,EAAE,WAAW,CAAC,QAAQ,CAAC,CAAC;gBAC9E,IAAI,SAAS,KAAK,MAAM;oBACtB,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;aACjC;YAED,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;SACxB;IACH,CAAC;IAEkB,WAAW,CAAC,GAAkB,EAAE,SAAkB;QACnE,OAAO,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACjE,CAAC;IAEe,KAAK,CAAC,aAAa,CAAC,EAAiB;QACnD,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC;QACtB,IAAI,SAAS,KAAK,IAAI,CAAC,OAAO,IAAI,CAAC,MAAM,IAAI,CAAC,oBAAoB,CAAC,EAAE,CAAC;YACpE,OAAO;QAET,IAAI,SAAS,KAAK,IAAI,CAAC,OAAO,EAAE;YAC9B,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;YAC5B,MAAM,IAAI,CAAC,oBAAoB,CAAC,EAAE,CAAC,CAAC;SACrC;QAED,OAAO,IAAI,CAAC,WAAW,EAAE,CAAC;IAC5B,CAAC;IAEkB,qBAAqB,CAAC,cAAuB,EAAE,gBAA8C;QAC9G,IAAI,OAAO,CAAC;QACZ,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO;YACrB,OAAO,GAAG,oBAAS,CAAC,SAAS,CAAC,kCAAkC,CAAC,CAAC;QACpE,KAAK,CAAC,qBAAqB,CAAC,OAAO,CAAC,CAAC;IACvC,CAAC;IAEM,KAAK,CAAC,aAAa;QACxB,MAAM,IAAI,GAAG,IAAI,cAAc,EAAE,CAAC;QAClC,IAAI,CAAC,MAAM,IAAI,CAAC,GAAG,EAAE;YACnB,OAAO,IAAI,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;;AA9IsB,qBAAM,GAAG,YAAY,AAAf,CAAgB;AACtB,uBAAQ,GAAG,YAAY,AAAf,CAAgB,CAAC,sBAAsB;AAF3D,wCAAc;AAkJ3B,yDAAyD;AACzD,MAAa,eAAgB,SAAQ,eAAe;IAMlD,IAAuB,4BAA4B,KAAc,OAAO,IAAI,CAAC,CAAC,CAAC;IAE5D,WAAW,CAAC,KAAuC;QACpE,IAAI,gBAAgB,KAAK,KAAK,CAAC,gBAAgB;YAC7C,OAAO,KAAK,CAAC,yBAAyB,CAAC;QAEzC,OAAO,KAAK,CAAC,UAAU,CAAC;IAC1B,CAAC;IAES,WAAW,CAAC,IAAoB,EAAE,SAAkB,EAAE,UAAmB;QACjF,MAAM,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;QACvD,IAAI,SAAS,KAAK,UAAU,EAAE,KAAK;YACjC,OAAO,SAAS,CAAC;QAEnB,MAAM,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;QACxD,IAAI,SAAS,KAAK,WAAW,EAAE,KAAK;YAClC,OAAO,SAAS,CAAC;QAEnB,IAAI,WAAW,CAAC,KAAK,YAAY,qBAAK,EAAE;YACtC,IAAI,UAAU,CAAC,QAAQ,GAAG,GAAG,IAAI,WAAW,CAAC,QAAQ,GAAG,GAAG,EAAE;gBAC3D,MAAM,QAAQ,GAAG,WAAW,CAAC,KAAK,CAAC,iBAAiB,CAAC,WAAW,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;gBAChF,QAAQ,CAAC,KAAK,CAAC,eAAe,CAAC,KAAK,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC;gBACtD,OAAO,QAAQ,CAAC;aACjB;iBAAM,IAAI,UAAU,CAAC,QAAQ,IAAI,GAAG,IAAI,WAAW,CAAC,QAAQ,GAAG,GAAG,EAAE;gBACnE,MAAM,QAAQ,GAAG,WAAW,CAAC,KAAK,CAAC,iBAAiB,CAAC,GAAG,EAAE,WAAW,CAAC,QAAQ,CAAC,CAAC;gBAChF,QAAQ,CAAC,KAAK,CAAC,eAAe,CAAC,KAAK,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC;gBACtD,OAAO,QAAQ,CAAC;aACjB;iBAAM,IAAI,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,QAAQ,GAAG,GAAG,CAAC,CAAC,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,GAAG,WAAW,CAAC,QAAQ,CAAC,GAAG,wBAAQ,CAAC,aAAa,EAAE;gBAC3H,MAAM,OAAO,GAAG,WAAW,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;gBAC1C,OAAO,CAAC,KAAK,GAAG,0BAAU,CAAC,SAAS,EAAE,CAAC;gBACvC,OAAO,OAAO,CAAC;aAChB;SACF;QAED,OAAO,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,QAAQ,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,WAAW,CAAC,QAAQ,CAAC,CAAC;IAC7F,CAAC;IAES,aAAa,CAAC,IAAU,EAAE,WAAgC,EAAE,OAAgB;QACpF,IAAI,SAAS,KAAK,WAAW,CAAC,KAAK;YACjC,OAAO,SAAS,CAAC;QAEnB,MAAM,KAAK,GAAG,WAAW,CAAC,KAAK,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;QAC9H,IAAI,SAAS,KAAK,KAAK;YACrB,OAAO,SAAS,CAAC;QAEnB,IAAI,KAAK,YAAY,qBAAK,IAAI,WAAW,CAAC,KAAK,YAAY,qBAAK,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,KAAK,WAAW,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC;YACvH,KAAK,CAAC,KAAK,CAAC,eAAe,CAAC,IAAI,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,sCAAsC;QAExF,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,EAAU,CAAC;QACpC,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,KAAK,CAAC;QAEhE,OAAO,MAAM,CAAC;IAChB,CAAC;IAES,UAAU,CAAC,IAAU,EAAE,SAAkB,EAAE,UAAmB;QACtE,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC;YAC1B,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,UAAU,CAAC,CAAC;QAEnE,MAAM,eAAe,GAAG,2CAA2B,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QACxE,MAAM,WAAW,GAAG,eAAe,CAAC,YAAY,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;QACnE,IAAI,SAAS,KAAK,WAAW,EAAE,KAAK,IAAI,SAAS,KAAK,WAAW,CAAC,WAAW,EAAE,KAAK;YAClF,OAAO,SAAS,CAAC;QAEnB,IAAI,SAAS,KAAK,IAAI,CAAC,YAAY,EAAE;YACnC,IAAI,WAAW,CAAC,WAAW,CAAC,KAAK,KAAK,IAAI,CAAC,YAAY,EAAE;gBACvD,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC,CAAC,qDAAqD;aACrF;iBAAM;gBACL,MAAM,aAAa,GAAG,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;gBACvE,IAAI,SAAS,KAAK,aAAa,EAAE,KAAK;oBACpC,OAAO,SAAS,CAAC;gBACnB,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,aAAa,EAAE,CAAC,aAAa,CAAC,KAAK,KAAK,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;aAC5F;SACF;QAED,8FAA8F;QAC9F,IAAI,WAAW,CAAC,QAAQ,GAAG,GAAG,EAAE;YAC9B,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC,WAAW,CAAC,KAAK,CAAC;YAClD,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,WAAW,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC;SAChE;aAAM,IAAI,WAAW,CAAC,QAAQ,GAAG,GAAG,EAAE;YACrC,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC,WAAW,CAAC,KAAK,CAAC;YAClD,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,WAAW,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC;SACjE;QAED,MAAM,UAAU,GAAG,eAAe,CAAC,YAAY,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;QAClE,IAAI,SAAS,KAAK,UAAU,EAAE,KAAK;YACjC,OAAO,SAAS,CAAC;QAEnB,MAAM,MAAM,GAAG,eAAe,CAAC,iBAAiB,CAAC,UAAU,CAAC,QAAQ,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,WAAW,CAAC,QAAQ,CAAC,CAAC;QAC9G,IAAI,SAAS,KAAK,MAAM;YACtB,OAAO,SAAS,CAAC;QAEnB,OAAO,oBAAI,CAAC,MAAM,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAC9C,CAAC;IAEkB,WAAW,CAAC,EAAiB,EAAE,SAAkB;QAClE,IAAI,SAAS,KAAK,EAAE,CAAC,QAAQ,IAAI,SAAS,KAAK,IAAI,CAAC,WAAW;YAC7D,OAAO,SAAS,CAAC;QAEnB,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC;QAClC,IAAI,SAAS,KAAK,IAAI;YACpB,OAAO,SAAS,CAAC;QAEnB,MAAM,MAAM,GAAG,mCAAmB,CAAC,kBAAkB,CAAC,EAAE,CAAC,QAAQ,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;QAC/E,MAAM,YAAY,GAAG,4BAAY,CAAC,sBAAsB,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;QACrF,IAAI,SAAS,KAAK,YAAY;YAC5B,OAAO,SAAS,CAAC;QAEnB,MAAM,YAAY,GAAG,YAAY,CAAC,OAAO,EAAE,CAAC;QAC5C,IAAI,SAAS,KAAK,YAAY;YAC5B,OAAO,SAAS,CAAC;QAEnB,MAAM,UAAU,GAAG,mCAAmB,CAAC,yBAAyB,CAAC,EAAE,CAAC,KAAK,EAAE,YAAY,CAAC,SAAS,EAAE,EAAE,YAAY,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,QAAQ,CAAC,CAAC;QACpJ,IAAI,SAAS,KAAK,UAAU;YAC1B,OAAO,SAAS,CAAC;QAEnB,IAAI,IAAI,YAAY,8BAAc;YAChC,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,IAAI,CAAC,WAAW,EAAE,UAAU,CAAC,CAAC;aACzD,IAAI,IAAI,YAAY,oBAAI;YAC3B,OAAO,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,WAAW,EAAE,UAAU,CAAC,CAAC;QAE7D,OAAO,SAAS,CAAC;IACnB,CAAC;IAEkB,KAAK,CAAC,gBAAgB;QACvC,yBAAS,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,6EAA6E;QAClI,OAAO,KAAK,CAAC,gBAAgB,EAAE,CAAC;IAClC,CAAC;IAEkB,aAAa;QAC9B,MAAM,KAAK,GAAG,IAAI,mCAAmB,EAAE,CAAC;QAExC,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE;YACvB,KAAK,CAAC,mBAAmB,GAAG,IAAI,CAAC;SAClC;aAAM;YACL,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC;YAClC,IAAI,SAAS,KAAK,IAAI,IAAI,SAAS,KAAK,IAAI,CAAC,WAAW;gBACtD,OAAO;YAET,IAAI,UAAU,CAAC;YACf,IAAI,IAAI,YAAY,8BAAc;gBAChC,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC;iBACrD,IAAI,IAAI,YAAY,oBAAI;gBAC3B,UAAU,GAAG,2CAA2B,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC;YACrG,IAAI,SAAS,KAAK,UAAU,EAAE,KAAK;gBACjC,OAAO;YAET,MAAM,KAAK,GAAG,CAAC,SAAS,KAAK,UAAU,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC,CAAC,UAAU,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;YAE/G,IAAI,KAAK,YAAY,qBAAK,EAAE;gBAC1B,MAAM,MAAM,GAAG,KAAK,CAAC,WAAW,EAAE,CAAC;gBACnC,MAAM,CAAC,uBAAuB,EAAE,CAAC;gBACjC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;gBAC9B,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;gBACxB,KAAK,CAAC,YAAY,EAAE,CAAC;aACtB;iBAAM,IAAI,KAAK,YAAY,6BAAa,EAAE;gBACzC,KAAK,CAAC,SAAS,CAAC,UAAU,CAAC,QAAQ,GAAG,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;gBAC/E,KAAK,CAAC,QAAQ,CAAC,wBAAQ,CAAC,cAAc,CAAC,UAAU,CAAC,QAAQ,GAAG,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS,EAAE,UAAU,CAAC,QAAQ,GAAG,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC;gBACtK,KAAK,CAAC,kBAAkB,EAAE,CAAC;aAC5B;iBAAM,IAAI,KAAK,YAAY,4BAAY,EAAE;gBACxC,IAAI,KAAK,CAAC,SAAS,EAAE,GAAG,CAAC,EAAE;oBACzB,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,YAAY,CAAC,+BAA+B,CAAC,UAAU,CAAC,QAAQ,GAAG,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;oBAC3H,KAAK,CAAC,QAAQ,CAAC,wBAAQ,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,+BAA+B,CAAC,UAAU,CAAC,QAAQ,GAAG,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,YAAY,CAAC,+BAA+B,CAAC,UAAU,CAAC,QAAQ,GAAG,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;iBAC/P;gBACD,KAAK,CAAC,kBAAkB,EAAE,CAAC;aAC5B;iBAAM;gBACL,MAAM,GAAG,GAAG,KAAK,CAAC,6BAA6B,CAAC,UAAU,CAAC,QAAQ,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;gBACvF,KAAK,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;gBAC5B,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;gBAC9B,KAAK,CAAC,kBAAkB,EAAE,CAAC;aAC5B;SACF;QACD,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IACzB,CAAC;IAEkB,qBAAqB,CAAC,cAAuB,EAAE,gBAA8C;QAC9G,IAAI,OAAO,CAAC;QACZ,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO;YACrB,OAAO,GAAG,oBAAS,CAAC,SAAS,CAAC,iCAAiC,CAAC,CAAC;QACnE,KAAK,CAAC,qBAAqB,CAAC,OAAO,CAAC,CAAC;IACvC,CAAC;IAEM,KAAK,CAAC,aAAa;QACxB,MAAM,IAAI,GAAG,IAAI,eAAe,EAAE,CAAC;QACnC,IAAI,CAAC,MAAM,IAAI,CAAC,GAAG,EAAE;YACnB,OAAO,IAAI,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;;AA9LsB,sBAAM,GAAG,aAAa,CAAC;AACvB,wBAAQ,GAAG,YAAY,CAAC,CAAC,sBAAsB;AAF3D,0CAAe;AAkM5B,aAAa;AACb,IAAY,iBAOX;AAPD,WAAY,iBAAiB;IAC3B,oDAAoD;IACpD,2DAAS,CAAA;IACT,iEAAiE;IACjE,iEAAY,CAAA;IACZ,2DAA2D;IAC3D,mEAAa,CAAA;AACf,CAAC,EAPW,iBAAiB,GAAjB,yBAAiB,KAAjB,yBAAiB,QAO5B;AAED,mEAAmE;AACnE,MAAa,iBAAkB,SAAQ,eAAe;IAKpD,IAAW,gBAAgB;QACzB,IAAI,CAAC,IAAI,CAAC,iBAAiB;YACzB,IAAI,CAAC,iBAAiB,GAAG,IAAI,+BAAc,CACzC,0CAAyB,CAAC,sBAAsB,CAAC,mBAAmB,EAAE,oBAAS,CAAC,SAAS,CAAC,kCAAkC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC;QAC3I,OAAO,IAAI,CAAC,iBAAiB,CAAC;IAChC,CAAC;IAED,IAAW,QAAQ,KAAc,OAAO,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC,CAAC;IACtE,IAAW,QAAQ,CAAC,KAAc,IAAI,IAAI,CAAC,gBAAgB,CAAC,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC;IAEpE,MAAM,CAAC,WAAW,CAAC,GAAW,IAAI,OAAO,oBAAS,CAAC,SAAS,CAAC,sBAAsB,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;IAUpG,IAAW,YAAY;QACrB,IAAI,CAAC,IAAI,CAAC,aAAa;YACrB,IAAI,CAAC,aAAa,GAAG,IAAI,+BAAc,CAAS,0CAAyB,CAAC,kCAAkC,CAC1G,mBAAmB,EAAE,oBAAS,CAAC,SAAS,CAAC,0BAA0B,CAAC,EAAE,iBAAiB,CAAC,cAAc,EAAE,CAAC,EAAE,iBAAiB,CAAC,KAAe,CAAC,CAAC;QAClJ,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IAED,IAAW,IAAI,KAAwB,OAAO,IAAI,CAAC,YAAY,CAAC,KAA0B,CAAC,CAAC,CAAC;IAC7F,IAAW,IAAI,CAAC,IAAuB,IAAI,IAAI,CAAC,YAAY,CAAC,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC;IAE5E,IAAuB,iBAAiB,KAAc,OAAO,KAAK,CAAC,CAAC,CAAC,CAAC,0DAA0D;IAChI,IAAuB,iBAAiB,KAAc,OAAO,iBAAiB,CAAC,QAAQ,KAAK,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IACxG,IAAuB,eAAe,KAAc,OAAO,iBAAiB,CAAC,QAAQ,KAAK,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IACtG,IAAuB,4BAA4B,KAAc,OAAO,IAAI,CAAC,CAAC,CAAC;IAC/E,IAAuB,oBAAoB,KAAa,OAAO,CAAC,CAAC,CAAC,CAAC;IAEnE,IAAuB,YAAY,KAAc,OAAO,KAAK,CAAC,CAAC,CAAC;IAChE,IAAuB,YAAY,KAAc,OAAO,KAAK,CAAC,CAAC,CAAC;IAChE,IAAuB,kBAAkB,KAAc,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;IAE5D,KAAK,CAAC,gBAAgB,KAAoB,CAAC,CAAC,4DAA4D;IAExG,WAAW,CAAC,KAAuC;QACpE,IAAI,gBAAgB,KAAK,KAAK,CAAC,gBAAgB;YAC7C,OAAO,KAAK,CAAC;QAEf,OAAO,KAAK,CAAC,eAAe,CAAC;IAC/B,CAAC;IAEO,cAAc;QACpB,QAAQ,IAAI,CAAC,IAAI,EAAE;YACjB,KAAK,iBAAiB,CAAC,QAAQ;gBAC7B,OAAO,kCAAkB,CAAC,OAAO,CAAC;YACpC,KAAK,iBAAiB,CAAC,SAAS;gBAC9B,OAAO,kCAAkB,CAAC,YAAY,CAAC;YACzC;gBACE,OAAO,kCAAkB,CAAC,KAAK,CAAC;SACnC;IACH,CAAC;IAEO,qBAAqB,CAAC,KAAkB;QAC9C,QAAQ,KAAK,CAAC,iBAAiB,CAAC,MAAM,EAAE;YACtC,KAAK,CAAC;gBACJ,OAAO,SAAS,CAAC;YACnB,KAAK,CAAC;gBACJ,OAAO,KAAK,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC;YACpC;gBACE,OAAO,yBAAS,CAAC,uBAAuB,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC;SACrE;IACH,CAAC;IAEO,eAAe,CAAC,KAAkB,EAAE,EAAsB;QAChE,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC;YAClB,OAAO,SAAS,CAAC;QAEnB,MAAM,MAAM,GAAG,CAAC,kCAAkB,CAAC,KAAK,KAAK,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;QACpE,MAAM,MAAM,GAAG,CAAC,kCAAkB,CAAC,KAAK,KAAK,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;QAE9E,oHAAoH;QACpH,MAAM,KAAK,GAAG,yBAAS,CAAC,eAAe,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,CAAC,CAAC;QAC5D,IAAI,SAAS,KAAK,KAAK;YACrB,OAAO,SAAS,CAAC;QAEnB,0FAA0F;QAC1F,MAAM,KAAK,GAAG,yBAAS,CAAC,yBAAyB,CAAC,KAAK,CAAC,CAAC;QAEzD,IAAI,CAAC,KAAK,KAAK,CAAC,MAAM;YACpB,OAAO,IAAI,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QAE9C,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;YACpB,MAAM,WAAW,GAAG,2BAAW,CAAC,MAAM,EAAE,CAAC;YAEzC,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE;gBACxB,MAAM,KAAK,GAAG,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;gBAC/C,IAAI,SAAS,KAAK,KAAK;oBACrB,SAAS;gBAEX,WAAW,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;aAChC;YAED,IAAI,WAAW,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC;gBACjC,OAAO,WAAW,CAAC;SACtB;QAED,OAAO,SAAS,CAAC;IACnB,CAAC;IAES,KAAK,CAAC,eAAe,CAAC,GAAkB;QAChD,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAE3B,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,IAAI,CAAC,oBAAoB;YAChD,OAAO;QAET,MAAM,UAAU,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;QACpE,IAAI,SAAS,KAAK,UAAU,EAAE,IAAI;YAChC,OAAO;QAET,MAAM,kBAAkB,GAAG,4BAAY,CAAC,sBAAsB,CAAC,SAAS,EAAE,UAAU,CAAC,IAAI,CAAC,CAAC;QAC3F,IAAI,SAAS,KAAK,kBAAkB;YAClC,OAAO;QAET,MAAM,kBAAkB,GAAG,kBAAkB,CAAC,OAAO,EAAE,CAAC;QACxD,IAAI,SAAS,KAAK,kBAAkB;YAClC,OAAO;QAET,MAAM,WAAW,GAAG,4CAA4B,CAAC,MAAM,CAAC,kBAAkB,CAAC,SAAS,EAAE,EAAE,kBAAkB,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;QAChI,IAAI,SAAS,KAAK,WAAW;YAC3B,OAAO;QAET,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,mBAAmB,CAAC,kBAAkB,CAAC;YAC1D,OAAO;QAET,MAAM,KAAK,GAAgB,CAAC,UAAU,CAAC,IAAiB,CAAC,CAAC;QAE1D,KAAK,MAAM,EAAE,IAAI,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE;YACrC,IAAI,EAAE,KAAK,UAAU,CAAC,KAAK,CAAC,EAAE;gBAC5B,SAAS;YAEX,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC;YAC9C,IAAI,SAAS,KAAK,SAAS,EAAE,IAAI;gBAC/B,OAAO;YAET,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,EAAE,WAAW,CAAC,EAAE;gBAC3D,yBAAS,CAAC,aAAa,CAAC,aAAa,CAAC,IAAI,oCAAoB,CAAC,qCAAqB,CAAC,IAAI,EAAE,oBAAS,CAAC,SAAS,CAAC,iCAAiC,CAAC,CAAC,CAAC,CAAC;gBACpJ,OAAO;aACR;YAED,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,mBAAmB,CAAC,kBAAkB,CAAC;gBACzD,OAAO;YAET,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,IAAiB,CAAC,CAAC;SACzC;QAED,MAAM,MAAM,GAAG,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC;QAClE,IAAI,SAAS,KAAK,MAAM,IAAI,CAAC,MAAM,CAAC,mBAAmB,CAAC,kBAAkB,CAAC;YACzE,OAAO;QAET,IAAI,CAAC,SAAS,GAAG,UAAU,CAAC;QAC5B,IAAI,CAAC,SAAS,CAAC,IAAI,GAAG,MAAM,CAAC;IAC/B,CAAC;IAEkB,WAAW,CAAC,GAAkB,EAAE,SAAkB;QACnE,OAAO,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC;IAC9B,CAAC;IAEkB,KAAK,CAAC,oBAAoB,CAAC,EAAiB;QAC7D,IAAI,CAAC,MAAM,KAAK,CAAC,oBAAoB,CAAC,EAAE,CAAC;YACvC,OAAO,KAAK,CAAC;QAEf,IAAI,IAAI,CAAC,kBAAkB,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC;YACnD,MAAM,kCAAoB,CAAC,cAAc,CAAC,gCAAiB,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAE9G,OAAO,IAAI,CAAC;IACd,CAAC;IAEe,KAAK,CAAC,aAAa,CAAC,EAAiB;QACnD,MAAM,IAAI,CAAC,eAAe,CAAC,EAAE,CAAC,CAAC;QAC/B,OAAO,KAAK,CAAC,aAAa,CAAC,EAAE,CAAC,CAAC;IACjC,CAAC;IAEM,KAAK,CAAC,aAAa;QACxB,MAAM,IAAI,GAAG,IAAI,iBAAiB,EAAE,CAAC;QACrC,IAAI,CAAC,MAAM,IAAI,CAAC,GAAG,EAAE;YACnB,OAAO,IAAI,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;IAEe,KAAK,CAAC,8BAA8B,CAAC,YAAoC;QACvF,IAAI,CAAC,IAAI,CAAC,8BAA8B,CAAC,YAAY,CAAC;YACpD,OAAO,KAAK,CAAC;QAEf,IAAI,IAAI,CAAC,YAAY,CAAC,IAAI,KAAK,YAAY,CAAC,YAAY;YACtD,MAAM,IAAI,CAAC,cAAc,EAAE,CAAC;QAE9B,OAAO,IAAI,CAAC;IACd,CAAC;IAEe,4BAA4B;QAC1C,IAAI,CAAC,mCAAmC,CAAC,CAAC,IAAI,CAAC,gBAAgB,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;QAErF,MAAM,YAAY,GAAG,IAAI,KAAK,EAAc,CAAC;QAE7C,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACtF,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAE1F,OAAO,YAAY,CAAC;IACtB,CAAC;;AAjNsB,wBAAM,GAAG,eAAe,CAAC;AACzB,0BAAQ,GAAG,YAAY,CAAC,CAAC,sBAAsB;AAcvD,gCAAc,GAAG,GAAwB,EAAE;IACxD,OAAO;QACL,EAAE,KAAK,EAAE,iBAAiB,CAAC,WAAW,CAAC,OAAO,CAAC,EAAE,KAAK,EAAE,iBAAiB,CAAC,KAAK,EAAE;QACjF,EAAE,KAAK,EAAE,iBAAiB,CAAC,WAAW,CAAC,UAAU,CAAC,EAAE,KAAK,EAAE,iBAAiB,CAAC,QAAQ,EAAE;QACvF,EAAE,KAAK,EAAE,iBAAiB,CAAC,WAAW,CAAC,WAAW,CAAC,EAAE,KAAK,EAAE,iBAAiB,CAAC,SAAS,EAAE;KAC1F,CAAC;AACJ,CAAC,CAAC;AAtBS,8CAAiB","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n\r\nimport { DialogItem, DialogProperty, DialogPropertySyncItem, EnumerationChoice, PropertyDescriptionHelper } from \"@itwin/appui-abstract\";\r\nimport { CompressedId64Set, Id64String } from \"@itwin/core-bentley\";\r\nimport {\r\n BentleyError, Code, ElementGeometry, ElementGeometryInfo, ElementGeometryOpcode, FlatBufferGeometryStream, GeometricElementProps,\r\n GeometryParams, JsonGeometryStream,\r\n} from \"@itwin/core-common\";\r\nimport {\r\n AccuDrawHintBuilder, BeButtonEvent, IModelApp,\r\n LengthDescription, NotifyMessageDetails, OutputMessagePriority, ToolAssistanceInstruction,\r\n} from \"@itwin/core-frontend\";\r\nimport {\r\n AngleSweep, AnyRegion, Arc3d, AxisOrder, CurveChainWithDistanceIndex, CurveCollection, CurveLocationDetail, CurvePrimitive, FrameBuilder, Geometry, GeometryQuery, JointOptions, LineSegment3d, LineString3d, Loop, Matrix3d,\r\n Path, Plane3dByOriginAndUnitNormal, Point3d, RegionBinaryOpType, RegionOps, SignedLoops, UnionRegion, Vector3d,\r\n} from \"@itwin/core-geometry\";\r\nimport { editorBuiltInCmdIds } from \"@itwin/editor-common\";\r\nimport { EditTools } from \"./EditTool\";\r\nimport { basicManipulationIpc } from \"./EditToolIpc\";\r\nimport { ModifyElementWithDynamicsTool } from \"./ModifyElementTool\";\r\n\r\n/** @alpha */\r\nexport class CurveData {\r\n public props: GeometricElementProps;\r\n public params: GeometryParams;\r\n public geom: CurveCollection | CurvePrimitive;\r\n\r\n constructor(props: GeometricElementProps, params: GeometryParams, geom: CurveCollection | CurvePrimitive) {\r\n this.props = props;\r\n this.params = params;\r\n this.geom = geom;\r\n }\r\n}\r\n\r\n/** @alpha Base class for modifying all types of curve geometry. */\r\nexport abstract class ModifyCurveTool extends ModifyElementWithDynamicsTool {\r\n protected _startedCmd?: string;\r\n protected curveData?: CurveData;\r\n\r\n protected async startCommand(): Promise<string> {\r\n if (undefined !== this._startedCmd)\r\n return this._startedCmd;\r\n return EditTools.startCommand<string>({ commandId: editorBuiltInCmdIds.cmdBasicManipulation, iModelKey: this.iModel.key });\r\n }\r\n\r\n public static isSingleCurve(info: ElementGeometryInfo): { curve: CurveCollection | CurvePrimitive, params: GeometryParams } | undefined {\r\n const it = new ElementGeometry.Iterator(info);\r\n it.requestWorldCoordinates();\r\n\r\n for (const entry of it) {\r\n const geom = entry.toGeometryQuery();\r\n if (undefined === geom)\r\n return;\r\n\r\n if (\"curvePrimitive\" === geom.geometryCategory) {\r\n return { curve: geom as CurvePrimitive, params: entry.geomParams };\r\n } else if (\"curveCollection\" === geom.geometryCategory) {\r\n return { curve: geom as CurveCollection, params: entry.geomParams };\r\n }\r\n\r\n break;\r\n }\r\n\r\n return;\r\n }\r\n\r\n public static isInPlane(curve: CurveCollection | CurvePrimitive, plane: Plane3dByOriginAndUnitNormal): boolean {\r\n if (\"curvePrimitive\" === curve.geometryCategory)\r\n return curve.isInPlane(plane);\r\n\r\n if (!curve.children)\r\n return false;\r\n\r\n for (const child of curve.children) {\r\n if (child instanceof CurvePrimitive) {\r\n if (!child.isInPlane(plane))\r\n return false;\r\n } else if (child instanceof CurveCollection) {\r\n if (!this.isInPlane(child, plane))\r\n return false;\r\n }\r\n }\r\n\r\n return true;\r\n }\r\n\r\n protected acceptCurve(_curve: CurveCollection | CurvePrimitive): boolean { return true; }\r\n protected modifyCurve(_ev: BeButtonEvent, _isAccept: boolean): GeometryQuery | undefined { return undefined; }\r\n\r\n protected async getCurveData(id: Id64String): Promise<CurveData | undefined> {\r\n try {\r\n this._startedCmd = await this.startCommand();\r\n const reject: ElementGeometryOpcode[] = [ElementGeometryOpcode.Polyface, ElementGeometryOpcode.SolidPrimitive, ElementGeometryOpcode.BsplineSurface, ElementGeometryOpcode.BRep];\r\n const info = await basicManipulationIpc.requestElementGeometry(id, { maxDisplayable: 1, reject, geometry: { curves: true, surfaces: true, solids: false } });\r\n if (undefined === info)\r\n return undefined;\r\n\r\n const data = ModifyCurveTool.isSingleCurve(info);\r\n if (undefined === data)\r\n return undefined;\r\n\r\n if (!this.acceptCurve(data.curve))\r\n return undefined;\r\n\r\n const props = await this.iModel.elements.loadProps(id) as GeometricElementProps;\r\n if (undefined === props)\r\n return undefined;\r\n\r\n return new CurveData(props, data.params, data.curve);\r\n } catch (err) {\r\n IModelApp.notifications.outputMessage(new NotifyMessageDetails(OutputMessagePriority.Error, BentleyError.getErrorMessage(err)));\r\n return undefined;\r\n }\r\n }\r\n\r\n protected override async doAcceptElementForOperation(id: Id64String): Promise<boolean> {\r\n return (undefined !== await this.getCurveData(id));\r\n }\r\n\r\n protected override async onAgendaModified(): Promise<void> {\r\n this.curveData = undefined;\r\n if (this.agenda.isEmpty)\r\n return;\r\n\r\n const id = this.agenda.elements[this.agenda.length - 1];\r\n this.curveData = await this.getCurveData(id);\r\n }\r\n\r\n protected override setupAccuDraw(): void {\r\n const hints = new AccuDrawHintBuilder();\r\n\r\n hints.enableSmartRotation = true;\r\n hints.sendHints(false);\r\n }\r\n\r\n protected getGeometryProps(ev: BeButtonEvent, isAccept: boolean): JsonGeometryStream | FlatBufferGeometryStream | undefined {\r\n if (undefined === this.curveData)\r\n return;\r\n\r\n const geom = this.modifyCurve(ev, isAccept);\r\n if (undefined === geom)\r\n return;\r\n\r\n const builder = new ElementGeometry.Builder();\r\n builder.setLocalToWorldFromPlacement(this.curveData.props.placement!);\r\n\r\n if (!builder.appendGeometryParamsChange(this.curveData.params))\r\n return;\r\n\r\n if (!builder.appendGeometryQuery(geom))\r\n return;\r\n\r\n return { format: \"flatbuffer\", data: builder.entries };\r\n }\r\n\r\n protected getElementProps(ev: BeButtonEvent): GeometricElementProps | undefined {\r\n if (undefined === this.curveData)\r\n return;\r\n\r\n if (!this.wantModifyOriginal) {\r\n // Create result as new element with same model and category as original...\r\n const classFullName = (ev.viewport?.view.is3d() ? \"Generic:PhysicalObject\" : \"BisCore:DrawingGraphic\");\r\n return { classFullName, model: this.curveData.props.model, category: this.curveData.props.category, code: Code.createEmpty(), placement: this.curveData.props.placement };\r\n }\r\n\r\n return this.curveData.props;\r\n }\r\n\r\n protected override async doUpdateElement(elemProps: GeometricElementProps): Promise<boolean> {\r\n try {\r\n this._startedCmd = await this.startCommand();\r\n if (undefined === elemProps.id) {\r\n const repeatOperation = this.wantContinueWithPreviousResult;\r\n if (repeatOperation)\r\n this.agenda.clear();\r\n\r\n const newId = await basicManipulationIpc.insertGeometricElement(elemProps);\r\n\r\n if (repeatOperation && this.agenda.add(newId))\r\n await this.onAgendaModified();\r\n } else {\r\n await basicManipulationIpc.updateGeometricElement(elemProps);\r\n }\r\n return true;\r\n } catch (err) {\r\n IModelApp.notifications.outputMessage(new NotifyMessageDetails(OutputMessagePriority.Error, BentleyError.getErrorMessage(err) || \"An unknown error occurred.\"));\r\n return false;\r\n }\r\n }\r\n\r\n protected get wantModifyOriginal(): boolean { return true; }\r\n protected get wantContinueWithPreviousResult(): boolean { return false; }\r\n\r\n public override async onProcessComplete(): Promise<void> {\r\n // Don't restart tool want to continue operation using previous result...\r\n if (this.wantContinueWithPreviousResult && !this.agenda.isEmpty && undefined !== this.curveData)\r\n return;\r\n return super.onProcessComplete();\r\n }\r\n}\r\n\r\n/** @alpha Tool for applying an offset to paths and loops. */\r\nexport class OffsetCurveTool extends ModifyCurveTool {\r\n public static override toolId = \"OffsetCurve\";\r\n public static override iconSpec = \"icon-scale\"; // Need better icon...\r\n\r\n private _useDistanceProperty: DialogProperty<boolean> | undefined;\r\n public get useDistanceProperty() {\r\n if (!this._useDistanceProperty)\r\n this._useDistanceProperty = new DialogProperty<boolean>(PropertyDescriptionHelper.buildLockPropertyDescription(\"useOffsetDistance\"), false);\r\n return this._useDistanceProperty;\r\n }\r\n\r\n public get useDistance(): boolean { return this.useDistanceProperty.value; }\r\n public set useDistance(value: boolean) { this.useDistanceProperty.value = value; }\r\n\r\n private _distanceProperty: DialogProperty<number> | undefined;\r\n public get distanceProperty() {\r\n if (!this._distanceProperty)\r\n this._distanceProperty = new DialogProperty<number>(new LengthDescription(\"offsetDistance\", EditTools.translate(\"OffsetCurve.Label.Distance\")), 0.1, undefined, !this.useDistance);\r\n return this._distanceProperty;\r\n }\r\n\r\n public get distance(): number { return this.distanceProperty.value; }\r\n public set distance(value: number) { this.distanceProperty.value = value; }\r\n\r\n private _makeCopyProperty: DialogProperty<boolean> | undefined;\r\n public get makeCopyProperty() {\r\n if (!this._makeCopyProperty)\r\n this._makeCopyProperty = new DialogProperty<boolean>(\r\n PropertyDescriptionHelper.buildToggleDescription(\"offsetCopy\", EditTools.translate(\"OffsetCurve.Label.MakeCopy\")), false);\r\n return this._makeCopyProperty;\r\n }\r\n\r\n public get makeCopy(): boolean { return this.makeCopyProperty.value; }\r\n public set makeCopy(value: boolean) { this.makeCopyProperty.value = value; }\r\n\r\n protected override getToolSettingPropertyLocked(property: DialogProperty<any>): DialogProperty<any> | undefined {\r\n return (property === this.useDistanceProperty ? this.distanceProperty : undefined);\r\n }\r\n\r\n public override async applyToolSettingPropertyChange(updatedValue: DialogPropertySyncItem): Promise<boolean> {\r\n return this.changeToolSettingPropertyValue(updatedValue);\r\n }\r\n\r\n public override supplyToolSettingsProperties(): DialogItem[] | undefined {\r\n this.initializeToolSettingPropertyValues([this.makeCopyProperty, this.useDistanceProperty, this.distanceProperty]);\r\n\r\n const toolSettings = new Array<DialogItem>();\r\n\r\n // ensure controls are enabled/disabled based on current lock property state\r\n this.distanceProperty.isDisabled = !this.useDistance;\r\n const useDistanceLock = this.useDistanceProperty.toDialogItem({ rowPriority: 1, columnIndex: 0 });\r\n toolSettings.push(this.distanceProperty.toDialogItem({ rowPriority: 1, columnIndex: 1 }, useDistanceLock));\r\n toolSettings.push(this.makeCopyProperty.toDialogItem({ rowPriority: 2, columnIndex: 0 }));\r\n\r\n return toolSettings;\r\n }\r\n\r\n protected override acceptCurve(curve: CurveCollection | CurvePrimitive): boolean {\r\n if (\"curvePrimitive\" === curve.geometryCategory)\r\n return true;\r\n\r\n return (curve.isOpenPath || curve.isClosedPath);\r\n }\r\n\r\n protected override modifyCurve(ev: BeButtonEvent, isAccept: boolean): GeometryQuery | undefined {\r\n if (undefined === ev.viewport)\r\n return undefined;\r\n\r\n const geom = this.curveData?.geom;\r\n if (undefined === geom)\r\n return undefined;\r\n\r\n const matrix = AccuDrawHintBuilder.getCurrentRotation(ev.viewport, true, true);\r\n const localToWorld = FrameBuilder.createRightHandedFrame(matrix?.getColumn(2), geom);\r\n if (undefined === localToWorld)\r\n return undefined;\r\n\r\n const worldToLocal = localToWorld.inverse();\r\n if (undefined === worldToLocal)\r\n return undefined;\r\n\r\n const geomXY = ((geom instanceof CurvePrimitive) ? Path.create(geom) : geom).cloneTransformed(worldToLocal);\r\n if (undefined === geomXY)\r\n return undefined;\r\n\r\n const spacePoint = AccuDrawHintBuilder.projectPointToPlaneInView(ev.point, localToWorld.getOrigin(), localToWorld.matrix.getColumn(2), ev.viewport);\r\n if (undefined === spacePoint)\r\n return undefined;\r\n\r\n worldToLocal.multiplyPoint3d(spacePoint, spacePoint);\r\n spacePoint.z = 0.0;\r\n\r\n const closeDetail = geomXY.closestPoint(spacePoint);\r\n if (undefined === closeDetail?.curve)\r\n return undefined;\r\n\r\n const unitZ = Vector3d.unitZ();\r\n const unitX = closeDetail.curve.fractionToPointAndUnitTangent(closeDetail.fraction).direction;\r\n const unitY = unitZ.unitCrossProduct(unitX);\r\n\r\n if (undefined === unitY)\r\n return undefined;\r\n\r\n let distance = closeDetail.point.distance(spacePoint);\r\n const refDir = Vector3d.createStartEnd(closeDetail.point, spacePoint);\r\n\r\n if (refDir.dotProduct(unitY) < 0.0)\r\n distance = -distance;\r\n\r\n let offset = 0.0;\r\n\r\n if (this.useDistance) {\r\n offset = this.distance;\r\n if ((offset < 0.0 && distance > 0.0) || (offset > 0.0 && distance < 0.0))\r\n offset = -offset;\r\n } else {\r\n offset = distance;\r\n }\r\n\r\n if (Math.abs(offset) < Geometry.smallMetricDistance)\r\n return undefined;\r\n\r\n if (offset !== this.distance) {\r\n this.distance = offset;\r\n this.syncToolSettingPropertyValue(this.distanceProperty);\r\n if (isAccept)\r\n this.saveToolSettingPropertyValue(this.distanceProperty, this.distanceProperty.dialogItemValue);\r\n }\r\n\r\n const jointOptions = new JointOptions(offset);\r\n jointOptions.preserveEllipticalArcs = true;\r\n\r\n const offsetGeom = RegionOps.constructCurveXYOffset(geomXY as Path | Loop, jointOptions);\r\n if (undefined === offsetGeom)\r\n return undefined;\r\n\r\n if (!offsetGeom.tryTransformInPlace(localToWorld))\r\n return undefined;\r\n\r\n if (geom instanceof CurvePrimitive && offsetGeom instanceof Path && 1 === offsetGeom.children.length)\r\n return offsetGeom.getChild(0); // Don't create path for offset of single open curve...\r\n\r\n return offsetGeom;\r\n }\r\n\r\n protected override get wantModifyOriginal(): boolean {\r\n return !this.makeCopy;\r\n }\r\n\r\n protected override get wantContinueWithPreviousResult(): boolean {\r\n return !this.wantModifyOriginal;\r\n }\r\n\r\n protected override setupAccuDraw(): void {\r\n const hints = new AccuDrawHintBuilder();\r\n\r\n if (this.agenda.isEmpty) {\r\n hints.enableSmartRotation = true;\r\n } else if (undefined !== this.anchorPoint && undefined !== this.targetView) {\r\n const geom = this.curveData?.geom;\r\n const closeDetail = (geom instanceof CurvePrimitive) ? geom.closestPoint(this.anchorPoint, false) : geom?.closestPoint(this.anchorPoint);\r\n\r\n if (undefined !== closeDetail?.curve) {\r\n const unitX = closeDetail.curve.fractionToPointAndUnitTangent(closeDetail.fraction).direction;\r\n\r\n if (undefined !== unitX) {\r\n const matrix = AccuDrawHintBuilder.getCurrentRotation(this.targetView, true, true);\r\n const localToWorld = FrameBuilder.createRightHandedFrame(matrix?.getColumn(2), geom);\r\n\r\n if (undefined !== localToWorld) {\r\n const unitZ = localToWorld.matrix.getColumn(2);\r\n const frame = Matrix3d.createRigidFromColumns(unitX, unitZ, AxisOrder.XZY);\r\n\r\n if (undefined !== frame) {\r\n hints.setOrigin(closeDetail.point);\r\n hints.setMatrix(frame);\r\n }\r\n }\r\n }\r\n }\r\n }\r\n\r\n hints.sendHints(false);\r\n }\r\n\r\n protected override provideToolAssistance(_mainInstrText?: string, _additionalInstr?: ToolAssistanceInstruction[]): void {\r\n let mainMsg;\r\n if (!this.agenda.isEmpty)\r\n mainMsg = EditTools.translate(\"OffsetCurve.Prompts.DefineOffset\");\r\n super.provideToolAssistance(mainMsg);\r\n }\r\n\r\n public async onRestartTool(): Promise<void> {\r\n const tool = new OffsetCurveTool();\r\n if (!await tool.run())\r\n return this.exitTool();\r\n }\r\n}\r\n\r\n/** @alpha Tool for opening loops and splitting paths. */\r\nexport class BreakCurveTool extends ModifyCurveTool {\r\n public static override toolId = \"BreakCurve\";\r\n public static override iconSpec = \"icon-scale\"; // Need better icon...\r\n\r\n protected resultA?: CurveCollection | CurvePrimitive;\r\n protected resultB?: CurveCollection | CurvePrimitive;\r\n protected modifyOriginal = true;\r\n\r\n protected override get wantDynamics(): boolean { return false; }\r\n protected override get wantModifyOriginal(): boolean { return this.modifyOriginal; }\r\n\r\n protected override acceptCurve(curve: CurveCollection | CurvePrimitive): boolean {\r\n if (\"curvePrimitive\" === curve.geometryCategory)\r\n return true;\r\n\r\n return (curve.isOpenPath || curve.isClosedPath);\r\n }\r\n\r\n protected doBreakCurve(ev: BeButtonEvent): void {\r\n this.resultA = this.resultB = undefined;\r\n\r\n if (undefined === ev.viewport)\r\n return;\r\n\r\n const geom = this.curveData?.geom;\r\n if (undefined === geom)\r\n return;\r\n\r\n const closeDetail = (geom instanceof CurvePrimitive) ? geom.closestPoint(ev.point, false) : geom.closestPoint(ev.point);\r\n if (undefined === closeDetail?.curve)\r\n return;\r\n\r\n const selectedStart = (closeDetail.fraction <= Geometry.smallFraction);\r\n const selectedEnd = (closeDetail.fraction >= (1.0 - Geometry.smallFraction));\r\n\r\n if (geom instanceof CurvePrimitive) {\r\n if (selectedStart || selectedEnd)\r\n return; // split is no-op...\r\n\r\n this.resultA = geom.clonePartialCurve(0.0, closeDetail.fraction);\r\n this.resultB = geom.clonePartialCurve(closeDetail.fraction, 1.0);\r\n return;\r\n } else if (geom instanceof Path) {\r\n const firstCurve = geom.children[0];\r\n const lastCurve = geom.children[geom.children.length - 1];\r\n\r\n if ((closeDetail.curve === firstCurve && selectedStart) || (closeDetail.curve === lastCurve && selectedEnd))\r\n return; // split is no-op...\r\n\r\n let beforeCurve = true;\r\n const resultA = Path.create();\r\n const resultB = Path.create();\r\n\r\n for (const curve of geom.children) {\r\n if (curve === closeDetail.curve) {\r\n if (selectedStart) {\r\n resultB.children.push(curve.clone());\r\n } else if (selectedEnd) {\r\n resultA.children.push(curve.clone());\r\n } else {\r\n const curveA = curve.clonePartialCurve(0.0, closeDetail.fraction);\r\n if (undefined !== curveA)\r\n resultA.children.push(curveA);\r\n\r\n const curveB = curve.clonePartialCurve(closeDetail.fraction, 1.0);\r\n if (undefined !== curveB)\r\n resultB.children.push(curveB);\r\n }\r\n beforeCurve = false;\r\n } else {\r\n if (beforeCurve)\r\n resultA.children.push(curve.clone());\r\n else\r\n resultB.children.push(curve.clone());\r\n }\r\n }\r\n\r\n this.resultA = resultA;\r\n this.resultB = resultB;\r\n } else if (geom instanceof Loop) {\r\n const closeIndex = geom.children.findIndex((child) => child === closeDetail.curve);\r\n if (-1 === closeIndex)\r\n return;\r\n\r\n const endIndex = closeIndex + geom.children.length;\r\n const resultA = Path.create(); // Result is always a single path...\r\n\r\n if (selectedStart) {\r\n resultA.children.push(closeDetail.curve.clone());\r\n } else if (!selectedEnd) {\r\n const curveB = closeDetail.curve.clonePartialCurve(closeDetail.fraction, 1.0);\r\n if (undefined !== curveB)\r\n resultA.children.push(curveB);\r\n }\r\n\r\n for (let index = closeIndex; index < endIndex; ++index) {\r\n const curve = geom.cyclicCurvePrimitive(index);\r\n if (undefined === curve || curve === closeDetail.curve)\r\n continue;\r\n\r\n resultA.children.push(curve.clone());\r\n }\r\n\r\n if (selectedEnd) {\r\n resultA.children.push(closeDetail.curve.clone());\r\n } else if (!selectedStart) {\r\n const curveA = closeDetail.curve.clonePartialCurve(0.0, closeDetail.fraction);\r\n if (undefined !== curveA)\r\n resultA.children.push(curveA);\r\n }\r\n\r\n this.resultA = resultA;\r\n }\r\n }\r\n\r\n protected override modifyCurve(_ev: BeButtonEvent, _isAccept: boolean): GeometryQuery | undefined {\r\n return (this.wantModifyOriginal ? this.resultA : this.resultB);\r\n }\r\n\r\n public override async processAgenda(ev: BeButtonEvent): Promise<void> {\r\n this.doBreakCurve(ev);\r\n if (undefined === this.resultA || !await this.applyAgendaOperation(ev))\r\n return;\r\n\r\n if (undefined !== this.resultB) {\r\n this.modifyOriginal = false;\r\n await this.applyAgendaOperation(ev);\r\n }\r\n\r\n return this.saveChanges();\r\n }\r\n\r\n protected override provideToolAssistance(_mainInstrText?: string, _additionalInstr?: ToolAssistanceInstruction[]): void {\r\n let mainMsg;\r\n if (this.agenda.isEmpty)\r\n mainMsg = EditTools.translate(\"BreakCurve.Prompts.IdentifyBreak\");\r\n super.provideToolAssistance(mainMsg);\r\n }\r\n\r\n public async onRestartTool(): Promise<void> {\r\n const tool = new BreakCurveTool();\r\n if (!await tool.run())\r\n return this.exitTool();\r\n }\r\n}\r\n\r\n/** @alpha Tool to extend or trim a path or open curve */\r\nexport class ExtendCurveTool extends ModifyCurveTool {\r\n public static override toolId = \"ExtendCurve\";\r\n public static override iconSpec = \"icon-scale\"; // Need better icon...\r\n\r\n protected modifyingEnd?: CurvePrimitive;\r\n\r\n protected override get wantAgendaAppearanceOverride(): boolean { return true; }\r\n\r\n protected override acceptCurve(curve: CurveCollection | CurvePrimitive): boolean {\r\n if (\"curvePrimitive\" === curve.geometryCategory)\r\n return curve.isExtensibleFractionSpace;\r\n\r\n return curve.isOpenPath;\r\n }\r\n\r\n protected extendCurve(geom: CurvePrimitive, pickPoint: Point3d, spacePoint: Point3d): CurvePrimitive | undefined {\r\n const pickDetail = geom.closestPoint(pickPoint, false);\r\n if (undefined === pickDetail?.curve)\r\n return undefined;\r\n\r\n const closeDetail = geom.closestPoint(spacePoint, true);\r\n if (undefined === closeDetail?.curve)\r\n return undefined;\r\n\r\n if (closeDetail.curve instanceof Arc3d) {\r\n if (pickDetail.fraction > 0.5 && closeDetail.fraction < 0.0) {\r\n const smallArc = closeDetail.curve.clonePartialCurve(closeDetail.fraction, 0.0);\r\n smallArc.sweep.cloneComplement(false, smallArc.sweep);\r\n return smallArc;\r\n } else if (pickDetail.fraction <= 0.5 && closeDetail.fraction > 1.0) {\r\n const smallArc = closeDetail.curve.clonePartialCurve(1.0, closeDetail.fraction);\r\n smallArc.sweep.cloneComplement(false, smallArc.sweep);\r\n return smallArc;\r\n } else if (Math.abs(pickDetail.fraction > 0.5 ? closeDetail.fraction : 1.0 - closeDetail.fraction) < Geometry.smallFraction) {\r\n const fullArc = closeDetail.curve.clone();\r\n fullArc.sweep = AngleSweep.create360();\r\n return fullArc;\r\n }\r\n }\r\n\r\n return geom.clonePartialCurve(pickDetail.fraction > 0.5 ? 0.0 : 1.0, closeDetail.fraction);\r\n }\r\n\r\n protected extendPathEnd(geom: Path, closeDetail: CurveLocationDetail, isStart: boolean): Path | undefined {\r\n if (undefined === closeDetail.curve)\r\n return undefined;\r\n\r\n const curve = closeDetail.curve.clonePartialCurve(isStart ? closeDetail.fraction : 0.0, isStart ? 1.0 : closeDetail.fraction);\r\n if (undefined === curve)\r\n return undefined;\r\n\r\n if (curve instanceof Arc3d && closeDetail.curve instanceof Arc3d && (curve.sweep.isCCW !== closeDetail.curve.sweep.isCCW))\r\n curve.sweep.cloneComplement(true, curve.sweep); // Preserve current sweep direction...\r\n\r\n const result = geom.clone() as Path;\r\n result.children[isStart ? 0 : geom.children.length - 1] = curve;\r\n\r\n return result;\r\n }\r\n\r\n protected extendPath(geom: Path, pickPoint: Point3d, spacePoint: Point3d): Path | CurvePrimitive | undefined {\r\n if (geom.children.length < 2)\r\n return this.extendCurve(geom.children[0], pickPoint, spacePoint);\r\n\r\n const pathAsPrimitive = CurveChainWithDistanceIndex.createCapture(geom);\r\n const closeDetail = pathAsPrimitive.closestPoint(spacePoint, true);\r\n if (undefined === closeDetail?.curve || undefined === closeDetail.childDetail?.curve)\r\n return undefined;\r\n\r\n if (undefined !== this.modifyingEnd) {\r\n if (closeDetail.childDetail.curve === this.modifyingEnd) {\r\n this.modifyingEnd = undefined; // Ok to unlock extending first/last curve in path...\r\n } else {\r\n const pathEndDetail = this.modifyingEnd.closestPoint(spacePoint, true);\r\n if (undefined === pathEndDetail?.curve)\r\n return undefined;\r\n return this.extendPathEnd(geom, pathEndDetail, (pathEndDetail.curve === geom.children[0]));\r\n }\r\n }\r\n\r\n // NOTE: Special case extend instead of using CurveChainWithDistanceIndex.clonePartialCurve...\r\n if (closeDetail.fraction < 0.0) {\r\n this.modifyingEnd = closeDetail.childDetail.curve;\r\n return this.extendPathEnd(geom, closeDetail.childDetail, true);\r\n } else if (closeDetail.fraction > 1.0) {\r\n this.modifyingEnd = closeDetail.childDetail.curve;\r\n return this.extendPathEnd(geom, closeDetail.childDetail, false);\r\n }\r\n\r\n const pickDetail = pathAsPrimitive.closestPoint(pickPoint, false);\r\n if (undefined === pickDetail?.curve)\r\n return undefined;\r\n\r\n const result = pathAsPrimitive.clonePartialCurve(pickDetail.fraction > 0.5 ? 0.0 : 1.0, closeDetail.fraction);\r\n if (undefined === result)\r\n return undefined;\r\n\r\n return Path.create(...result.path.children);\r\n }\r\n\r\n protected override modifyCurve(ev: BeButtonEvent, _isAccept: boolean): GeometryQuery | undefined {\r\n if (undefined === ev.viewport || undefined === this.anchorPoint)\r\n return undefined;\r\n\r\n const geom = this.curveData?.geom;\r\n if (undefined === geom)\r\n return undefined;\r\n\r\n const matrix = AccuDrawHintBuilder.getCurrentRotation(ev.viewport, true, true);\r\n const localToWorld = FrameBuilder.createRightHandedFrame(matrix?.getColumn(2), geom);\r\n if (undefined === localToWorld)\r\n return undefined;\r\n\r\n const worldToLocal = localToWorld.inverse();\r\n if (undefined === worldToLocal)\r\n return undefined;\r\n\r\n const spacePoint = AccuDrawHintBuilder.projectPointToPlaneInView(ev.point, localToWorld.getOrigin(), localToWorld.matrix.getColumn(2), ev.viewport);\r\n if (undefined === spacePoint)\r\n return undefined;\r\n\r\n if (geom instanceof CurvePrimitive)\r\n return this.extendCurve(geom, this.anchorPoint, spacePoint);\r\n else if (geom instanceof Path)\r\n return this.extendPath(geom, this.anchorPoint, spacePoint);\r\n\r\n return undefined;\r\n }\r\n\r\n protected override async onAgendaModified(): Promise<void> {\r\n IModelApp.accuSnap.neverFlash(this.agenda.elements); // Don't flash snapped segment for better preview when trimming curve/path...\r\n return super.onAgendaModified();\r\n }\r\n\r\n protected override setupAccuDraw(): void {\r\n const hints = new AccuDrawHintBuilder();\r\n\r\n if (this.agenda.isEmpty) {\r\n hints.enableSmartRotation = true;\r\n } else {\r\n const geom = this.curveData?.geom;\r\n if (undefined === geom || undefined === this.anchorPoint)\r\n return;\r\n\r\n let pickDetail;\r\n if (geom instanceof CurvePrimitive)\r\n pickDetail = geom.closestPoint(this.anchorPoint, false);\r\n else if (geom instanceof Path)\r\n pickDetail = CurveChainWithDistanceIndex.createCapture(geom).closestPoint(this.anchorPoint, false);\r\n if (undefined === pickDetail?.curve)\r\n return;\r\n\r\n const curve = (undefined !== pickDetail.childDetail?.curve ? pickDetail.childDetail?.curve : pickDetail.curve);\r\n\r\n if (curve instanceof Arc3d) {\r\n const matrix = curve.matrixClone();\r\n matrix.normalizeColumnsInPlace();\r\n hints.setOrigin(curve.center);\r\n hints.setMatrix(matrix);\r\n hints.setModePolar();\r\n } else if (curve instanceof LineSegment3d) {\r\n hints.setOrigin(pickDetail.fraction > 0.5 ? curve.point0Ref : curve.point1Ref);\r\n hints.setXAxis(Vector3d.createStartEnd(pickDetail.fraction > 0.5 ? curve.point0Ref : curve.point1Ref, pickDetail.fraction > 0.5 ? curve.point1Ref : curve.point0Ref));\r\n hints.setModeRectangular();\r\n } else if (curve instanceof LineString3d) {\r\n if (curve.numPoints() > 1) {\r\n hints.setOrigin(curve.packedPoints.getPoint3dAtUncheckedPointIndex(pickDetail.fraction > 0.5 ? curve.numPoints() - 2 : 1));\r\n hints.setXAxis(Vector3d.createStartEnd(curve.packedPoints.getPoint3dAtUncheckedPointIndex(pickDetail.fraction > 0.5 ? curve.numPoints() - 2 : 1), curve.packedPoints.getPoint3dAtUncheckedPointIndex(pickDetail.fraction > 0.5 ? curve.numPoints() - 1 : 0)));\r\n }\r\n hints.setModeRectangular();\r\n } else {\r\n const ray = curve.fractionToPointAndUnitTangent(pickDetail.fraction > 0.5 ? 0.0 : 1.0);\r\n hints.setOrigin(ray.origin);\r\n hints.setXAxis(ray.direction);\r\n hints.setModeRectangular();\r\n }\r\n }\r\n hints.sendHints(false);\r\n }\r\n\r\n protected override provideToolAssistance(_mainInstrText?: string, _additionalInstr?: ToolAssistanceInstruction[]): void {\r\n let mainMsg;\r\n if (this.agenda.isEmpty)\r\n mainMsg = EditTools.translate(\"ExtendCurve.Prompts.IdentifyEnd\");\r\n super.provideToolAssistance(mainMsg);\r\n }\r\n\r\n public async onRestartTool(): Promise<void> {\r\n const tool = new ExtendCurveTool();\r\n if (!await tool.run())\r\n return this.exitTool();\r\n }\r\n}\r\n\r\n/** @alpha */\r\nexport enum RegionBooleanMode {\r\n /** Create region from union of all input regions */\r\n Unite = 0,\r\n /** Create region from subtraction from the first input region */\r\n Subtract = 1,\r\n /** Create region from intersection of all input regions */\r\n Intersect = 2,\r\n}\r\n\r\n/** @alpha Tool to unite, subtract, or intersect planar regions. */\r\nexport class RegionBooleanTool extends ModifyCurveTool {\r\n public static override toolId = \"RegionBoolean\";\r\n public static override iconSpec = \"icon-scale\"; // Need better icon...\r\n\r\n private _makeCopyProperty: DialogProperty<boolean> | undefined;\r\n public get makeCopyProperty() {\r\n if (!this._makeCopyProperty)\r\n this._makeCopyProperty = new DialogProperty<boolean>(\r\n PropertyDescriptionHelper.buildToggleDescription(\"regionBooleanKeep\", EditTools.translate(\"RegionBoolean.Label.KeepOriginal\")), false);\r\n return this._makeCopyProperty;\r\n }\r\n\r\n public get makeCopy(): boolean { return this.makeCopyProperty.value; }\r\n public set makeCopy(value: boolean) { this.makeCopyProperty.value = value; }\r\n\r\n private static modeMessage(str: string) { return EditTools.translate(`RegionBoolean.Mode.${str}`); }\r\n private static getModeChoices = (): EnumerationChoice[] => {\r\n return [\r\n { label: RegionBooleanTool.modeMessage(\"Unite\"), value: RegionBooleanMode.Unite },\r\n { label: RegionBooleanTool.modeMessage(\"Subtract\"), value: RegionBooleanMode.Subtract },\r\n { label: RegionBooleanTool.modeMessage(\"Intersect\"), value: RegionBooleanMode.Intersect },\r\n ];\r\n };\r\n\r\n private _modeProperty: DialogProperty<number> | undefined;\r\n public get modeProperty() {\r\n if (!this._modeProperty)\r\n this._modeProperty = new DialogProperty<number>(PropertyDescriptionHelper.buildEnumPicklistEditorDescription(\r\n \"regionBooleanMode\", EditTools.translate(\"RegionBoolean.Label.Mode\"), RegionBooleanTool.getModeChoices()), RegionBooleanMode.Unite as number);\r\n return this._modeProperty;\r\n }\r\n\r\n public get mode(): RegionBooleanMode { return this.modeProperty.value as RegionBooleanMode; }\r\n public set mode(mode: RegionBooleanMode) { this.modeProperty.value = mode; }\r\n\r\n protected override get clearSelectionSet(): boolean { return false; } // Don't clear for subtract so that mode can be changed...\r\n protected override get allowSelectionSet(): boolean { return RegionBooleanMode.Subtract !== this.mode; }\r\n protected override get allowDragSelect(): boolean { return RegionBooleanMode.Subtract !== this.mode; }\r\n protected override get controlKeyContinuesSelection(): boolean { return true; }\r\n protected override get requiredElementCount(): number { return 2; }\r\n\r\n protected override get wantAccuSnap(): boolean { return false; }\r\n protected override get wantDynamics(): boolean { return false; }\r\n protected override get wantModifyOriginal(): boolean { return !this.makeCopy; }\r\n\r\n protected override async onAgendaModified(): Promise<void> { } // No intermediate result preview, defer to processAgenda...\r\n\r\n protected override acceptCurve(curve: CurveCollection | CurvePrimitive): boolean {\r\n if (\"curvePrimitive\" === curve.geometryCategory)\r\n return false;\r\n\r\n return curve.isAnyRegionType;\r\n }\r\n\r\n private regionBinaryOp(): RegionBinaryOpType {\r\n switch (this.mode) {\r\n case RegionBooleanMode.Subtract:\r\n return RegionBinaryOpType.AMinusB;\r\n case RegionBooleanMode.Intersect:\r\n return RegionBinaryOpType.Intersection;\r\n default:\r\n return RegionBinaryOpType.Union;\r\n }\r\n }\r\n\r\n private regionFromSignedLoops(loops: SignedLoops): AnyRegion | undefined {\r\n switch (loops.negativeAreaLoops.length) {\r\n case 0:\r\n return undefined;\r\n case 1:\r\n return loops.negativeAreaLoops[0];\r\n default:\r\n return RegionOps.sortOuterAndHoleLoopsXY(loops.negativeAreaLoops);\r\n }\r\n }\r\n\r\n private regionBooleanXY(tools: AnyRegion[], op: RegionBinaryOpType): AnyRegion | undefined {\r\n if (tools.length < 2)\r\n return undefined;\r\n\r\n const loopsA = (RegionBinaryOpType.Union !== op ? tools[0] : tools);\r\n const loopsB = (RegionBinaryOpType.Union !== op ? tools.slice(1) : undefined);\r\n\r\n // TODO: Need to be able to specify group operation for loopsB to correctly support intersect w/o doing 2 at time...\r\n const areas = RegionOps.regionBooleanXY(loopsA, loopsB, op);\r\n if (undefined === areas)\r\n return undefined;\r\n\r\n // TODO: Holes are expected to be returned as negative area loops but currently are not...\r\n const loops = RegionOps.constructAllXYRegionLoops(areas);\r\n\r\n if (1 === loops.length)\r\n return this.regionFromSignedLoops(loops[0]);\r\n\r\n if (loops.length > 1) {\r\n const unionRegion = UnionRegion.create();\r\n\r\n for (const loop of loops) {\r\n const child = this.regionFromSignedLoops(loop);\r\n if (undefined === child)\r\n continue;\r\n\r\n unionRegion.tryAddChild(child);\r\n }\r\n\r\n if (unionRegion.children.length > 1)\r\n return unionRegion;\r\n }\r\n\r\n return undefined;\r\n }\r\n\r\n protected async doRegionBoolean(_ev: BeButtonEvent): Promise<void> {\r\n this.curveData = undefined;\r\n\r\n if (this.agenda.length < this.requiredElementCount)\r\n return;\r\n\r\n const targetData = await this.getCurveData(this.agenda.elements[0]);\r\n if (undefined === targetData?.geom)\r\n return;\r\n\r\n const targetLocalToWorld = FrameBuilder.createRightHandedFrame(undefined, targetData.geom);\r\n if (undefined === targetLocalToWorld)\r\n return;\r\n\r\n const targetWorldToLocal = targetLocalToWorld.inverse();\r\n if (undefined === targetWorldToLocal)\r\n return;\r\n\r\n const targetPlane = Plane3dByOriginAndUnitNormal.create(targetLocalToWorld.getOrigin(), targetLocalToWorld.matrix.getColumn(2));\r\n if (undefined === targetPlane)\r\n return;\r\n\r\n if (!targetData.geom.tryTransformInPlace(targetWorldToLocal))\r\n return;\r\n\r\n const tools: AnyRegion[] = [targetData.geom as AnyRegion];\r\n\r\n for (const id of this.agenda.elements) {\r\n if (id === targetData.props.id)\r\n continue;\r\n\r\n const curveData = await this.getCurveData(id);\r\n if (undefined === curveData?.geom)\r\n return;\r\n\r\n if (!ModifyCurveTool.isInPlane(curveData.geom, targetPlane)) {\r\n IModelApp.notifications.outputMessage(new NotifyMessageDetails(OutputMessagePriority.Info, EditTools.translate(\"RegionBoolean.Error.NonCoplanar\")));\r\n return;\r\n }\r\n\r\n if (!curveData.geom.tryTransformInPlace(targetWorldToLocal))\r\n return;\r\n\r\n tools.push(curveData.geom as AnyRegion);\r\n }\r\n\r\n const result = this.regionBooleanXY(tools, this.regionBinaryOp());\r\n if (undefined === result || !result.tryTransformInPlace(targetLocalToWorld))\r\n return;\r\n\r\n this.curveData = targetData;\r\n this.curveData.geom = result;\r\n }\r\n\r\n protected override modifyCurve(_ev: BeButtonEvent, _isAccept: boolean): GeometryQuery | undefined {\r\n return this.curveData?.geom;\r\n }\r\n\r\n protected override async applyAgendaOperation(ev: BeButtonEvent): Promise<boolean> {\r\n if (!await super.applyAgendaOperation(ev))\r\n return false;\r\n\r\n if (this.wantModifyOriginal && this.agenda.length > 1)\r\n await basicManipulationIpc.deleteElements(CompressedId64Set.sortAndCompress(this.agenda.elements.slice(1)));\r\n\r\n return true;\r\n }\r\n\r\n public override async processAgenda(ev: BeButtonEvent): Promise<void> {\r\n await this.doRegionBoolean(ev);\r\n return super.processAgenda(ev);\r\n }\r\n\r\n public async onRestartTool(): Promise<void> {\r\n const tool = new RegionBooleanTool();\r\n if (!await tool.run())\r\n return this.exitTool();\r\n }\r\n\r\n public override async applyToolSettingPropertyChange(updatedValue: DialogPropertySyncItem): Promise<boolean> {\r\n if (!this.changeToolSettingPropertyValue(updatedValue))\r\n return false;\r\n\r\n if (this.modeProperty.name === updatedValue.propertyName)\r\n await this.onReinitialize();\r\n\r\n return true;\r\n }\r\n\r\n public override supplyToolSettingsProperties(): DialogItem[] | undefined {\r\n this.initializeToolSettingPropertyValues([this.makeCopyProperty, this.modeProperty]);\r\n\r\n const toolSettings = new Array<DialogItem>();\r\n\r\n toolSettings.push(this.modeProperty.toDialogItem({ rowPriority: 1, columnIndex: 0 }));\r\n toolSettings.push(this.makeCopyProperty.toDialogItem({ rowPriority: 2, columnIndex: 0 }));\r\n\r\n return toolSettings;\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"ModifyCurveTools.js","sourceRoot":"","sources":["../../src/ModifyCurveTools.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n* See LICENSE.md in the project root for license terms and full copyright notice.\n*--------------------------------------------------------------------------------------------*/\n\nimport { DialogItem, DialogProperty, DialogPropertySyncItem, EnumerationChoice, PropertyDescriptionHelper } from \"@itwin/appui-abstract\";\nimport { CompressedId64Set, Id64String } from \"@itwin/core-bentley\";\nimport {\n BentleyError, Code, ElementGeometry, ElementGeometryInfo, ElementGeometryOpcode, FlatBufferGeometryStream, GeometricElementProps,\n GeometryParams, JsonGeometryStream,\n} from \"@itwin/core-common\";\nimport {\n AccuDrawHintBuilder, BeButtonEvent, IModelApp,\n LengthDescription, NotifyMessageDetails, OutputMessagePriority, ToolAssistanceInstruction,\n} from \"@itwin/core-frontend\";\nimport {\n AngleSweep, AnyRegion, Arc3d, AxisOrder, CurveChainWithDistanceIndex, CurveCollection, CurveLocationDetail, CurvePrimitive, FrameBuilder, Geometry, GeometryQuery, JointOptions, LineSegment3d, LineString3d, Loop, Matrix3d,\n Path, Plane3dByOriginAndUnitNormal, Point3d, RegionBinaryOpType, RegionOps, SignedLoops, UnionRegion, Vector3d,\n} from \"@itwin/core-geometry\";\nimport { editorBuiltInCmdIds } from \"@itwin/editor-common\";\nimport { EditTools } from \"./EditTool\";\nimport { basicManipulationIpc } from \"./EditToolIpc\";\nimport { ModifyElementWithDynamicsTool } from \"./ModifyElementTool\";\n\n/** @alpha */\nexport class CurveData {\n public props: GeometricElementProps;\n public params: GeometryParams;\n public geom: CurveCollection | CurvePrimitive;\n\n constructor(props: GeometricElementProps, params: GeometryParams, geom: CurveCollection | CurvePrimitive) {\n this.props = props;\n this.params = params;\n this.geom = geom;\n }\n}\n\n/** @alpha Base class for modifying all types of curve geometry. */\nexport abstract class ModifyCurveTool extends ModifyElementWithDynamicsTool {\n protected _startedCmd?: string;\n protected curveData?: CurveData;\n\n protected async startCommand(): Promise<string> {\n if (undefined !== this._startedCmd)\n return this._startedCmd;\n return EditTools.startCommand<string>({ commandId: editorBuiltInCmdIds.cmdBasicManipulation, iModelKey: this.iModel.key });\n }\n\n public static isSingleCurve(info: ElementGeometryInfo): { curve: CurveCollection | CurvePrimitive, params: GeometryParams } | undefined {\n const it = new ElementGeometry.Iterator(info);\n it.requestWorldCoordinates();\n\n for (const entry of it) {\n const geom = entry.toGeometryQuery();\n if (undefined === geom)\n return;\n\n if (\"curvePrimitive\" === geom.geometryCategory) {\n return { curve: geom as CurvePrimitive, params: entry.geomParams };\n } else if (\"curveCollection\" === geom.geometryCategory) {\n return { curve: geom as CurveCollection, params: entry.geomParams };\n }\n\n break;\n }\n\n return;\n }\n\n public static isInPlane(curve: CurveCollection | CurvePrimitive, plane: Plane3dByOriginAndUnitNormal): boolean {\n if (\"curvePrimitive\" === curve.geometryCategory)\n return curve.isInPlane(plane);\n\n if (!curve.children)\n return false;\n\n for (const child of curve.children) {\n if (child instanceof CurvePrimitive) {\n if (!child.isInPlane(plane))\n return false;\n } else if (child instanceof CurveCollection) {\n if (!this.isInPlane(child, plane))\n return false;\n }\n }\n\n return true;\n }\n\n protected acceptCurve(_curve: CurveCollection | CurvePrimitive): boolean { return true; }\n protected modifyCurve(_ev: BeButtonEvent, _isAccept: boolean): GeometryQuery | undefined { return undefined; }\n\n protected async getCurveData(id: Id64String): Promise<CurveData | undefined> {\n try {\n this._startedCmd = await this.startCommand();\n const reject: ElementGeometryOpcode[] = [ElementGeometryOpcode.Polyface, ElementGeometryOpcode.SolidPrimitive, ElementGeometryOpcode.BsplineSurface, ElementGeometryOpcode.BRep];\n const info = await basicManipulationIpc.requestElementGeometry(id, { maxDisplayable: 1, reject, geometry: { curves: true, surfaces: true, solids: false } });\n if (undefined === info)\n return undefined;\n\n const data = ModifyCurveTool.isSingleCurve(info);\n if (undefined === data)\n return undefined;\n\n if (!this.acceptCurve(data.curve))\n return undefined;\n\n const props = await this.iModel.elements.loadProps(id) as GeometricElementProps;\n if (undefined === props)\n return undefined;\n\n return new CurveData(props, data.params, data.curve);\n } catch (err) {\n IModelApp.notifications.outputMessage(new NotifyMessageDetails(OutputMessagePriority.Error, BentleyError.getErrorMessage(err)));\n return undefined;\n }\n }\n\n protected override async doAcceptElementForOperation(id: Id64String): Promise<boolean> {\n return (undefined !== await this.getCurveData(id));\n }\n\n protected override async onAgendaModified(): Promise<void> {\n this.curveData = undefined;\n if (this.agenda.isEmpty)\n return;\n\n const id = this.agenda.elements[this.agenda.length - 1];\n this.curveData = await this.getCurveData(id);\n }\n\n protected override setupAccuDraw(): void {\n const hints = new AccuDrawHintBuilder();\n\n hints.enableSmartRotation = true;\n hints.sendHints(false);\n }\n\n protected getGeometryProps(ev: BeButtonEvent, isAccept: boolean): JsonGeometryStream | FlatBufferGeometryStream | undefined {\n if (undefined === this.curveData)\n return;\n\n const geom = this.modifyCurve(ev, isAccept);\n if (undefined === geom)\n return;\n\n const builder = new ElementGeometry.Builder();\n builder.setLocalToWorldFromPlacement(this.curveData.props.placement!);\n\n if (!builder.appendGeometryParamsChange(this.curveData.params))\n return;\n\n if (!builder.appendGeometryQuery(geom))\n return;\n\n return { format: \"flatbuffer\", data: builder.entries };\n }\n\n protected getElementProps(ev: BeButtonEvent): GeometricElementProps | undefined {\n if (undefined === this.curveData)\n return;\n\n if (!this.wantModifyOriginal) {\n // Create result as new element with same model and category as original...\n const classFullName = (ev.viewport?.view.is3d() ? \"Generic:PhysicalObject\" : \"BisCore:DrawingGraphic\");\n return { classFullName, model: this.curveData.props.model, category: this.curveData.props.category, code: Code.createEmpty(), placement: this.curveData.props.placement };\n }\n\n return this.curveData.props;\n }\n\n protected override async doUpdateElement(elemProps: GeometricElementProps): Promise<boolean> {\n try {\n this._startedCmd = await this.startCommand();\n if (undefined === elemProps.id) {\n const repeatOperation = this.wantContinueWithPreviousResult;\n if (repeatOperation)\n this.agenda.clear();\n\n const newId = await basicManipulationIpc.insertGeometricElement(elemProps);\n\n if (repeatOperation && this.agenda.add(newId))\n await this.onAgendaModified();\n } else {\n await basicManipulationIpc.updateGeometricElement(elemProps);\n }\n return true;\n } catch (err) {\n IModelApp.notifications.outputMessage(new NotifyMessageDetails(OutputMessagePriority.Error, BentleyError.getErrorMessage(err) || \"An unknown error occurred.\"));\n return false;\n }\n }\n\n protected get wantModifyOriginal(): boolean { return true; }\n protected get wantContinueWithPreviousResult(): boolean { return false; }\n\n public override async onProcessComplete(): Promise<void> {\n // Don't restart tool want to continue operation using previous result...\n if (this.wantContinueWithPreviousResult && !this.agenda.isEmpty && undefined !== this.curveData)\n return;\n return super.onProcessComplete();\n }\n}\n\n/** @alpha Tool for applying an offset to paths and loops. */\nexport class OffsetCurveTool extends ModifyCurveTool {\n public static override toolId = \"OffsetCurve\";\n public static override iconSpec = \"icon-scale\"; // Need better icon...\n\n private _useDistanceProperty: DialogProperty<boolean> | undefined;\n public get useDistanceProperty() {\n if (!this._useDistanceProperty)\n this._useDistanceProperty = new DialogProperty<boolean>(PropertyDescriptionHelper.buildLockPropertyDescription(\"useOffsetDistance\"), false);\n return this._useDistanceProperty;\n }\n\n public get useDistance(): boolean { return this.useDistanceProperty.value; }\n public set useDistance(value: boolean) { this.useDistanceProperty.value = value; }\n\n private _distanceProperty: DialogProperty<number> | undefined;\n public get distanceProperty() {\n if (!this._distanceProperty)\n this._distanceProperty = new DialogProperty<number>(new LengthDescription(\"offsetDistance\", EditTools.translate(\"OffsetCurve.Label.Distance\")), 0.1, undefined, !this.useDistance);\n return this._distanceProperty;\n }\n\n public get distance(): number { return this.distanceProperty.value; }\n public set distance(value: number) { this.distanceProperty.value = value; }\n\n private _makeCopyProperty: DialogProperty<boolean> | undefined;\n public get makeCopyProperty() {\n if (!this._makeCopyProperty)\n this._makeCopyProperty = new DialogProperty<boolean>(\n PropertyDescriptionHelper.buildToggleDescription(\"offsetCopy\", EditTools.translate(\"OffsetCurve.Label.MakeCopy\")), false);\n return this._makeCopyProperty;\n }\n\n public get makeCopy(): boolean { return this.makeCopyProperty.value; }\n public set makeCopy(value: boolean) { this.makeCopyProperty.value = value; }\n\n protected override getToolSettingPropertyLocked(property: DialogProperty<any>): DialogProperty<any> | undefined {\n return (property === this.useDistanceProperty ? this.distanceProperty : undefined);\n }\n\n public override async applyToolSettingPropertyChange(updatedValue: DialogPropertySyncItem): Promise<boolean> {\n return this.changeToolSettingPropertyValue(updatedValue);\n }\n\n public override supplyToolSettingsProperties(): DialogItem[] | undefined {\n this.initializeToolSettingPropertyValues([this.makeCopyProperty, this.useDistanceProperty, this.distanceProperty]);\n\n const toolSettings = new Array<DialogItem>();\n\n // ensure controls are enabled/disabled based on current lock property state\n this.distanceProperty.isDisabled = !this.useDistance;\n const useDistanceLock = this.useDistanceProperty.toDialogItem({ rowPriority: 1, columnIndex: 0 });\n toolSettings.push(this.distanceProperty.toDialogItem({ rowPriority: 1, columnIndex: 1 }, useDistanceLock));\n toolSettings.push(this.makeCopyProperty.toDialogItem({ rowPriority: 2, columnIndex: 0 }));\n\n return toolSettings;\n }\n\n protected override acceptCurve(curve: CurveCollection | CurvePrimitive): boolean {\n if (\"curvePrimitive\" === curve.geometryCategory)\n return true;\n\n return (curve.isOpenPath || curve.isClosedPath);\n }\n\n protected override modifyCurve(ev: BeButtonEvent, isAccept: boolean): GeometryQuery | undefined {\n if (undefined === ev.viewport)\n return undefined;\n\n const geom = this.curveData?.geom;\n if (undefined === geom)\n return undefined;\n\n const matrix = AccuDrawHintBuilder.getCurrentRotation(ev.viewport, true, true);\n const localToWorld = FrameBuilder.createRightHandedFrame(matrix?.getColumn(2), geom);\n if (undefined === localToWorld)\n return undefined;\n\n const worldToLocal = localToWorld.inverse();\n if (undefined === worldToLocal)\n return undefined;\n\n const geomXY = ((geom instanceof CurvePrimitive) ? Path.create(geom) : geom).cloneTransformed(worldToLocal);\n if (undefined === geomXY)\n return undefined;\n\n const spacePoint = AccuDrawHintBuilder.projectPointToPlaneInView(ev.point, localToWorld.getOrigin(), localToWorld.matrix.getColumn(2), ev.viewport);\n if (undefined === spacePoint)\n return undefined;\n\n worldToLocal.multiplyPoint3d(spacePoint, spacePoint);\n spacePoint.z = 0.0;\n\n const closeDetail = geomXY.closestPoint(spacePoint);\n if (undefined === closeDetail?.curve)\n return undefined;\n\n const unitZ = Vector3d.unitZ();\n const unitX = closeDetail.curve.fractionToPointAndUnitTangent(closeDetail.fraction).direction;\n const unitY = unitZ.unitCrossProduct(unitX);\n\n if (undefined === unitY)\n return undefined;\n\n let distance = closeDetail.point.distance(spacePoint);\n const refDir = Vector3d.createStartEnd(closeDetail.point, spacePoint);\n\n if (refDir.dotProduct(unitY) < 0.0)\n distance = -distance;\n\n let offset = 0.0;\n\n if (this.useDistance) {\n offset = this.distance;\n if ((offset < 0.0 && distance > 0.0) || (offset > 0.0 && distance < 0.0))\n offset = -offset;\n } else {\n offset = distance;\n }\n\n if (Math.abs(offset) < Geometry.smallMetricDistance)\n return undefined;\n\n if (offset !== this.distance) {\n this.distance = offset;\n this.syncToolSettingPropertyValue(this.distanceProperty);\n if (isAccept)\n this.saveToolSettingPropertyValue(this.distanceProperty, this.distanceProperty.dialogItemValue);\n }\n\n const jointOptions = new JointOptions(offset);\n jointOptions.preserveEllipticalArcs = true;\n\n const offsetGeom = RegionOps.constructCurveXYOffset(geomXY as Path | Loop, jointOptions);\n if (undefined === offsetGeom)\n return undefined;\n\n if (!offsetGeom.tryTransformInPlace(localToWorld))\n return undefined;\n\n if (geom instanceof CurvePrimitive && offsetGeom instanceof Path && 1 === offsetGeom.children.length)\n return offsetGeom.getChild(0); // Don't create path for offset of single open curve...\n\n return offsetGeom;\n }\n\n protected override get wantModifyOriginal(): boolean {\n return !this.makeCopy;\n }\n\n protected override get wantContinueWithPreviousResult(): boolean {\n return !this.wantModifyOriginal;\n }\n\n protected override setupAccuDraw(): void {\n const hints = new AccuDrawHintBuilder();\n\n if (this.agenda.isEmpty) {\n hints.enableSmartRotation = true;\n } else if (undefined !== this.anchorPoint && undefined !== this.targetView) {\n const geom = this.curveData?.geom;\n const closeDetail = (geom instanceof CurvePrimitive) ? geom.closestPoint(this.anchorPoint, false) : geom?.closestPoint(this.anchorPoint);\n\n if (undefined !== closeDetail?.curve) {\n const unitX = closeDetail.curve.fractionToPointAndUnitTangent(closeDetail.fraction).direction;\n\n if (undefined !== unitX) {\n const matrix = AccuDrawHintBuilder.getCurrentRotation(this.targetView, true, true);\n const localToWorld = FrameBuilder.createRightHandedFrame(matrix?.getColumn(2), geom);\n\n if (undefined !== localToWorld) {\n const unitZ = localToWorld.matrix.getColumn(2);\n const frame = Matrix3d.createRigidFromColumns(unitX, unitZ, AxisOrder.XZY);\n\n if (undefined !== frame) {\n hints.setOrigin(closeDetail.point);\n hints.setMatrix(frame);\n }\n }\n }\n }\n }\n\n hints.sendHints(false);\n }\n\n protected override provideToolAssistance(_mainInstrText?: string, _additionalInstr?: ToolAssistanceInstruction[]): void {\n let mainMsg;\n if (!this.agenda.isEmpty)\n mainMsg = EditTools.translate(\"OffsetCurve.Prompts.DefineOffset\");\n super.provideToolAssistance(mainMsg);\n }\n\n public async onRestartTool(): Promise<void> {\n const tool = new OffsetCurveTool();\n if (!await tool.run())\n return this.exitTool();\n }\n}\n\n/** @alpha Tool for opening loops and splitting paths. */\nexport class BreakCurveTool extends ModifyCurveTool {\n public static override toolId = \"BreakCurve\";\n public static override iconSpec = \"icon-scale\"; // Need better icon...\n\n protected resultA?: CurveCollection | CurvePrimitive;\n protected resultB?: CurveCollection | CurvePrimitive;\n protected modifyOriginal = true;\n\n protected override get wantDynamics(): boolean { return false; }\n protected override get wantModifyOriginal(): boolean { return this.modifyOriginal; }\n\n protected override acceptCurve(curve: CurveCollection | CurvePrimitive): boolean {\n if (\"curvePrimitive\" === curve.geometryCategory)\n return true;\n\n return (curve.isOpenPath || curve.isClosedPath);\n }\n\n protected doBreakCurve(ev: BeButtonEvent): void {\n this.resultA = this.resultB = undefined;\n\n if (undefined === ev.viewport)\n return;\n\n const geom = this.curveData?.geom;\n if (undefined === geom)\n return;\n\n const closeDetail = (geom instanceof CurvePrimitive) ? geom.closestPoint(ev.point, false) : geom.closestPoint(ev.point);\n if (undefined === closeDetail?.curve)\n return;\n\n const selectedStart = (closeDetail.fraction <= Geometry.smallFraction);\n const selectedEnd = (closeDetail.fraction >= (1.0 - Geometry.smallFraction));\n\n if (geom instanceof CurvePrimitive) {\n if (selectedStart || selectedEnd)\n return; // split is no-op...\n\n this.resultA = geom.clonePartialCurve(0.0, closeDetail.fraction);\n this.resultB = geom.clonePartialCurve(closeDetail.fraction, 1.0);\n return;\n } else if (geom instanceof Path) {\n const firstCurve = geom.children[0];\n const lastCurve = geom.children[geom.children.length - 1];\n\n if ((closeDetail.curve === firstCurve && selectedStart) || (closeDetail.curve === lastCurve && selectedEnd))\n return; // split is no-op...\n\n let beforeCurve = true;\n const resultA = Path.create();\n const resultB = Path.create();\n\n for (const curve of geom.children) {\n if (curve === closeDetail.curve) {\n if (selectedStart) {\n resultB.children.push(curve.clone());\n } else if (selectedEnd) {\n resultA.children.push(curve.clone());\n } else {\n const curveA = curve.clonePartialCurve(0.0, closeDetail.fraction);\n if (undefined !== curveA)\n resultA.children.push(curveA);\n\n const curveB = curve.clonePartialCurve(closeDetail.fraction, 1.0);\n if (undefined !== curveB)\n resultB.children.push(curveB);\n }\n beforeCurve = false;\n } else {\n if (beforeCurve)\n resultA.children.push(curve.clone());\n else\n resultB.children.push(curve.clone());\n }\n }\n\n this.resultA = resultA;\n this.resultB = resultB;\n } else if (geom instanceof Loop) {\n const closeIndex = geom.children.findIndex((child) => child === closeDetail.curve);\n if (-1 === closeIndex)\n return;\n\n const endIndex = closeIndex + geom.children.length;\n const resultA = Path.create(); // Result is always a single path...\n\n if (selectedStart) {\n resultA.children.push(closeDetail.curve.clone());\n } else if (!selectedEnd) {\n const curveB = closeDetail.curve.clonePartialCurve(closeDetail.fraction, 1.0);\n if (undefined !== curveB)\n resultA.children.push(curveB);\n }\n\n for (let index = closeIndex; index < endIndex; ++index) {\n const curve = geom.cyclicCurvePrimitive(index);\n if (undefined === curve || curve === closeDetail.curve)\n continue;\n\n resultA.children.push(curve.clone());\n }\n\n if (selectedEnd) {\n resultA.children.push(closeDetail.curve.clone());\n } else if (!selectedStart) {\n const curveA = closeDetail.curve.clonePartialCurve(0.0, closeDetail.fraction);\n if (undefined !== curveA)\n resultA.children.push(curveA);\n }\n\n this.resultA = resultA;\n }\n }\n\n protected override modifyCurve(_ev: BeButtonEvent, _isAccept: boolean): GeometryQuery | undefined {\n return (this.wantModifyOriginal ? this.resultA : this.resultB);\n }\n\n public override async processAgenda(ev: BeButtonEvent): Promise<void> {\n this.doBreakCurve(ev);\n if (undefined === this.resultA || !await this.applyAgendaOperation(ev))\n return;\n\n if (undefined !== this.resultB) {\n this.modifyOriginal = false;\n await this.applyAgendaOperation(ev);\n }\n\n return this.saveChanges();\n }\n\n protected override provideToolAssistance(_mainInstrText?: string, _additionalInstr?: ToolAssistanceInstruction[]): void {\n let mainMsg;\n if (this.agenda.isEmpty)\n mainMsg = EditTools.translate(\"BreakCurve.Prompts.IdentifyBreak\");\n super.provideToolAssistance(mainMsg);\n }\n\n public async onRestartTool(): Promise<void> {\n const tool = new BreakCurveTool();\n if (!await tool.run())\n return this.exitTool();\n }\n}\n\n/** @alpha Tool to extend or trim a path or open curve */\nexport class ExtendCurveTool extends ModifyCurveTool {\n public static override toolId = \"ExtendCurve\";\n public static override iconSpec = \"icon-scale\"; // Need better icon...\n\n protected modifyingEnd?: CurvePrimitive;\n\n protected override get wantAgendaAppearanceOverride(): boolean { return true; }\n\n protected override acceptCurve(curve: CurveCollection | CurvePrimitive): boolean {\n if (\"curvePrimitive\" === curve.geometryCategory)\n return curve.isExtensibleFractionSpace;\n\n return curve.isOpenPath;\n }\n\n protected extendCurve(geom: CurvePrimitive, pickPoint: Point3d, spacePoint: Point3d): CurvePrimitive | undefined {\n const pickDetail = geom.closestPoint(pickPoint, false);\n if (undefined === pickDetail?.curve)\n return undefined;\n\n const closeDetail = geom.closestPoint(spacePoint, true);\n if (undefined === closeDetail?.curve)\n return undefined;\n\n if (closeDetail.curve instanceof Arc3d) {\n if (pickDetail.fraction > 0.5 && closeDetail.fraction < 0.0) {\n const smallArc = closeDetail.curve.clonePartialCurve(closeDetail.fraction, 0.0);\n smallArc.sweep.cloneComplement(false, smallArc.sweep);\n return smallArc;\n } else if (pickDetail.fraction <= 0.5 && closeDetail.fraction > 1.0) {\n const smallArc = closeDetail.curve.clonePartialCurve(1.0, closeDetail.fraction);\n smallArc.sweep.cloneComplement(false, smallArc.sweep);\n return smallArc;\n } else if (Math.abs(pickDetail.fraction > 0.5 ? closeDetail.fraction : 1.0 - closeDetail.fraction) < Geometry.smallFraction) {\n const fullArc = closeDetail.curve.clone();\n fullArc.sweep = AngleSweep.create360();\n return fullArc;\n }\n }\n\n return geom.clonePartialCurve(pickDetail.fraction > 0.5 ? 0.0 : 1.0, closeDetail.fraction);\n }\n\n protected extendPathEnd(geom: Path, closeDetail: CurveLocationDetail, isStart: boolean): Path | undefined {\n if (undefined === closeDetail.curve)\n return undefined;\n\n const curve = closeDetail.curve.clonePartialCurve(isStart ? closeDetail.fraction : 0.0, isStart ? 1.0 : closeDetail.fraction);\n if (undefined === curve)\n return undefined;\n\n if (curve instanceof Arc3d && closeDetail.curve instanceof Arc3d && (curve.sweep.isCCW !== closeDetail.curve.sweep.isCCW))\n curve.sweep.cloneComplement(true, curve.sweep); // Preserve current sweep direction...\n\n const result = geom.clone() as Path;\n result.children[isStart ? 0 : geom.children.length - 1] = curve;\n\n return result;\n }\n\n protected extendPath(geom: Path, pickPoint: Point3d, spacePoint: Point3d): Path | CurvePrimitive | undefined {\n if (geom.children.length < 2)\n return this.extendCurve(geom.children[0], pickPoint, spacePoint);\n\n const pathAsPrimitive = CurveChainWithDistanceIndex.createCapture(geom);\n const closeDetail = pathAsPrimitive.closestPoint(spacePoint, true);\n if (undefined === closeDetail?.curve || undefined === closeDetail.childDetail?.curve)\n return undefined;\n\n if (undefined !== this.modifyingEnd) {\n if (closeDetail.childDetail.curve === this.modifyingEnd) {\n this.modifyingEnd = undefined; // Ok to unlock extending first/last curve in path...\n } else {\n const pathEndDetail = this.modifyingEnd.closestPoint(spacePoint, true);\n if (undefined === pathEndDetail?.curve)\n return undefined;\n return this.extendPathEnd(geom, pathEndDetail, (pathEndDetail.curve === geom.children[0]));\n }\n }\n\n // NOTE: Special case extend instead of using CurveChainWithDistanceIndex.clonePartialCurve...\n if (closeDetail.fraction < 0.0) {\n this.modifyingEnd = closeDetail.childDetail.curve;\n return this.extendPathEnd(geom, closeDetail.childDetail, true);\n } else if (closeDetail.fraction > 1.0) {\n this.modifyingEnd = closeDetail.childDetail.curve;\n return this.extendPathEnd(geom, closeDetail.childDetail, false);\n }\n\n const pickDetail = pathAsPrimitive.closestPoint(pickPoint, false);\n if (undefined === pickDetail?.curve)\n return undefined;\n\n const result = pathAsPrimitive.clonePartialCurve(pickDetail.fraction > 0.5 ? 0.0 : 1.0, closeDetail.fraction);\n if (undefined === result)\n return undefined;\n\n return Path.create(...result.path.children);\n }\n\n protected override modifyCurve(ev: BeButtonEvent, _isAccept: boolean): GeometryQuery | undefined {\n if (undefined === ev.viewport || undefined === this.anchorPoint)\n return undefined;\n\n const geom = this.curveData?.geom;\n if (undefined === geom)\n return undefined;\n\n const matrix = AccuDrawHintBuilder.getCurrentRotation(ev.viewport, true, true);\n const localToWorld = FrameBuilder.createRightHandedFrame(matrix?.getColumn(2), geom);\n if (undefined === localToWorld)\n return undefined;\n\n const worldToLocal = localToWorld.inverse();\n if (undefined === worldToLocal)\n return undefined;\n\n const spacePoint = AccuDrawHintBuilder.projectPointToPlaneInView(ev.point, localToWorld.getOrigin(), localToWorld.matrix.getColumn(2), ev.viewport);\n if (undefined === spacePoint)\n return undefined;\n\n if (geom instanceof CurvePrimitive)\n return this.extendCurve(geom, this.anchorPoint, spacePoint);\n else if (geom instanceof Path)\n return this.extendPath(geom, this.anchorPoint, spacePoint);\n\n return undefined;\n }\n\n protected override async onAgendaModified(): Promise<void> {\n IModelApp.accuSnap.neverFlash(this.agenda.elements); // Don't flash snapped segment for better preview when trimming curve/path...\n return super.onAgendaModified();\n }\n\n protected override setupAccuDraw(): void {\n const hints = new AccuDrawHintBuilder();\n\n if (this.agenda.isEmpty) {\n hints.enableSmartRotation = true;\n } else {\n const geom = this.curveData?.geom;\n if (undefined === geom || undefined === this.anchorPoint)\n return;\n\n let pickDetail;\n if (geom instanceof CurvePrimitive)\n pickDetail = geom.closestPoint(this.anchorPoint, false);\n else if (geom instanceof Path)\n pickDetail = CurveChainWithDistanceIndex.createCapture(geom).closestPoint(this.anchorPoint, false);\n if (undefined === pickDetail?.curve)\n return;\n\n const curve = (undefined !== pickDetail.childDetail?.curve ? pickDetail.childDetail?.curve : pickDetail.curve);\n\n if (curve instanceof Arc3d) {\n const matrix = curve.matrixClone();\n matrix.normalizeColumnsInPlace();\n hints.setOrigin(curve.center);\n hints.setMatrix(matrix);\n hints.setModePolar();\n } else if (curve instanceof LineSegment3d) {\n hints.setOrigin(pickDetail.fraction > 0.5 ? curve.point0Ref : curve.point1Ref);\n hints.setXAxis(Vector3d.createStartEnd(pickDetail.fraction > 0.5 ? curve.point0Ref : curve.point1Ref, pickDetail.fraction > 0.5 ? curve.point1Ref : curve.point0Ref));\n hints.setModeRectangular();\n } else if (curve instanceof LineString3d) {\n if (curve.numPoints() > 1) {\n hints.setOrigin(curve.packedPoints.getPoint3dAtUncheckedPointIndex(pickDetail.fraction > 0.5 ? curve.numPoints() - 2 : 1));\n hints.setXAxis(Vector3d.createStartEnd(curve.packedPoints.getPoint3dAtUncheckedPointIndex(pickDetail.fraction > 0.5 ? curve.numPoints() - 2 : 1), curve.packedPoints.getPoint3dAtUncheckedPointIndex(pickDetail.fraction > 0.5 ? curve.numPoints() - 1 : 0)));\n }\n hints.setModeRectangular();\n } else {\n const ray = curve.fractionToPointAndUnitTangent(pickDetail.fraction > 0.5 ? 0.0 : 1.0);\n hints.setOrigin(ray.origin);\n hints.setXAxis(ray.direction);\n hints.setModeRectangular();\n }\n }\n hints.sendHints(false);\n }\n\n protected override provideToolAssistance(_mainInstrText?: string, _additionalInstr?: ToolAssistanceInstruction[]): void {\n let mainMsg;\n if (this.agenda.isEmpty)\n mainMsg = EditTools.translate(\"ExtendCurve.Prompts.IdentifyEnd\");\n super.provideToolAssistance(mainMsg);\n }\n\n public async onRestartTool(): Promise<void> {\n const tool = new ExtendCurveTool();\n if (!await tool.run())\n return this.exitTool();\n }\n}\n\n/** @alpha */\nexport enum RegionBooleanMode {\n /** Create region from union of all input regions */\n Unite = 0,\n /** Create region from subtraction from the first input region */\n Subtract = 1,\n /** Create region from intersection of all input regions */\n Intersect = 2,\n}\n\n/** @alpha Tool to unite, subtract, or intersect planar regions. */\nexport class RegionBooleanTool extends ModifyCurveTool {\n public static override toolId = \"RegionBoolean\";\n public static override iconSpec = \"icon-scale\"; // Need better icon...\n\n private _makeCopyProperty: DialogProperty<boolean> | undefined;\n public get makeCopyProperty() {\n if (!this._makeCopyProperty)\n this._makeCopyProperty = new DialogProperty<boolean>(\n PropertyDescriptionHelper.buildToggleDescription(\"regionBooleanKeep\", EditTools.translate(\"RegionBoolean.Label.KeepOriginal\")), false);\n return this._makeCopyProperty;\n }\n\n public get makeCopy(): boolean { return this.makeCopyProperty.value; }\n public set makeCopy(value: boolean) { this.makeCopyProperty.value = value; }\n\n private static modeMessage(str: string) { return EditTools.translate(`RegionBoolean.Mode.${str}`); }\n private static getModeChoices = (): EnumerationChoice[] => {\n return [\n { label: RegionBooleanTool.modeMessage(\"Unite\"), value: RegionBooleanMode.Unite },\n { label: RegionBooleanTool.modeMessage(\"Subtract\"), value: RegionBooleanMode.Subtract },\n { label: RegionBooleanTool.modeMessage(\"Intersect\"), value: RegionBooleanMode.Intersect },\n ];\n };\n\n private _modeProperty: DialogProperty<number> | undefined;\n public get modeProperty() {\n if (!this._modeProperty)\n this._modeProperty = new DialogProperty<number>(PropertyDescriptionHelper.buildEnumPicklistEditorDescription(\n \"regionBooleanMode\", EditTools.translate(\"RegionBoolean.Label.Mode\"), RegionBooleanTool.getModeChoices()), RegionBooleanMode.Unite as number);\n return this._modeProperty;\n }\n\n public get mode(): RegionBooleanMode { return this.modeProperty.value as RegionBooleanMode; }\n public set mode(mode: RegionBooleanMode) { this.modeProperty.value = mode; }\n\n protected override get clearSelectionSet(): boolean { return false; } // Don't clear for subtract so that mode can be changed...\n protected override get allowSelectionSet(): boolean { return RegionBooleanMode.Subtract !== this.mode; }\n protected override get allowDragSelect(): boolean { return RegionBooleanMode.Subtract !== this.mode; }\n protected override get controlKeyContinuesSelection(): boolean { return true; }\n protected override get requiredElementCount(): number { return 2; }\n\n protected override get wantAccuSnap(): boolean { return false; }\n protected override get wantDynamics(): boolean { return false; }\n protected override get wantModifyOriginal(): boolean { return !this.makeCopy; }\n\n protected override async onAgendaModified(): Promise<void> { } // No intermediate result preview, defer to processAgenda...\n\n protected override acceptCurve(curve: CurveCollection | CurvePrimitive): boolean {\n if (\"curvePrimitive\" === curve.geometryCategory)\n return false;\n\n return curve.isAnyRegionType;\n }\n\n private regionBinaryOp(): RegionBinaryOpType {\n switch (this.mode) {\n case RegionBooleanMode.Subtract:\n return RegionBinaryOpType.AMinusB;\n case RegionBooleanMode.Intersect:\n return RegionBinaryOpType.Intersection;\n default:\n return RegionBinaryOpType.Union;\n }\n }\n\n private regionFromSignedLoops(loops: SignedLoops): AnyRegion | undefined {\n switch (loops.negativeAreaLoops.length) {\n case 0:\n return undefined;\n case 1:\n return loops.negativeAreaLoops[0];\n default:\n return RegionOps.sortOuterAndHoleLoopsXY(loops.negativeAreaLoops);\n }\n }\n\n private regionBooleanXY(tools: AnyRegion[], op: RegionBinaryOpType): AnyRegion | undefined {\n if (tools.length < 2)\n return undefined;\n\n const loopsA = (RegionBinaryOpType.Union !== op ? tools[0] : tools);\n const loopsB = (RegionBinaryOpType.Union !== op ? tools.slice(1) : undefined);\n\n // TODO: Need to be able to specify group operation for loopsB to correctly support intersect w/o doing 2 at time...\n const areas = RegionOps.regionBooleanXY(loopsA, loopsB, op);\n if (undefined === areas)\n return undefined;\n\n // TODO: Holes are expected to be returned as negative area loops but currently are not...\n const loops = RegionOps.constructAllXYRegionLoops(areas);\n\n if (1 === loops.length)\n return this.regionFromSignedLoops(loops[0]);\n\n if (loops.length > 1) {\n const unionRegion = UnionRegion.create();\n\n for (const loop of loops) {\n const child = this.regionFromSignedLoops(loop);\n if (undefined === child)\n continue;\n\n unionRegion.tryAddChild(child);\n }\n\n if (unionRegion.children.length > 1)\n return unionRegion;\n }\n\n return undefined;\n }\n\n protected async doRegionBoolean(_ev: BeButtonEvent): Promise<void> {\n this.curveData = undefined;\n\n if (this.agenda.length < this.requiredElementCount)\n return;\n\n const targetData = await this.getCurveData(this.agenda.elements[0]);\n if (undefined === targetData?.geom)\n return;\n\n const targetLocalToWorld = FrameBuilder.createRightHandedFrame(undefined, targetData.geom);\n if (undefined === targetLocalToWorld)\n return;\n\n const targetWorldToLocal = targetLocalToWorld.inverse();\n if (undefined === targetWorldToLocal)\n return;\n\n const targetPlane = Plane3dByOriginAndUnitNormal.create(targetLocalToWorld.getOrigin(), targetLocalToWorld.matrix.getColumn(2));\n if (undefined === targetPlane)\n return;\n\n if (!targetData.geom.tryTransformInPlace(targetWorldToLocal))\n return;\n\n const tools: AnyRegion[] = [targetData.geom as AnyRegion];\n\n for (const id of this.agenda.elements) {\n if (id === targetData.props.id)\n continue;\n\n const curveData = await this.getCurveData(id);\n if (undefined === curveData?.geom)\n return;\n\n if (!ModifyCurveTool.isInPlane(curveData.geom, targetPlane)) {\n IModelApp.notifications.outputMessage(new NotifyMessageDetails(OutputMessagePriority.Info, EditTools.translate(\"RegionBoolean.Error.NonCoplanar\")));\n return;\n }\n\n if (!curveData.geom.tryTransformInPlace(targetWorldToLocal))\n return;\n\n tools.push(curveData.geom as AnyRegion);\n }\n\n const result = this.regionBooleanXY(tools, this.regionBinaryOp());\n if (undefined === result || !result.tryTransformInPlace(targetLocalToWorld))\n return;\n\n this.curveData = targetData;\n this.curveData.geom = result;\n }\n\n protected override modifyCurve(_ev: BeButtonEvent, _isAccept: boolean): GeometryQuery | undefined {\n return this.curveData?.geom;\n }\n\n protected override async applyAgendaOperation(ev: BeButtonEvent): Promise<boolean> {\n if (!await super.applyAgendaOperation(ev))\n return false;\n\n if (this.wantModifyOriginal && this.agenda.length > 1)\n await basicManipulationIpc.deleteElements(CompressedId64Set.sortAndCompress(this.agenda.elements.slice(1)));\n\n return true;\n }\n\n public override async processAgenda(ev: BeButtonEvent): Promise<void> {\n await this.doRegionBoolean(ev);\n return super.processAgenda(ev);\n }\n\n public async onRestartTool(): Promise<void> {\n const tool = new RegionBooleanTool();\n if (!await tool.run())\n return this.exitTool();\n }\n\n public override async applyToolSettingPropertyChange(updatedValue: DialogPropertySyncItem): Promise<boolean> {\n if (!this.changeToolSettingPropertyValue(updatedValue))\n return false;\n\n if (this.modeProperty.name === updatedValue.propertyName)\n await this.onReinitialize();\n\n return true;\n }\n\n public override supplyToolSettingsProperties(): DialogItem[] | undefined {\n this.initializeToolSettingPropertyValues([this.makeCopyProperty, this.modeProperty]);\n\n const toolSettings = new Array<DialogItem>();\n\n toolSettings.push(this.modeProperty.toDialogItem({ rowPriority: 1, columnIndex: 0 }));\n toolSettings.push(this.makeCopyProperty.toDialogItem({ rowPriority: 2, columnIndex: 0 }));\n\n return toolSettings;\n }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"ModifyElementTool.js","sourceRoot":"","sources":["../../src/ModifyElementTool.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n\r\n/** @packageDocumentation\r\n * @module Editing\r\n */\r\n\r\nimport { Id64, Id64Arg, Id64Array, Id64String } from \"@itwin/core-bentley\";\r\nimport { FeatureAppearance, FlatBufferGeometryStream, GeometricElementProps, JsonGeometryStream } from \"@itwin/core-common\";\r\nimport { BeButtonEvent, DynamicsContext, ElementSetTool, FeatureOverrideProvider, FeatureSymbology, HitDetail, IModelApp, LocateResponse, SelectionMethod, SelectionSet, Viewport } from \"@itwin/core-frontend\";\r\nimport { Point3d } from \"@itwin/core-geometry\";\r\nimport { computeChordToleranceFromPoint, DynamicGraphicsProvider } from \"./CreateElementTool\";\r\n\r\n/** Edit tool base class for updating existing elements.\r\n * @beta\r\n */\r\nexport abstract class ModifyElementTool extends ElementSetTool {\r\n protected readonly _checkedIds = new Map<Id64String, boolean>();\r\n\r\n protected allowView(_vp: Viewport) { return true; }\r\n public override isCompatibleViewport(vp: Viewport | undefined, isSelectedViewChange: boolean): boolean { return (super.isCompatibleViewport(vp, isSelectedViewChange) && undefined !== vp && this.allowView(vp)); }\r\n\r\n protected onGeometryFilterChanged(): void { this._checkedIds.clear(); }\r\n\r\n protected async doAcceptElementForOperation(_id: Id64String): Promise<boolean> { return false; }\r\n\r\n protected async acceptElementForOperation(id: Id64String): Promise<boolean> {\r\n if (Id64.isInvalid(id) || Id64.isTransient(id))\r\n return false;\r\n\r\n let accept = this._checkedIds.get(id);\r\n\r\n if (undefined === accept) {\r\n if (this.agenda.isEmpty && this._checkedIds.size > 1000)\r\n this._checkedIds.clear(); // Limit auto-locate cache size to something reasonable...\r\n\r\n accept = await this.doAcceptElementForOperation(id);\r\n this._checkedIds.set(id, accept);\r\n }\r\n\r\n return accept;\r\n }\r\n\r\n protected override async isElementValidForOperation(hit: HitDetail, out?: LocateResponse): Promise<boolean> {\r\n if (!await super.isElementValidForOperation(hit, out))\r\n return false;\r\n\r\n return this.acceptElementForOperation(hit.sourceId);\r\n }\r\n\r\n protected async postFilterIds(arg: Id64Arg): Promise<Id64Arg> {\r\n const ids: Id64Array = [];\r\n\r\n for (const id of Id64.iterable(arg)) {\r\n if (await this.acceptElementForOperation(id))\r\n ids.push(id);\r\n }\r\n\r\n return ids;\r\n }\r\n\r\n protected override async getGroupIds(id: Id64String): Promise<Id64Arg> {\r\n return this.postFilterIds(await super.getGroupIds(id));\r\n }\r\n\r\n protected override async getSelectionSetCandidates(ss: SelectionSet): Promise<Id64Arg> {\r\n return this.postFilterIds(await super.getSelectionSetCandidates(ss));\r\n }\r\n\r\n protected override async getDragSelectCandidates(vp: Viewport, origin: Point3d, corner: Point3d, method: SelectionMethod, overlap: boolean): Promise<Id64Arg> {\r\n return this.postFilterIds(await super.getDragSelectCandidates(vp, origin, corner, method, overlap));\r\n }\r\n\r\n protected setupAccuDraw(): void { }\r\n\r\n protected override setupAndPromptForNextAction(): void {\r\n this.setupAccuDraw();\r\n super.setupAndPromptForNextAction();\r\n }\r\n\r\n protected abstract getGeometryProps(ev: BeButtonEvent, isAccept: boolean): JsonGeometryStream | FlatBufferGeometryStream | undefined;\r\n protected abstract getElementProps(ev: BeButtonEvent): GeometricElementProps | undefined;\r\n\r\n protected async doUpdateElement(_props: GeometricElementProps): Promise<boolean> { return false; }\r\n\r\n protected async applyAgendaOperation(ev: BeButtonEvent): Promise<boolean> {\r\n const geometry = this.getGeometryProps(ev, true);\r\n if (undefined === geometry)\r\n return false;\r\n\r\n const elemProps = this.getElementProps(ev);\r\n if (undefined === elemProps)\r\n return false;\r\n\r\n if (\"flatbuffer\" === geometry.format)\r\n elemProps.elementGeometryBuilderParams = { entryArray: geometry.data };\r\n else\r\n elemProps.geom = geometry.data;\r\n\r\n return this.doUpdateElement(elemProps);\r\n }\r\n\r\n public override async processAgenda(ev: BeButtonEvent): Promise<void> {\r\n if (await this.applyAgendaOperation(ev))\r\n return this.saveChanges();\r\n }\r\n}\r\n\r\n/** Edit tool base class for updating existing elements that use dynamics to show intermediate results.\r\n * @beta\r\n */\r\nexport abstract class ModifyElementWithDynamicsTool extends ModifyElementTool implements FeatureOverrideProvider {\r\n protected _graphicsProvider?: DynamicGraphicsProvider;\r\n protected _firstResult = true;\r\n protected _agendaAppearanceDefault?: FeatureAppearance;\r\n protected _agendaAppearanceDynamic?: FeatureAppearance;\r\n\r\n protected override get wantAccuSnap(): boolean { return true; }\r\n protected override get wantDynamics(): boolean { return true; }\r\n\r\n protected agendaAppearance(isDynamics: boolean): FeatureAppearance {\r\n if (isDynamics) {\r\n if (undefined === this._agendaAppearanceDynamic)\r\n this._agendaAppearanceDynamic = FeatureAppearance.fromTransparency(0.0);\r\n\r\n return this._agendaAppearanceDynamic;\r\n }\r\n\r\n if (undefined === this._agendaAppearanceDefault)\r\n this._agendaAppearanceDefault = FeatureAppearance.fromTransparency(0.9);\r\n\r\n return this._agendaAppearanceDefault;\r\n }\r\n\r\n protected get wantAgendaAppearanceOverride(): boolean { return false; }\r\n\r\n public addFeatureOverrides(overrides: FeatureSymbology.Overrides, _vp: Viewport): void {\r\n if (this.agenda.isEmpty)\r\n return;\r\n\r\n const appearance = this.agendaAppearance(false);\r\n this.agenda.elements.forEach((elementId) => overrides.override({ elementId, appearance }));\r\n }\r\n\r\n protected updateAgendaAppearanceProvider(drop?: true): void {\r\n if (!this.wantAgendaAppearanceOverride)\r\n return;\r\n\r\n for (const vp of IModelApp.viewManager) {\r\n if (!this.allowView(vp))\r\n continue;\r\n\r\n if (drop || this.agenda.isEmpty)\r\n vp.dropFeatureOverrideProvider(this);\r\n else if (!vp.addFeatureOverrideProvider(this))\r\n vp.setFeatureOverrideProviderChanged();\r\n }\r\n }\r\n\r\n protected clearGraphics(): void {\r\n if (undefined === this._graphicsProvider)\r\n return;\r\n this._graphicsProvider.cleanupGraphic();\r\n this._graphicsProvider = undefined;\r\n }\r\n\r\n protected async createGraphics(ev: BeButtonEvent): Promise<void> {\r\n if (!IModelApp.viewManager.inDynamicsMode)\r\n return; // Don't need to create graphic if dynamics aren't yet active...\r\n\r\n const geometry = this.getGeometryProps(ev, false);\r\n if (undefined === geometry) {\r\n this.clearGraphics();\r\n return;\r\n }\r\n\r\n const elemProps = this.getElementProps(ev);\r\n if (undefined === elemProps?.placement) {\r\n this.clearGraphics();\r\n return;\r\n }\r\n\r\n if (undefined === this._graphicsProvider) {\r\n if (this._firstResult) {\r\n this.updateAgendaAppearanceProvider();\r\n this._firstResult = false;\r\n }\r\n this._graphicsProvider = new DynamicGraphicsProvider(this.iModel, this.toolId);\r\n }\r\n\r\n // Set chord tolerance for non-linear/non-planar geometry...\r\n if (ev.viewport)\r\n this._graphicsProvider.chordTolerance = computeChordToleranceFromPoint(ev.viewport, ev.point);\r\n\r\n await this._graphicsProvider.createGraphic(elemProps.category, elemProps.placement, geometry);\r\n }\r\n\r\n public override onDynamicFrame(_ev: BeButtonEvent, context: DynamicsContext): void {\r\n if (undefined !== this._graphicsProvider)\r\n this._graphicsProvider.addGraphic(context);\r\n }\r\n\r\n public override async onMouseMotion(ev: BeButtonEvent): Promise<void> {\r\n return this.createGraphics(ev);\r\n }\r\n\r\n public override async onUnsuspend(): Promise<void> {\r\n if (!this._firstResult)\r\n this.updateAgendaAppearanceProvider();\r\n return super.onUnsuspend();\r\n }\r\n\r\n public override async onSuspend(): Promise<void> {\r\n if (!this._firstResult)\r\n this.updateAgendaAppearanceProvider(true);\r\n return super.onSuspend();\r\n }\r\n\r\n public override async onPostInstall(): Promise<void> {\r\n await super.onPostInstall();\r\n if (this.wantAgendaAppearanceOverride)\r\n this.agenda.manageHiliteState = false;\r\n }\r\n\r\n public override async onCleanup(): Promise<void> {\r\n this.clearGraphics();\r\n this.updateAgendaAppearanceProvider(true);\r\n return super.onCleanup();\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"ModifyElementTool.js","sourceRoot":"","sources":["../../src/ModifyElementTool.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n* See LICENSE.md in the project root for license terms and full copyright notice.\n*--------------------------------------------------------------------------------------------*/\n\n/** @packageDocumentation\n * @module Editing\n */\n\nimport { Id64, Id64Arg, Id64Array, Id64String } from \"@itwin/core-bentley\";\nimport { FeatureAppearance, FlatBufferGeometryStream, GeometricElementProps, JsonGeometryStream } from \"@itwin/core-common\";\nimport { BeButtonEvent, DynamicsContext, ElementSetTool, FeatureOverrideProvider, FeatureSymbology, HitDetail, IModelApp, LocateResponse, SelectionMethod, SelectionSet, Viewport } from \"@itwin/core-frontend\";\nimport { Point3d } from \"@itwin/core-geometry\";\nimport { computeChordToleranceFromPoint, DynamicGraphicsProvider } from \"./CreateElementTool\";\n\n/** Edit tool base class for updating existing elements.\n * @beta\n */\nexport abstract class ModifyElementTool extends ElementSetTool {\n protected readonly _checkedIds = new Map<Id64String, boolean>();\n\n protected allowView(_vp: Viewport) { return true; }\n public override isCompatibleViewport(vp: Viewport | undefined, isSelectedViewChange: boolean): boolean { return (super.isCompatibleViewport(vp, isSelectedViewChange) && undefined !== vp && this.allowView(vp)); }\n\n protected onGeometryFilterChanged(): void { this._checkedIds.clear(); }\n\n protected async doAcceptElementForOperation(_id: Id64String): Promise<boolean> { return false; }\n\n protected async acceptElementForOperation(id: Id64String): Promise<boolean> {\n if (Id64.isInvalid(id) || Id64.isTransient(id))\n return false;\n\n let accept = this._checkedIds.get(id);\n\n if (undefined === accept) {\n if (this.agenda.isEmpty && this._checkedIds.size > 1000)\n this._checkedIds.clear(); // Limit auto-locate cache size to something reasonable...\n\n accept = await this.doAcceptElementForOperation(id);\n this._checkedIds.set(id, accept);\n }\n\n return accept;\n }\n\n protected override async isElementValidForOperation(hit: HitDetail, out?: LocateResponse): Promise<boolean> {\n if (!await super.isElementValidForOperation(hit, out))\n return false;\n\n return this.acceptElementForOperation(hit.sourceId);\n }\n\n protected async postFilterIds(arg: Id64Arg): Promise<Id64Arg> {\n const ids: Id64Array = [];\n\n for (const id of Id64.iterable(arg)) {\n if (await this.acceptElementForOperation(id))\n ids.push(id);\n }\n\n return ids;\n }\n\n protected override async getGroupIds(id: Id64String): Promise<Id64Arg> {\n return this.postFilterIds(await super.getGroupIds(id));\n }\n\n protected override async getSelectionSetCandidates(ss: SelectionSet): Promise<Id64Arg> {\n return this.postFilterIds(await super.getSelectionSetCandidates(ss));\n }\n\n protected override async getDragSelectCandidates(vp: Viewport, origin: Point3d, corner: Point3d, method: SelectionMethod, overlap: boolean): Promise<Id64Arg> {\n return this.postFilterIds(await super.getDragSelectCandidates(vp, origin, corner, method, overlap));\n }\n\n protected setupAccuDraw(): void { }\n\n protected override setupAndPromptForNextAction(): void {\n this.setupAccuDraw();\n super.setupAndPromptForNextAction();\n }\n\n protected abstract getGeometryProps(ev: BeButtonEvent, isAccept: boolean): JsonGeometryStream | FlatBufferGeometryStream | undefined;\n protected abstract getElementProps(ev: BeButtonEvent): GeometricElementProps | undefined;\n\n protected async doUpdateElement(_props: GeometricElementProps): Promise<boolean> { return false; }\n\n protected async applyAgendaOperation(ev: BeButtonEvent): Promise<boolean> {\n const geometry = this.getGeometryProps(ev, true);\n if (undefined === geometry)\n return false;\n\n const elemProps = this.getElementProps(ev);\n if (undefined === elemProps)\n return false;\n\n if (\"flatbuffer\" === geometry.format)\n elemProps.elementGeometryBuilderParams = { entryArray: geometry.data };\n else\n elemProps.geom = geometry.data;\n\n return this.doUpdateElement(elemProps);\n }\n\n public override async processAgenda(ev: BeButtonEvent): Promise<void> {\n if (await this.applyAgendaOperation(ev))\n return this.saveChanges();\n }\n}\n\n/** Edit tool base class for updating existing elements that use dynamics to show intermediate results.\n * @beta\n */\nexport abstract class ModifyElementWithDynamicsTool extends ModifyElementTool implements FeatureOverrideProvider {\n protected _graphicsProvider?: DynamicGraphicsProvider;\n protected _firstResult = true;\n protected _agendaAppearanceDefault?: FeatureAppearance;\n protected _agendaAppearanceDynamic?: FeatureAppearance;\n\n protected override get wantAccuSnap(): boolean { return true; }\n protected override get wantDynamics(): boolean { return true; }\n\n protected agendaAppearance(isDynamics: boolean): FeatureAppearance {\n if (isDynamics) {\n if (undefined === this._agendaAppearanceDynamic)\n this._agendaAppearanceDynamic = FeatureAppearance.fromTransparency(0.0);\n\n return this._agendaAppearanceDynamic;\n }\n\n if (undefined === this._agendaAppearanceDefault)\n this._agendaAppearanceDefault = FeatureAppearance.fromTransparency(0.9);\n\n return this._agendaAppearanceDefault;\n }\n\n protected get wantAgendaAppearanceOverride(): boolean { return false; }\n\n public addFeatureOverrides(overrides: FeatureSymbology.Overrides, _vp: Viewport): void {\n if (this.agenda.isEmpty)\n return;\n\n const appearance = this.agendaAppearance(false);\n this.agenda.elements.forEach((elementId) => overrides.override({ elementId, appearance }));\n }\n\n protected updateAgendaAppearanceProvider(drop?: true): void {\n if (!this.wantAgendaAppearanceOverride)\n return;\n\n for (const vp of IModelApp.viewManager) {\n if (!this.allowView(vp))\n continue;\n\n if (drop || this.agenda.isEmpty)\n vp.dropFeatureOverrideProvider(this);\n else if (!vp.addFeatureOverrideProvider(this))\n vp.setFeatureOverrideProviderChanged();\n }\n }\n\n protected clearGraphics(): void {\n if (undefined === this._graphicsProvider)\n return;\n this._graphicsProvider.cleanupGraphic();\n this._graphicsProvider = undefined;\n }\n\n protected async createGraphics(ev: BeButtonEvent): Promise<void> {\n if (!IModelApp.viewManager.inDynamicsMode)\n return; // Don't need to create graphic if dynamics aren't yet active...\n\n const geometry = this.getGeometryProps(ev, false);\n if (undefined === geometry) {\n this.clearGraphics();\n return;\n }\n\n const elemProps = this.getElementProps(ev);\n if (undefined === elemProps?.placement) {\n this.clearGraphics();\n return;\n }\n\n if (undefined === this._graphicsProvider) {\n if (this._firstResult) {\n this.updateAgendaAppearanceProvider();\n this._firstResult = false;\n }\n this._graphicsProvider = new DynamicGraphicsProvider(this.iModel, this.toolId);\n }\n\n // Set chord tolerance for non-linear/non-planar geometry...\n if (ev.viewport)\n this._graphicsProvider.chordTolerance = computeChordToleranceFromPoint(ev.viewport, ev.point);\n\n await this._graphicsProvider.createGraphic(elemProps.category, elemProps.placement, geometry);\n }\n\n public override onDynamicFrame(_ev: BeButtonEvent, context: DynamicsContext): void {\n if (undefined !== this._graphicsProvider)\n this._graphicsProvider.addGraphic(context);\n }\n\n public override async onMouseMotion(ev: BeButtonEvent): Promise<void> {\n return this.createGraphics(ev);\n }\n\n public override async onUnsuspend(): Promise<void> {\n if (!this._firstResult)\n this.updateAgendaAppearanceProvider();\n return super.onUnsuspend();\n }\n\n public override async onSuspend(): Promise<void> {\n if (!this._firstResult)\n this.updateAgendaAppearanceProvider(true);\n return super.onSuspend();\n }\n\n public override async onPostInstall(): Promise<void> {\n await super.onPostInstall();\n if (this.wantAgendaAppearanceOverride)\n this.agenda.manageHiliteState = false;\n }\n\n public override async onCleanup(): Promise<void> {\n this.clearGraphics();\n this.updateAgendaAppearanceProvider(true);\n return super.onCleanup();\n }\n}\n"]}